
:root{
  --fg:#e8e8e8; --muted:#a8a8a8; --bg:#0b0b0b; --card:rgba(0,0,0,.55);
  --line:rgba(255,255,255,.15); --danger:#ff4d4d;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--fg);font-family:system-ui,-apple-system,Segoe UI,Roboto,Noto Sans KR,sans-serif}
.bg{position:fixed;inset:0;background-size:cover;background-position:center;filter:contrast(1.05) saturate(.9);transform:scale(1.01)}
.ov{position:fixed;inset:0;background-size:cover;background-position:center;mix-blend-mode:overlay;opacity:.35;pointer-events:none}
.veil{position:fixed;inset:0;background:radial-gradient(ellipse at center, rgba(0,0,0,.35), rgba(0,0,0,.75));pointer-events:none}
.card{background:var(--card);border:1px solid var(--line);backdrop-filter:blur(6px);border-radius:14px;padding:14px}
.cardSub{background:rgba(0,0,0,.35);border:1px solid var(--line);border-radius:12px;padding:10px}
.cardTitle{font-size:12px;letter-spacing:.18em;color:var(--muted);margin-bottom:10px}
.imgFill{width:100%;height:220px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}
.imgFillTall{width:100%;height:420px;object-fit:contain;border-radius:12px;border:1px solid var(--line);background:rgba(0,0,0,.35)}
.small{font-size:12px}
.muted{color:var(--muted)}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--line);border-radius:999px;background:rgba(0,0,0,.35);font-size:12px;letter-spacing:.12em}
.chip.muted{color:var(--muted)}
.chip.danger{border-color:rgba(255,77,77,.35);color:var(--danger)}
.btn{border:1px solid var(--line);background:rgba(0,0,0,.35);color:var(--fg);padding:10px 12px;border-radius:12px;cursor:pointer}
.btn:hover{background:rgba(255,255,255,.06)}
.btn.primary{background:rgba(255,255,255,.09)}
.btn.danger{border-color:rgba(255,77,77,.45);color:var(--danger)}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:10px}
.page.gate .gateWrap{position:relative;min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}
.gatePanel{width:min(520px,92vw);position:relative}
.gateHeader{display:flex;gap:8px}
.field{margin-top:12px}
.pw{width:100%;padding:14px 12px;border-radius:12px;border:1px solid var(--line);background:rgba(0,0,0,.35);color:var(--fg);font-size:16px;letter-spacing:.12em}
.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}
.keypad button{padding:14px;border-radius:12px;border:1px solid var(--line);background:rgba(0,0,0,.25);color:var(--fg);font-size:16px}
.msg{min-height:18px;margin-top:10px;color:var(--muted);font-size:13px}
.stamp{position:absolute;right:12px;bottom:12px;width:180px;height:180px;background-size:contain;background-repeat:no-repeat;opacity:0;transform:rotate(-12deg) scale(.95);pointer-events:none}
.stamp.granted{filter:contrast(1.1)}
.stamp.denied{filter:contrast(1.1)}
.flash{position:absolute;inset:0;background:rgba(255,255,255,.05);opacity:0;pointer-events:none;border-radius:14px}
.hidden{display:none !important}
.page.play .topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:rgba(0,0,0,.45);border-bottom:1px solid var(--line);backdrop-filter:blur(8px)}
.tabs{display:flex;gap:8px}
.tab{border:1px solid var(--line);background:rgba(0,0,0,.25);color:var(--fg);padding:8px 10px;border-radius:999px;cursor:pointer}
.tab.active{background:rgba(255,255,255,.07)}
.main{padding:14px}
.tabPane{display:none}
.tabPane.active{display:block}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width: 900px){ .grid2{grid-template-columns:1fr} }
.storyPanel{min-height:160px;line-height:1.55}
.choices{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.choiceBtn{width:100%;text-align:left}
.feed{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.feedItem{padding:10px;border:1px solid var(--line);border-radius:12px;background:rgba(0,0,0,.25)}
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.65);z-index:10}
.modalInner{width:min(520px,92vw)}
.miniPanel{width:min(980px,96vw)}
.miniGrid{display:grid;grid-template-columns:320px 1fr;gap:12px;margin-top:12px}
@media (max-width: 900px){ .miniGrid{grid-template-columns:1fr} }
.people{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.personCard{position:relative;overflow:hidden;border-radius:12px;border:1px solid var(--line);background:rgba(0,0,0,.25);cursor:pointer}
.personCard img{width:100%;height:200px;object-fit:cover;display:block;filter:contrast(1.05)}
.personCard .tag{position:absolute;left:10px;top:10px}
.speech{min-height:90px;white-space:pre-wrap;line-height:1.5}
.label{font-size:12px;color:var(--muted);letter-spacing:.14em;margin-bottom:6px}
.miniTop{display:flex;gap:8px;align-items:center}
.miniRuleReveal img{width:100%;max-height:200px;object-fit:contain;border:1px solid var(--line);border-radius:12px;background:rgba(0,0,0,.25)}
.miniRuleReveal pre{margin:8px 0 0 0;white-space:pre-wrap;color:var(--muted);font-size:13px}
