:root{
  --brand-accent: #4a86ff;
  --page-bg-1: #121a24;
  --page-bg-2: #05070a;
  --panel-bg: #0b0f14;
  --panel-border: rgba(255,255,255,0.12);
  --divider: rgba(255,255,255,0.16);

  --text-main: #f6f8ff;
  --text-soft: #dfe6f7;
  --text-muted: rgba(255,255,255,0.62);

  --heading-color: #f9f6ea;
  --heading-accent: #ffd36a;
  --subheading-color: #f2e7c6;

  --link-color: #8fb5ff;
  --link-hover: #ffffff;

  --card-bg: var(--panel-bg);
  --card-border: var(--panel-border);
  --text-primary: var(--text-main);
  --text-accent: var(--heading-accent);
}
html, body {
  height: 100%;
}
body {
  background: radial-gradient(1200px 600px at 20% 0%, var(--page-bg-1), var(--page-bg-2)) fixed;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 0;
  color: var(--text-main);
}
.site-content {
  flex: 1 0 auto;
  width: 100%;
}
footer {
  margin-top: auto;
  position: relative;
  z-index: 1;
}
.navbar {
  position: relative;
  z-index: 1030;
}
.navbar .dropdown-menu {
  z-index: 1040;
}
.site-content {
  position: relative;
  z-index: auto;
}
.site-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.site-bg__video,
.site-bg__image,
.site-bg__fallback,
.site-bg__overlay {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.site-bg__video,
.site-bg__image,
.site-bg__fallback {
  object-fit: cover;
  display: block;
}
.site-bg__fallback {
  display: none;
}
.site-bg--video .site-bg__fallback {
  display: none;
}
.site-bg__overlay {
  z-index: 1;
  background: rgba(0, 0, 0, var(--site-bg-overlay-opacity, 0.35));
}
@media (max-width: 767.98px) {
  .site-bg--mobile-static .site-bg__video {
    display: none;
  }
  .site-bg--mobile-static .site-bg__fallback {
    display: block;
  }
}
@media (prefers-reduced-motion: reduce) {
  .site-bg--reduce-motion .site-bg__video {
    display: none;
  }
  .site-bg--reduce-motion .site-bg__fallback {
    display: block;
  }
}
.card.bg-black {
  background-color: var(--panel-bg) !important;
}
.border-secondary {
  border-color: var(--panel-border) !important;
}
.text-secondary {
  color: var(--text-muted) !important;
}
.text-muted {
  color: var(--text-muted) !important;
}
small,
.small {
  color: var(--text-muted);
}
h1, h2, h3, h4, h5,
.h1, .h2, .h3, .h4, .h5,
.card-title,
.card-header,
.section-title,
.section-header,
.category-title,
.category-header {
  color: var(--heading-accent);
  text-shadow: 0 6px 16px rgba(0,0,0,0.45);
}
.subheading,
.section-subtitle {
  color: var(--subheading-color);
}
a {
  color: var(--link-color);
}
a:hover {
  color: var(--link-hover);
}
a.link-light {
  color: var(--link-color);
}
a.link-light:hover {
  color: var(--link-hover);
  text-decoration: underline !important;
}
a[href*="p=character"][href*="name="] {
  color: #cfe0ff !important;
  text-shadow: 0 0 8px rgba(74, 134, 255, 0.42), 0 0 18px rgba(74, 134, 255, 0.18);
  transition: color 0.18s ease, text-shadow 0.18s ease;
}
a[href*="p=character"][href*="name="]:hover {
  color: #ffffff !important;
  text-shadow: 0 0 10px rgba(126, 176, 255, 0.65), 0 0 22px rgba(126, 176, 255, 0.34);
}
.breadcrumb .breadcrumb-item,
.breadcrumb .breadcrumb-item a {
  color: var(--text-muted);
}
hr,
.divider {
  border-color: var(--divider) !important;
}
.btn-primary {
  background-color: var(--brand-accent);
  border-color: var(--brand-accent);
}
.btn-outline-light:hover {
  border-color: var(--brand-accent);
}
.staff-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.16rem 0.48rem;
  border-radius: 999px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.2px;
  line-height: 1.1;
  text-transform: none;
  border: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 0 10px rgba(255, 255, 255, 0.14), inset 0 0 10px rgba(255, 255, 255, 0.04);
}
.staff-badge--gm {
  color: #b9deff;
  background: linear-gradient(180deg, rgba(13, 110, 253, 0.34), rgba(13, 110, 253, 0.2));
  border-color: rgba(13, 110, 253, 0.45);
  box-shadow: 0 0 12px rgba(13, 110, 253, 0.36), inset 0 0 10px rgba(185, 222, 255, 0.1);
}
.staff-badge--mod {
  color: #b8f8df;
  background: linear-gradient(180deg, rgba(25, 135, 84, 0.32), rgba(25, 135, 84, 0.2));
  border-color: rgba(25, 135, 84, 0.42);
  box-shadow: 0 0 12px rgba(25, 135, 84, 0.34), inset 0 0 10px rgba(184, 248, 223, 0.1);
}
.staff-badge--admin {
  color: #ffe7b7;
  background: linear-gradient(180deg, rgba(255, 193, 7, 0.35), rgba(255, 193, 7, 0.2));
  border-color: rgba(255, 193, 7, 0.5);
  box-shadow: 0 0 12px rgba(255, 193, 7, 0.34), inset 0 0 10px rgba(255, 231, 183, 0.1);
}
.staff-badge--staff {
  color: #e7e9ff;
  background: linear-gradient(180deg, rgba(108, 117, 125, 0.32), rgba(108, 117, 125, 0.2));
  border-color: rgba(108, 117, 125, 0.48);
  box-shadow: 0 0 10px rgba(108, 117, 125, 0.32), inset 0 0 10px rgba(231, 233, 255, 0.06);
}
.navbar-online-badge {
  text-decoration: none;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}
