:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;width:100%;box-sizing:border-box}*,*:before,*:after{box-sizing:border-box}html{width:100%;overflow-x:hidden}#root{width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.navigation-bar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:1000}.nav-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem}.nav-brand h1{margin:0;font-size:1.25rem;font-weight:600}.burger-menu{display:flex;flex-direction:column;justify-content:space-around;width:24px;height:24px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001}.burger-menu span{width:24px;height:3px;background:#fff;border-radius:2px;transition:all .3s ease;transform-origin:1px}.burger-menu.active span:first-child{transform:rotate(45deg)}.burger-menu.active span:nth-child(2){opacity:0}.burger-menu.active span:nth-child(3){transform:rotate(-45deg)}.nav-menu{position:fixed;top:0;right:-300px;width:280px;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);transition:right .3s ease;z-index:1000;padding-top:80px;box-shadow:-2px 0 10px #0000001a}.nav-menu.active{right:0}.nav-items{display:flex;flex-direction:column;padding:1rem;gap:.5rem}.nav-item{display:flex;align-items:center;text-decoration:none;color:#ffffffe6;padding:1rem 1.5rem;border-radius:12px;transition:all .3s ease;gap:1rem}.nav-item:hover{background:#ffffff1a;color:#fff;transform:translate(5px)}.nav-item.active{background:#fff3;color:#fff;box-shadow:0 2px 8px #0003}.nav-icon{font-size:1.5rem;min-width:24px}.nav-label{font-size:1rem;font-weight:500}.nav-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 768px){.nav-header{padding:.5rem 1rem}.nav-brand h1{font-size:1.1rem}.nav-menu{width:100vw;right:-100vw}.nav-menu.active{right:0}}.page-layout{padding:1rem;margin:0 auto;min-height:calc(100vh - 80px);width:100%;box-sizing:border-box}.page-header{text-align:center;margin-bottom:2rem;padding:1.5rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px;box-shadow:0 2px 8px #0000001a;width:100%;box-sizing:border-box}.page-header h1{margin:0 0 .5rem;font-size:2rem;color:#333;font-weight:600}.page-header p{margin:0;color:#666;font-size:1rem;line-height:1.4}.page-content{display:flex;flex-direction:column;gap:2rem;width:100%;box-sizing:border-box}.page-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000001a;border:1px solid #e0e6ed;width:100%;box-sizing:border-box}.page-section h2{margin:0 0 1rem;font-size:1.5rem;color:#333;font-weight:600;border-bottom:2px solid #667eea;padding-bottom:.5rem}.page-section h3{margin:0 0 .75rem;font-size:1.25rem;color:#444;font-weight:500}.coming-soon{text-align:center;background:#fff;border-radius:16px;padding:3rem 2rem;box-shadow:0 8px 24px #0000001a;border:1px solid #e0e6ed;max-width:600px;width:100%;margin:0 auto;box-sizing:border-box}.coming-soon-icon{font-size:4rem;margin-bottom:1rem;opacity:.8}.coming-soon h2{margin:0 0 1rem;font-size:1.8rem;color:#333;font-weight:600;border:none;padding:0}.coming-soon p{color:#666;font-size:1rem;margin-bottom:1.5rem;line-height:1.5}.coming-soon ul{text-align:left;color:#555;margin-bottom:2rem;padding-left:1rem}.coming-soon li{margin-bottom:.5rem;line-height:1.4}.phase-indicator{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding-top:1.5rem;border-top:1px solid #e0e6ed}.phase-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.phase-indicator span:last-child{color:#666;font-size:.9rem;font-style:italic}@media (max-width: 768px){.page-layout{padding:.5rem;min-height:calc(100vh - 70px)}.page-header{margin-bottom:1rem;padding:1rem}.page-header h1{font-size:1.5rem}.page-section{padding:1rem}.page-section h2{font-size:1.25rem}.coming-soon{padding:2rem 1rem}.coming-soon-icon{font-size:3rem}.coming-soon h2{font-size:1.5rem}}@media (min-width: 769px) and (max-width: 1024px){.page-layout{padding:1.5rem}}@media (min-width: 768px) and (max-width: 1024px) and (orientation: portrait){.page-layout{padding:1rem;width:100%}}@media (min-width: 768px) and (max-width: 1024px) and (orientation: landscape){.page-layout{padding:1rem;width:100%}}@media (min-width: 1025px){.page-layout{padding:2rem;width:100%}}.team-config-panel{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 12px #0000001a;margin-bottom:20px;max-width:600px}.config-header{text-align:center;margin-bottom:20px}.config-header h2{margin:0;color:#1976d2;font-size:1.8em}.config-table{display:flex;flex-direction:column;gap:8px}.config-row{display:grid;grid-template-columns:120px 1fr 1fr;gap:15px;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0}.config-row:last-child{border-bottom:none}.header-row{font-weight:700;background:#f8f9fa;padding:12px 0;border-radius:8px;margin-bottom:5px}.position-label{font-weight:600;color:#333;text-align:center;font-size:14px}.team-column{display:flex;justify-content:center;align-items:center}.player-input{width:100%;max-width:140px;padding:8px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;text-align:center;transition:all .3s ease}.player-input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.system-row{background:#fff3e0;padding:12px 0;border-radius:8px;margin:10px 0;border:none}.system-select{width:100%;max-width:140px;padding:8px 12px;border:2px solid #ff9800;border-radius:6px;font-size:14px;text-align:center;background:#fff;cursor:pointer}.system-select:focus{outline:none;border-color:#f57c00;box-shadow:0 0 0 3px #ff98001a}.starting-rotation{display:flex;align-items:center;gap:8px}.sr-label{font-weight:700;color:#1976d2;font-size:14px;min-width:20px}.rotation-select{padding:6px 10px;border:2px solid #4caf50;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;min-width:100px}.rotation-select:focus{outline:none;border-color:#388e3c;box-shadow:0 0 0 3px #4caf501a}.config-info{margin-top:20px;padding:15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #1976d2}.system-info{margin:0;font-size:14px;color:#333;line-height:1.6}@media (max-width: 768px){.config-row{grid-template-columns:80px 1fr 1fr;gap:10px}.position-label{font-size:12px}.player-input,.system-select,.rotation-select{max-width:none;font-size:13px;padding:6px 8px}.config-header h2{font-size:1.5em}}@media (min-width: 768px) and (max-width: 1024px){.team-config-panel{max-width:700px}.player-input,.system-select,.rotation-select{max-width:160px}}.advanced-volleyball-court{width:100%;max-width:350px;margin:10px}.advanced-volleyball-court.top-half,.advanced-volleyball-court.bottom-half{margin:0;max-width:100%}.advanced-volleyball-court.top-half .court,.advanced-volleyball-court.bottom-half .court{border-bottom:none;border-top:none}.advanced-volleyball-court.top-half .court{border-bottom:none}.advanced-volleyball-court.bottom-half .court{border-top:none}.court-title{text-align:center;margin-bottom:10px}.court-title h4{margin:0;font-size:1.2em;font-weight:700}.court-title span{font-size:.9em;opacity:.8}.court{position:relative;width:100%;height:280px;background:linear-gradient(135deg,#f0f8ff,#e6f3ff);border:3px solid #2196f3;border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden}.court-background{position:absolute;inset:0}.net-line{position:absolute;top:50%;left:0;right:0;height:3px;background:#333;transform:translateY(-50%);box-shadow:0 1px 3px #0000004d}.attack-line-front{position:absolute;top:25%;left:8%;right:8%;height:2px;background:#666;transform:translateY(-50%)}.attack-line-back{position:absolute;top:75%;left:8%;right:8%;height:2px;background:#666;transform:translateY(-50%)}.center-line{position:absolute;left:50%;top:0;bottom:0;width:1px;background:#999;transform:translate(-50%)}.player-position{position:absolute;z-index:10}.player-circle{width:60px;height:60px;border-radius:50%;background:#fff;border:3px solid #2196f3;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;font-weight:700;box-shadow:0 3px 8px #0003;cursor:pointer;transition:all .3s ease}.player-circle:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000004d}.player-number{font-size:10px;font-weight:700;margin-bottom:1px}.player-name{font-size:9px;font-weight:400;margin-bottom:1px;text-align:center;line-height:1}.player-role{font-size:7px;font-weight:400;opacity:.9}.server .player-circle{background:#ff5722;border-color:#d84315;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 3px 8px #0003}50%{box-shadow:0 3px 8px #ff572266,0 0 0 8px #ff57221a}to{box-shadow:0 3px 8px #0003}}.server-indicator{position:absolute;top:-8px;right:-8px;width:16px;height:16px;background:#ff5722;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;animation:bounce 1s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}60%{transform:translateY(-2px)}}.formation-indicator{position:absolute;top:8px;right:8px;background:#000000b3;color:#fff;padding:4px 8px;border-radius:12px;font-size:10px;font-weight:700}.formation-indicator .serving{color:#4caf50}.formation-indicator .rally{color:#ff9800}.court-labels{position:absolute;width:100%;height:100%;pointer-events:none}.front-court-label{position:absolute;top:12%;left:50%;transform:translate(-50%);color:#666;font-size:10px;font-weight:700;background:#fffc;padding:2px 6px;border-radius:3px}.back-court-label{position:absolute;top:88%;left:50%;transform:translate(-50%);color:#666;font-size:10px;font-weight:700;background:#fffc;padding:2px 6px;border-radius:3px}.net-label{position:absolute;top:50%;right:8px;transform:translateY(-50%);color:#333;font-size:8px;font-weight:700;background:#ffffffe6;padding:1px 4px;border-radius:2px}@media (max-width: 768px){.advanced-volleyball-court{max-width:300px}.court{height:240px}.player-circle{width:50px;height:50px}.player-number{font-size:9px}.player-name{font-size:8px}.player-role{font-size:6px}}.rotation-map-viewer{width:100%;margin:0 auto;padding:1rem}.rotation-legend{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:1rem;padding:.75rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:#555}.legend-item.serving{color:#28a745}.legend-item.rally{color:#fd7e14}.rotation-controls{display:flex;justify-content:center;align-items:center;gap:1rem;margin-bottom:2rem;padding:1rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.rotation-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease}.rotation-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.rotation-btn:active{transform:translateY(0)}.rotation-indicators{display:flex;gap:.5rem}.rotation-dot{width:40px;height:40px;border-radius:50%;border:2px solid #dee2e6;background:#fff;color:#6c757d;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.rotation-dot:hover{border-color:#667eea;color:#667eea;transform:scale(1.1)}.rotation-dot.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;transform:scale(1.1);box-shadow:0 4px 12px #667eea4d}.courts-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.formation-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #0000001a;border:1px solid #e0e6ed}.formation-title{text-align:center;margin:0 0 1rem;font-size:1.3rem;font-weight:600;padding-bottom:.5rem;border-bottom:2px solid #e0e6ed}.formation-title.serving{color:#28a745;border-bottom-color:#28a745}.formation-title.rally{color:#fd7e14;border-bottom-color:#fd7e14}.unified-volleyball-court{width:100%;max-width:400px;margin:0 auto;aspect-ratio:3/4}.unified-court{position:relative;width:100%;height:100%;background:#fff3cd;border:3px solid #333;border-radius:8px;overflow:hidden}.unified-court-background{position:absolute;inset:0}.unified-net-line{position:absolute;top:50%;left:0;right:0;height:4px;background:#333;transform:translateY(-50%);box-shadow:0 2px 4px #0000004d}.unified-player-position{position:absolute;z-index:10}.unified-player-circle{width:45px;height:45px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px solid;position:relative;cursor:pointer;transition:all .3s ease}.unified-player-circle:hover{transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.unified-player-circle.team-a{background:#dc3545;border-color:#b02a37;color:#fff}.unified-player-circle.team-b{background:#0d6efd;border-color:#0a5bb5;color:#fff}.unified-player-name{font-size:.7rem;font-weight:600;text-align:center;line-height:.9;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.unified-position-number{font-size:.6rem;font-weight:500;opacity:.8}.server-indicator{position:absolute;top:-8px;right:-8px;background:#ffc107;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:.7rem;animation:pulse 2s infinite;box-shadow:0 2px 4px #0000004d}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@media (max-width: 768px){.unified-player-circle{width:35px;height:35px}.unified-player-name{font-size:.6rem}.unified-position-number{font-size:.5rem}.server-indicator{width:14px;height:14px;font-size:.6rem;top:-6px;right:-6px}}@media (max-width: 768px){.rotation-map-viewer{padding:.5rem}.courts-container{grid-template-columns:1fr;gap:1rem}.rotation-controls{flex-direction:column;gap:1rem}.rotation-legend{flex-direction:column;gap:.5rem}.rotation-btn{padding:.5rem 1rem;font-size:.8rem}.rotation-dot{width:35px;height:35px;font-size:.9rem}.formation-title{font-size:1.1rem}.team-label{font-size:.9rem}}@media (min-width: 768px) and (max-width: 1024px){.rotation-map-viewer{width:100%;padding:1rem}.courts-container{gap:1.5rem;width:100%}.formation-section{padding:1.25rem;width:100%}.unified-volleyball-court{max-width:none;width:100%}}@media (min-width: 768px) and (max-width: 1024px){.courts-container{grid-template-columns:1fr 1fr;gap:1.5rem}}.rotations-layout{display:grid;gap:2rem}@media (min-width: 1024px){.rotations-layout{grid-template-columns:1fr 2fr;align-items:start}.rotations-layout .page-section:first-child{position:sticky;top:100px}}.match-list-page{padding:24px;max-width:1400px;margin:0 auto}.match-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.match-list-header h1{font-size:32px;font-weight:700;color:#111827;margin:0}.btn-new-match{background:#3b82f6;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.btn-new-match:hover{background:#2563eb}.match-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.match-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .2s;position:relative;display:flex;flex-direction:column;gap:12px}.match-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.status-badge{position:absolute;top:12px;right:12px;padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.ongoing{background:#fef3c7;color:#92400e}.status-badge.completed{background:#e5e7eb;color:#6b7280}.status-badge.new{background:#dbeafe;color:#1e40af}.match-card-teams{font-size:18px;font-weight:600;color:#111827;margin-top:8px;padding-right:90px}.match-card-info{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#6b7280;padding:8px 0;border-top:1px solid #f3f4f6;border-bottom:1px solid #f3f4f6}.match-status{color:#f59e0b;font-weight:500}.match-date{color:#6b7280}.match-score{font-weight:600;color:#111827;font-size:16px}.btn-open{width:100%;padding:12px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:4px}.btn-open.ongoing{background:#10b981;color:#fff}.btn-open.ongoing:hover{background:#059669}.btn-open.completed{background:#3b82f6;color:#fff}.btn-open.completed:hover{background:#2563eb}.btn-open.new{background:#8b5cf6;color:#fff}.btn-open.new:hover{background:#7c3aed}.match-list-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.spinner{width:48px;height:48px;border:4px solid #f3f4f6;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.match-list-loading p{font-size:16px;color:#6b7280}.match-list-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.match-list-error p{font-size:16px;color:#ef4444}.btn-retry{background:#3b82f6;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:600;cursor:pointer}.btn-retry:hover{background:#2563eb}.match-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:8px}.match-list-empty p{font-size:18px;color:#6b7280;margin:0}.empty-hint{font-size:14px;color:#9ca3af}@media (min-width: 768px) and (max-width: 1024px){.match-list-grid{grid-template-columns:repeat(2,1fr);gap:24px}.match-card{padding:24px}}@media (max-width: 767px){.match-list-page{padding:16px}.match-list-header{margin-bottom:24px}.match-list-header h1{font-size:24px}.btn-new-match{padding:10px 20px;font-size:14px}.match-list-grid{grid-template-columns:1fr;gap:16px}}.match-setup-page{min-height:100vh;background:#f9fafb;padding:20px}.match-setup-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px}.match-setup-loading .spinner{width:48px;height:48px;border:4px solid #f3f4f6;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.match-setup-header{display:flex;align-items:center;gap:16px;margin-bottom:32px}.match-setup-header h1{font-size:24px;font-weight:600;color:#111827;margin:0}.btn-back-arrow{background:none;border:none;color:#3b82f6;font-size:16px;cursor:pointer;padding:8px;transition:color .2s}.match-setup-form{max-width:500px;margin:0 auto;background:#fff;border-radius:12px;padding:32px;box-shadow:0 1px 3px #0000001a}.error-banner{background:#fee2e2;color:#991b1b;padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:14px}.form-section{margin-bottom:24px}.form-section label{display:block;font-weight:500;font-size:14px;color:#374151;margin-bottom:8px}.form-input,.form-select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:16px;transition:border-color .2s}.form-input:focus,.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-select{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px}.form-select option:disabled{color:#9ca3af}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.btn-secondary,.btn-primary{padding:10px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.btn-secondary:hover{background:#f9fafb}.btn-primary{background:#3b82f6;border:none;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 6px #3b82f633}.btn-primary:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}@media (max-width: 1024px) and (orientation: landscape){.match-setup-page{padding:16px}.match-setup-form{max-width:600px}}@media (max-width: 768px){.match-setup-header h1{font-size:20px}.match-setup-form{padding:24px}.form-actions{flex-direction:column}.btn-secondary,.btn-primary{width:100%}}.win-loss-toggle{display:flex;gap:12px;margin-bottom:20px}.toggle-btn{flex:1;padding:16px 24px;font-size:18px;font-weight:600;border:2px solid #d1d5db;border-radius:8px;background-color:#fff;color:#6b7280;cursor:pointer;transition:all .2s ease;min-height:60px;touch-action:manipulation}.toggle-btn.win-btn{border-color:#93c5fd}.toggle-btn.loss-btn{border-color:#fca5a5}.toggle-btn:hover:not(:disabled){background-color:#f9fafb}.toggle-btn.win-btn:hover:not(:disabled){border-color:#60a5fa;background-color:#eff6ff}.toggle-btn.loss-btn:hover:not(:disabled){border-color:#f87171;background-color:#fef2f2}.toggle-btn:active:not(:disabled){transform:scale(.98)}.toggle-btn.active{font-weight:700;border-width:3px}.toggle-btn.win-btn.active{background-color:#dbeafe;border-color:#2563eb;color:#1e40af}.toggle-btn.loss-btn.active{background-color:#fee2e2;border-color:#dc2626;color:#991b1b}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.toggle-btn:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}@media (min-width: 768px){.toggle-btn{min-height:70px;font-size:20px}}.segmented-control{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin-bottom:16px}.segment-btn{padding:12px 16px;font-size:16px;font-weight:500;border:2px solid #e5e7eb;border-radius:6px;background-color:#fff;color:#374151;cursor:pointer;transition:all .15s ease;touch-action:manipulation;white-space:nowrap;text-align:center}.segment-btn:hover:not(:disabled){border-color:#9ca3af;background-color:#f9fafb}.segment-btn:active:not(:disabled){transform:scale(.97)}.segment-btn.active{background-color:#1f2937;border-color:#1f2937;color:#fff;font-weight:600}.segment-btn:disabled{opacity:.4;cursor:not-allowed}.segment-btn:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}@media (max-width: 640px){.segmented-control{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:6px}.segment-btn{padding:10px 12px;font-size:14px}}@media (min-width: 768px) and (max-width: 1024px){.segmented-control{grid-template-columns:repeat(5,1fr);gap:10px}.segment-btn{padding:14px 20px;font-size:17px}}.conditional-dropdown{margin-bottom:16px}.dropdown-label{display:block;font-size:15px;font-weight:500;color:#374151;margin-bottom:8px}.dropdown-select{width:100%;padding:12px 40px 12px 16px;font-size:16px;color:#1f2937;background-color:#fff;border:2px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .15s ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:20px}.dropdown-select:hover:not(:disabled){border-color:#9ca3af}.dropdown-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.dropdown-select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.dropdown-select.error{border-color:#dc2626}.dropdown-select.error:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}@media (min-width: 768px){.dropdown-select{padding:14px 18px;font-size:17px}}.player-selector{margin-bottom:16px}.player-label{display:block;font-size:15px;font-weight:500;color:#374151;margin-bottom:8px}.required-indicator{color:#dc2626;margin-left:4px}.team-indicator{font-size:13px;color:#6b7280;margin-left:6px;text-transform:capitalize}.player-select{width:100%;padding:12px 40px 12px 16px;font-size:16px;color:#1f2937;background-color:#fff;border:2px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .15s ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:20px}.player-select:hover:not(:disabled){border-color:#9ca3af}.player-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.player-select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.player-select.error{border-color:#dc2626}.player-select.error:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.error-message{display:block;margin-top:6px;font-size:14px;color:#dc2626}.warning-message{display:block;margin-top:6px;font-size:14px;color:#d97706}@media (min-width: 768px){.player-select{padding:14px 18px;font-size:17px}}.point-entry-form{background-color:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.form-title{font-size:20px;font-weight:600;color:#1f2937;margin:0 0 20px}.form-section{margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}@media (max-width: 767px){.form-row{grid-template-columns:1fr;gap:16px}}.section-label{display:block;font-size:15px;font-weight:500;color:#374151;margin-bottom:8px}.submit-btn{width:100%;padding:16px 24px;font-size:18px;font-weight:600;color:#fff;background-color:#2563eb;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-top:20px;touch-action:manipulation}.submit-btn:hover:not(:disabled){background-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.submit-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0000001a}.submit-btn:disabled{background-color:#9ca3af;cursor:not-allowed;opacity:.6}.submit-btn:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.save-btn{width:100%;padding:14px 24px;font-size:16px;font-weight:600;color:#fff;background-color:#059669;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-top:12px;touch-action:manipulation}.save-btn:hover:not(:disabled){background-color:#047857;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.save-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0000001a}.save-btn:disabled{background-color:#9ca3af;cursor:not-allowed;opacity:.6}.form-errors{margin-top:16px;padding:12px 16px;background-color:#fee2e2;border-left:4px solid #dc2626;border-radius:6px}.error-item{font-size:14px;color:#991b1b;margin-bottom:4px}.error-item:last-child{margin-bottom:0}.save-status{margin-top:12px;padding:10px 14px;border-radius:6px;font-size:14px;text-align:center}.save-status.error{background-color:#fef3c7;color:#92400e;border:1px solid #fbbf24}.save-status.success{background-color:#d1fae5;color:#065f46;border:1px solid #10b981}@media (min-width: 768px){.point-entry-form{padding:28px}.form-title{font-size:22px}.submit-btn{padding:18px 28px;font-size:19px}}.point-by-point-list{background-color:#fff;padding:24px;border-radius:12px;box-shadow:0 1px 3px #0000001a}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.list-title{font-size:20px;font-weight:600;color:#1f2937;margin:0}.undo-btn{padding:8px 16px;font-size:14px;font-weight:500;color:#dc2626;background-color:#fff;border:2px solid #dc2626;border-radius:6px;cursor:pointer;transition:all .15s ease}.undo-btn:hover{background-color:#fee2e2;border-color:#b91c1c;color:#991b1b}.undo-btn:active{transform:scale(.97)}.empty-state{text-align:center;padding:40px 20px;color:#6b7280}.empty-state p{margin:0;font-size:16px}.list-column-headers{display:grid;grid-template-columns:100px 1fr 1fr;gap:16px;padding:12px 16px;background-color:#f9fafb;border-radius:6px;margin-bottom:12px;font-weight:600;font-size:14px;color:#374151}.header-score,.header-home,.header-opponent{text-transform:uppercase;letter-spacing:.025em}.points-container{max-height:500px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:6px}.point-row{display:grid;grid-template-columns:100px 1fr 1fr;gap:16px;padding:12px 16px;border-bottom:1px solid #e5e7eb;transition:background-color .15s ease}.point-row:last-child{border-bottom:none}.point-row:hover{background-color:#f9fafb}.score-column{font-size:16px;font-weight:600;color:#000;display:flex;align-items:center}.action-column{font-size:15px;display:flex;align-items:center;line-height:1.4}.home-action{color:#06c}.opponent-action{color:red}.action-column.hidden{visibility:hidden}.points-container::-webkit-scrollbar{width:8px}.points-container::-webkit-scrollbar-track{background-color:#f3f4f6;border-radius:4px}.points-container::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:4px}.points-container::-webkit-scrollbar-thumb:hover{background-color:#9ca3af}@media (min-width: 768px){.point-by-point-list{padding:28px}.list-title{font-size:22px}.list-column-headers{font-size:15px}.score-column{font-size:18px}.action-column{font-size:16px}.points-container{max-height:600px}}@media (max-width: 640px){.list-column-headers{grid-template-columns:80px 1fr 1fr;gap:8px;font-size:12px}.point-row{grid-template-columns:80px 1fr 1fr;gap:8px;padding:10px 12px}.score-column{font-size:14px}.action-column{font-size:13px}}.summary-card{background:#fff;border-radius:6px;padding:10px 12px;box-shadow:0 1px 2px #00000014;display:flex;flex-direction:column;gap:8px;min-width:110px}.summary-card-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;margin:0;text-align:center;line-height:1.2}.summary-card-values{display:flex;align-items:center;justify-content:center;gap:8px}.summary-value{display:flex;flex-direction:column;align-items:center;gap:2px}.value-number{font-size:22px;font-weight:700;line-height:1}.home-value .value-number{color:#3b82f6}.opponent-value .value-number{color:#f59e0b}.value-label{font-size:9px;font-weight:500;color:#9ca3af;text-transform:uppercase;letter-spacing:.3px}.summary-separator{font-size:12px;color:#d1d5db;font-weight:600;margin:0 2px}@media (min-width: 768px) and (max-width: 1024px){.summary-card{padding:12px 14px;min-width:130px}.summary-card-title{font-size:12px}.value-number{font-size:26px}.value-label{font-size:10px}}.momentum-indicator{background:#fff;border-radius:8px;padding:16px 20px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px}.momentum-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.momentum-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#374151;margin:0}.current-run{display:flex;align-items:center;gap:8px;padding:4px 12px;border-radius:16px;font-size:13px;font-weight:600}.home-run{background:#dbeafe;color:#1e40af}.opponent-run{background:#fed7aa;color:#c2410c}.run-team{font-weight:700}.run-count{font-weight:600}.last-points{display:flex;align-items:center;gap:12px}.last-points-label{font-size:12px;font-weight:500;color:#6b7280;white-space:nowrap}.points-strip{display:flex;gap:4px;flex-wrap:wrap}.point-indicator{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;font-size:13px;font-weight:700;cursor:help;transition:transform .2s}.point-indicator:hover{transform:scale(1.1)}.point-indicator.home{background:#3b82f6;color:#fff}.point-indicator.opponent{background:#f59e0b;color:#fff}@media (min-width: 768px) and (max-width: 1024px){.momentum-indicator{padding:18px 24px;margin-bottom:24px}.momentum-title{font-size:15px}.current-run{padding:6px 14px;font-size:14px}.last-points-label{font-size:13px}.point-indicator{width:36px;height:36px;font-size:14px}}.point-progression-chart{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a}.chart-title{font-size:14px;font-weight:600;color:#1f2937;margin:0 0 8px}.chart-legend{display:flex;gap:16px;margin-bottom:12px;font-size:11px}.legend-item{display:flex;align-items:center;gap:6px;color:#6b7280}.legend-color{width:12px;height:12px;border-radius:2px}.legend-color.home{background:#3b82f6}.legend-color.opponent{background:#ef4444}.chart-svg{display:block;overflow:visible}.zero-line{stroke:#d1d5db;stroke-width:.5;stroke-dasharray:2,2}.area-fill{fill:#3b82f6;opacity:.1}.line-stroke{fill:none;stroke:#3b82f6;stroke-width:.8;stroke-linejoin:round;stroke-linecap:round}.point-home{fill:#3b82f6}.point-opponent{fill:#ef4444}.point-tie{fill:#9ca3af}.axis-label{font-size:3px;fill:#9ca3af;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.chart-footer{margin-top:8px;text-align:center}.footer-label{font-size:10px;color:#9ca3af}.chart-empty{padding:40px;text-align:center;color:#9ca3af;font-size:12px}@media (max-width: 1024px){.point-progression-chart{padding:12px}.chart-title{font-size:13px}.chart-legend{font-size:10px;gap:12px}.legend-color{width:10px;height:10px}}.scoring-runs-chart{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a}.runs-bars-container{display:flex;flex-direction:column;gap:8px;margin-top:12px}.run-bar-row{display:flex;align-items:center;gap:8px}.run-label{min-width:80px;font-size:10px;color:#6b7280;text-align:right}.run-points{font-weight:500}.run-bar-track{flex:1;height:24px;background:#f3f4f6;border-radius:4px;position:relative;overflow:hidden}.run-bar{height:100%;display:flex;align-items:center;justify-content:flex-end;padding-right:8px;border-radius:4px;transition:width .3s ease;min-width:50px}.run-bar.home{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.run-bar.opponent{background:linear-gradient(90deg,#ef4444,#f87171)}.run-count{font-size:11px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}@media (max-width: 1024px){.scoring-runs-chart{padding:12px}.run-label{min-width:70px;font-size:9px}.run-bar-track{height:20px}.run-count{font-size:10px}}.action-breakdown-chart{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a}.breakdown-subtitle{font-size:11px;color:#9ca3af;margin-bottom:16px}.breakdowns-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.team-breakdown{display:flex;flex-direction:column}.team-name{font-size:13px;font-weight:600;margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid}.team-name.home{color:#3b82f6;border-color:#3b82f6}.team-name.opponent{color:#ef4444;border-color:#ef4444}.breakdown-bars{display:flex;flex-direction:column;gap:8px}.breakdown-bar-row{display:flex;flex-direction:column;gap:4px}.breakdown-label{display:flex;justify-content:space-between;align-items:center;font-size:11px}.action-name{font-weight:500;color:#374151}.action-count{color:#9ca3af;font-size:10px}.breakdown-bar-track{height:20px;background:#f3f4f6;border-radius:4px;overflow:hidden;position:relative}.breakdown-bar{height:100%;display:flex;align-items:center;justify-content:flex-end;padding-right:6px;border-radius:4px;transition:width .3s ease;min-width:30px}.breakdown-percentage{font-size:10px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.no-data{padding:20px;text-align:center;color:#9ca3af;font-size:11px;font-style:italic}@media (max-width: 1024px){.action-breakdown-chart{padding:12px}.breakdowns-grid{grid-template-columns:1fr;gap:16px}.team-name{font-size:12px}.breakdown-label{font-size:10px}.action-count{font-size:9px}.breakdown-bar-track{height:18px}.breakdown-percentage{font-size:9px}}.player-hit-ace-ratio-chart{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.player-hit-ace-ratio-chart .chart-title{font-size:18px;font-weight:600;margin:0 0 20px;color:#1f2937;text-align:center}.player-hit-ace-ratio-chart .teams-container{display:flex;gap:24px}.player-hit-ace-ratio-chart .team-section{flex:1;min-width:0}.player-hit-ace-ratio-chart .team-title{font-size:14px;font-weight:600;margin:0 0 12px;color:#4b5563}.player-hit-ace-ratio-chart .ratio-row{display:flex;align-items:center;margin-bottom:8px;gap:12px}.player-hit-ace-ratio-chart .row-label{min-width:60px;font-size:13px;font-weight:500;color:#6b7280;text-align:right}.player-hit-ace-ratio-chart .row-bar{flex:1;height:32px;position:relative}.player-hit-ace-ratio-chart .row-total{min-width:40px;font-size:13px;font-weight:600;color:#1f2937;text-align:left;padding-left:8px}.player-hit-ace-ratio-chart .stacked-bar{display:flex;width:100%;height:100%;background:#f3f4f6;border-radius:4px;overflow:hidden}.player-hit-ace-ratio-chart .bar-segment{display:flex;align-items:center;justify-content:center;height:100%;position:relative;transition:opacity .2s}.player-hit-ace-ratio-chart .bar-segment:hover{opacity:.8}.player-hit-ace-ratio-chart .bar-label{font-size:11px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);-webkit-user-select:none;user-select:none}.player-hit-ace-ratio-chart .empty-bar{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:4px;font-size:12px;color:#9ca3af;font-style:italic}.player-hit-ace-ratio-chart .chart-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.player-hit-ace-ratio-chart .legend-item{display:flex;align-items:center;gap:6px}.player-hit-ace-ratio-chart .legend-color{width:14px;height:14px;border-radius:2px}.player-hit-ace-ratio-chart .legend-label{font-size:12px;color:#6b7280}.player-hit-ace-ratio-chart .custom-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px;box-shadow:0 4px 6px #0000001a}.player-hit-ace-ratio-chart .custom-tooltip .tooltip-name{font-weight:600;font-size:13px;color:#1f2937;margin:0 0 8px;border-bottom:1px solid #e5e7eb;padding-bottom:6px}.player-hit-ace-ratio-chart .custom-tooltip .tooltip-stat{font-size:12px;color:#6b7280;margin:4px 0}.player-hit-ace-ratio-chart .empty-state{display:flex;align-items:center;justify-content:center;height:200px;font-size:14px;color:#9ca3af;font-style:italic}@media (max-width: 1024px){.player-hit-ace-ratio-chart .teams-container{flex-direction:column;gap:20px}}@media (max-width: 640px){.player-hit-ace-ratio-chart{padding:16px}.player-hit-ace-ratio-chart .teams-container{gap:16px}.player-hit-ace-ratio-chart .row-label{min-width:50px;font-size:12px}.player-hit-ace-ratio-chart .row-bar{height:28px}.player-hit-ace-ratio-chart .chart-legend{gap:8px}.player-hit-ace-ratio-chart .legend-label{font-size:11px}}.attack-kd-efficiency-chart{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.attack-kd-efficiency-chart .chart-title{font-size:18px;font-weight:600;margin:0 0 16px;color:#1f2937;text-align:center}.attack-kd-efficiency-chart .summary-stats{display:flex;justify-content:space-around;gap:20px;margin-bottom:16px;padding:12px;background:#f9fafb;border-radius:8px}.attack-kd-efficiency-chart .team-summary{display:flex;flex-direction:column;gap:4px}.attack-kd-efficiency-chart .team-name{font-size:13px;font-weight:600;color:#374151}.attack-kd-efficiency-chart .team-stat{font-size:12px;color:#6b7280}.attack-kd-efficiency-chart .tooltip-team{font-size:11px;color:#9ca3af;margin:0 0 4px;font-style:italic}.attack-kd-efficiency-chart .teams-container{display:grid;grid-template-columns:1fr 1fr;gap:24px}.attack-kd-efficiency-chart .team-section{min-height:300px}.attack-kd-efficiency-chart .team-title{font-size:14px;font-weight:600;margin:0 0 8px;color:#4b5563}.attack-kd-efficiency-chart .summary-label{font-size:12px;color:#6b7280;margin-bottom:16px;padding:8px;background:#f9fafb;border-radius:4px;text-align:center}.attack-kd-efficiency-chart .bars-container{display:flex;justify-content:space-around;align-items:flex-end;height:240px;padding:20px 0;background:linear-gradient(to top,#f3f4f6 0%,transparent 100%);border-radius:4px}.attack-kd-efficiency-chart .efficiency-bar-container{display:flex;flex-direction:column;align-items:center;flex:1;max-width:80px;position:relative}.attack-kd-efficiency-chart .efficiency-bar{width:50px;min-height:40px;max-height:200px;background:#3b82f6;border-radius:4px 4px 0 0;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all .3s ease;cursor:pointer}.attack-kd-efficiency-chart .efficiency-bar:hover{transform:translateY(-4px);box-shadow:0 4px 12px #3b82f666}.attack-kd-efficiency-chart .bar-stats{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px}.attack-kd-efficiency-chart .stat-label{font-size:10px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);white-space:nowrap}.attack-kd-efficiency-chart .stat-label.kills{color:#10b981}.attack-kd-efficiency-chart .stat-label.errors{color:#ef4444}.attack-kd-efficiency-chart .stat-label.attempts{color:#fff}.attack-kd-efficiency-chart .player-name{font-size:11px;font-weight:500;color:#374151;margin-top:8px;text-align:center;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attack-kd-efficiency-chart .efficiency-value{font-size:12px;font-weight:600;color:#059669;margin-top:4px}.attack-kd-efficiency-chart .empty-state{display:flex;align-items:center;justify-content:center;height:240px;font-size:14px;color:#9ca3af;font-style:italic}.custom-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px;box-shadow:0 4px 6px #0000001a}.custom-tooltip .tooltip-name{font-weight:600;font-size:13px;color:#1f2937;margin:0 0 8px;border-bottom:1px solid #e5e7eb;padding-bottom:6px}.custom-tooltip .tooltip-stat{font-size:12px;color:#6b7280;margin:4px 0}@media (max-width: 768px){.attack-kd-efficiency-chart .teams-container{grid-template-columns:1fr;gap:32px}.attack-kd-efficiency-chart .bars-container{height:200px}.attack-kd-efficiency-chart .efficiency-bar{width:40px}.attack-kd-efficiency-chart .efficiency-bar-container{max-width:60px}}@media (max-width: 640px){.attack-kd-efficiency-chart{padding:16px}.attack-kd-efficiency-chart .bars-container{height:180px;padding:16px 0}.attack-kd-efficiency-chart .stat-label{font-size:9px}.attack-kd-efficiency-chart .player-name{font-size:10px}}.kill-zones-by-player-chart{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.kill-zones-by-player-chart .chart-title{font-size:18px;font-weight:600;margin:0 0 16px;color:#1f2937;text-align:center}.kill-zones-by-player-chart .empty-state{display:flex;align-items:center;justify-content:center;height:300px;font-size:14px;color:#9ca3af;font-style:italic}.kill-zones-by-player-chart .custom-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px;box-shadow:0 4px 6px #0000001a}.kill-zones-by-player-chart .custom-tooltip .tooltip-location{font-weight:600;font-size:13px;color:#1f2937;margin:0 0 8px;border-bottom:1px solid #e5e7eb;padding-bottom:6px}.kill-zones-by-player-chart .custom-tooltip .tooltip-stat{font-size:12px;margin:4px 0;font-weight:500}@media (max-width: 768px){.kill-zones-by-player-chart{padding:16px}.kill-zones-by-player-chart .chart-title{font-size:16px}}.attack-attempts-by-position-chart{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:24px}.attack-attempts-by-position-chart .chart-title{margin:0 0 16px;font-size:1.25rem;font-weight:600;color:#1f2937}.attack-attempts-by-position-chart .empty-state{padding:40px;text-align:center;color:#6b7280;font-style:italic}.attack-attempts-by-position-chart .custom-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:4px;padding:12px;box-shadow:0 2px 8px #00000026}.attack-attempts-by-position-chart .tooltip-label{font-weight:600;margin:0 0 8px;color:#1f2937}.attack-attempts-by-position-chart .custom-tooltip p{margin:4px 0;font-size:.875rem}.stats-dashboard{padding:20px;max-width:1200px;margin:0 auto}.stats-toggle{display:flex;justify-content:flex-end;margin-bottom:16px}.toggle-btn{padding:10px 24px;font-size:14px;font-weight:600;color:#4b5563;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000000d}.toggle-btn:hover{border-color:#3b82f6;color:#3b82f6;box-shadow:0 2px 6px #3b82f626}.toggle-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.toggle-btn.active:hover{background:#2563eb;border-color:#2563eb}.stats-empty{background:#fff;border-radius:12px;padding:60px 24px;text-align:center;box-shadow:0 1px 3px #0000001a}.stats-empty p{font-size:18px;color:#374151;margin:0 0 8px}.stats-empty-hint{font-size:14px;color:#9ca3af}.summary-section{margin-bottom:24px}.section-title{font-size:18px;font-weight:700;color:#111827;margin:0 0 16px;padding-left:4px}.summary-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.charts-section{margin-top:32px}.advanced-stats-section{margin-top:32px;padding-top:24px;border-top:2px solid #e5e7eb;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.charts-grid{display:grid;grid-template-columns:1fr;gap:16px}.chart-full-width{grid-column:1 / -1}.chart-half-width{width:100%}.teams-container{display:flex;gap:24px;margin-bottom:24px}.teams-container>*{flex:1;min-width:0}@media (max-width: 1024px){.teams-container{flex-direction:column}}@media (min-width: 768px) and (max-width: 1024px){.stats-dashboard{padding:24px}.section-title{font-size:20px;margin-bottom:18px}.summary-cards-grid{grid-template-columns:repeat(3,1fr);gap:16px}.charts-grid{grid-template-columns:1fr 1fr}}@media (min-width: 1025px){.summary-cards-grid{grid-template-columns:repeat(6,1fr)}.charts-grid{grid-template-columns:1fr 1fr}}.stats-page{max-width:1200px;margin:0 auto;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f7;min-height:100vh}.stats-page-header{padding:12px 20px;background:#fff;border-bottom:1px solid #e5e7eb}.btn-back-arrow{background:none;border:none;color:#3b82f6;font-size:16px;font-weight:500;cursor:pointer;padding:8px 12px;transition:color .2s}.btn-back-arrow:hover{color:#2563eb}.stats-page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px}.stats-page-loading .spinner{width:48px;height:48px;border:4px solid #f3f4f6;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stats-page-loading p{font-size:16px;color:#6b7280}.stats-page-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px}.stats-page-error p{font-size:16px;color:#ef4444}.btn-back{background:#3b82f6;color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:14px;font-weight:600;cursor:pointer}.btn-back:hover{background:#2563eb}.stats-page-content{padding:15px}@media (min-width: 768px) and (max-width: 1024px){.stats-page{max-width:100%}.stats-page-content{padding:20px}}.game-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:16px;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:16px}.game-info h2{margin:0 0 4px;font-size:20px;color:#333}.game-info p{margin:0;color:#666;font-size:14px}@media (min-width: 768px) and (max-width: 1024px){.game-header{padding:20px}.game-info h2{font-size:24px}.game-info p{font-size:16px}}.score-display{display:flex;align-items:flex-end;gap:16px}.team-score{display:flex;flex-direction:column;align-items:center;gap:4px}.opponent-score{flex-direction:column-reverse}.team-name{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;line-height:1.2;white-space:nowrap}.home-score .team-name{color:#dc2626}.opponent-score .team-name{color:#2563eb}.score{font-size:36px;font-weight:700;color:#1f2937;line-height:1;min-width:40px;text-align:center}.score-separator{font-size:28px;color:#9ca3af;font-weight:600;align-self:center;padding-bottom:4px}@media (min-width: 768px) and (max-width: 1024px){.score-display{gap:20px}.team-name{font-size:14px;letter-spacing:1px}.score{font-size:42px;min-width:50px}.score-separator{font-size:32px;padding-bottom:6px}}@media (max-width: 767px){.score-display{gap:12px}.team-name{font-size:11px;letter-spacing:.5px}.score{font-size:28px;min-width:32px}.score-separator{font-size:22px;padding-bottom:2px}}.quick-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.stat-card{background:#fff;padding:12px;border-radius:6px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .2s}.stat-card:hover{transform:translateY(-1px)}.stat-label{font-size:11px;color:#666;font-weight:500;text-align:center;line-height:1.2}.stat-value{font-size:24px;font-weight:700;color:#333}@media (min-width: 768px) and (max-width: 1024px){.quick-stats{gap:12px;margin-bottom:20px}.stat-card{padding:16px}.stat-label{font-size:13px}.stat-value{font-size:28px}}.point-entry{background:#fff;padding:16px;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:16px}.point-entry h3{margin:0 0 16px;font-size:18px;color:#333}@media (min-width: 768px) and (max-width: 1024px){.point-entry{padding:20px;margin-bottom:20px}.point-entry h3{font-size:20px;margin-bottom:20px}}.team-selection{display:flex;gap:8px;margin-bottom:16px}.team-btn{flex:1;padding:12px 16px;border:2px solid #e5e7eb;border-radius:6px;background:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px}@media (min-width: 768px) and (max-width: 1024px){.team-selection{gap:12px;margin-bottom:20px}.team-btn{padding:16px 20px;font-size:16px;min-height:50px;border-radius:8px}}.home-btn.active{border-color:#dc2626;background:#dc2626;color:#fff}.opponent-btn.active{border-color:#2563eb;background:#2563eb;color:#fff}.team-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.action-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.action-btn{padding:10px 8px;border:2px solid #e5e7eb;border-radius:6px;background:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;min-height:44px;display:flex;align-items:center;justify-content:center;text-align:center}@media (min-width: 768px) and (max-width: 1024px){.action-buttons{gap:12px;margin-bottom:20px}.action-btn{padding:14px 12px;font-size:14px;min-height:50px;border-radius:8px}}.action-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.spike-btn:hover,.spike-btn.active{border-color:#059669;background:#059669;color:#fff}.error-btn:hover,.error-btn.active{border-color:#dc2626;background:#dc2626;color:#fff}.block-btn:hover,.block-btn.active{border-color:#7c3aed;background:#7c3aed;color:#fff}.serve-btn:hover,.serve-btn.active{border-color:#ea580c;background:#ea580c;color:#fff}.play-btn:hover,.play-btn.active{border-color:#0891b2;background:#0891b2;color:#fff}.other-btn:hover,.other-btn.active{border-color:#6b7280;background:#6b7280;color:#fff}.player-selection{margin-bottom:16px}.player-select{width:100%;padding:12px 14px;border:2px solid #e5e7eb;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;min-height:44px}.player-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}@media (min-width: 768px) and (max-width: 1024px){.player-selection{margin-bottom:20px}.player-select{padding:16px 18px;font-size:16px;min-height:50px;border-radius:8px}}.position-selector{margin-bottom:16px}.position-selector h4{margin:0 0 10px;font-size:14px;color:#333}.court-positions{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;max-width:100%}.pos-btn{padding:10px 6px;border:2px solid #e5e7eb;border-radius:6px;background:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px;display:flex;align-items:center;justify-content:center}@media (min-width: 768px) and (max-width: 1024px){.position-selector{margin-bottom:20px}.position-selector h4{font-size:16px;margin-bottom:14px}.court-positions{gap:10px}.pos-btn{padding:14px 10px;font-size:14px;min-height:50px;border-radius:8px}}.pos-btn:hover,.pos-btn.active{border-color:#2563eb;background:#2563eb;color:#fff}.add-point-btn{width:100%;padding:14px;background:#059669;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;min-height:50px;display:flex;align-items:center;justify-content:center}@media (min-width: 768px) and (max-width: 1024px){.add-point-btn{padding:18px;font-size:18px;min-height:56px;border-radius:8px}}.add-point-btn:hover{background:#047857;transform:translateY(-1px);box-shadow:0 4px 8px #0596694d}.add-point-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.recent-points{background:#fff;padding:16px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.recent-points h3{margin:0 0 16px;font-size:18px;color:#333}@media (min-width: 768px) and (max-width: 1024px){.recent-points{padding:20px}.recent-points h3{font-size:20px;margin-bottom:20px}}.points-list{display:flex;flex-direction:column;gap:6px}.point-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:6px;font-size:13px;min-height:40px}@media (min-width: 768px) and (max-width: 1024px){.points-list{gap:8px}.point-item{padding:12px 16px;font-size:14px;min-height:44px;gap:16px;border-radius:8px}}.home-point{background:#fef2f2;border-left:4px solid #dc2626}.opponent-point{background:#eff6ff;border-left:4px solid #2563eb}.point-number{font-weight:600;min-width:30px}.point-action{font-weight:500;min-width:60px}.point-player{flex:1;color:#666}.point-position{font-family:monospace;font-size:12px;background:#f3f4f6;padding:2px 6px;border-radius:4px}.undo-btn{background:none;border:none;font-size:16px;cursor:pointer;padding:4px;border-radius:4px;color:#666;transition:all .2s}.undo-btn:hover{background:#f3f4f6;color:#333}@media (max-width: 768px){.stats-page{padding:15px}.game-header{flex-direction:column;gap:15px;text-align:center}.score-display{order:-1}.quick-stats,.action-buttons{grid-template-columns:repeat(2,1fr)}.court-positions{max-width:none;grid-template-columns:repeat(6,1fr)}.point-item{flex-wrap:wrap;gap:8px}.point-player{flex-basis:100%;order:1}}@media (max-width: 480px){.action-buttons{grid-template-columns:1fr}.team-selection{flex-direction:column}}.tabs-container{display:flex;justify-content:space-between;align-items:center;gap:24px;margin-bottom:0;padding:6px 15px;background:#fff;border:1px solid #e5e7eb;box-sizing:border-box}@media (min-width: 768px) and (max-width: 1024px){.tabs-container{padding:6px 20px;gap:32px;box-sizing:border-box}}.set-tabs{display:flex;gap:8px;overflow-x:auto;flex:1;align-items:center}.set-tab{position:relative;padding:10px 16px;background-color:transparent;border:none;font-size:15px;font-weight:500;color:#6b7280;cursor:pointer;transition:color .2s ease;white-space:nowrap;height:40px;display:flex;align-items:center;box-sizing:border-box;outline:none}.set-tab:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background-color:transparent;transition:background-color .2s ease}.set-tab:hover{color:#1f2937}.set-tab:focus{outline:none;border:none}.set-tab.active{color:#1f2937;font-weight:600}.set-tab.active:after{background-color:#3b82f6}@media (min-width: 768px) and (max-width: 1024px){.set-tabs{gap:12px}.set-tab{padding:12px 20px;font-size:16px;height:44px;box-sizing:border-box}.set-tab:after{bottom:0;height:3px}}.view-toggle{display:flex;gap:0;background:#f3f4f6;border-radius:6px;padding:3px;flex-shrink:0;height:32px;box-sizing:border-box}.view-toggle-btn{padding:0 16px;font-size:13px;font-weight:500;background-color:transparent;border:none;border-radius:4px;color:#6b7280;cursor:pointer;transition:all .15s ease;white-space:nowrap;display:flex;align-items:center;justify-content:center;height:26px;box-sizing:border-box}.view-toggle-btn:hover{color:#1f2937}.view-toggle-btn.active{background-color:#fff;color:#1f2937;font-weight:600;box-shadow:0 1px 2px #00000014}@media (min-width: 768px) and (max-width: 1024px){.view-toggle{height:36px;padding:4px;box-sizing:border-box}.view-toggle-btn{padding:0 20px;font-size:14px;height:28px;box-sizing:border-box}}.coming-soon{background-color:#fff;padding:60px 24px;border-radius:12px;box-shadow:0 1px 3px #0000001a;text-align:center}.coming-soon h3{font-size:24px;font-weight:600;color:#1f2937;margin:0 0 12px}.coming-soon p{font-size:16px;color:#6b7280;margin:0}.volleyball-court{display:block;width:auto;height:100%;max-width:100%;aspect-ratio:420 / 800;border-radius:12px;user-select:none;-webkit-user-select:none;-moz-user-select:none;touch-action:none;cursor:default;pointer-events:auto}.volleyball-court.drawing-mode{cursor:crosshair}.volleyball-court line,.volleyball-court rect,.volleyball-court circle,.volleyball-court text{transition:opacity .2s ease}.volleyball-court.drawing-mode text{opacity:.3}.volleyball-court text{user-select:none;-webkit-user-select:none;pointer-events:none}.visual-tracking-page{width:100vw;height:100vh;overflow:hidden;display:flex;flex-direction:column;background:#f5f5f5}.visual-tracking-header{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:#fff;border-bottom:2px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;height:60px;flex-shrink:0}.visual-tracking-header .btn-back-arrow{padding:8px 16px;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.visual-tracking-header .btn-back-arrow:hover{background:#e0e0e0;border-color:#ccc}.header-info{flex:1;text-align:center}.header-info h1{margin:0;font-size:20px;font-weight:700;color:#333}.match-info{margin:4px 0 0;font-size:13px;color:#666}.header-actions{display:flex;gap:12px}.btn-icon{width:40px;height:40px;border:1px solid #ddd;border-radius:6px;background:#fff;font-size:18px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:#f5f5f5;border-color:#ccc}.visual-tracking-content{display:grid;grid-template-columns:40% 60%;gap:20px;padding:20px;height:calc(100vh - 60px);overflow:hidden}.court-section{background:#1f2937;border:2px solid #e0e0e0;border-radius:12px;padding:0;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000014;overflow:hidden;pointer-events:none}.panel-section{display:flex;flex-direction:column;gap:20px;overflow:hidden}.stats-panel{flex:1;background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;overflow-y:auto}.controls-panel{flex-shrink:0;background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;min-height:280px;max-height:320px}.court-placeholder,.panel-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#666;text-align:center;padding:20px}.placeholder-content h2,.panel-placeholder h3{margin:0 0 16px;color:#333;font-size:18px}.placeholder-content p{margin:0 0 20px;font-size:14px;color:#666}.placeholder-specs{margin:0;padding:0;list-style:none;text-align:left;font-size:13px;line-height:1.8}.placeholder-specs li{padding:4px 0;color:#555}.placeholder-specs li:before{content:"• ";color:#2196f3;font-weight:700;margin-right:8px}.orientation-warning{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#1976d2;color:#fff;z-index:9999;align-items:center;justify-content:center}.warning-content{text-align:center;padding:40px}.warning-content h2{margin:0 0 16px;font-size:28px;font-weight:700}.warning-content p{margin:0 0 32px;font-size:18px;opacity:.9}.rotate-icon{font-size:64px;animation:rotate-pulse 2s ease-in-out infinite}@keyframes rotate-pulse{0%,to{transform:rotate(0) scale(1)}50%{transform:rotate(90deg) scale(1.1)}}@media (orientation: portrait){.orientation-warning{display:flex}.visual-tracking-content{display:none}}@media (max-width: 1024px) and (orientation: landscape){.visual-tracking-content{grid-template-columns:40% 60%;gap:16px;padding:16px}.stats-panel,.controls-panel{padding:16px}.visual-tracking-header{padding:10px 16px;height:50px}.header-info h1{font-size:18px}.match-info{font-size:12px}}@media (max-width: 768px) and (orientation: landscape){.visual-tracking-content{grid-template-columns:40% 60%;gap:12px;padding:12px}.header-info h1{font-size:16px}.controls-panel{min-height:240px;max-height:280px}}@media print{.visual-tracking-header,.panel-section{display:none}.visual-tracking-content{grid-template-columns:1fr;padding:0}.court-section{border:none;box-shadow:none;height:100vh}}.app{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;flex-direction:column}.app-main{flex:1;background:#f8f9fa;min-height:calc(100vh - 120px)}@media (max-width: 768px){.app-main{min-height:calc(100vh - 100px)}}@media (min-width: 769px){.app-main{min-height:calc(100vh - 140px)}}
