/* oak.css — Captain Vector's Try Line (Oak, age 8-9, rugby/comic register).
   Bespoke vertical slice cloned from annabel.css's polish layer, re-skinned to
   Oak's rugby-comic world. The four techniques the prior Clark CSS lacked
   (R1-studio): layered shadow + inset highlight + GLOW, spring easing, multi-
   property correct moment, ambient drift. Mobile-first: base = 390px phone. */

:root{
  --electric:#3CE2A5;      /* try / correct / active glow */
  --electric-d:#1FB985;
  --crimson:#E63946;       /* chalk try-line, danger, overdrive */
  --gold:#FFC93C;          /* tries / xp */
  --midnight:#1A2B4A;      /* card field */
  --midnight-2:#22386A;
  --ink:#0B0F1A;           /* hard comic offset + bg base */
  --paper:#EAF2FF;
  --muted:#8FA4C7;
  --line:rgba(96,140,200,.28);
  --line-bright:rgba(60,226,165,.55);
  --warm:#FFC93C;          /* "tiny slip" — never red */
  --radius:20px;
  --radius-sm:13px;
  --tap:54px;
  --spring:cubic-bezier(.2,1.4,.4,1);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
[hidden]{display:none!important;}   /* class rules (.actions/.recipe/.aitag) must never beat the hidden attribute */
html,body{margin:0;padding:0;height:100%;}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--paper);
  background:
    radial-gradient(820px 560px at 12% -6%, rgba(60,226,165,.20) 0%, transparent 55%),
    radial-gradient(760px 560px at 96% 4%, rgba(230,57,70,.18) 0%, transparent 52%),
    radial-gradient(700px 700px at 70% 112%, rgba(255,201,60,.12) 0%, transparent 55%),
    linear-gradient(180deg,var(--ink),#0E1424 55%,var(--ink));
  background-attachment:fixed;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
.app{max-width:680px;margin:0 auto;padding:12px 13px 44px;position:relative;z-index:2;}

/* a11y */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--electric-d);color:#04130E;
  padding:12px 18px;border-radius:0 0 12px 0;font-family:'Bungee';font-size:13px;}
.skip-link:focus{left:0;}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
:focus-visible{outline:3px solid var(--electric);outline-offset:2px;}

/* ===== ambient: drifting chalk motion-lines + halftone field (ANIMATED — R1-studio d) ===== */
.bg-pitch{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:repeating-linear-gradient(115deg, rgba(96,140,200,.05) 0 2px, transparent 2px 46px);
  animation:drift 12s linear infinite;}