.navbar-online-badge:hover {
  color: #fff;
}
.navbar-online-badge.is-online {
  box-shadow: 0 0 12px rgba(25, 135, 84, 0.35);
}
.navbar-online-badge.is-online::after {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: 999px;
  border: 1px solid rgba(25, 135, 84, 0.6);
  animation: navbarPulse 1.8s ease-out infinite;
}
@keyframes navbarPulse {
  0% { opacity: 0.6; transform: scale(1); }
  70% { opacity: 0; transform: scale(1.15); }
  100% { opacity: 0; transform: scale(1.15); }
}
.content h1, .content h2, .content h3, .content h4 {
  margin-top: 1.0rem;
}
.content p, .content li {
  color: var(--text-soft);
}
.content ul {
  margin-bottom: 1rem;
}
.content img, .content video, .content iframe {
  max-width: 100%;
}
.content iframe {
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 0;
}

/* CMS form readability */
.cms-form .form-label {
  color: var(--heading-color);
  font-weight: 600;
  letter-spacing: 0.2px;
}
.cms-form .form-text,
.cms-form .text-secondary {
  color: var(--text-muted) !important;
}
.cms-form .form-text code {
  color: var(--heading-accent);
}

/* Features page pop */
.feature-lead {
  color: var(--text-soft) !important;
}
.feature-card-title {
  color: var(--text-accent);
  letter-spacing: 0.2px;
}
.feature-card-desc {
  color: var(--text-soft) !important;
}

