:root{
  --bg:#070b14; --bg2:#0c1322; --ink:#eef2f7; --muted:#9fb0c3;
  --amber:#ffb347; --amber2:#ff8c1a; --moon:#f2efd9;
  --green:#3f6d3a; --good:#5fd16a; --bad:#ff5c5c; --circle:#7fa8ff;
  --panel:rgba(10,16,28,.82); --line:rgba(255,255,255,.10);
  --redtick:#c0392b; --bluetick:#3a6ea5; --tri:#b9892f;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%;background:var(--bg);color:var(--ink);
  font-family:"Trebuchet MS",-apple-system,system-ui,Segoe UI,Roboto,sans-serif;
  overflow:hidden;user-select:none;-webkit-user-select:none}
#app{position:fixed;inset:0}
.screen{position:absolute;inset:0;display:none;align-items:center;justify-content:center}
.screen.active{display:flex}
.hidden{display:none !important}
button{font-family:inherit;cursor:pointer}

/* ---------- shared ---------- */
.big-btn{background:linear-gradient(180deg,var(--amber),var(--amber2));border:none;
  color:#241200;font-weight:800;font-size:1.15rem;letter-spacing:.04em;
  padding:16px 26px;border-radius:14px;box-shadow:0 6px 0 #a85c0d,0 10px 22px rgba(0,0,0,.5);
  transition:transform .05s,box-shadow .05s}
