/* ===========================================================
   ANIME FINAL QUEST — unofficial fan wiki
   Design system: dark "living database / tool" aesthetic
   =========================================================== */

/* ---------- tokens ---------- */
:root{
  --bg:#0a0712;
  --bg-2:#0d0918;
  --panel:#140e22;
  --panel-2:#1a1330;
  --panel-3:#221838;
  --line:#2a2142;
  --line-2:#392c5c;
  --text:#ece8f8;
  --text-dim:#a79fc4;
  --text-faint:#736a93;

  /* rarity spectrum (gacha convention + Cosmic update theme) */
  --r-common:#97a0b2;
  --r-rare:#3f86f7;
  --r-epic:#b061f5;
  --r-legend:#f7a724;
  --r-mythic:#ff3d77;
  --r-cosmic:#27e7d6;

  /* tier ramp */
  --t-s:#ff5b6e;
  --t-a:#ff9f40;
  --t-b:#ffd23f;
  --t-c:#57d06a;
  --t-d:#5b9cff;

  /* brand */
  --accent:#b061f5;          /* cosmic purple primary */
  --accent-2:#27e7d6;        /* cyan secondary */
  --sys:#9dff5a;             /* acid green system accent */
  --sys-ink:#0a0712;

  --shadow:0 18px 48px -18px rgba(0,0,0,.75);
  --glow-accent:0 0 0 1px rgba(176,97,245,.4), 0 0 28px -6px rgba(176,97,245,.55);

  --font-display:"Chakra Petch",system-ui,sans-serif;
  --font-body:"Noto Sans SC","Chakra Petch",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,monospace;
  --font-pixel:"Press Start 2P",monospace;

  --maxw:1280px;
  --nav-h:68px;
}