/* Sidebar widgets */
.sidebar-widgets .card,
.sidebar-widgets .card-body {
  color: var(--text-soft) !important;
}
.sidebar-widgets .card-header {
  color: var(--text-accent) !important;
}
.sidebar-widgets .widget-muted {
  color: rgba(255,255,255,0.82) !important;
}
.sidebar-widgets .widget-list {
  padding-left: 1.05rem;
}
.sidebar-widgets .widget-list li {
  margin-bottom: 0.35rem;
  color: rgba(255,255,255,0.92) !important;
}
.sidebar-widgets .highscores-list li {
  list-style-position: outside;
  padding-right: 0.1rem;
}
.sidebar-widgets .highscores-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline;
  column-gap: 0.5rem;
}
.sidebar-widgets .highscores-name {
  display: block;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sidebar-widgets .highscores-level {
  min-width: 3.4rem;
  text-align: right;
  white-space: nowrap;
  margin-left: 0;
}
.sidebar-widgets .widget-meta {
  color: rgba(255,255,255,0.84) !important;
  margin-left: 0.35rem;
  white-space: nowrap;
}
.sidebar-widgets .widget-label {
  color: rgba(255,204,51,0.98) !important;
  font-weight: 600;
}
.sidebar-widgets .widget-killer {
  color: rgba(255,255,255,0.92) !important;
}
.sidebar-widgets .widget-death {
  line-height: 1.25rem;
}
.sidebar-widgets .widget-glow {
  border-color: rgba(198, 124, 255, 0.95) !important;
  box-shadow:
    0 0 0 1px rgba(198, 124, 255, 0.6),
    0 0 18px rgba(198, 124, 255, 0.6),
    0 0 34px rgba(92, 230, 255, 0.45),
    0 0 68px rgba(92, 230, 255, 0.35);
  position: relative;
  overflow: hidden;
}
.sidebar-widgets .widget-glow::before {
  content: "";
  position: absolute;
  inset: -30%;
  background: radial-gradient(circle at 20% 20%, rgba(198,124,255,0.18), transparent 45%),
              radial-gradient(circle at 80% 0%, rgba(92,230,255,0.16), transparent 50%),
              radial-gradient(circle at 40% 80%, rgba(255,118,196,0.14), transparent 55%);
  animation: widgetGlowPulse 6s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}
.sidebar-widgets .widget-glow::after {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: 12px;
  border: 1px solid rgba(198,124,255,0.5);
  box-shadow: 0 0 24px rgba(92,230,255,0.4);
  animation: widgetGlowRing 3s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}
.sidebar-widgets .widget-glow .card-body,
.sidebar-widgets .widget-glow .card-header {
  position: relative;
  z-index: 1;
}
.sidebar-widgets .widget-glow .btn-primary {
  box-shadow: 0 0 16px rgba(198, 124, 255, 0.55);
}
.sidebar-widgets .widget-glow .badge {
  background: rgba(255,255,255,0.08);
  color: #f3ddff;
  border: 1px solid rgba(198,124,255,0.6);
}

/* Class accent tokens */
:root {
  --accent: #4cc9f0;
  --accent2: #7c3aed;
  --border-accent: rgba(76,201,240,0.35);
  --bg-tint: rgba(76,201,240,0.06);
  --glow: 0 0 18px rgba(76,201,240,0.2);
}
body[data-class="paladin"] {
  --accent: #7c3aed;
  --accent2: #22d3ee;
  --border-accent: rgba(124,58,237,0.45);
  --bg-tint: rgba(124,58,237,0.08);
  --glow: 0 0 22px rgba(124,58,237,0.25);
}
body[data-class="druid"] {
  --accent: #22c55e;
  --accent2: #34d399;
  --border-accent: rgba(34,197,94,0.45);
  --bg-tint: rgba(34,197,94,0.08);
  --glow: 0 0 22px rgba(34,197,94,0.22);
}
body[data-class="sorcerer"] {
  --accent: #3b82f6;
  --accent2: #38bdf8;
  --border-accent: rgba(59,130,246,0.45);
  --bg-tint: rgba(59,130,246,0.08);
  --glow: 0 0 22px rgba(59,130,246,0.22);
}
body[data-class="knight"] {
  --accent: #f97316;
  --accent2: #ef4444;
  --border-accent: rgba(249,115,22,0.5);
  --bg-tint: rgba(249,115,22,0.08);
  --glow: 0 0 22px rgba(249,115,22,0.22);
}

/* Character profile accents */
.character-hero,
.character-card,
.character-grid .card {
  border-color: var(--border-accent) !important;
  background: linear-gradient(180deg, var(--bg-tint), transparent);
  box-shadow: var(--glow);
}
.character-hero__icon,
.character-card__title,
.character-name,
.hero-vocation {
  color: var(--accent);
}
.hero-badge,
.character-hero__actions .btn,
.character-card .btn.hero-primary {
  background-color: var(--accent);
  border-color: var(--accent);
  color: #0b0f14;
}
.hero-badge:hover,
.character-hero__actions .btn:hover,
.character-card .btn.hero-primary:hover {
  background-color: var(--accent2);
  border-color: var(--accent2);
  color: #0b0f14;
}
.hero-badge--status {
  box-shadow: var(--glow);
}
.hero-badge--level,
.hero-badge--status {
  border-color: var(--border-accent);
}
.character-card .progress-bar,
.stat-progress .progress-bar {
  background-color: var(--accent);
}
.character-card .stat-label,
.hero-lastseen,
.hero-world,
.hero-town {
  color: var(--accent2);
}
.character-card__title {
  border-bottom: 1px solid var(--border-accent);
  padding-bottom: 0.35rem;
  margin-bottom: 0.75rem;
}
.character-hero__actions .btn {
  border-color: var(--border-accent);
  color: var(--accent);
  box-shadow: var(--glow);
}
.character-hero__actions .btn:hover {
  border-color: var(--accent2);
  color: var(--accent2);
}
.character-grid .card {
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.character-grid .card:hover {
  border-color: var(--accent2) !important;
  box-shadow: var(--glow);
}
@keyframes widgetGlowPulse {
  0%, 100% { transform: scale(1); opacity: 0.8; }
  50% { transform: scale(1.05); opacity: 1; }
}
@keyframes widgetGlowRing {
  0%, 100% { opacity: 0.65; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.03); }
}

/* Client download tooltip */
.cta-wrap {
  position: relative;
  display: inline-block;
  width: 100%;
}
.cta-popover {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  z-index: 9999;
  width: 100%;
  max-width: 260px;
  padding: 0.6rem 0.75rem;
  border-radius: 12px;
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  color: rgba(255, 255, 255, 0.9);
  box-shadow: 0 18px 35px rgba(0, 0, 0, 0.45);
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.cta-wrap:hover .cta-popover,
.cta-wrap:focus-within .cta-popover {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* Calendar widget */
.calendar-widget .calendar-weekdays,
.calendar-widget .calendar-grid {
  grid-template-columns: repeat(7, 1fr);
  gap: 0.25rem;
}
.calendar-widget .calendar-grid .calendar-day {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.03);
  border-radius: 0.4rem;
  color: rgba(255,255,255,0.92);
  font-size: 0.85rem;
  line-height: 1;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 0.35rem 0.35rem 0.35rem 0.35rem;
}
.calendar-widget .calendar-grid .calendar-day.is-outside {
  opacity: 0.35;
}
.calendar-widget .calendar-grid .calendar-day.is-today {
  border-color: color-mix(in srgb, var(--brand-accent) 70%, #ffffff 30%);
  box-shadow: 0 0 0 0.15rem rgba(74, 134, 255, 0.12);
}
.calendar-widget .calendar-grid .calendar-day.has-event {
  background: rgba(255,255,255,0.06);
}
.calendar-widget .calendar-grid .calendar-day .calendar-num {
  font-weight: 700;
}
.calendar-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,204,51,0.95);
  flex: 0 0 auto;
  margin-top: 0.2rem;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.35);
}
.calendar-widget .calendar-grid .calendar-day .calendar-dots {
  position: absolute;
  bottom: 0.25rem;
  left: 0.25rem;
  display: flex;
  gap: 0.2rem;
}
.calendar-widget .calendar-grid .calendar-day .calendar-dots .calendar-dot {
  width: 7px;
  height: 7px;
  margin-top: 0;
}

