:root{
  --violet:#3E6FE0;--violet2:#8FB6FF;--gold:#FFC23C;--gold2:#E8A41E;--blade:#5BC8FF;--cyan:#5BC8FF;--ink:#0a0a12;--bone:#EFE6CF;
  --panel:rgba(255,232,190,.05);--line:rgba(255,205,110,.16);
  --hp:#FF5E7E;--mp:#7CFFB0;
  --r-common:#9aa3b8;--r-rare:#5BC8FF;--r-epic:#FFC23C;--r-legend:#c98bff;
  --disp:'Cinzel Decorative','Cinzel',serif; /* chunky ornate display face, closer to the logo lettering */
}
*{box-sizing:border-box;margin:0;padding:0}
html{overscroll-behavior:none} /* no pull-to-refresh / rubber-band reload mid-game */
body{font-family:'Spectral','Segoe UI',system-ui,serif;background:#070810;color:var(--bone);min-height:100vh;overflow-x:hidden;overscroll-behavior:none;letter-spacing:.2px;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}
button,.card,.unit,.huntBtn,.spd,.sell,.stat{touch-action:manipulation}
.cols,.arenaInner,#combatLog,.meterBody,.modalInner,.detailInner,#installGate,#startScreen{overscroll-behavior:contain}
.stat b,.cost,.scount{font-family:'Cinzel','Spectral',serif}
h1,h2,#resultTitle,.arenaHead,.belt-label{font-family:var(--disp);font-weight:700}

/* ===== Start screen (menu) — run begins only on PLAY; hub for future modes ===== */
#startScreen{position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center;padding:26px;background:radial-gradient(130% 100% at 50% 2%,#1b2236 0%,#0a0b13 68%)}
#startScreen.hide{display:none}
.browser-mode #startScreen{display:none!important}
.ss-card{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;max-width:360px;width:100%}
.ss-logo{width:min(78vw,320px);height:auto;display:block;transform-origin:center;filter:drop-shadow(0 0 26px #ffcf5a55) drop-shadow(0 0 14px #8a44ff55);animation:logoIdle 2.6s ease-in-out infinite}
@keyframes logoIdle{0%,100%{transform:scale(1);filter:drop-shadow(0 0 22px #ffcf5a55) drop-shadow(0 0 14px #8a44ff55)}50%{transform:scale(1.035);filter:drop-shadow(0 0 34px #ffcf5a99) drop-shadow(0 0 16px #8a44ff77)}}
/* when the lobby track is being analysed, the logo pulses to the beat (JS drives --beat 0..1) */
.ss-logo.live{animation:none;transform:scale(calc(1 + var(--beat,0)*.085));filter:drop-shadow(0 0 calc(20px + var(--beat,0)*40px) #ffcf5a) drop-shadow(0 0 14px #8a44ff77);transition:transform .09s ease-out,filter .09s ease-out}
.ss-play{font-family:var(--disp);font-weight:900;font-size:20px;letter-spacing:2px;color:#0a0b13;background:linear-gradient(180deg,#FFD874,#FFC23C);border:1px solid #ffffff66;border-radius:14px;padding:15px 48px;cursor:pointer;box-shadow:0 8px 26px #ffc23c55;animation:bpulse 2.2s ease-in-out infinite}
.ss-play:hover{filter:brightness(1.08)}
.ss-how{font-family:var(--disp);font-weight:700;font-size:13px;letter-spacing:1px;color:var(--violet2);background:#ffffff10;border:1px solid var(--line);border-radius:11px;padding:11px 22px;cursor:pointer}
.ss-how:hover{background:#ffffff1a}
.ss-modes{font-size:11px;letter-spacing:1px;opacity:.5;margin-top:6px;text-transform:uppercase;font-family:var(--disp);font-weight:700}
.ss-modes span{opacity:.6;font-family:'Spectral';font-weight:400;text-transform:none;letter-spacing:0}

/* ===== PWA install gate (shown in a browser; the installed app skips it) ===== */
#installGate{display:none}
.browser-mode .wrap,.browser-mode #arena,.browser-mode #player,.browser-mode #achv,.browser-mode #pausedTag,.browser-mode #toast,.browser-mode #tip,.browser-mode #help,.browser-mode #detail{display:none!important}
.browser-mode #installGate{display:flex;position:fixed;inset:0;z-index:200;align-items:center;justify-content:center;padding:26px;background:radial-gradient(130% 100% at 50% 2%,#1b2236 0%,#0a0b13 68%)}
.ig-card{display:flex;flex-direction:column;align-items:center;gap:15px;text-align:center;max-width:360px;width:100%}
.ig-logo{width:min(74vw,300px);height:auto;display:block;filter:drop-shadow(0 0 26px #ffcf5a55) drop-shadow(0 0 14px #8a44ff55)}
.ig-tag{font-family:var(--disp);font-weight:700;color:var(--gold);letter-spacing:1px;font-size:15px}
.ig-btn{font-family:var(--disp);font-weight:900;font-size:18px;letter-spacing:1.5px;color:#0a0b13;background:linear-gradient(180deg,#FFD874,#FFC23C);border:1px solid #ffffff66;border-radius:14px;padding:14px 32px;cursor:pointer;box-shadow:0 8px 26px #ffc23c55;animation:bpulse 2.2s ease-in-out infinite}
.ig-btn:hover{filter:brightness(1.08)}
.ig-btn:disabled{filter:grayscale(.6) brightness(.8);box-shadow:none;animation:none;cursor:default}
.ig-ios{display:none;font-size:13.5px;opacity:.88;line-height:1.55;max-width:300px}
.ig-ios b{color:var(--gold)}.ig-share{color:var(--cyan)}
.ig-skip{display:none;background:none;border:none;color:var(--violet2);font-size:13px;opacity:.7;cursor:pointer;text-decoration:underline;margin-top:2px}

/* animated background */
.bg{position:fixed;inset:0;z-index:-3;background:radial-gradient(135% 95% at 50% -25%,#1b2236 0%,#11131e 36%,#070810 74%)}
.bg-sun{position:fixed;left:50%;top:-300px;width:620px;height:620px;transform:translateX(-50%);z-index:-2;border-radius:50%;
  background:radial-gradient(circle,#ffcf5a4d 0%,#caa01f22 44%,transparent 70%);filter:blur(11px);opacity:.5;animation:breathe 7s ease-in-out infinite}
.bg-grid{position:fixed;left:-50%;right:-50%;bottom:-10%;height:60vh;z-index:-2;
  background:linear-gradient(transparent,#2a344f1c),
   repeating-linear-gradient(90deg,#3a63c824 0 1px,transparent 1px 64px),
   repeating-linear-gradient(0deg,#3a63c824 0 1px,transparent 1px 64px);
  transform:perspective(340px) rotateX(64deg);mask:linear-gradient(transparent,#000 60%);animation:scroll 9s linear infinite}
@keyframes scroll{to{background-position:0 0,0 64px,0 64px}}
@keyframes breathe{50%{opacity:.75;filter:blur(14px)}}

.wrap{max-width:1120px;margin:0 auto;padding:16px 16px 30px}
.topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:start;gap:10px;margin-bottom:14px}
.topbtns{display:flex;gap:8px;align-items:center}
.topbtns button{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--panel);color:var(--bone);font-size:17px;font-weight:700;cursor:pointer;transition:.15s}
.topbtns button:hover{background:#ffffff14;box-shadow:0 0 14px #3E6FE055}
.brand{display:flex;align-items:center;justify-content:center;min-width:0}
.logoimg{height:116px;width:auto;max-width:100%;display:block;filter:drop-shadow(0 0 18px #ffcf5a44) drop-shadow(0 0 10px #3E6FE055)}
.topright{justify-self:end;width:186px;max-width:46vw;display:flex;flex-direction:column;gap:6px}
.scorecards{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.sc{display:flex;flex-direction:column;align-items:center;gap:0;line-height:1.1;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:3px 3px;backdrop-filter:blur(6px)}
.sc .sci{font-size:11px}
.sc b{font-size:13px;font-weight:800;font-family:'Cinzel'}
.sc .scl{font-size:7.5px;letter-spacing:1px;opacity:.5;text-transform:uppercase;font-weight:600}
.scorecards .sc:nth-child(1) b{color:var(--gold)}
.scorecards .sc:nth-child(2) b{color:var(--mp)}
.scorecards .sc:nth-child(3) b{color:var(--cyan)}

/* HUD */
.stats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.stat{display:flex;align-items:center;gap:5px;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:6px 12px;font-size:13px;backdrop-filter:blur(6px)}
.stat .lbl{opacity:.55;font-size:11px;font-weight:600}
.stat b{font-size:16px;font-weight:700;color:var(--bone)}
.stat.hp b{color:var(--hp)}.stat.gold b{color:var(--gold)}.stat.power b{color:var(--mp)}
.stat.dim2{opacity:.6}
/* relocated pills */
.roundbar .stat.gold{padding:7px 11px;gap:4px;font-size:14px;flex:0 0 auto}
.roundbar .stat.gold .gi{color:var(--gold)}
.panel h2.boardhead{align-items:center;opacity:1}
.boardhead .htitle{display:flex;align-items:baseline;gap:8px}
.boardhead .hstats{display:flex;gap:6px}
.boardhead .hstats .stat{padding:3px 9px;gap:4px;border-radius:9px;font-size:13px;opacity:1;background:var(--panel);border:1px solid var(--line);backdrop-filter:blur(6px)}
.boardhead .hstats .stat b{font-size:15px;font-weight:800;color:var(--bone)}
/* HP and Stage are key stats — keep them bright, not washed out */
.boardhead .hstats .stat.hp{background:#ff5e7e1c;border-color:#ff5e7e66}
.boardhead .hstats .stat.hp b,.boardhead .hstats .stat.hp .gi{color:var(--hp)}
.boardhead .hstats .stat:not(.hp){background:#ffc23c16;border-color:#ffc23c55}
.boardhead .hstats .stat:not(.hp) b,.boardhead .hstats .stat:not(.hp) .gi{color:var(--gold)}
.boardhead .htitle{color:var(--gold);opacity:1}
#boardCount,#benchCount{opacity:.9;color:var(--bone);font-weight:700;font-size:11px;font-family:'Spectral'}
.mini-stats{margin-top:12px;margin-bottom:0}

/* belt */
.belt-frame{position:relative;height:106px;border:none;border-radius:14px;overflow:hidden;
  background:url(belt-frame.webp?v=21) center center/100% 100% no-repeat}
.belt-rail{display:none}
.belt-rail.top{top:20px}.belt-rail.bot{bottom:20px}
@keyframes rail{to{background-position:28px 0}}
.belt-label{display:none}
.ready{position:absolute;top:6px;right:12px;font-size:11px;font-weight:700;letter-spacing:1px;z-index:3;padding:2px 9px;border-radius:6px;font-family:'Cinzel'}
.ready.ok{color:var(--mp);background:#7cffb016}.ready.wait{color:#FFB14C;background:#ffb14c16}
#belt{position:absolute;inset:0}
.card{position:absolute;top:14px;width:86px;height:78px;border-radius:12px;cursor:pointer;will-change:transform;user-select:none;
  background:linear-gradient(180deg,#1d2032,#13151f);border:2px solid var(--glow);overflow:hidden;
  display:flex;flex-direction:column;align-items:center;padding-top:5px;box-shadow:0 4px 14px #0007}
.card .ic{width:62px;height:40px;font-size:28px;display:flex;align-items:center;justify-content:center;pointer-events:none}
.card .nm{font-size:12px;font-weight:700;pointer-events:none;text-shadow:0 1px 3px #000}
.card .meta2{display:flex;gap:7px;align-items:center;font-size:12px;margin-top:1px;pointer-events:none}
.card .meta2 .cost{color:var(--gold);font-weight:700}
.card .tag{position:absolute;top:-1px;left:0;right:0;font-size:9px;font-weight:800;background:var(--gold);color:#000;padding:2px;text-align:center;letter-spacing:1px;display:none;pointer-events:none}
.card .tag.hunt{background:var(--cyan)}
.card.dim{filter:grayscale(.55) brightness(.62)}
.card.r-rare{box-shadow:0 0 12px -2px var(--r-rare),0 4px 14px #0007}
.card.r-epic{box-shadow:0 0 16px -2px var(--r-epic),0 4px 14px #0007}
.card.r-legend{box-shadow:0 0 22px -1px var(--r-legend),0 4px 14px #0007}
.card.flare-soft{box-shadow:0 0 14px 1px var(--glow)}
.card.flare-big{box-shadow:0 0 26px 5px var(--gold);animation:pulse .8s infinite alternate}
.card.flare-hunt{box-shadow:0 0 22px 4px var(--cyan);animation:pulse 1s infinite alternate}
.card.shake{animation:shake .32s}
@keyframes pulse{from{filter:brightness(1)}to{filter:brightness(1.4)}}
@keyframes shake{0%,100%{margin-left:0}20%{margin-left:-6px}60%{margin-left:6px}80%{margin-left:-3px}}

/* portrait (art swaps in over emoji) */
.port{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.port img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;z-index:2;filter:drop-shadow(0 2px 4px #000a)}
.pemoji{z-index:1}

.cols{display:grid;grid-template-columns:1.34fr 1fr;gap:14px;margin-top:14px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:13px;backdrop-filter:blur(8px)}
.panel h2{font-size:13px;letter-spacing:2px;opacity:.95;color:var(--gold);margin-bottom:9px;display:flex;justify-content:space-between;align-items:baseline}
.panel h2.mt{margin-top:14px}
.panel h2 span{opacity:.45;font-weight:400;letter-spacing:.5px;font-size:10px;font-family:'Spectral'}
.armylist{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;min-height:40px}

/* unit card — compact portrait-centric tile (fits the whole board/bench with little scroll) */
.unit{position:relative;min-width:0;border-radius:11px;padding:4px;background:linear-gradient(180deg,#151826,#10121d);border:1px solid var(--line);border-top:3px solid var(--uc);display:flex;flex-direction:column;gap:4px;transition:.15s}
.unit:hover{transform:translateY(-2px)}
.unit.onb{box-shadow:0 0 0 1px var(--uc) inset,0 0 16px -5px var(--uc)}
.unit.r-epic{box-shadow:0 0 13px -5px var(--r-epic)}
.unit.r-legend{box-shadow:0 0 18px -4px var(--r-legend);border-image:linear-gradient(120deg,#c98bff,#FFC23C,#5BE0FF) 1}
.unit.lvlpop{animation:lvlpop .7s}.unit.evopop{animation:evopop .8s}
@keyframes lvlpop{0%{transform:scale(1)}30%{transform:scale(1.06);box-shadow:0 0 20px 2px var(--gold)}100%{transform:scale(1)}}
@keyframes evopop{0%{transform:scale(1)}25%{transform:scale(1.13);box-shadow:0 0 30px 8px #c98bff;filter:brightness(1.6)}100%{transform:scale(1)}}
/* portrait tile with overlaid pips */
.uic{position:relative;width:100%;aspect-ratio:1/1;border-radius:8px;overflow:hidden;background:color-mix(in srgb,var(--uc) 20%,#0a0b13);border:1px solid color-mix(in srgb,var(--uc) 45%,transparent)}
.uic .port{position:absolute;inset:0}
.unit .sell{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:6px;border:none;background:#0009;color:var(--hp);font-size:11px;line-height:1;cursor:pointer;opacity:.85;z-index:4;transition:.12s}
.unit .sell:hover{opacity:1;background:#ff5e7e55}
.rolepip{position:absolute;top:2px;left:2px;z-index:3;width:18px;height:18px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;background:#000a;line-height:1}
.rolepip.rl-front{box-shadow:0 0 0 1px #ff7a7a99}.rolepip.rl-ranged{box-shadow:0 0 0 1px #ffc23c99}.rolepip.rl-support{box-shadow:0 0 0 1px #7cffb099}
.crestpip{position:absolute;bottom:14px;left:2px;z-index:3;width:18px;height:18px}
.crestpip .crest{width:18px;height:18px}
.costpip{position:absolute;bottom:14px;right:2px;z-index:3;font-size:11px;font-weight:800;color:var(--gold);background:#000a;border-radius:5px;padding:0 4px;font-family:'Cinzel'}
.unm{position:absolute;left:0;right:0;bottom:4px;z-index:2;font-size:9.5px;font-weight:700;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 3px;text-shadow:0 1px 2px #000,0 0 4px #000;background:linear-gradient(0deg,#000c,transparent)}
.uic .ubar{position:absolute;left:0;right:0;bottom:0;height:4px;background:#00000088;border-radius:0;border:none;z-index:3}
.ufill{position:absolute;inset:0;width:0;background:linear-gradient(90deg,var(--uc),#fff);opacity:.7;transition:width .3s}
.urow{display:flex;align-items:center;gap:3px}
.urow .stars{color:var(--gold);font-size:9px;letter-spacing:-1px;flex:0 0 auto}
.chip{flex:1;text-align:center;font-size:10px;font-weight:700;padding:2px 0;border-radius:6px;background:#ffffff0d;border:1px solid var(--line)}
.chip.hp{color:var(--mp)}.chip.atk{color:var(--gold)}
.ubtns{display:flex;gap:3px}
.ubtns button{font-size:11px;font-weight:700;padding:5px 4px;border-radius:7px;cursor:pointer;border:none;transition:.12s;line-height:1}
.ubtns .mv{flex:1;background:#ffffff12;border:1px solid var(--line);color:var(--bone)}
.unit.onb .ubtns .mv{background:#ffffff08;color:var(--violet2)}
.ubtns .evo{flex:0 0 auto;width:28px;background:linear-gradient(180deg,#c98bff,#3E6FE0);color:#fff;box-shadow:0 0 12px #c98bff66}
.ubtns .info{flex:0 0 auto;width:26px;background:#ffffff0d;border:1px solid var(--line);color:var(--cyan)}
.ubtns button:hover{filter:brightness(1.2)}
.empty{opacity:.4;font-size:12px;padding:12px;text-align:center;grid-column:1/-1}

/* ---------------- planning grid (6×4 board) ---------------- */
.benchhint{opacity:.4;font-weight:400;letter-spacing:.5px;font-size:9.5px;font-family:'Spectral'}
.planGrid{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:1fr;gap:5px}
.planGrid .cell{position:relative;aspect-ratio:1/1;border-radius:9px;border:1px dashed #ffffff18;background:#ffffff06;transition:border-color .12s,box-shadow .12s,background .12s}
.planGrid .cell.frontzone{background:#ff7a7a0a;border-color:#ff7a7a26}
.planGrid .cell.backzone{background:#7cffb00a;border-color:#7cffb01f}
.planGrid .cell.filled{border-style:solid;border-color:transparent;background:transparent}
.dragging-unit .planGrid .cell:not(.filled){border-color:#ffffff33;background:#ffffff0d}
.planGrid .cell.snap{border:1px solid var(--gold)!important;box-shadow:0 0 0 2px var(--gold),0 0 16px -2px var(--gold);background:#ffc23c22!important}
/* cardless board tile — portrait fills the cell; pips overlay role/stars/cost; bar at the foot */
.btile{position:relative;width:100%;height:100%;border-radius:9px;cursor:grab;touch-action:none;user-select:none;-webkit-user-select:none;box-shadow:0 0 0 1px var(--uc) inset,0 0 13px -5px var(--uc);overflow:hidden;transition:transform .12s,box-shadow .12s}
.btile:hover{transform:translateY(-1px);box-shadow:0 0 0 1px var(--uc) inset,0 0 16px -3px var(--uc)}
.btile.dragging{opacity:.35}
.btile.r-epic{box-shadow:0 0 0 1px var(--uc) inset,0 0 13px -4px var(--r-epic)}
.btile.r-legend{box-shadow:0 0 0 1px #FFC23C inset,0 0 16px -3px var(--r-legend)}
.bport{position:absolute;inset:0;background:color-mix(in srgb,var(--uc) 20%,#0a0b13)}
.bport .port{position:absolute;inset:0}
.btile .rolepip{top:2px;left:2px}
.btile .evoflag{position:absolute;top:2px;left:50%;transform:translateX(-50%);z-index:4;font-size:11px;color:#fff;text-shadow:0 0 7px #c98bff,0 0 3px #c98bff;animation:evoflag 1.4s ease-in-out infinite}
@keyframes evoflag{50%{opacity:.45}}
.bstars{position:absolute;top:2px;right:3px;z-index:3;color:var(--gold);font-size:8px;letter-spacing:-1.5px;text-shadow:0 1px 2px #000,0 0 4px #000}
.bcost{position:absolute;bottom:6px;right:2px;z-index:3;font-size:8.5px;font-weight:800;color:var(--gold);background:#000a;border-radius:4px;padding:0 3px;font-family:'Cinzel'}
.bname{position:absolute;left:0;right:0;bottom:4px;z-index:2;font-size:8px;font-weight:700;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 2px;text-shadow:0 1px 2px #000,0 0 4px #000;background:linear-gradient(0deg,#000c,transparent 90%)}
.bbar{position:absolute;left:0;right:0;bottom:0;height:3px;background:#00000088;z-index:3}
.bfill{position:absolute;inset:0;width:0;background:linear-gradient(90deg,var(--uc),#fff);opacity:.7;transition:width .3s}
/* floating drag ghost + bench drop highlight */
.dragGhost{position:fixed;z-index:120;width:56px;height:56px;border-radius:11px;overflow:hidden;pointer-events:none;transform:translate(-50%,-50%) scale(1.06);box-shadow:0 0 0 2px var(--uc),0 8px 22px #000b,0 0 18px -2px var(--uc);opacity:.95}
.dragGhost .port{position:absolute;inset:0}
.benchdrop-on .benchwrap{outline:2px dashed var(--gold);outline-offset:3px;border-radius:11px;background:#ffc23c0d}
.dragging-unit{cursor:grabbing}
.dragging-unit *{cursor:grabbing!important}
/* board-tile action popover */
.actpop{position:fixed;z-index:130;display:flex;flex-direction:column;gap:4px;min-width:128px;padding:7px;background:#12141fF2;border:1px solid #3E6FE077;border-radius:12px;box-shadow:0 12px 32px #000b,0 0 22px -6px #3E6FE0;backdrop-filter:blur(8px);animation:popin .14s ease-out}
@keyframes popin{from{opacity:0;transform:translateY(-4px) scale(.96)}}
.actpop .actname{font-family:var(--disp);font-weight:800;font-size:11px;letter-spacing:1px;color:var(--gold);text-align:center;padding:1px 0 3px;border-bottom:1px solid var(--line);margin-bottom:1px}
.actpop .act{font-size:12px;font-weight:700;padding:7px 9px;border-radius:8px;cursor:pointer;border:1px solid var(--line);background:#ffffff10;color:var(--bone);text-align:left;transition:.12s}
.actpop .act:hover{filter:brightness(1.2);background:#ffffff18}
.actpop .act.evo{background:linear-gradient(180deg,#c98bff,#3E6FE0);color:#fff;border-color:#c98bff;box-shadow:0 0 12px #c98bff55}
.actpop .act.sell{color:var(--hp);border-color:#ff5e7e44}

/* synergy */
#synergy{display:flex;flex-direction:column;gap:6px}
.syn{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:9px;background:#ffffff07;border:1px solid var(--line);font-size:12.5px;opacity:.5;transition:.15s}
.syn.on{opacity:1;border-color:var(--sc,var(--gold));background:color-mix(in srgb,var(--sc,var(--gold)) 13%,transparent);box-shadow:0 0 12px -3px var(--sc,var(--gold))}
.syn .sicon{color:var(--sc,inherit);font-size:14px;display:inline-flex;align-items:center}.syn .sname{flex:1;font-weight:700}
.syn .scount{font-weight:700;color:var(--gold);font-size:13px}
/* faction crest emblem */
.crest{display:inline-flex;align-items:center;justify-content:center;width:1.35em;height:1.35em;vertical-align:middle;position:relative}
.crest img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 1px 2px #000a)}
.syn .sicon .crest{width:20px;height:20px}
/* hunt — grouped by faction with crest headers + real-art portraits */
#hunts{display:flex;flex-direction:column;gap:8px}
.huntGrp{border:1px solid var(--line);border-radius:11px;padding:7px 8px;background:color-mix(in srgb,var(--hc,#888) 7%,transparent)}
.huntHead{display:flex;align-items:center;gap:6px;font-family:var(--disp);font-weight:800;font-size:11px;letter-spacing:1px;color:var(--hc,var(--bone));margin-bottom:6px}
.huntHead .crest{width:18px;height:18px}
.huntRow{display:flex;flex-wrap:wrap;gap:6px}
.huntBtn{width:42px;height:42px;padding:3px;background:#ffffff0d;border:1px solid var(--line);border-radius:10px;cursor:pointer;transition:.12s;overflow:hidden}
.huntBtn .port{width:100%;height:100%}
.huntBtn:hover{background:#ffffff18;transform:translateY(-1px)}
.huntBtn.on{background:color-mix(in srgb,var(--hc,#5be0ff) 22%,transparent);border-color:var(--hc,var(--cyan));box-shadow:0 0 9px color-mix(in srgb,var(--hc,#5be0ff) 60%,transparent)}
.controls{margin-top:14px}
#mainbar{display:flex;gap:10px;align-items:center;margin-top:12px;position:relative;z-index:46}
#mainbar .roundbar{flex:1;margin-top:0}
.drawerToggle{display:none}
#battleBtn{width:100%;background:linear-gradient(180deg,#E8455E,#9E1430);color:#FFE9C2;border:1px solid #FFCB4577;font-family:var(--disp);font-weight:900;font-size:13px;letter-spacing:1.5px;padding:9px 8px;border-radius:10px;cursor:pointer;text-shadow:0 1px 2px #4a0a16;box-shadow:0 6px 16px #9e143066,0 0 14px #ffc23c22;animation:bpulse 2.2s ease-in-out infinite}
#battleBtn:hover{filter:brightness(1.12)}
@keyframes bpulse{50%{box-shadow:0 6px 22px #9e1430aa,0 0 22px #ffcb4566}}
.hint{font-size:11px;opacity:.5;margin-top:11px;line-height:1.55}
.footer{text-align:center;font-size:10.5px;opacity:.32;margin-top:18px;letter-spacing:.5px}
.footer code{color:var(--violet2)}

/* arena */
#arena{position:fixed;inset:0;background:#05030cf2;display:none;align-items:center;justify-content:center;z-index:65;backdrop-filter:blur(5px)}
#arena.show{display:flex;animation:fade .25s}
@keyframes fade{from{opacity:0}}
.arenaInner{position:relative;width:min(980px,95vw);max-height:95vh;overflow:auto;background:linear-gradient(180deg,#141728,#0b0d16);border:1px solid #3E6FE077;border-radius:20px;padding:20px;box-shadow:0 0 70px #3E6FE044,0 20px 60px #000a}
/* themed boss-round background — one or more oversized images, layered + cross-dissolved, each
   gently panned for an animated parallax look (sits behind the battlefield, under a dark vignette) */
#bossBg{position:absolute;inset:0;z-index:0;opacity:0;transition:opacity .8s;pointer-events:none;border-radius:20px;overflow:hidden}
#bossBg.show{opacity:.5}
#bossBg::after{content:'';position:absolute;inset:0;z-index:2;background:radial-gradient(120% 95% at 50% 36%,transparent,#05030cdd)}
#bossBg .bgLayer{position:absolute;inset:0;z-index:1;background-size:cover;background-position:center;opacity:0;transition:opacity 1.6s ease;animation:bossPan 15s ease-in-out infinite alternate}
#bossBg .bgLayer.on{opacity:1}
#bossBg .bgLayer:nth-child(even){animation-duration:19s;animation-direction:alternate-reverse}
@keyframes bossPan{from{transform:scale(1.22) translate(-8%,-3%)}to{transform:scale(1.22) translate(8%,3%)}}
/* keep gameplay content above the boss background */
.arenaInner>.arenaHead,.arenaInner>.teams,.arenaInner>.battleinfo,.arenaInner>.resultBox,.arenaInner>.reportLbl,.arenaInner>#waveBanner{position:relative;z-index:1}
.arenaHead{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.arenaHead .ah{font-size:20px;letter-spacing:4px;font-weight:900;color:var(--gold);text-shadow:0 0 20px #ffc23c66}
.spdctrl{font-size:10px;letter-spacing:2px;opacity:.8;display:flex;align-items:center;gap:5px}
.spd{background:#ffffff10;border:1px solid var(--line);color:var(--bone);border-radius:7px;padding:4px 9px;font-size:11px;font-weight:700;cursor:pointer}
.spd.on{background:var(--gold);color:#000;border-color:var(--gold)}
/* boss rounds lock to 1× — the other speeds grey out */
.spdctrl.locked .spd{opacity:.32;pointer-events:none}
.spdctrl.locked .spd.on{opacity:1;box-shadow:0 0 9px var(--gold)}
.spdctrl.locked::after{content:'🔒';margin-left:1px;font-size:10px;opacity:.85}
/* Battlefield is TOP (enemy) vs BOTTOM (player) — column-reverse over DOM order [ally, vs, enemy]. */
.teams{display:flex;flex-direction:column-reverse;gap:8px;align-items:stretch}
.teamLbl{font-size:11px;letter-spacing:2px;margin-bottom:6px;text-align:center;font-weight:700}.teamLbl.ally{color:var(--mp)}.teamLbl.enemy{color:#ff8a9a}
.vs{align-self:center}.vs span{font-family:var(--disp);font-size:18px;font-weight:900;opacity:.5;text-shadow:0 0 16px #fff4}
/* auto-chess grid: each side a 6-col × 4-row grid; both FRONT rows (row 0) meet at the VS line.
   Ally grid sits below (row 0 at its top), enemy grid mirrored above (row 0 at its bottom). */
.fighters{display:flex;justify-content:center;min-height:0}
.fgrid{display:grid;grid-template-columns:repeat(6,var(--fw,90px));grid-auto-rows:auto;gap:6px 7px;justify-content:center;align-items:end}
.fgrid.enemy{align-items:start}
/* cardless combatant — just the character with a health bar floating above its head */
.fighter{position:relative;width:var(--fw,90px);display:flex;flex-direction:column;align-items:center;text-align:center;transition:opacity .35s,filter .35s,transform .35s}
.fighter.slidein{animation:waveIn .42s cubic-bezier(.2,1.1,.4,1)}
@keyframes waveIn{0%{opacity:0;transform:translateY(-40px) scale(.85)}100%{opacity:1;transform:none}}
.fhead{position:relative;width:84%;z-index:5}
.fighter .hpbar{position:relative;height:7px;background:#000b;border-radius:4px;overflow:hidden;border:1px solid #0007;box-shadow:0 1px 2px #0007}
.fighter .hp{position:absolute;inset:0;width:100%;background:linear-gradient(90deg,#37d36a,#5bf08a);transition:width .25s,background .25s;z-index:1}
.fighter .shield{position:absolute;top:0;left:0;height:100%;width:0;background:linear-gradient(90deg,#aeb6c2,#eef2f7);opacity:.95;z-index:2;transition:width .2s;box-shadow:0 0 6px #cfd6e0cc}
.fighter .fstatus{position:absolute;left:50%;top:9px;transform:translateX(-50%);font-size:11px;line-height:1;z-index:8;text-shadow:0 1px 2px #000;letter-spacing:-1px;white-space:nowrap}
.fighter .fbody{position:relative;width:var(--fw,90px);height:var(--fh,90px);display:flex;align-items:center;justify-content:center}
.fighter .fic{width:100%;height:100%;font-size:var(--ff,48px);display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 5px 5px #0009)}
.fighter .fname{max-width:118%;font-size:10px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 2px #000,0 0 5px #000;margin-top:1px}
.fighter.a .fname{color:#bfe9ff}.fighter.e .fname{color:#ff9aa8}
.fighter.dead{opacity:.1;filter:grayscale(1) blur(.6px);transform:translateY(10px) scale(.88) rotate(-3deg)}
/* BOSS — bigger, no frame, ominous aura + glowing name */
.fighter.boss{width:calc(var(--fw,90px)*1.5)}
.fighter.boss .fhead{width:94%}
.fighter.boss .fbody{height:calc(var(--fh,90px)*1.5)}
.fighter.boss .fic{font-size:calc(var(--ff,48px)*1.5);filter:drop-shadow(0 0 16px #FFB020) drop-shadow(0 5px 5px #0009);animation:bossglow 1.9s ease-in-out infinite}
@keyframes bossglow{0%,100%{filter:drop-shadow(0 0 12px #FFCF3A) drop-shadow(0 5px 5px #0009)}50%{filter:drop-shadow(0 0 28px #FFB020) drop-shadow(0 5px 5px #0009)}}
.fighter.boss .bosslbl{font-family:var(--disp);font-size:9px;font-weight:900;letter-spacing:2px;color:#FFE07A;text-shadow:0 0 8px #FFB020,0 1px 2px #000;z-index:6;margin-bottom:1px}
.fighter.boss .fname{color:#FFE07A}
/* arcade-style boss commentary chat box (pops on boss appearance, lines cycle, then fades) */
#bossChat{position:absolute;left:50%;top:8px;transform:translate(-50%,-12px);z-index:40;display:flex;align-items:stretch;gap:9px;max-width:min(440px,92%);padding:8px 11px 8px 8px;background:linear-gradient(180deg,#1a1326f2,#0d0a16f2);border:2px solid #FFCF3A;border-radius:14px;box-shadow:0 0 0 2px #0008,0 10px 30px #000b,0 0 26px -4px #FFB020;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
#bossChat.show{opacity:1;transform:translate(-50%,0)}
#bossChat .bcPortrait{flex:0 0 auto;width:46px;height:46px;border-radius:10px;overflow:hidden;background:#FFCF3A22;border:1px solid #FFCF3A88;position:relative;display:flex;align-items:center;justify-content:center;font-size:26px}
#bossChat .bcPortrait .port{position:absolute;inset:0}
#bossChat .bcBody{display:flex;flex-direction:column;justify-content:center;min-width:0}
#bossChat .bcName{font-family:var(--disp);font-weight:900;font-size:11px;letter-spacing:1.5px;color:#FFE07A;text-shadow:0 0 8px #FFB020,0 1px 2px #000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
#bossChat .bcLine{font-size:12.5px;color:var(--bone);line-height:1.3;font-style:italic;text-shadow:0 1px 2px #000}
#bossChat .bcLine.type{animation:bcType .35s steps(1) ,bcBlink .8s step-end infinite}
@keyframes bcType{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}
@keyframes bcBlink{50%{box-shadow:none}}
#bossChat .bcLine.type::after{content:'▮';color:#FFCF3A;margin-left:2px;animation:bcCaret .7s step-end infinite}
@keyframes bcCaret{50%{opacity:0}}
/* boss intro cinematic — struts in at round start, speaks, trods off, then the waves begin */
.bossIntro{position:absolute;inset:0;z-index:55;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;cursor:pointer;opacity:0;transition:opacity .3s}
.bossIntro.show{opacity:1}
.bossIntro.leave{opacity:0}
.bossIntro .biVeil{position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 45%,#1a0f24e8,#05030cf7);backdrop-filter:blur(3px);z-index:-1}
.bossIntro .biFighter{display:flex;flex-direction:column;align-items:center;gap:8px;transform:translateX(120%) scale(.9);opacity:0;animation:bossStrut .7s cubic-bezier(.2,.9,.3,1) forwards}
@keyframes bossStrut{60%{opacity:1}100%{transform:translateX(0) scale(1);opacity:1}}
.bossIntro .biFighter.troddoff{animation:bossTrod .85s ease-in forwards}
@keyframes bossTrod{0%{transform:translateX(0) scale(1);opacity:1}100%{transform:translateX(-140%) scale(.85) rotate(-3deg);opacity:0}}
.bossIntro .biPortrait{width:min(40vw,180px);height:min(40vw,180px);border-radius:18px;overflow:hidden;position:relative;border:2px solid #FFCF3A;box-shadow:0 0 0 3px #0009,0 12px 40px #000c,0 0 46px -6px #FFB020;background:#FFCF3A18;display:flex;align-items:center;justify-content:center;font-size:84px;animation:bossGlowPulse 1.8s ease-in-out infinite}
@keyframes bossGlowPulse{50%{box-shadow:0 0 0 3px #0009,0 12px 40px #000c,0 0 64px -2px #FFB020}}
.bossIntro .biPortrait .port{position:absolute;inset:0}
.bossIntro .biName{font-family:var(--disp);font-weight:900;font-size:clamp(15px,4.6vw,26px);letter-spacing:2px;color:#FFE07A;text-shadow:0 0 16px #FFB020,0 2px 4px #000;text-align:center;padding:0 12px}
.bossIntro .biChat{min-height:1.4em;max-width:min(460px,90%);text-align:center}
.bossIntro .biLine{font-size:clamp(13px,3.6vw,18px);color:#fff;font-style:italic;line-height:1.4;text-shadow:0 2px 6px #000}
.bossIntro .biLine.type{animation:biLineIn .3s ease-out}
@keyframes biLineIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.bossIntro .biSkip{position:absolute;bottom:16px;right:18px;font-size:11px;letter-spacing:2px;color:#ffffff66;font-weight:700}
.fighter.atk-a{animation:lungeR .32s ease-out;z-index:5}.fighter.atk-e{animation:lungeL .32s ease-out;z-index:5}
@keyframes lungeR{0%{transform:translateY(0)}45%{transform:translateY(-20px)}100%{transform:translateY(0)}}
@keyframes lungeL{0%{transform:translateY(0)}45%{transform:translateY(20px)}100%{transform:translateY(0)}}
.fighter.atk-a .fic,.fighter.atk-e .fic{animation:jab .32s ease-out}
@keyframes jab{0%{transform:scale(1) rotate(0)}45%{transform:scale(1.5) rotate(-15deg)}100%{transform:scale(1) rotate(0)}}
.fighter.hit{animation:flinch .3s}@keyframes flinch{0%,100%{transform:translate(0,0)}25%{transform:translate(-4px,2px)}60%{transform:translate(4px,-1px)}}
.fighter.hit .fic{animation:hitflash .3s}@keyframes hitflash{0%{filter:none}22%{filter:brightness(2.6) drop-shadow(0 0 10px #fff) saturate(.4)}100%{filter:drop-shadow(0 5px 5px #0009)}}
.spark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:28px;pointer-events:none;animation:sparkpop .4s ease-out;z-index:6}
@keyframes sparkpop{0%{transform:scale(.3);opacity:0}30%{transform:scale(1.3);opacity:1}100%{transform:scale(2);opacity:0}}
/* floating combat numbers — color coded by type */
.popnum{position:absolute;top:-2px;left:50%;font-family:'Cinzel';font-weight:800;font-size:14px;pointer-events:none;text-shadow:0 1px 3px #000,0 0 6px #000;animation:popfloat .68s ease-out forwards;z-index:9;white-space:nowrap}
.popnum.dmg{color:#ff5161}.popnum.kill{color:#ff2e44;font-size:18px}
.popnum.burn{color:#ff9326}.popnum.poison{color:#b870ff}
.popnum.heal{color:#46b4ff}.popnum.shield{color:#dfe6ef}.popnum.block{color:#b6bdc9;font-size:12px}
.popnum.weaken{color:#c98bff;font-size:12px}
/* richer attacks — only added at 1x / 2x speed */
.fighter.big.atk-a{animation:lungeRbig .42s ease-out}
.fighter.big.atk-e{animation:lungeLbig .42s ease-out}
@keyframes lungeRbig{0%{transform:translateY(0) scale(1)}38%{transform:translateY(-46px) scale(1.15)}56%{transform:translateY(-40px) scale(1.12)}100%{transform:translateY(0) scale(1)}}
@keyframes lungeLbig{0%{transform:translateY(0) scale(1)}38%{transform:translateY(46px) scale(1.15)}56%{transform:translateY(40px) scale(1.12)}100%{transform:translateY(0) scale(1)}}
.fighter.big .fic{animation:jabbig .42s ease-out}
@keyframes jabbig{0%{transform:scale(1) rotate(0)}40%{transform:scale(1.85) rotate(-24deg)}100%{transform:scale(1) rotate(0)}}
.fighter.a.hit-big{animation:knockL .42s ease-out}
.fighter.e.hit-big{animation:knockR .42s ease-out}
@keyframes knockL{0%,100%{transform:translateY(0) rotate(0)}28%{transform:translateY(13px) rotate(-4deg)}}
@keyframes knockR{0%,100%{transform:translateY(0) rotate(0)}28%{transform:translateY(-13px) rotate(4deg)}}
.spark.big{font-size:40px;animation:sparkpop .5s ease-out}
.popnum.big{font-size:17px}.popnum.big.kill{font-size:23px}.popnum.big.block,.popnum.big.weaken{font-size:14px}
.slash{position:absolute;inset:-6px;pointer-events:none;z-index:6;mix-blend-mode:screen;background:linear-gradient(115deg,transparent 42%,#fff 49%,#fff 51%,transparent 58%);opacity:0;animation:slashfx .38s ease-out}
@keyframes slashfx{0%{opacity:0;transform:translateX(-40%) scaleY(.6)}30%{opacity:.95}100%{opacity:0;transform:translateX(40%) scaleY(1.1)}}
/* WAVE / BOSS cue — punches in over the arena when the next wave flows on */
#waveBanner{position:fixed;left:50%;top:34%;transform:translate(-50%,-50%) scale(.7);z-index:80;pointer-events:none;font-family:var(--disp);font-weight:900;letter-spacing:4px;font-size:34px;color:#fff;text-shadow:0 0 22px #3E6FE0,0 3px 10px #000;opacity:0}
#waveBanner.show{animation:wavePunch 1.3s ease-out}
#waveBanner.boss{color:#FFE07A;text-shadow:0 0 26px #FF7A2C,0 3px 12px #000;letter-spacing:3px;font-size:30px}
@keyframes wavePunch{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}18%{opacity:1;transform:translate(-50%,-50%) scale(1.12)}30%{transform:translate(-50%,-50%) scale(1)}78%{opacity:1}100%{opacity:0;transform:translate(-50%,-50%) scale(1)}}
@media(max-width:600px){#waveBanner{font-size:24px;letter-spacing:2px}#waveBanner.boss{font-size:21px}}
.lvchip{display:inline-block;font-family:var(--disp);font-size:10px;font-weight:900;letter-spacing:1px;color:#0a0b13;background:linear-gradient(180deg,#FFE07A,#FFB020);border-radius:6px;padding:1px 6px;vertical-align:middle;box-shadow:0 0 10px -2px #FFB020}
.arenaInner.qshake{animation:qshake .32s}
@keyframes qshake{0%,100%{transform:translate(0,0)}20%{transform:translate(-5px,3px)}50%{transform:translate(5px,-3px)}80%{transform:translate(-3px,2px)}}
@keyframes dmgfloat{0%{opacity:0;transform:translate(-50%,4px) scale(.8)}20%{opacity:1}100%{opacity:0;transform:translate(-50%,-30px) scale(1.15)}}
@keyframes popfloat{0%{opacity:0;transform:translate(calc(-50% + var(--jit,0px)*.2),6px) scale(.7)}18%{opacity:1;transform:translate(calc(-50% + var(--jit,0px)*.5),-10px) scale(1.12)}100%{opacity:0;transform:translate(calc(-50% + var(--jit,0px)),-38px) scale(1)}}
/* Battlefield owns the arena during the fight (room for animations); the report appears post-battle. */
.battleinfo{display:none;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.arenaInner.ended .battleinfo{display:grid;animation:reportrise .35s ease-out}
@keyframes reportrise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.reportLbl{display:none}
.arenaInner.ended .reportLbl{display:block;text-align:center;font-family:var(--disp);font-weight:900;font-size:12px;letter-spacing:4px;color:var(--cyan);opacity:.7;margin-top:16px}
/* Fight phase: let the two boards breathe so charges/casts have travel room. */
/* Fight phase: separate the top/bottom boards so charges/casts have travel room across the center. */
.arenaInner:not(.ended) .teams{min-height:54vh;justify-content:space-between}
.arenaInner.ended .teams{min-height:0;gap:6px}
/* Battle Report — the combat log and the DMG/SUPP meter are a matched pair:
   identical frame, a 34px header bar, and an equal-height body. */
.logwrap,.meter{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#08050f;display:flex;flex-direction:column}
.logHead,.meterTabs{height:34px;flex:0 0 34px;border-bottom:1px solid var(--line);background:#ffffff07}
.logHead{display:flex;align-items:center;padding:0 12px;font-family:var(--disp);font-weight:700;font-size:10px;letter-spacing:2px;color:var(--cyan);opacity:.85}
.meterTabs{display:flex}
.mtab{flex:1;background:none;border:none;color:var(--bone);opacity:.5;font-family:var(--disp);font-weight:700;font-size:10px;letter-spacing:1px;padding:0 4px;cursor:pointer;border-bottom:2px solid transparent}
.mtab.on{opacity:1;color:var(--gold);border-bottom-color:var(--gold)}
#combatLog,.meterBody{height:150px;overflow-y:auto}
#combatLog{padding:8px 12px;font-size:11.5px;line-height:1.6;font-family:ui-monospace,Menlo,Consolas,monospace}
.logline{padding:1px 0}
.logline.la{color:#9CFFC4}.logline.le{color:#ff9aa8}
.meterBody{padding:10px;display:flex;flex-direction:column;gap:8px}
.mrow{display:grid;grid-template-columns:62px 1fr 42px;align-items:center;gap:9px;font-size:11px}
.mname{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.9}
.mbar{height:8px;background:#ffffff12;border-radius:5px;overflow:hidden}
.mfill{height:100%;width:0;border-radius:5px;background:linear-gradient(90deg,var(--mc,#888),#fff6);transition:width .25s}
.mfill.dmg{background:linear-gradient(90deg,#FFC23C,#ff7a3c)}
.mfill.supp{background:linear-gradient(90deg,#7CFFB0,#5BC8FF)}
.mval{font-family:'Cinzel';font-weight:700;font-size:11px;color:var(--gold);text-align:right}
.meterBody .msub{color:var(--mp)}
.msub{font-size:8.5px;opacity:.7;font-family:'Spectral'}
.mempty{opacity:.4;text-align:center;padding:14px;font-size:11px}
.resultBox{display:none;margin:14px auto 0;align-items:center;justify-content:space-between;gap:14px;padding:12px 16px 12px 20px;border-radius:14px;background:#0a0b13f5;box-shadow:0 14px 44px #000b;max-width:560px}
.resultBox.show{display:flex;animation:resultpop .32s ease-out}
.resultBox.win{border:1px solid #39FF88;box-shadow:0 0 30px #39ff8855,0 14px 44px #000b}
.resultBox.loss{border:1px solid #ff5a6e;box-shadow:0 0 30px #ff5a6e55,0 14px 44px #000b}
.resultText{text-align:left;line-height:1.15}
#resultTitle{font-size:20px;font-weight:900;letter-spacing:1px}#resultSub{font-size:12px;opacity:.8;margin-top:1px}
#continueBtn{background:linear-gradient(180deg,#FFD874,#FFC23C);color:#000;border:none;font-family:var(--disp);font-weight:900;font-size:13px;letter-spacing:1px;padding:11px 18px;border-radius:11px;cursor:pointer;white-space:nowrap;flex:0 0 auto}
@keyframes pop{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes resultpop{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* help modal */
.modal{position:fixed;inset:0;background:#05030cf2;display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(5px)}
.modal.hide{display:none}
.modalInner{width:min(540px,92vw);background:linear-gradient(180deg,#141728,#0b0d16);border:1px solid #3E6FE077;border-radius:18px;padding:24px;box-shadow:0 0 60px #3E6FE044}
.modalInner h2{font-size:18px;letter-spacing:3px;color:var(--gold);margin-bottom:14px;text-align:center}
.modalInner ol{margin:0 0 18px 18px;font-size:14px;line-height:1.75}
.modalInner li{margin-bottom:7px}.modalInner .g{color:var(--gold);font-weight:700}.modalInner .c{color:var(--cyan);font-weight:700}
.cltitle{font-family:'Cinzel';font-size:11px;letter-spacing:2px;color:var(--cyan);opacity:.8;margin:0 0 8px}
.classlegend{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin:0 0 18px;font-size:12.5px}
.classlegend .cl{background:#ffffff08;border:1px solid var(--line);border-radius:8px;padding:7px 9px}
.classlegend .cl b{font-weight:700}
#helpClose{width:100%;background:linear-gradient(180deg,#FFD874,#FFC23C);color:#0a0b13;border:1px solid #ffffff66;font-family:var(--disp);font-weight:900;letter-spacing:1.5px;padding:14px;border-radius:12px;cursor:pointer;font-size:16px;box-shadow:0 8px 22px #ffc23c44}
/* visual how-to modal */
.help2{max-height:92vh;overflow-y:auto}
.help2 h2{margin-bottom:18px}
.hsteps{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:16px}
.hstep{position:relative;background:#ffffff08;border:1px solid var(--line);border-radius:12px;padding:13px 7px 9px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}
.hstep .hn{position:absolute;top:-9px;left:50%;transform:translateX(-50%);width:21px;height:21px;border-radius:50%;background:linear-gradient(180deg,#5b86e8,#2747a8);color:#fff;font-family:var(--disp);font-weight:900;font-size:11px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 10px #3E6FE077;border:1px solid #ffffff33}
.hstep .hi{font-size:24px;line-height:1;margin-bottom:3px}
.hstep b{font-family:var(--disp);font-weight:700;color:var(--gold);font-size:11px;letter-spacing:.5px}
.hstep>span:last-child{font-size:10px;opacity:.72;line-height:1.25}
.htips,.htags{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.htip,.htag{display:flex;align-items:center;gap:9px;background:#ffffff08;border:1px solid var(--line);border-radius:10px;padding:9px 11px}
.htip .hi,.htag .hi{font-size:19px;line-height:1;flex:0 0 auto}
.htip>div,.htag>div{display:flex;flex-direction:column;line-height:1.18;min-width:0}
.htip b,.htag b{font-family:var(--disp);font-weight:700;font-size:11px;color:var(--bone);letter-spacing:.3px}
.htip span,.htag span{font-size:10px;opacity:.72}
.htip.g{border-color:#FFC23C66}.htip.g b{color:var(--gold)}
.htip.c{border-color:#5BC8FF66}.htip.c b{color:var(--cyan)}
/* how-to: grid positioning callout + faction crest strip + boss teaser */
.gridnote{display:flex;align-items:center;gap:11px;background:linear-gradient(180deg,#3E6FE01c,#ffffff06);border:1px solid #3E6FE066;border-radius:12px;padding:10px 12px;margin-bottom:16px}
.gridnote .gi2{font-size:23px;line-height:1;flex:0 0 auto}
.gridnote>div{display:flex;flex-direction:column;gap:2px;line-height:1.3;min-width:0}
.gridnote>div>b{font-family:var(--disp);color:var(--gold);font-size:11px;letter-spacing:.5px}
.gridnote>div>span{font-size:10.5px;opacity:.78}
.gridnote>div>span b{color:var(--cyan);font-family:inherit;letter-spacing:0}
.hfactions{display:flex;gap:6px;margin-bottom:14px}
.hfac{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;background:#ffffff08;border:1px solid var(--line);border-radius:10px;padding:8px 3px}
.hfac img{width:30px;height:30px;object-fit:contain;filter:drop-shadow(0 1px 3px #000a)}
.hfac b{font-size:9.5px;font-weight:700;opacity:.85;font-family:'Spectral';letter-spacing:.3px}
.bossteaser{font-size:11px;opacity:.72;line-height:1.5;margin-bottom:16px;text-align:center}
.bossteaser b{color:#FFE07A;font-weight:700}

#toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:#0a0b13ee;border:1px solid var(--gold);color:var(--bone);padding:11px 20px;border-radius:11px;font-size:14px;font-weight:600;opacity:0;pointer-events:none;transition:.25s;z-index:95;box-shadow:0 0 24px #ffc23c33}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#tip{position:fixed;left:0;top:0;z-index:120;max-width:230px;background:linear-gradient(180deg,#1c2036,#131520);border:1px solid var(--violet);border-radius:10px;padding:8px 11px;font-size:12px;line-height:1.45;color:var(--bone);box-shadow:0 8px 24px #000a,0 0 16px #3E6FE066;opacity:0;transform:translateY(4px);transition:opacity .12s,transform .12s;pointer-events:none}
#tip.show{opacity:1;transform:translateY(0)}
#tip b{color:var(--gold)}#tip .tg{color:var(--gold);font-weight:700}#tip .tl{opacity:.6}
.tiptap{cursor:help}

/* projectiles / blink / support fx */
.proj{position:fixed;z-index:80;font-size:20px;pointer-events:none;transform:translate(-50%,-50%) rotate(var(--ang,0deg));will-change:left,top}
.proj.arrow{color:var(--gold);filter:drop-shadow(0 0 6px #ffc23c)}
.proj.fire{font-size:24px;filter:drop-shadow(0 0 9px #ff7a3c)}
.proj.ice{font-size:22px;filter:drop-shadow(0 0 9px #8fe3ff)}
.fighter.bflash{filter:brightness(2.4) drop-shadow(0 0 12px #c98bff)}
.fighter.fxheal{box-shadow:0 0 20px 3px #39ff88}
.fighter.fxshield{box-shadow:0 0 20px 3px #5BE0FF}
.fighter.fxweaken{box-shadow:0 0 20px 3px #c98bff}

/* round timer + controls */
.roundbar{display:flex;align-items:center;gap:8px;margin-top:14px}
.rtimer{font-family:'Cinzel';font-weight:700;font-size:15px;min-width:42px;color:var(--mp)}
.roundbar.low .rtimer{color:#ff5a6e}
.tbar{flex:1;height:9px;background:#00000066;border:1px solid var(--line);border-radius:6px;overflow:hidden}
#timerBar{height:100%;width:100%;background:linear-gradient(90deg,#7CFFB0,#39FF88);transition:width .2s}
.roundbar.low #timerBar{background:linear-gradient(90deg,#ff8a9a,#ff5a6e)}
.rbtn{background:#ffffff12;border:1px solid var(--line);color:var(--bone);border-radius:9px;padding:8px 10px;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap}
.rbtn:hover{background:#ffffff22}.rbtn.on{background:var(--gold);color:#000;border-color:var(--gold)}
/* AUTO speed toggle — a checkbox that re-buys the first belt speed-up each planning phase */
.rbtn.auto{display:inline-flex;align-items:center;gap:5px;font-family:var(--disp);font-size:11px;letter-spacing:1px;padding:8px 9px}
.rbtn.auto::before{content:'☐';font-size:14px;line-height:1}
.rbtn.auto.on{background:#7CFFB0;color:#06210f;border-color:#7CFFB0;box-shadow:0 0 12px #7cffb055}
.rbtn.auto.on::before{content:'☑'}

/* music + paused + role badge */
.musicCtl{display:flex;align-items:center;gap:5px;font-size:15px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:5px 9px}
.musicCtl input[type=range]{width:66px;accent-color:var(--violet)}
#pausedTag{position:fixed;top:30%;left:50%;transform:translate(-50%,-50%);background:#0a0b13f0;border:1px solid var(--gold);color:var(--gold);font-family:'Cinzel';font-weight:700;letter-spacing:2px;padding:14px 26px;border-radius:14px;z-index:80;display:none;box-shadow:0 0 34px #ffc23c44}
body.paused #pausedTag{display:block}
body.paused .belt-frame{filter:grayscale(.55) brightness(.55)}
.synlbl{font-family:'Cinzel';font-size:9px;letter-spacing:1.5px;opacity:.5;margin:6px 0 3px}
/* unit detail card */
.detailInner{width:min(440px,92vw);background:linear-gradient(180deg,#141728,#0b0d16);border:1px solid var(--uc,#3E6FE0);border-top:4px solid var(--uc,#3E6FE0);border-radius:18px;padding:20px;box-shadow:0 0 60px #3E6FE044;max-height:92vh;overflow-y:auto}
.dhead{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.dic{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:34px;background:color-mix(in srgb,var(--uc) 18%,#0a0b13);border:1px solid color-mix(in srgb,var(--uc) 45%,transparent);flex:0 0 auto}
.dname{font-family:var(--disp);font-size:19px;font-weight:700}
.dsub{font-size:12px;opacity:.85;margin-top:2px}.dsub .cost{color:var(--gold);font-weight:700}.dsub .stars{color:var(--gold)}
.drow{display:flex;gap:10px;align-items:flex-start;padding:8px 0;border-top:1px solid #ffffff12}
.dlabel{font-family:'Cinzel';font-size:9px;letter-spacing:1px;font-weight:700;padding:4px 6px;border-radius:6px;background:#ffffff10;flex:0 0 62px;text-align:center}
.dinfo b{font-size:13px}.dtext{font-size:12px;opacity:.72;line-height:1.4;margin-top:1px}
.dstats{display:flex;gap:8px;margin:12px 0}.dstats .chip{flex:1}
.ddesc{font-size:13px;color:var(--violet2);font-weight:600;margin:-4px 0 12px;line-height:1.4}
.dlore{font-size:12px;opacity:.6;font-style:italic;margin-bottom:14px}
.dclose{width:100%;background:linear-gradient(180deg,#c98bff,#3E6FE0);color:#fff;border:none;font-family:'Cinzel';font-weight:700;letter-spacing:1px;padding:12px;border-radius:11px;cursor:pointer}

/* ---------------- mobile ---------------- */
@media(max-width:860px){
  .cols{grid-template-columns:1fr}
  .stat.dim2{display:none}
}
@media(max-width:600px){
  .wrap{padding:10px 10px 26px}
  .topbar{gap:7px}
  .logoimg{height:90px;filter:drop-shadow(0 0 12px #ffcf5a44) drop-shadow(0 0 8px #3E6FE055)}
  .topright{width:132px}.topright #battleBtn{font-size:12px;padding:8px 6px}
  .sc{padding:4px 2px}.sc .sci{font-size:12px}.sc b{font-size:13px}.sc .scl{font-size:7.5px}
  .topbtns button{width:40px;height:40px;font-size:18px}
  .stats{gap:6px}.stat{padding:6px 10px;font-size:13px}.stat .lbl{display:none}.stat b{margin-left:1px}
  .belt-frame{height:96px;border-radius:12px}
  .card{width:80px;height:72px;top:13px;border-radius:11px;padding-top:4px}
  .card .ic{width:56px;height:36px;font-size:26px}
  .card .nm{font-size:11px}.card .meta2{font-size:11px;gap:6px}
  .panel{padding:10px;border-radius:13px}.panel h2{font-size:12px}
  .armylist{gap:6px;grid-template-columns:repeat(3,1fr)}
  .unit{padding:4px;gap:3px}
  .ubtns .mv{overflow:hidden;white-space:nowrap}
  .ubtns button{padding:6px 3px;font-size:11px}
  .syn{padding:8px 10px}
  .huntBtn{width:46px;height:46px;padding:3px}
  .arenaInner{padding:11px;border-radius:15px}
  .arenaHead{margin-bottom:9px}.arenaHead .ah{font-size:16px;letter-spacing:2px}
  .teams{gap:6px}.teamLbl{margin-bottom:6px}
  .fighter{border-radius:9px}
  .fighter .fic{width:100%;height:100%}
  .fighter .fname{font-size:9px}.fighter .hpbar{height:6px}.fhead{width:90%}
  .vs span{font-size:16px}
  .battleinfo{margin-top:10px;gap:8px}#combatLog,.meterBody{height:136px}#combatLog{font-size:11px}
  .mtab{font-size:9.5px}.mrow{font-size:10px;grid-template-columns:52px 1fr 38px;gap:7px}
  #resultTitle{font-size:18px}#continueBtn{padding:10px 16px}
  .modalInner{padding:18px}.modalInner ol{font-size:13px;line-height:1.6;margin-left:16px}
  .classlegend{font-size:11.5px}
  .fgrid{gap:5px}
  .arenaInner:not(.ended) .teams{min-height:56vh}
  .roundbar{flex-wrap:wrap}.musicCtl input[type=range]{width:54px}
}
@media(max-width:380px){
  .armylist{grid-template-columns:repeat(3,1fr)}
  .classlegend{grid-template-columns:1fr}
}

/* music mini-player */
#player{position:fixed;left:14px;bottom:14px;z-index:60;display:flex;align-items:center;gap:8px;background:#10121dee;border:1px solid #3E6FE066;border-radius:14px;padding:7px 11px;box-shadow:0 8px 24px #0008,0 0 18px #3E6FE033;backdrop-filter:blur(8px);max-width:min(360px,92vw)}
#player .eq{display:flex;align-items:flex-end;gap:2px;height:16px;width:18px;flex:0 0 auto}
#player .eq i{flex:1;background:linear-gradient(#8FB6FF,#3E6FE0);border-radius:1px;height:30%;animation:eq .9s ease-in-out infinite}
#player .eq i:nth-child(2){animation-delay:.2s}#player .eq i:nth-child(3){animation-delay:.4s}#player .eq i:nth-child(4){animation-delay:.6s}
@keyframes eq{0%,100%{height:25%}50%{height:100%}}
#player.mpaused .eq i{animation-play-state:paused;height:30%}
.nptitle{font-family:'Cinzel';font-size:11px;font-weight:700;letter-spacing:.4px;color:var(--violet2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:128px}
.mpbtn{background:#ffffff14;border:1px solid var(--line);color:var(--bone);border-radius:8px;width:30px;height:30px;font-size:13px;cursor:pointer;flex:0 0 auto}
.mpbtn:hover{background:#ffffff24}
#player input[type=range]{width:68px;accent-color:var(--violet)}

/* Xbox-style achievement banner */
#achv{position:fixed;top:-130px;left:50%;transform:translateX(-50%);z-index:90;display:flex;align-items:center;gap:14px;background:linear-gradient(180deg,#1b1b1bf2,#0d0d0df2);border:1px solid #2c2c2c;border-radius:14px;padding:11px 22px 11px 11px;box-shadow:0 12px 44px #000b,0 0 34px #107c1055;min-width:300px;opacity:0;transition:top .5s cubic-bezier(.2,1.15,.4,1),opacity .4s}
#achv.show{top:18px;opacity:1}
.achv-ic{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;background:radial-gradient(circle at 50% 40%,#1d1d1d,#080808);border:3px solid #107C10;box-shadow:0 0 16px #107C10aa,inset 0 0 10px #107c1055}
#achv.show .achv-ic{animation:achvspin .9s ease-out}
@keyframes achvspin{0%{transform:scale(.4) rotate(-90deg);opacity:0}60%{transform:scale(1.12) rotate(8deg)}100%{transform:scale(1) rotate(0)}}
.achv-body{flex:1}.achv-top{font-family:'Cinzel';font-size:10px;letter-spacing:2px;color:#6CCB5A;font-weight:700}
.achv-name{font-family:'Cinzel';font-size:15px;font-weight:700;color:#fff;margin-top:2px}
.achv-g{font-family:'Cinzel';font-weight:900;font-size:18px;color:#fff;opacity:.92;padding-left:10px;border-left:1px solid #333}

@media(max-width:600px){
  /* music player docks full-width at the very bottom */
  #player{left:0;right:0;bottom:0;border-radius:0;max-width:none;justify-content:center;border-left:none;border-right:none;gap:6px;padding:6px 9px}
  .nptitle{max-width:96px;font-size:10px}#player input[type=range]{width:60px}.mpbtn{width:30px;height:30px}
  #achv{min-width:0;width:94vw;padding:10px 14px 10px 10px;gap:10px}
  .achv-ic{width:44px;height:44px;font-size:21px}.achv-name{font-size:13px}.achv-g{font-size:15px}
  /* belt + round controls = the main view; board/bench = expandable bottom drawer.
     The roundbar is opaque and sits ABOVE the drawer (z-index) so the timer is never covered. */
  #mainbar{flex-wrap:wrap;gap:8px;background:#0a0b13;border-radius:12px;padding:6px;box-shadow:0 6px 16px #000a}
  #mainbar .roundbar{flex:1 1 100%}
  #mainbar #battleBtn{flex:1 1 100%;width:100%;padding:15px}
  .drawerToggle{display:flex;align-items:center;justify-content:center;gap:8px;position:sticky;top:0;z-index:3;width:100%;background:#13151f;border:none;border-bottom:1px solid var(--line);color:var(--violet2);font-family:var(--disp);font-weight:700;font-size:11px;letter-spacing:1px;padding:11px;cursor:pointer;border-radius:14px 14px 0 0}
  /* fixed bottom drawer; max-height pinned so its TOP sits just below the controls on any screen height (no gap, no overlap) */
  .cols{position:fixed;left:0;right:0;bottom:46px;z-index:45;grid-template-columns:1fr;gap:8px;background:#0a0b13f7;border-top:1px solid #3E6FE066;border-radius:16px 16px 0 0;padding:0 10px 12px;max-height:calc(100dvh - 350px);overflow-y:auto;transition:max-height .3s;box-shadow:0 -12px 34px #000b}
  body.drawer-open .cols{max-height:calc(100dvh - 96px)}
  .footer{display:none}
}

/* ============ readability bump (bigger text everywhere) ============ */
.tagline{font-size:12px}
.stat{font-size:14px}.stat .lbl{font-size:12px}.stat b{font-size:17px}
.panel h2{font-size:14px}.panel h2 span{font-size:11px}
.card .nm{font-size:13px}.card .meta2{font-size:13px}
.utitle .nm{font-size:14.5px}.utitle .sub{font-size:12.5px}.utitle .stars{font-size:13.5px}
.chip{font-size:10px}
.ubtns button{font-size:11.5px}.empty{font-size:13px}
.syn{font-size:13.5px}.syn .scount{font-size:14px}.synlbl{font-size:11px}
.hint{font-size:12.5px}.spdctrl{font-size:11.5px}.spd{font-size:12.5px}.teamLbl{font-size:12px}
.fighter .fname{font-size:11px}.fighter .fstatus{font-size:12px}
.logHead{font-size:11px}#combatLog{font-size:13.5px}
#resultSub{font-size:14px}.modalInner ol{font-size:15.5px}.cltitle{font-size:12px}.classlegend{font-size:14px}
#tip{font-size:13.5px}.nptitle{font-size:12.5px}
.dsub{font-size:13.5px}.dlabel{font-size:11px}.dinfo b{font-size:14.5px}.dtext{font-size:13.5px}.dlore{font-size:13.5px}
@media(max-width:600px){
  .stat{font-size:14.5px}.panel h2{font-size:14px}
  .card .nm{font-size:13px}.card .meta2{font-size:13px}
  .chip{font-size:10px}
  .ubtns button{font-size:11.5px}.syn{font-size:13.5px}
  .fighter .fic{width:100%;height:100%}
  .fighter .fname{font-size:9px}
  #combatLog{font-size:12px}.classlegend{font-size:13.5px}.modalInner ol{font-size:14.5px}
  .nptitle{font-size:12px}.drawerToggle{font-size:12.5px}.dtext{font-size:13px}.dinfo b{font-size:14px}
}
