@import"https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;600;700;800;900&family=Rajdhani:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap";.app{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-primary)}.app-header{background:var(--bg-secondary);padding:.875rem 1.5rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.app-header h1{font-family:Orbitron,sans-serif;font-size:1.25rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.5rem;letter-spacing:.05em;text-transform:uppercase}.app-header h1 .logo-img{width:28px;height:28px}.header-info{display:flex;gap:1rem;align-items:center}.workspace-id{background:var(--bg-elevated);padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;color:var(--text-secondary);border:1px solid var(--border-color)}.user-info{display:flex;align-items:center;gap:.75rem}.user-info .username{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.logout-button{padding:.375rem .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.logout-button:hover{border-color:var(--accent-red);color:var(--accent-red);background:#ef44441a}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);gap:1rem}.app-loading .logo-img{width:64px;height:64px;animation:pulse 1.5s ease-in-out infinite}.app-loading p{color:var(--text-muted);font-size:.875rem;text-transform:uppercase;letter-spacing:.1em}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}.api-key-setup input{padding:.375rem .75rem;border:1px solid var(--border-color);border-radius:6px;font-size:.8125rem;width:200px;background:var(--bg-input);color:var(--text-primary)}.api-key-setup input:focus{outline:none;border-color:var(--accent-primary)}.tabs{display:flex;background:var(--bg-secondary);padding:0 1.5rem;gap:.25rem;border-bottom:1px solid var(--border-color)}.tabs button{padding:.75rem 1rem;border:none;background:transparent;cursor:pointer;font-family:Rajdhani,sans-serif;font-size:.9375rem;font-weight:600;color:var(--text-muted);border-bottom:2px solid transparent;transition:all .15s ease;margin-bottom:-1px;text-transform:uppercase;letter-spacing:.03em}.tabs button:hover{color:var(--text-primary)}.tabs button.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.app-content{flex:1;padding:1.5rem;max-width:1400px;width:100%;margin:0 auto;animation:fade-in .2s ease}.toast-container{position:fixed;top:16px;right:16px;z-index:10000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast-container>*{pointer-events:auto}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-sm)}button{font-family:inherit;cursor:pointer}.btn-primary{background:var(--accent-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;transition:background .15s ease;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;transition:all .15s ease}.btn-secondary:hover{border-color:var(--text-muted);background:var(--bg-elevated)}input,textarea,select{font-family:inherit;background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem .75rem;border-radius:6px;font-size:.875rem;transition:border-color .15s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-muted)}input::placeholder,textarea::placeholder{color:var(--text-muted)}table{width:100%;border-collapse:collapse}th{text-align:left;padding:.75rem 1rem;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);background:var(--bg-elevated)}td{padding:.75rem 1rem;font-size:.875rem;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle)}tr:hover td{background:var(--bg-elevated)}.status{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:4px}.status-success{background:#10b9811a;color:var(--accent-green)}.status-error{background:#ef44441a;color:var(--accent-red)}.status-warning{background:#f59e0b1a;color:var(--accent-yellow)}.status-info{background:var(--accent-muted);color:var(--accent-primary)}@media (max-width: 768px){.app-header{flex-direction:column;gap:.75rem;padding:.75rem 1rem}.tabs{padding:0 1rem;overflow-x:auto}.tabs button{padding:.625rem .75rem;font-size:.8125rem;white-space:nowrap}.app-content{padding:1rem}}.upload-tab{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a}.upload-tab h2{margin-bottom:.5rem;color:#333}.upload-tab>p{color:#666;margin-bottom:2rem}.form-group input[type=file],.form-group input[type=text],.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.ingest-section{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.1)}.ingest-section p{margin-bottom:1rem}.query-tab{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a}.query-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.query-header h2{margin:0;color:#333}.query-layout{display:grid;grid-template-columns:250px 1fr;gap:1.5rem}.tables-panel{background:#f8f9fa;border-radius:6px;padding:1rem}.tables-panel h3{margin-bottom:1rem;font-size:1rem;color:#666}.table-list{list-style:none;padding:0;margin:0}.table-item{padding:.5rem;margin-bottom:.25rem;background:#fff;border-radius:4px;cursor:pointer;transition:all .2s}.table-item:hover{background:#e9ecef;transform:translate(4px)}.table-item code{font-size:.85rem;color:#667eea}.empty{color:#999;font-style:italic;padding:1rem 0}.query-panel{display:flex;flex-direction:column;gap:1.5rem}.sql-editor{display:flex;flex-direction:column;gap:1rem}.sql-editor textarea{width:100%;padding:1rem;border:1px solid #ddd;border-radius:6px;font-family:Courier New,monospace;font-size:.95rem;resize:vertical}.result-box{background:#f8f9fa;border-radius:6px;padding:1.5rem}.result-box.error{background:#fff5f5;border:1px solid #fc8181}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.result-header h3{margin:0;font-size:1.1rem}.row-count{color:#666;font-size:.9rem}.table-container{overflow-x:auto;max-height:600px;overflow-y:auto}.table-container table{width:100%;border-collapse:collapse;background:#fff}.table-container th{background:#667eea;color:#fff;padding:.75rem;text-align:left;font-weight:600;position:sticky;top:0}.table-container td{padding:.75rem;border-bottom:1px solid #e0e0e0}.table-container tr:hover{background:#f8f9ff}.table-container td em{color:#999;font-style:italic}.assets-tab{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a}.assets-tab h2{margin-bottom:.5rem;color:#333}.assets-tab>p{color:#666;margin-bottom:2rem}.upload-section{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input[type=file],.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.form-group input[type=file]{cursor:pointer}.file-info{margin-top:.5rem;padding:.75rem;background:#f8f9fa;border-radius:6px;color:#666}.btn-secondary{background:#48bb78;color:#fff}.btn-secondary:hover:not(:disabled){background:#38a169}.status-box{padding:1.5rem;border-radius:6px;margin-top:1.5rem}.status-box.success{background:#f0fff4;border:1px solid #9ae6b4}.status-box.error{background:#fff5f5;border:1px solid #fc8181}.status-box h3{margin-bottom:.5rem;font-size:1.1rem}.status-box h4{margin-top:1rem;margin-bottom:.5rem;font-size:1rem}.status-box code{background:#0000000d;padding:.2rem .4rem;border-radius:3px;font-size:.9rem}.details{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.1)}.details p{margin-bottom:.5rem}.embed-section{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.1)}.embed-section p{margin-bottom:1rem;color:#666}.status-box pre{margin-top:1rem;padding:1rem;background:#0000000d;border-radius:4px;overflow-x:auto;font-size:.9rem}.chat-message{display:flex;gap:.75rem;animation:fade-in .2s ease;user-select:text;-webkit-user-select:text;-moz-user-select:text}.chat-message-user{flex-direction:row-reverse}.chat-message-avatar{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;background:var(--bg-elevated)}.chat-message-assistant .chat-message-avatar{background:var(--accent-muted)}.chat-message-content{max-width:85%;display:flex;flex-direction:column;gap:.25rem}.chat-message-user .chat-message-content{align-items:flex-end}.chat-bubble{padding:.875rem 1rem;border-radius:12px;font-family:Rajdhani,sans-serif;font-size:.9375rem;font-weight:500;line-height:1.6;user-select:text;-webkit-user-select:text;-moz-user-select:text;cursor:text;position:relative}.chat-bubble-assistant{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);box-shadow:var(--shadow-sm)}.copy-button{position:absolute;top:.5rem;right:.5rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;padding:.25rem .5rem;font-size:.75rem;cursor:pointer;opacity:0;transition:opacity .15s ease,background .15s ease}.chat-bubble:hover .copy-button{opacity:1}.copy-button:hover{background:var(--accent-muted);border-color:var(--accent-primary)}.chat-bubble-user{background:var(--accent-primary);color:#fff}.chat-bubble-user::selection,.chat-bubble-user *::selection{background:#fff6;color:#fff}.chat-bubble-user::-moz-selection,.chat-bubble-user *::-moz-selection{background:#fff6;color:#fff}.chat-bubble-error{background:#ef44440d;border-color:#ef444433}.chat-message-time{font-size:.6875rem;color:var(--text-muted)}.chat-bubble-text h1,.chat-bubble-text h2,.chat-bubble-text h3{font-family:Orbitron,sans-serif;font-weight:600;margin:1rem 0 .5rem;color:var(--text-primary)}.chat-bubble-text h1{font-size:1.125rem}.chat-bubble-text h2{font-size:1rem}.chat-bubble-text h3{font-size:.9375rem}.chat-bubble-text p{margin:.5rem 0}.chat-bubble-text ul,.chat-bubble-text ol{margin:.5rem 0;padding-left:1.5rem}.chat-bubble-text li{margin:.25rem 0}.chat-bubble-text strong{font-weight:700;color:var(--text-primary)}.inline-code{background:var(--bg-elevated);padding:.15em .4em;border-radius:4px;font-family:SF Mono,Fira Code,monospace;font-size:.85em;color:var(--accent-primary)}.code-block{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:.875rem 1rem;margin:.75rem 0;overflow-x:auto;font-family:SF Mono,Fira Code,monospace;font-size:.8125rem;line-height:1.5}.table-wrapper{overflow-x:auto;margin:.75rem 0;border-radius:8px;border:1px solid var(--border-color)}.data-table{width:100%;border-collapse:collapse;font-family:Rajdhani,sans-serif;font-size:.875rem;background:var(--bg-secondary)}.data-table th{background:var(--bg-elevated);color:var(--accent-primary);font-family:Orbitron,sans-serif;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.75rem 1rem;text-align:left;border-bottom:2px solid var(--accent-primary);white-space:nowrap}.data-table td{padding:.625rem 1rem;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);white-space:nowrap}.data-table tr:hover td{background:var(--bg-elevated);color:var(--text-primary)}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:nth-child(2n){background:var(--bg-elevated)}.data-table td:first-child{font-weight:600;color:var(--text-primary)}.data-table td:not(:first-child){text-align:right;font-variant-numeric:tabular-nums}.data-table th:not(:first-child){text-align:right}.chat-tool-calls{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-subtle)}.chat-tool-calls-header{display:flex;align-items:center;gap:.375rem;font-size:.6875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.chat-tool-calls-list{display:flex;flex-direction:column;gap:.375rem}.chat-tool-call{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:6px;padding:.5rem .75rem;font-size:.8125rem}.chat-tool-name{color:var(--accent-primary);font-weight:600;font-family:SF Mono,monospace;font-size:.75rem}.chat-tool-args{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem}.chat-tool-arg{font-size:.75rem;color:var(--text-muted)}.chat-tool-arg code{background:var(--bg-primary);padding:.1em .3em;border-radius:3px;font-size:.7rem;color:var(--text-secondary)}.chat-input-form{width:100%}.chat-input-wrapper{display:flex;gap:.75rem;align-items:flex-end;width:100%}.chat-input-textarea{flex:1;padding:.75rem 1rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-family:Rajdhani,sans-serif;font-size:.9375rem;font-weight:500;resize:none;min-height:44px;max-height:120px;transition:border-color .15s,box-shadow .15s;line-height:1.5}.chat-input-textarea::placeholder{color:var(--text-muted);font-size:.875rem}.chat-input-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-muted)}.chat-input-textarea:disabled{opacity:.5;cursor:not-allowed}.chat-input-send{width:44px;height:44px;min-width:44px;border-radius:8px;border:none;background:var(--accent-primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.125rem;transition:background .15s;flex-shrink:0;box-shadow:var(--shadow-sm)}.chat-input-send:hover:not(:disabled){background:var(--accent-hover)}.chat-input-send:disabled{opacity:.5;cursor:not-allowed;background:var(--text-muted)}.chat-input-hint{font-size:.6875rem;color:var(--text-muted);margin-top:.375rem}.chat-panel{display:flex;flex-direction:column;height:calc(100vh - 180px);min-height:500px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.chat-header-info{display:flex;align-items:center;gap:.75rem}.chat-avatar{width:36px;height:36px;border-radius:8px;background:var(--accent-muted);display:flex;align-items:center;justify-content:center;font-size:1.125rem}.chat-title{font-family:Orbitron,sans-serif;font-size:.875rem;font-weight:600;color:var(--text-primary);letter-spacing:.05em;text-transform:uppercase}.chat-status{font-family:Rajdhani,sans-serif;font-size:.8125rem;font-weight:500;color:var(--accent-green);display:flex;align-items:center;gap:.375rem}.chat-status:before{content:"";width:6px;height:6px;background:var(--accent-green);border-radius:50%}.chat-status.offline{color:var(--text-muted)}.chat-status.offline:before{background:var(--text-muted)}.chat-clear-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-muted);padding:.375rem .5rem;border-radius:6px;cursor:pointer;transition:all .15s;font-size:.875rem}.chat-clear-btn:hover{border-color:var(--text-muted);color:var(--text-secondary);background:var(--bg-elevated)}.chat-messages{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;background:var(--bg-primary)}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);text-align:center;padding:2rem}.chat-empty-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.5}.chat-empty h3{font-size:1rem;font-weight:500;margin-bottom:.25rem;color:var(--text-secondary)}.chat-empty p{font-size:.875rem}.chat-typing{display:flex;align-items:center;gap:.5rem;padding:.75rem;color:var(--text-muted);font-size:.875rem}.chat-typing-dots{display:flex;gap:3px}.chat-typing-dots span{width:6px;height:6px;background:var(--accent-primary);border-radius:50%;animation:typing-bounce 1.4s infinite ease-in-out both}.chat-typing-dots span:nth-child(1){animation-delay:-.32s}.chat-typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes typing-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.chat-input-area{padding:1rem 1.25rem;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.llm-tab{height:calc(100vh - 200px);min-height:600px}.llm-tab .chat-panel{height:100%}.jobs-tab{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a}.jobs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.jobs-header h2{margin:0;color:#333}.jobs-filters{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:6px}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.9rem;font-weight:500;color:#666}.filter-group select{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.empty-state{text-align:center;padding:3rem;color:#999}.jobs-list{display:flex;flex-direction:column;gap:1rem}.job-card{border:1px solid #e0e0e0;border-radius:6px;padding:1rem;background:#fff;transition:all .2s}.job-card:hover{box-shadow:0 2px 8px #0000001a}.job-card.job-success{border-left:4px solid #10b981}.job-card.job-error{border-left:4px solid #ef4444}.job-card.job-info{border-left:4px solid #3b82f6}.job-card.job-warning{border-left:4px solid #f59e0b}.job-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.job-title{display:flex;align-items:center;gap:.75rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.status-success{background:#d1fae5;color:#065f46}.status-badge.status-error{background:#fee2e2;color:#991b1b}.status-badge.status-info{background:#dbeafe;color:#1e40af}.status-badge.status-warning{background:#fef3c7;color:#92400e}.status-badge.status-neutral{background:#f3f4f6;color:#374151}.job-name{color:#666;font-size:.9rem}.job-info{font-size:.85rem;color:#666}.job-meta{display:flex;gap:1rem}.job-details{margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.detail-section{margin-bottom:1rem}.detail-section strong{display:block;margin-bottom:.5rem;color:#333}.detail-section code{background:#f3f4f6;padding:.25rem .5rem;border-radius:4px;font-size:.85rem}.detail-section pre{background:#f8f9fa;padding:.75rem;border-radius:4px;overflow-x:auto;font-size:.85rem;margin:0}.detail-section.error{background:#fff5f5;padding:1rem;border-radius:4px;border:1px solid #fecaca}.detail-section.error pre{background:#fff;color:#991b1b}.job-actions{margin-top:1rem}.btn-small{padding:.5rem 1rem;font-size:.9rem}.capabilities-tab{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a}.capabilities-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.capabilities-header h2{margin:0;color:#333}.capabilities-header p{margin:.5rem 0 0;color:#666}.capabilities-filters{display:flex;gap:1rem;margin-bottom:2rem}.search-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.capabilities-filters select{padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.capabilities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.capability-card{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;background:#fff;transition:all .2s}.capability-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.capability-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.capability-icon{font-size:2rem}.capability-header h3{margin:0;font-size:1.25rem;color:#333}.capability-category{display:inline-block;padding:.25rem .75rem;background:#f3f4f6;border-radius:12px;font-size:.75rem;color:#666;margin-top:.25rem}.capability-description{color:#666;margin:1rem 0;line-height:1.5}.capability-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tag{padding:.25rem .5rem;background:#e3f2fd;color:#1976d2;border-radius:4px;font-size:.75rem}.capability-actions{display:flex;gap:.5rem;margin-top:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;padding:2rem;max-width:800px;max-height:90vh;overflow-y:auto;width:90%;box-shadow:0 4px 20px #0000004d}.modal-content h3{margin-top:0;color:#333}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem;border-top:1px solid #e0e0e0}.capability-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-field label{font-weight:500;color:#333;font-size:.9rem}.form-field input,.form-field textarea,.form-field select{padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit}.form-field textarea{resize:vertical}.poml-editor{font-family:Courier New,monospace;font-size:.9rem}.form-field small{color:#666;font-size:.85rem;margin-top:.25rem}.run-form{margin:1.5rem 0}.btn-primary:hover{background:#5568d3}.btn-secondary:hover{background:#4b5563}.btn-danger:hover{background:#dc2626}.btn-small{padding:.5rem 1rem;font-size:.875rem}.query-mode{display:flex;flex-direction:column;gap:2rem}.query-inputs{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.query-input-card{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;background:#fff;box-shadow:0 2px 4px #0000001a}.query-input-card h3{margin:0 0 1rem;color:#333;font-size:1.125rem}.query-textarea{width:100%;padding:1rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;font-family:inherit;resize:vertical;margin-bottom:1rem;min-height:200px}.query-textarea:disabled{opacity:.5;cursor:not-allowed}.sql-editor{font-family:Courier New,monospace;background:#f8f9fa}.query-error{padding:1rem;background:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#991b1b}.query-results{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;background:#fff;box-shadow:0 2px 4px #0000001a}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.results-header h3{margin:0;color:#333}.results-table-container{max-height:600px;overflow:auto;border:1px solid #e0e0e0;border-radius:6px}.results-table{width:100%;border-collapse:collapse;font-size:.875rem}.results-table thead{position:sticky;top:0;background:#f3f4f6;z-index:10}.results-table th{padding:.75rem;text-align:left;font-weight:600;border-bottom:2px solid #e0e0e0;background:#f3f4f6}.results-table td{padding:.75rem;border-bottom:1px solid #f3f4f6;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.results-table tr:hover{background:#f9fafb}.no-results{text-align:center;padding:3rem;color:#999}.dashboards-tab{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a}.dashboards-header{margin-bottom:2rem}.dashboards-header h2{margin:0;color:#333}.dashboards-header p{margin:.5rem 0 0;color:#666}.dashboards-tabs{display:flex;gap:.5rem;border-bottom:2px solid #e0e0e0;margin-bottom:2rem}.dashboards-tabs button{padding:.75rem 1.5rem;border:none;background:none;cursor:pointer;font-size:1rem;color:#666;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.dashboards-tabs button:hover{color:#333}.dashboards-tabs button.active{color:#667eea;border-bottom-color:#667eea;font-weight:600}.dashboard-builder{display:flex;flex-direction:column;gap:2rem}.builder-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border-radius:6px}.dashboard-name{margin:0;cursor:pointer;color:#333}.dashboard-name:hover{color:#667eea}.dashboard-name-input{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:1.25rem;font-weight:600}.widget-count{display:inline-block;padding:.25rem .75rem;background:#e3f2fd;color:#1976d2;border-radius:12px;font-size:.75rem;margin-left:1rem}.empty-dashboard{text-align:center;padding:4rem;color:#999}.hint{font-size:.9rem;margin-top:.5rem}.widgets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.widget-card{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;background:#fff;box-shadow:0 2px 4px #0000001a}.widget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.widget-header h4{margin:0;color:#333}.widget-remove{background:none;border:none;cursor:pointer;font-size:1.25rem;color:#999;padding:.25rem .5rem;border-radius:4px;transition:all .2s}.widget-remove:hover{background:#fee2e2;color:#dc2626}.widget-table{overflow-x:auto}.widget-table table{width:100%;border-collapse:collapse;font-size:.875rem}.widget-table th{background:#f3f4f6;padding:.75rem;text-align:left;font-weight:600;border-bottom:2px solid #e0e0e0}.widget-table td{padding:.75rem;border-bottom:1px solid #f3f4f6}.widget-table tr:hover{background:#f9fafb}.widget-more{text-align:center;padding:.5rem;color:#666;font-size:.875rem}.widget-chart-placeholder{padding:3rem;text-align:center;color:#999;background:#f9fafb;border-radius:4px}.saved-dashboards{display:flex;flex-direction:column;gap:1.5rem}.dashboards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.dashboard-card{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;background:#fff;box-shadow:0 2px 4px #0000001a}.dashboard-card h3{margin:0 0 .5rem;color:#333}.dashboard-card p{margin:.5rem 0;color:#666}.dashboard-date{font-size:.875rem;color:#999}.dashboard-actions{display:flex;gap:.5rem;margin-top:1rem}.empty-state{text-align:center;padding:4rem;color:#999}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5568d3}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.video-analyzer-tab{height:calc(100vh - 200px);min-height:600px;display:flex;flex-direction:column;animation:fade-in .2s ease}.analyzer-header{margin-bottom:1.5rem}.analyzer-header h2{font-family:Orbitron,sans-serif;font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem;display:flex;align-items:center;gap:.5rem}.analyzer-header .header-logo{width:28px;height:28px}.analyzer-header p{margin:0;color:var(--text-muted);font-size:.875rem}.analyzer-content{flex:1;display:grid;grid-template-columns:280px 1fr 320px;gap:1.5rem;min-height:0;overflow:hidden}.analyzer-controls{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem;overflow-y:auto;box-shadow:var(--shadow-sm)}.control-section{margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border-subtle)}.control-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.control-section h3{margin:0 0 .75rem;font-family:Rajdhani,sans-serif;font-size:.8125rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.video-input{width:100%;padding:.5rem;background:var(--bg-input);border:1px dashed var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:.875rem;transition:border-color .15s ease}.video-input:hover{border-color:var(--accent-primary)}.file-name{margin:.5rem 0 0;font-size:.75rem;color:var(--accent-green);word-break:break-all}.extract-btn,.analyze-btn{width:100%;padding:.625rem;font-size:.875rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .15s ease}.extract-btn{background:var(--accent-primary);color:#fff;box-shadow:var(--shadow-sm)}.extract-btn:hover:not(:disabled){background:var(--accent-hover)}.analyze-btn{background:var(--accent-green);color:#fff;box-shadow:var(--shadow-sm)}.analyze-btn:hover:not(:disabled){background:#059669}.extract-btn:disabled,.analyze-btn:disabled{opacity:.5;cursor:not-allowed}.enhance-section{background:var(--accent-muted);border:1px solid var(--accent-primary);border-radius:6px;padding:.75rem}.enhance-section h3{color:var(--accent-primary)}.enhance-controls{display:flex;gap:.75rem;align-items:center;margin-bottom:.75rem}.scale-select{flex:1;padding:.375rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:.8125rem}.toggle-label{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-muted);cursor:pointer}.toggle-label input{accent-color:var(--accent-primary)}.enhance-buttons{display:flex;flex-direction:column;gap:.5rem}.enhance-btn{padding:.5rem;font-size:.8125rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all .15s ease;background:var(--bg-secondary);border:1px solid var(--accent-primary);color:var(--accent-primary)}.enhance-btn:hover:not(:disabled){background:var(--accent-muted)}.enhance-btn.key{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.enhance-btn.key:hover:not(:disabled){background:var(--accent-hover)}.enhance-btn:disabled{opacity:.5;cursor:not-allowed}.enhance-info{margin:.5rem 0 0;font-size:.6875rem;color:var(--accent-primary);font-family:SF Mono,monospace}.upscale-progress{margin:.75rem 0;padding:.75rem;background:var(--bg-elevated);border-radius:6px;border:1px solid var(--border-color)}.progress-bar-container{height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#4ecdc4,#44a08d);border-radius:4px;transition:width .3s ease}.progress-info{display:flex;justify-content:space-between;align-items:center;font-size:.75rem}.progress-info .frame-count{display:flex;align-items:baseline;gap:2px;font-family:SF Mono,monospace}.progress-info .frame-count strong{color:var(--accent-primary);font-size:.875rem}.progress-info .frame-count .separator{color:var(--text-muted);margin:0 2px}.progress-info .frame-count .label{color:var(--text-muted);margin-left:4px;font-size:.6875rem}.progress-info .status-text{color:var(--text-secondary)}.progress-info .percent{color:var(--accent-green);font-weight:600;font-family:SF Mono,monospace}.enhance-note{margin:.5rem 0 0;font-size:.6875rem;color:var(--text-muted);font-style:italic}.help-text{margin:.25rem 0;font-size:.75rem;color:var(--text-muted)}.help-text kbd{background:var(--bg-elevated);padding:.125rem .375rem;border-radius:3px;font-family:SF Mono,monospace;font-size:.6875rem;border:1px solid var(--border-color);color:var(--text-secondary)}.frame-nav{display:flex;align-items:center;gap:.375rem;margin-top:.5rem}.frame-nav button{padding:.375rem .5rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:.75rem;transition:all .15s ease}.frame-nav button:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.frame-nav span{flex:1;text-align:center;font-family:SF Mono,monospace;font-size:.8125rem;color:var(--text-secondary)}.frame-markers{display:flex;flex-direction:column;gap:.25rem;margin-top:.5rem}.marker{font-size:.6875rem;padding:.25rem .5rem;border-radius:4px;font-weight:500}.marker.release{background:#f59e0b1a;color:var(--accent-yellow)}.marker.touch{background:#10b9811a;color:var(--accent-green)}.direction-select{width:100%;padding:.5rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.875rem}.calibration-buttons,.ball-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.5rem}.calibration-buttons{grid-template-columns:1fr 1fr 1fr}.cal-btn,.ball-btn{padding:.5rem;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .15s ease}.cal-btn.ball{border-color:#f59e0b;color:#f59e0b}.cal-btn.ball:hover{background:#f59e0b1a;border-color:#f59e0b}.cal-btn:hover,.ball-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.cal-btn.active,.ball-btn.active{background:var(--accent-muted);border-color:var(--accent-primary);color:var(--accent-primary)}.cal-btn.ball.active{background:#f59e0b33;border-color:#f59e0b;color:#f59e0b}.cal-btn.done,.ball-btn.done{background:#10b9811a;border-color:var(--accent-green);color:var(--accent-green)}.cal-btn.selected,.ball-btn.selected{background:#ffff0026;border-color:#ff0;box-shadow:0 0 0 2px #ffff004d}.calibration-actions{display:flex;gap:.5rem;margin-top:.75rem}.reset-btn,.restart-btn{flex:1;padding:.375rem .5rem;font-size:.6875rem;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.reset-btn:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.restart-btn:hover{background:#3b82f61a;border-color:#3b82f6;color:#3b82f6}.ball-btn:disabled{opacity:.5;cursor:not-allowed}.yard-distance,.sigma-input{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;font-size:.75rem;color:var(--text-muted)}.yard-distance input,.sigma-input input{width:50px;padding:.375rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);text-align:center;font-size:.8125rem}.analyzer-viewer{position:relative;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;overflow:visible;display:flex;align-items:stretch;justify-content:center;box-shadow:var(--shadow-sm)}.analyzer-viewer canvas{max-width:100%;max-height:100%;object-fit:contain}.analyzer-viewer canvas.clicking{cursor:crosshair}.video-container{width:100%;height:100%;display:flex;flex-direction:column;position:relative;background:#0a0a0a;border-radius:8px;overflow:hidden;box-shadow:0 4px 24px #0006}.video-container canvas{flex:1;object-fit:contain;background:#000;min-height:0}.frame-info-overlay{position:absolute;top:12px;left:12px;display:flex;gap:6px;align-items:center;z-index:10;pointer-events:none}.frame-info-overlay span{background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:4px 10px;border-radius:4px;font-family:SF Mono,monospace;font-size:.75rem;color:#fff}.frame-info-overlay .frame-tag{font-weight:600}.frame-info-overlay .frame-tag.release{background:#f59e0be6}.frame-info-overlay .frame-tag.touch{background:#10b981e6}.zoom-controls{display:none;position:absolute;top:.75rem;right:.75rem;align-items:center;gap:.25rem;background:#000000bf;padding:.25rem .5rem;border-radius:6px;z-index:10}.zoom-controls button{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:4px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:background .15s ease}.zoom-controls button:hover{background:#fff3}.zoom-controls .zoom-level{font-family:SF Mono,monospace;font-size:.6875rem;color:#fff;min-width:40px;text-align:center}.zoom-controls .reset-btn{width:auto;padding:0 .5rem;font-size:.625rem;text-transform:uppercase;letter-spacing:.03em}.video-container canvas.panning{cursor:grabbing!important}.player-controls{background:linear-gradient(to top,#000000f2,#000c);padding:0;display:flex;flex-direction:column}.timeline-container{padding:8px 12px 4px;cursor:pointer}.timeline-track{position:relative;height:4px;background:#fff3;border-radius:2px;transition:height .15s ease}.timeline-container:hover .timeline-track{height:6px}.timeline-progress{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:2px;pointer-events:none;transition:width .05s linear}.timeline-scrubber{position:absolute;top:0;left:0;width:100%;height:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer;margin:0}.timeline-scrubber::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0006;transform:translateY(-5px);opacity:0;transition:opacity .15s ease,transform .1s ease}.timeline-container:hover .timeline-scrubber::-webkit-slider-thumb{opacity:1}.timeline-scrubber::-moz-range-thumb{width:14px;height:14px;background:#fff;border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 6px #0006}.timeline-marker{position:absolute;top:-8px;transform:translate(-50%);width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;z-index:5;cursor:pointer;transition:transform .15s ease}.timeline-marker:hover{transform:translate(-50%) scale(1.2)}.timeline-marker.release{background:#f59e0b;box-shadow:0 0 8px #f59e0b80}.timeline-marker.touch{background:#10b981;box-shadow:0 0 8px #10b98180}.timeline-marker span{line-height:1}.control-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 10px;gap:16px}.control-group{display:flex;align-items:center;gap:4px}.control-group.left{flex:1;justify-content:flex-start}.control-group.center{flex:0 0 auto}.control-group.right{flex:1;justify-content:flex-end}.ctrl-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:4px;color:#ffffffd9;cursor:pointer;transition:all .15s ease;padding:0}.ctrl-btn:hover{background:#ffffff1a;color:#fff}.ctrl-btn:active{transform:scale(.95)}.ctrl-btn svg{width:20px;height:20px}.ctrl-btn.play-pause{width:40px;height:40px;background:#ffffff1a;border-radius:50%;margin-right:8px}.ctrl-btn.play-pause:hover{background:#fff3}.ctrl-btn.play-pause svg{width:22px;height:22px}.frame-nav{display:flex;align-items:center;gap:2px;padding:0 8px;border-left:1px solid rgba(255,255,255,.1);margin-left:4px}.time-display{display:flex;align-items:baseline;gap:4px;font-family:JetBrains Mono,SF Mono,monospace;font-size:13px;color:#ffffffe6;background:#ffffff0d;padding:6px 12px;border-radius:4px}.time-display .current-frame{color:#fff;font-weight:600;min-width:4ch;text-align:right}.time-display .separator{color:#fff6}.time-display .total-frames{color:#fff9;min-width:4ch}.time-display .time-code{color:#ffffff80;font-size:11px;margin-left:8px;padding-left:8px;border-left:1px solid rgba(255,255,255,.15)}.zoom-display{display:flex;align-items:center;gap:4px;padding-right:8px;border-right:1px solid rgba(255,255,255,.1);margin-right:8px}.zoom-display .zoom-level{font-family:JetBrains Mono,SF Mono,monospace;font-size:11px;color:#fff9;min-width:36px;text-align:center}.ctrl-btn.zoom-btn{width:28px;height:28px}.ctrl-btn.zoom-btn svg{width:16px;height:16px}.ctrl-btn.reset-zoom{width:28px;height:28px;margin-left:2px}.ctrl-btn.reset-zoom svg{width:16px;height:16px}.frame-jump-input{width:60px;padding:6px 8px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:#fff;font-family:JetBrains Mono,SF Mono,monospace;font-size:12px;text-align:center;transition:all .15s ease}.frame-jump-input:hover{background:#ffffff1a;border-color:#fff3}.frame-jump-input:focus{outline:none;background:#ffffff1f;border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.frame-jump-input::-webkit-inner-spin-button,.frame-jump-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.scrubber-controls{display:none}.scrubber-buttons button{padding:.375rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:.875rem;transition:all .15s ease}.scrubber-buttons button:hover{background:var(--accent-muted);border-color:var(--accent-primary)}.scrubber-slider{position:relative;padding:0 .5rem}.frame-scrubber{width:100%;height:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-secondary);border-radius:4px;outline:none;cursor:pointer}.frame-scrubber::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:var(--accent-primary);border-radius:50%;cursor:pointer;box-shadow:var(--shadow-sm)}.frame-scrubber::-moz-range-thumb{width:16px;height:16px;background:var(--accent-primary);border-radius:50%;cursor:pointer;border:none}.scrubber-markers{position:absolute;top:0;left:.5rem;right:.5rem;height:8px;pointer-events:none}.scrubber-markers .marker{position:absolute;width:4px;height:16px;top:-4px;transform:translate(-50%);border-radius:2px;pointer-events:auto;cursor:pointer}.scrubber-markers .marker.release{background:var(--accent-yellow)}.scrubber-markers .marker.touch{background:var(--accent-green)}.scrubber-jump{display:flex;justify-content:center;align-items:center;gap:.375rem}.frame-input{width:70px;padding:.25rem .5rem;text-align:center;font-family:SF Mono,monospace;font-size:.8125rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary)}.frame-total{font-family:SF Mono,monospace;font-size:.8125rem;color:var(--text-muted)}.keyboard-hints{display:grid;gap:.25rem;margin:.5rem 0;font-size:.75rem;color:var(--text-muted)}.keyboard-hints kbd{background:var(--bg-elevated);padding:.125rem .375rem;border-radius:3px;font-family:SF Mono,monospace;font-size:.6875rem;border:1px solid var(--border-color);color:var(--text-secondary)}.marker-item{display:flex;align-items:center;gap:.375rem;padding:.375rem .5rem;border-radius:4px;font-size:.75rem;cursor:pointer;transition:all .15s ease}.marker-item.release{background:#f59e0b1a;border:1px solid var(--accent-yellow);color:var(--accent-yellow)}.marker-item.touch{background:#10b9811a;border:1px solid var(--accent-green);color:var(--accent-green)}.marker-item:hover{opacity:.8}.marker-item button{margin-left:auto;padding:0 .25rem;background:none;border:none;color:inherit;cursor:pointer;opacity:.6;font-size:.875rem}.marker-item button:hover{opacity:1}.marker-icon{font-size:.6875rem;font-weight:700;width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:currentColor;color:var(--bg-card);border-radius:3px}.fps-control{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.75rem;color:var(--text-muted)}.fps-control select{padding:.25rem .5rem;font-size:.75rem;background:var(--bg-input);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary)}.duration-info{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem;padding:.375rem .5rem;background:var(--bg-elevated);border-radius:4px;font-size:.75rem;color:var(--text-secondary);font-family:SF Mono,monospace}.override-btn{padding:.125rem .375rem;background:none;border:1px solid var(--border-color);border-radius:3px;cursor:pointer;font-size:.6875rem;color:var(--text-muted);transition:all .15s ease}.override-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.perspective-toggle{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.5rem;background:var(--accent-muted);border-radius:4px;cursor:pointer}.perspective-toggle input{accent-color:var(--accent-primary)}.perspective-toggle span:first-of-type{font-size:.8125rem;color:var(--text-primary);font-weight:500}.toggle-hint{font-size:.6875rem;color:var(--accent-primary);margin-left:auto}.audio-mode-selector{display:flex;flex-direction:column;gap:.375rem;padding:.5rem 0}.audio-mode-selector label{font-size:.75rem;font-weight:600;color:var(--text-primary)}.audio-mode-select{padding:.375rem .5rem;font-size:.75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-elevated);color:var(--text-primary);cursor:pointer}.audio-mode-select:hover{border-color:var(--accent-primary)}.audio-mode-hint{font-size:.625rem;color:var(--text-muted);font-style:italic}.calibration-frame-selector{background:var(--bg-elevated);border-radius:6px;padding:.625rem;margin-bottom:.75rem;border:1px solid var(--border-subtle)}.calibration-frame-selector .selector-label{display:block;font-size:.6875rem;font-weight:600;color:var(--text-muted);margin-bottom:.375rem;text-transform:uppercase;letter-spacing:.05em}.frame-toggle-btns{display:flex;gap:.375rem}.frame-toggle-btn{flex:1;padding:.5rem .625rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);font-size:.6875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.frame-toggle-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.frame-toggle-btn.active{background:var(--accent-muted);border-color:var(--accent-primary);color:var(--accent-primary);font-weight:600}.calibration-hint-small{margin:.375rem 0 0;font-size:.625rem;color:var(--text-muted);font-style:italic}.calibration-instructions{background:var(--bg-elevated);border-radius:6px;padding:.75rem;margin-bottom:.75rem;border:1px solid var(--border-subtle)}.broadcast-diagram{margin-bottom:.75rem}.field-svg{width:100%;height:auto;border-radius:4px;background:#111}.instruction-steps.compact{font-size:.75rem}.instruction-steps.compact ol{margin:.5rem 0;padding-left:1.25rem}.instruction-steps.compact li{margin-bottom:.25rem;line-height:1.4}.instruction-steps.compact strong{color:var(--text-primary)}.instruction-note{font-size:.6875rem;color:#4ecdc4;margin-top:.5rem;padding:.375rem .5rem;background:#4ecdc41a;border-radius:4px;border-left:2px solid #4ecdc4}.instruction-warning{color:#ffc107;font-size:.625rem;margin-top:.25rem}.instruction-steps{font-size:.6875rem;color:var(--text-secondary);line-height:1.5}.instruction-steps p{margin:0 0 .375rem}.instruction-steps ol{margin:0 0 .5rem;padding-left:1.25rem}.instruction-steps li{margin-bottom:.25rem}.instruction-steps em{color:var(--accent-primary);font-style:normal}.instruction-tip{font-size:.6875rem;color:var(--accent-primary);margin:.5rem 0 .25rem!important;display:flex;align-items:center;gap:.375rem}.instruction-tip kbd{background:var(--bg-secondary);padding:.125rem .375rem;border-radius:3px;font-family:SF Mono,monospace;font-size:.625rem;border:1px solid var(--border-color)}.instruction-note{font-size:.625rem;color:var(--text-muted);font-style:italic;margin:0!important}.ball-instructions{background:var(--bg-elevated);border-radius:6px;padding:.75rem;margin-bottom:.75rem;border:1px solid var(--border-subtle);font-size:.6875rem;color:var(--text-secondary);line-height:1.5}.ball-instructions p{margin:0 0 .375rem}.ball-instructions ul{margin:0 0 .5rem;padding-left:1rem}.ball-instructions li{margin-bottom:.25rem}.calibration-hint{margin-top:.5rem;padding:.5rem;background:var(--bg-elevated);border-radius:4px;font-size:.6875rem;color:var(--text-muted);display:flex;align-items:flex-start;gap:.375rem}.calibration-hint span{font-size:.875rem}.warp-btn{width:100%;margin-top:.75rem;padding:.5rem;background:var(--bg-elevated);border:1px dashed var(--accent-primary);border-radius:4px;color:var(--accent-primary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease}.warp-btn:hover:not(:disabled){background:var(--accent-muted);border-style:solid}.warp-btn:disabled{opacity:.5;cursor:not-allowed}.auto-detect-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.auto-detect-btn{width:100%;padding:.625rem 1rem;background:linear-gradient(135deg,#2d8cf0,#19a0ff);border:none;border-radius:6px;color:#fff;font-family:Rajdhani,sans-serif;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .15s ease}.auto-detect-btn:hover:not(:disabled){background:linear-gradient(135deg,#3d9cff,#29b0ff);transform:translateY(-1px)}.auto-detect-btn:disabled{opacity:.5;cursor:not-allowed}.detection-settings{margin-top:.75rem}.detection-settings summary{font-size:.75rem;color:var(--text-muted);cursor:pointer;padding:.25rem 0}.detection-settings summary:hover{color:var(--text-secondary)}.detection-params{margin-top:.5rem;display:flex;flex-direction:column;gap:.5rem;padding:.5rem;background:var(--bg-tertiary);border-radius:4px}.detection-params label{display:flex;align-items:center;gap:.5rem;font-size:.7rem;color:var(--text-secondary)}.detection-params label span:first-child{min-width:80px}.detection-params input[type=range]{flex:1;height:4px;-webkit-appearance:none;background:var(--border-color);border-radius:2px}.detection-params input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#2d8cf0;cursor:pointer}.detection-params .param-value{min-width:40px;text-align:right;font-family:JetBrains Mono,monospace;font-size:.65rem;color:var(--text-muted)}.preview-detection-btn{width:100%;margin-top:.5rem;padding:.375rem .75rem;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .15s ease}.preview-detection-btn:hover{border-color:#2d8cf0;color:#2d8cf0}.detection-modal{max-width:800px}.detection-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.75rem;padding:.75rem;background:var(--bg-tertiary);border-radius:4px;font-size:.75rem}.detection-legend>div{display:flex;align-items:center;gap:.5rem}.detection-legend .line{display:inline-block;width:24px;height:3px;border-radius:1px}.detection-legend .line.blue{background:#ff6464}.detection-legend .line.green{background:#0f0}.detection-legend .dot.cyan{width:10px;height:10px;border-radius:50%;background:#0ff}.detection-legend .dot.magenta{width:10px;height:10px;border-radius:50%;background:#f0f}.detection-legend .line.cyan-sel{background:#0ff}.detection-legend .line.magenta-sel{background:#f0f}.line-selection-controls{background:var(--bg-tertiary);border-radius:6px;padding:.75rem;margin-bottom:.75rem}.selection-status{display:flex;gap:.75rem;margin-bottom:.5rem}.selection-btn{flex:1;padding:.625rem 1rem;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:6px;color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease;text-align:center}.selection-btn:hover{border-color:var(--accent-primary)}.selection-btn.active{border-color:var(--accent-primary);background:var(--accent-muted);color:var(--accent-primary);box-shadow:0 0 0 3px #6366f133}.selection-btn.done{border-color:var(--accent-green);color:var(--accent-green)}.selection-hint{margin:0;font-size:.75rem;color:var(--text-muted);text-align:center}.detection-image-container{position:relative;border-radius:6px;overflow:hidden;background:#000}.detection-image-container img{display:block;width:100%;height:auto}.detection-image-container svg{position:absolute;top:0;left:0;width:100%;height:100%}.detection-footer{padding:1rem 1.25rem;background:var(--bg-elevated);border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.yardage-section{display:flex;align-items:center;gap:.5rem}.yardage-section label{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.yardage-input-group{display:flex;align-items:center}.selection-summary{flex:1;text-align:center;font-size:.875rem}.detection-actions{display:flex;gap:.625rem}.detection-btn{padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;border:none}.detection-btn.secondary{background:#333;color:#aaa;border:1px solid #555}.detection-btn.secondary:hover{background:#444;color:#fff}.detection-btn.primary{background:#333;color:#666;cursor:not-allowed}.detection-btn.primary.enabled{background:linear-gradient(135deg,#4ecdc4,#44a08d);color:#000;cursor:pointer}.detection-btn.primary.enabled:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4ecdc44d}.warped-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fade-in .2s ease}.warped-modal{background:var(--bg-card);border-radius:12px;max-width:500px;width:90%;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0000004d}.warped-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.warped-header h3{margin:0;font-family:Rajdhani,sans-serif;font-size:1rem;font-weight:600;color:var(--text-primary)}.warped-header .close-btn{width:32px;height:32px;border:none;background:var(--bg-elevated);border-radius:6px;font-size:1.25rem;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center}.warped-header .close-btn:hover{background:var(--accent-muted);color:var(--accent-primary)}.warped-content{padding:1rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.warped-content img{max-width:100%;border-radius:8px;box-shadow:var(--shadow-md)}.warped-legend{display:flex;gap:1.5rem;font-size:.75rem;color:var(--text-muted)}.warped-legend div{display:flex;align-items:center;gap:.375rem}.warped-legend .dot{width:12px;height:12px;border-radius:50%}.warped-legend .dot.release{background:#00c8ff}.warped-legend .dot.touch{background:#00ff96}.warped-legend .arrow{color:#ff0;font-weight:700}.warped-footer{padding:1rem 1.25rem;background:var(--bg-elevated);border-top:1px solid var(--border-color)}.warped-footer p{margin:0 0 .5rem;font-size:.75rem;color:var(--text-muted);line-height:1.5}.warped-footer p:last-child{margin-bottom:0}.warped-footer strong{color:var(--text-primary)}.video-preview{text-align:center;padding:1.5rem}.video-preview video{border-radius:6px;box-shadow:var(--shadow-md)}.video-preview p{margin-top:1rem;color:var(--text-muted);font-size:.875rem}.placeholder{text-align:center;color:var(--text-muted)}.placeholder .placeholder-logo{width:64px;height:64px;display:block;margin:0 auto 1rem;opacity:.4}.placeholder p{font-size:.875rem}.click-indicator{position:absolute;top:1rem;left:50%;transform:translate(-50%);background:var(--bg-card);padding:.5rem 1rem;border-radius:6px;font-size:.8125rem;border:1px solid var(--accent-primary);box-shadow:var(--shadow-md);display:flex;flex-direction:column;align-items:center;gap:.25rem}.click-indicator strong{color:var(--accent-primary)}.click-hints{font-size:.6875rem;color:var(--text-muted);opacity:.8}.click-hints kbd{background:var(--bg-elevated);padding:.1rem .3rem;border-radius:3px;font-size:.625rem;border:1px solid var(--border-color)}.point-selected-indicator{position:absolute;top:4rem;left:50%;transform:translate(-50%);background:var(--bg-elevated);padding:.5rem 1rem;border-radius:6px;font-size:.8125rem;border:2px solid #ffff00;box-shadow:var(--shadow-md);display:flex;flex-direction:column;align-items:center;gap:.25rem}.point-selected-indicator strong{color:#ff0}.analyzer-results{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1rem;overflow-y:auto;box-shadow:var(--shadow-sm)}.analyzer-results h3{margin:0 0 1rem;font-family:Rajdhani,sans-serif;font-size:.875rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.result-card{background:var(--bg-elevated);border-radius:8px;padding:1rem;margin-bottom:1rem}.verdict{text-align:center;padding:1rem;border-radius:6px;margin-bottom:1rem;font-size:1.25rem}.verdict-text{display:block;font-family:Orbitron,sans-serif;font-weight:700;font-size:.875rem;letter-spacing:.05em;margin-top:.25rem}.verdict.forward{background:#ef44441a;border:2px solid var(--accent-red);color:var(--accent-red)}.verdict.lateral-or-backward{background:#10b9811a;border:2px solid var(--accent-green);color:var(--accent-green)}.verdict.indeterminate{background:#f59e0b1a;border:2px solid var(--accent-yellow);color:var(--accent-yellow)}.result-stats{display:grid;gap:.5rem}.stat{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-subtle)}.stat:last-child{border-bottom:none}.stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.stat-value{font-family:SF Mono,monospace;font-size:.875rem;font-weight:600;color:var(--text-primary)}.stat-value.forward{color:var(--accent-red)}.stat-value.backward{color:var(--accent-green)}.interpretation{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-subtle)}.interpretation h4{margin:0 0 .5rem;font-size:.75rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.03em}.interpretation p{margin:0;font-size:.8125rem;line-height:1.6;color:var(--text-secondary)}.no-results{text-align:center;padding:1rem}.no-results p{margin-bottom:1rem;color:var(--text-muted);font-size:.875rem}.checklist{text-align:left;font-size:.8125rem;line-height:2}.checklist div{color:var(--text-muted)}.checklist div.done{color:var(--accent-green)}.about-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-subtle)}.about-section h4{margin:0 0 .5rem;font-size:.6875rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.about-section p{margin:0 0 .5rem;font-size:.75rem;line-height:1.5;color:var(--text-muted)}.precision-tips{margin:0;padding:0;list-style:none;font-size:.6875rem;color:var(--text-muted)}.precision-tips li{margin-bottom:.25rem;line-height:1.4}.precision-tips kbd{background:var(--bg-elevated);padding:.1rem .3rem;border-radius:3px;font-size:.625rem;border:1px solid var(--border-color);font-family:var(--font-mono)}.quick-steps{display:flex;flex-direction:column;gap:.375rem}.quick-steps .step{display:flex;align-items:center;gap:.5rem;font-size:.6875rem;color:var(--text-secondary)}.quick-steps .step span{width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:var(--accent-primary);color:#fff;border-radius:50%;font-size:.625rem;font-weight:700;flex-shrink:0}.quick-steps .step kbd{background:var(--bg-elevated);padding:.0625rem .25rem;border-radius:2px;font-family:SF Mono,monospace;font-size:.5625rem;border:1px solid var(--border-color);color:var(--text-secondary)}@media (max-width: 1200px){.analyzer-content{grid-template-columns:260px 1fr;grid-template-rows:1fr auto}.analyzer-results{grid-column:span 2;max-height:280px}}@media (max-width: 768px){.analyzer-content{grid-template-columns:1fr;grid-template-rows:auto 300px auto}.analyzer-controls{order:1}.analyzer-viewer{order:2;min-height:300px}.analyzer-results{order:3;grid-column:1;max-height:none}}.yt-player{width:100%;height:100%;display:flex;flex-direction:column;background:#000;border-radius:8px;overflow:hidden;position:relative;box-shadow:0 0 0 1px #ffffff0f,0 25px 80px -15px #000c}.yt-video-wrapper{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;min-height:200px;background:#000}.yt-video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;background:transparent}.yt-overlay{position:absolute;pointer-events:auto;z-index:100}.yt-overlay.clicking{cursor:crosshair}.av-club-brand{position:absolute;bottom:16px;right:16px;display:flex;align-items:center;gap:8px;opacity:.4;transition:opacity .3s ease;pointer-events:none;z-index:5}.yt-player:hover .av-club-brand{opacity:.6}.av-club-brand span{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:11px;font-weight:600;letter-spacing:.2em;color:#fff;text-transform:uppercase}.yt-zoom-controls{position:absolute;top:16px;right:16px;display:flex;align-items:center;gap:4px;background:#000000bf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:4px;border-radius:6px;z-index:10;opacity:0;transform:translateY(-4px);transition:all .2s ease}.yt-player:hover .yt-zoom-controls{opacity:1;transform:translateY(0)}.yt-zoom-controls button{background:transparent;border:none;color:#fffc;width:28px;height:28px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.yt-zoom-controls button:hover{background:#ffffff1a;color:#fff}.yt-zoom-controls span{min-width:42px;text-align:center;font-family:SF Mono,Monaco,monospace;font-size:11px;color:#fff9;padding:0 4px}.yt-frame-info{position:absolute;top:16px;left:16px;display:flex;align-items:center;gap:8px;background:#000000bf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:6px 12px;border-radius:6px;font-family:SF Mono,Monaco,monospace;font-size:12px;color:#ffffffe6;z-index:10;opacity:0;transform:translateY(-4px);transition:all .2s ease;pointer-events:none}.yt-player:hover .yt-frame-info{opacity:1;transform:translateY(0)}.yt-frame-info .tag-release,.yt-frame-info .tag-touch,.yt-frame-info .tag-enhanced{padding:2px 8px;border-radius:3px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.yt-frame-info .tag-release{background:#f59e0b;color:#000}.yt-frame-info .tag-touch{background:#10b981;color:#000}.yt-frame-info .tag-enhanced{background:#6366f1;color:#fff}.yt-controls{background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.6) 60%,transparent 100%);padding:40px 12px 8px;position:absolute;bottom:0;left:0;right:0;opacity:0;transition:opacity .25s ease;pointer-events:none;z-index:15}.yt-controls>*{pointer-events:auto}.yt-player:hover .yt-controls{opacity:1}.yt-progress-container{height:20px;display:flex;align-items:flex-end;cursor:pointer;margin-bottom:6px}.yt-progress-bar{position:relative;width:100%;height:3px;background:#ffffff4d;transition:height .1s ease}.yt-progress-container:hover .yt-progress-bar{height:5px}.yt-progress-played{position:absolute;bottom:0;left:0;height:100%;background:red;pointer-events:none}.yt-progress-container:hover .yt-progress-played{background:red}.yt-progress-thumb{position:absolute;bottom:50%;transform:translate(-50%,50%) scale(0);width:13px;height:13px;background:red;border-radius:50%;pointer-events:none;transition:transform .1s ease}.yt-progress-container:hover .yt-progress-thumb{transform:translate(-50%,50%) scale(1)}.yt-progress-input{position:absolute;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;margin:0}.yt-marker{position:absolute;bottom:-2px;transform:translate(-50%);width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:#000;cursor:pointer;z-index:5;transition:all .15s ease}.yt-progress-container:hover .yt-marker{bottom:0;width:16px;height:16px}.yt-marker:hover{transform:translate(-50%) scale(1.3)}.yt-marker.release{background:#fbbf24}.yt-marker.touch{background:#34d399}.yt-buttons{display:flex;align-items:center;justify-content:space-between;height:36px}.yt-left,.yt-center,.yt-right{display:flex;align-items:center}.yt-left{gap:4px}.yt-center{position:absolute;left:50%;transform:translate(-50%)}.yt-right{gap:8px}.yt-btn{background:none;border:none;color:#fff;width:36px;height:36px;border-radius:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .1s ease;padding:0}.yt-btn svg{width:24px;height:24px;fill:currentColor}.yt-btn:hover{opacity:.8}.yt-btn:active{opacity:.6}.yt-btn.yt-play{width:40px;height:40px}.yt-btn.yt-play svg{width:28px;height:28px}.yt-btn.yt-step{width:32px;height:32px;opacity:.8}.yt-btn.yt-step svg{width:20px;height:20px}.yt-time{font-family:Roboto,Arial,sans-serif;font-size:13px;color:#fff;margin-left:8px;white-space:nowrap}.yt-time .separator{color:#ffffff80;margin:0 4px}.yt-frame-counter{display:flex;align-items:center;gap:6px;color:#ffffffe6;font-family:Roboto,Arial,sans-serif;font-size:13px}.yt-frame-input{width:50px;background:transparent;border:none;color:#fff;padding:4px;font-family:Roboto,Arial,sans-serif;font-size:13px;text-align:center;border-radius:2px;transition:background .15s ease}.yt-frame-input:hover{background:#ffffff1a}.yt-frame-input:focus{outline:none;background:#ffffff26}.yt-frame-input::-webkit-inner-spin-button,.yt-frame-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.yt-fps{font-size:11px;color:#ffffff80;font-family:Roboto,Arial,sans-serif}.yt-click-mode{position:absolute;bottom:100px;right:24px;background:#000000d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:#fff;padding:16px 28px;border-radius:8px;font-size:14px;text-align:right;z-index:150;pointer-events:none;animation:fade-in-scale .2s ease;border:1px solid rgba(255,255,255,.1);box-shadow:0 10px 40px #00000080}@keyframes fade-in-scale{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.yt-click-mode strong{display:block;color:#fbbf24;font-size:16px;font-weight:600;margin-bottom:4px}.yt-click-mode.editing strong{color:#a78bfa}.yt-click-mode small{display:block;font-size:11px;color:#ffffff80}.telestrator-bar{position:absolute;bottom:70px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:#000000d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:6px 12px;border-radius:8px;opacity:0;transition:opacity .25s ease;z-index:15}.yt-player:hover .telestrator-bar,.telestrator-bar.active{opacity:1}.tele-toggle{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:none;border-radius:4px;color:#fffc;font-family:Roboto,Arial,sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease}.tele-toggle:hover{background:#ffffff1a;color:#fff}.tele-toggle.on{background:red;color:#fff}.tele-toggle svg{width:16px;height:16px}.tele-divider{width:1px;height:24px;background:#ffffff26}.tele-tools{display:flex;gap:2px}.tele-tool{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;font-size:16px;color:#ffffffb3;cursor:pointer;transition:all .1s ease}.tele-tool:hover{color:#fff}.tele-tool.active{background:#ffffff26;color:#fff}.tele-colors{display:flex;gap:4px;padding:0 4px}.tele-color{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .1s ease;box-shadow:0 0 0 1px #0000004d inset}.tele-color:hover{transform:scale(1.15)}.tele-color.active{border-color:#fff;box-shadow:0 0 8px #ffffff4d}.tele-width{display:flex;align-items:center;gap:8px;padding:0 8px}.tele-width input[type=range]{width:60px;height:4px;-webkit-appearance:none;background:#fff3;border-radius:2px;cursor:pointer}.tele-width input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 1px 4px #0000004d}.tele-width span{font-size:11px;color:#ffffff80;min-width:20px}.tele-actions{display:flex;gap:2px}.tele-action{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;font-size:14px;color:#fff9;cursor:pointer;transition:all .1s ease}.tele-action:hover{background:#ffffff1a;color:#fff}.tele-count{font-size:11px;color:#fff9;padding:0 8px}.yt-overlay.drawing{cursor:crosshair!important}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a0a0f,#1a1a2e,#16213e);padding:20px}.login-card{background:#14141ef2;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:48px;width:100%;max-width:400px;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff0d}.login-header{text-align:center;margin-bottom:36px}.login-logo{width:64px;height:64px;display:block;margin:0 auto 16px;filter:drop-shadow(0 0 20px rgba(99,102,241,.4))}.login-header h1{font-family:Space Grotesk,Inter,system-ui,sans-serif;font-size:28px;font-weight:700;color:#fff;margin:0 0 8px;letter-spacing:-.5px}.login-header p{color:#ffffff80;font-size:14px;margin:0;text-transform:uppercase;letter-spacing:2px}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:8px;font-size:14px;text-align:center}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:500;color:#ffffffb3;text-transform:uppercase;letter-spacing:1px}.form-group input{padding:14px 16px;font-size:16px;border:1px solid rgba(255,255,255,.15);border-radius:8px;background:#0000004d;color:#fff;transition:all .2s ease}.form-group input:focus{outline:none;border-color:#ff8c00;box-shadow:0 0 0 3px #ff8c0026;background:#00000080}.form-group input::placeholder{color:#ffffff4d}.form-group input:disabled{opacity:.5;cursor:not-allowed}.login-button{margin-top:8px;padding:16px 24px;font-size:15px;font-weight:600;text-transform:uppercase;letter-spacing:1px;border:none;border-radius:8px;background:linear-gradient(135deg,#ff8c00,#ff6b00);color:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #ff8c004d}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff8c0066}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{margin-top:32px;text-align:center}.login-footer p{color:#ffffff4d;font-size:12px;margin:0}@media (max-width: 480px){.login-card{padding:32px 24px}.login-header h1{font-size:24px}}.toast{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;border-radius:8px;background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:var(--shadow-md);animation:toast-in .2s ease;font-size:.875rem;min-width:240px;max-width:360px}@keyframes toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{font-size:1rem;flex-shrink:0}.toast-message{flex:1;color:var(--text-primary)}.toast-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;font-size:.875rem}.toast-close:hover{color:var(--text-secondary)}.toast.success{border-left:3px solid var(--accent-green)}.toast.success .toast-icon{color:var(--accent-green)}.toast.error{border-left:3px solid var(--accent-red)}.toast.error .toast-icon{color:var(--accent-red)}.toast.warning{border-left:3px solid var(--accent-yellow)}.toast.warning .toast-icon{color:var(--accent-yellow)}.toast.info{border-left:3px solid var(--accent-primary)}.toast.info .toast-icon{color:var(--accent-primary)}*{margin:0;padding:0;box-sizing:border-box}*,*:before,*:after{user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important}button,input[type=submit],input[type=button]{user-select:none!important;-webkit-user-select:none!important}:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-elevated: #f1f5f9;--bg-input: #ffffff;--text-primary: #1e3a5f;--text-secondary: #475569;--text-muted: #94a3b8;--accent-primary: #6366f1;--accent-hover: #4f46e5;--accent-muted: rgba(99, 102, 241, .1);--accent-green: #10b981;--accent-red: #ef4444;--accent-yellow: #f59e0b;--accent-cyan: #06b6d4;--border-color: #e2e8f0;--border-subtle: #f1f5f9;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);font-size:14px;line-height:1.5}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-elevated)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-primary);color:#fff}code{font-family:SF Mono,Fira Code,monospace;font-size:13px;background:var(--bg-elevated);padding:2px 6px;border-radius:4px;color:var(--accent-primary)}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
