html,body,#root{width:100%;height:100%;margin:0}body{min-width:320px}:root{--bg-primary: #0b0f19;--bg-secondary: #111827;--bg-tertiary: #1f2937;--bg-card: #1a2234;--border-color: #2d3748;--border-light: #374151;--text-primary: #f9fafb;--text-secondary: #9ca3af;--text-muted: #6b7280;--accent-blue: #3b82f6;--accent-green: #10b981;--accent-red: #ef4444;--accent-yellow: #f59e0b;--accent-purple: #8b5cf6;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.login-app{background:linear-gradient(135deg,#0b0f19,#1a1f2e,#0f1419)}.login-container{flex:1;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:48px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.logo-icon{font-size:32px}.login-logo h1{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--accent-blue) 0%,var(--accent-purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px;font-size:14px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-secondary);font-size:13px}.form-group input{width:100%;padding:12px 16px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);font-size:15px;transition:all .2s}.form-group input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.form-group input::placeholder{color:var(--text-muted)}.login-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--accent-blue) 0%,var(--accent-purple) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;font-size:15px;cursor:pointer;transition:all .2s;margin-top:8px}.login-btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px -4px #3b82f666}.login-hint{margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color);text-align:center}.login-hint p{color:var(--text-muted);font-size:12px}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0 24px;display:flex;justify-content:space-between;align-items:center;height:64px;flex-shrink:0}.header-left{display:flex;align-items:center;gap:16px}.brand{display:flex;align-items:center;gap:10px}.brand-icon{font-size:24px}.brand h1{font-size:22px;font-weight:700;background:linear-gradient(135deg,var(--accent-blue) 0%,var(--accent-purple) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.status-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase}.status-badge.connected{background:#10b9811a;color:var(--accent-green);border:1px solid rgba(16,185,129,.2)}.status-badge.disconnected{background:#ef44441a;color:var(--accent-red);border:1px solid rgba(239,68,68,.2)}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.header-right{display:flex;align-items:center;gap:16px}.user-info{text-align:right}.user-name{display:block;font-weight:600;color:var(--text-primary);font-size:14px}.user-role{display:block;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.logout-btn{padding:8px 16px;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-light);border-radius:var(--radius-sm);font-weight:500;font-size:13px;cursor:pointer;transition:all .2s}.logout-btn:hover{background:var(--border-light);color:var(--text-primary)}.error-banner{background:#ef44441a;border-bottom:1px solid rgba(239,68,68,.2);color:var(--accent-red);padding:12px 24px;display:flex;align-items:center;justify-content:center;gap:16px;font-size:13px}.error-banner button{padding:6px 12px;background:var(--accent-red);color:#fff;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer}.admin-tabs{display:flex;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0 24px;flex-shrink:0;gap:4px}.admin-tabs button{padding:14px 20px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-weight:500;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;margin-bottom:-1px}.admin-tabs button:hover{color:var(--text-primary);background:#ffffff08}.admin-tabs button.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue);background:#3b82f60d}.tab-icon{font-size:16px}.main-content{display:flex;flex:1;overflow:hidden}.sidebar{width:340px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.sidebar-header h2{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.agent-count{background:var(--accent-blue);color:#fff;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:700;min-width:24px;text-align:center}.agent-list{flex:1;overflow-y:auto;padding:12px}.no-agents{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.no-agents-icon{font-size:48px;margin-bottom:16px;opacity:.5}.no-agents p{color:var(--text-secondary);font-size:15px;font-weight:500;margin-bottom:4px}.no-agents span{color:var(--text-muted);font-size:13px}.agent-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px;margin-bottom:10px;cursor:pointer;transition:all .2s}.agent-card:hover{border-color:var(--border-light);background:var(--bg-tertiary)}.agent-card.active{border-color:var(--accent-blue);background:#3b82f614}.agent-card.normal{border-left:3px solid var(--accent-blue)}.agent-card.silent{border-left:3px solid var(--accent-green)}.agent-card-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.agent-icon-wrapper{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.agent-type-icon{font-size:20px}.agent-info-main{flex:1;min-width:0}.agent-name{display:block;font-weight:600;color:var(--text-primary);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agent-user{display:block;color:var(--text-secondary);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agent-status{flex-shrink:0}.status-indicator{display:block;width:10px;height:10px;border-radius:50%;background:var(--accent-green)}.agent-status.offline .status-indicator{background:var(--accent-red)}.agent-details{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);margin-bottom:10px}.detail-separator{opacity:.5}.sleep-banner{background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);color:var(--accent-yellow);padding:6px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;display:flex;align-items:center;gap:6px;margin-bottom:10px}.agent-controls{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--border-color)}.ctrl-btn{flex:1;padding:8px 12px;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.ctrl-btn.sleep{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-light)}.ctrl-btn.sleep:hover{background:var(--border-light);color:var(--text-primary)}.ctrl-btn.wake{background:var(--accent-yellow);color:#1f2937}.ctrl-btn.wake:hover{background:#fbbf24}.ctrl-btn.uninstall{background:#ef44441a;color:var(--accent-red);border:1px solid rgba(239,68,68,.2)}.ctrl-btn.uninstall:hover{background:var(--accent-red);color:#fff}.monitor-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.sleep-warning-banner{background:#f59e0b1a;border-bottom:1px solid rgba(245,158,11,.2);color:var(--accent-yellow);padding:12px 24px;display:flex;align-items:center;justify-content:space-between;font-size:13px;flex-shrink:0}.sleep-warning-banner button{padding:6px 14px;background:var(--accent-yellow);color:#1f2937;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer}.monitor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border-color);flex-shrink:0}.toolbar-left{display:flex;align-items:center;gap:16px}.toolbar-left h3{font-size:16px;font-weight:600;color:var(--text-primary)}.stats-badges{display:flex;gap:8px}.badge{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600}.badge.fps{background:#3b82f61a;color:var(--accent-blue);border:1px solid rgba(59,130,246,.2)}.badge.latency{background:#10b9811a;color:var(--accent-green);border:1px solid rgba(16,185,129,.2)}.badge.type-normal{background:#3b82f61a;color:var(--accent-blue);border:1px solid rgba(59,130,246,.2)}.badge.type-silent{background:#10b9811a;color:var(--accent-green);border:1px solid rgba(16,185,129,.2)}.toolbar-right{display:flex;gap:8px}.toolbar-btn{padding:8px 16px;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.toolbar-btn.stop{background:#ef44441a;color:var(--accent-red);border:1px solid rgba(239,68,68,.2)}.toolbar-btn.stop:hover{background:var(--accent-red);color:#fff}.toolbar-btn.record{background:#ef444414;color:#f87171;border:1px solid rgba(239,68,68,.2)}.toolbar-btn.record:hover{background:#ef444433}.toolbar-btn.recording{background:var(--accent-red);color:#fff;animation:pulse-rec 1.5s ease-in-out infinite}@keyframes pulse-rec{0%,to{opacity:1}50%{opacity:.7}}.recording-indicator{display:flex;align-items:center;gap:6px;color:var(--accent-red);font-size:12px;font-weight:700;letter-spacing:1px}.rec-dot{width:8px;height:8px;background:var(--accent-red);border-radius:50%;animation:blink-rec 1s ease-in-out infinite}@keyframes blink-rec{0%,to{opacity:1}50%{opacity:.2}}.recordings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;padding:20px}.recording-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:border-color .2s}.recording-card:hover{border-color:var(--accent-blue)}.recording-card-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-color);background:#00000026}.rec-status{font-size:12px;font-weight:600}.rec-status.completed{color:var(--accent-green)}.rec-status.recording{color:var(--accent-red)}.rec-date{font-size:12px;color:var(--text-secondary)}.recording-card-body{padding:12px 16px;display:flex;flex-direction:column;gap:6px}.rec-info-row{display:flex;justify-content:space-between;font-size:13px}.rec-label{color:var(--text-secondary)}.rec-value{color:var(--text-primary);font-weight:500}.recording-card-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border-color)}.btn-danger{background:#ef44441a;color:var(--accent-red);border:1px solid rgba(239,68,68,.2)}.btn-danger:hover{background:var(--accent-red);color:#fff}.playback-modal{width:90vw;max-width:1200px;max-height:90vh;display:flex;flex-direction:column}.playback-viewer{flex:1;display:flex;align-items:center;justify-content:center;background:#000;min-height:400px;max-height:60vh;overflow:hidden}.playback-image{max-width:100%;max-height:100%;object-fit:contain}.playback-controls{display:flex;align-items:center;gap:10px;padding:16px 20px;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.playback-progress{flex:1;display:flex;align-items:center;gap:12px}.progress-slider{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:var(--border-color);border-radius:2px;outline:none;cursor:pointer}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--accent-blue);border-radius:50%;cursor:pointer}.frame-counter{font-size:12px;color:var(--text-secondary);white-space:nowrap;min-width:80px;text-align:right}.controls-panel{padding:16px 24px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.text-controls{display:flex;flex-direction:column;gap:12px}.input-group{display:flex;gap:8px}.text-input{flex:1;padding:10px 14px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:14px;transition:all .2s}.text-input:focus{outline:none;border-color:var(--accent-blue)}.text-input::placeholder{color:var(--text-muted)}.btn-send,.btn-clear{padding:10px 18px;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-send{background:var(--accent-green);color:#fff}.btn-send:hover{background:#059669}.btn-clear{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-light)}.btn-clear:hover{background:var(--border-light);color:var(--text-primary)}.options-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.option-group{display:flex;align-items:center;gap:8px}.option-group label{color:var(--text-secondary);font-size:12px;font-weight:500}.color-picker{width:32px;height:28px;border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;background:transparent;padding:2px}.size-slider{width:80px;height:4px;-webkit-appearance:none;background:var(--border-light);border-radius:2px;outline:none}.size-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--accent-blue);border-radius:50%;cursor:pointer}.size-value{color:var(--text-secondary);font-size:12px;min-width:36px}.btn-toggle{padding:6px 12px;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.btn-toggle:hover,.btn-toggle.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.position-row{display:flex;align-items:center;gap:16px;padding-top:12px;border-top:1px solid var(--border-color)}.pos-field{display:flex;align-items:center;gap:6px}.pos-field label{color:var(--text-secondary);font-size:12px;font-weight:500}.pos-field input{width:60px;padding:6px 8px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);text-align:center;font-size:13px}.hint{color:var(--text-muted);font-size:12px;margin-left:auto}.screen-viewer{flex:1;background:#000;margin:24px;border-radius:var(--radius-md);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color)}.screen-image{max-width:100%;max-height:100%;object-fit:contain}.waiting-screen{text-align:center;color:var(--text-muted);padding:48px}.spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.overlay-text{position:absolute;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.9);pointer-events:auto;-webkit-user-select:none;user-select:none;padding:8px 12px;border:2px dashed rgba(255,255,255,.3);border-radius:6px;background:#0003;transition:all .1s}.overlay-text.dragging{border-color:var(--accent-blue);border-style:solid;background:#0006}.drag-hint{display:block;font-size:10px;opacity:.6;margin-top:4px;text-align:center;font-weight:400}.admin-cursor{position:absolute;pointer-events:none;transform:translate(-50%,-50%);z-index:1000}.cursor-dot{width:14px;height:14px;background:var(--accent-red);border-radius:50%;border:2px solid white;box-shadow:0 0 10px #ef4444cc}.cursor-label{position:absolute;top:18px;left:50%;transform:translate(-50%);background:var(--accent-red);color:#fff;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;white-space:nowrap}.help-bar{padding:12px 24px;background:var(--bg-secondary);border-top:1px solid var(--border-color);font-size:12px;color:var(--text-secondary);flex-shrink:0}.help-bar strong{color:var(--text-primary)}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;text-align:center}.empty-icon{font-size:64px;margin-bottom:24px;opacity:.5}.empty-state h3{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.empty-state p{color:var(--text-secondary);margin-bottom:32px}.legend{display:flex;flex-direction:column;gap:12px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px;max-width:400px}.legend-item{display:flex;align-items:center;gap:12px;text-align:left}.legend-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:var(--radius-sm)}.legend-item div{display:flex;flex-direction:column}.legend-item strong{color:var(--text-primary);font-size:14px}.legend-item span{color:var(--text-muted);font-size:12px}.management-panel{flex:1;padding:24px;overflow-y:auto;background:var(--bg-primary)}.panel-header{margin-bottom:24px}.panel-header h2{font-size:20px;font-weight:600;color:var(--text-primary)}.content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;max-width:900px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.card-header{padding:16px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.card-header h3{font-size:14px;font-weight:600;color:var(--text-primary)}.card-body{padding:20px}.btn-primary,.btn-secondary,.btn-small{padding:10px 18px;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:var(--accent-blue);color:#fff}.btn-primary:hover{background:#2563eb}.btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-light)}.btn-secondary:hover{background:var(--border-light);color:var(--text-primary)}.btn-small{padding:6px 14px;font-size:12px}.create-form{display:flex;flex-direction:column;gap:12px}.create-form input{padding:10px 14px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:14px}.create-form input:focus{outline:none;border-color:var(--accent-blue)}.form-actions{display:flex;gap:10px;margin-top:8px}.empty-text{color:var(--text-muted);font-size:14px;text-align:center;padding:24px}.supervisors-list{display:flex;flex-direction:column;gap:10px}.supervisor-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm)}.row-actions{display:flex;align-items:center;gap:8px}.supervisor-info{display:flex;flex-direction:column;gap:2px}.sup-name{font-weight:600;color:var(--text-primary);font-size:14px}.sup-count{color:var(--text-muted);font-size:12px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:16px;font-weight:600;color:var(--text-primary)}.btn-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:20px;cursor:pointer;transition:all .2s}.btn-close:hover{background:var(--border-light);color:var(--text-primary)}.modal-body{padding:20px 24px;overflow-y:auto;flex:1}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.agents-checklist{display:flex;flex-direction:column;gap:8px}.checklist-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.checklist-item:hover{border-color:var(--border-light)}.checklist-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-blue);cursor:pointer}.check-icon{font-size:18px}.check-label{flex:1;color:var(--text-primary);font-size:14px}.check-type{color:var(--text-muted);font-size:12px;text-transform:lowercase}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:1024px){.sidebar{width:300px}.content-grid{grid-template-columns:1fr}}@media(max-width:768px){.main-content{flex-direction:column}.sidebar{width:100%;height:240px;border-right:none;border-bottom:1px solid var(--border-color)}.monitor-toolbar{flex-direction:column;gap:12px;align-items:flex-start}.options-row{flex-direction:column;align-items:flex-start}}
