:root{
  --bg:#0a0e14; --bg2:#121826; --line:#1e2940; --text:#e6edf3; --text2:#8b98a9;
  --sun:#ffb700; --wind:#38d9f5; --hydro:#4f8cff; --kinetic:#ff7ac6;
  --nuclear:#ff5252; --gas:#ff9e3d; --gravity:#b388ff; --accent:#69f0ae;
}
*{box-sizing:border-box;margin:0;padding:0;font-family:system-ui,-apple-system,sans-serif}
body{background:#000;color:var(--text);overflow:hidden;display:flex;align-items:center;justify-content:center;height:100vh}
/* lock everything to a 16:9 stage */
#frame{aspect-ratio:16/9;width:min(100vw,177.78vh);height:min(56.25vw,100vh);
  background:var(--bg);display:flex;flex-direction:column}
#topbar{display:flex;gap:16px;align-items:center;padding:10px 16px;background:var(--bg2);
  border-bottom:1px solid var(--line);font-size:13px;flex-wrap:wrap}
#topbar button{margin-left:auto;background:var(--line);color:var(--text);border:0;
  padding:5px 10px;border-radius:6px;cursor:pointer}
#topbar button+button{margin-left:6px}
#stage{flex:1;display:grid;grid-template-columns:230px 1fr 230px;gap:10px;padding:10px;min-height:0}
#left,#right{display:flex;flex-direction:column;gap:8px;min-height:0;overflow:auto}
.pl{border:2px solid;border-radius:10px;padding:8px;background:var(--bg2);font-size:13px}
.pl.active{background:#16203a;box-shadow:0 0 12px #2a3f6b}
.pl.dead{opacity:.4;filter:grayscale(1)}
#actions{margin-top:auto;display:flex;flex-direction:column;gap:6px}
#actions button{padding:10px 12px;border:1px solid var(--line);background:var(--bg2);
  color:var(--text);border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:.15s;box-shadow:0 2px 6px #0000}
#actions button:hover:not(:disabled){box-shadow:0 4px 12px rgba(105,240,174,0.2);transform:translateY(-1px)}
#actions button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0000}
#actions button.on{background:var(--accent);color:#06231a;font-weight:700;box-shadow:0 4px 12px rgba(169,240,110,0.4)}
#actions .big{background:var(--sun);color:#241a00;font-weight:800;font-size:15px;box-shadow:0 4px 12px rgba(255,183,0,0.3)}
#actions button:disabled{opacity:.4;cursor:not-allowed}
#board{flex:1;display:grid;gap:6px;align-content:stretch}
#board.blocks{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:10px}
.city{display:flex;flex-direction:column;background:transparent;border:3px solid var(--line);
  border-radius:12px;padding:6px;min-height:0;position:relative;z-index:2}
.city .cgrid{flex:1;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:9px;min-height:0}
.chead{display:flex;gap:8px;align-items:center;font-size:11px;color:var(--text2);
  padding:5px 4px 2px;flex-wrap:wrap}
.chead b{color:var(--text);font-size:12px}
.chead .pos{color:var(--accent)} .chead .neg{color:var(--nuclear)} .chead .pos{color:var(--accent)}
.adv{position:absolute;top:3px;left:5px;font-size:13px;opacity:.85}
.cons{position:absolute;top:3px;right:5px;font-size:11px}
.cell{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:6px;
  cursor:pointer;display:flex;flex-direction:column;gap:2px;position:relative;transition:.1s}
.cell:hover{border-color:var(--accent)}
.cell.sel{outline:2px solid var(--accent)}
.cell.dim{opacity:.35}
.cn{font-size:11px;font-weight:700;color:var(--text)}
.ci{font-size:22px;text-align:center;flex:1;display:flex;align-items:center;justify-content:center}
.cc{font-size:9px;color:var(--text2)}
.bat{position:absolute;top:18px;right:5px;font-size:9px;color:var(--accent)}
.life{position:absolute;bottom:4px;left:6px;right:6px;height:3px;background:#333;border-radius:2px}
.life>i{display:block;height:100%;border-radius:2px;background:var(--accent)}
.life.warn>i{background:var(--gas)} .life.bad>i{background:var(--nuclear)}
#right{font-size:12px}
#log .hint{color:var(--accent);font-weight:700;margin-bottom:6px;min-height:16px}
#log div{padding:2px 0;border-bottom:1px solid var(--line);color:var(--text2)}
#modal{display:none;position:fixed;inset:0;background:#000a;align-items:center;justify-content:center;z-index:9}
#modal .card{background:var(--bg2);border:1px solid var(--line);border-radius:14px;
  padding:18px;width:min(440px,90%);position:relative;max-height:80vh;overflow:auto}
#modal h3{margin-bottom:10px;font-size:15px}
#modal .opt{display:flex;flex-direction:column;gap:2px;width:100%;text-align:left;
  background:var(--bg);border:1px solid var(--line);color:var(--text);border-radius:8px;
  padding:8px;margin-bottom:6px;cursor:pointer;font-size:12px}