.gallery-thumb {
  cursor: zoom-in;
}
.world-card {
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
}
.world-banner {
  overflow: hidden;
  border-radius: 0.5rem;
  border: 1px solid var(--panel-border);
}
.world-banner__img {
  width: 100%;
  height: clamp(220px, 34vw, 420px);
  object-fit: cover;
  display: block;
}
.world-thumb {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  transition: transform 0.25s ease;
}
.world-thumb-frame {
  width: 100%;
  aspect-ratio: 16 / 10;
  background:
    radial-gradient(circle at 20% 20%, rgba(74, 134, 255, 0.14), transparent 55%),
    rgba(8, 12, 18, 0.9);
  display: grid;
  place-items: center;
  padding: 0.35rem;
}
.world-card a:hover .world-thumb {
  transform: scale(1.03);
}

.progress-slim {
  height: 0.55rem;
  background-color: rgba(255,255,255,0.10);
}
.progress-slim .progress-bar {
  transition: width .25s ease;
}

.countdown-time {
  letter-spacing: 0.6px;
}

.news-rotator-thumb {
  width: 56px;
  height: 56px;
  object-fit: cover;
  flex: 0 0 auto;
}

.news-rotator .carousel-control-prev,
.news-rotator .carousel-control-next {
  width: 2.25rem;
  opacity: 0.65;
}
.news-rotator:hover .carousel-control-prev,
.news-rotator:hover .carousel-control-next {
  opacity: 0.95;
}

.class-icon {
  width: 56px;
  height: 56px;
  object-fit: cover;
  flex: 0 0 auto;
}

/* Forum board avatars */
.forum-board-avatar {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06);
  display: grid;
  place-items: center;
  overflow: hidden;
  flex: 0 0 auto;
}
.forum-board-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.forum-board-avatar--lg {
  width: 72px;
  height: 72px;
  border-radius: 16px;
}
.forum-board-avatar--xs {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  font-size: 0.65rem;
}
.forum-board-avatar__fallback {
  font-weight: 700;
  color: rgba(255,255,255,0.9);
}

/* Home hero */
.home-hero__grid {
  display: grid;
  gap: 1.5rem;
  align-items: center;
}
@media (min-width: 768px) {
  .home-hero__grid {
    grid-template-columns: 1.3fr 0.7fr;
  }
}
.home-hero__media {
  display: flex;
  justify-content: center;
}
.home-hero__media img {
  width: 100%;
  max-width: 320px;
  border-radius: 1rem;
  border: 1px solid rgba(255,255,255,0.18);
  box-shadow: 0 20px 40px rgba(0,0,0,0.35);
  object-fit: cover;
}
.home-hero--banner {
  margin-left: 0;
  margin-right: 0;
  border-radius: var(--bs-border-radius, 0.5rem);
  overflow: hidden;
  position: relative;
  background-image: var(--home-hero-banner, none);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media (min-width: 768px) {
  .home-hero--banner {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
}

/* Classes page readability */
.classes-page .classes-title {
  background: linear-gradient(90deg, #ffffff 0%, color-mix(in srgb, var(--brand-accent) 70%, #ffffff 30%) 55%, #ffffff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.classes-page .classes-lead {
  color: var(--text-soft);
}
.classes-page .class-tagline {
  color: var(--text-soft);
}
.classes-page .class-name {
  color: var(--text-accent);
  text-shadow: 0 0 14px rgba(74,134,255,0.12);
}
.classes-page .classes-section-label {
  color: var(--text-accent);
  letter-spacing: 0.2px;
}
.classes-page .classes-body,
.classes-page li {
  color: var(--text-soft);
}
.classes-page .classes-strong {
  color: var(--text-primary);
}
.classes-page,
.classes-page * {
  word-break: normal;
  overflow-wrap: break-word;
  hyphens: none;
}
.classes-page .class-card {
  background: radial-gradient(600px 300px at 10% 0%, rgba(255,255,255,0.04), transparent) no-repeat, var(--panel-bg);
}
.classes-page .class-icon,
.class-guide .class-icon {
  width: 46px;
  height: 46px;
  flex: 0 0 46px;
  font-weight: 700;
  line-height: 1;
}
.classes-page .class-icon--fallback {
  background: linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  color: var(--text-soft);
  font-size: 0.95rem;
}
.classes-page .class-icon-img,
.class-guide .class-icon-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}
.classes-page .class-role {
  font-size: 0.9rem;
}
.classes-page .class-tile {
  background: rgba(255,255,255,0.02);
}
.classes-page .class-list {
  padding-left: 1rem;
}
.classes-page .class-sections .class-tile {
  min-height: 100%;
}
.classes-page .class-tagline {
  line-height: 1.4;
}
.classes-page .class-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(320px, 1fr));
  gap: 1rem;
}
.classes-page .class-grid > .col {
  width: 100%;
}
.classes-page .class-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 0.75rem;
}
.classes-page .class-core-spells {
  list-style: none;
  padding-left: 0;
}
.classes-page .class-link {
  color: var(--heading-accent);
  text-decoration: none;
}
.classes-page .class-link:hover {
  text-decoration: underline;
}

