@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Sora:wght@400;500;600;700&display=swap";.card{background:var(--panel-strong);border-radius:16px;padding:1.25rem;border:1px solid var(--border);box-shadow:var(--shadow)}.badge{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:999px;font-weight:600;font-size:.8rem;letter-spacing:.01em;background:#ffffff14;color:var(--color-text-primary)}.badge:before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;opacity:.8}.badge-success{color:var(--color-success);background:#2fd68e24}.badge-danger{color:var(--color-danger);background:#ff647626}.badge-neutral{color:var(--color-text-muted);background:#9aa3b226}.btn{border:none;border-radius:12px;padding:.85rem 1.25rem;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .16s ease;font-size:.95rem;display:inline-flex;align-items:center;gap:.5rem}.btn:hover:enabled{transform:translateY(-1px);box-shadow:0 12px 30px #00000059}.btn:active:enabled{transform:translateY(0);box-shadow:0 6px 16px #0006}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);color:#04121f}.btn-danger{background:linear-gradient(135deg,var(--color-danger-light) 0%,var(--color-danger) 100%);color:#2a0308}.btn-ghost{background:var(--panel-soft);color:var(--color-text-primary);border:1px solid var(--border)}.input-field{display:flex;flex-direction:column;gap:.5rem;width:100%}.input-meta{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem}.input-label{font-weight:600;color:var(--color-text-primary);font-size:.9rem;letter-spacing:.01em}.input-description{color:var(--color-text-secondary);font-size:.8rem}.input-control{border-radius:12px;border:1px solid var(--border);padding:.75rem .9rem;font-size:.95rem;background:#0c0e14e6;color:var(--color-text-primary);transition:border .12s ease,box-shadow .12s ease}.input-control:focus{outline:none;border-color:#5cc8ffb3;box-shadow:0 0 0 3px #5cc8ff33}.stream-config-item{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:.6rem;transition:all .2s ease;cursor:grab;position:relative}.stream-config-item:active{cursor:grabbing}.stream-config-item:hover{border-color:#5cc8ff4d;background:#ffffff0d}.stream-config-item:before,.stream-config-item:after{content:"";position:absolute;left:.75rem;right:.75rem;height:2px;border-radius:999px;background:var(--color-primary-light);opacity:0;pointer-events:none;transition:opacity .15s ease}.stream-config-item.drop-before:before{top:-1px;opacity:1}.stream-config-item.drop-after:after{bottom:-1px;opacity:1}.stream-config-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;gap:.35rem}.stream-config-header .drag-handle{cursor:grab;font-size:1rem;color:var(--color-text-tertiary);-webkit-user-select:none;user-select:none;padding:.15rem .2rem;border-radius:.4rem;opacity:0;transition:color .15s ease,background-color .15s ease,opacity .15s ease;letter-spacing:-1px}.stream-config-item:hover .drag-handle,.stream-config-item:focus-within .drag-handle{opacity:1}.stream-config-header .drag-handle:hover{color:var(--color-text-primary);background:#5cc8ff1f}.stream-config-toggle{display:flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--color-text-primary);cursor:pointer;font-size:.95rem;font-weight:600;padding:0;flex:1;text-align:left}.stream-config-toggle:hover{color:var(--color-primary-light)}.toggle-icon{font-size:.7rem;transition:transform .2s ease}.toggle-icon-wrapper{position:relative;display:inline-flex;align-items:center;justify-content:center}.toggle-tooltip{position:absolute;top:120%;left:0;padding:.35rem .6rem;background:#0f131b;color:#fff;border-radius:.4rem;font-size:.75rem;white-space:nowrap;box-shadow:0 8px 24px #0f1b2d29;opacity:0;transform:translateY(-4px);transition:opacity .15s ease,transform .15s ease;pointer-events:none}.toggle-tooltip:after{content:"";position:absolute;top:-4px;left:10px;width:8px;height:8px;background:#0f131b;transform:rotate(45deg);border-radius:2px}.stream-config-toggle:hover .toggle-tooltip,.toggle-icon-wrapper:hover .toggle-tooltip{opacity:1;transform:translateY(0)}.stream-title{flex:1}.stream-actions{display:flex;align-items:center;gap:.5rem}.delete-btn{padding:.25rem .5rem;font-size:1rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.stream-config-content{padding:1rem;display:flex;flex-direction:column;gap:1rem;border-top:1px solid rgba(255,255,255,.05)}.config-panel{display:flex;flex-direction:column;gap:1.1rem}.config-panel__actions{display:flex;gap:.5rem;justify-content:flex-end}.config-streams{display:flex;flex-direction:column;gap:.75rem}.status-bar{display:flex;align-items:center;gap:.75rem;color:var(--color-text-primary);font-weight:600}.status-bar__text{color:var(--color-text-secondary);font-size:.9rem}.layout-switcher{display:flex;flex-direction:column;gap:4px;width:100%}.layout-switcher__buttons{display:flex;flex-wrap:wrap;gap:4px}.layout-switcher__btn{flex:1 1 auto;min-width:56px;padding:4px 8px;font-size:12px;line-height:1.4;color:#cbd5e1;background:#1e293bb3;border:1px solid rgba(148,163,184,.3);border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.layout-switcher__btn:hover:not(:disabled){background:#334155e6;border-color:#94a3b899}.layout-switcher__btn.is-active{color:#fff;background:#2563eb;border-color:#2563eb}.layout-switcher__btn:disabled{opacity:.6;cursor:default}.layout-switcher__note{font-size:11px;color:#fbbf24}.video-player{display:flex;flex-direction:column;gap:1rem;height:100%}.video-surface{position:relative;flex:1;min-height:340px;width:100%;background:#05070b;border-radius:16px;overflow:hidden;border:1px solid var(--border-strong);box-shadow:inset 0 0 25px #000000b3}.video-element{width:100%;height:100%;display:block;object-fit:contain;background:#05070b}.video-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#5cc8ff1a,#0d121ce6);color:var(--color-text-secondary);font-size:1rem}.placeholder-content{text-align:center;padding:1.5rem;letter-spacing:.01em}.tap-to-play{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:#05070bb8;color:#fff;border:none;cursor:pointer;z-index:2}.tap-to-play-icon{font-size:3rem;line-height:1}.tap-to-play-label{font-size:1.1rem;font-weight:600;letter-spacing:.02em}.player-footer{display:flex;align-items:center;gap:1rem;justify-content:space-between;flex-wrap:wrap}.player-action{min-width:150px}.debug-stats{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.72rem;line-height:1.4;color:var(--color-text-secondary);background:#0d121cd9;border:1px solid var(--border-strong);border-radius:8px;padding:.5rem .7rem;word-break:break-all}.error-message{padding:.85rem 1rem;background:#ff64761f;color:var(--color-text-error);border-radius:10px;border:1px solid rgba(255,100,118,.3);font-weight:600}@media(min-width:1280px){.video-surface{min-height:450px}}.video-grid{display:grid;gap:.9rem;height:100%;width:100%}.video-grid-empty{display:flex;align-items:center;justify-content:center;min-height:260px;border:1px dashed rgba(255,255,255,.12);border-radius:14px;background:#0c0e1499}.empty-state{color:var(--color-text-tertiary);font-size:1.05rem}.video-grid-1{grid-template-columns:1fr;grid-template-rows:1fr}.video-grid-2{grid-template-columns:1fr 1fr;grid-template-rows:1fr}.video-grid-3{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.video-grid-3 .video-grid-item-1{grid-column:1 / -1}.video-grid-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.video-grid-item{display:flex;flex-direction:column;min-height:0;min-width:0;background:#080a0ecc;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.06);box-shadow:inset 0 0 12px #0009}@media(max-width:768px){.video-grid-2,.video-grid-3,.video-grid-4{grid-template-columns:1fr;grid-template-rows:repeat(auto-fit,minmax(200px,1fr))}.video-grid-3 .video-grid-item-1{grid-column:1}}.main-shell{min-height:100vh;background:radial-gradient(circle at 15% 10%,var(--color-gradient-1),transparent 45%),radial-gradient(circle at 85% 15%,var(--color-gradient-2),transparent 40%),linear-gradient(145deg,#0d0f13,#11141a 45%,#0c0f15);position:relative;overflow:hidden}.main-shell:before{content:"";position:absolute;inset:0;background-image:linear-gradient(transparent 95%,#ffffff0d),linear-gradient(90deg,transparent 95%,rgba(255,255,255,.04) 100%);background-size:40px 40px;opacity:.2;pointer-events:none}.backdrop{position:absolute;inset:0;background:radial-gradient(circle at 15% 80%,rgba(0,208,255,.12),transparent 60%),radial-gradient(circle at 85% 80%,rgba(70,124,255,.2),transparent 55%);filter:blur(140px);transform:scale(1.1);pointer-events:none}.main-layout{position:relative;min-height:100vh;height:100vh;display:grid;grid-template-rows:auto 1fr auto;gap:1.2rem;padding:1.2rem 1.6rem .9rem;z-index:1}.layout-controls{position:fixed;top:1.1rem;right:2rem;display:flex;gap:.6rem;z-index:6}.layout-toggle{border:1px solid var(--border);background:#0f1116e6;color:var(--color-text-primary);border-radius:999px;padding:.4rem .85rem;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease;box-shadow:0 10px 24px #00000040}.layout-toggle:hover{transform:translateY(-1px);border-color:#5cc8ff80}.layout-toggle.is-collapsed{background:#5cc8ff26;border-color:#5cc8ff99}.main-header{display:flex;align-items:center;gap:1.2rem;padding:.85rem 1.4rem;background:var(--panel);border-radius:18px;border:1px solid var(--border);box-shadow:var(--shadow);position:sticky;top:1rem;z-index:3}.main-header:after{content:"";margin-left:auto;width:140px;height:30px;border-radius:999px;background:linear-gradient(120deg,#5cc8ff66,#3d7dff1a);border:1px solid rgba(92,200,255,.4);box-shadow:inset 0 0 12px #5cc8ff4d;opacity:.6}.main-content{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:1.5rem;align-items:stretch;min-height:0;height:100%}.main-layout.header-collapsed .main-header{display:none}.main-layout.sidebar-collapsed .main-content{grid-template-columns:1fr}.main-layout.header-collapsed{padding-top:.7rem;padding-bottom:.7rem}.main-layout.no-sidebar .main-content{grid-template-columns:1fr}.main-sidebar{display:flex;flex-direction:column;gap:1rem;background:var(--panel);border-radius:18px;padding:1.2rem;border:1px solid var(--border);box-shadow:var(--shadow);overflow:auto;animation:rise .4s ease both}.main-body{display:flex;flex-direction:column;gap:1.2rem;min-height:0;height:100%;flex:1}.main-footer{padding:.5rem .8rem;color:var(--color-text-tertiary);font-weight:500;font-size:.85rem;text-align:right}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1100px){.main-content{grid-template-columns:1fr}.main-sidebar{order:2}.main-header{position:relative;top:0}.main-header:after{display:none}}@media(max-width:720px){.main-layout{padding:1rem}.layout-controls{right:1rem;top:.85rem;flex-direction:column;align-items:flex-end}}.topbar{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;width:100%}.topbar-left{display:flex;flex-direction:column;gap:.35rem}.topbar-subtitle{margin:0;color:var(--color-text-tertiary);font-weight:500;font-size:.9rem}.topbar-right{display:flex;align-items:center;gap:.8rem}.topbar-meta{display:flex;flex-direction:column;gap:.2rem;text-align:right}.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;color:var(--color-primary-light);margin:0}.sidebar-panel{display:flex;flex-direction:column;gap:1rem;height:100%;overflow:hidden}.sidebar-header{display:flex;flex-direction:column;gap:.35rem}.sidebar-subtitle{margin:0;color:var(--color-text-tertiary);font-size:.85rem}.video-card{display:flex;flex-direction:column;gap:1rem;height:100%;background:transparent;border-radius:14px;padding:0;border:none;box-shadow:none}.meta-label{text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;color:var(--color-text-secondary)}.meta-value{font-weight:600;color:var(--color-text-primary);max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-user{display:flex;align-items:center;gap:12px;margin-left:16px;padding-left:16px;border-left:1px solid var(--border)}.topbar-username{font-size:.85rem;color:var(--text-secondary)}.topbar-link{font-size:.8rem;color:var(--primary);text-decoration:none}.topbar-link:hover{text-decoration:underline}.topbar-logout{background:none;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;padding:4px 8px;border-radius:4px}.topbar-logout:hover{color:var(--danger);background:#ff64761a}@media(max-width:900px){.topbar{flex-direction:column;align-items:flex-start}.topbar-right{width:100%;justify-content:space-between}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary)}.login-card{background:var(--bg-light);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:400px}.login-header{margin-bottom:32px}.login-header h1{font-family:var(--font-header);font-size:1.5rem;color:var(--text-primary);margin:8px 0 0}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.login-field input{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text-primary);font-size:.95rem;outline:none;transition:border-color .2s}.login-field input:focus{border-color:var(--primary)}.login-error{background:#ff64761a;border:1px solid var(--danger);border-radius:8px;padding:10px 14px;color:var(--text-error);font-size:.85rem}.login-form .btn{width:100%;margin-top:8px}.admin-layout{display:flex;min-height:100vh;background:var(--bg-primary)}.admin-sidebar{width:240px;background:var(--bg-light);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 16px;flex-shrink:0}.admin-sidebar-header{margin-bottom:32px}.admin-sidebar-header h2{font-family:var(--font-header);font-size:1.2rem;color:var(--text-primary);margin:8px 0 0}.admin-nav{display:flex;flex-direction:column;gap:4px}.admin-nav-link{display:block;padding:10px 14px;border-radius:8px;color:var(--text-secondary);text-decoration:none;font-size:.9rem;transition:all .15s}.admin-nav-link:hover{background:var(--bg-primary);color:var(--text-primary)}.admin-nav-link.active{background:#3d7dff1a;color:var(--primary);font-weight:500}.admin-sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:12px;padding-top:16px;border-top:1px solid var(--border)}.admin-user-info{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;color:var(--text-tertiary)}.admin-logout-btn{background:none;border:none;color:var(--danger);cursor:pointer;font-size:.8rem;padding:4px 8px;border-radius:4px}.admin-logout-btn:hover{background:#ff64761a}.admin-main{flex:1;padding:32px;overflow-y:auto}.modal-overlay{position:fixed;inset:0;background:#050b14b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:var(--panel-strong);border-radius:14px;box-shadow:0 20px 60px #00000073;max-width:520px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .2s ease-out;border:1px solid var(--border)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.4rem 1rem;border-bottom:1px solid rgba(255,255,255,.08)}.modal-title{margin:0;font-size:1.3rem;color:var(--color-text-primary);font-weight:600}.modal-close{background:none;border:none;font-size:1.4rem;color:var(--color-text-secondary);cursor:pointer;padding:.25rem .5rem;line-height:1;transition:color .2s ease,background .2s ease;border-radius:6px}.modal-close:hover{color:var(--color-text-primary);background:#ffffff14}.modal-content{padding:1.25rem 1.4rem 1.4rem;overflow-y:auto;flex:1}@media(max-width:640px){.modal-container{max-width:100%;max-height:95vh}.modal-header{padding:1rem 1rem .75rem}.modal-title{font-size:1.15rem}.modal-content{padding:1rem}}.admin-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.admin-page-header h1{font-family:var(--font-header);font-size:1.4rem;color:var(--text-primary)}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{text-align:left;padding:10px 14px;color:var(--text-tertiary);font-weight:500;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.admin-table td{padding:12px 14px;color:var(--text-primary);border-bottom:1px solid var(--border)}.admin-table tbody tr:hover{background:#ffffff05}.action-cell{display:flex;gap:8px}.action-cell .btn{padding:4px 12px;font-size:.8rem}.mono{font-family:monospace;font-size:.85rem}.small{font-size:.8rem;color:var(--text-tertiary)}.role-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:.75rem;font-weight:500}.role-admin{background:#3d7dff26;color:var(--primary)}.role-user{background:#2fd68e26;color:var(--accent)}.status-dot{display:inline-flex;align-items:center;gap:6px;font-size:.85rem}.status-dot:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%}.status-dot.online:before{background:var(--success)}.status-dot.offline:before{background:var(--text-muted)}.modal-form{display:flex;flex-direction:column;gap:16px}.modal-form label{display:flex;flex-direction:column;gap:4px;font-size:.85rem;color:var(--text-secondary)}.modal-form input,.modal-form select{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text-primary);font-size:.9rem}.modal-form input:focus,.modal-form select:focus{outline:none;border-color:var(--primary)}.modal-error{background:#ff64761a;border:1px solid var(--danger);border-radius:8px;padding:8px 12px;color:var(--text-error);font-size:.85rem}.assignment-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px}.assignment-layout h3{font-family:var(--font-header);font-size:1rem;color:var(--text-primary);margin-bottom:12px}.assignment-list{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.assignment-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-light);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:.9rem;text-align:left;transition:all .15s}.assignment-item:hover{border-color:var(--primary)}.assignment-item.selected{background:#3d7dff1a;border-color:var(--primary)}.assignment-checkbox{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-light);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.assignment-checkbox:hover{border-color:var(--primary)}.assignment-checkbox input[type=checkbox]{accent-color:var(--primary);width:16px;height:16px}.assignment-robot-info{display:flex;flex-direction:column;gap:2px}.assignment-placeholder{color:var(--text-muted);font-size:.9rem;padding:20px;text-align:center}*{box-sizing:border-box}:root{--color-text-primary: #e6edf3;--color-text-secondary: #a7b0bf;--color-text-tertiary: #8a95a7;--color-text-muted: #667085;--color-text-light: #c7d1e0;--color-text-error: #ffd1d7;--color-bg-primary: #0e1014;--color-bg-light: #151922;--color-bg-pink-light: #2a0f18;--color-bg-dark: #05070b;--color-bg-dark-blue: #0f1621;--color-primary: #3d7dff;--color-primary-light: #5cc8ff;--color-accent: #2fd68e;--color-success: #2fd68e;--color-danger: #ff6476;--color-danger-light: #ff8f9f;--color-danger-dark: #c61f3a;--color-gradient-1: rgba(92, 200, 255, .12);--color-gradient-2: rgba(61, 125, 255, .18);--color-gradient-3: #0b0f15;--panel: #171b22;--panel-strong: #1d2330;--panel-soft: rgba(255, 255, 255, .04);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--shadow: 0 22px 45px rgba(3, 10, 20, .55);font-family:Sora,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--color-text-primary);background-color:var(--color-bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:var(--color-bg-primary)}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2;font-family:Space Grotesk,Sora,sans-serif}button{font-family:inherit}@media(min-width:1024px){body{overflow:hidden}}