#modal .opt:hover{border-color:var(--accent)}
#modal .opt span{color:var(--text2)}
#modal .close{position:absolute;top:10px;right:12px;background:0;border:0;color:var(--text2);font-size:18px;cursor:pointer}
#modal label{display:block;margin-top:8px;font-size:13px}

/* ============ GAMER POLISH ============ */
#frame{transition:background .8s ease, box-shadow .8s ease;position:relative;overflow:hidden}
#frame.day{background:radial-gradient(1200px 500px at 50% -10%,#16223b 0%,var(--bg) 60%)}
#frame.night{background:radial-gradient(1000px 500px at 50% -10%,#0b1430 0%,#05070d 70%)}
#frame::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(2px 2px at 20% 30%,#fff6 0,#0000 100%),
             radial-gradient(2px 2px at 70% 20%,#fff4 0,#0000 100%),
             radial-gradient(1px 1px at 40% 60%,#fff5 0,#0000 100%),
             radial-gradient(1px 1px at 85% 70%,#fff4 0,#0000 100%);
  opacity:0;transition:opacity 1s}
#frame.night::before{opacity:.5}
#frame>*{position:relative;z-index:1}

/* cells: hover lift + sheen */
.cell{transition:transform .12s ease, box-shadow .18s ease, border-color .18s}
.cell:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 6px 18px #000a,0 0 0 1px var(--accent)}
.cell .ci{filter:drop-shadow(0 2px 4px #000a);transition:transform .15s}
.cell:hover .ci{transform:scale(1.15)}
.adv{transition:transform .15s}.cell:hover .adv{transform:scale(1.3) rotate(-6deg)}

/* current player's stations: animated glow */
@keyframes mineGlow{0%,100%{box-shadow:inset 0 0 0 3px var(--c),0 0 4px var(--c)}
  50%{box-shadow:inset 0 0 0 3px var(--c),0 0 16px var(--c)}}
.cell.mine{animation:mineGlow 1.6s ease-in-out infinite}
.cell.dim{filter:grayscale(.6) brightness(.7)}

/* battery pulse */
@keyframes batPulse{0%,100%{opacity:.7}50%{opacity:1;text-shadow:0 0 6px var(--accent)}}
.bat{animation:batPulse 2s infinite}

/* life bar shimmer */
.life>i{transition:width .4s ease}

/* city block hover + active player frame */
.city{transition:box-shadow .25s, transform .15s}
.city:hover{box-shadow:0 0 0 1px var(--accent),0 8px 24px #0007}
.chead .neg{animation:warnBlink 1s steps(2) infinite}
@keyframes warnBlink{50%{opacity:.45}}

/* CO% blink on districts */
@keyframes blink{0%,49%{opacity:1}50%,100%{opacity:.3}}

/* players panel: active sweeping highlight */
.pl{transition:box-shadow .25s}
.pl.active{box-shadow:0 0 0 2px var(--accent)}
.pl.active::after{content:"◀";position:absolute;right:8px;top:8px;color:var(--accent);animation:nudge 1s infinite}
.pl{position:relative}
@keyframes nudge{50%{transform:translateX(-3px)}}

/* roll button: big juicy */
#actions .big{transition:transform .1s, box-shadow .2s;box-shadow:0 4px 0 #b07d00}
#actions .big:hover{transform:translateY(-2px);box-shadow:0 6px 0 #b07d00,0 0 20px #ffb70066}
#actions .big:active{transform:translateY(3px);box-shadow:0 1px 0 #b07d00}
#actions button{transition:transform .1s,background .15s,box-shadow .2s}
#actions button.on{box-shadow:0 0 14px #69f0ae88}

/* CO plant coverage — blinking danger red */
@keyframes coDanger{0%,49%{opacity:1;color:#ff2222}50%,100%{opacity:.25;color:#ff2222}}
.co-danger{animation:coDanger .7s steps(2) infinite;color:#ff2222;font-weight:700}

/* stability low: pulsing alarm */
.stab b{transition:color .3s}
#frame.alarm{animation:alarmFlash 0.6s ease 3}
@keyframes alarmFlash{50%{box-shadow:inset 0 0 120px #ff525266}}

/* event toast */
#toast{position:absolute;bottom:14px;left:50%;transform:translateX(-50%) translateY(20px);
  background:#16203aee;border:1px solid var(--accent);border-radius:12px;padding:10px 18px;
  font-size:14px;color:var(--text);z-index:20;opacity:0;pointer-events:none;
  box-shadow:0 8px 30px #000a, 0 0 24px #69f0ae33;max-width:60%;text-align:center;
  transition:opacity .3s, transform .3s}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.crit{border-color:var(--nuclear);box-shadow:0 8px 30px #000a,0 0 28px #ff525266}
#toast .ti{font-size:26px;display:block;margin-bottom:4px}

/* dice overlay */
#dice{position:absolute;inset:0;display:none;align-items:center;justify-content:center;
  z-index:25;background:#0007;backdrop-filter:blur(2px);pointer-events:none}
#dice.show{display:flex}
.die{width:84px;height:84px;border-radius:16px;background:linear-gradient(145deg,#fff,#cfd6e0);
  color:#111;font-size:48px;font-weight:800;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px #000a;animation:tumble .12s linear infinite}
@keyframes tumble{0%{transform:rotate(0) scale(1)}100%{transform:rotate(90deg) scale(1.05)}}

/* production badge on a station */
.prod{position:absolute;bottom:9px;left:5px;font-size:10px;font-weight:800;color:var(--sun);
  text-shadow:0 0 6px #ffb70088}
/* energy bridges overlay */
#board{position:relative}
#bridges{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:visible}
.bridge{stroke-linecap:round;fill:none;
  filter:drop-shadow(0 0 6px currentColor);stroke-dasharray:10 6;
  animation:flow-fwd var(--dur,0.8s) linear infinite;opacity:.9}
.bridge[style*="--flow-dir:-1"]{animation-name:flow-fwd}
.bridge[style*="--flow-dir:1"]{animation-name:flow-rev}
@keyframes flow-fwd{to{stroke-dashoffset:-16}}
@keyframes flow-rev{to{stroke-dashoffset:16}}

/* CO% indicator - prominent danger display */
.stab{font-size:15px;font-weight:700;padding:6px 10px;border-radius:6px;transition:.2s;cursor:pointer}
.stab:hover{background:rgba(255,34,34,0.1)}
.stab b{font-size:17px;letter-spacing:1px}

/* one-action turn bar + player energy readout */
.turnbar{font-weight:800;color:var(--accent);text-align:center;padding:6px;
  background:#16203a;border-radius:8px;border:1px solid var(--accent);margin-bottom:2px}
.pl .ok{color:var(--accent)} .pl .low{color:var(--gas)}
.weather b{color:var(--text)}

/* per-city background tints + action tip */
.city-0{background:transparent!important;border-color:#244a6e!important}
.city-1{background:transparent!important;border-color:#6e5a24!important}
.city-2{background:transparent!important;border-color:#1f5a52!important}
.city-3{background:transparent!important;border-color:#6e2438!important}
.tip{font-size:10px;color:var(--text2);text-align:center;margin-top:4px;line-height:1.3}

/* ===== FATE OPPORTUNITY CARD (drops & flips in, no decline) ===== */
#modal.fate{background:#000c;backdrop-filter:blur(4px)}
.fatecard{position:relative;width:min(340px,86%);padding:26px 22px 22px;border-radius:20px;
  background:linear-gradient(160deg,#1c2740 0%,#101726 60%,#0c1322 100%);
  border:1px solid #3a4d77;color:var(--text);text-align:center;overflow:hidden;
  box-shadow:0 24px 60px #000b, 0 0 0 1px #ffffff14, 0 0 40px #69f0ae22;
  transform-origin:top center;animation:fcDrop .7s cubic-bezier(.2,1.4,.3,1) both}
@keyframes fcDrop{
  0%{transform:translateY(-120%) rotateX(70deg) scale(.7);opacity:0}
  60%{opacity:1}
  80%{transform:translateY(8px) rotateX(0) scale(1.02)}
  100%{transform:translateY(0) rotateX(0) scale(1)}}
.fatecard::before{content:"";position:absolute;inset:0;border-radius:20px;padding:1px;
  background:linear-gradient(140deg,#ffd86b,#69f0ae,#38d9f5,#b388ff);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.6;pointer-events:none}
.fc-shine{position:absolute;top:-60%;left:-30%;width:60%;height:220%;
  background:linear-gradient(90deg,#0000,#ffffff35,#0000);transform:rotate(18deg);
  animation:fcShine 2.4s ease-in-out .6s infinite}
@keyframes fcShine{0%{left:-40%}60%,100%{left:130%}}
.fc-ribbon{display:inline-block;font-size:11px;letter-spacing:1px;text-transform:uppercase;
  color:#0a1020;background:linear-gradient(90deg,#ffd86b,#69f0ae);padding:3px 12px;border-radius:20px;font-weight:800}
.fc-icon{font-size:60px;margin:14px 0 6px;filter:drop-shadow(0 6px 14px #000a);animation:fcPop .6s .25s both}
@keyframes fcPop{0%{transform:scale(0) rotate(-30deg)}70%{transform:scale(1.25)}100%{transform:scale(1)}}
.fc-title{font-size:20px;font-weight:800;margin-bottom:8px}
.fc-desc{font-size:13px;color:var(--text2);line-height:1.45;margin-bottom:14px}
.fc-effect{display:inline-block;font-size:15px;font-weight:800;color:var(--accent);
  background:#69f0ae18;border:1px solid #69f0ae55;border-radius:10px;padding:8px 14px;margin-bottom:16px}
.fc-accept{display:block;width:100%;padding:12px;border:0;border-radius:12px;cursor:pointer;
  font-size:16px;font-weight:800;color:#06231a;background:linear-gradient(90deg,#ffd86b,#69f0ae);
  box-shadow:0 6px 18px #69f0ae44;transition:transform .1s}
.fc-accept:hover{transform:translateY(-2px)}.fc-accept:active{transform:translateY(1px)}

/* fate card: risk variant (red) */
.fatecard.bad{background:linear-gradient(160deg,#3a1620 0%,#1c1018 60%,#140c10 100%);
  box-shadow:0 24px 60px #000b,0 0 0 1px #ffffff14,0 0 40px #ff525233}
.fatecard.bad::before{background:linear-gradient(140deg,#ff8a5b,#ff5252,#b3387a);opacity:.6}
.fatecard.bad .fc-ribbon{background:linear-gradient(90deg,#ffb86b,#ff5252)}
.fatecard.bad .fc-accept{background:linear-gradient(90deg,#ffb86b,#ff7a7a);color:#2a0a0a;box-shadow:0 6px 18px #ff525244}

.stlist{font-size:12px;margin-top:2px;letter-spacing:1px}

/* tidy scrollbars + compact player cards (no ugly native bar) */
#left{overflow-x:hidden}
#left,#right{scrollbar-width:thin;scrollbar-color:var(--line) transparent}
#left::-webkit-scrollbar,#right::-webkit-scrollbar{width:6px;height:6px}
#left::-webkit-scrollbar-thumb,#right::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
#left::-webkit-scrollbar-track,#right::-webkit-scrollbar-track{background:transparent}
.pl{padding:6px 8px;font-size:12px;gap:1px}
.pl b{font-size:13px}
.pl>div{line-height:1.35}
.stlist{margin-top:1px}

/* zone = 9 info blocks (3x3) */
.cell9{background:var(--bg2);border:1px solid var(--line);border-radius:9px;cursor:pointer;
  position:relative;display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr 1fr;
  transition:box-shadow .18s,border-color .18s;overflow:hidden}
.cell9:hover{box-shadow:0 0 0 2px var(--accent),0 0 16px rgba(105,240,174,0.4);border-color:var(--accent);transform:scale(1.04);background:#1a2f2f}
.cell9.dim{filter:grayscale(.6) brightness(.7)}
.cell9.sel{outline:2px solid var(--accent)}
.cell9.mine{animation:mineGlow 1.6s ease-in-out infinite}
.cell9 .s{display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text2);line-height:1}
.cell9 .mc{font-size:28px;color:var(--text);text-shadow:0 0 8px rgba(0,0,0,0.7);filter:drop-shadow(0 0 3px rgba(255,255,255,0.2))}
.cell9 .tl{justify-content:flex-start;padding-left:3px;color:#ff9e6b}
.cell9 .tr{justify-content:flex-end;padding-right:3px;color:var(--accent)}
.cell9 .bl{justify-content:flex-start;padding-left:3px;color:#8bb4ff}
.cell9 .br{justify-content:flex-end;padding-right:3px;color:var(--sun)}
.cell9 .ml{opacity:.8} .cell9 .mr{font-size:8px}
.cell9 .bc{font-weight:700;color:var(--text)}
.cell9 .tc{font-size:10px}

#topbar select{background:var(--line);color:var(--text);border:0;border-radius:6px;padding:4px 6px;font-size:12px;max-width:130px}

/* station guide */
#tech-guide{margin-top:8px;font-size:11px;display:flex;flex-direction:column;gap:5px}
.guide-title{font-weight:700;color:var(--text2);font-size:11px;padding:2px 0;border-bottom:1px solid var(--line);margin-bottom:2px}
.guide-row{background:var(--bg2);border-radius:7px;padding:5px 7px;border:1px solid var(--line)}
.guide-head{display:flex;align-items:center;gap:5px;margin-bottom:2px}
.guide-icon{font-size:14px}
.guide-stat{color:var(--text2);font-size:10px;margin-bottom:2px}
.guide-plus{color:#69f0ae;font-size:10px}
.guide-minus{color:#ff6b6b;font-size:10px}

/* central energy hub cell */
.hub-cell{background:linear-gradient(135deg,#1a2a1a,#0d1f0d);border:2px solid #69f0ae88 !important;
  cursor:default;animation:hubPulse 2.5s ease-in-out infinite}
@keyframes hubPulse{0%,100%{box-shadow:0 0 6px #69f0ae44}50%{box-shadow:0 0 18px #69f0ae88,inset 0 0 8px #69f0ae22}}
@keyframes flow-osc{0%{stroke-dashoffset:0}50%{stroke-dashoffset:-24}100%{stroke-dashoffset:0}}

/* pre-game lobby */
.lobby-card{width:min(420px,92%)}
.lobby-row{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--line);
  border-radius:9px;padding:8px 10px;margin-bottom:7px}
.lobby-name{flex:1;background:transparent;border:0;border-bottom:1px solid var(--line);
  color:var(--text);font-size:14px;font-weight:700;padding:3px 2px;outline:none}
.lobby-name:focus{border-bottom-color:var(--accent)}
.lobby-die{font-size:15px;font-weight:800;min-width:42px;text-align:right}
.lobby-seat{font-size:16px;min-width:24px;text-align:center}
.lobby-btns{display:flex;gap:8px;margin-top:12px}
.lobby-btns .opt{flex:1;text-align:center;align-items:center;margin:0}
.lobby-disabled{opacity:.4;cursor:not-allowed}

/* lobby header + language toggle */
.lobby-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.lobby-head h3{margin:0}
.lobby-lang{display:flex;gap:4px}
.lobby-lang button{background:var(--line);color:var(--text2);border:0;border-radius:6px;
  padding:3px 9px;font-size:12px;font-weight:700;cursor:pointer}
.lobby-lang button.on{background:var(--accent);color:#06231a}
.lobby-seat{font-size:17px;font-weight:800;min-width:26px;text-align:center}

/* lobby rules */
.lobby-rules{margin:8px 0 4px;border:1px solid var(--line);border-radius:8px;background:var(--bg)}
.lobby-rules summary{cursor:pointer;padding:8px 10px;font-size:13px;font-weight:700;color:var(--accent);list-style:none}
.lobby-rules summary::-webkit-details-marker{display:none}
.lobby-rules[open] summary{border-bottom:1px solid var(--line)}
.rules-body{padding:10px;font-size:12px;line-height:1.55;color:var(--text2);max-height:200px;overflow:auto}

/* left news feed (under players) */
#news{flex:1;min-height:0;overflow:auto;font-size:11px;display:flex;flex-direction:column;gap:3px;margin:4px 0}
.news-title{font-weight:700;color:var(--text2);font-size:11px;padding:2px 0;border-bottom:1px solid var(--line);margin-bottom:2px}
.news-item{background:var(--bg2);border:1px solid var(--line);border-radius:6px;padding:4px 6px;color:var(--text2);line-height:1.3}
.news-item.crit{border-color:var(--nuclear);color:#ffb3b3}
.news-item span{margin-right:3px}

/* action hint — bottom-left corner overlay, never shifts layout */
#hint{position:absolute;bottom:12px;left:14px;z-index:18;display:none;
  background:#16203aee;border:1px solid var(--accent);border-radius:10px;
  padding:7px 14px;font-size:13px;font-weight:700;color:var(--accent);
  box-shadow:0 4px 16px #000a;pointer-events:none;max-width:40%}

/* toast → bottom-right corner (оклик) */
#toast{left:auto;right:14px;transform:translateY(20px);max-width:44%}
#toast.show{transform:translateY(0)}

/* lobby player count */
.lobby-count{display:flex;align-items:center;gap:8px;margin:6px 0 8px;font-size:13px;color:var(--text2)}
.lobby-count button{width:26px;height:26px;border:0;border-radius:6px;background:var(--line);
  color:var(--text);font-size:16px;font-weight:800;cursor:pointer}
.lobby-count button:disabled{opacity:.3;cursor:not-allowed}
.lobby-count b{font-size:16px;color:var(--accent);min-width:18px;text-align:center}

/* city header on top */
.chead{padding:2px 4px 5px}

/* ==== fit-to-window: allow grid/flex children to shrink, never overflow frame ==== */
#stage{overflow:hidden}
#board{min-height:0;overflow:hidden}
#board.blocks > .city{min-height:0;min-width:0;overflow:hidden}
.city .cgrid{min-height:0}
.cgrid > .cell9{min-height:0;min-width:0;overflow:hidden}
.chead{flex:0 0 auto}

/* ==== finish screen + fireworks ==== */
#modal.finish{background:#000d}
.finish-card{position:relative;overflow:hidden;width:min(440px,92%);text-align:center}
#fireworks{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}
.finish-card>*{position:relative;z-index:1}
.fin-crown{font-size:42px;animation:crownPop .6s ease}
@keyframes crownPop{0%{transform:scale(0) rotate(-30deg)}70%{transform:scale(1.3)}100%{transform:scale(1)}}
.fin-title{font-size:26px;margin:4px 0 0;text-shadow:0 0 18px currentColor}
.fin-sub{color:var(--text2);font-size:13px;margin-bottom:14px}
.fin-board{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.fin-row{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--line);
  border-radius:9px;padding:8px 12px;opacity:0;animation:finSlide .4s ease forwards}
@keyframes finSlide{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}
.fin-medal{font-size:18px;min-width:24px}
.fin-name{font-weight:800;flex:1;text-align:left}
.fin-money{font-weight:700;color:var(--text)}

/* credits under station guide */
.guide-credits{margin-top:8px;padding-top:8px;border-top:1px solid var(--line);
  font-size:9.5px;color:var(--text2);text-align:center;line-height:1.5;opacity:.75}

/* tutorial overlay (bottom-center, doesn't block board) */
#tut{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);z-index:19;display:none;max-width:62%}
.tut-box{background:#16203af2;border:2px solid var(--sun);border-radius:14px;padding:12px 18px;
  box-shadow:0 10px 34px #000b,0 0 24px #ffb70044;text-align:center}
.tut-step{font-size:11px;font-weight:800;color:var(--sun);letter-spacing:1px;margin-bottom:4px}
.tut-text{font-size:14px;line-height:1.45;color:var(--text);margin-bottom:8px}
.tut-text b{color:var(--sun)}
.tut-box{position:relative}
.tut-btn{background:linear-gradient(135deg,#ffb700,#ff9e3d);color:#241a00;border:0;border-radius:20px;
  padding:7px 18px;font-weight:800;font-size:13px;cursor:pointer;float:right;
  box-shadow:0 3px 10px #ffb70055;transition:transform .12s,box-shadow .2s}
.tut-btn:hover{transform:translateY(-1px) scale(1.04);box-shadow:0 5px 16px #ffb70088}
.tut-btn:active{transform:translateY(1px)}

/* clickable guide rows + SWOT modal */
.guide-row{cursor:pointer;transition:border-color .15s,transform .1s}
.guide-row:hover{border-color:var(--accent);transform:translateX(2px)}
.guide-more{margin-left:auto;color:var(--accent);font-size:12px;opacity:.7}
#modal.swot{background:#000c}
.swot-card{width:min(560px,94%);text-align:left}
.swot-fact{font-size:13px;color:var(--text2);line-height:1.5;margin:2px 0 12px;
  border-left:3px solid var(--accent);padding-left:10px}
.swot-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.swot-q{border-radius:9px;padding:9px 11px;font-size:12px;line-height:1.45;border:1px solid var(--line)}
.swot-q .swot-h{font-weight:800;font-size:12px;margin-bottom:4px}
.swot-q.s{background:#0f2417;border-color:#1f6f4a}.swot-q.s .swot-h{color:#69f0ae}
.swot-q.w{background:#2a1a0d;border-color:#7a5320}.swot-q.w .swot-h{color:#ffb700}
.swot-q.o{background:#0d1f2a;border-color:#1f5a7a}.swot-q.o .swot-h{color:#38d9f5}
.swot-q.t{background:#2a0f12;border-color:#7a2530}.swot-q.t .swot-h{color:#ff6b6b}
.swot-credits{margin-top:12px;font-size:10px;color:var(--text2);text-align:center;opacity:.7}

/* hub import/export values raised toward the top, clear of the centre label */
.hub-cell .ml, .hub-cell .mr{align-items:flex-start;padding-top:2px}