@keyframes drift{from{background-position:0 0;}to{background-position:460px 0;}}
.bg-halftone{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.10;
  background-image:radial-gradient(rgba(60,226,165,.6) 1px, transparent 1.4px);
  background-size:16px 16px;
  mask-image:radial-gradient(ellipse 85% 70% at 50% 16%,#000 28%,transparent 92%);
  -webkit-mask-image:radial-gradient(ellipse 85% 70% at 50% 16%,#000 28%,transparent 92%);}
.spark{position:fixed;border-radius:50%;z-index:0;pointer-events:none;filter:blur(.5px);
  animation:float 9s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateY(0);opacity:.5;}50%{transform:translateY(-20px);opacity:1;}}

/* comic panel base — hard ink offset + MINT HALO + inset highlight (R1-studio: "premium not flat") */
.panel{background:linear-gradient(165deg,var(--midnight),#16264a);
  border:2.5px solid var(--ink);border-radius:var(--radius);
  box-shadow:5px 5px 0 var(--ink), 0 0 18px rgba(60,226,165,.30), inset 0 2px 0 rgba(255,255,255,.12);}

/* ===================== HUD ===================== */
.topbar{display:flex;align-items:center;gap:9px;margin-bottom:10px;}
.backlink{display:inline-flex;align-items:center;gap:6px;color:var(--muted);text-decoration:none;
  font-family:'Bungee';font-size:11px;letter-spacing:.4px;padding:9px 13px;border-radius:11px;
  border:2px solid var(--ink);background:var(--midnight);min-height:44px;box-shadow:3px 3px 0 var(--ink);}
.backlink .material-icons-round{font-size:18px;}
.jokebtn{margin-left:auto;display:inline-flex;align-items:center;gap:6px;min-height:44px;padding:9px 14px;border-radius:11px;
  background:var(--midnight);border:2px solid var(--ink);color:var(--paper);font-family:'Bungee';font-size:11px;letter-spacing:.4px;
  cursor:pointer;box-shadow:3px 3px 0 var(--ink);transition:transform .1s;}
.jokebtn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);}

.hud{display:flex;align-items:center;gap:11px;padding:12px 13px;flex-wrap:wrap;}
.crest{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:27px;flex:none;
  background:linear-gradient(145deg,var(--electric-d),var(--electric));color:#04130E;
  box-shadow:0 0 18px rgba(60,226,165,.6), inset 0 2px 0 rgba(255,255,255,.4);border:2px solid var(--ink);}
.rank-meta{line-height:1.18;}
.rank-meta .who{font-family:'Bungee';font-size:15px;letter-spacing:.3px;}
.rank-meta .rk{font-size:12px;color:var(--electric);font-weight:700;letter-spacing:.3px;}
.xpwrap{flex:1 1 180px;min-width:150px;}
.xprow{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px;}
.xprow .lv{font-family:'Bungee';font-size:12px;color:var(--paper);}
.xprow .nx{font-size:11.5px;color:var(--muted);font-weight:600;}
.xptrack{height:14px;border-radius:9px;background:rgba(0,0,0,.4);overflow:hidden;border:2px solid var(--ink);}
.xpfill{height:100%;width:0%;border-radius:7px;
  background:linear-gradient(90deg,var(--gold),#F59E0B);box-shadow:0 0 12px rgba(255,201,60,.8);
  transition:width .8s var(--spring);}
.stat{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:13px;border:2px solid var(--ink);
  background:var(--midnight);font-family:'Bungee';font-size:15px;white-space:nowrap;box-shadow:3px 3px 0 var(--ink);}
.stat .ico{font-size:18px;}
.stat.tries{color:var(--gold);}
.stat.streak .fl{font-size:18px;animation:flame 1.4s ease-in-out infinite;}
@keyframes flame{0%,100%{transform:scale(1) rotate(-3deg);}50%{transform:scale(1.18) rotate(3deg);}}
.streakNum.wilt{animation:wilt 1s ease;}
@keyframes wilt{0%{transform:translateY(0);}40%{transform:translateY(4px) rotate(-6deg);opacity:.5;}100%{transform:translateY(0);}}
.iconbtn{width:var(--tap);height:var(--tap);min-width:var(--tap);border:2px solid var(--ink);border-radius:13px;cursor:pointer;
  background:var(--midnight);display:grid;place-items:center;box-shadow:3px 3px 0 var(--ink);transition:transform .1s;}
.iconbtn .material-icons-round{font-size:25px;color:var(--paper);}
.iconbtn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);}
.iconbtn.muted{background:rgba(255,201,60,.16);border-color:var(--ink);}
.iconbtn.muted .material-icons-round{color:var(--gold);}

