:root{--green-dark: #1a4a2e;--green-field: #2e7d3a;--green-mid: #3d9147;--green-light: #5ab366;--green-pale: #d4edda;--tan: #c8a060;--tan-light: #e8d4a0;--tan-pale: #fdf5e0;--slate: #3d5166;--slate-mid: #546882;--slate-light: #8fa4bc;--slate-pale: #eef2f7;--white: #ffffff;--cream: #fefdf8;--red: #cc3030;--red-light: #f8d7da;--yellow: #f0b429;--yellow-light: #fff3cd;--text-dark: #1a2332;--text-mid: #374151;--text-soft: #6b7280;--border: #d1dae5;--shadow: 0 2px 8px rgba(0,0,0,.12);--shadow-lg: 0 4px 16px rgba(0,0,0,.15);--radius: 10px;--radius-sm: 6px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--slate-pale);color:var(--text-dark);min-height:100vh}.app{max-width:1100px;margin:0 auto;padding:0 0 40px}.app-header{background:var(--green-dark);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.app-header-left{display:flex;align-items:center;gap:10px}.app-title{color:var(--white);font-size:1.2rem;font-weight:700;letter-spacing:.3px}.app-sport-tag{font-size:.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;background:#ffffff1a;color:#fff9;padding:2px 8px;border-radius:10px;border:1px solid rgba(255,255,255,.15)}.btn-switch-team{background:#ffffff14;color:#ffffffb3;border:1px solid rgba(255,255,255,.18);border-radius:6px;padding:5px 12px;font-size:.78rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}.btn-switch-team:hover{background:#ffffff26;color:#fff}.scoreboard{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:var(--slate);padding:14px 20px;flex-wrap:wrap}.team-block{flex:1;min-width:130px;display:flex;flex-direction:column;align-items:flex-start;gap:8px}.team-block.right{align-items:flex-end}.team-name-input{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1rem;font-weight:700;padding:5px 10px;border-radius:var(--radius-sm);width:100%;text-align:center;max-width:180px}.team-name-input:focus{outline:none;border-color:var(--green-light);background:#fff3}.score-controls{display:flex;align-items:center;gap:12px}.score-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.25);color:#fff;font-size:1.25rem;font-weight:700;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.score-btn:hover{background:#ffffff47}.score-value{font-size:2.2rem;font-weight:800;color:#fff;min-width:48px;text-align:center}.inning-block{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:110px}.inning-label{font-size:.68rem;letter-spacing:2px;color:#ffffffa6;font-weight:600}.inning-controls{display:flex;align-items:center;gap:10px}.inning-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.25);color:#fff;font-size:1rem;font-weight:700;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.inning-btn:hover{background:#ffffff47}.inning-num{font-size:1.8rem;font-weight:800;color:#fff;min-width:36px;text-align:center}.top-bot-btn{background:var(--green-mid);border:1px solid var(--green-light);color:#fff;font-size:.8rem;font-weight:700;padding:4px 16px;border-radius:20px;cursor:pointer;letter-spacing:1px}.top-bot-btn.is-top{background:var(--green-mid)}.top-bot-btn.is-bot{background:var(--slate-mid);border-color:var(--slate-light)}.top-bot-btn:hover{opacity:.85}.count-bar{display:flex;gap:0;background:var(--green-dark);padding:10px 16px;align-items:center;flex-wrap:wrap;gap:8px}.count-group{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 14px;border-right:1px solid rgba(255,255,255,.12);flex:1;min-width:80px}.count-group:last-child{border-right:none}.pitch-group{flex:2;min-width:160px}.count-dots-row{display:flex;gap:6px;align-items:center}.count-dot{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.3);background:transparent}.count-dot.active.ball-dot{background:#4ade80;border-color:#22c55e}.count-dot.active.strike-dot{background:#f87171;border-color:#ef4444}.count-dot.active.out-dot{background:#fbbf24;border-color:#f59e0b}.count-label{font-size:.62rem;letter-spacing:1.5px;color:#fff9;font-weight:600;text-transform:uppercase}.count-btns{display:flex;gap:4px;align-items:center}.pitch-btns{flex-wrap:wrap;justify-content:center}.cnt-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:4px;cursor:pointer;letter-spacing:.3px}.cnt-btn:hover{background:#ffffff38}.cnt-btn.ball{background:#4ade8038;border-color:#4ade8080}.cnt-btn.strike{background:#f8717138;border-color:#f8717180}.cnt-btn.out{background:#fbbf2438;border-color:#fbbf2480}.cnt-btn.pitch-add{background:#60a5fa38;border-color:#60a5fa80}.cnt-btn.pitch-sub{background:#9ca3af26}.pitch-count-display{display:flex;align-items:baseline;gap:6px}.pitch-count-num{font-size:1.8rem;font-weight:800;color:#93c5fd}.pitch-count-label{font-size:.72rem;color:#fff9;max-width:120px;text-align:center;line-height:1.2}.main-content{display:flex;gap:16px;padding:16px;align-items:flex-start;flex-wrap:wrap}.field-container{flex:1 1 320px;background:var(--cream);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.field-title{background:var(--green-dark);color:#ffffffbf;font-size:.65rem;letter-spacing:3px;padding:5px 12px;font-weight:700}.field-svg{width:100%;display:block;background:#1e5c28}.field-actions{display:flex;gap:8px;padding:10px 12px;align-items:center;flex-wrap:wrap;background:var(--cream);border-top:1px solid var(--border)}.btn-record{background:var(--green-mid);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:700;cursor:pointer;flex:1;min-width:180px}.btn-record:hover{background:var(--green-field)}.btn-record:disabled{background:#86a891;cursor:default;opacity:.8}.record-msg{margin:4px 12px 8px;font-size:.8rem;font-weight:600;color:var(--green-field);animation:fadein .3s ease}@keyframes fadein{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.roster-panel{flex:0 0 240px;background:var(--cream);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px;min-height:300px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.8rem;font-weight:700;color:var(--slate);text-transform:uppercase;letter-spacing:.5px}.roster-count{font-size:.72rem;color:var(--text-soft);font-weight:500;text-transform:none;letter-spacing:0}.add-player-form{display:flex;gap:6px;margin-bottom:10px;align-items:center}.input-sm{border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 8px;font-size:.82rem;color:var(--text-dark);background:#fff}.input-sm:focus{outline:none;border-color:var(--green-mid);box-shadow:0 0 0 2px #3d914726}.btn-add{background:var(--green-mid);color:#fff;border:none;padding:6px 12px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:700;cursor:pointer;white-space:nowrap}.btn-add:hover{background:var(--green-field)}.roster-list{display:flex;flex-direction:column;gap:5px;max-height:380px;overflow-y:auto}.player-card{display:flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 8px;cursor:grab;transition:border-color .15s,box-shadow .15s,opacity .15s;-webkit-user-select:none;user-select:none}.player-card:hover{border-color:var(--green-mid);box-shadow:0 2px 6px #3d914726}.player-card.on-field{background:var(--green-pale);border-color:var(--green-light);cursor:default;opacity:.75}.player-card.dragging{opacity:.4}.player-num{font-size:.75rem;font-weight:700;color:var(--slate);min-width:28px}.player-name{flex:1;font-size:.82rem;font-weight:600;color:var(--text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-status{font-size:.7rem;font-weight:700;color:var(--green-field);min-width:22px;text-align:center}.btn-remove{background:none;border:none;color:var(--slate-light);font-size:1rem;cursor:pointer;padding:0 2px;line-height:1;opacity:.6}.btn-remove:hover{color:var(--red);opacity:1}.drag-hint{font-size:.68rem;color:var(--text-soft);text-align:center;margin-top:10px;font-style:italic}.btn-reset-sm{background:#0000000f;border:1px solid var(--border);color:var(--text-soft);font-size:.7rem;padding:3px 9px;border-radius:4px;cursor:pointer;font-weight:600;white-space:nowrap}.btn-reset-sm:hover{background:#0000001f;color:var(--text-dark)}.tabs{display:flex;gap:0;padding:0 16px;border-bottom:2px solid var(--border);margin:0}.tab-btn{background:none;border:none;border-bottom:3px solid transparent;color:var(--text-soft);font-size:.82rem;font-weight:600;padding:8px 16px;cursor:pointer;margin-bottom:-2px;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--green-field)}.tab-btn.active{color:var(--green-field);border-bottom-color:var(--green-field)}.section{margin:14px 16px 16px;background:var(--cream);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px}.summary-grid{display:flex;flex-wrap:wrap;gap:8px}.summary-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;min-width:90px;text-align:center}.summary-pos{font-size:.7rem;font-weight:800;color:var(--green-field);letter-spacing:1px}.summary-name{font-size:.78rem;color:var(--text-dark);font-weight:500;margin-top:2px}.table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}.tracker-table{width:100%;border-collapse:collapse;font-size:.78rem;white-space:nowrap}.tracker-table th{background:var(--green-dark);color:#ffffffd9;padding:6px 8px;text-align:center;font-size:.7rem;font-weight:700;letter-spacing:.5px}.tracker-table td{padding:6px 8px;border-bottom:1px solid var(--border);text-align:center}.tracker-table tr:last-child td{border-bottom:none}.tracker-table tr:hover td{background:var(--green-pale)}.player-cell{text-align:left!important;font-weight:600;color:var(--text-dark);padding-left:10px!important}.count-cell{color:var(--text-soft)}.count-cell.has-count{color:var(--green-field);font-weight:700}.total-cell{font-weight:800;color:var(--slate)}.recorded-innings{font-size:.72rem;color:var(--text-soft);margin-top:10px;padding-top:8px;border-top:1px solid var(--border)}.pitch-list{display:flex;flex-direction:column;gap:8px}.pitch-row{display:flex;align-items:center;gap:10px}.pitch-name{font-size:.82rem;font-weight:600;color:var(--text-dark);min-width:140px}.pitch-bar-wrap{flex:1;background:var(--border);border-radius:20px;height:10px;overflow:hidden}.pitch-bar{height:100%;background:linear-gradient(90deg,var(--green-mid),var(--green-light));border-radius:20px;transition:width .4s ease;min-width:4px}.pitch-total{font-size:.9rem;font-weight:800;color:var(--green-field);min-width:32px;text-align:right}.empty-msg{color:var(--text-soft);font-size:.82rem;font-style:italic;padding:8px 0}@media(max-width:680px){.scoreboard{padding:10px 12px;gap:8px}.score-value{font-size:1.8rem}.inning-num{font-size:1.5rem}.main-content{flex-direction:column;padding:10px;gap:10px}.roster-panel{flex:none;width:100%}.roster-list{max-height:220px}.count-bar{gap:6px;padding:8px 10px}.count-group{padding:4px 8px;min-width:60px}.pitch-count-num{font-size:1.4rem}.tab-btn{font-size:.75rem;padding:7px 10px}.section{margin:10px 10px 0}.tabs{padding:0 10px}.tracker-table{font-size:.7rem}.tracker-table th,.tracker-table td{padding:4px 5px}.app-title{font-size:1.05rem}.pitch-name{min-width:110px;font-size:.75rem}}@media(max-width:420px){.team-name-input{font-size:.85rem;max-width:130px}.score-value{font-size:1.5rem}.count-group{padding:4px 5px;min-width:50px}.cnt-btn{font-size:.65rem;padding:2px 5px}}.modal-backdrop{position:fixed;inset:0;background:#0000008c;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadein .18s ease}.modal-panel{background:var(--cream);border-radius:var(--radius);box-shadow:0 8px 40px #00000047;width:100%;max-width:480px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{background:var(--green-dark);padding:14px 18px}.modal-title{display:block;color:#fff;font-size:1rem;font-weight:700}.modal-subtitle{display:block;color:#ffffffa6;font-size:.75rem;margin-top:3px}.modal-positions{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:8px}.modal-pos-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm)}.modal-pos-label{font-size:.8rem;font-weight:800;color:var(--green-field);min-width:28px;letter-spacing:.5px}.modal-select{flex:1;border:1px solid var(--border);border-radius:var(--radius-sm);padding:5px 8px;font-size:.8rem;color:var(--text-dark);background:#fff;cursor:pointer}.modal-select:focus{outline:none;border-color:var(--green-mid)}.modal-player-badge{font-size:.72rem;font-weight:600;color:var(--green-field);background:var(--green-pale);padding:2px 7px;border-radius:12px;white-space:nowrap}.modal-footer{border-top:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;background:var(--cream)}.modal-count{font-size:.78rem;color:var(--text-soft);font-weight:600}.modal-actions{display:flex;gap:8px}.btn-modal-cancel{background:#fff;border:1px solid var(--border);color:var(--text-soft);font-size:.82rem;font-weight:600;padding:7px 16px;border-radius:var(--radius-sm);cursor:pointer}.btn-modal-cancel:hover{background:var(--slate-pale)}.btn-modal-confirm{background:var(--green-mid);border:none;color:#fff;font-size:.82rem;font-weight:700;padding:7px 18px;border-radius:var(--radius-sm);cursor:pointer}.btn-modal-confirm:hover{background:var(--green-field)}.btn-modal-confirm:disabled{background:#86a891;cursor:default;opacity:.75}.plan-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background:var(--slate);color:#fff;padding:10px 22px;border-radius:24px;font-size:.85rem;font-weight:600;z-index:2000;box-shadow:var(--shadow-lg);animation:fadein .2s ease;white-space:nowrap}.plan-badge{font-size:.68rem;background:#ffffff26;color:#ffffffe6;padding:2px 10px;border-radius:10px;font-weight:600;letter-spacing:.3px;border:1px solid rgba(255,255,255,.25)}.plan-save-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px;padding:10px 12px;background:var(--green-pale);border-radius:var(--radius-sm);border:1px solid #b2d8bb}.plan-save-label{font-size:.8rem;font-weight:600;color:var(--green-dark);white-space:nowrap}.plan-tip{font-size:.75rem;color:var(--text-soft);margin-bottom:14px;padding:6px 10px;background:var(--yellow-light);border-radius:var(--radius-sm);border-left:3px solid var(--yellow)}.plans-list{display:flex;flex-direction:column;gap:12px}.plan-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.plan-card-header{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--slate-pale);border-bottom:1px solid var(--border);flex-wrap:wrap}.plan-inning-badge{font-size:.82rem;font-weight:800;color:var(--slate)}.plan-filled{font-size:.72rem;color:var(--text-soft);flex:1}.plan-card-actions{display:flex;gap:6px}.btn-plan-apply{background:var(--green-mid);color:#fff;border:none;font-size:.72rem;font-weight:700;padding:4px 12px;border-radius:4px;cursor:pointer}.btn-plan-apply:hover{background:var(--green-field)}.btn-plan-delete{background:#fff;color:var(--red);border:1px solid #ecc;font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:4px;cursor:pointer}.btn-plan-delete:hover{background:var(--red-light)}.plan-preview-grid{display:flex;flex-wrap:wrap;gap:6px;padding:10px 12px}.plan-chip{font-size:.75rem;background:var(--slate-pale);border:1px solid var(--border);border-radius:12px;padding:3px 10px;color:var(--text-mid)}.plan-chip strong{color:var(--green-field);margin-right:2px}.plan-empty{font-size:.75rem;color:var(--text-soft);font-style:italic;padding:8px 12px}@media(max-width:680px){.modal-panel{max-width:100%}.plan-save-row{flex-direction:column;align-items:flex-start}.plan-toast{font-size:.78rem;padding:8px 16px;white-space:normal;text-align:center;max-width:90vw}}.status-bench{font-size:.62rem;font-weight:700;color:#9b6a2a;background:#fdf0db;border:1px solid #e8c97a;border-radius:4px;padding:1px 5px;min-width:40px;text-align:center}.status-field{font-size:.7rem;font-weight:700;color:var(--green-field);min-width:22px;text-align:center}.bench-th{background:#5a4018!important;color:#fdf0db!important}.bench-cell{background:#fdf8f0}.bench-cell.has-bench{color:#9b6a2a!important;font-weight:700!important;background:#fdf0db}.modal-section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-soft);padding:8px 4px 4px;border-top:1px solid var(--border);margin-top:4px}.modal-section-label:first-child{border-top:none;margin-top:0;padding-top:0}.bench-label{color:#9b6a2a;background:#fdf8f0;padding:6px 8px;border-radius:var(--radius-sm);border:1px solid #e8c97a;border-top:1px solid #e8c97a;margin-top:8px}.modal-bench-list{display:flex;flex-wrap:wrap;gap:6px;padding:8px 4px}.modal-bench-chip{font-size:.75rem;font-weight:600;background:#fdf0db;border:1px solid #e8c97a;color:#7a4f10;padding:3px 10px;border-radius:12px}.sync-bar{background:#1e293b;padding:8px 20px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;border-bottom:1px solid rgba(255,255,255,.08)}.btn-open-display{background:#2563eb;color:#fff;border:none;padding:6px 14px;border-radius:var(--radius-sm);font-size:.8rem;font-weight:700;cursor:pointer;white-space:nowrap}.btn-open-display:hover{background:#1d4ed8}.sync-toggle-wrap{display:flex;align-items:center;gap:8px}.sync-toggle-label{display:flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:#ffffffbf;cursor:pointer;-webkit-user-select:none;user-select:none}.sync-toggle-label input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:#4ade80}.sync-status-badge{font-size:.7rem;font-weight:700;padding:2px 9px;border-radius:12px;white-space:nowrap}.sync-status-badge.ok{background:#4ade802e;color:#4ade80;border:1px solid rgba(74,222,128,.4)}.sync-status-badge.err{background:#f871712e;color:#f87171;border:1px solid rgba(248,113,113,.4)}.sync-status-badge.idle{background:#ffffff14;color:#ffffff80;border:1px solid rgba(255,255,255,.12)}.sync-hint{font-size:.7rem;color:#ffffff59;flex:1;min-width:160px}.player-card.bench-alert{border-color:#f59e0b;background:#fffbeb}.player-card.bench-alert:hover{border-color:#d97706;box-shadow:0 2px 8px #f59e0b40}.bench-warn-icon{font-size:.75rem;margin-right:3px}.roster-footer{margin-top:8px;padding-top:8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.bench-threshold-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.bench-threshold-label{font-size:.7rem;color:var(--text-soft);font-weight:600;white-space:nowrap}.bench-threshold-input{width:48px!important;text-align:center;padding:3px 6px!important;font-size:.78rem!important}@media(max-width:680px){.sync-bar{padding:8px 12px;gap:8px}.sync-hint{display:none}}.tab-record-pill{display:inline-block;background:#4ade8033;color:#4ade80;font-size:.65rem;font-weight:700;border-radius:10px;padding:1px 6px;margin-left:4px;border:1px solid rgba(74,222,128,.3);vertical-align:middle}.season-record-header{display:flex;align-items:center;justify-content:center;gap:0;background:linear-gradient(135deg,#1a3a1f,#1e293b);border-radius:12px;padding:20px 24px;margin-bottom:20px;flex-wrap:wrap;row-gap:8px}.record-stat-block{display:flex;flex-direction:column;align-items:center;min-width:64px;padding:0 16px}.record-big-num{font-size:2.6rem;font-weight:900;color:#fff;line-height:1}.record-big-num.win-num{color:#4ade80}.record-big-num.loss-num{color:#f87171}.record-big-num.tie-num{color:#fbbf24}.record-big-num.pct-num{font-size:2rem;color:#60a5fa}.record-label{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffff80;margin-top:3px}.record-dash{font-size:2.2rem;font-weight:300;color:#ffffff4d;align-self:center;padding:0 2px}.record-divider{width:1px;height:48px;background:#ffffff1f;margin:0 12px;align-self:center}.record-empty-hint{color:#ffffff59;font-size:.8rem;text-align:center;width:100%;padding-top:4px}.add-game-panel{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:20px}.add-game-title{font-size:.8rem;font-weight:700;color:var(--primary);margin-bottom:10px}.add-game-form{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.game-input-opponent,.game-input-notes{flex:2;min-width:140px}.games-section{margin-bottom:20px}.games-section-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.game-card{border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:10px;background:#fff;position:relative}.game-card.upcoming{border-left:3px solid #60a5fa}.game-card.tournament-day{border-left:3px solid #f59e0b;background:#fffdf5}.game-card.result-W{border-left:3px solid #4ade80}.game-card.result-L{border-left:3px solid #f87171}.game-card.result-T{border-left:3px solid #fbbf24}.tournament-badge{display:inline-block;font-size:.65rem;font-weight:700;background:#fef3c7;color:#d97706;border:1px solid #fcd34d;border-radius:8px;padding:1px 8px;margin-bottom:6px}.game-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.game-card-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.game-opponent{font-size:1rem;font-weight:700;color:#1e293b}.game-score-display{font-size:.9rem;font-weight:700;color:#475569;background:#f1f5f9;border-radius:6px;padding:2px 8px}.game-card-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}.game-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.game-meta-item{font-size:.72rem;color:var(--text-soft);display:flex;align-items:center;gap:3px}.game-notes{font-style:italic}.result-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:.8rem;font-weight:900;flex-shrink:0}.result-badge.result-W{background:#dcfce7;color:#16a34a;border:1.5px solid #4ade80}.result-badge.result-L{background:#fee2e2;color:#dc2626;border:1.5px solid #f87171}.result-badge.result-T{background:#fef9c3;color:#ca8a04;border:1.5px solid #fbbf24}.btn-record-result{background:var(--primary);color:#fff;border:none;padding:4px 12px;border-radius:var(--radius-sm);font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap}.btn-record-result:hover{background:var(--primary-dark)}.record-result-form{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border);display:flex;flex-direction:column;gap:8px}.record-result-row,.record-score-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.record-result-label{font-size:.75rem;font-weight:700;color:var(--text-soft);min-width:44px}.btn-result{padding:4px 12px;border-radius:6px;border:1.5px solid var(--border);font-size:.75rem;font-weight:700;cursor:pointer;background:#fff;transition:all .12s}.btn-result:hover{border-color:#94a3b8;background:#f8fafc}.btn-result.active-W{background:#dcfce7;border-color:#4ade80;color:#16a34a}.btn-result.active-L{background:#fee2e2;border-color:#f87171;color:#dc2626}.btn-result.active-T{background:#fef9c3;border-color:#fbbf24;color:#ca8a04}.score-input{width:60px!important;text-align:center}.score-sep{font-weight:700;color:var(--text-soft)}.record-result-actions{display:flex;gap:8px}.game-edit-form{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.game-edit-actions{display:flex;gap:6px;width:100%;margin-top:4px}@media(max-width:680px){.season-record-header{gap:4px;padding:14px 10px}.record-stat-block{min-width:48px;padding:0 8px}.record-big-num{font-size:2rem}.record-divider{display:none}.add-game-form{flex-direction:column}.game-input-opponent,.game-input-notes{width:100%}}.active-game-banner{background:linear-gradient(135deg,#052e16,#14532d);border-bottom:2px solid #4ade80;padding:10px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.active-game-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.active-game-pulse{color:#4ade80;font-size:1rem;animation:pulse-green 1.4s ease-in-out infinite}@keyframes pulse-green{0%,to{opacity:1}50%{opacity:.3}}.active-game-label{font-size:.65rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase;color:#4ade80;background:#4ade801f;border:1px solid rgba(74,222,128,.3);padding:2px 8px;border-radius:8px}.active-game-opponent{font-size:1rem;font-weight:800;color:#fff}.active-game-meta{font-size:.72rem;color:#ffffff8c}.active-game-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.btn-preset-load,.btn-preset-save{padding:5px 12px;border-radius:var(--radius-sm);font-size:.72rem;font-weight:700;cursor:pointer;border:none;white-space:nowrap}.btn-preset-load{background:#ffffff1f;color:#fff}.btn-preset-load:disabled{opacity:.4;cursor:not-allowed}.btn-preset-load:not(:disabled):hover{background:#fff3}.btn-preset-save{background:#4ade8033;color:#4ade80;border:1px solid rgba(74,222,128,.35)}.btn-preset-save:hover{background:#4ade804d}.btn-deactivate{padding:5px 12px;border-radius:var(--radius-sm);font-size:.72rem;font-weight:700;cursor:pointer;border:1px solid rgba(248,113,113,.35);background:#f871711f;color:#f87171;white-space:nowrap}.btn-deactivate:hover{background:#f8717140}.player-card.absent{opacity:.6;background:#f8f9fa;border-color:#cbd5e1;cursor:default}.status-absent{background:#e2e8f0;color:#64748b;font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.05em}.btn-absent-toggle{font-size:.6rem;font-weight:700;padding:2px 7px;border-radius:4px;border:1px solid #cbd5e1;background:#fff;color:#64748b;cursor:pointer;white-space:nowrap;flex-shrink:0}.btn-absent-toggle:hover{background:#f1f5f9;border-color:#94a3b8}.btn-absent-toggle.is-absent{background:#dcfce7;border-color:#4ade80;color:#16a34a}.active-dot{font-size:.65rem;font-weight:900;color:#16a34a;background:#dcfce7;border:1px solid #4ade80;border-radius:8px;padding:1px 8px;animation:pulse-green 1.4s ease-in-out infinite}.preset-badge{font-size:.65rem;font-weight:700;color:#0369a1;background:#e0f2fe;border:1px solid #7dd3fc;border-radius:8px;padding:1px 8px}.btn-activate{background:#16a34a;color:#fff;border:none;padding:4px 12px;border-radius:var(--radius-sm);font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap}.btn-activate:hover{background:#15803d}.btn-deactivate-sm{background:#f871711a;color:#ef4444;border:1px solid rgba(248,113,113,.3);padding:4px 10px;border-radius:var(--radius-sm);font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap}.btn-deactivate-sm:hover{background:#f8717133}.game-preset-row{display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px dashed #e2e8f0;flex-wrap:wrap}.btn-preset-save-sm{font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:5px;border:1px solid #7dd3fc;background:#f0f9ff;color:#0369a1;cursor:pointer;white-space:nowrap}.btn-preset-save-sm:hover{background:#e0f2fe}.btn-preset-load-sm{font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:5px;border:1px solid #4ade80;background:#f0fdf4;color:#16a34a;cursor:pointer;white-space:nowrap}.btn-preset-load-sm:hover{background:#dcfce7}.game-card.result-W.active-game,.game-card.result-L.active-game,.game-card.result-T.active-game,.game-card.upcoming.active-game{box-shadow:0 0 0 2px #4ade80}.btn-sub{font-size:.78rem;font-weight:700;padding:7px 14px;border-radius:var(--radius-sm);border:1.5px solid #f59e0b;background:#fffbeb;color:#92400e;cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}.btn-sub:hover{background:#fef3c7;border-color:#d97706}.sub-modal{max-width:420px}.sub-count-toggle{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-mid);padding:10px 20px 6px;cursor:pointer}.sub-count-toggle input[type=checkbox]{width:15px;height:15px;accent-color:var(--green-field);cursor:pointer}.season-header-actions{display:flex;align-items:center;gap:8px}.btn-edit-counts{font-size:.75rem;font-weight:700;padding:5px 12px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:#fff;color:var(--text-mid);cursor:pointer;transition:all .15s}.btn-edit-counts:hover{border-color:var(--slate-mid)}.btn-edit-counts.active{border-color:var(--green-field);background:#f0fdf4;color:#166534}.edit-counts-hint{font-size:.78rem;color:var(--text-soft);background:#fefce8;border:1px solid #fde68a;border-radius:var(--radius-sm);padding:6px 12px;margin-bottom:8px}.editable-count{padding:2px 4px!important}.count-adj{font-size:.8rem;font-weight:800;width:20px;height:20px;border-radius:4px;border:1px solid var(--border);background:#fff;color:var(--text-dark);cursor:pointer;line-height:1;padding:0;display:inline-flex;align-items:center;justify-content:center;transition:background .12s}.count-adj:hover{background:var(--slate-pale)}.count-adj-val{display:inline-block;min-width:18px;text-align:center;font-size:.82rem;font-weight:700;color:var(--text-dark)}.display-root{min-height:100vh;background:#0d2b14;color:#e8f5e9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;flex-direction:column;gap:0;position:relative;overflow:hidden}.no-data{align-items:center;justify-content:center}.no-data-inner{text-align:center;padding:40px}.no-data-icon{font-size:4rem;margin-bottom:16px}.no-data-title{font-size:2rem;font-weight:800;color:#81c784;margin-bottom:8px}.no-data-msg{font-size:1.1rem;color:#ffffffb3;margin-bottom:12px}.no-data-hint{font-size:.9rem;color:#ffffff73}.no-data-hint strong{color:#a5d6a7}.sync-dot{position:absolute;top:10px;right:14px;font-size:.7rem;font-weight:700;letter-spacing:1px;padding:3px 10px;border-radius:12px;z-index:10}.sync-live{background:#4caf5040;color:#81c784;border:1px solid #388e3c}.sync-api{background:#2196f333;color:#90caf9;border:1px solid #1976d2}.sync-local{background:#ffffff14;color:#fff6;border:1px solid rgba(255,255,255,.15)}.sync-time{font-weight:400;opacity:.75;margin-left:4px}.display-scoreboard{display:flex;align-items:center;background:#0a1f0d;border-bottom:2px solid #1b5e20;padding:18px 32px;gap:0}.display-team{flex:1;display:flex;flex-direction:column;gap:6px}.display-team.home-side{align-items:flex-end}.display-team-name{font-size:clamp(1rem,3vw,1.6rem);font-weight:700;color:#fffc;letter-spacing:.5px;text-transform:uppercase}.display-score{font-size:clamp(2.5rem,8vw,5rem);font-weight:900;color:#a5d6a7;line-height:1}.display-inning-block{display:flex;flex-direction:column;align-items:center;gap:4px;padding:0 12px;min-width:72px}.display-inning-label{font-size:.65rem;letter-spacing:3px;color:#fff6;font-weight:600}.display-inning-num{font-size:clamp(2rem,6vw,4rem);font-weight:900;color:#fff;line-height:1}.display-topbot{font-size:clamp(.8rem,2vw,1rem);font-weight:700;padding:3px 14px;border-radius:20px;letter-spacing:1px}.display-topbot.top{background:#1b5e20;color:#a5d6a7}.display-topbot.bot{background:#1a237e;color:#90caf9}.display-count-bar{display:flex;align-items:center;gap:0;background:#112318;padding:12px 32px;border-bottom:1px solid #1b5e20;flex-wrap:wrap;gap:8px}.display-count-group{display:flex;align-items:center;gap:10px;padding:6px 20px;border-right:1px solid rgba(255,255,255,.08)}.display-count-group:last-child{border-right:none}.pitcher-count{flex:1;flex-direction:column;align-items:flex-start;gap:2px}.display-count-label{font-size:.62rem;letter-spacing:2px;color:#fff6;font-weight:700;min-width:60px}.display-dots{display:flex;gap:8px}.display-dot{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.2);background:transparent}.display-dot.ball.on{background:#4caf50;border-color:#81c784}.display-dot.strike.on{background:#f44336;border-color:#ef9a9a}.display-dot.out.on{background:#ffc107;border-color:#ffe082}.display-pitch-num{font-size:clamp(1.4rem,3vw,2rem);font-weight:900;color:#90caf9;line-height:1}.display-pitcher-name{font-size:.75rem;color:#ffffff80}.display-field-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:8px 16px 64px;min-height:0;position:relative}.display-count-overlay{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;background:#08180ce0;border:1px solid rgba(76,175,80,.35);border-radius:18px;padding:10px 8px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);gap:0;white-space:nowrap;z-index:5}.dco-group{display:flex;flex-direction:column;align-items:center;gap:5px;padding:0 18px}.dco-pitcher{padding:0 16px}.dco-divider{width:1px;height:38px;background:#ffffff1a;flex-shrink:0}.dco-dots{display:flex;gap:7px}.dco-dot{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.18);background:#ffffff0a;transition:background .15s,border-color .15s}.dco-dot.ball.on{background:#4caf50;border-color:#81c784;box-shadow:0 0 6px #4caf5080}.dco-dot.strike.on{background:#f44336;border-color:#ef9a9a;box-shadow:0 0 6px #f4433680}.dco-dot.out.on{background:#ffc107;border-color:#ffe082;box-shadow:0 0 6px #ffc10780}.dco-label{font-size:.52rem;letter-spacing:2px;color:#ffffff61;font-weight:800;text-transform:uppercase}.dco-pitch-num{font-size:clamp(1.2rem,2.5vw,1.8rem);font-weight:900;color:#90caf9;line-height:1}.dco-pitcher-name{font-size:.6rem;color:#ffffff73;font-weight:600;max-width:80px;overflow:hidden;text-overflow:ellipsis}.display-field-svg{width:100%;height:100%;max-height:calc(100vh - 260px);max-width:min(100%,calc((100vh - 260px) * 400 / 390));display:block;filter:drop-shadow(0 4px 24px rgba(0,0,0,.5))}.display-bench{background:#ffffff0a;border-top:1px solid rgba(255,255,255,.08);padding:12px 24px 16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}.display-bench-label{font-size:.6rem;letter-spacing:3px;color:#a1855a;font-weight:800;white-space:nowrap}.display-bench-players{display:flex;flex-wrap:wrap;gap:8px}.display-bench-chip{font-size:.82rem;font-weight:600;background:#c8a0601f;border:1px solid rgba(200,160,96,.3);color:#e8c97a;padding:4px 12px;border-radius:16px}@media(max-width:600px){.display-scoreboard{padding:12px 16px}.display-inning-block{padding:0 16px;min-width:100px}.display-count-bar{padding:8px 12px}.display-count-group{padding:4px 10px}.display-field{padding:10px 12px}.slot{min-width:90px;padding:8px 10px}}.picker-root{min-height:100vh;background:#0d2b14;display:flex;flex-direction:column;align-items:center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#e8f5e9;padding-bottom:40px}.picker-hero{text-align:center;padding:52px 24px 32px}.picker-ball{font-size:3.5rem;margin-bottom:12px}.picker-title{font-size:2.2rem;font-weight:900;color:#a5d6a7;margin:0 0 8px;letter-spacing:-.5px}.picker-subtitle{font-size:1rem;color:#ffffff80;margin:0}.picker-body{width:100%;max-width:560px;padding:0 20px;display:flex;flex-direction:column;gap:16px}.picker-team-grid{display:flex;flex-direction:column;gap:10px}.picker-team-card{position:relative;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:18px 48px 18px 20px;cursor:pointer;transition:background .15s,border-color .15s,transform .1s}.picker-team-card:hover{background:#4caf501f;border-color:#4caf5059;transform:translateY(-1px)}.picker-sport-tag{font-size:.7rem;font-weight:700;letter-spacing:.5px;color:#ffffff73;margin-bottom:5px}.picker-team-name{font-size:1.25rem;font-weight:700;color:#e8f5e9}.picker-delete-btn{position:absolute;top:12px;right:14px;background:transparent;border:none;color:#ffffff40;font-size:1.3rem;cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1;transition:color .15s,background .15s}.picker-delete-btn:hover{color:#ef5350;background:#ef53501f}.picker-confirm{margin-top:12px;padding:10px 14px;background:#ef53501f;border:1px solid rgba(239,83,80,.3);border-radius:8px}.picker-confirm p{margin:0 0 10px;font-size:.85rem;color:#ef9a9a}.picker-confirm-btns{display:flex;gap:8px}.picker-new-form{background:#ffffff0d;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:22px;display:flex;flex-direction:column;gap:10px}.picker-form-label{font-size:.7rem;font-weight:700;letter-spacing:1px;color:#fff6;text-transform:uppercase;margin:0}.picker-input{background:#0000004d;border:1px solid rgba(255,255,255,.18);border-radius:8px;color:#fff;font-size:1rem;padding:10px 14px;outline:none;width:100%;box-sizing:border-box;transition:border-color .15s}.picker-input:focus{border-color:#4caf50}.picker-input::placeholder{color:#ffffff4d}.picker-sport-row{display:flex;gap:10px}.picker-sport-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 12px;border-radius:10px;border:2px solid rgba(255,255,255,.12);background:#ffffff0a;color:#fff9;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .15s}.picker-sport-btn.active{border-color:#4caf50;background:#4caf5026;color:#a5d6a7}.picker-sport-icon{font-size:1.6rem}.picker-form-actions{display:flex;gap:10px;margin-top:4px}.picker-btn-create{flex:1;background:#2e7d32;color:#fff;border:none;border-radius:8px;padding:12px 20px;font-size:1rem;font-weight:700;cursor:pointer;transition:background .15s}.picker-btn-create:hover:not(:disabled){background:#388e3c}.picker-btn-create:disabled{opacity:.45;cursor:not-allowed}.picker-btn-ghost{background:transparent;color:#ffffff80;border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:12px 16px;font-size:.9rem;cursor:pointer;transition:color .15s}.picker-btn-ghost:hover{color:#fff}.picker-btn-danger{background:#c62828;color:#fff;border:none;border-radius:6px;padding:7px 14px;font-size:.85rem;font-weight:600;cursor:pointer}.picker-btn-danger:hover{background:#d32f2f}.picker-new-btn{width:100%;padding:16px;border:2px dashed rgba(76,175,80,.35);border-radius:12px;background:transparent;color:#81c784;font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s}.picker-new-btn:hover{border-color:#4caf50;background:#4caf5012}.picker-empty{text-align:center;padding:20px;color:#fff6;font-size:.95rem}.picker-empty-hint{font-size:.82rem;color:#ffffff4d;margin-top:4px}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,select,textarea{font-family:inherit}
