:root{--bg: #0f1117;--panel: #171a23;--panel-2: #1f2331;--ink: #e7e3d8;--muted: #8b91a3;--gold: #d9b25a;--gold-soft: #b9924a;--line: #2a2f3d;--slide-1: #2a2438;--slide-2: #14202e}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink);font-family:ui-sans-serif,system-ui,Segoe UI,Roboto,sans-serif}.app{display:flex;flex-direction:column;height:100%}.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#141824,#0f1117)}.topbar h1{margin:0;font-size:20px;letter-spacing:.3px}.control-pill{font-size:13px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);padding:5px 12px;border-radius:999px}.control-pill b{color:var(--gold)}.split{flex:1;display:grid;grid-template-columns:360px 1fr;min-height:0}.panel{padding:16px;overflow:auto;min-height:0}.panel.dm{border-right:1px solid var(--line);background:var(--panel)}.panel.player{background:#0c0e14;display:flex;flex-direction:column}.panel-head{font-weight:600;margin-bottom:14px}.muted{color:var(--muted);font-weight:400}.scene-list{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.scene-btn{display:flex;align-items:center;gap:10px;text-align:left;cursor:pointer;background:var(--panel-2);color:var(--ink);border:1px solid var(--line);border-radius:10px;padding:9px 11px;font-size:14px;transition:border-color .12s,transform .04s}.scene-btn:hover{border-color:var(--gold-soft)}.scene-btn:active{transform:translateY(1px)}.scene-btn.active{border-color:var(--gold);background:#232838}.scene-btn .num{display:grid;place-items:center;width:22px;height:22px;border-radius:6px;background:#0f1117;color:var(--gold);font-size:12px;font-weight:700}.scene-btn .nm{flex:1}.scene-btn .kind{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border:1px solid var(--line);padding:2px 7px;border-radius:999px}.scene-btn .kind.map{color:var(--gold);border-color:var(--gold-soft)}.dm-notes{font-size:13px;line-height:1.5;color:#cfd3df;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-bottom:14px}.dm-notes strong{color:var(--gold)}.stepper{display:flex;align-items:center;gap:10px;margin-bottom:14px}.stepper .count{color:var(--muted);font-variant-numeric:tabular-nums}.control-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}button{cursor:pointer;font-size:13px;background:var(--panel-2);color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:7px 12px}button:hover:not(:disabled){border-color:var(--gold-soft)}button:disabled{opacity:.4;cursor:not-allowed}.stage{position:relative;flex:1;min-height:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:grid;place-items:center}.stage img{width:100%;height:100%;object-fit:cover}.placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:linear-gradient(135deg,var(--slide-1),var(--slide-2));color:#d6d2c4;font-size:30px;letter-spacing:1px;text-shadow:0 2px 12px rgba(0,0,0,.5)}.placeholder.map-bg{background:linear-gradient(135deg,#1a2230,#101620),repeating-linear-gradient(0deg,transparent 0 39px,rgba(255,255,255,.03) 39px 40px),repeating-linear-gradient(90deg,transparent 0 39px,rgba(255,255,255,.03) 39px 40px)}.grid{position:absolute;top:0;right:0;bottom:0;left:0;display:grid}.cell{border:.5px solid rgba(255,255,255,.04);transition:background .18s,backdrop-filter .18s}.cell:hover{background:#d9b25a1a;cursor:pointer}.cell.fog{background:#06080cf0}.cell:not(.clickable){cursor:default}.cell.clickable:hover{background:#d9b25a1a;cursor:pointer}.cell.fog.clickable:hover{background:#06080ccc}.landing{min-height:100%;display:grid;place-items:center;padding:24px}.landing-card{width:100%;max-width:380px;text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:28px 24px}.landing-card h1{margin:0 0 4px;font-size:28px}.landing-card .sub{color:var(--muted);margin:0 0 22px;font-size:14px}.big{width:100%;padding:13px;font-size:15px;border-radius:10px}.primary{background:var(--gold);color:#1a1407;border-color:var(--gold);font-weight:600}.primary:hover:not(:disabled){background:#e6c069}.ghost{width:100%;padding:11px}.divider{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px;margin:16px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--line)}.join{display:flex;gap:8px}.code-input{width:90px;text-align:center;letter-spacing:4px;text-transform:uppercase;font-size:18px;font-weight:700;color:var(--gold)}.name-input{flex:1}.join input{background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:9px 11px;color:var(--ink)}.join input:focus{outline:none;border-color:var(--gold-soft)}.join button{padding:9px 16px}.connecting{height:100%;display:grid;place-items:center;color:var(--muted);font-size:16px}.player-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;padding:12px;background:#0c0e14;display:flex}.player-fullscreen .stage{flex:1;min-height:0}.share{padding:8px 20px;font-size:13px;color:var(--muted);background:#11151d;border-bottom:1px solid var(--line)}.share code{color:var(--gold);background:#0c0e14;padding:2px 7px;border-radius:6px}.onboarding{min-height:100%;display:grid;place-items:center;padding:24px}.onboarding-card{width:100%;max-width:360px;text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:26px 22px}.onboarding-card h2{margin:0 0 16px}.preview-token{width:64px;height:64px;border-radius:50%;margin:0 auto 18px;display:grid;place-items:center;font-size:30px;box-shadow:0 4px 16px #0006;border:2px solid rgba(255,255,255,.25)}.field{display:block;text-align:left;margin-bottom:14px}.field>span{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}.field input{width:100%;background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:9px 11px;color:var(--ink)}.field input:focus{outline:none;border-color:var(--gold-soft)}.swatches,.icons{display:flex;gap:8px;flex-wrap:wrap}.swatch{width:30px;height:30px;border-radius:50%;border:2px solid transparent;padding:0}.swatch.on{border-color:var(--ink);transform:scale(1.12)}.iconbtn{width:38px;height:38px;font-size:18px;border-radius:8px}.iconbtn.on{border-color:var(--gold);background:#232838}.sidebar{margin-top:16px}.player-fullscreen .sidebar{position:absolute;top:20px;left:20px;z-index:5;background:#141822db;border:1px solid var(--line);border-radius:12px;padding:10px 12px;min-width:150px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sidebar-head{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:8px}.sidebar-empty{color:var(--muted);font-size:13px}.roster-row{display:flex;align-items:center;gap:9px;padding:4px 0;font-size:14px}.roster-token{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:14px;border:1px solid rgba(255,255,255,.25);flex-shrink:0}.roster-name{flex:1}.roster-row.me .roster-name{color:var(--gold);font-weight:600}.roster-you{font-size:10px;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:1px 6px}.tokens{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.token{position:absolute;width:30px;height:30px;border-radius:50%;transform:translate(-50%,-50%);display:grid;place-items:center;font-size:15px;border:2px solid rgba(255,255,255,.7);box-shadow:0 2px 8px #00000080;transition:left .18s ease,top .18s ease}.board-frame{flex:1;min-height:0;min-width:0;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;touch-action:none}.board-frame.maximized{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0c0e14;padding:14px}.board{position:relative;aspect-ratio:3 / 2;max-width:100%;max-height:100%;transform-origin:center center;cursor:grab}.board:active{cursor:grabbing}.board-map{display:block;width:100%;height:100%;object-fit:fill;border-radius:8px;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.board-grid{position:absolute;top:0;right:0;bottom:0;left:0;display:grid}.board-tokens{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.map-controls{position:absolute;right:12px;bottom:12px;display:flex;gap:6px;z-index:10}.map-controls button{width:34px;height:34px;padding:0;font-size:15px;line-height:1;background:#12151deb;border:1px solid var(--line);border-radius:8px;color:var(--ink)}.map-controls button:hover{border-color:var(--gold-soft)}.slide-stage img{object-fit:contain}
