:root{--bg-primary: #f0f2f5;--bg-secondary: rgba(255, 255, 255, .4);--bg-card: rgba(255, 255, 255, .7);--bg-elevated: rgba(255, 255, 255, .9);--text-primary: #1a1c30;--text-secondary: #4a5568;--text-muted: #718096;--accent-gold: #e6b800;--accent-gold-dim: #b38f00;--accent-wood: #a0785a;--accent-wood-light: #d2b48c;--border: rgba(0, 0, 0, .1);--border-light: rgba(255, 255, 255, .5);--danger: #e53e3e;--success: #38a169;--team1-bg: rgba(66, 153, 225, .15);--team1-accent: #3182ce;--team2-bg: rgba(245, 101, 101, .15);--team2-accent: #e53e3e;--team3-bg: rgba(72, 187, 120, .15);--team3-accent: #38a169;--shadow-lg: 0 8px 32px rgba(31, 38, 135, .15);--shadow-sm: 0 4px 6px rgba(0, 0, 0, .05);--glass-blur: blur(12px);--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--radius-full: 50%;--transition: .3s cubic-bezier(.4, 0, .2, 1);--font: "M PLUS Rounded 1c", -apple-system, BlinkMacSystemFont, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:var(--font);background:linear-gradient(135deg,#f0f4f8,#e2e8f0);background-attachment:fixed;color:var(--text-primary);min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased}#app{max-width:480px;margin:0 auto;min-height:100dvh;position:relative}.setup-screen{padding:24px 16px;display:flex;flex-direction:column;gap:20px;min-height:100dvh}.setup-header{text-align:center;padding:32px 0 16px}.logo-area{display:flex;flex-direction:column;align-items:center;gap:8px}.logo-icon{font-size:56px;line-height:1;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.setup-header h1{font-size:28px;font-weight:900;background:linear-gradient(135deg,var(--accent-gold),var(--accent-wood-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-secondary);font-size:14px}.setup-section{background:var(--bg-card);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius-md);padding:20px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.setup-section h2{font-size:14px;font-weight:700;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}.team-count-buttons{display:flex;gap:8px}.count-btn{flex:1;padding:14px;border:1px solid var(--border);background:#ffffff80;color:var(--text-primary);border-radius:var(--radius-sm);font-family:var(--font);font-size:15px;font-weight:700;cursor:pointer;transition:var(--transition)}.count-btn:hover{background:#fffc}.count-btn.active{border-color:var(--accent-gold);background:var(--bg-elevated);box-shadow:0 4px 12px #e6b80033;color:var(--accent-gold-dim)}.teams-config{display:flex;flex-direction:column;gap:12px;background:none;border:none;padding:0}.team-card{background:var(--bg-card);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius-md);padding:16px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:transform .2s ease}@media(min-width:400px){.team-card{padding:20px}}.team-card-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:12px;border-bottom:2px solid}.team-badge{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:14px;color:#fff;flex-shrink:0}.team-name-input{flex:1;background:#fff9;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--text-primary);font-family:var(--font);font-size:16px;font-weight:700;outline:none;transition:var(--transition)}.team-name-input:focus{border-color:var(--accent-gold);box-shadow:0 0 0 3px #f5c54226}.player-inputs{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.player-input{background:#fff6;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;color:var(--text-primary);font-family:var(--font);font-size:16px;outline:none;transition:var(--transition)}.player-input:focus{border-color:var(--accent-gold);background:#fffc;box-shadow:0 4px 12px #f5c54226;transform:scale(1.02)}.player-input::placeholder{color:var(--text-muted)}.start-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px;background:linear-gradient(135deg,var(--accent-gold),#e0a030);border:none;border-radius:var(--radius-md);color:#1a1a2e;font-family:var(--font);font-size:18px;font-weight:900;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm);margin-top:8px}.start-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.start-btn:active{transform:translateY(0)}.btn-arrow{font-size:20px;transition:transform .2s}.start-btn:hover .btn-arrow{transform:translate(4px)}.play-screen{display:flex;flex-direction:column;min-height:100dvh}.top-bar-dual{display:flex;align-items:center;justify-content:space-between;padding:16px;background:#fff9;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:100}.top-bar-left{display:flex;align-items:center;gap:12px}.top-time-display{display:flex;flex-direction:column}.time-now{font-size:13px;font-weight:700;color:var(--text-primary);line-height:1.2}.top-bar-right{display:flex;align-items:center;gap:12px}.top-btn{background:none;border:none;font-size:20px;cursor:pointer;padding:4px;color:var(--text-primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:var(--transition)}.top-btn:hover{background:var(--bg-elevated)}.end-game-btn{font-size:16px}.scoreboard{display:flex;gap:10px;padding:12px 16px;isolation:isolate;position:relative;z-index:5}.score-column{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.score-card{background:var(--bg-card);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius-md);border:1px solid var(--border-light);overflow:hidden;position:relative;transition:var(--transition);padding:0;contain:layout}.team-0-bg{background-color:var(--team1-bg);border-color:#4299e14d}.team-1-bg{background-color:var(--team2-bg);border-color:#f565654d}.team-2-bg{background-color:var(--team3-bg);border-color:#48bb784d}.score-card-active{box-shadow:0 8px 24px #1f268733;transform:scale(1.05);border-color:var(--accent-gold)!important;z-index:10}.score-card-eliminated{opacity:.5}.score-card-bar{position:absolute;top:0;left:0;height:100%;opacity:.15;transition:width .5s ease}.score-card-content{position:relative;padding:10px 12px;display:flex;justify-content:space-between;align-items:center}.score-team-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.score-value-area{display:flex;align-items:baseline;gap:2px}.score-value{font-size:32px;font-weight:900;line-height:1;color:var(--text-primary)}.score-max{font-size:12px;color:var(--text-muted)}.miss-indicator{position:absolute;top:4px;right:4px;font-size:10px}.player-reel{background:#fff6;border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden;transition:var(--transition)}.player-reel-active{background:#ffffffb3;border-color:var(--accent-gold);box-shadow:0 4px 16px #e6b80040,inset 0 0 0 1px #e6b8001a}.reel-window{height:40px;overflow:hidden;position:relative}.reel-window:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,#fff6,#fff0 30% 70%,#fff3);pointer-events:none;z-index:2}.reel-strip{display:flex;flex-direction:column}.reel-item{height:24px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 4px;flex-shrink:0;opacity:.2;transform:scale(.9);transition:all .4s ease}.reel-item-current{opacity:1;transform:scale(1.1);color:var(--text-primary);font-weight:900}.player-reel-active .reel-item-current{color:var(--accent-gold-dim);text-shadow:0 0 10px rgba(230,184,0,.2)}.turn-miss-warning-bar{text-align:center;font-size:13px;color:#c60;font-weight:700;background:#ffc80026;padding:8px 16px;margin:0 16px;border-radius:var(--radius-sm);border:1px solid rgba(255,153,0,.2)}.pin-area{padding:16px;display:flex;justify-content:center}.pin-layout{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.pin-row{display:flex;gap:10px;justify-content:center}.pin{width:54px;height:54px;border-radius:var(--radius-full);border:3px solid transparent;font-family:var(--font);font-size:18px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 10px #0006;position:relative;-webkit-user-select:none;user-select:none;will-change:transform}.pin-available{border-color:var(--accent-wood);background:linear-gradient(145deg,#f3e9dc,#e5d5c0);color:#5d4037}.pin-available:hover{transform:translateY(-2px);box-shadow:0 6px 15px #00000080}.pin-selected{border-color:var(--accent-gold);background:linear-gradient(145deg,gold,#fc0);color:#1a1a2e;box-shadow:0 8px 20px #ffd70066;transform:scale(1.1) translateY(-4px);z-index:10}.pin:active:not(:disabled){transform:scale(.95)}@keyframes pinKnock{0%{transform:scale(1)}50%{transform:scale(1.15) rotate(10deg)}to{transform:scale(1)}}.pin-number{pointer-events:none}.pin-layout-mini{display:flex;flex-direction:column;align-items:center;gap:2px}.pin-layout-small .pin-mini{width:22px;height:22px;font-size:9px}.pin-layout-tiny .pin-mini{width:16px;height:16px;font-size:7px}.pin-row-mini{display:flex;gap:2px;justify-content:center}.pin-mini{border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:700}.pin-mini-available{background:#d4a574;color:#2a1810;border:1px solid #b88a5e}.pin-mini-knocked{background:var(--accent-gold);color:var(--bg-primary);border:1px solid var(--accent-gold);box-shadow:0 0 4px #f5c54280}.info-bar{text-align:center;padding:8px 16px;min-height:36px;display:flex;align-items:center;justify-content:center;gap:8px}.info-hint{color:var(--text-muted);font-size:14px}.info-pins{color:var(--text-secondary);font-size:14px}.info-score{font-size:16px;color:var(--accent-gold)}.action-bar{display:flex;gap:10px;padding:32px 16px 12px;position:sticky;bottom:0;background:linear-gradient(transparent,var(--bg-primary) 20%)}.play-btn{flex:1;padding:14px;border:none;border-radius:var(--radius-md);font-family:var(--font);font-size:16px;font-weight:700;cursor:pointer;transition:var(--transition)}.miss-btn{background:#fff9;color:var(--danger);border:1px solid var(--danger)}.miss-btn:hover{background:#ff44551a}.miss-active{background:var(--danger);color:#fff;border-color:var(--danger);box-shadow:0 0 15px #f456}.confirm-btn{background:linear-gradient(135deg,var(--accent-gold),#e0a030);color:var(--bg-primary)}.confirm-btn:disabled{background:var(--bg-card);color:var(--text-muted);cursor:not-allowed}.confirm-btn:not(:disabled):hover{box-shadow:0 4px 16px #f5c5424d}.history-section-header{padding:16px 16px 8px;border-top:1px solid var(--border);margin-top:20px}.history-section-header h3{font-size:14px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.header-hint{font-size:11px;color:var(--text-muted);font-weight:400;margin-left:6px;text-transform:none}.round-history-visible{padding:0 16px 100px}.history-table{width:100%}.history-row{display:flex;border-bottom:1px solid var(--border);background:#fff3}.history-header{font-weight:700;font-size:12px;color:var(--text-secondary);border-bottom:2px solid var(--border)}.history-cell{padding:10px 4px;display:flex;align-items:center;justify-content:center;gap:4px;font-size:14px}.history-round-cell{width:40px;flex-shrink:0;color:var(--text-muted);font-weight:700}.history-team-cell{flex:1;min-width:80px}.history-team-cell-combined{flex-direction:column;gap:8px;padding:12px 8px;border-left:1px solid var(--border)}.history-score-container{display:flex;align-items:center;gap:4px}.round-score{font-weight:700}.score-miss{color:var(--danger)}.round-total{color:var(--text-muted);font-size:11px}.round-empty{color:var(--text-muted)}.no-history{text-align:center;color:var(--text-muted);padding:16px}.result-screen{padding:24px 16px;display:flex;flex-direction:column;gap:20px;min-height:100dvh}.result-header{text-align:center;padding:24px 0}.trophy-animation{font-size:64px;line-height:1;animation:trophy 1s ease}@keyframes trophy{0%{transform:scale(0) rotate(-20deg);opacity:0}50%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0);opacity:1}}.winner-name{font-size:28px;font-weight:900;margin-top:12px}.winner-sub{font-size:16px;color:var(--accent-gold);font-weight:700;margin-top:4px}.result-time-info{font-size:12px;color:var(--text-muted);font-weight:700;letter-spacing:.5px;margin-bottom:12px}.result-scores{display:flex;gap:10px}.result-score-card{flex:1;background:var(--bg-card);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius-md);padding:16px;text-align:center;border:1px solid var(--border-light);transition:var(--transition)}.result-total{font-size:40px;font-weight:900;line-height:1.2;margin:8px 0 4px;color:var(--text-primary)}.result-rounds{font-size:12px;color:var(--text-muted)}.result-details h2{font-size:14px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}.result-player-name{font-size:13px;color:var(--text-muted);font-weight:700;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.round-total-main{font-size:18px;font-weight:900;color:var(--text-primary)}.score-miss{color:var(--danger)!important}.qr-area{display:flex;flex-direction:column;align-items:center;gap:12px;margin:24px 0;padding:20px;background:#fff6;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius-md);border:1px solid var(--border-light);color:var(--text-primary)}.qr-area div{font-weight:700;font-size:14px}.qr-area img{width:180px;height:180px}.save-image-btn{background:var(--bg-card);color:var(--text-primary);border:2px solid var(--border)}.save-image-btn:hover{border-color:var(--accent-gold);box-shadow:0 4px 12px #e6b80033}.result-actions{display:flex;flex-direction:column;gap:10px;padding:8px 0 32px}.action-btn{width:100%;padding:14px;border:none;border-radius:var(--radius-md);font-family:var(--font);font-size:16px;font-weight:700;cursor:pointer;transition:var(--transition)}.share-btn{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.share-btn:hover{border-color:var(--accent-gold-dim)}.share-btn.copied{border-color:var(--success);color:var(--success)}.image-btn{background:var(--bg-card);color:var(--text-primary);border:2px solid var(--border)}.image-btn:hover{border-color:var(--accent-wood)}.new-game-btn{background:linear-gradient(135deg,var(--accent-gold),#e0a030);color:var(--bg-primary)}.new-game-btn:hover{box-shadow:0 4px 16px #f5c5424d}.toast{padding:12px 24px;border-radius:var(--radius-md);font-family:var(--font);font-size:14px;font-weight:700;transition:all .3s cubic-bezier(.18,.89,.32,1.28);max-width:90vw;width:max-content;text-align:center;box-shadow:var(--shadow-lg);opacity:0}.toast-visible{opacity:1}.toast-win{background:linear-gradient(135deg,var(--accent-gold),#e0a030);color:#1a1a2e}.toast-reset{background:var(--bg-elevated);color:var(--accent-gold);border:1px solid var(--accent-gold-dim)}.toast-miss_warning{background:var(--bg-elevated);color:#fa3;border:1px solid #664400}.toast-eliminated,.toast-all_eliminated{background:var(--bg-elevated);color:var(--danger);border:1px solid var(--danger)}.toast-info{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-light);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}@media(max-width:380px){.pin{width:46px;height:46px;font-size:15px}.pin-row{gap:6px}.score-value{font-size:24px}}@media(min-width:481px){#app{border-left:1px solid var(--border);border-right:1px solid var(--border)}}
