*{box-sizing:border-box}:root{--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-success: #22c55e;--color-danger: #ef4444;--color-warning: #f59e0b;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border-color: #e2e8f0;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .2s ease}@media(prefers-color-scheme:dark){:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #64748b;--border-color: #334155;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -4px rgba(0, 0, 0, .3)}}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}#root{min-height:100vh}button{font-family:inherit;border:none;cursor:pointer}input{font-family:inherit;border:none;outline:none}h1,h2,h3,h4,h5,h6,p{margin:0}.text-center{text-align:center}.text-muted{color:var(--text-muted)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.home-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.home-container{width:100%;max-width:480px;display:flex;flex-direction:column;align-items:center;gap:var(--space-2xl)}.home-header{text-align:center}.logo{width:80px;height:80px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-lg);box-shadow:var(--shadow-lg),0 8px 32px #3b82f64d}.logo-icon{font-size:40px}.home-title{font-size:36px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm);letter-spacing:-.5px}.home-subtitle{font-size:16px;color:var(--text-muted)}.modes-container{width:100%}.modes-label{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-md);text-align:center}.modes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.mode-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-lg);background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:center}.mode-card:hover{border-color:var(--color-primary);background-color:var(--bg-tertiary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.mode-card:active{transform:translateY(0)}.mode-icon{font-size:32px}.mode-label{font-size:20px;font-weight:700;color:var(--text-primary)}.mode-description{font-size:12px;color:var(--text-muted);line-height:1.4}.home-footer{text-align:center}.home-footer p{font-size:14px;color:var(--text-muted)}@media(max-width:400px){.modes-grid{grid-template-columns:1fr}.mode-card{padding:var(--space-md)}.mode-icon{font-size:24px}.mode-label{font-size:18px}}@media(min-width:640px){.home-title{font-size:48px}.home-container{max-width:600px}.modes-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;box-shadow:var(--shadow-sm),0 1px 2px #3b82f64d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md),0 4px 12px #3b82f666}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--border-color)}.btn-danger{background:linear-gradient(135deg,var(--color-danger) 0%,#dc2626 100%);color:#fff;box-shadow:var(--shadow-sm),0 1px 2px #ef44444d}.btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md),0 4px 12px #ef444466}.btn-ghost{background-color:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-small{padding:var(--space-sm) var(--space-md);font-size:13px}.btn-medium{padding:var(--space-sm) var(--space-lg);font-size:14px;min-height:44px}.btn-large{padding:var(--space-md) var(--space-xl);font-size:16px;min-height:52px}.btn-full{width:100%}.btn-icon{display:flex;align-items:center;justify-content:center}.player-input{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm);background-color:var(--bg-tertiary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.player-input:focus-within{background-color:var(--bg-primary);box-shadow:0 0 0 2px var(--color-primary)}.player-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.player-avatar span{font-size:12px;font-weight:700;color:#fff}.player-name-input{flex:1;font-size:16px;color:var(--text-primary);background:transparent;padding:var(--space-sm) 0;min-width:0}.player-name-input::placeholder{color:var(--text-muted)}.player-remove-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:transparent;color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast);flex-shrink:0}.player-remove-btn:hover{background-color:#ef44441a;color:var(--color-danger)}.rule-toggle{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);width:100%;padding:var(--space-md) 0;background:transparent;text-align:left;cursor:pointer}.rule-toggle-content{flex:1}.rule-toggle-label{display:block;font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-xs)}.rule-toggle-description{display:block;font-size:14px;color:var(--text-muted)}.toggle-switch{width:52px;height:28px;background-color:var(--bg-tertiary);border-radius:var(--radius-full);padding:2px;transition:background-color var(--transition-normal);flex-shrink:0}.toggle-switch.active{background-color:var(--color-primary)}.toggle-knob{width:24px;height:24px;background-color:#fff;border-radius:var(--radius-full);box-shadow:var(--shadow-sm);transition:transform var(--transition-normal)}.toggle-switch.active .toggle-knob{transform:translate(24px)}.leg-selector{padding:var(--space-md) 0}.leg-selector-label{margin-bottom:var(--space-md)}.leg-selector-title{display:block;font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-xs)}.leg-selector-description{display:block;font-size:14px;color:var(--text-muted)}.leg-options{display:flex;gap:var(--space-sm)}.leg-option{flex:1;padding:var(--space-md);background-color:var(--bg-tertiary);border-radius:var(--radius-md);font-size:18px;font-weight:700;color:var(--text-secondary);transition:all var(--transition-fast)}.leg-option:hover{background-color:var(--border-color)}.leg-option.active{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;box-shadow:var(--shadow-sm),0 2px 8px #3b82f64d}.setup-page{min-height:100vh;background-color:var(--bg-primary)}.setup-header{position:sticky;top:0;z-index:10;padding:var(--space-md) var(--space-lg);background-color:var(--bg-primary);border-bottom:1px solid var(--border-color)}.setup-container{max-width:480px;margin:0 auto;padding:var(--space-lg);padding-bottom:120px}.setup-hero{text-align:center;margin-bottom:var(--space-xl)}.setup-mode-badge{display:inline-block;font-size:48px;font-weight:800;color:var(--color-primary);letter-spacing:-2px}.setup-title{font-size:16px;font-weight:500;color:var(--text-muted);margin-top:var(--space-xs)}.setup-description{font-size:14px;color:var(--text-secondary);margin-top:var(--space-sm);line-height:1.5}.setup-content{display:flex;flex-direction:column;gap:var(--space-xl)}.setup-section{background-color:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-lg);border:1px solid var(--border-color)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.section-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.section-hint{font-size:13px;color:var(--text-muted);background-color:var(--bg-tertiary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.players-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.setup-footer{position:fixed;bottom:0;left:0;right:0;padding:var(--space-lg);background:linear-gradient(to top,var(--bg-primary) 80%,transparent)}.setup-footer .btn{max-width:480px;margin:0 auto;display:flex}.section-actions{display:flex;align-items:center;gap:var(--space-sm)}.shuffle-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;font-size:16px;transition:all var(--transition-fast)}.shuffle-btn:hover{background-color:var(--bg-secondary);border-color:var(--color-primary)}.shuffle-btn:active{transform:scale(.95)}.variant-selector{margin-top:var(--space-md)}.variant-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm)}.variant-options{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.variant-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-md);background-color:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:center}.variant-btn:hover{border-color:var(--text-muted)}.variant-btn.active{border-color:var(--color-primary);background-color:#3b82f61a}.variant-name{font-size:14px;font-weight:600;color:var(--text-primary)}.variant-desc{font-size:11px;color:var(--text-muted);line-height:1.3}.lives-selector{margin-top:var(--space-md)}.lives-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm)}.lives-options{display:flex;gap:var(--space-sm)}.lives-btn{flex:1;padding:var(--space-md) var(--space-lg);background-color:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;font-size:18px;font-weight:700;color:var(--text-primary);transition:all var(--transition-fast)}.lives-btn:hover{border-color:var(--text-muted)}.lives-btn.active{border-color:var(--color-danger);background-color:#ef44441a;color:var(--color-danger)}.dartboard-container{position:relative}.dartboard-overlay{position:absolute;inset:0;background-color:#0000004d;border-radius:50%}.score-display{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.score-player-name{font-size:16px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.score-value{font-size:72px;font-weight:800;color:var(--text-primary);line-height:1;letter-spacing:-2px;transition:color var(--transition-fast)}.score-value.bust{color:var(--color-danger)}.score-value.checkout{color:var(--color-success)}.turn-delta{font-size:24px;font-weight:600;color:var(--text-secondary)}.turn-delta.bust{color:var(--color-danger);font-weight:700}@media(min-width:768px){.score-value{font-size:96px}}.current-turn{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.current-turn-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.dart-slots{display:flex;gap:var(--space-sm)}.dart-slot{width:72px;height:72px;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.dart-slot.active{border-color:var(--color-primary);border-style:dashed}.dart-slot.filled{background-color:var(--bg-tertiary);border-color:transparent}.dart-slot-value{font-size:24px;font-weight:700;color:var(--text-primary);line-height:1}.dart-slot-label{font-size:11px;font-weight:500;color:var(--text-muted);margin-top:var(--space-xs)}.dart-slot-empty{font-size:18px;font-weight:600;color:var(--text-muted);opacity:.4}.turn-controls{display:flex;flex-direction:column;gap:var(--space-sm);width:100%;max-width:320px;padding:var(--space-md) 0}.turn-controls-row{display:flex;gap:var(--space-sm)}.undo-turn-btn{margin-top:var(--space-sm);padding:var(--space-sm);background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;text-decoration:underline;transition:all var(--transition-fast)}.undo-turn-btn:hover{color:var(--text-secondary)}.undo-turn-btn.confirm{color:var(--color-danger);font-weight:600;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.player-card{display:flex;flex-direction:column;align-items:center;padding:var(--space-md);background-color:var(--bg-tertiary);border-radius:var(--radius-lg);border:2px solid transparent;min-width:120px;transition:all var(--transition-fast)}.player-card.active{background-color:var(--bg-primary);border-color:var(--color-primary);box-shadow:0 0 0 4px #3b82f61a}.player-card.winner{background-color:var(--bg-primary);border-color:var(--color-success);box-shadow:0 0 0 4px #22c55e1a}.player-card-header{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-xs)}.player-card-name{font-size:13px;font-weight:600;color:var(--text-secondary)}.player-status-badge{font-size:10px;font-weight:700;color:#fff;background-color:var(--color-primary);padding:2px var(--space-sm);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.3px}.player-status-badge.winner{background-color:var(--color-success)}.player-card-score{font-size:28px;font-weight:800;color:var(--text-primary);line-height:1;margin:var(--space-xs) 0}.player-card-stats{font-size:11px;color:var(--text-muted)}.player-list{display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);overflow-x:auto;justify-content:center}.player-list::-webkit-scrollbar{display:none}.checkout-hint{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:linear-gradient(135deg,var(--color-success) 0%,#16a34a 100%);border-radius:var(--radius-full);box-shadow:var(--shadow-sm),0 2px 8px #22c55e4d}.checkout-label{font-size:11px;font-weight:700;color:#fffc;text-transform:uppercase;letter-spacing:.5px}.checkout-path,.checkout-dart{display:flex;align-items:center;gap:var(--space-xs)}.checkout-arrow{color:#fff9;font-size:12px}.checkout-dart-value{font-size:14px;font-weight:700;color:#fff;background-color:#fff3;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.match-stats{width:100%;max-width:600px}.leg-info{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-md)}.leg-label{font-size:14px;font-weight:700;color:var(--color-primary)}.leg-format{font-size:12px;color:var(--text-muted)}.stats-grid{display:flex;gap:var(--space-sm);overflow-x:auto;padding-bottom:var(--space-xs)}.stats-grid::-webkit-scrollbar{display:none}.player-stats-card{flex:1;min-width:140px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-md)}.player-stats-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.player-stats-name{font-size:13px;font-weight:600;color:var(--text-secondary)}.player-legs-won{font-size:20px;font-weight:800;color:var(--color-primary)}.stats-row{display:flex;gap:var(--space-md);justify-content:space-around}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-label{font-size:10px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.ton-stats{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm);justify-content:center}.ton-badge{font-size:10px;font-weight:600;padding:2px var(--space-sm);border-radius:var(--radius-full)}.ton-180{background-color:#ef444426;color:var(--color-danger)}.ton-140{background-color:#f59e0b26;color:var(--color-warning)}.ton-100{background-color:#3b82f626;color:var(--color-primary)}.cricket-scoreboard{width:100%;max-width:400px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.cricket-header{display:flex;background-color:var(--bg-tertiary);border-bottom:2px solid var(--border-color)}.cricket-corner{width:60px;min-width:60px;padding:var(--space-sm);display:flex;align-items:center;justify-content:center;border-right:1px solid var(--border-color)}.variant-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.cricket-player-col{flex:1;padding:var(--space-sm) var(--space-xs);display:flex;flex-direction:column;align-items:center;text-align:center;border-right:1px solid var(--border-color);transition:background-color var(--transition-fast)}.cricket-player-col:last-child{border-right:none}.cricket-player-col.active{background-color:#3b82f61a}.cricket-player-col .player-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.cricket-player-col .player-points{font-size:20px;font-weight:800;color:var(--color-primary);margin-top:var(--space-xs)}.cricket-player-col .player-points.cutthroat{color:var(--color-danger)}.cricket-grid{display:flex;flex-direction:column}.cricket-row{display:flex;border-bottom:1px solid var(--border-color);transition:opacity var(--transition-fast)}.cricket-row:last-child{border-bottom:none}.cricket-row.all-closed{opacity:.5}.cricket-number{width:60px;min-width:60px;padding:var(--space-md) var(--space-sm);display:flex;align-items:center;justify-content:center;background-color:var(--bg-tertiary);border-right:1px solid var(--border-color)}.cricket-number span{font-size:16px;font-weight:700;color:var(--text-primary)}.cricket-cell{flex:1;padding:var(--space-md) var(--space-sm);display:flex;align-items:center;justify-content:center;border-right:1px solid var(--border-color);transition:background-color var(--transition-fast)}.cricket-cell:last-child{border-right:none}.cricket-cell.active{background-color:#3b82f60d}.cricket-cell.closed{background-color:#22c55e1a}.marks{font-size:20px;font-weight:700;color:var(--text-secondary)}.marks.empty{color:var(--text-muted)}.marks.closed{color:var(--color-success)}@media(max-width:480px){.cricket-scoreboard{max-width:100%}.cricket-corner,.cricket-number{width:50px;min-width:50px}.cricket-number span{font-size:14px}.marks,.cricket-player-col .player-points{font-size:18px}}.clock-tracker{width:100%;max-width:400px}.current-target-section{text-align:center;padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-md)}.target-label{display:block;font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-xs)}.target-number{display:block;font-size:72px;font-weight:900;color:var(--color-primary);line-height:1;margin-bottom:var(--space-sm)}.target-number.finished{color:var(--color-success)}.player-throwing{display:block;font-size:16px;font-weight:600;color:var(--text-secondary)}.progress-section{display:flex;flex-direction:column;gap:var(--space-md)}.player-progress{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);transition:all var(--transition-fast)}.player-progress.active{border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f633}.player-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.progress-player-name{font-size:14px;font-weight:600;color:var(--text-primary)}.progress-count{font-size:12px;font-weight:700;color:var(--color-primary);background-color:#3b82f61a;padding:2px var(--space-sm);border-radius:var(--radius-full)}.progress-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.progress-item{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--text-muted);background-color:var(--bg-tertiary);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.progress-item.hit{background-color:var(--color-success);color:#fff}.progress-item.current{background-color:var(--color-primary);color:#fff;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media(max-width:400px){.target-number{font-size:56px}.progress-grid{grid-template-columns:repeat(7,1fr);gap:3px}.progress-item{font-size:10px}}.killer-status{width:100%;max-width:500px}.killer-phase{text-align:center;padding:var(--space-md);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-md)}.phase-label{display:block;font-size:12px;font-weight:700;color:var(--color-danger);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-xs)}.phase-hint{display:block;font-size:14px;color:var(--text-secondary)}.current-killer-display{text-align:center;padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:var(--space-md)}.throwing-label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.throwing-name{display:block;font-size:28px;font-weight:800;color:var(--text-primary);margin:var(--space-xs) 0}.killer-badge-large{display:inline-block;font-size:12px;font-weight:800;color:#fff;background-color:var(--color-danger);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);margin-bottom:var(--space-xs)}.throwing-double{display:block;font-size:24px;font-weight:700;color:var(--color-primary)}.killer-players-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md)}.killer-player-card{background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-md);text-align:center;transition:all var(--transition-fast)}.killer-player-card.active{border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f633}.killer-player-card.eliminated{opacity:.5;background-color:var(--bg-tertiary)}.killer-card-header{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-sm)}.killer-player-name{font-size:14px;font-weight:600;color:var(--text-primary)}.killer-badge{font-size:10px;font-weight:800;color:#fff;background-color:var(--color-danger);padding:2px var(--space-sm);border-radius:var(--radius-full)}.killer-card-body{margin-bottom:var(--space-sm)}.assigned-double{font-size:32px;font-weight:800;color:var(--color-primary)}.no-double{font-size:32px;font-weight:800;color:var(--text-muted)}.killer-card-footer{min-height:24px}.lives-display{display:flex;justify-content:center;gap:4px}.life-heart{font-size:18px;transition:all var(--transition-fast)}.life-heart.active{color:var(--color-danger)}.life-heart.lost{color:var(--text-muted);opacity:.3}.eliminated-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}@media(max-width:400px){.killer-players-grid{grid-template-columns:repeat(2,1fr)}.assigned-double,.no-double{font-size:24px}.life-heart{font-size:14px}}.recent-throws{width:100%;max-width:400px}.recent-throws-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.recent-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.player-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.turns-strip{display:flex;gap:var(--space-sm);overflow-x:auto;padding-bottom:var(--space-xs)}.turn-card{flex-shrink:0;min-width:100px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-sm);transition:all var(--transition-fast)}.turn-card.recent{border-color:var(--color-primary);background-color:#3b82f60d}.turn-card.bust{border-color:var(--color-danger);background-color:#ef44440d}.turn-score{text-align:center;margin-bottom:var(--space-xs)}.score-value{font-size:20px;font-weight:800;color:var(--text-primary)}.bust-indicator{font-size:14px;font-weight:800;color:var(--color-danger);letter-spacing:1px}.turn-darts{display:flex;justify-content:center;gap:4px;flex-wrap:wrap}.dart-notation{font-size:10px;font-weight:600;padding:2px 4px;border-radius:var(--radius-sm);background-color:var(--bg-tertiary);color:var(--text-secondary)}.dart-notation.triple{background-color:#ef444433;color:var(--color-danger)}.dart-notation.double{background-color:#22c55e33;color:var(--color-success)}.dart-notation.bull{background-color:#fbbf2433;color:#f59e0b}.dart-notation.miss{background-color:var(--bg-tertiary);color:var(--text-muted)}.dart-notation.empty{visibility:hidden}.turns-strip::-webkit-scrollbar{height:4px}.turns-strip::-webkit-scrollbar-track{background:transparent}.turns-strip::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:2px}.summary-modal-overlay{position:fixed;inset:0;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-lg);z-index:100;animation:fadeIn .2s ease-out}.summary-modal{background-color:var(--bg-primary);border-radius:var(--radius-xl);border:1px solid var(--border-color);width:100%;max-width:480px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.summary-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary)}.summary-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.summary-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.summary-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.summary-content{flex:1;overflow-y:auto;padding:var(--space-lg)}.winner-banner{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-xl);background:linear-gradient(135deg,#fbbf241a,#f59e0b1a);border:2px solid rgba(251,191,36,.3);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);text-align:center}.winner-crown{font-size:48px}.winner-text{font-size:24px;font-weight:800;color:var(--text-primary)}.legs-text{font-size:14px;font-weight:600;color:var(--text-secondary)}.summary-section{margin-bottom:var(--space-xl)}.summary-section:last-child{margin-bottom:0}.section-title{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--space-md) 0}.standings-list{display:flex;flex-direction:column;gap:var(--space-sm)}.standing-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.standing-row.winner{border-color:#fbbf2480;background-color:#fbbf240d}.standing-position{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-tertiary);border-radius:50%;font-size:14px;font-weight:700;color:var(--text-secondary)}.standing-row.winner .standing-position{background-color:#fbbf2433;color:#f59e0b}.standing-name{flex:1;font-size:14px;font-weight:600;color:var(--text-primary)}.standing-legs{font-size:14px;font-weight:600;color:var(--text-secondary)}.player-stats-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-md)}.player-stats-card:last-child{margin-bottom:0}.player-stats-header{margin-bottom:var(--space-md)}.player-stats-name{font-size:16px;font-weight:700;color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.stat-card{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-sm);background-color:var(--bg-tertiary);border-radius:var(--radius-md)}.stat-card.highlight{background-color:#3b82f61a;border:1px solid rgba(59,130,246,.3)}.stat-value{font-size:18px;font-weight:700;color:var(--text-primary)}.stat-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.best-checkout{margin-top:var(--space-sm);font-size:12px;color:var(--text-secondary);text-align:center}.best-checkout strong{color:var(--color-success)}.highlights-list{display:flex;flex-direction:column;gap:var(--space-sm)}.highlight-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background-color:var(--bg-secondary);border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.highlight-item.one-eighty{border-left-color:#f59e0b}.highlight-item.high-checkout{border-left-color:var(--color-success)}.highlight-item.ton-plus{border-left-color:var(--color-primary)}.highlight-icon{font-size:16px}.highlight-text{font-size:13px;color:var(--text-primary)}.summary-footer{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-lg);border-top:1px solid var(--border-color);background-color:var(--bg-secondary)}.gif-reaction-overlay{position:fixed;inset:0;background-color:#000;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s ease-out;cursor:pointer}.gif-reaction-overlay.visible{opacity:1;pointer-events:auto}.gif-reaction-image{width:100vw;height:100vh;object-fit:contain;animation:zoomIn .3s ease-out}@keyframes zoomIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.voice-indicator{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--background-secondary);border-radius:var(--radius-full);font-size:12px;color:var(--text-secondary);transition:all .2s ease}.voice-indicator.listening{background:#22c55e26;color:var(--color-success)}.voice-indicator.processing{background:#3b82f626;color:var(--color-info)}.voice-indicator.error{background:#ef444426;color:var(--color-error)}.voice-indicator.disabled{opacity:.5}.voice-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.voice-icon svg{width:18px;height:18px}.voice-icon .spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.voice-status{display:flex;align-items:center;gap:var(--space-xs)}.pulse-dot{width:8px;height:8px;background:currentColor;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.voice-text{white-space:nowrap}.game-header .voice-indicator{position:absolute;left:50%;transform:translate(-50%);top:calc(100% + var(--space-sm));z-index:10}@media(max-width:767px){.voice-indicator{font-size:11px;padding:var(--space-xs) var(--space-sm)}.voice-icon svg{width:16px;height:16px}}.settings-modal-overlay{position:fixed;inset:0;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-lg);z-index:100;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-modal{background-color:var(--bg-secondary);border-radius:var(--radius-xl);border:1px solid var(--border-color);width:100%;max-width:400px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.settings-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0}.settings-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.settings-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.settings-content{flex:1;overflow-y:auto;padding:var(--space-lg)}.settings-section{margin-bottom:var(--space-xl)}.settings-section:last-child{margin-bottom:0}.settings-section-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--space-md) 0}.settings-toggle{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md);background-color:var(--bg-tertiary);border-radius:var(--radius-md);cursor:pointer;margin-bottom:var(--space-sm)}.toggle-label{font-size:14px;font-weight:500;color:var(--text-primary)}.settings-toggle input{display:none}.toggle-slider{position:relative;width:48px;height:28px;background-color:var(--bg-secondary);border:2px solid var(--border-color);border-radius:14px;transition:all var(--transition-fast);flex-shrink:0}.toggle-slider:after{content:"";position:absolute;width:20px;height:20px;left:2px;top:2px;background-color:var(--text-muted);border-radius:50%;transition:all var(--transition-fast)}.settings-toggle input:checked+.toggle-slider{background-color:var(--color-primary);border-color:var(--color-primary)}.settings-toggle input:checked+.toggle-slider:after{transform:translate(20px);background-color:#fff}.settings-slider-group{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background-color:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--space-sm)}.slider-label{font-size:14px;font-weight:500;color:var(--text-primary);min-width:60px}.volume-slider{flex:1;height:4px;background-color:var(--bg-secondary);border-radius:2px;appearance:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;background-color:var(--color-primary);border-radius:50%;cursor:pointer}.volume-slider::-moz-range-thumb{width:16px;height:16px;background-color:var(--color-primary);border-radius:50%;border:none;cursor:pointer}.slider-value{font-size:14px;font-weight:600;color:var(--text-secondary);min-width:40px;text-align:right}.settings-hint{font-size:12px;color:var(--text-muted);line-height:1.5;margin:var(--space-sm) 0 0 0}.settings-hint-inline{font-size:11px;color:var(--text-muted);line-height:1.4;margin:0 0 var(--space-sm) 0;padding-left:var(--space-md)}.settings-unavailable{font-size:14px;color:var(--text-muted);font-style:italic;margin:0 0 var(--space-sm) 0}.settings-footer{padding:var(--space-lg);border-top:1px solid var(--border-color)}.game-page{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-primary)}.game-loading{align-items:center;justify-content:center;gap:var(--space-lg)}.game-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:10}.game-page>.voice-indicator{position:absolute;top:52px;left:50%;transform:translate(-50%);z-index:9}.game-mode-info{display:flex;flex-direction:column;align-items:center}.game-mode-score{font-size:18px;font-weight:700;color:var(--text-primary)}.game-mode-rule{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.settings-button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.settings-button:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.settings-button:active{transform:scale(.95)}.game-main{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding-bottom:var(--space-md)}.game-main.landscape{flex-direction:row;padding:var(--space-md)}.dartboard-section{display:flex;justify-content:center;align-items:center;padding:var(--space-md)}.game-main.landscape .dartboard-section{flex:1}.score-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:0 var(--space-md)}.game-main.landscape .score-section{flex:1;justify-content:center}.game-over-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);padding:var(--space-lg)}.winner-announcement{text-align:center}.winner-label{display:block;font-size:14px;font-weight:600;color:var(--color-success);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-sm)}.winner-name{display:block;font-size:36px;font-weight:800;color:var(--text-primary)}.game-over-actions{display:flex;flex-direction:column;gap:var(--space-sm);width:100%;max-width:280px}.leg-winner-announcement{text-align:center}.leg-winner-label{display:block;font-size:14px;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-sm)}.leg-winner-name{display:block;font-size:28px;font-weight:800;color:var(--text-primary);margin-bottom:var(--space-md)}.leg-scores{display:flex;gap:var(--space-lg);justify-content:center}.leg-score-item{font-size:14px;font-weight:600;color:var(--text-secondary)}.final-scores{display:flex;flex-direction:column;gap:var(--space-xs);margin-top:var(--space-md);padding:var(--space-md);background-color:var(--bg-tertiary);border-radius:var(--radius-md)}.final-score-item{font-size:14px;font-weight:600;color:var(--text-secondary)}.game-footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);padding:var(--space-md);display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.copied-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background-color:var(--color-success);color:#fff;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);font-size:14px;font-weight:600;box-shadow:var(--shadow-lg);z-index:200;animation:toastIn .3s ease-out}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}
