:root{--color-bg: #1a1a2e;--color-surface: #16213e;--color-primary: #e94560;--color-secondary: #0f3460;--color-text: #ffffff;--color-text-muted: rgba(255, 255, 255, .7);--color-success: #4ade80;--color-error: #f87171;--color-team-a: #3b82f6;--color-team-b: #f59e0b;--font-size-xs: clamp(.875rem, 1vw, 1rem);--font-size-sm: clamp(1rem, 1.5vw, 1.25rem);--font-size-base: clamp(1.25rem, 2vw, 1.5rem);--font-size-lg: clamp(1.5rem, 2.5vw, 2rem);--font-size-xl: clamp(2rem, 4vw, 3rem);--font-size-2xl: clamp(2.5rem, 5vw, 4rem);--font-size-3xl: clamp(3rem, 6vw, 5rem);--font-size-display: clamp(4rem, 10vw, 8rem);--space-xs: .5rem;--space-sm: 1rem;--space-md: 1.5rem;--space-lg: 2rem;--space-xl: 3rem;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;display:flex;flex-direction:column}#root{flex:1;display:flex;flex-direction:column}h1{font-size:var(--font-size-2xl);font-weight:700;line-height:1.2;margin-bottom:var(--space-md)}h2{font-size:var(--font-size-xl);font-weight:600;line-height:1.3;margin-bottom:var(--space-sm)}h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-xs)}p{font-size:var(--font-size-base);margin-bottom:var(--space-sm)}button,.btn{border-radius:12px;border:none;padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-base);font-weight:600;font-family:inherit;cursor:pointer;transition:transform .15s,box-shadow .15s;touch-action:manipulation}button:hover,.btn:hover{transform:translateY(-2px)}button:active,.btn:active{transform:translateY(0)}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 4px 14px #e9456066}.btn-primary:hover{box-shadow:0 6px 20px #e9456080}.btn-secondary{background:var(--color-secondary);color:#fff;box-shadow:0 4px 14px #0f346066}.btn-large{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-lg)}.btn-success{background:var(--color-success);color:#1a1a2e}.btn-error{background:var(--color-error);color:#fff}input,textarea{background:var(--color-surface);border:2px solid rgba(255,255,255,.1);border-radius:12px;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base);color:var(--color-text);font-family:inherit;width:100%;transition:border-color .2s}input:focus,textarea:focus{outline:none;border-color:var(--color-primary)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}.landing{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-lg);text-align:center}.subtitle{color:var(--color-text-muted);margin-bottom:var(--space-xl)}.landing-actions{display:flex;flex-direction:column;gap:var(--space-lg);width:100%;max-width:400px}.divider{color:var(--color-text-muted);font-size:var(--font-size-sm);position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:#fff3}.divider:before{left:0}.divider:after{right:0}.join-section{display:flex;flex-direction:column;gap:var(--space-sm)}.room-code-input{text-align:center;font-size:var(--font-size-xl);font-weight:700;letter-spacing:.5em;text-transform:uppercase;padding:var(--space-md)}.error{color:var(--color-error);font-size:var(--font-size-sm)}.room-code-display{font-size:var(--font-size-display);font-weight:800;letter-spacing:.2em;color:var(--color-primary);text-shadow:0 0 30px rgba(233,69,96,.5)}.score-display{display:flex;justify-content:center;gap:var(--space-xl);font-size:var(--font-size-2xl);font-weight:700}.team-a{color:var(--color-team-a)}.team-b{color:var(--color-team-b)}.card{background:var(--color-surface);border-radius:16px;padding:var(--space-lg);box-shadow:0 4px 20px #0000004d}.player-list{list-style:none;display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center}.player-chip{background:#ffffff1a;padding:var(--space-xs) var(--space-md);border-radius:9999px;font-size:var(--font-size-base)}.player-chip.team-a{background:#3b82f64d;border:2px solid var(--color-team-a)}.player-chip.team-b{background:#f59e0b4d;border:2px solid var(--color-team-b)}.question-text{font-size:var(--font-size-xl);font-weight:500;line-height:1.4;margin-bottom:var(--space-lg)}.tv-display{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);text-align:center}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;font-size:var(--font-size-lg);color:var(--color-text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:fadeIn .3s ease-out}.host-controls{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-lg);text-align:center}.host-badge{background:var(--color-primary);color:#fff;font-size:var(--font-size-xs);padding:2px 8px;border-radius:9999px;margin-left:var(--space-xs);font-weight:600}.team-badge{font-size:var(--font-size-xs);padding:2px 8px;border-radius:9999px;margin-left:var(--space-xs);font-weight:600}.team-badge.team-a{background:var(--color-team-a);color:#fff}.team-badge.team-b{background:var(--color-team-b);color:#fff}.btn-text{background:transparent;color:var(--color-text-muted);padding:var(--space-xs) var(--space-sm);box-shadow:none}.btn-text:hover{color:var(--color-text);background:#ffffff1a;box-shadow:none}button:disabled{opacity:.5;cursor:not-allowed;transform:none}button:disabled:hover{transform:none}.host-name-section{display:flex;flex-direction:column;gap:var(--space-sm);width:100%}.name-input{text-align:center;font-size:var(--font-size-lg)}.warning{color:var(--color-team-b)}.player-join{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-lg);text-align:center}.team-selection{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-lg);text-align:center;width:100%;max-width:800px;margin:0 auto}.team-rosters{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);width:100%}.team-roster{background:var(--color-surface);border-radius:16px;padding:var(--space-md)}.team-a-roster{border:2px solid var(--color-team-a)}.team-b-roster{border:2px solid var(--color-team-b)}.team-roster .player-list{flex-direction:column;align-items:stretch}.team-roster .player-chip{display:flex;justify-content:center;align-items:center}.unassigned-section{width:100%}.text-sm{font-size:var(--font-size-sm)}.swipe-list{display:flex;flex-direction:column;gap:var(--space-sm)}.swipe-card{display:flex;align-items:center;justify-content:space-between;background:#ffffff1a;border-radius:12px;padding:var(--space-sm) var(--space-md);transition:background .2s,transform .1s;touch-action:pan-y;-webkit-user-select:none;user-select:none;position:relative}.swipe-card.swiping-left{background:#3b82f64d}.swipe-card.swiping-right{background:#f59e0b4d}.swipe-hint{font-size:var(--font-size-lg);font-weight:700;opacity:.3;transition:opacity .2s}.swipe-hint.left{color:var(--color-team-a)}.swipe-hint.right{color:var(--color-team-b)}.swiping-left .swipe-hint.left,.swiping-right .swipe-hint.right{opacity:1}.player-name{flex:1;text-align:center;font-size:var(--font-size-base);font-weight:500}.manual-assign{display:flex;gap:var(--space-xs)}.btn-small{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm);border-radius:8px;border:none;cursor:pointer;font-weight:600;transition:transform .1s}.btn-small:hover{transform:scale(1.05)}.team-a-btn{background:var(--color-team-a);color:#fff}.team-b-btn{background:var(--color-team-b);color:#fff}.action-buttons{display:flex;flex-direction:column;gap:var(--space-md);align-items:center}@media(hover:none)and (pointer:coarse){.manual-assign{display:none}}@media(max-width:600px){.team-rosters{grid-template-columns:1fr}.landing,.host-controls,.player-join{padding:var(--space-md)}.room-code-display{font-size:clamp(3rem,12vw,6rem);letter-spacing:.1em}.card{padding:var(--space-md)}.btn-large{padding:var(--space-md) var(--space-lg)}.answer-buttons{flex-direction:column;gap:var(--space-md)}.btn-correct,.btn-incorrect{width:100%;min-width:unset}.score-display{flex-direction:column;gap:var(--space-md)}.error-actions{flex-direction:column}.error-actions button{width:100%}}.custom-badge{display:inline-block;font-size:var(--font-size-xs);background:linear-gradient(135deg,var(--color-team-a),var(--color-team-b));color:#fff;padding:2px 8px;border-radius:9999px;margin-left:var(--space-xs);font-weight:600;vertical-align:middle}.custom-question-section{border-top:1px solid rgba(255,255,255,.1);padding-top:var(--space-md)}.custom-question-form{background:#ffffff0d;border-radius:12px;padding:var(--space-md)}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);text-align:center;background:var(--color-bg)}.error-boundary-content{max-width:500px;background:var(--color-surface);border-radius:16px;padding:var(--space-xl);box-shadow:0 4px 20px #0000004d}.error-boundary-content h1{color:var(--color-error)}.error-details{font-size:var(--font-size-sm);color:var(--color-text-muted);background:#ffffff0d;padding:var(--space-sm);border-radius:8px;word-break:break-word;margin-top:var(--space-md)}.error-actions{display:flex;gap:var(--space-md);justify-content:center;margin-top:var(--space-lg)}.player-count-input{text-align:center;font-size:var(--font-size-lg);max-width:200px;margin:0 auto}.answer-buttons{display:flex;gap:var(--space-lg);justify-content:center;flex-wrap:wrap}.btn-correct{background:var(--color-success);color:#1a1a2e;min-width:150px;padding:var(--space-lg) var(--space-xl);font-size:var(--font-size-xl);box-shadow:0 4px 14px #4ade8066}.btn-correct:hover{box-shadow:0 6px 20px #4ade8080}.btn-incorrect{background:var(--color-error);color:#fff;min-width:150px;padding:var(--space-lg) var(--space-xl);font-size:var(--font-size-xl);box-shadow:0 4px 14px #f8717166}.btn-incorrect:hover{box-shadow:0 6px 20px #f8717180}.point-badge{display:inline-block;padding:var(--space-xs) var(--space-md);border-radius:9999px;background:#ffffff1a;font-size:var(--font-size-sm);font-weight:600;margin-top:var(--space-md)}.point-badge.bonus{background:linear-gradient(135deg,var(--color-team-a),var(--color-team-b));color:#fff;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.reveal-card{background:var(--color-surface);border-radius:16px;padding:var(--space-lg);max-width:500px;width:100%;text-align:center;border:3px solid}.reveal-card.correct{border-color:var(--color-success)}.reveal-card.incorrect{border-color:var(--color-error)}.reveal-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-xs)}.reveal-answer{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--space-md);word-wrap:break-word}.reveal-result{font-size:var(--font-size-lg);font-weight:700}.reveal-card.correct .reveal-result{color:var(--color-success)}.reveal-card.incorrect .reveal-result{color:var(--color-error)}.player-card{display:flex;align-items:center;gap:var(--space-xs);background:#ffffff0d;border-radius:8px;padding:var(--space-xs) var(--space-sm);transition:background .2s}.player-card:hover{background:#ffffff1a}.player-card:focus{outline:2px solid var(--color-primary);outline-offset:2px;background:#ffffff26}.player-card .player-name{flex:1;text-align:left;font-size:var(--font-size-base);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:80px}.btn-arrow{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border-radius:6px;font-size:14px;font-weight:700;transition:transform .15s,opacity .15s}.btn-arrow:hover{transform:scale(1.1)}.btn-arrow.team-a-btn{background:var(--color-team-a);color:#fff}.btn-arrow.team-b-btn{background:var(--color-team-b);color:#fff}.btn-remove{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border-radius:6px;background:#f8717133;color:var(--color-error);font-size:16px;font-weight:700;transition:background .15s,transform .15s}.btn-remove:hover{background:var(--color-error);color:#fff;transform:scale(1.1)}.card .player-list{display:flex;flex-direction:column;gap:var(--space-xs);align-items:stretch}.text-success{color:var(--color-success)}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-xs)}.category-checkbox:hover{background:#ffffff0d}.category-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary)}.tv-display{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);text-align:center;background:linear-gradient(135deg,var(--color-bg) 0%,#0d1b2a 100%)}.tv-loading{font-size:clamp(2rem,5vw,4rem);color:var(--color-text-muted)}.tv-error{color:var(--color-error)}.tv-setup{gap:var(--space-lg)}.tv-join-text{font-size:clamp(1.5rem,4vw,3rem);color:var(--color-text-muted);margin:0;letter-spacing:.1em;text-transform:uppercase}.tv-room-code{font-size:clamp(6rem,15vw,12rem);font-weight:800;letter-spacing:.2em;color:var(--color-primary);text-shadow:0 0 60px rgba(233,69,96,.5);line-height:1}.tv-player-count{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);margin-top:var(--space-xl)}.tv-count-number{font-size:clamp(4rem,10vw,8rem);font-weight:700;line-height:1;color:var(--color-text)}.tv-count-label{font-size:clamp(1.5rem,3vw,2.5rem);color:var(--color-text-muted)}.tv-player-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-md);max-width:90vw;margin-top:var(--space-lg)}.tv-player-name{background:#ffffff1a;padding:var(--space-sm) var(--space-lg);border-radius:9999px;font-size:clamp(1.25rem,2.5vw,2rem);font-weight:500;animation:fadeInPlayer .3s ease-out}@keyframes fadeInPlayer{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.tv-waiting{font-size:clamp(1.5rem,3vw,2.5rem);color:var(--color-text-muted);margin-top:var(--space-xl);animation:pulse 2s infinite}.tv-team-selection{gap:var(--space-lg)}.tv-title{font-size:clamp(3rem,7vw,6rem);font-weight:700;margin-bottom:var(--space-lg)}.tv-teams-container{display:flex;gap:var(--space-xl);justify-content:center;align-items:flex-start;flex-wrap:wrap;width:100%;max-width:1600px}.tv-team{flex:1;min-width:300px;max-width:600px;background:var(--color-surface);border-radius:24px;padding:var(--space-lg)}.tv-team-a{border:4px solid var(--color-team-a)}.tv-team-b{border:4px solid var(--color-team-b)}.tv-team-title{font-size:clamp(2rem,5vw,4rem);font-weight:700;margin-bottom:var(--space-sm)}.tv-team-count{font-size:clamp(1rem,2vw,1.5rem);color:var(--color-text-muted);margin-bottom:var(--space-md)}.tv-team-roster{display:flex;flex-direction:column;gap:var(--space-sm)}.tv-team-player{font-size:clamp(1.25rem,2.5vw,2rem);padding:var(--space-sm) var(--space-md);border-radius:12px;animation:fadeInPlayer .3s ease-out}.tv-team-player.team-a{background:#3b82f633}.tv-team-player.team-b{background:#f59e0b33}.tv-unassigned{margin-top:var(--space-lg)}.tv-unassigned-label{font-size:clamp(1rem,2vw,1.5rem);color:var(--color-text-muted);margin-bottom:var(--space-sm)}.tv-unassigned-list{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-sm)}.tv-unassigned-player{font-size:clamp(1rem,2vw,1.5rem);background:#ffffff1a;padding:var(--space-xs) var(--space-md);border-radius:9999px}.tv-answering{gap:var(--space-lg)}.tv-progress-section{margin:var(--space-xl) 0;width:100%;max-width:800px}.tv-progress-bar{height:24px;background:#ffffff1a;border-radius:12px;overflow:hidden;margin:var(--space-md) 0}.tv-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-success));border-radius:12px;transition:width .5s ease-out}.tv-progress-text{font-size:clamp(1.5rem,3vw,2.5rem);color:var(--color-text-muted);margin:0}.tv-playing{gap:var(--space-lg)}.tv-scoreboard{display:flex;align-items:center;gap:var(--space-xl);margin-bottom:var(--space-lg)}.tv-score{display:flex;flex-direction:column;align-items:center;padding:var(--space-md) var(--space-xl);background:var(--color-surface);border-radius:24px;min-width:200px}.tv-score-a{border:4px solid var(--color-team-a)}.tv-score-b{border:4px solid var(--color-team-b)}.tv-score-label{font-size:clamp(1.5rem,3vw,2.5rem);font-weight:600}.tv-score-a .tv-score-label{color:var(--color-team-a)}.tv-score-b .tv-score-label{color:var(--color-team-b)}.tv-score-value{font-size:clamp(4rem,10vw,8rem);font-weight:800;line-height:1}.tv-score-divider{font-size:clamp(2rem,4vw,3rem);color:var(--color-text-muted);font-weight:600}.tv-question-info{display:flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap;justify-content:center}.tv-question-number{font-size:clamp(1.5rem,3vw,2.5rem);color:var(--color-text-muted)}.tv-point-badge{display:inline-block;padding:var(--space-sm) var(--space-lg);border-radius:9999px;background:#ffffff1a;font-size:clamp(1.25rem,2.5vw,2rem);font-weight:600}.tv-point-badge.bonus{background:linear-gradient(135deg,var(--color-team-a),var(--color-team-b));color:#fff;animation:pulse 2s infinite}.tv-question-card{background:var(--color-surface);border-radius:24px;padding:var(--space-xl);max-width:1200px;width:90%;box-shadow:0 8px 40px #0000004d}.tv-guessing-team{font-size:clamp(1.5rem,3vw,2.5rem);color:var(--color-text-muted);margin-bottom:var(--space-lg)}.tv-player-highlight{color:var(--color-text);font-weight:700}.tv-question-text{font-size:clamp(2rem,5vw,4rem);font-weight:600;line-height:1.3;margin:0}.tv-reveal{background:var(--color-surface);border-radius:24px;padding:var(--space-xl);max-width:800px;width:90%;margin-top:var(--space-lg);border:6px solid;animation:revealSlideIn .4s ease-out}@keyframes revealSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tv-reveal.correct{border-color:var(--color-success);background:linear-gradient(135deg,var(--color-surface) 0%,rgba(74,222,128,.1) 100%)}.tv-reveal.incorrect{border-color:var(--color-error);background:linear-gradient(135deg,var(--color-surface) 0%,rgba(248,113,113,.1) 100%)}.tv-reveal-label{font-size:clamp(1.25rem,2.5vw,2rem);color:var(--color-text-muted);margin-bottom:var(--space-sm)}.tv-reveal-answer{font-size:clamp(2rem,5vw,4rem);font-weight:600;line-height:1.3;margin-bottom:var(--space-md);word-wrap:break-word}.tv-reveal-result{font-size:clamp(2.5rem,6vw,5rem);font-weight:800}.tv-reveal.correct .tv-reveal-result{color:var(--color-success)}.tv-reveal.incorrect .tv-reveal-result{color:var(--color-error)}.tv-finished{gap:var(--space-xl)}.tv-game-over{font-size:clamp(4rem,10vw,8rem);font-weight:800;animation:gameOverPulse 2s ease-in-out infinite}@keyframes gameOverPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.tv-final-scores{display:flex;align-items:center;gap:var(--space-xl);flex-wrap:wrap;justify-content:center}.tv-final-score{display:flex;flex-direction:column;align-items:center;padding:var(--space-xl);background:var(--color-surface);border-radius:32px;min-width:250px;transition:transform .3s,box-shadow .3s}.tv-final-a{border:4px solid var(--color-team-a)}.tv-final-b{border:4px solid var(--color-team-b)}.tv-final-score.winner{transform:scale(1.1);box-shadow:0 0 60px #4ade8066}.tv-final-a.winner{border-color:var(--color-success);box-shadow:0 0 60px #3b82f666}.tv-final-b.winner{border-color:var(--color-success);box-shadow:0 0 60px #f59e0b66}.tv-final-team-name{font-size:clamp(2rem,4vw,3rem);font-weight:600}.tv-final-a .tv-final-team-name{color:var(--color-team-a)}.tv-final-b .tv-final-team-name{color:var(--color-team-b)}.tv-final-score-value{font-size:clamp(6rem,15vw,12rem);font-weight:800;line-height:1}.tv-winner-crown{font-size:clamp(1.5rem,3vw,2.5rem);color:var(--color-success);font-weight:700;margin-top:var(--space-sm);animation:crownBounce 1s ease-in-out infinite}@keyframes crownBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.tv-vs{font-size:clamp(2rem,4vw,3rem);color:var(--color-text-muted);font-weight:600}.tv-tie-message{font-size:clamp(3rem,7vw,6rem);font-weight:700;color:var(--color-primary);animation:tiePulse 1.5s ease-in-out infinite}@keyframes tiePulse{0%,to{opacity:1}50%{opacity:.7}}.tv-thanks{font-size:clamp(1.5rem,3vw,2.5rem);color:var(--color-text-muted);margin:0}@media(max-width:768px){.tv-teams-container{flex-direction:column;align-items:center}.tv-team{width:100%;max-width:500px}.tv-scoreboard{flex-direction:column;gap:var(--space-md)}.tv-score-divider{display:none}.tv-final-scores{flex-direction:column}.tv-vs{display:none}}@media(min-width:1920px){.tv-display{padding:var(--space-xl) calc(var(--space-xl) * 2)}}