@media (max-width: 767.98px) {
  .classes-page .class-card {
    padding: 0.25rem;
  }
  .classes-page .class-icon {
    width: 50px;
    height: 50px;
  }
}

@media (max-width: 900px) {
  .classes-page .class-grid {
    grid-template-columns: 1fr;
  }
  .classes-page .class-stats {
    grid-template-columns: 1fr;
  }
}

/* Class guide */
.class-guide,
.class-guide * {
  word-break: normal;
  overflow-wrap: break-word;
  hyphens: none;
}
.class-guide .guide-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1rem;
}
.class-guide .guide-card {
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  padding: 1rem;
}
.class-guide .guide-list {
  margin: 0;
  padding-left: 1.1rem;
}
.class-guide .guide-subgrid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.75rem;
}
.class-guide .guide-builds {
  display: grid;
  gap: 0.75rem;
}
.class-guide .guide-build {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  padding: 0.75rem;
}

/* Spells page */
.spells-page,
.spells-page * {
  word-break: normal;
  overflow-wrap: break-word;
  hyphens: none;
}
.spells-page .spells-tabs .btn {
  min-width: 80px;
}
.spells-page .spells-table code {
  white-space: nowrap;
}

/* Feature detail page readability */
.feature-page .content h1 {
  background: linear-gradient(90deg, #ffffff 0%, color-mix(in srgb, var(--brand-accent) 75%, #ffffff 25%) 60%, #ffffff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: 0.2px;
}
.feature-page .content h2,
.feature-page .content h3,
.feature-page .content h4 {
  color: var(--text-accent);
}
.feature-page .content p,
.feature-page .content li {
  color: var(--text-soft);
}
.feature-page .content strong,
.feature-page .content b {
  color: var(--text-primary);
}
.feature-page .content a {
  color: var(--link-color);
}
.feature-page .content a:hover {
  color: var(--link-hover);
}
.feature-page .content blockquote {
  border-left: 3px solid var(--text-accent);
  padding-left: 0.85rem;
  color: var(--text-soft);
}
.feature-page .content code {
  color: var(--text-soft);
}

/* Spells page */
.spells-filters .form-control,
.spells-filters .form-select {
  background-color: rgba(10, 14, 20, 0.95) !important;
  color: rgba(255,255,255,0.96) !important;
  border-color: rgba(255,255,255,0.18) !important;
}
.spells-filters .form-control::placeholder {
  color: rgba(255,255,255,0.62) !important;
}
.spells-filters .form-control:focus,
.spells-filters .form-select:focus {
  border-color: color-mix(in srgb, var(--brand-accent) 70%, #ffffff 30%) !important;
  box-shadow: 0 0 0 0.2rem rgba(74, 134, 255, 0.18) !important;
}
.spells-table code {
  white-space: normal;
  word-break: break-word;
}
.spell-link {
  text-decoration: none;
}
.spell-link:hover {
  text-decoration: underline;
}

/* NexusVerse 2026 theme refresh */
:root {
  --nv-bg-0: #05070d;
  --nv-bg-1: #0b1020;
  --nv-bg-2: #121728;
  --nv-panel: rgba(9, 14, 26, 0.88);
  --nv-panel-strong: rgba(12, 18, 34, 0.96);
  --nv-border: rgba(124, 92, 255, 0.22);
  --nv-border-strong: rgba(94, 214, 255, 0.32);
  --nv-text: #eef3ff;
  --nv-text-soft: #c5d0ea;
  --nv-text-muted: #8d97b4;
  --nv-blue: #6da8ff;
  --nv-cyan: #59edff;
  --nv-violet: #9067ff;
  --nv-rose: #ff73c8;
  --nv-danger: #ff6b88;
  --brand-accent: var(--nv-violet);
  --page-bg-1: var(--nv-bg-1);
  --page-bg-2: var(--nv-bg-0);
  --panel-bg: var(--nv-panel);
  --panel-border: var(--nv-border);
  --divider: rgba(255,255,255,0.08);
  --text-main: var(--nv-text);
  --text-soft: var(--nv-text-soft);
  --text-muted: var(--nv-text-muted);
  --heading-color: #f6f8ff;
  --heading-accent: #d7c8ff;
  --subheading-color: #96e8ff;
  --link-color: #8fcbff;
  --link-hover: #ffffff;
  --card-bg: var(--nv-panel);
  --card-border: var(--nv-border);
  --text-primary: var(--nv-text);
  --text-accent: var(--nv-cyan);
  --shadow-panel: 0 28px 70px rgba(0, 0, 0, 0.48);
  --shadow-glow: 0 0 0 1px rgba(105, 158, 255, 0.09), 0 18px 45px rgba(0, 0, 0, 0.42), 0 0 38px rgba(96, 102, 255, 0.1);
  --radius-panel: 20px;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "Rajdhani", "Segoe UI", sans-serif;
  letter-spacing: 0.015em;
  background:
    radial-gradient(circle at 15% 18%, rgba(83, 128, 255, 0.2), transparent 28%),
    radial-gradient(circle at 82% 0%, rgba(84, 241, 255, 0.12), transparent 25%),
    radial-gradient(circle at 50% 120%, rgba(143, 64, 255, 0.18), transparent 30%),
    linear-gradient(180deg, #04060d 0%, #080c17 42%, #05070d 100%) fixed;
  color: var(--nv-text);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(circle at center, black 38%, transparent 100%);
  opacity: 0.22;
}

.site-shell {
  overflow-x: hidden;
}

.site-chroma {
  position: fixed;
  inset: auto;
  width: 44rem;
  height: 44rem;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0.22;
  pointer-events: none;
  z-index: 0;
}

.site-chroma--north {
  top: -18rem;
  right: -10rem;
  background: radial-gradient(circle, rgba(105, 160, 255, 0.9) 0%, rgba(89, 237, 255, 0.35) 36%, transparent 68%);
}

.site-chroma--south {
  bottom: -24rem;
  left: -14rem;
  background: radial-gradient(circle, rgba(144, 103, 255, 0.75) 0%, rgba(255, 115, 200, 0.28) 40%, transparent 72%);
}

.container {
  position: relative;
  z-index: 1;
}

.nexus-navbar {
  background: rgba(6, 10, 19, 0.82) !important;
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(110, 119, 255, 0.18);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.42);
}

.nexus-brand {
  display: grid;
  gap: 0.05rem;
  color: var(--nv-text) !important;
  text-decoration: none;
}

.nexus-brand__eyebrow,
.page-intro__eyebrow,
.section-heading__eyebrow,
.home-hero__eyebrow {
  font-size: 0.75rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--nv-cyan);
}

.nexus-brand__title {
  font-family: "Cinzel", serif;
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.nexus-brand__subtitle {
  color: var(--nv-text-muted);
  font-size: 0.74rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.nexus-nav .nav-link,
.nexus-account-link {
  color: rgba(235, 241, 255, 0.88) !important;
  font-weight: 600;
  letter-spacing: 0.04em;
  border-radius: 999px;
  padding: 0.6rem 0.95rem !important;
  transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.nexus-nav .nav-link:hover,
.nexus-nav .nav-link:focus,
.nexus-account-link:hover,
.nexus-account-link:focus {
  color: #fff !important;
  background: rgba(255,255,255,0.06);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.06);
}

.nexus-nav-meta {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.navbar-online-badge {
  padding: 0.58rem 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: var(--nv-text);
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
}

.navbar-online-badge__label {
  font-weight: 700;
  letter-spacing: 0.04em;
}

.navbar-online-badge__value {
  color: var(--nv-text-soft);
  font-size: 0.88rem;
}

.navbar-online-badge.is-online {
  border-color: rgba(89, 237, 255, 0.36);
  background: rgba(89, 237, 255, 0.08);
}

.navbar-online-badge.is-offline {
  border-color: rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
}

.nexus-dropdown {
  border: 1px solid rgba(95, 119, 255, 0.18);
  background: rgba(7, 10, 20, 0.96);
  backdrop-filter: blur(18px);
  border-radius: 18px;
  box-shadow: var(--shadow-panel);
  padding: 0.6rem;
}

.nexus-dropdown .dropdown-item {
  border-radius: 12px;
  color: var(--nv-text-soft);
  padding: 0.65rem 0.8rem;
}

.nexus-dropdown .dropdown-item:hover,
.nexus-dropdown .dropdown-item:focus {
  background: linear-gradient(90deg, rgba(144, 103, 255, 0.18), rgba(89, 237, 255, 0.12));
  color: #fff;
}

.nexus-account-link {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  line-height: 1.1;
}

.nexus-account-link__label {
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--nv-text-muted);
}

.nexus-account-link__name {
  font-size: 0.98rem;
}

.nexus-nav-cta {
  min-width: 7.5rem;
}

.home-hero {
  position: relative;
  padding: clamp(1.5rem, 3vw, 2rem);
  border: 1px solid rgba(123, 136, 255, 0.2);
  border-radius: 28px;
  box-shadow: var(--shadow-panel);
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(95, 150, 255, 0.22), transparent 28%),
    linear-gradient(135deg, rgba(6, 10, 18, 0.92), rgba(10, 14, 28, 0.84));
}

.home-hero__backdrop {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(115deg, rgba(5, 7, 13, 0.38) 18%, rgba(6, 10, 18, 0.82) 55%, rgba(8, 11, 18, 0.95) 100%),
    var(--home-hero-banner, none);
  background-size: cover;
  background-position: center;
  filter: saturate(1.1);
}

.home-hero__grid {
  position: relative;
  z-index: 1;
}

.home-hero__copy {
  max-width: 42rem;
}

.home-hero__title {
  margin-top: 0.55rem;
  margin-bottom: 0.9rem;
  font-family: "Cinzel", serif;
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  line-height: 1.04;
  color: #f8fbff;
  text-shadow: 0 12px 38px rgba(0,0,0,0.46);
}

.home-hero__subtitle {
  max-width: 42rem;
  margin-bottom: 1.35rem;
  color: var(--nv-text-soft);
  font-size: clamp(1rem, 2vw, 1.2rem);
}

.home-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
}

.home-hero__signals {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
  margin-top: 1.4rem;
}

.home-hero__signal {
  padding: 0.9rem 1rem;
  border-radius: 18px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
}

.home-hero__signal strong {
  display: block;
  color: #fff;
  font-size: 1.08rem;
}

.home-hero__signal-label {
  display: block;
  margin-bottom: 0.2rem;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--nv-text-muted);
}

