
:root{
  --bg:#07080d;--panel:rgba(11,14,22,.84);--panel2:rgba(19,24,36,.74);--line:rgba(255,255,255,.10);
  --text:#f5f6fb;--muted:#aeb8cc;--soft:#dce3f3;--red:#ff5366;--amber:#f0b25c;--green:#65e091;--blue:#65dfff;--violet:#9d8bff;
  --accent:var(--amber);--accent2:var(--red);--radius:22px;--shadow:0 24px 60px rgba(0,0,0,.48);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;touch-action:manipulation}
button,input{font:inherit}
button{border:0;cursor:pointer;color:var(--text)}
#bg{position:fixed;inset:0;background-image:url("assets/bg-dossier.png");background-size:cover;background-position:center;filter:brightness(.5) saturate(.95);transform:scale(1.04);transition:.3s ease}
.grain{position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 50% 25%,rgba(255,255,255,.08),transparent 34%),linear-gradient(180deg,rgba(5,6,10,.44),rgba(5,6,10,.9));}
.grain:after{content:"";position:absolute;inset:0;opacity:.13;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.05) 0 1px,transparent 1px 4px)}
#app{position:relative;width:min(100vw,460px);height:100svh;margin:0 auto;padding:calc(env(safe-area-inset-top) + 9px) 10px calc(env(safe-area-inset-bottom) + 9px);display:grid;grid-template-rows:70px 122px 1fr 58px;gap:9px}
.glass{background:linear-gradient(180deg,rgba(18,22,32,.84),rgba(7,9,14,.88));border:1px solid var(--line);box-shadow:var(--shadow);backdrop-filter:blur(16px)}
.top,.case-card,.stage,.bottom,.modal-card{border-radius:var(--radius)}
.top{display:flex;align-items:center;justify-content:space-between;padding:12px 14px}
.micro{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:800}
h1,h2,h3,p{margin:0} h1{font-size:24px;letter-spacing:-.05em;line-height:1.05}
.square-btn{width:40px;height:40px;border-radius:14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);font-size:20px;font-weight:900}
.case-card{position:relative;display:grid;grid-template-columns:38% 1fr;overflow:hidden}
.case-card img{width:100%;height:100%;object-fit:cover;opacity:.92}
.case-card:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,0),rgba(8,10,16,.62) 42%,rgba(8,10,16,.94));pointer-events:none}
.case-copy{position:relative;z-index:2;padding:11px 12px;display:flex;flex-direction:column;justify-content:center;min-width:0}
.case-meta{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:6px}
.tag{font-size:10px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;border-radius:999px;padding:5px 8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);white-space:nowrap}
.tag.hot{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#08090d}
.case-copy h2{font-size:18px;line-height:1.05;letter-spacing:-.035em;margin-bottom:5px}
.case-copy p{font-size:11.5px;line-height:1.25;color:var(--muted)}
.stage{min-height:0;padding:9px;display:grid;grid-template-rows:34px 1fr;gap:8px;overflow:hidden}
.status{border-radius:13px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.07);display:flex;align-items:center;padding:0 10px;color:var(--soft);font-size:12px;line-height:1.15;overflow:hidden}
.status span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#game{min-height:0;overflow:hidden}
.screen{height:100%;display:grid;gap:8px}
.panel{border-radius:17px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border:1px solid rgba(255,255,255,.075);padding:9px;min-height:0}
.copy{font-size:12px;line-height:1.28;color:#dbe2ef}.muted{color:var(--muted)}
.row{display:flex;align-items:center;gap:8px}.space{justify-content:space-between}
.bottom{display:flex;gap:8px;padding:8px}
.bottom button,.modal-actions button,.admin-tools button,.small-btn{flex:1;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.09);padding:10px 10px;font-weight:900;font-size:13px}
.primary{background:linear-gradient(135deg,var(--accent),var(--accent2))!important;color:#07080d!important}
.hidden{display:none!important}

/* Wordle */
.word-shell{height:100%;display:grid;grid-template-rows:auto 1fr auto;gap:8px}
.word-grid{display:grid;grid-template-rows:repeat(5,1fr);gap:6px;height:100%}
.word-row{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.letter{display:grid;place-items:center;border-radius:12px;background:rgba(255,255,255,.065);border:1px solid rgba(255,255,255,.11);font-size:23px;font-weight:1000;letter-spacing:.02em;box-shadow:inset 0 -8px 18px rgba(0,0,0,.15)}
.letter.ok{background:rgba(101,224,145,.22);border-color:rgba(101,224,145,.55)} .letter.near{background:rgba(240,178,92,.24);border-color:rgba(240,178,92,.55)} .letter.no{background:rgba(255,255,255,.035);color:#778094}
.keyboard{display:grid;grid-template-rows:repeat(3,1fr);gap:5px;height:100%}
.kb-row{display:grid;gap:4px;height:100%}
.kb-row.r1{grid-template-columns:repeat(10,1fr)} .kb-row.r2{grid-template-columns:repeat(9,1fr);padding:0 16px} .kb-row.r3{grid-template-columns:1.6fr repeat(7,1fr) 1.6fr}
.key{border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,.11),rgba(255,255,255,.06));border:1px solid rgba(255,255,255,.09);font-weight:900;font-size:13px;min-height:0;box-shadow:inset 0 -8px 18px rgba(0,0,0,.16)}
.key.ok{background:rgba(101,224,145,.24)} .key.near{background:rgba(240,178,92,.22)} .key.no{background:rgba(255,255,255,.035);color:#777}
.word-footer{display:grid;grid-template-columns:1fr;gap:8px}

/* Generic blocks */
.fact-list,.clues,.legend,.timeline,.history,.hint-lines,.master-history{display:grid;gap:6px}
.fact,.clue,.legend div,.history-item,.master-row{border-radius:13px;background:rgba(255,255,255,.052);border:1px solid rgba(255,255,255,.065);padding:7px;font-size:11px;line-height:1.2}
.legend b{display:block;color:var(--accent);font-size:13px}

/* Murdoku */
.murdoku-wrap{display:grid;grid-template-columns:1fr 112px;gap:8px;height:100%}
.murdoku-grid,.circuit-grid,.target-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}
.murdoku-grid{height:100%}
.cell{border-radius:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:grid;place-items:center;font-size:28px;font-weight:1000}
.cell.lock{box-shadow:inset 0 0 0 2px rgba(255,255,255,.18);background:rgba(255,255,255,.11)}

/* Timeline */
.timeline{height:100%}
.t-card{display:grid;grid-template-columns:28px 1fr 34px;gap:7px;align-items:center;border-radius:15px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.075);padding:7px}
.num{width:28px;height:28px;border-radius:10px;background:rgba(255,255,255,.09);display:grid;place-items:center;font-weight:900}
.t-card b{font-size:12px;display:block}.t-card small{display:block;color:var(--muted);font-size:10.5px;line-height:1.15}
.arrows{display:grid;gap:4px}.arrows button{height:24px;border-radius:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08)}