/* theme: raid (crimson accent) */
html[data-theme="raid"]{
  --accent:#ff3b46;
  --accent-2:#ff8a3d;
  --sys:#ff5b5b;
}
/* theme: terminal (green everything) */
html[data-theme="terminal"]{
  --accent:#39ff14;
  --accent-2:#9dff5a;
  --sys:#39ff14;
  --bg:#06080a;
  --bg-2:#080b0d;
  --panel:#0c1110;
  --panel-2:#101816;
  --panel-3:#16201d;
  --line:#1b2a24;
  --line-2:#273a30;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* ---------- background texture layers ---------- */
.bg-fx{position:fixed;inset:0;z-index:-1;pointer-events:none}
.bg-fx .stars{position:absolute;inset:0;
  background:
    radial-gradient(1.5px 1.5px at 20% 30%, rgba(255,255,255,.5), transparent),
    radial-gradient(1.5px 1.5px at 70% 60%, rgba(176,97,245,.5), transparent),
    radial-gradient(1px 1px at 40% 80%, rgba(39,231,214,.5), transparent),
    radial-gradient(1.5px 1.5px at 85% 20%, rgba(255,255,255,.4), transparent),
    radial-gradient(1px 1px at 12% 70%, rgba(255,255,255,.4), transparent),
    radial-gradient(1.5px 1.5px at 60% 12%, rgba(176,97,245,.4), transparent),
    radial-gradient(1px 1px at 90% 75%, rgba(39,231,214,.4), transparent);
  background-size:480px 480px,520px 520px,420px 420px,600px 600px,500px 500px,560px 560px,440px 440px;
  opacity:.7;
}
.bg-fx .glowtop{position:absolute;top:-12%;left:50%;transform:translateX(-50%);
  width:90vw;height:60vh;
  background:radial-gradient(ellipse at center, rgba(176,97,245,.22), transparent 62%);
  filter:blur(20px);
}
.bg-fx .grid{position:absolute;inset:0;
  background-image:linear-gradient(rgba(176,97,245,.05) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(176,97,245,.05) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 0%, #000 35%, transparent 80%);
}
html[data-texture="grid"] .bg-fx .stars{display:none}
html[data-texture="off"] .bg-fx .stars,
html[data-texture="off"] .bg-fx .grid{display:none}

/* ---------- shared layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
section{position:relative}
.sec-pad{padding:74px 0}

a{color:inherit;text-decoration:none}
img{max-width:100%}

/* section heading w/ system marker + live count */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:30px;flex-wrap:wrap}
.sec-kicker{font-family:var(--font-pixel);font-size:10px;letter-spacing:1px;color:var(--sys);
  display:inline-flex;align-items:center;gap:9px;margin-bottom:14px;text-transform:uppercase}
.sec-kicker::before{content:"\25C6";color:var(--sys);font-size:10px}
.sec-title{font-family:var(--font-display);font-weight:700;font-size:clamp(26px,3.6vw,42px);
  line-height:1.05;margin:0;letter-spacing:-.01em}
.sec-title .alt{color:var(--text-faint);font-weight:500;font-size:.6em;margin-left:10px}
.sec-sub{color:var(--text-dim);max-width:54ch;margin:12px 0 0}
.count-chip{font-family:var(--font-mono);font-size:13px;color:var(--sys);
  border:1px solid var(--line-2);border-radius:999px;padding:7px 14px;white-space:nowrap;
  background:rgba(157,255,90,.06)}
.count-chip b{color:var(--text)}

/* reliability badges */
.rel{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10.5px;
  letter-spacing:.04em;padding:3px 8px;border-radius:5px;white-space:nowrap;vertical-align:middle}
.rel.ok{color:#7ff0b0;background:rgba(50,210,140,.1);border:1px solid rgba(50,210,140,.32)}
.rel.chk{color:#ffd27a;background:rgba(247,167,36,.1);border:1px solid rgba(247,167,36,.32)}
.rel::before{font-size:9px}
.rel.ok::before{content:"\2713"}
.rel.chk::before{content:"\26A0"}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;white-space:nowrap;
  font-family:var(--font-display);font-weight:600;font-size:14.5px;letter-spacing:.01em;
  padding:12px 20px;border-radius:10px;border:1px solid transparent;cursor:pointer;
  transition:transform .12s ease, box-shadow .2s ease, background .2s ease, border-color .2s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(180deg,var(--accent),color-mix(in oklab,var(--accent),#000 22%));
  color:#fff;box-shadow:var(--glow-accent)}
.btn-primary:hover{box-shadow:0 0 0 1px var(--accent), 0 0 34px -4px var(--accent)}
.btn-sys{background:var(--sys);color:var(--sys-ink);font-weight:700}
.btn-sys:hover{box-shadow:0 0 24px -4px var(--sys)}
.btn-ghost{background:rgba(255,255,255,.03);border-color:var(--line-2);color:var(--text)}
.btn-ghost:hover{border-color:var(--accent);background:rgba(176,97,245,.08)}
.btn-sm{padding:8px 14px;font-size:13px;border-radius:8px}
.ext::after{content:"\2197";font-family:var(--font-mono);opacity:.7;font-size:.9em}

/* ===========================================================
   NAV
   =========================================================== */
.nav{position:sticky;top:0;z-index:60;height:var(--nav-h);
  background:rgba(10,7,18,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)}
.nav-inner{max-width:var(--maxw);margin:0 auto;height:100%;padding:0 28px;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:22px}
.brand{display:flex;align-items:center;gap:11px;min-width:0}
.brand-mark{width:34px;height:34px;border-radius:8px;flex:none;position:relative;
  background:conic-gradient(from 200deg,var(--accent),var(--accent-2),var(--r-mythic),var(--accent));
  display:grid;place-items:center;box-shadow:var(--glow-accent)}
.brand-mark::after{content:"AFQ";font-family:var(--font-pixel);font-size:7px;color:#fff;
  text-shadow:0 1px 0 rgba(0,0,0,.6)}
.brand-txt{display:flex;flex-direction:column;line-height:1;min-width:0}
.brand-name{font-family:var(--font-display);font-weight:700;font-size:15px;letter-spacing:.02em;white-space:nowrap}
.brand-dom{font-family:var(--font-mono);font-size:10px;color:var(--text-faint);margin-top:3px;white-space:nowrap}
.brand-badge{font-family:var(--font-pixel);font-size:6.5px;color:var(--sys);border:1px solid var(--line-2);
  border-radius:4px;padding:3px 5px;margin-left:6px;white-space:nowrap;align-self:center}

/* global search (nav center) */
.search{position:relative;max-width:520px;width:100%;justify-self:center}
.search-box{display:flex;align-items:center;gap:10px;height:42px;padding:0 14px;
  background:var(--panel);border:1px solid var(--line-2);border-radius:11px;
  transition:border-color .2s, box-shadow .2s}
.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(176,97,245,.18)}
.search-ico{width:15px;height:15px;border:2px solid var(--sys);border-radius:50%;flex:none;position:relative}
.search-ico::after{content:"";position:absolute;width:6px;height:2px;background:var(--sys);
  right:-4px;bottom:-1px;transform:rotate(45deg)}
.search input{flex:1;background:none;border:none;outline:none;color:var(--text);
  font-family:var(--font-body);font-size:14px;min-width:0}
.search input::placeholder{color:var(--text-faint)}
.search kbd{font-family:var(--font-mono);font-size:11px;color:var(--text-faint);
  border:1px solid var(--line-2);border-radius:5px;padding:2px 6px;white-space:nowrap}
.search-results{position:absolute;top:50px;left:0;right:0;background:var(--panel-2);
  border:1px solid var(--line-2);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;
  max-height:60vh;overflow-y:auto;display:none;z-index:80}
.search-results.show{display:block}
.sr-group{padding:8px 0}
.sr-group-h{font-family:var(--font-pixel);font-size:8px;color:var(--text-faint);
  padding:8px 16px 6px;letter-spacing:.5px;text-transform:uppercase}
.sr-item{display:flex;align-items:center;gap:11px;padding:9px 16px;cursor:pointer;transition:background .12s}
.sr-item:hover,.sr-item.active{background:rgba(176,97,245,.12)}
.sr-dot{width:9px;height:9px;border-radius:3px;flex:none}
.sr-name{font-size:14px;color:var(--text)}
.sr-name b{color:var(--sys)}
.sr-type{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--text-faint)}
.sr-empty{padding:20px 16px;color:var(--text-faint);font-size:14px;text-align:center}

.nav-right{display:flex;align-items:center;gap:10px;justify-self:end}
/* lang toggle — fixed width so right side never shifts */
.lang{display:inline-flex;border:1px solid var(--line-2);border-radius:9px;overflow:hidden;
  font-family:var(--font-mono);font-size:12px;height:38px;flex:none}
.lang button{width:42px;background:none;border:none;color:var(--text-faint);cursor:pointer;
  font-family:inherit;font-size:12px;transition:background .15s,color .15s}
.lang button.on{background:var(--accent);color:#fff}
.nav-cta{flex:none}
.hamburger{display:none;width:42px;height:38px;border:1px solid var(--line-2);border-radius:9px;
  background:var(--panel);cursor:pointer;flex-direction:column;gap:4px;align-items:center;justify-content:center}
.hamburger span{width:18px;height:2px;background:var(--text);border-radius:2px}

/* mobile drawer */
.drawer{position:fixed;inset:var(--nav-h) 0 0;background:rgba(10,7,18,.97);backdrop-filter:blur(8px);
  z-index:55;padding:24px 28px;display:none;flex-direction:column;gap:6px;overflow-y:auto}
.drawer.open{display:flex}
.drawer a{padding:14px 4px;border-bottom:1px solid var(--line);font-family:var(--font-display);font-size:18px}
.drawer .btn{margin-top:16px}

/* i18n visibility */
html[data-lang="zh"] .en{display:none}
html[data-lang="en"] .zh{display:none}
.zh{font-family:var(--font-body)}

/* ===========================================================
   HERO
   =========================================================== */
.hero{padding:54px 0 64px;position:relative;overflow:hidden}
.hero-grid{display:flex;flex-direction:column;align-items:center;text-align:center;gap:38px}
.hero-grid .hero-copy{max-width:980px;width:100%}
.hero-grid .hero-lead{margin-left:auto;margin-right:auto}
.hero-grid .hero-cta{justify-content:center}
.hero-grid .hero-stats{justify-content:center;gap:42px}
.hero-grid .hero-video{width:100%;max-width:920px}
.hero-live{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:12.5px;
  color:var(--sys);border:1px solid rgba(157,255,90,.3);background:rgba(157,255,90,.06);
  padding:6px 13px;border-radius:999px;margin-bottom:22px}
.hero-live .dot{width:8px;height:8px;border-radius:50%;background:var(--sys);box-shadow:0 0 0 0 var(--sys);
  animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(157,255,90,.55)}70%{box-shadow:0 0 0 8px rgba(157,255,90,0)}100%{box-shadow:0 0 0 0 rgba(157,255,90,0)}}
.hero h1{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.04;
  font-size:clamp(38px,5.4vw,66px);margin:0 0 20px;text-wrap:balance}
.hero h1 .grad{background:linear-gradient(96deg,var(--accent),var(--accent-2) 60%,var(--r-mythic));
  -webkit-background-clip:text;background-clip:text;color:transparent}
/* controlled line break: forced on wide screens, natural wrap on phones */
.hero .hb{display:none}
.hero-lead{font-size:18px;color:var(--text-dim);max-width:54ch;margin:0 0 26px;text-wrap:balance}
@media (min-width:920px){
  .hero .hb{display:inline}
  .hero h1{text-wrap:normal}
  .hero-lead{max-width:none;text-wrap:normal}
}
.hero-lead b{color:var(--text)}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:30px}
.hero-stats{display:flex;gap:26px;flex-wrap:wrap}
.hstat{display:flex;flex-direction:column;gap:3px}
.hstat .n{font-family:var(--font-mono);font-weight:700;font-size:24px;color:var(--text);line-height:1}
.hstat .n .u{color:var(--sys);font-size:.7em}
.hstat .l{font-size:12.5px;color:var(--text-faint)}

/* hero visual — pure CSS cosmic emblem */
.hero-art{position:relative;aspect-ratio:1/1;display:grid;place-items:center}
.orb{position:relative;width:min(420px,90%);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 38% 32%, rgba(176,97,245,.55), rgba(39,231,214,.18) 45%, transparent 70%);
  box-shadow:inset 0 0 80px rgba(39,231,214,.25), 0 0 90px -20px rgba(176,97,245,.6)}
.orb::before,.orb::after{content:"";position:absolute;inset:0;border-radius:50%;
  border:1px solid rgba(176,97,245,.35)}
.orb::before{inset:-26px;border-style:dashed;border-color:rgba(39,231,214,.28);animation:spin 32s linear infinite}
.orb::after{inset:18px;border-color:rgba(255,255,255,.08)}
@keyframes spin{to{transform:rotate(360deg)}}
.orb .core{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--font-pixel);
  font-size:clamp(20px,4.4vw,40px);color:#fff;text-shadow:0 0 24px var(--accent);letter-spacing:1px}
.orb-tag{position:absolute;font-family:var(--font-mono);font-size:11px;padding:5px 10px;border-radius:7px;
  background:var(--panel-2);border:1px solid var(--line-2);white-space:nowrap;box-shadow:var(--shadow)}
.orb-tag .d{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:6px;vertical-align:middle}
.ot1{top:3%;left:1%}
.ot2{top:47%;right:7%}
.ot3{bottom:5%;left:5%}

/* hero video — lite-youtube facade (lazy-loads the player on click) */
.hero-video{position:relative;width:100%}
.lite-yt{position:relative;display:block;width:100%;aspect-ratio:16/9;padding:0;cursor:pointer;
  border:1px solid var(--line-2);border-radius:16px;overflow:hidden;background:#05040a;box-shadow:var(--shadow)}
.lite-yt-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.82;
  transition:opacity .2s, transform .3s}
.lite-yt:hover .lite-yt-thumb{opacity:1;transform:scale(1.03)}
.lite-yt::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,7,18,.1),rgba(10,7,18,.55))}
.lite-yt-play{position:absolute;inset:0;margin:auto;width:64px;height:64px;border-radius:50%;z-index:2;
  background:var(--accent);box-shadow:0 0 0 8px rgba(176,97,245,.22), var(--glow-accent);
  display:grid;place-items:center;transition:transform .15s}
