:root{--bg: #f2ecdf;--surface: rgba(255, 251, 244, .88);--surface-strong: #fffaf0;--card: rgba(255, 248, 236, .92);--accent: #8d2f23;--accent-strong: #632117;--ink: #1f2230;--ink-soft: #4d5364;--good: #246648;--evil: #8c2b2b;--muted: #6b6f7e;--border: rgba(77, 61, 40, .18);--shadow: 0 18px 48px rgba(61, 39, 26, .12);--radius: 18px;--radius-sm: 12px;font-family:Iowan Old Style,Palatino Linotype,Book Antiqua,Georgia,serif}*{box-sizing:border-box;margin:0;padding:0}html{background:radial-gradient(circle at top,rgba(141,47,35,.18),transparent 28%),linear-gradient(180deg,#f7f0e4,#efe6d6 45%,#e6dbc8)}body{color:var(--ink);min-height:100vh;background:transparent}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 18% 20%,rgba(99,33,23,.08),transparent 22%),radial-gradient(circle at 82% 12%,rgba(36,102,72,.08),transparent 18%),repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0 2px,transparent 2px 14px);opacity:.75}#root{min-height:100vh}button{cursor:pointer;border:none;border-radius:999px;padding:.78rem 1.15rem;font-size:.98rem;font-weight:700;letter-spacing:.02em;transition:transform .16s ease,opacity .16s ease,box-shadow .16s ease}button:disabled{opacity:.42;cursor:not-allowed}button:hover:not(:disabled){opacity:.94;transform:translateY(-1px)}.btn-primary{background:linear-gradient(180deg,#a43b2c 0%,var(--accent) 100%);color:#fffaf5;box-shadow:0 10px 20px #8d2f233d}.btn-secondary{background:#fffbf4c7;color:var(--ink);border:1px solid var(--border);box-shadow:inset 0 1px #ffffffe6}.btn-good{background:#edf7f0;color:var(--good);border:1px solid rgba(36,102,72,.25)}.btn-evil{background:#fff0ec;color:var(--evil);border:1px solid rgba(140,43,43,.25)}.btn-danger{background:linear-gradient(180deg,#b84234,#8d2f23);color:#fffaf5;box-shadow:0 8px 18px #8d2f2347}.leave-confirm-card{gap:1.1rem}.leave-confirm-title{font-size:1.18rem;font-weight:700;color:var(--accent);text-align:center}.leave-confirm-body{text-align:center;line-height:1.55}.leave-confirm-actions{justify-content:center;gap:.75rem}.leave-confirm-actions button{min-width:100px}.leave-confirm-actions button .discussion-focus-card{border:2px solid rgba(36,102,72,.3);background:#edf7f0b3}.leave-confirm-actions button .discussion-focus-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.leave-confirm-actions button .discussion-focus-countdown{font-size:2rem;font-weight:800;font-variant-numeric:tabular-nums;color:var(--good);letter-spacing:-.02em}.leave-confirm-actions button .countdown-local-card{padding:.7rem .8rem;border-radius:var(--radius-sm);background:#fff8e1b3;border:1.5px solid rgba(141,47,35,.22)}input,select{background:#fffcf7eb;color:var(--ink);border:1px solid rgba(77,61,40,.16);border-radius:var(--radius-sm);padding:.82rem .92rem;font-size:.98rem;width:100%;box-shadow:inset 0 1px #fffffff2}input:focus,select:focus{outline:2px solid rgba(141,47,35,.24);border-color:#8d2f234d}.app-shell{position:relative;min-height:100vh;padding:1.2rem 0 5rem}.public-banner{position:sticky;top:.75rem;z-index:8;max-width:760px;margin:0 auto .9rem;display:flex;gap:.75rem;align-items:center;justify-content:center;text-align:center;border-color:#8d2f2352;background:linear-gradient(180deg,#fff8ecfa,#fff1e4f5);box-shadow:0 16px 30px #3d271a24;border-left:6px solid rgba(141,47,35,.45)}.announcement-emoji{font-size:1.1rem;line-height:1.1;padding-top:.05rem}.public-banner .tag{background:#ffffffb3;color:#5f4a36;border:1px solid rgba(95,74,54,.2)}.public-banner-default{border-left-color:#8d2f2373}.public-banner-clickable{cursor:pointer}.public-banner-clickable:hover{transform:translateY(-1px);box-shadow:0 18px 36px #3d271a2e}.public-banner-clickable:focus-visible{outline:2px solid rgba(32,91,120,.55);outline-offset:2px}.public-banner-night{border-left-color:#423c66a6;background:linear-gradient(180deg,#efeefff5,#e6e3fcf0)}.public-banner-night .tag{color:#393364;border-color:#39336438}.public-banner-execution{border-left-color:#8c2b2b99;background:linear-gradient(180deg,#ffeeecf5,#ffe5e1f0)}.public-banner-execution .tag{color:#7b2e2e;border-color:#7b2e2e3d}.public-banner-combat{border-left-color:#8f4d189e;background:linear-gradient(180deg,#fff2def7,#ffeacdf2)}.public-banner-combat .tag{color:#7e4c1e;border-color:#7e4c1e3d}.public-banner-proposal{border-left-color:#1c5e809e;background:linear-gradient(180deg,#eaf7fff7,#dceffaf0)}.public-banner-proposal .tag{color:#205b78;border-color:#205b783d}.public-banner-nudge{border-left-color:#267a599e;background:linear-gradient(180deg,#eafbf3f7,#dcf5e8f0)}.public-banner-nudge .tag{color:#2b6f53;border-color:#2b6f533d}.announcement-dismiss{width:auto;min-width:2rem;align-self:flex-start}.app-frame{position:relative;z-index:1}.leave-corner-btn{position:static;width:auto;padding:.35rem .65rem;font-size:.78rem;border-radius:999px;opacity:.9}.top-corner-actions{position:fixed;top:.9rem;right:.9rem;z-index:40;display:flex;gap:.45rem;align-items:center}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.15rem;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.page{max-width:760px;margin:0 auto;padding:1rem}.stack{display:flex;flex-direction:column;gap:.75rem}.row{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.player-row{border:1px solid rgba(77,61,40,.12);border-radius:var(--radius-sm);background:#ffffff73;padding:.55rem .7rem}.player-row-targetable{border-color:#8c2b2b52;background:linear-gradient(90deg,#fff0ecd1,#fff8ecb8);box-shadow:inset 0 0 0 1px #8c2b2b14}.player-row-targetable:hover{border-color:#8c2b2b85;transform:translateY(-1px);transition:border-color .15s ease,transform .15s ease}.seating-row{cursor:grab}.seating-row-dragging{opacity:.6;cursor:grabbing}.seating-row-touch-over{outline:2px solid rgba(141,47,35,.5);background:#8d2f230f}h1{font-size:clamp(2rem,5vw,3.1rem);line-height:.94;letter-spacing:-.03em}h2{font-size:1.06rem;color:var(--ink-soft);font-weight:700;letter-spacing:.01em}h3{font-size:1rem}.tag{display:inline-block;border-radius:999px;padding:.2rem .62rem;font-size:.76rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.tag-town{background:#e7eef9;color:#30527d}.tag-outsider{background:#f7efcf;color:#87642a}.tag-minion{background:#f7e8e8;color:#874040}.tag-demon{background:#2a2022;color:#f3d7cf}.pill{display:inline-flex;align-items:center;gap:.3rem;padding:.38rem .72rem;border-radius:999px;font-size:.8rem;border:1px solid rgba(77,61,40,.14);background:#ffffff85}.muted{color:var(--muted);font-size:.9rem;line-height:1.45}.night-info-line{color:var(--ink);font-size:1rem;line-height:1.55;font-weight:600}.danger{color:var(--evil)}.success{color:var(--good)}.divider{height:1px;background:#4d3d281f;margin:.35rem 0}.spinner{width:24px;height:24px;border:3px solid rgba(77,61,40,.16);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:2rem auto}@keyframes spin{to{transform:rotate(360deg)}}.landing-page{min-height:calc(100vh - 7rem);justify-content:center}.hero-card{position:relative;overflow:hidden;align-items:center;text-align:center;padding:1.5rem 1.1rem 1.2rem;background:radial-gradient(circle at top,rgba(141,47,35,.14),transparent 35%),linear-gradient(180deg,#fffcf6f5,#f9f2e7e6)}.brand-kicker{font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);font-weight:800}.doc-nav-link{font-size:1.6rem;text-decoration:none;opacity:.7;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}.doc-nav-wrap{position:absolute;top:0;right:0;display:flex;gap:.5rem}.doc-nav-link:hover{opacity:1;transform:scale(1.1)}.hero-copy{max-width:34rem;margin:0 auto}.hero-actions{justify-content:center;width:100%}.hero-actions button{flex:1 1 12rem}.hero-notes{justify-content:center}.hero-mark{position:relative;width:8.5rem;height:8.5rem;margin:.15rem auto .35rem}.hero-ring,.hero-core,.hero-hand{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border-radius:999px}.hero-ring-outer{width:100%;height:100%;border:4px solid rgba(31,34,48,.9);box-shadow:inset 0 0 0 6px #8d2f231a}.hero-ring-inner{width:72%;height:72%;border:2px solid rgba(31,34,48,.28)}.hero-core{width:.7rem;height:.7rem;background:var(--accent)}.hero-hand{transform-origin:center bottom;border-radius:999px;background:var(--ink)}.hero-hand-long{width:.26rem;height:2.6rem;transform:translate(-50%,-94%) rotate(28deg)}.hero-hand-short{width:.3rem;height:1.9rem;transform:translate(-50%,-94%) rotate(-48deg)}.landing-panel{width:100%;max-width:28rem;margin:0 auto}.room-code-input{text-transform:uppercase;font-weight:800;letter-spacing:.2em}.cheatsheet-wrap{position:fixed;right:1rem;bottom:1rem;z-index:50;max-width:min(92vw,460px)}.cheatsheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#261b1542;display:flex;align-items:flex-end;justify-content:flex-end;padding:1rem}.cheatsheet-panel{margin-top:.6rem;max-height:78vh;overflow:auto;width:min(92vw,480px)}.role-blurb{border:1px solid rgba(77,61,40,.12);border-radius:var(--radius-sm);padding:.6rem .7rem;background:#ffffff73}.role-good{background:#ecf9f1ad;border-color:#24664833}.role-outsider{background:#fff9eac2;border-color:#8b6d2d3d}.role-evil,.role-demon{background:#fff0ecc7;border-color:#8c2b2b38}.cheat-team-heading{font-size:.92rem;letter-spacing:.01em}.cheat-team-heading.good{color:var(--good)}.cheat-team-heading.outsider{color:#8b6d2d}.cheat-team-heading.evil,.cheat-team-heading.demon{color:var(--evil)}.cheat-segments{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.35rem}.cheat-segment{border:1px solid rgba(77,61,40,.18);background:#ffffff9e;color:var(--ink-soft);border-radius:999px;padding:.35rem .5rem;font-size:.76rem;font-weight:700}.cheat-segment.active{border-color:#8d2f2373;background:#fff1ecf2;color:var(--accent)}.cheat-count-pill{display:inline-flex;width:auto;flex:0 0 auto;align-items:center;border:1px solid rgba(77,61,40,.18);background:#ffffff9e;color:var(--ink-soft);border-radius:999px;padding:.3rem .65rem;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.cheat-count-pill:hover{background:#fff1ecb3;border-color:#8d2f234d}.cheat-count-pill.active{border-color:#8d2f238c;background:#fff1ecf2;color:var(--accent)}.phase-timeline{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.45rem;padding:.7rem}.phase-step{display:flex;align-items:center;gap:.4rem;border-radius:999px;border:1px solid rgba(77,61,40,.16);background:#ffffff7a;padding:.25rem .45rem;min-width:0}.phase-step.done{border-color:#24664859;background:#ecf7f0e6}.phase-step.active{border-color:#8d2f2361;background:#fff1ecf2}.phase-dot{width:1.1rem;height:1.1rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.66rem;font-weight:800;background:#4d3d281f;color:var(--ink-soft);flex-shrink:0}.phase-step.done .phase-dot{background:#2466482e;color:var(--good)}.phase-step.active .phase-dot{background:#8d2f2329;color:var(--accent)}.phase-label{font-size:.72rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vote-order-list{display:flex;flex-direction:column;gap:.4rem}.vote-order-item{display:flex;align-items:center;justify-content:space-between;gap:.45rem;padding:.34rem .5rem;border-radius:10px;background:#ffffff73;border:1px solid rgba(77,61,40,.12)}.vote-order-left{display:flex;align-items:center;gap:.42rem;min-width:0}.vote-order-right{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--ink-soft)}.day-timer-controls{align-items:stretch}.day-timer-controls select{max-width:11rem}.day-tabs-sticky{position:sticky;top:.9rem;z-index:7}.day-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.45rem;padding:.6rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.day-tab-btn{width:100%;padding:.58rem .45rem;font-size:.83rem}.day-tab-active{border-color:#8d2f2373;color:var(--accent);background:#fff1ecf2;box-shadow:inset 0 0 0 1px #8d2f231a}.nomination-focus-card{border-color:#8d2f2359;box-shadow:0 22px 46px #8d2f2324}.private-toggle-btn{width:auto;padding-inline:.8rem;white-space:nowrap}.day-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:45;background:#261b1542;display:flex;align-items:center;justify-content:center;padding:.9rem}.day-popup-card{width:min(94vw,430px)}.summary-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.55rem .65rem;border-radius:12px;background:#ffffff6b;border:1px solid rgba(77,61,40,.12)}.summary-row strong:before{content:"🗳️ "}.summary-right{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.35rem}.summary-pass{border-color:#2466483d;color:var(--good)}.summary-lead{border-color:#8d2f2347;color:var(--accent)}@media (max-width: 640px){.app-shell{padding-top:.55rem}.page{padding:.75rem}.top-corner-actions{top:.5rem;right:.5rem;gap:.35rem}.leave-corner-btn{font-size:.74rem;padding:.3rem .55rem;width:auto}.card{padding:1rem;border-radius:16px}.row{gap:.6rem}button{width:100%;justify-content:center}.cheat-count-pill{width:auto;justify-content:flex-start}.day-timer-controls select{max-width:none}.day-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.private-toggle-btn{width:100%}.summary-row,.summary-right{flex-direction:column;align-items:stretch}.hero-card{padding-top:1.2rem}.hero-mark{width:7.4rem;height:7.4rem}.cheatsheet-wrap{right:.6rem;left:.6rem;bottom:.6rem;max-width:none}.cheatsheet-overlay{align-items:flex-end;justify-content:center;padding:.6rem}.phase-timeline{grid-template-columns:repeat(2,minmax(0,1fr))}.cheat-segments{grid-template-columns:repeat(3,minmax(0,1fr))}.public-banner{align-items:flex-start;text-align:left;gap:.5rem;padding:.7rem .75rem}.public-banner .announcement-dismiss{width:auto;min-width:2rem;padding:.1rem;margin-top:-.1rem;flex-shrink:0}.public-banner .announcement-message{line-height:1.3}}