.home-hero__media {
  justify-content: flex-end;
}

.home-hero__media-frame {
  position: relative;
  width: min(100%, 22rem);
  aspect-ratio: 0.82;
  border-radius: 28px;
  padding: 1rem;
  background: linear-gradient(145deg, rgba(89, 237, 255, 0.08), rgba(144, 103, 255, 0.12));
  border: 1px solid rgba(113, 154, 255, 0.22);
  box-shadow: 0 28px 60px rgba(0,0,0,0.4);
}

.home-hero__media-frame::before {
  content: "";
  position: absolute;
  inset: 1rem;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.14);
  pointer-events: none;
}

.home-hero__media-frame img,
.home-hero__sigil {
  width: 100%;
  height: 100%;
  border-radius: 22px;
  object-fit: cover;
}

.home-hero__sigil {
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 30% 25%, rgba(89, 237, 255, 0.2), transparent 26%),
    radial-gradient(circle at 70% 75%, rgba(144, 103, 255, 0.22), transparent 25%),
    linear-gradient(180deg, rgba(11,17,32,0.96), rgba(6,9,18,0.98));
  border: 1px solid rgba(255,255,255,0.08);
}

.home-hero__sigil span {
  font-family: "Cinzel", serif;
  font-size: clamp(4rem, 12vw, 7rem);
  color: rgba(255,255,255,0.92);
  text-shadow: 0 0 32px rgba(89, 237, 255, 0.24);
}