/* Circuit */
.circuit-layout{display:grid;grid-template-columns:110px 1fr;gap:10px;height:100%}
.target-grid{width:96px;height:96px}
.node,.c-node{border-radius:14px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.045)}
.node.on,.c-node.on{background:radial-gradient(circle,var(--accent),rgba(255,255,255,.1));box-shadow:0 0 18px color-mix(in srgb,var(--accent) 45%,transparent)}
.circuit-grid{height:100%}
.c-node{font-size:0}
.circuit-stats{display:grid;gap:6px}
.stat-pill{border-radius:12px;padding:7px 8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.07);font-size:11px}

/* Phone */
.phone-layout{display:grid;grid-template-columns:1fr 132px;gap:8px;height:100%}
.display{height:42px;border-radius:12px;background:#030507;border:1px solid rgba(255,255,255,.1);display:grid;place-items:center;color:var(--accent);font-family:monospace;font-size:22px;letter-spacing:.16em;margin-bottom:7px}
.dial{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}
.dial button{height:38px;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.09);font-weight:900}
.clue code{font-family:monospace;font-weight:900;color:var(--accent);font-size:14px}

/* Witness */
.witness-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;height:62%}
.witness{border-radius:15px;background:rgba(255,255,255,.052);border:1px solid rgba(255,255,255,.075);padding:8px;text-align:left}
.witness b{display:block;color:var(--accent);font-size:12px}.witness small{display:block;color:var(--soft);font-size:10.8px;line-height:1.18;margin-top:4px}
.choice-row{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-top:8px}
.choice-row button{border-radius:14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.09);padding:10px 6px;font-weight:900}

