:root{
  --bg:#080a11;
  --panel:linear-gradient(178deg,#161b28 0%,#0c0f19 100%);
  --panelflat:#11151f;
  --steel:#2c3546;
  --steel2:#404d66;
  --line:rgba(125,224,216,.22);
  --line2:rgba(125,224,216,.5);
  --tx:#efe8d7;
  --dim:#868ea3;
  --amber:#ffb454;
  --amber2:#ffd23e;
  --teal:#79e0d6;
  --red:#ff6b5e;
  --ok:#9dff70;
  --brk:rgba(121,224,214,.5);
  --scan:repeating-linear-gradient(0deg,rgba(255,255,255,.016) 0 1px,transparent 1px 3px);
  --mono:"SF Mono","Cascadia Mono","JetBrains Mono",ui-monospace,Menlo,Consolas,"Courier New",monospace;
  --shadow:0 10px 30px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.055),inset 0 0 0 1px rgba(0,0,0,.35);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;overflow:hidden;background:var(--bg)}
body{font-family:var(--mono);color:var(--tx);user-select:none;-webkit-user-select:none}
button{font-family:inherit}
#game{position:fixed;inset:0;display:block}
#hud{position:fixed;inset:0;pointer-events:none;z-index:5}
#hud>*{pointer-events:auto}
.hidden{display:none!important}

/* ---- châssis commun (console récupérée) ---- */
#quest,#sam,#gauges,#hint,#chips,.tb,.toast{
  background:var(--scan),var(--panel);
  border:1px solid var(--steel);
  box-shadow:var(--shadow);
}
/* coins-crochets pour les blocs principaux */
#quest,#gauges{position:absolute}
#quest::before,#quest::after,#gauges::before,#gauges::after{
  content:"";position:absolute;width:10px;height:10px;pointer-events:none;
  border:0 solid var(--brk);
}
#quest::before,#gauges::before{top:5px;left:5px;border-top-width:2px;border-left-width:2px}
#quest::after,#gauges::after{bottom:5px;right:5px;border-bottom-width:2px;border-right-width:2px}

/* ---- objectif ---- */
#quest{top:14px;left:14px;width:340px;border-radius:4px;padding:11px 14px}
#quest .qhead{display:flex;align-items:center;gap:8px;font-size:9.5px;letter-spacing:.24em;color:var(--amber);margin-bottom:6px;font-weight:600}
#quest .qhead::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--amber);box-shadow:0 0 8px var(--amber);animation:pulse 2.2s infinite}
#quest .qtxt{font-size:13.5px;line-height:1.5;letter-spacing:.01em}
#quest .qprog{margin-top:6px;font-size:11px;color:var(--teal);letter-spacing:.03em}
#quest .qtip{margin-top:6px;font-size:10.5px;color:var(--dim);padding-top:6px;border-top:1px dashed var(--steel)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ---- SAM, ordinateur de bord ---- */
#sam{position:absolute;top:150px;left:14px;width:340px;border-radius:4px;border-color:var(--steel2);padding:10px 13px;font-size:12px;line-height:1.6;animation:tin .25s ease}
#sam .samtag{color:var(--teal);letter-spacing:.16em;font-size:9.5px;margin-right:8px;font-weight:600}
#sam .samtxt{color:var(--tx)}
#sam .caret{display:inline-block;width:7px;height:12px;background:var(--teal);margin-left:2px;vertical-align:-2px;box-shadow:0 0 6px var(--teal);animation:blink 1s steps(2) infinite}
.gmode{display:flex;align-items:center;gap:6px;font-size:9px;letter-spacing:.24em;color:var(--amber);margin-bottom:6px;padding-bottom:6px;border-bottom:1px dashed var(--steel);font-weight:600}
.qflash{animation:qf 1s ease}
@keyframes qf{0%{box-shadow:0 0 0 2px var(--amber),var(--shadow)}100%{box-shadow:0 0 0 0 rgba(255,180,84,0),var(--shadow)}}
.chain{font-size:11px;line-height:2;color:var(--dim)}
.chain b{color:var(--amber);font-weight:600}
.chain .ri{margin-right:3px}

