:root{--bg: #0e0e16;--surface: #1c1c2e;--surface-2: #252540;--border: #2e2e4a;--accent: #818cf8;--accent-dim: #3730a3;--plus-color: #4ade80;--minus-color: #f87171;--text: #e2e8f0;--text-muted: #64748b;--text-dim: #94a3b8;--radius: 14px;--radius-sm: 8px;--gap: 12px;--header-h: 56px;--font-mono: ui-monospace, "Cascadia Code", "JetBrains Mono", Consolas, monospace;--game-accent: #2e2e4a;--game-accent-secondary: transparent}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;line-height:1.5;-webkit-font-smoothing:antialiased}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}input{font:inherit;color:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;min-height:44px;transition:opacity .15s,background .15s;white-space:nowrap}.btn:disabled{opacity:.45;pointer-events:none}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{opacity:.85}.btn--ghost{background:transparent;color:var(--text-dim);border:1px solid var(--border)}.btn--ghost:hover{background:var(--surface-2);color:var(--text)}.btn--sm{padding:8px 14px;font-size:.82rem;min-height:36px}.btn--lg{padding:14px 24px;font-size:1rem;min-height:52px}.btn--full{width:100%}.btn--large{min-height:56px;font-size:1.05rem}.input,.name-input{width:100%;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:1rem;min-height:48px;outline:none;transition:border-color .15s}.input:focus,.name-input:focus{border-color:var(--accent)}.input::placeholder,.name-input::placeholder{color:var(--text-muted)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:100dvh;color:var(--text-muted)}.spinner{width:36px;height:36px;border:3px solid var(--surface-2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:100dvh;padding:32px;text-align:center}.error-screen__icon{font-size:3rem}.error-screen__title{font-size:1.5rem;font-weight:800}.error-screen__body{color:var(--text-muted);max-width:320px;line-height:1.6}.role-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.role-badge--player{background:#818cf82e;color:var(--accent);border:1px solid rgba(129,140,248,.3)}.role-badge--audience{background:#94a3b81f;color:var(--text-muted);border:1px solid var(--border)}.conn-status{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:500;color:var(--text-muted)}.conn-status__dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted)}.conn-status--connected .conn-status__dot{background:var(--game-accent-text, #4ade80)}.conn-status--connecting .conn-status__dot,.conn-status--reconnecting .conn-status__dot{background:#facc15;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.home-page{max-width:520px;margin:0 auto;padding:32px 16px 48px}.home-header{text-align:center;margin-bottom:36px}.home-header__title{font-size:clamp(2rem,8vw,3rem);font-weight:800;letter-spacing:-.5px;color:var(--text)}.home-header__wand{margin-right:8px}.home-header__tagline{color:var(--text-muted);font-size:.9rem;margin-top:6px}.home-form{display:flex;flex-direction:column;gap:28px}.form-section{display:flex;flex-direction:column;gap:12px}.form-section__label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.preset-card{padding:12px 8px;background:var(--surface);border:2px solid transparent;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;color:var(--text-dim);text-align:center;min-height:52px;transition:border-color .15s,color .15s}.preset-card:hover{border-color:var(--border);color:var(--text)}.preset-card--selected{border-color:var(--accent);color:var(--text);background:var(--surface-2)}.name-list{display:flex;flex-direction:column;gap:8px}.name-row{display:flex;align-items:center;gap:8px}.name-remove{flex-shrink:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.8rem;transition:background .15s}.name-remove:hover{background:var(--surface-2);color:var(--minus-color)}.form-error{color:var(--minus-color);font-size:.9rem;text-align:center}.session-page{display:flex;flex-direction:column;min-height:100dvh}.session-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:var(--header-h);background:var(--bg);border-bottom:1px solid var(--border);gap:12px;border-top:3px solid var(--game-accent, transparent)}.session-header__left{display:flex;align-items:center;gap:12px;min-width:0}.session-header__right{display:flex;align-items:center;gap:8px;flex-shrink:0}.session-header__game{font-weight:700;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--game-accent-text, var(--text))}.share-panel{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 16px;display:flex;flex-direction:column;gap:14px}.share-panel__header{display:flex;align-items:center;justify-content:space-between}.share-panel__heading{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.share-panel__close{color:var(--text-muted);font-size:.78rem;padding:4px 8px;border-radius:var(--radius-sm);transition:background .15s}.share-panel__close:hover{background:var(--surface-2);color:var(--text)}.share-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.share-row__info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.share-row__label{font-weight:600;font-size:.9rem}.share-row__desc{font-size:.78rem;color:var(--text-muted)}.share-row__url{font-size:.72rem;color:var(--text-muted);font-family:ui-monospace,Cascadia Code,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;margin-top:2px}.share-row__actions{display:flex;gap:6px;flex-shrink:0;align-items:flex-start;padding-top:2px}.btn--copied{background:#166534!important;color:#4ade80!important}.audience-banner{background:var(--surface);text-align:center;padding:8px;font-size:.82rem;color:var(--text-muted);border-bottom:1px solid var(--border)}.toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--surface-2);border:1px solid var(--border);padding:10px 20px;border-radius:var(--radius);font-size:.9rem;z-index:100;white-space:nowrap;animation:fadeInUp .2s ease}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.player-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--gap);padding:var(--gap);align-content:start}.empty-state{grid-column:1 / -1;text-align:center;color:var(--text-muted);padding:40px}.session-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:8px;align-items:center;background:var(--bg)}.add-player-form{display:flex;gap:8px;width:100%}.add-player-form .name-input{flex:1}.player-card{background:var(--surface);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:14px;border-left:4px solid var(--player-color, var(--game-accent));transition:border-color .2s;position:relative;overflow:hidden}.player-card:after{content:"";position:absolute;width:90px;height:90px;border-radius:50%;background:var(--player-color, var(--game-accent, transparent));opacity:.28;top:-28px;right:-28px;pointer-events:none}.player-card__header{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:36px}.player-card__name{font-size:1rem;font-weight:700;color:var(--text);background:none;border:none;padding:4px 0;text-align:left;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-bottom:1px solid transparent;transition:border-color .15s}.player-card__name:hover{border-bottom-color:var(--border)}.player-card__name-input{flex:1;background:var(--surface-2);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:6px 10px;font-size:1rem;font-weight:700;outline:none;min-width:0}.player-card__remove{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--text-muted);font-size:.78rem;transition:background .15s,color .15s}.player-card__remove:hover{background:var(--surface-2);color:var(--minus-color)}.player-card__score{font-family:var(--font-mono);font-size:clamp(3.5rem,14vw,5.5rem);font-weight:800;text-align:center;line-height:1;letter-spacing:-2px;color:var(--text);font-variant-numeric:tabular-nums;padding:12px 0}@keyframes scoreFlashPlus{0%{transform:scale(1);color:var(--text)}30%{transform:scale(1.15);color:#4ade80}to{transform:scale(1);color:var(--text)}}@keyframes scoreFlashMinus{0%{transform:scale(1);color:var(--text)}30%{transform:scale(1.15);color:#f87171}to{transform:scale(1);color:var(--text)}}.player-card__score--flash-plus{animation:scoreFlashPlus .2s ease-out}.player-card__score--flash-minus{animation:scoreFlashMinus .2s ease-out}.player-card__secondary{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.secondary-counter{font-size:.78rem;color:var(--text-muted);background:var(--surface-2);border-radius:4px;padding:2px 8px}.player-card__controls{display:flex;flex-direction:column;gap:10px}.step-buttons{display:grid;grid-template-columns:1fr 1.6fr 1.6fr 1fr;gap:6px}.step-btn{border-radius:var(--radius-sm);font-weight:700;display:flex;align-items:center;justify-content:center;transition:opacity .1s,transform .1s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.step-btn:active{transform:scale(.94)}.step-btn--lg{min-height:60px;font-size:1.4rem}.step-btn--lg.step-btn--minus{background:#f871712e;color:var(--minus-color);border:1px solid rgba(248,113,113,.3)}.step-btn--lg.step-btn--plus{background:#4ade802e;color:var(--plus-color);border:1px solid rgba(74,222,128,.3)}.step-btn--lg.step-btn--minus:hover{background:#f871714d}.step-btn--lg.step-btn--plus:hover{background:#4ade804d}.step-btn--sm{min-height:44px;font-size:.9rem;background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border)}.step-btn--sm:hover{background:var(--border);color:var(--text)}.step-btn--sm.step-btn--minus{background:#f871711a;color:var(--minus-color);border-color:#f8717133}.step-btn--sm.step-btn--plus{background:#4ade801a;color:var(--plus-color);border-color:#4ade8033}.step-btn--sm.step-btn--minus:hover{background:#f8717133}.step-btn--sm.step-btn--plus:hover{background:#4ade8033}.math-input{width:100%;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.95rem;min-height:44px;outline:none;text-align:center;transition:border-color .15s}.math-input:focus{border-color:var(--accent)}.math-input::placeholder{color:var(--text-muted);font-size:.85rem}.btn--active{background:var(--surface-2);color:var(--accent);border-color:#818cf866}.history-panel{background:var(--surface);border-bottom:1px solid var(--border);max-height:40vh;overflow-y:auto;display:flex;flex-direction:column}.history-panel__header{position:sticky;top:0;background:var(--surface);display:flex;align-items:center;justify-content:space-between;padding:10px 16px 8px;border-bottom:1px solid var(--border);z-index:1}.history-panel__title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.history-panel__close{color:var(--text-muted);font-size:.78rem;padding:4px 8px;border-radius:var(--radius-sm);transition:background .15s}.history-panel__close:hover{background:var(--surface-2);color:var(--text)}.history-panel__loading,.history-panel__empty,.history-panel__error{padding:16px;font-size:.85rem;color:var(--text-muted);text-align:center}.history-panel__error{color:var(--minus-color)}.history-list{list-style:none;display:flex;flex-direction:column;padding:6px 0}.history-entry{display:flex;align-items:center;gap:8px;padding:7px 16px;font-size:.82rem;border-bottom:1px solid rgba(46,46,74,.5);flex-wrap:nowrap}.history-entry:last-child{border-bottom:none}.history-entry--voided{opacity:.5}.history-entry--voided .history-entry__player{text-decoration:line-through}.history-entry__player{font-weight:600;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;max-width:7rem}.history-entry__counter{font-size:.72rem;color:var(--text-muted);background:var(--surface-2);border-radius:3px;padding:1px 5px;white-space:nowrap;flex-shrink:0}.history-entry__delta{font-weight:700;font-variant-numeric:tabular-nums;min-width:3ch;text-align:right;flex-shrink:0}.delta--plus{color:var(--plus-color)}.delta--minus{color:var(--minus-color)}.delta--zero{color:var(--text-muted)}.history-entry__score{color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;white-space:nowrap}.history-entry__time{color:var(--text-muted);font-size:.75rem;flex-shrink:0;white-space:nowrap;margin-left:auto}.history-entry__voided-badge{font-size:.68rem;font-weight:700;color:var(--text-muted);border:1px solid var(--border);border-radius:3px;padding:1px 5px;flex-shrink:0;text-transform:uppercase;letter-spacing:.04em}@media(max-width:360px){.player-card__score{font-size:3rem}.step-btn--lg{min-height:52px;font-size:1.2rem}}@media(min-width:640px){.player-grid{padding:16px;gap:16px}}.table-view{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;background:var(--bg);overflow:hidden}.table-cell{overflow:hidden;position:relative;container-type:size;border:1px solid var(--border)}.table-cell__inner{position:absolute;top:50%;left:50%;width:100cqw;height:100cqh;transform:translate(-50%,-50%) rotate(var(--rotation, 0deg))}.table-cell__inner--sideways{width:100cqh;height:100cqw}.table-cell .player-card{height:100%;border-radius:0;border-left:none;border-bottom:4px solid var(--player-color, var(--game-accent));justify-content:center}.table-cell .player-card__score{font-size:clamp(2rem,14cqw,5rem)}.table-exit-btn{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:30;background:#0e0e16cc;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:99px;color:var(--text-muted);font-size:.78rem;font-weight:600;padding:6px 14px;min-height:36px;min-width:120px;transition:background .15s,color .15s;pointer-events:all}.table-exit-btn:hover,.table-exit-btn:focus{background:var(--surface-2);color:var(--text)}.settings-grid{display:flex;flex-direction:column;gap:10px}.setting-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.setting-row--toggle{flex-wrap:nowrap}.setting-row__label{font-size:.85rem;color:var(--text-dim);min-width:120px;flex-shrink:0}.setting-row__unit{font-size:.85rem;color:var(--text-muted)}.setting-input{padding:8px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.9rem;width:90px;outline:none;transition:border-color .15s;-moz-appearance:textfield}.setting-input:focus{border-color:var(--accent)}.setting-input--inline{width:80px}.setting-select{padding:8px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.85rem;outline:none;flex:1;min-width:0;transition:border-color .15s}.setting-select:focus{border-color:var(--accent)}.toggle-label{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-dim);cursor:pointer}.toggle-label input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.toggle-label__text{white-space:nowrap}.setting-note{font-size:.82rem;color:var(--text-muted);font-style:italic}.session-menu{position:relative}.session-menu__dropdown{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:160px;z-index:50;overflow:hidden;box-shadow:0 8px 24px #0006;animation:fadeInDown .15s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.session-menu__item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;font-size:.9rem;color:var(--text);text-align:left;transition:background .12s}.session-menu__item:hover{background:var(--border)}.session-menu__item+.session-menu__item{border-top:1px solid var(--border)}.victory-hint{display:flex;align-items:center;justify-content:center;gap:8px;padding:5px 16px;font-size:.75rem;color:var(--text-muted);background:var(--surface);border-bottom:1px solid var(--game-accent, var(--border));letter-spacing:.01em}.victory-hint--editing{padding:8px 16px;gap:8px;flex-wrap:wrap}.victory-hint__label{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.victory-hint__input{width:72px;padding:4px 8px;background:var(--surface-2);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--text);font-size:.85rem;text-align:center;outline:none;-moz-appearance:textfield}.victory-hint__edit-btn{font-size:.7rem;color:var(--text-muted);opacity:.5;padding:2px 5px;border-radius:4px;transition:opacity .15s,background .15s}.victory-hint:hover .victory-hint__edit-btn{opacity:1}.victory-hint__edit-btn:hover{background:var(--surface-2)}.victory-banner{background:linear-gradient(135deg,#7c3aed,#1d4ed8,#0e7490);padding:14px 16px;animation:victorySlideIn .4s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden}.victory-banner:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.15) 50%,transparent 70%);animation:shimmer 2s ease-in-out infinite}@keyframes victorySlideIn{0%{opacity:0;transform:translateY(-12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}.victory-banner__inner{display:flex;align-items:center;gap:12px;max-width:600px;margin:0 auto;position:relative;z-index:1}.victory-banner__emoji{font-size:1.8rem;animation:bounce .6s ease infinite alternate;flex-shrink:0}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-4px)}}.victory-banner__text{flex:1;font-size:1.25rem;font-weight:800;color:#fff;line-height:1.2}.victory-banner__name{color:#fde68a}.victory-banner__dismiss{flex-shrink:0;color:#ffffffb3;font-size:1rem;padding:6px 10px;border-radius:var(--radius-sm);transition:background .15s,color .15s}.victory-banner__dismiss:hover{background:#ffffff26;color:#fff}.player-card--eliminated{opacity:.45;filter:grayscale(.6)}.player-card__eliminated-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--minus-color);border:1px solid rgba(248,113,113,.4);border-radius:4px;padding:2px 6px;flex-shrink:0}
