:root {
  color-scheme: dark;
  --bg: #061019;
  --bg-deep: #03090f;
  --panel: rgba(10, 25, 35, 0.82);
  --panel-border: rgba(170, 207, 220, 0.14);
  --text: #edf4f2;
  --muted: #a0b1b7;
  --faint: #71858c;
  --gold: #d5a753;
  --gold-light: #f0d08a;
  --gold-dark: #9c6d26;
  --ice: #84b5c2;
  --positive: #78c39b;
  --font-title: "Cinzel", Georgia, serif;
  --font-body: "Manrope", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg-deep); color: var(--text); font-family: var(--font-body); }
button, input { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
a { color: inherit; text-decoration: none; }

.content-shell { width: min(1180px, calc(100% - 48px)); margin: 0 auto; }
.site-header {
  align-items: center; display: flex; height: 76px; justify-content: space-between; left: 0;
  padding: 0 5vw; position: absolute; right: 0; top: 0; z-index: 10;
  border-bottom: 1px solid rgba(255,255,255,.09); background: rgba(2,9,14,.3); backdrop-filter: blur(12px);
}
.brand { align-items: center; display: flex; gap: 11px; }
.brand-mark {
  align-items: center; border: 1px solid rgba(225,188,108,.58); color: var(--gold-light); display: flex;
  font: 700 21px/1 var(--font-title); height: 42px; justify-content: center; transform: rotate(45deg); width: 42px;
  box-shadow: inset 0 0 0 3px rgba(213,167,83,.08), 0 0 28px rgba(213,167,83,.12);
}
.brand-mark::first-letter { transform: rotate(-45deg); }
.brand-text { color: #fff; font: 800 17px/1 var(--font-title); letter-spacing: .11em; text-transform: uppercase; }
.brand-text small { color: var(--gold); display: block; font: 700 8px/1.4 var(--font-body); letter-spacing: .42em; margin-top: 5px; }
.site-nav { display: flex; gap: 34px; margin-left: auto; margin-right: 40px; }
.site-nav a, footer a { color: #c4d1d4; font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; transition: .2s; }
.site-nav a:hover, footer a:hover { color: var(--gold-light); }
.header-actions { display: flex; gap: 10px; }
.menu-toggle { background: transparent; border: 0; color: white; display: none; font-size: 22px; }

.btn {
  align-items: center; border: 1px solid transparent; cursor: pointer; display: inline-flex; font-size: 11px;
  font-weight: 800; justify-content: center; letter-spacing: .14em; min-height: 42px; padding: 0 22px;
  text-transform: uppercase; transition: .25s;
}
.btn-gold { background: linear-gradient(135deg, var(--gold-light), var(--gold) 55%, #b57e2c); color: #162126; box-shadow: 0 8px 24px rgba(155,105,31,.25); }
.btn-gold:hover { box-shadow: 0 10px 32px rgba(213,167,83,.4); filter: brightness(1.08); transform: translateY(-2px); }
.btn:disabled { cursor: wait; filter: grayscale(.35); opacity: .72; transform: none; }
.btn-ghost { background: rgba(255,255,255,.02); border-color: rgba(255,255,255,.17); color: #e7eeee; }
.btn-ghost:hover, .btn-glass:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.3); }
.btn-glass { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.2); color: white; gap: 14px; }
.btn-large { min-height: 55px; padding: 0 29px; }

.hero { min-height: 780px; overflow: hidden; position: relative; }
.hero-bg, .hero-fog { inset: 0; position: absolute; }
.hero-bg { background: linear-gradient(90deg, rgba(2,8,13,.95), rgba(3,11,17,.53) 50%, rgba(3,10,15,.12)), url("./assets/frozen-citadel-hero.png") center/cover; }
.hero-bg::after { background: linear-gradient(0deg, var(--bg-deep), transparent 28%); content: ""; inset: 0; position: absolute; }
.hero-fog { background: radial-gradient(ellipse at 35% 65%, rgba(79,134,151,.2), transparent 35%); mix-blend-mode: screen; opacity: .7; }
.hero-content { padding-top: 188px; position: relative; z-index: 1; }
.eyebrow, .section-kicker { color: var(--gold-light); font-size: 10px; font-weight: 800; letter-spacing: .22em; text-transform: uppercase; }
.eyebrow { align-items: center; display: flex; gap: 11px; }
.eyebrow span { background: var(--gold); height: 1px; width: 34px; }
h1, h2, h3, p { margin-top: 0; }
h1, h2 { font-family: var(--font-title); text-transform: uppercase; }
h1 { font-size: clamp(47px, 6.3vw, 78px); letter-spacing: -.03em; line-height: .98; margin: 21px 0 24px; max-width: 780px; text-shadow: 0 3px 26px rgba(0,0,0,.4); }
h1 em, h2 em { color: var(--gold-light); font-style: normal; }
.hero-lead { color: #c2d0d2; font-size: 16px; line-height: 1.8; max-width: 570px; }
.hero-actions { display: flex; gap: 12px; margin-top: 31px; }
.server-pill {
  align-items: center; background: rgba(5,18,24,.64); border: 1px solid rgba(144,189,199,.16); color: #a9bbc0;
  display: inline-flex; font-size: 11px; gap: 11px; letter-spacing: .06em; margin-top: 47px; padding: 12px 16px; text-transform: uppercase;
}
.server-pill strong, .server-pill b { color: #dce7e7; }
.status-dot { background: #6bcb95; border-radius: 50%; box-shadow: 0 0 12px #67c795; display: inline-block; height: 8px; width: 8px; }
.server-divider { background: rgba(255,255,255,.16); height: 16px; width: 1px; }
.scroll-note { bottom: 32px; color: #9aabb1; font-size: 9px; left: 50%; letter-spacing: .3em; position: absolute; text-transform: uppercase; transform: translateX(-50%); z-index: 2; }
.scroll-note span { background: var(--gold); display: block; height: 35px; margin: 13px auto 0; width: 1px; }

.world-stats { background: #07121a; border-bottom: 1px solid var(--panel-border); border-top: 1px solid var(--panel-border); }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stats-grid div { border-right: 1px solid var(--panel-border); padding: 29px 25px; text-align: center; }
.stats-grid div:first-child { border-left: 1px solid var(--panel-border); }
.stats-grid strong { color: var(--gold-light); display: block; font: 700 26px/1 var(--font-title); }
.stats-grid span { color: var(--faint); display: block; font-size: 10px; font-weight: 700; letter-spacing: .16em; margin-top: 9px; text-transform: uppercase; }
.section { padding: 112px 0; }
.section-kicker { margin-bottom: 18px; }
h2 { font-size: clamp(33px, 4vw, 48px); line-height: 1.07; margin-bottom: 0; }
.split { align-items: center; display: grid; gap: 80px; grid-template-columns: 1.15fr 1fr; }
.story { background: linear-gradient(135deg, #07151e, #050e15); }
.story-copy { border-left: 1px solid rgba(213,167,83,.4); padding-left: 34px; }
.story-copy p, .start p { color: var(--muted); font-size: 15px; line-height: 1.85; }
.text-link { color: var(--gold-light); display: inline-flex; font-size: 11px; font-weight: 800; gap: 12px; letter-spacing: .14em; margin-top: 14px; text-transform: uppercase; }
.text-link span { transition: .2s; }
.text-link:hover span { transform: translateX(5px); }
.features { background: #061019; }
.feature-grid { display: grid; gap: 14px; grid-template-columns: repeat(3, 1fr); margin-top: 42px; }
.feature-card { background: linear-gradient(145deg, rgba(19,43,53,.65), rgba(7,21,29,.75)); border: 1px solid var(--panel-border); min-height: 250px; padding: 30px; transition: .25s; }
.feature-card:hover { border-color: rgba(213,167,83,.42); transform: translateY(-5px); }
.feature-icon { color: var(--gold-light); font: 700 28px/1 var(--font-title); }
.feature-card h3, .steps h3 { font: 700 18px/1.2 var(--font-title); letter-spacing: .04em; margin: 30px 0 13px; text-transform: uppercase; }
.feature-card p, .steps p { color: var(--muted); font-size: 13px; line-height: 1.75; margin: 0; }
.start { background: #07151d; }
.start-layout { display: grid; gap: 80px; grid-template-columns: 1fr 1fr; }
.steps { list-style: none; margin: 0; padding: 0; }
.steps li { align-items: flex-start; border-top: 1px solid var(--panel-border); display: flex; gap: 28px; padding: 20px 0; }
.steps span { color: var(--gold); font: 700 25px/1 var(--font-title); }
.steps h3 { margin: 0 0 6px; }
.cta { background: linear-gradient(rgba(3,12,17,.82), rgba(3,12,17,.88)), url("./assets/frozen-citadel-hero.png") center 62%/cover; padding: 105px 0; text-align: center; }
.cta h2 { margin-bottom: 29px; }
footer { background: #03090f; border-top: 1px solid var(--panel-border); padding: 24px 0; }
.footer-inner { align-items: center; display: flex; justify-content: space-between; }
footer p { color: var(--faint); font-size: 11px; margin: 0; }
footer div div { display: flex; gap: 22px; }

.auth-dialog {
  background: #091821; border: 1px solid rgba(190,217,221,.18); box-shadow: 0 25px 80px rgba(0,0,0,.65);
  color: var(--text); max-width: 440px; padding: 30px; width: calc(100% - 28px);
}
.auth-dialog::backdrop { background: rgba(1,7,11,.76); backdrop-filter: blur(6px); }
.dialog-close { background: transparent; border: 0; color: #a8b9bd; cursor: pointer; font-size: 27px; position: absolute; right: 14px; top: 11px; }
.auth-brand { display: flex; justify-content: center; margin: 5px 0 24px; }
.auth-tabs { border-bottom: 1px solid var(--panel-border); display: flex; margin-bottom: 24px; }
.auth-tab { background: transparent; border: 0; color: var(--faint); cursor: pointer; flex: 1; font-size: 11px; font-weight: 800; letter-spacing: .14em; padding: 12px; text-transform: uppercase; }
.auth-tab.active { border-bottom: 1px solid var(--gold); color: var(--gold-light); }
.auth-form { display: none; }
.auth-form.active { display: grid; gap: 14px; }
.auth-form h2 { font-size: 25px; text-align: center; }
.auth-form > p { color: var(--muted); font-size: 13px; line-height: 1.6; margin: -5px 0 5px; text-align: center; }
.auth-form label { color: #cbd7d9; display: grid; font-size: 10px; font-weight: 800; gap: 7px; letter-spacing: .12em; text-transform: uppercase; }
.auth-form input { background: #061117; border: 1px solid rgba(181,209,214,.17); color: white; outline: 0; padding: 13px; }
.auth-form input:focus { border-color: rgba(213,167,83,.7); }
.auth-form .check { align-items: center; display: flex; font-size: 10px; gap: 8px; letter-spacing: .05em; text-transform: none; }
.check input { accent-color: var(--gold); }
.auth-form .form-message { color: var(--gold-light); margin: 0; min-height: 19px; }

.dashboard { background: #061019; display: none; inset: 0; min-height: 100vh; position: fixed; z-index: 20; }
.dashboard.open { display: block; overflow-y: auto; }
.dashboard-header { align-items: center; background: #07131b; border-bottom: 1px solid var(--panel-border); display: flex; justify-content: space-between; padding: 17px 4vw; }
.dashboard-shell { display: grid; grid-template-columns: 230px 1fr; min-height: calc(100vh - 76px); }
aside { background: #07131b; border-right: 1px solid var(--panel-border); padding: 34px 18px; }
.dashboard-label, .panel-label { color: var(--gold); font-size: 9px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }
.aside-link { background: transparent; border: 0; border-left: 2px solid transparent; color: var(--muted); cursor: pointer; display: block; font-size: 12px; font-weight: 700; margin: 7px 0; padding: 11px 14px; text-align: left; width: 100%; }
.aside-link.active { background: rgba(213,167,83,.08); border-left-color: var(--gold); color: var(--gold-light); }
.aside-link.muted { cursor: default; opacity: .42; }
.dashboard-main { margin: 0 auto; max-width: 1120px; padding: 50px 5vw; width: 100%; }
.dashboard-welcome { align-items: center; display: flex; justify-content: space-between; margin-bottom: 30px; }
.dashboard-welcome h1 { font-size: 35px; margin: 0 0 9px; }
.dashboard-welcome p { color: var(--muted); font-size: 13px; margin: 0; }
.account-badge { align-items: center; background: rgba(68,151,104,.11); border: 1px solid rgba(107,203,149,.25); color: var(--positive); display: flex; font-size: 10px; font-weight: 800; gap: 8px; letter-spacing: .11em; padding: 11px 14px; text-transform: uppercase; }
.account-grid { display: grid; gap: 16px; grid-template-columns: 1.25fr .75fr; }
.panel { background: var(--panel); border: 1px solid var(--panel-border); padding: 25px; }
.panel h2 { font-size: 25px; }
dl { margin: 27px 0 0; }
dl div { border-top: 1px solid var(--panel-border); display: flex; font-size: 12px; justify-content: space-between; padding: 12px 0; }
dt { color: var(--faint); }
dd { color: #d9e4e4; margin: 0; }
.positive { color: var(--positive); }
.realm-title { align-items: center; display: flex; gap: 10px; }
.realm-panel p, .character-panel p { color: var(--muted); font-size: 13px; }
.realm-panel strong { color: var(--gold-light); display: block; font: 700 30px/1 var(--font-title); margin-top: 29px; }
.realm-panel small { color: var(--faint); display: block; font: 700 9px/1.5 var(--font-body); letter-spacing: .1em; text-transform: uppercase; }
.character-panel { margin-top: 16px; }
.character-heading { align-items: center; display: flex; justify-content: space-between; }
.character-heading h2 { margin-bottom: 9px; }
.character-heading > span { color: var(--faint); font-size: 10px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.character-list { display: grid; gap: 12px; margin-top: 22px; }
.character-card { background: rgba(5,17,24,.65); border: 1px solid rgba(170,207,220,.12); padding: 17px; }
.character-card-header, .character-identity { align-items: center; display: flex; }
.character-card-header { justify-content: space-between; }
.character-identity { gap: 12px; }
.character-avatar { align-items: center; background: linear-gradient(135deg, rgba(213,167,83,.23), rgba(132,181,194,.1)); border: 1px solid rgba(213,167,83,.35); color: var(--gold-light); display: flex; font: 700 17px/1 var(--font-title); height: 42px; justify-content: center; width: 42px; }
.character-card h3 { color: #e7eeee; font: 700 17px/1.2 var(--font-title); letter-spacing: .04em; margin: 0 0 5px; text-transform: uppercase; }
.character-card p { font-size: 11px; margin: 0; }
.character-state { color: var(--faint); font-size: 9px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.character-state.online { color: var(--positive); }
.character-stats { display: grid; gap: 8px; grid-template-columns: repeat(7, 1fr); margin-top: 16px; }
.character-stat { border-left: 1px solid rgba(213,167,83,.3); padding-left: 10px; }
.character-stat span { color: var(--faint); display: block; font-size: 8px; font-weight: 800; letter-spacing: .1em; margin-bottom: 5px; text-transform: uppercase; }
.character-stat strong { color: #dce7e7; font-size: 12px; }
.hardcore-tag { border: 1px solid rgba(213,167,83,.35); color: var(--gold-light); display: inline-block; font-size: 8px; font-weight: 800; letter-spacing: .12em; margin-top: 15px; padding: 6px 8px; text-transform: uppercase; }
.hardcore-tag.status-2 { border-color: rgba(107,203,149,.35); color: var(--positive); }
.hardcore-tag.status-3 { border-color: rgba(211,103,103,.35); color: #e08d8d; }
.character-empty { border: 1px dashed rgba(170,207,220,.18); padding: 20px; }
.character-empty h3 { color: #dce7e7; font: 700 16px/1.2 var(--font-title); letter-spacing: .04em; margin: 0 0 8px; text-transform: uppercase; }
.character-empty p { margin: 0; }
.status-dot.offline { background: #b76b6b; box-shadow: 0 0 12px #9f5656; }

@media (max-width: 800px) {
  .content-shell { width: min(100% - 30px, 620px); }
  .site-header { height: 68px; padding: 0 16px; }
  .site-nav, .header-actions { display: none; }
  .menu-toggle { display: block; }
  .site-header.mobile-open { align-items: flex-start; background: rgba(3,12,18,.97); flex-wrap: wrap; height: auto; padding-bottom: 18px; }
  .site-header.mobile-open .site-nav { display: grid; gap: 0; order: 3; padding-top: 17px; width: 100%; }
  .site-header.mobile-open .site-nav a { border-top: 1px solid var(--panel-border); padding: 12px 0; }
  .site-header.mobile-open .header-actions { display: flex; order: 4; padding-top: 8px; width: 100%; }
  .site-header.mobile-open .header-actions .btn { flex: 1; padding: 0 10px; }
  .site-header.mobile-open .menu-toggle { padding-top: 7px; }
  .hero { min-height: 720px; }
  .hero-content { padding-top: 160px; }
  h1 { font-size: 48px; }
  .hero-actions { align-items: stretch; flex-direction: column; width: min(100%, 300px); }
  .server-pill { align-items: flex-start; flex-direction: column; }
  .server-divider { display: none; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .stats-grid div { border-bottom: 1px solid var(--panel-border); }
  .section { padding: 76px 0; }
  .split, .start-layout, .feature-grid, .account-grid { gap: 16px; grid-template-columns: 1fr; }
  .story-copy { margin-top: 14px; }
  .footer-inner { align-items: flex-start; flex-direction: column; gap: 17px; }
  .dashboard-shell { display: block; }
  aside { display: none; }
  .dashboard-main { padding: 32px 16px; }
  .dashboard-welcome, .character-heading { align-items: flex-start; flex-direction: column; gap: 18px; }
  .character-stats { grid-template-columns: repeat(2, 1fr); }
}

/* BladeFall: blood, void and steel theme */
:root {
  --bg: #10080f;
  --bg-deep: #050306;
  --panel: rgba(21, 9, 20, .88);
  --panel-border: rgba(209, 181, 222, .16);
  --text: #f8f5fa;
  --muted: #c5b7c8;
  --faint: #8e7c94;
  --gold: #bd1f35;
  --gold-light: #ff5a68;
  --gold-dark: #6d0f23;
  --ice: #a84fda;
  --positive: #89d89e;
}

body {
  background:
    radial-gradient(circle at 12% 20%, rgba(126, 31, 156, .13), transparent 29rem),
    radial-gradient(circle at 82% 54%, rgba(170, 18, 49, .1), transparent 32rem),
    var(--bg-deep);
}

.site-header {
  background: rgba(5, 2, 7, .62);
  border-bottom-color: rgba(239, 214, 248, .12);
}

.brand-mark {
  border-color: rgba(255, 74, 97, .72);
  color: #fff;
  box-shadow: inset 0 0 0 3px rgba(147, 36, 173, .16), 0 0 28px rgba(188, 29, 63, .31);
}

.brand-text small,
.eyebrow,
.section-kicker,
.text-link,
.stats-grid strong,
.feature-icon,
.steps span,
.dashboard-label,
.panel-label,
.realm-panel strong {
  color: var(--gold-light);
}

.btn-gold {
  background: linear-gradient(135deg, #ff4a61, #bc1b38 58%, #761229);
  color: #fff;
  box-shadow: 0 10px 30px rgba(182, 21, 57, .3), 0 0 26px rgba(143, 43, 184, .14);
}

.btn-gold:hover {
  box-shadow: 0 13px 36px rgba(230, 36, 74, .44), 0 0 28px rgba(161, 60, 210, .24);
}

.hero-bg {
  background:
    linear-gradient(90deg, rgba(6, 2, 7, .98), rgba(12, 3, 12, .78) 49%, rgba(15, 3, 12, .28)),
    url("./assets/frozen-citadel-hero.png") center/cover;
  filter: saturate(.78) contrast(1.08);
}

.hero-fog {
  background:
    radial-gradient(ellipse at 28% 64%, rgba(142, 29, 173, .3), transparent 34%),
    radial-gradient(ellipse at 74% 48%, rgba(190, 25, 59, .2), transparent 30%);
}

h1 em,
h2 em {
  color: #ff6677;
  text-shadow: 0 0 28px rgba(194, 29, 63, .28);
}

.server-pill {
  background: rgba(12, 5, 14, .74);
  border-color: rgba(201, 100, 223, .22);
}

.world-stats,
.story,
.features,
.start {
  background: linear-gradient(135deg, #080409, #150812);
}

.story,
.start {
  background: linear-gradient(135deg, #0a050b, #190914 55%, #0c0610);
}

.story-copy {
  border-left-color: rgba(221, 40, 71, .58);
}

.feature-card {
  background: linear-gradient(145deg, rgba(35, 13, 30, .91), rgba(11, 6, 14, .92));
  border-color: rgba(196, 145, 211, .16);
  position: relative;
}

.feature-card::after {
  background: linear-gradient(90deg, rgba(198, 30, 62, .88), rgba(140, 50, 182, .65));
  bottom: 0;
  content: "";
  height: 2px;
  left: 0;
  opacity: .45;
  position: absolute;
  right: 0;
}

.feature-card:hover {
  border-color: rgba(236, 66, 98, .56);
  box-shadow: 0 16px 35px rgba(0, 0, 0, .24), 0 0 28px rgba(113, 32, 139, .12);
}

.feature-card-royale {
  background:
    radial-gradient(circle at 84% 18%, rgba(151, 50, 191, .2), transparent 35%),
    linear-gradient(145deg, rgba(67, 14, 35, .94), rgba(18, 7, 20, .96));
  border-color: rgba(243, 68, 101, .42);
}

.cta {
  background:
    linear-gradient(rgba(9, 2, 9, .87), rgba(13, 3, 11, .94)),
    url("./assets/frozen-citadel-hero.png") center 62%/cover;
}

footer,
.dashboard,
.dashboard-header,
aside {
  background: #070308;
}

.auth-dialog {
  background: #130713;
  border-color: rgba(209, 104, 224, .28);
}

.auth-form input,
.character-card {
  background: rgba(9, 4, 11, .78);
}
