@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg:#15221d;--surface:#1e2d27;--surface-2:#2a3a32;--border:#ffffff14;--border-hi:#ffffff26;--accent:#3b82f6;--accent-dim:#3b82f61f;--green:#22c55e;--green-dim:#22c55e1f;--red:#f43f5e;--red-dim:#f43f5e1f;--amber:#f59e0b;--text:#d1dce8;--text-sub:#64748b;--text-muted:#2e4260;--radius:10px;--radius-lg:16px;--font:"Inter", system-ui, sans-serif;--mono:"JetBrains Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;min-height:100vh;font-size:14px;line-height:1.5}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:0 1.5rem;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;padding:1rem 0 .75rem;display:flex}.header-brand{align-items:center;gap:.75rem;display:flex}.brand-title{letter-spacing:-.01em;color:#e2e8f0;font-size:1.05rem;font-weight:700}.brand-sub{color:var(--text-sub);letter-spacing:.04em;text-transform:uppercase;margin-top:1px;font-size:.72rem}.header-meta{gap:.5rem;display:flex}.meta-pill{color:#eaedea99;text-transform:uppercase;letter-spacing:.05em;background:#2a3a32;border-radius:999px;padding:.25rem .75rem;font-size:.7rem;font-weight:500;box-shadow:inset 0 0 0 1px #ffffff1a}.view-switcher{gap:0;padding:.5rem 0;display:flex}.view-tab{color:var(--text-sub);font-size:.8rem;font-weight:500;font-family:var(--font);cursor:pointer;border-radius:var(--radius);letter-spacing:.01em;background:0 0;border:none;padding:.45rem 1.25rem;transition:all .18s}.view-tab:hover{color:var(--text);background:#ffffff0a}.view-tab.active{color:var(--accent);background:var(--accent-dim);border:1px solid #3b82f640}.app-main{flex-direction:column;flex:1;width:100%;max-width:1100px;margin:0 auto;padding:1.5rem 1.5rem 2rem;display:flex}.view-body{flex-direction:column;gap:1rem;display:flex}.view-controls{flex-flow:column wrap;justify-content:center;align-items:center;gap:1.5rem;width:100%;max-width:600px;margin:0 auto;display:flex}.selector-wrap{align-items:center;gap:.5rem;display:flex}.selector-label{letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;font-size:.65rem;font-weight:700}.game-select{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);cursor:pointer;outline:none;min-width:240px;padding:.45rem .85rem;font-size:.85rem;transition:border-color .15s}.game-select:hover{border-color:var(--border-hi)}.game-select:focus{border-color:var(--accent)}.game-select option{background:#111d2c}.stats-row{border-radius:var(--radius-lg);background:#2a3a32;display:flex;box-shadow:inset 0 0 0 1px #ffffff1a}.stat-badge{border-right:1px solid #ffffff1a;flex-direction:column;justify-content:center;align-items:center;min-width:140px;padding:1.2rem 2rem;display:flex}.stat-badge:last-child{border-right:none}.stat-val{color:#eaedea;margin-bottom:.4rem;font-size:1.75rem;font-weight:700;line-height:1}.stat-val.hi{color:#eaedea}.stat-lbl{text-transform:uppercase;letter-spacing:.05em;color:#eaedea99;white-space:nowrap;align-items:center;font-size:.7rem;font-weight:500;display:flex}.sz-chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem .5rem .5rem}.chart-legend{justify-content:center;align-items:center;gap:1.2rem;padding:.5rem 0;display:flex}.legend-item{color:var(--text-sub);align-items:center;gap:.4rem;font-size:.75rem;display:flex}.legend-item.muted{opacity:.55}.lg-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.chart-tooltip{border:1px solid var(--border-hi);border-radius:var(--radius);background:#0d1826;min-width:200px;padding:.75rem .9rem;font-size:.78rem;box-shadow:0 8px 32px #0009,0 0 0 1px #3b82f614}.tt-name{color:#e2e8f0;margin-bottom:.4rem;font-size:.88rem;font-weight:700}.tt-separator{background:var(--border);height:1px;margin:.4rem 0}.tt-row{color:var(--text-sub);justify-content:space-between;gap:1rem;line-height:1.8;display:flex}.tt-row span:last-child{color:var(--text);font-weight:500;font-family:var(--mono);font-size:.76rem}.tt-outcome{margin-top:.35rem;font-size:.82rem;font-weight:700}.tt-des{color:var(--text-sub);max-width:240px;font-size:.72rem;font-style:italic;line-height:1.45}.leverage-row span:last-child{color:var(--amber)}.league-header{flex-direction:column;align-items:flex-start;gap:.6rem}.league-title{color:#e2e8f0;font-size:1rem;font-weight:600}.league-sub{color:var(--text-sub);font-size:.75rem}.quadrant-key{color:var(--text-sub);flex-wrap:wrap;align-items:center;gap:.6rem;font-size:.73rem;display:flex}.qk-dot{border-radius:50%;width:9px;height:9px;display:inline-block}.loading-wrapper{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;display:flex}.loading-zone{margin-bottom:.5rem}.zone-box{background:#3b82f60a;border:2px solid #3b82f666;border-radius:4px;width:72px;height:90px;position:relative}.zone-dot{border-radius:50%;width:11px;height:11px;animation:1.5s ease-in-out infinite dotPop;position:absolute}.d1{background:#22c55e;animation-delay:0s;top:20%;left:15%}.d2{background:#f43f5e;animation-delay:.4s;top:60%;left:70%}.d3{background:#22c55e;animation-delay:.8s;top:35%;left:55%}.d4{background:#f43f5e;animation-delay:1.2s;top:75%;left:25%}@keyframes dotPop{0%,to{opacity:.2;transform:scale(.7)}50%{opacity:1;transform:scale(1.2);box-shadow:0 0 8px}}.loading-title{color:#e2e8f0;font-size:1rem;font-weight:600}.loading-sub{color:var(--text-sub);text-align:center;max-width:320px;font-size:.78rem}.loading-bar-track{background:var(--border);border-radius:999px;width:220px;height:3px;margin-top:.5rem;overflow:hidden}.loading-bar-fill{background:var(--accent);border-radius:999px;height:100%;animation:2s ease-in-out infinite barSweep}@keyframes barSweep{0%{width:0%;margin-left:0}50%{width:60%;margin-left:20%}to{width:0%;margin-left:100%}}.error-wrapper{text-align:center;flex-direction:column;flex:1;align-items:center;gap:.75rem;padding:4rem 2rem;display:flex}.error-icon{font-size:2.5rem}.error-title{color:var(--red);font-size:1rem;font-weight:600}.error-msg{color:var(--text-sub);white-space:pre-line;max-width:420px;font-size:.82rem}.error-hint{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-sub);padding:1rem 1.25rem;font-size:.78rem}.error-hint code{background:var(--border);font-family:var(--mono);color:var(--accent);border-radius:4px;margin-top:.25rem;padding:.2rem .6rem;font-size:.78rem;display:inline-block}.retry-btn{background:var(--accent-dim);border-radius:var(--radius);color:var(--accent);font-family:var(--font);cursor:pointer;border:1px solid #3b82f64d;margin-top:.5rem;padding:.5rem 1.25rem;font-size:.82rem;font-weight:500;transition:all .15s}.retry-btn:hover{background:#3b82f633}.empty-state{text-align:center;color:var(--text-sub);flex-direction:column;align-items:center;gap:.5rem;padding:5rem 2rem;display:flex}.empty-icon{margin-bottom:.5rem;font-size:2.5rem}.empty-sub{color:var(--text-muted);max-width:320px;font-size:.78rem}.app-footer{border-top:1px solid var(--border);color:var(--text-muted);align-items:center;gap:.6rem;padding:.75rem 1.5rem;font-size:.7rem;display:flex}.footer-sep{opacity:.4}.footer-note{font-style:italic}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:#1e2d4680}.recharts-scatter-symbol{cursor:pointer}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.realistic-sz-container{flex-direction:column;align-items:center;width:100%;display:flex}.stadium-bg{aspect-ratio:1;border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;max-width:600px;position:relative;overflow:hidden;box-shadow:0 10px 30px #00000080}.sz-img-bg{object-fit:cover;transform-origin:50%;width:100%;height:100%;transform:scale(1.05)}.sz-overlay-area{width:100%;height:100%;position:absolute;top:0;left:0}.sz-box{background:#ffffff26;border:2px solid #fffc;position:absolute;box-shadow:0 0 15px #fff6}.sz-grid{background-image:linear-gradient(90deg,#0000 33.33%,#ffffff4d 33.33% 33.6%,#0000 33.6%),linear-gradient(90deg,#0000 66.66%,#ffffff4d 66.66% 67%,#0000 67%),linear-gradient(#0000 33.33%,#ffffff4d 33.33% 33.6%,#0000 33.6%),linear-gradient(#0000 66.66%,#ffffff4d 66.66% 67%,#0000 67%);width:100%;height:100%}.pitch-dot{cursor:pointer;background-size:cover;border-radius:50%;transition:transform .2s;position:absolute;box-shadow:0 4px 10px #00000080}.pitch-dot:hover,.pitch-dot.hovered{z-index:10;transform:translate(-50%,-50%)scale(1.3)!important}.pitch-dot.overturned{background-color:var(--green);box-shadow:0 0 15px var(--green);border:2px solid #fff}.pitch-dot.upheld{background-color:var(--red);box-shadow:0 0 15px var(--red);border:2px solid #fff}.baseball-texture{border-radius:50%;width:100%;height:100%}.realistic-sz-controls{margin-top:1rem}.realistic-tt{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0d1826f2}.info-bubble{cursor:help;color:var(--text-sub);opacity:1;align-items:center;transition:all .2s;display:inline-flex;position:relative}.info-bubble:hover{color:var(--accent);opacity:1}[data-tooltip]:hover:after{content:attr(data-tooltip);background:var(--surface-2);border:1px solid var(--border-hi);border-radius:var(--radius);color:var(--text);white-space:normal;z-index:100;text-transform:none;pointer-events:none;text-align:left;width:max-content;max-width:240px;margin-bottom:8px;padding:.6rem .8rem;font-size:.75rem;font-weight:400;line-height:1.4;position:absolute;bottom:100%;right:-10px;box-shadow:0 4px 16px #00000080}.tooltip-bottom[data-tooltip]:hover:after{max-width:300px;margin-top:8px;margin-bottom:0;inset:100% auto auto 0}@media (width<=600px){.header-inner{flex-direction:column;align-items:flex-start;gap:.75rem}.header-meta{gap:.5rem;width:100%}.app-main{padding:1rem 1rem 1.5rem}.selector-wrap{flex-direction:column;align-items:flex-start;width:100%}.game-select{width:100%;min-width:unset}.stats-row{flex-wrap:wrap}.stat-badge{width:50%;min-width:unset;border-right:none;padding:1rem .5rem}.stat-badge:first-child,.stat-badge:nth-child(2){border-bottom:1px solid #ffffff1a}.stat-badge:nth-child(odd){border-right:1px solid #ffffff1a}.stat-val{font-size:1.4rem}.stat-lbl{font-size:.65rem}.chart-legend{flex-direction:column;align-items:flex-start;border-radius:12px!important;gap:.8rem!important}.chart-tooltip{min-width:160px;max-width:180px;padding:.5rem .65rem}.tt-name{font-size:.8rem}.tt-row span:last-child{font-size:.7rem}.tt-des{font-size:.65rem}[data-tooltip]:hover:after{width:240px;max-width:85vw;left:50%;right:auto;transform:translate(-50%)}.tooltip-bottom[data-tooltip]:hover:after{width:260px;left:50%;right:auto;transform:translate(-50%)}}
