:root,[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--color-bg:#0f0f23;--color-bg-2:#14142b;--color-surface:#1b1b30;--color-surface-2:#27273b;--color-surface-3:#303049;--color-line:#312e81;--color-line-soft:#2a2a44;--color-text:#f8fafc;--color-text-muted:#a5a8c2;--color-text-dim:#7d8099;--color-primary:#4338ca;--color-primary-hover:#5b50e0;--color-on-primary:#fff;--color-secondary:#312e81;--color-on-secondary:#fff;--color-accent:#ca8a04;--color-accent-hover:#eab308;--color-on-accent:#1a1303;--color-accent-soft:#ca8a0429;--color-accent-ring:#eab308bf;--color-success:#22c55e;--color-success-soft:#22c55e2e;--color-warn:#f59e0b;--color-warn-soft:#f59e0b2e;--color-danger:#ef4444;--color-danger-soft:#ef44442e;--color-info:#60a5fa;--color-info-soft:#60a5fa29;--color-surface-soft:#ffffff0a;--color-surface-hover:#ffffff14;--color-suspect:#f59e0b;--color-suspect-strong:#fbbf24;--color-suspect-soft:#f59e0b2e;--color-clue-tint:#f59e0b12;--color-clue-edge:#f59e0b5c;--color-means-tint:#60a5fa12;--color-means-edge:#60a5fa5c;--support:#a78bfa;--shadow-1:0 1px 0 #0006, 0 2px 8px #00000040;--shadow-2:0 8px 24px #00000073;--shadow-3:0 24px 64px #0009;--shadow:var(--shadow-2);--ring-focus:0 0 0 3px var(--color-bg), 0 0 0 5px var(--color-accent-ring);--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-xs:4px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-pill:999px;--font-sans:var(--font-manrope), ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display:var(--font-lora), Georgia, "Times New Roman", serif;--font-mono:var(--font-gl-mono), ui-monospace, "SFMono-Regular", Menlo, monospace;--font-gl-display:var(--font-lora), Georgia, "Times New Roman", serif;--font-gl-body:var(--font-lora), Georgia, "Times New Roman", serif;--font-xs:.75rem;--font-sm:.875rem;--font-md:1rem;--font-lg:1.125rem;--font-xl:1.375rem;--font-2xl:1.75rem;--font-3xl:2.25rem;--font-4xl:3rem;--leading-tight:1.15;--leading-snug:1.3;--leading-normal:1.5;--leading-relaxed:1.7;--z-base:0;--z-sticky:50;--z-overlay:80;--z-modal:100;--z-toast:120;--z-debug:9999;--easing-out:cubic-bezier(.22, 1, .36, 1);--easing-in:cubic-bezier(.55, 0, .65, .45);--duration-fast:.14s;--duration-base:.22s;--duration-slow:.32s;--gl-bg-0:#0a0805;--gl-bg-1:#0f0c08;--gl-bg-2:#14110a;--gl-bg-3:#1a160d;--gl-surface:#f5e6c40a;--gl-surface-hover:#f5e6c414;--gl-line:#c9a0632e;--gl-line-strong:#c9a0635c;--gl-paper:#f5e6c4;--gl-paper-dim:#d8c89a;--gl-paper-soft:#a89478;--gl-muted:#7a6c52;--gl-gold:#c9a063;--gl-gold-bright:#e0bc7a;--gl-gold-soft:#c9a06326;--gl-rust:#8a3320;--gl-rust-bright:#a64428;--gl-green:#7da06b;--gl-amber:#e0a847;--gl-red:#c46b6b;--gl-ink:#1a130a;--gl-r-1:2px;--gl-r-2:4px;--gl-r-3:6px;--gl-r-4:8px;--gl-r-5:12px;--gl-sh-1:0 1px 0 #00000080, 0 2px 6px #0000004d;--gl-sh-2:0 6px 20px #00000073;--gl-sh-3:0 18px 50px #0009;--gl-sh-glow:0 0 0 3px #c9a06366, 0 0 24px #c9a06340;--gl-easing-out:cubic-bezier(.2, .7, .3, 1);--gl-easing-in:cubic-bezier(.5, 0, .7, .3);--gl-easing-spring:cubic-bezier(.34, 1.56, .64, 1)}.gl-display{font-family:var(--font-gl-display), serif;font-style:italic;font-weight:600}.gl-body{font-family:var(--font-gl-body), serif}.gl-mono{font-family:var(--font-gl-mono), monospace;letter-spacing:.02em;font-variant-numeric:tabular-nums}[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--color-bg:#efeae0;--color-bg-2:#e3dccc;--color-surface:#fffdf6;--color-surface-2:#f0e8d8;--color-surface-3:#e3d7c0;--color-line:#cdbfaa;--color-line-soft:#ddd1bb;--color-text:#1a1410;--color-text-muted:#594833;--color-text-dim:#8c7d68;--color-primary:#1d1915;--color-primary-hover:#322820;--color-on-primary:#fffdf6;--color-secondary:#4e4740;--color-on-secondary:#fffdf6;--color-accent:#c2410c;--color-accent-hover:#ea580c;--color-on-accent:#fffaf0;--color-accent-soft:#c2410c24;--color-accent-ring:#c2410c8c;--color-success:#15803d;--color-success-soft:#15803d24;--color-warn:#a16207;--color-warn-soft:#a1620729;--color-danger:#a91b1b;--color-danger-soft:#a91b1b29;--color-info:#1d4ed8;--color-info-soft:#1d4ed824;--color-surface-soft:#0000000a;--color-surface-hover:#00000014;--color-suspect:#b45309;--color-suspect-strong:#d97706;--color-suspect-soft:#b4530929;--color-clue-tint:#c2410c1a;--color-clue-edge:#c2410c80;--color-means-tint:#1d4ed814;--color-means-edge:#1d4ed873;--support:#6d28d9;--shadow-1:0 1px 0 #1520230a, 0 4px 14px #1520230f;--shadow-2:0 12px 32px #1520231a;--shadow-3:0 28px 64px #15202329;--shadow:var(--shadow-2);--ring-focus:0 0 0 3px var(--color-bg), 0 0 0 5px var(--color-accent-ring)}*,:before,:after{box-sizing:border-box}html,body{min-height:100%}html{font-family:var(--font-sans)}body{background:radial-gradient(1200px 700px at 80% -10%, #4338ca2e, transparent 60%), radial-gradient(900px 600px at 0% 110%, #ca8a0412, transparent 55%), var(--color-bg);color:var(--color-text);font-family:var(--font-sans);font-size:var(--font-md);line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;margin:0}[data-theme=light] body{background:radial-gradient(1200px 700px at 80% -10%, #c2410c2e, transparent 60%), radial-gradient(900px 600px at 0% 110%, #1d4ed814, transparent 55%), var(--color-bg)}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer}button:disabled,input:disabled,select:disabled{cursor:not-allowed;opacity:.55}a{color:var(--color-accent)}a:hover{color:var(--color-accent-hover)}:focus-visible{box-shadow:var(--ring-focus);border-radius:var(--radius-xs);outline:none}::selection{background:var(--color-accent-soft);color:var(--color-text)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.01em;font-weight:700;line-height:var(--leading-tight);margin:0}h1{font-size:clamp(2.4rem,4vw,3.2rem)}h2{font-size:var(--font-xl)}h3{font-size:var(--font-lg)}p{margin:0}.eyebrow{margin:0 0 var(--space-3);color:var(--color-accent);font-family:var(--font-sans);font-size:var(--font-xs);letter-spacing:.12em;text-transform:uppercase;font-weight:700}.intro{max-width:38rem;margin:var(--space-4) 0 0;color:var(--color-text);font-size:var(--font-md);line-height:var(--leading-relaxed);opacity:.92}.tabular{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}button{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);min-height:40px;color:var(--color-text);padding:0 var(--space-4);transition:background-color var(--duration-fast) var(--easing-out), border-color var(--duration-fast) var(--easing-out), color var(--duration-fast) var(--easing-out), transform var(--duration-fast) var(--easing-out);font-weight:600}button:hover:not(:disabled){background:var(--color-surface-3)}button:active:not(:disabled){transform:translateY(1px)}.compact-action{min-height:36px;padding:0 var(--space-3);font-size:var(--font-sm)}.compact-icon-action{justify-content:center;align-items:center;gap:var(--space-2);display:inline-flex}input:not([type=checkbox]):not([type=radio]),select,textarea{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-md);color:var(--color-text);width:100%;min-height:44px;transition:border-color var(--duration-fast) var(--easing-out), box-shadow var(--duration-fast) var(--easing-out);padding:10px 12px}input[type=checkbox],input[type=radio]{appearance:none;background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface-2);border:1.5px solid var(--color-line);cursor:pointer;width:18px;min-width:18px;height:18px;min-height:18px;transition:background-color var(--duration-fast) var(--easing-out), border-color var(--duration-fast) var(--easing-out), box-shadow var(--duration-fast) var(--easing-out), transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1);flex:none;place-items:center;margin:0;display:inline-grid;position:relative;box-shadow:inset 0 1px 1px #0000002e}input[type=checkbox]{border-radius:var(--radius-xs)}input[type=radio]{border-radius:var(--radius-pill)}input[type=checkbox]:hover:not(:disabled),input[type=radio]:hover:not(:disabled){border-color:color-mix(in srgb, var(--color-accent) 50%, var(--color-line))}input[type=checkbox]:focus-visible,input[type=radio]:focus-visible{border-color:var(--color-accent);box-shadow:inset 0 1px 1px #0000002e, 0 0 0 3px var(--color-accent-soft);outline:none}input[type=checkbox]:checked,input[type=radio]:checked{background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 88%, #fff 12%), var(--color-accent));border-color:var(--color-accent);box-shadow:inset 0 1px #ffffff38,0 1px 2px #00000052}input[type=checkbox]:checked:after{content:"";filter:drop-shadow(0 1px #0000004d);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='3 8.5 7 12 13 4'/></svg>");background-position:50%;background-repeat:no-repeat;background-size:contain;width:10px;height:10px;animation:.22s cubic-bezier(.34,1.56,.64,1) checkbox-check-in}input[type=radio]:checked:after{content:"";background:var(--color-on-accent);border-radius:50%;width:7px;height:7px;animation:.22s cubic-bezier(.34,1.56,.64,1) checkbox-check-in;box-shadow:inset 0 1px #0000002e}input[type=checkbox]:disabled,input[type=radio]:disabled{opacity:.45;cursor:not-allowed}@keyframes checkbox-check-in{0%{opacity:0;transform:scale(.4)}60%{opacity:1;transform:scale(1.18)}to{transform:scale(1)}}@media (prefers-reduced-motion:reduce){input[type=checkbox]:checked:after,input[type=radio]:checked:after{animation:none}}input::placeholder,textarea::placeholder{color:var(--color-text-dim)}input:not([type=checkbox]):not([type=radio]):focus,select:focus,textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft);outline:none}.field{gap:var(--space-2);color:var(--color-text-muted);font-size:var(--font-sm);font-weight:600;display:grid}.field>input,.field>select,.field>textarea{color:var(--color-text)}.field-caption{margin-bottom:var(--space-2);color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;font-weight:700;display:block}.form-error{color:var(--color-danger);font-size:var(--font-sm);margin:0;font-weight:600}.app-shell{min-height:100vh}.home-shell{min-height:100vh;padding:var(--space-8);place-items:start center;display:grid}@media (max-width:760px){.home-shell{padding:var(--space-5)}}.home-shell--v3{min-height:100dvh;padding:max(clamp(20px, 4vw, 56px), env(safe-area-inset-top)) max(clamp(20px, 4vw, 56px), env(safe-area-inset-right)) max(clamp(20px, 4vw, 56px), env(safe-area-inset-bottom)) max(clamp(20px, 4vw, 56px), env(safe-area-inset-left));place-items:center;display:grid}@media (max-width:640px){.home-display{font-size:clamp(34px,9vw,48px)}.home-tagline{font-size:var(--font-sm)}.home-stats{gap:var(--space-4)}.home-stat strong{font-size:var(--font-xl)}.home-card{padding:var(--space-4)}.home-profile-strip{padding:var(--space-2) var(--space-3);grid-template-columns:56px minmax(0,1fr)}.home-avatar{width:56px;height:56px}.home-avatar__initial{font-size:calc(24px * var(--app-text-scale,1))}.home-join-input{font-size:var(--font-md);letter-spacing:.24em;padding:12px}}.home-stage{grid-template-columns:minmax(0,1.1fr) minmax(380px,.9fr);align-items:center;gap:clamp(28px,4vw,56px);width:min(1200px,100%);display:grid;position:relative}.home-stage:before{content:"";aspect-ratio:1;background:radial-gradient(circle, var(--color-accent-soft), transparent 65%);pointer-events:none;z-index:-1;width:56%;position:absolute;top:-20%;right:-10%}.home-stage:after{content:"";aspect-ratio:1;background:radial-gradient(circle, color-mix(in srgb, var(--color-primary) 30%, transparent), transparent 65%);pointer-events:none;z-index:-1;width:50%;position:absolute;bottom:-25%;left:-10%}@media (max-width:920px){.home-stage{gap:var(--space-6);grid-template-columns:minmax(0,1fr)}}.home-eyebrow{align-items:center;gap:var(--space-2);margin:0 0 var(--space-3);border:1px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-line));border-radius:var(--radius-pill);background:var(--color-accent-soft);color:var(--color-accent);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.12em;padding:6px 12px;font-weight:700;display:inline-flex}.home-brand{margin:0 0 var(--space-2);font-family:var(--font-display);font-size:var(--font-2xl);letter-spacing:-.01em;color:var(--color-text);font-weight:700;line-height:1}.home-display{margin:var(--space-2) 0 var(--space-4);font-family:var(--font-display);letter-spacing:-.025em;color:var(--color-text);font-size:clamp(40px,6vw,72px);font-weight:700;line-height:.95}.home-hero__accent{background:linear-gradient(135deg, var(--color-accent-hover), var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;position:relative}.home-hero__accent:after{content:"";background:linear-gradient(90deg, var(--color-accent-soft), transparent);z-index:-1;height:10px;position:absolute;bottom:6px;left:0;right:0;transform:skew(-12deg)}.home-tagline{margin:0 0 var(--space-6);max-width:520px;color:var(--color-text-muted);font-size:var(--font-md);line-height:var(--leading-relaxed)}.home-stats{gap:var(--space-6);flex-wrap:wrap;display:flex}.home-stat{border-left:2px solid var(--color-accent);padding-left:var(--space-3);gap:2px;display:grid}.home-stat strong{font-family:var(--font-display);font-size:var(--font-2xl);color:var(--color-accent);font-feature-settings:"tnum";line-height:1}.home-stat span{font-size:var(--font-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}.home-card{gap:var(--space-3);padding:var(--space-5);border:1px solid var(--color-line);border-radius:var(--radius-xl);background:linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 95%, var(--color-text) 5%), var(--color-surface));box-shadow:var(--shadow-2);display:grid;position:relative}.home-card:before{content:"";border-radius:var(--radius-xl);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 30%, transparent), transparent 40%);-webkit-mask-composite:xor;pointer-events:none;padding:1px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000 0 0),linear-gradient(#000 0 0);mask-image:linear-gradient(#000 0 0),linear-gradient(#000 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.home-card>*{position:relative}.home-game-picker{min-width:0;padding:var(--space-2);border:1px solid var(--color-line-soft);border-radius:var(--radius-md);background:var(--color-surface-2);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin:0;display:grid}.home-game-picker legend{padding:0 var(--space-1);color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;font-weight:700}.home-game-option{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface);min-width:0;min-height:78px;color:var(--color-text);cursor:pointer;transition:border-color var(--duration-fast) var(--easing-out), background-color var(--duration-fast) var(--easing-out), transform var(--duration-fast) var(--easing-out);align-content:center;gap:3px;padding:10px 12px;display:grid;position:relative}.home-game-option input{opacity:0;pointer-events:none;position:absolute}.home-game-option:hover{border-color:color-mix(in srgb, var(--color-accent) 45%, var(--color-line));transform:translateY(-1px)}.home-game-option--active{border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 16%, transparent), transparent 75%), var(--color-surface)}.home-game-option__title,.home-game-option__meta,.home-game-option__description{text-overflow:ellipsis;min-width:0;overflow:hidden}.home-game-option__title{font-family:var(--font-display);font-size:var(--font-md);white-space:nowrap;font-weight:700}.home-game-option__meta{color:var(--color-text-muted);font-size:var(--font-xs);white-space:nowrap}.home-game-option__description{color:color-mix(in srgb, var(--color-text-muted) 86%, var(--color-text));-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.72rem;line-height:1.25;display:-webkit-box}.home-profile-strip{gap:var(--space-3);padding:var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-line-soft);border-radius:var(--radius-md);grid-template-columns:64px minmax(0,1fr);align-items:center;display:grid}.home-avatar{border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--color-primary) 80%, #fff 20%), var(--color-primary));color:#fff;width:64px;height:64px;font-family:var(--font-display);cursor:pointer;box-shadow:0 0 0 2px var(--color-surface-2), 0 0 0 4px color-mix(in srgb, var(--color-primary) 40%, transparent), 0 4px 12px #0006;transition:transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1);border:0;justify-content:center;align-items:center;padding:0;font-weight:700;display:flex;position:relative;overflow:hidden}.home-avatar:hover:not(:disabled){transform:scale(1.05)}.home-avatar:disabled{opacity:.55;cursor:not-allowed}.home-avatar img{object-fit:cover;object-position:center;border-radius:inherit;width:100%;height:100%;display:block;position:absolute;inset:0}.home-avatar__initial{font-size:calc(28px * var(--app-text-scale,1));line-height:1}.home-avatar__input{display:none}.home-name-field{gap:2px;min-width:0;display:grid}.home-name-field span{font-size:var(--font-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.home-name-field input{border:0;border-bottom:2px solid var(--color-line);color:var(--color-text);font-family:var(--font-display);font-size:var(--font-lg);width:100%;transition:border-color var(--duration-fast) var(--easing-out);background:0 0;outline:none;padding:4px 0;font-weight:600}.home-name-field input:focus{border-bottom-color:var(--color-accent)}.home-name-field input::placeholder{color:var(--color-text-dim);font-style:italic}.home-name-field input:disabled{opacity:.55}.home-color-block{gap:var(--space-2);padding:var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-line-soft);border-radius:var(--radius-md);display:grid}.home-color-block__label{font-size:var(--font-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.home-cta{margin-top:var(--space-2)}.home-divider{gap:var(--space-3);margin:var(--space-1) 0;color:var(--color-text-dim);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.18em;grid-template-columns:1fr auto 1fr;align-items:center;display:grid}.home-divider:before,.home-divider:after{content:"";background:var(--color-line);height:1px}.home-divider span{padding:0 var(--space-2)}.home-join-field{display:block}.home-join-input{background:var(--color-surface-2);border:2px solid var(--color-line);width:100%;color:var(--color-text);font-family:var(--font-mono);font-size:var(--font-lg);text-align:center;letter-spacing:.3em;border-radius:var(--radius-md);text-transform:uppercase;transition:border-color var(--duration-fast) var(--easing-out), box-shadow var(--duration-fast) var(--easing-out);outline:none;padding:14px;font-weight:700}.home-join-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 4px var(--color-accent-soft)}.home-join-input::placeholder{color:var(--color-text-dim);letter-spacing:.3em}.home-join-input:disabled{opacity:.55}.visually-hidden{clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.room-shell{min-height:100dvh;padding:max(var(--space-5), env(safe-area-inset-top)) max(var(--space-5), env(safe-area-inset-right)) max(var(--space-5), env(safe-area-inset-bottom)) max(var(--space-5), env(safe-area-inset-left))}.room-shell--active-game{padding:max(var(--space-2), env(safe-area-inset-top)) max(4px, env(safe-area-inset-right)) max(var(--space-2), env(safe-area-inset-bottom)) max(4px, env(safe-area-inset-left))}.room-shell--fullbleed{padding:0;overflow:hidden}.room-shell--fullbleed .room-alert{top:max(12px, env(safe-area-inset-top));z-index:var(--z-toast);width:min(640px,100vw - 24px);position:fixed;left:50%;transform:translate(-50%)}.room-shell--fullbleed .debug-room-tools{top:max(12px, env(safe-area-inset-top));left:max(12px, env(safe-area-inset-left));z-index:var(--z-debug);width:min(360px,100vw - 24px);max-height:calc(100dvh - 24px);margin:0;position:fixed;overflow:auto}@media (max-width:620px){.room-shell{padding:max(var(--space-3), env(safe-area-inset-top)) max(var(--space-3), env(safe-area-inset-right)) max(var(--space-3), env(safe-area-inset-bottom)) max(var(--space-3), env(safe-area-inset-left))}.room-shell--fullbleed{padding:0}}.room-header{justify-content:space-between;align-items:center;gap:var(--space-5);max-width:1440px;margin:0 auto var(--space-3);display:flex}.room-header h1{font-size:clamp(2rem,3.4vw,2.6rem)}.room-alert{max-width:980px;margin:0 auto var(--space-3)}.debug-room-tools{width:min(100%,1480px);margin:0 auto var(--space-2);border:1.5px dashed color-mix(in srgb, var(--color-accent) 55%, var(--color-line));border-radius:var(--radius-md);background:repeating-linear-gradient(45deg, color-mix(in srgb, var(--color-accent) 4%, transparent) 0 6px, transparent 6px 14px), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), color-mix(in srgb, var(--color-accent-soft) 40%, var(--color-surface));box-shadow:0 1px 2px #00000029}.debug-room-tools summary{justify-content:space-between;align-items:center;gap:var(--space-2);cursor:pointer;min-height:36px;color:var(--color-text);font-size:var(--font-sm);border-radius:var(--radius-md);transition:background-color var(--duration-fast) var(--easing-out);padding:4px 12px;font-weight:800;list-style:none;display:flex}.debug-room-tools summary:hover{background:color-mix(in srgb, var(--color-accent) 8%, transparent)}.debug-room-tools summary::-webkit-details-marker{display:none}.debug-room-tools summary span{color:var(--color-accent);text-transform:uppercase;letter-spacing:.14em;font-family:var(--font-mono);font-size:calc(11px * var(--app-text-scale,1));align-items:center;gap:4px;display:inline-flex}.debug-room-tools summary span:before{content:"";background:var(--color-accent);width:7px;height:7px;box-shadow:0 0 0 2px color-mix(in srgb, var(--color-accent) 22%, transparent), 0 0 8px color-mix(in srgb, var(--color-accent) 50%, transparent);border-radius:50%}.debug-room-tools summary strong{color:var(--color-text-2,var(--color-text-muted));font-size:var(--font-xs);font-weight:700;font-family:var(--font-display);letter-spacing:-.005em}.debug-room-tools__body{gap:var(--space-2);padding:0 var(--space-2) var(--space-2);grid-template-columns:minmax(360px,auto) 1fr;display:grid}.debug-room-tools--game{width:min(100%,1180px)}.debug-room-tools--game .debug-room-tools__body{grid-template-columns:1fr}.debug-room-tools--game .debug-room-tools__actions{justify-content:flex-start}.debug-room-tools__actions{align-content:start;gap:var(--space-2);flex-wrap:wrap;display:flex}.debug-player-switcher{gap:var(--space-1);flex-wrap:wrap;display:flex}.debug-player-switcher__item{align-items:center;gap:var(--space-1);border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface);min-width:104px;min-height:32px;color:var(--color-text);padding:var(--space-1) var(--space-2);text-align:left;cursor:pointer;grid-template-columns:20px minmax(42px,1fr) 14px;display:grid}.debug-player-switcher__item--active{border-color:var(--debug-player-color);box-shadow:inset 4px 0 0 var(--debug-player-color)}.debug-player-switcher__avatar{background:var(--debug-player-color);color:#fff;border-radius:999px;place-items:center;width:20px;height:20px;font-weight:900;line-height:1;display:grid}.debug-player-switcher__item strong,.debug-player-switcher__item small{display:block}.debug-player-switcher__item small{display:none}.room-panel{border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface);max-width:980px;margin:0 auto}.room-shell--loading{place-items:center;min-height:100dvh;display:grid}.room-loading{justify-items:center;gap:var(--space-4);color:var(--color-text-2,var(--color-text-muted));padding:var(--space-8) var(--space-6);border:1px solid var(--color-line);border-radius:var(--radius-xl);background:radial-gradient(420px 220px at 50% 0%, var(--color-accent-soft), transparent 60%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface);box-shadow:var(--shadow-2);text-align:center;max-width:420px;animation:room-loading-rise var(--duration-slow) cubic-bezier(.34, 1.56, .64, 1);display:grid}.room-loading p{font-size:var(--font-md);margin:0;font-weight:600}.room-loading__spinner{border:3px solid color-mix(in srgb, var(--color-accent) 25%, var(--color-line));border-top-color:var(--color-accent-hover);border-right-color:var(--color-accent);width:40px;height:40px;filter:drop-shadow(0 0 12px var(--color-accent-soft));border-radius:50%;animation:.9s cubic-bezier(.4,0,.6,1) infinite spin;display:inline-block}@keyframes room-loading-rise{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.room-loading{animation:none}.room-loading__spinner{border-top-color:var(--color-accent-hover);border-right-color:var(--color-accent);animation:none}}@keyframes spin{to{transform:rotate(360deg)}}.room-error{max-width:520px;margin:var(--space-12) auto;gap:var(--space-3);border:1px solid color-mix(in srgb, var(--color-danger) 60%, var(--color-line));border-radius:var(--radius-xl);background:radial-gradient(400px 200px at 50% 0%, color-mix(in srgb, var(--color-danger) 18%, transparent), transparent 60%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface);color:var(--color-text);padding:var(--space-6);text-align:center;box-shadow:var(--shadow-2), 0 0 32px color-mix(in srgb, var(--color-danger) 18%, transparent);display:grid}.room-error__icon{border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--color-danger) 88%, #fff 12%), var(--color-danger));color:#fff;width:56px;height:56px;box-shadow:inset 0 1px 0 #ffffff38, 0 1px 3px #00000052, 0 6px 18px var(--color-danger-soft);place-items:center;margin:0 auto;display:grid}.room-error h2{font-family:var(--font-display);font-size:var(--font-xl);letter-spacing:-.01em;color:var(--color-danger);margin:0}.room-error p{color:var(--color-text-2,var(--color-text-muted));line-height:var(--leading-relaxed);margin:0}.room-alert{margin:0 0 var(--space-3);border:1px solid color-mix(in srgb, var(--color-danger) 50%, var(--color-line));border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-danger) 12%, transparent), transparent 60%), var(--color-surface-2);color:var(--color-danger);font-size:var(--font-sm);letter-spacing:-.005em;align-items:center;gap:8px;padding:8px 14px;font-weight:700;animation:.24s cubic-bezier(.34,1.56,.64,1) room-alert-rise;display:inline-flex;box-shadow:inset 0 1px #ffffff0f,0 1px 3px #0000002e}.room-alert:before{content:"";background:var(--color-danger);width:8px;height:8px;box-shadow:0 0 0 2px color-mix(in srgb, var(--color-danger) 30%, transparent);border-radius:50%;flex:none}.room-alert--info{border-color:color-mix(in srgb, var(--color-info) 50%, var(--color-line));background:linear-gradient(180deg, color-mix(in srgb, var(--color-info) 12%, transparent), transparent 60%), var(--color-surface-2);color:var(--color-info)}.room-alert--info:before{background:var(--color-info);box-shadow:0 0 0 2px color-mix(in srgb, var(--color-info) 30%, transparent);animation:1.4s ease-in-out infinite room-alert-info-pulse}@keyframes room-alert-info-pulse{0%,to{opacity:1}50%{opacity:.45}}@keyframes room-alert-rise{0%{opacity:0;transform:translateY(-4px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.room-alert,.room-alert--info:before{animation:none}}.preferred-color-picker{border:0;min-width:0;margin:0;padding:0}.preferred-color-picker legend{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.preferred-color-grid{gap:var(--space-2);flex-wrap:wrap;display:flex}.preferred-color{cursor:pointer;place-items:center;width:44px;height:44px;display:grid;position:relative}.preferred-color input{opacity:0;cursor:pointer;background:0 0;border:0;width:100%;height:100%;min-height:0;margin:0;padding:0;position:absolute;inset:0}.preferred-color span{border:2px solid var(--color-surface);border-radius:var(--radius-pill);background:radial-gradient(circle at 30% 28%, color-mix(in srgb, var(--swatch-color) 75%, #fff 25%), var(--swatch-color) 70%);width:32px;height:32px;box-shadow:inset 0 1px 0 #ffffff2e, 0 0 0 1px var(--color-line), 0 1px 3px #00000052;transition:transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1), box-shadow var(--duration-fast) var(--easing-out)}.preferred-color:hover span{box-shadow:inset 0 1px 0 #ffffff38, 0 0 0 1px var(--color-line), 0 4px 10px color-mix(in srgb, var(--swatch-color) 32%, transparent);transform:scale(1.12)}.preferred-color--selected span{box-shadow:inset 0 1px 0 #ffffff38, 0 0 0 2px var(--color-bg), 0 0 0 5px var(--color-accent), 0 0 12px color-mix(in srgb, var(--swatch-color) 50%, transparent)}.preferred-color--occupied span{opacity:.45;filter:grayscale(.35)}.preferred-color--occupied:after{content:"";border-radius:var(--radius-pill);background:var(--color-text-muted);width:30px;height:2px;box-shadow:0 0 0 2px color-mix(in srgb, var(--color-bg) 80%, transparent);position:absolute;transform:rotate(-34deg)}.preferred-color input:focus-visible+span{box-shadow:inset 0 1px 0 #ffffff38, 0 0 0 2px var(--color-bg), 0 0 0 5px var(--color-accent-ring)}@media (prefers-reduced-motion:reduce){.preferred-color:hover span{transform:none}}.forensic-event-card{background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 4%, transparent), transparent 55%), var(--color-surface-2);border:2px solid var(--color-accent);border-radius:var(--radius-md);box-shadow:var(--shadow-2), 0 0 24px var(--color-accent-soft);grid-template-rows:auto 1fr auto;margin:0;animation:.32s cubic-bezier(.34,1.56,.64,1) forensic-event-rise;display:grid;position:relative;overflow:hidden}@keyframes forensic-event-rise{0%{opacity:0;transform:translateY(6px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.forensic-event-card__title{background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 92%, #fff 8%), var(--color-accent));color:var(--color-on-accent);text-align:left;font-family:var(--font-display);font-size:var(--font-md);letter-spacing:-.005em;border-bottom:1px solid var(--color-accent);gap:2px;padding:8px 14px;font-weight:700;line-height:1.2;display:grid;box-shadow:inset 0 1px #ffffff38}.forensic-event-card__kind{font-family:var(--font-sans);font-size:calc(9px * var(--app-text-scale,1));text-transform:uppercase;letter-spacing:.2em;opacity:.78;font-weight:800}.forensic-event-card__art{background:radial-gradient(140px 80px at 50% 50%, var(--color-accent-soft), transparent 65%);height:120px;color:var(--color-accent-hover);place-items:center;padding:8px;display:grid}.forensic-event-card__art img{object-fit:contain;max-width:100%;max-height:100%}.forensic-event-card__art--blank{color:var(--color-accent-hover);opacity:.55}.forensic-event-card__description{background:color-mix(in srgb, var(--color-accent) 6%, var(--color-surface-2));color:var(--color-text);font-size:var(--font-xs);line-height:var(--leading-snug);border-top:1px solid color-mix(in srgb, var(--color-accent) 28%, var(--color-line-soft));margin:0;padding:10px 14px}@media (prefers-reduced-motion:reduce){.forensic-event-card{animation:none}}.profile-gate{gap:var(--space-3);margin:var(--space-5) auto;max-width:480px;padding:var(--space-4) var(--space-5);border:1px solid color-mix(in srgb, var(--color-warn) 50%, var(--color-line));border-radius:var(--radius-lg);background:radial-gradient(360px 180px at 0% 0%, color-mix(in srgb, var(--color-warn) 16%, transparent), transparent 60%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-2), 0 0 24px color-mix(in srgb, var(--color-warn) 14%, transparent);grid-template-columns:44px minmax(0,1fr);align-items:center;display:grid}.profile-gate__icon{border-radius:var(--radius-md);background:linear-gradient(135deg, color-mix(in srgb, var(--color-warn) 88%, #fff 12%), var(--color-warn));color:#1a1303;place-items:center;width:44px;height:44px;display:grid;box-shadow:inset 0 1px #ffffff38,0 1px 3px #00000052}.profile-gate__copy{gap:4px;min-width:0;display:grid}.profile-gate__title{font-family:var(--font-display);font-size:var(--font-lg);letter-spacing:-.005em;color:var(--color-text);margin:0;font-weight:700}.profile-gate__hint{font-size:var(--font-sm);line-height:var(--leading-snug);color:var(--color-text-2,var(--color-text-muted));margin:0}.color-picker-hint{margin:var(--space-2) 0 0;color:var(--color-text-muted);font-size:var(--font-sm)}.lobby-layout{gap:var(--space-3);grid-template-columns:minmax(0,1fr) minmax(300px,360px);align-items:start;width:min(100%,1480px);margin:0 auto;display:grid}.lobby-main,.lobby-settings{border:1px solid var(--color-line);border-radius:var(--radius-lg);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 30%), var(--color-surface);box-shadow:var(--shadow-1);align-content:start;gap:6px;padding:10px;display:grid}.ghost-letters-settings__in-game-hint{border:1px dashed color-mix(in srgb, var(--color-accent) 50%, var(--color-line));border-radius:var(--radius-md);background:color-mix(in srgb, var(--color-accent) 8%, transparent);color:var(--color-text-soft);font-size:calc(12px * var(--app-text-scale,1));margin:0 0 6px;padding:8px 10px;line-height:1.4}.lobby-command-bar{gap:var(--space-3);border:1px solid color-mix(in srgb, var(--color-accent) 25%, var(--color-line));border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 40%), var(--color-surface-2);box-shadow:var(--shadow-1);grid-template-columns:minmax(260px,1fr) auto;align-items:center;padding:10px 14px;display:grid}.lobby-code{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.lobby-code span{color:var(--color-text-muted);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.lobby-code strong{font-family:var(--font-mono);letter-spacing:.18em;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;background:var(--color-accent-soft);color:var(--color-accent);border-radius:var(--radius-sm);border:1px solid color-mix(in srgb, var(--color-accent) 50%, transparent);padding:4px 12px;font-size:clamp(1.15rem,1.45vw,1.4rem);font-weight:700}.ready-toggle{align-items:center;gap:var(--space-2);color:var(--color-text);font-weight:600;display:flex}.ready-toggle--command{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-3);min-height:32px;color:var(--color-text);white-space:nowrap;flex:none;padding:0 10px}.lobby-command-actions{justify-content:flex-end;align-items:center;gap:var(--space-2);flex-wrap:wrap;min-width:0;display:flex}.ready-toggle--explained{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-2);align-items:flex-start;padding:8px 10px}.ready-toggle--explained span{gap:var(--space-1);display:grid}.ready-toggle--explained small{display:none}.lobby-start{justify-content:flex-end;align-items:center;gap:var(--space-2);min-width:0;display:flex}.lobby-start button{border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 88%, #fff 12%), var(--color-accent));min-width:136px;min-height:38px;color:var(--color-on-accent);letter-spacing:-.005em;box-shadow:inset 0 1px 0 #ffffff38, 0 1px 2px #00000052, 0 6px 16px var(--color-accent-soft);transition:transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1), box-shadow var(--duration-fast) var(--easing-out);font-weight:800}.lobby-start button:hover:not(:disabled){background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 96%, #fff 4%), var(--color-accent-hover));border-color:var(--color-accent-hover);box-shadow:inset 0 1px 0 #ffffff42, 0 4px 12px #0000005c, 0 14px 32px color-mix(in srgb, var(--color-accent) 32%, transparent);transform:translateY(-1px)}.lobby-start button:disabled{background:var(--color-surface-3);border-color:var(--color-line);color:var(--color-text-muted);box-shadow:none;opacity:.7;cursor:not-allowed}.start-blocker{border:1px solid color-mix(in srgb, var(--color-warn) 50%, var(--color-line));border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-warn) 14%, transparent), transparent 60%), var(--color-surface-2);max-width:220px;color:var(--color-warn);font-size:var(--font-xs);letter-spacing:.02em;text-align:left;overflow-wrap:anywhere;align-items:center;gap:6px;margin:0;padding:6px 10px;font-weight:700;display:inline-flex;box-shadow:0 1px 2px #00000029}.start-blocker:before{content:"";background:var(--color-warn);width:6px;height:6px;box-shadow:0 0 0 2px color-mix(in srgb, var(--color-warn) 30%, transparent);border-radius:50%;flex:none}.start-blocker--ok{border-color:color-mix(in srgb, var(--color-success) 50%, var(--color-line));background:linear-gradient(180deg, color-mix(in srgb, var(--color-success) 14%, transparent), transparent 60%), var(--color-surface-2);color:var(--color-success)}.start-blocker--ok:before{background:var(--color-success);box-shadow:0 0 0 2px color-mix(in srgb, var(--color-success) 30%, transparent)}@media (prefers-reduced-motion:reduce){.lobby-start button:hover:not(:disabled){transform:none}}.lobby-profile-editor{gap:var(--space-3);border:1px solid var(--color-line);border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface-2);box-shadow:var(--shadow-1);grid-template-columns:56px minmax(220px,340px) minmax(320px,1fr);align-items:center;padding:10px 12px;display:grid}.lobby-avatar-picker{place-items:center;min-width:0;display:grid}.lobby-avatar-picker__button{border:1px dashed color-mix(in srgb, var(--color-accent) 35%, var(--color-line));border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface);width:56px;height:56px;color:var(--color-text-muted);cursor:pointer;transition:border-color var(--duration-fast) var(--easing-out), color var(--duration-fast) var(--easing-out), transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1), box-shadow var(--duration-fast) var(--easing-out);place-items:center;padding:0;line-height:0;display:grid;overflow:hidden}.lobby-avatar-picker__button--image{border-style:solid;border-color:color-mix(in srgb, var(--color-accent) 75%, var(--color-line));background:var(--color-surface-3);box-shadow:0 0 0 2px var(--color-surface-2), 0 0 0 4px color-mix(in srgb, var(--color-accent) 35%, transparent), 0 4px 12px var(--color-accent-soft)}.lobby-avatar-picker__button:hover{border-color:var(--color-accent);color:var(--color-accent);box-shadow:0 4px 12px var(--color-accent-soft);transform:scale(1.04)}@media (prefers-reduced-motion:reduce){.lobby-avatar-picker__button:hover{transform:none}}.lobby-avatar-picker__button svg{display:block}.lobby-avatar-picker__button img,.seat-avatar img,.player-avatar img{object-fit:cover;width:100%;height:100%;display:block}.lobby-avatar-picker__input{display:none}.lobby-avatar-error{color:var(--color-danger);font-size:var(--font-xs);grid-column:1/-1;margin:-2px 0 0}.lobby-profile-editor .field{gap:4px}.lobby-profile-editor .field>span,.lobby-profile-editor .field>label{font-size:var(--font-xs)}.lobby-profile-editor .field input{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface);min-height:32px;padding:6px 9px}.lobby-profile-name__control{grid-template-columns:minmax(0,1fr) 32px;align-items:center;gap:6px;display:grid}.lobby-profile-name__control .lobby-profile-name__confirm{width:32px;height:32px}.lobby-profile-editor .preferred-color-picker{flex-wrap:wrap;grid-column:1/-1;align-items:center;gap:6px 8px;min-width:0;display:flex}.lobby-profile-editor .preferred-color-picker legend{clip:auto;white-space:nowrap;width:auto;height:auto;color:var(--color-text-muted);font-size:var(--font-xs);flex:none;font-weight:700;position:static;overflow:visible}.lobby-profile-editor .preferred-color-grid{gap:var(--space-1);flex-wrap:wrap;flex:240px;min-width:0;display:flex}.lobby-profile-editor .preferred-color{width:24px;height:24px}.lobby-profile-editor .preferred-color span{width:17px;height:17px}.lobby-profile-editor .preferred-color--occupied:after{width:20px}.lobby-profile-editor .color-picker-hint{display:none}.start-checklist{border:1px solid var(--color-line);border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 40%), var(--color-surface-2);box-shadow:var(--shadow-1);flex-wrap:wrap;gap:6px;padding:8px 10px;display:flex}.start-checklist--top{width:min(100%,1480px);margin:0 auto var(--space-2);justify-content:flex-end;padding:8px 12px}.start-checklist .checkline{border-radius:var(--radius-pill);background:var(--color-surface-3);border:1px solid var(--color-line);padding:4px 10px}.start-checklist .checkline--ok{background:color-mix(in srgb, var(--color-success) 12%, var(--color-surface-3));border-color:color-mix(in srgb, var(--color-success) 35%, var(--color-line))}@media (max-width:640px){.lobby-command-bar{gap:var(--space-2);grid-template-columns:minmax(0,1fr);padding:10px}.lobby-code{justify-content:space-between}.seat-card{grid-template-columns:44px minmax(0,1fr) auto;min-height:64px;padding:8px}.seat-avatar{width:44px;height:44px;font-size:var(--font-md)}.start-checklist--top{justify-content:stretch}.start-checklist--top .checkline{flex:auto;justify-content:center}}.checkline{color:var(--color-text-muted);font-size:var(--font-xs);align-items:center;gap:4px;margin:0;font-weight:600;display:flex}.checkline svg{color:var(--color-warn);flex:none}.checkline--ok,.checkline--ok svg{color:var(--color-success)}.seat-grid{gap:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:start;display:grid}.seat-card{--seat-color:var(--color-primary);gap:var(--space-2);border:1px solid var(--color-line);border-left:3px solid var(--seat-color);border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--seat-color) 5%, transparent), transparent 50%), var(--color-surface-2);min-height:82px;box-shadow:var(--shadow-1);transition:transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1), box-shadow var(--duration-fast) var(--easing-out), border-color var(--duration-fast) var(--easing-out);grid-template-columns:56px minmax(0,1fr) auto;align-items:center;padding:10px;display:grid}.seat-card:hover{box-shadow:var(--shadow-2);transform:translateY(-1px)}.seat-card:has(.ready-chip--ok){border-color:color-mix(in srgb, var(--color-success) 50%, var(--color-line));box-shadow:var(--shadow-1), 0 0 18px color-mix(in srgb, var(--color-success) 18%, transparent)}.seat-avatar{border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--seat-color) 88%, #fff 12%), var(--seat-color));color:#fff;width:56px;height:56px;font-family:var(--font-display);font-weight:700;font-size:var(--font-xl);letter-spacing:0;place-items:center;display:grid;overflow:hidden;box-shadow:inset 0 1px #ffffff2e,0 4px 10px #00000059}.seat-copy{gap:5px;min-width:0;display:grid}.seat-info{gap:2px;min-width:0;display:grid}.seat-info strong{min-width:0;font-size:var(--font-sm);align-items:center;gap:6px;font-weight:700;display:flex;overflow:hidden}.seat-info__name{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.seat-host-icon{color:var(--color-accent);flex:none}.seat-meta{flex-wrap:wrap;align-items:center;gap:5px 8px;min-width:0;display:flex}.seat-status{color:var(--color-text-muted);font-size:var(--font-xs);white-space:nowrap;align-items:center;gap:6px;font-weight:500;display:inline-flex}.status-dot{border-radius:var(--radius-pill);background:var(--color-text-dim);width:7px;height:7px;box-shadow:0 0 0 2px color-mix(in srgb, var(--color-bg) 60%, transparent)}.status-dot--online{background:var(--color-success);box-shadow:0 0 0 3px var(--color-success-soft)}.ready-chip{align-items:center;gap:var(--space-1);border:1px solid var(--color-warn);border-radius:var(--radius-pill);background:var(--color-warn-soft);min-height:24px;color:var(--color-warn);font-size:var(--font-xs);letter-spacing:.04em;white-space:nowrap;padding:1px 8px;font-weight:700;display:inline-flex}.ready-chip--ok{border-color:var(--color-success);background:var(--color-success-soft);color:var(--color-success)}.seat-remove{border:1px solid color-mix(in srgb, var(--color-danger) 45%, var(--color-line));border-radius:var(--radius-sm);background:color-mix(in srgb, var(--color-danger) 10%, transparent);width:30px;min-width:30px;height:30px;min-height:30px;color:var(--color-danger);place-items:center;padding:0;display:grid}.seat-remove:hover,.seat-remove:focus-visible{background:color-mix(in srgb, var(--color-danger) 18%, transparent);border-color:var(--color-danger)}.settings-heading{justify-content:space-between;align-items:baseline;gap:var(--space-2);border-bottom:1px solid color-mix(in srgb, var(--color-accent) 30%, var(--color-line-soft));margin-bottom:2px;padding:4px 6px 8px;display:flex}.settings-heading h2{font-family:var(--font-display);font-size:var(--font-lg);letter-spacing:-.005em;margin:0}.settings-heading span{color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.06em;text-transform:uppercase;font-weight:700}.lobby-settings .field{font-size:var(--font-xs);grid-template-columns:88px minmax(0,1fr);align-items:center;gap:4px;display:grid}.lobby-settings .field--role{align-items:start}.role-details{border:1px solid var(--color-line);border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface-2);color:var(--color-text-2,var(--color-text-muted));font-size:var(--font-xs);font-weight:600;line-height:var(--leading-snug);transition:border-color var(--duration-fast) var(--easing-out);overflow:hidden;box-shadow:0 1px 2px #00000029}.role-details:hover{border-color:color-mix(in srgb, var(--color-accent) 30%, var(--color-line))}.role-details strong{color:var(--color-text)}.role-details__summary{min-height:36px;color:var(--color-text);cursor:pointer;transition:background-color var(--duration-fast) var(--easing-out);justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;list-style:none;display:flex}.role-details__summary:hover{background:color-mix(in srgb, var(--color-accent) 6%, transparent)}.role-details__summary::-webkit-details-marker{display:none}.role-details__summary:after{content:"+";border:1px solid var(--color-line);border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface-3);width:22px;height:22px;color:var(--color-text-muted);font-weight:800;font-size:calc(14px * var(--app-text-scale,1));transition:background-color var(--duration-fast) var(--easing-out), border-color var(--duration-fast) var(--easing-out), color var(--duration-fast) var(--easing-out), transform var(--duration-base) var(--easing-out);flex:none;place-items:center;line-height:1;display:inline-grid}.role-details[open] .role-details__summary:after{content:"−";background:var(--color-accent-soft);border-color:var(--color-accent);color:var(--color-accent);transform:rotate(180deg)}.role-details__summary small{color:var(--color-text-muted);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;margin-left:auto;font-weight:700}.role-details__body{gap:8px;padding:6px 12px 12px;display:grid}.role-details__intro{color:var(--color-text-2,var(--color-text-muted));line-height:var(--leading-snug);margin:0}.role-details__list{gap:6px;margin:0;display:grid}.role-details__item{border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 1%, transparent), transparent 50%), var(--color-surface-3);grid-template-columns:minmax(96px,.35fr) minmax(0,1fr);align-items:start;gap:10px;padding:6px 8px;display:grid}.role-details__item dt{color:var(--color-text);font-family:var(--font-display);letter-spacing:-.005em;font-weight:700;font-size:var(--font-sm)}.role-details__item dd{color:var(--color-text-2,var(--color-text-muted));margin:0}.role-details__item--host{border-left:3px solid var(--color-accent);padding-left:10px}.role-details__item--host dt{color:var(--color-accent)}.role-details__item--enemy{border-left:3px solid var(--color-danger);padding-left:10px}.role-details__item--enemy dt{color:var(--color-danger)}.role-details__item--investigator{border-left:3px solid var(--color-info);padding-left:10px}.role-details__item--investigator dt{color:var(--color-info)}.role-details__item--suspect{border-left:3px solid var(--color-suspect);padding-left:10px}.role-details__item--suspect dt{color:var(--color-suspect)}.role-details__item--ally{border-left:3px solid var(--color-info);padding-left:10px}.role-details__item--ally dt{color:var(--color-info)}.field-help{color:var(--color-text-muted);font-size:var(--font-xs);grid-column:2;font-weight:600;line-height:1.2}.lobby-settings .field input,.lobby-settings select{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface);min-height:34px;font:inherit;font-size:var(--font-sm);color:var(--color-text);transition:border-color var(--duration-fast) var(--easing-out), box-shadow var(--duration-fast) var(--easing-out);padding:6px 10px;font-weight:600;box-shadow:inset 0 1px 2px #0000001f}.lobby-settings .field input:hover:not(:disabled),.lobby-settings select:hover:not(:disabled){border-color:color-mix(in srgb, var(--color-accent) 35%, var(--color-line))}.lobby-settings select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ca8a04' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>"), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface);background-position:right 10px center,top,top;background-repeat:no-repeat,no-repeat,no-repeat;background-size:14px,auto,auto;padding-right:32px}[data-theme=light] .lobby-settings select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c2410c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>"), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface);background-position:right 10px center,top,top;background-repeat:no-repeat,no-repeat,no-repeat;background-size:14px,auto,auto}.source-settings,.timer-settings,.auxiliary-settings{border:1px solid var(--color-line);border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface-2);min-width:0;transition:border-color var(--duration-fast) var(--easing-out);gap:6px;margin:0;padding:8px 10px;display:grid;box-shadow:0 1px 2px #00000029}.source-settings:hover,.timer-settings:hover,.auxiliary-settings:hover,.cards-per-type:hover{border-color:color-mix(in srgb, var(--color-accent) 30%, var(--color-line))}.source-settings legend,.timer-settings legend,.auxiliary-settings legend,.cards-per-type legend{padding:0 var(--space-1);color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;font-weight:700}.source-settings .ready-toggle,.auxiliary-settings .ready-toggle{min-height:24px;font-size:var(--font-sm)}.ghost-role-roster{border:1px solid var(--color-line);border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 5%, transparent), transparent 55%), var(--color-surface-2);gap:6px;min-width:0;margin:0;padding:8px 10px;display:grid}.ghost-role-roster__label{color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;font-weight:700}.ghost-role-roster__chips{flex-wrap:wrap;gap:5px;display:flex}.ghost-role-roster__chip{border:1px solid color-mix(in srgb, var(--color-accent) 28%, var(--color-line));border-radius:var(--radius-pill);background:color-mix(in srgb, var(--color-accent) 10%, transparent);color:var(--color-text);font-size:var(--font-xs);padding:3px 7px;line-height:1.2}.ghost-role-roster__empty{color:var(--color-text-muted);font-size:var(--font-sm);margin:0}.ghost-role-roster small{color:var(--color-text-muted);font-size:var(--font-xs);line-height:1.35}.clocktower-script-preview__groups{flex-wrap:wrap;gap:5px;display:flex}.clocktower-traveller-list{gap:6px;display:grid}.clocktower-traveller-row{color:var(--color-text);font-size:var(--font-sm);grid-template-columns:minmax(88px,.42fr) minmax(0,1fr);align-items:center;gap:8px;font-weight:700;display:grid}.clocktower-traveller-row select:disabled{cursor:not-allowed;opacity:.58}.clocktower-field-help{grid-column:1/-1}.clocktower-check-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:4px 8px;max-height:238px;padding-right:2px;display:grid;overflow:auto}.clocktower-table{width:min(1320px,100%);color:var(--color-text);gap:14px;margin:0 auto;display:grid}.clocktower-topbar{border:1px solid var(--color-line);border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 8%, transparent), transparent 58%), var(--color-surface-2);grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.clocktower-topbar h2{font-family:var(--font-display);margin:0;font-size:clamp(1.2rem,2vw,1.8rem)}.clocktower-phase-chip{border:1px solid color-mix(in srgb, var(--color-accent) 34%, var(--color-line));border-radius:var(--radius-sm);background:color-mix(in srgb, var(--color-accent) 10%, transparent);gap:2px;min-width:128px;padding:8px 10px;display:grid}.clocktower-phase-chip span{color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.07em;text-transform:uppercase;font-weight:800}.clocktower-phase-chip strong{font-size:var(--font-sm)}.clocktower-topbar__actions{flex-wrap:wrap;justify-content:end;gap:8px;display:flex}.clocktower-layout{grid-template-columns:minmax(0,1fr) minmax(320px,380px);align-items:start;gap:14px;display:grid}.clocktower-town-square{border:1px solid var(--color-line);border-radius:var(--radius-md);background:radial-gradient(circle at 50% 42%, color-mix(in srgb, var(--color-accent) 10%, transparent), transparent 38%), var(--color-surface);grid-template-columns:repeat(auto-fit,minmax(170px,1fr));align-content:start;gap:10px;min-height:540px;padding:14px;display:grid}.clocktower-player{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);grid-template-columns:42px minmax(0,1fr);gap:10px;min-width:0;min-height:112px;padding:10px;display:grid}.clocktower-player--self{border-color:var(--color-accent);box-shadow:0 0 0 1px color-mix(in srgb, var(--color-accent) 45%, transparent)}.clocktower-player--evil{border-color:color-mix(in srgb, var(--color-danger) 52%, var(--color-line))}.clocktower-player--dead{opacity:.68}.clocktower-player__avatar{color:#fff;border-radius:50%;place-items:center;width:42px;height:42px;font-weight:900;display:grid;box-shadow:inset 0 0 0 2px #ffffff3d}.clocktower-player__body{gap:4px;min-width:0;display:grid}.clocktower-player__name{justify-content:space-between;gap:8px;display:flex}.clocktower-player__name strong,.clocktower-player p{overflow-wrap:anywhere;min-width:0}.clocktower-player__name span,.clocktower-player small{color:var(--color-text-muted);font-size:var(--font-xs);font-weight:700}.clocktower-player p{font-size:var(--font-sm);margin:0;font-weight:800}.clocktower-side{gap:10px;display:grid}.clocktower-panel{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);gap:8px;padding:12px;display:grid}.clocktower-panel h3,.clocktower-panel p{margin:0}.clocktower-panel__heading{justify-content:space-between;align-items:center;gap:8px;display:flex}.clocktower-prompt-list{gap:6px;margin:0;padding:0;list-style:none;display:grid}.clocktower-prompt-list li{border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);gap:3px;padding:7px 8px;display:grid}.clocktower-prompt-list span{color:var(--color-text-muted);font-size:var(--font-xs);text-transform:uppercase;font-weight:800}.clocktower-grimoire__list{gap:7px;display:grid}.clocktower-grimoire__row{border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);background:var(--color-surface-3);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;padding:8px;display:grid}.clocktower-grimoire__row div{gap:2px;min-width:0;display:grid}.clocktower-grimoire__row span,.clocktower-grimoire__bluffs{color:var(--color-text-muted);font-size:var(--font-xs);font-weight:700}.clocktower-nominations{gap:7px}.clocktower-nomination{border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);background:var(--color-surface-3);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;padding:8px;display:grid}.clocktower-nomination div{gap:2px;min-width:0;display:grid}.clocktower-nomination span{color:var(--color-text-muted);font-size:var(--font-xs);font-weight:700}.clocktower-nomination__actions{justify-content:flex-end;display:flex}.clocktower-chat__messages{gap:6px;max-height:220px;display:grid;overflow:auto}.clocktower-chat__messages p{border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);background:var(--color-surface-3);gap:2px;padding:7px 8px;display:grid}.clocktower-chat__messages span,.clocktower-chat__empty{color:var(--color-text-muted);font-size:var(--font-sm)}.clocktower-chat__input{font-size:var(--font-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;gap:4px;font-weight:800;display:grid}.clocktower-chat__input textarea{resize:vertical;border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface);width:100%;min-height:72px;color:var(--color-text);font:inherit;font-size:var(--font-sm);text-transform:none;letter-spacing:0;padding:8px 10px}@media (max-width:860px){.clocktower-topbar,.clocktower-layout{grid-template-columns:1fr}.clocktower-topbar__actions{justify-content:start}.clocktower-town-square{grid-template-columns:1fr;min-height:auto}}.ghost-letters-timer-input{font-size:var(--font-sm);justify-content:space-between;align-items:center;gap:.5rem;padding:.25rem 0;display:flex}.ghost-letters-timer-input input[type=number]{width:5rem}.settings-warning{border:1px solid var(--color-danger);border-radius:var(--radius-sm,6px);background:var(--color-danger-soft);color:var(--color-danger);font-size:var(--font-sm);margin:6px 0 0;padding:6px 8px;line-height:1.3}.setting-label-line{align-items:center;gap:6px;min-width:0;display:inline-flex}.ready-toggle--inline-help{align-items:center;min-height:24px}.forensic-preference-toggle{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-2);min-height:30px;font-size:var(--font-sm);grid-column:1/-1;align-self:stretch;padding:5px 8px}.setting-label-line--pinned-help{white-space:normal;max-width:100%;line-height:1}.info-hint{flex:0 0 17px;align-self:center;place-items:center;width:17px;height:17px;display:grid;position:relative}.info-hint__button{border:1px solid var(--color-line);border-radius:var(--radius-pill);background:var(--color-surface-2);width:17px;min-width:17px;height:17px;min-height:17px;color:var(--color-text-muted);cursor:help;font:inherit;transition:border-color var(--duration-fast) var(--easing-out), color var(--duration-fast) var(--easing-out), background-color var(--duration-fast) var(--easing-out), transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1);place-items:center;padding:0;line-height:0;display:grid}.info-hint__button svg{display:block}.info-hint__button:hover,.info-hint__button:focus-visible{background:var(--color-accent-soft);border-color:var(--color-accent);color:var(--color-accent);outline:none;transform:scale(1.12)}.info-hint__button:active:not(:disabled){transform:scale(.95)}.info-hint__popup{z-index:var(--z-overlay);border:1px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-line));border-radius:var(--radius-md);background:radial-gradient(220px 120px at 100% 100%, var(--color-accent-soft), transparent 65%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 4%, transparent), transparent 50%), color-mix(in srgb, var(--color-surface) 92%, transparent);-webkit-backdrop-filter:blur(10px)saturate(1.1);width:min(280px,100vw - 32px);color:var(--color-text);font-size:var(--font-xs);font-weight:600;line-height:var(--leading-snug);overflow-wrap:anywhere;box-shadow:inset 0 1px 0 #ffffff0f, var(--shadow-2), 0 0 18px color-mix(in srgb, var(--color-accent) 14%, transparent);padding:10px 12px;animation:.18s cubic-bezier(.34,1.56,.64,1) info-hint-pop;display:block;position:absolute;bottom:calc(100% + 10px);right:-8px}.info-hint__popup:after{content:"";background:inherit;border-right:1px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-line));border-bottom:1px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-line));width:10px;height:10px;position:absolute;top:100%;right:12px;transform:translateY(-50%)rotate(45deg)}@keyframes info-hint-pop{0%{opacity:0;transform:translateY(4px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.info-hint__button:hover,.info-hint__button:focus-visible,.info-hint__button:active:not(:disabled){transform:none}.info-hint__popup{animation:none}}@media (max-width:520px){.home-game-picker,.ghost-mode-options{grid-template-columns:1fr}}.timer-settings--grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}@media (min-width:1280px){.timer-settings--grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.cards-per-type{border:1px solid var(--color-line);border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface-2);transition:border-color var(--duration-fast) var(--easing-out);gap:6px;margin:0;padding:8px 10px;display:grid;box-shadow:0 1px 2px #00000029}.cards-per-type legend{padding:0 var(--space-1);color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.06em;text-transform:uppercase;font-weight:700}.cards-per-type__chips{flex-wrap:wrap;gap:6px;display:flex}.ghost-mode-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.ghost-mode-option{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface);min-width:0;min-height:34px;color:var(--color-text-muted);font-size:var(--font-sm);cursor:pointer;transition:border-color var(--duration-fast) var(--easing-out), background-color var(--duration-fast) var(--easing-out), transform var(--duration-fast) var(--easing-out);place-items:center;padding:0 8px;font-weight:700;display:grid;position:relative}.ghost-mode-option input{opacity:0;pointer-events:none;position:absolute}.ghost-mode-option span{text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:100%;overflow:hidden}.ghost-mode-option:hover:not(.ghost-mode-option--active){border-color:color-mix(in srgb, var(--color-accent) 50%, var(--color-line));color:var(--color-text);transform:translateY(-1px)}.ghost-mode-option--active{border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 88%, #fff 12%), var(--color-accent));color:var(--color-on-accent);box-shadow:0 0 0 1px color-mix(in srgb, var(--color-accent) 40%, transparent)}.cards-per-type__chip{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface);width:40px;height:34px;color:var(--color-text);font-family:var(--font-display);font-size:var(--font-md);cursor:pointer;transition:border-color var(--duration-fast) var(--easing-out), background-color var(--duration-fast) var(--easing-out), transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1), box-shadow var(--duration-fast) var(--easing-out), color var(--duration-fast) var(--easing-out);padding:0;font-weight:700;line-height:1;display:block;position:relative;box-shadow:0 1px 2px #0000002e}.cards-per-type__chip>span{justify-content:center;place-items:center;line-height:1;display:flex;position:absolute;inset:0}.cards-per-type__chip input{opacity:0;pointer-events:none;width:0;height:0;min-height:0;position:absolute}.cards-per-type__chip:hover{background:var(--color-surface-3)}.cards-per-type__chip:hover:not(.cards-per-type__chip--active){border-color:color-mix(in srgb, var(--color-accent) 50%, var(--color-line));transform:translateY(-1px);box-shadow:0 4px 10px #00000038}.cards-per-type__chip--active{border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 88%, #fff 12%), var(--color-accent));color:var(--color-on-accent);box-shadow:0 1px 0 #ffffff2e inset, 0 4px 10px var(--color-accent-soft)}.timer-settings--grid legend{grid-column:1/-1}@media (max-width:480px){.timer-settings--grid{grid-template-columns:1fr}}.source-settings legend,.timer-settings legend,.auxiliary-settings legend{padding:0 var(--space-1);color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.06em;text-transform:uppercase;font-weight:700}.timer-setting{grid-template-columns:1fr;align-items:center;gap:4px;min-width:0;display:grid}.timer-setting>span{min-width:0;color:var(--color-text);font-size:var(--font-xs);text-overflow:ellipsis;white-space:nowrap;font-weight:700;line-height:1.1;overflow:hidden}.timer-setting input{border:1px solid var(--color-line);border-radius:var(--radius-sm);width:100%;min-height:24px;font-size:calc(12px * var(--app-text-scale,1));text-align:center;appearance:textfield;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;padding:2px 5px;font-weight:700;line-height:1}.timer-setting input::-webkit-outer-spin-button{appearance:none;margin:0}.timer-setting input::-webkit-inner-spin-button{appearance:none;margin:0}.timer-setting small{display:none}.settings-summary{gap:6px;margin:0;display:grid}.settings-summary div{gap:var(--space-2);border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-2);grid-template-columns:110px minmax(0,1fr);padding:6px 8px;display:grid}.settings-summary dt{color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.06em;text-transform:uppercase;font-weight:700}.settings-summary dd{overflow-wrap:anywhere;min-width:0;margin:0;font-weight:600}.player-row{justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-line-soft);display:flex}.player-row:last-child{border-bottom:0}.player-row strong,.player-row span{display:block}.player-row span{color:var(--color-text-muted);font-size:var(--font-sm)}.player-flags{text-align:right}@media (max-width:920px){.lobby-layout,.lobby-command-bar,.lobby-profile-editor{grid-template-columns:1fr}.lobby-start,.lobby-command-actions{justify-content:stretch}.ready-toggle--command{flex:160px}.lobby-start button{flex:1}.start-blocker{text-align:left;max-width:none}}@media (max-width:720px){.lobby-command-bar{gap:var(--space-3)}}@media (max-width:560px){.seat-grid{grid-template-columns:1fr}.seat-card{grid-template-columns:52px minmax(0,1fr) auto}.seat-avatar{width:52px;height:52px}}.game-table{gap:var(--space-3);width:min(100%,1520px);margin:0 auto;display:grid}.ghost-table{--ghost-card-size:86px;gap:var(--space-3);width:min(100%,1520px);margin:0 auto;display:grid}.ghost-table-top{align-items:center;gap:var(--space-3);padding:var(--space-3);border:1px solid color-mix(in srgb, var(--color-accent) 18%, var(--color-line));border-radius:var(--radius-lg);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 60%), var(--color-surface);box-shadow:var(--shadow-1);grid-template-columns:minmax(0,1fr) auto;display:grid}.ghost-table-kicker{color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;font-weight:700;display:block}.ghost-table-top h2{font-family:var(--font-display);font-size:var(--font-2xl);margin:0;line-height:1.05}.ghost-table-status{color:var(--color-text-muted);font-size:var(--font-sm);flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.ghost-table-status span,.ghost-table-status strong,.ghost-table-status em{border:1px solid var(--color-line);border-radius:var(--radius-pill);background:var(--color-surface-2);align-items:center;min-height:28px;padding:0 10px;font-style:normal;display:inline-flex}.ghost-table-status strong{color:var(--color-accent)}.ghost-table-settings-toggle{border:1px solid var(--color-line);border-radius:var(--radius-pill);background:var(--color-surface-2);min-width:28px;min-height:28px;color:var(--color-text-muted);cursor:pointer;transition:color var(--duration-fast) var(--easing-out), border-color var(--duration-fast) var(--easing-out), background-color var(--duration-fast) var(--easing-out);justify-content:center;align-items:center;padding:0 8px;display:inline-flex}.ghost-table-settings-toggle:hover,.ghost-table-settings-toggle:focus-visible{color:var(--color-accent);border-color:color-mix(in srgb, var(--color-accent) 40%, var(--color-line));background:color-mix(in srgb, var(--color-accent) 8%, var(--color-surface-2))}.ghost-table-layout{gap:var(--space-3);grid-template-columns:minmax(0,1fr) minmax(252px,320px);align-items:start;display:grid}.ghost-main-stack{gap:var(--space-3);min-width:0;display:grid}.ghost-case-board,.ghost-rail,.ghost-hand-rail{border:1px solid var(--color-line);border-radius:var(--radius-lg);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface);min-width:0;box-shadow:var(--shadow-1)}.ghost-case-board{gap:var(--space-2);padding:var(--space-3);display:grid}.ghost-case-row{gap:var(--space-2);grid-template-columns:minmax(88px,116px) minmax(0,1fr);align-items:stretch;min-width:0;display:grid}.ghost-case-row__heading{border:1px solid var(--color-line-soft);border-radius:var(--radius-md);background:var(--color-surface-2);align-content:center;gap:4px;min-width:0;padding:8px;display:grid}.ghost-case-row__heading strong,.ghost-case-row__heading span{overflow-wrap:anywhere}.ghost-case-row__heading strong{font-family:var(--font-display);font-size:var(--font-md)}.ghost-case-row__heading span{color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.06em;text-transform:uppercase;font-weight:700}.ghost-card-row{grid-template-columns:repeat(auto-fit,minmax(74px,1fr));gap:8px;min-width:0;display:grid}.ghost-card{border:1px solid var(--color-line);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 4%, transparent), transparent 60%), var(--color-surface-2);width:100%;min-width:0;color:var(--color-text);cursor:pointer;transition:border-color var(--duration-fast) var(--easing-out), background-color var(--duration-fast) var(--easing-out), transform var(--duration-fast) var(--easing-out);border-radius:8px;place-items:center;padding:7px;display:grid;position:relative;overflow:hidden;box-shadow:0 1px 2px #00000029}.ghost-card--square{aspect-ratio:1}.ghost-card:hover:not(:disabled){border-color:color-mix(in srgb, var(--color-accent) 50%, var(--color-line));transform:translateY(-1px)}.ghost-card--selected{border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 18%, transparent), transparent 70%), var(--color-surface-2);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--color-accent) 36%, transparent), 0 0 0 1px color-mix(in srgb, var(--color-accent) 30%, transparent)}.ghost-card:disabled{cursor:default}.ghost-card--true-clue{border-width:3px;border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 22%, transparent), color-mix(in srgb, var(--color-accent) 6%, transparent) 72%), var(--color-surface-2);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--color-accent) 38%, transparent), 0 0 0 2px var(--color-accent-soft), 0 0 18px color-mix(in srgb, var(--color-accent-ring) 70%, transparent);animation:2.4s ease-in-out infinite ghost-card-true-clue-pulse;position:relative}.ghost-card--true-clue:after{content:"★ ИСТИНА";font-size:calc(11px * var(--app-text-scale,1));letter-spacing:.02em;color:var(--color-bg);background:var(--color-accent);pointer-events:none;border-radius:4px;padding:2px 6px;font-weight:700;position:absolute;top:6px;right:6px}@keyframes ghost-card-true-clue-pulse{0%,to{box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--color-accent) 38%, transparent), 0 0 0 2px var(--color-accent-soft), 0 0 18px color-mix(in srgb, var(--color-accent-ring) 70%, transparent)}50%{box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--color-accent) 56%, transparent), 0 0 0 3px color-mix(in srgb, var(--color-accent-ring) 55%, transparent), 0 0 28px color-mix(in srgb, var(--color-accent-ring) 92%, transparent)}}@media (prefers-reduced-motion:reduce){.ghost-card--true-clue{animation:none}}.ghost-card--disappeared{opacity:.74;border-style:dashed}.ghost-card img{object-fit:contain;opacity:.92;width:calc(100% - 12px);height:calc(100% - 12px);position:absolute;inset:6px}.ghost-card>span:not(.ghost-card__check){z-index:1;-webkit-line-clamp:3;max-width:100%;color:var(--color-text);font-size:var(--font-xs);overflow-wrap:anywhere;text-align:center;-webkit-box-orient:vertical;font-weight:800;line-height:1.12;display:-webkit-box;position:relative;overflow:hidden}.ghost-card img+span:not(.ghost-card__check){border-radius:var(--radius-sm);background:color-mix(in srgb, var(--color-surface) 84%, transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);align-self:end;padding:3px 4px}.ghost-card__check{z-index:2;border-radius:var(--radius-pill);background:var(--color-accent);width:20px;height:20px;color:var(--color-on-accent);place-items:center;display:grid;position:absolute;top:5px;right:5px}.ghost-card--compact{padding:5px}.ghost-rail{gap:var(--space-2);padding:var(--space-3);top:var(--space-3);display:grid;position:sticky}.ghost-action-panel,.ghost-mailbox-cards,.ghost-revealed-hints,.ghost-player-list{gap:var(--space-2);min-width:0;padding:var(--space-2);border:1px solid var(--color-line-soft);border-radius:var(--radius-md);background:var(--color-surface-2);display:grid}.ghost-action-panel__title,.ghost-player-list h3,.ghost-mailbox-cards h3,.ghost-revealed-hints h3{min-width:0;font-size:var(--font-sm);align-items:center;gap:6px;margin:0;display:flex}.ghost-table-metrics{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin:0;display:grid}.ghost-table-metrics div{border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);background:var(--color-surface);min-width:0;padding:6px}.ghost-table-metrics dt{color:var(--color-text-muted);font-size:calc(10px * var(--app-text-scale,1));letter-spacing:.06em;text-transform:uppercase;font-weight:800}.ghost-table-metrics dd{font-family:var(--font-display);font-size:var(--font-md);margin:0;font-weight:800}.ghost-mini-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.ghost-hint-round{gap:var(--space-2);min-width:0;color:var(--color-text-muted);font-size:var(--font-sm);display:grid}.ghost-hint-round>strong{color:var(--color-text);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.06em}.ghost-hint-card-grid{grid-template-columns:repeat(auto-fill,minmax(72px,96px));gap:6px;display:grid}.ghost-empty-hints{color:var(--color-text-muted);font-size:var(--font-xs);margin:0}.ghost-final-guess{gap:var(--space-2);display:grid}.ghost-final-guess__roles{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.ghost-role-toggle{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface);min-width:0;min-height:34px;color:var(--color-text);font:inherit;font-size:var(--font-sm);padding:6px 8px;font-weight:800}.ghost-role-toggle--selected{border-color:var(--color-accent);background:color-mix(in srgb, var(--color-accent) 14%, var(--color-surface))}.ghost-player-list{align-content:start}.ghost-player-pill{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface);width:100%;min-width:0;min-height:34px;color:var(--color-text);font:inherit;text-align:left;grid-template-columns:10px minmax(0,1fr) auto;align-items:center;gap:8px;padding:6px 8px;display:grid}.ghost-player-pill:disabled{cursor:default;opacity:.72}.ghost-player-pill>span{border-radius:var(--radius-pill);background:var(--ghost-player-color,var(--color-accent));width:10px;height:10px}.ghost-player-pill strong,.ghost-player-pill em{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.ghost-player-pill em{color:var(--color-text-muted);font-size:var(--font-xs);font-style:normal}.ghost-player-pill--own,.ghost-player-pill--selected{border-color:color-mix(in srgb, var(--ghost-player-color,var(--color-accent)) 70%, var(--color-line))}.ghost-player-pill-wrap{gap:4px;display:grid}.ghost-player-pill-caption{color:var(--color-text-muted);font-size:var(--font-xs);margin:0;padding:0 4px;line-height:1.3}.ghost-drop-role-status{border:1px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-line));border-radius:var(--radius-pill);background:color-mix(in srgb, var(--color-accent) 10%, var(--color-surface-2));min-height:28px;color:var(--color-text);align-items:center;padding:0 10px;font-style:normal;display:inline-flex}.ghost-hand-rail{gap:var(--space-2);padding:var(--space-3);display:grid}.ghost-hand-rail__heading{justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.ghost-hand-rail__heading strong{font-family:var(--font-display)}.ghost-hand-rail__heading span{border-radius:var(--radius-pill);background:var(--color-surface-2);min-width:28px;height:24px;color:var(--color-text-muted);font-size:var(--font-xs);place-items:center;font-weight:800;display:grid}.ghost-hand-row{scrollbar-width:thin;gap:8px;min-width:0;display:flex;overflow-x:auto}.ghost-hand-card-slot{flex:0 0 var(--ghost-card-size);gap:5px;display:grid}.ghost-hand-row .ghost-card{flex:0 0 var(--ghost-card-size)}.ghost-discard-card-button{border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);background:var(--color-surface-2);min-width:0;min-height:26px;color:var(--color-text-muted);font-size:calc(10px * var(--app-text-scale,1));cursor:pointer;justify-content:center;align-items:center;gap:4px;padding:0 6px;font-weight:800;display:inline-flex}.ghost-discard-card-button--selected{border-color:color-mix(in srgb, var(--color-danger) 62%, var(--color-line));background:color-mix(in srgb, var(--color-danger) 12%, var(--color-surface-2));color:var(--color-danger)}.ghost-end-reveal{border:1px solid color-mix(in srgb, var(--color-success) 24%, var(--color-line));border-radius:var(--radius-lg);background:linear-gradient(180deg, color-mix(in srgb, var(--color-success) 7%, transparent), transparent 62%), var(--color-surface);box-shadow:var(--shadow-1);flex-direction:column;gap:16px;padding:24px;display:flex}.ghost-end-reveal__headline h2{font-size:calc(28px * var(--app-text-scale,1));margin:0}.ghost-end-reveal__headline p{opacity:.8;margin:4px 0 0}.ghost-end-reveal__headline--detective_team h2{color:#2e7d32}.ghost-end-reveal__headline--ghost_team h2{color:#6a1b9a}.ghost-end-reveal__headline--murderer_team h2{color:#c62828}.ghost-end-reveal__headline--mimic_team h2{color:#d84315}.ghost-end-reveal__headline--blackmailer_team h2{color:#4527a0}.ghost-end-reveal__case-board{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.ghost-end-reveal__case-board--with-secret{grid-template-columns:repeat(4,1fr)}.ghost-end-reveal__category-column{flex-direction:column;gap:8px;display:flex}.ghost-end-reveal__category-title{font-weight:600;font-size:calc(14px * var(--app-text-scale,1))}.ghost-end-reveal__vote-mark--correct{color:#2e7d32;font-weight:600}.ghost-end-reveal__vote-mark--wrong{color:#c62828;font-weight:600}.ghost-end-reveal__arrest,.ghost-end-reveal__final-guess,.ghost-end-reveal__clue-comparison{background:#0000000a;border-radius:8px;padding:12px}.ghost-end-reveal__clue-comparison h3{font-size:calc(16px * var(--app-text-scale,1));margin:0 0 8px}.ghost-end-reveal__clue-comparison-grid{flex-direction:column;gap:6px;display:flex}.ghost-end-reveal__clue-comparison-row{grid-template-columns:minmax(80px,1fr) 2fr 2fr;align-items:baseline;gap:8px;display:grid}.ghost-end-reveal__clue-comparison-category{font-weight:600}.ghost-end-reveal__clue-comparison-guess--correct{color:var(--color-success)}.ghost-end-reveal__clue-comparison-guess--wrong{color:var(--color-danger);text-decoration:line-through}.ghost-end-reveal__clue-comparison-truth{opacity:.8}.ghost-role-roster{flex-wrap:wrap;gap:8px;display:flex}.ghost-role-roster__player{border-radius:8px;align-items:center;gap:6px;padding:8px 12px;display:flex}.ghost-role-roster__player--ghost_team{background:#e1bee7}.ghost-role-roster__player--detective_team{background:#c8e6c9}.ghost-role-roster__player--murderer_team{background:#ffcdd2}.ghost-role-roster__player--mimic_team{background:#ffe0b2}.ghost-role-roster__player--blackmailer_team{background:#d1c4e9}.ghost-end-reveal__actions{flex-wrap:wrap;gap:8px;display:flex}.ghost-end-reveal__modal{z-index:50;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.ghost-end-reveal__modal-content{background:var(--color-surface,#fff);border-radius:12px;max-width:800px;max-height:80vh;padding:24px;overflow-y:auto}.ghost-end-reveal__modal-section{margin-bottom:16px}.ghost-end-reveal__modal-section h3{font-size:calc(16px * var(--app-text-scale,1));margin:0 0 8px}.ghost-end-reveal__modal-card-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;display:grid}@media (max-width:980px){.ghost-table-layout{grid-template-columns:1fr}.ghost-rail{order:-1;position:static}.ghost-end-reveal__case-board,.ghost-end-reveal__case-board--with-secret{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:620px){.ghost-table{--ghost-card-size:78px}.ghost-table-top,.ghost-case-row{grid-template-columns:1fr}.ghost-table-status{justify-content:flex-start}.ghost-table-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.ghost-end-reveal__case-board,.ghost-end-reveal__case-board--with-secret{grid-template-columns:1fr}}.game-layout{gap:var(--space-3);display:grid}.game-main{gap:var(--space-3);grid-template-columns:minmax(0,1fr) minmax(280px,340px);align-items:start;width:100%;max-width:1520px;margin:0 auto;display:grid}.game-main--wide{grid-template-columns:1fr}.table-column{gap:var(--space-3);min-width:0;display:grid}.action-column{gap:var(--space-3);min-width:0;top:var(--space-4);align-self:start;display:grid;position:sticky}@media (max-width:980px){.game-main{grid-template-columns:1fr}.action-column{order:-1;position:static}}.top-forensic-pref{border:1px solid color-mix(in srgb, var(--color-accent) 38%, var(--color-line));border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 8%, transparent), transparent 60%), var(--color-surface-2);color:var(--color-text-muted);font-size:calc(11px * var(--app-text-scale,1));letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:background-color var(--duration-fast) var(--easing-out), border-color var(--duration-fast) var(--easing-out), color var(--duration-fast) var(--easing-out), transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1);justify-content:center;align-items:center;gap:6px;padding:6px 12px;font-weight:700;display:inline-flex}.top-forensic-pref--icon{border-radius:var(--radius-pill);width:36px;height:36px;padding:0}.top-forensic-pref:hover{border-color:var(--color-accent);color:var(--color-text);transform:translateY(-1px)}.top-forensic-pref--active{background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 92%, #fff 8%), var(--color-accent));border-color:var(--color-accent);color:var(--color-on-accent);box-shadow:0 0 0 2px var(--color-accent-soft)}.top-forensic-pref--active:hover{filter:brightness(1.05);transform:translateY(-1px)}.role-card{--role-color:var(--color-accent);border:1px solid color-mix(in srgb, var(--role-color) 30%, var(--color-line));border-left:4px solid var(--role-color);border-radius:var(--radius-md);background:linear-gradient(90deg, color-mix(in srgb, var(--role-color) 14%, transparent), transparent 60%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface-2);min-width:0;min-height:48px;color:inherit;text-align:left;cursor:pointer;font:inherit;transition:transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1), border-color var(--duration-fast) var(--easing-out), box-shadow var(--duration-fast) var(--easing-out);align-content:center;gap:2px;padding:7px 12px;display:grid;box-shadow:inset 0 1px #ffffff0a,0 1px 2px #0000002e}.role-card:hover:not(:disabled){border-color:var(--role-color);box-shadow:inset 0 1px 0 #ffffff0f, 0 1px 2px #00000052, 0 6px 14px color-mix(in srgb, var(--role-color) 22%, transparent);transform:translateY(-1px)}.role-card:focus-visible{outline:2px solid var(--color-accent-ring);outline-offset:2px}@media (prefers-reduced-motion:reduce){.role-card:hover:not(:disabled){transform:none}}.ingame-timer-settings{gap:var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}@media (max-width:480px){.ingame-timer-settings{grid-template-columns:1fr}}.game-profile-editor-sheet{gap:var(--space-3);min-width:0;display:grid}.game-profile-editor-sheet .lobby-profile-editor{padding:var(--space-3) var(--space-4);align-items:start;gap:var(--space-3);border-radius:var(--radius-md);grid-template-columns:64px minmax(0,1fr)}.game-profile-editor-sheet .lobby-avatar-picker__button{width:64px;height:64px}.game-profile-editor-sheet .lobby-profile-editor .field{gap:4px;min-width:0;display:grid}.game-profile-editor-sheet .lobby-profile-editor .field>span{font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);font-weight:700}.game-profile-editor-sheet .preferred-color-picker{gap:var(--space-2);grid-column:1/-1;display:grid}.game-profile-editor-sheet .preferred-color-grid{scrollbar-width:thin;scrollbar-color:var(--color-line) transparent;max-height:112px;padding-right:4px;overflow-y:auto}.game-profile-editor-sheet .preferred-color-grid::-webkit-scrollbar{width:4px}.game-profile-editor-sheet .preferred-color-grid::-webkit-scrollbar-thumb{background:var(--color-line);border-radius:var(--radius-pill)}.role-card:hover{border-color:var(--role-color);background:color-mix(in srgb, var(--role-color) 10%, var(--color-surface-2))}.game-control-strip{justify-content:flex-end;align-items:center;gap:var(--space-2);flex-wrap:wrap;min-height:0;display:flex}.forensic-host-badge{--host-color:var(--color-accent);border:1px solid color-mix(in srgb, var(--color-accent) 35%, var(--color-line));border-radius:var(--radius-pill);background:linear-gradient(90deg, var(--color-accent-soft), transparent 60%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface);width:fit-content;margin-bottom:var(--space-2);box-shadow:inset 0 1px 0 #ffffff0f, 0 1px 2px #0000002e, 0 0 18px color-mix(in srgb, var(--color-accent) 14%, transparent);grid-template-columns:auto 28px minmax(0,1fr);align-items:center;gap:8px;padding:6px 14px 6px 10px;display:inline-grid}.forensic-host-badge__icon{border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--color-accent-hover) 88%, #fff 12%), var(--color-accent));width:22px;height:22px;color:var(--color-on-accent);place-items:center;display:grid;box-shadow:inset 0 1px #ffffff38,0 1px 2px #00000052}.forensic-host-badge__avatar{border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--host-color) 88%, #fff 12%), var(--host-color));color:#fff;width:28px;height:28px;font-family:var(--font-display);font-weight:700;font-size:calc(14px * var(--app-text-scale,1));place-items:center;display:grid;overflow:hidden;box-shadow:inset 0 1px #ffffff38,0 1px 2px #00000052}.forensic-host-badge__avatar img{object-fit:cover;width:100%;height:100%;display:block}.forensic-host-badge__copy{gap:0;min-width:0;line-height:1.05;display:grid}.forensic-host-badge__eyebrow{font-size:calc(9px * var(--app-text-scale,1));letter-spacing:.18em;text-transform:uppercase;color:var(--color-accent);font-weight:800}.forensic-host-badge__name{font-family:var(--font-display);font-size:var(--font-md);letter-spacing:-.005em;color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-weight:700;display:inline-flex;overflow:hidden}.forensic-host-badge__you{background:var(--color-accent-soft);color:var(--color-accent);border:1px solid color-mix(in srgb, var(--color-accent) 60%, transparent);border-radius:var(--radius-pill);font-family:var(--font-sans);font-size:calc(9px * var(--app-text-scale,1));letter-spacing:.12em;text-transform:uppercase;padding:1px 6px;font-weight:800}.spectator-note{color:var(--color-text-2,var(--color-text-muted));font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.1em;background:linear-gradient(180deg, color-mix(in srgb, var(--color-info) 12%, transparent), transparent 50%), var(--color-surface-2);border:1px solid color-mix(in srgb, var(--color-info) 35%, var(--color-line));border-radius:var(--radius-pill);padding:5px 12px;font-weight:800;box-shadow:0 1px 2px #00000029}.spectator-list{align-items:center;gap:var(--space-2);min-width:0;color:var(--color-text-muted);font-size:var(--font-xs);border:1px solid var(--color-line);border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface-2);padding:5px 10px 5px 8px;font-weight:700;display:inline-flex;box-shadow:0 1px 2px #00000029}.spectator-list>span{color:var(--color-text);text-transform:uppercase;letter-spacing:.1em;font-weight:800}.spectator-list ul{flex-wrap:wrap;gap:4px;margin:0;padding:0;list-style:none;display:inline-flex}.spectator-list li{border:1px solid color-mix(in srgb, var(--color-info) 30%, var(--color-line));border-radius:var(--radius-pill);background:color-mix(in srgb, var(--color-info) 8%, var(--color-surface-3));min-height:22px;color:var(--color-text-2,var(--color-text));align-items:center;gap:5px;padding:1px 9px 1px 3px;display:inline-flex}.spectator-list__avatar{border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--color-info) 88%, #fff 12%), var(--color-info));color:#fff;width:20px;height:20px;font-size:calc(10px * var(--app-text-scale,1));place-items:center;font-weight:800;display:grid;overflow:hidden;box-shadow:inset 0 1px #ffffff2e,0 1px 2px #00000052}.spectator-list__avatar img{object-fit:cover;width:100%;height:100%}.role-card--murderer{--role-color:var(--color-danger)}.role-card--investigator{--role-color:var(--color-info)}.role-card--support{--role-color:var(--support)}.role-card--unassigned{--role-color:var(--color-line)}.role-card span{color:var(--role-color);font-size:var(--font-xs);letter-spacing:.12em;text-transform:uppercase;font-weight:700}.role-card--unassigned span{color:var(--color-text-muted)}.role-card strong{font-family:var(--font-display);font-size:var(--font-lg);font-weight:700}.game-tools-dock{right:16px;bottom:calc(16px + 36px + var(--space-2));z-index:var(--z-sticky);pointer-events:none;flex-direction:column-reverse;align-items:flex-end;gap:5px;display:flex;position:fixed}.game-tools-dock>*{pointer-events:auto}.game-tools-dock__fab{border:1px solid color-mix(in srgb, var(--color-accent) 38%, var(--color-line));background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 16%, transparent), transparent 64%), var(--color-surface-2);width:32px;height:28px;min-height:28px;color:var(--color-text);cursor:pointer;appearance:none;box-shadow:inset 0 1px 0 #ffffff0f, 0 1px 2px #0000002e, 0 6px 14px var(--color-accent-soft);transition:transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1), border-color var(--duration-fast) var(--easing-out), box-shadow var(--duration-fast) var(--easing-out);border-radius:10px;justify-content:center;align-items:center;padding:0;display:inline-flex}.game-tools-dock__fab:hover{border-color:var(--color-accent);transform:translateY(-1px)}.game-tools-dock__fab:focus-visible{outline:2px solid var(--color-accent-ring);outline-offset:2px}.game-tools-dock__fab[aria-expanded=true]{border-color:var(--color-accent);box-shadow:inset 0 1px 0 #ffffff0f, 0 0 0 2px var(--color-accent-soft), 0 6px 14px color-mix(in srgb, var(--color-accent) 22%, transparent)}.game-tools-dock__popover{border:1px solid color-mix(in srgb, var(--color-accent) 18%, var(--color-line));background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 60%), color-mix(in srgb, var(--color-surface) 96%, transparent);max-width:min(153px,100vw - 32px);box-shadow:var(--shadow-2,0 8px 24px #00000052);-webkit-backdrop-filter:blur(14px)saturate(1.1);border-radius:12px;flex-wrap:wrap;align-items:center;gap:5px;padding:5px;display:inline-flex}.game-tools-dock__popover>button{border-radius:10px;width:32px;height:32px;min-height:32px;padding:0}.game-tools-dock__popover>button svg{width:16px;height:16px}@media (prefers-reduced-motion:reduce){.game-tools-dock__fab:hover{transform:none}}.game-timer-dock{z-index:var(--z-sticky);pointer-events:none;align-items:flex-end;gap:var(--space-2);flex-direction:column;max-width:calc(100vw - 32px);display:flex;position:fixed;bottom:16px;right:16px}.game-timer-dock>*{pointer-events:auto}.game-timer-dock__ability{align-items:center;display:inline-flex}.game-timer-dock__role-strip{max-width:100%;padding-right:calc(32px + var(--space-2));justify-content:flex-end;display:flex}.game-timer-dock__role-chip{--role-color:var(--color-accent);border:1px solid color-mix(in srgb, var(--role-color) 44%, var(--color-line));border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--role-color) 18%, transparent), transparent 62%), color-mix(in srgb, var(--color-surface-2) 92%, transparent);max-width:min(380px,100%);min-height:28px;color:var(--color-text-muted);appearance:none;font-size:calc(10px * var(--app-text-scale,1));text-transform:uppercase;white-space:nowrap;align-items:center;padding:0 12px;line-height:1;display:inline-flex;box-shadow:inset 0 1px #ffffff0f,0 1px 2px #0000002e}.game-timer-dock__role-chip:hover{border-color:var(--role-color);color:var(--color-text);background:linear-gradient(135deg, color-mix(in srgb, var(--role-color) 24%, transparent), transparent 62%), var(--color-surface-2)}.game-timer-dock__role-chip:focus-visible{outline:2px solid var(--color-accent-ring);outline-offset:2px}.game-timer-dock__role-chip strong{min-width:0;color:var(--role-color);font-size:calc(11.5px * var(--app-text-scale,1));text-overflow:ellipsis;overflow:hidden}.game-timer-dock__role-chip--murderer{--role-color:var(--color-danger)}.game-timer-dock__role-chip--investigator{--role-color:var(--color-info)}.game-timer-dock__role-chip--support{--role-color:var(--support)}.game-timer-dock__role-chip--unassigned{--role-color:var(--color-line)}.game-timer-dock__bar{--timer-tone:var(--color-accent);--timer-tone-hi:var(--color-accent-hover);--timer-tone-soft:var(--color-accent-soft);align-items:center;gap:var(--space-2);border:1px solid var(--timer-tone);border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--timer-tone) 18%, transparent), transparent 62%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface-2);height:36px;color:var(--color-text);box-shadow:inset 0 1px 0 color-mix(in srgb, var(--timer-tone-hi) 24%, transparent), inset 0 0 0 1px color-mix(in srgb, var(--timer-tone) 30%, transparent), 0 1px 2px #00000029, 0 0 18px var(--timer-tone-soft);transition:border-color var(--duration-base) var(--easing-out), box-shadow var(--duration-base) var(--easing-out);padding:0 10px;display:inline-flex}.game-timer-dock__bar--urgent{--timer-tone:var(--color-danger);--timer-tone-hi:var(--color-danger);--timer-tone-soft:var(--color-danger-soft);animation:1s ease-in-out infinite game-timer-dock-pulse}.game-timer-dock__bar--urgent .game-timer-dock__phase,.game-timer-dock__bar--urgent .game-timer-dock__time strong{color:var(--color-danger)}@keyframes game-timer-dock-pulse{0%,to{box-shadow:inset 0 1px 0 color-mix(in srgb, var(--timer-tone-hi) 24%, transparent), inset 0 0 0 1px color-mix(in srgb, var(--timer-tone) 30%, transparent), 0 1px 2px #00000029, 0 0 18px var(--timer-tone-soft)}50%{box-shadow:inset 0 1px 0 color-mix(in srgb, var(--timer-tone-hi) 36%, transparent), inset 0 0 0 2px color-mix(in srgb, var(--timer-tone) 50%, transparent), 0 2px 6px #00000052, 0 0 28px color-mix(in srgb, var(--timer-tone) 42%, transparent)}}@media (prefers-reduced-motion:reduce){.game-timer-dock__bar--urgent{box-shadow:inset 0 1px 0 color-mix(in srgb, var(--timer-tone-hi) 28%, transparent), inset 0 0 0 2px var(--timer-tone), 0 0 24px color-mix(in srgb, var(--timer-tone) 40%, transparent);animation:none}}.game-timer-dock__bar--paused{--timer-tone:var(--color-text-dim);--timer-tone-hi:var(--color-text-muted);--timer-tone-soft:transparent;filter:saturate(.5);opacity:.85}.game-timer-dock__bar--paused .game-timer-dock__time strong{color:var(--color-text-muted)}.game-timer-dock__sep{background:color-mix(in srgb, var(--color-line) 70%, transparent);width:1px;height:18px}.game-timer-dock__time{align-items:baseline;gap:6px;line-height:1;display:inline-flex}.game-timer-dock__phase{color:var(--color-accent);font-size:calc(10px * var(--app-text-scale,1));letter-spacing:.12em;text-transform:uppercase;font-weight:700}.game-timer-dock__time strong{font-family:var(--font-display);font-size:var(--font-lg);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;line-height:1}.game-timer-dock__step{font-size:calc(11px * var(--app-text-scale,1));color:var(--color-text-muted);font-variant-numeric:tabular-nums;font-weight:700}.game-timer-dock__badges{color:var(--color-accent);font-size:calc(11px * var(--app-text-scale,1));font-variant-numeric:tabular-nums;align-items:center;gap:3px;font-weight:700;display:inline-flex}.game-timer-dock__pause{border:1px solid var(--color-line);border-radius:var(--radius-pill);background:var(--color-surface-2);width:32px;height:32px;color:var(--color-text);appearance:none;cursor:pointer;justify-content:center;align-items:center;padding:0;line-height:0;display:inline-flex}.game-timer-dock__pause:hover{border-color:var(--color-accent)}.game-timer-dock__pause:focus-visible{outline:2px solid var(--color-accent-ring);outline-offset:2px}.game-timer-dock__pause svg{display:block}@media (max-width:480px){.game-timer-dock__step,.game-timer-dock__step+.game-timer-dock__sep{display:none}.game-tools-dock__popover{max-width:calc(100vw - 32px)}}.game-phase-bar{align-items:center;gap:var(--space-3);border:1px solid var(--color-line);border-radius:var(--radius-lg);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface);padding:var(--space-2) var(--space-4);box-shadow:var(--shadow-1);grid-template-columns:minmax(0,1fr) auto;display:grid}.phase-now{display:none}.phase-pills{scrollbar-width:none;scroll-snap-type:none;scroll-behavior:smooth;flex-wrap:wrap;gap:5px;min-width:0;max-width:none;display:flex;overflow:visible}.phase-pills::-webkit-scrollbar{height:6px}.phase-pills::-webkit-scrollbar-thumb{background:var(--color-line);border-radius:var(--radius-pill)}.phase-pill{border:1px solid var(--color-line);border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface-2);min-width:0;min-height:28px;color:var(--color-text-muted);font-size:var(--font-xs);white-space:nowrap;scroll-snap-align:start;transition:border-color var(--duration-fast) var(--easing-out);flex:108px;justify-content:space-between;align-items:center;gap:6px;padding:3px 10px;font-weight:600;display:inline-flex;box-shadow:0 1px 2px #00000029}.phase-pill.current{border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 88%, #fff 12%), var(--color-accent));color:var(--color-on-accent);box-shadow:inset 0 1px 0 #ffffff38, 0 1px 2px #00000052, 0 4px 12px var(--color-accent-soft)}.phase-pill b{color:var(--color-text-dim);font-size:var(--font-xs);font-variant-numeric:tabular-nums;font-weight:700}.phase-pill.current b{color:color-mix(in srgb, var(--color-on-accent) 84%, transparent)}.badge-counter{align-items:center;gap:var(--space-1);white-space:nowrap;color:var(--color-accent);font-variant-numeric:tabular-nums;font-weight:700;display:inline-flex}.phase-extras{align-items:center;gap:var(--space-2);white-space:nowrap;display:inline-flex}.phase-progress{border:1px solid var(--color-line);border-radius:var(--radius-pill);background:var(--color-surface-2);color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.06em;text-transform:uppercase;font-variant-numeric:tabular-nums;align-items:center;padding:4px 10px;font-weight:700;display:inline-flex}@media (max-width:920px){.game-phase-bar{grid-template-columns:1fr}.phase-pills{order:3}}.phase-timeline{gap:var(--space-2);flex-wrap:wrap;width:100%;max-width:1520px;margin:0 auto;display:flex}.phase-timeline--compact{gap:var(--space-2);padding-bottom:var(--space-1);scrollbar-width:thin;flex-wrap:nowrap;overflow-x:auto}.phase-step{align-items:center;gap:var(--space-2);border:1px solid var(--color-line);border-radius:var(--radius-pill);background:var(--color-surface-2);min-height:32px;color:var(--color-text-muted);padding:var(--space-1) var(--space-3);font-size:var(--font-sm);flex:none;font-weight:600;display:inline-flex}.phase-step.current{border-color:var(--color-accent);background:var(--color-accent-soft);color:var(--color-accent)}.phase-step svg{width:16px;height:16px}.phase-timeline--compact .phase-step{min-height:28px;padding:4px var(--space-2);font-size:var(--font-xs)}.identity-panel{--player-color:var(--color-accent);gap:var(--space-3);border:1px solid var(--color-line);border-left:4px solid var(--player-color);border-radius:var(--radius-lg);background:var(--color-surface);width:100%;max-width:1520px;padding:var(--space-3) var(--space-4);grid-template-columns:auto minmax(0,1fr) minmax(240px,auto);align-items:center;margin:0 auto;display:grid}.identity-panel--murderer{border-left-color:var(--color-danger)}.identity-panel--investigator{border-left-color:var(--color-info)}.identity-panel--support{border-left-color:var(--support)}.identity-panel--unassigned{border-left-color:var(--color-line);background:var(--color-surface-2)}.identity-panel--unassigned .identity-icon{background:var(--color-surface-3);color:var(--color-text-muted)}.identity-icon{border-radius:var(--radius-md);background:color-mix(in srgb, var(--player-color) 18%, var(--color-surface));width:44px;height:44px;color:var(--player-color);place-items:center;display:grid}.identity-copy{min-width:0}.identity-copy h2{margin:0 0 var(--space-1);font-size:var(--font-xl);line-height:var(--leading-tight)}.identity-copy p:last-child{color:var(--color-text-muted);font-size:var(--font-sm);line-height:var(--leading-snug);margin:0}.identity-facts{justify-content:flex-end;gap:var(--space-1);flex-wrap:wrap;display:flex}.identity-facts span{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);min-height:28px;color:var(--color-text);font-size:var(--font-xs);letter-spacing:.04em;align-items:center;padding:4px 10px;font-weight:600;display:inline-flex}@media (max-width:760px){.identity-panel{grid-template-columns:auto minmax(0,1fr)}.identity-facts{grid-column:1/-1;justify-content:flex-start}}.inline-actions{align-items:stretch;gap:var(--space-3);z-index:var(--z-sticky);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex;position:sticky;top:0}@media (max-width:920px){.inline-actions{top:0}}.inline-actions .private-panel{flex:360px}.next-phase-action{align-self:center}.private-panel,.solve-panel,.end-panel{border:1px solid var(--color-line);border-radius:var(--radius-lg);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface);padding:var(--space-4);gap:var(--space-3);box-shadow:var(--shadow-1);display:grid}.private-panel{border-color:color-mix(in srgb, var(--color-accent) 55%, var(--color-line));background:radial-gradient(420px 200px at 0% 0%, var(--color-accent-soft), transparent 60%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface);box-shadow:var(--shadow-1), 0 0 24px color-mix(in srgb, var(--color-accent) 14%, transparent);position:relative}.private-panel:before{content:"";border-radius:var(--radius-md) 0 var(--radius-md) 0;background:linear-gradient(180deg, var(--color-accent-hover), var(--color-accent));width:4px;height:26px;box-shadow:0 0 12px var(--color-accent-soft);position:absolute;top:-1px;left:-1px}.private-panel .eyebrow{color:var(--color-accent);text-transform:uppercase;letter-spacing:.14em;font-weight:700;font-size:var(--font-xs);margin:0}.private-panel h2{font-family:var(--font-display);font-size:var(--font-xl);letter-spacing:-.01em;margin:0;line-height:1.1}.private-panel p{color:var(--color-text-2,var(--color-text-muted));margin:0}.panel-heading{justify-content:space-between;align-items:start;gap:var(--space-3);display:flex}.panel-heading h2{font-size:var(--font-lg);margin:0}.status-pill{align-items:center;gap:var(--space-1);border:1px solid var(--color-accent);border-radius:var(--radius-pill);background:var(--color-accent-soft);min-height:28px;color:var(--color-accent);font-size:var(--font-xs);letter-spacing:.04em;white-space:nowrap;padding:2px 10px;font-weight:700;display:inline-flex}.status-pill--muted{border-color:var(--color-line);background:var(--color-surface-2);color:var(--color-text-muted)}.status-pill--success{border-color:var(--color-success);background:var(--color-success-soft);color:var(--color-success)}.status-pill--danger{border-color:var(--color-danger);background:var(--color-danger-soft);color:var(--color-danger)}.solve-panel{gap:var(--space-3);display:grid}.solve-panel select{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);min-height:42px;padding:8px 10px}.solve-panel--builder{border-color:var(--color-accent);background:linear-gradient(180deg, var(--color-accent-soft), transparent 50%), var(--color-surface)}.solve-slots{gap:var(--space-2);display:grid}.solve-slot{border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);padding:var(--space-2) var(--space-3);transition:border-color var(--duration-fast) var(--easing-out), background-color var(--duration-fast) var(--easing-out);gap:2px;display:grid}.solve-slot--filled{border-color:var(--color-accent);background:linear-gradient(135deg, var(--color-accent-soft), transparent 70%), var(--color-surface-2)}.solve-slot--crime{border-style:dashed;border-color:var(--color-danger)}.solve-slot--filled-crime{background:linear-gradient(135deg, var(--color-danger-soft), transparent 70%), var(--color-surface-2);border-style:solid}.solve-slot--filled-crime strong{color:var(--color-text)}.solve-slot span{align-items:center;gap:var(--space-1);color:var(--color-text-muted);font-size:var(--font-xs);letter-spacing:.06em;text-transform:uppercase;font-weight:700;display:inline-flex}.solve-slot strong{overflow-wrap:anywhere;min-width:0;font-weight:600}.action-hint{color:var(--color-text-muted);font-size:var(--font-sm);line-height:var(--leading-snug);margin:0}.private-panel .action-effect{color:var(--color-text);font-size:var(--font-sm);font-weight:700;line-height:var(--leading-snug);margin:0}.crime-selection-status,.forensic-board-hint{border:1px solid color-mix(in srgb, var(--color-danger) 55%, var(--color-line));border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--color-danger) 24%, transparent), transparent 65%), var(--color-danger-soft);width:fit-content;color:var(--color-danger);font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;font-variant-numeric:tabular-nums;align-items:center;gap:6px;margin:0;padding:5px 12px;font-weight:800;display:inline-flex;box-shadow:inset 0 1px #ffffff0f,0 1px 2px #00000029}.forensic-board-hint{border-color:color-mix(in srgb, var(--color-accent) 55%, var(--color-line));background:linear-gradient(135deg, color-mix(in srgb, var(--color-accent) 24%, transparent), transparent 65%), var(--color-accent-soft);color:var(--color-accent)}.button-row{gap:var(--space-2);grid-template-columns:1fr auto;display:grid}.button-row button,.compact-icon-action{min-height:38px}.button-row .primary-cta,.solve-panel--builder .primary-cta{border-color:var(--color-accent);background:var(--color-accent);color:var(--color-on-accent)}.button-row .primary-cta:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}@media (max-width:560px){.button-row{grid-template-columns:1fr}}.forensic-solution{gap:var(--space-1);border:1px solid var(--color-accent);border-radius:var(--radius-md);background:var(--color-accent-soft);padding:var(--space-3);display:grid}.forensic-solution__warning{align-items:center;gap:var(--space-1);margin:0 0 var(--space-2);color:var(--color-danger);font-size:var(--font-xs);letter-spacing:.06em;text-transform:uppercase;font-weight:700;display:inline-flex}.stack-actions{gap:var(--space-2);display:grid}.stack-actions button{width:100%}.scene-board-shell{gap:var(--space-3);border:1px solid var(--color-line);border-radius:var(--radius-lg);background:radial-gradient(600px 200px at 50% 0%, var(--color-accent-soft), transparent 60%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 60%), var(--color-surface);padding:var(--space-3);box-shadow:var(--shadow-1);display:grid}.scene-board-header{justify-content:space-between;align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.scene-board-header__copy{align-items:center;gap:var(--space-2);min-width:0;color:var(--color-text-muted);display:inline-flex}.scene-board-header__copy strong{color:var(--color-text);font-size:var(--font-sm);font-variant-numeric:tabular-nums;font-weight:900}.scene-board-header__eyebrow{color:var(--color-text-muted);font-size:calc(11px * var(--app-text-scale,1));letter-spacing:.08em;text-transform:uppercase;font-weight:900}.scene-board-pin{border:1px solid color-mix(in srgb, var(--color-accent) 38%, var(--color-line));border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 55%), var(--color-surface-2);min-height:32px;color:var(--color-text);font-size:var(--font-xs);justify-content:center;align-items:center;gap:6px;padding:5px 11px;font-weight:800;line-height:1;display:inline-flex}.scene-board-pin:hover:not(:disabled){border-color:var(--color-accent);background:var(--color-accent-soft);color:var(--color-accent)}.scene-board-pin--active{border-color:var(--color-accent);background:var(--color-accent);color:var(--color-on-accent)}.scene-board-pin--active:hover:not(:disabled){background:color-mix(in srgb, var(--color-accent) 86%, #fff 14%);color:var(--color-on-accent)}.scene-board-header .forensic-host-badge{gap:6px;margin-bottom:0;padding:4px 11px 4px 7px}.scene-board-header .forensic-host-badge__avatar{width:24px;height:24px;font-size:calc(12px * var(--app-text-scale,1))}.scene-board-header .forensic-host-badge__name{font-size:var(--font-sm)}.scene-replace-btn__count{background:var(--color-accent);min-width:16px;height:16px;color:var(--color-on-accent);font-size:calc(10px * var(--app-text-scale,1));letter-spacing:0;border-radius:999px;place-items:center;margin-left:4px;padding:0 5px;font-weight:800;line-height:1;display:inline-grid}.scene-replacement-gallery{gap:var(--space-3);margin-top:var(--space-2);padding:var(--space-3) var(--space-3) var(--space-3) calc(var(--space-3) + 6px);border:1px solid color-mix(in srgb, var(--color-accent) 24%, var(--color-line));border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 6%, transparent), transparent 65%), color-mix(in srgb, var(--color-surface) 92%, #000 8%);box-shadow:var(--shadow-1), inset 0 1px 0 #ffffff08;display:grid;position:relative}.scene-replacement-gallery:before{content:"";background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 80%, transparent), color-mix(in srgb, var(--color-accent) 40%, transparent));border-radius:2px;width:3px;position:absolute;top:12px;bottom:12px;left:0}.scene-replacement-gallery__head{justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.scene-replacement-gallery__head-copy{gap:2px;min-width:0;display:grid}.scene-replacement-gallery__eyebrow{font-family:var(--font-display);font-size:var(--font-sm);letter-spacing:.01em;color:var(--color-text);font-weight:800}.scene-replacement-gallery__hint{font-size:var(--font-xs);color:var(--color-text-muted);line-height:var(--leading-snug)}.scene-replacement-gallery__counter{border:1px solid color-mix(in srgb, var(--color-accent) 38%, var(--color-line));border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 12%, transparent), transparent 60%), color-mix(in srgb, var(--color-surface-2) 90%, #000 10%);font-family:var(--font-display);font-size:var(--font-xs);letter-spacing:.04em;color:var(--color-accent);font-variant-numeric:tabular-nums;text-transform:uppercase;align-items:center;gap:6px;padding:5px 12px;font-weight:800;display:inline-flex}.scene-replacement-gallery__list{align-items:stretch;gap:var(--space-3);flex-wrap:wrap;margin:0;padding:0;list-style:none;display:flex}.scene-replacement-card{border:1px solid color-mix(in srgb, var(--color-accent) 22%, var(--color-line));border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 5%, transparent), transparent 75%), color-mix(in srgb, var(--color-surface-2) 96%, #000 4%);appearance:none;width:100%;font:inherit;color:inherit;text-align:left;cursor:pointer;opacity:0;gap:10px;padding:14px 14px 12px;transition:transform .16s ease-out,border-color .16s ease-out,box-shadow .16s ease-out;animation:.26s ease-out forwards scene-replacement-card-in;display:grid;transform:translateY(4px);box-shadow:inset 0 1px #ffffff0a,0 2px 6px #0000003d}.scene-replacement-card:not(:disabled):hover{border-color:color-mix(in srgb, var(--color-accent) 55%, var(--color-line));box-shadow:0 0 0 1px color-mix(in srgb, var(--color-accent) 35%, transparent), 0 10px 28px #0000006b, inset 0 1px 0 #ffffff0d;transform:translateY(-2px)}.scene-replacement-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@keyframes scene-replacement-card-in{to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.scene-replacement-card{opacity:1;animation:none;transform:none}.scene-replacement-card:hover{transform:none}}.scene-replacement-card__header{justify-content:space-between;align-items:baseline;gap:var(--space-2);display:flex}.scene-replacement-card__title{font-family:var(--font-display);font-size:var(--font-md);letter-spacing:-.005em;color:var(--color-text);text-transform:none;min-width:0;margin:0;font-weight:700}.scene-replacement-card__index{font-family:var(--font-display);font-size:calc(10px * var(--app-text-scale,1));letter-spacing:.08em;color:var(--color-text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;font-weight:800}.scene-replacement-card__options{gap:4px;margin:0;padding:0;list-style:none;display:grid}.scene-replacement-card__options li{font-size:var(--font-sm);color:var(--color-text);line-height:var(--leading-snug);align-items:center;gap:8px;padding:4px 0;display:flex}.scene-replacement-card__bullet{background:var(--color-accent);width:5px;height:5px;box-shadow:0 0 0 2px color-mix(in srgb, var(--color-accent) 18%, transparent);border-radius:50%;flex-shrink:0}.scene-replacement-card__placeholder{font-size:var(--font-xs);color:var(--color-text-muted);margin:0;font-style:italic}.scene-replacement-card-wrap{flex:260px;min-width:220px;max-width:360px;list-style:none;display:flex}.scene-replacement-card__check{background:var(--color-accent);width:22px;height:22px;color:var(--color-on-accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--color-accent) 20%, transparent);border-radius:50%;flex-shrink:0;place-items:center;display:grid}.scene-replacement-card__cta{border-top:1px dashed color-mix(in srgb, var(--color-line) 70%, transparent);font-size:calc(10px * var(--app-text-scale,1));letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);text-align:center;margin-top:auto;padding-top:8px;font-weight:800}.scene-replacement-card--selected .scene-replacement-card__cta{color:var(--color-accent)}.scene-replacement-card[disabled]{opacity:.4;cursor:not-allowed}.scene-replacement-card--selected{border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 14%, transparent), transparent 70%), color-mix(in srgb, var(--color-surface-2) 92%, #000 8%);box-shadow:0 0 0 2px color-mix(in srgb, var(--color-accent) 65%, transparent), 0 14px 32px #00000080, inset 0 1px 0 #ffffff0f;transform:translateY(-2px)}.scene-replacement-card--selected:hover{transform:translateY(-2px)}.scene-replacement-gallery__cancel{border:1px solid color-mix(in srgb, var(--color-accent) 32%, var(--color-line));border-radius:var(--radius-pill);color:var(--color-text-muted);font-size:var(--font-xs);cursor:pointer;background:0 0;align-items:center;gap:5px;padding:6px 12px;font-weight:700;transition:color .12s,border-color .12s,background .12s;display:inline-flex}.scene-replacement-gallery__cancel:hover{color:var(--color-text);border-color:color-mix(in srgb, var(--color-accent) 55%, var(--color-line));background:color-mix(in srgb, var(--color-accent) 10%, transparent)}.scene-tile--swap-target{cursor:pointer;border-color:color-mix(in srgb, var(--color-accent) 65%, var(--color-line));background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 10%, transparent), transparent 60%), var(--color-surface-2);box-shadow:0 0 0 2px color-mix(in srgb, var(--color-accent) 35%, transparent), 0 6px 18px #00000059;animation:1.6s ease-in-out infinite scene-tile-swap-pulse}.scene-tile--swap-target:hover{border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 18%, transparent), transparent 60%), var(--color-surface-2);animation:none;transform:translateY(-2px)}.scene-tile--swap-target:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}@keyframes scene-tile-swap-pulse{0%,to{box-shadow:0 0 0 2px color-mix(in srgb, var(--color-accent) 35%, transparent), 0 6px 18px #00000059}50%{box-shadow:0 0 0 4px color-mix(in srgb, var(--color-accent) 55%, transparent), 0 10px 28px #00000080}}@media (prefers-reduced-motion:reduce){.scene-tile--swap-target{animation:none}}.scene-replacement-gallery__discard{color:var(--color-text-muted);font-size:var(--font-xs);cursor:pointer;background:0 0;border:none;border-bottom:1px solid #0000;padding:2px 0;font-weight:600;text-decoration:none;transition:color .12s,border-color .12s}.scene-replacement-gallery__discard:hover{color:var(--color-text);border-bottom-color:color-mix(in srgb, var(--color-text) 50%, transparent)}.discussion-skip-bar{border:1px solid color-mix(in srgb, var(--color-accent) 32%, var(--color-line));border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 6%, transparent), transparent 70%), var(--color-surface-2);width:fit-content;max-width:100%;box-shadow:var(--shadow-1);gap:8px;padding:12px 14px;display:grid}.discussion-skip-bar__meta{justify-content:space-between;align-items:baseline;gap:var(--space-2);display:flex}.discussion-skip-bar__label{font-size:var(--font-xs);color:var(--color-text);letter-spacing:.01em;font-weight:700}.discussion-skip-bar__count{font-family:var(--font-display);font-size:var(--font-sm);font-variant-numeric:tabular-nums;color:var(--color-accent);font-weight:800}.discussion-skip-bar__track{background:color-mix(in srgb, var(--color-line) 70%, transparent);border-radius:999px;width:min(280px,100%);height:4px;position:relative;overflow:hidden}.discussion-skip-bar__fill{background:linear-gradient(90deg, color-mix(in srgb, var(--color-accent) 75%, transparent), var(--color-accent));border-radius:inherit;transition:width .22s ease-out;position:absolute;inset:0 auto 0 0}.discussion-skip-bar__action{border-radius:var(--radius-pill);font-size:var(--font-xs);letter-spacing:.02em;cursor:pointer;border:1px solid #0000;align-self:flex-start;align-items:center;gap:6px;padding:7px 14px;font-weight:800;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.discussion-skip-bar__action--skip{background:var(--color-accent);color:var(--color-on-accent);border-color:var(--color-accent)}.discussion-skip-bar__action--skip:hover{background:color-mix(in srgb, var(--color-accent) 88%, #fff 12%)}.discussion-skip-bar__action--undo{color:var(--color-text-muted);border-color:var(--color-line);background:0 0}.discussion-skip-bar__action--undo:hover{color:var(--color-text);border-color:color-mix(in srgb, var(--color-text) 40%, var(--color-line))}.discussion-skip-bar__chip{background:color-mix(in srgb, var(--color-on-accent) 22%, transparent);color:var(--color-on-accent);font-size:calc(10px * var(--app-text-scale,1));border-radius:999px;align-items:center;gap:2px;margin-left:4px;padding:2px 6px;font-weight:800;line-height:1;display:inline-flex}.scene-replacement-gallery__footer{justify-content:flex-end;display:flex}.scene-board-shell .scene-board,.scene-board{gap:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(170px,1fr));max-width:none;margin:0;display:grid}.scene-board-shell--expanded .scene-board{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.scene-board-shell--collapsed .scene-board{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.scene-tile{border:1px solid var(--color-line);border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface-2);gap:var(--space-1);transition:border-color var(--duration-fast) var(--easing-out);padding:10px;display:grid;box-shadow:inset 0 1px #ffffff0a,0 1px 3px #00000038}.scene-tile:hover{border-color:color-mix(in srgb, var(--color-accent) 30%, var(--color-line))}.scene-tile--tentative{border-color:color-mix(in srgb, var(--color-accent) 55%, var(--color-line));box-shadow:inset 0 1px 0 #ffffff0a, 0 0 0 1px var(--color-accent-soft), 0 0 14px color-mix(in srgb, var(--color-accent) 20%, transparent)}.scene-tile--tentative .scene-tile__title h3{color:var(--color-accent)}.scene-tile--confirmed{border-color:color-mix(in srgb, var(--color-success) 50%, var(--color-line));background:linear-gradient(180deg, color-mix(in srgb, var(--color-success) 10%, transparent), transparent 60%), var(--color-surface-2)}.scene-tile--confirmed .scene-tile__title h3{color:var(--color-success)}.scene-tile h3{font-family:var(--font-display);font-size:var(--font-sm);letter-spacing:-.005em;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:700;font-size:calc(11px * var(--app-text-scale,1));margin:0}.scene-tile__title{gap:var(--space-1);grid-template-columns:minmax(0,1fr) auto;align-items:center;display:grid}.scene-replace-btn{border:1px solid var(--color-accent);border-radius:var(--radius-pill);background:var(--color-accent-soft);width:28px;min-width:28px;height:28px;min-height:28px;color:var(--color-accent);justify-content:center;align-items:center;padding:0;display:inline-flex}.scene-replace-btn:hover:not(:disabled){background:var(--color-accent);color:#fff}.scene-location-select{border:1px solid var(--color-accent);border-radius:var(--radius-sm);background:var(--color-surface-3);min-width:112px;max-width:100%;min-height:28px;color:var(--color-text);font-size:var(--font-xs);padding:2px 26px 2px 8px;font-weight:700}.scene-location-switcher{min-width:0;margin-top:var(--space-1);flex-wrap:nowrap;justify-content:center;align-items:center;gap:4px;display:inline-flex}.scene-location-switcher__button{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:var(--color-surface-3);width:26px;min-width:26px;height:26px;min-height:26px;color:var(--color-text-muted);font-size:var(--font-xs);place-items:center;padding:0;font-weight:800;display:grid}.scene-location-switcher__button:hover:not(:disabled){border-color:var(--color-accent);background:var(--color-accent);color:var(--color-on-accent)}.scene-location-switcher__counter{min-width:34px;color:var(--color-text);font-size:var(--font-xs);font-variant-numeric:tabular-nums;place-items:center;font-weight:900;display:inline-grid}.scene-tile ol{gap:var(--space-1);grid-template-columns:repeat(2,minmax(0,1fr));margin:0;padding:0;list-style:none;display:grid}.scene-board-shell--expanded .scene-tile ol,.scene-board-shell--collapsed .scene-tile ol{grid-template-columns:1fr}.scene-tile li{display:block}.scene-tile li button{border:1px solid var(--color-line);border-radius:var(--radius-sm);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface-3);width:100%;min-height:32px;color:var(--color-text);text-align:left;font-size:var(--font-xs);font-weight:500;line-height:var(--leading-snug);overflow-wrap:anywhere;white-space:normal;transition:border-color var(--duration-fast) var(--easing-out), background-color var(--duration-fast) var(--easing-out), transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1);padding:5px 10px}.scene-tile li button:hover:not(:disabled){border-color:color-mix(in srgb, var(--color-accent) 60%, var(--color-line));background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 14%, transparent), transparent 60%), var(--color-surface-3);color:var(--color-text);transform:translate(2px)}.scene-tile li.selected button{border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 88%, #fff 12%), var(--color-accent));color:var(--color-on-accent);box-shadow:inset 0 1px 0 #ffffff38, 0 1px 2px #00000052, 0 0 12px var(--color-accent-soft);font-weight:700}.scene-tile li button:disabled{cursor:default;opacity:1}.home-theme-toggle-wrap{top:var(--space-3);right:var(--space-3);z-index:var(--z-sticky,5);position:absolute}.lobby-toolbar{justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.lobby-toolbar .start-checklist--top{margin-bottom:0}.lobby-toolbar__actions{align-items:center;gap:var(--space-2);flex:none;display:flex}.lobby-theme-toggle,.lobby-leave-toggle{flex:none}.location-pool-slider{gap:6px;display:grid}.location-pool-slider__row{align-items:center;gap:var(--space-3);display:flex}.location-pool-slider__input{min-width:0;height:4px;accent-color:var(--color-accent);cursor:pointer;flex:auto}.location-pool-slider__value{text-align:right;min-width:56px;color:var(--color-text);font-family:var(--font-display);letter-spacing:.04em;font-weight:700;font-size:calc(13px * var(--app-text-scale,1));flex:none}.scene-tile li.selected button:before{content:"";width:8px;height:8px;margin-right:var(--space-2);border-radius:var(--radius-pill);background:var(--color-on-accent);vertical-align:middle;box-shadow:0 0 0 2px color-mix(in srgb, var(--color-on-accent) 30%, transparent);display:inline-block}.scene-actions{justify-content:center;gap:var(--space-2);display:flex}.scene-actions .expand-forensic{border-color:var(--color-line);min-width:130px;min-height:32px;color:var(--color-text);background:0 0;font-weight:600}.scene-actions .expand-forensic:hover:not(:disabled){background:var(--color-surface-2)}.scene-status-row{justify-content:space-between;align-items:center;gap:var(--space-2);border:1px solid color-mix(in srgb, var(--color-accent) 25%, var(--color-line));border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 6%, transparent), transparent 50%), var(--color-surface-2);padding:var(--space-2) var(--space-3);box-shadow:var(--shadow-1);flex-wrap:wrap;display:flex}.scene-status-row p{min-width:180px;color:var(--color-text-muted);font-size:var(--font-sm);line-height:var(--leading-snug);flex:260px;margin:0}.scene-confirm-row{margin-top:var(--space-2);justify-content:flex-end;display:flex}.card-grid,.player-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(420px,1fr));max-width:none;display:grid}.card-grid--horizontal,.player-grid.card-grid--horizontal{--game-card-width:96px;--cards-per-type-count:4;--player-panel-min-width:calc(var(--game-card-width) * var(--cards-per-type-count) + 28px);grid-template-columns:repeat(auto-fit, minmax(min(100%, var(--player-panel-min-width)), 1fr));place-content:flex-start center;align-items:start;gap:var(--space-2);display:grid}.card-grid--horizontal[data-cards-per-type="5"],.card-grid--horizontal[data-cards-per-type="6"],.card-grid--horizontal[data-cards-per-type="7"]{--game-card-width:72px}.card-grid--horizontal[data-cards-per-type="3"]{--cards-per-type-count:3}.card-grid--horizontal[data-cards-per-type="5"]{--cards-per-type-count:5}.card-grid--horizontal[data-cards-per-type="6"]{--cards-per-type-count:6}.card-grid--horizontal[data-cards-per-type="7"]{--cards-per-type-count:7}.card-owner,.player-grid .player{--player-color:var(--color-primary);align-content:start;gap:var(--space-1);border:1px solid color-mix(in srgb, var(--player-color) 70%, var(--color-line));border-left:4px solid var(--player-color);border-radius:var(--radius-lg);background:var(--color-surface);min-width:0;padding:var(--space-2);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--player-color) 28%, transparent);transition:border-color var(--duration-fast) var(--easing-out), box-shadow var(--duration-fast) var(--easing-out), transform var(--duration-fast) var(--easing-out);display:grid}.card-grid--horizontal .card-owner,.player-grid.card-grid--horizontal .player{width:100%;max-width:none}.card-owner--frame-action.card-owner--active-target{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent), 0 0 0 7px var(--color-accent-soft), inset 0 0 0 2px var(--color-accent), var(--shadow-2)}.card-owner--own-profile{border:2px solid var(--player-color);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--player-color) 35%, transparent), 0 0 0 1px color-mix(in srgb, var(--player-color) 22%, transparent), 0 0 18px color-mix(in srgb, var(--player-color) 28%, transparent), var(--shadow-2)}.card-owner--own-profile .player-avatar{box-shadow:0 0 0 2px var(--color-surface), 0 0 0 4px color-mix(in srgb, var(--player-color) 78%, #fff 22%), 0 0 14px color-mix(in srgb, var(--player-color) 52%, transparent)}.own-player-badge{border:1px solid color-mix(in srgb, var(--player-color) 82%, #fff 18%);border-radius:var(--radius-pill);background:color-mix(in srgb, var(--player-color) 78%, transparent);color:#fff;min-height:20px;font-size:calc(10px * var(--app-text-scale,1));text-transform:uppercase;white-space:nowrap;align-items:center;padding:1px 7px;font-weight:900;line-height:1;display:inline-flex}.player-status-badge{border-radius:var(--radius-pill);width:fit-content;min-height:20px;font-size:calc(10px * var(--app-text-scale,1));letter-spacing:0;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;gap:4px;padding:1px 7px;font-weight:900;line-height:1;display:inline-flex}.player-status-badge svg{flex:none}.player-status-badge--identity{border-color:color-mix(in srgb, var(--player-color) 82%, #fff 18%);background:color-mix(in srgb, var(--player-color) 78%, transparent);color:#fff}.player-status-badge--danger{background:var(--color-danger);color:#fff;box-shadow:0 0 0 2px var(--color-danger-soft)}.player-status-badge--support{background:color-mix(in srgb, var(--color-info) 28%, var(--color-surface-2));color:color-mix(in srgb, var(--color-info) 86%, #fff 14%);box-shadow:0 0 0 2px var(--color-info-soft)}.player-status-badge--suspect{background:var(--color-suspect);color:#1a1303;box-shadow:0 0 0 2px var(--color-suspect-soft)}.player-status-badge--solution-hidden,.player-status-badge--murder-hidden,.player-status-badge--culprit-hidden,.player-status-badge--ally-hidden{display:none}.card-owner--identity-own .player-avatar{box-shadow:0 0 0 3px var(--color-surface), 0 0 0 6px color-mix(in srgb, var(--player-color) 86%, #fff 14%), 0 0 18px color-mix(in srgb, var(--player-color) 48%, transparent)}.card-owner--frame-crime.card-owner--own-hand{border-left-color:var(--color-danger);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--color-danger) 35%, transparent), var(--shadow-2);border-left-width:6px}.card-owner--own-hand .card-owner-header{background:linear-gradient(90deg, color-mix(in srgb, var(--color-danger) 26%, transparent), transparent 70%), color-mix(in srgb, var(--color-danger) 14%, var(--color-surface-2));border-bottom-color:color-mix(in srgb, var(--color-danger) 50%, var(--color-line-soft))}.card-owner--dimmed{opacity:.45;pointer-events:none;filter:grayscale(.4)}.card-owner--frame-candidate.card-owner--ability-targetable{border-color:var(--color-warn);box-shadow:0 0 0 3px var(--color-warn-soft), inset 0 0 0 2px color-mix(in srgb, var(--color-warn) 72%, transparent), var(--shadow-2)}.card-owner--frame-action.card-owner--ability-selected{border-color:var(--color-warn);box-shadow:0 0 0 2px var(--color-warn), 0 0 0 4px var(--color-warn-soft), inset 0 0 0 1px var(--color-warn), var(--shadow-2);border-width:2px}.card-owner--facilitator{border-left-color:var(--color-accent);background:linear-gradient(180deg, var(--color-accent-soft), transparent 60%), var(--color-surface)}.card-owner-header,.player-grid .card-owner-header{margin:calc(var(--space-2) * -1) calc(var(--space-2) * -1) 0;border-bottom:1px solid var(--color-line-soft);border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:color-mix(in srgb, var(--player-color) 14%, var(--color-surface-2));grid-template-columns:auto minmax(0,1fr) repeat(4,auto);align-items:center;gap:6px;min-height:48px;padding:4px 10px;display:grid}.player-avatar-wrap{width:36px;height:36px;position:relative}.player-avatar{border-radius:var(--radius-pill);background:var(--player-color);color:#fff;width:36px;min-width:36px;height:36px;min-height:36px;font-family:var(--font-display);font-weight:700;font-size:var(--font-md);border:0;place-items:center;line-height:1;display:grid;overflow:hidden;box-shadow:0 1px 3px #00000059,inset 0 1px #ffffff2e}.player-color-dot.player-avatar{border:0;place-items:center;width:36px;min-width:36px;height:36px;min-height:36px;display:grid;overflow:hidden}.player-color-dot.player-avatar img{object-fit:cover;width:100%;height:100%;display:block}.known-culprit-marker,.known-murder-team-marker{border:2px solid var(--color-surface);border-radius:var(--radius-pill);width:20px;height:20px;position:absolute;top:-4px;right:-4px}.known-murder-team-marker{background:var(--color-danger);box-shadow:0 0 0 1px var(--color-danger-soft), 0 0 6px color-mix(in srgb, var(--color-danger) 60%, transparent), 0 0 12px color-mix(in srgb, var(--color-danger) 45%, transparent)}.known-culprit-marker{background:var(--color-suspect);box-shadow:0 0 0 1px var(--color-suspect-soft), 0 0 6px color-mix(in srgb, var(--color-suspect) 60%, transparent), 0 0 12px color-mix(in srgb, var(--color-suspect) 45%, transparent)}.known-ally-marker{border:2px solid var(--color-surface);border-radius:var(--radius-pill);background:var(--color-info);width:20px;height:20px;box-shadow:0 0 0 1px var(--color-info-soft), 0 0 6px color-mix(in srgb, var(--color-info) 60%, transparent), 0 0 12px color-mix(in srgb, var(--color-info) 45%, transparent);position:absolute;bottom:-4px;right:-4px}@keyframes role-pulse-danger{0%,to{outline:2px solid color-mix(in srgb, var(--color-danger) 55%, transparent);outline-offset:2px}50%{outline:3px solid var(--color-danger);outline-offset:4px}}@keyframes role-pulse-suspect{0%,to{outline:2px solid color-mix(in srgb, var(--color-suspect) 55%, transparent);outline-offset:2px}50%{outline:3px solid var(--color-suspect);outline-offset:4px}}@keyframes role-pulse-protection{0%,to{outline:2px solid color-mix(in srgb, var(--color-info) 55%, transparent);outline-offset:2px}50%{outline:3px solid var(--color-info);outline-offset:4px}}@media (prefers-reduced-motion:reduce){.card-owner--frame-protection.known-ally,.card-owner--frame-danger.known-culprit,.card-owner--frame-danger.known-murder-team{animation:none}}.final-shot-banner{background:linear-gradient(135deg, color-mix(in srgb, var(--color-danger) 18%, transparent), color-mix(in srgb, var(--color-danger) 6%, transparent));border:2px solid var(--color-danger);margin-bottom:var(--space-3,12px);padding:var(--space-3,12px) var(--space-4,16px);text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:4px;animation:2s ease-in-out infinite role-pulse-danger;display:flex}@media (prefers-reduced-motion:reduce){.final-shot-banner{animation:none}}.final-shot-banner__headline{letter-spacing:.02em;font-size:1.25rem}.final-shot-banner__subline{opacity:.85;font-size:.9rem}.card-owner--frame-danger.known-murder-team{border-color:color-mix(in srgb, var(--color-danger) 60%, var(--color-line));border-left-color:var(--color-danger);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--color-danger) 35%, transparent), var(--shadow-2);border-left-width:6px;animation:2s ease-in-out infinite role-pulse-danger}.card-owner--frame-danger.known-culprit{border-color:color-mix(in srgb, var(--color-suspect) 60%, var(--color-line));border-left-color:var(--color-suspect);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--color-suspect) 35%, transparent), var(--shadow-2);border-left-width:6px;animation:2s ease-in-out infinite role-pulse-suspect}.team-indicator{border-radius:var(--radius-pill);min-height:20px;font-size:calc(10px * var(--app-text-scale,1));letter-spacing:0;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;padding:1px 7px;font-weight:900;line-height:1;display:inline-flex}.team-indicator--murder{background:var(--color-danger);color:#fff;box-shadow:0 0 0 2px var(--color-danger-soft)}.known-murder-team .card-owner-header{background:linear-gradient(90deg, color-mix(in srgb, var(--color-danger) 32%, transparent), transparent 70%), color-mix(in srgb, var(--color-danger) 18%, var(--color-surface-2));border-bottom-color:color-mix(in srgb, var(--color-danger) 50%, var(--color-line-soft))}.known-culprit .card-owner-header{background:linear-gradient(90deg, color-mix(in srgb, var(--color-suspect) 32%, transparent), transparent 70%), color-mix(in srgb, var(--color-suspect) 18%, var(--color-surface-2));border-bottom-color:color-mix(in srgb, var(--color-suspect) 50%, var(--color-line-soft))}.card-owner--frame-protection.known-ally{border-color:var(--color-info);border-left-color:var(--player-color);outline:2px solid color-mix(in srgb, var(--color-info) 76%, #fff 24%);outline-offset:2px;box-shadow:0 0 0 4px var(--color-info-soft), inset 0 0 0 3px color-mix(in srgb, var(--color-info) 70%, transparent), var(--shadow-2);border-width:2px 2px 2px 8px;animation:2s ease-in-out infinite role-pulse-protection}.known-ally .card-owner-header{background:linear-gradient(90deg, color-mix(in srgb, var(--player-color) 20%, transparent), transparent 46%), color-mix(in srgb, var(--color-info) 14%, var(--color-surface-2))}.card-owner--frame-truth.card-owner--solution-player{border-color:color-mix(in srgb, var(--color-accent) 60%, var(--color-line));border-left-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent-soft), inset 0 0 0 1px color-mix(in srgb, var(--color-accent) 45%, transparent), 0 0 24px color-mix(in srgb, var(--color-accent) 35%, transparent), var(--shadow-2);border-left-width:6px}.card-owner--solution-player .card-owner-header{background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 28%, transparent), color-mix(in srgb, var(--color-accent) 6%, transparent) 90%), color-mix(in srgb, var(--color-accent) 14%, var(--color-surface-2));border-bottom-color:var(--color-accent)}.card-owner--own-profile .card-owner-header{background:repeating-linear-gradient(135deg, color-mix(in srgb, var(--player-color) 18%, transparent) 0 6px, transparent 6px 14px), linear-gradient(90deg, color-mix(in srgb, var(--player-color) 36%, transparent), transparent 70%), color-mix(in srgb, var(--player-color) 22%, var(--color-surface-2))}.remove-player-btn{border:1px solid var(--color-danger);border-radius:var(--radius-pill);background:var(--color-danger-soft);width:28px;height:28px;color:var(--color-danger);appearance:none;justify-content:center;align-items:center;padding:0;line-height:0;display:inline-flex}.remove-player-btn svg{flex:none;margin:0;display:block}.ability-player-target-btn{border:1.5px solid var(--color-warn);border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-warn) 28%, transparent), transparent 60%), var(--color-warn-soft);min-width:92px;min-height:36px;color:var(--color-warn);font-size:calc(12px * var(--app-text-scale,1));letter-spacing:.04em;appearance:none;cursor:pointer;z-index:2;transition:background-color var(--duration-fast) var(--easing-out), border-color var(--duration-fast) var(--easing-out), color var(--duration-fast) var(--easing-out), transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1);justify-content:center;align-items:center;padding:0 14px;font-weight:800;line-height:1;display:inline-flex;position:relative;box-shadow:inset 0 1px #ffffff0f,0 1px 2px #00000052}.ability-player-target-btn:hover:not(:disabled){background:linear-gradient(180deg, color-mix(in srgb, var(--color-warn) 92%, #fff 8%), var(--color-warn));color:#1a1303;box-shadow:inset 0 1px 0 #ffffff38, 0 4px 12px color-mix(in srgb, var(--color-warn) 35%, transparent);transform:translateY(-1px)}.card-owner--ability-selected .ability-player-target-btn{background:linear-gradient(180deg, color-mix(in srgb, var(--color-warn) 92%, #fff 8%), var(--color-warn));color:#1a1303;box-shadow:inset 0 1px #ffffff38,0 1px 2px #00000052}@media (prefers-reduced-motion:reduce){.ability-player-target-btn:hover:not(:disabled){transform:none}}.ability-pill{border:1px solid color-mix(in srgb, var(--color-accent) 42%, var(--color-line));border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 10%, transparent), transparent 60%), var(--color-surface-2);color:var(--color-text);font-size:calc(11px * var(--app-text-scale,1));letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:background-color var(--duration-fast) var(--easing-out), border-color var(--duration-fast) var(--easing-out), color var(--duration-fast) var(--easing-out), transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1);align-items:center;gap:5px;padding:4px 10px;font-weight:700;display:inline-flex}.ability-pill__label{white-space:nowrap}.ability-pill--inside{border-color:color-mix(in srgb, var(--color-danger) 50%, var(--color-line));background:linear-gradient(180deg, color-mix(in srgb, var(--color-danger) 12%, transparent), transparent 60%), var(--color-surface-2)}.ability-pill--idle:hover{border-color:var(--color-accent);transform:translateY(-1px)}.ability-pill--inside.ability-pill--idle:hover{border-color:var(--color-danger)}.ability-pill--armed{background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 88%, #fff 12%), var(--color-accent));color:var(--color-on-accent);border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-soft);animation:1.6s ease-in-out infinite ability-pill-pulse}.ability-pill--inside.ability-pill--armed{background:linear-gradient(180deg, color-mix(in srgb, var(--color-danger) 92%, #fff 8%), var(--color-danger));color:#fff;border-color:var(--color-danger);box-shadow:0 0 0 2px var(--color-danger-soft)}@keyframes ability-pill-pulse{0%,to{box-shadow:0 0 0 2px var(--color-accent-soft)}50%{box-shadow:0 0 0 4px var(--color-accent-soft)}}.ability-pill--inside.ability-pill--armed{animation-name:ability-pill-pulse-danger}@keyframes ability-pill-pulse-danger{0%,to{box-shadow:0 0 0 2px var(--color-danger-soft)}50%{box-shadow:0 0 0 4px var(--color-danger-soft)}}.ability-pill--selected{cursor:default;border-color:var(--color-accent);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 22%, transparent), transparent 60%), var(--color-surface-2);padding:3px 4px 3px 10px}.ability-pill--inside.ability-pill--selected{border-color:var(--color-danger);background:linear-gradient(180deg, color-mix(in srgb, var(--color-danger) 22%, transparent), transparent 60%), var(--color-surface-2)}.ability-pill__confirm,.ability-pill__cancel{border-radius:var(--radius-pill);cursor:pointer;width:22px;height:22px;transition:background-color var(--duration-fast) var(--easing-out), transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1);border:1px solid #0000;justify-content:center;align-items:center;padding:0;display:inline-flex}.ability-pill__confirm{background:var(--color-success);color:#04220e;border-color:var(--color-success)}.ability-pill__confirm:hover{transform:scale(1.08)}.ability-pill__cancel{color:var(--color-text-muted);border-color:var(--color-line);background:0 0}.ability-pill__cancel:hover{color:var(--color-danger);border-color:var(--color-danger)}.ability-pill--used{cursor:default}.ability-pill--success{border-color:var(--color-success);background:linear-gradient(180deg, color-mix(in srgb, var(--color-success) 18%, transparent), transparent 60%), var(--color-surface-2);color:var(--color-success)}.ability-pill--muted{border-color:var(--color-line);background:var(--color-surface-2);color:var(--color-text-muted)}.ability-pill--danger{border-color:var(--color-danger);background:linear-gradient(180deg, color-mix(in srgb, var(--color-danger) 18%, transparent), transparent 60%), var(--color-surface-2);color:var(--color-danger)}@media (prefers-reduced-motion:reduce){.ability-pill--idle:hover{transform:none}.ability-pill--armed{animation:none}}.final-shot-btn{border:1px solid var(--color-danger);border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-danger) 92%, #fff 8%), var(--color-danger));color:#fff;font-size:calc(11px * var(--app-text-scale,1));letter-spacing:.06em;text-transform:uppercase;cursor:pointer;box-shadow:0 0 0 2px var(--color-danger-soft), 0 4px 10px #ef444459;transition:transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1);align-items:center;gap:5px;padding:4px 10px;font-weight:800;animation:1.6s ease-in-out infinite final-shot-pulse;display:inline-flex}.final-shot-btn:hover{filter:brightness(1.08);transform:translateY(-1px)scale(1.04)}@keyframes final-shot-pulse{0%,to{box-shadow:0 0 0 2px var(--color-danger-soft), 0 4px 10px #ef444452}50%{box-shadow:0 0 0 5px var(--color-danger-soft), 0 6px 14px #ef44446b}}@media (prefers-reduced-motion:reduce){.final-shot-btn{animation:none}.final-shot-btn:hover{transform:none}}.revealed-role{border-radius:var(--radius-pill);width:fit-content;color:var(--color-danger);background:var(--color-danger-soft);font-size:calc(10px * var(--app-text-scale,1));letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;margin-top:0;padding:1px 7px;font-weight:700;display:inline-flex}.revealed-role--investigator,.revealed-role--lab_technician,.revealed-role--protective_detail,.revealed-role--consulting_detective,.revealed-role--witness{color:var(--color-info);background:var(--color-info-soft)}.suspect-badge,.ally-badge{border-radius:var(--radius-pill);font-size:calc(10px * var(--app-text-scale,1));letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;gap:4px;margin-top:2px;padding:1px 7px;font-weight:700;display:inline-flex}.suspect-badge{color:var(--color-danger);background:var(--color-danger-soft)}.ally-badge{color:var(--color-info);background:var(--color-info-soft)}.badge-indicator{border-radius:var(--radius-pill);font-size:calc(10px * var(--app-text-scale,1));letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;gap:4px;margin-top:0;padding:1px 7px;font-weight:700;display:inline-flex}.badge-indicator--available{color:var(--color-accent);background:var(--color-accent-soft)}.badge-indicator--spent{color:var(--color-text-muted);background:var(--color-surface-3);text-decoration:line-through}.badge-indicator--removed{color:var(--color-warn);background:var(--color-warn-soft)}.suspect-list{gap:var(--space-2);margin:0;padding:0;list-style:none;display:grid}.suspect-list li{--player-color:var(--color-suspect,var(--color-warn));align-items:center;gap:var(--space-3);border:1px solid color-mix(in srgb, var(--color-suspect) 60%, var(--color-line));border-left:4px solid var(--player-color);border-radius:var(--radius-md);background:linear-gradient(135deg, color-mix(in srgb, var(--color-suspect) 18%, transparent), transparent 65%), var(--color-surface-2);padding:var(--space-2) var(--space-3);box-shadow:var(--shadow-1);grid-template-columns:auto minmax(0,1fr) auto;display:grid}.suspect-list--ally li{--player-color:var(--color-info);border-color:color-mix(in srgb, var(--color-info) 55%, var(--color-line));background:linear-gradient(135deg, color-mix(in srgb, var(--color-info) 16%, transparent), transparent 65%), var(--color-surface-2)}.suspect-list__avatar{border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--player-color) 92%, #fff 8%), var(--player-color));color:#fff;width:36px;height:36px;font-family:var(--font-display);font-weight:700;font-size:var(--font-md);place-items:center;display:grid;box-shadow:inset 0 1px #ffffff2e,0 2px 6px #00000052}.suspect-list__name{min-width:0;font-family:var(--font-display);font-size:var(--font-md);text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.suspect-list__icon{color:var(--player-color);flex:none}.player-name{align-content:center;gap:1px;min-width:0;display:grid}.player-name h3{font-family:var(--font-display);font-size:var(--font-sm);text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.005em;margin:0;font-weight:700;overflow:hidden}.player-name p{clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.card-owner--disconnected .player-avatar{filter:grayscale(.7);opacity:.7}.card-owner--disconnected .player-name h3{color:var(--color-text-muted)}.card-owner--disconnected{opacity:.78}.player-meta-row{flex-wrap:wrap;align-items:center;gap:3px;min-width:0;min-height:20px;display:flex}.player-color-dot{border:2px solid var(--color-surface);border-radius:var(--radius-pill);background:var(--player-color);width:12px;height:12px;box-shadow:0 0 0 1px var(--color-line-soft);flex:none}.accuse-btn{border:1px solid var(--color-accent);border-radius:var(--radius-md);background:var(--color-accent);min-height:32px;color:var(--color-on-accent);padding:0 var(--space-3);font-size:var(--font-xs);letter-spacing:.04em;text-transform:uppercase;font-weight:700}.accuse-btn:hover:not(:disabled){background:var(--color-accent-hover);border-color:var(--color-accent-hover)}.accuse-btn--header{white-space:nowrap;align-self:center;min-width:0;min-height:28px;padding:0 10px}.crime-card-confirm{border:1px solid var(--color-danger);border-radius:var(--radius-pill);background:var(--color-danger);width:34px;height:34px;color:var(--color-on-accent);appearance:none;justify-content:center;align-items:center;padding:0;line-height:0;display:inline-flex}.crime-card-confirm svg{flex:none;margin:0;display:block}.crime-card-confirm:disabled{cursor:not-allowed;opacity:.35}.facilitator-note{align-content:center;gap:var(--space-1);border:1px dashed var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);min-height:88px;color:var(--color-text-muted);padding:var(--space-3);display:grid}.facilitator-note strong{color:var(--color-accent)}.facilitator-note span{line-height:var(--leading-snug);font-size:var(--font-sm)}.card-type-columns{gap:var(--space-2);grid-template-columns:1fr;display:grid}.card-type-column{grid-template-columns:minmax(0,1fr);align-content:start;align-items:start;gap:4px;min-width:0;display:grid}.card-type-column h4{clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;margin:-1px;position:absolute;overflow:hidden}.card-list{scrollbar-width:none;scroll-snap-type:none;grid-auto-columns:minmax(0,1fr);grid-auto-flow:column;gap:0;min-width:0;padding:0;display:grid;overflow:visible}.card-grid--horizontal .card-list{grid-template-columns:repeat(var(--cards-per-type-count), minmax(var(--game-card-width), 1fr));grid-auto-columns:minmax(var(--game-card-width), 1fr);scrollbar-width:none;width:100%;max-width:none;overflow-x:visible}.card-grid--horizontal .game-card-shell{width:100%}.card-grid--horizontal .card-type-columns{width:100%;max-width:none}.card-list::-webkit-scrollbar{height:6px}.card-list::-webkit-scrollbar-thumb{background:var(--color-line);border-radius:var(--radius-pill)}.game-card{align-content:start;gap:var(--space-1);border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface-2);min-width:0;min-height:64px;color:var(--color-text);text-align:left;font-size:var(--font-sm);font-weight:500;line-height:var(--leading-snug);padding:8px 12px;display:grid}.game-card>span:first-child,.game-card .card-title{overflow-wrap:anywhere;font-size:var(--font-sm);font-weight:600;line-height:var(--leading-snug);max-height:36px;color:var(--color-text);overflow:hidden}.game-card small{color:var(--color-text-muted);font-size:var(--font-xs)}.game-card--clue{border-color:var(--color-clue-edge);background:linear-gradient(135deg, color-mix(in srgb, var(--color-clue-edge) 30%, transparent), transparent 58%), var(--color-surface-2);box-shadow:inset 0 4px 0 var(--color-clue-edge), inset 0 -5px 0 var(--color-clue-edge), inset 0 0 0 1px color-mix(in srgb, var(--color-clue-edge) 66%, transparent)}.game-card--means{border-color:var(--color-means-edge);background:linear-gradient(135deg, color-mix(in srgb, var(--color-means-edge) 34%, transparent), transparent 58%), var(--color-surface-2);box-shadow:inset 0 4px 0 var(--color-means-edge), inset 0 -5px 0 var(--color-means-edge), inset 0 0 0 1px color-mix(in srgb, var(--color-means-edge) 66%, transparent)}.game-card--clue .card-title{background:color-mix(in srgb, var(--color-clue-edge) 24%, var(--color-surface-2));border-bottom:1px solid color-mix(in srgb, var(--color-clue-edge) 56%, transparent)}.game-card--means .card-title{background:color-mix(in srgb, var(--color-means-edge) 26%, var(--color-surface-2));border-bottom:1px solid color-mix(in srgb, var(--color-means-edge) 56%, transparent)}@keyframes solution-pulse{0%,to{box-shadow:0 0 0 3px var(--color-warn), 0 0 16px 3px color-mix(in srgb, var(--color-warn) 65%, transparent), inset 0 0 0 1px color-mix(in srgb, var(--color-warn) 60%, transparent)}50%{box-shadow:0 0 0 3px var(--color-warn), 0 0 26px 6px color-mix(in srgb, var(--color-warn) 85%, transparent), inset 0 0 0 2px color-mix(in srgb, var(--color-warn) 75%, transparent)}}.game-card.highlighted{border-color:var(--color-warn);background:linear-gradient(135deg, color-mix(in srgb, var(--color-warn) 32%, transparent), color-mix(in srgb, var(--color-warn) 10%, transparent) 55%, transparent 90%), var(--color-surface-2);z-index:2;border-width:3px;animation:1.8s ease-in-out infinite solution-pulse;position:relative}.game-card.highlighted:after{content:"★";background:var(--color-warn);color:#1a1300;width:18px;height:18px;font-size:calc(12px * var(--app-text-scale,1));z-index:4;pointer-events:none;border-radius:50%;justify-content:center;align-items:center;font-weight:800;line-height:1;display:flex;position:absolute;bottom:4px;left:6px;box-shadow:0 0 0 1px #00000080,0 2px 6px #0000008c}@media (prefers-reduced-motion:reduce){.game-card.highlighted{box-shadow:0 0 0 3px var(--color-warn), 0 0 16px 3px color-mix(in srgb, var(--color-warn) 65%, transparent), inset 0 0 0 2px color-mix(in srgb, var(--color-warn) 65%, transparent);animation:none}}.game-card.accuse-selected,.game-card--solve-selected{border-color:var(--color-accent);outline:2px solid var(--color-accent);outline-offset:-5px;background:linear-gradient(135deg, color-mix(in srgb, var(--color-accent) 22%, transparent), transparent 68%), var(--color-surface-2);box-shadow:0 0 0 3px var(--color-accent-soft), inset 0 0 0 1px var(--color-accent);border-width:2px}@keyframes murder-selected-pulse{0%,to{box-shadow:0 0 0 3px var(--color-danger), 0 0 18px 4px color-mix(in srgb, var(--color-danger) 70%, transparent), inset 0 0 0 1px color-mix(in srgb, var(--color-danger) 60%, transparent)}50%{box-shadow:0 0 0 3px var(--color-danger), 0 0 28px 8px color-mix(in srgb, var(--color-danger) 90%, transparent), inset 0 0 0 2px color-mix(in srgb, var(--color-danger) 80%, transparent)}}.game-card--murder-selected{border-color:var(--color-danger);background:linear-gradient(135deg, color-mix(in srgb, var(--color-danger) 35%, transparent), color-mix(in srgb, var(--color-danger) 12%, transparent) 55%, transparent 90%), var(--color-surface-2);z-index:2;border-width:3px;animation:1.5s ease-in-out infinite murder-selected-pulse;position:relative}.game-card--murder-selected:after{content:"✕";background:var(--color-danger);color:#fff;width:18px;height:18px;font-size:calc(12px * var(--app-text-scale,1));z-index:4;pointer-events:none;border-radius:50%;justify-content:center;align-items:center;font-weight:800;line-height:1;display:flex;position:absolute;bottom:4px;left:6px;box-shadow:0 0 0 1px #00000080,0 2px 6px #0000008c}@media (prefers-reduced-motion:reduce){.game-card--murder-selected{box-shadow:0 0 0 3px var(--color-danger), 0 0 18px 4px color-mix(in srgb, var(--color-danger) 70%, transparent), inset 0 0 0 2px color-mix(in srgb, var(--color-danger) 70%, transparent);animation:none}}.game-card--solution{border-color:var(--color-accent);border-left-width:4px;border-left-color:var(--color-accent-hover);background:linear-gradient(135deg, color-mix(in srgb, var(--color-accent) 22%, transparent), transparent 62%), var(--color-surface-2);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--color-accent) 55%, transparent), 0 0 12px var(--color-accent-soft);position:relative}.game-card--solution:after{content:"★";color:var(--color-accent-hover);font-size:calc(13px * var(--app-text-scale,1));text-shadow:0 0 6px #000000b3;z-index:4;pointer-events:none;line-height:1;position:absolute;bottom:4px;left:5px}.game-card--selectable{border-color:var(--color-info);box-shadow:0 0 0 2px var(--color-info-soft);border-width:2px;animation:2s ease-in-out infinite pulse-selectable}.game-card--ability-target{border-color:var(--color-warn);box-shadow:0 0 0 2px var(--color-warn-soft), inset 0 0 0 1px color-mix(in srgb, var(--color-warn) 60%, transparent);border-width:2px}.game-card--ability-selected{border-color:var(--color-warn);outline:2px solid var(--color-warn);outline-offset:-5px;box-shadow:0 0 0 3px var(--color-warn-soft), inset 0 0 0 2px var(--color-warn);border-width:2px}@keyframes pulse-selectable{0%,to{box-shadow:0 0 0 2px var(--color-info-soft)}50%{box-shadow:0 0 0 4px var(--color-info-soft)}}@media (prefers-reduced-motion:reduce){.game-card--selectable{box-shadow:0 0 0 3px var(--color-info-soft);animation:none}}.game-card--checked{border-color:var(--color-success);box-shadow:inset 0 0 0 2px var(--color-success-soft)}.game-card:hover:not(:disabled){border-color:var(--color-accent);transform:translateY(-1px)}.game-card-shell{scroll-snap-align:start;min-width:0;min-height:0;position:relative;overflow:visible}.game-card-shell .game-card{width:100%;height:64px;min-height:64px;padding:8px 36px 8px 12px}.game-card-shell .game-card:has(.card-image-frame){grid-template-rows:42px auto;gap:0;height:auto;min-height:0;padding:0;overflow:hidden}.game-card-shell .card-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;height:42px;max-height:42px;padding:7px 8px 0;display:-webkit-box;overflow:hidden}.card-image-frame{touch-action:manipulation;-webkit-user-select:none;user-select:none;background:0 0;border:0;border-radius:0;width:100%;height:auto;display:block;overflow:hidden}.card-image{object-fit:contain;object-position:center;-webkit-user-select:none;user-select:none;width:100%;height:auto;display:block}.card-image-placeholder{background:var(--color-surface-2,#1a1c20);border:1px dashed var(--color-line,#3a3d44);color:var(--color-text-muted,#6c7280);border-radius:8px;justify-content:center;align-items:center;width:100%;height:100%;min-height:96px;font-size:1.5rem;display:flex}.card-image-placeholder.card-image{aspect-ratio:1;height:auto;min-height:80px}.card-grid--horizontal .game-card-shell .game-card:has(.card-image-frame){grid-template-rows:36px auto;gap:0;height:auto;min-height:0;padding:0}.card-grid--horizontal .game-card-shell .card-title{height:36px;max-height:36px;font-size:var(--font-xs);line-height:var(--leading-tight);padding:4px 6px 0}.game-card-shell .card-title--long,.card-grid--horizontal .game-card-shell .card-title--long{font-size:calc(11px * var(--app-text-scale,1));line-height:1.08}.game-card-shell .card-title--very-long,.card-grid--horizontal .game-card-shell .card-title--very-long{font-size:calc(10px * var(--app-text-scale,1));line-height:1.05}.card-grid--horizontal .card-image{object-fit:contain;object-position:center;height:auto}.lab-card-result{z-index:2;border-radius:var(--radius-pill);background:var(--color-surface);max-width:calc(100% - 10px);min-height:20px;font-size:calc(10px * var(--app-text-scale,1));letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;padding:1px 8px;font-weight:800;line-height:1;animation:.36s cubic-bezier(.34,1.56,.64,1) lab-result-stamp;display:inline-flex;position:absolute;bottom:5px;right:5px;box-shadow:inset 0 1px #ffffff1a,0 1px 3px #00000052}.lab-card-result--hit{color:#062014;background:linear-gradient(180deg, color-mix(in srgb, var(--color-success) 92%, #fff 8%), var(--color-success));border-color:var(--color-success);box-shadow:inset 0 1px 0 #ffffff2e, 0 0 0 1px var(--color-success-soft), 0 0 14px color-mix(in srgb, var(--color-success) 38%, transparent)}.lab-card-result--miss{color:var(--color-text-2,var(--color-text-muted));background:var(--color-surface-2);border-color:var(--color-line)}@keyframes lab-result-stamp{0%{opacity:0;transform:scale(1.6)rotate(-6deg)}55%{opacity:1;transform:scale(.94)rotate(1deg)}to{transform:scale(1)rotate(0)}}.ability-panel-actions{gap:var(--space-2);flex-wrap:wrap;align-items:center;display:flex}.game-card-shell .mark-row{z-index:2;position:absolute;bottom:4px;left:6px;right:6px}.mark-row{pointer-events:none;gap:4px;min-height:12px;display:flex}.mark-row i{border-radius:var(--radius-pill);background:var(--color-accent);flex:18px;max-width:42px;height:9px;box-shadow:0 0 0 1.5px #ffffffeb,0 0 0 2.5px #0000008c,0 1px 2px #00000073}.card-image-preview{z-index:1000;padding:var(--space-4);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#050714bd;place-items:center;display:grid;position:fixed;inset:0}.card-image-preview__figure{gap:var(--space-3);width:min(520px,92vw);padding:var(--space-4);border:1px solid var(--color-line);border-radius:var(--radius-lg);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 50%), var(--color-surface);box-shadow:var(--shadow-3);margin:0;display:grid;position:relative}.card-image-preview__figure figcaption{color:var(--color-text);font-family:var(--font-display);letter-spacing:-.01em;font-size:clamp(1.25rem,3vw,2rem);font-weight:700;line-height:1.1}.card-image-preview__figure img{object-fit:contain;border-radius:var(--radius-md);width:100%;max-height:70vh}.public-event-toast{--toast-tone:var(--color-warn);right:max(var(--space-4), env(safe-area-inset-right));bottom:max(var(--space-4), env(safe-area-inset-bottom));z-index:var(--z-toast);max-width:min(380px, calc(100vw - var(--space-8)));border:1px solid color-mix(in srgb, var(--toast-tone) 65%, var(--color-line));border-radius:var(--radius-lg);background:linear-gradient(135deg, color-mix(in srgb, var(--toast-tone) 22%, transparent), transparent 65%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 4%, transparent), transparent 50%), color-mix(in srgb, var(--color-surface) 90%, transparent);-webkit-backdrop-filter:blur(12px)saturate(1.1);color:var(--color-text);font-size:var(--font-sm);font-weight:700;line-height:var(--leading-snug);letter-spacing:-.005em;box-shadow:inset 0 1px 0 #ffffff1a, 0 2px 6px #00000052, 0 18px 46px #00000057, 0 0 28px color-mix(in srgb, var(--toast-tone) 22%, transparent);padding:12px 16px;animation:.32s cubic-bezier(.34,1.56,.64,1) public-toast-rise;position:fixed}.public-event-toast--warn{--toast-tone:var(--color-warn)}.public-event-toast--danger{--toast-tone:var(--color-danger)}.public-event-toast--success{--toast-tone:var(--color-success)}.public-event-toast--accent{--toast-tone:var(--color-accent)}@keyframes public-toast-rise{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.public-event-toast,.card-pick--selected,.resolved-accusation-mark,.lab-card-result{animation:none}}.ghost-settings-snackbar{background:var(--color-success);color:var(--color-bg);z-index:var(--z-toast);box-shadow:var(--shadow-2);border-radius:8px;padding:10px 20px;font-weight:600;animation:3s ease-out forwards ghost-snackbar-fade;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@keyframes ghost-snackbar-fade{0%{opacity:0;transform:translate(-50%,12px)}10%{opacity:1;transform:translate(-50%)}90%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-8px)}}@media (prefers-reduced-motion:reduce){.ghost-settings-snackbar{opacity:1;animation:none;transform:translate(-50%)}}.card-image-preview__close{top:var(--space-4);right:var(--space-4);border:1px solid var(--color-line);border-radius:var(--radius-pill);background:var(--color-surface-2);width:44px;height:44px;color:var(--color-text);box-shadow:var(--shadow-2);cursor:pointer;transition:border-color var(--duration-fast) var(--easing-out), background-color var(--duration-fast) var(--easing-out);font-size:1.5rem;line-height:1;position:fixed}.card-image-preview__close:hover{border-color:var(--color-accent);background:var(--color-surface-3)}.card-pick{top:auto;left:auto;right:6px;bottom:calc(6px + var(--pick-offset,0px));z-index:3;border:1.5px solid var(--color-line);border-radius:var(--radius-pill);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 4%, transparent), transparent 50%), var(--color-surface);width:26px;min-width:26px;height:26px;min-height:26px;color:var(--color-text-muted);font-size:calc(14px * var(--app-text-scale,1));cursor:pointer;opacity:0;pointer-events:none;transition:background-color var(--duration-fast) var(--easing-out), border-color var(--duration-fast) var(--easing-out), color var(--duration-fast) var(--easing-out), opacity var(--duration-fast) var(--easing-out), box-shadow var(--duration-fast) var(--easing-out), transform var(--duration-fast) cubic-bezier(.34, 1.56, .64, 1);place-items:center;padding:0;font-weight:700;line-height:1;display:grid;position:absolute;box-shadow:0 2px 6px #00000052}.game-card-shell:hover>.card-pick,.game-card-shell:focus-within>.card-pick,.card-pick--selected,.card-pick--readonly{opacity:1;pointer-events:auto}.card-pick:hover:not(:disabled){background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 22%, transparent), transparent 60%), var(--color-accent-soft);border-color:var(--color-accent);color:var(--color-accent);box-shadow:0 4px 12px var(--color-accent-soft);transform:scale(1.12)}.card-pick--selected{border-color:var(--selection-color);background:linear-gradient(180deg, color-mix(in srgb, var(--selection-color) 88%, #fff 12%), var(--selection-color));color:#fff;box-shadow:inset 0 1px 0 #ffffff38, 0 2px 6px #00000052, 0 0 18px color-mix(in srgb, var(--selection-color) 42%, transparent);animation:.32s cubic-bezier(.34,1.56,.64,1) card-pick-pop}@keyframes card-pick-pop{0%{opacity:0;transform:scale(.5)}60%{opacity:1;transform:scale(1.18)}to{transform:scale(1)}}.card-pick--selected:hover:not(:disabled){background:linear-gradient(180deg, color-mix(in srgb, var(--selection-color) 92%, #fff 8%), var(--selection-color))}.card-pick--readonly{pointer-events:none;z-index:2}.card-pick-stack{pointer-events:none;position:absolute;inset:0}.resolved-accusation-stack{pointer-events:none;z-index:4;position:absolute;inset:0}.resolved-accusation-mark{pointer-events:none;filter:drop-shadow(0 0 3px #ffffffeb)drop-shadow(0 0 1px #ffffffd9)drop-shadow(0 2px 3px #0000008c);background:0 0;border:0;animation:.28s cubic-bezier(.34,1.56,.64,1) resolved-cross-stamp;position:absolute;top:4px;right:4px}.resolved-accusation-mark+.resolved-accusation-mark{transform:translate(calc(var(--mark-offset,0) * -1px), calc(var(--mark-offset,0) * .6px)) rotate(calc(var(--mark-offset,0) * 1deg))}@keyframes resolved-cross-stamp{0%{opacity:0;transform:scale(2.2)rotate(-12deg)}60%{opacity:1;transform:scale(.9)rotate(2deg)}to{transform:scale(1)rotate(0)}}@media (max-width:920px){.card-grid,.player-grid{grid-template-columns:1fr}}@media (max-width:560px){.card-grid,.player-grid,.scene-board{grid-template-columns:1fr}.card-type-column{gap:var(--space-1);grid-template-columns:1fr}.card-type-column h4{min-height:0;padding-top:0}.card-list{grid-auto-columns:var(--game-card-width,96px);scrollbar-width:thin;scroll-snap-type:x proximity;gap:3px;padding-bottom:4px;overflow-x:auto}}.presentation-panel{align-items:center;gap:var(--space-2);border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface);width:100%;max-width:1520px;padding:var(--space-3) var(--space-4);flex-wrap:wrap;margin:0 auto;display:flex}.presentation-panel span{align-items:center;gap:var(--space-2);border:1px solid var(--color-line);border-radius:var(--radius-pill);background:var(--color-surface-2);min-height:32px;color:var(--color-text-muted);font-size:var(--font-sm);padding:4px 12px;font-weight:500;display:inline-flex}.presentation-panel .current-speaker{border-color:var(--color-accent);background:var(--color-accent-soft);color:var(--color-accent);font-family:var(--font-display);font-weight:700;font-size:var(--font-md)}.end-modal-backdrop{z-index:var(--z-modal);padding:var(--space-4);background:radial-gradient(ellipse at 50% 30%, color-mix(in srgb, var(--color-accent) 18%, transparent), transparent 50%), color-mix(in srgb, var(--color-bg) 75%, transparent);-webkit-backdrop-filter:blur(10px)saturate(1.1);backdrop-filter:blur(10px)saturate(1.1);animation:end-modal-fade-in var(--duration-slow) var(--easing-out);place-items:center;display:grid;position:fixed;inset:0}@keyframes end-modal-fade-in{0%{opacity:0}to{opacity:1}}.end-panel{gap:var(--space-5);border:1px solid color-mix(in srgb, var(--color-accent) 30%, var(--color-line));border-radius:var(--radius-xl);background:radial-gradient(800px 400px at 50% 0%, var(--color-accent-soft), transparent 55%), radial-gradient(600px 360px at 50% 100%, color-mix(in srgb, var(--color-danger) 14%, transparent), transparent 55%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 4%, transparent), transparent 50%), var(--color-surface);padding:var(--space-6) var(--space-6) var(--space-5);text-align:center;max-height:calc(100vh - 64px);display:grid;position:relative;overflow:hidden auto}.end-panel:before{content:"";pointer-events:none;border-radius:inherit;background-image:repeating-linear-gradient(0deg,#ffffff05 0 1px,#0000 1px 4px);position:absolute;inset:0}.end-panel>*{position:relative}.end-modal{width:min(640px,100vw - 32px);box-shadow:var(--shadow-3), 0 0 64px color-mix(in srgb, var(--color-accent) 22%, transparent);animation:end-modal-rise var(--duration-slow) cubic-bezier(.34, 1.56, .64, 1)}@keyframes end-modal-rise{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.end-panel__header{justify-items:center;gap:var(--space-3);display:grid}.end-panel h2{font-family:var(--font-display);font-size:clamp(1.85rem, 5.5vw, var(--font-4xl));letter-spacing:-.015em;color:var(--color-text);overflow-wrap:anywhere;margin:0;font-weight:700;line-height:1.05}.end-panel__subtitle{color:var(--color-text-2,var(--color-text-muted));font-size:var(--font-md);line-height:var(--leading-relaxed);margin:0;max-width:38rem;margin-inline:auto}.end-panel__actions{justify-content:center;gap:var(--space-3);margin-top:var(--space-3);flex-wrap:wrap;display:flex}.end-panel__actions>*{flex:200px;max-width:280px}.end-killer{--killer-color:var(--color-danger);gap:var(--space-3);border:2px solid color-mix(in srgb, var(--killer-color) 70%, var(--color-line));border-radius:var(--radius-lg);background:linear-gradient(135deg, color-mix(in srgb, var(--killer-color) 18%, transparent), transparent 55%), linear-gradient(180deg, color-mix(in srgb, var(--color-text) 4%, transparent), transparent 60%), var(--color-surface);box-shadow:var(--shadow-2), 0 0 32px color-mix(in srgb, var(--killer-color) 28%, transparent);text-align:left;grid-template-columns:64px minmax(0,1fr) auto;align-items:center;width:min(440px,100%);margin-inline:auto;padding:12px 14px;animation:.32s cubic-bezier(.34,1.56,.64,1) .2s backwards end-killer-rise;display:grid}@keyframes end-killer-rise{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.end-killer__avatar{border-radius:var(--radius-pill);background:linear-gradient(135deg, color-mix(in srgb, var(--killer-color) 92%, #fff 8%), var(--killer-color));color:#fff;width:64px;height:64px;font-family:var(--font-display);font-size:calc(28px * var(--app-text-scale,1));box-shadow:inset 0 1px 0 #ffffff38, 0 0 0 3px var(--color-surface), 0 0 0 5px var(--killer-color), 0 0 24px color-mix(in srgb, var(--killer-color) 50%, transparent);place-items:center;font-weight:700;display:grid;overflow:hidden}.end-killer__avatar img{object-fit:cover;width:100%;height:100%;display:block}.end-killer__copy{text-align:left;min-width:0}.end-killer__eyebrow{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.16em;color:color-mix(in srgb, var(--killer-color) 90%, #fff 10%);margin:0;font-weight:700}.end-killer__name{font-family:var(--font-display);font-size:var(--font-2xl);letter-spacing:-.01em;color:var(--color-text);margin:2px 0 0;font-weight:700;line-height:1.05}.end-killer__chip{border-radius:var(--radius-pill);background:var(--killer-color);color:#fff;font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;box-shadow:0 1px 0 #fff3 inset, 0 4px 10px color-mix(in srgb, var(--killer-color) 40%, transparent);align-items:center;gap:4px;padding:4px 10px;font-weight:800;display:inline-flex}.end-roster{justify-content:center;align-items:flex-start;gap:var(--space-4);text-align:left;flex-wrap:wrap;width:fit-content;max-width:100%;margin-inline:auto;display:flex}.end-roster__team-section{gap:4px;min-width:160px;margin:0;display:grid}.end-roster__team-section:last-child{margin:0}@media (max-width:480px){.end-roster{gap:var(--space-2);flex-direction:column;align-items:stretch}}.end-roster__team-title{letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted);margin:0 0 4px;font-size:.7rem;font-weight:700}.end-roster__item{align-items:center;gap:6px;padding:1px 0;font-size:.85rem;line-height:1.3;display:flex}.end-roster__avatar{border-radius:50%;flex-shrink:0;width:18px;height:18px}.end-roster__name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.end-roster__separator{color:var(--color-text-muted);opacity:.5}.end-roster__role-tag{color:var(--color-text-muted);font-size:.8rem}.end-solution{gap:var(--space-3);margin-top:var(--space-1);flex-wrap:wrap;justify-content:center;display:flex}.end-solution-card{background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 4%, transparent), transparent 55%), var(--color-surface-2);border:2px solid var(--color-accent-hover);border-radius:var(--radius-md);width:132px;box-shadow:var(--shadow-2), 0 0 24px var(--color-accent-soft);transition:transform var(--duration-base) cubic-bezier(.34, 1.56, .64, 1);margin:0;animation:.36s cubic-bezier(.34,1.56,.64,1) .36s backwards end-solution-rise;position:relative;overflow:hidden;transform:rotate(-2deg)}.end-solution-card:nth-child(2){animation-delay:.46s;transform:rotate(2deg)}.end-solution-card:hover{transform:rotate(0)translateY(-3px)}@keyframes end-solution-rise{0%{opacity:0;transform:translateY(14px)rotate(0)scale(.94)}to{opacity:1}}.end-solution-card__title{background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent-hover) 92%, #fff 8%), var(--color-accent));color:var(--color-on-accent);text-align:center;font-family:var(--font-display);font-size:var(--font-md);border-bottom:1px solid var(--color-accent);gap:2px;padding:8px 10px;font-weight:700;line-height:1.1;display:grid;box-shadow:inset 0 1px #ffffff38}.end-solution-card__kind{font-family:var(--font-sans);font-size:calc(9px * var(--app-text-scale,1));text-transform:uppercase;letter-spacing:.18em;opacity:.78;font-weight:800}.end-solution-card__art{background:radial-gradient(120px 60px at 50% 50%, var(--color-accent-soft), transparent 70%), linear-gradient(180deg, transparent, color-mix(in srgb, var(--color-accent) 6%, transparent));height:116px;color:var(--color-accent-hover);place-items:center;display:grid}.end-solution-card__art img{object-fit:contain;max-width:100%;max-height:100%}.end-solution-card__art--blank{font-size:calc(56px * var(--app-text-scale,1));opacity:.55;line-height:1}@media (prefers-reduced-motion:reduce){.end-modal-backdrop,.end-modal,.end-killer,.end-solution-card{animation:none}.end-solution-card:first-child,.end-solution-card:nth-child(2){transform:none}.end-solution-card:hover{transform:translateY(-2px)}.end-panel:before{display:none}}@media (max-width:560px){.end-modal-backdrop{padding:var(--space-2);align-items:end}.end-panel{gap:var(--space-3);padding:var(--space-4)}.end-panel__actions>*{max-width:none}}.role-onboarding__heading{align-items:center;gap:var(--space-3);display:inline-flex}.role-onboarding__icon{border-radius:var(--radius-md);background:linear-gradient(135deg, color-mix(in srgb, var(--color-accent-hover) 88%, #fff 12%), var(--color-accent));width:52px;height:52px;color:var(--color-on-accent);box-shadow:inset 0 1px 0 #ffffff38, 0 1px 3px #00000052, 0 8px 18px var(--color-accent-soft);place-items:center;display:grid}.role-onboarding__list{gap:var(--space-2);color:var(--color-text);line-height:var(--leading-snug);margin:0;padding-left:0;list-style:none;display:grid}.role-onboarding__list li{font-size:var(--font-md);border:1px solid var(--color-line-soft);border-radius:var(--radius-sm);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 50%), var(--color-surface-2);padding:8px 12px 8px 36px;position:relative}.role-onboarding__list li:before{content:"";background:var(--color-accent);width:8px;height:8px;box-shadow:0 0 0 2px var(--color-accent-soft);border-radius:50%;position:absolute;top:13px;left:12px}.rules-help{gap:var(--space-5);display:grid}.rules-help__heading{align-items:center;gap:var(--space-2);color:var(--color-accent);display:inline-flex}.rules-help__sections,.rules-help__role-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.rules-help__section,.rules-help__role{border:1px solid var(--color-line);border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 3%, transparent), transparent 60%), var(--color-surface-2);padding:var(--space-4);box-shadow:var(--shadow-1);transition:border-color var(--duration-fast) var(--easing-out)}.rules-help__section:hover,.rules-help__role:hover{border-color:color-mix(in srgb, var(--color-accent) 40%, var(--color-line))}.rules-help__section h3,.rules-help__role h4{margin:0 0 var(--space-2);font-family:var(--font-display);font-size:var(--font-lg);letter-spacing:-.005em;color:var(--color-text);border-bottom:1px solid var(--color-line-soft);padding-bottom:6px;font-weight:700}.rules-help__roles>h3{font-family:var(--font-display);font-size:var(--font-xl);letter-spacing:-.01em;margin:0 0 var(--space-3)}.rules-help__role p{margin:0 0 var(--space-2);color:var(--color-text-2,var(--color-text-muted));line-height:var(--leading-snug);font-size:var(--font-sm)}.rules-help ul{gap:var(--space-1);padding-left:var(--space-4);line-height:var(--leading-snug);color:var(--color-text-2,var(--color-text-muted));font-size:var(--font-sm);margin:0;display:grid}.rules-help ul li::marker{color:var(--color-accent)}.restart-countdown-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--color-text,#fff);align-items:center;gap:var(--space-2,8px);bottom:0;pointer-events:none;z-index:200;background:#000000c7;flex-direction:column;justify-content:center;display:flex;position:fixed;inset:0}.restart-countdown-overlay__number{letter-spacing:-.02em;font-size:clamp(6rem,18vw,12rem);font-weight:800;line-height:1}.restart-countdown-overlay__caption{letter-spacing:.05em;opacity:.85;text-transform:uppercase;font-size:1.1rem}.scene-peek{z-index:var(--z-sticky);background:var(--color-surface-2);border-bottom:1px solid var(--color-line);flex-wrap:nowrap;gap:10px;padding:6px 12px;display:flex;position:sticky;top:0;overflow-x:auto}.scene-peek--pinned{margin:0 0 var(--space-2);border:1px solid color-mix(in srgb, var(--color-accent) 28%, var(--color-line));border-radius:var(--radius-md);background:linear-gradient(180deg, color-mix(in srgb, var(--color-accent) 6%, transparent), transparent 70%), color-mix(in srgb, var(--color-surface-2) 94%, #000 6%);box-shadow:var(--shadow-2), 0 0 0 1px color-mix(in srgb, var(--color-accent) 8%, transparent);flex-wrap:wrap;gap:8px;padding:10px 14px;top:0}.scene-peek__item{background:var(--color-surface);border:1px solid var(--color-line);white-space:nowrap;border-radius:8px;flex:none;align-items:center;gap:8px;padding:4px 10px 4px 8px;font-size:.78rem;transition:border-color .12s,background .12s;display:inline-flex}.scene-peek--pinned .scene-peek__item{background:linear-gradient(180deg, color-mix(in srgb, var(--color-text) 2%, transparent), transparent 60%), var(--color-surface);flex:auto;min-width:140px;padding:6px 12px 6px 10px}.scene-peek__status-dot{background:color-mix(in srgb, var(--color-text-muted) 50%, transparent);width:8px;height:8px;box-shadow:0 0 0 2px color-mix(in srgb, var(--color-line) 60%, transparent);border-radius:50%;flex-shrink:0;display:inline-block}.scene-peek__item--confirmed{border-color:color-mix(in srgb, var(--color-success) 70%, var(--color-line));background:linear-gradient(180deg, color-mix(in srgb, var(--color-success) 12%, transparent), transparent 60%), var(--color-success-soft)}.scene-peek__item--confirmed .scene-peek__status-dot{background:var(--color-success);box-shadow:0 0 0 2px color-mix(in srgb, var(--color-success) 26%, transparent)}.scene-peek__item--empty .scene-peek__value{color:var(--color-text-muted);opacity:.7;font-style:italic}.scene-peek__copy{align-items:baseline;gap:6px;min-width:0;display:inline-flex}.scene-peek--pinned .scene-peek__copy{align-items:start;gap:1px;display:grid}.scene-peek__title{color:var(--color-text-muted)}.scene-peek__title:after{content:":";margin-left:1px}.scene-peek--pinned .scene-peek__title{font-size:calc(9px * var(--app-text-scale,1));letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);font-weight:800}.scene-peek--pinned .scene-peek__title:after{content:""}.scene-peek__value{color:var(--color-text);font-weight:600}.scene-peek--pinned .scene-peek__value{font-family:var(--font-display);font-size:var(--font-sm);letter-spacing:-.005em;font-weight:700}.scene-peek__toggle,.scene-peek__pin-toggle{border:1px solid var(--color-line);color:var(--color-text-muted);cursor:pointer;background:0 0;border-radius:6px;flex:none;justify-content:center;align-self:center;align-items:center;margin-left:auto;padding:2px 6px;font-size:.7rem;display:inline-flex}.scene-peek__toggle:hover,.scene-peek__pin-toggle:hover{background:var(--color-surface);color:var(--color-text)}.ghost-role-help{display:inline-block}.ghost-role-help__summary{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--radius-sm,6px);background:var(--color-surface-soft);padding:.25rem .5rem;font-size:.875rem}.ghost-role-help__summary:hover{background:var(--color-surface-hover)}.ghost-role-help__body{max-width:32rem;padding:.75rem 0}.ghost-role-help__body h3,.ghost-role-help__body h4{margin:0 0 .25rem}.ghost-role-help__current{margin:.25rem 0 .5rem}.ghost-role-help__bullets,.ghost-role-help__rules{margin:.25rem 0 .75rem 1.25rem;padding-left:0}.ghost-role-help__bullets li,.ghost-role-help__rules li{margin-bottom:.25rem}.ghost-phase-countdown{font-variant-numeric:tabular-nums;border-radius:var(--radius-sm,4px);background:#ffffff0a;margin-left:.5rem;padding:.125rem .5rem;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-size:.875rem;display:inline-block}.ghost-phase-countdown--paused{opacity:.6;font-family:inherit;font-style:italic}.ghost-phase-countdown--expired{background:var(--color-danger-soft,#c0392b26);color:var(--color-danger,#c0392b)}[data-gl-noir=true] :focus-visible{outline:2px solid var(--gl-gold-bright);outline-offset:2px}:root{--app-text-scale:1}:root[data-font-scale=compact]{--app-text-scale:.92}:root[data-font-scale=normal]{--app-text-scale:1}:root[data-font-scale=comfortable]{--app-text-scale:1.1}:root[data-font-scale=large]{--app-text-scale:1.22}.lobby-profile-font-scale{align-items:center;gap:var(--space-3,12px);padding-top:var(--space-2,8px);border-top:1px solid var(--color-line-soft);grid-column:1/-1;grid-template-columns:max-content minmax(0,1fr);display:grid}.lobby-profile-font-scale>label{font-size:calc(12px * var(--app-text-scale,1));color:var(--color-text-muted);letter-spacing:.04em}.lobby-profile-font-scale__segments{border:1px solid var(--color-line-soft);border-radius:var(--radius-md,8px);background:var(--color-surface);flex-wrap:wrap;gap:4px;padding:3px;display:inline-flex}.lobby-profile-font-scale__segment{appearance:none;color:var(--color-text-muted);border-radius:var(--radius-sm,6px);font:inherit;font-size:calc(12px * var(--app-text-scale,1));letter-spacing:.02em;cursor:pointer;background:0 0;border:1px solid #0000;min-height:32px;padding:5px 12px;transition:background .14s,color .14s,border-color .14s}.lobby-profile-font-scale__segment:hover{color:var(--color-text);background:color-mix(in srgb, var(--color-primary) 12%, transparent)}.lobby-profile-font-scale__segment:focus-visible{outline:2px solid var(--color-primary-hover);outline-offset:2px}.lobby-profile-font-scale__segment[aria-pressed=true]{background:var(--color-primary);color:var(--color-on-primary);border-color:var(--color-primary-hover);font-weight:600}@media (max-width:640px){.lobby-profile-font-scale{grid-template-columns:minmax(0,1fr)}}