/* ===================== BOSS / DRIVE BANNER ===================== */
.banner{margin-top:12px;display:flex;align-items:center;gap:13px;padding:14px 16px;}
.banner .face{width:56px;height:56px;border-radius:15px;display:grid;place-items:center;font-size:31px;flex:none;
  background:linear-gradient(145deg,#2A1840,#5B1E3A);border:2px solid var(--ink);
  box-shadow:0 0 18px rgba(230,57,70,.45), inset 0 2px 0 rgba(255,255,255,.1);}
.banner .bi{flex:1;min-width:0;}
.banner .bi h2{margin:0;font-family:'Bungee';font-size:17px;letter-spacing:.3px;}
.banner .bi p{margin:4px 0 0;font-size:12.5px;color:var(--muted);line-height:1.35;}
.bosshp{margin-top:8px;height:9px;border-radius:6px;background:rgba(0,0,0,.45);overflow:hidden;border:2px solid var(--ink);}
.bosshp .b{height:100%;width:0%;border-radius:4px;background:linear-gradient(90deg,var(--crimson),var(--gold));transition:width .6s var(--spring);}
.banner .diff{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex:none;}
.diff .pips{display:flex;gap:3px;}
.diff .pip{width:8px;height:17px;border-radius:3px;background:rgba(255,255,255,.12);border:1px solid var(--ink);}
.diff .pip.on{background:var(--electric);box-shadow:0 0 8px rgba(60,226,165,.7);}
.diff small{font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:700;}

/* ===================== QUESTION CARD ===================== */
.qcard{margin-top:12px;padding:20px;position:relative;overflow:hidden;}
.qhead{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.qtag{font-family:'Bungee';font-size:10.5px;letter-spacing:.5px;text-transform:uppercase;
  padding:6px 12px;border-radius:9px;background:var(--crimson);color:#fff;border:2px solid var(--ink);
  box-shadow:2px 2px 0 var(--ink);}
.qcount{margin-left:auto;font-size:12px;color:var(--muted);font-family:'Bungee';}
.qphase{font-size:10px;color:var(--electric);font-family:'Bungee';text-transform:uppercase;letter-spacing:.5px;margin-right:5px;}
.problem{font-size:21px;line-height:1.45;font-weight:700;color:var(--paper);}
.problem .hl{color:var(--electric);text-shadow:0 0 10px rgba(60,226,165,.5);}

.readbtn{display:inline-flex;align-items:center;gap:8px;margin-top:13px;background:var(--midnight);color:var(--paper);
  border:2px solid var(--ink);border-radius:12px;padding:10px 15px;font-family:'Bungee';font-size:12px;letter-spacing:.3px;
  cursor:pointer;min-height:46px;box-shadow:3px 3px 0 var(--ink);transition:transform .1s;}
.readbtn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);}
.readbtn .material-icons-round{font-size:20px;color:var(--electric);}
.readbtn.speaking{border-color:var(--electric);box-shadow:3px 3px 0 var(--ink),0 0 14px rgba(60,226,165,.6);}

/* ---------- shaded pitch (fraction-of-shape visual) ---------- */
.pitch{margin-top:18px;display:flex;gap:6px;padding:10px;border-radius:14px;border:2px solid var(--ink);
  background:repeating-linear-gradient(90deg,#123 0 1px,transparent 1px 100%),linear-gradient(180deg,#0d2438,#0a1a2a);
  box-shadow:inset 0 2px 10px rgba(0,0,0,.5);}
.pitch.vert{flex-direction:column;}
.lane{flex:1;min-height:74px;border-radius:8px;border:2px solid rgba(96,140,200,.35);background:rgba(255,255,255,.03);
  transition:background .3s,box-shadow .3s;position:relative;}
.lane.shaded{background:linear-gradient(160deg,var(--electric),var(--electric-d));border-color:var(--crimson);
  box-shadow:0 0 14px rgba(60,226,165,.55), inset 0 2px 0 rgba(255,255,255,.3);}
.lane.shaded::after{content:'';position:absolute;inset:0;border:2px dashed rgba(11,15,26,.5);border-radius:6px;}

/* ---------- choice tiles (shape answers) ---------- */
.tiles{margin-top:16px;display:flex;flex-direction:column;gap:10px;}
.tile{display:flex;align-items:center;gap:12px;padding:16px 18px;border-radius:14px;cursor:pointer;
  background:var(--midnight);border:2px solid var(--ink);font-family:'Bungee';font-size:20px;color:var(--paper);
  min-height:60px;text-align:left;width:100%;box-shadow:4px 4px 0 var(--ink);transition:transform .1s,box-shadow .1s;}
.tile .k{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex:none;font-size:13px;
  background:rgba(60,226,165,.18);color:var(--electric);border:1px solid var(--line);}
.tile:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink);}
.tile.right{background:linear-gradient(160deg,var(--electric),var(--electric-d));color:#04130E;border-color:var(--crimson);
  box-shadow:4px 4px 0 var(--ink),0 0 22px rgba(60,226,165,.7);animation:trypop .5s var(--spring);}
