:root{--gap: 12px;--bg: #0e1116;--card: #171b22;--ink: #e7edf2;--muted: #9fb2c8;--border: #222936;--border2: #2b3442;--danger: #3a1f28;--warning: #3a2e1f;--success: #7bffa7;--error: #ff6b7b;--surface-dark: #0b0f14;--surface-button: #1f2632;--surface-button-hover: #263041;--surface-secondary: #131922;--pill-border: #334050;--pill-text: #c9d7e6;--font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Helvetica, Arial, sans-serif;--font-mono: ui-monospace, Menlo, Consolas, monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 14px;--radius-pill: 999px;--transition-fast: .02s ease;--transition-normal: .2s ease}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--font-family);background:var(--bg);color:var(--ink)}h1,h2,h3{margin:0 0 10px}.wrap{max-width:1200px;margin:0 auto;padding:16px}.muted{color:var(--muted)}.ok{color:var(--success)}.err{color:var(--error)}.kbd{font-family:var(--font-mono);background:var(--surface-dark);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:2px 6px}.pill{font-size:.85rem;padding:2px 8px;border-radius:var(--radius-pill);border:1px solid var(--pill-border);color:var(--pill-text)}.small-link{font-size:.85rem;color:var(--muted);text-decoration:underline;background:none;border:0;cursor:pointer;padding:0}.hidden{display:none!important}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:16px}button,.btn{background:var(--surface-button);color:var(--ink);border:1px solid var(--border2);border-radius:var(--radius-md);padding:12px 14px;cursor:pointer;transition:transform var(--transition-fast),background var(--transition-normal);-webkit-user-select:none;user-select:none}button:hover{background:var(--surface-button-hover)}button:active{transform:scale(.98)}.btn-secondary{background:var(--surface-secondary)}.btn-danger{background:var(--danger)}.btn-warning{background:var(--warning)}input,select{background:var(--surface-dark);border:1px solid var(--border2);color:var(--ink);border-radius:var(--radius-md);padding:10px;width:100%;min-width:0}input[type=range]{width:100%}.list{display:grid;gap:10px}.device{display:flex;justify-content:space-between;align-items:center;padding:10px;border:1px solid var(--border2);border-radius:var(--radius-md)}.video-box{position:relative;background:var(--surface-dark);border:1px solid var(--border2);border-radius:var(--radius-lg);overflow:hidden}.video-box .header{display:flex;gap:10px;align-items:center;justify-content:space-between;padding:10px;border-bottom:1px solid #253041}.video-box .body{display:flex;justify-content:center;align-items:center;min-height:280px;padding:8px}.video-box img,.video-box video{max-width:100%;height:auto;display:block}.control-panel{display:flex;flex-direction:column;gap:12px}.pad{display:grid;gap:10px;grid-template-columns:1fr .65fr;align-items:stretch}@media(max-width:979px){.pad{grid-template-columns:1fr}}.pad-grid{display:grid;gap:10px;grid-template-rows:64px 64px 64px}@media(max-width:979px){.pad-grid{grid-template-rows:72px 72px 72px}}.pad-center{display:grid;gap:10px;grid-template-columns:1fr 1fr 1fr}.pad-vert{display:flex;flex-direction:column;gap:10px;min-width:120px}.pad-vert .pad__btn{flex:1}.pad__btn{width:100%;height:100%;font-size:1.05rem;border-radius:var(--radius-lg)}.speed{padding:12px;border-radius:var(--radius-lg);border:1px solid var(--border2);background:var(--surface-dark)}.speed label{display:block;margin-bottom:8px;color:var(--muted)}.debug{border:1px dashed var(--pill-border);border-radius:var(--radius-lg);padding:10px;background:var(--surface-dark)}.debug>summary{cursor:pointer;font-weight:600}.log{background:var(--surface-dark);border:1px solid var(--border2);border-radius:var(--radius-md);padding:10px;font-family:var(--font-mono);font-size:.9rem;max-height:200px;overflow:auto;white-space:pre-wrap}.status-online{background:#1a3d2e;color:#7bffa7;border-color:#2d5a3f}.status-offline{background:#3d1a1a;color:#ff7b7b;border-color:#5a2d2d}.small{font-size:.8rem}.info-box{background:var(--surface-dark);border:1px solid var(--border2);border-radius:var(--radius-md);padding:12px}.info-box p{margin:0}button:disabled{opacity:.5;cursor:not-allowed}.mt{margin-top:12px}.row{display:flex;gap:var(--gap);flex-wrap:wrap;align-items:center}.row.wrap>*{flex:1 1 auto}.row.spread{justify-content:space-between}.grid{display:grid;gap:var(--gap)}.grid.cols-2{grid-template-columns:1fr 1fr}.grid.cols-3{grid-template-columns:1fr 1fr 1fr}@media(max-width:640px){.grid.cols-2,.grid.cols-3{grid-template-columns:1fr}}.layout{display:grid;gap:var(--gap)}@media(min-width:980px){.layout{grid-template-columns:1.2fr .8fr}}.video-stack{display:flex;flex-direction:column;gap:var(--gap)}#view-control.cockpit-mode{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000;overflow:hidden;z-index:100;color:#e7edf2;font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif}.cockpit-video-layer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;display:flex;align-items:center;justify-content:center}.cockpit-video-layer video,.cockpit-video-layer img{width:100%;height:100%;object-fit:contain;background:#000}#movement-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;font-weight:800;color:#7bffa766;text-transform:uppercase;pointer-events:none;z-index:5;transition:opacity .2s;opacity:0;text-shadow:0 0 20px rgba(123,255,167,.6)}.cockpit-hud-layer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;display:grid;grid-template-rows:auto 1fr auto;grid-template-columns:1fr 1fr 1fr;padding:20px;gap:20px;pointer-events:none}.hud-panel{pointer-events:auto;background:#0e111699;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:15px;color:#fff;transition:all .3s ease}.hud-panel:hover{background:#0e1116cc;border-color:#7bffa74d}.hud-top-left{grid-row:1;grid-column:1;align-self:start;justify-self:start}.hud-top-right{grid-row:1;grid-column:3;align-self:start;justify-self:end;display:flex;flex-direction:column;gap:10px;align-items:flex-end}.video-pip video,.video-pip img{width:100%;height:100%;object-fit:contain;background:#000}.video-pip{width:280px;aspect-ratio:16/9;background:#000;border:1px solid rgba(255,255,255,.2);border-radius:8px;overflow:hidden;box-shadow:0 4px 15px #00000080;cursor:pointer;transition:transform .2s}.video-pip:hover{transform:scale(1.02);border-color:#7bffa7}.cockpit-hud-layer.hidden{opacity:0;pointer-events:none}.hud-bottom-left{grid-row:3;grid-column:1;align-self:end;width:300px}.hud-bottom-center{grid-row:3;grid-column:2;align-self:end;justify-self:center;width:100%;max-width:500px;height:150px;background:#0009;border:1px solid rgba(123,255,167,.2);border-radius:8px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);overflow-y:auto;padding:10px;font-family:Courier New,monospace;font-size:.8rem;display:flex;flex-direction:column;pointer-events:auto}.hud-bottom-center::-webkit-scrollbar{width:6px}.hud-bottom-center::-webkit-scrollbar-thumb{background:#7bffa74d;border-radius:3px}.log-line{margin-bottom:2px;border-left:2px solid transparent;padding-left:5px;word-wrap:break-word}.log-line.cmd{color:#fff;border-left-color:#aaa}.log-line.info{color:#888}.log-line.success{color:#7bffa7;border-left-color:#7bffa7}.log-line.error{color:#ff6b7b;border-left-color:#ff6b7b;background:#ff6b7b1a}.hud-bottom-right{grid-row:3;grid-column:3;align-self:end;justify-self:end}.transparent-pad .pad__btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.2rem;transition:all .1s}.transparent-pad .pad__btn:active,.transparent-pad .pad__btn.active{background:#7bffa733;border-color:#7bffa7;color:#7bffa7;box-shadow:0 0 15px #7bffa766;transform:scale(.95)}.hud-range{width:100%;height:6px;background:#ffffff1a;border-radius:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none}.hud-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#7bffa7;cursor:pointer;box-shadow:0 0 10px #7bffa780}.hud-select{background:#00000080;border:1px solid rgba(255,255,255,.2);color:#fff;padding:5px;border-radius:4px;pointer-events:auto;cursor:pointer}.navbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#171b22d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.navbar__brand{display:flex;align-items:center;gap:10px}.navbar__logo{font-size:1.5rem}.navbar__title{font-size:1.1rem;font-weight:600;color:var(--ink)}.navbar__menu{display:flex;align-items:center;gap:6px}.navbar__item{display:flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--muted);cursor:pointer;transition:all var(--transition-normal)}.navbar__item:hover{background:var(--surface-button);border-color:var(--border2);color:var(--ink)}.navbar__item--active{background:var(--surface-button-hover);border-color:var(--border2);color:var(--ink)}.navbar__item--placeholder{opacity:.6}.navbar__item--placeholder:hover{opacity:.8}.navbar__item--clicked{transform:scale(.95)}.navbar__icon{font-size:1rem}.navbar__label{font-size:.9rem}.navbar__user{display:flex;align-items:center;gap:12px}.navbar__username{color:var(--muted);font-size:.9rem;padding:6px 12px;background:var(--surface-dark);border:1px solid var(--border2);border-radius:var(--radius-pill)}.navbar__logout{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--surface-secondary);border:1px solid var(--border2);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal)}.navbar__logout:hover{background:var(--danger);border-color:#5a2d3d}@media(max-width:640px){.navbar{padding:8px 12px}.navbar__label,.navbar__title{display:none}.navbar__item{padding:8px 10px}.navbar__username{max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.admin-panel{display:flex;flex-direction:column;gap:20px}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:16px;border-bottom:1px solid var(--border)}.admin-header h2{margin:0 0 4px}.admin-header p{margin:0}.admin-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:16px}.admin-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px}.admin-section__header h3{margin:0}.admin-actions{display:flex;gap:12px;align-items:center}.admin-search{width:250px;padding:8px 12px;border:1px solid var(--border2);border-radius:var(--radius-md);background:var(--surface-dark);color:var(--ink)}.admin-search:focus{outline:none;border-color:var(--primary)}.admin-info{background:var(--surface-dark);border:1px solid var(--border2);border-radius:var(--radius-md);padding:10px 14px;margin-bottom:12px;font-size:.9rem}.admin-info p{margin:0}.admin-info a{color:var(--success)}.admin-list{display:flex;flex-direction:column;gap:8px;max-height:500px;overflow-y:auto;padding-right:4px}.admin-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface-dark);border:1px solid var(--border2);border-radius:var(--radius-md)}.admin-card__info{flex:1;min-width:0}.admin-card__name{display:block;font-weight:500;color:var(--ink)}.admin-card__email{display:block;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-card__meta{display:flex;gap:8px}.admin-card__actions{display:flex;gap:8px;flex-shrink:0}.admin-card__actions button{padding:6px 12px;font-size:.85rem}.admin-card__actions select{width:auto;padding:6px 10px;font-size:.85rem}.admin-badge{padding:4px 10px;border-radius:var(--radius-pill);font-size:.8rem;background:var(--surface-button);border:1px solid var(--border2);color:var(--muted)}.admin-badge--admin{background:#7bffa726;border-color:#7bffa74d;color:var(--success)}.role-select{cursor:pointer}@media(max-width:640px){.admin-section__header{flex-direction:column;align-items:stretch}.admin-search{max-width:none}.admin-card{flex-direction:column;align-items:stretch;gap:10px}.admin-card__actions{justify-content:flex-end}}.wip-page{display:flex;justify-content:center;align-items:center;min-height:50vh}.wip-content{text-align:center;padding:40px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);max-width:400px}.wip-icon{font-size:4rem;margin-bottom:16px}.wip-content h2{margin:0 0 12px;color:var(--ink)}.wip-message{color:var(--ink);margin-bottom:8px}.admin-modal{padding:0;border:none;border-radius:var(--radius-xl);background:var(--card);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:90vw;width:400px}.admin-modal::backdrop{background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{padding:24px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h3{margin:0;font-size:1.25rem}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.2rem;color:var(--muted);padding:4px;border-radius:var(--radius-md)}.btn-icon:hover{background:var(--surface-hover);color:var(--ink)}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-dark);color:var(--ink)}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb),.2)}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.discovery-container{max-width:1000px;margin:2rem auto;min-height:80vh}.discovery-header{border-bottom:1px solid var(--border-color);padding-bottom:1rem;margin-bottom:2rem}.discovery-tabs{display:flex;gap:1rem;margin-top:1rem}.tab-btn{background:none;border:none;padding:.5rem 1rem;font-size:1.1rem;cursor:pointer;color:var(--text-muted);border-bottom:2px solid transparent;transition:all .2s}.tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color);font-weight:700}.user-badge{display:flex;align-items:center;gap:1rem;background:var(--bg-dark);padding:.5rem 1rem;border-radius:20px;font-size:.9rem}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.device-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;box-shadow:0 4px 6px #0000001a;transition:transform .2s;border-left:4px solid var(--primary-color)}.device-card:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.device-card.status-busy{border-left-color:var(--status-warning);opacity:.8}.search-bar{margin-bottom:2rem}.search-bar input{width:100%;padding:1rem;font-size:1.1rem;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-input);color:var(--text-color)}.search-bar input:focus{border-color:var(--primary-color);outline:none}.badge{padding:.25rem .6rem;border-radius:12px;font-size:.8rem;font-weight:700;text-transform:uppercase}.status-online{background-color:var(--status-success-bg);color:var(--status-success)}.status-offline{background-color:var(--status-error-bg);color:var(--status-error)}.status-busy{background-color:var(--status-warning-bg);color:var(--status-warning)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.card-header h3{margin:0;font-size:1.3rem}.card-body p{margin:.5rem 0}.card-actions{margin-top:1.5rem;display:flex;justify-content:flex-end}.btn-link-cam{background:none;border:none;cursor:pointer;font-size:1rem;margin-left:.5rem}.modal{padding:2rem;border-radius:12px;border:none;box-shadow:0 20px 25px -5px #0000001a;max-width:500px;width:90%;background:var(--bg-card);color:var(--text-color)}.modal::backdrop{background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.cam-option:hover{background:var(--bg-hover)}.projects-panel{display:flex;flex-direction:column;gap:20px}.projects-upload-form{display:flex;flex-direction:column;gap:16px}.projects-upload-row{display:flex;gap:16px}.projects-upload-row .form-group{flex:1;margin-bottom:0}.projects-file-input{width:100%;padding:8px;border:1px dashed var(--border2);border-radius:var(--radius-md);background:var(--surface-dark);color:var(--ink);cursor:pointer;font-size:.9rem}.projects-file-input:hover{border-color:var(--primary)}.projects-file-input::file-selector-button{padding:6px 12px;border:1px solid var(--border2);border-radius:var(--radius-md);background:var(--surface-button);color:var(--ink);cursor:pointer;margin-right:10px}.projects-file-input::file-selector-button:hover{background:var(--surface-hover)}.projects-required{color:var(--danger, #ff6b6b);font-size:.75rem}.projects-upload-actions{display:flex;justify-content:flex-end}.projects-progress{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface-dark);border:1px solid var(--border2);border-radius:var(--radius-md)}.projects-progress__bar{flex:1;height:6px;background:var(--border2);border-radius:3px;overflow:hidden;position:relative}.projects-progress__bar:after{content:"";position:absolute;top:0;left:0;height:100%;width:30%;background:var(--primary);border-radius:3px;animation:progress-indeterminate 1.5s infinite ease-in-out}@keyframes progress-indeterminate{0%{left:-30%;width:30%}50%{left:50%;width:30%}to{left:100%;width:30%}}.projects-progress__text{font-size:.85rem;color:var(--muted);white-space:nowrap}.projects-card{flex-wrap:wrap}.projects-card__actions{flex-wrap:wrap;gap:6px!important}.projects-card__actions button{font-size:.8rem!important;padding:5px 10px!important}.projects-device-select select{width:100%;padding:10px 12px;border:1px solid var(--border2);border-radius:var(--radius-md);background:var(--surface-dark);color:var(--ink);font-size:.95rem;cursor:pointer}.projects-device-select select:focus{outline:none;border-color:var(--primary)}@media(max-width:640px){.projects-upload-row{flex-direction:column;gap:12px}.projects-card .admin-card__actions{justify-content:stretch}.projects-card__actions button{flex:1}}.groups-content{animation:fadeIn .3s ease-in-out}.groups-content h2{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem}.split-layout{display:flex;gap:1.5rem;align-items:flex-start}.split-layout>div{flex:1}#create-group-form .form-group{margin-bottom:1rem}#create-group-form label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem}.remove-member-btn{border:none;border-radius:var(--border-radius);padding:.25rem .5rem;font-size:.8rem;cursor:pointer}.device-card__actions{display:flex;gap:.5rem}
