:root{color-scheme:dark;--bg: #030303;--surface: #0a0a0a;--surface-hover: #121212;--border: #1a1a1a;--accent: #10b981;--accent-hover: #34d399;--warning: #ffad00;--warning-hover: #ffc233;--danger: #e11d48;--danger-hover: #f43f5e;--text: #ffffff;--text-2: #a0a0a0;--mono: ui-monospace, "SF Mono", SFMono-Regular, Menlo, Consolas, monospace;--yyp-accent: var(--accent);--yyp-warning: var(--warning)}*{box-sizing:border-box}html,body,#root{height:100vh;margin:0;overflow:hidden;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--surface-hover)}.app{height:100vh;max-height:100vh;display:flex;flex-direction:column;overflow:hidden;--timeline-h: 0px}.app.archive-mode.timeline-collapsed{--timeline-h: 96px}.app.archive-mode.timeline-expanded{--timeline-h: 280px}.topbar{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border)}.topbar h1{margin:0;font-size:20px;font-weight:900;letter-spacing:-.02em;text-transform:uppercase}.topbar-spacer{flex:1}.topbar-user{display:flex;align-items:center;gap:8px}.topbar-username{font-size:11px;font-family:var(--mono);color:var(--text-2)}.chip{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:#00ff660f;border:1px solid rgba(0,255,102,.25);border-radius:3px;padding:3px 8px}.chip.warn{color:var(--warning);background:#ffad0014;border-color:#ffad0059;animation:pulse 2s infinite}@keyframes pulse{50%{opacity:.55}}.error{margin:12px 16px 0;padding:8px 12px;border:1px solid rgba(255,173,0,.4);border-radius:4px;color:var(--warning);background:#ffad000f;cursor:pointer;font-family:var(--mono);font-size:11px}.grid-container{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:var(--row-h);grid-auto-flow:dense;gap:12px;padding:16px;flex:1;overflow-y:auto;align-content:start;--row-h: calc((100vw - var(--sidebar-width, 320px) - 32px - 11 * 12px) / 12 * .84375)}.grid-tile{position:relative;display:flex;flex-direction:column}.tile{position:relative;width:100%;height:100%;background:#000;border:1px solid var(--border);border-radius:4px;box-shadow:0 4px 16px #00000080;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;container-type:inline-size}.tile:hover,.tile:focus-within{z-index:80}.tile-video{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;border-radius:3px}.badges{position:absolute;top:8px;left:8px;z-index:50;display:flex;gap:6px;pointer-events:none}.badge{background:#000c;border:1px solid var(--border);border-radius:3px;padding:2px 8px;font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text);pointer-events:none}.badge.rec{color:var(--danger);border-color:#e11d4866;animation:pulse 2s infinite}.check{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none}.check input{width:auto;accent-color:var(--accent)}.tile-actions{position:absolute;bottom:0;left:0;right:0;height:28px;background:#0a0a0ad9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;padding:0 6px;gap:4px;z-index:50;opacity:0;transform:translateY(8px);transition:opacity .2s cubic-bezier(.16,1,.3,1),transform .2s cubic-bezier(.16,1,.3,1);pointer-events:none}.tile:hover .tile-actions{opacity:1;transform:translateY(0);pointer-events:auto}button{font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:0 10px;height:28px;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:background .15s,border-color .15s,transform .1s}button:hover{background:var(--surface-hover);border-color:#a0a0a04d}button:active{transform:scale(.95)}button.icon{width:28px;padding:0}button.danger{color:var(--danger);background:#7f1d1d33;border-color:#e11d4833}button.danger:hover{color:var(--bg);background:var(--danger-hover);border-color:var(--danger-hover)}button.primary{color:var(--bg);background:var(--accent);border-color:var(--accent)}button.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.tile-add{aspect-ratio:16 / 9;background:transparent;border:1px dashed var(--border);border-radius:4px;color:var(--text-2);font-size:11px;letter-spacing:.12em;height:auto;width:100%}.tile-add:hover{background:transparent;border-color:var(--accent);color:var(--accent)}.tile-form{aspect-ratio:auto;min-height:0;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:14px;display:flex;flex-direction:column;justify-content:center;gap:8px}.tile-form input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:var(--mono);font-size:11px;padding:8px 10px;outline:none;transition:border-color .15s}.tile-form input:focus{border-color:#00ff6680}.tile-form input::placeholder{color:#a0a0a073}.tile-form .row{display:flex;gap:8px}.tile-form .row>*{flex:1}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#000000e6;display:flex;align-items:center;justify-content:center;padding:4vh 4vw}.overlay-body{width:min(1280px,100%);background:var(--surface);border:1px solid var(--border);border-radius:4px;overflow:hidden;display:flex;flex-direction:column}.overlay-head{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.overlay-head .live{color:var(--accent)}.overlay-video{position:relative;aspect-ratio:16 / 9;background:#000}.overlay-video video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain}.archive-body{display:flex;flex-direction:column;gap:10px;padding:14px}.timeline{position:relative;height:36px;background:var(--bg);border:1px solid var(--border);border-radius:4px;cursor:crosshair;overflow:hidden}.timeline .seg{position:absolute;top:4px;bottom:4px;background:#00ff6659;border-radius:2px;pointer-events:none}.timeline .playhead{position:absolute;top:0;bottom:0;width:2px;background:var(--accent);box-shadow:0 0 6px var(--accent);pointer-events:none}.timeline-labels{display:flex;justify-content:space-between;font-family:var(--mono);font-size:9px;color:var(--text-2);letter-spacing:.06em}.archive-controls{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px}.archive-controls select{background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:var(--mono);font-size:11px;padding:5px 8px}.btn-link{font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--bg);background:var(--accent);border-radius:4px;padding:6px 12px;text-decoration:none}.btn-link:hover{background:var(--accent-hover)}.empty{grid-column:1 / -1;text-align:center;padding:48px 0 24px;color:#a0a0a073;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}.auth-modal{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:24px;display:flex;flex-direction:column;gap:16px;box-shadow:0 12px 40px #000c}.auth-modal h2{margin:0;font-size:16px;font-weight:700;letter-spacing:-.01em;text-transform:uppercase;color:var(--text);font-family:var(--mono)}.auth-desc{margin:0;font-size:12px;line-height:1.5;color:var(--text-2)}.auth-error{padding:8px 12px;border:1px solid rgba(248,113,113,.3);border-radius:4px;color:var(--danger);background:#f871710d;font-family:var(--mono);font-size:11px}.auth-fields{display:flex;flex-direction:column;gap:10px}.auth-fields input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:var(--mono);font-size:12px;padding:10px 12px;outline:none;transition:border-color .15s}.auth-fields input:focus{border-color:#00ff6680}.auth-actions{display:flex;gap:10px;margin-top:4px}.auth-actions button{flex:1;height:34px}.error-boundary{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.error-boundary-box{max-width:500px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:32px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px;box-shadow:0 8px 32px #0009}.error-boundary-box h1{margin:0;font-size:18px;font-weight:900;text-transform:uppercase;letter-spacing:-.01em;color:var(--danger);font-family:var(--mono)}.error-boundary-desc{margin:0;font-size:13px;line-height:1.6;color:var(--text-2)}.error-boundary-stack{width:100%;margin:0;padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--danger);font-family:var(--mono);font-size:11px;text-align:left;overflow-x:auto;max-height:150px}.error-boundary-box button{height:36px;padding:0 20px}.toast-container{position:fixed;bottom:20px;right:20px;z-index:500;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none}.toast{pointer-events:auto;min-width:260px;max-width:420px;padding:10px 14px;border-radius:4px;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.03em;display:flex;align-items:center;gap:10px;box-shadow:0 8px 24px #0009;animation:toast-in .28s ease-out forwards;cursor:pointer;-webkit-user-select:none;user-select:none}.toast.exiting{animation:toast-out .22s ease-in forwards}.toast-success{background:#00ff6614;border:1px solid rgba(0,255,102,.3);color:var(--accent)}.toast-error{background:#f8717114;border:1px solid rgba(248,113,113,.3);color:var(--danger)}.toast-info{background:#a0a0a014;border:1px solid rgba(160,160,160,.2);color:var(--text-2)}.toast-icon{font-size:14px;flex-shrink:0}.toast-message{flex:1;line-height:1.4}@keyframes toast-in{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(8px) scale(.96)}}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;animation:confirm-fade-in .2s ease-out}.confirm-dialog{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:24px;display:flex;flex-direction:column;gap:16px;box-shadow:0 12px 40px #000c;animation:confirm-scale-in .2s ease-out}.confirm-dialog h2{margin:0;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text);font-family:var(--mono)}.confirm-message{margin:0;font-size:13px;line-height:1.5;color:var(--text-2)}.confirm-actions{display:flex;gap:10px;margin-top:4px}.confirm-actions button{flex:1;height:34px}@keyframes confirm-fade-in{0%{opacity:0}to{opacity:1}}@keyframes confirm-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.users-modal{width:min(560px,100%)}.users-body{padding:16px;display:flex;flex-direction:column;gap:16px}.users-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.users-row-wrap{display:flex;flex-direction:column;gap:6px}.users-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:4px;background:var(--bg)}.users-pw-form{display:flex;gap:8px;padding:0 10px 4px}.users-pw-form>input{flex:1}.users-name{font-family:var(--mono);font-size:12px;color:var(--text)}.users-row-spacer{flex:1}.users-form{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--border);padding-top:16px}.users-form .row{display:flex;gap:8px}.users-form .row>*{flex:1}.users-role-select{background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:var(--mono);font-size:11px;padding:5px 8px}.discovery-wizard{width:min(600px,100%);max-height:90vh}.discovery-body{padding:24px;overflow-y:auto}.discovery-step{display:flex;flex-direction:column;gap:16px}.discovery-step h3{margin:0;font-size:16px;font-weight:700;letter-spacing:-.01em}.discovery-descr{margin:0;font-size:12px;line-height:1.5;color:var(--text-2)}.discovery-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}.discovery-actions.row{display:flex;flex-direction:row}.discovery-actions.row>button{flex:1}.discovery-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px 0;color:var(--text-2);font-size:13px}.discovery-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:discovery-spin .8s linear infinite}@keyframes discovery-spin{to{transform:rotate(360deg)}}.discovery-results{display:flex;flex-direction:column;gap:12px}.discovery-results h3{font-size:11px;font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2);margin:0}.discovery-device-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;max-height:250px;overflow-y:auto}.discovery-device{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff05;border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1)}.discovery-device:hover{background:#00ff660a;border-color:#00ff664d}.discovery-device .device-info{display:flex;flex-direction:column;gap:4px}.discovery-device .device-name{font-size:13px;font-weight:600;color:var(--text)}.discovery-device .device-ip{font-size:11px;font-family:var(--mono);color:var(--text-2)}.discovery-device .device-xaddr{font-size:11px;font-family:var(--mono);color:#ffffff4d}.discovery-empty{text-align:center;padding:40px 0;color:var(--text-2);font-size:12px;border:1px dashed var(--border);border-radius:4px}.form-fields{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:10px;font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2)}.device-details{display:flex;gap:24px;background:#ffffff05;border:1px solid var(--border);border-radius:4px;padding:12px 16px;font-size:12px}.stream-urls{display:flex;flex-direction:column;gap:8px;background:#ffffff05;border:1px solid var(--border);border-radius:4px;padding:12px 16px}.stream-url-item{display:flex;flex-direction:column;gap:4px}.stream-url-item .label{font-size:10px;font-family:var(--mono);color:var(--text-2)}.stream-url-item .value{font-size:11px;font-family:var(--mono);color:var(--accent);word-break:break-all;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-layout{display:flex;flex:1;min-height:0;overflow:hidden}.sidebar{width:var(--sidebar-width, 320px);flex-shrink:0;background:#0a0a0a73;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border);transition:width .3s cubic-bezier(.16,1,.3,1),border-color .3s;overflow:hidden}.sidebar.collapsed{border-right:none}.sidebar-content{width:320px;height:100%;padding:16px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.sidebar-nav-tabs{display:flex;gap:6px;width:100%}.sidebar-nav-btn{flex:1;height:32px;font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2);background:#ffffff05;border:1px solid var(--border);border-radius:4px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1)}.sidebar-nav-btn:hover{background:var(--surface-hover);color:var(--text);border-color:#a0a0a033}.sidebar-nav-btn.active{color:var(--bg);background:var(--accent);border-color:var(--accent)}.sidebar-admin-tabs{display:flex;flex-direction:column;gap:6px}.sidebar-admin-tab-btn{text-align:left;justify-content:flex-start;padding:0 12px;width:100%;height:32px;font-family:var(--mono);font-size:10px;font-weight:600;color:var(--text-2);background:#ffffff03;border:1px solid var(--border);border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .15s ease}.sidebar-admin-tab-btn:hover{background:var(--surface-hover);color:var(--text);border-color:#a0a0a040}.sidebar-admin-tab-btn.active{background:#00ff660f;border-color:#00ff6659;color:var(--accent)}.sidebar-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.metric-card{background:#ffffff05;border:1px solid var(--border);border-radius:4px;padding:10px;display:flex;flex-direction:column;gap:4px}.metric-card .label{font-size:9px;font-family:var(--mono);color:var(--text-2);text-transform:uppercase;letter-spacing:.05em}.metric-card .value{font-size:16px;font-family:var(--mono);font-weight:700;color:var(--text)}.metric-card .value.active{color:var(--accent)}.sidebar-section{display:flex;flex-direction:column;gap:8px}.sidebar-section-title{font-size:10px;font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-2);margin-bottom:4px}.camera-tree{display:flex;flex-direction:column;gap:6px}.camera-tree-search input{background:#0003!important;border-color:var(--border)!important;font-size:12px}.camera-tree-group{margin-bottom:8px}.camera-tree-group-header{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#ffffff05;border:1px solid var(--border);border-radius:4px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease,border-color .2s ease}.camera-tree-group-header:hover{background:#ffffff0d;border-color:#ffffff26}.camera-tree-group-chevron{color:var(--text-2);display:inline-flex;transition:transform .2s ease}.camera-tree-checkbox{margin:0;cursor:pointer}.camera-tree-group-name{font-size:11px;font-weight:600;color:var(--text-1)}.camera-tree-group-items{padding-left:16px;margin-top:4px;display:flex;flex-direction:column;gap:4px}.camera-tree-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#ffffff05;border:1px solid var(--border);border-radius:4px;cursor:grab;transition:all .2s cubic-bezier(.16,1,.3,1);-webkit-user-select:none;user-select:none}.camera-tree-item:hover{background:#ffffff0d;border-color:#ffffff26}.camera-tree-item.dragging{opacity:.4;border-style:dashed}.camera-tree-item.on-grid{background:#10b98114;border-color:#10b98140}.camera-tree-item.on-grid:hover{background:#10b9811f;border-color:#10b98159}.camera-tree-drag-icon{color:var(--text-2);font-size:11px;opacity:.4;margin-top:-1px}.camera-tree-name{flex:1;font-size:11px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.camera-tree-status{display:flex;gap:6px;align-items:center}.status-indicator{width:6px;height:6px;border-radius:50%;background:var(--accent)}.status-indicator.recording{background:var(--danger);animation:pulse 1.4s infinite}.status-indicator.offline{background:var(--text-2)}.sidebar-form-section{border:1px solid var(--border);border-radius:4px;background:#ffffff03;overflow:hidden}.sidebar-section-header{width:100%;height:36px;background:transparent;border:none;padding:0 12px;display:flex;align-items:center;justify-content:space-between;font-size:10px;font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2);cursor:pointer;transition:background .15s}.sidebar-section-header:hover{background:#ffffff08}.sidebar-section-header .arrow{font-size:8px;opacity:.7}.sidebar-form{padding:12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.sidebar-form input{width:100%}.sidebar-form .row{display:flex;gap:8px}.sidebar-form .row>*{flex:1}.sidebar-toggle-btn{margin-right:-4px;font-size:16px;line-height:1;width:28px;height:28px;min-width:28px;min-height:28px;aspect-ratio:1}.empty-slot{position:relative;background:#ffffff03;border:1px dashed var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.16,1,.3,1);overflow:hidden;container-type:inline-size}.empty-slot-content{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-2)}.empty-slot-icon{font-size:18px;opacity:.4;transition:transform .25s}.empty-slot-text{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;opacity:.45}.empty-slot-hover{background:#00ff6605;border-color:var(--accent)}.empty-slot-hover .empty-slot-icon{transform:scale(1.15);color:var(--accent);opacity:.8}.empty-slot-hover .empty-slot-text{color:var(--accent);opacity:.8}.empty-slot-actions{position:absolute;top:8px;right:8px;opacity:0;transition:opacity .2s}.empty-slot:hover .empty-slot-actions{opacity:1}@container (max-width: 195px){.badges{transform:scale(.85);transform-origin:top left}.badges>*:not(:first-child):not(.yyp-badge-rec):not(.badge.rec){display:none!important}.yyp-badge-rec,.badge.rec{display:inline-block!important;width:6px!important;height:6px!important;min-width:6px!important;max-width:6px!important;padding:0!important;border-radius:50%!important;font-size:0!important;color:transparent!important;background:var(--danger)!important;border:none!important;box-shadow:0 0 4px var(--danger);align-self:center;margin-left:2px;animation:yyp-pulse 1.4s infinite!important}.yyp-badge-neutral,.badge:first-child{max-width:80px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:8px!important;padding:1px 4px!important}.empty-slot-text{display:none!important}.empty-slot-content{width:100%!important;height:100%!important;justify-content:center;gap:0}.empty-slot-content select{position:absolute;top:0;right:0;bottom:0;left:0;width:100%!important;height:100%!important;opacity:0!important;cursor:pointer;z-index:10}.empty-slot-icon{font-size:24px;opacity:.6}}@container (max-width: 110px){.yyp-badge-neutral,.badge:first-child{display:none!important}.badges{top:4px!important;left:4px!important}.empty-slot-icon{font-size:16px}}.tile-dropdown-menu{position:absolute;bottom:32px;right:0;background:#0f0f0ffa;border:1px solid var(--border);border-radius:6px;padding:4px 0;display:flex;flex-direction:column;min-width:140px;box-shadow:0 8px 24px #000000a6;z-index:100;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.tile-dropdown-menu button{background:transparent!important;border:none!important;border-radius:0!important;padding:6px 12px!important;height:auto!important;width:100%!important;display:flex!important;align-items:center!important;justify-content:flex-start!important;gap:8px!important;color:var(--text-2)!important;font-family:var(--mono);font-size:10px!important;text-transform:uppercase;letter-spacing:.05em;text-align:left;transition:background .15s,color .15s}.tile-dropdown-menu button:hover{background:#ffffff14!important;color:var(--text)!important}.tile-dropdown-menu button.danger{color:var(--danger)!important}.tile-dropdown-menu button.danger:hover{background:#e11d4826!important;color:#fff!important}.tile-dropdown-menu .menu-item-icon{font-size:11px}.tile-dropdown-select-item{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;font-family:var(--mono);font-size:10px;text-transform:uppercase;color:var(--text-2);gap:8px;border-top:1px solid rgba(255,255,255,.05);margin-top:4px}.tile-dropdown-select-item select{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:9px;border-radius:3px;padding:2px 4px;outline:none;cursor:pointer}.tile-dropdown-select-item select:hover{border-color:var(--accent)}.tile-tiny-clear-btn{position:absolute;top:4px;right:4px;width:16px;height:16px;border-radius:50%;background:#0009;border:1px solid var(--border);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:8px;cursor:pointer;z-index:55;opacity:0;transition:opacity .2s,background .15s;padding:0}.tile:hover .tile-tiny-clear-btn{opacity:1}.tile-tiny-clear-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.resize-handle{position:absolute;bottom:0;right:0;width:16px;height:16px;cursor:se-resize;z-index:60;display:flex;align-items:flex-end;justify-content:flex-end;padding:3px;background:transparent;-webkit-user-select:none;user-select:none;touch-action:none}.resize-handle:after{content:"";width:0;height:0;border-style:solid;border-width:0 0 8px 8px;border-color:transparent transparent var(--text-2) transparent;opacity:.25;transition:border-color .15s,opacity .15s}.tile:hover .resize-handle:after,.empty-slot:hover .resize-handle:after{opacity:.55;border-color:transparent transparent var(--text) transparent}.resize-handle:hover:after{opacity:1;border-color:transparent transparent var(--accent) transparent}.tile-stream-select{height:20px;padding:0 4px;font-size:9px;background:#000000b3;border:1px solid var(--border);color:var(--text-2);border-radius:3px;font-family:var(--mono);outline:none;cursor:pointer;text-transform:uppercase}.tile-stream-select:hover{border-color:var(--accent);color:var(--text)}.tile-actions button{height:20px;font-size:11px}@media(max-width:768px){.main-layout{flex-direction:column}.sidebar{width:100%!important;height:auto;max-height:280px;border-right:none;border-bottom:1px solid var(--border)}.sidebar-content{width:100%}.grid-container{grid-template-columns:1fr!important;grid-auto-rows:auto!important}.grid-tile{grid-column:span 12!important;grid-row:span 1!important}.tile{aspect-ratio:16/9}.empty-slot{aspect-ratio:16/9;grid-column:span 12!important;grid-row:span 1!important}}.user-menu-container{position:relative;display:inline-block}.user-menu-trigger{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:0 12px;height:32px;cursor:pointer;font-family:var(--mono);font-size:11px;font-weight:700;color:var(--text);transition:all .15s ease;-webkit-user-select:none;user-select:none}.user-menu-trigger:hover,.user-menu-trigger.active{background:var(--surface-hover);border-color:#a0a0a066}.user-menu-trigger .arrow{font-size:8px;opacity:.6;transition:transform .2s ease}.user-menu-trigger.active .arrow{transform:rotate(180deg)}.user-dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;width:200px;background:#0a0a0ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:6px;box-shadow:0 10px 30px #000000b3;z-index:250;padding:6px 0;display:flex;flex-direction:column;transform-origin:top right;animation:dropdown-fade-in .18s cubic-bezier(.16,1,.3,1)}@keyframes dropdown-fade-in{0%{opacity:0;transform:scale(.96) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.dropdown-header{padding:8px 12px;display:flex;flex-direction:column;gap:2px}.dropdown-header .user-info-name{font-weight:700;font-size:12px;color:var(--text)}.dropdown-header .user-info-role{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2)}.dropdown-divider{height:1px;background:var(--border);margin:6px 0}.dropdown-item{width:100%;height:32px;background:transparent;border:none;border-radius:0;padding:0 12px;display:flex;align-items:center;justify-content:flex-start;gap:8px;font-family:ui-sans-serif,system-ui,sans-serif;font-size:12px;font-weight:500;text-transform:none;letter-spacing:normal;color:var(--text-2);cursor:pointer;transition:all .15s}.dropdown-item:hover{background:#ffffff0a;color:var(--text);border-color:transparent}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:#f8717114;color:var(--danger)}.admin-layout{display:flex;flex:1;min-height:0;overflow:hidden;background:var(--bg)}.admin-tabs{width:240px;background:#0a0a0a59;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-right:1px solid var(--border);padding:20px 12px;display:flex;flex-direction:column;gap:6px;flex-shrink:0}.admin-tab-btn{width:100%;height:38px;background:transparent;border:1px solid transparent;border-radius:4px;padding:0 14px;display:flex;align-items:center;justify-content:flex-start;gap:10px;font-family:ui-sans-serif,system-ui,sans-serif;font-size:13px;font-weight:600;color:var(--text-2);text-transform:none;letter-spacing:normal;cursor:pointer;transition:all .2s ease}.admin-tab-btn:hover{background:#ffffff05;color:var(--text);border-color:transparent}.admin-tab-btn.active{background:#00ff660a;border:1px solid rgba(0,255,102,.2);color:var(--accent);box-shadow:0 0 10px #00ff6608}.admin-content{flex:1;padding:24px;overflow-y:auto;min-width:0}.admin-section{display:flex;flex-direction:column;gap:20px;max-width:960px}.admin-section-header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);padding-bottom:12px;margin-bottom:8px}.admin-section-header h2{margin:0;font-size:18px;font-weight:800;letter-spacing:-.01em}.admin-table-container{border:1px solid var(--border);border-radius:4px;overflow:hidden;background:var(--surface)}.admin-table{width:100%;border-collapse:collapse;text-align:left;font-size:12px}.admin-table th{background:#ffffff05;border-bottom:1px solid var(--border);padding:12px 16px;font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-2)}.admin-table td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover{background:#ffffff03}.admin-table .mono{font-family:var(--mono);font-size:11px}.admin-table .badge{font-size:8px;padding:1px 4px}.admin-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:16px;display:flex;flex-direction:column;gap:16px}.admin-card-title{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-2);border-bottom:1px solid var(--border);padding-bottom:8px;margin-bottom:4px}.system-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.system-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:14px;display:flex;flex-direction:column;gap:6px}.system-stat-card .label{font-size:10px;font-family:var(--mono);color:var(--text-2);text-transform:uppercase;letter-spacing:.05em}.system-stat-card .value{font-size:18px;font-family:var(--mono);font-weight:700;color:var(--text)}.system-stat-card .value.active{color:var(--accent)}.system-stat-card .value.inactive{color:var(--danger)}.admin-accordion-form{border:1px solid var(--border);border-radius:4px;background:var(--surface);overflow:hidden;margin-bottom:16px}.admin-accordion-header{width:100%;height:44px;background:#ffffff03;border:none;padding:0 16px;display:flex;align-items:center;justify-content:space-between;font-size:11px;font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text);cursor:pointer;transition:background .15s}.admin-accordion-header:hover{background:#ffffff08}.admin-accordion-content{padding:16px;border-top:1px solid var(--border);background:#0003}.back-to-grid-btn{margin-right:12px;font-size:12px;font-weight:600;gap:4px}@media(max-width:768px){.admin-layout{flex-direction:column}.admin-tabs{width:100%!important;border-right:none;border-bottom:1px solid var(--border);flex-direction:row!important;overflow-x:auto;padding:10px;gap:8px}.admin-tab-btn{width:auto!important;white-space:nowrap}.system-status-grid{grid-template-columns:1fr!important}}.events-row-clickable:hover{background-color:var(--surface-hover)!important}.content-area{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;position:relative}.topbar-modes{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);padding:2px;border-radius:4px;margin-right:16px}.topbar-mode-btn{height:24px;padding:0 12px;font-family:var(--mono);font-size:9px;font-weight:700;text-transform:uppercase;border:none;background:transparent;color:var(--text-2);border-radius:2px;cursor:pointer;transition:all .15s}.topbar-mode-btn:hover{background:#ffffff08;color:var(--text)}.topbar-mode-btn.active{background:#00ff661a;color:var(--accent);border:1px solid rgba(0,255,102,.2)}.grid-tile.active-tile{border:2px solid var(--accent)!important;box-shadow:0 0 16px #00ff6626}.no-archive-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-2);z-index:10;font-family:var(--mono);font-size:11px}.no-archive-icon{font-size:24px;opacity:.6}.archive-panel{background:#080808f2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);display:flex;flex-direction:column;z-index:100;transition:height .22s cubic-bezier(.16,1,.3,1);flex-shrink:0;overflow:visible;width:100%;max-width:100%;box-sizing:border-box}.archive-panel.collapsed{height:96px}.archive-panel.expanded{height:280px}.archive-controls-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border);height:48px;flex-shrink:0}.archive-controls-left{display:flex;align-items:center;gap:12px}.archive-time-display{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--text);min-width:140px}.archive-controls-center{display:flex;align-items:center;gap:8px}.archive-controls-right{display:flex;align-items:center;gap:12px}.archive-tracks-viewport{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;position:relative;background:#0006}.archive-panel.collapsed .archive-tracks-viewport{overflow-y:hidden}.archive-timeline-wrapper{position:relative;width:100%;height:100%;display:flex;flex-direction:column}.timeline-vertical-playhead{position:absolute;top:0;bottom:0;width:2px;background:var(--danger);z-index:10;pointer-events:none}.timeline-vertical-playhead:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--danger)}.timeline-track-row{display:flex;border-bottom:1px solid var(--border);height:38px;flex-shrink:0}.timeline-track-row:last-child{border-bottom:none}.timeline-track-row.active-track{background:#00ff6604}.timeline-track-label{width:180px;padding:0 12px;display:flex;align-items:center;border-right:1px solid var(--border);font-size:11px;font-weight:600;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;background:#05050599;cursor:pointer;transition:color .15s}.timeline-track-row.active-track .timeline-track-label{color:var(--accent);font-weight:700}.timeline-track-label:hover{color:var(--text)}.timeline-time-marks{position:absolute;bottom:0;left:180px;right:0;height:14px;display:flex;pointer-events:none;font-family:var(--mono);font-size:8px;color:#ffffff4d}.timeline-time-mark{position:absolute;transform:translate(-50%);white-space:nowrap}.timeline-time-mark:before{content:"";position:absolute;top:-4px;left:50%;height:4px;width:1px;background:#fff3}.timeline-track-ruler{flex:1;position:relative;overflow:hidden;background:#0003;cursor:grab;-webkit-user-select:none;user-select:none}.timeline-track-ruler:active{cursor:grabbing}.timeline-segment-slice{position:absolute;top:6px;bottom:6px;background:#00ff664d;border:1px solid rgba(0,255,102,.45);border-radius:3px;min-width:2px;pointer-events:none}.timeline-track-row.active-track .timeline-segment-slice{background:#0f66;border-color:#0f69}.custom-calendar-popover{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:12px;width:260px;box-shadow:0 -4px 24px #0009;z-index:250;display:flex;flex-direction:column;gap:8px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.calendar-month-label{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text);letter-spacing:.04em}.calendar-nav-btn{height:20px;min-width:20px;padding:0;font-size:10px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day-name{font-size:8px;color:var(--text-2);font-family:var(--mono);font-weight:700;text-transform:uppercase;padding:4px 0;text-align:center}.calendar-cell{height:28px;display:flex;align-items:center;justify-content:center;font-size:10px;font-family:var(--mono);cursor:pointer;border-radius:3px;position:relative;border:1px solid transparent;color:var(--text);-webkit-user-select:none;user-select:none}.calendar-cell.calendar-cell-empty{cursor:default;opacity:.1;pointer-events:none}.calendar-cell.disabled{cursor:not-allowed;opacity:.15;pointer-events:none}.calendar-cell:not(.calendar-cell-empty):not(.disabled):hover{background:var(--surface-hover);border-color:#ffffff1a}.calendar-cell.selected{background:#00ff6626;border-color:var(--accent);color:var(--accent);font-weight:700}.calendar-cell.has-archive:after{content:"";position:absolute;bottom:3px;width:4px;height:4px;border-radius:50%;background:var(--accent)}.calendar-cell.selected.has-archive:after{background:var(--accent)}.custom-export-popover{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:12px;width:240px;box-shadow:0 -4px 24px #0009;z-index:250;display:flex;flex-direction:column;gap:10px}.export-title{font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;color:var(--accent);margin-bottom:2px;letter-spacing:.04em}.export-field{display:flex;flex-direction:column;gap:4px}.export-label{font-size:9px;font-family:var(--mono);color:var(--text-2);text-transform:uppercase;text-align:left}.export-actions{display:flex;gap:8px;margin-top:4px}.calendar-grid.months-grid{grid-template-columns:repeat(3,1fr);gap:4px}.calendar-cell.month-cell{height:36px;font-size:10px;font-family:var(--mono)}.calendar-grid.years-grid{grid-template-columns:repeat(4,1fr);gap:4px}.calendar-cell.year-cell{height:36px;font-size:10px;font-family:var(--mono)}.tooltip{position:relative}.tooltip:before{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%) translateY(4px);background:#0a0a0af2;border:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 6px;border-radius:4px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .12s cubic-bezier(.16,1,.3,1),transform .12s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 12px #0009;z-index:200}.tooltip:hover:before{opacity:1;transform:translate(-50%) translateY(0)}.yyp-badge-primary{background:#10b98114!important;color:var(--accent)!important;border-color:#10b9814d!important}.yyp-badge-rec{background:#e11d4814!important;color:var(--danger)!important;border-color:#e11d484d!important;box-shadow:none!important}.archive-expand-btn.yyp-btn-active{background:#ffffff14!important;border-color:var(--border)!important;color:var(--text)!important;box-shadow:none!important}.grid-presets-container{display:flex;flex-direction:column;gap:8px}.grid-presets-container.compact{flex-direction:row;align-items:center;gap:0}.grid-presets-container.compact .grid-presets-selector{display:flex;gap:4px}.topbar-grid-presets{display:flex;align-items:center;gap:6px;margin-left:4px;padding-left:12px;border-left:1px solid var(--border)}.topbar-reset-btn{width:28px;height:28px;min-width:28px}.grid-presets-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.grid-preset-tile{display:flex;align-items:center;justify-content:center;width:100%;height:54px;padding:6px;background:#ffffff05;border:1px solid var(--border);border-radius:6px;cursor:pointer;outline:none;transition:all .2s cubic-bezier(.16,1,.3,1)}.grid-preset-tile:hover{background:#ffffff0d;border-color:#ffffff26;transform:translateY(-1px)}.grid-preset-tile:active{transform:translateY(0)}.grid-preset-tile.active{border-color:var(--accent);background:#10b98108;box-shadow:0 0 12px #10b9811a}.grid-preset-mini{width:42px;height:42px;background:#0000004d;border:1px solid rgba(255,255,255,.05);border-radius:4px;padding:2px;box-sizing:border-box}.grid-preset-mini-cell{background:var(--text-2);opacity:.35;border-radius:1px;transition:all .2s ease}.grid-preset-tile:hover .grid-preset-mini-cell{opacity:.6}.grid-preset-tile.active .grid-preset-mini-cell{background:var(--accent);opacity:.9}.compact .grid-preset-tile{width:28px;height:28px;padding:3px;border-radius:4px}.compact .grid-preset-tile:hover{transform:none}.compact .grid-preset-mini{width:100%;height:100%;border-radius:2px;padding:1px}
