.app{min-height:100vh;display:flex;flex-direction:column}.app-header{text-align:center;margin-bottom:2rem}.app-title{margin-bottom:.5rem}.app-subtitle{opacity:.8}.canvas-container{flex:1;display:flex;justify-content:center;align-items:center;margin:2rem 0}.controls{margin-top:auto;padding-top:2rem}.instructions{margin-top:2rem}.status{margin-top:1rem}.video-player{max-width:1200px;margin:0 auto;padding:2rem}.video-container{position:relative;background:#000;border-radius:8px;overflow:hidden;margin-bottom:1rem}.video-element{width:100%;height:auto;display:block}.video-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#fff;background:#000000b3;padding:2rem;border-radius:8px}.loading-spinner{font-size:2rem;margin-bottom:1rem}.video-controls{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);padding:1rem;border-radius:8px;margin-bottom:1rem;color:#ffffffde}.control-buttons{display:flex;gap:.5rem;margin-bottom:1rem;align-items:center;flex-wrap:wrap}.control-btn{padding:.5rem 1rem;border:none;border-radius:4px;background:#007bff;color:#fff;cursor:pointer;font-size:1rem;transition:background-color .2s;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center}.control-btn:hover{background:#0056b3}.control-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.frame-btn{background:#6c757d;font-size:1.2rem;padding:.5rem;min-width:44px}.frame-btn:hover:not(:disabled){background:#545b62}.capture-btn{background:#28a745;min-width:auto;padding:.5rem 1rem}.capture-btn:hover{background:#1e7e34}.time-controls{display:flex;align-items:center;gap:1rem}.time-slider{flex:1;height:6px;border-radius:3px;background:#ddd;outline:none;-webkit-appearance:none}.time-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#007bff;cursor:pointer}.time-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#007bff;cursor:pointer;border:none}.time-display{font-family:monospace;font-weight:700;min-width:60px;text-align:center;color:#ffffffde}.video-instructions{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:1rem;margin-top:1rem;color:#ffffffde}.video-instructions h4{margin-top:0;margin-bottom:.5rem;color:#4ecdc4;font-weight:600}.video-instructions ol{margin:0;padding-left:1.5rem;color:#fffc}.video-instructions li{margin-bottom:.25rem;color:#fffc}.export-panel{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1.5rem;margin-top:2rem;border:1px solid rgba(255,255,255,.2)}.export-panel h3{margin-bottom:1rem;color:var(--primary-color)}.frame-info{background:#ffffff0d;border-radius:8px;padding:1rem;margin-bottom:1.5rem;border-left:4px solid var(--primary-color)}.frame-info p{margin:.25rem 0;font-size:.9rem}.frame-info p:first-child{font-weight:600}.offside-preview{background:#ffffff0d;border-radius:8px;padding:1rem;margin-bottom:1.5rem;border-left:4px solid}.offside-preview.offside{border-left-color:#ff6b6b;background:#ff6b6b1a}.offside-preview.no-offside{border-left-color:#51cf66;background:#51cf661a}.offside-preview h4{margin-bottom:.5rem;font-size:1rem}.result-text{font-size:1.2rem;font-weight:700;margin-bottom:.5rem}.result-text.offside-text{color:#ff6b6b}.result-text.no-offside-text{color:#51cf66}.reason-text{font-size:.9rem;opacity:.8;margin:0}.export-settings{margin-bottom:1.5rem}.export-settings h4{margin-bottom:1rem;font-size:1rem}.setting-group{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;gap:1rem}.setting-group label{font-size:.9rem;min-width:140px;text-align:left}.setting-group input{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:.5rem;color:#fff;width:100px}.setting-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4a90e24d}.export-status{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.export-status.processing{background:#ffc10733;border:1px solid rgba(255,193,7,.4);color:#ffc107}.export-status.complete{background:#51cf6633;border:1px solid rgba(81,207,102,.4);color:#51cf66}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.export-btn{width:100%;padding:1rem;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:1rem}.export-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #4a90e266}.export-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.requirements{background:#ffffff0d;border-radius:8px;padding:1rem}.requirements h4{margin-bottom:.75rem;font-size:.9rem;color:var(--primary-color)}.requirements ul{list-style:none;padding:0;margin:0}.requirements li{padding:.25rem 0;font-size:.85rem}.requirements li.complete{color:#51cf66}.requirements li.incomplete{color:#ff6b6b}:root{font-family:Inter,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;-webkit-text-size-adjust:100%}*{margin:0;padding:0;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298)}#root{width:100%;max-width:100vw;margin:0 auto;padding:1rem;text-align:center}.app{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:1.5rem;box-shadow:0 8px 32px #0000004d;border:1px solid rgba(255,255,255,.2);width:100%;max-width:100%}.app-header{margin-bottom:2rem}.app-title{font-size:2.5rem;font-weight:700;background:linear-gradient(45deg,#ff6b6b,#4ecdc4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;letter-spacing:-.02em}.app-subtitle{color:#ffffffb3;font-size:1.1rem;font-weight:400;letter-spacing:.01em}.upload-section{margin-bottom:2rem}.upload-area{border:2px dashed rgba(255,255,255,.3);border-radius:15px;padding:3rem;cursor:pointer;transition:all .3s ease;background:#ffffff0d}.upload-area:hover{border-color:#4ecdc4;background:#ffffff1a}.upload-area.dragover{border-color:#ff6b6b;background:#ff6b6b1a}.upload-icon{font-size:3rem;margin-bottom:1rem;color:#4ecdc4}.upload-text{font-size:1.2rem;margin-bottom:.5rem}.upload-hint{color:#fff9;font-size:.9rem}.canvas-container{position:relative;margin:1rem 0;border-radius:15px;overflow:hidden;box-shadow:0 4px 20px #0000004d;min-height:500px;width:100%}.canvas{display:block;max-width:100%;height:auto}.controls{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin:1rem 0}.btn{padding:.75rem 1.5rem;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.btn-primary{background:linear-gradient(45deg,#4ecdc4,#44a08d);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 15px #4ecdc466}.btn-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.3)}.btn-secondary:hover{background:#fff3;transform:translateY(-2px)}.btn-danger{background:linear-gradient(45deg,#ff6b6b,#ee5a52);color:#fff}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 15px #ff6b6b66}.instructions{background:#ffffff1a;border-radius:10px;padding:1.5rem;margin:1rem 0;text-align:left}.instructions h3{color:#4ecdc4;margin-bottom:1rem;font-weight:600;letter-spacing:-.01em}.instructions ol{padding-left:1.5rem}.instructions li{margin-bottom:.5rem;color:#fffc}.status{padding:1rem;border-radius:10px;margin:1rem 0;font-weight:600}.status.info{background:#4ecdc433;border:1px solid #4ecdc4;color:#4ecdc4}.status.warning{background:#ffc10733;border:1px solid #ffc107;color:#ffc107}.status.success{background:#28a74533;border:1px solid #28a745;color:#28a745}.hidden{display:none}@media (max-width: 768px){#root,.app{padding:1rem}.app-title{font-size:2rem}.controls{flex-direction:column;align-items:center}.btn{width:100%;max-width:300px}}.field-point-selector{background:#ffffff1a;border-radius:15px;padding:1.5rem;margin:1rem 0}.field-point-selector h3{color:#4ecdc4;margin-bottom:.5rem;font-weight:600;letter-spacing:-.01em}.selector-description{color:#ffffffb3;margin-bottom:1rem;font-size:.9rem}.selector-controls{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.search-box{flex:1;min-width:200px}.search-input{width:100%;padding:.75rem;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;font-size:.9rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.search-input:focus{outline:none;border-color:#4ecdc4;background:#ffffff26}.search-input::placeholder{color:#ffffff80}.category-select{padding:.75rem;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;font-size:.9rem;cursor:pointer;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.category-select:focus{outline:none;border-color:#4ecdc4}.category-select option{background:#2a2a2a;color:#fff;padding:.5rem}.points-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;max-height:400px;overflow-y:auto;margin:1rem 0}.point-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:1rem;cursor:pointer;transition:all .3s ease;position:relative}.point-card:hover{background:#ffffff1a;transform:translateY(-2px)}.point-card.selected{border-color:#4ecdc4;background:#4ecdc41a}.point-id{background:#4ecdc4;color:#1a1a1a;padding:.25rem .5rem;border-radius:4px;font-weight:700;font-size:.8rem}.point-label{font-weight:700;color:#fff}.point-description{color:#ffffffb3;font-size:.85rem;margin-bottom:.5rem}.point-coordinates{color:#ffffff80;font-size:.8rem;font-family:monospace}.selected-indicator{position:absolute;top:.5rem;right:.5rem;background:#28a745;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:700}.no-results{text-align:center;color:#ffffff80;padding:2rem}.selection-summary{margin-top:1rem;padding:1rem;background:#ffffff0d;border-radius:8px;text-align:center}.warning{color:#ffc107}@media (max-width: 768px){.selector-controls{flex-direction:column}.points-grid{grid-template-columns:1fr}}.calibration-panel{background:#ffffff1a;border-radius:15px;padding:1.5rem;margin:1rem 0}.calibration-panel h3{color:#4ecdc4;margin-bottom:1rem;font-weight:600;letter-spacing:-.01em}.calibration-summary{display:flex;justify-content:space-between;align-items:center;margin:1rem 0;padding:1rem;background:#ffffff0d;border-radius:10px}.calibration-summary h4{color:#fffc;margin:0}.points-list{max-height:400px;overflow-y:auto;margin:1rem 0}.point-item{background:#ffffff0d;border-radius:10px;padding:1rem;margin-bottom:1rem;border:1px solid rgba(255,255,255,.1)}.point-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.point-number{font-weight:700;color:#4ecdc4}.point-details{display:flex;flex-direction:column;gap:.5rem}.point-coordinates{color:#ffffffb3;font-size:.9rem}.point-distance{display:flex;flex-direction:column;gap:.25rem}.point-distance label{color:#fffc;font-size:.9rem}.input-field{padding:.5rem;border:1px solid rgba(255,255,255,.3);border-radius:5px;background:#ffffff1a;color:#fff;font-size:.9rem}.input-field:focus{outline:none;border-color:#4ecdc4;background:#ffffff26}.input-field::placeholder{color:#ffffff80}.calibration-actions{margin-top:1rem;text-align:center}.calibration-instructions{background:#ffffff0d;border-radius:10px;padding:1rem;margin-bottom:1rem}.calibration-instructions p{margin-bottom:.5rem;color:#fffc}.calibration-instructions ol{padding-left:1.5rem;color:#ffffffb3}.calibration-instructions li{margin-bottom:.25rem}.point-selection-mode{margin:1rem 0}.field-point-info{color:#ffffffb3;font-size:.9rem;margin-top:.5rem}.field-reference{margin-top:1rem;text-align:center}.field-reference-image{max-width:100%;height:auto;border-radius:10px;box-shadow:0 4px 20px #0000004d;border:2px solid rgba(255,255,255,.2);min-width:400px;object-fit:contain}.field-reference-image-large{max-width:100%;height:auto;border-radius:10px;box-shadow:0 4px 20px #0000004d;border:2px solid rgba(255,255,255,.2);min-width:600px}.calibration-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin:2rem 0;min-height:600px;width:100%}.canvas-section,.reference-section{display:flex;flex-direction:column}.canvas-section h3,.reference-section h3{color:#4ecdc4;margin-bottom:1rem;text-align:center;font-weight:600;letter-spacing:-.01em}.canvas-section .canvas-container{flex:1;display:flex;justify-content:center;align-items:center;min-height:500px;width:100%;overflow:visible}.reference-section .field-reference{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:500px;width:100%;overflow:visible}.reference-section .field-reference p{margin-top:1rem;text-align:center;color:#ffffffb3}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:9999;padding:1rem}.modal-content{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:15px;border:1px solid rgba(255,255,255,.2);width:95vw;height:95vh;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h3{color:#4ecdc4;margin:0;font-weight:600;letter-spacing:-.01em}.modal-close{background:none;border:none;color:#ffffffb3;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:5px;transition:all .3s ease}.modal-close:hover{color:#ff6b6b;background:#ff6b6b1a}.modal-body{flex:1;display:flex;flex-direction:column;padding:1.5rem;overflow:hidden}.point-info{text-align:center;margin-bottom:1rem;flex-shrink:0}.point-info p{color:#fffc;margin:.5rem 0}.modal-content-layout{display:flex;flex:1;gap:2rem;overflow:hidden}.modal-left-panel,.modal-right-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.modal-field-reference{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;background:#ffffff0d;border-radius:10px;padding:1rem;overflow:hidden}.modal-field-reference img{width:100%;height:100%;object-fit:contain;object-position:center}.field-point-selector-modal{flex:1;overflow:hidden;display:flex;flex-direction:column}.point-actions{display:flex;gap:.5rem}@media (max-width: 1200px){.calibration-layout{grid-template-columns:1fr;gap:1rem}.canvas-section,.reference-section{max-height:50vh}}@media (max-width: 768px){.modal-content{width:95vw;height:95vh}.modal-header,.modal-body{padding:1rem}.modal-content-layout{flex-direction:column;gap:1rem}.modal-left-panel,.modal-right-panel{flex:none;max-height:45vh}}.offside-controls{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:1.5rem;margin:1rem 0;display:flex;gap:2rem;align-items:center;flex-wrap:wrap}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{font-weight:600;color:#333;font-size:.9rem;letter-spacing:.01em}.team-selector{display:flex;gap:.5rem}.team-btn{padding:.5rem 1rem;border:2px solid #ddd;border-radius:6px;background:#fff;color:#333;cursor:pointer;transition:all .2s ease;font-weight:500;font-size:.9rem;letter-spacing:.01em}.team-btn:hover{border-color:#4ecdc4;background:#f0f9f8}.team-btn.active{border-color:#4ecdc4;background:#4ecdc4;color:#fff}.thickness-slider{width:120px;height:6px;border-radius:3px;background:#ddd;outline:none;-webkit-appearance:none}.thickness-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#4ecdc4;cursor:pointer}.thickness-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#4ecdc4;cursor:pointer;border:none}.thickness-value{font-weight:600;color:#333;font-size:.9rem}.distance-display{background:#4ecdc41a;border:1px solid rgba(78,205,196,.3);border-radius:8px;padding:.75rem 1rem;color:#2c7a7a;font-size:.9rem}.field-dimensions-btn{padding:.5rem 1rem;border:2px solid #ddd;border-radius:6px;background:#fff;color:#333;cursor:pointer;transition:all .2s ease;font-weight:500;font-size:.9rem;letter-spacing:.01em}.field-dimensions-btn:hover{border-color:#4ecdc4;background:#f0f9f8}.field-dimensions-input{background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:1rem;margin-top:.5rem;display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.dimension-input{display:flex;flex-direction:column;gap:.25rem}.dimension-input label{font-size:.8rem;color:#333;font-weight:500;letter-spacing:.01em}.dimension-input input{padding:.25rem .5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;width:80px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.dimension-input input:focus{outline:none;border-color:#4ecdc4}.pixel-per-meter-display{color:#666;font-size:.8rem;font-style:italic}.offside-panel{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:1.5rem;margin:1rem 0}
