:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";color-scheme:light dark;color:#ffffffde;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary-color: #1677ff;--primary-hover: #4096ff;--primary-light: #e6f4ff;--primary-dark: #0958d9;--secondary-color: #67c23a;--success-color: #52c41a;--success-light: #f6ffed;--success-dark: #389e0d;--danger-color: #f56c6c;--error-color: #ff4d4f;--error-light: #fff1f0;--error-dark: #cf1322;--warning-color: #faad14;--warning-light: #fffbe6;--warning-dark: #d48806;--info-color: #1890ff;--info-light: #e6f7ff;--info-dark: #096dd9;--text-primary: #333333;--text-secondary: #666666;--text-tertiary: #999999;--text-disabled: #bfbfbf;--text-inverse: #ffffff;--bg-white: #ffffff;--bg-primary: #f8fafc;--bg-secondary: #f5f5f5;--bg-hover: #fafafa;--bg-disabled: #f0f0f0;--bg-overlay: rgba(0, 0, 0, .4);--border-color: #d9d9d9;--border-light: #f0f0f0;--border-medium: #d9d9d9;--border-dark: #8c8c8c;--role-super-admin: #1677ff;--role-admin: #67c23a;--role-user: #95a5a6;--role-viewer: #95a5a6;--shadow-light: rgba(0, 0, 0, .06);--shadow-medium: rgba(0, 0, 0, .1);--shadow-dark: rgba(0, 0, 0, .15);--status-online: #52c41a;--status-offline: #ff4d4f;--status-idle: #faad14;--border-radius: 6px;--border-radius-sm: 4px;--border-radius-lg: 8px;--transition-speed: .2s;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem}*{margin:0;padding:0;box-sizing:border-box;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"}.app{display:flex;flex-direction:row;min-height:100vh;height:100vh;width:100%;margin:0;padding-left:14px}.main-content{display:flex;flex:auto;flex-direction:column;min-height:0;background:#f5f5f5;background-color:#f8fafc}.content-area{padding:24px;overflow-y:auto;height:calc(100vh - 60px)}.loading-overlay{position:fixed;top:0;left:0;z-index:9999;width:100vw;height:100vh;background-color:#ffffffb3;display:flex;justify-content:center;align-items:center}@media(max-width:768px){.app{padding-left:0}.main-content{margin-left:0}}.sidebar-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999}@media(min-width:769px){.sidebar-backdrop{display:none}}.custom-popup-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1001;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}.custom-popup-content{background:var(--bg-white);border-radius:var(--border-radius-lg);width:90%;max-width:550px;position:relative;box-shadow:0 8px 32px #0003;animation:slideUp .3s ease;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.popup-close-btn{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border:none;background:#00000080;color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease}.popup-close-btn:hover{background:#000000b3;transform:scale(1.1)}.popup-header{padding:1.5rem;display:flex;align-items:center;gap:1rem;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-white) 100%);border-bottom:1px solid var(--border-color)}.popup-icon{width:48px;height:48px;border-radius:12px;background:#1677ff1f;color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.popup-title-block{flex:1}.popup-title-block h3{margin:0 0 .5rem;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.popup-status-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;border-radius:999px;font-size:.8rem;font-weight:500}.popup-status-badge.online{background:#22c55e1f;color:#16a34a}.popup-status-badge.online svg{font-size:.6rem;animation:pulse 2s infinite}.popup-status-badge.offline{background:#9ca3af1f;color:#6b7280}.popup-status-badge.offline svg{font-size:.6rem}.popup-video-container{position:relative;width:100%;padding-top:56.25%;background:#000;overflow:hidden}.popup-video-iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.popup-video-loader,.popup-video-error{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#fff}.popup-video-error{background:linear-gradient(135deg,#1f2937,#111827)}.popup-video-error svg{font-size:3rem;opacity:.5}.popup-video-error p{margin:0;font-size:.95rem;color:#ffffffb3}.loader-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.popup-video-loader p{margin:0;font-size:.9rem;color:#fffc}.popup-footer{padding:1.25rem 1.5rem;border-top:1px solid var(--border-color);background:var(--bg-white)}.popup-details-btn{width:100%;justify-content:center}@media(max-width:768px){.custom-popup-content{width:95%;max-width:none;margin:1rem}.popup-header{padding:1.25rem}.popup-icon{width:40px;height:40px;font-size:1.2rem}.popup-title-block h3{font-size:1rem}.popup-footer{padding:1rem 1.25rem}}._btn_1cjt7_1{background-color:var(--primary-color);color:#fff;border-radius:8px;border:1px solid transparent;text-decoration:none;text-align:center;display:inline-block;cursor:pointer;font-family:inherit;outline:none;position:relative;font-weight:400;white-space:nowrap;background-image:none;transition:all .2s cubic-bezier(.645,.045,.355,1);-webkit-user-select:none;user-select:none;touch-action:manipulation;box-shadow:0 2px #0000000a}._small_1cjt7_23{padding:4px 8px;font-size:12px;line-height:1.5;min-width:60px}._medium_1cjt7_30{padding:5px 12px;font-size:14px;line-height:1.5;min-width:80px}._large_1cjt7_37{padding:7px 15px;font-size:16px;line-height:1.5;min-width:100px}._btn_1cjt7_1:not(._full-width_1cjt7_45){width:auto}._full-width_1cjt7_45{width:100%}._btn_1cjt7_1:hover{color:#fff;background-color:#4096ff}._btn_1cjt7_1:disabled{background-color:var(--border-color);cursor:not-allowed;opacity:.6}._inputWrapper_8ql1u_1{display:flex;flex-direction:column;gap:.25rem}._inputWrapper_8ql1u_1 label{font-size:.9375rem;color:var(--text-primary);margin-bottom:.1rem;font-weight:400;transition:color .2s ease}._input_8ql1u_1{border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-white);color:#000000e0;outline:none;width:100%;box-sizing:border-box;display:inline-flex;position:relative;min-width:0;padding:4px 11px;font-size:14px;line-height:1.5714285714285714;background-image:none;transition:all .2s;min-height:34px}._input_8ql1u_1::placeholder{font-size:14px;color:var(--text-tertiary)}._input_8ql1u_1:focus{border-color:#4096ff;box-shadow:0 0 0 2px #0591ff1a;border-inline-end-width:1px;outline:0}._input_8ql1u_1:hover{border-color:#4096ff;border-inline-end-width:1px}._input_8ql1u_1:disabled{background-color:var(--bg-disabled);color:var(--text-disabled);cursor:not-allowed}._error_8ql1u_57{border-color:var(--danger-color)!important;box-shadow:0 0 0 2px #ef44444d}._inputWithIcon_8ql1u_62{position:relative}._inputWithIcon_8ql1u_62 input{padding-right:2.5rem}._eyeIcon_8ql1u_71{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-primary);font-size:1.2rem;transition:color .2s ease;z-index:2}._eyeIcon_8ql1u_71:hover{color:var(--primary-color)}._addonButton_8ql1u_90{position:absolute;right:6px;top:50%;transform:translateY(-50%);z-index:2}._inputWithIcon_8ql1u_62:has(._addonButton_8ql1u_90) input{padding-right:140px}._input_8ql1u_1[type=checkbox]{display:none}._input_8ql1u_1[type=checkbox]+label{position:relative;padding-left:32px;cursor:pointer;display:inline-flex;align-items:center;font-size:.875rem;color:var(--text-primary);line-height:1.2;-webkit-user-select:none;user-select:none}._input_8ql1u_1[type=checkbox]+label:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:20px;height:20px;background-color:var(--bg-white);border:1px solid var(--border-color);border-radius:5px;transition:all .3s ease}._input_8ql1u_1[type=checkbox]:hover+label:before,._input_8ql1u_1[type=checkbox]:focus+label:before{border-color:var(--primary-color)}._input_8ql1u_1[type=checkbox]:checked+label:before{background-color:var(--primary-color);border-color:var(--primary-color)}._input_8ql1u_1[type=checkbox]:checked+label:after{content:"✓";position:absolute;left:5px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--bg-white)}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.cameras-page{height:calc(100vh - 60px);width:100%;position:relative;background:var(--bg-primary)}.map-container{height:100%;width:100%;position:relative}.leaflet-container{height:100%;width:100%;z-index:1}.map-controls{position:absolute;top:1rem;left:1rem;z-index:99;display:flex;flex-direction:column;gap:.75rem;max-width:350px}.search-box{background:var(--bg-white);padding:.75rem;border-radius:var(--border-radius-lg);box-shadow:0 4px 12px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease}.search-box:hover{box-shadow:0 6px 16px #00000026}.search-box input{border:none!important;box-shadow:none!important;padding:.5rem .75rem!important;font-size:.9rem!important;background:transparent!important}.search-box input:focus{border:none!important;box-shadow:none!important;outline:none!important}.toggle-list-btn{position:absolute;top:1rem;right:5.5rem;z-index:99;width:44px;height:44px;border-radius:var(--border-radius-lg);background:var(--bg-white);border:none;box-shadow:0 4px 12px #0000001a;color:var(--primary-color);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.toggle-list-btn:hover{box-shadow:0 6px 16px #00000026;transform:translateY(-2px)}.camera-count-badge{position:absolute;top:1rem;right:1rem;z-index:99;background:var(--bg-white);padding:.75rem 1.25rem;border-radius:var(--border-radius-lg);box-shadow:0 4px 12px #0000001a;display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-primary);font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease}.camera-count-badge:hover{box-shadow:0 6px 16px #00000026;transform:translateY(-2px)}.camera-count-badge svg{color:var(--primary-color)}.camera-count-badge .count{color:var(--primary-color);font-weight:700;font-size:1.2rem}.cameras-list-panel{position:absolute;top:1rem;right:1rem;bottom:1rem;width:320px;background:var(--bg-white);border-radius:var(--border-radius-lg);box-shadow:0 8px 24px #00000026;z-index:100;display:flex;flex-direction:column;animation:slideInRight .3s ease}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.cameras-list-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.cameras-list-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.cameras-list-header button{width:28px;height:28px;border-radius:50%;border:none;background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.cameras-list-header button:hover{background:var(--error-light);color:var(--error-color)}.cameras-list-content{flex:1;overflow-y:auto;padding:.5rem}.cameras-list-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);font-size:.9rem}.camera-list-item{display:flex;align-items:center;gap:.75rem;padding:.85rem;margin-bottom:.5rem;border-radius:var(--border-radius);background:var(--bg-secondary);cursor:pointer;transition:all .2s ease}.camera-list-item:hover{background:var(--bg-primary);transform:translate(4px)}.camera-list-item.active{background:#1677ff1a;border-left:3px solid var(--primary-color)}.camera-list-icon{width:36px;height:36px;border-radius:8px;background:#1677ff1f;color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.camera-list-info{flex:1;min-width:0}.camera-list-info h4{margin:0 0 .25rem;font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.camera-list-status{font-size:.75rem;font-weight:500}.camera-list-status.online{color:#16a34a}.camera-list-status.offline{color:#9ca3af}.map-legend{position:absolute;bottom:1.5rem;left:1rem;z-index:99;background:var(--bg-white);padding:1rem 1.25rem;border-radius:var(--border-radius-lg);box-shadow:0 4px 12px #0000001a;min-width:180px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.map-legend h4{margin:0 0 .75rem;font-size:.85rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.legend-item{display:flex;align-items:center;gap:.65rem;margin-bottom:.6rem;font-size:.85rem;color:var(--text-secondary);font-weight:500}.legend-item:last-child{margin-bottom:0}.legend-marker{width:14px;height:14px;border-radius:50%;flex-shrink:0;border:2px solid white;box-shadow:0 2px 4px #0003}.legend-marker.online{background-color:#4caf50;box-shadow:0 0 8px #4caf5099}.legend-marker.offline{background-color:#9e9e9e}@media(max-width:768px){.cameras-list-panel{width:280px;right:.75rem;top:.75rem;bottom:.75rem}.toggle-list-btn{right:4.5rem;width:40px;height:40px}.camera-count-badge{padding:.6rem 1rem;font-size:.85rem}}.summary-card{background:var(--bg-white);border-radius:var(--border-radius-lg);padding:1.1rem 1.3rem;box-shadow:0 1px 3px var(--shadow-light);display:flex;flex-direction:column;gap:.4rem}.summary-header{display:flex;flex-direction:column;gap:.15rem}.summary-title{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary)}.summary-label{font-size:.8rem;color:var(--text-tertiary)}.summary-value-container{display:flex;align-items:center;justify-content:space-between}.summary-value{font-size:1.6rem;font-weight:600;color:var(--text-primary)}.summary-subtitle{font-size:.8rem;color:var(--text-tertiary)}.summary-card[data-color=green] .summary-value,.summary-card[data-color=green] .summary-icon{color:var(--success-color)}.summary-card[data-color=orange] .summary-value,.summary-card[data-color=orange] .summary-icon{color:var(--warning-color)}.summary-card[data-color=red] .summary-value,.summary-card[data-color=red] .summary-icon{color:var(--danger-color)}.energy-ranking-container{display:flex;flex-direction:column;padding:.5rem 1.5rem 1rem}.ranking-empty{padding:3rem 1rem;text-align:center;color:var(--text-secondary);font-size:.95rem}.ranking-item{padding:1.25rem 0;border-bottom:1px solid var(--border-color);cursor:pointer;transition:all .2s ease}.ranking-item:last-child{border-bottom:none}.ranking-item:hover{background:var(--bg-secondary);margin:0 -1rem;padding-left:1rem;padding-right:1rem;border-radius:var(--border-radius)}.ranking-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.ranking-item-left{display:flex;align-items:flex-start;gap:1rem;flex:1}.ranking-number{font-size:1.1rem;font-weight:700;color:var(--primary-color);min-width:24px;text-align:center}.ranking-item-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.ranking-item-name{font-size:.95rem;font-weight:600;color:var(--text-primary);line-height:1.3}.ranking-item-family{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.ranking-item-right{display:flex;align-items:center;gap:.65rem}.ranking-item-power{font-size:1rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.ranking-chevron{color:var(--text-secondary);flex-shrink:0;opacity:.5;transition:all .2s ease}.ranking-item:hover .ranking-chevron{opacity:1;transform:translate(4px)}.ranking-progress-bar{height:6px;background-color:var(--bg-secondary);border-radius:999px;overflow:hidden;margin-left:36px}.ranking-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-color) 0%,#60a5fa 100%);border-radius:999px;transition:all .3s ease;box-shadow:0 0 8px #3b82f64d}.ranking-item:hover .ranking-progress-fill{background:linear-gradient(90deg,#2563eb 0%,var(--primary-color) 100%);box-shadow:0 0 12px #3b82f680}@media(max-width:768px){.energy-ranking-container{padding:.5rem 1rem 1rem}.ranking-item{padding:1rem 0}.ranking-number{font-size:1rem;min-width:20px}.ranking-item-name,.ranking-item-power{font-size:.9rem}.ranking-progress-bar{margin-left:32px}}.home-page{padding:1.5rem 2rem;background:var(--bg-primary);min-height:100vh}.page-header-home{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;background:var(--bg-white);padding:1.5rem 2rem;border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014}.page-header-content-home{flex:1}.page-title-home{font-size:1.75rem;font-weight:600;margin:0 0 .35rem;color:var(--text-primary)}.page-subtitle-home{font-size:.95rem;color:var(--text-secondary);margin:0}.page-header-badge-home{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#22c55e1f;color:#16a34a;border-radius:999px;font-size:.85rem;font-weight:500}.live-indicator-home{width:8px;height:8px;background:#16a34a;border-radius:50%;animation:pulse-home 2s infinite}@keyframes pulse-home{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.summary-section-home{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-bottom:2rem}.summary-card-wrapper{transition:transform .3s ease,box-shadow .3s ease}.summary-card-wrapper:hover{transform:translateY(-4px)}.summary-card-wrapper:hover .summary-card{box-shadow:0 8px 24px #0000001f}.dashboard-columns{display:flex;gap:1.5rem;align-items:flex-start}.dashboard-column-main{flex:1;display:flex;flex-direction:column;gap:1.5rem;min-width:0}.dashboard-column-side{width:340px;flex-shrink:0;display:flex;flex-direction:column;gap:1.5rem}.dashboard-card-home{background:var(--bg-white);border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;overflow:hidden;transition:box-shadow .2s ease}.dashboard-card-home:hover{box-shadow:0 4px 16px #0000001f}.card-header-home{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.card-header-home h2{font-size:1.1rem;font-weight:600;margin:0;color:var(--text-primary)}.card-badge-home{padding:.35rem .75rem;background:var(--bg-secondary);color:var(--text-secondary);border-radius:999px;font-size:.8rem;font-weight:500}.map-section-home{padding:0}.events-section-home{min-height:400px;display:flex;flex-direction:column}.events-section-home .event-log-widget{flex:1;min-height:0}@media(max-width:1200px){.dashboard-column-side{width:300px}}@media(max-width:1024px){.dashboard-columns{flex-direction:column}.dashboard-column-side{width:100%}}@media(max-width:768px){.home-page{padding:1rem}.page-header-home{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem}.page-title-home{font-size:1.5rem}.summary-section-home{grid-template-columns:1fr;gap:1rem}.dashboard-columns,.dashboard-column-main,.dashboard-column-side{gap:1rem}}.page-header-energy{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;background:var(--bg-white);padding:1.5rem 2rem;border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014}.page-header-content-energy{flex:1}.page-title-energy{font-size:1.75rem;font-weight:600;margin:0 0 .35rem;color:var(--text-primary)}.page-subtitle-energy{font-size:.95rem;color:var(--text-secondary);margin:0}.page-header-icon-energy{width:56px;height:56px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:#fff;box-shadow:0 4px 12px #f59e0b4d}.summary-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-bottom:2rem}.dashboard-card-energy{background:var(--bg-white);border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;overflow:hidden;transition:box-shadow .2s ease;margin-bottom:1.5rem}.dashboard-card-energy:hover{box-shadow:0 4px 16px #0000001f}.energy-card-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.energy-card-header h2{font-size:1.1rem;font-weight:600;margin:0;color:var(--text-primary)}.energy-toolbar{display:flex;gap:.75rem;align-items:center}.energy-toolbar-group{display:inline-flex;gap:0;background:var(--bg-secondary);border-radius:var(--border-radius);padding:.2rem}.energy-toggle-btn{border-radius:6px!important;padding:.5rem 1rem!important;font-size:.85rem!important;line-height:1.4;background-color:transparent!important;color:var(--text-secondary)!important;border:none!important;font-weight:500;transition:all .2s ease}.energy-toggle-btn.active{background-color:var(--bg-white)!important;color:var(--text-primary)!important;box-shadow:0 1px 3px #0000001a}.energy-toggle-btn:hover:not(.active){background-color:#ffffff80!important;color:var(--text-primary)!important}.energy-chart-container{height:300px;padding:1.5rem}.energy-navigation{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color)}.nav-arrow-btn{width:36px;height:36px;background:var(--bg-secondary);border:none;border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;font-size:.9rem}.nav-arrow-btn:hover:not(:disabled){background:var(--primary-color);color:#fff;transform:scale(1.05)}.nav-arrow-btn:disabled{opacity:.3;cursor:not-allowed}.energy-date-label{font-size:.95rem;color:var(--text-primary);font-weight:500;min-width:180px;text-align:center}.ranking-section{margin-bottom:0}.ranking-header{flex-direction:column;align-items:flex-start;gap:.75rem}.ranking-title-group{display:flex;align-items:center;gap:.65rem}.ranking-icon{color:var(--primary-color);font-size:1.15rem}.ranking-date-badge{padding:.35rem .75rem;background:var(--bg-secondary);color:var(--text-secondary);border-radius:999px;font-size:.8rem;font-weight:500}.energy-tooltip{background:#fff;border-radius:var(--border-radius);box-shadow:0 4px 12px #00000026;padding:.75rem 1rem;border:1px solid var(--border-color)}.energy-tooltip-label{color:var(--text-secondary);font-size:.8rem;margin-bottom:.35rem;font-weight:500}.energy-tooltip-value{font-weight:700;color:var(--text-primary);font-size:1rem}.energy-tooltip-value span{font-weight:500;color:var(--text-secondary);margin-left:.35rem;font-size:.85rem}@media(max-width:768px){.page-header-energy{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem}.page-title-energy{font-size:1.5rem}.page-header-icon-energy{width:48px;height:48px;font-size:1.5rem}.summary-section{grid-template-columns:1fr;gap:1rem}.energy-card-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:1rem 1.25rem}.energy-toolbar{width:100%;flex-direction:column;gap:.5rem}.energy-toolbar-group{width:100%}.energy-toggle-btn{flex:1}.energy-chart-container{padding:1rem;height:250px}.energy-navigation{padding:.85rem 1rem}.energy-date-label{font-size:.85rem;min-width:140px}.nav-arrow-btn{width:32px;height:32px;font-size:.85rem}.ranking-header{padding:1rem 1.25rem}.dashboard-columns{flex-direction:column;gap:1rem}.dashboard-column-main{gap:1rem}.dashboard-column-side{width:100%;gap:1rem}}.device-row-widget{background:var(--bg-white);padding:1.5rem;border-radius:var(--border-radius-lg);box-shadow:0 1px 3px var(--shadow-light)}.widget-title{font-size:1.1rem;font-weight:600;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;color:var(--text-primary)}.device-list{list-style:none;padding:0;margin:0;overflow-y:auto;max-height:210px}.device-list::-webkit-scrollbar{width:0;height:0}.device-list{scrollbar-width:none}.device-list{-ms-overflow-style:none}.device-list-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--border-light);font-size:.9rem;color:var(--text-secondary);transition:background-color var(--transition-speed) ease}.device-list-item:last-child{border-bottom:none}.device-list-item:hover{background-color:var(--bg-hover);padding-left:.5rem;padding-right:.5rem;margin-left:-.5rem;margin-right:-.5rem;border-radius:var(--border-radius-sm)}.device-status-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-on .device-status-indicator{background-color:var(--status-online);box-shadow:0 0 4px var(--status-online)}.status-off .device-status-indicator{background-color:var(--status-offline)}.view-all-link{display:block;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light);text-align:right;font-weight:500;font-size:.9rem;color:var(--primary-color);text-decoration:none;transition:color var(--transition-speed) ease}.view-all-link:hover{color:var(--primary-hover);text-decoration:underline}.event-log-widget{background:var(--bg-white);border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;overflow:hidden;height:100%;display:flex;flex-direction:column}.event-log-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.event-log-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.event-count{font-size:.85rem;color:var(--text-secondary);background:var(--bg-secondary);padding:.25rem .75rem;border-radius:999px;font-weight:500}.event-log-list{flex:1;overflow-y:auto;min-height:0}.event-log-loading{padding:2rem;text-align:center;color:var(--text-secondary)}.event-log-empty{padding:3rem 1.5rem;text-align:center;color:var(--text-secondary)}.event-log-empty svg{font-size:2.5rem;margin-bottom:1rem;opacity:.3}.event-log-empty p{margin:0;font-size:.9rem}.event-log-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);transition:background .2s ease}.event-log-item:last-child{border-bottom:none}.event-log-item:hover{background:var(--bg-secondary)}.event-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.event-log-item.device-on .event-icon{background:#22c55e26;color:#16a34a}.event-log-item.device-off .event-icon{background:#9ca3af26;color:#6b7280}.event-log-item.scene .event-icon{background:#8b5cf626;color:#7c3aed}.event-content{flex:1;min-width:0}.event-description{font-size:.9rem;color:var(--text-primary);margin-bottom:.35rem;line-height:1.4}.event-meta{display:flex;align-items:center;gap:.75rem;font-size:.75rem;color:var(--text-secondary)}.event-time{display:flex;align-items:center;gap:.3rem}.event-manual-badge{padding:.15rem .5rem;background:#1677ff1a;color:var(--primary-color);border-radius:4px;font-weight:500}@media(max-width:768px){.event-log-list{max-height:400px}.event-log-item{padding:.85rem 1rem}.event-icon{width:32px;height:32px;font-size:.9rem}}.map-view-container{height:450px;width:100%;border-radius:0 0 var(--border-radius-lg) var(--border-radius-lg);overflow:hidden}.leaflet-map-view{height:100%;width:100%;z-index:1}.custom-camera-marker{background:transparent!important;border:none!important}.marker-container{position:relative;width:36px;height:42px}.marker-pin{width:36px;height:36px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:3px solid white;box-shadow:0 3px 10px #0000004d;display:flex;align-items:center;justify-content:center;position:relative;z-index:2;transition:all .3s ease}.marker-pin:hover{transform:rotate(-45deg) scale(1.15);box-shadow:0 4px 15px #0006}.marker-pin.online{background:linear-gradient(135deg,#4caf50,#45a049)}.marker-pin.offline{background:linear-gradient(135deg,#9e9e9e,#757575)}.marker-initial{transform:rotate(45deg);color:#fff;font-weight:700;font-size:14px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.marker-pulse{position:absolute;top:0;left:0;width:36px;height:36px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);z-index:1}.marker-pulse.active{animation:pulse-animation 2s infinite;background:#4caf5066}@keyframes pulse-animation{0%{transform:rotate(-45deg) scale(1);opacity:1}to{transform:rotate(-45deg) scale(1.5);opacity:0}}.marker-cluster-wrapper{background:transparent!important;border:none!important}.marker-cluster-custom{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,#0d5fd9 100%);border:3px solid white;box-shadow:0 4px 12px #0000004d;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.marker-cluster-custom:hover{transform:scale(1.1);box-shadow:0 6px 16px #0006}.cluster-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;text-align:center}.cluster-count{font-size:16px;font-weight:700;line-height:1}.cluster-online{font-size:9px;font-weight:500;opacity:.9;margin-top:2px}.camera-tooltip{display:flex;flex-direction:column;gap:.25rem;padding:.25rem 0}.camera-tooltip strong{font-size:.9rem;color:var(--text-primary)}.tooltip-status{font-size:.75rem;font-weight:500}.tooltip-status.online{color:#16a34a}.tooltip-status.offline{color:#9ca3af}@media(max-width:768px){.map-view-container{height:300px}}.irrigation-page{padding:1.5rem 2rem;background:var(--bg-primary);min-height:100vh}.page-header-irrigation{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;background:var(--bg-white);padding:1.5rem 2rem;border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;flex-wrap:wrap;gap:1.5rem}.page-header-content-irrigation{flex:1}.page-title-irrigation{font-size:1.75rem;font-weight:600;margin:0 0 .35rem;color:var(--text-primary)}.page-subtitle-irrigation{font-size:.95rem;color:var(--text-secondary);margin:0}.irrigation-stats-group{display:flex;gap:1rem}.irrigation-stat-badge{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.1rem;border-radius:999px;font-size:.85rem;font-weight:500}.irrigation-stat-badge svg{font-size:.6rem}.irrigation-stat-badge.active{background:#22c55e1f;color:#16a34a}.irrigation-stat-badge.active svg{color:#16a34a;animation:pulse 2s infinite}.irrigation-stat-badge.inactive{background:#9ca3af1f;color:#6b7280}.irrigation-stat-badge.inactive svg{color:#9ca3af}.irrigation-device-card{background:var(--bg-white);border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;padding:1.25rem 1.5rem;margin-bottom:2rem;transition:box-shadow .2s ease}.irrigation-device-card:hover{box-shadow:0 4px 16px #0000001f}.irrigation-device-header{display:flex;align-items:center;gap:1rem}.irrigation-device-icon{width:56px;height:56px;border-radius:14px;background:#1677ff1a;color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.irrigation-device-info{flex:1}.irrigation-device-info h3{margin:0 0 .25rem;font-size:1.15rem;font-weight:600;color:var(--text-primary)}.irrigation-device-location{font-size:.85rem;color:var(--text-secondary)}.irrigation-device-status{display:flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:999px;font-size:.85rem;font-weight:500}.irrigation-device-status svg{font-size:.6rem}.irrigation-device-status.online{background:#22c55e1f;color:#16a34a}.irrigation-device-status.online svg{animation:pulse 2s infinite}.irrigation-device-status.offline{background:#ef44441f;color:#dc2626}.irrigation-tabs-container{display:flex;gap:.75rem;margin-bottom:1.5rem;background:var(--bg-white);padding:.5rem;border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014}.irrigation-view-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.5rem;border:none;background:transparent;color:var(--text-secondary);font-size:.95rem;font-weight:600;border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;position:relative}.irrigation-view-tab:hover{background:var(--bg-secondary);color:var(--text-primary)}.irrigation-view-tab.active{background:var(--primary-color);color:#fff;box-shadow:0 2px 8px #1677ff4d}.irrigation-view-tab svg{font-size:1.1rem}.irrigation-empty-state{background:var(--bg-white);border-radius:var(--border-radius-lg);padding:4rem 2rem;text-align:center;box-shadow:0 2px 8px #00000014}.irrigation-empty-state h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.irrigation-empty-state p{margin:0;font-size:.95rem;color:var(--text-secondary)}.irrigation-zones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}.irrigation-zone-card{background:var(--bg-white);border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;padding:1.25rem;display:flex;flex-direction:column;justify-content:space-between;gap:.85rem;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;min-height:160px}.irrigation-zone-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--border-color);transition:background .2s ease}.irrigation-zone-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.irrigation-zone-card:hover:before{background:var(--primary-color)}.irrigation-zone-top{display:flex;justify-content:space-between;align-items:center}.irrigation-zone-icon-pill{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--text-secondary);font-size:1.25rem;transition:all .3s ease}.irrigation-zone-icon-pill.running{background:#1677ff1f;color:var(--primary-color);box-shadow:0 0 0 1px #1677ff59}.irrigation-zone-icon-pill.idle{background:var(--bg-secondary);color:var(--text-secondary)}.irrigation-zone-status-dot{display:flex;align-items:center;justify-content:center}.irrigation-zone-status-dot svg{font-size:.7rem}.irrigation-zone-status-dot.running svg{color:#22c55e;animation:pulse 2s infinite}.irrigation-zone-status-dot.idle svg{color:#9ca3af}.irrigation-zone-name{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:.25rem 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.irrigation-zone-footer{display:flex;align-items:center;justify-content:space-between;padding-top:1rem;margin-top:auto;border-top:1px solid var(--border-color);gap:.5rem}.irrigation-zone-footer-left{display:flex;flex-direction:column;gap:.25rem}.irrigation-zone-status-text{font-size:.85rem;font-weight:600}.irrigation-zone-status-text.running{color:#16a34a}.irrigation-zone-status-text.idle{color:#9ca3af}.irrigation-zone-hint{color:var(--text-secondary);font-size:.75rem}.irrigation-zone-quick-actions{position:static;display:flex;align-items:center}.irrigation-quick-btn{width:36px;height:36px;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;transition:all .2s ease;box-shadow:0 2px 8px #00000026}.irrigation-quick-btn:disabled{opacity:.5;cursor:not-allowed}.irrigation-quick-btn.run{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.irrigation-quick-btn.run:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:scale(1.1);box-shadow:0 4px 12px #10b98166}.irrigation-quick-btn.stop{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.irrigation-quick-btn.stop:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);transform:scale(1.1);box-shadow:0 4px 12px #ef444466}@media(max-width:900px){.page-header-irrigation{flex-direction:column;align-items:flex-start}.irrigation-stats-group{width:100%;justify-content:flex-start}}@media(max-width:768px){.irrigation-page{padding:1rem}.page-header-irrigation{gap:1rem;padding:1.25rem 1.5rem}.page-title-irrigation{font-size:1.5rem}.irrigation-zones-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.irrigation-zone-card{padding:1rem}.irrigation-tabs-container{gap:.5rem;padding:.4rem}.irrigation-view-tab{padding:.7rem 1rem;font-size:.85rem}.irrigation-view-tab svg{font-size:1.2rem}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:102;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg-white);padding:2rem;border-radius:var(--border-radius-lg);box-shadow:0 8px 32px #0003;width:460px;max-width:95vw;animation:slideUp .3s ease;position:relative}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close-btn{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border:none;background:#00000080;color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease}.modal-close-btn:hover:not(:disabled){background:#000000b3;transform:scale(1.1)}.modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.modal-card h3{margin:0 0 1.5rem;padding:0 2rem 1rem 0;font-size:1.25rem;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.modal-error{background:#ef44441a;color:#dc2626;padding:.85rem 1rem;border-radius:var(--border-radius);margin-bottom:1.25rem;font-size:.9rem;border-left:3px solid #dc2626;display:flex;align-items:center;gap:.5rem}.user-form{display:flex;flex-direction:column;gap:1rem}.modal-actions{display:flex;gap:.75rem;margin-top:1.75rem;justify-content:flex-end;padding-top:1.25rem;border-top:1px solid var(--border-color)}.modal-actions button{min-width:120px;width:auto!important}.save-btn{background:linear-gradient(135deg,var(--primary-color) 0%,#0d5fd9 100%)!important;color:#fff!important;border:none!important;box-shadow:0 2px 8px #1677ff4d;transition:all .2s ease}.save-btn:hover:not(:disabled){background:linear-gradient(135deg,#0d5fd9,#0847b3)!important;box-shadow:0 4px 12px #1677ff66;transform:translateY(-2px)}.cancel-btn{background-color:var(--bg-secondary)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)!important;transition:all .2s ease}.cancel-btn:hover:not(:disabled){background-color:var(--bg-primary)!important;border-color:var(--text-secondary)!important;transform:scale(1.02)}@media(max-width:500px){.modal-card{padding:1.5rem;width:95vw}.modal-close-btn{top:1rem;right:1rem;width:28px;height:28px;font-size:.85rem}.modal-card h3{font-size:1.1rem;padding-right:1.5rem}.modal-actions{flex-direction:column-reverse;gap:.65rem}.modal-actions button{width:100%!important}}.irrigation-zone-modal{width:480px;max-width:95vw;position:relative}.irrigation-close-btn{position:absolute;top:1.25rem;right:1.25rem;width:32px;height:32px;border:none;background:var(--bg-secondary);color:var(--text-secondary);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease;font-size:.9rem}.irrigation-close-btn:hover{background:var(--text-primary);color:#fff;transform:scale(1.1)}.irrigation-modal-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.25rem;padding-right:2rem;border-bottom:1px solid var(--border-color)}.irrigation-modal-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;transition:all .3s ease}.irrigation-modal-icon.running{background:#06b6d426;color:#0891b2;box-shadow:0 0 0 1px #06b6d466}.irrigation-modal-icon.idle{background:var(--bg-secondary);color:var(--text-secondary)}.irrigation-modal-title{flex:1;min-width:0}.irrigation-modal-title h3{margin:0 0 .35rem;font-size:1.25rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.irrigation-modal-status{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;border-radius:999px;font-size:.8rem;font-weight:500}.irrigation-modal-status.running{background:#06b6d426;color:#0891b2}.irrigation-modal-status.idle{background:#9ca3af26;color:#6b7280}.irrigation-zone-details{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:1rem;margin-bottom:1.5rem}.irrigation-detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0}.irrigation-detail-row:not(:last-child){border-bottom:1px solid var(--border-color)}.detail-label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.detail-value{font-size:.9rem;font-weight:600;color:var(--text-primary)}.irrigation-controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.irrigation-control-group{display:flex;flex-direction:column;gap:.65rem}.control-label{font-size:.9rem;font-weight:600;color:var(--text-primary)}.duration-selector{display:flex;align-items:center;gap:1rem;justify-content:center;padding:1rem;background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius-lg)}.duration-btn{width:40px;height:40px;border:none;border-radius:10px;background:linear-gradient(135deg,#0891b2,#0e7490);color:#fff;font-size:1.25rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0891b24d}.duration-btn:hover:not(:disabled){background:linear-gradient(135deg,#0e7490,#155e75);transform:scale(1.05);box-shadow:0 4px 12px #0891b266}.duration-btn:disabled{opacity:.5;cursor:not-allowed;transform:scale(1)}.duration-display{font-size:1.25rem;font-weight:700;color:var(--text-primary);min-width:100px;text-align:center}.suspend-input{padding:.75rem;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:.9rem;color:var(--text-primary);background:var(--bg-white);transition:all .2s ease}.suspend-input:focus{outline:none;border-color:#0891b2;box-shadow:0 0 0 3px #06b6d41a}.irrigation-action-buttons{display:flex;gap:.75rem}.run-zone-btn{background:linear-gradient(135deg,#10b981,#059669)!important;color:#fff!important;border:none!important;display:flex;align-items:center;gap:.65rem;justify-content:center;width:100%;font-weight:600;box-shadow:0 4px 14px #10b98166;transition:all .3s ease}.run-zone-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857)!important;box-shadow:0 6px 20px #10b98180;transform:translateY(-2px)}.stop-zone-btn{background:linear-gradient(135deg,#ef4444,#dc2626)!important;color:#fff!important;border:none!important;display:flex;align-items:center;gap:.65rem;justify-content:center;width:100%;font-weight:600;box-shadow:0 4px 14px #ef444466;transition:all .3s ease}.stop-zone-btn:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c)!important;box-shadow:0 6px 20px #ef444480;transform:translateY(-2px)}.suspend-zone-btn{background:linear-gradient(135deg,#f59e0b,#d97706)!important;color:#fff!important;border:none!important;display:flex;align-items:center;gap:.65rem;justify-content:center;width:100%;font-weight:600;box-shadow:0 4px 14px #f59e0b66;transition:all .3s ease}.suspend-zone-btn:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309)!important;box-shadow:0 6px 20px #f59e0b80;transform:translateY(-2px)}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color)}.cancel-btn{background-color:var(--bg-secondary)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)!important;min-width:120px}.cancel-btn:hover:not(:disabled){background-color:var(--bg-primary)!important;border-color:var(--text-secondary)!important}@media(max-width:768px){.irrigation-zone-modal{width:95vw}.irrigation-close-btn{top:1rem;right:1rem;width:28px;height:28px;font-size:.85rem}.irrigation-modal-header{padding-bottom:1rem;padding-right:1.5rem}.irrigation-modal-icon{width:48px;height:48px;font-size:1.25rem}.irrigation-modal-title h3{font-size:1.1rem}.duration-selector{padding:.85rem}.duration-btn{width:36px;height:36px;font-size:1.1rem}.duration-display{font-size:1.1rem;min-width:80px}.modal-actions{flex-direction:column-reverse}.cancel-btn{width:100%}.irrigation-action-buttons{flex-direction:column}}.predictive-watering-container{background:var(--bg-white);padding:1.5rem;border-radius:16px;margin-top:2rem;box-shadow:0 2px 8px #0000000d}.section-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.section-subtitle{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem}.rules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.rule-card{border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;background:#fff;transition:transform .2s}.rule-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.rule-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.rule-icon{font-size:1.25rem}.rule-icon.temp{color:#f59e0b}.rule-icon.rain{color:#3b82f6}.rule-icon.wind{color:#6b7280}.rule-icon.smart{color:#10b981}.rule-title{font-weight:600;color:var(--text-primary)}.rule-desc{font-size:.85rem;color:var(--text-secondary);min-height:2.5em;margin-bottom:1rem}.rule-control{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.rule-value{font-weight:700;font-size:1.1rem;color:var(--primary-color)}.rule-slider{width:100%;accent-color:var(--primary-color)}.toggle-switch{width:44px;height:24px;background:#e5e7eb;border-radius:999px;position:relative;cursor:pointer;transition:background .3s}.toggle-switch.active{background:#10b981}.toggle-knob{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .3s;box-shadow:0 1px 3px #0003}.toggle-switch.active .toggle-knob{transform:translate(20px)}.football-field-container{width:100%;max-width:900px;margin:0 auto 2rem;padding:1rem;background:#1f2937;border-radius:16px;box-shadow:0 4px 20px #0003;overflow:hidden}.football-field{width:100%;aspect-ratio:16/9;background:linear-gradient(to right,#4ade80,#22c55e,#4ade80);position:relative;border:4px solid white;border-radius:4px;display:grid;grid-template-rows:repeat(6,1fr);grid-template-columns:1fr;gap:4px;padding:10px}.field-line.half-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:#fff9;transform:translate(-50%)}.field-circle.center-circle{position:absolute;top:50%;left:50%;width:15%;padding-top:15%;height:0;border:2px solid rgba(255,255,255,.6);border-radius:50%;transform:translate(-50%,-50%)}.field-box{position:absolute;top:50%;transform:translateY(-50%);width:12%;height:40%;border:2px solid rgba(255,255,255,.6)}.penalty-box-left{left:0;border-left:none}.penalty-box-right{right:0;border-right:none}.zone-side-left{grid-column:1 / span 6;grid-row:1}.zone-side-right{grid-column:1 / span 6;grid-row:3}.zone-row-1{grid-column:1;grid-row:1}.zone-row-2{grid-column:1;grid-row:2}.zone-rpw-3{grid-column:1;grid-row:3}.zone-row-4{grid-column:1;grid-row:4}.zone-row-5{grid-column:1;grid-row:5}.zone-row-6{grid-column:1;grid-row:6}@media(max-width:768px){.football-field{aspect-ratio:9/16;background:linear-gradient(to bottom,#4ade80,#22c55e,#4ade80);grid-template-columns:1fr;grid-template-rows:repeat(6,1fr);gap:6px}.zone-row-1{grid-column:1;grid-row:1}.zone-row-2{grid-column:1;grid-row:2}.zone-row-3{grid-column:1;grid-row:3}.zone-row-4{grid-column:1;grid-row:4}.zone-row-5{grid-column:1;grid-row:5}.zone-row-6{grid-column:1;grid-row:6}.field-line.half-line{inset:50% 0 auto;width:100%;height:2px;transform:translateY(-50%)}.field-box{left:50%;top:auto;transform:translate(-50%);width:40%;height:10%}.penalty-box-left{top:0;border-left:2px solid rgba(255,255,255,.6);border-bottom:2px solid rgba(255,255,255,.6);border-top:none}.penalty-box-right{bottom:0;border-left:2px solid rgba(255,255,255,.6);border-top:2px solid rgba(255,255,255,.6);border-bottom:none}}.field-zone{z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff26;border:1px dashed rgba(255,255,255,.4);border-radius:6px;cursor:pointer;color:#fff;font-size:.8rem;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.8);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.field-zone.running{background:#06b6d4d9;border:2px solid white;box-shadow:0 0 15px #06b6d499}.field-zone:hover{background:#ffffff59;transform:scale(1.05);border-color:#ffffffe6;box-shadow:0 8px 16px #0003;z-index:10}.field-zone:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(to right,#fff0,#ffffff4d,#fff0);transform:skew(-25deg);transition:none}.field-zone:hover:after{left:200%;transition:left .6s ease-in-out}.field-zone.running:hover{background:#06b6d4f2;box-shadow:0 0 20px #06b6d4cc;transform:scale(1.05)}.field-zone:active{transform:scale(.95);background:#ffffff80}.lighting-page{padding:1.5rem 2rem;background:var(--bg-primary);min-height:100vh}.page-header-lighting{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;background:var(--bg-white);padding:1.5rem 2rem;border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;flex-wrap:wrap;gap:1.5rem}.page-header-content-lighting{flex:1}.page-title-lighting{font-size:1.75rem;font-weight:600;margin:0 0 .35rem;color:var(--text-primary)}.page-subtitle-lighting{font-size:.95rem;color:var(--text-secondary);margin:0}.lighting-stats-group{display:flex;gap:1rem}.lighting-stat-badge{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.1rem;border-radius:999px;font-size:.85rem;font-weight:500}.lighting-stat-badge svg{font-size:.6rem}.lighting-stat-badge.active{background:#22c55e1f;color:#16a34a}.lighting-stat-badge.active svg{color:#16a34a;animation:pulse 2s infinite}.lighting-stat-badge.inactive{background:#9ca3af1f;color:#6b7280}.lighting-stat-badge.inactive svg{color:#9ca3af}.stat-count{font-weight:700;font-size:1rem}.stat-label{font-weight:500}.lighting-empty-state{background:var(--bg-white);border-radius:var(--border-radius-lg);padding:4rem 2rem;text-align:center;box-shadow:0 2px 8px #00000014}.empty-icon{width:80px;height:80px;margin:0 auto 1.5rem;border-radius:50%;background:#1677ff1f;color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:2rem}.lighting-empty-state h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.lighting-empty-state p{margin:0;font-size:.95rem;color:var(--text-secondary)}.lighting-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}.lighting-card{background:var(--bg-white);border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;padding:1.25rem;display:flex;flex-direction:column;gap:.85rem;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.lighting-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--border-color);transition:background .2s ease}.lighting-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.lighting-card:hover:before{background:var(--primary-color)}.lighting-card-top{display:flex;justify-content:space-between;align-items:center}.lighting-icon-pill{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--text-secondary);font-size:1.25rem;transition:all .3s ease}.lighting-icon-pill.on{background:#1677ff1f;color:var(--primary-color);box-shadow:0 0 0 1px #1677ff59}.lighting-icon-pill.off{background:var(--bg-secondary);color:var(--text-secondary)}.lighting-status-dot{display:flex;align-items:center;justify-content:center}.lighting-status-dot svg{font-size:.7rem}.lighting-status-dot.on svg{color:#22c55e;animation:pulse 2s infinite}.lighting-status-dot.off svg{color:#9ca3af}.lighting-card-name{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:.25rem 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lighting-card-power{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.power-value{font-size:1.1rem;font-weight:700;color:var(--primary-color)}.power-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.lighting-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.5rem;border-top:1px solid var(--border-color)}.lighting-card-status-text{font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.35rem}.lighting-card-status-text.on{color:#16a34a}.lighting-card-status-text.off{color:#9ca3af}.lighting-card-hint{color:var(--text-secondary);font-size:.75rem}@media(max-width:768px){.lighting-page{padding:1rem}.page-header-lighting{flex-direction:column;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem}.page-title-lighting{font-size:1.5rem}.lighting-stats-group{width:100%;justify-content:space-between}.lighting-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.lighting-card{padding:1rem}}.lighting-tabs{display:flex;gap:.75rem;margin-bottom:1.5rem;background:var(--bg-white);padding:.5rem;border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014}.lighting-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.5rem;border:none;background:transparent;color:var(--text-secondary);font-size:.95rem;font-weight:600;border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;position:relative}.lighting-tab:hover{background:var(--bg-secondary);color:var(--text-primary)}.lighting-tab.active{background:var(--primary-color);color:#fff;box-shadow:0 2px 8px #1677ff4d}.lighting-tab svg{font-size:1.1rem}.tab-count{background:#fff3;padding:.2rem .6rem;border-radius:999px;font-size:.8rem;font-weight:700;min-width:24px;text-align:center}.lighting-tab:not(.active) .tab-count{background:var(--bg-secondary);color:var(--text-secondary)}@media(max-width:768px){.lighting-tabs{gap:.5rem;padding:.4rem}.lighting-tab{padding:.7rem 1rem;font-size:.85rem}.lighting-tab span:not(.tab-count){display:none}.lighting-tab svg{font-size:1.2rem}}.lighting-controls-group{display:flex;gap:1rem;align-items:center}.global-control-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;border:none;border-radius:999px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.global-control-btn:disabled{opacity:.6;cursor:not-allowed}.global-control-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.global-control-btn.on{background:#e0f2fe;color:#0284c7}.global-control-btn.on:hover:not(:disabled){background:#bae6fd}.global-control-btn.off{background:#fef2f2;color:#dc2626}.global-control-btn.off:hover:not(:disabled){background:#fee2e2}@media(max-width:900px){.page-header-lighting{flex-direction:column;align-items:flex-start}.lighting-controls-group,.lighting-stats-group{width:100%;justify-content:flex-start}}.lighting-modal{width:480px;max-width:95vw;position:relative}.lighting-close-btn{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border:none;background:#00000080;color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease}.lighting-close-btn:hover{background:#000000b3;transform:scale(1.1)}.lighting-modal-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.25rem;padding-right:2rem;border-bottom:1px solid var(--border-color)}.lighting-modal-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;transition:all .3s ease}.lighting-modal-icon.on{background:#1677ff26;color:var(--primary-color);box-shadow:0 0 0 1px #1677ff66}.lighting-modal-icon.off{background:var(--bg-secondary);color:var(--text-secondary)}.lighting-modal-title{flex:1;min-width:0}.lighting-modal-title h3{margin:0 0 .35rem;font-size:1.25rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lighting-modal-status{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;border-radius:999px;font-size:.8rem;font-weight:500}.lighting-modal-status svg{font-size:.6rem}.lighting-modal-status.on{background:#22c55e26;color:#16a34a}.lighting-modal-status.on svg{animation:pulse 2s infinite}.lighting-modal-status.off{background:#9ca3af26;color:#6b7280}.lighting-main-value{text-align:center;margin-bottom:1.5rem;padding:1.5rem;background:linear-gradient(135deg,rgba(22,119,255,.05) 0%,var(--bg-white) 100%);border-radius:var(--border-radius-lg);border:1px solid rgba(22,119,255,.1)}.lighting-kwh{display:block;font-size:2.5rem;font-weight:700;color:var(--primary-color);margin-bottom:.35rem}.lighting-subtitle{display:block;font-size:.85rem;color:var(--text-secondary);font-weight:500}.lighting-metrics{display:flex;flex-direction:column;gap:.85rem;margin-bottom:1.75rem}.lighting-metric{display:flex;align-items:center;gap:1rem;background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;transition:all .2s ease}.lighting-metric:hover{border-color:var(--primary-color);transform:translate(4px);box-shadow:0 2px 8px #00000014}.lighting-metric-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.lighting-metric-icon.power{background:#f59e0b33;color:#ea580c}.lighting-metric-icon.voltage{background:#3b82f633;color:#2563eb}.lighting-metric-icon.current{background:#8b5cf633;color:#7c3aed}.lighting-metric-content{flex:1}.lighting-metric-value{font-weight:700;font-size:1.3rem;color:var(--text-primary);margin-bottom:.2rem}.lighting-metric-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.lighting-toggle-btn:disabled{opacity:.6;cursor:not-allowed}.lighting-toggle-icon{font-size:1.3rem;display:flex;align-items:center}.lighting-toggle-btn.on{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 14px #ef444480}.lighting-toggle-btn.on:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 6px 20px #ef444499;transform:translateY(-2px)}.lighting-toggle-btn.off{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 14px #3b82f680}.lighting-toggle-btn.off:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 20px #3b82f699;transform:translateY(-2px)}@media(max-width:768px){.lighting-modal{width:95vw}.lighting-close-btn{top:1rem;right:1rem;width:28px;height:28px;font-size:.85rem}.lighting-modal-header{padding-bottom:1rem;padding-right:1.5rem}.lighting-modal-icon{width:48px;height:48px;font-size:1.25rem}.lighting-modal-title h3{font-size:1.1rem}.lighting-main-value{padding:1.25rem}.lighting-kwh{font-size:2rem}.lighting-metrics{gap:.75rem}.lighting-metric{padding:.85rem}.lighting-metric-icon{width:44px;height:44px;font-size:1.1rem}.lighting-metric-value{font-size:1.15rem}.lighting-toggle-btn{padding:.8rem 1.5rem;font-size:1rem}}.lighting-actions-wrapper{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.lighting-toggle-wrapper{display:flex;justify-content:center;margin-top:.5rem}.lighting-toggle-btn{display:inline-flex;align-items:center;gap:.65rem;border-radius:999px;border:none;padding:.9rem 2.5rem;cursor:pointer;font-size:1.05rem;font-weight:600;transition:all .3s ease;width:100%;justify-content:center}.lighting-logs-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:999px;border:2px solid var(--border-color);background:var(--bg-white);color:var(--text-primary);padding:.75rem 1.5rem;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease;width:100%}.lighting-logs-btn:hover:not(:disabled){border-color:var(--primary-color);color:var(--primary-color);background:#1677ff0d;transform:translateY(-1px)}.lighting-logs-btn:disabled{opacity:.6;cursor:not-allowed}.lighting-logs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.lighting-logs-header h4{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.lighting-back-btn{background:transparent;border:none;color:var(--primary-color);font-size:.9rem;font-weight:600;cursor:pointer;padding:.5rem .75rem;border-radius:var(--border-radius);transition:all .2s ease}.lighting-back-btn:hover{background:#1677ff1a}.lighting-logs-container{max-height:400px;overflow-y:auto}.lighting-logs-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.lighting-logs-empty svg{font-size:3rem;margin-bottom:1rem;opacity:.3}.lighting-logs-empty p{margin:0;font-size:.95rem}.lighting-logs-list{display:flex;flex-direction:column;gap:.75rem}.lighting-log-item{display:flex;align-items:flex-start;gap:1rem;background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;transition:all .2s ease}.lighting-log-item:hover{border-color:var(--primary-color);transform:translate(4px);box-shadow:0 2px 8px #00000014}.lighting-log-status-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.lighting-log-status-icon.on{background:#22c55e26;color:#16a34a}.lighting-log-status-icon.off{background:#9ca3af26;color:#6b7280}.lighting-log-content{flex:1;min-width:0}.lighting-log-action{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.lighting-log-state{font-weight:600;font-size:.95rem}.lighting-log-state.on{color:#16a34a}.lighting-log-state.off{color:#6b7280}.lighting-log-source{font-size:.8rem;color:var(--text-secondary);padding:.2rem .5rem;background:var(--bg-secondary);border-radius:4px}.lighting-log-time{font-size:.8rem;color:var(--text-secondary)}@media(max-width:768px){.lighting-logs-container{max-height:300px}.lighting-log-item{padding:.85rem}.lighting-log-status-icon{width:36px;height:36px;font-size:1rem}.lighting-actions-wrapper{gap:.6rem}.lighting-logs-btn{padding:.65rem 1.25rem;font-size:.9rem}}.scene-card{background:var(--bg-white);border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;padding:1.25rem;display:flex;flex-direction:column;gap:.85rem;transition:all .2s ease;position:relative;overflow:hidden;cursor:pointer;border:1px solid transparent}.scene-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--primary-color);transition:background .2s ease}.scene-card.inactive:before{background:var(--border-color)}.scene-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.scene-card-header{display:flex;justify-content:space-between;align-items:center;min-height:48px}.scene-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all .3s ease}.scene-icon.on{background:#22c55e26;color:#16a34a;box-shadow:0 0 0 1px #22c55e4d}.scene-icon.off{background:#ef444426;color:#dc2626;box-shadow:0 0 0 1px #ef44444d}.scene-icon.mixed{background:#f59e0b26;color:#f59e0b;box-shadow:0 0 0 1px #f59e0b4d}.scene-card-toggle{background:transparent;border:none;cursor:pointer;padding:0;display:flex;align-items:center;position:relative;width:44px;height:24px;border-radius:999px;transition:background-color .2s ease;background-color:#374151;z-index:2}.scene-card-toggle.active{background-color:var(--primary-color)}.scene-card-toggle:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background-color:#fff;border-radius:50%;transition:transform .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0000004d}.scene-card-toggle.active:after{transform:translate(20px)}.scene-card-toggle.loading{opacity:.6;cursor:wait}.scene-card-toggle:hover{filter:brightness(1.1)}.scene-card-body{flex:1;display:flex;flex-direction:column;gap:.75rem}.scene-card-name{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scene-card-schedule{display:flex;flex-direction:column;gap:.4rem;padding:.75rem;background:#1677ff14;border-radius:var(--border-radius);border:1px solid rgba(22,119,255,.2)}.scene-time{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;color:var(--primary-color)}.scene-time svg{font-size:1rem}.scene-days{font-size:.8rem;color:var(--text-secondary);font-weight:500}.scene-card-info{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.scene-info-item{display:flex;flex-direction:column;gap:.25rem;padding:.6rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.scene-info-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.scene-info-value{font-size:.95rem;font-weight:700;color:var(--text-primary)}.scene-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.5rem;border-top:1px solid var(--border-color)}.scene-status-text{font-size:.85rem;font-weight:600}.scene-status-text.active{color:#16a34a}.scene-status-text.inactive{color:#9ca3af}.scene-card-hint{color:var(--text-secondary);font-size:.75rem}@media(max-width:768px){.scene-card{padding:1rem}.scene-icon{width:44px;height:44px;font-size:1.1rem}.scene-card-name{font-size:.95rem}}.scene-detail-modal{width:700px;max-width:95vw;max-height:85vh;position:relative;display:flex;flex-direction:column}.scene-close-btn{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border:none;background:#00000080;color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease}.scene-close-btn:hover{background:#000000b3;transform:scale(1.1)}.scene-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.25rem;padding-right:2rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.scene-detail-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;background:#1677ff26;color:var(--primary-color);box-shadow:0 0 0 1px #1677ff66}.scene-detail-title{flex:1;min-width:0}.scene-detail-title h3{margin:0 0 .35rem;font-size:1.25rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scene-detail-status{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .75rem;border-radius:999px;font-size:.8rem;font-weight:500}.scene-detail-status svg{font-size:.6rem}.scene-detail-status.active{background:#22c55e26;color:#16a34a}.scene-detail-status.active svg{animation:pulse 2s infinite}.scene-detail-status.inactive{background:#9ca3af26;color:#6b7280}.scene-detail-body{display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto;overflow-x:hidden;flex:1;padding-right:.5rem;margin-right:-.5rem}.scene-detail-body::-webkit-scrollbar{width:6px}.scene-detail-body::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}.scene-detail-body::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:3px}.scene-detail-body::-webkit-scrollbar-thumb:hover{background:#1d4ed8}.section-title{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem}.section-title svg{color:var(--primary-color)}.scene-schedule-section{background:linear-gradient(135deg,rgba(22,119,255,.05) 0%,var(--bg-white) 100%);border:1px solid rgba(22,119,255,.15);border-radius:var(--border-radius-lg);padding:1.25rem}.scene-schedule-card{display:flex;flex-direction:column;gap:.75rem}.schedule-time-display{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-white);border-radius:var(--border-radius);box-shadow:0 2px 4px #0000000d}.schedule-time-display svg{font-size:1.5rem;color:var(--primary-color)}.schedule-time{font-size:1.75rem;font-weight:700;color:var(--primary-color)}.schedule-days-display{padding:.75rem 1rem;background:var(--bg-white);border-radius:var(--border-radius);font-size:.9rem;font-weight:500;color:var(--text-secondary);text-align:center}.schedule-timezone{font-size:.75rem;color:var(--text-secondary);text-align:center}.scene-devices-section{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:1.25rem}.scene-devices-list{display:flex;flex-direction:column;gap:.75rem;max-height:none}.scene-device-item{display:flex;align-items:center;gap:1rem;padding:.85rem;background:var(--bg-secondary);border-radius:var(--border-radius);transition:all .2s ease}.scene-device-item:hover{background:#1677ff0d;transform:translate(4px)}.scene-device-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.scene-device-icon.on{background:#22c55e26;color:#16a34a}.scene-device-icon.off{background:#ef444426;color:#dc2626}.scene-device-info{flex:1;min-width:0}.scene-device-id{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.2rem}.scene-device-action{font-size:.8rem;font-weight:500}.scene-device-action.on{color:#16a34a}.scene-device-action.off{color:#dc2626}.scene-labels-section{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:1.25rem}.scene-labels{display:flex;flex-wrap:wrap;gap:.5rem}.scene-label{padding:.4rem .85rem;background:#1677ff1a;color:var(--primary-color);border-radius:999px;font-size:.8rem;font-weight:500}.scene-detail-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);flex-shrink:0}.scene-device-name{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.2rem}.scene-edit-external-btn{display:flex;align-items:center;justify-content:center;gap:.65rem;width:100%;padding:.9rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:999px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 14px #3b82f680}.scene-edit-external-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 20px #3b82f699;transform:translateY(-2px)}@media(max-width:1024px){.scene-detail-modal{width:90vw}}@media(max-width:768px){.scene-detail-modal{width:95vw;max-height:90vh}.scene-detail-icon{width:48px;height:48px;font-size:1.25rem}.scene-detail-title h3{font-size:1.1rem}.schedule-time{font-size:1.5rem}.scene-device-icon{width:36px;height:36px;font-size:1rem}.scene-detail-body{padding-right:.25rem;margin-right:-.25rem}}.scene-name-input{font-size:1.25rem;font-weight:600;padding:.25rem .5rem;border:1px solid var(--border-color);border-radius:6px;width:100%;color:var(--text-primary)}.scene-time-input{font-size:1.75rem;font-weight:700;color:var(--primary-color);border:1px solid var(--border-color);border-radius:6px;padding:0 .5rem;font-family:inherit}.scene-device-select{padding:.25rem .5rem;border-radius:4px;border:1px solid var(--border-color);background:#fff;font-size:.9rem;cursor:pointer}.scene-edit-icon-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.scene-edit-icon-btn:hover{background:#0000000d;color:var(--primary-color)}.scene-edit-actions{display:flex;gap:1rem;width:100%}.scene-cancel-btn{flex:1;padding:.9rem;border:1px solid var(--border-color);background:#fff;color:var(--text-secondary);border-radius:999px;font-weight:600;cursor:pointer;transition:all .2s}.scene-cancel-btn:hover{background:var(--bg-secondary)}.scene-save-btn{flex:1;padding:.9rem;background:var(--primary-color);color:#fff;border:none;border-radius:999px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.scene-save-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.scene-save-btn:disabled{opacity:.7;cursor:not-allowed}.scene-delete-btn{padding:.9rem;background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.2);border-radius:999px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;width:50px;flex-shrink:0}.scene-delete-btn:hover{background:#ef444433;transform:scale(1.05)}.scene-delete-btn:disabled{opacity:.5;cursor:not-allowed}.scene-status-row{display:flex;align-items:center;gap:1rem}.scene-modal-toggle{background:transparent;border:none;cursor:pointer;padding:0;display:flex;align-items:center;position:relative;width:48px;height:26px;border-radius:999px;transition:background-color .2s ease;background-color:#374151}.scene-modal-toggle.active{background-color:var(--primary-color)}.scene-modal-toggle:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background-color:#fff;border-radius:50%;transition:transform .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000004d}.scene-modal-toggle.active:after{transform:translate(22px)}.scene-modal-toggle.loading{opacity:.6;cursor:wait}.scene-modal-toggle:hover{filter:brightness(1.1)}.scene-modal-toggle svg{display:none}._selectWrapper_1gwgc_1{display:flex;flex-direction:column;gap:.25rem}._selectWrapper_1gwgc_1 label,._label_1gwgc_8{font-size:.9375rem;color:var(--text-primary);margin-bottom:.1rem;font-weight:400;transition:color var(--transition-speed) ease}._required_1gwgc_16{color:var(--danger-color)}._select_1gwgc_1{border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-white);color:var(--text-primary);outline:none;width:100%;box-sizing:border-box;display:inline-flex;position:relative;min-width:0;padding:4px 11px;font-size:14px;line-height:1.5714285714285714;transition:all var(--transition-speed);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg fill='none' stroke='%23666' stroke-width='2' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;padding-right:2.5rem}._select_1gwgc_1:focus{border-color:#4096ff;box-shadow:0 0 0 2px #0591ff1a;outline:0}._select_1gwgc_1:hover:not(:disabled){border-color:#4096ff}._select_1gwgc_1:disabled{background-color:var(--bg-disabled);color:var(--text-disabled);cursor:not-allowed;opacity:.6}._select_1gwgc_1 option{padding:8px 12px;background-color:var(--bg-white);color:var(--text-primary);font-size:14px}._select_1gwgc_1 option:hover{background-color:var(--bg-hover)}._select_1gwgc_1 option:checked,._select_1gwgc_1 option:focus{background-color:var(--primary-color);color:var(--text-inverse)}@-moz-document url-prefix(){._select_1gwgc_1 option:checked{background:var(--primary-color) linear-gradient(0deg,var(--primary-color) 0%,var(--primary-color) 100%);color:var(--text-inverse)}}._select_1gwgc_1 option:checked{background:var(--primary-color);color:var(--text-inverse)}._error_1gwgc_90{border-color:var(--danger-color)!important;box-shadow:0 0 0 2px #f56c6c4d}._selectWrapper_1gwgc_1 .react-select__control{font-family:inherit}._selectWrapper_1gwgc_1 .react-select__menu{z-index:999}.change-password-modal{max-width:420px}.modal-success{background:var(--success-light);color:var(--success-dark);padding:.75rem 1rem;border-radius:var(--border-radius);margin-bottom:1rem;font-weight:500;font-size:.9rem;border-left:3px solid var(--success-color);display:flex;align-items:center;gap:.5rem}.modal-success:before{content:"✓";font-size:1.2rem;font-weight:700}.modal-error{background:var(--error-light);color:var(--error-color);padding:.75rem 1rem;border-radius:var(--border-radius);margin-bottom:1rem;font-weight:500;font-size:.9rem;border-left:3px solid var(--error-color)}.settings-page{padding:1.5rem 2rem;background:var(--bg-primary);min-height:100vh}.page-header-settings{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;background:var(--bg-white);padding:1.5rem 2rem;border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014}.page-header-content-settings{flex:1}.page-title-settings{font-size:1.75rem;font-weight:600;margin:0 0 .35rem;color:var(--text-primary)}.page-subtitle-settings{font-size:.95rem;color:var(--text-secondary);margin:0}.page-header-icon-settings{width:56px;height:56px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:#fff;box-shadow:0 4px 12px #8b5cf64d;animation:rotate 20s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.settings-section{background:var(--bg-white);border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;padding:1.5rem 2rem;margin-bottom:2rem;transition:box-shadow .2s ease}.settings-section:hover{box-shadow:0 4px 16px #0000001f}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border-color)}.section-header svg{color:var(--primary-color);font-size:1.25rem}.section-header h2{flex:1;font-size:1.15rem;font-weight:600;margin:0;color:var(--text-primary)}.btn-add-user{display:inline-flex!important;align-items:center!important;gap:.5rem!important;background:linear-gradient(135deg,var(--primary-color) 0%,#0d5fd9 100%)!important;color:#fff!important;border:none!important;box-shadow:0 2px 8px #1677ff4d;transition:all .2s ease}.btn-add-user svg{font-size:1rem;line-height:1}.btn-add-user:hover:not(:disabled){background:linear-gradient(135deg,#0d5fd9,#0847b3)!important;box-shadow:0 4px 12px #1677ff66;transform:translateY(-2px)}.settings-content{display:flex;flex-direction:column;gap:.85rem}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--bg-secondary);border-radius:var(--border-radius);transition:all .2s ease}.setting-item:hover{background:var(--bg-primary);transform:translate(4px)}.setting-item label{font-weight:500;color:var(--text-secondary);font-size:.95rem}.setting-item .setting-value{color:var(--text-primary);font-weight:600;font-size:.95rem}.setting-item-action{display:flex;justify-content:space-between;align-items:center}.setting-info{display:flex;align-items:center;gap:.5rem}.change-password-btn{background:transparent!important;color:var(--primary-color)!important;border:1px solid var(--primary-color)!important;min-width:140px;transition:all .2s ease}.change-password-btn:hover:not(:disabled){background:var(--primary-color)!important;color:#fff!important;transform:scale(1.05)}.user-list-card{margin-top:1rem}.user-list-table{width:100%;border-collapse:collapse;font-size:.95rem;background:var(--bg-white);border-radius:var(--border-radius);overflow:hidden}.user-list-table th,.user-list-table td{padding:1rem 1.25rem;text-align:left}.user-list-table th{font-weight:600;color:var(--text-primary);background:var(--bg-secondary);text-transform:uppercase;font-size:.8rem;letter-spacing:.5px;border-bottom:2px solid var(--border-color)}.user-list-table tbody tr{transition:all .2s ease;border-bottom:1px solid var(--border-color)}.user-list-table tbody tr:last-child{border-bottom:none}.user-list-table tbody tr:hover{background:var(--bg-secondary);transform:scale(1.01)}.username-cell{font-weight:600;color:var(--text-primary)}.actions-cell{display:flex;gap:.65rem;align-items:center;justify-content:flex-start}.role-tag{padding:.4rem .85rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s ease}.role-super_admin{background:#6366f126;color:#6366f1;border:1px solid rgba(99,102,241,.3)}.role-admin{background:#f43f5e26;color:#f43f5e;border:1px solid rgba(244,63,94,.3)}.role-operator{background:#0ea5e926;color:#0ea5e9;border:1px solid rgba(14,165,233,.3)}.role-viewer{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.role-tag:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.action-btn{background:transparent!important;color:var(--primary-color)!important;border:1px solid var(--primary-color)!important;transition:all .2s ease}.action-btn:hover:not(:disabled){background:var(--primary-color)!important;color:#fff!important;transform:scale(1.05)}.delete-btn{background:transparent!important;color:#ef4444!important;border:1px solid #ef4444!important;transition:all .2s ease}.delete-btn:hover:not(:disabled){background:#ef4444!important;color:#fff!important;transform:scale(1.05)}.delete-btn:disabled{opacity:.5;cursor:not-allowed}.user-list-loading,.user-list-empty{padding:3rem 2rem;text-align:center;color:var(--text-secondary);font-size:.95rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.user-card-mobile{display:none}@media(max-width:768px){.settings-page{padding:.75rem}.page-header-settings{flex-direction:column;align-items:flex-start;gap:.85rem;padding:1rem;margin-bottom:1rem}.page-title-settings{font-size:1.35rem}.page-subtitle-settings{font-size:.85rem}.page-header-icon-settings{width:44px;height:44px;font-size:1.4rem}.settings-section{padding:1rem;margin-bottom:1rem}.section-header{gap:.5rem;padding-bottom:.85rem;margin-bottom:1rem}.section-header svg{font-size:1.1rem}.section-header h2{font-size:1rem}.btn-add-user{width:100%;justify-content:center!important;font-size:.9rem!important;padding:.65rem 1rem!important}.settings-content{gap:.65rem}.setting-item{flex-direction:column;align-items:flex-start;gap:.5rem;padding:.85rem 1rem}.setting-info{gap:.35rem}.setting-info svg{font-size:.9rem}.setting-item label{font-size:.85rem}.setting-item .setting-value{font-size:.9rem;width:100%;text-align:left}.setting-item-action{width:100%;flex-direction:column;align-items:flex-start;gap:.75rem}.change-password-btn{width:100%;min-width:unset;justify-content:center!important;font-size:.85rem!important;padding:.6rem 1rem!important}.role-tag{padding:.35rem .7rem;font-size:.7rem}.user-list-table{display:none}.user-card-mobile{display:flex;flex-direction:column;gap:.75rem}.user-list-loading,.user-list-empty{padding:2rem 1rem;font-size:.85rem}}.user-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;display:flex;flex-direction:column;gap:.75rem;transition:all .2s ease}.user-card:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.user-card-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.user-card-id{font-size:.75rem;color:var(--text-secondary);font-weight:500}.user-card-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.user-card-actions{display:flex;gap:.5rem}.user-card-actions button{flex:1;justify-content:center!important;font-size:.85rem!important;padding:.6rem!important}.single-camera-page{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem 2rem;max-width:1600px;margin:0 auto;background:var(--bg-primary);min-height:calc(100vh - 60px)}.camera-header{display:flex;align-items:center;gap:1.5rem;background:var(--bg-white);padding:1.25rem 1.5rem;border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014}.back-button{flex-shrink:0;display:inline-flex!important;align-items:center!important;gap:.5rem!important}.back-button svg{font-size:1rem;line-height:1}.camera-header-info{flex:1;display:flex;align-items:center;gap:1rem}.camera-icon-wrapper{width:56px;height:56px;border-radius:14px;background:#1677ff1f;color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.camera-header-text{flex:1;min-width:0}.camera-title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.camera-status-row{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}.status-indicator{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .85rem;border-radius:999px;font-size:.85rem;font-weight:500}.status-indicator.online{background:#22c55e1f;color:#16a34a}.status-indicator.online svg{font-size:.6rem;animation:pulse 2s infinite}.status-indicator.offline{background:#9ca3af1f;color:#6b7280}.status-indicator.offline svg{font-size:.6rem}.camera-last-refresh{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--text-secondary)}.camera-last-refresh svg{font-size:.85rem}.refresh-button{flex-shrink:0;display:inline-flex!important;align-items:center!important;gap:.5rem!important}.refresh-button svg{font-size:1rem;line-height:1}.camera-content{display:flex;gap:1.5rem;align-items:flex-start;flex:1}.video-panel{flex:1;background:var(--bg-white);border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #00000014;padding:1.25rem}.video-container{position:relative;width:100%;padding-top:56.25%;background:#000;border-radius:var(--border-radius);overflow:hidden}.video-iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.video-loading,.video-error{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:linear-gradient(135deg,#1f2937,#111827);color:#fff}.video-error svg{font-size:3rem;opacity:.5;margin-bottom:.5rem}.video-error h3{margin:0;font-size:1.1rem;font-weight:600}.video-error p{margin:.25rem 0 1rem;font-size:.9rem;opacity:.8}.loader-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.video-loading p{margin:0;font-size:.95rem;opacity:.9}.camera-sidebar{width:340px;flex-shrink:0;display:flex;flex-direction:column;gap:1.25rem}.sidebar-section{background:var(--bg-white);border-radius:var(--border-radius-lg);padding:1.25rem;box-shadow:0 2px 8px #00000014}.sidebar-section h3{margin:0 0 1rem;font-size:.95rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.5px}.sidebar-section h3 svg{color:var(--primary-color)}.info-grid{display:grid;grid-template-columns:1fr;gap:.85rem;margin-bottom:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.info-label{font-size:.8rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:.95rem;font-weight:600;color:var(--text-primary)}.map-button{width:100%}.info-list{display:flex;flex-direction:column;gap:.85rem}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-secondary);border-radius:var(--border-radius);gap:.75rem}.info-row .info-label{font-size:.85rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.info-value-small{font-size:.85rem;font-weight:500;color:var(--text-primary);text-align:right;word-break:break-all}.info-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;border-radius:999px;font-size:.8rem;font-weight:500}.info-badge.online{background:#22c55e1f;color:#16a34a}.info-badge.offline{background:#9ca3af1f;color:#6b7280}.info-badge svg{font-size:.55rem}.actions-section{border:2px solid var(--bg-secondary)}.actions-grid{display:flex;flex-direction:column;gap:.75rem}.action-button{width:100%;justify-content:center}.action-button.primary{background:#1677ff1a;color:var(--primary-color);border:1px solid rgba(22,119,255,.3)}.action-button.primary:hover:not(:disabled){background:#1677ff2e}.action-button.secondary{background:var(--bg-secondary);color:var(--text-primary)}.action-button.secondary:hover:not(:disabled){background:var(--bg-primary)}.sidebar-footer{background:#1677ff0d;border-radius:var(--border-radius-lg);padding:1rem;border-left:3px solid var(--primary-color)}.footer-note{margin:0;font-size:.85rem;color:var(--text-secondary);line-height:1.5}.footer-note strong{color:var(--text-primary)}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:1rem;padding:2rem}.error-icon{width:80px;height:80px;border-radius:50%;background:#ef44441a;color:#dc2626;display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin-bottom:.5rem}.error-container h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.error-container p{margin:.5rem 0 1.5rem;font-size:1rem;color:var(--text-secondary);max-width:400px}@media(max-width:1200px){.camera-sidebar{width:300px}}@media(max-width:900px){.single-camera-page{padding:.75rem;gap:1rem}.camera-header{flex-direction:column;align-items:stretch;padding:1rem;gap:1rem}.camera-header-info{width:100%}.back-button,.refresh-button{width:100%;justify-content:center!important}.camera-title{font-size:1.25rem}.camera-content{flex-direction:column;gap:1rem}.video-panel{padding:1rem;width:100%}.video-container{padding-top:56.25%}.camera-sidebar{width:100%}}@media(max-width:600px){.single-camera-page{padding:.5rem}.camera-header{gap:.75rem;padding:.85rem}.camera-icon-wrapper{width:44px;height:44px;font-size:1.25rem}.camera-title{font-size:1.1rem}.camera-status-row{flex-direction:column;align-items:flex-start;gap:.5rem}.video-panel{padding:.75rem}.sidebar-section{padding:1rem}.video-error svg{font-size:2rem}.video-error h3{font-size:1rem}.video-error p{font-size:.85rem}.loader-spinner{width:40px;height:40px;border-width:3px}.video-loading p{font-size:.85rem}}input.form-input{padding:7px 11px;font-size:16px;line-height:1.5;border-radius:8px}.login-form{max-width:600px;justify-self:center;width:100%}.login-container{min-height:100vh;position:relative;padding:37px 53px 20px;box-sizing:border-box;background-position:center;background-size:cover;background-repeat:no-repeat;overflow-x:hidden}.content-container{position:absolute;z-index:100;width:calc(100% - 106px);height:calc(100% - 57px);display:flex;flex-direction:column;justify-content:space-between}.form-row{margin-bottom:30px}.login-container .content-container header{display:flex;justify-content:space-between;align-items:center}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:var(--bg-white);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000000a}.header-left{display:flex;align-items:center;gap:1.5rem}.header-right{display:flex;align-items:center;gap:1rem}.mobile-menu-btn{display:none;background:none;border:none;font-size:1.5rem;color:var(--text-primary);cursor:pointer;padding:.5rem;transition:color .2s ease}.mobile-menu-btn:hover{color:var(--primary-color)}.header-welcome{display:flex;flex-direction:column;gap:.1rem}.welcome-text{font-size:.75rem;color:var(--text-secondary);font-weight:500}.welcome-user{font-size:1rem;font-weight:600;color:var(--text-primary)}.ws-status-header{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:999px;font-size:.85rem;font-weight:600;transition:all .3s ease}.ws-status-header.connected{background:#22c55e1f;color:#16a34a}.ws-status-header.connected svg{font-size:.6rem;color:#16a34a;animation:pulse 2s infinite}.ws-status-header.disconnected{background:#ef44441f;color:#dc2626}.ws-status-header.disconnected svg{font-size:.6rem;color:#dc2626;animation:pulse-warning 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes pulse-warning{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.9)}}.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #ef44444d}.logout-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}.logout-btn svg{font-size:1rem}@media(max-width:1024px){.header{padding:1rem 1.5rem}.header-welcome,.ws-status-header span{display:none}.ws-status-header{padding:.5rem;width:36px;height:36px;justify-content:center}.logout-btn span{display:none}.logout-btn{padding:.65rem;width:44px;height:44px;justify-content:center}}@media(max-width:768px){.header{padding:.85rem 1rem}.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.header-right{gap:.75rem}.ws-status-header{width:32px;height:32px}.logout-btn{width:40px;height:40px}}.sidebar{position:relative;width:260px;height:100vh;background:var(--bg-white);border-right:1px solid var(--border-color);display:flex;flex-direction:column;transition:width .3s cubic-bezier(.4,0,.2,1);flex-shrink:0;z-index:102}.sidebar-content{display:flex;flex-direction:column;justify-content:space-between;height:100%;overflow:hidden}.sidebar-top{flex:1;overflow-y:auto;overflow-x:hidden}.sidebar-top::-webkit-scrollbar{width:4px}.sidebar-top::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.sidebar-header{padding:1.5rem 1rem;border-bottom:1px solid var(--border-color)}.sidebar-logo-link{display:flex;align-items:center;gap:.85rem;text-decoration:none;color:inherit;transition:all .3s ease}.sidebar-logo-link:hover .logo{transform:scale(1.05);box-shadow:0 4px 12px #1677ff40}.logo{width:44px;height:44px;background:linear-gradient(135deg,var(--primary-color) 0%,#0d5fd9 100%);color:#fff;display:flex;align-items:center;justify-content:center;border-radius:12px;font-weight:700;font-size:1.25rem;flex-shrink:0;box-shadow:0 2px 8px #1677ff33;transition:all .3s ease}.logo-text{display:flex;flex-direction:column;gap:.15rem;min-width:0}.logo-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logo-subtitle{font-size:.75rem;font-weight:400;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav{padding:1rem 0}.sidebar-nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.sidebar-nav a{position:relative;display:flex;align-items:center;gap:.85rem;padding:.75rem 1rem;margin:0 .5rem;text-decoration:none;color:var(--text-secondary);font-size:.95rem;font-weight:500;border-radius:var(--border-radius);transition:all .2s ease;white-space:nowrap;overflow:hidden}.sidebar-nav a:hover{background:var(--bg-secondary);color:var(--text-primary);transform:translate(2px)}.nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0;transition:all .2s ease}.nav-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.nav-indicator{width:0;height:0;border-radius:2px;background:var(--primary-color);transition:width .2s ease}.sidebar-nav a.active{background:#1677ff14;color:var(--primary-color);font-weight:600}.sidebar-nav a.active .nav-icon{color:var(--primary-color);transform:scale(1.1)}.sidebar-nav a.active .nav-indicator{width:3px;height:20px}.sidebar-bottom{border-top:1px solid var(--border-color)}.sidebar-footer{padding:1rem;margin-top:.5rem}.sidebar-info{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--border-radius)}.info-icon{width:36px;height:36px;border-radius:8px;background:#1677ff1f;color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.info-content{display:flex;flex-direction:column;gap:.15rem;min-width:0}.info-title{font-size:.9rem;font-weight:600;color:var(--text-primary)}.info-subtitle{font-size:.75rem;color:var(--text-secondary)}.sidebar-toggle-btn{position:absolute;top:24px;right:-8px;width:28px;height:28px;background:var(--bg-white);border:1px solid var(--border-color);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:101;color:var(--text-secondary);box-shadow:0 2px 6px #00000014}.sidebar-toggle-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:scale(1.1);box-shadow:0 4px 12px #1677ff4d}.sidebar-toggle-btn svg{font-size:.9rem;transition:transform .2s ease}.sidebar.is-collapsed{width:80px}.sidebar.is-collapsed .sidebar-header{justify-content:center;padding:1.5rem .5rem}.sidebar.is-collapsed .sidebar-nav a{justify-content:center;padding:.75rem;margin:0 .5rem}.sidebar.is-collapsed .nav-text,.sidebar.is-collapsed .nav-indicator{display:none}.sidebar.is-collapsed .sidebar-nav a:hover{transform:scale(1.05)}.sidebar.is-collapsed .sidebar-nav a.active{background:#1677ff1f}.sidebar.is-collapsed .sidebar-nav a.active:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background:var(--primary-color);border-radius:2px 0 0 2px}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:1000;width:280px;box-shadow:2px 0 12px #0000001a}.sidebar.is-open{transform:translate(0)}.sidebar-toggle-btn{display:none}}@media(min-width:769px){.sidebar-nav a[title]:hover:before{content:attr(title);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%);background:var(--text-primary);color:#fff;padding:.5rem .75rem;border-radius:var(--border-radius);font-size:.85rem;white-space:nowrap;opacity:0;pointer-events:none;z-index:1000;box-shadow:0 4px 12px #00000026}.sidebar.is-collapsed .sidebar-nav a[title]:hover:before{opacity:1;transition:opacity .2s ease .3s}.sidebar.is-collapsed .sidebar-nav a[title]:hover:after{content:"";position:absolute;left:calc(100% + 4px);top:50%;transform:translateY(-50%);width:0;height:0;border-style:solid;border-width:6px 8px 6px 0;border-color:transparent var(--text-primary) transparent transparent;opacity:0}.sidebar.is-collapsed .sidebar-nav a[title]:hover:after{opacity:1;transition:opacity .2s ease .3s}}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.sidebar.is-open .sidebar-nav li{animation:slideIn .3s ease forwards}.sidebar.is-open .sidebar-nav li:nth-child(1){animation-delay:.05s}.sidebar.is-open .sidebar-nav li:nth-child(2){animation-delay:.1s}.sidebar.is-open .sidebar-nav li:nth-child(3){animation-delay:.15s}.sidebar.is-open .sidebar-nav li:nth-child(4){animation-delay:.2s}.sidebar.is-open .sidebar-nav li:nth-child(5){animation-delay:.25s}