.lite-yt:hover .lite-yt-play{transform:scale(1.08)}
.lite-yt-play::after{content:"";border-style:solid;border-width:10px 0 10px 17px;
  border-color:transparent transparent transparent #fff;margin-left:4px}
.lite-yt-badge{position:absolute;left:12px;bottom:12px;z-index:2;display:inline-flex;align-items:center;gap:7px;
  font-family:var(--font-mono);font-size:11.5px;color:#fff;background:rgba(10,7,18,.72);
  border:1px solid var(--line-2);border-radius:7px;padding:5px 10px;backdrop-filter:blur(4px)}
.lite-yt-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--sys);box-shadow:0 0 8px var(--sys)}
.hero-video-frame{display:block;width:100%;aspect-ratio:16/9;border:1px solid var(--line-2);
  border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.hero-video-cap{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;flex-wrap:wrap}
.vc-label{font-family:var(--font-mono);font-size:12px;color:var(--text-dim)}
.vc-link{font-family:var(--font-display);font-weight:600;font-size:13.5px;color:var(--text-dim);white-space:nowrap}
.vc-link:hover{color:var(--sys)}

/* ===========================================================
   RARITY SPECTRUM — visual protagonist
   =========================================================== */
.rarity-row{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.rar{position:relative;border-radius:14px;padding:20px 16px 18px;overflow:hidden;
  border:1px solid var(--rc);background:
    linear-gradient(180deg, color-mix(in oklab,var(--rc),transparent 86%), color-mix(in oklab,var(--rc),transparent 96%)),
    var(--panel);
  min-height:200px;display:flex;flex-direction:column;
  transition:transform .16s ease, box-shadow .2s ease}
.rar:hover{transform:translateY(-5px);box-shadow:0 0 0 1px var(--rc), 0 18px 40px -16px var(--rc)}
.rar::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--rc)}
.rar-idx{font-family:var(--font-mono);font-size:11px;color:var(--rc);opacity:.8}
.rar-name{font-family:var(--font-pixel);font-size:13px;line-height:1.5;color:var(--rc);margin:10px 0 4px;
  text-shadow:0 0 14px color-mix(in oklab,var(--rc),transparent 55%)}
