:root{--bg: #080b14;--bg-deep: #05070e;--bg-elev: rgba(20, 27, 44, .72);--bg-elev-2: rgba(32, 41, 62, .82);--surface: rgba(255, 255, 255, .04);--surface-strong: rgba(255, 255, 255, .08);--text: #eaf0fb;--text-dim: #9fb0cc;--border: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .16);--focus: #ffd166;--red: #f43f5e;--red-soft: #fb7185;--red-bg: rgba(244, 63, 94, .14);--red-glow: rgba(244, 63, 94, .55);--blue: #3b82f6;--blue-soft: #93c5fd;--blue-bg: rgba(59, 130, 246, .14);--blue-glow: rgba(59, 130, 246, .55);--agent: #22c55e;--agent-soft: #86efac;--agent-bg: rgba(34, 197, 94, .14);--agent-glow: rgba(34, 197, 94, .55);--neutral: #cbb88f;--neutral-bg: rgba(203, 184, 143, .16);--assassin: #0a0e16;--assassin-fg: #eef2fb;--card-face: linear-gradient(160deg, #f6f1e3 0%, #e7dec8 100%);--card-ink: #2a2f3a;--radius: 14px;--radius-sm: 9px;--shadow: 0 18px 50px -16px rgba(0, 0, 0, .7);--shadow-soft: 0 8px 24px -10px rgba(0, 0, 0, .55);--font-sans: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;--font-display: "Space Grotesk", "Inter", "Segoe UI", system-ui, sans-serif;font-synthesis:none}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg-deep);color:var(--text);font-family:var(--font-sans);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}:focus-visible{outline:3px solid var(--focus);outline-offset:2px;border-radius:4px}::selection{background:#ffd1664d}*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}@keyframes rise-in{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes deal-in{0%{opacity:0;transform:translateY(12px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes card-flip{0%{transform:rotateY(-92deg) scale(.92)}55%{transform:rotateY(6deg) scale(1.05)}to{transform:rotateY(0) scale(1)}}@keyframes assassin-reveal{0%{transform:rotateY(-90deg) scale(.9)}45%{transform:rotateY(0) scale(1.07)}60%{transform:translate(-3px) rotate(-1deg)}72%{transform:translate(3px) rotate(1deg)}84%{transform:translate(-2px)}to{transform:translate(0) scale(1)}}@keyframes proposed-pulse{0%,to{box-shadow:0 0 0 3px var(--focus),0 0 18px 2px #ffd16673}50%{box-shadow:0 0 0 3px var(--focus),0 0 28px 7px #ffd166cc}}@keyframes pulse-scale{0%,to{transform:scale(1)}50%{transform:scale(1.025)}}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.78)}}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%)}}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes panel-pop{0%{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes aurora-drift{0%{transform:translate3d(-4%,-2%,0) rotate(0)}50%{transform:translate3d(4%,3%,0) rotate(8deg)}to{transform:translate3d(-4%,-2%,0) rotate(0)}}.app{position:relative;display:flex;flex-direction:column;min-height:100%;isolation:isolate}.app:before{content:"";position:fixed;top:-25vmax;right:-25vmax;bottom:-25vmax;left:-25vmax;z-index:-2;pointer-events:none;background:radial-gradient(40vmax 40vmax at 18% 12%,rgba(59,130,246,.22),transparent 60%),radial-gradient(38vmax 38vmax at 82% 16%,rgba(244,63,94,.2),transparent 60%),radial-gradient(46vmax 46vmax at 50% 100%,rgba(125,91,255,.18),transparent 60%);animation:aurora-drift 28s ease-in-out infinite}.app:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-3;pointer-events:none;background-color:var(--bg-deep);background-image:repeating-linear-gradient(0deg,transparent 0 39px,rgba(255,255,255,.02) 39px 40px),repeating-linear-gradient(90deg,transparent 0 39px,rgba(255,255,255,.02) 39px 40px)}.app__header{position:sticky;top:0;z-index:10;padding:.85rem 1.5rem;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#0a0e18d9,#0a0e188c);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.app__title{display:inline-flex;align-items:center;gap:.6rem;margin:0;font-family:var(--font-display);font-size:1.4rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;background:linear-gradient(120deg,#fff 0%,var(--blue-soft) 45%,var(--red-soft) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.app__title:before{content:"";width:.95rem;height:.95rem;border-radius:5px;background:conic-gradient(from 45deg,var(--red),var(--focus),var(--blue),var(--red));box-shadow:0 0 14px #ffd16680}.app__main{flex:1;padding:1.5rem 1.25rem 3rem;max-width:1200px;width:100%;margin:0 auto;animation:rise-in .5s ease both}.btn{position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border-strong);background:var(--surface-strong);color:var(--text);padding:.6rem 1.1rem;font-family:var(--font-sans);font-size:.95rem;font-weight:600;letter-spacing:.01em;border-radius:var(--radius-sm);cursor:pointer;overflow:hidden;transition:background .18s ease,border-color .18s ease,transform .08s ease,box-shadow .18s ease}.btn:hover:not(:disabled){background:#ffffff1f;transform:translateY(-1px);box-shadow:var(--shadow-soft)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--primary{background:linear-gradient(135deg,#4f8df9,#2563eb);border-color:transparent;color:#fff;box-shadow:0 8px 22px -10px #2563ebe6}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,#62a0ff,#3b82f6);box-shadow:0 12px 28px -10px #3b82f6}.btn--primary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);transform:translate(-130%);transition:transform .6s ease}.btn--primary:hover:not(:disabled):after{transform:translate(130%)}.btn--ghost{background:transparent;border-color:var(--border)}.btn--block{width:100%}.btn--sm{padding:.32rem .7rem;font-size:.8rem}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem}.field--inline{flex-direction:row;align-items:center;gap:.5rem}.field__label{font-size:.72rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em}.field__input{background:#00000047;border:1px solid var(--border-strong);color:var(--text);border-radius:var(--radius-sm);padding:.6rem .8rem;font-size:1rem;font-family:inherit;transition:border-color .18s ease,background .18s ease}.field__input::placeholder{color:#9fb0cc80}.field__input:focus{border-color:var(--blue);background:#0000006b}.field__input--code{text-transform:uppercase;letter-spacing:.5em;font-weight:700;font-size:1.3rem;text-align:center;font-family:var(--font-display)}.field__input--num{width:5rem}.checkbox{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox input{accent-color:var(--blue);width:1.05rem;height:1.05rem}.home{position:relative;max-width:440px;margin:3rem auto;background:var(--bg-elev);padding:2rem 1.75rem;border-radius:calc(var(--radius) + 4px);border:1px solid var(--border);box-shadow:var(--shadow);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);overflow:hidden;animation:panel-pop .5s cubic-bezier(.2,.8,.2,1) both}.home:before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--red),var(--focus),var(--blue))}.home h2{font-family:var(--font-display);font-size:1.6rem;letter-spacing:.02em;margin:.2rem 0 .3rem}.home__lede{color:var(--text-dim);margin-top:0}.home__actions{margin:.5rem 0 1rem}.home__divider{display:flex;align-items:center;text-align:center;color:var(--text-dim);margin:.75rem 0}.home__divider:before,.home__divider:after{content:"";flex:1;border-bottom:1px solid var(--border)}.home__divider span{padding:0 .85rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.16em}.room{animation:rise-in .45s ease both}.room__bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:.7rem 1rem;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-soft)}.room__code{display:flex;align-items:center;gap:.7rem}.room__code-label{color:var(--text-dim);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em}.room__code-value{font-family:var(--font-display);font-size:1.35rem;font-weight:700;letter-spacing:.35em;color:var(--focus);background:#ffd1661f;border:1px solid rgba(255,209,102,.3);padding:.2rem .45rem .2rem .7rem;border-radius:8px}.lobby{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;animation:rise-in .5s ease both}.lobby__roster{grid-row:span 2}.lobby__roster,.lobby__seats,.lobby__controls{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-soft)}.lobby h2{font-family:var(--font-display);font-size:1rem;letter-spacing:.04em;margin:0 0 .75rem}.roster{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.45rem}.roster__item{display:flex;justify-content:space-between;align-items:center;padding:.55rem .75rem;background:var(--surface);border:1px solid var(--border);border-left-width:3px;border-radius:var(--radius-sm);transition:background .18s ease,transform .18s ease}.roster__item:hover{background:var(--surface-strong);transform:translate(2px)}.roster__item--red{border-left-color:var(--red)}.roster__item--blue{border-left-color:var(--blue)}.roster__item--none{border-left-color:var(--text-dim)}.roster__meta{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--text-dim)}.badge{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.12rem .5rem;border-radius:999px;background:var(--surface-strong);border:1px solid var(--border)}.badge--host{background:linear-gradient(135deg,#ffe08a,var(--focus));color:#2a1d00;border-color:transparent}.badge--off{background:#f43f5e2e;color:var(--red-soft);border-color:#f43f5e4d}.seats{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-bottom:.7rem}.seats__col{display:flex;flex-direction:column;gap:.7rem}.seat-btn{position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--text);padding:.8rem;border-radius:var(--radius-sm);font-family:inherit;font-weight:600;cursor:pointer;transition:transform .12s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease}.seat-btn:hover:not(:disabled){transform:translateY(-2px)}.seat-btn--red{border-color:#f43f5e8c}.seat-btn--red:hover:not(:disabled){background:var(--red-bg);box-shadow:0 8px 22px -10px var(--red-glow)}.seat-btn--blue{border-color:#3b82f68c}.seat-btn--blue:hover:not(:disabled){background:var(--blue-bg);box-shadow:0 8px 22px -10px var(--blue-glow)}.seat-btn--active{background:linear-gradient(135deg,#ffe08a,var(--focus));color:#2a1d00;border-color:transparent;box-shadow:0 8px 24px -10px #ffd166cc}.seat-btn--spectator{width:100%}.timer-config{display:flex;gap:1rem;margin:.6rem 0;flex-wrap:wrap}.lobby__hints{margin:.7rem 0 0;padding-left:1.1rem;color:var(--red-soft);font-size:.85rem}.lobby__mode{grid-column:1 / -1;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-soft)}.mode-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem}.mode-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--text);padding:.7rem .5rem;border-radius:var(--radius-sm);font-family:var(--font-display);font-weight:700;letter-spacing:.02em;cursor:pointer;transition:transform .12s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease}.mode-btn:hover:not(:disabled){transform:translateY(-2px);background:var(--surface-strong)}.mode-btn--active{background:linear-gradient(135deg,#ffe08a,var(--focus));color:#2a1d00;border-color:transparent;box-shadow:0 8px 24px -10px #ffd166cc}.mode-btn:disabled{cursor:default;opacity:.8}.mode-hint{margin:.75rem 0 0;color:var(--text-dim);font-size:.85rem}.mode-hint--muted{font-style:italic;opacity:.75}.roster__item--coop{border-left-color:var(--agent)}.seats--coop{grid-template-columns:1fr 1fr}.seat-btn--coop{border-color:#22c55e8c}.seat-btn--coop:hover:not(:disabled){background:var(--agent-bg);box-shadow:0 8px 22px -10px var(--agent-glow)}.lobby__waiting,.result__waiting{color:var(--text-dim);font-style:italic}.game{display:grid;grid-template-columns:320px 1fr;gap:1.4rem;position:relative;align-items:start;animation:rise-in .5s ease both}.game__sidebar{display:flex;flex-direction:column;gap:1rem;position:sticky;top:5rem}.game__main{min-width:0}.scoreboard{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-soft)}.scoreboard__teams{display:flex;align-items:stretch;gap:.6rem}.score{position:relative;flex:1;text-align:center;padding:.85rem .5rem;border-radius:var(--radius-sm);border:1.5px solid transparent;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.score--red{background:var(--red-bg);border-color:#f43f5e40}.score--blue{background:var(--blue-bg);border-color:#3b82f640}.score--active{animation:pulse-scale 2.6s ease-in-out infinite}.score--red.score--active{border-color:var(--red);box-shadow:0 0 0 1px var(--red),0 12px 30px -8px var(--red-glow)}.score--blue.score--active{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue),0 12px 30px -8px var(--blue-glow)}.score--active:before{content:"";position:absolute;inset:0 0 auto 0;height:3px;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.score--red.score--active:before{background:var(--red)}.score--blue.score--active:before{background:var(--blue)}.score__count{display:block;font-family:var(--font-display);font-size:2.2rem;font-weight:700;line-height:1;font-variant-numeric:tabular-nums}.score--red .score__count{color:var(--red-soft);text-shadow:0 0 18px var(--red-glow)}.score--blue .score__count{color:var(--blue-soft);text-shadow:0 0 18px var(--blue-glow)}.score__team{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}.scoreboard__vs{display:flex;align-items:center;font-family:var(--font-display);font-size:.78rem;font-weight:700;letter-spacing:.1em;color:var(--text-dim);opacity:.6}.scoreboard__turn{margin:.9rem 0 .5rem;text-align:center;font-size:.88rem;color:var(--text-dim)}.turn-chip{display:inline-block;padding:.12rem .65rem;border-radius:999px;font-weight:700;color:#fff}.turn-chip--red{background:var(--red);box-shadow:0 0 14px -2px var(--red-glow)}.turn-chip--blue{background:var(--blue);box-shadow:0 0 14px -2px var(--blue-glow)}.turn-chip--agent{background:var(--agent);box-shadow:0 0 14px -2px var(--agent-glow)}.score--agent{background:var(--agent-bg);border-color:#22c55e40}.score--agent.score--active{border-color:var(--agent);box-shadow:0 0 0 1px var(--agent),0 12px 30px -8px var(--agent-glow)}.score--agent.score--active:before{background:var(--agent)}.score--agent .score__count{color:var(--agent-soft);text-shadow:0 0 18px var(--agent-glow)}.score__total{font-size:1.1rem;color:var(--text-dim);text-shadow:none}.score__sub{display:block;margin-top:.15rem;font-size:.66rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.score--out{opacity:.5;filter:grayscale(.5)}.scoreboard__note{margin:0 0 .4rem;text-align:center;font-size:.8rem;color:var(--text-dim)}.scoreboard--coop .score--agent{margin-bottom:.2rem}.cluebar{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-soft)}.cluebar__count{display:flex;align-items:flex-end;gap:1rem;margin-bottom:.85rem}.cluebar--current{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap}.cluebar--current:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--focus);box-shadow:0 0 10px var(--focus);animation:dot-pulse 1.6s ease-in-out infinite}.cluebar__label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}.cluebar__word{font-family:var(--font-display);font-size:1.4rem;font-weight:700}.cluebar__word--red{color:var(--red-soft);text-shadow:0 0 18px var(--red-glow)}.cluebar__word--blue{color:var(--blue-soft);text-shadow:0 0 18px var(--blue-glow)}.cluebar__word--agent{color:var(--agent-soft);text-shadow:0 0 18px var(--agent-glow)}.cluebar__number{font-family:var(--font-display);font-size:1.05rem;font-weight:700;background:var(--surface-strong);border:1px solid var(--border-strong);border-radius:999px;min-width:2.1rem;text-align:center;padding:.12rem .55rem}.cluebar__remaining{margin-left:auto;color:var(--text-dim);font-size:.82rem}.cluebar--waiting{color:var(--text-dim);font-style:italic}.clue-history{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-soft)}.clue-history__title{margin:0 0 .65rem;font-family:var(--font-display);font-size:.92rem;letter-spacing:.03em}.clue-history__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem;max-height:240px;overflow-y:auto}.clue-history__item{display:flex;justify-content:space-between;align-items:center;padding:.4rem .6rem;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--border);animation:rise-in .3s ease both}.clue-history__item--red{border-left-color:var(--red)}.clue-history__item--blue{border-left-color:var(--blue)}.clue-history__word{font-weight:600;letter-spacing:.02em}.clue-history__count{font-family:var(--font-display);font-weight:700;color:var(--text-dim)}.board{display:grid;grid-template-columns:repeat(5,1fr);gap:.7rem;perspective:1400px}.card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;aspect-ratio:5 / 3;padding:.5rem;border:1px solid rgba(0,0,0,.18);border-radius:var(--radius-sm);background:var(--card-face);color:var(--card-ink);font-family:var(--font-sans);font-weight:700;text-align:center;text-transform:uppercase;letter-spacing:.03em;box-shadow:0 2px #00000038,0 10px 22px -14px #000c,inset 0 1px #fff9;transform-style:preserve-3d;animation:deal-in .5s cubic-bezier(.2,.8,.2,1) backwards;animation-delay:calc(var(--card-index, 0) * 16ms);transition:transform .18s ease,box-shadow .18s ease}.card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.35),transparent 42%);opacity:.6;pointer-events:none}button.card{cursor:pointer;font:inherit;font-weight:700;text-transform:uppercase}.card--interactive:hover{transform:translateY(-6px) scale(1.03);box-shadow:0 6px #00000038,0 22px 38px -16px #000000e6,0 0 0 2px var(--focus),inset 0 1px #fff9;z-index:2}.card--interactive:active{transform:translateY(-2px) scale(1.01)}.card__word{position:relative;z-index:1;font-size:clamp(.7rem,1.35vw,1rem);line-height:1.1}.card__glyph{position:relative;z-index:1;font-size:1.05rem;line-height:1}.card__identity{position:relative;z-index:1;font-size:.58rem;font-weight:700;letter-spacing:.08em;opacity:.85;text-transform:uppercase}.card--revealed{color:#fff;border-color:transparent;text-shadow:0 1px 2px rgba(0,0,0,.35);animation:card-flip .5s ease both}.card--revealed:after{opacity:.22}.card--revealed.card--red{background:linear-gradient(160deg,#fb5d74,var(--red));box-shadow:0 10px 26px -12px var(--red-glow),inset 0 1px #ffffff40}.card--revealed.card--blue{background:linear-gradient(160deg,#5b9bff,var(--blue));box-shadow:0 10px 26px -12px var(--blue-glow),inset 0 1px #ffffff40}.card--revealed.card--agent{background:linear-gradient(160deg,#4ade80,var(--agent));box-shadow:0 10px 26px -12px var(--agent-glow),inset 0 1px #ffffff40}.card--revealed.card--neutral{background:linear-gradient(160deg,#ded0ad,var(--neutral));color:#2a2620;text-shadow:none}.card--revealed.card--assassin{background:radial-gradient(circle at 50% 35%,#2a2f3c,var(--assassin));color:var(--assassin-fg);border:1px solid rgba(255,255,255,.12);box-shadow:0 0 0 1px #000,0 12px 30px -10px #000000e6;animation:assassin-reveal .8s ease both}.card--revealed.card--assassin .card__glyph{color:var(--red-soft);text-shadow:0 0 12px var(--red-glow)}.card--key.card--red{background:linear-gradient(160deg,#f8e3e6,#f1cdd2);box-shadow:inset 0 0 0 2px var(--red),0 8px 18px -12px var(--red-glow)}.card--key.card--blue{background:linear-gradient(160deg,#e2edfb,#cfe0f7);box-shadow:inset 0 0 0 2px var(--blue),0 8px 18px -12px var(--blue-glow)}.card--key.card--agent{background:linear-gradient(160deg,#dcf7e5,#c4eed2);box-shadow:inset 0 0 0 2px var(--agent),0 8px 18px -12px var(--agent-glow)}.card--key.card--neutral{background:linear-gradient(160deg,#efe7d2,#e3d8bd);box-shadow:inset 0 0 0 2px #b3a079}.card--key.card--assassin{background:linear-gradient(160deg,#2f333d,#1a1d25);color:#fff;box-shadow:inset 0 0 0 2px #000,0 0 18px -4px #000c}.card--key.card--assassin .card__word{color:#fff}.card--proposed{animation:proposed-pulse 1.3s ease-in-out infinite;z-index:3}.board__confirm{margin-top:1.2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1.1rem;background:var(--bg-elev);border:1px solid var(--focus);border-radius:var(--radius);box-shadow:0 0 0 1px #ffd1664d,0 14px 30px -14px #ffd16680;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);animation:rise-in .3s ease both}.board__confirm-actions{display:flex;gap:.6rem}.timer{display:flex;justify-content:space-between;align-items:center;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:.7rem 1.1rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-soft);transition:border-color .2s ease,box-shadow .2s ease}.timer__phase{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim)}.timer__clock{font-family:var(--font-display);font-size:1.6rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.02em}.timer--urgent{border-color:#f43f5e99;box-shadow:0 0 0 1px #f43f5e66,0 0 24px -6px var(--red-glow);animation:pulse-scale 1s ease-in-out infinite}.timer--urgent .timer__clock{color:var(--red-soft);text-shadow:0 0 16px var(--red-glow)}.result{position:fixed;top:0;right:0;bottom:0;left:0;background:#05080eb8;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:40;animation:overlay-in .3s ease both}.result__panel{position:relative;background:linear-gradient(180deg,#1a2134f5,#101522f5);border:1px solid var(--border-strong);border-radius:calc(var(--radius) + 6px);padding:2rem 1.9rem;max-width:640px;width:100%;box-shadow:var(--shadow);text-align:center;overflow:hidden;animation:panel-pop .5s cubic-bezier(.2,.8,.2,1) both}.result__panel:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--red),var(--focus),var(--blue))}.result__winner{margin:.3rem 0 .25rem;font-family:var(--font-display);font-size:2.3rem;letter-spacing:.01em}.result__winner--red{color:var(--red-soft);text-shadow:0 0 30px var(--red-glow)}.result__winner--blue{color:var(--blue-soft);text-shadow:0 0 30px var(--blue-glow)}.result__winner--agent{color:var(--agent-soft);text-shadow:0 0 30px var(--agent-glow)}.result__winner--assassin{color:var(--assassin-fg);text-shadow:0 0 30px rgba(0,0,0,.9)}.result__winner--draw{color:var(--text);text-shadow:0 0 30px var(--border-strong)}.result__reason{color:var(--text-dim);margin-top:0}.result__key{display:grid;grid-template-columns:repeat(5,1fr);gap:.4rem;margin:1.4rem 0}.result__key-card{display:flex;align-items:center;justify-content:center;aspect-ratio:5 / 3;font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em;padding:.4rem .2rem;border-radius:var(--radius-sm);color:#fff;animation:deal-in .4s ease backwards}.result__key-card--red{background:linear-gradient(160deg,#fb5d74,var(--red))}.result__key-card--blue{background:linear-gradient(160deg,#5b9bff,var(--blue))}.result__key-card--neutral{background:linear-gradient(160deg,#ded0ad,var(--neutral));color:#2a2620}.result__key-card--assassin{background:radial-gradient(circle at 50% 35%,#2a2f3c,var(--assassin));border:1px solid rgba(255,255,255,.14)}.result__key-card--agent{background:linear-gradient(160deg,#4ade80,var(--agent))}.result__key-card--teams{flex-direction:column;gap:.25rem;background:var(--surface-strong);border:1px solid var(--border);color:var(--text)}.result__key-word{font-size:.55rem;line-height:1.1}.result__key-tags{display:flex;gap:.2rem}.key-tag{width:.55rem;height:.55rem;border-radius:50%;border:1px solid rgba(0,0,0,.35);background:var(--neutral)}.key-tag--red.key-tag--agent{background:var(--red)}.key-tag--blue.key-tag--agent{background:var(--blue)}.key-tag--assassin{background:var(--assassin);border-color:#fff6}.key-tag--bystander{background:var(--neutral)}.toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.6rem;background:#141b2ceb;border:1px solid var(--border-strong);color:var(--text);padding:.75rem 1.25rem;border-radius:999px;box-shadow:var(--shadow);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:50;max-width:90vw;font-size:.92rem;animation:toast-in .35s cubic-bezier(.2,.8,.2,1) both}.toast:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--focus);box-shadow:0 0 10px var(--focus);flex:none}@media(max-width:960px){.game{grid-template-columns:1fr}.game__sidebar{position:static;top:auto}.lobby{grid-template-columns:1fr}.lobby__roster{grid-row:auto}}@media(max-width:560px){.app__main{padding:1rem .85rem 2.5rem}.board{gap:.45rem}.seats{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}