/* ---- toasts ---- */
#toasts{position:absolute;top:268px;left:14px;display:flex;flex-direction:column;gap:6px;width:340px;pointer-events:none}
.toast{border-radius:4px;border-left:3px solid var(--teal);padding:8px 11px;font-size:12px;line-height:1.4;animation:tin .25s ease;transition:opacity .4s,transform .4s}
.toast.ok{border-left-color:var(--ok)}
.toast.warn{border-left-color:var(--amber)}
.toast.bad{border-left-color:var(--red)}
.toast.out{opacity:0;transform:translateX(-8px)}
@keyframes tin{from{opacity:0;transform:translateY(-6px)}to{opacity:1}}

/* ---- barre haute : rail télémétrie + boutons console ---- */
#topbar{position:absolute;top:14px;right:14px;display:flex;gap:9px;align-items:stretch}
#chips{display:flex;border-radius:4px;overflow:hidden;align-items:stretch}
#topbtns{display:flex;gap:7px}
.chip{display:flex;align-items:center;padding:6px 11px;font-size:12px;border:0;border-right:1px solid var(--steel);box-shadow:none;background:transparent}
#chips{background:var(--scan),var(--panel)}
.chip:last-child{border-right:0}
.chip .clab{color:var(--dim);font-size:8.5px;letter-spacing:.14em;margin-right:6px;font-weight:600}
.chip b{color:var(--tx);font-weight:600;letter-spacing:.02em}
.chip.bad{color:var(--red)}
.chip.bad b,.chip.bad .clab{color:var(--red);animation:blink 1.1s steps(2) infinite}
.tb{color:var(--dim);border-radius:4px;padding:7px 12px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:color .15s,border-color .15s}
.tb:hover{color:var(--tx);border-color:var(--steel2)}
.tb.on{color:var(--amber);border-color:var(--amber)}