.rar-name.long{font-size:11px}
.rar-cn{font-size:13px;color:var(--text-dim);margin-bottom:auto}
.rar-desc{font-size:12.5px;color:var(--text-faint);margin-top:14px;line-height:1.45}
.rar-orb{width:38px;height:38px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff6,transparent 60%),var(--rc);
  box-shadow:0 0 22px -2px var(--rc);margin-bottom:4px}

/* ===========================================================
   BEGINNER ROUTE
   =========================================================== */
.route{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;
  counter-reset:step;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--panel)}
.step{padding:26px 22px;border-right:1px solid var(--line);position:relative}
.step:last-child{border-right:none}
.step-n{font-family:var(--font-pixel);font-size:13px;color:var(--sys-ink);background:var(--sys);
  width:34px;height:34px;border-radius:9px;display:grid;place-items:center;margin-bottom:16px}
.step h3{font-family:var(--font-display);font-size:18px;margin:0 0 8px;font-weight:600}
.step p{font-size:13.5px;color:var(--text-dim);margin:0}
.step .tag{display:inline-block;margin-top:12px;font-family:var(--font-mono);font-size:11px;color:var(--accent-2);
  border:1px solid var(--line-2);border-radius:6px;padding:3px 8px}

/* ===========================================================
   CORE SYSTEMS
   =========================================================== */
