:root,[data-theme=dark]{--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-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:"Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display:"Playfair Display", Georgia, "Times New Roman", serif;--font-mono:ui-monospace, "JetBrains Mono", "SFMono-Regular", Menlo, monospace;--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;--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}[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-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:24px}.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-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:28px;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))}@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-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);align-items:center;gap:4px;font-size:11px;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);text-transform:uppercase;letter-spacing:.2em;opacity:.78;font-size:9px;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}.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);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;font-size:14px;font-weight:800;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)}.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}}.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}.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);text-align:center;appearance:textfield;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;width:100%;min-height:24px;padding:2px 5px;font-size:12px;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}.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}}.game-topbar{align-items:center;gap:var(--space-2);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%), color-mix(in srgb, var(--color-surface) 90%, transparent);padding:var(--space-2) var(--space-3);min-height:64px;z-index:var(--z-sticky);-webkit-backdrop-filter:blur(14px)saturate(1.1);box-shadow:var(--shadow-1);grid-template-columns:minmax(140px,.8fr) minmax(330px,1.2fr) auto;display:grid;position:sticky;top:0}.game-brand{align-items:center;gap:var(--space-3);min-width:0;font-family:var(--font-display);font-size:var(--font-xl);letter-spacing:-.005em;font-weight:700;display:inline-flex}.game-brand strong{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.game-topbar__status{justify-content:center;align-items:stretch;gap:var(--space-2);flex-wrap:wrap;min-width:0;display:flex}.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);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-size:11px;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)}.brand-mark{border-radius:var(--radius-md);background:linear-gradient(135deg, color-mix(in srgb, var(--color-accent-hover) 88%, #fff 12%), var(--color-accent));width:44px;height:44px;color:var(--color-on-accent);font-family:var(--font-display);font-size:var(--font-lg);box-shadow:inset 0 1px 0 #ffffff38, 0 1px 2px #00000052, 0 6px 14px var(--color-accent-soft);place-items:center;font-weight:800;display:grid}.top-timer{--timer-tone:var(--color-accent);--timer-tone-hi:var(--color-accent-hover);--timer-tone-soft:var(--color-accent-soft);border:1px solid var(--timer-tone);border-radius:var(--radius-md);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);min-width:150px;min-height:48px;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);align-content:center;place-items:start;padding:6px 42px 6px 12px;display:grid}.top-timer--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 top-timer-pulse}.top-timer--urgent .top-timer__phase,.top-timer--urgent strong{color:var(--color-danger)}@keyframes top-timer-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)}}.top-timer--paused{--timer-tone:var(--color-text-dim);--timer-tone-hi:var(--color-text-muted);--timer-tone-soft:transparent;filter:saturate(.5);opacity:.85}.top-timer--paused strong{color:var(--color-text-muted)}@media (prefers-reduced-motion:reduce){.top-timer--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}}.top-timer__phase{color:var(--color-accent);font-size:var(--font-xs);letter-spacing:.12em;text-transform:uppercase;font-weight:700}.top-timer strong{font-family:var(--font-display);font-size:var(--font-2xl);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;letter-spacing:0;line-height:1}.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}}.game-top-actions{justify-content:flex-end;justify-self:end;align-items:center;gap:var(--space-2);min-width:0;display:inline-flex}.game-topbar__tools{max-width:100%}.game-theme-toggle,.game-profile-toggle,.game-rules-toggle,.game-restart-toggle,.game-spectator-toggle,.card-layout-toggle{flex:none}.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))}.top-timer{position:relative}.top-timer__meta{justify-content:flex-start;align-items:center;gap:var(--space-2);color:var(--color-text-muted);letter-spacing:0;text-transform:none;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.top-timer__badges{color:var(--color-accent);font-variant-numeric:tabular-nums;align-items:center;gap:3px;display:inline-flex}.top-timer__pause{border:1px solid var(--color-line);border-radius:var(--radius-pill);background:var(--color-surface-2);width:34px;height:34px;color:var(--color-text);appearance:none;justify-content:center;align-items:center;margin-top:-17px;padding:0;line-height:0;display:inline-flex;position:absolute;top:50%;right:8px;transform:none}.top-timer__pause:active:not(:disabled){transform:none}.top-timer__pause svg{flex:none;margin:0;display:block}.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);place-items:center;font-size:14px;font-weight:700;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{letter-spacing:.18em;text-transform:uppercase;color:var(--color-accent);font-size:9px;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);letter-spacing:.12em;text-transform:uppercase;padding:1px 6px;font-size:9px;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;place-items:center;width:20px;height:20px;font-size:10px;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}@media (max-width:920px){.game-topbar{grid-template-columns:1fr;min-height:0}.game-topbar__status{flex-direction:column;justify-content:stretch;align-items:stretch}.top-timer,.role-card{justify-content:center;justify-self:stretch;width:100%}.top-forensic-pref--icon{align-self:center}.game-top-actions{flex-wrap:wrap;justify-self:stretch}}@media (max-width:640px){.game-topbar{padding:6px var(--space-2);gap:6px}.game-brand strong{font-family:var(--font-mono);font-size:var(--font-sm);letter-spacing:.16em;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);align-items:center;gap:8px;padding:4px 10px;display:inline-flex}.game-topbar__status{grid-template-columns:1fr;gap:6px}.game-top-actions{scrollbar-width:thin;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;justify-content:flex-start;padding-bottom:2px;padding-right:4px;overflow:auto hidden}.game-top-actions>*{flex:none}.game-top-actions::-webkit-scrollbar{height:3px}.game-top-actions::-webkit-scrollbar-thumb{background:var(--color-line);border-radius:var(--radius-pill)}}.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:76px}@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-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;margin:0;font-size:11px;font-weight:700}.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;flex:none;font-size:13px;font-weight:700}.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;flex-wrap:wrap;justify-content:center;align-items:start;display:flex}.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{flex:none;width:fit-content;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;text-transform:uppercase;white-space:nowrap;align-items:center;min-height:20px;padding:1px 7px;font-size:10px;font-weight:900;line-height:1;display:inline-flex}.player-status-badge{border-radius:var(--radius-pill);letter-spacing:0;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;gap:4px;width:fit-content;min-height:20px;padding:1px 7px;font-size:10px;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:14px;height:14px;position:absolute;top:-3px;right:-3px}.known-murder-team-marker{background:var(--color-danger);box-shadow:0 0 0 1px var(--color-danger-soft), 0 0 8px color-mix(in srgb, var(--color-danger) 60%, transparent)}.known-culprit-marker{background:var(--color-suspect);box-shadow:0 0 0 1px var(--color-suspect-soft), 0 0 8px color-mix(in srgb, var(--color-suspect) 60%, transparent)}.known-ally-marker{border:2px solid var(--color-surface);border-radius:var(--radius-pill);background:var(--color-info);width:14px;height:14px;box-shadow:0 0 0 1px var(--color-info-soft), 0 0 8px color-mix(in srgb, var(--color-info) 60%, transparent);position:absolute;bottom:-3px;right:-3px}.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}.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}.team-indicator{border-radius:var(--radius-pill);letter-spacing:0;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;min-height:20px;padding:1px 7px;font-size:10px;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}.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);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-size:12px;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);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-size:11px;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;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-size:11px;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);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;margin-top:0;padding:1px 7px;font-size:10px;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);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;gap:4px;margin-top:2px;padding:1px 7px;font-size:10px;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);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;gap:4px;margin-top:0;padding:1px 7px;font-size:10px;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-auto-columns:var(--game-card-width);scrollbar-width:none;width:max-content;max-width:none;overflow-x:visible}.card-grid--horizontal .game-card-shell{width:var(--game-card-width)}.card-grid--horizontal .card-type-columns{width:max-content;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)}.game-card.highlighted{border-color:var(--color-warn);background:linear-gradient(135deg, var(--color-warn-soft), transparent 62%), var(--color-surface-2);box-shadow:0 0 0 2px var(--color-warn-soft), inset 0 0 0 1px var(--color-warn);border-width:2px}.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}.game-card--murder-selected{border-color:var(--color-danger);border-left-width:4px;border-left-color:var(--color-danger);background:linear-gradient(135deg, color-mix(in srgb, var(--color-danger) 18%, transparent), transparent 60%), var(--color-surface-2);box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--color-danger) 50%, transparent);position:relative}.game-card--murder-selected:after{content:"★";color:var(--color-danger);text-shadow:0 0 6px #000000b3;z-index:4;pointer-events:none;font-size:13px;line-height:1;position:absolute;bottom:4px;left:5px}.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);text-shadow:0 0 6px #000000b3;z-index:4;pointer-events:none;font-size:13px;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 1fr auto;gap:0;height:172px;min-height:172px;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;place-items:center;min-height:0;display:grid;overflow:hidden}.card-image{object-fit:contain;-webkit-user-select:none;user-select:none;width:100%;height:130px;display:block}.card-grid--horizontal .game-card-shell .game-card:has(.card-image-frame){grid-template-rows:36px 1fr auto;gap:0;height:116px;min-height:116px;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:11px;line-height:1.08}.game-card-shell .card-title--very-long,.card-grid--horizontal .game-card-shell .card-title--very-long{font-size:10px;line-height:1.05}.card-grid--horizontal .card-image{object-fit:contain;height:80px}.lab-card-result{z-index:2;border-radius:var(--radius-pill);background:var(--color-surface);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;border:1px solid;align-items:center;max-width:calc(100% - 10px);min-height:20px;padding:1px 8px;font-size:10px;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}}.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);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-size:14px;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;display:grid;position:relative;overflow:hidden}.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);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-size:28px;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-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);text-transform:uppercase;letter-spacing:.18em;opacity:.78;font-size:9px;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{opacity:.55;font-size:56px;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)}
