/* ---- SELF-HOSTED fonts ----------------------------------------------------------------------------
   All UI/combat fonts ship in the repo (fonts/, served by server.js) and are subset to the glyphs the
   game uses (see fonts/build-subset.py). No Google Fonts / installed-system-font dependency — the game
   renders identically offline. All four families are OFL-licensed (fonts/OFL-*.txt). The Cormorant and
   Noto faces are VARIABLE (one file spans the weight range); Space Mono / Zhi Mang Xing are static. */
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:400 700;font-display:swap;
  src:url('fonts/CormorantGaramond-var.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:400 700;font-display:swap;
  src:url('fonts/CormorantGaramond-Italic-var.woff2') format('woff2')}
@font-face{font-family:'Noto Serif SC';font-style:normal;font-weight:200 900;font-display:swap;
  src:url('fonts/NotoSerifSC-var.woff2') format('woff2')}
@font-face{font-family:'Space Mono';font-style:normal;font-weight:400;font-display:swap;
  src:url('fonts/SpaceMono-Regular.woff2') format('woff2')}
@font-face{font-family:'Space Mono';font-style:normal;font-weight:700;font-display:swap;
  src:url('fonts/SpaceMono-Bold.woff2') format('woff2')}
@font-face{font-family:'Zhi Mang Xing';font-style:normal;font-weight:400;font-display:swap;
  src:url('fonts/ZhiMangXing-Regular.woff2') format('woff2')}

:root{
  /* Palette now lives in theme.css ([data-theme] blocks). :root keeps only fonts +
     fallback so a no-JS first paint still resolves. */
  --mono:'Space Mono',ui-monospace,monospace;
  --serif:'Cormorant Garamond',Georgia,serif;
  --cjk:'Noto Serif SC',serif;
  --brush:'Zhi Mang Xing','Noto Serif SC',serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:
    radial-gradient(900px 620px at 82% -12%, rgba(var(--blood-rgb),0.10), transparent 70%),
    radial-gradient(760px 560px at -8% 112%, rgba(47,125,91,0.06), transparent 70%),
    var(--bg);
  color:var(--bone); font-family:var(--serif); font-size:18px; line-height:1.45;
  -webkit-font-smoothing:antialiased; overflow:hidden;
}
/* film grain + vignette (lifted from the design sheet) */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  opacity:0.035;mix-blend-mode:overlay;
}
body::after{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;
  background:radial-gradient(ellipse 74% 74% at 50% 50%, transparent 64%, var(--vignette) 100%);
}

/* ---------- typography helpers ---------- */
.brush,.cjk{font-family:var(--cjk)}
.mono{font-family:var(--mono)}
.muted{color:var(--muted)} .small{font-size:14px} .tiny{font-size:11.5px}
.blood-text{color:var(--blood-bright)} .jade-text{color:var(--jade)}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:0.34em;text-transform:uppercase;color:var(--muted)}
.rule{height:1px;background:var(--line);border:0;margin:0}
.row{display:flex;justify-content:space-between;align-items:center;gap:10px}
.row.left{justify-content:flex-start} .row.start{align-items:flex-start}
.wrap{flex-wrap:wrap} .gap{gap:10px} .right{text-align:right;margin-top:12px}

/* ---------- buttons ---------- */
button{
  font-family:var(--mono);cursor:pointer;color:var(--bone-dim);
  border:1px solid var(--line);background:linear-gradient(180deg,var(--btn-hi),var(--btn-lo));
  padding:8px 15px;border-radius:2px;letter-spacing:0.16em;font-size:11px;text-transform:uppercase;
  transition:.16s ease;
}
button:hover:not(:disabled){border-color:var(--line-strong);color:var(--bone);background:rgba(var(--line-rgb),0.05)}
button:disabled{opacity:.3;cursor:not-allowed}
button.primary{border-color:rgba(var(--blood-bright-rgb),0.55);color:var(--blood-text);background:linear-gradient(180deg,rgba(var(--blood-rgb),0.16),rgba(var(--blood-deep-rgb),0.10))}
button.primary:hover:not(:disabled){border-color:var(--blood-bright);color:var(--blood-text);background:rgba(var(--blood-rgb),0.22)}
button.danger{border-color:var(--blood-dim);color:var(--bone-dim)}
button.danger:hover:not(:disabled){border-color:var(--blood-bright);color:var(--blood-bright)}
button.mini{font-size:10px;padding:3px 8px;min-width:0;letter-spacing:0.1em}
.hidden{display:none!important}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:0}
::-webkit-scrollbar-track{background:transparent}

/* ---------- title / save slots ---------- */
#title{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;position:relative}
#title::after{content:"魔道";position:absolute;font-family:var(--cjk);font-weight:900;font-size:440px;color:rgba(var(--bone-rgb),0.022);z-index:0;pointer-events:none;letter-spacing:.1em}
#title .sub{color:var(--muted);letter-spacing:.4em;font-size:12px;text-transform:uppercase;font-family:var(--mono);z-index:1}
#title h1{font-family:var(--cjk);font-weight:900;font-size:96px;color:var(--bone);line-height:1;z-index:1;
  text-shadow:0 0 50px rgba(var(--blood-rgb),0.35),0 4px 0 #000}
#title h1 .accent{color:var(--blood-bright)}
.slots{display:flex;flex-direction:column;gap:12px;width:480px;margin-top:30px;z-index:1}
.slot{border:1px solid var(--line);background:var(--bg2);padding:16px 18px;display:flex;justify-content:space-between;align-items:center;gap:12px;transition:.16s}
.slot:hover{border-color:var(--line-strong)}
.auth-bar{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin:0 0 18px;
  padding:13px 18px;border:1px solid var(--line);background:linear-gradient(170deg,var(--bg2),var(--panel))}
.auth-bar .auth-cta,.auth-bar .auth-who{font-family:var(--serif);font-size:14px;color:var(--bone-dim);letter-spacing:.03em}
.auth-bar .auth-who b{color:var(--stone)}
.mig-list{display:flex;flex-direction:column;gap:8px}
.mig-row{display:flex;align-items:center;gap:11px;padding:11px 13px;border:1px solid var(--line);background:var(--bg2);cursor:pointer}
.mig-row:hover{border-color:var(--line-strong)}
.mig-row input{accent-color:var(--blood-bright);cursor:pointer}
.mig-row span{font-family:var(--serif);font-size:14px;color:var(--bone-dim)}
.mig-row b{color:var(--bone)}
.slot .meta{font-size:12px;color:var(--muted);font-family:var(--mono);letter-spacing:.04em;margin-top:3px}
.slot .nm{font-family:var(--serif);font-weight:600;font-size:18px;letter-spacing:.08em;color:var(--bone)}
.slot .acts{display:flex;gap:8px}

/* ---------- layout: topbar + nav + content ---------- */
#game{height:100%;display:grid;grid-template-rows:auto 1fr}
#topbar{display:flex;align-items:center;gap:26px;padding:12px 26px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg3),var(--panel))}
#topbar .logo{font-family:var(--cjk);font-weight:900;font-size:30px;color:var(--blood-bright);text-shadow:0 2px 10px rgba(var(--blood-rgb),0.4);transform:translateY(-1px)}
.stat{display:flex;flex-direction:column;line-height:1.15;gap:2px}
.stat .lbl{font-size:9.5px;letter-spacing:.22em;color:var(--muted);text-transform:uppercase;font-family:var(--mono)}
.stat .val{font-size:19px;font-family:var(--mono);color:var(--bone);letter-spacing:.02em}
.stat .val.stone{color:var(--stone)} .stat .val.jade{color:var(--jade)} .stat .val.immstone{color:var(--immstone)}
#topbar .spacer{flex:1}
#main{display:grid;grid-template-columns:208px 1fr;min-height:0;transition:grid-template-columns .18s ease}
#nav{border-right:1px solid var(--line);display:flex;flex-direction:column;min-height:0;background:rgba(var(--shadow-rgb),0.5)}
/* collapse toggle (top of sidebar) */
.nav-toggle{align-self:flex-end;width:26px;height:26px;margin:8px 10px 2px;padding:0;flex:none;
  display:flex;align-items:center;justify-content:center;font-size:15px;line-height:1;color:var(--muted);
  border:1px solid transparent;border-radius:3px;background:transparent;letter-spacing:0}
.nav-toggle:hover{color:var(--bone);background:rgba(var(--line-rgb),0.05);border-color:var(--line)}
/* scrolling tab list — extra bottom padding clears the bottom-left gear FAB */
.nav-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:2px;padding:2px 12px 78px}
.nav-scroll::-webkit-scrollbar{width:6px}
.nav-scroll::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px}
.nav-scroll::-webkit-scrollbar-track{background:transparent}
/* grouped sections */
.nav-group{display:flex;flex-direction:column;gap:2px}
.nav-grp-head{display:flex;align-items:center;gap:11px;width:100%;padding:11px 14px;font-family:var(--mono);
  font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--bone-dim);
  user-select:none;background:none;border:none;cursor:pointer;transition:color .15s ease,background .15s ease}
.nav-grp-head:hover{color:var(--bone);background:rgba(var(--line-rgb),0.04)}
.nav-grp-head:hover .nav-grp-ico{color:var(--blood-bright)}
.nav-grp-head:hover .nav-grp-chev{color:var(--bone-dim)}
.nav-grp-lbl{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-grp-chev{margin-left:auto;font-size:11px;color:var(--muted);line-height:1;transition:transform .15s ease,color .15s ease}
.nav-group.collapsed .nav-grp-chev{transform:rotate(-90deg)}
#main:not(.rail) .nav-group.collapsed button[data-tab]{display:none}
/* a collapsed group holding the active tab keeps its header lit so the current tab stays findable */
#main:not(.rail) .nav-group.collapsed:has(button[data-tab].active) .nav-grp-head{color:var(--bone)}
#main:not(.rail) .nav-group.collapsed:has(button[data-tab].active) .nav-grp-ico{color:var(--blood-bright)}
.nav-group + .nav-group{margin-top:7px;padding-top:7px;border-top:1px solid var(--line)} /* section divider */
.nav-grp-ico{flex:none;width:18px;text-align:center;font-family:var(--cjk);font-size:17px;color:var(--stone);line-height:1}
#nav button[data-tab]{display:flex;align-items:center;gap:11px;text-align:left;background:transparent;
  border:1px solid transparent;border-left:2px solid transparent;padding:10px 14px;font-size:13px;
  font-weight:500;letter-spacing:.12em;color:var(--bone-dim);border-radius:0;position:relative}
#nav button[data-tab]:hover{background:rgba(var(--line-rgb),0.04);color:var(--bone)}
#nav button[data-tab].active{border-left-color:var(--blood-bright);background:linear-gradient(90deg,rgba(var(--blood-rgb),0.12),transparent);color:var(--bone)}
.nav-ico{flex:none;width:18px;text-align:center;font-family:var(--cjk);font-size:15px;line-height:1}
.nav-lbl{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* ---- collapsed icon rail ---- */
#main.rail{grid-template-columns:60px 1fr}
#main.rail .nav-scroll{padding-left:0;padding-right:0}
#main.rail .nav-lbl,#main.rail .nav-grp-lbl{display:none}
#main.rail #nav button[data-tab]{justify-content:center;gap:0;padding:10px 0}
#main.rail .nav-ico{width:auto;font-size:17px}
#main.rail .nav-grp-head{justify-content:center;padding:9px 0 5px;pointer-events:none;cursor:default}
#main.rail .nav-grp-chev{display:none}
#main.rail .nav-group + .nav-group{border-top:1px solid var(--line);margin-top:4px;padding-top:2px}
#main.rail .nav-grp-ico{font-size:14px}
#main.rail .navbadges{right:7px;top:6px;transform:none}
#main.rail .nav-toggle{align-self:center;margin:8px auto 4px}
/* nav notification badges (e.g. fighters with unspent attribute points; duplicate copies to imprint) */
.navbadges{position:absolute;right:11px;top:50%;transform:translateY(-50%);display:flex;gap:4px;pointer-events:none}
.navbadge{display:none}
.navbadge.on{display:grid;place-items:center;
  min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--blood-bright);color:var(--on-accent);
  font-family:var(--mono);font-weight:700;font-size:10px;line-height:1;letter-spacing:0;
  box-shadow:0 0 0 3px rgba(var(--blood-bright-rgb),0.16);animation:navpulse 1.8s ease-in-out infinite}