.sys-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.syscard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px;
  transition:border-color .18s, transform .16s;position:relative;overflow:hidden}
.syscard:hover{border-color:var(--line-2);transform:translateY(-3px)}
.syscard .ic{font-family:var(--font-pixel);font-size:11px;color:var(--sys);margin-bottom:14px;
  display:inline-flex;align-items:center;gap:8px}
.syscard .ic::before{content:"[";color:var(--sys)}
.syscard .ic::after{content:"]";color:var(--sys)}
.syscard h3{font-family:var(--font-display);font-size:20px;margin:0 0 8px;font-weight:600}
.syscard h3 .cn{display:block;font-size:13px;color:var(--text-faint);font-weight:400;font-family:var(--font-body)}
.syscard p{font-size:14px;color:var(--text-dim);margin:0}
.syscard ul{margin:12px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:7px}
.syscard li{font-size:13px;color:var(--text-dim);padding-left:18px;position:relative}
.syscard li::before{content:"\25C6";position:absolute;left:0;color:var(--sys);font-size:9px;top:4px}

/* ===========================================================
   RESOURCE GRID
   =========================================================== */
.res-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.res{display:flex;flex-direction:column;gap:8px;padding:22px;border-radius:14px;
  background:var(--panel);border:1px solid var(--line);transition:.18s;position:relative;overflow:hidden}
.res:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 14px 30px -18px var(--accent)}
.res-ico{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-family:var(--font-pixel);
  font-size:13px;color:#fff;background:linear-gradient(150deg,var(--accent),var(--accent-2))}
.res h4{font-family:var(--font-display);font-size:16px;margin:6px 0 0;font-weight:600}
.res .cn{font-size:12px;color:var(--text-faint)}
.res .meta{font-family:var(--font-mono);font-size:11px;color:var(--sys);margin-top:auto;padding-top:8px}
.res .arrow{position:absolute;top:20px;right:20px;color:var(--text-faint);font-family:var(--font-mono)}

/* ===========================================================
   TIER LIST
   =========================================================== */
.tier-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.tier-filters button{font-family:var(--font-mono);font-size:13px;padding:7px 14px;border-radius:8px;
  background:var(--panel);border:1px solid var(--line-2);color:var(--text-dim);cursor:pointer;transition:.15s}
.tier-filters button.on{background:var(--accent);border-color:var(--accent);color:#fff}
.tier-table{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel)}
.tier-row{display:grid;grid-template-columns:74px 1fr;border-bottom:1px solid var(--line)}
.tier-row:last-child{border-bottom:none}
.tier-badge{display:grid;place-items:center;font-family:var(--font-pixel);font-size:18px;color:#0a0712;
  background:var(--tc)}
.tier-items{display:flex;flex-wrap:wrap;gap:8px;padding:14px}
.unit{display:inline-flex;align-items:center;gap:8px;padding:7px 12px 7px 9px;border-radius:9px;
  background:var(--panel-2);border:1px solid var(--line-2);font-size:13.5px;cursor:pointer;transition:.14s}
.unit:hover{border-color:var(--rc,var(--accent));transform:translateY(-2px)}
.unit .pip{width:9px;height:9px;border-radius:3px;background:var(--rc,var(--accent))}
.unit .sub{color:var(--text-faint);font-size:11px;font-family:var(--font-mono)}

/* ===========================================================
   NEWS / PATCH TIMELINE
   =========================================================== */
.news-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:20px}
.patchlist{display:flex;flex-direction:column;gap:0;border-left:2px solid var(--line-2);padding-left:0}
.patch{display:grid;grid-template-columns:120px 1fr;gap:18px;padding:18px 0 18px 22px;
  border-bottom:1px solid var(--line);position:relative}
.patch::before{content:"";position:absolute;left:-7px;top:24px;width:12px;height:12px;border-radius:50%;
  background:var(--bg);border:2px solid var(--accent)}