/* ---- jauges foreuse (segmentées) ---- */
#gauges{left:14px;bottom:14px;display:flex;flex-direction:column;gap:6px;border-radius:4px;padding:12px 14px 13px;width:266px}
.grow{display:flex;align-items:center;gap:9px;font-size:11px}
.glab{width:64px;letter-spacing:.12em;color:var(--dim);font-size:9px;font-weight:600}
.gbar{position:relative;flex:1;height:11px;background:#05070d;border:1px solid #222c3d;border-radius:2px;overflow:hidden;box-shadow:inset 0 1px 2px rgba(0,0,0,.6)}
.gbar i{display:block;height:100%;transition:width .18s ease;box-shadow:0 0 7px currentColor}
.gbar::after{content:"";position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(90deg,transparent 0 6px,#05070d 6px 8px)}
.grow b{min-width:56px;text-align:right;font-size:10px;font-weight:700;letter-spacing:.02em}
.grow.warn .glab,.grow.warn b{color:var(--red);animation:blink 1s steps(2) infinite}
.hotwarn{color:var(--red);animation:blink .7s steps(2) infinite;font-size:9.5px;margin-left:auto;font-weight:700}
.grow .dim{margin-left:auto;font-size:9.5px}
@keyframes blink{50%{opacity:.28}}

/* ---- indice contextuel (alertes seulement) ---- */
#hint{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);border-radius:4px;padding:8px 16px;font-size:11.5px;letter-spacing:.03em;color:var(--amber);white-space:nowrap;border-color:var(--amber);animation:tin .2s ease}

/* ---- panneau lateral ---- */
#panel{position:absolute;top:66px;right:14px;bottom:14px;width:384px;background:var(--scan),var(--panel);border:1px solid var(--steel);border-radius:5px;box-shadow:var(--shadow),0 10px 40px rgba(0,0,0,.5);overflow:hidden}
#panel::after{content:"";position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(125,224,216,.016) 2px 4px);border-radius:10px}
#panelIn{height:100%;overflow-y:auto;padding:14px;scrollbar-width:thin;scrollbar-color:#2a3149 transparent}
.phead{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.phead b{font-size:14px;letter-spacing:.04em}
.x{background:none;border:1px solid var(--line);color:var(--dim);border-radius:5px;width:26px;height:26px;cursor:pointer;flex:none}
.x:hover{color:var(--tx);border-color:var(--line2)}
.sect{margin:16px 0 8px;font-size:10px;letter-spacing:.2em;color:var(--amber)}
.cards{display:flex;flex-direction:column;gap:8px}
.card{background:rgba(255,255,255,.03);border:1px solid #1e2338;border-radius:8px;padding:10px;margin-bottom:8px}
.cards .card{margin-bottom:0}
.card.off{opacity:.6}
.card.done{border-color:rgba(157,255,112,.35)}
.card p{font-size:11.5px;color:var(--dim);margin:5px 0;line-height:1.45}
.cardTop{display:flex;align-items:center;gap:7px;font-size:13px}
.cardTop .ico{flex:none;font-size:9px;font-weight:700;letter-spacing:.08em;color:var(--teal);background:var(--panelflat);border:1px solid var(--steel);border-radius:3px;padding:3px 5px;min-width:30px;text-align:center}
.cardTop .ico.svgico{display:inline-flex;align-items:center;justify-content:center;padding:3px;min-width:24px}
.cardTop .ico svg{display:block}
.badge{margin-left:auto;font-size:10px;border:1px solid var(--line);border-radius:4px;padding:2px 6px;color:var(--teal);flex:none}
.badge.ok{color:var(--ok);border-color:rgba(157,255,112,.4)}
.costs{display:flex;flex-wrap:wrap;gap:5px;margin:7px 0}
.cost{font-size:11px;border-radius:4px;padding:3px 6px;background:#10141f;border:1px solid #1d2233;display:inline-flex;align-items:center;gap:5px}
.cost.no{color:var(--red);border-color:rgba(255,107,94,.35)}
.cost.ok{color:var(--tx)}
.ri{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;flex:none;vertical-align:-2px}
.ri svg{display:block}
.btn{background:linear-gradient(180deg,#ffc16a,#f09a3e);border:none;color:#231303;border-radius:6px;padding:8px 14px;font-size:12px;font-weight:700;letter-spacing:.04em;cursor:pointer}
.btn:hover{filter:brightness(1.08)}
.btn:disabled{opacity:.35;cursor:default;filter:grayscale(.7)}
.btn.big{font-size:15px;padding:13px 22px;width:100%;margin-top:12px;box-shadow:0 0 24px rgba(255,180,84,.25)}
.btn.ghost{background:none;border:1px solid var(--line2);color:var(--teal)}
.btn.danger{background:none;border:1px solid rgba(255,107,94,.5);color:var(--red)}
.mini{background:none;border:1px solid var(--line);color:var(--teal);border-radius:4px;padding:3px 7px;font-size:10px;cursor:pointer;flex:none}
.mini:hover{border-color:var(--line2)}
.recipes{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.recipe{border:1px solid #1e2338;border-radius:7px;padding:8px 10px;cursor:pointer;font-size:12px}
.recipe:hover{border-color:var(--line2)}
.recipe.sel{border-color:var(--amber);background:rgba(255,180,84,.06)}
.recipe .rline{margin-top:4px;font-size:11px;color:var(--dim);display:flex;flex-wrap:wrap;gap:4px;align-items:center;pointer-events:none}
.recipe b{pointer-events:none}
.arr{color:var(--amber)}
.pbar{height:6px;background:#0a0d15;border-radius:3px;margin-top:6px;overflow:hidden;border:1px solid #1d2233;pointer-events:none}
.pbar i{display:block;height:100%;background:var(--teal)}
.rstatus{font-size:10.5px;color:var(--dim);margin-top:4px;pointer-events:none}
.capbar{height:8px;background:#0a0d15;border-radius:3px;margin:4px 0 10px;overflow:hidden;border:1px solid #1d2233}
.capbar i{display:block;height:100%;background:var(--amber)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.resline{display:flex;align-items:center;gap:6px;font-size:11.5px;background:#10141f;border-radius:5px;padding:5px 8px}
.resline b{margin-left:auto}
.resline.zero{opacity:.4}
.needs{margin:6px 0}
.needline{font-size:11.5px;margin:6px 0}
.needline .nn{float:right;color:var(--dim)}
.rowline{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;padding:6px 0;border-bottom:1px dashed #1e2338;gap:8px}
table.keys{width:100%;font-size:11.5px;border-collapse:collapse}
table.keys td{padding:4px 6px;border-bottom:1px dashed #1e2338}
table.keys td:first-child{color:var(--amber);width:46%}
.tips{padding-left:18px;font-size:11.5px;color:var(--dim);line-height:1.65}
.dim{color:var(--dim)}
.okc{color:var(--ok)}
.noc{color:var(--red)}
.accent{color:var(--amber)}

/* ---- overlay recits ---- */
#overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 40%,rgba(10,12,25,.45),rgba(5,6,12,.9))}
.story{width:min(620px,92vw);background:var(--scan),var(--panel);border:1px solid var(--steel2);border-radius:8px;padding:36px 40px;text-align:center;box-shadow:0 20px 80px rgba(0,0,0,.65);position:relative;overflow:hidden;animation:tin .4s ease}
.story::after{content:"";position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,transparent 0 2px,rgba(125,224,216,.02) 2px 4px)}
.logo{font-size:33px;font-weight:800;letter-spacing:.3em;color:var(--amber);text-shadow:0 0 26px rgba(255,180,84,.4);margin-bottom:4px;padding-left:.3em}
.tagline{font-size:11px;letter-spacing:.5em;color:var(--teal);margin-bottom:20px;padding-left:.5em}
.story p{font-size:13.5px;line-height:1.7;margin:10px 0;color:var(--tx)}
.story .btn.big{width:auto;margin-top:18px;position:relative;z-index:1}
.story .btn.ghost{position:relative;z-index:1;margin-top:12px}
.keysline{font-size:10.5px!important;color:var(--dim)!important;margin-top:16px!important}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:20px 0 6px}
.stat{background:#10141f;border:1px solid #1e2338;border-radius:8px;padding:11px}
.stat b{display:block;font-size:20px;color:var(--amber)}
.stat span{font-size:9.5px;color:var(--dim);letter-spacing:.12em}

/* ---- menu principal / pause ---- */
.story.menu .btn.big{width:100%;margin-top:10px}
.story.menu .btn.big:first-of-type{margin-top:14px}
.difflab{font-size:9px;letter-spacing:.24em;color:var(--dim);margin:18px 0 8px;font-weight:600}
.pills{display:flex;gap:8px;position:relative;z-index:1}
.pill{flex:1;background:var(--panelflat);border:1px solid var(--steel);color:var(--dim);border-radius:5px;padding:9px 4px;font-size:11px;letter-spacing:.06em;cursor:pointer;transition:color .15s,border-color .15s,background .15s;font-family:inherit}
.pill:hover{color:var(--tx);border-color:var(--steel2)}
.pill.sel{color:var(--pc,var(--teal));border-color:var(--pc,var(--teal));background:rgba(121,224,214,.06);box-shadow:0 0 12px -4px var(--pc,var(--teal))}
.diffdesc{font-size:11px!important;color:var(--dim)!important;margin:10px 4px 4px!important;min-height:30px;line-height:1.5!important}
.menurow{display:flex;gap:8px;margin-top:12px;position:relative;z-index:1}
.menurow .btn{flex:1;margin:0}
.record{font-size:11px!important;color:var(--amber)!important;letter-spacing:.04em;margin-top:14px!important}
.story.menu .btn.danger{width:100%;margin-top:10px}