.page-intro,
.section-heading {
  display: grid;
  gap: 0.18rem;
}

.page-intro h1,
.section-heading h2 {
  color: #f7f9ff;
}

.shell-grid > aside,
.shell-grid > main {
  min-width: 0;
}

.card,
.list-group-item,
.modal-content,
.dropdown-menu,
.table,
.accordion-item {
  border-radius: var(--radius-panel);
}

.card.bg-black,
.modal-content.bg-black,
.list-group-item.bg-black {
  background: linear-gradient(180deg, rgba(14, 20, 36, 0.92), rgba(8, 12, 22, 0.96)) !important;
  border-color: var(--nv-border) !important;
  box-shadow: var(--shadow-glow);
}

.card-header,
.card-footer {
  background: rgba(255,255,255,0.02);
  border-color: rgba(255,255,255,0.06) !important;
}

.nexus-surface,
.nexus-news-card,
.nexus-auth-card,
.nexus-product-card,
.nexus-news-article {
  overflow: hidden;
}

.nexus-surface--highlight {
  background:
    radial-gradient(circle at top right, rgba(89, 237, 255, 0.08), transparent 32%),
    linear-gradient(180deg, rgba(14, 20, 36, 0.94), rgba(8, 12, 22, 0.98)) !important;
}

.btn {
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: 999px;
  padding: 0.72rem 1.15rem;
  box-shadow: none;
}

.btn-sm {
  padding: 0.5rem 0.9rem;
}

.btn-lg {
  padding: 0.9rem 1.35rem;
}

.btn-primary {
  color: #04060d;
  border: none;
  background: linear-gradient(135deg, var(--nv-cyan), var(--nv-violet));
  box-shadow: 0 15px 34px rgba(104, 100, 255, 0.3);
}

.btn-primary:hover,
.btn-primary:focus {
  color: #04060d;
  background: linear-gradient(135deg, #7ff4ff, #a17aff);
  transform: translateY(-1px);
}

.btn-outline-light {
  color: var(--nv-text);
  border-color: rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.02);
}

