@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap";:root{--bg-body: #d2d5da;--bg-app: #d2d5da;--bg-surface: #dadde2;--bg-surface-alt: #c8cace;--bg-input: #dadde2;--bg-navbar: #0f2034;--text-primary: #1a2535;--text-secondary: #4a5568;--text-heading: #0f2034;--text-mono: #1a2535;--border-color: #bcbfc6;--border-light: #c9cbd0;--accent: #f59e0b;--accent-hover: #d97706;--accent-glow: rgba(245, 158, 11, .3);--strike-color: #dc2626;--ball-color: #2563eb;--heatmap-empty-strike: #e8f4fd;--heatmap-empty-ball: #f0f0f0;--heatmap-low: #bfdbfe;--heatmap-mid: #fbbf24;--heatmap-high: #dc2626;--transition-theme: .2s ease}[data-theme=dark]{--bg-body: #0f1923;--bg-app: #0f1923;--bg-surface: #1a2d3e;--bg-surface-alt: #1a2840;--bg-input: #1a2d3e;--bg-navbar: #050d14;--text-primary: #e8edf5;--text-secondary: #8a9ab5;--text-heading: #f5f7fa;--text-mono: #a8c4e0;--border-color: #1e3050;--border-light: #162130;--accent: #f59e0b;--accent-hover: #fbbf24;--accent-glow: rgba(245, 158, 11, .45);--strike-color: #f87171;--ball-color: #60a5fa;--heatmap-empty-strike: #1a2840;--heatmap-empty-ball: #111820;--heatmap-low: #1e3a5f;--heatmap-mid: #b45309;--heatmap-high: #dc2626}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:DM Sans,system-ui,sans-serif;background-color:var(--bg-body);color:var(--text-primary);transition:background-color var(--transition-theme),color var(--transition-theme);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;inset:0;background-image:url(/epic-baseball-field-md.png);background-repeat:no-repeat;background-position:center center;background-size:480px auto;opacity:.12;pointer-events:none;z-index:0}[data-theme=dark] body:before{opacity:.07}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.metric-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;animation:fadeSlideUp .3s .15s ease both}.metric-card:last-child{grid-column:1 / -1}.metric-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;padding:16px 18px;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden;transition:border-color .2s,box-shadow .2s}.metric-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);opacity:.5;transition:opacity .2s}.metric-card:hover:before{opacity:1}.metric-card:hover{border-color:var(--accent);box-shadow:0 0 14px var(--accent-glow)}.metric-label{font-family:DM Mono,monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary)}.metric-value{font-family:DM Mono,monospace;font-size:28px;font-weight:500;color:var(--text-primary);line-height:1}.metric-unit{font-size:13px;color:var(--text-secondary);margin-left:3px;font-weight:400}.info-header{display:flex;flex-direction:column;width:100%}.info-header-row{display:flex;align-items:center;justify-content:space-between}.info-header-title{font-family:DM Mono,monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary)}.info-tooltip-wrapper{position:relative;display:inline-flex;align-items:center}.info-btn{background:transparent;border:none;padding:0;cursor:pointer;color:var(--accent);opacity:.65;display:flex;align-items:center;transition:opacity .15s}.info-tooltip-wrapper:hover .info-btn{opacity:1}.info-tooltip{display:none;position:absolute;top:calc(100% + 8px);right:0;width:260px;font-family:DM Sans,sans-serif;font-size:12px;line-height:1.6;color:var(--text-secondary);background:var(--bg-surface);border:1px solid var(--border-color);border-left:2px solid var(--accent);border-radius:0 4px 4px 0;padding:10px 12px;z-index:50;box-shadow:0 4px 16px #0003}.info-tooltip-wrapper:hover .info-tooltip{display:block}.heatmap-container{display:flex;flex-direction:column;align-items:center;gap:10px;animation:fadeSlideUp .3s .25s ease both}.heatmap-grid{display:grid;grid-template-columns:repeat(5,52px);grid-template-rows:repeat(5,52px);gap:2px;background:var(--border-color);border:2px solid var(--border-color);border-radius:4px;padding:2px}.heatmap-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:2px;cursor:default;transition:transform .12s,box-shadow .12s;position:relative}.heatmap-cell:hover{transform:scale(1.1);z-index:2;box-shadow:0 2px 10px #00000059}.strike-zone{outline:1px solid var(--accent);outline-offset:-1px}.zone-number{font-family:DM Mono,monospace;font-size:9px;color:#0006;line-height:1;position:absolute;top:3px;left:4px}[data-theme=dark] .zone-number{color:#ffffff4d}.zone-count{font-family:DM Mono,monospace;font-size:14px;font-weight:500;color:#000000bf}[data-theme=dark] .zone-count{color:#ffffffd9}.home-plate{margin-top:2px}.heatmap-legend{display:flex;gap:16px}.legend-item{display:flex;align-items:center;gap:5px;font-family:DM Mono,monospace;font-size:10px;color:var(--text-secondary);letter-spacing:.08em}.legend-swatch{width:12px;height:12px;border-radius:2px;border:1px solid var(--border-color)}.pitch-mix{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;padding:18px 20px;display:flex;flex-direction:column;gap:12px;animation:fadeSlideUp .3s .3s ease both}.pitch-mix-rows{display:flex;flex-direction:column;gap:10px}.pitch-mix-row{display:grid;grid-template-columns:40px 1fr 36px 52px 76px;align-items:center;gap:10px}.pitch-mix-type{font-family:DM Mono,monospace;font-size:12px;font-weight:500;color:var(--accent);letter-spacing:.06em}.pitch-mix-bar-track{height:8px;background:var(--border-color);border-radius:4px;overflow:hidden}.pitch-mix-bar-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .4s ease;opacity:.75}.pitch-mix-count{font-family:DM Mono,monospace;font-size:12px;color:var(--text-primary);text-align:right}.pitch-mix-pct,.pitch-mix-velo{font-family:DM Mono,monospace;font-size:12px;color:var(--text-secondary);text-align:right}.split-stats{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;padding:18px 20px;display:flex;flex-direction:column;gap:12px;animation:fadeSlideUp .3s .35s ease both}.split-stats-table{width:100%;border-collapse:collapse;font-family:DM Mono,monospace;font-size:13px}.split-stats-table th{text-align:left;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);padding:0 12px 8px 0;border-bottom:1px solid var(--border-color);font-weight:400}.split-stats-table th:not(:first-child){text-align:right}.split-stats-table td{padding:9px 12px 9px 0;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.split-stats-table td:not(:first-child){text-align:right}.split-stats-table tbody tr:last-child td{border-bottom:none}.split-stats-table tbody tr:hover td{background:var(--bg-surface-alt)}.split-type-cell{color:var(--accent)!important;font-weight:500;letter-spacing:.06em}.count-grid{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;padding:18px 20px;display:flex;flex-direction:column;gap:12px;animation:fadeSlideUp .3s .4s ease both}.count-grid-table{display:flex;flex-direction:column;gap:2px}.count-grid-header-row,.count-grid-data-row{display:grid;grid-template-columns:44px repeat(3,1fr);gap:2px}.count-grid-corner{font-family:DM Mono,monospace;font-size:9px;color:var(--text-secondary);display:flex;align-items:flex-end;padding-bottom:4px;opacity:.6}.count-grid-col-header{font-family:DM Mono,monospace;font-size:11px;color:var(--text-secondary);text-align:center;padding-bottom:4px}.count-grid-row-header{font-family:DM Mono,monospace;font-size:11px;color:var(--text-secondary);display:flex;align-items:center;justify-content:flex-end;padding-right:8px}.count-grid-cell{background:rgba(245,158,11,calc(var(--intensity, 0) * .55));border:1px solid var(--border-color);border-radius:4px;padding:8px 6px 6px;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:default;transition:transform .1s;min-height:52px}.count-grid-cell:hover{transform:scale(1.05);z-index:2;box-shadow:0 2px 8px #0003}.count-grid-count-label{font-family:DM Mono,monospace;font-size:9px;color:var(--text-secondary);opacity:.7}.count-grid-value{font-family:DM Mono,monospace;font-size:16px;font-weight:500;color:var(--text-primary);line-height:1}.count-grid-axis-note{font-family:DM Mono,monospace;font-size:9px;color:var(--text-secondary);opacity:.5;letter-spacing:.08em;text-align:center}.count-situations{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;padding:18px 20px;display:flex;flex-direction:column;gap:12px;animation:fadeSlideUp .3s .4s ease both}.count-situations-table{width:100%;border-collapse:collapse;font-family:DM Mono,monospace;font-size:13px}.count-situations-table th{text-align:left;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);padding:0 12px 8px 0;border-bottom:1px solid var(--border-color);font-weight:400}.count-situations-table th:not(:first-child){text-align:right}.count-situations-table td{padding:9px 12px 9px 0;color:var(--text-primary);border-bottom:1px solid var(--border-light);vertical-align:top}.count-situations-table td:not(:first-child){text-align:right}.count-situations-table tbody tr:last-child td{border-bottom:none}.count-situations-table tbody tr:hover td{background:var(--bg-surface-alt)}.situation-label{display:block;font-weight:500;letter-spacing:.06em}.situation-ahead{color:#16a34a}.situation-even{color:var(--accent)}.situation-behind{color:var(--strike-color)}.situation-counts{display:block;font-size:10px;color:var(--text-secondary);opacity:.7;margin-top:2px;letter-spacing:.04em}.platoon-splits{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;padding:18px 20px;display:flex;flex-direction:column;gap:12px;margin-top:28px;animation:fadeSlideUp .3s .4s ease both}.platoon-table{width:100%;border-collapse:collapse;font-family:DM Mono,monospace;font-size:12px}.platoon-table thead th{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);padding:6px 10px;border-bottom:1px solid var(--border-color);text-align:right}.platoon-type-header{text-align:left!important;width:52px}.platoon-hand-header{text-align:center!important;padding-bottom:4px!important;font-size:11px!important;letter-spacing:.04em!important}.rhh-header{color:var(--accent)!important;border-left:2px solid var(--accent)}.lhh-header{color:var(--text-secondary)!important;border-left:1px solid var(--border-color)}.platoon-table thead tr:last-child th{font-size:9px;padding-top:2px}.platoon-table thead tr:last-child th:nth-child(2){border-left:2px solid var(--accent)}.platoon-table thead tr:last-child th:nth-child(6){border-left:1px solid var(--border-color)}.platoon-table tbody td{padding:7px 10px;text-align:right;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:12px}.platoon-table tbody td:first-child{text-align:left}.platoon-table tbody td:nth-child(2),.platoon-table tfoot td:nth-child(2){border-left:2px solid var(--accent)}.platoon-table tbody td:nth-child(6),.platoon-table tfoot td:nth-child(6){border-left:1px solid var(--border-color)}.platoon-table tbody tr:hover td{background:var(--bg-surface-alt)}.platoon-pitch-type{color:var(--accent)!important;font-weight:500;letter-spacing:.06em}.platoon-table tfoot td{padding:7px 10px;text-align:right;color:var(--text-secondary);font-size:11px;letter-spacing:.04em;border-top:1px solid var(--border-color)}.platoon-table tfoot td:first-child{text-align:left;text-transform:uppercase;font-size:9px;letter-spacing:.1em}.platoon-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}@media(max-width:720px){.platoon-splits{padding:14px 12px}.platoon-table{font-size:11px}.platoon-table thead th{padding:5px 6px;font-size:9px}.platoon-table tbody td,.platoon-table tfoot td{padding:5px 6px;font-size:11px}}.velocity-trend{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;padding:18px 20px;display:flex;flex-direction:column;gap:12px;margin-top:28px;animation:fadeSlideUp .3s .45s ease both}.velocity-chart{width:100%;height:auto;display:block}.chart-axis-label{font-family:DM Mono,monospace;font-size:10px;fill:var(--text-secondary)}.chart-axis-sub{font-family:DM Mono,monospace;font-size:9px;fill:var(--text-secondary);opacity:.5;letter-spacing:.08em;text-transform:uppercase}.chart-grid-line,.chart-axis-line{stroke:var(--border-color);stroke-width:1}.velocity-legend{display:flex;flex-wrap:wrap;gap:14px}.velocity-legend-item{display:flex;align-items:center;gap:6px;font-family:DM Mono,monospace;font-size:11px;color:var(--text-secondary);letter-spacing:.06em}.velocity-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dashboard{animation:fadeSlideUp .3s ease both}.view-mode-tabs{display:flex;gap:8px;margin-bottom:24px}.view-mode-tab{font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;padding:8px 20px;border-radius:4px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.view-mode-tab.active{background:var(--accent);color:#000;border-color:var(--accent)}.view-mode-tab:not(.active):hover{border-color:var(--accent);color:var(--text-primary)}.compare-pitcher-selectors{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.compare-pitcher-pick label{display:block;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin-bottom:6px}.compare-pitcher-pick select{width:100%;font-family:DM Sans,sans-serif;font-size:15px;padding:11px 16px;background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);border-radius:4px;cursor:pointer;transition:border-color .15s;outline:none}.compare-pitcher-pick select:focus{border-color:var(--accent)}.compare-layout{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:20px;align-items:start}.compare-pitcher-label{font-family:DM Sans,sans-serif;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);padding-bottom:10px;border-bottom:2px solid var(--accent);margin-bottom:16px}.compare-pitcher-label--p2{color:var(--text-secondary);border-color:var(--border-color)}@media(max-width:720px){.compare-layout,.compare-pitcher-selectors{grid-template-columns:1fr}}.game-selector{display:flex;flex-direction:column;gap:8px;margin-bottom:28px}.game-selector-label{font-family:DM Sans,sans-serif;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary)}.game-select{width:100%;font-family:DM Sans,sans-serif;font-size:15px;padding:11px 16px;background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);border-radius:4px;cursor:pointer;transition:border-color .15s;outline:none}.game-select:focus{border-color:var(--accent)}.game-select:disabled{opacity:.5;cursor:not-allowed}.section-header{margin-bottom:20px}.section-header-title{font-family:DM Sans,sans-serif;font-size:22px;font-weight:700;color:var(--text-heading);margin-bottom:2px}.section-header-sub{font-family:DM Mono,monospace;font-size:12px;color:var(--text-secondary);letter-spacing:.06em}.error-banner{background:#dc262614;border:1px solid var(--strike-color);color:var(--strike-color);padding:10px 16px;border-radius:4px;font-size:14px;margin-bottom:20px;font-family:DM Mono,monospace}.game-info-header{margin-bottom:20px;animation:fadeSlideUp .3s 50ms ease both}.game-info-header h2{font-family:DM Sans,sans-serif;font-size:20px;font-weight:700;color:var(--text-heading);margin-bottom:2px}.game-info-sub{font-family:DM Mono,monospace;font-size:12px;color:var(--text-secondary);letter-spacing:.06em}.filter-bar{display:flex;gap:16px;flex-wrap:wrap;padding:14px 18px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;margin-bottom:24px;animation:fadeSlideUp .3s .1s ease both}.filter-item{display:flex;flex-direction:column;gap:4px;min-width:140px}.filter-item label{font-family:DM Mono,monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary)}.filter-item select{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);padding:7px 10px;border-radius:4px;font-size:14px;font-family:DM Sans,sans-serif;cursor:pointer;transition:border-color .15s;outline:none}.filter-item select:focus{border-color:var(--accent)}.filter-pitch-count{font-family:DM Mono,monospace;font-size:11px;color:var(--text-secondary);align-self:flex-end;padding-bottom:8px;margin-left:auto}.filter-pitch-count strong{color:var(--accent);font-weight:500}.dashboard-content{display:grid;grid-template-columns:1fr auto;gap:28px;align-items:start;animation:fadeSlideUp .3s .2s ease both}@media(max-width:720px){.dashboard-content{grid-template-columns:1fr}}.analytics-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:28px;margin-top:28px}@media(max-width:720px){.analytics-row{grid-template-columns:1fr}}.split-stats{margin-top:28px}.empty-state{text-align:center;padding:64px 0;color:var(--text-secondary)}.empty-state p{font-size:15px;margin-bottom:8px}.empty-state .empty-hint{font-family:DM Mono,monospace;font-size:12px;opacity:.7}.loading-state{text-align:center;padding:64px 0;color:var(--text-secondary);font-family:DM Mono,monospace;font-size:13px;letter-spacing:.08em}.app-shell{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1}.navbar{background-color:var(--bg-navbar);padding:0 28px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 20px #00000080}.navbar:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--accent) 30%,var(--accent) 70%,transparent 100%)}.navbar-brand{display:flex;align-items:center;gap:10px;font-family:DM Sans,sans-serif;font-size:17px;font-weight:700;color:var(--accent);letter-spacing:.08em;text-transform:uppercase}.navbar-logo{height:36px;width:auto;object-fit:contain}.navbar-brand span{color:#ffffff80;font-weight:400;margin-left:6px;font-size:13px;letter-spacing:.04em;text-transform:none}.theme-toggle{background:transparent;border:1px solid rgba(245,158,11,.5);color:var(--accent);font-family:DM Mono,monospace;font-size:11px;letter-spacing:.1em;padding:6px 14px;border-radius:4px;cursor:pointer;transition:background-color .15s,border-color .15s,color .15s;display:flex;align-items:center;gap:6px}.theme-toggle:hover{background-color:var(--accent);border-color:var(--accent);color:#0f1923}.theme-toggle-icon{font-size:13px}.app-main{flex:1;padding:28px 32px;max-width:1280px;width:100%;margin:0 auto}.not-found{text-align:center;padding:80px 0;color:var(--text-secondary)}.not-found p{font-size:18px;margin-bottom:12px}
