:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#e8e8e8;background:#000;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}#root{width:100%;height:100%}.app{background:#000;flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.app-container{flex:1;min-height:0;display:flex;overflow:hidden}.main-content{background:#000;flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.live-view{height:100%;display:flex;overflow:hidden}.camera-list-panel{background:#1c1c1c;border-right:1px solid #0a0a0a;flex-direction:column;flex-shrink:0;width:180px;display:flex}.camera-list-header{border-bottom:1px solid #0a0a0a;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.camera-list-header h3{color:#e8e8e8;font-size:13px;font-weight:600}.camera-search{border-bottom:1px solid #0a0a0a;padding:10px 12px;position:relative}.camera-search-input{color:#e8e8e8;background:#0a0a0a;border:1px solid #2a2a2a;border-radius:3px;outline:none;width:100%;padding:7px 28px 7px 10px;font-size:12px;transition:all .2s}.camera-search-input:focus{background:#151515;border-color:#06c}.camera-search-input::placeholder{color:#666}.search-clear-btn{color:#666;cursor:pointer;background:0 0;border:none;padding:4px;font-size:12px;transition:color .2s;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.search-clear-btn:hover{color:#e8e8e8}.camera-groups{scrollbar-width:thin;scrollbar-color:#2a2a2a #0a0a0a;border-bottom:1px solid #0a0a0a;flex-direction:column;gap:4px;max-height:150px;padding:8px 12px;display:flex;overflow-y:auto}.camera-groups::-webkit-scrollbar{width:6px}.camera-groups::-webkit-scrollbar-track{background:#0a0a0a}.camera-groups::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:3px}.group-btn{color:#999;cursor:pointer;text-align:left;background:#0a0a0a;border:1px solid #2a2a2a;border-radius:3px;padding:6px 10px;font-size:11px;transition:all .15s}.group-btn:hover{color:#e8e8e8;background:#151515}.group-btn.active{color:#fff;background:#06c;border-color:#06c}.camera-list-actions{border-bottom:1px solid #0a0a0a;gap:6px;padding:8px 12px;display:flex}.panel-action-btn{color:#999;cursor:pointer;white-space:nowrap;background:#0a0a0a;border:1px solid #2a2a2a;border-radius:3px;flex:1;padding:6px 8px;font-size:10px;transition:all .15s}.panel-close-btn{color:#999;cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;width:24px;height:24px;font-size:16px;transition:all .15s;display:flex}.panel-close-btn:hover{color:#e8e8e8;background:#ffffff14}.camera-grid-scroll{grid-template-columns:1fr;gap:8px;display:grid}.camera-grid-item{cursor:pointer;background:#0a0a0a;border:2px solid #2a2a2a;border-radius:4px;padding:6px;transition:all .15s}.camera-grid-item:hover{background:#151515;border-color:#3a3a3a}.camera-grid-item.selected{background:#06c3;border-color:#06c}.camera-grid-item.offline{opacity:.5}.camera-grid-preview{aspect-ratio:16/9;background:#000;border-radius:3px;width:100%;margin-bottom:6px;position:relative;overflow:hidden}.camera-grid-img{object-fit:cover;width:100%;height:100%}.camera-grid-check{color:#fff;background:#06c;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;display:flex;position:absolute;top:4px;right:4px}.camera-grid-rec{color:#f44;font-size:10px;animation:1.5s infinite blink;position:absolute;top:4px;left:4px}.camera-grid-info{flex-direction:column;gap:4px;display:flex}.camera-grid-name{color:#e8e8e8;white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:500;overflow:hidden}.camera-grid-status{color:#666;justify-content:space-between;align-items:center;font-size:10px;display:flex}.camera-grid-res{color:#555;font-size:9px}.camera-list-item{cursor:pointer;background:#0a0a0a;border:1px solid #2a2a2a;border-radius:3px;flex-direction:column;gap:6px;margin-bottom:4px;padding:8px;transition:all .15s;display:flex}.camera-list-item:hover{background:#151515;border-color:#3a3a3a}.camera-list-item.selected{background:#06c3;border-color:#06c}.camera-list-item.offline{opacity:.5}.camera-list-preview{aspect-ratio:16/9;background:#000;border-radius:2px;flex-shrink:0;justify-content:center;align-items:center;width:100%;display:flex;position:relative}.camera-preview-placeholder{opacity:.5;font-size:20px}.camera-rec-badge{color:#f44;font-size:10px;animation:1.5s infinite blink;position:absolute;top:4px;right:4px}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.camera-list-info{flex-direction:column;gap:2px;display:flex}.camera-list-name{color:#e8e8e8;white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:500;overflow:hidden}.camera-list-status{color:#888;justify-content:space-between;align-items:center;font-size:10px;display:flex}.status-indicator{background:#666;border-radius:50%;width:6px;height:6px}.status-indicator.live{background:#4caf50}.status-indicator.recording{background:#f44}.status-indicator.offline{background:#666}.live-view-main{flex-direction:column;flex:1;display:flex;overflow:hidden}.camera-grid{background:#000;flex:1;gap:1px;min-height:0;padding:1px;display:grid;overflow:hidden}.camera-cell{background:#0d0d0d;min-height:0;position:relative;overflow:hidden}.camera-stream{background:#000;width:100%;height:100%;position:relative}.camera-stream-placeholder{color:#333;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.camera-overlay-top{pointer-events:none;background:linear-gradient(#0009 0%,#0000 100%);justify-content:space-between;align-items:start;padding:8px;display:flex;position:absolute;top:0;left:0;right:0}.camera-name-badge{color:#e8e8e8;background:#000000b3;border-radius:3px;padding:4px 8px;font-size:12px;font-weight:500}.camera-rec-indicator{color:#fff;background:#ff4444e6;border-radius:3px;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:600;display:flex}.rec-dot{animation:1.5s infinite blink}.camera-overlay-bottom{opacity:0;background:linear-gradient(#0000 0%,#0009 100%);padding:8px;transition:opacity .2s;position:absolute;bottom:0;left:0;right:0}.camera-cell:hover .camera-overlay-bottom{opacity:1}.camera-controls{justify-content:center;gap:6px;display:flex}.camera-control-btn{color:#e8e8e8;cursor:pointer;background:#000000b3;border:1px solid #fff3;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:all .15s;display:flex}.camera-control-btn:hover{background:#06cc;border-color:#06c}.camera-control-btn.active{background:#ff3b30e6;border-color:#ff3b30;animation:1.5s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.camera-empty{color:#333;cursor:pointer;justify-content:center;align-items:center;width:100%;height:100%;font-size:48px;transition:all .2s;display:flex}.camera-empty:hover{color:#555;background:#ffffff05}.live-view-toolbar{background:#1c1c1c;border-top:1px solid #0a0a0a;flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 16px;display:flex}.toolbar-left,.toolbar-right{flex:1}.toolbar-center{justify-content:center;display:flex}.toolbar-btn{color:#b8b8b8;cursor:pointer;background:0 0;border:1px solid #3a3a3a;border-radius:4px;padding:6px 12px;font-size:12px;transition:all .15s}.toolbar-btn:hover{color:#e8e8e8;background:#ffffff0d;border-color:#555}.layout-selector{background:#0a0a0a;border-radius:3px;gap:4px;padding:3px;display:flex}.layout-btn{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:3px;width:36px;height:36px;padding:6px;transition:all .15s}.layout-btn:hover{background:#ffffff0d}.layout-btn.active{background:#06c3;border-color:#06c}.layout-btn[title="1x1 Layout"] .layout-grid{grid-template-rows:1fr;grid-template-columns:1fr}.layout-btn[title="2x2 Layout"] .layout-grid{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr}.layout-btn[title="3x3 Layout"] .layout-grid{grid-template-rows:1fr 1fr 1fr;grid-template-columns:1fr 1fr 1fr}.layout-btn[title="4x4 Layout"] .layout-grid{grid-template-rows:1fr 1fr 1fr 1fr;grid-template-columns:1fr 1fr 1fr 1fr}.layout-btn[title="2x3 Layout"] .layout-grid{grid-template-rows:1fr 1fr 1fr;grid-template-columns:1fr 1fr}.layout-cell{background:#666;border-radius:1px}.camera-stream-img{object-fit:cover;width:100%;height:100%}.camera-stream-iframe,.fullscreen-stream-iframe{border:none;width:100%;height:100%;display:block}.loading-screen{color:#999;flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100%;display:flex}.loading-spinner{font-size:48px;animation:2s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.no-cameras{color:#999;flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100%;display:flex}.no-cameras-icon{opacity:.5;font-size:64px}.no-cameras h2{color:#e8e8e8;margin:0;font-size:24px}.no-cameras p{margin:0;font-size:14px}.camera-counter{color:#999;background:#2a2a2a;border-radius:4px;margin-left:12px;padding:8px 12px;font-size:12px}.camera-list-item{position:relative}.camera-list-item:after{content:"";background:#1a1a1a;border:2px solid #3a3a3a;border-radius:4px;width:20px;height:20px;transition:all .15s;position:absolute;top:8px;right:8px}.camera-list-item.selected:after{content:"✓";color:#fff;background:#06c;border-color:#06c;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.camera-list-item:hover:after{border-color:#555}.camera-list-header{border-bottom:1px solid #0a0a0a;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;display:flex}.camera-list-actions{align-items:center;gap:4px;display:flex}.panel-action-btn{color:#999;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #3a3a3a;border-radius:3px;padding:4px 8px;font-size:11px;transition:all .15s}.panel-action-btn:hover{color:#e8e8e8;background:#ffffff0d;border-color:#555}.camera-list{flex:1;padding:8px;overflow:hidden auto}.camera-list::-webkit-scrollbar{width:6px}.camera-list::-webkit-scrollbar-track{background:#1a1a1a}.camera-list::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:3px}.camera-list::-webkit-scrollbar-thumb:hover{background:#555}.no-results{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.no-results-icon{opacity:.3;margin-bottom:12px;font-size:48px}.no-results p{color:#666;margin:0 0 16px;font-size:13px}.fullscreen-overlay{z-index:10000;background:#000000f2;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fullscreen-container{background:#0a0a0a;border-radius:8px;flex-direction:column;width:95%;height:95%;display:flex;overflow:hidden}.fullscreen-header{background:#1a1a1a;border-bottom:1px solid #2a2a2a;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.fullscreen-header h2{color:#e8e8e8;margin:0;font-size:20px;font-weight:500}.fullscreen-close{color:#999;cursor:pointer;background:#2a2a2a;border:none;border-radius:4px;justify-content:center;align-items:center;width:36px;height:36px;font-size:24px;transition:all .2s;display:flex}.fullscreen-close:hover{color:#e8e8e8;background:#3a3a3a}.fullscreen-video{background:#000;flex:1;justify-content:center;align-items:center;display:flex;overflow:hidden}.fullscreen-stream-img{object-fit:contain;width:100%;height:100%}.fullscreen-controls{background:#1a1a1a;border-top:1px solid #2a2a2a;justify-content:center;gap:12px;padding:16px 24px;display:flex}.fullscreen-control-btn{color:#e8e8e8;cursor:pointer;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;align-items:center;gap:8px;padding:12px 24px;font-size:14px;transition:all .2s;display:flex}.fullscreen-control-btn:hover{background:#3a3a3a;border-color:#06c;transform:translateY(-1px)}.fullscreen-control-btn:active{transform:translateY(0)}.camera-carousel{background:#1c1c1c;border-top:1px solid #0a0a0a;align-items:center;gap:8px;height:80px;padding:0 8px;display:flex;position:relative}.carousel-nav{color:#e8e8e8;cursor:pointer;z-index:10;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:24px;transition:all .2s;display:flex}.carousel-nav:hover{background:#3a3a3a;border-color:#06c}.carousel-prev{margin-right:8px}.carousel-next{margin-left:8px}.carousel-track{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#3a3a3a #1c1c1c;flex:1;gap:8px;padding:8px 0;display:flex;overflow:auto hidden}.carousel-track::-webkit-scrollbar{height:6px}.carousel-track::-webkit-scrollbar-track{background:#1c1c1c}.carousel-track::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:3px}.carousel-track::-webkit-scrollbar-thumb:hover{background:#4a4a4a}.carousel-item{cursor:pointer;background:#0a0a0a;border:2px solid #2a2a2a;border-radius:4px;flex-shrink:0;width:100px;padding:4px;transition:all .2s}.carousel-item:hover{border-color:#06c;transform:translateY(-2px)}.carousel-item.active{background:#0066cc1a;border-color:#06c}.carousel-preview{aspect-ratio:16/9;background:#000;border-radius:4px;width:100%;margin-bottom:6px;position:relative;overflow:hidden}.carousel-img{object-fit:cover;width:100%;height:100%}.carousel-selected{color:#fff;background:#06c;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;font-weight:700;display:flex;position:absolute;top:4px;right:4px}.carousel-name{color:#e8e8e8;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:9px;font-weight:500;overflow:hidden}.carousel-status{color:#666;align-items:center;gap:3px;font-size:8px;display:flex}.status-dot{background:#666;border-radius:50%;width:6px;height:6px}.status-dot.live{background:#34c759;box-shadow:0 0 4px #34c759}.status-dot.offline{background:#ff3b30}.pagination-info{color:#666;margin-left:12px;font-size:12px}.pagination-controls{align-items:center;gap:12px;margin-right:16px;display:flex}.pagination-btn{color:#e8e8e8;cursor:pointer;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;align-items:center;gap:4px;padding:6px 12px;font-size:12px;transition:all .2s;display:flex}.pagination-btn:hover:not(:disabled){background:#3a3a3a;border-color:#06c}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.pagination-pages{color:#999;text-align:center;min-width:60px;font-size:13px;font-weight:500}.page-indicator{color:#06c;font-weight:500}.carousel-layout-selector{border-left:1px solid #2a2a2a;gap:6px;margin-left:12px;padding-left:12px;display:flex}.carousel-layout-btn{cursor:pointer;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;justify-content:center;align-items:center;width:36px;height:36px;padding:4px;transition:all .2s;display:flex}.carousel-layout-btn:hover{background:#3a3a3a;border-color:#06c}.carousel-layout-btn.active{background:#06c;border-color:#06c}.layout-grid-mini{gap:2px;width:100%;height:100%;display:grid}.layout-grid-mini[style*="1"]{grid-template-rows:1fr;grid-template-columns:1fr}.layout-grid-mini:has(.layout-cell-mini:nth-child(4)){grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr)}.layout-grid-mini:has(.layout-cell-mini:nth-child(6)){grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(2,1fr)}.layout-grid-mini:has(.layout-cell-mini:nth-child(9)){grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr)}.layout-grid-mini:has(.layout-cell-mini:nth-child(16)){grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(4,1fr)}.layout-cell-mini{background:#666;border-radius:1px}.carousel-layout-btn.active .layout-cell-mini{background:#fff}.carousel-settings-btn{color:#e8e8e8;cursor:pointer;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;justify-content:center;align-items:center;width:36px;height:36px;margin-left:8px;font-size:18px;transition:all .2s;display:flex}.carousel-settings-btn:hover{background:#3a3a3a;border-color:#06c;transform:rotate(45deg)}.settings-panel{z-index:9999;background:#1c1c1c;border:1px solid #3a3a3a;border-radius:8px;width:400px;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 8px 32px #000c}.settings-content{padding:20px}.setting-group label{color:#999;margin-bottom:8px;font-size:13px;display:block}.setting-input{color:#e8e8e8;background:#0a0a0a;border:1px solid #3a3a3a;border-radius:4px;width:100%;padding:8px 12px;font-size:14px}.setting-input:focus{border-color:#06c;outline:none}.setting-preview{color:#999;background:#0a0a0a;border-radius:4px;margin-bottom:16px;padding:12px;font-size:13px}.setting-preview strong{color:#e8e8e8}.setting-apply-btn{color:#fff;cursor:pointer;background:#06c;border:none;border-radius:4px;width:100%;padding:10px;font-size:14px;font-weight:500;transition:all .2s}.setting-apply-btn:hover{background:#0052a3}.layout-grid{gap:1px;width:100%;height:100%;display:grid}.layout-grid:has(.layout-cell:nth-child(4):last-child){grid-template-rows:repeat(2,1fr);grid-template-columns:repeat(2,1fr)}.layout-grid:has(.layout-cell:nth-child(9):last-child){grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr)}.layout-grid:has(.layout-cell:nth-child(16):last-child){grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(4,1fr)}.layout-grid:has(.layout-cell:nth-child(25):last-child){grid-template-rows:repeat(5,1fr);grid-template-columns:repeat(5,1fr)}.layout-grid:has(.layout-cell:nth-child(36):last-child){grid-template-rows:repeat(6,1fr);grid-template-columns:repeat(6,1fr)}.layout-cell{background:#555;border-radius:1px;min-width:2px;min-height:2px}.layout-btn:hover .layout-cell{background:#888}.layout-btn.active .layout-cell{background:#4da6ff}.audio-control-wrapper{align-items:center;display:flex;position:relative}.fullscreen-control-btn.active{background:#06c;border-color:#06c}.volume-slider-container{background:#1a1a1a;border:1px solid #3a3a3a;border-radius:8px;flex-direction:column;align-items:center;gap:8px;margin-bottom:12px;padding:16px 12px;animation:.2s ease-out slideUp;display:flex;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.volume-slider{appearance:none;cursor:pointer;background:#2a2a2a;border-radius:3px;outline:none;width:120px;height:6px}.volume-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#06c;border-radius:50%;width:16px;height:16px;transition:all .2s}.volume-slider::-webkit-slider-thumb:hover{background:#0052a3;transform:scale(1.2)}.volume-slider::-moz-range-thumb{cursor:pointer;background:#06c;border:none;border-radius:50%;width:16px;height:16px;transition:all .2s}.volume-slider::-moz-range-thumb:hover{background:#0052a3;transform:scale(1.2)}.volume-label{color:#e8e8e8;text-align:center;min-width:40px;font-size:12px;font-weight:500}.audio-note{color:#999;text-align:center;max-width:120px;font-size:10px;line-height:1.3}.timeline-synology{background:#1a1a1a;height:100%;display:flex;overflow:hidden}.timeline-left{background:#0a0a0a;border-right:1px solid #2a2a2a;flex-direction:column;width:280px;display:flex}.camera-date-selector{border-bottom:1px solid #2a2a2a;padding:16px}.date-input{color:#e8e8e8;background:#1a1a1a;border:1px solid #3a3a3a;border-radius:6px;width:100%;padding:10px;font-size:14px}.camera-list{flex:1;padding:8px;overflow-y:auto}.camera-item{cursor:pointer;background:#1a1a1a;border:2px solid #0000;border-radius:8px;align-items:center;gap:12px;margin-bottom:4px;padding:12px;transition:all .2s;display:flex}.camera-item:hover{background:#252525;border-color:#3a3a3a}.camera-item.active{background:#06c;border-color:#0080ff}.camera-icon{font-size:20px}.camera-name{color:#e8e8e8;flex:1;font-size:14px;font-weight:500}.camera-item.active .camera-name{color:#fff}.camera-badge{background:#fff3;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:600}.timeline-right{flex-direction:column;flex:1;display:flex;overflow:hidden}.camera-grid-container{background:#0a0a0a;flex:1;min-height:0;padding:16px}.camera-grid-container.has-expanded{padding:0}.camera-grid-2x2{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;gap:8px;height:100%;display:grid}.grid-cell{cursor:pointer;background:#1a1a1a;border:2px solid #2a2a2a;border-radius:8px;transition:all .2s;position:relative;overflow:hidden}.grid-cell.expanded{border-radius:0;width:100%;height:100%}.grid-cell.has-camera:hover{border-color:#06c}.grid-cell.focused{border-color:#06c;box-shadow:0 0 0 2px #0066cc4d}.empty-cell{color:#3a3a3a;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.empty-cell-icon{opacity:.3;font-size:48px}.camera-stream{object-fit:cover;border:none;width:100%;height:100%}.no-event-message{color:#666;background:#000;justify-content:center;align-items:center;width:100%;height:100%;font-size:16px;display:flex}.camera-label{color:#fff;z-index:2;background:linear-gradient(#0000,#000c);padding:8px 12px;font-size:14px;font-weight:600;position:absolute;bottom:0;left:0;right:0}.camera-time{color:#ff9500;font-weight:400}.close-camera-btn{color:#fff;cursor:pointer;z-index:3;opacity:0;background:#000000b3;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:all .2s;display:flex;position:absolute;top:8px;right:8px}.grid-cell:hover .close-camera-btn{opacity:1}.close-camera-btn:hover{background:#f00c;transform:scale(1.1)}.loading-state,.empty-state{color:#666;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.empty-icon{margin-bottom:16px;font-size:64px}.empty-text{font-size:16px}.timeline-track-section{background:#0a0a0a;border-top:1px solid #2a2a2a;flex-direction:column;flex-shrink:0;height:180px;padding:16px;display:flex}.timeline-scroll-container{flex:1;overflow:auto hidden}.timeline-info{justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 4px;display:flex}.timeline-camera-name{color:#06c;font-size:14px;font-weight:600}.timeline-zoom-hint{color:#666;font-size:12px}.timeline-events-count{color:#999;font-size:12px}.timeline-hours{color:#666;transform-origin:0;grid-template-columns:repeat(25,1fr);min-width:100%;margin-bottom:8px;font-size:10px;transition:transform .2s;display:grid}.hour-label{text-align:left;padding-left:2px}.timeline-track{cursor:pointer;transform-origin:0;background:#1a1a1a;border-radius:6px;min-width:100%;height:50px;transition:transform .2s;position:relative;overflow:visible}.timeline-bg{grid-template-columns:repeat(24,1fr);display:grid;position:absolute;inset:0}.hour-segment{border-right:1px solid #2a2a2a}.hour-segment:nth-child(2n){background:#ffffff05}.timeline-event{cursor:pointer;z-index:1;background:#06c;border-radius:2px;height:100%;transition:all .2s;position:absolute;top:0}.timeline-event:hover{z-index:2;background:#0080ff;transform:scaleY(1.2)}.timeline-loading{color:#666;font-size:14px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.timeline-cursor{z-index:10;pointer-events:none;background:#ff9500;width:2px;position:absolute;top:-4px;bottom:-4px;box-shadow:0 0 10px #ff9500cc}.timeline-cursor:before{content:"";background:#ff9500;border-radius:50%;width:10px;height:10px;position:absolute;top:-6px;left:-4px;box-shadow:0 0 10px #ff9500cc}.timeline-tooltip{color:#fff;z-index:10000;pointer-events:none;white-space:nowrap;background:#000000e6;border-radius:4px;padding:6px 12px;font-size:12px;font-weight:600;position:fixed}.events-view{height:100%;padding:24px;overflow-y:auto}.events-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.events-header h2{color:#e8e8e8;margin:0;font-size:24px}.events-filters{gap:8px;display:flex}.filter-btn{color:#b8b8b8;cursor:pointer;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;padding:8px 16px;font-size:13px;transition:all .15s}.filter-btn:hover{color:#e8e8e8;background:#333}.filter-btn.active{color:#fff;background:#06c;border-color:#06c}.events-table{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;overflow:hidden}.events-table table{border-collapse:collapse;width:100%}.events-table th{text-align:left;color:#999;text-transform:uppercase;background:#1c1c1c;padding:12px;font-size:12px;font-weight:600}.events-table td{color:#e8e8e8;border-top:1px solid #3a3a3a;padding:12px;font-size:13px}.events-table tr:hover{background:#ffffff08}.action-btn{cursor:pointer;opacity:.7;background:0 0;border:none;padding:4px 8px;font-size:16px;transition:all .15s}.action-btn:hover{opacity:1;transform:scale(1.1)}.action-btn.danger:hover{color:#f44}.loading,.no-events{text-align:center;color:#999;padding:48px;font-size:14px}.camera-management{height:100%;padding:24px;overflow-y:auto}.cm-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.cm-header h2{color:#e8e8e8;margin:0;font-size:24px}.cameras-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;display:grid}.camera-card-manage{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;overflow:hidden}.camera-preview{aspect-ratio:16/9;background:#000;width:100%;position:relative}.camera-preview img{object-fit:cover;width:100%;height:100%}.camera-status-badge{border-radius:4px;padding:4px 8px;font-size:11px;font-weight:600;position:absolute;top:8px;right:8px}.camera-status-badge.enabled{color:#fff;background:#4caf50e6}.camera-status-badge.disabled{color:#fff;background:#9e9e9ee6}.camera-details{padding:16px}.camera-details h3{color:#e8e8e8;margin:0 0 12px;font-size:16px}.camera-specs{color:#999;gap:12px;margin-bottom:8px;font-size:12px;display:flex}.camera-source{color:#666;text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.camera-actions{border-top:1px solid #3a3a3a;gap:8px;padding:12px 16px;display:flex}.action-btn{color:#b8b8b8;cursor:pointer;background:0 0;border:1px solid #3a3a3a;border-radius:4px;flex:1;padding:8px;font-size:12px;transition:all .15s}.action-btn:hover{color:#e8e8e8;background:#ffffff0d;border-color:#555}.action-btn.danger:hover{color:#f44;background:#ff44441a;border-color:#f44}.add-camera-overlay{z-index:10000;background:#000c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.add-camera-dialog{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;flex-direction:column;width:90%;max-width:700px;max-height:90vh;animation:.3s slideUp;display:flex;box-shadow:0 8px 32px #000c}.dialog-header{border-bottom:1px solid #3a3a3a;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.dialog-header h3{color:#e8e8e8;margin:0;font-size:18px}.dialog-tabs{background:#1c1c1c;border-bottom:1px solid #3a3a3a;display:flex}.tab-btn{color:#999;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:12px 16px;font-size:14px;transition:all .15s}.tab-btn:hover{color:#e8e8e8;background:#ffffff0d}.tab-btn.active{color:#06c;background:#0066cc1a;border-bottom-color:#06c}.dialog-body{flex:1;padding:24px;overflow-y:auto}.scan-section{text-align:center}.scan-section p{color:#999;margin-bottom:20px}.btn-scan{color:#fff;cursor:pointer;background:#06c;border:none;border-radius:6px;padding:12px 32px;font-size:14px;font-weight:600;transition:all .2s}.btn-scan:hover:not(:disabled){background:#0052a3}.btn-scan:disabled{color:#666;cursor:not-allowed;background:#3a3a3a}.found-cameras{text-align:left;margin-top:24px}.found-cameras h4{color:#e8e8e8;margin-bottom:12px}.found-camera-item{background:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:12px;display:flex}.found-camera-info{flex-direction:column;gap:4px;display:flex}.found-camera-info strong{color:#e8e8e8;font-size:14px}.found-camera-info span{color:#999;font-size:12px}.onvif-badge{color:#34c759;background:#34c75933;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.btn-add-found{color:#fff;cursor:pointer;background:#34c759;border:none;border-radius:4px;padding:8px 16px;font-size:12px;font-weight:600;transition:all .2s}.btn-add-found:hover{background:#2fb350}.camera-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#999;font-size:13px;font-weight:600}.form-input,.form-select{color:#e8e8e8;background:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;padding:10px 12px;font-size:14px;transition:all .15s}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.checkbox-label{cursor:pointer;align-items:center;gap:8px;display:flex}.rtsp-preview{background:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;margin-top:8px;padding:12px}.rtsp-preview strong{color:#999;margin-bottom:8px;font-size:12px;display:block}.rtsp-preview code{color:#4da6ff;word-break:break-all;font-family:Courier New,monospace;font-size:12px;display:block}.dialog-footer{background:#1c1c1c;border-top:1px solid #3a3a3a;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.btn-cancel,.btn-test,.btn-add{cursor:pointer;border:none;border-radius:6px;padding:10px 24px;font-size:14px;font-weight:600;transition:all .2s}.btn-test{color:#fff;background:#ff9500}.btn-test:hover{background:#e68600}.btn-add{color:#fff;background:#34c759}.btn-add:hover{background:#2fb350}.camera-settings-overlay{z-index:10001;background:#000000d9;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.camera-settings-dialog{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;flex-direction:column;width:95%;max-width:1000px;max-height:90vh;animation:.3s slideUp;display:flex;box-shadow:0 8px 32px #000c}.settings-header{border-bottom:1px solid #3a3a3a;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.settings-header h3{color:#e8e8e8;margin:0;font-size:18px}.settings-close{color:#999;cursor:pointer;background:0 0;border:none;border-radius:4px;width:32px;height:32px;font-size:24px;transition:all .15s}.settings-close:hover{color:#e8e8e8;background:#ffffff14}.settings-tabs{background:#1c1c1c;border-bottom:1px solid #3a3a3a;display:flex}.settings-tab{color:#999;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:12px 16px;font-size:14px;transition:all .15s}.settings-tab:hover{color:#e8e8e8;background:#ffffff0d}.settings-tab.active{color:#06c;background:#0066cc1a;border-bottom-color:#06c}.settings-body{flex:1;padding:24px;overflow-y:auto}.settings-section h4{color:#e8e8e8;margin:0 0 20px;font-size:16px}.setting-group{margin-bottom:16px}.setting-group label{color:#999;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.setting-input,.setting-select{color:#e8e8e8;background:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;width:100%;padding:10px 12px;font-size:14px;transition:all .15s}.setting-input:focus,.setting-select:focus{background:#0a0a0a;border-color:#06c;outline:none}.setting-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.storage-estimate{background:#1a1a1a;border:1px solid #3a3a3a;border-radius:6px;margin-top:24px;padding:20px}.storage-estimate h4{color:#e8e8e8;margin:0 0 16px;font-size:16px}.estimate-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:12px;display:grid}.estimate-item{background:#2a2a2a;border-radius:4px;flex-direction:column;gap:4px;padding:12px;display:flex}.estimate-label{color:#999;font-size:12px}.estimate-value{color:#4da6ff;font-size:20px;font-weight:600}.estimate-note{color:#666;margin:0;font-size:11px;font-style:italic}.schedule-actions{gap:12px;margin-bottom:16px;display:flex}.schedule-btn{color:#e8e8e8;cursor:pointer;background:#3a3a3a;border:none;border-radius:4px;padding:8px 16px;font-size:12px;transition:all .15s}.schedule-btn:hover{background:#4a4a4a}.schedule-legend{color:#999;gap:20px;margin-bottom:16px;font-size:12px;display:flex}.legend-dot{border-radius:50%;width:12px;height:12px;margin-right:6px;display:inline-block}.schedule-grid{background:#1a1a1a;border-radius:4px;padding:12px;overflow-x:auto}.schedule-header{grid-template-columns:80px repeat(24,20px);gap:2px;margin-bottom:8px;display:grid}.schedule-hour-label{color:#666;text-align:center;font-size:10px}.schedule-row{grid-template-columns:80px repeat(24,20px);gap:2px;margin-bottom:4px;display:grid}.schedule-day-label{color:#999;align-items:center;gap:4px;padding-right:8px;font-size:12px;display:flex}.day-action-btn{cursor:pointer;opacity:.5;background:0 0;border:none;padding:2px;font-size:10px;transition:opacity .15s}.day-action-btn:hover{opacity:1}.schedule-cell{cursor:pointer;border-radius:2px;width:20px;height:20px;transition:all .15s}.schedule-cell:hover{opacity:.8;transform:scale(1.1)}.coming-soon{text-align:center;color:#666;padding:40px;font-size:14px}.settings-footer{background:#1c1c1c;border-top:1px solid #3a3a3a;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.btn-cancel,.btn-save{cursor:pointer;border:none;border-radius:6px;padding:10px 24px;font-size:14px;font-weight:600;transition:all .2s}.btn-cancel{color:#e8e8e8;background:#3a3a3a}.btn-save{color:#fff;background:#34c759}.btn-save:hover{background:#2fb350}.sensitivity-slider{-webkit-appearance:none;background:#3a3a3a;border-radius:3px;outline:none;width:100%;height:6px}.sensitivity-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#06c;border-radius:50%;width:18px;height:18px;transition:all .15s}.sensitivity-slider::-webkit-slider-thumb:hover{background:#0052a3;transform:scale(1.2)}.sensitivity-slider::-moz-range-thumb{cursor:pointer;background:#06c;border:none;border-radius:50%;width:18px;height:18px}.sensitivity-labels{color:#666;justify-content:space-between;margin-top:4px;font-size:11px;display:flex}.motion-zones-section{background:#1a1a1a;border-radius:6px;margin-top:24px;padding:20px}.motion-zones-section h4{margin:0 0 12px}.zone-hint{color:#999;margin:0 0 16px;font-size:12px;line-height:1.5}.motion-canvas-container{flex-direction:column;gap:16px;display:flex}.motion-preview{aspect-ratio:16/9;background:#000;border-radius:4px;width:100%;position:relative;overflow:hidden}.motion-preview-img{object-fit:cover;width:100%;height:100%}.motion-zones-overlay{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.motion-zone{cursor:move;pointer-events:all;transition:fill .15s}.motion-zone:hover{fill:#34c75980}.zone-controls{flex-wrap:wrap;gap:8px;display:flex}.zone-btn{color:#e8e8e8;cursor:pointer;background:#3a3a3a;border:none;border-radius:4px;padding:8px 16px;font-size:12px;transition:all .15s}.zone-btn:hover{background:#4a4a4a}.zone-btn.danger{color:#fff;background:#ff3b30}.zone-btn.danger:hover{background:#d32f2f}.zones-list{background:#2a2a2a;border-radius:4px;padding:12px}.zones-list strong{color:#e8e8e8;margin-bottom:8px;font-size:12px;display:block}.zone-item{color:#999;background:#1a1a1a;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:8px;font-size:12px;display:flex}.zone-remove-btn{color:#ff3b30;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:16px;transition:all .15s}.zone-remove-btn:hover{color:#d32f2f;transform:scale(1.2)}.motion-advanced{border-top:1px solid #3a3a3a;margin-top:24px;padding-top:24px}.motion-advanced h4{margin:0 0 16px}.display-subsection{border-bottom:1px solid #3a3a3a;margin-bottom:32px;padding-bottom:32px}.display-subsection:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.display-subsection h5{color:#e8e8e8;margin:0 0 16px;font-size:15px}.osd-preview{margin-top:16px}.osd-preview-container{aspect-ratio:16/9;background:#000;border-radius:4px;width:100%;position:relative;overflow:hidden}.osd-preview-img{object-fit:cover;width:100%;height:100%}.osd-overlay{background:linear-gradient(#0009,#0000);flex-direction:column;gap:4px;padding:12px;display:flex;position:absolute}.osd-overlay.top-left{top:0;left:0}.osd-overlay.top-right{background:linear-gradient(#0009,#0000);top:0;right:0}.osd-overlay.bottom-left{background:linear-gradient(#0000,#0009);bottom:0;left:0}.osd-overlay.bottom-right{background:linear-gradient(#0000,#0009);bottom:0;right:0}.osd-name{color:#fff;text-shadow:0 1px 3px #000c;font-size:14px;font-weight:600}.osd-time{color:#fff;text-shadow:0 1px 3px #000c;font-size:12px}.privacy-canvas-container{flex-direction:column;gap:16px;display:flex}.privacy-preview{aspect-ratio:16/9;background:#000;border-radius:4px;width:100%;position:relative;overflow:hidden}.privacy-preview-img{object-fit:cover;width:100%;height:100%}.privacy-masks-overlay{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.privacy-mask{cursor:move;pointer-events:all;transition:opacity .15s}.privacy-mask:hover{opacity:.9}.mask-controls{gap:8px;display:flex}.mask-btn{color:#e8e8e8;cursor:pointer;background:#3a3a3a;border:none;border-radius:4px;padding:8px 16px;font-size:12px;transition:all .15s}.mask-btn:hover{background:#4a4a4a}.mask-btn.danger{color:#fff;background:#ff3b30}.mask-btn.danger:hover{background:#d32f2f}.masks-list{background:#2a2a2a;border-radius:4px;padding:12px}.masks-list strong{color:#e8e8e8;margin-bottom:8px;font-size:12px;display:block}.mask-item{color:#999;background:#1a1a1a;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:8px;font-size:12px;display:flex}.mask-remove-btn{color:#ff3b30;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:16px;transition:all .15s}.mask-remove-btn:hover{color:#d32f2f;transform:scale(1.2)}.recording-view{height:100%;padding:24px;overflow-y:auto}.recording-view h2{color:#e8e8e8;margin:0 0 24px;font-size:24px}.recording-view h3{color:#e8e8e8;margin:0 0 16px;font-size:18px}.storage-info{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;margin-bottom:24px;padding:20px}.storage-stats{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px;display:grid}.stat-item{flex-direction:column;gap:4px;display:flex}.stat-label{color:#666;text-transform:uppercase;font-size:11px;font-weight:600}.stat-value{color:#e8e8e8;font-size:20px;font-weight:600}.stat-value.used{color:#ff9500}.stat-value.free{color:#34c759}.storage-bar{background:#1a1a1a;border-radius:16px;width:100%;height:32px;margin:16px 0;position:relative;overflow:hidden}.storage-used{background:linear-gradient(90deg,#06c 0%,#4da6ff 100%);justify-content:flex-end;align-items:center;height:100%;padding-right:12px;transition:width .3s;display:flex}.storage-percentage{color:#fff;text-shadow:0 1px 2px #00000080;font-size:13px;font-weight:600}.storage-path{border-top:1px solid #3a3a3a;margin-top:12px;padding-top:12px}.storage-path small{color:#666;font-size:12px}.recording-settings{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;padding:20px}.recording-table{border-collapse:collapse;width:100%;margin-top:16px}.recording-table th{text-align:left;color:#999;text-transform:uppercase;background:#1c1c1c;padding:12px;font-size:12px;font-weight:600}.recording-table td{color:#e8e8e8;border-top:1px solid #3a3a3a;padding:12px;font-size:13px}.function-select{color:#e8e8e8;cursor:pointer;background:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;padding:6px 12px;font-size:13px;transition:all .15s}.function-select:focus{background:#0a0a0a;border-color:#06c;outline:none}.fps-input{color:#e8e8e8;text-align:center;background:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;width:80px;padding:6px 12px;font-size:13px;transition:all .15s}.fps-input:focus{background:#0a0a0a;border-color:#06c;outline:none}.btn-save{color:#fff;cursor:pointer;background:#06c;border:none;border-radius:4px;padding:6px 16px;font-size:12px;transition:all .15s}.btn-save:hover:not(:disabled){background:#0052a3}.btn-save:disabled{color:#666;cursor:not-allowed;background:#3a3a3a}.export-recording-section{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;margin-bottom:24px;padding:20px}.export-recording-section h3{color:#e8e8e8;align-items:center;gap:8px;margin:0 0 20px;font-size:18px;display:flex}.export-modal-overlay{z-index:10000;background:#000c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.export-modal{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;width:90%;max-width:600px;animation:.3s slideUp;box-shadow:0 8px 32px #000c}.export-modal-header{border-bottom:1px solid #3a3a3a;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.export-modal-header h3{color:#e8e8e8;align-items:center;gap:8px;margin:0;font-size:18px;display:flex}.export-modal-close{color:#999;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;font-size:24px;transition:all .15s;display:flex}.export-modal-close:hover{color:#e8e8e8;background:#ffffff14}.export-modal-body{flex-direction:column;gap:16px;padding:24px;display:flex}.export-camera-display{color:#4da6ff;background:#1a1a1a;border:2px solid #06c;border-radius:4px;padding:12px 16px;font-size:16px;font-weight:600}.export-modal-footer{background:#1c1c1c;border-top:1px solid #3a3a3a;border-radius:0 0 8px 8px;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.btn-export-small{color:#fff;cursor:pointer;background:#34c759;border:none;border-radius:4px;margin-left:8px;padding:6px 12px;font-size:11px;font-weight:600;transition:all .15s}.btn-export-small:hover{background:#2fb350;transform:translateY(-1px)}.export-form{flex-direction:column;gap:16px;display:flex}.export-row{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.export-row:first-child{grid-template-columns:1fr}.export-field{flex-direction:column;gap:8px;display:flex}.export-field label{color:#999;text-transform:uppercase;font-size:12px;font-weight:600}.export-select,.export-input{color:#e8e8e8;background:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;padding:10px 12px;font-size:14px;transition:all .15s}.export-select:focus,.export-input:focus{background:#0a0a0a;border-color:#06c;outline:none}.export-select,.export-input[type=date],.export-input[type=time]{cursor:pointer}.export-input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.export-input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.export-actions{justify-content:flex-end;padding-top:8px;display:flex}.btn-export{color:#fff;cursor:pointer;background:#34c759;border:none;border-radius:6px;align-items:center;gap:8px;padding:12px 32px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.btn-export:hover:not(:disabled){background:#2fb350;transform:translateY(-1px);box-shadow:0 4px 12px #34c7594d}.btn-export:active:not(:disabled){transform:translateY(0)}.btn-export:disabled{color:#666;cursor:not-allowed;background:#3a3a3a}@media (max-width:768px){.export-row{grid-template-columns:1fr}.storage-stats{grid-template-columns:repeat(2,1fr)}}.logs-view{height:100%;padding:24px;overflow-y:auto}.logs-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.logs-header h2{color:#e8e8e8;margin:0;font-size:24px}.logs-filters{gap:8px;display:flex}.logs-table{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;overflow:hidden}.logs-table table{border-collapse:collapse;width:100%}.logs-table th{text-align:left;color:#999;text-transform:uppercase;background:#1c1c1c;padding:12px;font-size:12px;font-weight:600}.logs-table td{color:#e8e8e8;border-top:1px solid #3a3a3a;padding:12px;font-size:13px}.log-level-badge{border-radius:4px;padding:4px 8px;font-size:11px;font-weight:600}.log-error .log-level-badge{color:#f44;background:#f443}.log-warning .log-level-badge{color:#ff9800;background:#ff980033}.log-info .log-level-badge{color:#4da6ff;background:#06c3}.user-management{height:100%;padding:24px;overflow-y:auto}.user-management-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.user-management-header h2{color:#e8e8e8;align-items:center;gap:8px;margin:0;font-size:24px;display:flex}.btn-add-user{color:#fff;cursor:pointer;background:#34c759;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.btn-add-user:hover{background:#2fb350;transform:translateY(-1px)}.users-list{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;overflow:hidden}.users-table{border-collapse:collapse;width:100%}.users-table th{text-align:left;color:#999;text-transform:uppercase;background:#1c1c1c;padding:12px 16px;font-size:12px;font-weight:600}.users-table td{color:#e8e8e8;border-top:1px solid #3a3a3a;padding:16px;font-size:14px}.user-info{align-items:center;gap:12px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#06c 0%,#0052a3 100%);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.role-badge{text-transform:uppercase;border-radius:12px;padding:4px 12px;font-size:11px;font-weight:600}.role-admin{color:#ff3b30;background:#ff3b3033}.role-manager{color:#007aff;background:#007aff33}.role-viewer{color:#8e8e93;background:#8e8e9333}.status-badge{border-radius:12px;padding:4px 12px;font-size:11px;font-weight:600}.status-active{color:#34c759;background:#34c75933}.status-disabled{color:#8e8e93;background:#8e8e9333}.camera-count{color:#999;font-size:13px}.btn-edit,.btn-delete{cursor:pointer;border:none;border-radius:4px;margin-right:8px;padding:6px 12px;font-size:12px;transition:all .15s}.btn-edit{color:#fff;background:#06c}.btn-edit:hover{background:#0052a3}.btn-delete{color:#fff;background:#ff3b30}.btn-delete:hover{background:#d32f2f}.user-dialog-overlay{z-index:10000;background:#000c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.user-dialog{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;flex-direction:column;width:90%;max-width:800px;max-height:90vh;animation:.3s slideUp;display:flex;box-shadow:0 8px 32px #000c}.user-dialog-header{border-bottom:1px solid #3a3a3a;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.user-dialog-header h3{color:#e8e8e8;margin:0;font-size:18px}.user-dialog-footer{border-top:1px solid #3a3a3a;flex-shrink:0;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.dialog-close{color:#999;cursor:pointer;background:0 0;border:none;border-radius:4px;width:32px;height:32px;font-size:24px;transition:all .15s}.dialog-close:hover{color:#e8e8e8;background:#ffffff14}.user-dialog-body{flex:1;padding:24px;overflow-y:auto}.form-group label input[type=checkbox]{margin-right:8px}.form-input:focus,.form-select:focus{background:#0a0a0a;border-color:#06c;outline:none}.form-input:disabled{opacity:.5;cursor:not-allowed}.camera-selection-actions{align-items:center;gap:12px;margin-bottom:12px;display:flex}.btn-select-all,.btn-clear-all{color:#e8e8e8;cursor:pointer;background:#3a3a3a;border:none;border-radius:4px;padding:6px 12px;font-size:12px;transition:all .15s}.btn-select-all:hover,.btn-clear-all:hover{background:#4a4a4a}.selected-count{color:#999;margin-left:auto;font-size:12px}.camera-selection-grid{background:#1a1a1a;border-radius:4px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;max-height:300px;padding:12px;display:grid;overflow-y:auto}.camera-selection-item{cursor:pointer;background:#2a2a2a;border:2px solid #3a3a3a;border-radius:4px;align-items:center;gap:10px;padding:10px 12px;transition:all .15s;display:flex}.camera-selection-item:hover{background:#333;border-color:#4a4a4a}.camera-selection-item.selected{background:#06c3;border-color:#06c}.camera-checkbox{color:#fff;border:2px solid #3a3a3a;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:14px;display:flex}.camera-selection-item.selected .camera-checkbox{background:#06c;border-color:#06c}.camera-name{color:#e8e8e8;white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.user-dialog-footer{background:#1c1c1c;border-top:1px solid #3a3a3a;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.btn-cancel{color:#e8e8e8;cursor:pointer;background:#3a3a3a;border:none;border-radius:6px;padding:10px 24px;font-size:14px;font-weight:600;transition:all .2s}.btn-cancel:hover{background:#4a4a4a}.btn-save-user{color:#fff;cursor:pointer;background:#34c759;border:none;border-radius:6px;padding:10px 24px;font-size:14px;font-weight:600;transition:all .2s}.btn-save-user:hover{background:#2fb350}.loading{text-align:center;color:#666;padding:40px;font-size:14px}.action-rules{background:#0a0a0a;height:100%;padding:24px;overflow-y:auto}.action-rules-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.action-rules-header h2{color:#e8e8e8;margin:0 0 8px;font-size:28px}.action-rules-subtitle{color:#999;margin:0;font-size:14px}.btn-primary{color:#fff;cursor:pointer;background:#06c;border:none;border-radius:4px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.btn-primary:hover{background:#0052a3;transform:translateY(-1px)}.btn-secondary{color:#e8e8e8;cursor:pointer;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;padding:10px 20px;font-size:14px;transition:all .2s}.btn-secondary:hover{background:#3a3a3a}.rules-list{background:#1a1a1a;border-radius:8px;overflow:hidden}.no-rules{text-align:center;padding:80px 40px}.no-rules-icon{opacity:.3;margin-bottom:16px;font-size:64px}.no-rules h3{color:#e8e8e8;margin:0 0 8px;font-size:20px}.no-rules p{color:#999;margin:0 0 24px}.rules-table{overflow-x:auto}.rules-table table{border-collapse:collapse;width:100%}.rules-table thead{background:#0a0a0a}.rules-table th{text-align:left;color:#999;text-transform:uppercase;letter-spacing:.5px;padding:16px;font-size:13px;font-weight:500}.rules-table tbody tr{border-bottom:1px solid #2a2a2a;transition:background .2s}.rules-table tbody tr:hover{background:#ffffff05}.rules-table tbody tr.disabled{opacity:.5}.rules-table td{color:#e8e8e8;padding:16px;font-size:14px}.rule-name{font-weight:500}.rule-actions{gap:8px;display:flex}.btn-icon{color:#e8e8e8;cursor:pointer;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:all .2s;display:flex}.btn-icon:hover{background:#3a3a3a;border-color:#06c}.btn-icon.danger:hover{background:#ff3b30;border-color:#ff3b30}.toggle-switch{width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:#3a3a3a;border-radius:24px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .3s;position:absolute;bottom:3px;left:3px}input:checked+.toggle-slider{background-color:#06c}input:checked+.toggle-slider:before{transform:translate(20px)}.modal-overlay{z-index:9999;background:#000c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-container{background:#1a1a1a;border-radius:8px;flex-direction:column;width:90%;max-width:600px;max-height:90vh;display:flex;box-shadow:0 8px 32px #000c}.modal-container.large{max-width:800px}.modal-header{border-bottom:1px solid #2a2a2a;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{color:#e8e8e8;margin:0;font-size:20px}.modal-close{color:#999;cursor:pointer;background:#2a2a2a;border:none;border-radius:4px;width:32px;height:32px;font-size:20px;transition:all .2s}.modal-close:hover{color:#e8e8e8;background:#3a3a3a}.modal-body{flex:1;padding:24px;overflow-y:auto}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:#0a0a0a}.modal-body::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:3px}.modal-footer{border-top:1px solid #2a2a2a;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.form-section{margin-bottom:32px}.form-section h4{color:#06c;align-items:center;gap:8px;margin:0 0 16px;font-size:16px;display:flex}.form-input,.form-select{color:#e8e8e8;background:#0a0a0a;border:1px solid #3a3a3a;border-radius:4px;width:100%;padding:10px 12px;font-size:14px;transition:all .2s}.form-input:focus,.form-select:focus{border-color:#06c;outline:none}.checkbox-label{cursor:pointer;border-radius:4px;align-items:center;gap:8px;padding:8px;transition:background .2s;display:flex}.checkbox-label:hover{background:#ffffff05}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px}.checkbox-label span{color:#e8e8e8;font-size:14px}.camera-checkboxes{background:#0a0a0a;border:1px solid #2a2a2a;border-radius:4px;max-height:200px;padding:8px;overflow-y:auto}.camera-checkboxes::-webkit-scrollbar{width:6px}.camera-checkboxes::-webkit-scrollbar-track{background:#0a0a0a}.camera-checkboxes::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:3px}.time-range{align-items:center;gap:12px;margin-top:8px;display:flex}.time-range span{color:#999}.time-range .form-input{flex:1;width:auto}.action-group{background:#0a0a0a;border-radius:4px;margin-bottom:12px;padding:16px}.action-group .checkbox-label{margin-bottom:8px;font-weight:500}.action-group .form-input,.action-group .form-select{margin-top:8px}.recording-options{align-items:center;gap:12px;margin-top:8px;display:flex}.recording-options label{color:#999;margin:0;font-size:13px}.recording-options .form-input{width:120px;margin:0}.app-launcher{background:linear-gradient(135deg,#1a1a1a 0%,#0a0a0a 100%);flex-direction:column;align-items:center;height:100%;padding:40px;display:flex;overflow-y:auto}.app-launcher-header{text-align:center;margin-bottom:48px}.app-launcher-header h2{color:#e8e8e8;margin:0 0 8px;font-size:32px;font-weight:300}.app-launcher-subtitle{color:#999;margin:0;font-size:14px}.app-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px;width:100%;max-width:1200px;margin-bottom:48px;display:grid}.app-card{cursor:pointer;text-align:center;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;flex-direction:column;align-items:center;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.app-card:before{content:"";background:var(--app-color);height:3px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.app-card:hover{border-color:var(--app-color);background:#2a2a2a;transform:translateY(-4px);box-shadow:0 8px 24px #0006}.app-card:hover:before{transform:scaleX(1)}.app-card:active{transform:translateY(-2px)}.app-icon{border-radius:16px;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:16px;font-size:40px;transition:all .3s;display:flex;box-shadow:0 4px 12px #0000004d}.app-card:hover .app-icon{transform:scale(1.1);box-shadow:0 8px 24px #00000080}.app-info{width:100%}.app-name{color:#e8e8e8;margin-bottom:8px;font-size:16px;font-weight:500}.app-description{color:#999;font-size:12px;line-height:1.4}.app-launcher-footer{text-align:center;background:#0066cc1a;border-radius:8px;max-width:600px;padding:24px}.app-launcher-footer p{color:#4da6ff;margin:0;font-size:13px}@media (max-width:768px){.app-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.app-card{padding:16px}.app-icon{width:60px;height:60px;font-size:32px}.app-name{font-size:14px}.app-description{font-size:11px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.app-card{animation:.4s ease-out backwards fadeInUp}.app-card:first-child{animation-delay:50ms}.app-card:nth-child(2){animation-delay:.1s}.app-card:nth-child(3){animation-delay:.15s}.app-card:nth-child(4){animation-delay:.2s}.app-card:nth-child(5){animation-delay:.25s}.app-card:nth-child(6){animation-delay:.3s}.app-card:nth-child(7){animation-delay:.35s}.app-card:nth-child(8){animation-delay:.4s}.app-card:nth-child(9){animation-delay:.45s}.help-container{color:#e0e0e0;max-width:1200px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.help-header{text-align:center;border-bottom:2px solid #333;margin-bottom:40px;padding-bottom:20px}.help-header h1{color:#fff;margin:0 0 10px;font-size:32px}.help-header p{color:#999;margin:0;font-size:16px}.help-search{margin-bottom:30px;position:relative}.help-search input{color:#fff;background:#1a1a1a;border:1px solid #333;border-radius:8px;width:100%;padding:12px 40px 12px 15px;font-size:14px}.help-search input:focus{border-color:#06c;outline:none}.help-search-icon{color:#666;position:absolute;top:50%;right:15px;transform:translateY(-50%)}.help-content{gap:30px;display:flex}.help-sidebar{flex-shrink:0;width:250px}.help-nav{background:#1a1a1a;border-radius:8px;padding:15px;position:sticky;top:20px}.help-nav-item{cursor:pointer;border-radius:6px;align-items:center;gap:10px;margin-bottom:5px;padding:10px 15px;font-size:14px;transition:all .2s;display:flex}.help-nav-item:hover{background:#252525}.help-nav-item.active{color:#fff;background:#06c}.help-main{flex:1;min-width:0}.help-section{background:#1a1a1a;border-radius:8px;margin-bottom:20px;padding:30px}.help-section h2{color:#fff;align-items:center;gap:10px;margin:0 0 20px;font-size:24px;display:flex}.help-section h3{color:#06c;margin:25px 0 15px;font-size:18px}.help-section h4{color:#fff;margin:20px 0 10px;font-size:16px}.help-section p{color:#ccc;margin:10px 0;line-height:1.6}.help-section ul,.help-section ol{margin:15px 0;padding-left:25px}.help-section li{color:#ccc;margin:8px 0;line-height:1.6}.help-note{background:#2a2a2a;border-left:4px solid #06c;border-radius:4px;margin:20px 0;padding:15px}.help-note.warning{border-left-color:#ff9500}.help-note.error{border-left-color:#ff3b30}.help-note.success{border-left-color:#34c759}.help-note-title{color:#fff;margin-bottom:8px;font-weight:600}.help-code{color:#06c;background:#0a0a0a;border:1px solid #333;border-radius:4px;padding:2px 6px;font-family:Courier New,monospace;font-size:13px}.help-table{border-collapse:collapse;width:100%;margin:20px 0}.help-table th,.help-table td{text-align:left;border-bottom:1px solid #333;padding:12px}.help-table th{color:#fff;background:#252525;font-weight:600}.help-table td{color:#ccc}.help-image{border:1px solid #333;border-radius:8px;max-width:100%;margin:20px 0}.help-button{color:#fff;cursor:pointer;background:#06c;border:none;border-radius:6px;margin:10px 10px 10px 0;padding:10px 20px;font-size:14px;text-decoration:none;transition:background .2s;display:inline-block}.help-button:hover{background:#0052a3}.help-button.secondary{background:#333}.help-button.secondary:hover{background:#444}@media (max-width:768px){.help-content{flex-direction:column}.help-sidebar{width:100%}.help-nav{position:static}}.dashboard{flex-direction:column;height:100%;display:flex;overflow:hidden}.view-placeholder{color:#666;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.placeholder-icon{opacity:.5;font-size:64px}.view-placeholder h2{color:#999;margin:0;font-size:24px;font-weight:600}.view-placeholder p{color:#666;margin:0;font-size:14px}.sidebar{background:#1c1c1c;border-right:1px solid #0a0a0a;flex-direction:column;flex-shrink:0;width:180px;display:flex}.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto}.nav-item{color:#b8b8b8;cursor:pointer;-webkit-user-select:none;user-select:none;border-left:3px solid #0000;align-items:center;gap:12px;padding:11px 16px;font-size:13px;transition:all .15s;display:flex}.nav-item:hover{color:#e8e8e8;background:#ffffff0d}.nav-item.active{color:#4da6ff;background:#0066cc26;border-left-color:#06c}.nav-icon{justify-content:center;align-items:center;width:20px;font-size:16px;display:flex}.nav-label{letter-spacing:.2px;font-weight:400}.header{background:#1c1c1c;border-bottom:1px solid #0a0a0a;flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 12px;display:flex}.header-left{flex-shrink:0;align-items:center;gap:12px;display:flex}.logo{align-items:center;gap:10px;display:flex}.logo h1{color:#e0e0e0;letter-spacing:.3px;white-space:nowrap;font-size:20px;font-weight:600}.header-menu-btn{color:#999;cursor:pointer;background:0 0;border:1px solid #333;border-radius:3px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:all .15s;display:flex}.header-menu-btn:hover{color:#e0e0e0;background:#ffffff0d;border-color:#444}.header-search{position:relative}.header-search input{color:#e0e0e0;background:#0a0a0a;border:1px solid #2a2a2a;border-radius:3px;outline:none;width:240px;height:28px;padding:0 10px 0 30px;font-size:12px;transition:all .15s}.header-search input:focus{background:#151515;border-color:#06c}.header-search input::placeholder{color:#555}.header-search-icon{color:#555;font-size:12px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.header-center{flex:1;justify-content:center;padding:0 20px;display:flex;overflow:hidden}.header-tabs{align-items:center;gap:4px;display:flex}.header-tab{cursor:pointer;color:#999;white-space:nowrap;background:#2a2a2a;border-radius:3px;align-items:center;gap:8px;padding:6px 12px;font-size:12px;transition:all .15s;display:flex}.header-tab:hover{color:#e0e0e0;background:#333}.header-tab.active{color:#fff;background:#06c}.tab-close{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:2px;justify-content:center;align-items:center;width:16px;height:16px;padding:0;font-size:16px;line-height:1;transition:all .15s;display:flex}.tab-close:hover{opacity:1;background:#0003}.header-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.header-btn{color:#999;cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:all .15s;display:flex;position:relative}.header-btn:hover{color:#e0e0e0;background:#ffffff0d}.header-btn .badge{color:#fff;text-align:center;background:#e74c3c;border-radius:8px;min-width:14px;padding:2px 4px;font-size:9px;font-weight:600;line-height:1;position:absolute;top:2px;right:2px}.header-user{cursor:pointer;background:0 0;border:none;border-radius:3px;align-items:center;gap:6px;margin-left:4px;padding:3px 10px 3px 3px;transition:all .15s;display:flex}.header-user:hover{background:#ffffff0d}.header-user-avatar{color:#fff;background:linear-gradient(135deg,#06c 0%,#0052a3 100%);border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:600;display:flex}.header-user-name{color:#e0e0e0;font-size:12px}.user-menu-header{background:#1c1c1c;gap:12px;padding:16px;display:flex}.header-user-wrapper{position:relative}.user-menu-backdrop{z-index:999;position:fixed;inset:0}.user-menu{z-index:1000;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;width:220px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 4px 12px #00000080}.user-menu-header{background:#1c1c1c;border-bottom:1px solid #3a3a3a;gap:12px;padding:16px;display:flex}.user-menu-avatar{color:#fff;background:linear-gradient(135deg,#06c 0%,#0052a3 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;font-weight:600;display:flex}.user-menu-info{flex-direction:column;justify-content:center;gap:4px;display:flex}.user-menu-name{color:#e8e8e8;font-size:13px;font-weight:600}.user-menu-email{color:#999;font-size:11px}.user-menu-divider{background:#3a3a3a;height:1px;margin:4px 0}.user-menu-item{color:#e8e8e8;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:10px 16px;font-size:12px;transition:all .15s;display:flex}.user-menu-item:hover{background:#ffffff14}.user-menu-item span:first-child{justify-content:center;align-items:center;width:20px;font-size:16px;display:flex}.logo-image{object-fit:contain;border-radius:6px;width:36px;height:36px}.header-lang-wrapper{position:relative}.lang-menu-backdrop{z-index:999;position:fixed;inset:0}.lang-menu{z-index:1000;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;width:180px;padding:6px 0;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 4px 12px #00000080}.lang-menu-item{color:#e8e8e8;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:14px;transition:all .15s;display:flex}.lang-menu-item:hover{background:#ffffff14}.lang-menu-item.active{color:#4da6ff;background:#06c3}.lang-menu-item span:first-child{justify-content:center;align-items:center;width:28px;font-size:24px;display:flex}.header-help-wrapper{position:relative}.help-menu-backdrop{z-index:999;position:fixed;inset:0}.help-menu{z-index:1000;scrollbar-width:thin;scrollbar-color:#3a3a3a #2a2a2a;background:#2a2a2a;border:1px solid #3a3a3a;border-radius:6px;width:360px;max-height:600px;position:absolute;top:calc(100% + 8px);right:0;overflow-y:auto;box-shadow:0 8px 24px #0009}.help-menu::-webkit-scrollbar{width:6px}.help-menu::-webkit-scrollbar-track{background:#2a2a2a}.help-menu::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:3px}.help-menu-header{color:#e8e8e8;z-index:10;background:#1c1c1c;border-bottom:1px solid #3a3a3a;align-items:center;gap:10px;padding:16px 20px;font-size:16px;font-weight:600;display:flex;position:sticky;top:0}.help-menu-header span:first-child{font-size:20px}.help-menu-section{padding:12px 0}.help-menu-section-title{color:#999;text-transform:uppercase;letter-spacing:.5px;padding:8px 20px;font-size:11px;font-weight:600}.help-menu-item{cursor:pointer;text-align:left;background:0 0;border:none;align-items:flex-start;gap:12px;width:100%;padding:12px 20px;transition:all .15s;display:flex}.help-menu-item:hover{background:#ffffff14}.help-menu-item>span:first-child{flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:2px;font-size:20px;display:flex}.help-menu-item-content{flex-direction:column;flex:1;gap:4px;display:flex}.help-menu-item-title{color:#e8e8e8;font-size:13px;font-weight:500;line-height:1.4}.help-menu-item-desc{color:#999;font-size:11px;line-height:1.5}.help-menu-divider{background:#3a3a3a;height:1px;margin:8px 0}.help-menu-footer{background:#1c1c1c;border-top:1px solid #3a3a3a;flex-direction:column;gap:10px;padding:16px 20px;display:flex}.help-menu-version{color:#666;text-align:center;font-size:11px}.help-menu-links{justify-content:center;align-items:center;gap:8px;font-size:11px;display:flex}.help-menu-links a{color:#06c;text-decoration:none;transition:color .15s}.help-menu-links a:hover{color:#4da6ff;text-decoration:underline}.help-menu-links span{color:#555}.user-guide-overlay{z-index:10000;background:#000000e6;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.user-guide-modal{background:#1a1a1a;border-radius:8px;flex-direction:column;width:90%;max-width:1200px;height:90%;display:flex;overflow:hidden;box-shadow:0 8px 32px #000c}.user-guide-header{background:#0a0a0a;border-bottom:1px solid #2a2a2a;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.user-guide-header h2{color:#e8e8e8;margin:0;font-size:24px;font-weight:500}.user-guide-close{color:#999;cursor:pointer;background:#2a2a2a;border:none;border-radius:4px;justify-content:center;align-items:center;width:40px;height:40px;font-size:24px;transition:all .2s;display:flex}.user-guide-close:hover{color:#e8e8e8;background:#3a3a3a}.user-guide-content{color:#e8e8e8;background:#1a1a1a;flex:1;padding:32px;line-height:1.6;overflow:auto}.user-guide-content::-webkit-scrollbar{width:8px}.user-guide-content::-webkit-scrollbar-track{background:#0a0a0a}.user-guide-content::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:4px}.user-guide-content::-webkit-scrollbar-thumb:hover{background:#4a4a4a}.user-guide-content h1{color:#06c;margin-top:0;margin-bottom:24px;font-size:32px}.user-guide-content h2{color:#e8e8e8;border-bottom:1px solid #2a2a2a;margin-top:40px;margin-bottom:16px;padding-bottom:8px;font-size:24px}.user-guide-content h3{color:#06c;margin-top:24px;margin-bottom:12px;font-size:20px}.user-guide-content p{margin-bottom:16px}.user-guide-content ul,.user-guide-content ol{margin-bottom:16px;padding-left:24px}.user-guide-content li{margin-bottom:8px}.user-guide-content code{color:#4da6ff;background:#0a0a0a;border-radius:3px;padding:2px 6px;font-family:Courier New,monospace;font-size:14px}.user-guide-content pre{background:#0a0a0a;border-radius:4px;margin-bottom:16px;padding:16px;overflow-x:auto}.user-guide-content pre code{color:#e8e8e8;background:0 0;padding:0}.user-guide-content blockquote{color:#999;border-left:4px solid #06c;margin-left:0;padding-left:16px;font-style:italic}.user-guide-content a{color:#06c;text-decoration:none}.user-guide-content a:hover{text-decoration:underline}.user-guide-content table{border-collapse:collapse;width:100%;margin-bottom:16px}.user-guide-content th,.user-guide-content td{text-align:left;border:1px solid #2a2a2a;padding:12px}.user-guide-content th{background:#0a0a0a;font-weight:500}.user-guide-content hr{border:none;border-top:1px solid #2a2a2a;margin:32px 0}.zm-settings-overlay{z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.zm-settings-modal{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:8px;flex-direction:column;width:90%;max-width:600px;max-height:90vh;display:flex;box-shadow:0 8px 32px #0009}.zm-settings-header{border-bottom:1px solid #3a3a3a;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.zm-settings-header h2{color:#e8e8e8;margin:0;font-size:18px;font-weight:600}.close-btn{color:#999;cursor:pointer;background:0 0;border:none;border-radius:4px;width:32px;height:32px;font-size:20px;transition:all .15s}.close-btn:hover{color:#e8e8e8;background:#ffffff14}.zm-settings-body{flex:1;padding:24px;overflow-y:auto}.form-group{margin-bottom:20px}.form-group label{color:#e8e8e8;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.form-group input{color:#e8e8e8;background:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;outline:none;width:100%;height:40px;padding:0 12px;font-size:14px;transition:all .15s}.form-group input:focus{background:#222;border-color:#06c}.form-group small{color:#999;margin-top:6px;font-size:12px;display:block}.error-message{color:#e74c3c;background:#e74c3c1a;border:1px solid #e74c3c4d;border-radius:4px;margin-bottom:20px;padding:12px 16px;font-size:13px}.zm-settings-info{background:#0066cc1a;border:1px solid #0066cc4d;border-radius:4px;margin-top:20px;padding:16px}.zm-settings-info h3{color:#4da6ff;margin:0 0 12px;font-size:14px;font-weight:600}.zm-settings-info ol{color:#b8b8b8;margin:0;padding-left:20px;font-size:13px;line-height:1.8}.zm-settings-footer{border-top:1px solid #3a3a3a;justify-content:flex-end;gap:12px;padding:16px 24px;display:flex}.btn-secondary,.btn-primary{cursor:pointer;border:none;border-radius:4px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .15s}.btn-secondary{color:#b8b8b8;background:0 0;border:1px solid #3a3a3a}.btn-secondary:hover{color:#e8e8e8;background:#ffffff0d;border-color:#555}.btn-primary{color:#fff;background:#06c}.btn-primary:hover{background:#0052a3}.btn-primary:disabled{color:#888;cursor:not-allowed;background:#444}.login-container{z-index:10000;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login-box{background:#fff;border-radius:8px;width:500px;max-width:90%;padding:60px 80px;position:relative;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:40px}.login-title{color:#06c;letter-spacing:2px;margin:0;font-size:36px;font-weight:300}.login-form{position:relative}.login-subtitle{color:#333;margin:0 0 30px;font-size:24px;font-weight:400}.login-input-group{margin-bottom:20px}.login-input{box-sizing:border-box;background:0 0;border:none;border-bottom:2px solid #e0e0e0;outline:none;width:100%;padding:15px;font-size:16px;transition:border-color .3s}.login-input:focus{border-bottom-color:#06c}.login-input::placeholder{color:#999}.login-remember{margin:20px 0}.login-remember label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;display:flex}.login-remember input[type=checkbox]{cursor:pointer;width:18px;height:18px;margin-right:10px}.login-remember span{color:#666;font-size:14px}.login-error{color:#d32f2f;background:#ffebee;border-radius:4px;margin:15px 0;padding:10px;font-size:14px}.login-btn-next{color:#fff;cursor:pointer;background:#06c;border:none;border-radius:50%;justify-content:center;align-items:center;width:70px;height:70px;font-size:32px;transition:all .3s;display:flex;position:absolute;bottom:20px;right:-20px;box-shadow:0 4px 12px #06c6}.login-btn-next:hover:not(:disabled){background:#0052a3;transform:scale(1.05);box-shadow:0 6px 16px #0066cc80}.login-btn-next:disabled{opacity:.6;cursor:not-allowed}.login-back-btn{color:#666;cursor:pointer;background:0 0;border:none;padding:10px;font-size:24px;transition:color .3s;position:absolute;top:0;left:0}.login-back-btn:hover{color:#06c}.login-user-info{align-items:center;gap:15px;margin-bottom:30px;display:flex}.login-user-avatar{color:#fff;background:#06c;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:24px;font-weight:500;display:flex}.login-user-name{color:#333;font-size:18px;font-weight:500}
