*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Segoe UI,system-ui,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit}#root{min-height:100vh}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #2d6a4f;--green-light: #40916c;--green-dark: #1b4332;--yellow: #f4d03f;--red: #c0392b;--bg: #0f1923;--surface: #1a2535;--surface2: #243041;--border: #2e3e52;--text: #e8f0fe;--text-muted: #8fa3b1;--radius: 8px;font-size:15px}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif;min-height:100vh}.setup-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:radial-gradient(ellipse at center,#1a2535,#0f1923 70%)}.setup-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:2rem 2.5rem;width:100%;max-width:480px;box-shadow:0 8px 40px #0006}.setup-title{text-align:center;font-size:1.6rem;color:var(--yellow);margin-bottom:1.5rem;letter-spacing:.02em}.setup-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.3rem}.form-group label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}input[type=text],input[type=number],select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:.5rem .75rem;font-size:.95rem;width:100%;outline:none;transition:border-color .2s}input:focus,select:focus{border-color:var(--green-light)}.radio-group{display:flex;gap:1.5rem}.radio-label{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.95rem;color:var(--text)}.btn-start{margin-top:.5rem;padding:.75rem;background:var(--green);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;letter-spacing:.03em}.btn-start:hover{background:var(--green-light)}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.2rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.app-title{font-size:1.1rem;color:var(--yellow);font-weight:700;letter-spacing:.02em}.header-actions{display:flex;gap:.5rem}.btn-secondary{padding:.4rem .85rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);cursor:pointer;font-size:.85rem;transition:border-color .2s,background .2s}.btn-secondary:hover{border-color:var(--green-light);background:var(--green-dark)}.app-main{display:grid;grid-template-columns:420px 1fr;gap:0;flex:1;overflow:hidden}.left-panel{display:flex;flex-direction:column;gap:0;border-right:1px solid var(--border);overflow-y:auto}.right-panel{overflow-y:auto}.video-player{background:#000;position:relative}.drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;min-height:200px;border:2px dashed var(--border);border-radius:var(--radius);margin:.75rem;padding:1.5rem;color:var(--text-muted);transition:border-color .2s,background .2s}.drop-zone.dragging{border-color:var(--green-light);background:#40916c1a}.drop-zone p{font-size:.95rem}.file-label{cursor:pointer}.video-element{width:100%;max-height:240px;display:block;background:#000}.video-controls{background:var(--surface);padding:.5rem .75rem;border-top:1px solid var(--border)}.video-controls-row{display:flex;align-items:center;gap:.4rem;margin-bottom:.4rem}.btn-control{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:.25rem .5rem;cursor:pointer;font-size:.85rem;min-width:32px}.btn-control:hover{border-color:var(--green-light)}.btn-speed{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text-muted);padding:.2rem .4rem;cursor:pointer;font-size:.75rem}.btn-speed:hover{color:var(--text);border-color:var(--green-light)}.speed-buttons{display:flex;gap:.25rem;margin-left:auto}.time-display{font-family:monospace;font-size:.85rem;color:var(--text-muted);min-width:80px}.seek-bar{width:100%;accent-color:var(--green-light)}.video-file-name{font-size:.75rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:.2rem}.scoreboard{background:var(--surface);border-top:1px solid var(--border);padding:.75rem 1rem}.match-winner-banner{text-align:center;color:var(--yellow);font-weight:700;font-size:1rem;padding:.4rem;margin-bottom:.5rem;background:#f4d03f1a;border-radius:var(--radius)}.scoreboard-table{width:100%;border-collapse:collapse;font-size:1rem}.scoreboard-table th{color:var(--text-muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;padding:.25rem .5rem;border-bottom:1px solid var(--border);text-align:center}.scoreboard-table th.sb-name{text-align:left}.scoreboard-table td{padding:.5rem;text-align:center}.sb-name{text-align:left!important;font-weight:600;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.sb-val{font-size:1.3rem;font-weight:700;font-family:monospace}.sb-sets{color:#a8d8a8}.sb-games{color:#87ceeb}.sb-points{color:var(--yellow)}.serving-row td{background:#40916c14}.server-dot{color:var(--yellow);margin-right:.35rem;font-size:.6rem;vertical-align:middle}.scoring-panel{padding:.75rem;background:var(--surface);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}.scoring-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.btn-point{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.9rem .5rem;border:none;border-radius:var(--radius);cursor:pointer;transition:opacity .15s,transform .1s;gap:.1rem}.btn-point:active:not(:disabled){transform:scale(.97)}.btn-point:disabled{opacity:.4;cursor:not-allowed}.btn-point-a{background:linear-gradient(135deg,#1565c0,#1e88e5);color:#fff}.btn-point-b{background:linear-gradient(135deg,#c62828,#e53935);color:#fff}.btn-point-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;opacity:.8}.btn-point-player{font-size:1rem;font-weight:700;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-point-key{font-size:.65rem;opacity:.6;font-family:monospace}.btn-undo{padding:.45rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-size:.85rem;text-align:center;transition:border-color .2s}.btn-undo:hover{border-color:var(--green-light);color:var(--text)}.event-list{padding:1rem;height:100%;display:flex;flex-direction:column}.event-list h3{font-size:.95rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem}.event-count{font-weight:400;font-size:.8rem}.empty-msg{color:var(--text-muted);font-size:.9rem;text-align:center;margin-top:2rem}.event-table-wrapper{overflow-y:auto;flex:1}.event-table{width:100%;border-collapse:collapse;font-size:.875rem}.event-table th{color:var(--text-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;padding:.4rem .5rem;border-bottom:1px solid var(--border);text-align:left;position:sticky;top:0;background:var(--bg)}.event-table td{padding:.35rem .5rem;border-bottom:1px solid rgba(46,62,82,.5)}.event-table tr:hover td{background:#ffffff05}.col-idx{color:var(--text-muted);font-size:.75rem;width:30px}.col-time{font-family:monospace;width:80px}.col-winner{font-weight:600}.winner-A{color:#90caf9}.winner-B{color:#ef9a9a}.col-score{color:var(--text-muted);font-size:.82rem}.col-action{width:30px}.ts-value{cursor:pointer;text-decoration:underline dotted;text-underline-offset:2px;color:var(--text-muted)}.ts-value:hover{color:var(--text)}.ts-input{width:75px;padding:.15rem .3rem;background:var(--surface2);border:1px solid var(--green-light);border-radius:4px;color:var(--text);font-family:monospace;font-size:.85rem}.btn-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.75rem;padding:.15rem .3rem;border-radius:4px;transition:color .2s,background .2s}.btn-delete:hover{color:var(--red);background:#c0392b1a}.saved-matches{margin-top:1.5rem;border-top:1px solid var(--border);padding-top:1rem}.saved-matches-title{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.6rem}.saved-matches-list{list-style:none;display:flex;flex-direction:column;gap:.4rem;max-height:220px;overflow-y:auto}.saved-match-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:.45rem .75rem}.saved-match-info{display:flex;flex-direction:column;gap:.1rem;overflow:hidden}.saved-match-players{font-size:.9rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saved-match-meta{font-size:.73rem;color:var(--text-muted)}.saved-match-actions{display:flex;gap:.35rem;flex-shrink:0}.btn-load-match{padding:.28rem .6rem;background:var(--green);border:none;border-radius:var(--radius);color:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-load-match:hover{background:var(--green-light)}.btn-delete-match{padding:.28rem .5rem;background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:color .2s,border-color .2s}.btn-delete-match:hover{color:var(--red);border-color:var(--red)}@media(max-width:768px){.app-main{grid-template-columns:1fr}.left-panel{border-right:none;border-bottom:1px solid var(--border)}}