.big-btn:active{transform:translateY(4px);box-shadow:0 2px 0 #a85c0d,0 6px 12px rgba(0,0,0,.5)}
.ghost-btn{background:transparent;border:2px solid var(--line);color:var(--muted);
  padding:14px 20px;border-radius:14px;font-weight:700}
.fineprint{color:var(--muted);font-size:.8rem;margin-top:14px;text-align:center}
.hint{color:var(--muted);font-weight:400;font-size:.8rem}

/* ---------- title ---------- */
#screen-title{background:radial-gradient(120% 90% at 50% 8%,#16233f 0%,var(--bg) 60%)}
.title-wrap{text-align:center;padding:24px;max-width:520px;position:relative}
.moon{position:absolute;top:-6px;left:50%;transform:translateX(-50%);
  width:74px;height:74px;border-radius:50%;
  background:radial-gradient(circle at 38% 35%,#fff,var(--moon) 60%,#cfc8a3);
  box-shadow:0 0 60px 18px rgba(242,239,217,.25)}
.logo{margin:84px 0 0;font-size:3.2rem;line-height:.92;font-weight:900;letter-spacing:.02em;
  color:var(--ink);text-shadow:0 3px 0 #000,0 0 26px rgba(255,179,71,.35)}
.logo span{display:block;color:var(--amber);font-size:2.5rem;letter-spacing:.2em}
.tagline{color:var(--muted);margin:10px 0 26px;font-size:1rem;letter-spacing:.03em}
.handle-row{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:22px}
.handle-row label{color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.12em}
input{background:#0a1322;border:2px solid var(--line);color:var(--ink);
  padding:14px 16px;border-radius:12px;font-size:1.1rem;text-align:center;width:280px;max-width:80vw}
input:focus{outline:none;border-color:var(--amber)}

/* ---------- builder ---------- */
#screen-builder{background:radial-gradient(120% 90% at 50% 0%,#12203a,var(--bg) 65%);
  overflow-y:auto}
.builder-wrap{width:560px;max-width:92vw;padding:26px 20px 40px}
.builder-wrap h2{font-size:1.8rem;margin:6px 0 18px;text-align:center}
.field{margin-bottom:18px}
.field>label{display:block;margin-bottom:8px;font-weight:700;letter-spacing:.02em}
.choice-row{display:flex;gap:10px;flex-wrap:wrap}
.choice-col{display:flex;flex-direction:column;gap:10px}
.chip{flex:1;min-width:90px;border:2px solid var(--line);background:var(--bg2);
  border-radius:12px;padding:12px;text-align:center;color:var(--ink);font-weight:700}
.chip.sel{border-color:var(--amber);box-shadow:0 0 0 2px rgba(255,179,71,.25) inset}
.coat-sw{width:30px;height:30px;border-radius:50%;margin:0 auto 6px;border:2px solid rgba(0,0,0,.3)}
.opt{border:2px solid var(--line);background:var(--bg2);border-radius:12px;padding:12px 14px;text-align:left}
.opt.sel{border-color:var(--amber);box-shadow:0 0 0 2px rgba(255,179,71,.2) inset}
.opt .opt-title{font-weight:800;margin-bottom:3px}
.opt .opt-desc{color:var(--muted);font-size:.84rem;line-height:1.3}
.builder-actions{display:flex;gap:12px;margin-top:24px}
.builder-actions .big-btn{flex:1}

/* ---------- hunt ---------- */
#screen-hunt{background:#05070d}
#scene{position:absolute;inset:0;width:100%;height:100%;touch-action:none}
.hud{position:absolute;inset:0;pointer-events:none;display:flex;flex-direction:column;padding:14px}
.hud>*{pointer-events:auto}
.hud-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.info-chip{background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:7px 12px;font-weight:700;color:var(--muted);white-space:nowrap}
.info-chip #reg-badge{color:var(--amber);font-weight:800}
.view-switch{display:flex;margin:0 auto;border:1px solid var(--amber);border-radius:11px;overflow:hidden;
  max-width:100%;animation:viewpulse 2.2s ease-in-out 4}
@keyframes viewpulse{0%,100%{box-shadow:0 0 0 0 rgba(255,179,71,0)}50%{box-shadow:0 0 0 5px rgba(255,179,71,.22)}}
.vseg{background:transparent;border:none;border-right:1px solid rgba(255,179,71,.4);color:var(--muted);
  padding:8px 12px;font-weight:800;font-size:.84rem;min-width:0;white-space:nowrap}
.vseg:last-child{border-right:none}
.vseg.active{background:linear-gradient(180deg,var(--amber),var(--amber2));color:#241200}
.mute-btn{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:7px 10px;font-size:1rem;color:var(--ink)}
.view-toast{position:absolute;top:96px;left:50%;transform:translateX(-50%);z-index:6;max-width:90vw;text-align:center;
  background:var(--panel);border:1px solid var(--amber);color:var(--amber);font-weight:700;
  padding:8px 14px;border-radius:12px;pointer-events:none;font-size:.85rem}
.stage-kicker{font-size:.78rem;font-weight:800;letter-spacing:.22em;color:var(--amber);
  text-transform:uppercase;margin-bottom:6px;min-height:1em;text-shadow:0 1px 4px #000}
.scoreboard{position:absolute;top:60px;right:14px;width:min(190px,44vw);background:var(--panel);
  border:1px solid var(--line);border-radius:12px;padding:8px 10px;font-size:.82rem}
.sb-row{display:flex;justify-content:space-between;gap:8px;padding:3px 0;color:var(--muted)}
.sb-row .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
.sb-row.me{color:var(--ink);font-weight:800}
.sb-row.me .nm{color:var(--amber)}
.sb-row.scr{opacity:.45;text-decoration:line-through}
.sb-row .pts{font-variant-numeric:tabular-nums}
.hud-center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  text-align:center;margin-top:8vh;pointer-events:none}
.center-msg{font-size:clamp(1.4rem,5vw,2.4rem);font-weight:900;text-shadow:0 2px 8px #000;min-height:1.2em;max-width:92vw}
.center-msg.flash-good{color:var(--good)} .center-msg.flash-bad{color:var(--bad)}
.center-msg.flash-circle{color:var(--circle)}
.center-sub{margin-top:6px;font-size:clamp(.9rem,3.2vw,1.15rem);color:var(--ink);
  text-shadow:0 1px 6px #000;max-width:90vw;text-align:center}
.read-wrap{position:absolute;left:50%;transform:translateX(-50%);bottom:118px;width:300px;max-width:84vw;
  background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px 12px;text-align:center}
.read-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.read-bar{height:14px;background:#0a1322;border-radius:8px;margin:6px 0;overflow:hidden;border:1px solid var(--line)}
.read-fill{height:100%;width:50%;background:linear-gradient(90deg,#7a4,#cf3 60%,#5fd16a);transition:width .12s}
.read-text{font-size:.9rem;font-weight:700}
.actions{position:absolute;left:0;right:0;bottom:14px;display:flex;gap:12px;
  justify-content:center;padding:0 14px}
.act-btn{flex:1;max-width:230px;border:none;border-radius:14px;padding:18px 12px;font-weight:900;
  font-size:1.15rem;letter-spacing:.04em;color:#241200;
  background:linear-gradient(180deg,var(--amber),var(--amber2));box-shadow:0 6px 0 #a85c0d}
.act-btn:active{transform:translateY(4px);box-shadow:0 2px 0 #a85c0d}
.act-btn.layoff{background:linear-gradient(180deg,#8595a8,#5a6678);color:#0b1220;box-shadow:0 6px 0 #2f3a4d}
.act-btn.danger{background:linear-gradient(180deg,#ff7a7a,#e23b3b);color:#2a0606;box-shadow:0 6px 0 #8f1d1d}
.act-btn.hot{animation:hotpulse .55s ease-in-out infinite}
@keyframes hotpulse{0%,100%{box-shadow:0 6px 0 #a85c0d,0 0 0 0 rgba(255,225,77,0)}50%{box-shadow:0 6px 0 #a85c0d,0 0 20px 5px rgba(255,225,77,.65)}}
.cooldown-ring{position:absolute;top:8px;right:18px;font-weight:800;color:#241200;font-size:.8rem}

/* ---------- results ---------- */
#screen-results{background:radial-gradient(120% 90% at 50% 0%,#12203a,var(--bg) 65%)}
/* scroll from the TOP — a tall page vertically-centered in an overflow:auto box clips its top/bottom out of reach on short/landscape phones */
#screen-title,#screen-results,#screen-modes{align-items:flex-start;overflow-y:auto}
.title-wrap{margin:auto 0}   /* stays centered when there's room, but scrolls once the content (logo + rank strip + form) exceeds the viewport */
.results-wrap{width:520px;max-width:92vw;padding:24px 20px 44px;text-align:center}
.results-wrap h2{font-size:1.7rem;margin:0 0 4px}
.result-place{font-size:2.4rem;font-weight:900;margin:6px 0 14px}
.result-place.win{color:var(--good)} .result-place.lose{color:var(--muted)}
.result-career{margin:0 0 14px;font-size:.95rem;color:var(--ink);line-height:1.5}
.result-career .ttl{display:inline-block;background:rgba(255,140,26,.15);border:1px solid rgba(255,179,71,.4);color:var(--amber);font-weight:800;font-size:.72rem;border-radius:7px;padding:2px 8px;vertical-align:middle}
.result-career .cstat{color:var(--muted);font-size:.82rem;font-variant-numeric:tabular-nums}
.result-rank{margin:0 0 10px;font-size:1.05rem;color:var(--ink)}
.result-rank b{color:var(--amber);font-size:1.4rem;font-variant-numeric:tabular-nums}
.result-rank span{color:var(--muted);font-size:.85rem}
.lbrow{display:flex;align-items:center;gap:10px;padding:7px 4px;border-bottom:1px solid var(--line)}
.lbrow:last-child{border-bottom:none}
.lbrow.you{background:rgba(255,140,26,.13);border-radius:8px;margin:2px -6px;padding:8px 10px;border-bottom:none;box-shadow:0 0 0 1px rgba(255,179,71,.4) inset}
.lbr{flex:0 0 auto;width:42px;color:var(--muted);font-weight:800;font-variant-numeric:tabular-nums;font-size:.85rem}
.lbrow.you .lbr{color:var(--amber)}
.lbn{flex:1;text-align:left;font-weight:700;display:flex;flex-direction:column;line-height:1.2}
.lbn small{color:var(--muted);font-weight:600;font-size:.7rem}
.lbrow.you .lbn{color:var(--amber)}
.lbp{flex:0 0 auto;font-weight:900;font-variant-numeric:tabular-nums;color:var(--ink)}
.lbrow.you .lbp{color:var(--amber)}
/* progression strip on title + mode-select */
.rank-strip{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:9px 14px;margin:0 auto 6px;max-width:360px;line-height:1.45}
.rank-strip:empty{display:none}
.rank-strip.teaser{color:var(--muted);font-size:.85rem;text-align:center}
.rank-strip.teaser b{color:var(--amber)}
.rs-top{display:flex;align-items:center;gap:8px;justify-content:center;flex-wrap:wrap}
.rs-rank{font-weight:900;color:var(--amber);font-size:1.15rem;font-variant-numeric:tabular-nums}
.rs-of{color:var(--muted);font-size:.78rem}
.rs-title{background:rgba(255,140,26,.15);border:1px solid rgba(255,179,71,.4);color:var(--amber);font-weight:800;font-size:.66rem;letter-spacing:.04em;border-radius:6px;padding:2px 7px}
.rs-bot{color:var(--muted);font-size:.8rem;font-variant-numeric:tabular-nums;text-align:center;margin-top:2px}
.rs-bot b{color:#5fd16a}
.standings{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:8px 12px;margin-bottom:16px;text-align:left}
.st-row{display:flex;justify-content:space-between;padding:7px 4px;border-bottom:1px solid var(--line)}
.st-row:last-child{border-bottom:none}
.st-row.me{color:var(--amber);font-weight:800}
.st-row.scr{opacity:.5}
.result-stats{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}
.stat{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:12px 16px;min-width:120px}
.stat .v{font-size:1.5rem;font-weight:900;color:var(--amber)}
.stat .k{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.results-actions{display:flex;gap:12px;justify-content:center}
.results-actions .big-btn{flex:1;max-width:240px}

/* ---------- mode select ---------- */
#screen-modes{background:radial-gradient(120% 90% at 50% 0%,#12203a,var(--bg) 65%);overflow-y:auto}
.modes-wrap{width:560px;max-width:94vw;padding:30px 18px 40px;text-align:center;position:relative}
.modes-back{position:absolute;left:8px;top:22px;padding:8px 14px}
.modes-wrap h2{font-size:1.9rem;margin:6px 0 2px}
.modes-sub{color:var(--muted);margin:0 0 20px}
.mode-cards{display:flex;flex-direction:column;gap:14px}
.mode-card{display:block;text-align:left;background:var(--bg2);border:2px solid var(--line);border-radius:16px;
  padding:18px;color:var(--ink);position:relative;transition:transform .06s,border-color .1s;overflow:hidden}
.mode-card:active{transform:scale(.99)}
.mode-card:hover{border-color:var(--amber)}
.mc-emoji{font-size:2rem;float:left;margin-right:14px;line-height:1}
.mc-title{font-size:1.25rem;font-weight:900;color:var(--amber)}
.mc-desc{color:var(--muted);font-size:.9rem;margin-top:3px;line-height:1.35}
.mc-best{clear:both;font-size:.78rem;color:var(--good);margin-top:8px;font-weight:700;min-height:1em}
.mode-card.soon{opacity:.55}
.mode-card.soon::after{content:'SOON';position:absolute;top:12px;right:14px;font-size:.65rem;font-weight:800;
  letter-spacing:.1em;color:#241200;background:var(--amber);padding:2px 8px;border-radius:8px}

/* ---------- action play HUD ---------- */
#screen-play{background:#03050b}
#play-canvas{position:absolute;inset:0;width:100%;height:100%;touch-action:none;cursor:crosshair}
.phud{position:absolute;inset:0;pointer-events:none;display:flex;flex-direction:column;padding:12px}
.phud>*{pointer-events:auto}
.phud-top{display:flex;align-items:center;gap:10px}
.phud-btn{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:6px 13px;color:var(--ink);font-size:1.1rem;font-weight:800}
.phud-score{margin-left:auto;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:6px 14px;font-weight:900;font-size:1.3rem;color:var(--amber);font-variant-numeric:tabular-nums}
.phud-streak{font-weight:900;color:#ff8c1a;font-size:1.05rem;min-width:50px;text-shadow:0 0 8px rgba(255,140,26,.5)}
.play-timer{height:8px;background:#0a1322;border-radius:6px;margin:10px 2px 0;overflow:hidden;border:1px solid var(--line)}
#play-timer-fill{height:100%;width:100%;background:linear-gradient(90deg,#ff8c1a,#ffb347)}
.play-center{position:absolute;left:0;right:0;top:38%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 16px;text-align:center;pointer-events:none}
.play-msg{font-size:clamp(1.4rem,5.5vw,2.4rem);font-weight:900;text-shadow:0 2px 10px #000;max-width:92vw;min-height:1.2em}
.play-msg.flash-good{color:var(--good)} .play-msg.flash-bad{color:var(--bad)} .play-msg.flash-circle{color:var(--circle)}
.play-sub{margin-top:6px;font-size:clamp(1rem,3.4vw,1.3rem);font-weight:800;color:var(--ink);text-shadow:0 1px 6px #000}
.play-controls{display:flex;gap:7px;justify-content:center;flex-wrap:wrap;padding:6px 10px 0;pointer-events:none}
.phud-status{display:flex;align-items:center;gap:8px;margin:8px 2px 0;min-height:28px;flex-wrap:wrap}
.phud-clock{background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:4px 11px;font-weight:900;font-size:1rem;color:var(--ink);font-variant-numeric:tabular-nums}
.phud-clock.hot{color:#ff7a5a;border-color:var(--bad)}
.phud-tree{background:rgba(127,224,160,.12);border:1px solid rgba(127,224,160,.42);border-radius:9px;padding:4px 11px;font-weight:800;font-size:.85rem;color:#7fe0a0;white-space:nowrap}
.phud-tree.bare{background:rgba(174,183,196,.12);border-color:rgba(174,183,196,.42);color:#bcc4d0}
.play-spook{display:none;align-items:center;gap:6px;margin-left:auto;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:4px 9px;pointer-events:none}
/* vertical scroll control — crane up/down the tree (hold) */
.sp-label{font-size:.68rem;font-weight:800;color:var(--muted);letter-spacing:.06em}
.sp-bar{width:90px;height:8px;background:#0a1322;border-radius:5px;overflow:hidden}
#play-spook-fill{height:100%;width:0;background:linear-gradient(90deg,#5fd16a,#ffb347)}
.play-spook.hi #play-spook-fill{background:linear-gradient(90deg,#ff8c1a,#ff5c5c)}
.play-spook.hi{border-color:var(--bad);animation:ctrlpulse .6s infinite}
.ctrl{background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:5px 9px;font-size:.76rem;color:var(--muted);font-weight:700;white-space:nowrap}
.ctrl b{color:#ffb347;font-weight:900;margin-right:3px}
.ctrl.hot{border-color:var(--amber);color:var(--ink);animation:ctrlpulse .8s ease-in-out infinite}
.ctrl.done{opacity:.4}
@keyframes ctrlpulse{0%,100%{box-shadow:0 0 0 0 rgba(255,179,71,0)}50%{box-shadow:0 0 0 4px rgba(255,179,71,.25)}}
.play-actions{position:absolute;left:0;right:0;bottom:16px;display:flex;flex-wrap:wrap;gap:7px;justify-content:center;align-items:flex-end;padding:0 10px}
.play-actions .act-btn{flex:1;max-width:240px}
.play-actions .act-btn.walk{flex:0 0 46px;max-width:52px;font-size:1.25rem;padding:14px 0}
.play-actions .act-btn.look{flex:0 0 42px;max-width:48px;font-size:1.15rem;padding:14px 0;background:linear-gradient(180deg,#3a6ea5,#2a5180);box-shadow:0 5px 0 #1c3a5e;color:#eaf2ff}
.play-actions .act-btn.look:active{transform:translateY(4px);box-shadow:0 1px 0 #1c3a5e}
.play-actions .act-btn.howl{flex:1 1 100%;max-width:300px;margin-top:2px}
.play-actions .act-btn.call-big{flex-basis:100%;order:-1;max-width:none;margin-bottom:2px;animation:hotpulse .55s ease-in-out infinite}
.play-actions .act-btn.howl.squalling{filter:brightness(1.2);animation:hotpulse .4s ease-in-out infinite}
.play-actions .act-btn.pulloff{flex-basis:100%;order:1;max-width:none;background:transparent;border:1px solid var(--line);color:var(--muted);box-shadow:none;padding:9px;font-size:.84rem;font-weight:700}
.play-actions .act-btn.pulloff:active{transform:translateY(1px);box-shadow:none}

/* first-time "how to shine" card */
.shine-tip{position:absolute;inset:0;z-index:20;display:flex;align-items:center;justify-content:center;
  background:rgba(3,6,14,.86);backdrop-filter:blur(2px);padding:18px;overflow-y:auto}
.shine-tip.hidden{display:none}
.tip-card{width:430px;max-width:94vw;background:var(--bg2);border:2px solid var(--amber);border-radius:18px;
  padding:22px 20px;text-align:center;box-shadow:0 14px 40px rgba(0,0,0,.6)}
.tip-card h3{margin:0 0 10px;font-size:1.5rem;color:var(--amber)}
.tip-goal{color:var(--ink);font-size:.98rem;line-height:1.4;margin:0 0 14px}
.tip-goal b,.tip-warn b{color:var(--amber)}
.tip-controls{list-style:none;margin:0 0 14px;padding:0;text-align:left;display:flex;flex-direction:column;gap:8px}
.tip-controls li{color:var(--muted);font-size:.92rem;display:flex;align-items:center;gap:10px}
.tip-controls .tk{flex:0 0 auto;min-width:58px;text-align:center;background:#0a1322;border:1px solid var(--line);
  border-radius:8px;padding:5px 8px;color:#ffb347;font-weight:900;font-size:.85rem}
.tip-warn{color:var(--muted);font-size:.86rem;line-height:1.4;margin:0 0 18px;
  background:rgba(255,140,26,.08);border:1px solid rgba(255,179,71,.3);border-radius:12px;padding:10px 12px}
.tip-card .big-btn{width:100%}

/* ---------- mobile (phone-first) ---------- */
@media (max-width: 600px){
  .logo{font-size:2.5rem} .logo span{font-size:2rem}
  .view-switch{order:3;flex:0 0 100%;width:100%;margin:8px 0 0}   /* switcher: its own full row */
  .vseg{flex:1 1 0;min-width:0;padding:9px 2px;font-size:.76rem;white-space:nowrap;overflow:hidden}
  .info-chip{font-size:.78rem}
  .scoreboard{top:120px;right:8px;width:120px;font-size:.7rem;padding:5px 7px;opacity:.9}
  .sb-row .nm{max-width:62px}
  .hud-center{margin-top:28vh}
  .center-msg{font-size:clamp(1.25rem,6.5vw,1.9rem)}
  .read-wrap{bottom:122px;width:88vw}
  .actions{bottom:16px;padding:0 12px}
  .act-btn{padding:18px 10px;font-size:1.1rem}
  .view-toast{top:112px}
  .builder-wrap h2{font-size:1.5rem}
}
@media (max-width: 600px) and (max-height: 720px){
  .hud-center{margin-top:22vh}
  .scoreboard{top:114px}
}
