:root{--bg: #0f172a;--surface: #1e293b;--surface2: #283548;--surface3: #334155;--accent: #818cf8;--text: #f1f5f9;--muted: #94a3b8;--team1: #60a5fa;--team2: #f472b6;--danger: #ef4444;--ok: #4ade80;--border: rgba(241, 245, 249, .1);--border-strong: rgba(241, 245, 249, .16);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px);font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%;min-height:100dvh;margin:0;width:100%;min-width:0;max-width:100%;overflow-x:hidden;overflow-x:clip;background:var(--bg)}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{position:relative;color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.45;touch-action:manipulation;overscroll-behavior-y:none;background:var(--bg)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:var(--bg)}body:after{content:"";position:fixed;top:0;left:0;right:0;height:calc(var(--safe-top) + 8px);background:var(--bg);z-index:9998;pointer-events:none}button{font:inherit;cursor:pointer;border:none;border-radius:10px;min-height:48px;padding:.7rem 1rem;touch-action:manipulation;transition:background .15s ease,border-color .15s ease,opacity .15s ease}button:active:not(:disabled){transform:scale(.97);transition:transform .08s ease}button:disabled{opacity:.4;cursor:not-allowed}h1{font-size:1.6rem;font-weight:700;margin:0 0 .3rem;letter-spacing:-.02em}.brand{text-align:center}.brand-lockup{display:flex;align-items:center;justify-content:center;gap:.65rem;margin-bottom:.3rem}.brand-lockup h1{margin:0}.app-logo{flex-shrink:0;width:2.4rem;height:2.4rem;border-radius:22%;object-fit:cover}.app-logo--play{width:1.8rem;height:1.8rem}.play-brand-lockup{display:flex;align-items:center;justify-content:center;gap:.45rem}.playliist-mark{font-family:Inter,system-ui,sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.12em;display:inline-flex;align-items:center;gap:.02em;line-height:1}.playliist-mark.brand-title{font-size:1.15rem;color:var(--text)}.playliist-mark--compact{font-size:.68rem;letter-spacing:.1em}.play-brand.playliist-mark{font-weight:700;letter-spacing:.1em}.playliist-mark__char{display:inline-block;color:inherit}.playliist-embed{font-family:Inter,system-ui,sans-serif;font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.78em;display:inline-block;vertical-align:baseline;color:var(--text)}.lead{color:var(--muted);font-size:.92rem;margin:0 0 1.2rem}.hint{font-size:.82rem;color:var(--muted);margin:.35rem 0 0}.app{min-height:100%;min-height:100dvh;padding:calc(var(--safe-top) + .8rem) 1rem calc(1rem + var(--safe-bottom));width:100%;max-width:min(30rem,100%);margin:0 auto;min-width:0;box-sizing:border-box}.app-setup{overflow-x:visible;overflow-y:visible;-webkit-overflow-scrolling:touch}.app-rolegate{display:flex;flex-direction:column}.app-rolegate .brand{flex-shrink:0}.app-play{display:flex;flex-direction:column;padding-bottom:0;min-height:100dvh;min-height:100svh;max-height:none;overflow:clip}.panel{background:var(--surface);border-radius:14px;padding:1rem;margin-bottom:.75rem;border:1px solid var(--border);min-width:0;max-width:100%}.panel h2{font-size:.72rem;text-transform:uppercase;letter-spacing:.09em;color:var(--muted);font-weight:600;margin:0 0 .6rem}.panel-title{margin:0}.row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.score-big{font-size:2.15rem;font-weight:700;line-height:1;font-variant-numeric:tabular-nums}.btn-primary{background:var(--accent);color:#fff;font-weight:700;width:100%}.btn-primary:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 85%,#fff 15%)}.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border-strong)}.btn-secondary:hover:not(:disabled){border-color:#f1f5f933;background:#f1f5f90d}.btn-ghost{background:transparent;color:var(--muted);min-height:44px}.btn-ghost:hover:not(:disabled){color:var(--text)}.play-back-btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;min-height:48px;padding:.45rem .9rem .45rem .45rem;border-radius:12px;font:inherit;color:var(--text);background:var(--surface2);border:1px solid var(--border-strong);transition:background .15s ease,border-color .15s ease}.play-back-btn:hover:not(:disabled){background:var(--surface3);border-color:#f1f5f92e}.play-back-btn:active:not(:disabled){transform:scale(.97)}.play-back-btn--primary{border-color:color-mix(in srgb,var(--accent) 50%,transparent)}.play-back-btn--primary:hover:not(:disabled){border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface2))}.play-back-btn--primary .play-back-btn__ico{background:var(--accent);color:#fff}.play-back-btn--tone-back{border-color:var(--border)}.play-back-btn--tone-back:hover:not(:disabled){border-color:var(--border-strong)}.play-back-btn--tone-back .play-back-btn__ico{background:var(--surface3);color:var(--muted)}.play-back-btn--tone-p2{border-color:color-mix(in srgb,var(--team1) 35%,transparent)}.play-back-btn--tone-p2:hover:not(:disabled){border-color:color-mix(in srgb,var(--team1) 55%,transparent);background:color-mix(in srgb,var(--team1) 8%,var(--surface2))}.play-back-btn--tone-p2 .play-back-btn__ico{background:var(--team1);color:#fff}.play-back-btn--tone-p2 .play-back-btn__kicker{color:color-mix(in srgb,var(--team1) 60%,var(--muted))}.play-back-btn--tone-p3{border-color:color-mix(in srgb,var(--team2) 35%,transparent)}.play-back-btn--tone-p3:hover:not(:disabled){border-color:color-mix(in srgb,var(--team2) 55%,transparent);background:color-mix(in srgb,var(--team2) 8%,var(--surface2))}.play-back-btn--tone-p3 .play-back-btn__ico{background:var(--team2);color:#fff}.play-back-btn--tone-p3 .play-back-btn__kicker{color:color-mix(in srgb,var(--team2) 60%,var(--muted))}.play-back-btn--tone-df{border-color:color-mix(in srgb,var(--accent) 35%,transparent)}.play-back-btn--tone-df:hover:not(:disabled){border-color:color-mix(in srgb,var(--accent) 55%,transparent);background:color-mix(in srgb,var(--accent) 8%,var(--surface2))}.play-back-btn--tone-df .play-back-btn__ico{background:var(--accent);color:#fff}.play-back-btn--tone-df .play-back-btn__kicker{color:color-mix(in srgb,var(--accent) 60%,var(--muted))}.play-back-btn--tone-quit{border-color:color-mix(in srgb,var(--danger) 30%,transparent)}.play-back-btn--tone-quit:hover:not(:disabled){border-color:color-mix(in srgb,var(--danger) 50%,transparent);background:color-mix(in srgb,var(--danger) 8%,var(--surface2))}.play-back-btn--tone-quit .play-back-btn__ico{background:color-mix(in srgb,var(--danger) 80%,var(--surface3));color:#fff}.play-back-btn--tone-quit .play-back-btn__kicker{color:color-mix(in srgb,var(--danger) 55%,var(--muted))}.play-back-btn__ico{flex-shrink:0;width:1.9rem;height:1.9rem;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;font-size:.95rem;font-weight:700;line-height:1;color:#fff;background:var(--accent)}.play-back-btn__text{display:flex;flex-direction:column;align-items:flex-start;gap:.05rem;min-width:0;text-align:left}.play-back-btn__kicker{font-size:.56rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.play-back-btn__title{font-size:.82rem;font-weight:700;letter-spacing:.01em;line-height:1.2}.play-back-btn--solo{display:flex;width:fit-content;max-width:100%;margin:.9rem auto 0}.play-back-btn--solo .play-back-btn__text{align-items:center;text-align:center}.setup-join-slot{margin-bottom:1rem}.setup-join-primary-btn{width:100%;min-height:48px;justify-content:center}.setup-join-error{margin:.55rem 0 0;color:var(--danger)}.setup-launch-panel{margin-bottom:1rem}.setup-launch-title{margin-bottom:.35rem}.setup-launch-lead{margin:0 0 1rem;line-height:1.45}.setup-launch-btn{width:100%;min-height:48px;margin-bottom:.75rem}.setup-names-details{margin-top:.25rem;border-radius:10px;border:1px solid var(--border);padding:.5rem .75rem;background:var(--surface)}.setup-names-details summary{cursor:pointer;font-size:.85rem;color:var(--muted)}.setup-grid--optional{margin-top:.75rem}.setup-grid{display:grid;gap:.75rem;min-width:0}.setup-field{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:.65rem;min-width:0}.setup-field--dj{border-color:color-mix(in srgb,var(--accent) 30%,transparent)}.setup-team-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:.65rem;min-width:0}.setup-field--team1{border-color:color-mix(in srgb,var(--team1) 30%,transparent)}.setup-field--team2{border-color:color-mix(in srgb,var(--team2) 30%,transparent)}.setup-label{display:block;margin:0 0 .4rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.setup-input{margin:0;border-radius:8px;font-size:1.05rem;min-height:48px;padding:.7rem .8rem;width:100%;min-width:0;max-width:100%}.setup-input::placeholder{color:var(--muted)}input[type=text],input[type=number]{width:100%;max-width:100%;min-width:0;padding:.65rem .75rem;border-radius:8px;border:1px solid var(--border-strong);background:var(--surface2);color:var(--text);font-size:16px;min-height:48px;box-sizing:border-box;transition:border-color .15s ease}input[type=text]:focus,input[type=number]:focus{border-color:var(--accent);outline:none}input:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.rules-details{background:var(--surface);border-radius:12px;border:1px solid var(--border);margin-bottom:1rem;overflow-x:clip;overflow-y:visible;min-width:0;max-width:100%}.rules-details summary{padding:.85rem 1rem;font-weight:600;cursor:pointer;list-style:none;color:var(--muted)}.rules-details summary::-webkit-details-marker{display:none}.rules-body{padding:0 1rem 1rem;font-size:.86rem;color:var(--muted)}.rules-points{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .65rem;margin-bottom:.65rem;padding:.55rem .65rem;border:1px solid var(--border);border-radius:10px;background:var(--surface2);font-size:.82rem}.rules-points-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.rules-timeline{display:flex;flex-wrap:nowrap;gap:.4rem;margin-bottom:.75rem;width:100%;max-width:100%;min-width:0;overflow-x:auto;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;scrollbar-width:none}.rules-timeline::-webkit-scrollbar{display:none}.rules-phase-chip{display:inline-flex;align-items:center;min-height:32px;padding:.3rem .55rem;border-radius:8px;font-size:.74rem;font-weight:600;color:var(--text);background:var(--surface2);border:1px solid var(--border);white-space:nowrap}.rules-phase-card{border:1px solid var(--border);border-radius:10px;background:var(--surface2);padding:.6rem .7rem;margin-bottom:.55rem}.rules-phase-card h3{margin:0 0 .4rem;font-size:.78rem;letter-spacing:.03em;text-transform:uppercase;font-weight:700;color:var(--text)}.rules-phase-card ol{margin:0;padding-left:1.05rem;color:var(--muted);font-size:.82rem}.rules-phase-card li{margin-bottom:.22rem}.rules-phase-card li:last-child{margin-bottom:0}.pwa-tip{margin:.1rem 0 .95rem;padding:.85rem 1rem;border-radius:10px;text-align:left;border:1px solid var(--border);background:var(--surface);min-width:0;max-width:100%;overflow-wrap:anywhere}.pwa-tip-title{margin:0 0 .4rem;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}.pwa-tip-lead{margin:0 0 .6rem;font-size:.84rem;line-height:1.45;color:var(--muted)}.pwa-tip-lead strong{color:var(--text);font-weight:600}.pwa-tip-list{margin:0;padding-left:1.1rem;font-size:.8rem;line-height:1.5;color:var(--muted)}.pwa-tip-list li+li{margin-top:.4rem}.pwa-tip-list strong{color:var(--text);font-weight:600}.play-top{flex-shrink:0;margin:0 -1rem;padding:calc(var(--safe-top) + .35rem) 1rem .6rem;background:var(--bg);border-bottom:1px solid var(--border)}.play-top-row{display:flex;align-items:center;justify-content:center;gap:.55rem;margin-bottom:.5rem;position:relative}.play-quit-btn{position:absolute;right:0;top:50%;transform:translateY(-50%);min-height:32px;padding:.25rem .6rem;border-radius:8px;font-size:.72rem;font-weight:600;color:var(--danger);background:transparent;border:1px solid color-mix(in srgb,var(--danger) 30%,transparent);transition:background .15s ease,border-color .15s ease}.play-quit-btn:active:not(:disabled){transform:translateY(-50%) scale(.95)}.play-quit-btn:hover:not(:disabled){background:color-mix(in srgb,var(--danger) 10%,transparent);border-color:color-mix(in srgb,var(--danger) 50%,transparent)}.play-top-identity{display:flex;flex-direction:column;align-items:center;gap:.15rem;min-width:0;text-align:center}.play-brand{font-weight:700;font-size:.92rem;letter-spacing:.1em}.play-dj{font-size:.74rem;color:var(--muted);text-align:center;line-height:1.3;max-width:100%}.play-scores{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.6rem}.play-score-cell{border-radius:10px;padding:.5rem .6rem;border:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;gap:.1rem;min-width:0}.play-score-cell--1{border-color:color-mix(in srgb,var(--team1) 30%,transparent)}.play-score-cell--2{border-color:color-mix(in srgb,var(--team2) 30%,transparent)}.play-score-num{font-size:1.65rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1;font-family:SF Mono,Menlo,Monaco,ui-monospace,monospace}.phase-tabs{display:flex;gap:0;margin-bottom:0;border-bottom:1px solid var(--border)}.phase-tabs button{flex:1;min-height:40px;font-size:.76rem;font-weight:600;padding:.4rem .3rem;background:transparent;color:var(--muted);border:none;border-bottom:2px solid transparent;border-radius:0;transition:color .15s ease,border-color .15s ease}.phase-tabs button:active:not(:disabled){transform:none}.phase-tabs button.active{color:var(--text);border-bottom-color:var(--accent)}.phase-tabs button:disabled{opacity:.3}.role-tabs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.4rem;margin-top:.55rem}.role-tabs button{min-height:42px;font-size:.77rem;font-weight:600;padding:.38rem .35rem;background:var(--surface2);color:var(--muted);border:1px solid transparent}.role-tabs button.active{background:color-mix(in srgb,var(--accent) 15%,var(--surface2));border-color:color-mix(in srgb,var(--accent) 40%,transparent);color:var(--text)}.rolegate-panel{margin-top:1rem}.app-rolegate .rolegate-panel{flex:1;display:flex;flex-direction:column;min-height:0;margin-top:.55rem;margin-bottom:0}.rolegate-lead{margin:.15rem 0 .8rem;line-height:1.45}.app-rolegate .rolegate-lead{flex-shrink:0;margin-bottom:1rem}.app-rolegate .rolegate-panel>.panel-title{flex-shrink:0;font-size:clamp(.78rem,2dvh,.9rem);margin-bottom:.5rem}.rolegate-lead strong{color:var(--text);font-weight:700}.rolegate-roles-count{margin:-.35rem 0 .75rem;font-size:.88rem}.play-invite-hint{margin:.35rem 0 0;padding:0 .25rem .4rem;font-size:.76rem;line-height:1.35;text-align:center;color:var(--muted)}.rolegate-grid{display:grid;gap:.65rem}.app-rolegate .rolegate-grid{flex:1;min-height:min(52dvh,22rem);grid-template-rows:minmax(0,1.5fr) minmax(0,1fr) minmax(0,1fr);gap:clamp(.65rem,2.5dvh,1rem);align-content:stretch}.rolegate-btn{width:100%;min-height:58px;border-radius:12px;font-weight:700;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;padding:.7rem .9rem;text-align:center;line-height:1.2;border:none}.app-rolegate .rolegate-btn{min-height:0;height:100%;border-radius:clamp(12px,2dvw,16px);padding:clamp(.8rem,2dvh,1.2rem) 1rem;gap:clamp(.3rem,1dvh,.5rem)}.rolegate-btn-kicker{font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.rolegate-btn-name{font-size:1rem;font-weight:700}.app-rolegate .rolegate-btn--dj .rolegate-btn-kicker{font-size:clamp(.7rem,2dvh,.85rem);letter-spacing:.12em}.app-rolegate .rolegate-btn--dj .rolegate-btn-name{font-size:clamp(1.15rem,3.5dvh,1.45rem);font-weight:700;line-height:1.15}.app-rolegate .rolegate-btn--t1 .rolegate-btn-kicker,.app-rolegate .rolegate-btn--t2 .rolegate-btn-kicker{font-size:clamp(.6rem,1.7dvh,.74rem);letter-spacing:.1em}.app-rolegate .rolegate-btn--t1 .rolegate-btn-name,.app-rolegate .rolegate-btn--t2 .rolegate-btn-name{font-size:clamp(.95rem,2.8dvh,1.2rem);font-weight:700;line-height:1.18}.rolegate-btn--dj{background:var(--accent);color:#fff}.app-rolegate .rolegate-btn--dj{background:var(--accent)}.rolegate-btn--dj .rolegate-btn-kicker{color:color-mix(in srgb,var(--bg) 60%,transparent)}.rolegate-btn--t1,.rolegate-btn--t2{background:var(--surface);color:var(--text);border:1px solid var(--border-strong)}.rolegate-btn--t1{border-color:color-mix(in srgb,var(--team1) 35%,transparent)}.rolegate-btn--t1 .rolegate-btn-kicker{color:var(--team1)}.rolegate-btn--t2{border-color:color-mix(in srgb,var(--team2) 35%,transparent)}.rolegate-btn--t2 .rolegate-btn-kicker{color:var(--team2)}.rolegate-end-zone{display:flex;flex-direction:column;align-items:center;margin-top:2.4rem;padding-top:1.5rem;border-top:1px solid var(--border)}.app-rolegate .rolegate-end-zone{flex-shrink:0;margin-top:auto;padding-top:clamp(1rem,3dvh,1.6rem)}.rolegate-end-hint{margin:0 0 .55rem;font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:center;line-height:1.35}.rolegate-end-btn{width:fit-content;max-width:100%;margin:0;padding:.4rem 1rem;min-height:40px;border-radius:8px;font:inherit;font-size:.78rem;font-weight:600;cursor:pointer;color:var(--danger);background:transparent;border:1px solid color-mix(in srgb,var(--danger) 30%,transparent);transition:background .15s ease,border-color .15s ease}.rolegate-end-btn:hover{background:color-mix(in srgb,var(--danger) 10%,transparent);border-color:color-mix(in srgb,var(--danger) 50%,transparent)}.rolegate-end-btn:active:not(:disabled){transform:scale(.97)}.label-team1{color:var(--team1);font-weight:700}.label-team2{color:var(--team2);font-weight:700}.app-play .alert{flex-shrink:0;margin:.55rem 0 0}.alert{background:color-mix(in srgb,var(--danger) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--danger) 30%,transparent);border-radius:10px;padding:.75rem;font-size:.88rem}.play-main{flex:1;min-height:0;min-width:0;display:flex;flex-direction:column;overflow-x:hidden;overflow-x:clip;overflow-y:hidden;padding:.3rem 0}.app-play--team .play-main{display:flex;flex-direction:column;padding-bottom:calc(.5rem + var(--safe-bottom))}.team-play-stack{flex:1;min-height:0;display:flex;flex-direction:column;gap:.5rem}.app-play--team .team-play-stack>.panel{margin-bottom:0}.app-play--team .team-play-stack .team-answer-card{flex:1 1 0;min-height:min(42dvh,22rem);display:flex;flex-direction:column}.app-play--team .team-play-stack .team-answer-card .setup-grid{flex:1;min-height:0;justify-content:center;gap:1rem}.app-play--team .team-play-stack .team-answer-card .btn-primary,.app-play--team .team-play-stack .team-answer-card .row{flex-shrink:0;margin-top:auto}.app-play--team .team-play-panel--result{flex:1;min-height:0;display:flex;flex-direction:column}.app-play--team .team-play-panel--result .team-result-card{flex:1;min-height:min(36dvh,18rem);display:flex;flex-direction:column;justify-content:center}.app-play--team .team-play-panel--deathfest{flex:1;min-height:min(32dvh,14rem);display:flex;flex-direction:column;justify-content:center}.app-play--team .team-play-back.play-back-btn--solo{margin-top:auto;margin-bottom:0;width:100%;max-width:100%;align-self:stretch}.dj-swipe{display:flex;gap:.6rem;width:100%;max-width:100%;min-width:0;flex:1;min-height:0;overflow-x:auto;overflow-y:hidden;overscroll-behavior-x:contain;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:.2rem}.dj-swipe-hint{flex-shrink:0;text-align:center;font-size:.68rem;color:var(--muted);margin:0 0 .2rem;letter-spacing:.08em;opacity:.6}.dj-swipe::-webkit-scrollbar{display:none}.dj-swipe-page{flex:0 0 100%;min-width:0;max-height:100%;scroll-snap-align:start;display:flex;flex-direction:column}.dj-swipe-page>.panel{flex:1;min-height:0;margin-bottom:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.ptr-indicator{position:fixed;top:0;left:50%;translate:-50% 0;z-index:10000;transform:translateY(0);opacity:0;transition:transform .2s ease,opacity .2s ease;pointer-events:none}.ptr-spinner{width:24px;height:24px;border:2.5px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;margin:12px auto}.ptr-loading .ptr-spinner{animation:ptr-spin .6s linear infinite}@keyframes ptr-spin{to{transform:rotate(360deg)}}.music-status{text-align:center;padding:.55rem .7rem;border-radius:10px;font-size:.84rem;font-weight:600;color:var(--muted);background:var(--surface2);border:1px solid var(--border);margin:.3rem 0}.music-status--playing{color:var(--ok);background:color-mix(in srgb,var(--ok) 10%,var(--surface));border-color:color-mix(in srgb,var(--ok) 30%,transparent)}.spotify-block{margin:.4rem 0 .5rem;padding-top:.4rem;border-top:1px solid var(--border)}.spotify-connect-btn{width:100%}.spotify-now-playing{display:flex;align-items:center;gap:.55rem;padding:.5rem;border-radius:10px;background:var(--surface2);margin-bottom:.55rem}.spotify-np-img{flex-shrink:0;width:44px;height:44px;border-radius:6px;object-fit:cover}.spotify-np-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.05rem}.spotify-np-name{font-size:.84rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-np-artist{font-size:.74rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-np-controls{flex-shrink:0;display:flex;gap:.3rem}.spotify-ctrl-btn{min-height:38px;min-width:38px;padding:0;border-radius:50%;background:var(--accent);color:#fff;font-size:1rem;display:inline-flex;align-items:center;justify-content:center}.spotify-ctrl-btn:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 85%,#fff 15%)}.spotify-ctrl-btn--secondary{background:var(--surface3);color:var(--text)}.spotify-ctrl-btn--secondary:hover:not(:disabled){background:color-mix(in srgb,var(--surface3) 80%,#fff 20%)}.spotify-shuffle-badge{flex-shrink:0;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);padding:.2rem .45rem;border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);border-radius:6px}.spotify-tabs{display:flex;gap:0;margin-bottom:.5rem;border-bottom:1px solid var(--border)}.spotify-tabs button{flex:1;min-height:36px;font-size:.76rem;font-weight:600;padding:.35rem .3rem;background:transparent;color:var(--muted);border:none;border-bottom:2px solid transparent;border-radius:0;transition:color .15s ease,border-color .15s ease}.spotify-tabs button:active:not(:disabled){transform:none}.spotify-tabs button.active{color:var(--text);border-bottom-color:var(--accent)}.spotify-back-btn{min-height:34px;padding:.25rem .5rem;margin-bottom:.4rem;background:transparent;color:var(--muted);font-size:.76rem;font-weight:600;border:none;border-radius:8px}.spotify-back-btn:hover{color:var(--text)}.spotify-pl-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.45rem}.spotify-pl-header-img{flex-shrink:0;width:48px;height:48px;border-radius:6px;object-fit:cover}.spotify-pl-header-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.05rem}.spotify-pl-header-name{font-size:.88rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-pl-header-count{font-size:.72rem;color:var(--muted)}.spotify-playlists.spotify-playlists{max-height:160px}.spotify-search{margin-bottom:.35rem}.spotify-search-input{width:100%;font-size:16px}.spotify-results{list-style:none;margin:0 0 .4rem;padding:0;max-height:240px;overflow-y:auto;border-radius:10px;border:1px solid var(--border);background:var(--surface)}.spotify-results li{border-bottom:1px solid var(--border)}.spotify-results li:last-child{border-bottom:none}.spotify-result-btn{width:100%;display:flex;align-items:center;gap:.5rem;padding:.45rem .55rem;background:transparent;border:none;border-radius:0;min-height:52px;text-align:left;color:var(--text);font:inherit;cursor:pointer;transition:background .12s ease}.spotify-result-btn:hover{background:#f1f5f90d}.spotify-result-btn:active{transform:none}.spotify-result-img{flex-shrink:0;width:40px;height:40px;border-radius:5px;object-fit:cover}.spotify-result-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.05rem}.spotify-result-name{font-size:.82rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-result-artist{font-size:.72rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-disconnect-btn{width:100%;font-size:.7rem;min-height:30px;padding:.2rem .5rem;margin-top:.15rem}.phase-steps{margin:0 0 .8rem;padding-left:1.1rem;font-size:.88rem;color:var(--muted);line-height:1.5}.phase-steps li{margin-bottom:.3rem}.timer-row{margin-bottom:.65rem;align-items:flex-end}.timer-label{flex:1;margin:0}.input-short{width:5.2rem;flex-shrink:0}.timer-start-btn{width:auto;min-width:6.5rem;flex:1 1 auto;border-radius:10px;padding-inline:.9rem;font-size:.86rem;font-weight:700;min-height:48px}.timer-display{font-variant-numeric:tabular-nums;font-size:2.5rem;font-weight:700;font-family:SF Mono,Menlo,Monaco,ui-monospace,monospace;text-align:center;margin:.5rem 0;color:var(--accent)}.phase-theme-block{margin-top:.8rem;padding-top:.75rem;border-top:1px solid var(--border)}.btn-theme-draw{width:100%;min-height:56px;padding:.7rem 1rem;border-radius:12px;border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 8%,var(--surface2));color:var(--text);font-weight:700;font-size:1rem;line-height:1.25;display:flex;align-items:center;justify-content:center;gap:.65rem;flex-wrap:wrap;text-align:left;transition:background .15s ease,border-color .15s ease}.btn-theme-draw:before{display:none}.btn-theme-draw:not(:disabled):hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--surface2))}.btn-theme-draw:not(:disabled):active{transform:scale(.98)}.btn-theme-draw:disabled{cursor:not-allowed;border-style:dashed;border-color:var(--border);background:var(--surface2);color:var(--muted);font-weight:600;font-size:.84rem}.btn-theme-draw__ico{flex-shrink:0;font-size:1.5rem;line-height:1}.btn-theme-draw__text{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;min-width:0}.btn-theme-draw__text--solo{align-items:center;text-align:center;width:100%;line-height:1.35}.btn-theme-draw__title{font-size:.95rem;font-weight:700;letter-spacing:.01em}.btn-theme-draw__sub{font-size:.7rem;font-weight:600;color:var(--muted);letter-spacing:.03em;text-transform:uppercase}.theme-card{background:var(--surface2);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);border-radius:12px;padding:.7rem .8rem;text-align:center;display:flex;flex-direction:column;gap:.15rem;margin:.3rem 0}.theme-card__label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.theme-card__name{font-size:1.05rem;font-weight:700;color:var(--text)}.theme-card--waiting{border-style:dashed;border-color:var(--border-strong);opacity:.7}.role-theme-card{margin:.2rem 0 0}.theme-meta{font-size:.74rem;color:var(--muted);font-weight:400;margin-top:.45rem}.role-panel h2{margin-bottom:.4rem}.answers-grid{display:grid;grid-template-columns:1fr;gap:.5rem}.answer-box{border:1px solid var(--border);border-radius:10px;padding:.6rem .7rem;background:var(--surface2);transition:border-color .15s ease,background .15s ease}.answer-box--sent{border-color:color-mix(in srgb,var(--ok) 30%,transparent);background:color-mix(in srgb,var(--ok) 5%,var(--surface2))}.answer-box--1{border-left:3px solid color-mix(in srgb,var(--team1) 50%,transparent)}.answer-box--2{border-left:3px solid color-mix(in srgb,var(--team2) 50%,transparent)}.answer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.45rem}.answer-value{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:.05rem;line-height:1.3}.answer-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.4rem}.answer-label:last-child{margin-bottom:0}.answer-status{display:inline-flex;align-items:center;font-size:.68rem;font-weight:600;color:var(--muted);padding:.12rem .4rem;border-radius:6px;background:var(--surface3)}.answer-status--sent{color:var(--ok);background:color-mix(in srgb,var(--ok) 12%,var(--surface3))}.death-list{list-style:none;padding:0;margin:0}.death-list li{padding:0;border-bottom:1px solid var(--border)}.death-title-hit{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding:.65rem .35rem;margin:0;min-height:48px;font:inherit;color:inherit;cursor:pointer;background:transparent;border:none;border-radius:8px;text-align:left;transition:background .12s ease}.death-title-hit:hover:not(:disabled){background:#f1f5f90d}.death-title-hit:active:not(:disabled){transform:scale(.99)}.death-title-hit:disabled{cursor:default}.death-title-hit--ok:not(:disabled){background:color-mix(in srgb,var(--ok) 8%,transparent)}.death-title-hit__label{font-weight:700;font-size:.92rem}.death-item-state{display:inline-flex;align-items:center;border-radius:6px;padding:.1rem .45rem;font-size:.68rem;font-weight:700;color:var(--muted);border:1px solid var(--border);background:var(--surface2)}.death-item-state--ok{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 40%,transparent);background:color-mix(in srgb,var(--ok) 12%,var(--surface2))}.play-dock{flex-shrink:0;margin:0 -1rem;padding:.65rem 1rem calc(.8rem + var(--safe-bottom));background:var(--surface);border-top:1px solid var(--border)}.play-dock-title{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin:0 0 .2rem}.play-dock-hint{font-size:.72rem;color:var(--muted);margin:0 0 .6rem;line-height:1.35}.dock-team{margin-bottom:.55rem}.dock-team-label{font-size:.78rem;font-weight:700;margin-bottom:.3rem}.dock-chips{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.toggle-chip{min-height:38px;padding:.35rem .6rem;border-radius:8px;font-size:.76rem;font-weight:600;background:var(--surface2);color:var(--muted);border:1px solid var(--border);transition:background .12s ease,border-color .12s ease,color .12s ease}.toggle-chip--on{background:color-mix(in srgb,var(--chip-color, var(--accent)) 18%,var(--surface));color:var(--text);border-color:color-mix(in srgb,var(--chip-color, var(--accent)) 45%,transparent)}.dock-preview{margin-left:auto;font-size:.8rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--muted)}.dock-actions{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.45rem;align-items:stretch}.dock-btn{flex:1 1 0;min-width:0;min-height:44px;padding:.5rem .75rem;border-radius:10px;font:inherit;font-size:.82rem;font-weight:700;letter-spacing:.01em;line-height:1.2;border:none;color:#fff;transition:opacity .15s ease,transform .1s ease}.dock-btn:active:not(:disabled){transform:scale(.96)}.dock-btn:disabled{opacity:.4}.dock-btn--back{background:var(--surface3);color:var(--muted);flex:0 0 auto;min-width:5rem}.dock-btn--back:hover:not(:disabled){opacity:.85}.dock-btn--validate{background:var(--ok);color:#0f172a}.dock-btn--validate:hover:not(:disabled){opacity:.88}.dock-btn--next{background:var(--accent)}.dock-btn--next:hover:not(:disabled){opacity:.88}.dock-btn--deathfest{background:linear-gradient(135deg,var(--accent),var(--team2))}.dock-btn--deathfest:hover:not(:disabled){opacity:.88}.two-cols>*{flex:1;min-width:0}.btn-full-margin{margin-top:.6rem}.btn-center-action{display:block;width:fit-content;margin:.6rem auto 0;padding-inline:1rem}.btn-icon{display:inline-block;margin-right:.4rem;font-weight:700}.btn-abort{width:100%;margin-top:.25rem}.scores-final{justify-content:space-between;text-align:center;gap:1rem}.scores-final>div{flex:1}.scores-final-b{border-left:1px solid var(--border);padding-left:1rem}.win-banner{background:color-mix(in srgb,var(--ok) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--ok) 30%,transparent);border-radius:10px;padding:.8rem;text-align:center;font-weight:700;margin-bottom:.7rem}.team-result-card{border-radius:12px;border:1px solid var(--border);background:var(--surface2);padding:.75rem .8rem}.team-result-card--win{border-color:color-mix(in srgb,var(--ok) 35%,transparent);background:color-mix(in srgb,var(--ok) 8%,var(--surface2))}.team-result-card--lose{border-color:color-mix(in srgb,var(--danger) 30%,transparent);background:color-mix(in srgb,var(--danger) 8%,var(--surface2))}.team-result-card--tie{border-color:color-mix(in srgb,var(--accent) 30%,transparent);background:color-mix(in srgb,var(--accent) 8%,var(--surface2))}.team-result-badge{display:inline-flex;border-radius:6px;padding:.12rem .5rem;font-size:.65rem;font-weight:700;letter-spacing:.08em;color:var(--text);background:var(--surface3);border:1px solid var(--border)}.team-result-title{margin:.45rem 0 .2rem;font-size:.9rem;font-weight:700;line-height:1.35}.team-result-text{margin:0;font-size:.82rem;color:var(--muted);line-height:1.45}.footer-note{font-size:.72rem;color:var(--muted);text-align:center;margin-top:1.5rem;line-height:1.4}@media(max-width:540px){.setup-team-grid{grid-template-columns:1fr}}@media(max-width:390px){.phase-tabs button{font-size:.72rem}.play-score-num{font-size:1.45rem}.timer-display{font-size:2.2rem}.role-tabs{grid-template-columns:1fr}}@media(orientation:landscape)and (max-height:520px){.app{padding-top:calc(var(--safe-top) + .4rem);padding-bottom:calc(.6rem + var(--safe-bottom));max-width:48rem}.play-top{padding-top:calc(var(--safe-top) + .2rem);padding-bottom:.4rem}.play-main{padding-top:.35rem}}
