:root{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-card: #222240;--bg-elevated: #2a2a4a;--text-primary: #e8e8f0;--text-secondary: #8888aa;--text-muted: #555570;--accent-gold: #f5c542;--accent-gold-dim: #9a7a22;--accent-wood: #c8956a;--accent-wood-light: #e0b88a;--border: #333355;--danger: #ff4455;--success: #44cc88;--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 50%;--transition: .2s ease;--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:var(--bg-primary);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-secondary);border-radius:var(--radius-md);padding:16px;border:1px solid var(--border)}.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:12px;border:2px solid var(--border);background:var(--bg-card);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{border-color:var(--accent-gold-dim)}.count-btn.active{border-color:var(--accent-gold);background:linear-gradient(135deg,#f5c54226,#c8956a1a);color:var(--accent-gold)}.teams-config{display:flex;flex-direction:column;gap:12px;background:none;border:none;padding:0}.team-card{background:var(--bg-secondary);border-radius:var(--radius-md);padding:16px;border:1px solid var(--border)}.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:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;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:1fr 1fr;gap:6px}.player-input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;color:var(--text-primary);font-family:var(--font);font-size:13px;outline:none;transition:var(--transition)}.player-input:focus{border-color:var(--accent-wood)}.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:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);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:16px;font-weight:900;color:var(--accent-gold);line-height:1.1}.time-start{font-size:10px;color:var(--text-muted)}.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:8px;padding:12px 16px}.score-card{flex:1;background:var(--bg-secondary);border-radius:var(--radius-sm);border-left:4px solid;overflow:hidden;position:relative;transition:var(--transition)}.score-card-active{box-shadow:0 0 20px #f5c54226;transform:scale(1.02)}.score-card-eliminated{opacity:.5}.score-card-bar{position:absolute;top:0;left:0;height:100%;opacity:.08;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}.current-player{display:block;font-size:11px;color:var(--text-secondary);margin-top:2px}.score-value-area{display:flex;align-items:baseline;gap:2px}.score-value{font-size:28px;font-weight:900;line-height:1}.score-max{font-size:12px;color:var(--text-muted)}.miss-indicator{position:absolute;top:4px;right:4px;font-size:10px}.turn-indicator{text-align:center;padding:12px 16px 4px}.turn-team{font-size:20px;font-weight:900}.turn-player{font-size:13px;color:var(--text-secondary);margin-top:4px}.turn-miss-warning{font-size:14px;color:#f90;font-weight:700;background:#ff99001a;padding:4px 12px;border-radius:var(--radius-sm);display:inline-block;margin-top:8px}.pin-area{padding:16px;display:flex;justify-content:center}.pin-layout{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border)}.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}.pin-available{border-color:var(--accent-wood);background:linear-gradient(145deg,#d4a574,#b88a5e);color:#2a1810}.pin-available:hover{transform:translateY(-2px);box-shadow:0 6px 15px #00000080}.pin-selected{border-color:var(--accent-gold);background:linear-gradient(145deg,var(--accent-gold),#e0a030);color:var(--bg-primary);box-shadow:0 0 20px #f5c54280;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:var(--bg-card);color:var(--danger);border:2px solid var(--danger)}.miss-btn:hover{background:#ff44551a}.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)}.history-header{font-weight:700;font-size:12px;color:var(--text-secondary);border-bottom:2px solid var(--border)}.history-cell{padding:8px;display:flex;align-items:center;justify-content:center;gap:4px;font-size:13px}.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}.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-secondary);border-radius:var(--radius-md);padding:16px;text-align:center;border:1px solid var(--border);transition:var(--transition)}.winner-card{border-color:var(--accent-gold);box-shadow:0 0 20px #f5c54233}.eliminated-card{opacity:.5}.result-team-name{font-size:14px;font-weight:700}.result-total{font-size:40px;font-weight:900;line-height:1.2;margin:8px 0 4px}.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-table{background:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border)}.result-table-row{display:flex;border-bottom:1px solid var(--border)}.result-table-row:last-child{border-bottom:none}.result-table-header{background:var(--bg-card);font-weight:700;font-size:12px}.result-table-cell{padding:8px;display:flex;align-items:center;justify-content:center;gap:4px}.result-team-cell-combined{flex-direction:column;gap:8px;min-height:80px}.result-score-container{display:flex;align-items:center;gap:4px}.result-player-name{font-size:11px;color:var(--text-muted);font-weight:700;margin-bottom:4px}.result-total-main,.round-total-main{font-size:18px;font-weight:900;color:var(--text-primary)}.result-score-sub,.round-score-sub{font-size:12px;font-weight:700;color:var(--text-muted)}.team-col{flex:1;font-size:13px;min-width:80px}.round-col{width:40px;flex-shrink:0;color:var(--text-muted);font-size:14px;font-weight:700}.result-score{font-weight:700}.result-score.miss{color:var(--danger)!important}.result-total-small{font-size:11px;color:var(--text-muted)}.result-empty{color:var(--text-muted)}.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:2px 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:var(--bg-primary)}.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)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}@media(max-width:360px){.pin{width:46px;height:46px;font-size:15px}.pin-row{gap:6px}.score-value{font-size:22px}}@media(min-width:481px){#app{border-left:1px solid var(--border);border-right:1px solid var(--border)}}
