:root{--bg:#0e0f12;--panel:#16181d;--accent:#7a8cff;--accent-2:#20d3a7;--text:#e6e8ef;--muted:#9aa0a6;--danger:#ff5d5d;--warn:#ffd166}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:radial-gradient(1200px 600px at 70% -10%,rgba(122,140,255,.12),transparent 50%),radial-gradient(800px 400px at 20% 110%,rgba(32,211,167,.06),transparent 40%),var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Helvetica Neue,Arial,"Apple Color Emoji","Segoe UI Emoji"}.container{max-width:1080px;margin:0 auto;padding:24px}.card{background:linear-gradient(180deg,#ffffff0a,#ffffff05);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:20px;box-shadow:0 20px 60px #0000004d;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}h1{font-size:28px;margin:0 0 16px;letter-spacing:.5px}h2{font-size:20px;margin:0 0 12px;color:var(--muted)}.col{flex:1;min-width:280px}input,button,select{background:var(--panel);border:1px solid rgba(255,255,255,.08);color:var(--text);border-radius:12px;padding:12px 14px;outline:none;font-size:14px}button{background:linear-gradient(120deg,var(--accent),var(--accent-2));border:none;font-weight:600;cursor:pointer;transition:transform .05s ease}button:active{transform:translateY(1px)}.button-secondary{background:transparent;border:1px solid rgba(255,255,255,.14)}.code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;padding:8px 10px;background:#ffffff0f;border-radius:8px}.badge{padding:6px 10px;border-radius:999px;background:#ffffff14;font-size:12px;border:1px solid rgba(255,255,255,.1)}.players{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-top:10px}.player{background:#00000040;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:12px;display:flex;align-items:center;gap:10px}.avatar{width:44px;height:44px;display:grid;place-items:center;font-size:24px;border-radius:14px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08)}.role-pill{font-size:12px;padding:2px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f}.killed{opacity:.45;filter:grayscale(100%)}.phase-banner{padding:10px 12px;border-radius:12px;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(90deg,#20d3a714,#7a8cff14);border:1px solid rgba(255,255,255,.1);margin:10px 0 16px}.stack{display:grid;gap:10px}.vote-list{display:grid;gap:8px}.vote-row{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff0a}.footer-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;margin-top:12px}@media (max-width:600px){.players{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.table-wrap{--circle: 480px;--seatInset: 78px;position:relative;width:100%;aspect-ratio:16 / 9;min-height:360px;border:1px solid rgba(255,255,255,.06);border-radius:16px;overflow:hidden;background:radial-gradient(60% 60% at 50% 40%,rgba(0,0,0,.35),transparent 70%)}.dealer-btn{position:absolute;left:50%;top:18%;transform:translate(-50%,-50%);padding:6px 10px;border-radius:999px;font-size:12px;background:#ffd16622;border:1px solid #ffd16666;z-index:3}.seat-wrap{position:absolute;left:50%;top:50%;transform-origin:center;transform:translate(-50%,-50%) rotate(var(--angle)) translate(calc(var(--circle) / 2)) translate(calc(-1 * var(--seatInset)));z-index:2}.seat{transform:rotate(calc(-1 * var(--angle)));padding:10px;border-radius:14px;background:#00000059;border:1px solid rgba(255,255,255,.08);display:flex;gap:8px;align-items:center}.seat .avatar{width:38px;height:38px;font-size:20px;border-radius:12px}.alive-false{opacity:.45;filter:grayscale(100%)}@media (max-width: 900px){.seat{width:100px}.table-wrap{--seatInset: 64px}}@media (max-width: 600px){.seat{width:60px}.table-wrap{--seatInset: 56px}}.row{display:flex;gap:12px;flex-wrap:wrap}.col{flex:1 1 0;min-width:280px}.chat{display:flex;flex-direction:column;gap:8px;width:100%;max-width:100%}.chat .panel{background:#00000059;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px;overflow:auto;max-height:280px}.chat .input-row{display:flex;gap:8px;align-items:stretch}.chat .input-row select,.chat .input-row input{flex:1 1 0;min-width:0}.chat .input-row button{flex:0 0 auto}@media (max-width: 600px){.chat .input-row{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:8px}.chat .input-row select{grid-column:1 / -1}.chat .input-row input{min-width:0}.chat .panel{max-height:220px}}@media (max-width: 900px){.col{flex:1 0 100%}}.story,.newspaper{background:#00000059;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px}.newspaper h3{margin:0 0 6px}.newspaper small{color:var(--muted)}.papers{display:grid;gap:10px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c108c;-webkit-backdrop-filter:blur(6px) saturate(1.1);backdrop-filter:blur(6px) saturate(1.1);display:grid;place-items:center;padding:16px;z-index:9999}.modal-card{width:min(560px,96vw);border-radius:18px;background:radial-gradient(120% 120% at 50% 0%,#ffffff0f,#ffffff05),#111418;border:1px solid rgba(255,255,255,.14);box-shadow:0 28px 80px #0000008c;color:var(--text);animation:modalIn .18s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 18px 0}.modal-title{font-size:20px;font-weight:700;letter-spacing:.2px}.countdown-badge{padding:4px 10px;border-radius:999px;font-size:12px;background:#ffffff14;border:1px solid rgba(255,255,255,.14)}.modal-body{padding:10px 18px 14px;opacity:.95;line-height:1.45}.modal-options{display:grid;gap:10px;padding:0 18px 18px}.modal-option{width:100%;padding:12px 14px;border-radius:14px;font-weight:600;background:linear-gradient(180deg,#ffffff0d,#ffffff08);border:1px solid rgba(255,255,255,.14);cursor:pointer;transition:transform .08s ease,box-shadow .08s ease}.modal-option:hover{transform:translateY(-1px);box-shadow:0 8px 24px #00000040}.modal-option:active{transform:translateY(0)}@keyframes modalIn{0%{transform:translateY(8px);opacity:0}to{transform:none;opacity:1}}body.modal-open{overflow:hidden}@media (max-width: 480px){.modal-title{font-size:18px}.modal-body{font-size:14px}}.newspaper{background:#00000059;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px}.newspaper .papers{max-height:280px;overflow:auto;display:grid;gap:10px}@media (max-width: 600px){.newspaper .papers{max-height:220px}}.chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:linear-gradient(135deg,#ffffff14,#ffffff08);border:1px solid rgba(255,255,255,.12);font-size:12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000}.settings-sheet{width:min(640px,92%);max-height:85vh;overflow-y:auto;border-radius:20px;padding:20px;background:#191b23e0;border:1px solid rgba(255,255,255,.08);box-shadow:0 12px 40px #0009;animation:scaleIn .25s ease}@keyframes scaleIn{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}.sheet-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.sheet-header h3{font-size:20px;font-weight:700}.sheet-footer{margin-top:20px;display:flex;justify-content:flex-end;gap:10px}.settings-grid{display:grid;gap:14px;margin:10px 0 6px;grid-template-columns:1fr 1fr}@media (max-width: 820px){.settings-grid{grid-template-columns:1fr}}.fieldset{display:flex;flex-direction:column;gap:6px}.label{font-weight:600}.muted{color:var(--muted);opacity:.85}.switch{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.switch .knob{width:44px;height:24px;border-radius:999px;position:relative;background:#ffffff1f;border:1px solid rgba(255,255,255,.12);transition:.2s}.switch .knob:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:.2s}.switch .knob.on{background:linear-gradient(90deg,#38bdf8,#22d3ee)}.switch .knob.on:after{left:22px}.preview-box{padding:8px 10px;border:1px dashed rgba(255,255,255,.18);border-radius:10px;opacity:.95}
