:root{--bg-color: #1b1b1b;--bg-panel: #242424;--text-color: rgba(255, 255, 255, .87);--accent-color: #646cff;--accent-hover: #535bf2;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--text-color);background-color:var(--bg-color);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{height:100%;width:100%;margin:0;overflow:hidden}body{display:flex;flex-direction:column}a{font-weight:500;color:var(--accent-color);text-decoration:none}a:hover{color:var(--accent-hover)}h1,h2,h3{margin:0 0 .5em;font-weight:700}p{margin:.25em 0}.panel{background:var(--bg-panel);padding:12px;border-radius:14px;box-shadow:0 8px 24px #00000059}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:600;background-color:#1a1a1a;color:var(--text-color);cursor:pointer;transition:border-color .25s,background-color .25s}button:hover{border-color:var(--accent-color);background-color:#222}button:focus,button:focus-visible{outline:3px solid var(--accent-color)}.topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 12px;backdrop-filter:blur(6px);background:#00000040;border-bottom:1px solid rgba(255,255,255,.06)}.brand{font-weight:800;letter-spacing:.5px}.topbar-center{text-align:center}.topbar-actions{display:flex;justify-content:flex-end;gap:8px}.secondary{background:transparent;border-color:#ffffff29}.viewport{display:grid;grid-template-rows:56px 1fr;height:100%;background:radial-gradient(1200px 400px at 20% -10%,rgba(255,255,255,.05),transparent 60%),var(--bg-color)}.main-grid{display:grid;grid-template-columns:minmax(260px,320px) 1fr;gap:12px;padding:12px;overflow:hidden}.left-col,.right-col{display:grid;grid-template-rows:auto 1fr auto;gap:12px;min-height:0}.scroll-inner{overflow-y:auto;min-height:0}.scroll-inner::-webkit-scrollbar{width:6px}.scroll-inner::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.reqs{display:flex;flex-wrap:wrap;gap:8px}.req-chip{font-size:12px;padding:6px 10px;border-radius:999px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12)}.req-chip.ok{border-color:#64ffb466}.req-chip.warn{border-color:#ffdc6459}.players-panel{overflow:hidden;display:flex;flex-direction:column}.player-grid{display:flex;flex-direction:column;gap:8px}.player-card{display:flex;align-items:center;gap:8px;background:#ffffff0d;border-radius:8px;padding:6px 8px}.player-avatar{width:40px;height:40px;border-radius:50%}.player-info{display:flex;flex-direction:column}.small{font-size:12px}.muted{opacity:.75}.role-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.role-card{border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:10px;background:linear-gradient(180deg,#ffffff0a,#ffffff05);opacity:.65}.role-card.on{opacity:1}.role-card.good{box-shadow:inset 0 0 0 1px #64ffb42e}.role-card.evil{box-shadow:inset 0 0 0 1px #ff788c2e}.role-card-header{display:flex;justify-content:space-between;margin-bottom:6px}.role-name{font-weight:700}.role-badge{font-size:11px;opacity:.85}.role-card-blurb{font-size:13px;opacity:.9}.role-card-foot{margin-top:6px;font-size:12px;opacity:.75}.settings-row{display:flex;justify-content:space-between;align-items:baseline}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:8px}.sw{display:flex;align-items:center;gap:8px;margin:6px 0}.sw input[type=checkbox]{transform:scale(1.15)}.action-bar{display:flex;gap:10px;flex-shrink:0}.modal-backdrop{position:fixed;inset:0;background:#0009;backdrop-filter:blur(4px);display:grid;place-items:center;z-index:50}.modal-card{width:min(820px,92vw);max-height:80vh;overflow:auto;border-radius:16px;background:var(--bg-panel);box-shadow:0 10px 40px #00000080;border:1px solid rgba(255,255,255,.08)}.modal-header,.modal-footer{padding:12px 16px;display:flex;align-items:center;gap:12px}.modal-header{border-bottom:1px solid rgba(255,255,255,.06);justify-content:space-between}.modal-footer{border-top:1px solid rgba(255,255,255,.06);justify-content:flex-end}.modal-body{padding:16px;display:grid;gap:12px}.icon-btn{border-radius:8px;border:1px solid rgba(255,255,255,.16);background:transparent;padding:6px 10px;font-weight:700}.icon-btn:hover{background:#ffffff0f}.hud-bar{position:fixed;left:12px;bottom:12px;display:flex;gap:8px;align-items:center;background:#00000059;border:1px solid rgba(255,255,255,.12);padding:8px 10px;border-radius:12px;backdrop-filter:blur(6px);z-index:30}.hud-btn{background:transparent;border-color:#ffffff2e}.conn-dot{width:10px;height:10px;border-radius:999px;background:#ffffff4d}.conn-dot.ok{background:#68f0b6}.conn-dot.bad{background:#f06868}.player-card .ready-indicator{font-size:12px;font-weight:600}.player-card.ready .ready-indicator{color:#68f0b6}.player-card.not-ready .ready-indicator{color:#f06868}@media (max-width: 768px){.board-head{flex-direction:column;align-items:flex-start}.targets{flex-direction:column}}.game-board{display:grid;gap:12px}.board-head{display:flex;gap:12px;align-items:center;justify-content:space-between}.phase-timer{font-size:.9em;color:#ffcb6b;margin-left:4px}.panel.night{border-left:4px solid #ff788c}.panel.day{border-left:4px solid #ffd95e}.targets{display:flex;flex-wrap:wrap;gap:8px}.targets button{flex:1 1 auto;min-width:120px}