/* duplicate-set badge: brass accent so it reads as a distinct alert from the red unspent-points one */
.navbadge.dup.on{background:var(--brass);color:#241c0c;box-shadow:0 0 0 3px rgba(176,139,62,0.18);animation:navpulse-dup 1.8s ease-in-out infinite}
/* daily-quest badge: jade accent (the Immortal-Essence colour) so it reads as a reward, distinct from the others */
.navbadge.quest.on{background:var(--jade);color:#06150e;box-shadow:0 0 0 3px rgba(63,158,116,0.20);animation:navpulse-quest 1.8s ease-in-out infinite}
/* vital-gu choice badge: stone/gold accent (the Vital Gu 本命蛊 colour) — active fighters awaiting a core pick */
.navbadge.vital.on{background:var(--stone);color:#241c0c;box-shadow:0 0 0 3px rgba(199,154,69,0.20);animation:navpulse-vital 1.8s ease-in-out infinite}
@keyframes navpulse-quest{0%,100%{box-shadow:0 0 0 3px rgba(63,158,116,0.20)}50%{box-shadow:0 0 0 6px rgba(63,158,116,0.0)}}
@keyframes navpulse{0%,100%{box-shadow:0 0 0 3px rgba(var(--blood-bright-rgb),0.16)}50%{box-shadow:0 0 0 6px rgba(var(--blood-bright-rgb),0.0)}}
@keyframes navpulse-dup{0%,100%{box-shadow:0 0 0 3px rgba(176,139,62,0.20)}50%{box-shadow:0 0 0 6px rgba(176,139,62,0.0)}}
@keyframes navpulse-vital{0%,100%{box-shadow:0 0 0 3px rgba(199,154,69,0.22)}50%{box-shadow:0 0 0 6px rgba(199,154,69,0.0)}}
#content{overflow:auto;padding:0 38px 90px;min-height:0;position:relative}

/* ---------- page header (per tab) ---------- */
.pagehead{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center;
  padding:30px 0 24px;border-bottom:1px solid var(--line);margin-bottom:30px}
.pagehead .seal{
  width:74px;height:74px;flex:none;display:grid;place-items:center;
  background:linear-gradient(160deg,var(--blood) 0%,var(--blood-deep) 100%);
  color:var(--on-accent);font-family:var(--cjk);font-weight:900;font-size:42px;line-height:1;
  border:1px solid rgba(243,233,218,0.22);transform:rotate(-3deg);
  box-shadow:0 0 0 5px rgba(var(--blood-rgb),0.08),0 14px 30px -16px rgba(var(--blood-rgb),0.7);
  text-shadow:0 2px 6px rgba(0,0,0,0.45);
}
.pagehead .ph-eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:0.3em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.pagehead h1{font-family:var(--serif);font-weight:600;font-size:38px;letter-spacing:0.16em;text-transform:uppercase;color:var(--bone);line-height:1}
.pagehead .ph-sub{font-family:var(--serif);font-size:17px;color:var(--bone-dim);margin-top:9px;max-width:120ch;line-height:1.5}

/* ---------- section header (CJK numeral) ---------- */
.sec-head{display:flex;align-items:baseline;gap:16px;margin:38px 0 18px;flex-wrap:wrap}
.sec-head .sec-num{font-family:var(--cjk);font-weight:900;font-size:26px;color:var(--blood);line-height:1}
.sec-head .sec-title{font-family:var(--serif);font-weight:600;font-size:23px;letter-spacing:0.16em;text-transform:uppercase;color:var(--bone);white-space:nowrap}
.sec-head .sec-meta{margin-left:auto;font-family:var(--mono);font-size:10.5px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.sec-head::after{content:"";flex:0 0 100%;height:1px;background:var(--line);margin-top:-8px;order:5}
/* legacy in-card heading */
.sec{font-family:var(--serif);font-weight:600;color:var(--bone);font-size:16px;letter-spacing:.12em;text-transform:uppercase;margin:16px 0 8px}
.ptitle{font-family:var(--serif);font-weight:600;font-size:26px;letter-spacing:.1em;text-transform:uppercase;color:var(--bone);margin-bottom:6px}
.psub{color:var(--bone-dim);margin-bottom:18px;max-width:120ch}

/* ---------- cards / pills / tags ---------- */
.grid{display:grid;gap:14px} .cards{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}
.card{border:1px solid var(--line);background:linear-gradient(170deg,var(--bg2),var(--panel));padding:17px 18px;position:relative}
.body{font-size:16px;line-height:1.6;color:var(--bone-dim)}
.big{font-family:var(--serif);font-weight:600;font-size:17px;letter-spacing:.04em}
.uname{font-family:var(--serif);font-weight:600} .uname.big{font-size:19px;letter-spacing:.05em;color:var(--bone)}
.pill{display:inline-block;font-size:10px;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;
  padding:3px 9px;border-radius:2px;border:1px solid var(--line);color:var(--bone-dim);vertical-align:middle}
.pill.unique{color:var(--t10);border-color:var(--t10);margin-left:6px}
.pill.glow{color:var(--jade);border-color:var(--jade-dim);box-shadow:0 0 10px rgba(63,158,116,0.3)}
.tag{font-size:10px;font-family:var(--mono);letter-spacing:.16em;padding:4px 10px;border-radius:2px;border:1px solid var(--line);color:var(--bone-dim);text-transform:uppercase}
.tag.on{color:var(--jade);border-color:var(--jade-dim)}
.tag.blood{border-color:rgba(var(--blood-bright-rgb),0.5);color:var(--blood-text);background:rgba(var(--blood-rgb),0.08)}
.tag.auto{color:var(--blood-bright);border-color:rgba(var(--blood-bright-rgb),0.65);background:rgba(var(--blood-rgb),0.12);animation:autopulse 1.4s ease-in-out infinite}
@keyframes autopulse{0%,100%{opacity:1}50%{opacity:.55}}
.tierbadge{font-family:var(--mono);font-weight:700;border:1px solid;padding:1px 7px;border-radius:2px;font-size:11px;letter-spacing:.04em}
.rar{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase}

/* ---------- battle controls + arena ---------- */
.ctl{display:flex;gap:10px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.ctl .ctl-sep{flex:1 1 auto}
/* arena stacked over a full-width combat feed (feed occupies the lower half) */
.battle-stack{display:flex;flex-direction:column;gap:16px}
.feedwrap{display:flex;flex-direction:column;gap:8px}
.feed-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
/* arena = three stacked sections: the battlefield grids, a centred Floor·Wave meta bar, then the
   per-side Cultivators & Gu panels */
.arena{border:1px solid var(--line);background:radial-gradient(70% 90% at 50% 30%,rgba(var(--blood-rgb),0.06),transparent 70%),var(--bg2);
  padding:30px 40px;min-height:380px;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}
.arena::before{content:"戦";position:absolute;left:50%;top:30px;transform:translateX(-50%);font-family:var(--cjk);font-weight:900;font-size:340px;color:rgba(var(--bone-rgb),0.022);pointer-events:none;z-index:0}
/* the battlefield row: each side fills half, teams hug the outer edges and face across the centre */
.arena-top{display:flex;align-items:flex-start;justify-content:center;gap:30px;width:100%;position:relative;z-index:1}
.bside{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}
.bside.ally{align-items:flex-start} .bside.foe{align-items:flex-end}
.bvs{flex:none;font-family:var(--cjk);color:var(--blood);font-size:40px;align-self:center;opacity:.45;z-index:1}
.bgrid{display:grid;grid-template-columns:repeat(2,minmax(150px,196px));grid-template-rows:repeat(5,minmax(62px,auto));gap:10px}
/* centred meta bar: current floor + "Wave X of Y", sitting just before the Cultivators & Gu details */
.arena-meta{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;position:relative;z-index:2}
.arena-floor,.wave-indicator{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  background:rgba(var(--shadow-rgb),0.72);padding:6px 16px;white-space:nowrap}
.wave-indicator{color:var(--bone-dim);border:1px solid var(--line)}
.arena-floor{color:var(--stone);border:1px solid rgba(199,154,69,0.4)}
.arena-floor.boss{color:var(--blood-text);border-color:rgba(var(--blood-bright-rgb),0.55);background:rgba(var(--blood-rgb),0.14)}
.arena-floor.arena-vs{color:var(--blood-text);border-color:rgba(var(--blood-bright-rgb),0.55);background:rgba(var(--blood-rgb),0.14)}
/* ranked-bout VICTORY/DEFEAT stamp over the battlefield (added/removed by playTimeline + showArenaResult) */
.arena-result{position:absolute;inset:0;z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  background:radial-gradient(60% 60% at 50% 45%,rgba(var(--shadow-rgb),0.82),rgba(var(--shadow-rgb),0.52));pointer-events:none;animation:arResult .45s cubic-bezier(.2,.9,.25,1) both}
.arena-result .ar-verdict{font-family:var(--cjk);font-weight:900;font-size:100px;line-height:.9;text-shadow:0 4px 30px rgba(0,0,0,0.6)}
.arena-result .ar-title{font-family:var(--mono);font-size:22px;letter-spacing:.42em;text-indent:.42em;font-weight:700}
.arena-result .ar-opp{font-family:var(--serif);font-size:19px;color:var(--bone);font-style:italic}
.arena-result .ar-delta{font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--bone-dim)}
.arena-result.win .ar-verdict,.arena-result.win .ar-title{color:var(--jade)}
.arena-result.lose .ar-verdict,.arena-result.lose .ar-title{color:var(--blood-bright)}
@keyframes arResult{from{opacity:0;transform:scale(1.14)}to{opacity:1;transform:scale(1)}}
/* floating "skip to result" for ranked arena bouts (added/removed by runBattle around the bout playback) */
.arena-skip{position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:6;pointer-events:auto;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);
  background:rgba(var(--shadow-rgb),0.82);border:1px solid rgba(199,154,69,0.5);padding:7px 16px;cursor:pointer;border-radius:2px;
  transition:background .15s,color .15s,border-color .15s}
.arena-skip:hover{background:rgba(199,154,69,0.16);color:var(--bone);border-color:var(--stone)}
.side-lbl{font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--muted);text-transform:uppercase}
/* per-side "Auras & Traits" panels, side by side below the meta bar */
.arena-panels{display:flex;gap:30px;width:100%;position:relative;z-index:1}
/* per-side "Auras & Traits" panel — who carries what, and the team auras + sources */
.trait-panel{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:2px;
  border-top:1px solid var(--line);padding-top:8px}
.trait-panel.foe{text-align:right}
.trait-panel .tp-h{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:7px 0 2px}
.trait-panel .tp-h:first-child{margin-top:0}
.tp-row{display:flex;align-items:flex-start;gap:7px;line-height:1.3}
.trait-panel.foe .tp-row{flex-direction:row-reverse}
.tp-seal{flex:none;font-family:var(--cjk);font-weight:700;font-size:12px;line-height:1;width:18px;height:18px;
  display:flex;align-items:center;justify-content:center;border:1px solid;border-radius:2px;background:rgba(var(--shadow-rgb),0.6);margin-top:1px}
.tp-body{min-width:0}
.tp-body b{font-family:var(--serif);font-weight:600;font-size:11.5px;color:var(--bone)}
.tp-aura .tp-body b{color:var(--brass)}
.tp-src{font-family:var(--mono);font-size:9.5px;color:var(--bone-dim)}
.tp-eff{display:block;font-family:var(--mono);font-size:9.5px;color:var(--muted);letter-spacing:.02em}
.tp-empty{font-family:var(--mono);font-size:10px;color:var(--muted)}
/* per-cultivator block: trait row + its equipped-Gu list (name + effect) */
.tp-unit{padding:6px 0;border-bottom:1px solid rgba(var(--bone-rgb),0.05)}
.tp-unit:last-child{border-bottom:none}
/* Gu flow HORIZONTALLY (each Gu = a name-over-effect column) and wrap across the panel's width,
   so a loadout reads as a compact row instead of a tall stack. */
.tp-gu{list-style:none;margin:5px 0 0;padding:0 0 0 25px;display:flex;flex-flow:row wrap;gap:5px 22px}
.trait-panel.foe .tp-gu{padding:0 25px 0 0;justify-content:flex-end}
.tp-gu li{display:flex;flex-direction:column;gap:1px;line-height:1.3;min-width:0;max-width:240px}
.tp-gu li b{font-family:var(--serif);font-weight:600;font-size:11.5px;color:var(--bone-dim)}
.tp-gueff{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:.02em}
.tp-nogu{font-family:var(--mono);font-size:9px;color:var(--muted);padding:2px 0 0 25px;opacity:.7}
.trait-panel.foe .tp-nogu{padding:2px 25px 0 0}
/* archetype-line bonuses (combat lines fold a personal stat bag into the unit; support lines hint to the aura) */
.tp-lineeff{font-family:var(--mono);font-size:9px;letter-spacing:.02em;line-height:1.4;padding:3px 0 1px 25px}
.trait-panel.foe .tp-lineeff{padding:3px 25px 1px 0}
.tp-lineeff.muted{color:var(--muted)}
.side{margin-bottom:14px}

/* arena unit blocks (ATB) */
.ublock{position:relative;border:1px solid var(--line);background:var(--bg3);padding:10px 12px;display:flex;flex-direction:column;justify-content:center;transition:transform .11s ease,opacity .25s,filter .15s}
.ublock.enemy{border-color:var(--blood-deep);background:var(--bg3)}
.ublock.back{border-style:dashed;opacity:.82}
.ublock.ub-cult{border-color:rgba(176,139,62,0.5)} .ublock.enemy.ub-cult{border-color:rgba(176,107,62,0.6)}
.ublock.dead{opacity:.2;filter:grayscale(1)}
.ublock .ub-name{font-family:var(--serif);font-weight:600;font-size:14.5px;line-height:1.2;margin-bottom:8px;color:var(--bone);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;padding-right:20px}
/* corner TRAIT SEAL — the unit's archetype-line glyph, top-right; reserves a gutter via the paddings above/below */
.ub-trait{position:absolute;top:6px;right:8px;z-index:2;font-family:var(--cjk);font-weight:700;font-size:13px;line-height:1;
  width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:1px solid;border-radius:2px;background:rgba(var(--shadow-rgb),0.72)}
/* Gu CHANNEL indicator (bottom-right): equipped Gu currently channelled vs total. Amber when a Gu is
   starved out (active < total) — essence too low to channel the whole loadout. */
.ub-gu{position:absolute;bottom:6px;right:8px;z-index:2;font-family:var(--cjk);font-size:9.5px;line-height:1;
  color:#8a7d6e;opacity:.6;letter-spacing:.02em;pointer-events:none}
.ub-gu.starved{color:#e0a23a;opacity:1;font-weight:700;text-shadow:0 0 4px rgba(224,162,58,.5),0 1px 2px #000}
/* active-status badge row across the top of a unit block */
.ub-status{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:6px;min-height:14px;align-content:flex-start;padding-right:20px}
.ub-status:empty{margin:0;min-height:0}
.ust{font-family:var(--mono);font-size:8px;font-weight:700;letter-spacing:.06em;line-height:1.4;padding:0 3px;
  border:1px solid;border-radius:0;background:rgba(0,0,0,0.32)}
.ust>b{font-weight:700;margin-left:2px;opacity:.85}
/* KILLER MOVE: positive buff chip — subtle glow + tinted backing so gains read apart from debuffs */
.ust.ust-buff{background:rgba(199,154,69,0.14);text-shadow:0 0 4px currentColor}
/* active buffs mirrored into the side "Cultivators & Gu" panel row */
.tp-buffs{display:flex;flex-flow:row wrap;gap:4px;padding:3px 0 1px 25px}
.trait-panel.foe .tp-buffs{padding:3px 25px 1px 0;justify-content:flex-end}
.ub-bar{height:7px;background:var(--inset);overflow:hidden;margin-top:4px}
.ub-bar>i{display:block;height:100%;width:100%}
/* HP / Essence bars carry their current value overlaid at the right edge */
.ub-bar.val{height:14px;position:relative}
.ub-bar.val>i{position:absolute;left:0;top:0;height:100%}
.ub-num{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;pointer-events:none;
  font-family:var(--mono);font-weight:700;font-size:9px;line-height:1;color:#f3ecdf;letter-spacing:.02em;
  text-shadow:0 1px 2px #000,0 0 3px #000}
.ub-bar.hp>i{background:linear-gradient(90deg,var(--jade-dim),var(--jade));transition:width .18s ease}
.ublock.enemy .ub-bar.hp>i{background:linear-gradient(90deg,var(--blood-deep),var(--blood-bright))}
.ub-bar.ess>i{background:linear-gradient(90deg,#235d72,var(--essence));transition:width .18s ease}
.ub-bar.chg>i{width:0;background:linear-gradient(90deg,#5a4a86,#9a86c8);transition:width .18s linear}
.ublock.full .ub-bar.chg>i{background:linear-gradient(90deg,var(--brass),#fff0bd)}
.ublock.atk-a{transform:translateX(14px)} .ublock.atk-f{transform:translateX(-14px)}
/* a lunging actor (and its whole side) ride above the rest of the board while it strikes across the arena */
.ublock.lunging{z-index:5}
.bside.lunge-active{z-index:6}
.ublock.hit{animation:ubhit .2s}
@keyframes ubhit{0%{filter:none}30%{filter:brightness(2.4)}100%{filter:none}}
.dmgpop{position:absolute;left:50%;top:0;transform:translateX(-50%);font-family:var(--brush);font-weight:400;font-size:42px;letter-spacing:.02em;color:#ff9d8a;pointer-events:none;text-shadow:0 2px 4px #000,0 0 3px #000;animation:dmgrise .82s ease-out forwards;z-index:3;white-space:nowrap}
.dmgpop.crit{color:var(--stone);font-size:48px}
.dmgpop.crit.lucky{color:#b79bff;font-size:54px;text-shadow:0 0 10px rgba(157,123,255,0.67),0 1px 2px #000}
.dmgpop.miss{color:var(--muted);font-weight:400}
.dmgpop.dot{color:#c97bff;font-size:36px}
/* distinct DoT tick numbers — Burn / Poison / Bleed */
.dmgpop.dot-burn{color:#ff7a3c} .dmgpop.dot-poison{color:#7bdc5a} .dmgpop.dot-bleed{color:#ff5a6a}
.dmgpop.stun{color:var(--stone);font-size:33px;letter-spacing:.08em}
.dmgpop.stun.frozen{color:#8fd9ff;text-shadow:0 0 6px rgba(143,217,255,0.53),0 1px 2px #000}
.dmgpop.status{color:#7fe0ff;font-size:33px;font-weight:400;letter-spacing:.04em}
/* inflicted-status labels, coloured per status (match the on-block badges) */
.dmgpop.status-burn{color:#ff7a3c} .dmgpop.status-poison{color:#7bdc5a} .dmgpop.status-bleed{color:#ff5a6a}
.dmgpop.status-slow{color:#5aa9e6} .dmgpop.status-weaken{color:#b79bff} .dmgpop.status-sunder{color:#e0a23c}
.dmgpop.status-frail{color:#ef82c6} .dmgpop.status-stun{color:#e8c777} .dmgpop.status-frozen{color:#8fd9ff}
/* Mender aura feedback: green heal numbers + a softer "cleansed" tag */
.dmgpop.heal{color:#7be0a0;text-shadow:0 0 6px rgba(123,224,160,.45),0 1px 2px #000}
.dmgpop.cleanse{color:#9fe8d0;font-size:30px;font-weight:400;letter-spacing:.05em}
@keyframes dmgrise{0%{opacity:0;transform:translate(-50%,6px)}18%{opacity:1}100%{opacity:0;transform:translate(-50%,-64px)}}
/* KILLER MOVE: shield (temp HP) overlay on the HP bar — translucent cyan hatch, width = shield/maxHP */
.ub-bar.hp .ub-shield{position:absolute;left:0;top:0;height:100%;z-index:1;pointer-events:none;transition:width .18s ease;
  background:repeating-linear-gradient(135deg,rgba(143,217,255,.55) 0 4px,rgba(143,217,255,.22) 4px 8px);
  box-shadow:inset 0 0 0 1px rgba(143,217,255,.5)}
/* The "+shield" amount appended to the HP number — cyan to match the shield overlay */
.ub-bar.hp .ub-num .ub-sh-num{color:#8fd9ff;text-shadow:0 0 3px rgba(143,217,255,.5),0 1px 2px #000}
/* KILLER MOVE: name banner + path glyph float, and the casting actor's glow */
.dmgpop.combo{color:var(--stone);font-size:46px;font-weight:400;letter-spacing:.06em;z-index:4;animation-duration:1.32s;text-shadow:0 0 8px rgba(199,154,69,.65),0 2px 4px #000,0 0 3px #000}
/* The killer-move NAME stays in the brush font (--brush, inherited); the large background CJK glyph
   reverts to the previous serif (--cjk, Noto Serif SC) at its old heavy weight — cleaner than the
   cursive brush for a single big character. */
.dmgpop.combo-cjk{color:#fff0bd;font-family:var(--cjk);font-weight:900;font-size:86px;line-height:1;z-index:1;animation-duration:1.32s;
  text-shadow:0 0 14px rgba(199,154,69,.65),0 0 26px rgba(199,154,69,.35),0 2px 5px #000}
.ublock.casting{filter:brightness(1.35) drop-shadow(0 0 8px rgba(199,154,69,.7))}
/* KILLER MOVE target auras: a coloured glow on each affected unit for the cast's duration. Red = hostile
   (damage / debuff) · green = heal & buff · blue = guard / tank buff · red-orange = warcry (ATK rally). */
.ublock.km-aura{transition:box-shadow .12s ease;border-radius:3px;z-index:4}
.ublock.km-hostile{box-shadow:0 0 0 2px rgba(var(--blood-bright-rgb),.85),0 0 20px 5px rgba(var(--blood-bright-rgb),.6)}
.ublock.km-heal{box-shadow:0 0 0 2px rgba(63,176,138,.9),0 0 20px 5px rgba(63,176,138,.6)}
.ublock.km-guard{box-shadow:0 0 0 2px rgba(70,150,220,.9),0 0 20px 5px rgba(70,150,220,.6)}
.ublock.km-warcry{box-shadow:0 0 0 2px rgba(224,103,62,.95),0 0 20px 5px rgba(224,103,62,.65)}
/* Team-tab inline killer-move editor (on roster cards) — an open card spans the full grid row for room */
.card.member.km-open{grid-column:1 / -1}
.km-row{display:flex;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}
.km-row .mini{white-space:nowrap}
.km-sum{font-size:12px}
.km-editor{margin-top:12px;border-top:1px solid var(--line);padding-top:12px;cursor:default}
/* KILLER MOVE config block (character sheet) */
.killer-block{margin-top:6px}
.killer-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.killer-row>b{font-family:var(--serif);font-size:16px;color:var(--bone)}
.killer-block .mini{font-size:11px;padding:3px 10px}
.killer-gus{display:flex;flex-wrap:wrap;gap:6px}
.killer-gu{font-family:var(--mono);font-size:11px;padding:5px 9px;border:1px solid var(--line);background:rgba(20,16,12,.5);color:var(--bone-dim);border-radius:5px;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.killer-gu .cjk{font-size:14px}
.killer-gu.on{background:rgba(199,154,69,.14);font-weight:700}
.killer-gu.off{opacity:.32;cursor:not-allowed}
.killer-gu:not(.off):hover{border-color:var(--bone-dim)}
.killer-hint{margin-top:9px;font-size:12px;color:var(--muted);border-left:2px solid var(--line);padding-left:10px}
/* PROGRESSION GATE: locked killer-move panel (rank 3+ / Floor 100) */
.killer-locked{opacity:.92}
.km-reqs{list-style:none;margin:9px 0 2px;padding:0;display:flex;flex-direction:column;gap:5px}
.km-reqs li{font-family:var(--mono);font-size:12px;padding-left:2px}
.km-req-ok{color:#6fcf97}
.km-req-no{color:var(--muted)}
/* archetype picker, grouped by favored domain */
.killer-chooser{display:flex;flex-direction:column;gap:10px}
.killer-domgroup{border:1px solid var(--line-soft);border-radius:6px;padding:8px 10px 10px}
.killer-domgroup.active{border-color:rgba(199,154,69,.4);background:rgba(199,154,69,.04)}
.killer-domhead{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin-bottom:7px;
  font-family:var(--serif);font-size:14px;color:var(--bone);text-transform:uppercase;letter-spacing:.06em}
.killer-archgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(172px,1fr));gap:6px}
.killer-arch{display:flex;flex-direction:column;gap:3px;align-items:stretch;text-align:left;padding:7px 10px;
  border:1px solid var(--line);background:rgba(20,16,12,.5);border-radius:5px;cursor:pointer;color:var(--bone-dim)}
.killer-arch .ka-top{display:flex;align-items:baseline;justify-content:space-between;gap:6px}
.killer-arch b{font-family:var(--serif);font-size:14px}
.killer-arch .ka-deliv{font-family:var(--mono);font-size:8.5px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
.killer-arch .ka-desc{font-family:var(--mono);font-size:10px;line-height:1.35;color:var(--muted)}
.killer-arch:hover{border-color:var(--bone-dim)}
.killer-arch.on{border-color:var(--stone);background:rgba(199,154,69,.14);color:var(--bone)}
.killer-arch.on .ka-desc{color:var(--bone-dim)}
/* archetype unlock cost: locked archetypes are dimmed with a jade price badge; the free first pick a brass FREE tag */
.killer-arch.locked{opacity:.72}
.killer-arch.locked:hover{opacity:1}
.killer-arch .ka-cost{font-family:var(--mono);font-size:8.5px;color:var(--jade);letter-spacing:.04em;white-space:nowrap}
.killer-arch .ka-cost.free{color:var(--brass)}
.killer-preview{margin-top:14px;border:1px solid rgba(199,154,69,.4);background:rgba(199,154,69,.06);border-radius:6px;padding:12px 14px}
.killer-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.killer-head b{font-family:var(--serif);font-size:18px;color:var(--bone)}
.killer-ops{margin:10px 0 6px;padding-left:18px;font-size:12.5px;line-height:1.7;color:var(--bone-dim)}

/* combat feed */
.log{border:1px solid var(--line);background:rgba(var(--shadow-rgb),0.6);padding:12px 15px;height:44vh;min-height:280px;overflow:auto;
  font-family:var(--mono);font-size:12.5px;line-height:1.7;font-variant-numeric:tabular-nums}
.log .l{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:3px 0;border-bottom:1px solid var(--line-soft);color:var(--bone-dim)}
.log .l .l-msg{min-width:0;flex:1}
.log .l .l-time{flex:none;color:var(--muted);font-weight:400;font-size:10.5px;letter-spacing:.04em;white-space:nowrap;opacity:.85}
.log .l.win{color:var(--jade);font-weight:700} .log .l.lose{color:var(--blood-bright)} .log .l.loot{color:var(--stone)}
.log .l.rare{color:#e0a36e;font-weight:700;letter-spacing:.01em}

/* ---------- team: formation board ---------- */
.member{position:relative}
.formation{margin-bottom:8px}
.fmboard{display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:center;margin-top:14px;max-width:600px}
.fmrowlbl{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);text-align:right;padding-right:8px}
.fmrow{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.fmtile{border:1px dashed var(--line);min-height:60px;display:flex;align-items:center;justify-content:center;padding:5px;background:rgba(12,9,8,0.5);transition:border-color .12s,background .12s}
.fmtile.on{border-style:solid;background:var(--bg3)}
.fmtile.drop{border-color:var(--jade);background:rgba(47,125,91,0.12)}
.fmunit{position:relative;display:flex;flex-direction:column;gap:2px;align-items:center;width:100%;cursor:grab}
.fmunit:active{cursor:grabbing}
.fmunit .uname{font-family:var(--serif);font-weight:600;font-size:13px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.fmunit .fmrealm{font-family:var(--mono);font-size:9px;letter-spacing:.03em;color:var(--bone-dim);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.fmbench .teamctl{margin:10px 0 14px}
.fmx{position:absolute;top:-8px;right:-6px;padding:0 5px;font-size:10px;line-height:1.6}
.fmbench{margin-top:16px}
.fmbenchrow{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.fmbench .fmunit{width:auto;border:1px solid var(--line);padding:8px 12px;background:var(--bg3)}

/* ---------- team member card ---------- */
.member.clickable{cursor:pointer;transition:border-color .15s,transform .12s}
.member.clickable:hover{border-color:var(--line-strong);transform:translateY(-2px)}
/* active-team slots (6) on the Team page */
.teamslots{margin-bottom:8px}
.teamslot.empty{border-style:dashed;display:grid;place-items:center;text-align:center;min-height:200px}
.teamslot .uname.big:hover{color:var(--blood-bright)}
/* "points to allocate" indicator + card accent */
.alloc-note{margin-top:10px;font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--stone);border:1px solid rgba(199,154,69,0.4);background:rgba(199,154,69,0.08);padding:6px 10px;cursor:pointer;transition:.14s}
.alloc-note:hover{border-color:var(--stone);background:rgba(199,154,69,0.16);color:#e8c777}
.member.has-alloc,.teamslot.has-alloc{border-color:rgba(199,154,69,0.5);box-shadow:0 0 0 1px rgba(199,154,69,0.12) inset}
/* Soul-Imprint duplicate banner (Team tab roster section) */
.dup-banner{border-color:rgba(176,139,62,0.4);background:linear-gradient(180deg,rgba(176,139,62,0.07),rgba(0,0,0,0.18));margin-bottom:14px}
.dup-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:13px}
.dup-chip{display:flex;align-items:center;gap:8px;text-transform:none;letter-spacing:0;font-family:var(--serif);font-size:13px;
  padding:7px 11px;border-color:rgba(176,139,62,0.35)}
.dup-chip:hover:not(:disabled){border-color:var(--brass);background:rgba(176,139,62,0.12);color:var(--bone)}
.dup-chip .cjk{font-size:15px} .dup-chip .tiny{font-family:var(--mono)}
/* Soul-Imprint level shown as compact gold stars — used on every character representation */
.imp-stars{color:var(--brass);font-size:10px;letter-spacing:.5px;line-height:1;white-space:nowrap;
  text-shadow:0 1px 1px rgba(0,0,0,.55);vertical-align:baseline}
/* arena unit-block variant: its own tight line under the name, never crowding the bars */
.ub-imp{display:block;margin:-4px 0 7px;font-size:9px;letter-spacing:0}
.statline{display:flex;gap:16px;font-size:13px;color:var(--muted);margin-top:10px;flex-wrap:wrap;font-family:var(--mono)}
.statline b{color:var(--bone);font-weight:700} .statline.big{font-size:14px}
.derived{margin-top:6px;line-height:1.5;font-family:var(--mono);font-size:11px}
.cult{color:var(--jade);font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;margin-top:3px}
.active-mark{position:absolute;top:14px;right:16px;font-size:10px;color:var(--jade);font-family:var(--mono);letter-spacing:.1em}
.xpbar{height:5px;background:var(--inset);overflow:hidden;margin-top:9px}
.xpbar>i{display:block;height:100%;background:linear-gradient(90deg,var(--jade-dim),var(--jade))}

/* attribute allocation panel */
.attrs{margin-top:12px;padding:11px 12px;border:1px solid var(--line);background:rgba(0,0,0,0.15)}
.attrs .row.between{display:flex;justify-content:space-between;align-items:center}
.steprow{display:flex;gap:5px;margin:9px 0}
.attrgrid{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px}
.attrrow{display:flex;align-items:center;gap:7px}
.attrrow .ak{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--muted);width:28px}
.attrrow .av{color:var(--bone);font-size:15px;min-width:36px;text-align:right;font-family:var(--mono)}
.attrrow .apts{flex:1;font-family:var(--mono)}
.attrrow button.plus{margin-left:auto}

/* Gu slot chips */
.slot-row{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap}
.slot-row .slot{border:1px dashed var(--line);padding:7px 10px;font-size:12px;min-width:96px;text-align:center;color:var(--muted);cursor:pointer;font-family:var(--mono);letter-spacing:.04em;background:rgba(12,9,8,0.4);transition:.13s;display:block;justify-content:unset;align-items:unset}
.slot-row .slot.filled{border-style:solid;color:var(--bone)} .slot-row .slot:hover{border-color:var(--jade-dim);color:var(--bone)}

/* ---------- character sheet (the hero view) ---------- */
.sheet{max-width:1180px;margin:0 auto}
.cs-metabar{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:16px 0 13px;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.cs-metabar b{color:var(--blood-bright);font-weight:400} .cs-metabar .c{color:var(--bone-dim);letter-spacing:.26em}
.cs-back{margin:20px 0 0;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.cs-nav{display:flex;align-items:center;gap:8px}
.cs-nav-pos{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--bone-dim);min-width:52px;text-align:center}

.cs-ident{display:grid;grid-template-columns:auto 1fr auto;gap:40px;align-items:center;padding:40px 0 36px;border-bottom:1px solid var(--line)}
.cs-seal{width:118px;height:118px;flex:none;display:grid;place-items:center;
  font-family:var(--cjk);font-weight:900;font-size:64px;line-height:1;color:var(--on-accent);
  background:linear-gradient(160deg,var(--blood) 0%,var(--blood-deep) 100%);
  border:1px solid rgba(243,233,218,0.25);transform:rotate(-3deg);
  box-shadow:0 0 0 6px rgba(var(--blood-rgb),0.10),0 18px 40px -18px rgba(var(--blood-rgb),0.7);text-shadow:0 2px 6px rgba(0,0,0,0.45)}
.cs-ident-main{min-width:0}
.cs-name{font-family:var(--serif);font-weight:700;font-size:46px;letter-spacing:.06em;color:var(--bone);line-height:1;margin-bottom:8px}
.cs-realm{font-family:var(--cjk);font-weight:600;font-size:22px;color:var(--blood-bright);margin-bottom:4px}
.cs-sub{font-family:var(--serif);font-size:18px;color:var(--bone-dim)}
.cs-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
/* Character-sheet identity chips a touch larger for readability (other .tag chips are unchanged). */
.cs-tags .tag{font-size:12px;padding:5px 11px;letter-spacing:.12em}
/* THEMED hover tooltip — a single body-level portal card (#tip-pop) positioned with JS so it NEVER
   clips against scroll/overflow ancestors. Rich tooltips keep their markup in a hidden .tip data
   holder inside a .tip-host; plain native title="" hints are intercepted and shown as a .tip-line.
   See ui.js initTooltips(). */
.tip-host{cursor:help}
.tip{display:none}
#tip-pop{position:fixed;z-index:9999;display:none;pointer-events:none;
  width:max-content;max-width:300px;padding:9px 12px 10px;
  text-align:left;text-transform:none;letter-spacing:normal;line-height:1.4;
  background:linear-gradient(180deg,var(--bg3),var(--panel));border:1px solid var(--line-strong);
  border-top:2px solid var(--blood);border-radius:3px;
  box-shadow:0 12px 30px rgba(0,0,0,.6),inset 0 0 0 1px rgba(0,0,0,.35);
  font-family:var(--serif);color:var(--bone)}
#tip-pop.on{display:block;animation:tiprise .14s ease-out}
@keyframes tiprise{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
#tip-pop .tip-head{display:block;font-family:var(--cjk);font-weight:600;font-size:14px;letter-spacing:.02em;color:var(--on-accent)}
#tip-pop .tip-sub{display:block;margin-top:2px;font-style:italic;font-size:12.5px;color:var(--muted)}
#tip-pop .tip-eff{display:flex;flex-direction:column;gap:3px;margin-top:8px;padding-top:7px;border-top:1px solid var(--line)}
#tip-pop .tip-eff>span{font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--stone)}
#tip-pop .tip-line{display:block;font-size:13px;color:var(--bone-dim)}
#tip-pop::after{content:"";position:absolute;left:var(--arrow-x,20px);transform:translateX(-50%);border:7px solid transparent}
#tip-pop:not(.below)::after{top:100%;border-top-color:var(--line-strong)}
#tip-pop.below::after{bottom:100%;border-bottom-color:var(--line-strong)}
.cs-aside{text-align:right;font-family:var(--mono);font-size:11px;line-height:2.1;color:var(--muted);letter-spacing:.06em}
.cs-aside b{display:block;color:var(--bone);font-weight:400;font-size:14px;letter-spacing:.1em;font-family:var(--serif)}
.cs-aside .k{font-size:9.5px;letter-spacing:.2em}

/* portrait + at-a-glance */
.cs-glance{display:grid;grid-template-columns:300px 1fr;gap:30px;align-items:stretch;margin-top:30px}
.cs-portrait{position:relative;border:1px solid var(--line);min-height:300px;display:grid;place-items:center;overflow:hidden;
  background:radial-gradient(62% 76% at 50% 40%,rgba(var(--blood-rgb),0.16),transparent 72%),var(--panel)}
.cs-portrait .glyph{font-family:var(--cjk);font-weight:900;font-size:200px;color:var(--bone);opacity:.9;text-shadow:0 18px 50px rgba(0,0,0,0.6);line-height:1}
.cs-portrait .pcap{position:absolute;bottom:0;left:0;right:0;border-top:1px solid var(--line);padding:11px 14px;display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:rgba(var(--shadow-rgb),0.55)}
.cs-portrait .pcap b{color:var(--blood-bright);font-weight:400}
.cs-vitals{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.vital{background:var(--bg2);padding:18px 20px;display:flex;flex-direction:column;justify-content:center;gap:5px}
.vital .vk{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.vital .vv{font-family:var(--mono);font-size:30px;color:var(--bone);line-height:1;letter-spacing:.01em}
.vital .vv.hp{color:var(--jade)} .vital .vv.atk{color:var(--blood-bright)}

/* spec rows (dt/dd) */
.spec{border-top:1px solid var(--line)}
.spec-row{display:grid;grid-template-columns:170px 1fr;gap:20px;padding:13px 2px;border-bottom:1px solid var(--line-soft)}
.spec-row dt{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);padding-top:4px}
.spec-row dd{margin:0;font-family:var(--serif);font-size:18px;color:var(--bone);letter-spacing:.02em}
.spec-row dd .cjk{color:var(--blood-bright);margin-left:6px;font-size:15px}
.spec-row dd .mono{font-family:var(--mono);font-size:15px}

/* attribute board on the sheet */
.cs-attrs{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.cs-attr{background:var(--bg2);padding:18px 16px;text-align:center;position:relative}
.cs-attr .an{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.cs-attr .av{font-family:var(--mono);font-size:38px;color:var(--bone);line-height:1.1;margin:6px 0 2px}
.cs-attr .apts{font-family:var(--mono);font-size:10px;color:var(--bone-dim);letter-spacing:.06em}
.cs-attr .ad{font-family:var(--serif);font-size:12.5px;color:var(--muted);margin-top:7px;line-height:1.45;min-height:34px}
.cs-attr .av .stg{font-size:14px;color:var(--stone);margin-left:5px;vertical-align:middle}
.cs-attr.staged{box-shadow:inset 0 0 0 1px var(--stone)}
.cs-step{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px}
.cs-step button.step{width:34px;padding:5px 0;font-size:15px;line-height:1}
.cs-step .step-amt{font-family:var(--mono);font-size:13px;color:var(--bone);min-width:40px;text-align:center}
.staged-pill{border-color:var(--stone)!important;background:rgba(199,154,69,0.14)!important;color:#e8c777!important}
.cs-alloc{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}

/* stat grid on the sheet */
.cs-statgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.cs-stat{background:var(--bg2);padding:14px 16px;display:flex;flex-direction:column;gap:4px}
.cs-stat .sk{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.cs-stat .sv{font-family:var(--mono);font-size:19px;color:var(--bone)}

/* daily quests board */
.quest-list{display:flex;flex-direction:column;gap:1px;background:var(--line);border:1px solid var(--line)}
.quest-row{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg2)}
.quest-row .q-mark{flex:0 0 auto;width:26px;height:26px;display:grid;place-items:center;border-radius:50%;
  font-family:var(--mono);font-size:13px;color:var(--muted);border:1px solid var(--line)}
.quest-row.full .q-mark{color:var(--brass);border-color:var(--brass)}
.quest-row.ready .q-mark{color:var(--jade);border-color:var(--jade)}
.quest-row.claimed .q-mark{color:var(--jade);border-color:var(--jade-dim);background:rgba(63,158,116,0.08)}
.quest-row .q-body{flex:1 1 auto;min-width:0}
.quest-row .q-label{font-family:var(--serif);font-size:16px;color:var(--bone)}
.quest-row.claimed .q-label{color:var(--muted);text-decoration:line-through;text-decoration-color:var(--jade-dim)}
.quest-row .q-hint{font-size:12px;color:var(--muted);margin:2px 0 7px}
.quest-row .q-bar{height:5px;background:var(--line);border-radius:3px;overflow:hidden}
.quest-row .q-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--brass),var(--jade));transition:width .3s ease}
.quest-row.claimed .q-bar span{background:var(--jade-dim)}
.quest-row .q-side{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;gap:6px;min-width:120px}
.quest-row .q-count{font-family:var(--mono);font-size:13px;color:var(--bone-dim)}
.quest-row .q-reward{font-family:var(--mono);font-size:12px;color:var(--jade);letter-spacing:.04em}
.quest-row .q-claimed{font-family:var(--mono);font-size:12px;color:var(--jade-dim);letter-spacing:.06em}
.quest-row .q-claim{padding:6px 12px;white-space:nowrap}
.quest-row.bonus{background:linear-gradient(90deg,rgba(176,139,62,0.06),rgba(63,158,116,0.06))}
.quest-row.bonus .q-label{font-family:var(--display,var(--serif));letter-spacing:.02em}

/* Gu cards on the sheet + refinery grid */
.gu-card{border:1px solid var(--line);background:linear-gradient(170deg,var(--bg2),var(--panel));padding:18px 18px 16px;position:relative;overflow:hidden}
.gu-card::before{content:"";position:absolute;right:-40px;top:-40px;width:130px;height:130px;border-radius:50%;
  background:radial-gradient(circle,rgba(63,158,116,0.12),transparent 70%);pointer-events:none}
.gu-card.empty{border-style:dashed;cursor:pointer;display:grid;place-items:center;min-height:150px;color:var(--muted);font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.gu-card.empty:hover{border-color:var(--jade-dim);color:var(--bone-dim)}
.gu-cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px}
.gu-top{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);position:relative;z-index:1}
.gu-glyph{font-family:var(--cjk);font-weight:600;font-size:40px;line-height:1;margin:12px 0 2px;position:relative;z-index:1}
.gu-name{font-family:var(--serif);font-weight:600;font-size:19px;color:var(--bone);position:relative;z-index:1}
.gu-eff{font-family:var(--mono);font-size:11px;color:var(--bone-dim);line-height:1.7;margin-top:9px;position:relative;z-index:1}
/* per-Gu essence channel cost (cyan, distinct from the ✦ Immortal Essence currency) */
.gu-ess{font-family:var(--mono);font-size:10.5px;color:var(--essence);letter-spacing:.04em;line-height:1.6}
.gu-card .gu-ess{display:block;margin-top:7px;position:relative;z-index:1}
.gu-foot{margin-top:13px;padding-top:11px;border-top:1px solid var(--line);font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--jade);position:relative;z-index:1}
/* Channel PRIORITY (slot order) — badge + reorder controls + starved state. Slot order = the order Gu
   light up in battle until essence runs out; "starved" Gu fall past the full-aperture budget. */
.gu-prio{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.06em;padding:2px 5px;border-radius:2px;
  border:1px solid var(--jade-dim);color:var(--jade);background:rgba(63,158,116,0.1);margin-right:6px;vertical-align:middle}
.gu-prio.starved{border-color:var(--blood);color:var(--blood-bright);background:rgba(var(--blood-rgb),0.12)}
.gu-reorder{display:inline-flex;gap:3px}
.gu-move{font-family:var(--mono);font-size:11px;line-height:1;padding:2px 5px;border:1px solid var(--line);border-radius:2px;
  background:transparent;color:var(--bone-dim);cursor:pointer}
.gu-move:hover{border-color:var(--blood-bright);color:var(--blood-bright)}
.gu-move.disabled{opacity:.25;pointer-events:none}
.gu-card.starved{opacity:.62;filter:saturate(.55)}
.gu-card.starved:hover{opacity:.85}
.gu-starved{font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;color:var(--blood-bright);margin-top:8px;position:relative;z-index:1}
.gu-aperture-note{font-family:var(--mono);font-size:11px;line-height:1.6;color:var(--muted);margin-bottom:13px;letter-spacing:.02em}
.gu-aperture-note b{color:var(--bone)}
.starved-ink{color:var(--blood-bright)}
/* Gu TAGS — a Gu's effect kinds; refinement fodder must cover these between them */
.gu-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:7px;position:relative;z-index:1}
.gu-tag{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-dim);border:1px solid var(--line);border-radius:2px;padding:1px 6px;white-space:nowrap}
.gurow-tags{display:flex;flex-wrap:wrap;align-items:center;gap:4px;font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--muted);line-height:1.5;margin:2px 0}

/* dao / comprehension rows */
.markwrap{margin-top:10px;display:flex;flex-direction:column;gap:6px}
.markrow{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--line);padding:8px 12px;font-size:14px;background:rgba(0,0,0,0.12)}
.markrow button{padding:4px 9px}
.compbar{height:5px;background:var(--inset);overflow:hidden;margin-top:6px;width:140px}
.compbar>i{display:block;height:100%;background:linear-gradient(90deg,var(--jade-dim),var(--jade))}

/* ---------- recruit ---------- */
.pulls{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:12px;margin-top:22px}
.pull{border:1px solid var(--line);padding:18px 14px;text-align:center;background:var(--bg2);animation:rise .4s ease both;position:relative;overflow:hidden}
.pull .pglyph{font-family:var(--cjk);font-weight:900;font-size:54px;opacity:.12;position:absolute;top:-6px;right:4px;line-height:1}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------- gu refinery / inventory ---------- */
.pathsec{margin-bottom:26px}
.pathhdr{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.pathhdr.clickable{cursor:pointer;user-select:none;transition:border-color .15s}
.pathhdr.clickable:hover{border-bottom-color:var(--ink)}
.pathhdr.clickable:hover .pname{text-decoration:underline}
.pathhdr .gucaret{font-size:12px;width:14px;color:var(--muted);flex:0 0 auto}
.pathhdr .pglyph{font-family:var(--cjk);font-weight:900;font-size:24px;line-height:1}
.pathhdr .pname{font-family:var(--serif);font-weight:600;font-size:19px;letter-spacing:.06em}
.viewtoggle{display:inline-flex;margin:0 0 16px}
.viewtoggle.wrap{flex-wrap:wrap;margin:0}
.viewtoggle button{font-size:10px;padding:6px 13px;border-radius:0}
.viewtoggle button:not(:first-child){border-left:none}
.teamctl{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:0 0 18px}
.teamctl .viewtoggle{margin:0}
.teamctl select{background:var(--bg3);color:var(--bone);border:1px solid var(--line);border-radius:0;padding:7px 10px;font-size:11px;font-family:var(--mono);letter-spacing:.08em;cursor:pointer;text-transform:uppercase}
.teamctl input.searchbox{background:var(--bg3);color:var(--bone);border:1px solid var(--line);border-radius:0;padding:7px 10px;font-size:11px;font-family:var(--mono);letter-spacing:.08em;min-width:190px}
.teamctl input.searchbox::placeholder{color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.teamctl input.searchbox:focus{outline:none;border-color:var(--stone)}
.gulist,.reslist{display:flex;flex-direction:column;gap:6px}
.gurow,.resrow{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);padding:9px 13px;background:var(--bg2)}
.gurow{align-items:center}
.gurow.locked{opacity:.85;border-style:dashed} /* still readable: the missing-ingredients line must be legible */
.gurow-main{display:flex;flex-direction:column;gap:5px;min-width:0;flex:1}
.gurow-top{display:flex;align-items:center;gap:9px;flex-wrap:wrap;min-width:0}
.gurow-recipe{font-family:var(--mono);font-size:11px;color:var(--bone-dim);letter-spacing:.02em;line-height:1.5}
.gurow-need{font-family:var(--mono);font-size:11px;color:var(--blood-bright);letter-spacing:.02em;line-height:1.5}
.gurow>button{flex:none}
.resrow .rq{font-family:var(--mono);color:var(--bone);white-space:nowrap}

/* inventory grid */
.resgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:9px}
.restile{border:1px solid var(--line);border-left:3px solid var(--line);padding:10px 12px;background:var(--bg2);min-width:0}
.restile .rn{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:7px;color:var(--bone)}
.restile .rrow{display:flex;justify-content:space-between;align-items:center;gap:6px}
.restile .rq{font-family:var(--mono);font-size:15px;color:var(--bone)}
.restile.clk{cursor:pointer;transition:border-color .15s,transform .12s,background .15s}
.restile.clk:hover{border-color:var(--blood-bright);transform:translateY(-1px);background:var(--bg3)}

/* ---------- floors ---------- */
.floorgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:9px}
.floor{border:1px solid var(--line);padding:13px;background:var(--bg2);cursor:pointer;text-align:center;transition:.13s}
.floor:hover{border-color:var(--line-strong)} .floor.locked{opacity:.3;cursor:not-allowed}
.floor.boss{border-color:var(--blood-dim)}
.floor.farming{border-color:var(--stone);box-shadow:0 0 0 1px var(--stone) inset}
.floor .fnum{font-family:var(--mono);font-size:17px;color:var(--bone);letter-spacing:.02em}
.floor .muted{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;margin-top:4px}

/* ---------- modal & toast ---------- */
#overlay{position:fixed;inset:0;background:rgba(0,0,0,0.72);display:flex;align-items:center;justify-content:center;z-index:50;backdrop-filter:blur(2px)}
.modal{width:540px;max-height:82vh;overflow:auto;border:1px solid var(--line-strong);background:var(--bg2);padding:24px;
  box-shadow:0 30px 80px -30px rgba(0,0,0,0.9)}
.modal.wide{width:min(1180px,94vw)}
.modal h3{font-family:var(--serif);font-weight:600;font-size:20px;letter-spacing:.1em;text-transform:uppercase;color:var(--bone);margin-bottom:14px}
/* bulk-dismiss modal: roomier than the default, with a tall scrollable checklist */
.modal.bulk{width:min(840px,94vw)}
/* bulk-dismiss checklist: scrollable list of benched cultivators with a checkbox per row */
.bulk-list{max-height:54vh;overflow:auto;border:1px solid var(--line);margin:4px 0 2px}
.bulk-row{display:flex;align-items:center;gap:11px;padding:8px 12px;border-bottom:1px solid var(--line);cursor:pointer;font-size:14px}
.bulk-row:last-child{border-bottom:none}
.bulk-row:hover{background:rgba(var(--line-rgb),0.045)}
.bulk-row input[type=checkbox]{width:16px;height:16px;flex:none;cursor:pointer;accent-color:var(--blood-bright)}
.bulk-row .bulk-name{font-family:var(--serif);font-weight:600;color:var(--bone)}
.bulk-row .stone{font-family:var(--mono);font-size:12px}
.pickrow{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;border:1px solid var(--line);margin-bottom:7px;font-size:14px}
/* equip-Gu picker rows: multi-line info column (tier · name · path · effect · essence) + right button */
.pickrow.gu-pick{align-items:flex-start;gap:14px}
.gu-pick .gp-info{flex:1;min-width:0}
.gp-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.gp-name{font-family:var(--serif);font-weight:600;font-size:15px;color:var(--bone)}
.gp-path{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--muted)}
.gu-pick .gu-eff{margin-top:6px}
.gu-pick > button{flex:none;align-self:center}
/* toast stack: host is fixed bottom-centre, toasts flow as a column (newest at the bottom) */
#toast-host{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);z-index:80;
  display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}
.toast{background:var(--bg3);border:1px solid var(--blood-dim);color:var(--blood-text);pointer-events:auto;max-width:84vw;text-align:center;
  padding:11px 20px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;animation:rise .3s both;
  box-shadow:0 12px 30px -16px rgba(0,0,0,0.8)}
.toast.out{animation:toastout .42s ease forwards}
@keyframes toastout{to{opacity:0;transform:translateY(10px)}}
/* realm-up (ascension) toast — jade/stone, distinct from the default blood toast */
.toast.ascend{border-color:var(--jade-dim);color:var(--jade);background:linear-gradient(180deg,rgba(47,125,91,0.14),var(--bg3))}
/* first-visit tab tip — a readable sentence (not the uppercase mono action toast), jade accent */
.toast.tip{border-color:var(--jade-dim);color:var(--bone);background:linear-gradient(180deg,rgba(47,125,91,0.12),var(--bg3));
  text-transform:none;letter-spacing:.01em;font-family:var(--serif);font-size:15px;line-height:1.45;text-align:left;max-width:400px;padding:13px 18px}

/* ---------- announcement banner: a floating, self-fading milestone notice across the TOP of the screen ---------- */
#banner-host{position:fixed;top:0;left:50%;transform:translateX(-50%);z-index:90;
  display:flex;flex-direction:column;gap:10px;align-items:center;padding-top:22px;pointer-events:none}
.banner{pointer-events:auto;display:flex;align-items:center;gap:16px;max-width:90vw;
  padding:14px 30px;background:linear-gradient(180deg,var(--bg3),var(--panel));
  border:1px solid var(--line-strong);border-top:2px solid var(--essence);
  box-shadow:0 22px 60px -22px rgba(0,0,0,0.9),0 0 34px -10px rgba(70,179,207,0.28);
  animation:bannerin .5s cubic-bezier(.2,.9,.3,1.2) both}
.banner.out{animation:bannerout .7s ease forwards}
.banner .b-seal{font-size:30px;line-height:1;color:var(--essence);text-shadow:0 0 16px rgba(70,179,207,0.45)}
.banner .b-text{display:flex;flex-direction:column;gap:3px}
.banner .b-text b{font-family:var(--serif);font-size:19px;letter-spacing:.04em;color:var(--bone)}
.banner .b-sub{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--bone-dim)}
.banner .b-sub .essence{color:var(--essence)}
@keyframes bannerin{from{opacity:0;transform:translateY(-26px)}to{opacity:1;transform:none}}
@keyframes bannerout{to{opacity:0;transform:translateY(-20px)}}

/* ---------- onboarding: First-Steps floating widget (sits below modals + toasts) ---------- */
#onboard-host{position:fixed;right:22px;bottom:22px;z-index:40;pointer-events:none}
.onboard-widget{pointer-events:auto;width:312px;max-width:calc(100vw - 44px);
  border:1px solid var(--line-strong);background:linear-gradient(170deg,var(--bg3),var(--panel));
  box-shadow:0 24px 60px -24px rgba(0,0,0,0.9),0 0 0 4px rgba(var(--blood-rgb),0.05);animation:rise .3s both}
.ob-head{display:flex;align-items:center;gap:9px;padding:12px 14px;border-bottom:1px solid var(--line);
  background:linear-gradient(90deg,rgba(var(--blood-rgb),0.12),transparent)}
.ob-seal{font-family:var(--cjk);font-weight:900;font-size:22px;color:var(--blood-bright);line-height:1}
.ob-title{font-family:var(--serif);font-weight:600;font-size:15px;letter-spacing:.14em;text-transform:uppercase;color:var(--bone)}
.ob-prog{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--stone);letter-spacing:.06em}
.ob-x{min-width:0;padding:2px 7px;font-size:11px;letter-spacing:0;border-color:transparent;color:var(--muted)}
.ob-x:hover:not(:disabled){color:var(--blood-bright);border-color:var(--blood-dim);background:transparent}
.ob-steps{padding:8px 14px 13px}
.onboard-step{display:flex;align-items:center;gap:9px;padding:5px 0;font-family:var(--serif);font-size:15px}
.ob-mark{font-family:var(--mono);font-size:13px;width:16px;text-align:center;flex:none}
.ob-label{flex:1;line-height:1.3}
.onboard-step.done{color:var(--muted)}
.onboard-step.done .ob-mark{color:var(--jade)}
.onboard-step.done .ob-label{text-decoration:line-through;text-decoration-color:var(--jade-dim)}
.onboard-step.pending{color:var(--bone-dim)} .onboard-step.pending .ob-mark{color:var(--muted)}
.onboard-step.current{color:var(--bone)} .onboard-step.current .ob-mark{color:var(--blood-bright)}
.ob-go{min-width:0;padding:3px 10px;font-size:10px;letter-spacing:.08em}
.ob-hint{font-family:var(--mono);font-size:11px;line-height:1.5;color:var(--muted);margin:0 0 6px 25px;padding-left:9px;border-left:1px solid var(--line)}
.ob-foot{margin-top:9px;padding-top:10px;border-top:1px solid var(--line)}
.ob-guide{width:100%;padding:7px 10px;font-size:10px;letter-spacing:.1em;border-color:rgba(63,158,116,0.4);color:var(--jade)}
.ob-guide:hover:not(:disabled){border-color:var(--jade);color:var(--jade);background:rgba(63,158,116,0.08)}

/* ---------- Codex / beginner's guide ---------- */
.cdx-onboard{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;
  border:1px solid rgba(63,158,116,0.3);background:linear-gradient(170deg,rgba(47,125,91,0.08),var(--panel));
  padding:13px 16px;margin-bottom:14px;font-size:15px;color:var(--bone-dim)}
.cdx-onboard button{flex:none}
.cdx-toc{display:flex;flex-wrap:wrap;gap:7px;margin:-2px 0 6px}
.cdx-tab{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;
  color:var(--bone-dim);border:1px solid var(--line);border-radius:2px;padding:4px 10px;transition:.16s}
.cdx-tab:hover{border-color:var(--blood-dim);color:var(--bone);background:rgba(var(--line-rgb),0.04)}
/* Expand/Collapse-all toggle in the TOC row */
.cdx-allbtn{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;
  color:var(--muted);border:1px solid var(--line);border-radius:2px;padding:4px 10px;background:none;transition:.16s;margin-left:auto}
.cdx-allbtn:hover{border-color:var(--blood-dim);color:var(--bone);background:rgba(var(--line-rgb),0.04)}
/* GUIDE: collapsible sections — native <details>, collapsed by default so the page opens short */
.cdx-sec{scroll-margin-top:14px}
.cdx-sec>summary{list-style:none;cursor:pointer;outline:none}
.cdx-sec>summary::-webkit-details-marker{display:none}
.cdx-sec>summary::marker{content:""}
.cdx-sec>summary .sec-head{margin:18px 0 14px}
.cdx-sec>summary .sec-head::before{content:"▸";order:-1;align-self:center;color:var(--blood);font-size:12px;line-height:1}
.cdx-sec[open]>summary .sec-head::before{content:"▾"}
.cdx-sec>summary:hover .sec-title{color:var(--blood-bright)}
.cdx-sec[open]{margin-bottom:8px}
.cdx-list{list-style:none;margin:11px 0 4px;padding:0;display:flex;flex-direction:column;gap:6px}
.cdx-list li{font-size:15.5px;line-height:1.4;padding-left:14px;position:relative}
.cdx-list li::before{content:"·";position:absolute;left:2px;color:var(--blood-bright);font-weight:700}
/* codex reference tables (Dao-path focus stats, archetype rarity ladders) — no row striping, just rules */
.cdx-cat{font-family:var(--serif);font-style:italic;color:var(--blood-bright);font-size:14px;letter-spacing:.04em;margin:18px 0 2px}
.cdx-cat:first-child{margin-top:10px}
.cdx-table{width:100%;border-collapse:collapse;margin:6px 0 2px}
.cdx-table th{font-family:var(--serif);font-weight:600;text-align:left;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--bone);background:rgba(var(--blood-rgb),0.16);border-bottom:1px solid var(--line-strong);padding:7px 10px}
.cdx-table td{padding:6px 10px;border-bottom:1px solid var(--line-soft);color:var(--bone-dim);vertical-align:top;font-size:14.5px}
.cdx-table tr:last-child td{border-bottom:0}
.cdx-table .cdx-path{font-family:var(--serif);color:var(--bone);white-space:nowrap}
.cdx-table .cdx-seal{font-family:var(--cjk);margin-right:8px}
.cdx-table .cdx-foc{font-family:var(--mono);font-size:12.5px;letter-spacing:.01em}
.cdx-arch{margin:16px 0 4px}
.cdx-arch:first-of-type{margin-top:10px}
.cdx-arch-head{font-family:var(--serif);font-size:17px;color:var(--bone);display:flex;align-items:baseline;gap:6px}
.cdx-arch-head b{font-weight:600}
.cdx-arch-blurb{margin:3px 0 0}

/* ---------- what's new (changelog) ---------- */
.wn-entry{margin-bottom:22px}
.wn-head{display:flex;align-items:baseline;gap:12px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.wn-tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--blood-text);
  border:1px solid rgba(var(--blood-bright-rgb),0.5);background:rgba(var(--blood-rgb),0.14);padding:3px 9px;border-radius:2px}
.wn-title{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--bone)}
.wn-date{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--muted);margin-left:auto}
.wn-list li{font-size:14.5px}
.wn-list li b{color:var(--bone)}

/* ---------- new-game starter pickers (Dao path → first Gu) ---------- */
.starter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;margin-top:4px}
.starter-grid.gu{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.starter-path,.starter-gu{display:flex;flex-direction:column;border:1px solid var(--line);background:linear-gradient(170deg,var(--bg2),var(--panel));padding:13px 14px;cursor:pointer;transition:.16s}
.starter-path:hover,.starter-gu:hover{border-color:var(--blood-dim);background:rgba(var(--line-rgb),0.04)}
.sp-head{display:flex;align-items:center;gap:8px}
.sp-seal{font-family:var(--cjk);font-weight:900;font-size:24px;line-height:1}
.sp-name{font-family:var(--serif);font-weight:600;font-size:17px;color:var(--bone);letter-spacing:.04em;flex:1}
.sp-blurb{font-size:13.5px;color:var(--bone-dim);line-height:1.4;margin:7px 0}
.sp-excel,.sp-grants,.sp-inflicts{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--bone-dim);line-height:1.6;margin-top:3px}
.sp-inflicts{display:flex;flex-wrap:wrap;align-items:center;gap:5px}
.sp-k{color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-right:5px}
.statchip{font-family:var(--mono);font-size:10px;letter-spacing:.06em;border:1px solid var(--line);border-radius:2px;padding:1px 6px;cursor:help}
.sp-sig{font-family:var(--mono);font-size:10.5px;color:var(--muted);line-height:1.5;margin-top:7px;padding-top:7px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:2px}
.sp-arsenal{margin-top:9px;padding-top:8px;border-top:1px solid var(--line)}
.sp-gulist{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:5px}
.sp-gulist li{display:flex;flex-direction:column;gap:1px;line-height:1.35}
.sp-gulist li b{font-family:var(--serif);font-size:13px;letter-spacing:.02em}
.sp-gulist li.cap b{font-size:13.5px}
.sp-gulist li.cap{padding-bottom:5px;margin-bottom:2px;border-bottom:1px dashed var(--line)}
.sg-head{display:flex;align-items:center;gap:9px}
.sg-name{font-family:var(--serif);font-weight:600;font-size:16px;color:var(--bone)}

/* archetype picker (step 4): one card per line, each showing its FULL rarity ladder. --acc = per-line hue */
.starter-grid.arch{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}
.starter-arch{display:flex;flex-direction:column;border:1px solid var(--line);background:linear-gradient(170deg,var(--bg2),var(--panel));padding:13px 14px;cursor:pointer;transition:.16s}
.starter-arch:hover{border-color:var(--acc);background:rgba(var(--line-rgb),0.04)}
.arch-ladder{margin-top:9px;padding-top:8px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:2px}
.arch-row{display:flex;align-items:baseline;gap:9px;font-family:var(--mono);font-size:10.5px;line-height:1.45;padding:2px 6px;border-left:2px solid transparent}
.arch-rar{flex:none;width:72px;letter-spacing:.07em;text-transform:uppercase}
.arch-eff{flex:1;color:var(--bone-dim)}
.arch-row.you{background:rgba(var(--blood-rgb),0.09);border-left-color:var(--blood-bright)}
.arch-row.you .arch-eff{color:var(--bone)}
.arch-you{flex:none;font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:var(--blood-bright);border:1px solid var(--blood-dim);border-radius:2px;padding:0 5px;align-self:center}

/* ---------- settings: bottom-left gear FAB + audio panel ---------- */
#settings-fab{position:fixed;left:22px;bottom:22px;z-index:40;width:46px;height:46px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:22px;line-height:1;padding:0;
  border:1px solid var(--line-strong);background:linear-gradient(170deg,var(--bg3),var(--panel));
  color:var(--bone-dim);box-shadow:0 16px 40px -18px rgba(0,0,0,0.9);cursor:pointer;transition:.2s}
#settings-fab:hover{color:var(--bone);border-color:var(--blood-dim);background:var(--bg3);transform:rotate(45deg)}
#title:not(.hidden) ~ #settings-fab{display:none} /* hidden on the title screen */

/* save indicator — fades in on save, auto-fades out */
.save-indicator{font-size:14px;opacity:0;transition:opacity .25s;cursor:default;user-select:none;line-height:1}
.save-indicator.show{opacity:.55}
.save-indicator.saving{opacity:1;animation:savePulse .6s ease-in-out}
@keyframes savePulse{0%{opacity:1}50%{opacity:.3}100%{opacity:.55}}

/* topbar external plugs — Ko-fi + Discord, tucked beside Save & Title (brand fill on hover) */
.topbar-actions{display:flex;align-items:center;gap:10px}
.tb-link{width:34px;height:34px;flex:none;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:2px;
  background:linear-gradient(180deg,var(--btn-hi),var(--btn-lo));transition:.16s ease}
.tb-kofi{color:#ff5e5b}
.tb-kofi:hover{color:#fff;background:#ff5e5b;border-color:#ff5e5b}
.tb-discord{color:#7b84f0}
.tb-discord:hover{color:#fff;background:#5865f2;border-color:#5865f2}

/* live "players online" indicator — sits left of the Ko-fi plug, fed by Realtime Presence */
.tb-online{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 11px;cursor:default;
  border:1px solid var(--line);border-radius:2px;
  background:linear-gradient(180deg,var(--btn-hi),var(--btn-lo));
  font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--muted)}
.tb-online-dot{width:7px;height:7px;border-radius:50%;background:var(--jade);
  box-shadow:0 0 7px var(--jade);animation:onlinePulse 2.4s ease-in-out infinite}
.tb-online-num{color:var(--jade);font-weight:700}
.tb-online-lbl{font-size:11px;opacity:.65;text-transform:uppercase;letter-spacing:.14em}
@keyframes onlinePulse{0%,100%{opacity:1}50%{opacity:.35}}

.modal.narrow{width:380px}
.set-row{display:flex;align-items:center;gap:14px;padding:15px 0;border-bottom:1px solid var(--line)}
.set-row:last-of-type{border-bottom:none}
.set-label{font-family:var(--serif);font-weight:600;font-size:16px;letter-spacing:.06em;color:var(--bone);width:54px;flex:none}
.set-slider{flex:1;display:flex;align-items:center;gap:11px}
.set-slider input[type=range]{flex:1;accent-color:var(--blood-bright);cursor:pointer}
.set-slider input[type=range]:disabled{opacity:.3;cursor:not-allowed}
.set-val{font-family:var(--mono);font-size:13px;color:var(--stone);width:18px;text-align:right}
.set-mute{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--bone-dim);cursor:pointer;user-select:none}
.set-mute input{accent-color:var(--blood-bright);cursor:pointer}

/* ---- Arena (async PvP) — standing panel + podium + formation ladder ---- */
.arena-pvp{display:grid;grid-template-columns:320px 1fr;gap:22px;align-items:start}

/* LEFT — "Your Standing": sticky while the ladder scrolls */
.apv-side{position:sticky;top:12px;overflow:hidden;border:1px solid var(--line);
  background:linear-gradient(170deg,var(--bg2),var(--panel));padding:22px 22px 18px}
.apv-side>*{position:relative;z-index:1}
.apv-ghost{position:absolute;right:-12px;top:-22px;z-index:0;font-family:var(--cjk);font-weight:900;
  font-size:120px;line-height:1;color:rgba(var(--bone-rgb),0.03);pointer-events:none}
.apv-h{font-family:var(--mono);font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.apv-pts{font-family:var(--mono);font-weight:700;font-size:54px;color:var(--stone);line-height:1;text-shadow:0 0 22px rgba(199,154,69,0.35)}
.apv-pos{font-family:var(--mono);font-size:10.5px;color:var(--bone-dim);letter-spacing:.06em;margin-top:7px}
.apv-rule{border:0;height:1px;background:var(--line);margin:16px 0}
.apv-name{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.apv-name input{flex:1;min-width:0;font-family:var(--serif);font-size:14px;color:var(--bone);background:rgba(0,0,0,0.3);border:1px solid var(--line);padding:7px 10px}
.apv-wide{width:100%;margin-bottom:8px}
.apv-note{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:12px}

/* formation mini-grid (side preview + podium cards + ladder rows) */
.afm-grid{display:flex;gap:7px}
.afm-grid.concealed{flex-wrap:wrap} /* opponents: no front/back columns — a flat, position-agnostic roster */
.afm-col{display:flex;flex-direction:column;gap:6px}
.afm-tile{position:relative;width:104px;border:1px solid var(--line);border-left-width:3px;background:var(--bg3);
  padding:5px 9px;display:flex;flex-direction:column;gap:1px}
.afm-tile.empty{border-style:dashed;opacity:.3;min-height:30px}
.afm-seal{position:absolute;right:7px;top:6px;font-family:var(--cjk);font-size:12px;line-height:1}
.afm-name{font-family:var(--serif);font-weight:600;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:15px}
.afm-realm{font-family:var(--mono);font-size:8px;color:var(--muted);letter-spacing:.04em}

/* loadout slots */
.ald-col{display:flex;flex-direction:column;gap:7px}
.ald{display:flex;align-items:center;gap:11px;width:100%;text-align:left;cursor:pointer;
  border:1px solid var(--line);background:var(--bg3);padding:9px 12px;border-radius:2px;letter-spacing:0;text-transform:none;font-size:inherit;transition:.14s}
.ald:hover:not(:disabled){border-color:var(--line-strong);background:var(--bg3)}
.ald.active{border-color:rgba(176,139,62,0.55);background:linear-gradient(90deg,rgba(176,139,62,0.10),var(--bg3));box-shadow:0 0 0 1px rgba(176,139,62,0.12) inset}
.ald.empty{border-style:dashed;opacity:.65}
.ald-n{flex:none;width:26px;height:26px;display:grid;place-items:center;font-family:var(--cjk);font-weight:700;font-size:13px;
  color:var(--bone-dim);border:1px solid var(--line);background:rgba(var(--shadow-rgb),0.6)}
.ald.active .ald-n{color:var(--stone);border-color:rgba(176,139,62,0.55)}
.ald-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.ald-info b{font-family:var(--serif);font-weight:600;font-size:13.5px;color:var(--bone);letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ald-info i{font-style:normal;font-family:var(--mono);font-size:8.5px;color:var(--muted);letter-spacing:.06em}
.ald>em{font-style:normal;font-family:var(--mono);font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.ald.active>em{color:var(--brass)}
.ald-edit{text-decoration:none;font-size:11px;color:var(--muted);margin-left:7px;cursor:pointer;transition:.13s}
.ald:hover .ald-edit{color:var(--bone)}

/* challenge attempts + refill timer */
.ach-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.ach-pips{display:flex;gap:6px}
.ach-pips i{width:22px;height:10px;border:1px solid var(--line);background:rgba(var(--shadow-rgb),0.6)}
.ach-pips i.on{background:linear-gradient(180deg,rgba(199,154,69,0.85),rgba(176,139,62,0.55));border-color:rgba(199,154,69,0.6);box-shadow:0 0 8px rgba(199,154,69,0.25)}
.ach-count{font-family:var(--mono);font-weight:700;font-size:19px;color:var(--stone);line-height:1}
.ach-count span{font-size:11px;font-weight:400;color:var(--muted)}
.ach-timer{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:9px}
.ach-timer b{color:var(--bone);font-size:12px;letter-spacing:.06em}
.ach-timer.full{color:var(--jade)}

/* RIGHT — podium (top 3) */
.apv-podium{display:grid;grid-template-columns:1fr 1.12fr 1fr;gap:14px;align-items:end;margin-bottom:18px}
.apd{position:relative;overflow:hidden;border:1px solid var(--line);background:linear-gradient(170deg,var(--bg2),var(--bg));
  padding:14px 14px 12px;display:flex;flex-direction:column;gap:9px}
.apd>*{position:relative;z-index:1}
.apd-1{border-color:rgba(199,154,69,0.55);background:linear-gradient(170deg,var(--bg3),var(--bg));
  box-shadow:0 0 0 1px rgba(199,154,69,0.12) inset,0 18px 40px -24px rgba(199,154,69,0.45);padding:18px 16px 14px}
.apd-2{border-color:rgba(var(--line-rgb),0.3)} .apd-3{border-color:rgba(176,107,62,0.4)}
.apd.mine{border-color:var(--brass)}
.apd-ghost{position:absolute;right:-10px;top:-18px;z-index:0;font-family:var(--cjk);font-weight:900;font-size:100px;line-height:1;color:rgba(var(--bone-rgb),0.04);pointer-events:none}
.apd-rank{font-family:var(--mono);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.apd-1 .apd-rank{color:var(--stone)}
.apd-owner{font-family:var(--serif);font-weight:600;font-size:17.5px;letter-spacing:.05em;color:var(--bone);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apd-1 .apd-owner{font-size:20px}
.apd-pts{font-family:var(--mono);font-weight:700;font-size:24px;color:var(--stone);line-height:1;text-shadow:0 0 14px rgba(199,154,69,0.3)}
.apd-1 .apd-pts{font-size:30px}
.apd-pts span{display:block;font-size:8px;font-weight:400;letter-spacing:.26em;color:var(--muted);text-shadow:none;margin-top:3px}
.apd-fm{padding:6px 0 4px}
.apd-1 .afm-tile{width:112px}
.apd-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;border-top:1px solid var(--line-soft);padding-top:11px;margin-top:2px}
.apd-pwr{font-family:var(--mono);font-size:10.5px;color:var(--bone-dim);letter-spacing:.08em}

/* RIGHT — ladder rows (rank 4+) */
.apv-row{display:grid;grid-template-columns:44px 158px 1fr 86px 104px;gap:12px;align-items:center;
  border:1px solid var(--line);background:linear-gradient(160deg,var(--bg2),var(--bg) 70%);padding:12px 14px;margin-bottom:10px}
.apv-row.mine{border-color:rgba(176,139,62,0.5);background:linear-gradient(160deg,var(--bg3),var(--bg) 75%)}
.apr-rank{display:flex;flex-direction:column;align-items:center;gap:2px;border-right:1px solid var(--line);padding-right:10px}
.apr-rk-n{font-family:var(--serif);font-weight:700;font-size:26px;color:var(--bone);opacity:.65;line-height:1}
.apv-row.mine .apr-rk-n{color:var(--brass);opacity:1}
.apr-rk-l{font-family:var(--mono);font-size:8px;letter-spacing:.3em;color:var(--muted)}
.apr-owner{display:flex;flex-direction:column;gap:4px;min-width:0}
.apr-owner b{font-family:var(--serif);font-weight:600;font-size:17px;letter-spacing:.04em;color:var(--bone);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apr-sub,.apr-killers{font-family:var(--mono);font-size:8.5px;color:var(--muted);letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apr-killers{color:var(--stone)}
.apr-you{font-style:normal;font-family:var(--mono);font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);
  border:1px solid rgba(176,139,62,0.45);padding:2px 7px;background:rgba(176,139,62,0.08);width:max-content;margin-top:2px}
.apr-stamp{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.apr-stamp b{font-family:var(--mono);font-weight:700;font-size:19px;color:var(--stone);line-height:1}
.apv-row.mine .apr-stamp b{color:var(--brass)}
.apr-stamp span{font-family:var(--mono);font-size:7.5px;letter-spacing:.3em;color:var(--muted)}
.apr-stamp i{font-style:normal;font-family:var(--mono);font-size:9px;color:var(--bone-dim);letter-spacing:.08em;margin-top:3px}
.apr-act{text-align:right}
.apr-act .mine-mark{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--brass)}
.arena-cd{font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--bone-dim);border:1px solid var(--line);
  background:rgba(var(--shadow-rgb),0.5);padding:5px 9px;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.arena-cd b{color:var(--stone);font-variant-numeric:tabular-nums}
.arena-cd.mini{font-size:10px;padding:4px 7px}
.arena-oor{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);
  border:1px dashed var(--line);padding:5px 9px;display:inline-block;white-space:nowrap}
.arena-oor.mini{font-size:9px;padding:4px 7px}
.arena-rec{font-family:var(--mono);font-size:11px;letter-spacing:.03em;white-space:nowrap}
.arena-rec .rec-w{color:var(--jade)} .arena-rec .rec-l{color:var(--blood-bright)}
.arena-rec .rec-sep{color:var(--muted);margin:0 1px} .arena-rec .rec-wr{color:var(--bone-dim);font-size:.9em}
.arena-rec.big{font-size:15px}
.apv-rec{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-top:7px}
.apd-rec{margin-top:1px} .apr-stamp .apr-rec{margin-top:3px}

@media (max-width:1080px){
  .arena-pvp{grid-template-columns:1fr}
  .apv-side{position:static}
  .apv-podium{grid-template-columns:1fr;align-items:stretch}
}

@media (max-width:560px){
  .starter-grid{grid-template-columns:1fr}
  #onboard-host{left:12px;right:12px;bottom:12px} .onboard-widget{width:auto}
  #settings-fab{left:12px;bottom:12px}
}

@media (max-width:1080px){
  #content{padding:0 20px 70px}
  .cs-ident{grid-template-columns:1fr;gap:22px} .cs-aside{text-align:left}
  .cs-glance{grid-template-columns:1fr} .cs-attrs{grid-template-columns:repeat(2,1fr)}
  .cs-statgrid{grid-template-columns:repeat(2,1fr)}
  .pagehead{grid-template-columns:1fr}
  .bounty-grid{grid-template-columns:1fr}
}

/* ---- Bounties board — large "wanted-poster" cards, 2-up on wide screens ---- */
.bounty-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(440px,1fr));gap:20px}
.bounty-card{position:relative;border:1px solid var(--line);border-top:3px solid var(--rc,var(--line-strong));
  background:linear-gradient(165deg,var(--bg2),var(--panel));padding:26px 28px;display:flex;flex-direction:column;gap:20px;min-height:300px;transition:.16s}
.bounty-card:hover{border-color:var(--line-strong);background:linear-gradient(165deg,var(--bg3),var(--panel))}
.bounty-card.locked{opacity:.5;filter:saturate(.35)}
.bounty-card .bc-head{display:flex;align-items:flex-start;gap:20px}
.bounty-card .bc-seal{flex:0 0 auto;width:76px;height:76px;display:grid;place-items:center;font-size:46px;line-height:1;
  color:var(--rc);border:1px solid var(--rc);background:rgba(0,0,0,.28);box-shadow:inset 0 0 26px rgba(0,0,0,.45)}
.bounty-card .bc-id{flex:1;min-width:0}
.bounty-card .bc-tier{font-family:var(--mono);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--rc)}
.bounty-card .bc-name{font-family:var(--serif,inherit);font-size:26px;color:var(--bone);line-height:1.14;margin:6px 0 5px}
.bounty-card .bc-arch{font-size:15px;color:var(--bone-dim)}
.bounty-card .bc-path{font-size:13px;color:var(--muted);margin-top:4px;letter-spacing:.02em}
.bounty-card .bc-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;border-top:1px solid var(--line-soft);padding-top:16px;margin-top:auto}
.bounty-card .bc-stats > div{display:flex;flex-direction:column;gap:3px}
.bounty-card .bc-stats .sk{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.bounty-card .bc-stats .sv{font-family:var(--mono);font-size:16px;font-weight:700;color:var(--bone)}
.bounty-card .bc-rewards{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding-top:4px}
.bounty-card .bc-rtile{display:flex;flex-direction:column;gap:4px;background:rgba(0,0,0,.18);border:1px solid var(--line-soft);padding:10px 13px}
.bounty-card .bc-rtile .sk{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.bounty-card .bc-rtile .sv{font-family:var(--mono);font-size:17px;font-weight:700}
.bounty-card .bc-rtile.bc-gu{grid-column:1/-1}
.bounty-card .bc-rtile .sv-gu{font-family:var(--mono);font-size:13px;color:var(--bone-dim);letter-spacing:.02em}
.bounty-card .bc-go{padding:13px;font-size:14px;letter-spacing:.12em;text-transform:uppercase}

/* ===== Market & Refinery redesign (workshop layout) ===== */
/* ---- Workshop shared (Market + Refinery) ---- */
.wk-rail{position:sticky;top:12px;border:1px solid var(--line);background:rgba(var(--shadow-rgb),0.4);padding:14px}
.wk-h{font-family:var(--mono);font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.wk-comm{margin-top:13px;margin-bottom:5px;letter-spacing:.3em}
.wk-rule{border:0;height:1px;background:var(--line);margin:14px 0}
.wk-note{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:10px}
.wk-wide{width:100%;margin-top:10px}
.searchbox.wide{width:100%;margin-bottom:12px}

/* path buttons (rail) — shared by Market path filter + Refinery path nav */
.ref-pbtn{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:transparent;border:1px solid transparent;border-left:2px solid transparent;
  padding:5px 8px;font-family:var(--serif);font-size:13.5px;letter-spacing:.02em;text-transform:none;color:var(--bone-dim);cursor:pointer;border-radius:0}
.ref-pbtn span{font-family:var(--cjk);width:18px;text-align:center;flex:none}
.ref-pbtn i{font-style:normal;margin-left:auto;font-family:var(--mono);font-size:8.5px;color:var(--stone);letter-spacing:.02em}
.ref-pbtn:hover{background:rgba(var(--line-rgb),0.04);color:var(--bone);border-color:transparent}
.ref-pbtn.on{border-left-color:var(--blood-bright);background:linear-gradient(90deg,rgba(var(--blood-rgb),0.12),transparent);color:var(--bone)}
.ref-pbtn.locked{opacity:.45}
.ref-pbtn.locked i{color:var(--muted)}

/* ---- Market: counter layout ---- */
.mkt-split{display:grid;grid-template-columns:205px 1fr 330px;gap:20px;align-items:start}
/* (rank filter renders as .ref-tiers chips above the list — see Refinery block below) */
.mkt-list{min-width:0}
.mkt-row{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-top:none;background:var(--bg2);padding:10px 14px;cursor:pointer;transition:.12s}
.mkt-row:first-of-type{border-top:1px solid var(--line)}
.mkt-row:hover{background:var(--bg3)}
.mkt-row.poor{opacity:.55}
.mkt-row.sel{border-color:rgba(var(--blood-bright-rgb),0.5);border-top:1px solid rgba(var(--blood-bright-rgb),0.5);background:linear-gradient(90deg,rgba(var(--blood-rgb),0.08),var(--bg2))}
.mkt-row.sel + .mkt-row{border-top:none}
.mkt-dot{width:8px;height:8px;border-radius:50%;flex:none}
.mkt-name{font-family:var(--serif);font-weight:600;font-size:16px;color:var(--bone);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mkt-held{font-family:var(--mono);font-size:10px;color:var(--muted);white-space:nowrap}
.mkt-cost{font-family:var(--mono);font-size:13px;color:var(--stone);min-width:74px;text-align:right;white-space:nowrap}
.mkt-desk{position:sticky;top:12px;border:1px solid var(--line);background:linear-gradient(170deg,var(--bg2),var(--panel));padding:18px 20px}
.mkt-wallet{display:flex;flex-direction:column;gap:2px;border:1px solid rgba(199,154,69,0.4);background:rgba(199,154,69,0.06);padding:12px 18px}
.mkt-wallet span{font-family:var(--mono);font-size:8.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.mkt-wallet b{font-family:var(--mono);font-weight:700;font-size:26px;color:var(--stone);line-height:1}
.mkt-wallet b i{font-style:normal;font-family:var(--cjk);font-size:15px}
.mkt-sel{display:flex;gap:14px;align-items:center}
.mkt-sel-glyph{font-family:var(--cjk);font-weight:600;font-size:44px;line-height:1;flex:none}
.mkt-sel b{font-family:var(--serif);font-weight:600;font-size:19px;color:var(--bone)}
.mkt-sel-sub{font-family:var(--mono);font-size:9.5px;color:var(--muted);margin-top:5px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.mkt-qty{display:flex;gap:6px;flex-wrap:wrap}
.mkt-bill{margin:14px 0 0;border-top:1px solid var(--line);padding-top:6px}
.mkt-bill>div{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--line-soft)}
.mkt-bill dt{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.mkt-bill dd{margin:0;font-family:var(--mono);font-size:13px;color:var(--bone)}
.mkt-bill .tot dd{color:var(--stone);font-weight:700;font-size:16px}

/* ---- Refinery: workbench layout ---- */
.ref-split{display:grid;grid-template-columns:215px 1fr 330px;gap:20px;align-items:start}
.ref-flags{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}
.ref-flag{display:flex;align-items:center;gap:8px;width:100%;text-align:left;border:1px solid var(--line);background:var(--bg2);
  padding:7px 10px;cursor:pointer;font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--bone-dim);border-radius:0}
.ref-flag.on{border-color:rgba(199,154,69,0.5);background:rgba(199,154,69,0.08);color:#e8c777}
.ref-mid{min-width:0}
.ref-tiers{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}
.ref-row{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-left-width:3px;border-top:none;background:var(--bg2);padding:9px 13px;cursor:pointer;transition:.12s}
.ref-row:hover{background:var(--bg3)}
.ref-row.sel{background:linear-gradient(90deg,rgba(var(--blood-rgb),0.08),var(--bg2));border-color:rgba(var(--blood-bright-rgb),0.5);border-top:1px solid rgba(var(--blood-bright-rgb),0.5)}
.ref-row.sel + .ref-row{border-top:none}
.ref-name{font-family:var(--serif);font-weight:600;font-size:15.5px;color:var(--bone);display:flex;align-items:center;gap:7px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ref-eff{font-family:var(--mono);font-size:9.5px;color:var(--muted);letter-spacing:.02em;margin-left:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:none;max-width:46%}
.ref-can{font-style:normal;color:var(--stone);font-size:12px;flex:none;text-shadow:0 0 8px rgba(199,154,69,0.45)}
.ref-can.dim{color:#564d3e;opacity:.55;text-shadow:none}
.ref-desk{position:sticky;top:12px}
.ref-card{display:flex;flex-direction:column;gap:8px;border:1px solid;background:linear-gradient(170deg,var(--bg2),var(--bg));padding:14px 16px}
.ref-card.can{box-shadow:0 0 22px -8px rgba(199,154,69,0.35)}
.ref-card-top{display:flex;align-items:center;gap:7px}
.ref-glyph{position:relative;display:grid;place-items:center;height:74px;margin:2px 0}
.ref-glyph i{position:absolute;width:58px;height:58px;border-radius:50%;border:1px solid}
.ref-glyph span{font-family:var(--cjk);font-weight:600;font-size:40px;line-height:1;position:relative}
.ref-cname{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--bone);text-align:center;letter-spacing:.04em}
.ref-effs{font-family:var(--mono);font-size:10.5px;color:var(--jade);letter-spacing:.02em;text-align:center;line-height:1.6}
.ref-ctags{display:flex;gap:5px;justify-content:center;flex-wrap:wrap}
.ref-ctags i{font-style:normal;font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--bone-dim);border:1px solid var(--line);padding:2px 7px}
.ref-recipe{display:flex;flex-direction:column;gap:4px;border-top:1px solid var(--line-soft);padding-top:9px;margin-top:2px}
.ref-ing{display:flex;align-items:baseline;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.02em}
.ref-ing i{font-style:normal;width:12px;flex:none}
.ref-ing.ok{color:var(--bone-dim)} .ref-ing.ok i{color:var(--jade)}
.ref-ing.no{color:var(--muted)} .ref-ing.no i{color:var(--blood-bright)}
.ref-ing em{font-style:normal;margin-left:auto;color:var(--blood-bright)}
.ref-why{font-family:var(--mono);font-size:9.5px;color:var(--blood-bright);line-height:1.5;border-left:2px solid var(--blood);padding-left:9px}

@media (max-width:1080px){
  .mkt-split,.ref-split{grid-template-columns:1fr}
  .wk-rail,.mkt-desk,.ref-desk{position:static}
}

/* ===== Formation & Bounties redesign (command board + hunt ledger) ===== */
/* ---- Formation: F4 Command Final ---- */
.fm4-split{display:grid;grid-template-columns:1fr 320px;gap:22px;align-items:start}
.fm4-board{padding:18px 22px 12px}
.fm4-board .fmboard{max-width:none;grid-template-columns:86px 1fr;gap:8px}
.fm4-lanehead{display:grid;grid-template-columns:86px repeat(5,1fr);gap:8px;margin-bottom:8px}
.fm4-lanehead i{font-style:normal;font-family:var(--mono);font-size:8.5px;letter-spacing:.24em;color:var(--muted);text-align:center}
.fm4-board .fmrowlbl{display:flex;flex-direction:column;justify-content:center;gap:2px;text-align:right;padding-right:10px;border-right:1px solid var(--line);color:var(--bone-dim)}
.fm4-board .fmrowlbl i{font-style:normal;font-size:8px;color:var(--muted);letter-spacing:.12em;text-transform:none}
.fm4-board .fmtile{min-height:92px;justify-content:flex-start;align-items:stretch;padding:9px 12px}
.fm4-board .fmunit{align-items:flex-start;gap:3px}
.fm4-board .fmunit .uname{font-size:15px;text-align:left;padding-right:20px}
.fm4-board .fmunit .fmrealm{text-align:left}
.fm4-board .fmtile.seltile{box-shadow:0 0 0 1px rgba(var(--blood-bright-rgb),0.5);border-color:rgba(var(--blood-bright-rgb),0.5)}
.fm4-seal{position:absolute;top:7px;right:8px;font-size:15px;line-height:1}
.fm4-board .fmx{position:absolute;bottom:6px;right:8px;top:auto}
.fm4-enemy{margin-top:10px;padding-top:10px;border-top:1px dashed rgba(var(--blood-bright-rgb),0.25);text-align:center;
  font-family:var(--mono);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:rgba(var(--blood-bright-rgb),0.55)}

/* reserves deploy list */
.fm4-row{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-left-width:3px;border-top:none;
  background:var(--bg2);padding:8px 12px;cursor:grab}
.fm4-row:active{cursor:grabbing}
.fm4-row:first-of-type{border-top:1px solid var(--line)}
.fm4-rseal{font-size:18px;line-height:1;flex:none}
.fm4-row b{font-family:var(--serif);font-weight:600;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fm4-sub{font-family:var(--mono);font-size:9px;color:var(--muted)}
.fm4-stats{margin-left:auto;font-family:var(--mono);font-size:9px;color:var(--bone-dim);white-space:nowrap}
.fm4-acts{display:flex;gap:5px;flex:none}

/* unit inspector */
.fm4-desk{position:sticky;top:12px;border:1px solid var(--line);background:linear-gradient(170deg,var(--bg2),var(--panel));padding:18px 20px}
.fm4-h{font-family:var(--mono);font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.fm4-rule{border:0;height:1px;background:var(--line);margin:14px 0}
.fm4-id{display:flex;gap:13px;align-items:center;margin-bottom:14px}
.fm4-bigseal{font-size:34px;line-height:1;flex:none}
.fm4-name{font-family:var(--serif);font-weight:600;font-size:21px}
.fm4-isub{font-family:var(--mono);font-size:9.5px;color:var(--muted);margin-top:3px}
.fm4-imp{color:var(--brass)}
.fm4-statgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-bottom:10px}
.fm4-statgrid>div{background:var(--bg2);padding:9px 12px;display:flex;flex-direction:column;gap:2px}
.fm4-statgrid span{font-family:var(--mono);font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.fm4-statgrid b{font-family:var(--mono);font-size:17px;color:var(--bone)}
.fm4-irow{display:flex;flex-direction:column;gap:3px;padding:8px 0;border-bottom:1px solid var(--line-soft);font-size:14.5px;color:var(--bone)}
.fm4-irow .fm4-h{margin-bottom:0}
.fm4-pos{font-family:var(--mono);font-size:11px;letter-spacing:.1em}
.fm4-pos i{font-style:normal;color:var(--muted);font-size:10px;letter-spacing:.02em}
.fm4-iacts{display:flex;gap:8px;margin-top:12px}
.fm4-team>div{display:flex;justify-content:space-between;gap:10px;padding:6px 0;border-bottom:1px solid var(--line-soft);
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase}
.fm4-team span{color:var(--muted)} .fm4-team b{color:var(--bone);font-weight:400;font-size:11px}

/* ---- Bounties: B2 Hunt Ledger ---- */
.bn2-split{display:grid;grid-template-columns:280px 1fr;gap:22px;align-items:start}
.bn2-rail{position:sticky;top:12px;border:1px solid var(--line);background:linear-gradient(170deg,var(--bg2),var(--panel));padding:16px 18px}
.bn2-h{font-family:var(--mono);font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.bn2-cell{display:flex;flex-direction:column;gap:4px;margin-top:14px}
.bn2-cell .bn2-h{margin-bottom:0}
.bn2-cell b{font-family:var(--mono);font-weight:700;font-size:19px;color:var(--bone);line-height:1}
.bn2-note{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.bn2-row{display:grid;grid-template-columns:64px 1.3fr 1.1fr 170px 170px;gap:16px;align-items:center;
  border:1px solid var(--line);border-left:3px solid var(--rc,var(--line-strong));
  background:linear-gradient(160deg,var(--bg2),var(--bg) 70%);padding:13px 16px;margin-bottom:10px}
.bn2-row.locked{opacity:.5;filter:saturate(.35)}
.bn2-seal{display:flex;flex-direction:column;align-items:center;gap:3px;border-right:1px solid var(--line);padding-right:14px}
.bn2-seal span{font-size:30px;line-height:1;color:var(--rc)}
.bn2-seal i{font-style:normal;font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;color:var(--rc)}
.bn2-id{display:flex;flex-direction:column;gap:3px;min-width:0}
.bn2-id b{font-family:var(--serif);font-weight:600;font-size:17.5px;color:var(--bone);letter-spacing:.03em}
.bn2-sub{font-family:var(--mono);font-size:9px;letter-spacing:.06em}
.bn2-sub.dim{color:var(--muted)}
.bn2-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.bn2-stats>div{display:flex;flex-direction:column;gap:2px}
.bn2-stats .sk{font-family:var(--mono);font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.bn2-stats b{font-family:var(--mono);font-size:13px;color:var(--bone)}
.bn2-loot{display:flex;flex-direction:column;gap:3px;font-family:var(--mono);font-size:10.5px}
.bn2-gu{font-size:8.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bn2-act{text-align:right}
.bn2-act .bc-go{padding:11px 14px;font-size:12px;width:100%}

@media (max-width:1080px){
  .fm4-split,.bn2-split{grid-template-columns:1fr}
  .fm4-desk,.bn2-rail{position:static}
}

/* ===== Team (Vanguard Hall) & Character (Aperture Mandala) redesign ===== */
/* ---- shared chips ---- */
.tc-seal{display:inline-grid;place-items:center;width:36px;height:36px;border:1px solid;border-radius:2px;background:rgba(var(--shadow-rgb),0.7);font-weight:700;font-size:19px;line-height:1;flex:none}
.tc-chips{display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.tc-chip{font-style:normal;font-family:var(--cjk);font-size:13px;width:26px;height:26px;display:inline-grid;place-items:center;border:1px solid;border-radius:2px;background:rgba(var(--shadow-rgb),0.6);cursor:pointer}
.tc-chip.sm{width:22px;height:22px;font-size:11px}
.tc-chip.empty{color:var(--muted);border-color:var(--line);border-style:dashed;opacity:.5;font-size:11px}
.tc-chip.starved{opacity:.4;border-style:dashed}
.t1-killer{font-family:var(--mono);font-size:9px;color:var(--stone);letter-spacing:.06em;border:1px solid rgba(199,154,69,0.4);background:rgba(199,154,69,0.07);padding:2px 7px}
.t1-pwr{font-family:var(--mono);font-size:11px;color:var(--stone);text-align:right}

/* ---- T4 hero cards ---- */
.h4-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.h4-card{border-top:3px solid;display:flex;flex-direction:column;gap:10px;cursor:pointer}
.h4-card.h4-empty{align-items:center;justify-content:center;text-align:center;border-top-color:var(--line);border-style:dashed;cursor:default}
.h4-head{display:flex;align-items:center;gap:11px}
.h4-id{display:flex;flex-direction:column;gap:2px;min-width:0}
.h4-id b{font-family:var(--serif);font-weight:600;font-size:19px;letter-spacing:.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.h4-id span{font-family:var(--mono);font-size:8.5px;color:var(--muted)}
.h4-you{font-style:normal;font-family:var(--mono);font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);border:1px solid rgba(176,139,62,0.45);background:rgba(176,139,62,0.08);padding:1px 6px;margin-left:8px;vertical-align:2px}
.h4-pos{margin-left:auto;font-family:var(--mono);font-size:8.5px;letter-spacing:.14em;color:var(--bone-dim);border:1px solid var(--line);padding:3px 8px;background:rgba(var(--shadow-rgb),0.5);white-space:nowrap}
.h4-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.h4-stats>div{background:var(--bg2);padding:7px 10px;display:flex;flex-direction:column;gap:1px}
.h4-stats span{font-family:var(--mono);font-size:7.5px;letter-spacing:.18em;color:var(--muted)}
.h4-stats b{font-family:var(--mono);font-size:13.5px;color:var(--bone)}
.h4-gulbl{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.h4-gulbl i{font-style:normal;color:var(--stone);letter-spacing:.06em}
.h4-foot{display:flex;justify-content:space-between;align-items:center;gap:8px;border-top:1px solid var(--line-soft);padding-top:10px;margin-top:auto}
.h4-nok{font-family:var(--mono);font-size:8.5px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.h4-acts{display:flex;gap:6px}

/* ---- T4 roster rows (wrapper id=rosterResults gets class h4-roster) ---- */
.h4-roster{display:flex;flex-direction:column}
.h4-row{display:grid;grid-template-columns:34px 1.3fr 200px minmax(0,1fr) 70px auto;gap:12px;align-items:center;
  border:1px solid var(--line);border-left-width:3px;border-top:none;background:var(--bg2);padding:8px 14px;cursor:pointer}
.h4-row:first-of-type{border-top:1px solid var(--line)}
.h4-row.act{background:linear-gradient(90deg,rgba(var(--blood-rgb),0.05),var(--bg2) 40%)}
.h4-rid{display:flex;flex-direction:column;gap:1px;min-width:0}
.h4-rid b{font-family:var(--serif);font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.h4-rid i{font-style:normal;font-family:var(--mono);font-size:8.5px;color:var(--muted)}
.h4-rstat{font-family:var(--mono);font-size:9.5px;color:var(--bone-dim);white-space:nowrap}

/* ---- Aperture mandala ---- */
.ap-mandala{display:flex;flex-direction:column;align-items:center;gap:14px;margin:8px 0 4px}
.ap-box{position:relative;width:700px;height:720px;max-width:100%;overflow:visible;background:radial-gradient(40% 40% at 50% 50%,rgba(var(--blood-rgb),0.12),transparent 72%)}
.ap-ring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border:1px dashed rgba(var(--line-rgb),0.16);border-radius:50%;pointer-events:none}
.ap-ringarc{position:absolute;left:50%;top:50%;width:300px;height:300px;transform:translate(-50%,-50%);border-radius:50%;transition:filter 3s ease}
.ap-ringarc::before{content:"";position:absolute;inset:7px;border-radius:50%;background:#100c0b}
.ap-liquid{position:absolute;left:50%;top:50%;width:244px;height:244px;transform:translate(-50%,-50%);border-radius:50%;overflow:hidden;background:#100c0b;transition:box-shadow 3s ease;z-index:1}
.ap-liquid.r1{--lq1:rgba(63,158,116,0.38);--lq2:rgba(28,78,57,0.55);--lq3:rgba(12,36,28,0.85)}
.ap-liquid.r2{--lq1:rgba(200,49,60,0.40);--lq2:rgba(122,21,32,0.58);--lq3:rgba(52,10,16,0.88)}
.ap-liquid.r3{--lq1:rgba(250,250,248,0.62);--lq2:rgba(202,210,222,0.55);--lq3:rgba(118,128,144,0.8)}
.ap-liquid.r4{--lq1:rgba(232,199,119,0.38);--lq2:rgba(176,139,62,0.52);--lq3:rgba(70,52,18,0.85)}
.ap-liquid.r5{--lq1:rgba(183,155,255,0.36);--lq2:rgba(108,77,196,0.5);--lq3:rgba(40,26,78,0.85)}
/* Aperture WALL — a bordered ring hugging the sea with an always-on, thick, fluctuating aura the
   same colour as the liquid (rank-tinted). Sits over the liquid edge; pointer-transparent. */
.ap-wall{position:absolute;left:50%;top:50%;width:244px;height:244px;transform:translate(-50%,-50%);border-radius:50%;border:3px solid var(--wall);pointer-events:none;z-index:1}
.ap-wall.r1{--wall:#5fcf97;--aura:rgba(63,158,116,0.62)}
.ap-wall.r2{--wall:#e0545f;--aura:rgba(200,49,60,0.6)}
.ap-wall.r3{--wall:#d6deec;--aura:rgba(210,218,232,0.55)}
.ap-wall.r4{--wall:#ecca7c;--aura:rgba(232,199,119,0.58)}
.ap-wall.r5{--wall:#c4a9ff;--aura:rgba(183,155,255,0.6)}
@media (prefers-reduced-motion: no-preference){ .ap-wall{animation:apaura 3.4s ease-in-out infinite} }
@media (prefers-reduced-motion: reduce){
  .ap-wall{box-shadow:0 0 44px 14px var(--aura),0 0 14px 3px var(--aura),inset 0 0 26px 4px var(--aura)}
}
@keyframes apaura{
  0%,100%{box-shadow:0 0 30px 8px var(--aura),0 0 10px 2px var(--aura),inset 0 0 18px 3px var(--aura)}
  50%{box-shadow:0 0 64px 24px var(--aura),0 0 24px 7px var(--aura),inset 0 0 36px 8px var(--aura)}
}
.ap-wave{position:absolute;width:220%;height:220%;left:-60%;border-radius:42%;background:linear-gradient(180deg,var(--lq1),var(--lq2) 40%,var(--lq3))}
.ap-wave.w2{border-radius:46%;opacity:.6;background:linear-gradient(180deg,var(--lq2),var(--lq3) 55%)}
@media (prefers-reduced-motion: no-preference){
  .ap-wave{animation:apspin 11s linear infinite}
  .ap-wave.w2{animation:apspin 17s linear infinite reverse}
}
@keyframes apspin{to{transform:rotate(360deg)}}
.ap-core{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center;z-index:2;width:228px}
.ap-core b,.ap-core i,.ap-core em{text-shadow:0 1px 8px rgba(0,0,0,0.95),0 0 16px rgba(0,0,0,0.9)}
.ap-glyph{font-weight:900;font-size:46px;line-height:1;text-shadow:0 0 24px rgba(255,90,106,0.3),0 2px 10px rgba(0,0,0,0.9)}
.ap-core b{font-family:var(--cjk);font-weight:900;font-size:20px;color:var(--bone)}
.ap-core i{font-style:normal;font-family:var(--mono);font-size:8px;letter-spacing:.18em;color:var(--bone-dim)}
.ap-core em{font-style:normal;font-family:var(--mono);font-size:9px;color:var(--stone)}
.ap-net{border:1px solid var(--line);background:rgba(var(--shadow-rgb),0.72);padding:3px 8px;margin-top:3px;font-size:8.5px!important;letter-spacing:.06em}
.ap-net.dn{color:var(--blood-bright)!important;border-color:rgba(var(--blood-bright-rgb),0.4)}
.ap-net.up{color:var(--jade)!important;border-color:rgba(63,158,116,0.4)}
/* Gu nodes ride the concentric rings (compact disc + label) — no overlap as slot count grows */
.ap-node{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:3px;width:98px;cursor:pointer;z-index:3;text-align:center}
.ap-disc{position:relative;display:grid;place-items:center;width:50px;height:50px;border:1px solid var(--line);border-radius:50%;background:rgba(12,9,8,0.96);box-shadow:0 6px 18px -8px #000}
.ap-disc i.cjk{font-style:normal;font-weight:600;font-size:24px;line-height:1}
.ap-p{position:absolute;bottom:-6px;right:-7px;font-style:normal;font-family:var(--mono);font-size:7.5px;letter-spacing:.02em;color:var(--stone);background:var(--bg);border:1px solid rgba(199,154,69,0.5);padding:0 3px;border-radius:2px;line-height:1.5}
.ap-nname{font-family:var(--serif);font-weight:600;font-size:11.5px;color:var(--bone);line-height:1.1;max-width:98px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ap-nmeta{font-family:var(--mono);font-size:7.5px;letter-spacing:.04em;color:var(--muted)}
.ap-mv{display:flex;gap:3px}
.ap-mvb{font-family:var(--mono);font-size:9px;line-height:1;padding:2px 6px;border:1px solid var(--line);background:rgba(var(--shadow-rgb),0.6);color:var(--bone-dim);cursor:pointer;border-radius:0}
.ap-mvb:hover{background:var(--bg3);color:var(--bone)}
.ap-mvb:disabled{opacity:.3;cursor:default}
.ap-node.starved .ap-disc{border-style:dashed;opacity:.6}
.ap-node.starved .ap-nname{color:var(--muted)}
.ap-node.empty .ap-disc{border-style:dashed;color:var(--muted);font-size:19px}
.ap-node.empty .ap-nname{color:var(--muted);font-family:var(--mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase}
/* VITAL GU (本命蛊): the core Gu pinned to P1 — gold disc + a star seal. */
.ap-node.vital .ap-disc{border-color:var(--stone);box-shadow:0 0 11px rgba(199,154,69,0.45),0 6px 18px -8px #000}
.ap-vstar{position:absolute;top:-7px;left:-7px;font-style:normal;font-size:11px;color:var(--stone);text-shadow:0 0 5px rgba(199,154,69,0.6);line-height:1}
.ap-mvb.vital{color:var(--stone);border-color:rgba(199,154,69,0.5)}
.ap-mvb.vital:hover{background:rgba(199,154,69,0.16);color:var(--stone)}
.ap-mv.vital-tag{font-family:var(--mono);font-size:8px;letter-spacing:.06em;color:var(--stone);text-transform:uppercase;white-space:nowrap}
.vital-backlash{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;width:100%;max-width:620px;margin-top:10px;
  border:1px solid rgba(176,62,62,0.5);background:linear-gradient(170deg,rgba(176,62,62,0.12),var(--bg));padding:8px 14px;font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--blood-bright)}
.vital-backlash button{font-family:var(--mono);font-size:10px}
/* Vital-Gu CHOICE prompt (本命蛊): a gentle stone/gold nudge above the loadout for a not-yet-chosen core */
.vital-choose{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;width:100%;max-width:620px;margin-bottom:10px;
  border:1px solid rgba(199,154,69,0.5);background:linear-gradient(170deg,rgba(199,154,69,0.12),var(--bg));padding:8px 14px;font-family:var(--mono);font-size:10px;letter-spacing:.03em;color:var(--stone)}

/* ---- breakthrough dock + rite ---- */
.ap-btdock{display:flex;align-items:center;gap:12px;flex-wrap:wrap;width:100%;max-width:620px;
  border:1px solid rgba(199,154,69,0.35);background:linear-gradient(170deg,var(--bg3),var(--bg));padding:11px 16px}
.ap-btlbl{font-family:var(--mono);font-size:9px;letter-spacing:.26em;color:var(--muted)}
.ap-btv{font-family:var(--mono);font-size:10px;color:var(--bone-dim)}
.ap-btnext{flex-basis:100%;font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.ap-btnext b{font-weight:400;color:var(--bone)}
.ch2-bar{height:8px;border:1px solid var(--line);background:rgba(var(--shadow-rgb),0.6);display:inline-block;min-width:90px}
.ch2-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--blood),var(--blood-bright))}
.ap-btres{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;padding:3px 9px;border:1px solid}
.ap-btres.gold{color:#e8c777;border-color:rgba(232,199,119,0.55);background:rgba(199,154,69,0.1)}
.ap-btres.dull{color:var(--muted);border-color:var(--line);background:rgba(var(--shadow-rgb),0.5)}
.ap-box.g-sus .ap-ringarc{filter:brightness(1.25)}
@media (prefers-reduced-motion: no-preference){
  .ap-box.g-sus .ap-liquid{animation:aprite 1.25s ease-in-out infinite alternate}
}
@media (prefers-reduced-motion: reduce){
  .ap-box.g-sus .ap-liquid{box-shadow:0 0 70px 22px rgba(232,199,119,0.45)}
}
@keyframes aprite{
  from{box-shadow:0 0 74px 24px rgba(232,199,119,0.6),0 0 18px 4px rgba(232,199,119,0.5)}
  to{box-shadow:0 0 30px 9px rgba(108,98,86,0.42),0 0 10px 2px rgba(108,98,86,0.3)}
}
.ap-box.g-fin-gold .ap-liquid{box-shadow:0 0 120px 46px rgba(232,199,119,0.72),0 0 30px 10px rgba(245,229,138,0.6)}
.ap-box.g-fin-gold .ap-ringarc{filter:brightness(1.5)}
.ap-box.g-fin-dull .ap-liquid{box-shadow:0 0 26px 8px rgba(95,88,78,0.4)}
.ap-box.g-fin-dull .ap-ringarc{filter:brightness(.8) saturate(.6)}

@media (max-width:1080px){ .h4-grid{grid-template-columns:1fr 1fr} .ap-box{transform:scale(.82);margin:-64px 0} }
@media (max-width:820px){ .ap-box{transform:scale(.6);margin:-144px 0} }


/* ===== CH5 character sheet — 3-column hero layout (Marrow / Mandala / Tempered Flesh + Soul Imprint) ===== */
.ch5-sheet{max-width:1660px}
.cs-back-spec{margin-left:auto;font-family:var(--mono);font-size:9px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.ch5-grid{display:grid;grid-template-columns:390px minmax(0,1fr) 330px;gap:20px;align-items:start;margin-top:10px}
.ch5-side{display:flex;flex-direction:column;gap:18px;min-width:0}
.ch5-center{display:flex;justify-content:center;align-items:flex-start;min-width:0}
.ch5-panel{border:1px solid var(--line);background:linear-gradient(170deg,var(--bg2),var(--panel));padding:16px 18px}
.ch5-h{font-family:var(--mono);font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.ch5-h i{font-style:normal;color:var(--stone);letter-spacing:.1em}
.ch5-note{font-family:var(--mono);font-size:8.5px;color:var(--muted);letter-spacing:.04em;margin-top:10px;line-height:1.55}

/* Marrow — attribute allocation list */
.ch5-attrlist{display:flex;flex-direction:column;gap:1px;background:var(--line);border:1px solid var(--line)}
.ch5-attr{display:grid;grid-template-columns:48px 1fr auto;grid-template-rows:auto auto;gap:1px 12px;align-items:center;background:var(--bg2);padding:9px 12px}
.ch5-attr.staged{background:linear-gradient(90deg,rgba(199,154,69,0.09),var(--bg2))}
.ch5-ak{grid-row:1/3;font-family:var(--mono);font-size:13px;letter-spacing:.12em;color:var(--bone-dim)}
.ch5-av{font-family:var(--mono);font-size:19px;font-weight:700;color:var(--bone);line-height:1.1}
.ch5-av .ch5-stg{font-style:normal;font-size:11px;color:var(--jade);margin-left:5px;font-weight:400}
.ch5-astep{grid-row:1/3;display:flex;gap:5px}
.ch5-astep .step{width:30px;padding:5px 0;text-align:center;font-size:13px}
.ch5-ad{grid-column:2/3;font-family:var(--mono);font-size:7.5px;letter-spacing:.05em;color:var(--muted);text-transform:uppercase}
.ch5-steprow{display:flex;align-items:center;gap:10px;margin-top:13px;flex-wrap:wrap}
.ch5-sublbl{font-family:var(--mono);font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.ch5-allocacts{display:flex;gap:6px;margin-top:11px;flex-wrap:wrap}

/* Tempered flesh — combat stats, 2-up grid */
.ch5-flesh{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.ch5-core{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-bottom:12px}
.ch5-ccell{display:flex;flex-direction:column;gap:3px;background:var(--bg3);padding:9px 11px;align-items:flex-start}
.ch5-cv{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--bone)}
.ch5-fcell{display:flex;flex-direction:column;gap:3px;background:var(--bg2);padding:9px 12px}
.ch5-fk{font-family:var(--mono);font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.ch5-fv{font-family:var(--mono);font-size:15px;color:var(--bone)}
/* Staged-allocation preview: jade delta chip beside a combat stat (red when a stat would drop) */
.ch5-fd{font-style:normal;font-size:11px;color:var(--jade);margin-left:5px;font-weight:400}
.ch5-fd.dn{color:var(--blood-bright)}
.ch5-preview{font-style:normal;font-family:var(--mono);font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--jade);margin-left:7px;vertical-align:middle}

/* Soul imprint */
.ch5-imprint{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ch5-imp-seal{font-size:22px;color:var(--brass);line-height:1}
.ch5-imp-stars{color:var(--brass);font-size:13px}
.ch5-imp-pct{font-family:var(--mono);font-size:11px;color:var(--jade)}
.ch5-imp-copies{font-family:var(--mono);font-size:9px;color:var(--muted);margin-left:auto;text-transform:uppercase;letter-spacing:.1em}
.ch5-imp-btn{width:100%;margin-top:12px}

/* Killer move section sits full-width under the grid */
.ch5-killer{margin-top:28px}

@media (max-width:1300px){
  .ch5-sheet{max-width:1180px}
  .ch5-grid{grid-template-columns:1fr}
  .ch5-center{order:-1}
}

/* ---- Social: Friends & Trading (friends/requests/trades cards + the trade-builder modal) ---- */
.friend-cards,.trade-cards{display:flex;flex-direction:column;gap:10px;margin:6px 0 18px;max-width:680px}
.friend-card .body,.trade-card .body{display:flex;flex-direction:column;gap:9px}
.fc-head{display:flex;align-items:center;gap:11px}
.fc-acts{display:flex;flex-wrap:wrap;gap:6px}
.tc-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.tc-ledger{display:flex;align-items:flex-start;gap:12px}
.tc-col{flex:1;min-width:0}
.tc-arrow{color:var(--stone);font-size:1.15rem;align-self:center;flex:none}
.trade-exp{font-family:var(--mono);font-size:11px;color:var(--stone);opacity:.8;white-space:nowrap}
.trade-exp.warn{color:var(--blood,#b5483a);opacity:1}
.code-row{display:flex;align-items:center;gap:10px;margin:8px 0;flex-wrap:wrap}
.code-chip{font-family:var(--mono);font-size:1.15rem;letter-spacing:.2em;color:var(--stone);
  border:1px solid var(--line);padding:6px 16px;background:var(--bg2)}
.tb-tile.on{background:rgba(63,158,116,0.10)}
.tb-tile:hover{border-color:var(--jade)}
.tb-qty{font-family:var(--mono);background:var(--bg2);border:1px solid var(--line);color:var(--bone);padding:3px 6px}

/* ===== Loading overlay (for slow API calls) ===== */
.loading-overlay{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  background:rgba(10,8,7,0.75);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:opacity .2s}
.loading-overlay.hidden{opacity:0;pointer-events:none}
.loading-spinner{width:40px;height:40px;border:3px solid var(--line-strong);border-top-color:var(--blood-bright);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-msg{font-family:var(--mono);font-size:13px;letter-spacing:.16em;color:var(--bone-dim);text-transform:uppercase}

/* ===== RESPONSIVE — comprehensive device support ===== */

/* ---- large tablets / small laptops (≤1080px) ---- */
@media (max-width:1080px){
  .slots{width:90%;max-width:480px}
  #title h1{font-size:clamp(40px,12vw,96px)}
  #title::after{font-size:clamp(160px,50vw,440px);opacity:.4}
  .h4-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
  .h4-row{grid-template-columns:34px 1fr minmax(0,1fr)}
  .h4-row .h4-pos{display:none}
}

/* ---- tablets (≤900px) ---- */
@media (max-width:900px){
  #topbar{gap:12px;padding:10px 14px;flex-wrap:wrap}
  #topbar .logo{font-size:24px}
  .stat .val{font-size:16px}
  .stat .lbl{font-size:8px}
  .topbar-actions{gap:6px}
  .tb-link svg{width:16px;height:16px}
  .tb-online-lbl{display:none}
  #main{grid-template-columns:1fr}
  #nav{position:fixed;top:0;left:0;bottom:0;z-index:100;width:220px;transform:translateX(-100%);transition:transform .2s ease;box-shadow:4px 0 30px rgba(0,0,0,.5)}
  #nav.open{transform:translateX(0)}
  .nav-toggle{display:block;position:fixed;left:10px;bottom:10px;z-index:101;width:40px;height:40px;background:var(--panel);border:1px solid var(--line);border-radius:50%;font-size:18px;box-shadow:0 2px 12px rgba(0,0,0,.3)}
  #main.rail{grid-template-columns:1fr}
  #main.rail #nav{width:60px;transform:translateX(0)}
  #main.rail #nav .nav-lbl{display:none}
  #main.rail .nav-toggle{position:static;width:26px;height:26px;border-radius:3px}
  #content{padding:0 14px 80px}
  .slots{width:95%}
  .pagehead{grid-template-columns:1fr;gap:10px}
  .arena-pvp{grid-template-columns:1fr}
  .apv-podium{grid-template-columns:1fr}
  .mkt-split,.ref-split{grid-template-columns:1fr}
  .wk-rail,.mkt-desk,.ref-desk{position:static}
  .fm4-split,.bn2-split{grid-template-columns:1fr}
  .fm4-desk,.bn2-rail{position:static}
  .bn2-row{grid-template-columns:64px 1fr;gap:10px}
  .bn2-stats{grid-template-columns:repeat(2,1fr)}
  .bn2-loot{grid-column:1/-1}
  .cs-grid{grid-template-columns:1fr}
  .cs-statgrid{grid-template-columns:repeat(2,1fr)}
  .cs-attrs{grid-template-columns:repeat(2,1fr)}
  .ch5-grid{grid-template-columns:1fr}
  .ch5-center{order:-1}
  .ash-cores-split{grid-template-columns:1fr}
  .ash-cores-split .wk-rail{position:static}
  .h4-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
  .friend-cards,.trade-cards{max-width:100%}
  .modal-wide{width:95%}
  .fmtile{min-height:70px;padding:6px 10px}
  .tc-head{flex-wrap:wrap}
  .code-row{flex-direction:column;align-items:flex-start}
}

/* ---- tablets — fix battle arena overflow (bgrid needs narrower columns on mid-size) ---- */
@media (max-width:960px){
  .arena-top{gap:14px}
  .bgrid{grid-template-columns:repeat(2,minmax(120px,1fr));gap:6px}
  .bvs{font-size:26px}
  .arena-panels{gap:14px}
}

/* ---- phones (≤640px) ---- */
@media (max-width:640px){
  #topbar{gap:6px;padding:8px 8px}
  #topbar .logo{font-size:20px;display:none}
  .stat .val{font-size:13px}
  .stat .lbl{font-size:7px;letter-spacing:.12em}
  .topbar-actions{gap:4px}
  .tb-link svg{width:14px;height:14px}
  .tb-online-num{font-size:10px}
  #title h1{font-size:clamp(28px,10vw,48px)}
  #title .sub{font-size:9px;letter-spacing:.2em}
  .slots{width:100%;margin-top:16px}
  .slot{flex-direction:column;align-items:stretch;padding:12px 14px}
  .slot .acts{justify-content:flex-end}
  .starter-grid{grid-template-columns:1fr}
  #onboard-host{left:8px;right:8px;bottom:8px}
  .onboard-widget{width:auto;font-size:12px;padding:12px}
  #settings-fab{left:8px;bottom:8px;width:36px;height:36px;font-size:15px}
  .modal-wide{width:100%;border-radius:0;max-height:100vh;overflow-y:auto}
  .modal{width:100%;border-radius:0;max-height:100vh;overflow-y:auto}
  .h4-grid{grid-template-columns:1fr}
  .h4-row{grid-template-columns:34px 1fr;gap:8px;padding:6px 10px;font-size:12px}
  .cs-ident{grid-template-columns:1fr;gap:16px}
  .cs-aside{text-align:left}
  .cs-glance{grid-template-columns:1fr}
  .cs-cult{padding:16px}
  .cs-attrs{grid-template-columns:repeat(2,1fr)}
  .cs-statgrid{grid-template-columns:1fr}
  .ch5-sheet{padding:14px}
  .bounty-grid{grid-template-columns:1fr}
  .bounty-card{padding:16px 14px}
  .bounty-card .bc-stats{grid-template-columns:repeat(2,1fr)}
  .pvp-form{flex-direction:column}
  .arena-form{flex-direction:column;gap:8px}
  .ap-box{transform:none;margin:0}
  .ref-card{padding:10px 12px}
  .mkt-row{padding:8px 10px;flex-wrap:wrap}
  .mkt-name{font-size:14px}
  .fm4-lanehead{grid-template-columns:50px repeat(5,1fr);gap:4px}
  .fm4-board .fmboard{grid-template-columns:50px 1fr;gap:4px}
  .fmtile{min-height:56px;padding:4px 6px}
  .fmunit .uname{font-size:12px}
  .fmrealm{font-size:8px}
  .fm4-lanehead i{font-size:7px}
  .ash-table{font-size:11px}
  .ash-table th,.ash-table td{padding:4px 6px}
  .sec-head .sec-title{font-size:17px;letter-spacing:.1em}
  .sec-head .sec-meta{font-size:8px}
  .pagehead{padding:0 0 12px}
  .pagehead h2{font-size:20px}
  .pagehead .sub{font-size:10px}
  .ref-split,.mkt-split{grid-template-columns:1fr}
  .bn2-row{grid-template-columns:1fr;gap:8px;padding:10px 12px}
  .bn2-stats{grid-template-columns:repeat(4,1fr)}
  .bn2-seal{flex-direction:row;justify-content:flex-start;gap:8px;border-right:none;padding-right:0;padding-bottom:6px;border-bottom:1px solid var(--line)}
  .bn2-seal span{font-size:22px}
  .friend-card,.trade-card{padding:12px}
  .fc-head{flex-wrap:wrap}
  .tc-ledger{flex-direction:column}
  .trade-cards{margin:4px 0 12px}
  .code-row{flex-direction:column;align-items:stretch}
  .starter-grid .sg-card{padding:14px}
  .starter-grid .sg-name{font-size:17px}
  .ref-pbtn{font-size:12px;padding:4px 6px}
  .ref-tiers button{font-size:10px;padding:4px 8px}
  .apv-opponent{flex-direction:column;gap:10px}
  .arena-result{padding:16px;margin:10px}
  .arena-result .ar-verdict{font-size:28px}
  .arena-result .ar-title{font-size:16px}
}

/* ---- small phones (≤400px) ---- */
@media (max-width:400px){
  #topbar{gap:4px;padding:6px 4px}
  .stat .val{font-size:11px}
  .stat .lbl{font-size:6px;letter-spacing:.08em}
  .topbar-actions{gap:2px}
  .tb-link svg{width:12px;height:12px}
  button{font-size:11px;padding:5px 10px}
  .primary{font-size:11px;padding:5px 12px}
  #content{padding:0 8px 80px}
  .cs-attrs{grid-template-columns:1fr}
  .cs-statgrid{grid-template-columns:1fr}
  .h4-grid{grid-template-columns:1fr}
  .h4-stats{grid-template-columns:repeat(2,1fr)}
  .bounty-card .bc-head{flex-direction:column;gap:10px}
  .bounty-card .bc-seal{width:56px;height:56px;font-size:32px}
  .bounty-card .bc-name{font-size:20px}
  .ref-glyph span{font-size:28px}
  .ref-glyph i{width:42px;height:42px}
  .modal .body{padding:10px}
  /* battle arena: shrink to fit narrow phones */
  .arena{padding:12px 8px !important}
  .arena-top{gap:8px;flex-wrap:nowrap}
  .bgrid{grid-template-columns:repeat(2,minmax(80px,1fr));gap:4px;grid-template-rows:repeat(5,minmax(48px,auto))}
  .bvs{font-size:16px}
  .arena-panels{gap:8px}
  .arena .unitblock{padding:3px 4px;font-size:9px}
  .arena .unitblock .ub-name{font-size:8px}
  .arena .unitblock .ub-hp{font-size:7px}
  .arena .unitblock .ub-bar{height:5px}
  .arena .unitblock .ub-tier{font-size:7px;padding:0 3px}
  .arena-floor{font-size:9px;padding:3px 8px}
  .arena-skip{top:6px;font-size:10px;padding:4px 10px}
  .arena-result .ar-verdict{font-size:36px}
  .arena-result .ar-title{font-size:14px;letter-spacing:.2em}
  .arena .ub-icon{width:20px;height:20px;font-size:9px}
  /* codex tables: scroll instead of overflow */
  .cdx-table{font-size:12px;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .cdx-table .cdx-path{white-space:normal;word-break:break-word}
}
