body{font-family:Microsoft JhengHei,Segoe UI,Arial,sans-serif;margin:0;padding:0;background-color:#f5f5f5;transition:background-color .3s ease,color .3s ease}body.dark-mode{background-color:#1a1a1a;color:#e8e8e8}body.dark-mode h1,body.dark-mode h2,body.dark-mode h3,body.dark-mode h4,body.dark-mode h5,body.dark-mode h6{color:#f0f0f0}body.dark-mode .card{background-color:#2d2d2d;color:#e8e8e8;border:1px solid #444}body.dark-mode .card-header{background-color:#1e3a5f;color:#fff}body.dark-mode .form-control,body.dark-mode .form-select,body.dark-mode .input-group-text{background-color:#3d3d3d;color:#f0f0f0;border-color:#555}body.dark-mode .form-control::placeholder{color:#999}body.dark-mode .form-label,body.dark-mode .form-label-sm,body.dark-mode label{color:#e0e0e0}body.dark-mode .table{color:#e8e8e8;border-color:#444}body.dark-mode .table th{background-color:#333;color:#f0f0f0;border-color:#444}body.dark-mode .table td{border-color:#444;color:#e8e8e8}body.dark-mode .table-striped>tbody>tr:nth-of-type(odd)>*{background-color:hsla(0,0%,100%,.05)}body.dark-mode .btn{color:#e8e8e8;border-color:#555}body.dark-mode .btn-primary{background-color:#2563eb;border-color:#2563eb;color:#fff}body.dark-mode .btn-secondary{background-color:#4b5563;border-color:#4b5563;color:#f0f0f0}body.dark-mode .btn-success{background-color:#059669;border-color:#059669;color:#fff}body.dark-mode .btn-danger{background-color:#dc2626;border-color:#dc2626;color:#fff}body.dark-mode .btn-warning{background-color:#d97706;border-color:#d97706;color:#fff}body.dark-mode .btn-info{background-color:#0891b2;border-color:#0891b2;color:#fff}body.dark-mode .btn-outline-primary{color:#60a5fa;border-color:#60a5fa}body.dark-mode .btn-outline-secondary{color:#9ca3af;border-color:#6b7280}body.dark-mode .nav-tabs{border-bottom-color:#444}body.dark-mode .nav-tabs .nav-link{color:#9ca3af}body.dark-mode .nav-tabs .nav-link.active{color:#60a5fa;border-bottom-color:#60a5fa;background-color:transparent}body.dark-mode .nav-tabs .nav-link:hover{color:#93c5fd}body.dark-mode .small,body.dark-mode .text-muted,body.dark-mode small{color:#9ca3af!important}body.dark-mode p{color:#e0e0e0}body.dark-mode .score-label,body.dark-mode .score-separator{color:#f0f0f0}body.dark-mode .score-btn{color:#f0f0f0!important;border-color:#f0f0f0!important}body.dark-mode #currentTimeDisplay{color:#f0f0f0}body.dark-mode #startTimeLabel{color:#4ade80}body.dark-mode .selection-status{background-color:#1e3a5f}body.dark-mode .status-text{color:#93c5fd}body.dark-mode .toast{background-color:#2d2d2d;color:#e8e8e8}body.dark-mode .toast-header{background-color:#1e3a5f;color:#fff}body.dark-mode .alert{color:#f0f0f0;border-color:#555}body.dark-mode .alert-success{background-color:#065f46;border-color:#059669}body.dark-mode .alert-danger{background-color:#7f1d1d;border-color:#dc2626}body.dark-mode .alert-warning{background-color:#78350f;border-color:#d97706}body.dark-mode .alert-info{background-color:#164e63;border-color:#0891b2}body.dark-mode .modal-content{background-color:#2d2d2d;color:#e8e8e8}body.dark-mode .modal-header{border-bottom-color:#444;color:#f0f0f0}body.dark-mode .modal-footer{border-top-color:#444}body.dark-mode .modal-title{color:#f0f0f0}body.dark-mode .list-group-item{background-color:#2d2d2d;color:#e8e8e8;border-color:#444}body.dark-mode #techniqueList .list-group-item{background-color:#333;color:#e8e8e8}body.dark-mode::-webkit-scrollbar-track{background:#2d2d2d}body.dark-mode::-webkit-scrollbar-thumb{background:#4b5563}body.dark-mode::-webkit-scrollbar-thumb:hover{background:#6b7280}body.dark-mode .dropdown-menu{background-color:#2d2d2d;border-color:#444}body.dark-mode .dropdown-item{color:#e8e8e8}body.dark-mode .dropdown-item:hover{background-color:#3d3d3d;color:#f0f0f0}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.7);display:none;justify-content:center;align-items:center;z-index:9999}.loading-overlay.show{display:flex}.loading-spinner{text-align:center;color:#fff}.spinner{border:4px solid hsla(0,0%,100%,.3);border-top-color:#3498db;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 15px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.shortcuts-panel{position:fixed;bottom:20px;right:20px;background:#fff;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);padding:15px;max-width:300px;display:none;z-index:1000}.shortcuts-panel.show{display:block;animation:slideIn .3s ease-out}body.dark-mode .shortcuts-panel{background:#2d2d2d;color:#e0e0e0}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.shortcut-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #eee}body.dark-mode .shortcut-item{border-bottom-color:#444}.shortcut-item:last-child{border-bottom:none}.shortcut-key{background:#f0f0f0;padding:4px 8px;border-radius:4px;font-family:monospace;font-weight:700;font-size:.85rem}body.dark-mode .shortcut-key{background:#3d3d3d;color:#fff}.theme-toggle{position:fixed;top:20px;right:20px;background:#fff;border:none;border-radius:50%;width:50px;height:50px;box-shadow:0 2px 8px rgba(0,0,0,.15);cursor:pointer;font-size:1.5rem;z-index:1000;transition:transform .2s ease,box-shadow .2s ease}.theme-toggle:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(0,0,0,.2)}body.dark-mode .theme-toggle{background:#2d2d2d;color:gold}.shortcuts-help-btn{position:fixed;bottom:80px;right:20px;background:#3498db;color:#fff;border:none;border-radius:50%;width:50px;height:50px;box-shadow:0 2px 8px rgba(0,0,0,.15);cursor:pointer;font-size:1.3rem;z-index:1000;transition:transform .2s ease}.shortcuts-help-btn:hover{transform:scale(1.1)}.container-fluid{padding:10px 15px;max-width:1600px;margin:0 auto}h1{color:#2c3e50;font-weight:600;font-size:1.6rem;margin-bottom:.5rem;margin-top:.5rem}.card{border:none;box-shadow:0 2px 4px rgba(0,0,0,.1);border-radius:8px;margin-bottom:.75rem}.card-header{background-color:#3498db;color:#fff;font-weight:600;border-radius:8px 8px 0 0!important;padding:.4rem .8rem;font-size:.9rem}.card-body{padding:.75rem}.form-label-sm{font-size:.8rem;font-weight:500;margin-bottom:.2rem;color:#555}.form-label{font-size:.85rem;font-weight:500;margin-bottom:.25rem}#record .form-label-sm{font-size:.75rem;margin-bottom:.15rem}#record .btn-group .btn{padding:.35rem .5rem;font-size:.8rem}#record .card-header{display:flex;justify-content:space-between;align-items:center}.score-display{display:flex;align-items:center;gap:3px;font-size:.8rem;white-space:nowrap}.score-label{color:#000;font-weight:500;margin-right:2px}.score-team-a{color:#0d6efd}.score-team-a,.score-team-b{font-weight:700;font-size:1rem;min-width:20px;text-align:center}.score-team-b{color:#dc3545}.score-separator{color:#000;font-weight:700;font-size:.9rem;margin:0 2px}.score-btn{padding:.1rem .3rem!important;font-size:.7rem!important;line-height:1!important;background:transparent!important;min-width:20px!important}.score-btn,.score-btn:hover{border-color:#000!important;color:#000!important}.score-btn:hover{background:rgba(0,0,0,.1)!important}.btn{border-radius:6px;font-weight:500}.btn-sm{padding:.35rem .75rem;font-size:.85rem}.btn-jump{padding:.2rem .5rem;font-size:.8rem}.nav-tabs{border-bottom:2px solid #dee2e6}.nav-tabs .nav-link{border:none;color:#6c757d;font-weight:500;padding:.75rem 1.5rem}.nav-tabs .nav-link.active{color:#3498db;border-bottom:3px solid #3498db;background-color:transparent}.nav-tabs .nav-link:hover{border-color:transparent;color:#3498db}#player-container{margin-top:.5rem}#player{width:100%;height:480px;border-radius:8px;overflow:hidden;background-color:#000;margin-bottom:0;resize:both;min-height:240px;max-height:960px;min-width:100%}.input-group-text{background-color:#e9ecef;border:1px solid #ced4da;font-size:.9rem}.input-group-sm .input-group-text{font-size:.85rem;padding:.35rem .75rem}.table{font-size:.9rem}.table th{background-color:#f8f9fa;font-weight:600;color:#495057;border-bottom:2px solid #dee2e6;padding:.75rem .5rem}.table td{vertical-align:middle;padding:.6rem .5rem}.toast{min-width:300px}.toast-header{background-color:#3498db;color:#fff;font-weight:600}@media (max-width:768px){.col-md-6{margin-bottom:1rem}#player{height:250px}h1{font-size:1.5rem}.btn-group{flex-wrap:wrap}}@media (max-width:575.98px){.container-fluid{padding:6px 8px}#player{height:200px;min-height:160px}.court-grid{max-width:220px;grid-template-rows:repeat(3,30px) 24px repeat(3,30px);gap:2px}.court-grid:after,.court-grid:before{height:calc(3 * 30px + 2 * 2px + 4px)}.court-grid.court-grid-9{max-width:300px;grid-template-rows:repeat(3,30px) 24px repeat(3,30px)}.court-grid.court-grid-9:after,.court-grid.court-grid-9:before{height:calc(3 * 30px + 2 * 2px + 4px)}.court-grid.court-grid-24{max-width:100%;grid-template-rows:repeat(4,26px) 22px repeat(4,26px);gap:1px}.court-grid.court-grid-24:after,.court-grid.court-grid-24:before{height:calc(4 * 26px + 3 * 1px + 4px)}.court-grid.court-grid-24 .court-cell{font-size:.7rem;border-width:1px}.court-cell{font-size:.9rem;border-width:1.5px}.btn{min-height:36px}.btn-sm{padding:.3rem .5rem;font-size:.8rem}.card-body{padding:.5rem}.card-header{padding:.3rem .6rem;font-size:.8rem}.table{font-size:.75rem}.table th{padding:.4rem .3rem;font-size:.7rem}.table td{padding:.3rem .25rem}.nav-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.nav-tabs .nav-link{padding:.5rem .75rem;white-space:nowrap;font-size:.85rem}.filter-toolbar .col-md-1,.filter-toolbar .col-md-2,.filter-toolbar .col-md-3{flex:0 0 50%;max-width:50%}h1{font-size:1.2rem}.score-display{font-size:.7rem}.score-team-a,.score-team-b{font-size:.85rem}}@media (min-width:576px) and (max-width:767.98px){#player{height:280px}.btn{min-height:38px}.court-grid{max-width:250px;grid-template-rows:repeat(3,34px) 28px repeat(3,34px)}.court-grid:after,.court-grid:before{height:calc(3 * 34px + 2 * 3px + 6px)}.court-grid.court-grid-9{max-width:360px;grid-template-rows:repeat(3,34px) 28px repeat(3,34px)}.court-grid.court-grid-9:after,.court-grid.court-grid-9:before{height:calc(3 * 34px + 2 * 3px + 6px)}.court-grid.court-grid-24{max-width:520px;grid-template-rows:repeat(4,28px) 26px repeat(4,28px)}.court-grid.court-grid-24:after,.court-grid.court-grid-24:before{height:calc(4 * 28px + 3 * 2px + 4px)}.table{font-size:.8rem}.filter-toolbar .col-md-1,.filter-toolbar .col-md-2,.filter-toolbar .col-md-3{flex:0 0 50%;max-width:50%}}.g-2{--bs-gutter-x:0.5rem;--bs-gutter-y:0.5rem}small{font-size:.8rem;line-height:1.4}#recordDataBtn{font-size:.9rem;font-weight:600;padding:.5rem;letter-spacing:.3px;margin-top:.4rem!important}#currentTimeDisplay{font-weight:600;color:#2c3e50;font-size:.9rem}#startTimeLabel{font-size:.85rem;color:#27ae60;font-weight:500}.row{align-items:stretch}#record .card{margin-bottom:.4rem}#record .card-body{padding:.5rem}#record .card-header{padding:.3rem .6rem;font-size:.85rem}#record .row.g-2{--bs-gutter-x:0.3rem;--bs-gutter-y:0.3rem}body::-webkit-scrollbar{width:10px}body::-webkit-scrollbar-track{background:#f1f1f1}body::-webkit-scrollbar-thumb{background:#3498db;border-radius:5px}body::-webkit-scrollbar-thumb:hover{background:#2980b9}.selection-status{text-align:center;margin-bottom:6px;padding:4px 6px;background-color:#e3f2fd;border-radius:4px}.status-text{font-weight:600;color:#1976d2;font-size:.8rem}.selection-status .btn-sm{padding:.2rem .5rem;font-size:.75rem}.court-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,38px) 30px repeat(3,38px);grid-gap:3px;gap:3px;margin-bottom:8px;max-width:280px;margin-left:auto;margin-right:auto;position:relative}.court-grid:before{top:-3px;border:3px solid #dc3545;border-radius:8px}.court-grid:after,.court-grid:before{content:"";position:absolute;left:-3px;right:-3px;height:calc(3 * 38px + 2 * 3px + 6px);pointer-events:none;z-index:1}.court-grid:after{bottom:-3px;border:3px solid #0d6efd;border-radius:8px}.court-grid.court-swapped:before{border-color:#0d6efd}.court-grid.court-swapped:after{border-color:#dc3545}.court-grid.court-grid-9{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,38px) 30px repeat(3,38px);max-width:420px}.court-grid.court-grid-9:after,.court-grid.court-grid-9:before{height:calc(3 * 38px + 2 * 3px + 6px)}.court-grid.court-grid-24{grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(4,32px) 30px repeat(4,32px);max-width:640px;gap:2px}.court-grid.court-grid-24 .court-cell{font-size:.9rem;border-width:1.5px}.court-grid.court-grid-24:after,.court-grid.court-grid-24:before{height:calc(4 * 32px + 3 * 2px + 6px)}.court-cell{background-color:#c8e6c9;border:2px solid #66bb6a;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;color:#2e7d32;cursor:pointer;transition:all .3s ease;position:relative}.court-cell:hover{background-color:#a5d6a7;transform:scale(1.05);box-shadow:0 3px 8px rgba(76,175,80,.4)}.court-cell.disabled{background-color:#e0e0e0;border-color:#bdbdbd;color:#9e9e9e;cursor:not-allowed;opacity:.5}.court-cell.disabled:hover{background-color:#e0e0e0;transform:none;box-shadow:none}.court-cell.hit-position{background-color:#2196f3;color:#fff;border-color:#1976d2;box-shadow:0 4px 10px rgba(33,150,243,.5);transform:scale(1.08)}.court-cell.hit-position:after{content:"擊";position:absolute;top:2px;right:4px;font-size:.7rem;background-color:#0d47a1;color:#fff;padding:2px 4px;border-radius:3px}.court-cell.drop-position{background-color:#ff9800;color:#fff;border-color:#f57c00;box-shadow:0 4px 10px rgba(255,152,0,.5);transform:scale(1.08)}.court-cell.drop-position:after{content:"落";position:absolute;top:2px;right:4px;font-size:.7rem;background-color:#e65100;color:#fff;padding:2px 4px;border-radius:3px}.court-cell.both-position{background:linear-gradient(135deg,#2196f3,#2196f3 50%,#ff9800 0,#ff9800);color:#fff;border-color:#9c27b0;box-shadow:0 4px 12px rgba(156,39,176,.6);transform:scale(1.1)}.court-cell.both-position:after{content:"擊/落";position:absolute;top:2px;right:2px;font-size:.65rem;background-color:#9c27b0;color:#fff;padding:2px 3px;border-radius:3px}.court-net{grid-column:1/-1;background:linear-gradient(90deg,#757575,#9e9e9e 50%,#757575);border:3px solid #424242;border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.95rem;letter-spacing:2px}.court-grid-settings{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,50px) 40px repeat(3,50px);grid-gap:5px;gap:5px;max-width:320px;margin-left:auto;margin-right:auto}.court-grid-settings.grid-9{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,50px) 40px repeat(3,50px)}.court-grid-settings.grid-24{grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(4,40px) 40px repeat(4,40px);max-width:720px;gap:3px}.court-grid-settings.grid-24 .court-cell-settings{font-size:1.1rem}.court-cell-settings{background-color:#e3f2fd;border:3px solid #2196f3;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.4rem;color:#1976d2;cursor:pointer;transition:all .3s ease}.court-cell-settings:hover{background-color:#bbdefb;transform:scale(1.05)}.court-cell-settings.editing{background-color:#fff9c4;border-color:#fbc02d;color:#f57f17;animation:pulse 1s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}#techniqueList .list-group-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem}#techniqueList .list-group-item .btn{padding:.25rem .5rem;font-size:.75rem}.progress-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.7);display:none;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .3s ease}.progress-overlay.show{display:flex}.progress-container{background:#fff;border-radius:12px;padding:30px;min-width:400px;max-width:600px;box-shadow:0 8px 32px rgba(0,0,0,.3);animation:slideUp .3s ease}body.dark-mode .progress-container{background:#2d2d2d;color:#e8e8e8}.progress-title{margin:0 0 10px;font-size:1.3rem;font-weight:600;color:#2c3e50;text-align:center}body.dark-mode .progress-title{color:#f0f0f0}.progress-message{margin-bottom:20px;text-align:center;color:#555;font-size:.95rem}body.dark-mode .progress-message{color:#b0b0b0}.progress-bar-wrapper{position:relative;width:100%;height:30px;background-color:#e0e0e0;border-radius:15px;overflow:hidden;margin-bottom:15px;box-shadow:inset 0 2px 4px rgba(0,0,0,.1)}body.dark-mode .progress-bar-wrapper{background-color:#444}.progress-bar-fill{height:100%;width:0;background:linear-gradient(90deg,#3498db,#2ecc71);border-radius:15px;transition:width .3s ease,background .3s ease;box-shadow:0 2px 4px rgba(0,0,0,.2);position:relative;overflow:hidden}.progress-bar-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.progress-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-weight:700;font-size:.9rem;color:#2c3e50;text-shadow:0 1px 2px hsla(0,0%,100%,.8);z-index:1}body.dark-mode .progress-percentage{color:#f0f0f0;text-shadow:0 1px 2px rgba(0,0,0,.8)}.progress-details{text-align:center;font-size:.85rem;color:#777;min-height:20px;margin-bottom:15px}body.dark-mode .progress-details{color:#999}.progress-cancel-btn{display:block;width:100%;padding:10px;background-color:#e74c3c;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:600;transition:background-color .3s ease}.progress-cancel-btn:hover{background-color:#c0392b}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes indeterminate{0%{transform:translateX(-100%)}50%{transform:translateX(0)}to{transform:translateX(100%)}}@keyframes slideInRight{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}