.patch.live::before{background:var(--sys);border-color:var(--sys);box-shadow:0 0 12px var(--sys)}
.patch:last-child{border-bottom:none}
.patch .date{font-family:var(--font-mono);font-size:12px;color:var(--text-faint)}
.patch .ver{font-family:var(--font-pixel);font-size:9px;color:var(--accent-2);margin-top:6px}
.patch h4{font-family:var(--font-display);font-size:17px;margin:0 0 6px;font-weight:600}
.patch p{font-size:13.5px;color:var(--text-dim);margin:0}

/* codes panel */
.codes{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;height:fit-content}
.codes-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.codes-head h3{font-family:var(--font-display);font-size:18px;margin:0;font-weight:600}
.code{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px dashed var(--line)}
.code:last-child{border-bottom:none}
.code code{font-family:var(--font-mono);font-size:14px;color:var(--sys);font-weight:700;letter-spacing:.02em}
.code .rw{font-size:12px;color:var(--text-faint);margin-left:2px}
.code .copy{margin-left:auto;font-family:var(--font-mono);font-size:11px;padding:5px 11px;border-radius:7px;
  background:var(--panel-2);border:1px solid var(--line-2);color:var(--text-dim);cursor:pointer;transition:.14s;flex:none}
.code .copy:hover{border-color:var(--sys);color:var(--sys)}
.code .copy.done{background:var(--sys);color:var(--sys-ink);border-color:var(--sys)}

/* ===========================================================
   BUILDS
   =========================================================== */
.build-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.build{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.build-top{padding:18px 20px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,color-mix(in oklab,var(--rc),transparent 90%),transparent)}
.build-top .role{font-family:var(--font-pixel);font-size:9px;color:var(--rc)}
.build-top h4{font-family:var(--font-display);font-size:19px;margin:6px 0 0;font-weight:600}
.build-body{padding:16px 20px;display:flex;flex-direction:column;gap:11px}
.build-row{display:flex;align-items:center;gap:10px;font-size:13.5px}
.build-row .k{font-family:var(--font-mono);font-size:11px;color:var(--text-faint);width:64px;flex:none}
.build-row .v{color:var(--text)}
.build-row .v .pip{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:6px;vertical-align:middle}

/* ===========================================================
   CHARACTER CODEX
   =========================================================== */
.codex-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.char{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;border:1px solid var(--line);
  background:var(--panel);transition:.18s;text-align:left}
.char:hover{transform:translateY(-4px);border-color:var(--rc);box-shadow:0 18px 40px -20px var(--rc)}
.char-vis{aspect-ratio:4/3;position:relative;display:grid;place-items:center;overflow:hidden;
  background:radial-gradient(circle at 50% 35%, color-mix(in oklab,var(--rc),transparent 55%), transparent 62%),var(--panel-2)}
.char-vis .mono{font-family:var(--font-pixel);font-size:clamp(20px,3vw,34px);color:#fff;
  text-shadow:0 0 22px var(--rc);opacity:.92}
.char-vis::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(10,7,18,.85));}
.char-rar{position:absolute;top:10px;left:10px;font-family:var(--font-pixel);font-size:7.5px;color:#fff;
  background:var(--rc);padding:4px 7px;border-radius:5px;z-index:2}
.char-info{padding:14px 16px}
.char-info .ttl{font-family:var(--font-mono);font-size:11px;color:var(--rc)}
.char-info h4{font-family:var(--font-display);font-size:16px;margin:3px 0 2px;font-weight:600;line-height:1.1}
.char-info .cn{font-size:12px;color:var(--text-faint)}
.char-info .class{font-size:12.5px;color:var(--text-dim);margin-top:8px;display:flex;align-items:center;gap:6px}
.char-info .class .pip{width:7px;height:7px;border-radius:2px;background:var(--rc)}

/* modal */
.modal-bg{position:fixed;inset:0;z-index:100;background:rgba(6,4,12,.82);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:24px}
.modal-bg.show{display:flex}
.modal{width:min(680px,100%);max-height:88vh;overflow-y:auto;background:var(--panel-2);
  border:1px solid var(--line-2);border-radius:18px;box-shadow:var(--shadow);position:relative}
.modal-hero{padding:28px;display:flex;gap:22px;align-items:center;border-bottom:1px solid var(--line);
  background:radial-gradient(circle at 18% 30%, color-mix(in oklab,var(--rc),transparent 70%), transparent 60%)}