.tile.miss{background:rgba(255,201,60,.14);border-color:var(--warm);}
@keyframes trypop{0%{transform:scale(1);}45%{transform:scale(1.09);}100%{transform:scale(1);}}

/* ---------- keypad (amount answers) ---------- */
.compute{margin-top:18px;}
.ansbox{min-height:64px;border-radius:14px;border:2.5px solid var(--electric);background:rgba(60,226,165,.08);
  display:flex;align-items:center;justify-content:center;font-family:'Bungee';font-size:32px;color:var(--paper);
  box-shadow:inset 0 2px 10px rgba(0,0,0,.4),0 0 14px rgba(60,226,165,.3);padding:0 10px;}
.ansbox.empty{color:rgba(143,164,199,.5);}
.pad{margin-top:12px;display:grid;grid-template-columns:repeat(3,1fr);gap:9px;}
.key{min-height:var(--tap);border:2px solid var(--ink);border-radius:12px;background:var(--midnight);cursor:pointer;
  font-family:'Bungee';font-size:22px;color:var(--paper);box-shadow:3px 3px 0 var(--ink);transition:transform .08s,box-shadow .08s;padding:10px 0;}
.key:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);}
.key.fn{font-size:15px;color:var(--gold);}
.key.del{color:var(--crimson);}
.submit{margin-top:14px;width:100%;min-height:62px;border:2px solid var(--ink);border-radius:15px;cursor:pointer;
  background:linear-gradient(135deg,var(--electric),var(--electric-d));color:#04130E;font-family:'Bungee';font-size:18px;letter-spacing:.4px;
  box-shadow:5px 5px 0 var(--ink),0 0 22px rgba(60,226,165,.5);transition:transform .1s,box-shadow .1s;
  display:flex;align-items:center;justify-content:center;gap:9px;}
.submit:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink);}
.submit .material-icons-round{font-size:24px;}

/* ===================== HELP CONTROLS ===================== */
.helprow{margin-top:13px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;}
.hbtn{min-height:62px;border-radius:14px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;font-family:'Bungee';font-size:10.5px;letter-spacing:.2px;border:2px solid var(--ink);box-shadow:3px 3px 0 var(--ink);
  background:var(--midnight);color:var(--paper);padding:8px 5px;line-height:1.15;text-align:center;transition:transform .1s,box-shadow .1s;}
.hbtn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);}
.hbtn .em{font-size:21px;}
.hbtn.reexplain{border-color:var(--ink);color:var(--electric);}
.hbtn.power{color:var(--gold);}
.hbtn.refresh{color:var(--crimson);}
.hbtn:disabled{opacity:.45;cursor:default;}

/* squad reaction toast */
.reaction{margin-top:13px;display:none;align-items:center;gap:12px;padding:13px 15px;border-radius:14px;
  background:var(--midnight);border:2px solid var(--ink);box-shadow:4px 4px 0 var(--ink);}
.reaction.show{display:flex;animation:slidein .3s var(--spring);}
@keyframes slidein{from{opacity:0;transform:translateX(-12px);}to{opacity:1;transform:translateX(0);}}
.reaction .emo{font-size:28px;}
.reaction .emo.wiggle{animation:wiggle .6s ease;}
@keyframes wiggle{0%,100%{transform:rotate(0);}25%{transform:rotate(-18deg) scale(1.15);}75%{transform:rotate(18deg) scale(1.15);}}
.reaction .line{font-size:14px;color:var(--paper);font-weight:600;font-style:italic;}