/* Cipher */
.cipher-top{display:grid;grid-template-columns:1fr 115px;gap:8px}.cipher-box{border-radius:15px;background:#030609;border:1px solid rgba(255,255,255,.09);padding:9px;font-family:monospace;color:var(--accent);font-size:17px;letter-spacing:.09em;line-height:1.35;min-height:70px}
.answer-input{height:44px;border-radius:13px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.07);color:var(--text);padding:0 12px;text-transform:uppercase;font-weight:900;letter-spacing:.08em;width:100%}.cipher-map{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;margin-top:8px}.cipher-map span{border-radius:10px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.07);padding:6px 4px;text-align:center;font-size:11px;font-family:monospace}

/* Sequence */
.seq-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;height:56%}.color-btn{border-radius:17px;border:1px solid rgba(255,255,255,.12);font-size:0;position:relative;overflow:hidden}.color-btn:after{content:"";position:absolute;inset:20%;border-radius:50%;background:rgba(255,255,255,.2)}
.c-red{background:#dc4055}.c-blue{background:#3db3ff}.c-green{background:#55d987}.c-yellow{background:#f0bd4f}.c-purple{background:#977cff}
.seq-log,.master-current{min-height:34px;border-radius:13px;background:rgba(0,0,0,.25);display:flex;gap:6px;align-items:center;justify-content:center;padding:7px}
.dot{width:18px;height:18px;border-radius:50%;border:1px solid rgba(255,255,255,.3)}

/* Mastermind */
.master-grid{display:grid;grid-template-rows:auto auto 1fr auto;gap:8px;height:100%}
.master-palette{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.master-palette button{height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.11)}
.master-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
.master-guess{display:flex;gap:6px}.master-pegs{display:grid;grid-template-columns:repeat(2,10px);grid-template-rows:repeat(2,10px);gap:4px;align-content:center}
.peg{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.15)} .peg.black{background:#111;border:1px solid #fff}.peg.white{background:#fff}

/* Modal/admin */
.modal{position:fixed;inset:0;z-index:40;background:rgba(0,0,0,.62);backdrop-filter:blur(7px);display:grid;place-items:center;padding:14px}
.modal-card{width:min(94vw,450px);max-height:88svh;padding:14px;overflow:hidden}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.modal-card h3{font-size:24px;letter-spacing:-.04em;margin-bottom:6px}.modal-card p{font-size:13px;color:var(--soft);line-height:1.35}
#shareText{white-space:pre-wrap;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.075);border-radius:16px;padding:12px;font-size:13px;color:var(--soft)}
.modal-actions{display:flex;gap:8px}.admin-card{display:grid;gap:10px}.admin-card input{flex:1;height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.07);color:var(--text);padding:0 12px}.admin-tools{display:flex;gap:8px;margin-bottom:9px}#adminList{display:grid;gap:7px;max-height:58svh;overflow:auto;padding-right:2px}.admin-item{border-radius:16px;background:rgba(255,255,255,.052);border:1px solid rgba(255,255,255,.075);padding:9px;display:grid;gap:7px}.admin-item b{font-size:13px}.admin-item small{color:var(--muted);font-size:11px}.admin-actions{display:flex;gap:6px}.admin-actions button{flex:1;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);padding:9px;font-size:12px;font-weight:900}
.toast{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom) + 12px);transform:translateX(-50%);z-index:60;border-radius:999px;background:rgba(8,10,15,.95);border:1px solid rgba(255,255,255,.12);padding:11px 15px;font-size:12px;box-shadow:var(--shadow);white-space:nowrap}
body.scene-lab{--accent:var(--blue);--accent2:#557bff} body.scene-ruin{--accent:var(--green);--accent2:#d8a74f} body.scene-dossier{--accent:var(--amber);--accent2:var(--red)} body.scene-terminal{--accent:#ffbd58;--accent2:#65dfff}
@media (max-height:760px){#app{grid-template-rows:60px 108px 1fr 54px;gap:7px;padding-inline:8px}.top{padding:9px 12px}.case-copy h2{font-size:16px}.case-copy p,.fact,.clue,.copy{font-size:10.7px}.stage{padding:7px;gap:6px;grid-template-rows:30px 1fr}.status{font-size:11px}.letter{font-size:18px}.key{font-size:11px}.panel{padding:7px}.witness small{font-size:10px}.kb-row.r2{padding:0 10px}}