.btn-outline-light:hover,
.btn-outline-light:focus {
  color: #fff;
  border-color: rgba(89, 237, 255, 0.42);
  background: rgba(89, 237, 255, 0.08);
}

.btn-outline-danger,
.btn-danger {
  border-color: rgba(255, 107, 136, 0.36);
}

.badge {
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 0.5em 0.75em;
}

.alert {
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  box-shadow: var(--shadow-glow);
}

.alert-success {
  background: rgba(33, 176, 131, 0.12);
  color: #d9fff3;
}

.alert-danger {
  background: rgba(255, 107, 136, 0.12);
  color: #ffe5eb;
}

.alert-warning,
.alert-secondary {
  background: rgba(255,255,255,0.05);
  color: var(--nv-text-soft);
}

.form-control,
.form-select,
.input-group-text {
  border-radius: 16px;
  background: rgba(7, 11, 21, 0.92);
  border-color: rgba(255,255,255,0.11);
  color: var(--nv-text);
}

.form-control::placeholder {
  color: rgba(191, 202, 230, 0.45);
}

.form-control:focus,
.form-select:focus {
  color: #fff;
  background: rgba(9, 14, 26, 0.98);
  border-color: rgba(89, 237, 255, 0.42);
  box-shadow: 0 0 0 0.24rem rgba(89, 237, 255, 0.12);
}

.form-check-input {
  background-color: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.18);
}

.form-check-input:checked {
  background-color: var(--nv-violet);
  border-color: var(--nv-violet);
}

.table {
  --bs-table-bg: transparent;
  --bs-table-color: var(--nv-text);
  --bs-table-striped-bg: rgba(255,255,255,0.025);
  --bs-table-hover-bg: rgba(89, 237, 255, 0.04);
  margin-bottom: 0;
}

.table thead th {
  border-bottom-color: rgba(255,255,255,0.08);
  color: var(--nv-cyan);
  font-size: 0.84rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.table tbody td {
  border-top-color: rgba(255,255,255,0.06);
}

.pagination .page-link {
  background: rgba(255,255,255,0.03);
  border-color: rgba(255,255,255,0.08);
  color: var(--nv-text-soft);
  border-radius: 12px;
  margin-right: 0.35rem;
}

.pagination .page-item.active .page-link {
  color: #04060d;
  border-color: transparent;
  background: linear-gradient(135deg, var(--nv-cyan), var(--nv-violet));
}

.list-group-item {
  background-color: transparent !important;
}

.content p,
.content li,
.card-body,
.card-footer,
.list-group-item,
.table,
.form-label,
.form-text {
  color: var(--nv-text-soft);
}

.text-secondary,
.text-muted,
small,
.small {
  color: var(--nv-text-muted) !important;
}

.nexus-footer {
  position: relative;
  padding: 2rem 0 2.4rem;
  border-top: 1px solid rgba(121, 129, 255, 0.12);
  background: rgba(4, 6, 13, 0.88);
  backdrop-filter: blur(12px);
}

.nexus-footer__inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1.25rem;
  align-items: flex-end;
}

.nexus-footer__brand {
  font-family: "Cinzel", serif;
  font-size: 1.1rem;
  letter-spacing: 0.08em;
  color: #fff;
}

.nexus-footer__tagline {
  color: var(--nv-text-muted);
}

.nexus-footer__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  color: var(--nv-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.72rem;
}

.sidebar-widgets .card,
.sidebar-widgets .card-body,
.sidebar-widgets .card-header {
  border-radius: 18px;
}

.sidebar-widgets .card-header {
  color: #f6f9ff !important;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.78rem;
}

.nexus-news-card .card-img-top,
.nexus-news-article .card-img-top,
.nexus-product-card .card-img-top {
  max-height: 16rem;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.02);
}

.nexus-auth-card {
  max-width: 42rem;
}

body[data-view^="admin"] .page-intro__eyebrow,
body[data-view^="admin"] .section-heading__eyebrow {
  color: #ff8dc8;
}

body[data-view^="admin"] .btn-danger {
  background: linear-gradient(135deg, #ff7b93, #ff476f);
  border: none;
  color: #fff;
}

body[data-view="home"] .home-hero-offset {
  padding-top: 0;
}

@media (max-width: 1199.98px) {
  .nexus-nav-meta {
    margin-top: 1rem;
    justify-content: space-between;
  }
}

@media (max-width: 991.98px) {
  .home-hero__signals {
    grid-template-columns: 1fr;
  }

  .home-hero__media {
    justify-content: center;
  }
}

@media (max-width: 767.98px) {
  .home-hero {
    border-radius: 22px;
  }

  .nexus-footer__inner,
  .nexus-nav-meta {
    flex-direction: column;
    align-items: flex-start;
  }

  .home-hero__actions {
    flex-direction: column;
  }

  .home-hero__actions .btn,
  .nexus-auth-card .btn,
  .d-grid > .btn {
    width: 100%;
    justify-content: center;
  }
}
