:root{--app-max-width: 560px;--good: #3b82f6;--good-bg: #dbeafe;--evil: #ef4444;--evil-bg: #fee2e2;--bg: #000000;--surface: #0d0d0d;--surface2: #1a1a1a;--text: #f1f5f9;--text-dim: #a3a3a3;--border: #2a2a2a;--success: #22c55e;--danger: #ef4444;--warn: #f59e0b}*{margin:0;padding:0;box-sizing:border-box}html{font-size:20px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:300;font-size:1rem;line-height:1.5;letter-spacing:.012em;background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;display:flex;justify-content:center;overscroll-behavior:none;-webkit-tap-highlight-color:transparent}#app{width:100%;max-width:var(--app-max-width);padding:0 20px 164px;position:relative}.status-banner{position:fixed;left:0;right:0;display:flex;align-items:center;justify-content:center;text-align:center}.status-banner-top{top:0}.status-banner-bottom{bottom:var(--status-banner-bottom, 0px)}.status-banner-connection{height:3px;z-index:100;transition:background .3s,min-height .2s}.actions-paused .status-banner-connection{z-index:140}.status-banner-connection.connected-synced{background:var(--success)}.status-banner-connection.disconnected{display:none;background:var(--danger)}.actions-paused .status-banner-connection.disconnected{display:flex}.actions-paused .status-banner-connection.disconnected,.status-banner-connection.connecting,.status-banner-connection.reconnecting,.status-banner-connection.stale,.status-banner-connection.offline{min-height:30px;background:var(--warn);color:#1f2937;font-size:.85rem;font-weight:700;box-shadow:0 8px 18px #00000059}#connection-text{display:none}.actions-paused .status-banner-connection.disconnected #connection-text,.status-banner-connection.connecting #connection-text,.status-banner-connection.reconnecting #connection-text,.status-banner-connection.stale #connection-text,.status-banner-connection.offline #connection-text{display:block}.status-banner-connection.status-banner-delayed{min-height:3px;box-shadow:none}.status-banner-connection.status-banner-delayed #connection-text{display:none}.actions-paused button:disabled{cursor:not-allowed}.actions-paused .screen{padding-top:92px}.screen{padding-top:52px}.hidden{display:none!important}.screen-footer{position:fixed;left:0;right:0;bottom:0;width:100%;padding:18px max(20px,calc((100vw - var(--app-max-width)) / 2 + 20px)) calc(18px + env(safe-area-inset-bottom,0px));background:#000;box-shadow:0 -18px 24px #000000f5;z-index:90}.screen-footer .action-area{width:100%;align-items:stretch}.screen-footer .btn{width:100%;min-height:56px;font-size:1.08rem;border-radius:8px}#lobby-footer .btn+.btn{margin-top:8px}#lobby-footer{background:#000}.screen-footer .vote-buttons,.screen-footer .quest-buttons{width:100%}.screen-footer .btn-success-card,.screen-footer .btn-fail-card{padding:16px;font-size:1.05rem}#screen-home{text-align:center;padding-top:80px}.home-accent-bar{position:fixed;top:0;left:0;right:0;height:3px;background:var(--danger);pointer-events:none;z-index:80}#screen-home h1{font-size:3rem;letter-spacing:.1em;margin-bottom:8px}.subtitle{color:var(--text-dim);margin-bottom:40px}.home-form{display:flex;flex-direction:column;gap:12px;max-width:300px;margin:0 auto}.field-label{color:var(--text-dim);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-align:left;text-transform:uppercase}.invite-context{display:grid;gap:6px;max-width:300px;margin:0 auto 18px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:8px;text-align:left}.invite-label{color:var(--success);font-size:.68rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.invite-title{color:var(--text);font-size:1.15rem;font-weight:700}#invite-room-code{padding:0;background:transparent;border:0;color:var(--warn);cursor:pointer;font:inherit;letter-spacing:.15em}#invite-room-code:active{opacity:.65}#invite-context:not(.hidden) .invite-title,#invite-context:not(.hidden) .invite-title *{cursor:pointer}.invite-context p{color:var(--text-dim);font-size:.9rem;margin:0}.invite-exit{align-self:start;margin-top:2px;padding:0;background:transparent;border:0;color:var(--text-dim);cursor:pointer;font:inherit;font-size:.82rem;text-decoration:underline;text-underline-offset:3px}.invite-exit:hover,.invite-exit:focus-visible{color:var(--text)}.invite-mode .create-room-control,.invite-mode .room-code-control{display:none}.invite-mode .home-form{gap:10px}.divider{display:flex;align-items:center;gap:12px;color:var(--text-dim);margin:8px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.analytics-link,.changelog-link{color:var(--text-dim);text-decoration:none;font-size:.9rem}.analytics-link:hover,.changelog-link:hover{color:var(--text)}#btn-join{background:#16a34a;color:#fff}.btn.btn-role-guide{margin-top:8px;text-decoration:none;background:#7c3aed;color:#fff}input[type=text]{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px 16px;color:var(--text);font-size:1rem;outline:none;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none}input[type=text]:focus{border-color:var(--good)}input[type=text]::placeholder{color:var(--text-dim)}#room-code-input{text-transform:uppercase;text-align:center;letter-spacing:.2em;font-size:1.3rem}button:not(:disabled),button:not(:disabled) *,.btn:not(:disabled),.btn:not(:disabled) *{cursor:pointer}button:disabled,button:disabled *{cursor:not-allowed}.btn{padding:12px 24px;border:none;border-radius:6px;font-size:1rem;font-weight:600;transition:opacity .15s,transform .1s;touch-action:manipulation}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}@media(hover:none){.btn:active:not(:disabled){transform:scale(.96);opacity:.85}}.btn-primary{background:var(--good);color:#fff}.btn-secondary{background:var(--surface2);color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.analytics-page{width:100%;max-width:760px;margin:0 auto;padding:48px 20px 72px}.analytics-shell{display:grid;gap:20px}.analytics-hero{display:grid;gap:10px;padding:28px;background:radial-gradient(circle at top left,rgba(59,130,246,.16),transparent 42%),radial-gradient(circle at top right,rgba(34,197,94,.12),transparent 35%),var(--surface);border:1px solid var(--border);border-radius:18px}.analytics-kicker{color:var(--good);font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase}.analytics-hero h1{font-size:clamp(2rem,5vw,3.6rem);line-height:.95;letter-spacing:-.04em}.analytics-hero p{max-width:32rem;color:var(--text-dim)}.analytics-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.analytics-card{padding:24px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(180deg,#ffffff05,#ffffff03),var(--surface)}.analytics-label{display:block;color:var(--text-dim);font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;margin-bottom:14px}.analytics-value{font-size:clamp(2.4rem,5vw,4rem);line-height:1;font-weight:700;letter-spacing:-.06em}.analytics-meta{color:var(--text-dim);font-size:.9rem}.history-page{width:100%;max-width:720px;margin:0 auto;padding:40px 20px 72px}.history-shell{display:grid;gap:16px}.history-header{display:grid;gap:8px}.history-kicker{color:var(--good);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}.history-header h1{font-size:2.4rem;line-height:1}.history-form{display:grid;grid-template-columns:minmax(220px,1fr) auto;gap:12px;align-items:end}.history-form label{display:grid;gap:6px;color:var(--text-dim);font-size:.8rem;font-weight:600}.history-form input{width:100%;min-height:44px}.history-output-bar{display:flex;align-items:center;justify-content:space-between;gap:12px}.history-output-bar p{color:var(--text-dim);font-size:.9rem}@media(max-width:720px){.history-form{grid-template-columns:1fr}.history-output-bar{align-items:stretch;flex-direction:column}}.changelog-page{width:100%;max-width:720px;margin:0 auto;padding:52px 24px 80px}.changelog-shell{display:grid;gap:28px}.changelog-back{display:inline-block;font-size:.82rem;font-weight:500;color:var(--text-dim);text-decoration:none;letter-spacing:.01em;transition:opacity .2s}.changelog-back:hover{opacity:.7}.changelog-hero{display:grid;gap:10px;padding:44px 40px;background:#ffffff06;border:1px solid rgba(255,255,255,.06);border-radius:16px;position:relative;overflow:hidden;animation:rg-fade-up .5s ease both}.changelog-hero:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(201,164,78,.35),transparent)}.changelog-eyebrow{color:#c9a44e;font-size:.6rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase}.changelog-hero h1{font-size:clamp(2rem,4.8vw,3.2rem);line-height:1.05;font-weight:700;letter-spacing:-.03em}.changelog-content{display:grid;gap:16px}.changelog-entry{padding:22px 26px;border:1px solid rgba(255,255,255,.07);border-radius:14px;background:#ffffff06;position:relative;animation:rg-fade-up .4s ease both}.changelog-entry:before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:2px;background:#c9a44e59;border-radius:2px}.changelog-entry-header{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:14px}.changelog-version{font-size:1.1rem;font-weight:700;letter-spacing:-.02em;color:#f1f5f9}.changelog-date{font-size:.78rem;color:var(--text-dim);letter-spacing:.01em}.changelog-list{list-style:none;display:grid;gap:8px}.changelog-list li{font-size:.88rem;line-height:1.55;color:#a3a3a3e6;display:flex;align-items:baseline;gap:10px}.changelog-tag{flex-shrink:0;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 7px;border-radius:4px;line-height:1.6}.changelog-tag--new{background:#22c55e26;color:#4ade80}.changelog-tag--fix{background:#ef444426;color:#f87171}.changelog-tag--improve{background:#3b82f626;color:#60a5fa}@media(max-width:640px){.changelog-page{padding:36px 16px 56px}.changelog-hero{padding:28px 20px}.changelog-entry{padding:16px}.changelog-entry-header{flex-direction:column;gap:4px}}.analytics-page .btn{width:fit-content;text-decoration:none}@media(max-width:640px){.analytics-page{padding-top:28px}.analytics-hero,.analytics-card{padding:20px}}.btn-leave-room{position:fixed;top:10px;right:max(12px,env(safe-area-inset-right,12px));z-index:120;padding:10px 14px;font-size:.85rem;min-height:40px;min-width:40px}.btn-change-name{position:fixed;top:10px;left:max(12px,env(safe-area-inset-left,12px));z-index:120;padding:10px 14px;font-size:.85rem;min-height:40px;min-width:40px}.actions-paused .btn-leave-room{top:42px}.actions-paused .btn-change-name,.actions-paused .change-name-inline{display:none!important}.change-name-inline{position:fixed;top:10px;left:max(12px,env(safe-area-inset-left,12px));right:max(12px,env(safe-area-inset-right,12px));z-index:120;display:flex;flex-direction:column;gap:6px}.change-name-inline.hidden{display:none!important}.change-name-inline input{width:100%;box-sizing:border-box;padding:8px 10px;font-size:1rem}.change-name-actions{display:flex;gap:6px}.btn-sm{padding:8px 12px;font-size:.85rem}.btn-approve{background:var(--success);color:#fff;flex:1}.btn-reject{background:var(--danger);color:#fff;flex:1}.vote-choice-dimmed{background:#888!important;opacity:.5}.btn-success-card{background:var(--success);color:#fff;flex:1;padding:20px;font-size:1.1rem;transition:transform .2s,opacity .2s,box-shadow .2s}.btn-fail-card{background:var(--danger);color:#fff;flex:1;padding:20px;font-size:1.1rem;transition:transform .2s,opacity .2s,box-shadow .2s}.room-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.room-code-display,.room-code-small{color:var(--text-dim);font-size:1rem}.room-code-display{display:inline-flex;align-items:center;cursor:pointer;gap:6px}.room-code-display *{cursor:pointer}.room-code{font-weight:700;color:var(--warn);letter-spacing:.15em;font-size:1.1em;padding:4px 8px;border-radius:4px;transition:background .15s}.room-code:active{background:#f59e0b26}.room-copy-button{position:relative;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);touch-action:manipulation;transition:border-color .15s,background .15s,transform .1s}.room-copy-button svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.room-copy-button:hover,.room-copy-button:focus-visible{background:#242424;border-color:var(--warn);outline:none}.room-copy-button:active{transform:scale(.96)}.room-copy-button:after{content:attr(data-tooltip);position:absolute;right:0;top:calc(100% + 8px);width:max-content;max-width:180px;padding:6px 8px;background:#f8fafc;border:1px solid var(--warn);border-radius:6px;color:#111827;font-size:.72rem;font-weight:600;letter-spacing:0;line-height:1.2;opacity:0;pointer-events:none;transform:translateY(4px);transition:opacity .15s,transform .15s;box-shadow:0 8px 18px #00000059;z-index:200}.room-copy-button:hover:after,.room-copy-button:focus-visible:after{opacity:1;transform:translateY(0)}.room-code-small{text-align:right;margin-bottom:8px}.lobby-team-split{text-align:center;font-size:1.2rem;font-weight:600;letter-spacing:.04em;margin-bottom:12px}.lobby-good-count{color:var(--success)}.lobby-evil-count{color:var(--evil)}.lobby-vs{color:var(--text-dim)}.player-list{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.player-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface);border-radius:6px;border:1px solid var(--border);min-height:48px}.player-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.player-dot.connected{background:var(--success)}.player-dot.disconnected{background:var(--danger)}.player-name{flex:1;font-weight:400}.player-item-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.player-badge{font-size:.82rem;padding:3px 9px;border-radius:3px;font-weight:600}.badge-host{background:var(--warn);color:#000}.badge-you{background:var(--good);color:#fff}.badge-ai{background:#6b7280;color:#fff}.badge-leader{background:#a855f7;color:#fff}.badge-offline{background:#3f3f46;color:var(--text-dim)}.player-reorder-controls{display:flex;gap:6px;flex-shrink:0}.btn-reorder{background:transparent;border:1px solid var(--border);color:var(--text);width:32px;height:32px;border-radius:6px;cursor:pointer;font-size:.95rem;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s,background .15s,color .15s}.btn-reorder:hover,.btn-reorder:active{border-color:var(--good);background:#3b82f61f;color:var(--good)}.btn-reorder:disabled{opacity:.4;cursor:not-allowed}.btn-make-host{background:transparent;border:1px solid var(--warn);color:var(--warn);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:.9rem;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.btn-make-host:hover,.btn-make-host:active{background:var(--warn);color:#000}.btn-kick{background:transparent;border:1px solid var(--danger);color:var(--danger);width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:.9rem;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.btn-kick:hover,.btn-kick:active{background:var(--danger);color:#fff}.btn-spectator-toggle{background:var(--good);border:1px solid var(--good);color:#fff;width:38px;height:34px;border-radius:6px;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 0 1px #ffffff1f inset;transition:background .15s,color .15s,border-color .15s}.btn-spectator-toggle[data-spectating=false]{border-color:var(--border);background:var(--surface2);color:var(--text)}.btn-spectator-toggle svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.btn-spectator-toggle:hover,.btn-spectator-toggle:active{background:#2563eb;border-color:var(--good);color:var(--text)}.btn-spectator-toggle[data-spectating=false]:hover,.btn-spectator-toggle[data-spectating=false]:active{background:#ffffff1f;color:#fff}.spectator-list{margin-bottom:16px}.spectator-list h4{color:var(--text-dim);font-size:.95rem;margin-bottom:6px}.spectator-player-item{background:#ffffff08}.role-config-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:10px}.lobby-role-guide-link{flex-shrink:0;color:var(--text-dim);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-decoration:none;text-transform:uppercase}.lobby-role-guide-link:hover,.lobby-role-guide-link:focus-visible{color:var(--text);outline:none}.role-toggles{width:100%;margin-bottom:12px}.role-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.role-section-header{grid-column:1 / -1;display:flex;align-items:center;gap:10px;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim)}.role-section-header:not(:first-child){margin-top:6px}.role-section-header:before,.role-section-header:after{content:"";flex:1;height:1px;background:currentColor;opacity:.35}.role-section-good{color:var(--good)}.role-section-evil{color:var(--evil)}.role-cell{min-height:84px;padding:14px 12px;border-radius:8px;border:2px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:1.02rem;font-weight:600;text-align:center;transition:all .15s;touch-action:manipulation}.role-cell-good{background:#10b9810d}.role-cell-evil{background:#ef44440d}.role-cell.active-good{border-color:var(--good);background:var(--good);color:#fff}.role-cell.active-evil{border-color:var(--evil);background:var(--evil);color:#fff}.role-cell.inactive:hover:not(:disabled),.role-cell.inactive:active:not(:disabled){transform:translateY(-1px);border-color:#6b7280}.role-cell:active:not(:disabled){transform:scale(.97)}.role-cell:disabled{opacity:.55;cursor:not-allowed}@media(max-width:560px){.role-grid{grid-template-columns:1fr}}.role-summary{color:var(--text-dim);font-size:.95rem;margin-bottom:8px}.evil-message-threshold,.watch-config{margin-top:12px;text-align:center}.threshold-label{display:block;font-size:.85rem;color:var(--text-dim);margin-bottom:6px}.threshold-toggle{display:inline-flex;flex-wrap:wrap;max-width:100%;gap:6px}.threshold-btn{flex:0 0 auto;min-width:40px;padding:6px 14px;font-size:.9rem;border:2px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:6px;font-weight:600;transition:all .15s}.threshold-btn.selected{border-color:var(--evil);background:var(--evil);color:#fff}.threshold-btn:disabled{opacity:.5;cursor:not-allowed}.waiting-text{color:var(--text-dim);text-align:center;margin-top:12px}.role-card{position:relative;text-align:center;padding:40px 24px;border-radius:10px;margin:24px 0;border:3px solid}.role-card.good{background:linear-gradient(135deg,#1c1c1c,#111);border-color:var(--good)}.role-card.evil{background:linear-gradient(135deg,#5f1e1e,#111);border-color:var(--evil)}.role-card.spectator-role-card{background:#ffffff09;border-color:var(--border)}.role-name{font-size:2rem;font-weight:700;margin-bottom:8px}.role-team{font-size:1.1rem;font-weight:500}.known-info{margin-bottom:24px}.known-info h3{font-size:1rem;margin-bottom:8px;color:var(--text-dim)}.known-player{padding:8px 14px;background:var(--surface);border-radius:6px;margin-bottom:4px;display:flex;justify-content:space-between;align-items:center}.known-tag{font-size:.82rem;padding:3px 9px;border-radius:3px;font-weight:600}.tag-evil{background:var(--evil);color:#fff}.tag-unknown{background:#a855f7;color:#fff}.tag-good{background:var(--good);color:#fff}.quest-board{display:flex;justify-content:center;gap:12px;margin-bottom:16px}.quest-circle{width:52px;height:52px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;border:3px solid var(--border);background:var(--surface);position:relative}.quest-size{display:inline-flex;align-items:flex-start;line-height:1}.quest-circle.current{border-color:var(--warn);box-shadow:0 0 12px #f59e0b66}.quest-circle.passed{background:var(--success);border-color:var(--success);color:#fff}.quest-circle.failed{background:var(--evil);border-color:var(--evil);color:#fff}.quest-fails-plus{font-size:.6em;margin-left:2px;transform:translateY(-.28em);color:currentColor}.quest-circle-clickable{cursor:pointer;transition:transform .15s ease}.quest-circle-clickable:hover{transform:scale(1.12)}.quest-circle.selected{outline:3px solid white;outline-offset:2px}.quest-history-panel{margin:8px auto 0;padding:10px 14px;border-radius:8px;background:var(--surface);border:2px solid var(--border);text-align:center;max-width:360px}.quest-history-panel.passed{border-color:var(--success)}.quest-history-panel.failed{border-color:var(--evil)}.quest-history-header{display:grid;grid-template-columns:32px minmax(0,1fr) 32px;align-items:center;gap:8px;margin-bottom:6px}.quest-history-nav{width:32px;height:30px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);font:inherit;font-size:1rem;font-weight:700;line-height:1;cursor:pointer}.quest-history-nav:hover:not(:disabled){border-color:var(--text-dim);background:var(--surface2)}.quest-history-nav:disabled{cursor:not-allowed;opacity:.35}.quest-history-title{font-weight:700;font-size:.95rem;min-width:0}.quest-history-team{display:flex;flex-wrap:wrap;justify-content:center;gap:6px}.quest-history-member{background:var(--bg);padding:2px 10px;border-radius:4px;font-size:.9rem}.quest-history-no-team{color:var(--text-dim);font-style:italic;font-size:.9rem}.lotl-chain-panel{margin:8px auto 0;padding:8px 14px;border-radius:8px;background:var(--surface);border:2px solid var(--border);text-align:center;max-width:360px}.lotl-chain-title{font-weight:700;margin-bottom:4px;font-size:.95rem}.lotl-chain-entries{display:flex;flex-direction:column;gap:2px;align-items:center}.lotl-chain-entry{font-size:.9rem}#quest-history-detail:not(:empty){margin-bottom:16px}.vote-track{display:flex;justify-content:center;align-items:center;gap:6px;margin-bottom:16px}.vote-track-label{font-size:.9rem;color:var(--text-dim);margin-right:8px;align-self:center}.vote-marker{width:20px;height:20px;border-radius:3px;border:2px solid var(--border);background:var(--surface)}.vote-marker.filled{background:var(--danger);border-color:var(--danger)}.phase-banner{text-align:center;padding:10px;margin-bottom:12px;border-radius:6px;background:var(--surface);font-weight:600}.banner-leader-name{display:block;font-size:1.4em;font-weight:700}.your-role-badge{text-align:center;font-size:.9rem;margin-bottom:12px;padding:8px 12px;border-radius:6px;display:block}.your-role-badge.good{background:#ffffff1f;color:var(--good)}.your-role-badge.evil{background:#ef444433;color:var(--evil)}.your-role-badge--tappable{cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;min-height:44px;touch-action:manipulation}.your-role-badge--tappable:active{opacity:.85}.your-role-badge-info{font-size:1rem;opacity:.8;margin-left:4px}.your-role-badge--tappable:focus-visible{outline:2px solid currentColor;outline-offset:2px}.roles-in-play-details{margin-bottom:12px;border-radius:6px;background:#ffffff0f}.roles-in-play-summary{cursor:pointer;padding:6px 12px;font-size:.85rem;color:#aaa;text-align:center;-webkit-user-select:none;user-select:none;list-style:none}.roles-in-play-summary::-webkit-details-marker{display:none}.roles-in-play-summary:after{content:" ▼";font-size:.7rem}.roles-in-play-details[open] .roles-in-play-summary:after{content:" ▲"}.roles-in-play-content{display:flex;gap:16px;justify-content:center;padding:4px 12px 10px;flex-wrap:wrap}.roles-in-play-group{display:flex;flex-direction:column;align-items:center;gap:4px}.roles-in-play-team-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.roles-in-play-team-label.good{color:var(--good)}.roles-in-play-team-label.evil{color:var(--evil)}.roles-in-play-role{font-size:.8rem;padding:2px 8px;border-radius:4px}.roles-in-play-role.good{color:var(--good)}.roles-in-play-role.evil{color:var(--evil)}.game-player-list{margin-bottom:16px;overflow-x:auto}.game-player-table{width:100%;border-collapse:separate;border-spacing:0 6px;min-width:280px}.game-player-table th{text-align:left;font-size:.82rem;font-weight:700;color:var(--text-dim);padding:0 12px 4px;text-transform:uppercase;letter-spacing:.03em}.game-player-table th:last-child{text-align:right}.game-player-row td{background:var(--surface);border-top:2px solid var(--border);border-bottom:2px solid var(--border);padding:12px;transition:border-color .15s,background .15s}.game-player-row td:first-child{border-left:2px solid var(--border);border-radius:6px 0 0 6px;font-weight:600;font-size:.9rem}.game-player-row td:last-child{border-right:2px solid var(--border);border-radius:0 6px 6px 0;text-align:right}.game-player-row.selectable{cursor:pointer;touch-action:manipulation}.game-player-row.selectable:hover td,.game-player-row.selectable:active td{border-color:var(--good);background:#3b82f614}.game-player-row.on-team td{border-color:var(--warn);background:#f59e0b26}.game-player-row.disconnected-player{opacity:.5}.player-you{color:var(--good);font-size:.9rem}.player-status-cell{white-space:nowrap}.player-status-chip{display:inline-block;font-size:.78rem;padding:4px 10px;border-radius:10px;font-weight:600;margin-left:4px;background:#ffffff1f;color:var(--text-dim)}.player-status-chip:first-child{margin-left:0}.player-status-chip.voted{background:#22c55e2e;color:var(--success)}.player-status-chip.leader{background:#3b82f62e;color:var(--good)}.player-status-chip.hammer{background:#ef444433;color:#fca5a5}.player-status-chip.disconnected{background:#ef44442e;color:var(--evil)}.player-status-chip.lady{background:#8b5cf62e;color:#c4b5fd}.player-status-chip.watch{background:#14b8a62e;color:#5eead4}.player-status-empty{color:var(--text-dim)}.inline-quest-result{background:var(--surface);border:2px solid var(--border);border-radius:8px;padding:14px;text-align:center}.inline-quest-result-dismiss{margin-top:12px}.known-marker{width:8px;height:8px;border-radius:50%;display:inline-block;margin-left:4px}.known-marker.evil-known{background:var(--evil)}.known-marker.merlin-morgana-known{background:#a855f7}.known-marker.evil-teammate-known{background:var(--evil)}.known-marker.good-known{background:var(--good)}.known-marker.lancelot-known{background:#3b82f6}.action-area{display:flex;flex-direction:column;gap:10px;align-items:center;min-height:30px}.vote-buttons,.quest-buttons{display:flex;gap:12px;width:100%}.quest-choice-selected{transform:scale(1.05);box-shadow:0 0 12px #fff6;opacity:1}.quest-choice-dimmed{opacity:.3;transform:scale(.95)}.btn-message-success{background:#0ea5e9;color:#fff;flex:1}.btn-message-success:hover{background:#0284c7}.btn-message-fail{background:#7c3aed;color:#fff;flex:1}.btn-message-fail:hover{background:#6d28d9}.btn-magic{background:#d97706;color:#fff;flex:1}.btn-magic:hover{background:#b45309}.btn-rogue-success{background:#059669;color:#fff;flex:1}.btn-rogue-success:hover{background:#047857}.btn-rogue-fail{background:#be123c;color:#fff;flex:1}.btn-rogue-fail:hover{background:#9f1239}.messenger-counters{display:flex;gap:12px;justify-content:center;margin:8px 0}.messenger-counter{font-size:.8rem;font-weight:600;padding:4px 10px;border-radius:12px}.messenger-counter.good-messages{background:#22c55e26;color:var(--good)}.messenger-counter.evil-messages{background:#ef444426;color:var(--evil)}#screen-assassinate h2{text-align:center;margin-bottom:22px}#screen-assassinate{padding-bottom:128px}#assassination-desc{margin-bottom:24px}.assassination-targets{width:100%;margin-bottom:16px}.assassination-target-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.assassination-target-table th{text-align:center;padding:10px 12px;color:var(--text-dim);font-weight:500;border-bottom:1px solid var(--border)}.assassination-target-table td{padding:0}.assassination-target-table tbody tr+tr td{border-top:1px solid var(--border)}.assassination-target{width:100%;padding:16px 12px;background:transparent;border:none;text-align:center;color:var(--text);font:inherit;cursor:pointer;font-weight:600;transition:all .15s;min-height:48px}.assassination-target:hover,.assassination-target:active{background:#ef44441a}.assassination-target.selected{background:#ef444433}.assassination-context{display:grid;grid-template-columns:1fr;gap:18px;margin-top:22px}.assassination-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;margin:0 0 18px;padding:4px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.assassination-tab{min-height:38px;border:0;border-radius:6px;background:transparent;color:var(--text-dim);font:inherit;font-size:.9rem;font-weight:700;cursor:pointer}.assassination-tab.selected{background:var(--surface2);color:var(--text);box-shadow:inset 0 -2px 0 var(--good)}.assassination-context-section{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:18px}.assassination-context-section h3{margin:0 0 14px;color:var(--text-dim);font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:0}.assassination-quest-list{display:flex;flex-direction:column;gap:12px}.assassination-quest-row{display:grid;gap:10px;padding:14px;border-left:4px solid var(--border);background:var(--bg)}.assassination-quest-row.passed{border-left-color:var(--success)}.assassination-quest-row.failed{border-left-color:var(--evil)}.assassination-quest-result{display:flex;justify-content:space-between;gap:14px;font-size:1rem;font-weight:700}.assassination-quest-team{display:flex;flex-wrap:wrap;gap:8px}.assassination-context-chip,.assassination-context-muted,.assassination-seat-badge{border-radius:4px;padding:5px 10px;font-size:.92rem;line-height:1.4}.assassination-context-chip{background:var(--surface);border:1px solid var(--border)}.assassination-context-muted{color:var(--text-dim);font-style:italic}.assassination-seat-list{display:grid;gap:8px;margin:0;padding:0;list-style:none}.assassination-seat-list li{display:grid;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:10px;padding:12px;background:var(--bg);border:1px solid var(--border)}.assassination-seat-number{color:var(--text-dim);font-size:.92rem;font-weight:700;text-align:center}.assassination-seat-name{min-width:0;overflow-wrap:anywhere;font-size:1rem;font-weight:600}.assassination-seat-badges{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:4px}.assassination-seat-badge{background:#22c55e24;color:var(--success);font-weight:700}.assassination-seat-badge.muted{background:#94a3b824;color:var(--text-dim)}.shot-type-selector{display:flex;gap:8px;justify-content:center;margin-bottom:16px;flex-wrap:wrap}.shot-type-btn{padding:10px 16px;background:var(--surface);border:2px solid var(--border);color:var(--text);font-weight:600;cursor:pointer;border-radius:8px;transition:all .15s}.shot-type-btn:hover{border-color:var(--evil)}.shot-type-btn.selected{border-color:var(--evil);background:#ef444426}.servant-guess-result{text-align:center;padding:12px 16px;border-radius:8px;font-weight:600;margin-bottom:16px}.servant-guess-result.correct{background:#ef444426;color:var(--evil)}.servant-guess-result.incorrect{background:#22c55e26;color:var(--good)}#screen-lady{text-align:center}#screen-lady h2{margin-bottom:8px}#lady-desc{color:var(--text-dim);margin-bottom:20px}.lady-reveal-result{display:inline-block;border-radius:12px;padding:24px 40px;margin:16px auto;text-align:center}.lady-reveal-result.good-result{background:#22c55e26;border:1px solid rgba(34,197,94,.3)}.lady-reveal-result.evil-result{background:#ef444426;border:1px solid rgba(239,68,68,.3)}.lady-reveal-name{font-size:1.3rem;font-weight:700;margin-bottom:8px}.lady-reveal-alignment{font-size:1.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.lady-alignment-good{color:var(--good)}.lady-alignment-evil{color:var(--evil)}.watch-config{margin-top:12px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}#screen-gameover{text-align:center}#gameover-title{font-size:2rem;margin-bottom:8px}#gameover-title.good-win{color:var(--good)}#gameover-title.evil-win{color:var(--evil)}#gameover-title.solo-win{letter-spacing:0}#gameover-reason{color:var(--text-dim);margin-bottom:18px}.gameover-recap,.gameover-roles{text-align:left}.gameover-recap-shell,.gameover-roles{display:grid;gap:10px;margin-bottom:20px}.gameover-tab-panel{display:grid;gap:10px}.gameover-view-tabs{display:grid;gap:6px;grid-template-columns:repeat(2,minmax(0,1fr))}.gameover-view-tab{min-width:0;padding:9px 10px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-dim);cursor:pointer;font:inherit;font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.gameover-view-tab.selected{background:var(--surface);color:var(--text);border-color:#ffffff38}.gameover-section-title{color:var(--text);font-size:.88rem;font-weight:800;letter-spacing:.08em;margin:0;text-transform:uppercase}.gameover-quest-tabs{display:grid;gap:6px;grid-template-columns:repeat(5,minmax(0,1fr))}.gameover-quest-tab{display:grid;gap:2px;min-width:0;padding:7px 4px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font:inherit;text-align:center}.gameover-quest-tab.pass{border-color:#3b82f68c}.gameover-quest-tab.fail{border-color:#ef44448c}.gameover-quest-tab.empty{opacity:.55}.gameover-quest-tab.selected{background:var(--surface2);box-shadow:0 0 0 1px #ffffff24 inset}.gameover-quest-tab:disabled{cursor:not-allowed}.gameover-quest-tab span{color:var(--text-dim);font-size:.62rem;font-weight:800;letter-spacing:.08em}.gameover-quest-tab strong{color:var(--text);font-size:.74rem;line-height:1.1}.gameover-selected-quest{display:grid;gap:10px;padding:12px;background:var(--surface);border:1px solid var(--border);border-left-width:4px;border-radius:8px}.gameover-selected-quest.passed{border-left-color:var(--good)}.gameover-selected-quest.failed{border-left-color:var(--evil)}.gameover-selected-header{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.gameover-selected-header span{color:var(--text);font-size:1rem;font-weight:800}.gameover-selected-header strong{color:var(--text);font-size:.82rem;font-weight:800;text-align:right}.gameover-chip-list{display:flex;flex-wrap:wrap;gap:5px;min-width:0}.gameover-chip,.gameover-muted{display:inline-flex;max-width:100%;min-width:0;padding:3px 7px;border-radius:999px;font-size:.7rem;font-weight:650;overflow-wrap:anywhere}.gameover-chip{color:var(--text);background:var(--surface2);border:1px solid var(--border)}.gameover-muted{color:var(--text-dim);background:#ffffff08}.gameover-selected-team,.gameover-proposal-list{display:grid;gap:0}.gameover-selected-team>span,.gameover-detail-label,.gameover-selected-note>span,.gameover-vote-breakdown-row span{color:var(--text-dim);font-size:.64rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.gameover-proposal-row{display:grid;gap:7px;padding:10px 0;border-top:1px solid var(--border)}.gameover-detail-label+.gameover-proposal-row{margin-top:4px}.gameover-proposal-row.approved .gameover-proposal-header strong{color:var(--good)}.gameover-proposal-row.rejected .gameover-proposal-header strong{color:var(--evil)}.gameover-proposal-header,.gameover-vote-breakdown-row,.gameover-selected-note{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.gameover-proposal-header span{color:var(--text);font-size:.84rem;font-weight:750}.gameover-proposal-header strong,.gameover-vote-breakdown-row strong,.gameover-selected-note strong{color:var(--text);font-size:.74rem;font-weight:700;line-height:1.3;text-align:right}.gameover-vote-breakdown{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 10px}.gameover-vote-breakdown-row{display:grid;gap:2px;min-width:0}.gameover-vote-breakdown-row strong{text-align:left;overflow-wrap:anywhere}.gameover-vote-breakdown-row.approve-votes span{color:var(--good)}.gameover-vote-breakdown-row.deny-votes span{color:var(--evil)}.gameover-selected-note{padding-top:8px;border-top:1px solid var(--border)}.gameover-roles,.gameover-role-list{gap:8px}.gameover-role-item{display:flex;align-items:center;gap:12px;justify-content:space-between;padding:10px 14px;background:var(--surface);border-radius:6px;border-left:4px solid}.gameover-role-item.good-role{border-left-color:var(--good)}.gameover-role-item.evil-role{border-left-color:var(--evil)}.gameover-role-name{min-width:0;font-weight:500;overflow-wrap:anywhere}.gameover-role-role{flex:none;font-weight:600;text-align:right}.gameover-actions{display:flex;gap:10px;justify-content:center}.gameover-actions .btn{min-width:140px}@media(max-width:430px){.gameover-proposal-header,.gameover-vote-breakdown-row,.gameover-selected-note{align-items:flex-start;flex-direction:column;gap:3px}.gameover-proposal-header strong,.gameover-vote-breakdown-row strong,.gameover-selected-note strong{text-align:left}}.status-banner-spectator{background:var(--surface2);color:var(--text-dim);padding:10px;font-size:.95rem;z-index:110}.vote-result-table{width:100%;table-layout:fixed;border-collapse:collapse;margin-bottom:8px;font-weight:500}.vote-result-table th{width:50%;font-weight:600;font-size:.85rem;padding:6px 20px;border-bottom:1px solid rgba(255,255,255,.15);text-align:center;color:var(--text)}.vote-result-table td{padding:4px 20px;text-align:center;word-break:normal;overflow-wrap:normal;white-space:nowrap}.vote-result-table td.vote-col-approve{color:var(--success);text-align:center}.vote-result-table td.vote-col-reject{color:var(--danger);text-align:center}.vote-result-verdict{font-weight:700;font-size:1.1rem;margin-bottom:12px}.vote-result-verdict.approved{color:var(--success)}.vote-result-verdict.rejected{color:var(--danger)}.inline-vote-result{background:var(--surface);border-radius:8px;padding:16px;margin:0 auto 12px;width:fit-content;min-width:min(100%,300px);max-width:100%;overflow-x:auto;text-align:center}.inline-vote-result .vote-result-table{width:auto;min-width:100%;table-layout:auto;margin-bottom:8px}.inline-vote-result .vote-result-table th,.inline-vote-result .vote-result-table td{padding-left:12px;padding-right:12px}.inline-vote-result-dismiss{margin-top:12px}.quest-result-cards{display:flex;justify-content:center;gap:16px;margin:0}.quest-result-card{padding:12px 20px;border-radius:6px;font-weight:700;font-size:1.2rem}.qrc-success{background:var(--success);color:#fff}.qrc-fail{background:var(--evil);color:#fff}.qrc-magic{background:#78350f;color:#fbbf24}.watch-selection{display:grid;gap:16px;padding:1rem 0;text-align:center}.watch-selection-title{color:var(--text);font-size:1rem;font-weight:700}.watch-target-list{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.watch-target-button,.watch-target-chip{border-radius:8px;padding:10px 14px;font-weight:700}.watch-target-button{border:1px solid rgba(20,184,166,.55);background:#14b8a629;color:#ccfbf1}.watch-target-button:hover,.watch-target-button:focus-visible{background:#14b8a647}.watch-target-button.selected{border-color:var(--good);background:#3b82f638}.watch-target-chip{background:#ffffff14;color:var(--text-dim)}.expansion-panel{display:grid;gap:12px;padding:12px 0;text-align:left}.expansion-panel-title{color:var(--text);font-size:1rem;font-weight:800;text-align:center}.expansion-panel-status{color:var(--text-dim);font-size:.86rem;font-weight:600;line-height:1.35;text-align:center}.expansion-choice-list{display:grid;gap:8px}.expansion-choice-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;width:100%;min-height:46px;padding:10px 12px;border:2px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);text-align:left}.expansion-choice-row:not(:disabled):hover,.expansion-choice-row:not(:disabled):focus-visible{border-color:#14b8a6bf;background:#14b8a61f}.expansion-choice-row.selected{border-color:var(--good);background:#3b82f62e}.expansion-choice-row:disabled{opacity:.58;cursor:not-allowed}.expansion-choice-name,.expansion-choice-meta{min-width:0;overflow-wrap:anywhere;line-height:1.2}.expansion-choice-name{font-size:.92rem;font-weight:800}.expansion-choice-meta{color:var(--text-dim);font-size:.78rem;font-weight:700;text-align:right}.expansion-footer-actions{display:flex;gap:10px;width:100%}.expansion-footer-actions .btn{flex:1}@media(max-width:420px){.expansion-choice-row{grid-template-columns:1fr;gap:4px}.expansion-choice-meta{text-align:left}.expansion-footer-actions{flex-direction:column}}.plot-card-window{gap:12px;padding:.75rem 0}.plot-card-window>.watch-selection-title{font-size:.95rem}.plot-card-notices{display:grid;gap:6px;justify-items:center}.plot-card-notice{max-width:100%;padding:6px 10px;border-radius:6px;background:#ffffff14;color:var(--text-dim);font-size:.82rem;font-weight:700;line-height:1.25}.plot-card-action-stack{display:grid;gap:10px}.plot-card-action-row{display:grid;gap:8px;padding:12px;border:1px solid rgba(20,184,166,.32);border-radius:8px;background:#14b8a614}.plot-card-action-title{color:var(--text);font-size:.9rem;font-weight:800;line-height:1.25;text-align:center}.plot-card-button-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.plot-card-action-row .watch-target-button{min-height:44px;padding:8px 12px;font-size:.86rem;line-height:1.2}.plot-card-primary-action{justify-self:center;min-width:min(100%,220px)}.quest-reveal{text-align:center;padding:1rem 0}.quest-reveal-title{font-size:1.2rem;font-weight:600;margin-bottom:1.2rem;color:var(--text)}.quest-reveal-cards{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem}.reveal-card{width:80px;height:110px;perspective:600px}.reveal-card .card-inner{position:relative;width:100%;height:100%;transition:transform .6s ease;transform-style:preserve-3d}.reveal-card.revealed .card-inner{transform:rotateY(180deg)}.reveal-card .card-face{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;backface-visibility:hidden;border-radius:6px;font-weight:700;font-size:.9rem}.reveal-card .card-back{background:#334155;color:#94a3b8;border:2px solid #475569;font-size:1.5rem}.reveal-card .card-front{transform:rotateY(180deg)}.reveal-card.card-success .card-front{background:#166534;color:#4ade80;border:2px solid #22c55e}.reveal-card.card-fail .card-front{background:#7f1d1d;color:#f87171;border:2px solid #ef4444}.reveal-card.card-message-success .card-front{background:#0c4a6e;color:#7dd3fc;border:2px solid #0ea5e9}.reveal-card.card-message-fail .card-front{background:#4c1d95;color:#c4b5fd;border:2px solid #7c3aed}.reveal-card.card-magic .card-front{background:#78350f;color:#fbbf24;border:2px solid #d97706}.reveal-card.card-rogue-success .card-front{background:#064e3b;color:#6ee7b7;border:2px solid #10b981}.reveal-card.card-rogue-fail .card-front{background:#881337;color:#fda4af;border:2px solid #e11d48}.waiting-text{color:#94a3b8;font-style:italic;margin-top:.5rem}@media(max-width:480px){html{font-size:18px}#screen-home h1{font-size:2.6rem}.room-header h2{font-size:1.1rem}.phase-banner{font-size:.95rem;padding:8px}.btn-change-name,.btn-leave-room{padding:8px 10px;font-size:.8rem}.change-name-inline input{font-size:.9rem}.game-player-row td:first-child{font-size:.85rem}.player-status-chip{font-size:.74rem;padding:3px 8px}}@media(max-width:360px){html{font-size:16px}.quest-circle{width:44px;height:44px;font-size:.95rem}.quest-board{gap:8px}.game-player-table th{font-size:.74rem;padding:0 10px 3px}.game-player-row td{padding:10px}.player-status-chip{font-size:.72rem;padding:3px 7px}.screen-footer .btn{min-height:52px;font-size:1rem}.role-card{padding:28px 16px}.role-name{font-size:1.6rem}.btn-change-name,.btn-leave-room{padding:6px 8px;font-size:.75rem}#app{padding:0 14px 164px}}.app-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;display:flex;align-items:center;justify-content:center;padding:20px}.app-overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b8}.app-overlay-sheet{position:relative;width:100%;max-width:var(--app-max-width);max-height:90dvh;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px 20px calc(20px + env(safe-area-inset-bottom,0px));box-shadow:0 24px 60px #000000b3;animation:overlay-rise .18s ease}.app-overlay-sheet-compact{max-width:420px}.app-overlay-sheet:focus{outline:none}.app-overlay-close{position:absolute;top:8px;right:8px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-dim);font-size:1.6rem;line-height:1;cursor:pointer;border-radius:8px}.app-overlay-close:hover{color:var(--text)}@keyframes overlay-rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:560px){.app-overlay{align-items:flex-end;padding:0}.app-overlay-sheet{max-width:100%;max-height:88dvh;border-radius:16px 16px 0 0;animation:sheet-up .2s ease}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}}@media(prefers-reduced-motion:reduce){.app-overlay-sheet{animation:none}}.role-explain{position:absolute;top:8px;right:8px;margin:0}.role-explain-summary{font-size:.95rem;line-height:1.5;color:var(--text)}.role-explain-info{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:none;border:none;border-radius:50%;color:var(--text-dim);cursor:pointer;transition:color .15s ease,background-color .15s ease}.role-explain-info svg{width:22px;height:22px}.role-explain-info:hover,.role-explain-info:focus-visible{color:var(--text);background:#ffffff0f}.role-popover-body .role-explain-head,.role-explain-head{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding-right:44px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}.role-explain-name{font-size:1.35rem;font-weight:700;line-height:1.1;color:var(--text)}.role-explain-team{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.role-explain-team.good{color:var(--good)}.role-explain-team.evil{color:var(--evil)}