.modal-emblem{width:96px;height:96px;border-radius:16px;flex:none;display:grid;place-items:center;
  font-family:var(--font-pixel);font-size:30px;color:#fff;background:
    radial-gradient(circle at 35% 30%,#fff5,transparent 60%),var(--rc);box-shadow:0 0 40px -8px var(--rc)}
.modal-hero .rar{margin-bottom:8px}
.modal-hero h3{font-family:var(--font-display);font-size:24px;margin:0;font-weight:700}
.modal-hero .cn{color:var(--text-dim);font-size:15px;margin-top:2px}
.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:9px;
  background:var(--panel-3);border:1px solid var(--line-2);color:var(--text);cursor:pointer;font-size:18px;z-index:5}
.modal-body{padding:24px 28px}
.infobox{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-bottom:18px}
.ib{background:var(--panel);padding:13px 15px}
.ib .k{font-family:var(--font-mono);font-size:10.5px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}
.ib .v{font-size:14.5px;color:var(--text);margin-top:4px}
.ib.full{grid-column:1/-1}
.skills{display:flex;flex-direction:column;gap:9px;margin-bottom:18px}
.skill{display:flex;gap:12px;align-items:baseline;padding:11px 14px;background:var(--panel);border-radius:10px;
  border:1px solid var(--line)}
.skill .key{font-family:var(--font-pixel);font-size:9px;color:var(--sys);flex:none;width:30px}
.skill .sn{font-family:var(--font-display);font-size:14.5px;font-weight:600}
.skill .sd{font-size:12.5px;color:var(--text-dim);margin-top:2px}
.modal-foot{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.modal-note{font-size:12px;color:var(--text-faint);margin-top:14px}

/* ===========================================================
   CONTROLS / TROUBLESHOOT
   =========================================================== */
.ctrl-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:20px}
.ctrl-table{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.ctrl-row{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;padding:13px 20px;
  border-bottom:1px solid var(--line)}
.ctrl-row:last-child{border-bottom:none}
.ctrl-row .act{font-size:14px;color:var(--text)}
.ctrl-row .act .cn{color:var(--text-faint);font-size:12px;margin-left:6px}
.keys{display:flex;gap:6px}
.keys kbd{font-family:var(--font-mono);font-size:12px;color:var(--text);background:var(--panel-3);
  border:1px solid var(--line-2);border-bottom-width:2px;border-radius:6px;padding:3px 9px;min-width:26px;text-align:center}
.faq{display:flex;flex-direction:column;gap:10px}
.faq details{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:0 18px}
.faq summary{cursor:pointer;padding:15px 0;font-family:var(--font-display);font-weight:600;font-size:15px;
  list-style:none;display:flex;align-items:center;gap:10px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"\25C6";color:var(--sys);font-size:10px}
.faq details[open] summary::before{transform:rotate(45deg)}
.faq p{margin:0 0 16px;padding-left:20px;color:var(--text-dim);font-size:13.5px}

/* ===========================================================
   FOOTER
   =========================================================== */
.foot{border-top:1px solid var(--line);margin-top:30px;padding:54px 0 40px;background:var(--bg-2)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;margin-bottom:36px}
.foot h5{font-family:var(--font-pixel);font-size:9px;color:var(--text-faint);margin:0 0 16px;letter-spacing:.5px}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.foot a{font-size:14px;color:var(--text-dim);transition:.14s}
.foot a:hover{color:var(--sys)}
.foot-brand .brand{margin-bottom:14px}
.foot-brand p{font-size:13px;color:var(--text-faint);max-width:38ch;margin:0}
.disclaimer{border-top:1px solid var(--line);padding-top:24px;font-size:12px;color:var(--text-faint);
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;line-height:1.6}
.disclaimer .cn{display:block}

/* ===========================================================
   TWEAKS PANEL (in-page)
   =========================================================== */
.tweak-fab{position:fixed;right:20px;bottom:20px;z-index:90;width:50px;height:50px;border-radius:14px;
  background:var(--accent);border:none;cursor:pointer;box-shadow:var(--glow-accent);
  display:grid;place-items:center;color:#fff;font-size:20px;transition:transform .15s}
.tweak-fab:hover{transform:rotate(40deg)}
.tweak-panel{position:fixed;right:20px;bottom:82px;z-index:91;width:280px;background:var(--panel-2);
  border:1px solid var(--line-2);border-radius:16px;box-shadow:var(--shadow);padding:18px;
  display:none;flex-direction:column;gap:16px}
.tweak-panel.open{display:flex}
.tweak-panel h4{font-family:var(--font-pixel);font-size:10px;color:var(--sys);margin:0;display:flex;align-items:center;gap:8px}
.tweak-grp .tl{font-size:12px;color:var(--text-faint);margin-bottom:8px;font-family:var(--font-mono)}
.seg{display:flex;gap:6px}
.seg button{flex:1;font-family:var(--font-body);font-size:12px;padding:8px 6px;border-radius:8px;
  background:var(--panel);border:1px solid var(--line-2);color:var(--text-dim);cursor:pointer;transition:.14s}
.seg button.on{background:var(--accent);border-color:var(--accent);color:#fff}
.swatches{display:flex;gap:8px}
.swatches button{width:32px;height:32px;border-radius:8px;border:2px solid transparent;cursor:pointer}
.swatches button.on{border-color:#fff}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:1180px){
  .rarity-row{grid-template-columns:repeat(3,1fr)}
  .route{grid-template-columns:repeat(3,1fr)}
  .step:nth-child(3){border-right:none}
  .res-grid{grid-template-columns:repeat(3,1fr)}
  .codex-grid{grid-template-columns:repeat(3,1fr)}
}
/* collapse nav to hamburger at ~1080px (per brief) */
@media (max-width:1080px){
  .nav-inner{grid-template-columns:auto 1fr auto}
  .search{display:none}
  .lang{display:inline-flex}
  .nav-cta{display:none}
  .hamburger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-art{order:-1;max-width:380px;margin:0 auto}
  .news-grid{grid-template-columns:1fr}
  .ctrl-grid{grid-template-columns:1fr}
  .build-grid{grid-template-columns:1fr}
  .sys-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .wrap,.nav-inner{padding:0 18px}
  .sec-pad{padding:54px 0}
  .rarity-row{grid-template-columns:repeat(2,1fr)}
  .route{grid-template-columns:1fr;}
  .step{border-right:none;border-bottom:1px solid var(--line)}
  .res-grid{grid-template-columns:repeat(2,1fr)}
  .sys-grid{grid-template-columns:1fr}
  .codex-grid{grid-template-columns:repeat(2,1fr)}
  .build-grid{grid-template-columns:1fr}
  .infobox{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .tier-row{grid-template-columns:56px 1fr}
  .brand-badge{display:none}
}
@media (max-width:430px){
  .codex-grid{grid-template-columns:1fr}
  .rarity-row{grid-template-columns:1fr}
  .hero-stats{gap:18px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
}

/* density tweak */
html[data-density="dense"] .sec-pad{padding:48px 0}
html[data-density="dense"] .sec-head{margin-bottom:22px}
html[data-density="dense"] .syscard{padding:18px}
html[data-density="dense"] .rar{min-height:172px;padding:16px 14px 14px}
html[data-density="dense"] .res{padding:16px}
html[data-density="dense"] .step{padding:20px 18px}
html[data-density="dense"] .hero{padding:36px 0 48px}

/* ===========================================================
   INNER PAGES (codes / tier-list / builds)
   =========================================================== */
.crumbs{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-family:var(--font-mono);
  font-size:12.5px;color:var(--text-faint);padding:22px 0 0}
.crumbs a{color:var(--text-dim)}
.crumbs a:hover{color:var(--sys)}
.crumbs .sep{opacity:.5}
.crumbs .cur{color:var(--sys)}

.page-hero{padding:26px 0 8px}
.page-hero h1{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.02;
  font-size:clamp(32px,5vw,58px);margin:14px 0 16px}
.page-hero h1 .grad{background:linear-gradient(96deg,var(--accent),var(--accent-2) 60%,var(--r-mythic));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.page-hero .lead{font-size:17.5px;color:var(--text-dim);max-width:62ch;margin:0}
.page-hero .lead b{color:var(--text)}
.page-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}

/* generic prose for guide copy */
.prose{max-width:72ch}
.prose p{color:var(--text-dim);margin:0 0 14px;font-size:15px;line-height:1.65}
.prose h3{font-family:var(--font-display);font-size:21px;margin:26px 0 10px;font-weight:600}
.prose b{color:var(--text)}
.prose ul{margin:0 0 14px;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.prose li{font-size:14.5px;color:var(--text-dim);padding-left:20px;position:relative}
.prose li::before{content:"\25C6";position:absolute;left:0;color:var(--sys);font-size:9px;top:5px}

/* full-width codes table on the codes page */
.code.lg{padding:15px 0}
.code.lg code{font-size:15.5px}

/* related inner-page cross-links */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px}
.related{display:flex;flex-direction:column;gap:8px;padding:22px;border-radius:14px;background:var(--panel);
  border:1px solid var(--line);transition:.18s;position:relative;overflow:hidden}
.related:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 14px 30px -18px var(--accent)}
.related .k{font-family:var(--font-pixel);font-size:10px;color:var(--sys)}
.related h4{font-family:var(--font-display);font-size:18px;margin:6px 0 2px;font-weight:600}
.related p{font-size:13px;color:var(--text-faint);margin:0}
.related .arrow{position:absolute;top:20px;right:20px;color:var(--text-faint);font-family:var(--font-mono)}

@media (max-width:1080px){ .related-grid{grid-template-columns:1fr} }
@media (max-width:720px){ .related-grid{grid-template-columns:1fr} }