/* ===================== OVERLAYS ===================== */
.overlay{position:fixed;inset:0;z-index:50;background:rgba(6,9,16,.78);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:20px;overflow-y:auto;}
.overlay.show{display:flex;animation:fade .2s ease;}
@keyframes fade{from{opacity:0;}to{opacity:1;}}
.sheet{background:linear-gradient(165deg,var(--midnight-2),#10203e);border:2.5px solid var(--ink);
  border-radius:24px;max-width:440px;width:100%;padding:26px 24px;margin:auto;
  box-shadow:8px 8px 0 var(--ink), 0 0 34px rgba(60,226,165,.25), inset 0 2px 0 rgba(255,255,255,.1);
  animation:rise .34s var(--spring);}
@keyframes rise{from{transform:translateY(28px) scale(.96);opacity:0;}to{transform:translateY(0) scale(1);opacity:1;}}
.sheet .icon{font-size:58px;text-align:center;line-height:1;margin-bottom:6px;}
.sheet h3{font-family:'Bungee';font-size:23px;margin:4px 0 8px;text-align:center;line-height:1.15;}
.sheet p{font-size:15px;color:var(--paper);line-height:1.5;margin:6px 0;text-align:center;opacity:.92;}
.sheet .recipe{background:rgba(0,0,0,.32);border:2px solid var(--ink);border-radius:14px;padding:15px;margin-top:14px;}
.sheet .recipe .s{display:flex;gap:11px;align-items:flex-start;margin:9px 0;font-size:14.5px;line-height:1.4;text-align:left;}
.sheet .recipe .s .n{width:26px;height:26px;flex:none;border-radius:7px;background:linear-gradient(145deg,var(--electric-d),var(--electric));
  display:grid;place-items:center;font-family:'Bungee';font-size:12px;color:#04130E;}
.sheet .recipe .s b{color:var(--electric);}
.aitag{display:inline-flex;align-items:center;gap:6px;margin:2px auto 0;padding:5px 11px;border-radius:20px;
  background:rgba(60,226,165,.14);border:1px solid var(--line-bright);color:var(--electric);
  font-family:'Bungee';font-size:10px;letter-spacing:.4px;}
.aitag.fallback{background:rgba(143,164,199,.12);border-color:var(--line);color:var(--muted);}
.xpgain{font-family:'Bungee';font-size:22px;color:var(--gold);text-align:center;margin-top:14px;text-shadow:0 0 14px rgba(255,201,60,.7);}
.sheet .actions{display:flex;flex-direction:column;gap:10px;margin-top:20px;}
.bigbtn{min-height:58px;border:2px solid var(--ink);border-radius:14px;cursor:pointer;font-family:'Bungee';font-size:16px;letter-spacing:.3px;
  box-shadow:4px 4px 0 var(--ink);transition:transform .1s,box-shadow .1s;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--paper);background:var(--midnight);}
.bigbtn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink);}
.bigbtn.go{background:linear-gradient(135deg,var(--electric),var(--electric-d));color:#04130E;box-shadow:4px 4px 0 var(--ink),0 0 18px rgba(60,226,165,.45);}
.bigbtn.alt{background:rgba(255,201,60,.14);color:var(--gold);}
.bigbtn.ghost{background:var(--midnight);color:var(--paper);}

/* TRY! correct celebration — multi-property (R1-studio c) */
.sheet.trywin{position:relative;overflow:hidden;}
.sheet.trywin .icon{animation:trySlam .55s var(--spring);}
@keyframes trySlam{0%{transform:scale(0) rotate(-25deg);}65%{transform:scale(1.25) rotate(8deg);}100%{transform:scale(1) rotate(0);}}
.sheet.trywin h3{color:var(--electric);text-shadow:0 0 16px rgba(60,226,165,.6);}
.chalkline{height:5px;margin:14px auto 4px;width:72%;border-radius:3px;background:var(--crimson);
  box-shadow:0 0 12px rgba(230,57,70,.7);transform-origin:left;animation:chalk .5s var(--spring);}
@keyframes chalk{from{transform:scaleX(0);}to{transform:scaleX(1);}}
.powerchip{display:inline-flex;align-items:center;gap:8px;margin:14px auto 0;padding:10px 15px;border-radius:12px;
  background:rgba(255,201,60,.14);border:2px solid var(--ink);color:var(--gold);font-family:'Bungee';font-size:12.5px;}

/* ===================== VECTOR'S OVERDRIVE (the 5x gate) ===================== */
.chip-overdrive{display:inline-flex;align-items:center;gap:8px;margin-top:12px;width:100%;justify-content:center;
  min-height:56px;border-radius:15px;cursor:pointer;border:2px solid var(--ink);
  background:linear-gradient(135deg,#3a0a18,#7a0f26);color:#fff;font-family:'Bungee';font-size:14px;letter-spacing:.5px;
  box-shadow:5px 5px 0 var(--ink),0 0 16px rgba(230,57,70,.5);animation:odpulse 1.8s ease-in-out infinite;transition:transform .1s,box-shadow .1s;}
.chip-overdrive:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink);}
@keyframes odpulse{0%,100%{box-shadow:5px 5px 0 var(--ink),0 0 16px rgba(230,57,70,.45);}50%{box-shadow:5px 5px 0 var(--ink),0 0 26px rgba(230,57,70,.85);}}
.sheet.overdrive{background:linear-gradient(165deg,#3a0a18,#160509);border-color:var(--ink);
  box-shadow:8px 8px 0 var(--ink),0 0 34px rgba(230,57,70,.4);text-align:center;}
.sheet.overdrive .icon{filter:drop-shadow(0 0 14px rgba(230,57,70,.8));animation:odshake 2.2s ease-in-out infinite;}
.odmeter{font-family:'Bungee';font-size:12px;color:var(--crimson);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;}
.odmeter b{color:#fff;margin-left:5px;}
.sheet.overdrive h3{color:#fff;text-shadow:0 0 14px rgba(230,57,70,.7);}
.bigbtn.danger{background:linear-gradient(135deg,var(--crimson),#FF6B3D);color:#fff;box-shadow:4px 4px 0 var(--ink),0 0 18px rgba(230,57,70,.55);}
.sheet.overdrive.lvl2{box-shadow:8px 8px 0 var(--ink),0 0 44px rgba(230,57,70,.55);}
.sheet.overdrive.lvl3{box-shadow:8px 8px 0 var(--ink),0 0 54px rgba(230,57,70,.7);animation:odjitter 3s ease-in-out infinite;}
.sheet.overdrive.lvl4{box-shadow:8px 8px 0 var(--ink),0 0 64px rgba(230,57,70,.82);animation:odjitter 1.6s ease-in-out infinite;}
.sheet.overdrive.lvl5{border-color:var(--crimson);box-shadow:8px 8px 0 var(--ink),0 0 80px rgba(230,57,70,.95);animation:odjitter .9s ease-in-out infinite;}
@keyframes odshake{0%,100%{transform:rotate(-4deg);}50%{transform:rotate(4deg) scale(1.06);}}
@keyframes odjitter{0%,100%{transform:translate(0,0);}25%{transform:translate(-1.5px,1px);}50%{transform:translate(1.5px,-1px);}75%{transform:translate(-1px,-1.5px);}}

/* overdrive bail-out (never trapped) */
.odbail{margin-top:12px;display:flex;flex-direction:column;gap:8px;padding:13px 15px;border-radius:16px;
  background:linear-gradient(135deg,rgba(60,226,165,.16),rgba(255,201,60,.10));
  border:2px solid var(--ink);box-shadow:4px 4px 0 var(--ink);animation:slidein .3s var(--spring);}
.odbail[hidden]{display:none;}
.odbailbtn{align-self:flex-start;display:inline-flex;align-items:center;gap:9px;min-height:48px;padding:11px 20px;
  border-radius:13px;cursor:pointer;border:2px solid var(--ink);background:linear-gradient(135deg,var(--electric),var(--electric-d));
  color:#04130E;font-family:'Bungee';font-size:14px;box-shadow:3px 3px 0 var(--ink);transition:transform .1s;}
.odbailbtn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink);}
.odbailnote{font-size:13px;color:var(--paper);opacity:.92;font-style:italic;line-height:1.4;}

.sheet.odwin{background:linear-gradient(160deg,#46122a,#180814);border-color:var(--crimson);
  box-shadow:8px 8px 0 var(--ink),0 0 36px rgba(230,57,70,.5);text-align:center;}
.sheet.odwin h3{color:#fff;text-shadow:0 0 14px rgba(230,57,70,.7);}

/* ===================== COMIC-CUTSCENE KIT UNLOCK (full-screen halftone slam) ===================== */
.cutscene{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(circle at 50% 40%, #16335c, #060910 70%);}
.cutscene.show{display:flex;animation:cutFade .25s ease;}
@keyframes cutFade{from{opacity:0;}to{opacity:1;}}
.cutscene.shake{animation:cutShake .5s ease;}
@keyframes cutShake{0%,100%{transform:translate(0,0);}10%{transform:translate(-9px,5px);}30%{transform:translate(8px,-6px);}50%{transform:translate(-7px,-4px);}70%{transform:translate(6px,5px);}90%{transform:translate(-3px,2px);}}
.cutcell{position:relative;max-width:460px;width:100%;text-align:center;
  background:linear-gradient(160deg,#102544,#0a1830);border:4px solid var(--ink);border-radius:18px;padding:30px 26px 28px;
  box-shadow:10px 10px 0 var(--ink),0 0 46px rgba(60,226,165,.4);
  background-image:radial-gradient(rgba(255,255,255,.07) 1.2px,transparent 1.4px);background-size:13px 13px;}
.cutcell .burst{font-family:'Bungee';font-size:13px;letter-spacing:1px;color:var(--crimson);text-shadow:0 0 10px rgba(230,57,70,.6);
  transform:rotate(-4deg);animation:trySlam .5s var(--spring);}
.cutcell .kititem{font-size:84px;line-height:1;margin:10px 0;filter:drop-shadow(0 0 20px rgba(60,226,165,.7));animation:kitSlam .6s var(--spring);}
@keyframes kitSlam{0%{transform:scale(0) rotate(-30deg);}60%{transform:scale(1.35) rotate(10deg);}100%{transform:scale(1) rotate(0);}}
.cutcell h2{font-family:'Bungee';font-size:24px;margin:8px 0 6px;color:var(--electric);text-shadow:0 0 16px rgba(60,226,165,.6);line-height:1.15;}
.cutcell .boots{font-size:14.5px;color:var(--gold);font-style:italic;font-weight:700;margin:10px 0 0;}
.cutcell .pow{position:absolute;top:-22px;right:-10px;font-family:'Bungee';font-size:30px;color:var(--gold);
  text-shadow:0 0 14px rgba(255,201,60,.8);transform:rotate(12deg);animation:powIn .5s var(--spring);}
@keyframes powIn{0%{transform:scale(0) rotate(12deg);}70%{transform:scale(1.3) rotate(12deg);}100%{transform:scale(1) rotate(12deg);}}
.cutcell .dismiss{margin-top:20px;min-height:54px;width:100%;border:2px solid var(--ink);border-radius:14px;cursor:pointer;
  background:linear-gradient(135deg,var(--electric),var(--electric-d));color:#04130E;font-family:'Bungee';font-size:16px;
  box-shadow:4px 4px 0 var(--ink);transition:transform .1s;}
.cutcell .dismiss:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink);}

/* ===================== CONFETTI / FX ===================== */
#fx{position:fixed;inset:0;pointer-events:none;z-index:60;}

/* boot */
.boot{position:fixed;inset:0;z-index:90;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  background:var(--ink);color:var(--paper);transition:opacity .4s;}
.boot.hide{opacity:0;pointer-events:none;}
.boot .spin{width:46px;height:46px;border-radius:50%;border:5px solid rgba(60,226,165,.25);border-top-color:var(--electric);animation:rot 1s linear infinite;}
@keyframes rot{to{transform:rotate(360deg);}}
.boot .msg{font-family:'Bungee';font-size:14px;color:var(--muted);}
.boot .err{color:var(--warm);max-width:420px;text-align:center;line-height:1.5;font-size:14px;}

/* ===================== HUB / MODE PICKER (Wave 1) ===================== */
.hub-screen{margin-top:14px;animation:rise .34s var(--spring);}
.hub-head{text-align:center;margin:6px 0 16px;}
.hub-title{font-family:'Bungee';font-size:26px;margin:0;color:var(--electric);text-shadow:0 0 16px rgba(60,226,165,.5);letter-spacing:.4px;}
.hub-sub{font-size:13.5px;color:var(--muted);margin:7px 0 0;line-height:1.4;}
.hub-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.modecard{display:flex;flex-direction:column;align-items:flex-start;gap:5px;text-align:left;cursor:pointer;
  padding:16px 15px 15px;border-radius:var(--radius-sm);border:2.5px solid var(--ink);color:var(--paper);
  background:linear-gradient(165deg,var(--midnight),#16264a);min-height:150px;
  box-shadow:5px 5px 0 var(--ink), 0 0 16px rgba(60,226,165,.22), inset 0 2px 0 rgba(255,255,255,.1);
  transition:transform .12s var(--spring),box-shadow .12s;}
.modecard:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink),0 0 12px rgba(60,226,165,.3);}
.modecard:hover{box-shadow:5px 5px 0 var(--ink),0 0 26px rgba(60,226,165,.5),inset 0 2px 0 rgba(255,255,255,.12);}
.modecard-face{font-size:34px;line-height:1;filter:drop-shadow(0 0 10px rgba(60,226,165,.45));}
.modecard-pos{font-family:'Bungee';font-size:9.5px;letter-spacing:.6px;text-transform:uppercase;color:var(--gold);
  padding:3px 8px;border-radius:7px;background:rgba(255,201,60,.14);border:1px solid var(--line);}
.modecard-name{font-family:'Bungee';font-size:13.5px;line-height:1.2;color:var(--paper);}
.modecard-trophy{margin-left:5px;}
.modecard-desc{font-size:11.5px;color:var(--muted);line-height:1.35;}
.modecard.boss{background:linear-gradient(165deg,#3a0a18,#160509);border-color:var(--crimson);
  box-shadow:5px 5px 0 var(--ink),0 0 18px rgba(230,57,70,.4),inset 0 2px 0 rgba(255,255,255,.08);}
.modecard.boss .modecard-pos{color:#fff;background:rgba(230,57,70,.22);}
.modecard.boss .modecard-face{filter:drop-shadow(0 0 12px rgba(230,57,70,.6));}
.modecard.locked{opacity:.62;cursor:not-allowed;filter:grayscale(.35);}
.modecard.locked:active{transform:none;}
.modecard-lock{font-size:10px;color:var(--warm);font-weight:700;line-height:1.3;margin-top:2px;}

/* ===================== PHASE PLAY (sequencing board) ===================== */
.phase-board{margin-top:16px;display:flex;flex-direction:column;gap:8px;padding:13px;border-radius:14px;
  border:2px solid var(--ink);background:linear-gradient(180deg,#0d2438,#0a1a2a);box-shadow:inset 0 2px 10px rgba(0,0,0,.5);}
.phase-step{display:flex;align-items:center;gap:11px;font-size:14.5px;color:var(--paper);font-weight:600;line-height:1.35;}
.phase-step .pn{width:28px;height:28px;flex:none;border-radius:8px;display:grid;place-items:center;font-family:'Bungee';font-size:13px;
  background:linear-gradient(145deg,var(--midnight-2),#10203e);color:var(--electric);border:2px solid var(--ink);box-shadow:2px 2px 0 var(--ink);}
.phase-cta{margin:15px 0 4px;font-family:'Bungee';font-size:12px;color:var(--electric);text-transform:uppercase;letter-spacing:.5px;}
.tile.order{font-size:18px;letter-spacing:1px;}

/* ===================== RESPONSIVE / reduced-motion ===================== */
@media (max-width:360px){ .helprow{grid-template-columns:1fr;} .pad{gap:7px;} .problem{font-size:19px;} .hub-cards{grid-template-columns:1fr;} }
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.05ms!important;}
}
