:root{--bg-primary: #0f1117;--bg-secondary: #1a1d27;--bg-card: #222533;--bg-hover: #2a2d3d;--border: #2e3142;--text-primary: #e4e6f0;--text-secondary: #8b8fa3;--text-dim: #5c5f72;--accent: #3b82f6;--accent-hover: #2563eb;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--info: #06b6d4}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.5rem 0;flex-shrink:0}.sidebar-header{padding:0 1.25rem 1.5rem;border-bottom:1px solid var(--border)}.sidebar-header h2{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.sidebar-header .subtitle{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.nav-links{list-style:none;padding:1rem 0;flex:1}.nav-links a{display:block;padding:.625rem 1.25rem;color:var(--text-secondary);text-decoration:none;font-size:.875rem;transition:all .15s}.nav-links a:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-links a.active{color:var(--accent);background:#3b82f61a;border-right:2px solid var(--accent)}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--border)}.user-info{margin-bottom:.75rem}.user-email{display:block;font-size:.813rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.688rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.main-content{flex:1;padding:2rem;overflow-y:auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-header h1{font-size:1.5rem;font-weight:600}.btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .15s}.btn:hover{background:var(--bg-hover)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-danger{color:var(--danger);border-color:var(--danger);background:transparent}.btn-danger:hover{background:#ef44441a}.btn-sm{padding:.25rem .625rem;font-size:.813rem}.btn-xs{padding:.125rem .5rem;font-size:.75rem}.btn-full{width:100%;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed}.stats{display:flex;gap:1.5rem}.stat{font-size:.875rem;color:var(--text-secondary)}.stat-value{font-weight:700;color:var(--text-primary);margin-right:.25rem}.stream-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-bottom:2rem}.stream-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:all .15s}.stream-card.online{cursor:pointer}.stream-card.online:hover{border-color:var(--accent);transform:translateY(-1px)}.stream-card-preview{aspect-ratio:16 / 9;background:var(--bg-primary);display:flex;align-items:center;justify-content:center}.live-indicator{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--danger)}.live-dot{width:8px;height:8px;background:var(--danger);border-radius:50%;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.offline-indicator{font-size:.813rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.stream-card-info{padding:.75rem 1rem}.stream-card-info h3{font-size:.938rem;font-weight:500;margin-bottom:.125rem}.drone-model{font-size:.75rem;color:var(--text-secondary)}.video-player{position:relative;background:#000;border-radius:8px;overflow:hidden}.video-player video{width:100%;display:block}.video-overlay{position:absolute;top:.75rem;right:.75rem;display:flex;gap:.5rem}.badge{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:4px;font-size:.688rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-good{background:#22c55e26;color:var(--success)}.badge-warn{background:#f59e0b26;color:var(--warning)}.badge-error{background:#ef444426;color:var(--danger)}.badge-info{background:#06b6d426;color:var(--info)}.badge-dim{background:#5c5f7226;color:var(--text-dim)}.stream-view-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.stream-meta{flex:1}.stream-meta h1{font-size:1.25rem}.stream-stats{display:flex;align-items:center;gap:.75rem}.stream-view-player{border-radius:8px;overflow:hidden}.no-stream{aspect-ratio:16 / 9;background:var(--bg-card);display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;color:var(--text-secondary)}.no-stream .hint{font-size:.813rem;color:var(--text-dim);margin-top:.5rem}.data-table{width:100%;border-collapse:collapse;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden}.data-table th,.data-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.data-table th{background:var(--bg-secondary);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-secondary)}.data-table td{font-size:.875rem}.data-table tr:last-child td{border-bottom:none}.row-inactive{opacity:.5}.stream-key-cell{display:flex;align-items:center;gap:.5rem}.stream-key-cell code{font-size:.75rem;background:var(--bg-primary);padding:.125rem .375rem;border-radius:3px}.role-select{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);padding:.25rem .5rem;border-radius:4px;font-size:.813rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.813rem;font-weight:500;color:var(--text-secondary);margin-bottom:.375rem}input[type=text],input[type=email],input[type=password]{width:100%;padding:.625rem .75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.875rem;transition:border-color .15s}input:focus{outline:none;border-color:var(--accent)}.inline-form{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1.5rem}.form-row{display:flex;gap:.75rem;align-items:center}.form-row input,.form-row select{flex:1}.form-row select{background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);padding:.625rem .75rem;border-radius:6px;font-size:.875rem}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary)}.login-card{width:100%;max-width:380px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:2.5rem}.login-card h1{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.login-subtitle{color:var(--text-secondary);font-size:.875rem;margin-bottom:2rem}.alert{padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem}.alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--danger)}.alert-success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:var(--success)}.alert-success p{margin:.5rem 0}.rtmp-url{display:block;background:var(--bg-primary);padding:.5rem .75rem;border-radius:4px;font-size:.813rem;word-break:break-all;margin:.5rem 0;color:var(--text-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;width:90%;max-width:800px;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.playback-video{width:100%;display:block}.loading{display:flex;align-items:center;justify-content:center;padding:4rem;color:var(--text-secondary)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state .btn{margin-top:1rem}.error-state{text-align:center;padding:4rem 2rem;color:var(--danger)}.recording-group{margin-bottom:2rem}.recording-group h2{font-size:1.125rem;margin-bottom:.75rem}.no-segments{color:var(--text-dim);font-size:.875rem}section{margin-bottom:2rem}section h2{font-size:1rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.75rem}.publish-page{max-width:900px}.publish-controls{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem;margin-bottom:1rem}.control-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.control-row:last-child{margin-bottom:0}.control-row label{font-size:.813rem;font-weight:600;color:var(--text-secondary);min-width:60px}.control-row select{flex:1;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);padding:.5rem .75rem;border-radius:6px;font-size:.875rem}.publish-buttons{justify-content:flex-start;padding-top:.25rem}.publish-preview{position:relative;background:#000;border-radius:8px;overflow:hidden;aspect-ratio:16 / 9}.publish-preview video{width:100%;height:100%;object-fit:contain}.publish-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--text-dim)}.publish-stats{position:absolute;bottom:0;left:0;right:0;display:flex;gap:1.5rem;padding:.75rem 1rem;background:linear-gradient(transparent,#000c)}.stat-item{display:flex;flex-direction:column}.stat-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.stat-val{font-size:.875rem;font-weight:600;color:#fff}.live-badge{display:inline-flex;align-items:center;gap:.375rem}.url-panel{margin-top:1.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem}.url-panel h3{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.url-grid{display:flex;flex-direction:column;gap:.5rem}.url-row{display:flex;align-items:center;gap:.75rem}.url-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);min-width:100px}.url-value{flex:1;font-size:.688rem;background:var(--bg-primary);padding:.375rem .5rem;border-radius:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-dim)}.embed-page{width:100vw;height:100vh;background:#000;display:flex;align-items:center;justify-content:center}.embed-page .video-player{width:100%;height:100%}.embed-page video{width:100%;height:100%;object-fit:contain}.embed-error{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;background:#000;color:var(--text-secondary)}.hint{font-size:.813rem;color:var(--text-dim);margin-top:.5rem}@media (max-width: 768px){.sidebar{width:200px}.main-content{padding:1rem}.stream-grid{grid-template-columns:1fr}.form-row{flex-direction:column}}
