@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap";:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: #e74c3c;--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient( to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55 );--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;padding:4px;width:var(--toastify-toast-width);box-sizing:border-box;color:#fff}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right)}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right)}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;padding:0;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}}.Toastify__toast{--y: 0;position:relative;-ms-touch-action:none;touch-action:none;min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:8px;border-radius:var(--toastify-toast-bd-radius);box-shadow:0 4px 12px #0000001a;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);cursor:default;direction:ltr;z-index:0;overflow:hidden}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{margin:auto 0;-ms-flex:1 1 auto;flex:1 1 auto;padding:6px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}.Toastify__toast-body>div:last-child{word-break:break-word;-ms-flex:1;flex:1}.Toastify__toast-icon{-webkit-margin-end:10px;margin-inline-end:10px;width:20px;-ms-flex-negative:0;flex-shrink:0;display:-ms-flexbox;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}@media only screen and (max-width:480px){.Toastify__toast{margin-bottom:0;border-radius:0}}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;-ms-flex-item-align:start;align-self:flex-start;z-index:1}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:var(--toastify-z-index);opacity:.7;transform-origin:left;border-bottom-left-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial;border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp{position:absolute;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--bg-primary: #0a0e14;--bg-secondary: #111820;--bg-tertiary: #1a2332;--bg-elevated: #212d3b;--bg-card: #161f2d;--accent-primary: #00d4aa;--accent-secondary: #0ea5e9;--accent-warning: #f59e0b;--accent-danger: #ef4444;--accent-success: #22c55e;--accent-purple: #a855f7;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px rgba(0, 212, 170, .15);--font-sans: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", monospace;--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.main-content{flex:1;margin-left:var(--sidebar-width);padding:24px;transition:margin-left var(--transition-base);overflow-x:hidden;min-height:100vh;background:var(--bg-page)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-sidebar-hover);border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;transition:width var(--transition-base);z-index:100}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;min-height:80px}.sidebar-logo{display:flex;align-items:center;gap:12px;overflow:hidden}.sidebar-logo img{max-height:40px;max-width:160px;object-fit:contain}.sidebar.collapsed .sidebar-logo img{max-width:36px}.sidebar-logo-placeholder{width:40px;height:40px;background:linear-gradient(135deg,var(--accent),var(--accent-secondary));border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:var(--bg-sidebar);flex-shrink:0}.sidebar-title{font-size:16px;font-weight:600;color:var(--bg-sidebar-text-hover);white-space:nowrap;transition:opacity var(--transition-fast)}.sidebar.collapsed .sidebar-title{opacity:0;width:0}.hamburger-btn{background:transparent;border:none;color:var(--bg-sidebar-text);cursor:pointer;padding:8px;border-radius:8px;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.hamburger-btn:hover{background:var(--bg-sidebar-hover);color:var(--bg-sidebar-text-hover)}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section{margin-bottom:24px}.nav-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--bg-sidebar-text);padding:0 12px;margin-bottom:8px;white-space:nowrap;transition:opacity var(--transition-fast)}.sidebar.collapsed .nav-section-title{opacity:0}.nav-link{display:flex;align-items:center;gap:12px;padding:12px;border-radius:10px;color:var(--bg-sidebar-text);text-decoration:none;transition:all var(--transition-fast);margin-bottom:4px;position:relative}.nav-link.active{background:#00d4aa1a;color:var(--accent)}.nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background:var(--accent);border-radius:0 2px 2px 0}.nav-link-icon{flex-shrink:0;width:20px;height:20px}.nav-link-text{font-size:14px;font-weight:500;white-space:nowrap;transition:opacity var(--transition-fast)}.sidebar.collapsed .nav-link-text{opacity:0;width:0}.page-header{margin-bottom:24px}.page-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.page-subtitle{font-size:14px;color:var(--text-secondary)}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;padding:24px;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.card:hover{border-color:var(--border)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-size:16px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:10px}.card-title svg{color:var(--accent)}.form-group{margin-bottom:20px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.form-input{width:100%;padding:12px 16px;background:var(--bg-page);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-family:var(--font-sans);font-size:14px;transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa1a}.form-input-mono{font-family:var(--font-mono)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer}.form-checkbox input{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.form-checkbox span{font-size:14px;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:10px;font-family:var(--font-sans);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none;text-decoration:none}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-glow)}.btn-secondary:hover{background:var(--bg-surface);border-color:var(--text-tertiary);box-shadow:var(--shadow-sm)}.btn-icon{padding:10px;background:var(--bg-page);color:var(--text-secondary);border:1px solid var(--border)}.btn-icon:hover{color:var(--text-primary);background:var(--bg-surface)}.btn-sm{padding:8px 14px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500}.status-badge.success{background:#22c55e1a;color:var(--accent-success)}.status-badge.warning{background:#f59e0b1a;color:var(--accent-warning)}.status-badge.danger{background:#ef44441a;color:var(--accent-danger)}.status-badge.info{background:#0ea5e91a;color:var(--accent)}.status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.status-dot.success{background:var(--accent-success)}.status-dot.warning{background:var(--accent-warning)}.status-dot.danger{background:var(--accent-danger)}.status-dot.info{background:var(--accent)}.camera-grid{display:grid;gap:16px;height:calc(100vh - 180px)}.camera-cell{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;position:relative;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.camera-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.camera-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);padding:20px;text-align:center}.grid-controls{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.grid-select{padding:10px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-family:var(--font-sans);font-size:14px;cursor:pointer;min-width:140px}.grid-btn{padding:10px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);font-family:var(--font-sans);font-size:13px;cursor:pointer;transition:all var(--transition-fast)}.grid-btn.active{background:#00d4aa1a;border-color:var(--accent);color:var(--accent)}.archive-container{display:flex;flex-direction:column;height:calc(100vh - 180px)}.archive-player{flex:1;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}.archive-player video{width:100%;height:100%;object-fit:contain}.timeline-container{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:20px;margin-top:16px;box-shadow:var(--shadow-sm)}.timeline-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.timeline-controls{display:flex;align-items:center;gap:12px}.timeline-bar{height:40px;background:var(--bg-page);border-radius:8px;position:relative;cursor:pointer;overflow:hidden}.timeline-progress{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent));opacity:.3}.timeline-playhead{position:absolute;top:0;width:2px;height:100%;background:var(--accent);box-shadow:0 0 8px var(--accent)}.timeline-recordings{position:absolute;top:0;left:0;right:0;height:100%;display:flex}.timeline-recording{height:100%;background:#00d4aa4d;border-left:1px solid var(--accent)}.timeline-time{font-family:var(--font-mono);font-size:14px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.webhook-list{display:flex;flex-direction:column;gap:12px}.webhook-item{background:var(--bg-page);border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;align-items:center;justify-content:space-between;transition:all var(--transition-fast)}.webhook-item:hover{border-color:var(--accent)}.webhook-info{display:flex;flex-direction:column;gap:4px}.webhook-name{font-weight:500;color:var(--text-primary)}.webhook-url{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary)}.webhook-actions{display:flex;gap:8px}.door-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.door-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:20px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.door-card:hover{border-color:var(--accent);transform:translateY(-2px)}.door-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.door-name{font-size:16px;font-weight:600;color:var(--text-primary)}.door-status{display:flex;align-items:center;gap:8px}.door-actions{display:flex;gap:10px}.door-btn{flex:1;padding:12px;border-radius:10px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:none;display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans)}.door-btn.unlock{background:#22c55e1a;color:var(--accent-success);border:1px solid rgba(34,197,94,.3)}.door-btn.unlock:hover{background:#22c55e33}.door-btn.lock{background:#ef44441a;color:var(--accent-danger);border:1px solid rgba(239,68,68,.3)}.door-btn.lock:hover{background:#ef444433}.intercom-modal{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.intercom-modal-content{background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;width:90%;max-width:600px;overflow:hidden;animation:slideUp .3s ease;box-shadow:var(--shadow-sm)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.intercom-modal-header{padding:20px 24px;background:var(--bg-page);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.intercom-modal-title{font-size:18px;font-weight:600;display:flex;align-items:center;gap:12px}.intercom-modal-video{aspect-ratio:16/9;background:var(--bg-page)}.intercom-modal-video img,.intercom-modal-video video{width:100%;height:100%;object-fit:contain}.intercom-modal-actions{padding:20px 24px;display:flex;gap:12px;justify-content:center}.intercom-unlock-btn{padding:16px 40px;background:linear-gradient(135deg,var(--accent-success),#16a34a);color:var(--text-primary);border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:10px;transition:all var(--transition-fast);font-family:var(--font-sans)}.intercom-unlock-btn:hover{transform:scale(1.02);box-shadow:0 0 20px #22c55e4d}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.logo-upload{border:2px dashed var(--border);border-radius:12px;padding:30px;text-align:center;transition:all var(--transition-fast);cursor:pointer}.logo-upload:hover{border-color:var(--accent);background:#00d4aa0d}.logo-upload input{display:none}.logo-preview{margin-top:16px}.logo-preview img{max-height:60px;max-width:200px}.Toastify__toast{background:var(--bg-surface)!important;border:1px solid var(--border)!important;border-radius:12px!important;color:var(--text-primary)!important;box-shadow:var(--shadow-sm)}.Toastify__toast--success{border-color:var(--accent-success)!important}.Toastify__toast--error{border-color:var(--accent-danger)!important}.Toastify__progress-bar{background:var(--accent)!important}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.empty-state{text-align:center;padding:60px 20px;color:var(--text-tertiary)}.empty-state svg{margin-bottom:16px;opacity:.5}.empty-state h3{font-size:18px;color:var(--text-secondary);margin-bottom:8px}@media(max-width:768px){.sidebar{position:fixed;left:-100%;transition:left var(--transition-base)}.sidebar.open{left:0}.main-content{margin-left:0!important;padding:16px;padding-bottom:calc(6rem + env(safe-area-inset-bottom,20px));overflow-y:auto;-webkit-overflow-scrolling:touch}.mobile-header{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding:16px;background:var(--bg-surface);border-radius:12px;box-shadow:var(--shadow-sm)}.mobile-overlay{position:fixed;inset:0;background:#000000b3;z-index:99}.admin-grid,.form-row{grid-template-columns:1fr}.page-title{font-size:22px}.camera-grid{height:auto}.camera-cell{min-height:200px}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.text-sm{font-size:14px}.text-danger{color:var(--accent-danger)}.font-mono{font-family:var(--font-mono)}.webrtc-player{width:100%;height:100%;position:relative;background:var(--bg-page);display:flex;align-items:center;justify-content:center}.webrtc-player video{background:#000}.btn-icon.active{color:var(--accent);background:#00d4aa1a}.live-indicator{background:var(--accent-danger);color:var(--text-primary);font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;animation:pulse-live 1.5s infinite}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.6}}.btn-danger{background:#ef44441a;color:var(--accent-danger);border:1px solid rgba(239,68,68,.3)}.live-indicator.fallback{background:var(--accent-warning)}.sidebar-logo.custom-logo{flex:1;display:flex;align-items:center;justify-content:center;padding:0}.sidebar-logo.custom-logo img{max-width:100%;max-height:50px;object-fit:contain}.sidebar.collapsed .sidebar-logo.custom-logo img{max-width:40px;max-height:40px}.archive-grid-1{display:flex}.archive-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.archive-grid-4{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:8px}.archive-grid-6{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:8px}.archive-video-cell{position:relative;background:var(--bg-secondary);border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.archive-video-cell video{width:100%;height:100%;object-fit:contain;flex:1}.archive-video-header{padding:8px 12px;background:#00000080;color:#fff;font-size:12px;font-weight:500}.archive-datetime{display:flex;gap:12px;padding:16px;border-bottom:1px solid var(--border-color)}.archive-datetime .form-group{flex:1;margin-bottom:0}.archive-datetime .form-label{display:flex;align-items:center;gap:6px;font-size:12px;margin-bottom:6px}.archive-camera-list{flex:1;overflow-y:auto;padding:12px;max-height:300px}.camera-checkbox{padding:10px 8px;border-radius:6px;transition:background .2s}.camera-checkbox:hover{background:var(--bg-surface)}.archive-controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;border-top:1px solid var(--border-color)}.archive-controls .btn-lg{padding:12px 24px;font-size:16px}.archive-sidebar{display:flex;flex-direction:column}.multi-timeline{padding:16px}.timeline-tracks{display:flex;flex-direction:column;gap:8px;margin:16px 0}.timeline-track{display:flex;align-items:center;gap:12px;height:32px}.timeline-track-label{width:150px;min-width:150px;font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-left:8px;color:var(--text-secondary)}.timeline-track-bar{flex:1;height:24px;background:var(--bg-surface);border-radius:4px;position:relative;cursor:pointer;overflow:hidden;box-shadow:var(--shadow-sm)}.timeline-track-bar .timeline-recordings{position:absolute;inset:0}.timeline-track-bar .timeline-recording{position:absolute;top:0;height:100%;opacity:.8}.timeline-playhead-container{position:relative;margin-left:162px;margin-right:0;height:0}.timeline-playhead-track{position:relative;height:0}.timeline-playhead-container .timeline-playhead{position:absolute;top:-8px;width:2px;height:calc(100% + 16px);background:var(--accent);transform:translate(-50%);z-index:10}.timeline-playhead-container .timeline-playhead:before{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--accent)}.multi-timeline .timeline-labels{margin-left:162px;display:flex;justify-content:space-between;font-size:11px;color:var(--text-tertiary);padding-top:8px}.camera-color-indicator{width:12px;height:12px;border-radius:3px;flex-shrink:0;margin-right:8px}.camera-checkbox{display:flex;align-items:center}.camera-checkbox input[type=checkbox]{margin-right:8px}.recording-status{padding:12px 16px;border-bottom:1px solid var(--border)}.status-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500}.status-badge.success{background:#22c55e26;color:#22c55e}.status-badge.warning{background:#fb923c26;color:#fb923c}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.clip-navigation{display:flex;gap:8px;padding:12px 16px;justify-content:center}.clip-navigation .btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px}.timeline-track-playhead{position:absolute;top:0;bottom:0;width:2px;background:#fff;transform:translate(-50%);z-index:5;box-shadow:0 0 4px #00000080}.timeline-track-playhead:before{content:"";position:absolute;top:-4px;left:50%;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid #fff}.timeline-track-playhead:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:5px solid #fff}.timeline-labels-container{display:flex;margin-top:8px}.timeline-label-spacer{width:162px;min-width:162px}.timeline-labels-container .timeline-labels{flex:1;display:flex;justify-content:space-between;font-size:11px;color:var(--text-tertiary)}.timeline-track-bar:hover{background:var(--bg-page)}.timeline-track-bar .timeline-recordings{pointer-events:none}.timeline-zoom-controls{display:flex;align-items:center;gap:8px;margin-left:auto}.zoom-label{font-size:12px;font-weight:600;color:var(--text-secondary);min-width:32px;text-align:center}.track-clip-count{display:block;font-size:10px;color:var(--text-tertiary);font-weight:400}.recording-count{font-size:11px;color:var(--text-tertiary);margin-top:4px}.timeline-track-bar{position:relative;overflow:visible}.timeline-recording{border-radius:2px;transition:opacity .2s}.timeline-recording:hover{opacity:1!important;z-index:5}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--bg-page);color:var(--text-secondary)}.app-loading p{margin-top:16px}.intercom-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.intercom-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent));display:flex;align-items:center;justify-content:center;color:var(--bg-page)}.intercom-name{font-size:16px;font-weight:600;margin:0}.intercom-time{font-size:12px;color:var(--text-tertiary);display:flex;align-items:center;gap:4px;margin:4px 0 0}.intercom-thumbnail{position:relative;background:var(--bg-page);cursor:pointer}.intercom-thumbnail img{width:100%;height:200px;object-fit:cover}.intercom-camera-badge{position:absolute;bottom:8px;left:8px;background:#000000b3;color:var(--text-primary);font-size:11px;padding:4px 8px;border-radius:4px;display:flex;align-items:center;gap:4px}.intercom-card-actions{display:flex;gap:8px;padding:16px}.intercom-card-actions .btn{flex:1}.intercom-modal{max-width:600px;width:90vw}.intercom-live-view{background:var(--bg-page);border-radius:8px;overflow:hidden;min-height:300px;display:flex;align-items:center;justify-content:center}.intercom-live-view img{width:100%;height:auto;max-height:400px;object-fit:contain}.intercom-details{padding:16px 0;font-size:14px}.intercom-details p{margin:8px 0;color:var(--text-secondary)}.intercom-details strong{color:var(--text-primary)}.modal-content{background:var(--bg-surface);border-radius:16px;overflow:hidden;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h3{display:flex;align-items:center;gap:8px;margin:0;font-size:18px}.modal-body{padding:20px;overflow-y:auto}.modal-footer{display:flex;gap:12px;padding:16px 20px;border-top:1px solid var(--border)}.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#16a34a,#15803d)}.btn-success:disabled{background:#4b5563;cursor:not-allowed}.intercom-list{display:flex;flex-direction:column;gap:8px}.intercom-list-item strong{color:var(--text-primary)}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}@media(max-width:768px){.admin-grid{grid-template-columns:1fr}}@media(max-width:500px){.form-row{grid-template-columns:1fr}}.mb-4{margin-bottom:16px}.mt-1{margin-top:4px}.mt-4{margin-top:16px}.empty-state-small{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;text-align:center}.empty-state-small p{margin:8px 0 0}.intercom-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.intercom-list-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-page);border-radius:8px;border:1px solid var(--border)}.intercom-list-info{flex:1;min-width:0}.intercom-list-info strong{color:var(--text-primary)}.webhook-info{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.form-section-title{font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-tertiary);margin:20px 0 12px;letter-spacing:.5px}.intercom-form-modal{width:500px;max-width:90vw}.text-success{color:#22c55e}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500}.badge-info{background:#3b82f633;color:#60a5fa}.text-info{color:#60a5fa}.camera-warning{padding:12px;background:#eab3081a;border:1px solid rgba(234,179,8,.3);border-radius:8px}.text-warning{color:#eab308}.mt-3{margin-top:12px}.section-title{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;margin:24px 0 16px;color:var(--text-primary)}.section-title:first-of-type{margin-top:0}.notifications-section{margin-bottom:24px}.notification-bar{display:flex;gap:12px;overflow-x:auto;padding:4px}.notification-item{display:flex;align-items:center;gap:12px;background:var(--bg-surface);border:2px solid var(--accent-warning);border-radius:12px;padding:12px;min-width:280px;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.notification-item:hover{background:var(--bg-page)}.notification-thumbnail{width:60px;height:60px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--bg-page)}.notification-info{flex:1;min-width:0}.notification-info strong{display:block;font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.intercom-card{display:flex;flex-direction:column}.intercom-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px;border-bottom:1px solid var(--border)}.intercom-camera-name{font-size:12px;color:var(--text-tertiary);display:flex;align-items:center;gap:4px;margin:4px 0 0}.intercom-thumbnail{position:relative;background:var(--bg-page);cursor:pointer;min-height:180px;display:flex;align-items:center;justify-content:center}.intercom-thumbnail img{width:100%;height:180px;object-fit:cover}.intercom-thumbnail:hover{opacity:.9}.snapshot-loading{display:flex;align-items:center;justify-content:center;width:100%;height:180px}.no-thumbnail{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--text-tertiary);width:100%;height:180px}.no-thumbnail span{font-size:12px}.badge-warning{background:#eab30833;color:#eab308;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center}.intercom-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent));display:flex;align-items:center;justify-content:center;color:var(--bg-page);flex-shrink:0}.drag-hint{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-tertiary);margin-bottom:12px;padding:8px 12px;background:var(--bg-surface);border-radius:8px;width:fit-content;box-shadow:var(--shadow-sm)}.camera-tile{position:relative;transition:transform .2s,box-shadow .2s,opacity .2s;border-radius:12px;overflow:hidden}.camera-tile.dragging{opacity:.5;transform:scale(.98)}.camera-tile.drag-over{box-shadow:0 0 0 3px var(--accent);transform:scale(1.02)}.camera-tile.drag-over:before{content:"";position:absolute;inset:0;background:#3b82f61a;z-index:10;pointer-events:none;border-radius:12px}.drag-handle{display:flex;align-items:center;justify-content:center;cursor:grab;padding:4px;margin-right:4px;color:var(--text-tertiary);border-radius:4px;transition:all .2s}.drag-handle:hover{color:var(--text-primary);background:#ffffff1a}.drag-handle:active{cursor:grabbing}.grid-options{display:flex;gap:4px}.grid-btn{padding:6px 12px;font-size:13px;border-radius:6px;background:var(--bg-page);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all .2s;position:relative;display:flex;align-items:center;gap:6px}.grid-btn:hover{background:var(--bg-surface);color:var(--text-primary)}.grid-btn.active{background:var(--accent);border-color:var(--accent);color:var(--text-primary)}.grid-btn-badge{font-size:9px;padding:2px 5px;border-radius:4px;background:#fff3;font-weight:600;text-transform:uppercase}.grid-btn.active .grid-btn-badge{background:#ffffff4d}.camera-fullscreen-modal{max-width:95vw!important;width:95vw;max-height:95vh!important}.camera-fullscreen-view{width:100%;height:calc(95vh - 80px);background:#000;display:flex;align-items:center;justify-content:center}.camera-fullscreen-view video{max-width:100%;max-height:100%}.camera-grid{gap:8px}@media(min-width:1400px){.camera-grid{gap:12px}}.camera-cell{min-height:120px}@media(max-height:800px){.camera-cell{min-height:100px}}.camera-grid-scrollable{height:auto!important;max-height:none!important;overflow:visible!important}.camera-grid-scrollable .camera-tile{min-height:250px;height:250px}.camera-grid-scrollable .camera-cell{min-height:230px;height:100%}.camera-grid-scrollable .camera-stream{min-height:180px;height:calc(100% - 50px)}.camera-grid-scrollable .camera-stream img{height:100%;width:100%;object-fit:cover}.page-container{overflow-y:auto;height:auto;min-height:100%}.camera-grid{height:auto!important;max-height:none!important;overflow:visible!important}.camera-tile{min-height:300px;height:auto}.camera-cell{min-height:280px;height:100%;display:flex;flex-direction:column}.camera-header{flex-shrink:0}.camera-stream{flex:1;min-height:220px;display:flex;align-items:center;justify-content:center}.camera-stream img{width:100%;height:100%;object-fit:contain}.camera-grid[style*="repeat(1, 1fr)"] .camera-tile{min-height:500px}.camera-grid[style*="repeat(1, 1fr)"] .camera-stream{min-height:440px}.camera-grid[style*="repeat(2, 1fr)"] .camera-tile{min-height:350px}.camera-grid[style*="repeat(2, 1fr)"] .camera-stream{min-height:280px}:root{--sidebar-width: 240px;--sidebar-collapsed-width: 64px;--header-height: 60px;--safe-area-inset-top: env(safe-area-inset-top, 0px);--safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);--safe-area-inset-left: env(safe-area-inset-left, 0px);--safe-area-inset-right: env(safe-area-inset-right, 0px)}.app-container{padding-top:var(--safe-area-inset-top);padding-bottom:var(--safe-area-inset-bottom);padding-left:var(--safe-area-inset-left);padding-right:var(--safe-area-inset-right)}@media(max-width:1024px){.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:1000;transform:translate(-100%);transition:transform .3s ease;width:var(--sidebar-width)!important}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:999}.sidebar.open+.sidebar-overlay{display:block}.main-content{margin-left:0!important;width:100%!important}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.grid-controls{flex-wrap:wrap;gap:8px}.grid-options{order:-1;width:100%;justify-content:flex-start}.camera-grid{gap:8px!important}.camera-tile{min-height:200px!important}.camera-stream{min-height:150px!important}}@media(max-width:768px){.page-container{padding:12px}.page-title{font-size:20px}.page-subtitle{font-size:12px}.card{padding:12px}.btn{padding:8px 12px;font-size:13px}.btn-sm{padding:6px 10px;font-size:12px}.grid-controls{flex-direction:column;align-items:stretch}.grid-controls>*{width:100%}.grid-select{width:100%}.grid-options{display:flex;flex-wrap:wrap;justify-content:center}.grid-btn{flex:1;min-width:60px;justify-content:center}.camera-grid{grid-template-columns:1fr!important}.camera-tile{min-height:250px!important}.camera-stream{min-height:200px!important}.camera-header{padding:8px 10px}.camera-name{font-size:12px}.intercom-grid{grid-template-columns:1fr}.intercom-thumbnail{min-height:200px!important}.intercom-thumbnail img{height:200px!important}.notification-bar{flex-direction:column}.notification-item{min-width:100%}.modal-content{width:100%!important;max-width:100%!important;height:100%!important;max-height:100%!important;border-radius:0!important;margin:0!important}.modal-overlay{padding:0}.intercom-live-view{height:calc(100vh - 200px)!important}.camera-fullscreen-view{height:calc(100vh - 120px)!important}.admin-grid{grid-template-columns:1fr}.form-row{flex-direction:column}.form-row .form-group{width:100%}.drag-hint{display:none}}@media(max-width:480px){.page-container{padding:8px}.page-header{margin-bottom:12px}.page-title{font-size:18px}.btn{padding:6px 10px;font-size:12px}.grid-btn{padding:6px 8px;font-size:11px}.grid-btn-badge{display:none}.camera-tile{min-height:220px!important}.section-title{font-size:14px}}@media(max-height:500px)and (orientation:landscape){.camera-grid{grid-template-columns:repeat(2,1fr)!important}.camera-tile{min-height:180px!important}.camera-stream{min-height:130px!important}.page-header{padding:8px 0;margin-bottom:8px}.grid-controls{padding:8px 0}}@media(hover:none)and (pointer:coarse){.btn,.grid-btn,.btn-icon{min-height:44px;min-width:44px}.camera-header button{min-width:36px;min-height:36px}.drag-handle{padding:8px}.btn:hover,.grid-btn:hover,.camera-tile:hover{transform:none}}@media(display-mode:standalone){.app-container{padding-top:max(var(--safe-area-inset-top),20px)}}@media(prefers-color-scheme:dark){:root{color-scheme:dark}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.loading-spinner{animation:none}}@media print{.sidebar,.grid-controls,.btn,.drag-hint{display:none!important}.main-content{margin-left:0!important}.camera-grid{grid-template-columns:repeat(2,1fr)!important}}.mobile-menu-btn{display:none;position:fixed;bottom:20px;right:20px;z-index:998;width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;border:none;box-shadow:0 4px 12px #0000004d;cursor:pointer;align-items:center;justify-content:center}@media(max-width:1024px){.mobile-menu-btn{display:flex}}.pull-to-refresh{position:fixed;top:0;left:0;right:0;height:60px;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);transform:translateY(-100%);transition:transform .3s ease;z-index:1001}.pull-to-refresh.visible{transform:translateY(0)}.modal-footer{padding-bottom:max(16px,var(--safe-area-inset-bottom))}.page-container,.modal-body,.camera-grid-scrollable{-webkit-overflow-scrolling:touch}input,select,textarea{font-size:16px}@media(max-width:768px){input,select,textarea{font-size:16px!important}}.sidebar-overlay{position:fixed;inset:0;background:#0009;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:100;padding:0 16px;align-items:center;padding-top:env(safe-area-inset-top,0);box-shadow:var(--shadow-sm)}.mobile-header-logo{height:36px;width:auto;object-fit:contain}.mobile-header-brand{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;color:var(--text-primary)}.mobile-header-brand .brand-icon{color:var(--accent)}@media(max-width:1024px){.mobile-header{display:flex}.main-content{padding-top:calc(60px + env(safe-area-inset-top,0))!important}}@media(max-width:1024px){.sidebar{position:fixed;left:0;top:0;bottom:0;width:280px!important;z-index:1000;transform:translate(-100%);transition:transform .3s ease;background:var(--bg-surface);border-right:1px solid var(--border);padding-top:env(safe-area-inset-top,0);overflow-y:auto}.sidebar.open{transform:translate(0)}.sidebar-header{padding:20px;border-bottom:1px solid var(--border)}.sidebar-logo{max-height:40px;width:auto}.sidebar-brand{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:600;color:var(--bg-sidebar-text-hover)}.sidebar-nav{padding:16px 0;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:14px;padding:14px 20px;color:var(--bg-sidebar-text);text-decoration:none;transition:all .2s;font-size:15px}.nav-item:hover,.nav-item.active{background:var(--bg-sidebar-hover);color:var(--accent)}.nav-item.active{border-left:3px solid var(--accent)}.nav-label{display:block!important}.sidebar-toggle{display:none}.sidebar-overlay{position:fixed;inset:0;background:#0009;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-menu-btn{position:fixed;bottom:24px;right:24px;z-index:998;width:56px;height:56px;border-radius:50%;background:var(--accent);color:var(--text-primary);border:none;box-shadow:0 4px 12px #0006;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}.mobile-menu-btn:active{transform:scale(.95)}.page-container{padding-top:16px}}@media(min-width:1025px){.mobile-header,.mobile-menu-btn,.sidebar-overlay{display:none!important}}@media(display-mode:standalone){.mobile-header{padding-top:env(safe-area-inset-top,20px);height:calc(60px + env(safe-area-inset-top,20px))}.sidebar{padding-top:env(safe-area-inset-top,20px)}.mobile-menu-btn{bottom:calc(24px + env(safe-area-inset-bottom,0))}}.home-page{max-width:1000px;margin:0 auto}.home-hero{text-align:center;padding:40px 20px;margin-bottom:32px}.home-logo-container{margin-bottom:24px}.home-logo{max-height:100px;max-width:280px;width:auto;object-fit:contain}.home-logo-default{display:inline-flex;align-items:center;justify-content:center;width:120px;height:120px;border-radius:24px;background:linear-gradient(135deg,var(--accent) 0%,#059669 100%);color:var(--text-primary);box-shadow:0 8px 32px #10b9814d}.home-title{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 12px}.home-subtitle{font-size:18px;color:var(--text-secondary);margin:0 0 8px}.home-stats{font-size:14px;color:var(--accent);margin:0;font-weight:500}.home-section{margin-bottom:32px}.home-section-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 16px;padding-left:4px}.home-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.home-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;text-decoration:none;transition:all .2s ease;box-shadow:var(--shadow-sm)}.home-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.home-card-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:12px;flex-shrink:0}.home-card-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.home-card-description{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.4}.home-card-arrow{color:var(--text-tertiary);flex-shrink:0;transition:transform .2s}.home-card:hover .home-card-arrow{color:var(--accent);transform:translate(4px)}.home-features{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.home-feature{display:flex;gap:12px;padding:16px;background:var(--bg-page);border-radius:10px}.home-feature-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:#10b98126;color:var(--accent);flex-shrink:0}.home-feature-content{flex:1;min-width:0}.home-feature-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.home-feature-description{font-size:12px;color:var(--text-secondary);margin:0;line-height:1.4}.home-info-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm)}.home-info-card h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.home-steps{margin:0;padding-left:20px;color:var(--text-secondary);font-size:14px;line-height:1.8}.home-steps li{margin-bottom:8px}.home-steps li:last-child{margin-bottom:0}.home-steps strong{color:var(--text-primary)}.home-steps a{color:var(--accent);text-decoration:none}.home-steps a:hover{text-decoration:underline}.home-footer{display:flex;justify-content:center;gap:24px;padding:24px 0;border-top:1px solid var(--border);margin-top:16px}.home-footer-link{display:flex;align-items:center;gap:8px;color:var(--text-secondary);text-decoration:none;font-size:14px;transition:color .2s}.home-footer-link:hover{color:var(--accent)}@media(max-width:768px){.home-hero{padding:24px 16px}.home-logo{max-height:80px;max-width:200px}.home-logo-default{width:100px;height:100px}.home-logo-default svg{width:48px;height:48px}.home-title{font-size:24px}.home-subtitle{font-size:15px}.home-grid,.home-features{grid-template-columns:1fr}.home-card{padding:16px}.home-card-icon{width:48px;height:48px}.home-card-title{font-size:15px}.home-card-description{font-size:12px}.home-info-card{padding:16px}.home-footer{flex-direction:column;align-items:center;gap:16px}}@media(max-width:480px){.home-hero{padding:20px 12px}.home-title{font-size:22px}.home-section-title{font-size:16px}}.home-logo-main{width:100%;max-width:min(50vw,350px);height:auto;object-fit:contain}@media(min-width:1400px){.home-logo-main{max-width:400px}}@media(min-width:1024px)and (max-width:1399px){.home-logo-main{max-width:320px}}@media(min-width:768px)and (max-width:1023px){.home-logo-main{max-width:280px}}@media(max-width:767px){.home-logo-main{max-width:220px}}@media(max-width:480px){.home-logo-main{max-width:180px}}@media(max-height:500px)and (orientation:landscape){.home-logo-main{max-width:200px}.home-hero{padding:16px}}.sidebar{display:flex;flex-direction:column;width:var(--sidebar-width);min-width:var(--sidebar-width);height:100vh;background:var(--bg-sidebar-hover);border-right:1px solid rgba(255,255,255,.08);position:fixed;left:0;top:0;z-index:100;transition:width .3s ease,min-width .3s ease}.sidebar.collapsed{width:var(--sidebar-collapsed-width);min-width:var(--sidebar-collapsed-width)}.sidebar-header{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.sidebar-brand{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:600;color:var(--bg-sidebar-text-hover);white-space:nowrap;overflow:hidden}.sidebar-brand .brand-icon{color:var(--accent);flex-shrink:0}.sidebar-logo{max-height:40px;width:auto;object-fit:contain}.sidebar-nav{display:flex;flex-direction:column;padding:16px 0;flex:1;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--bg-sidebar-text);text-decoration:none;transition:all .2s;white-space:nowrap;border-left:3px solid transparent}.nav-item:hover{background:#10b9811a;color:var(--bg-sidebar-text-hover)}.nav-item.active{background:#10b98126;color:var(--accent);border-left-color:var(--accent)}.nav-item svg{flex-shrink:0}.nav-label{overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .nav-label,.sidebar.collapsed .sidebar-brand span{display:none}.sidebar-toggle{display:flex;align-items:center;justify-content:center;padding:12px;margin:8px;background:var(--bg-sidebar-hover);border:1px solid rgba(255,255,255,.08);border-radius:8px;color:var(--bg-sidebar-text);cursor:pointer;transition:all .2s;flex-shrink:0}.sidebar-toggle:hover{background:var(--bg-sidebar);color:var(--bg-sidebar-text-hover)}.main-content{margin-left:var(--sidebar-width);min-height:100vh;padding:20px;transition:margin-left .3s ease}.sidebar.collapsed~.main-content{margin-left:var(--sidebar-collapsed-width)}.app-container{display:flex;min-height:100vh}@media(min-width:1025px){.sidebar-nav{display:flex;flex-direction:column}.nav-item{display:flex;flex-direction:row;width:100%}.mobile-header,.mobile-menu-btn{display:none!important}}.input-with-button{display:flex;gap:8px}.input-with-button .form-input{flex:1}.sidebar-logo{max-width:100%;height:32px;object-fit:contain}.sidebar.collapsed .sidebar-logo{display:none}.sidebar.collapsed .sidebar-header{padding:20px 8px;display:flex;justify-content:center}.mobile-header-logo{height:28px;width:auto;object-fit:contain}@media(min-width:1025px){.sidebar-logo{height:42px;max-width:100%;object-fit:contain}.sidebar-header{padding:24px 16px}}@media(max-width:1024px){.main-content{padding-top:16px!important}.home-page{padding-top:60px}}@media(display-mode:standalone){.main-content{padding-top:calc(16px + env(safe-area-inset-top,0))!important}.home-page{padding-top:calc(60px + env(safe-area-inset-top,0))}.mobile-header{padding-top:env(safe-area-inset-top,0);height:calc(60px + env(safe-area-inset-top,0))}}.mobile-header{display:none!important}@media(max-width:1024px){.home-page{padding-top:16px}.home-hero{padding:40px 16px}.home-logo-container{width:100%;padding:0 16px}.home-logo-main{width:100%;max-width:100%;height:auto}.main-content{padding-top:16px!important;margin-left:0!important}}@media(display-mode:standalone){.page-container{padding-top:env(safe-area-inset-top,16px)}.home-hero{padding-top:calc(20px + env(safe-area-inset-top,0))}.mobile-menu-btn{bottom:calc(24px + env(safe-area-inset-bottom,0))}}@media(max-width:480px){.home-logo-container{padding:0 8px}.home-hero{padding:32px 8px}}@media(max-width:1024px){.mobile-header{display:flex!important;position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:100;padding:0 16px;align-items:center;box-shadow:var(--shadow-sm)}.mobile-header-logo{height:28px;width:auto;object-fit:contain}.main-content:has(~.mobile-header),body:has(.mobile-header) .main-content{padding-top:72px!important}.home-page{padding-top:0!important}}@media(max-width:1024px)and (display-mode:standalone){.mobile-header{padding-top:env(safe-area-inset-top,0);height:calc(56px + env(safe-area-inset-top,0))}}@media(max-width:1024px){.app-container.has-mobile-header .main-content{padding-top:72px!important}.app-container.is-home-page .main-content{padding-top:16px!important}}@media(max-width:1024px)and (display-mode:standalone){.app-container.has-mobile-header .main-content{padding-top:calc(72px + env(safe-area-inset-top,0))!important}.app-container.is-home-page .main-content{padding-top:calc(16px + env(safe-area-inset-top,0))!important}}.notification-badge{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#f59e0b33;border:1px solid rgba(245,158,11,.4);border-radius:8px;color:var(--accent-warning);font-size:13px;font-weight:500}.notification-card{margin-bottom:20px;border:1px solid rgba(245,158,11,.3)}.notification-card .card-title{color:var(--accent-warning)}.notification-list{display:flex;flex-direction:column;gap:12px}.notification-item{display:flex;align-items:center;gap:16px;padding:12px;background:var(--bg-page);border-radius:10px;border:1px solid var(--border)}.notification-thumbnail{width:80px;height:60px;border-radius:8px;overflow:hidden;background:var(--bg-page);flex-shrink:0}.notification-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.notification-name{font-weight:600;color:var(--text-primary);font-size:14px}.notification-time{font-size:12px;color:var(--text-secondary)}.notification-event{font-size:11px;color:var(--accent-warning);font-weight:500}.notification-actions{display:flex;gap:8px;flex-shrink:0}.intercom-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.intercom-cell{cursor:pointer}.intercom-stream{cursor:pointer;transition:opacity .2s}.intercom-stream:hover{opacity:.9}.intercom-stream img{width:100%;height:100%;object-fit:cover}.btn-icon.btn-unlock{color:var(--accent)}.btn-icon.btn-unlock:hover{background:#10b98133}.btn-icon.btn-unlock:disabled{color:var(--text-tertiary);opacity:.5}.intercom-warning-badge{position:absolute;bottom:8px;left:8px;display:flex;align-items:center;gap:4px;padding:4px 8px;background:#ef4444e6;border-radius:4px;font-size:10px;color:var(--text-primary);font-weight:500}.intercom-modal-controls{display:flex;justify-content:center;gap:16px;padding:16px;background:var(--bg-surface);border-top:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-unlock-large{min-width:160px}.btn-success{background:var(--accent);color:#fff}.btn-success:hover{background:#059669}.btn-success:disabled{background:var(--bg-tertiary);color:var(--text-muted)}.intercom-snapshot-fullscreen{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#000}.intercom-snapshot-fullscreen img{max-width:100%;max-height:100%;object-fit:contain}@media(max-width:768px){.intercom-grid{grid-template-columns:1fr}.notification-item{flex-wrap:wrap}.notification-actions{width:100%;justify-content:flex-end;margin-top:8px}.intercom-modal-controls{flex-direction:column;gap:12px}.intercom-modal-controls .btn{width:100%;justify-content:center}}@media(min-width:1200px){.intercom-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1600px){.intercom-grid{grid-template-columns:repeat(4,1fr)}}.registration-page{display:flex;flex-direction:column;height:100%}.registration-form-container{flex:1;position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;min-height:600px;box-shadow:var(--shadow-sm)}.registration-iframe{width:100%;height:100%;min-height:600px;border:none;background:#fff;border-radius:12px}.form-loading-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--bg-surface);z-index:10}.form-loading-overlay p{color:var(--text-secondary);font-size:14px}.loading-badge{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#3b82f633;border:1px solid rgba(59,130,246,.4);border-radius:8px;color:var(--accent-info);font-size:13px;font-weight:500}.error-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:var(--accent-danger);margin-bottom:16px}.error-banner span{flex:1}@media(max-width:768px){.registration-form-container,.registration-iframe{min-height:500px;border-radius:8px}}@media(max-width:480px){.registration-form-container{min-height:450px;margin:0 -8px;border-radius:0}.registration-iframe{min-height:450px;border-radius:0}}@media(min-height:800px){.registration-form-container,.registration-iframe{min-height:calc(100vh - 250px)}}.mobile-form-message{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 24px;gap:16px}.mobile-form-message svg{color:var(--accent);opacity:.8}.mobile-form-message h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.mobile-form-message p{color:var(--text-secondary);font-size:14px;line-height:1.6;max-width:300px;margin:0}.mobile-form-message .btn-lg{margin-top:16px;padding:14px 28px;font-size:16px}.btn-lg{padding:12px 24px;font-size:15px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-page);padding:20px}.login-container{width:100%;max-width:400px;background:var(--bg-surface);border-radius:16px;padding:40px;border:.5px solid var(--border);box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:32px}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:20px;margin-bottom:16px;color:var(--text-primary)}.login-header h1{font-size:24px;font-weight:600;margin:0 0 8px;color:var(--text-primary)}.login-header p{color:var(--text-secondary);margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:8px;font-size:14px;text-align:center}.login-form .form-label{display:flex;align-items:center;gap:8px;margin-bottom:8px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.login-btn{width:100%;padding:14px;font-size:16px;display:flex;align-items:center;justify-content:center;gap:8px}.login-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1)}.login-footer p{color:var(--text-tertiary);font-size:12px;margin:0}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#0a0a0f;color:var(--text-primary);gap:16px}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;text-transform:uppercase}.badge-primary{background:#3b82f633;color:#3b82f6}.badge-danger{background:#ef444433;color:#ef4444}.badge-secondary{background:#6b728033;color:var(--text-secondary)}.badge-success{background:#10b98133;color:#10b981}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;margin-top:auto}.user-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;color:var(--bg-sidebar-text-hover);text-overflow:ellipsis}.user-role{font-size:11px;color:var(--bg-sidebar-text);text-transform:capitalize}.logout-btn{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:8px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.logout-btn:hover{background:#ef444433}.login-logo-wrapper{display:flex;align-items:center;justify-content:center;margin-bottom:20px}.login-logo-img{width:100%;max-width:180px;height:auto;object-fit:contain;border-radius:16px}@media(min-width:768px){.login-logo-img{max-width:220px}.login-container{padding:48px}.login-header h1{font-size:28px}}@media(min-width:481px)and (max-width:767px){.login-logo-img{max-width:180px}.login-container{padding:36px}}@media(max-width:480px){.login-page{padding:16px}.login-container{padding:24px;border-radius:12px}.login-logo-img{max-width:140px}.login-header h1{font-size:22px}.login-header p{font-size:14px}.login-btn{padding:12px;font-size:15px}}@media(display-mode:standalone){.login-page{padding-top:env(safe-area-inset-top,20px);padding-bottom:env(safe-area-inset-bottom,20px)}.login-logo-img{max-width:160px}}.oauth-provider-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:20px}.oauth-provider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--text-tertiary);transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:var(--text-primary);transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#10b981}.oauth-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 24px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff0d;color:var(--text-primary);text-decoration:none;font-size:14px;transition:all .2s}.oauth-btn:hover{background:#ffffff1a;border-color:#ffffff4d}.oauth-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--text-tertiary);font-size:14px}.oauth-divider:before,.oauth-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.lockdown-container{margin-bottom:24px}.lockdown-box{background:var(--status-ok-bg);border:.5px solid var(--status-ok);border-radius:12px;padding:20px 24px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}.lockdown-box.active{background:var(--status-error-bg);border-color:var(--status-error);animation:pulse-border 2s infinite}@keyframes pulse-border{0%,to{border-color:var(--status-error)}50%{border-color:var(--status-error)}}.lockdown-content{display:flex;align-items:center;gap:16px;color:var(--status-ok-text)}.lockdown-box.active .lockdown-content{color:var(--status-error-text)}.lockdown-text h3{margin:0 0 4px;font-size:18px;font-weight:600;color:var(--text-primary)}.lockdown-text p{margin:0;font-size:14px;color:var(--text-secondary)}.lockdown-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;font-weight:600;white-space:nowrap}.btn-danger{background:var(--status-error);color:#fff;border:none}.btn-danger:hover{background:var(--status-error);filter:brightness(.9)}.lockdown-btn.btn-danger{background:var(--status-error);color:#fff}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none}.btn-success:hover{background:linear-gradient(135deg,#059669,#047857)}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--bg-surface);border-radius:16px;padding:32px;max-width:480px;width:100%;position:relative;border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-sm)}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px}.modal-close:hover{color:var(--text-primary)}.modal-icon{text-align:center;margin-bottom:20px}.modal-content h2{text-align:center;margin:0 0 16px;font-size:24px}.modal-content p{text-align:center;color:var(--text-secondary);margin:0 0 24px;line-height:1.6}.modal-actions{display:flex;gap:12px;justify-content:center}.modal-actions .btn{min-width:140px}.lockdown-modal{border:2px solid rgba(249,115,22,.5)}@media(max-width:640px){.lockdown-box{flex-direction:column;text-align:center}.lockdown-content,.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.sidebar{z-index:1001!important}.sidebar-nav{position:relative;z-index:1002!important}.sidebar-overlay{z-index:1000!important}.camera-thumbnail-container{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#111}.camera-thumbnail{width:100%;height:100%;object-fit:contain}.camera-stream{position:relative}.camera-stream .camera-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.camera-grid-scrollable .camera-tile,.camera-grid-scrollable .camera-cell{contain:layout style}.modal-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.camera-fullscreen-modal{background:#000!important;border:none!important;border-radius:0!important;width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;margin:0!important;display:flex;flex-direction:column;overflow:hidden}.camera-fullscreen-modal .modal-header{position:absolute;top:0;left:0;right:0;z-index:10;background:linear-gradient(to bottom,#000c,#0000);padding:16px 20px;border:none;display:flex;justify-content:space-between;align-items:center;transition:opacity .3s ease}.camera-fullscreen-modal .modal-header h3{color:var(--text-primary);font-size:16px;font-weight:500;margin:0;text-shadow:0 1px 3px rgba(0,0,0,.5)}.camera-fullscreen-modal .modal-header .btn{background:#ffffff26;border:none;color:var(--text-primary);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;transition:background .2s ease}.camera-fullscreen-modal .modal-header .btn:hover{background:#ffffff40}.camera-fullscreen-modal .modal-body{flex:1;padding:0!important;margin:0;display:flex;align-items:center;justify-content:center;background:#000;overflow:hidden}.camera-fullscreen-view{width:100%;height:100vh;background:#000;display:flex;align-items:center;justify-content:center;position:relative}.camera-fullscreen-view video{width:100%;height:100%;object-fit:contain;background:#000}.camera-fullscreen-view .webrtc-player{width:100%;height:100%}.camera-fullscreen-view .webrtc-player video{width:100%;height:100%;object-fit:contain}.camera-fullscreen-view .camera-placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#666;text-align:center}body.modal-open{overflow:hidden}@supports (padding: max(0px)){.camera-fullscreen-modal .modal-header{padding-top:max(16px,env(safe-area-inset-top));padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right))}.camera-fullscreen-view{padding-bottom:env(safe-area-inset-bottom)}}@media(min-width:768px)and (min-height:600px){.camera-fullscreen-modal{width:95vw!important;height:90vh!important;max-width:1400px!important;border-radius:12px!important}.camera-fullscreen-view{height:calc(90vh - 60px);border-radius:0 0 12px 12px}.camera-fullscreen-modal .modal-header{position:relative;background:#000000f2;border-radius:12px 12px 0 0}}@media(max-height:500px)and (orientation:landscape){.camera-fullscreen-modal .modal-header{padding:8px 16px}.camera-fullscreen-modal .modal-header h3{font-size:14px}.camera-fullscreen-modal .modal-header .btn{width:32px;height:32px;font-size:20px}}@media(pointer:coarse){.camera-fullscreen-modal .modal-header .btn{width:44px;height:44px}}.intercom-modal-controls{position:absolute;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(to top,#000000e6,#0000);display:flex;justify-content:center;gap:16px;z-index:10}@supports (padding: max(0px)){.intercom-modal-controls{padding-bottom:max(20px,env(safe-area-inset-bottom))}}@media(orientation:landscape)and (max-height:500px){.camera-fullscreen-modal{width:100vw!important;height:100vh!important;max-width:100vw!important;max-height:100vh!important;border-radius:0!important}.camera-fullscreen-modal .modal-header{position:absolute;top:0;left:0;right:0;padding:8px 16px;background:linear-gradient(to bottom,rgba(0,0,0,.7) 0%,transparent 100%);opacity:0;transition:opacity .3s ease;z-index:20}.camera-fullscreen-modal:hover .modal-header,.camera-fullscreen-modal:active .modal-header,.camera-fullscreen-modal .modal-header:focus-within{opacity:1}.camera-fullscreen-modal.show-controls .modal-header{opacity:1}.camera-fullscreen-modal .modal-header h3{font-size:14px}.camera-fullscreen-modal .modal-header .btn{width:36px;height:36px}.camera-fullscreen-view{width:100vw!important;height:100vh!important;padding:0!important}.camera-fullscreen-view video{width:100vw!important;height:100vh!important;object-fit:contain}.camera-fullscreen-view .webrtc-player{width:100vw!important;height:100vh!important}.camera-fullscreen-view .webrtc-player video{width:100vw!important;height:100vh!important;object-fit:contain}.camera-fullscreen-modal .modal-body{padding:0!important;margin:0!important}@supports (padding: max(0px)){.camera-fullscreen-modal .modal-header{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.camera-fullscreen-view{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}}@media(pointer:coarse){.camera-fullscreen-modal .modal-header{opacity:1}.camera-fullscreen-modal.controls-hidden .modal-header{opacity:0;pointer-events:none}.camera-fullscreen-modal.controls-hidden:active .modal-header{opacity:1;pointer-events:auto}}@media(max-width:600px){.registration-form-row{grid-template-columns:1fr!important;gap:0!important}.registration-step-indicator{gap:.25rem!important;padding:1rem .5rem 0!important;flex-wrap:nowrap;overflow-x:auto}.registration-step-dot{width:32px!important;height:32px!important;font-size:.75rem!important;flex-shrink:0}.registration-step-line{width:1.5rem!important;margin-top:-16px!important}.registration-step-label{font-size:.625rem!important;max-width:60px;text-align:center;word-wrap:break-word}.registration-action-grid{grid-template-columns:1fr!important;gap:.75rem!important}.registration-action-card{padding:1rem!important}.registration-action-icon{width:40px!important;height:40px!important;margin-bottom:.75rem!important}.registration-action-title{font-size:1rem!important}.registration-action-desc{font-size:.8125rem!important}.registration-footer{flex-direction:column-reverse!important;gap:.75rem!important;padding:1rem!important}.registration-footer button{width:100%!important;justify-content:center!important;padding:.875rem 1rem!important;min-height:48px}.registration-card-content{padding:1rem!important}.registration-photo-buttons{flex-direction:column!important;gap:.5rem!important}.registration-photo-buttons button{width:100%!important;justify-content:center!important}.registration-form-section{margin-bottom:1.5rem!important}.registration-form-icon{width:48px!important;height:48px!important}.registration-form-title{font-size:1.25rem!important}.registration-summary-grid{grid-template-columns:1fr!important}.registration-header{margin-bottom:1rem!important;gap:.5rem!important}.registration-header h1{font-size:1.25rem!important}.registration-header-title svg{width:24px!important;height:24px!important}}@media(display-mode:standalone){.registration-container{padding-top:env(safe-area-inset-top,1rem);padding-bottom:env(safe-area-inset-bottom,1rem);min-height:100vh;min-height:-webkit-fill-available}}@media(pointer:coarse){.registration-form input,.registration-form select{min-height:48px;font-size:16px!important}.registration-form button{min-height:48px}.registration-checkbox-input{width:24px!important;height:24px!important}}@media(max-width:600px){.registration-container{padding:1rem!important;overflow-x:hidden}.registration-action-grid{grid-template-columns:1fr!important;min-width:0!important}.registration-action-card{min-width:0!important;width:100%!important;box-sizing:border-box!important}.registration-card-content{padding:1rem!important}}@media(max-width:600px){.main-content{overflow-x:hidden!important;max-width:100vw!important}.registration-container{padding:.75rem!important;width:100%!important;max-width:100%!important;overflow-x:hidden!important}.registration-container>div{width:100%!important;max-width:100%!important}.registration-action-grid{display:flex!important;flex-direction:column!important;gap:.75rem!important;width:100%!important}.registration-action-card{width:100%!important;min-width:0!important;max-width:100%!important}}.tenant-selector{position:relative;z-index:1000}.tenant-selector-button{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:13px;cursor:pointer;transition:all .2s;min-width:160px}.tenant-selector-button:hover{background:#ffffff26;border-color:#ffffff4d}.tenant-selector-button:disabled{opacity:.6;cursor:not-allowed}.tenant-selector-button .tenant-name{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tenant-selector-button .chevron{transition:transform .2s}.tenant-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;background:#1e293b;border:1px solid rgba(255,255,255,.15);border-radius:8px;box-shadow:0 10px 40px #0006;overflow:hidden}.tenant-dropdown-header{padding:10px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#64748b;border-bottom:1px solid rgba(255,255,255,.1)}.tenant-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:transparent;border:none;color:#e2e8f0;cursor:pointer;transition:background .15s}.tenant-option.active{background:#3b82f633}.tenant-option-info{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.tenant-option-name{font-size:13px;font-weight:500}.tenant-option-role{font-size:11px;color:#64748b;text-transform:capitalize}.tenant-dropdown-footer{padding:8px 12px;border-top:1px solid rgba(255,255,255,.1)}.platform-admin-badge{display:inline-block;padding:3px 8px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#000;border-radius:4px}.tenant-backdrop{position:fixed;inset:0;z-index:-1}.sidebar-tenant{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-tenant-single{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:12px;color:#94a3b8;border-bottom:1px solid rgba(255,255,255,.1)}.platform-admin{padding:24px;max-width:1400px;margin:0 auto}.platform-admin .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.platform-admin .page-title{display:flex;align-items:center;gap:12px}.platform-admin .page-title h1{margin:0;font-size:24px;font-weight:600}.admin-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:4px}.admin-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;background:transparent;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;border-radius:6px 6px 0 0;transition:all .2s}.admin-tab.active{color:#3b82f6;background:#3b82f61a}.admin-content{background:#ffffff08;border-radius:12px;padding:24px;border:1px solid rgba(255,255,255,.08)}.overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-surface);border-radius:10px;border:.5px solid var(--border);box-shadow:var(--shadow-sm)}.stat-card svg{color:var(--accent)}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary)}.stat-label{font-size:13px;color:var(--text-tertiary)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{margin:0;font-size:18px;font-weight:600}.org-list,.tenant-list{display:flex;flex-direction:column;gap:12px}.org-card,.tenant-card{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:8px;overflow:hidden}.org-header,.tenant-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;cursor:pointer;transition:background .15s}.org-header:hover,.tenant-header:hover{background:#ffffff08}.org-info,.tenant-info{display:flex;align-items:center;gap:12px}.org-info>div,.tenant-info>div{display:flex;flex-direction:column}.org-name,.tenant-name{font-weight:500;color:#e2e8f0}.org-meta,.tenant-meta{font-size:12px;color:var(--text-tertiary)}.org-actions,.tenant-actions{display:flex;align-items:center;gap:12px}.org-details,.tenant-details{padding:16px;background:#0003;border-top:1px solid rgba(255,255,255,.08)}.detail-row{display:flex;gap:8px;margin-bottom:8px;font-size:13px}.detail-label{color:var(--text-tertiary);min-width:80px}.detail-row code{background:#ffffff1a;padding:2px 6px;border-radius:4px;font-size:12px}.status-badge{padding:4px 10px;font-size:11px;font-weight:600;text-transform:uppercase;border-radius:4px}.status-badge.active{background:#22c55e33;color:#22c55e}.status-badge.suspended{background:#ef444433;color:#ef4444}.status-badge.sm{padding:2px 6px;font-size:10px}.status-dot.enabled{background:#22c55e}.status-dot.disabled{background:var(--text-tertiary)}.mini-tenant{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff08;border-radius:6px;margin-top:8px;font-size:13px}.org-tenants h4,.integrations-section h4{font-size:13px;font-weight:600;margin:16px 0 8px;color:var(--text-secondary)}.no-tenants,.no-integrations{font-size:13px;color:var(--text-tertiary);padding:8px 0}.integrations-section{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}.integrations-header{display:flex;justify-content:space-between;align-items:center}.integrations-header h4{display:flex;align-items:center;gap:6px;margin:0}.integration-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}.integration-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#ffffff08;border-radius:6px}.integration-info{display:flex;align-items:center;gap:10px}.integration-name{font-size:13px;font-weight:500}.integration-type{font-size:11px;color:var(--text-tertiary);text-transform:capitalize}.integration-actions{display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .15s}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:#ffffff1a;color:var(--text-primary)}.btn-secondary:hover{background:#ffffff26}.btn-danger{background:#ef444433;color:#ef4444}.btn-danger:hover{background:#ef44444d}.btn-xs{padding:4px 8px;font-size:12px}.btn-icon{padding:6px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:#ffffff1a;color:var(--text-primary)}.btn-icon.sm{padding:4px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#1e293b;border-radius:12px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;border:1px solid rgba(255,255,255,.1)}.modal.modal-lg{max-width:600px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h3{margin:0;font-size:18px}.modal form{padding:20px}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid rgba(255,255,255,.1);margin-top:16px}.modal-footer .footer-right{display:flex;gap:8px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:var(--text-secondary)}.form-group label small{font-weight:400;color:var(--text-tertiary)}.form-group input,.form-group select{width:100%;padding:10px 12px;background:#0000004d;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:var(--text-primary);font-size:14px}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px}.config-header{font-size:14px;font-weight:600;margin:16px 0 12px;color:var(--text-secondary)}.config-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}.config-fields .form-group{margin-bottom:0}.loading-state,.empty-state{padding:40px;text-align:center;color:var(--text-tertiary)}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;text-align:center;color:var(--text-tertiary)}.access-denied svg{margin-bottom:16px;color:#ef4444}.access-denied h2{margin:0 0 8px;color:var(--text-primary)}.spinning{animation:spin 1s linear infinite}.users-tab .tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.users-tab .tab-header h2{margin:0;color:var(--text-primary)}.users-list{display:flex;flex-direction:column;gap:.75rem}.user-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}.user-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;cursor:pointer;transition:background .2s}.user-header:hover{background:#ffffff05}.user-info{display:flex;align-items:center;gap:.75rem}.user-details{display:flex;flex-direction:column}.user-name{font-weight:600;color:var(--text-primary)}.user-email{font-size:.85rem;color:var(--text-secondary)}.user-badges{display:flex;gap:.5rem;flex-wrap:wrap}.badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.badge-admin{background:#8b5cf633;color:#a78bfa}.badge-inactive{background:#ef444433;color:#f87171}.badge-org{background:#3b82f633;color:#60a5fa}.badge-count{background:#6b728033;color:var(--text-secondary)}.user-expanded{padding:1rem;border-top:1px solid var(--border);background:#0003}.user-actions{display:flex;gap:.5rem;margin-bottom:1.5rem}.btn-warning{background:#f59e0b33;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.btn-warning:hover{background:#f59e0b4d}.btn-success{background:#10b98133;color:#34d399;border:1px solid rgba(16,185,129,.3)}.btn-success:hover{background:#10b9814d}.tenant-access-section h4{margin:0 0 1rem;color:var(--text-primary);font-size:.9rem}.tenant-access-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.tenant-access-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:#ffffff08;border-radius:6px}.tenant-access-item .tenant-name{flex:1;color:var(--text-primary)}.role-badge{padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.role-admin{background:#ef444433;color:#f87171}.role-operator{background:#3b82f633;color:#60a5fa}.role-viewer{background:#6b728033;color:var(--text-secondary)}.add-tenant-access{display:flex;gap:.5rem;align-items:center}.add-tenant-access select{padding:.5rem;background:var(--input-bg);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.9rem}.add-tenant-access select:first-child{flex:1;min-width:150px}.sidebar-tenant{padding:0 .75rem;margin-bottom:.5rem}.tenant-selector{position:relative;z-index:100}.tenant-selector-button{width:100%;display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:6px;color:#10b981;cursor:pointer;transition:all .2s;font-size:.85rem;font-weight:500}.tenant-selector-button:hover{background:#10b98133}.tenant-selector-button .tenant-name{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tenant-selector-button .chevron{transition:transform .2s;opacity:.7}.tenant-selector-button .chevron.open{transform:rotate(180deg)}.tenant-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;background:#1e2530;border:1px solid rgba(255,255,255,.15);border-radius:8px;box-shadow:0 10px 40px #00000080;z-index:9999;overflow:hidden}.tenant-dropdown-header{padding:.6rem .75rem;font-size:.7rem;font-weight:600;text-transform:uppercase;color:#6b7280;background:#0003;letter-spacing:.5px}.tenant-option{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.05);color:#e5e7eb;cursor:pointer;transition:background .15s;text-align:left}.tenant-option:last-of-type{border-bottom:none}.tenant-option:hover{background:#ffffff14}.tenant-option.active{background:#10b98126;color:#10b981}.tenant-option-info{display:flex;flex-direction:column;gap:1px}.tenant-option-name{font-size:.85rem;font-weight:500}.tenant-option-role{font-size:.7rem;color:#6b7280;text-transform:uppercase}.tenant-dropdown-footer{padding:.5rem .75rem;background:#0003;text-align:center}.platform-admin-badge{display:inline-block;padding:.2rem .5rem;background:#8b5cf633;border-radius:4px;font-size:.65rem;font-weight:600;text-transform:uppercase;color:#a78bfa;letter-spacing:.5px}.tenant-backdrop{position:fixed;inset:0;z-index:9998;background:transparent}.sidebar-tenant-single{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;margin:0 .75rem .5rem;background:#ffffff08;border-radius:6px;color:#9ca3af;font-size:.8rem}.platform-admin select,.modal select{appearance:none;width:100%;background:#151a23 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center;padding:.65rem 2.5rem .65rem .75rem;border:1px solid rgba(255,255,255,.12);border-radius:6px;color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:all .2s}.platform-admin select:hover,.modal select:hover{border-color:#ffffff40}.platform-admin select:focus,.modal select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-alpha-15)}.platform-admin select option,.modal select option{background:var(--bg-surface);color:var(--text-primary);padding:.5rem}.add-tenant-access select{appearance:none;background:#151a23 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;padding:.5rem 2rem .5rem .65rem;border:1px solid rgba(255,255,255,.12);border-radius:5px;color:var(--text-primary);font-size:.85rem;cursor:pointer}.add-tenant-access select:first-of-type{flex:1;min-width:140px}.add-tenant-access select:nth-of-type(2){width:100px}.sidebar-tenant{position:relative;z-index:1000}.tenant-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:200px;background:#232a38!important;border:1px solid rgba(255,255,255,.2);border-radius:8px;box-shadow:0 10px 40px #0009;z-index:10000!important;overflow:visible}.sidebar nav{position:relative;z-index:1}.add-tenant-access select,.users-tab select,.user-expanded select{appearance:none;background:var(--bg-surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center!important;padding:.6rem 2.2rem .6rem .75rem!important;border:1px solid rgba(255,255,255,.2)!important;border-radius:6px!important;color:var(--text-primary)!important;font-size:.85rem;cursor:pointer;min-width:140px;box-shadow:var(--shadow-sm)}.add-tenant-access select:hover,.users-tab select:hover,.user-expanded select:hover{background-color:var(--bg-page)!important;border-color:#ffffff4d!important}.add-tenant-access select:focus,.users-tab select:focus,.user-expanded select:focus{outline:none;border-color:#10b981!important;box-shadow:0 0 0 2px #10b98133}.add-tenant-access select option,.users-tab select option,.user-expanded select option{background:var(--bg-surface);color:var(--text-primary);padding:8px}.add-tenant-access select:nth-of-type(2){min-width:100px;width:auto}.sidebar-tenant,.tenant-selector{position:relative;z-index:9999!important}.tenant-dropdown{position:absolute;z-index:99999!important;background:#232a38!important}.tenant-backdrop{z-index:99998!important}.sidebar nav,.sidebar .nav-items,.sidebar a,.nav-link{position:relative;z-index:1!important}.sidebar-tenant:has(.tenant-dropdown)~nav{z-index:0!important}.tenant-select-dropdown-wrapper{display:flex;gap:.5rem;align-items:center}.tenant-select-dropdown,.role-select-dropdown{position:relative}.tenant-select-btn,.role-select-btn{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.55rem .75rem;background:var(--bg-surface);border:1px solid rgba(255,255,255,.15);border-radius:6px;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .2s;min-width:160px;box-shadow:var(--shadow-sm)}.role-select-btn{min-width:100px}.tenant-select-btn:hover,.role-select-btn:hover{background:var(--bg-page);border-color:#ffffff40}.tenant-select-btn svg,.role-select-btn svg{transition:transform .2s;opacity:.6}.tenant-select-btn svg.open{transform:rotate(180deg)}.tenant-select-menu,.role-select-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;min-width:100%;background:var(--bg-surface);border:1px solid rgba(255,255,255,.2);border-radius:6px;box-shadow:0 8px 24px #0006;z-index:9999;overflow:hidden;max-height:200px;overflow-y:auto}.role-select-menu{display:none}.role-select-menu.show{display:block}.tenant-select-option,.role-select-option{display:block;width:100%;padding:.6rem .75rem;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text-primary);font-size:.85rem;text-align:left;cursor:pointer;transition:background .15s}.tenant-select-option:last-child,.role-select-option:last-child{border-bottom:none}.tenant-select-option:hover,.role-select-option:hover{background:#ffffff1a}.tenant-select-option.active,.role-select-option.active{background:#10b98133;color:#10b981}.tenant-select-backdrop{position:fixed;inset:0;z-index:9998}.no-tenants-msg{color:var(--text-tertiary);font-size:.85rem;font-style:italic}.user-card{position:relative;overflow:visible!important}.user-expanded{position:relative;overflow:visible!important;z-index:10}.add-tenant-access,.tenant-select-dropdown-wrapper{position:relative;z-index:100}.tenant-select-dropdown{position:relative;z-index:1000}.tenant-select-menu{z-index:10000!important}.tenant-select-backdrop{z-index:9999!important}.users-list{overflow:visible!important}.user-card:has(.tenant-select-menu){z-index:1000!important}.role-select-dropdown{position:relative;z-index:1000}.role-select-menu{z-index:10000!important}.nav-section{margin-bottom:.25rem}.nav-section-header{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;color:var(--bg-sidebar-text);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:left}.nav-section-header:hover{background:#ffffff0d;color:var(--bg-sidebar-text-hover)}.nav-section-header svg:last-child{opacity:.5}.nav-section-items{padding-left:.5rem;border-left:2px solid rgba(255,255,255,.1);margin-left:1.5rem;margin-bottom:.5rem}.nav-link.nav-child{padding:.6rem 1rem;font-size:.85rem}.nav-link.nav-child svg{width:18px;height:18px}.nav-section:has(.nav-link.active) .nav-section-header{color:var(--accent)}.nav-section:has(.nav-link.active) .nav-section-items{border-left-color:var(--accent)}.users-tab .tab-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem}.user-filters{display:flex;gap:1rem;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.filter-group select{appearance:none;background:var(--bg-surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;padding:.5rem 2rem .5rem .75rem;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:var(--text-primary);font-size:.85rem;cursor:pointer;min-width:160px;box-shadow:var(--shadow-sm)}.filter-group select:hover{border-color:#ffffff40}.filter-group select:focus{outline:none;border-color:var(--accent)}.no-results{text-align:center;padding:2rem;color:var(--text-secondary);font-style:italic}.app-layout{display:flex;min-height:100vh;min-height:100dvh}.app-layout>.main-content{flex:1;margin-left:var(--sidebar-width);padding:24px;transition:margin-left var(--transition-base);min-height:100vh;background:var(--bg-page);max-width:calc(100vw - var(--sidebar-width));overflow-x:hidden}.app-layout>.main-content.collapsed{margin-left:var(--sidebar-collapsed);max-width:calc(100vw - var(--sidebar-collapsed))}@media(max-width:1024px){.app-layout{flex-direction:column}.main-content{margin-left:0!important;padding-top:16px;padding-bottom:calc(80px + env(safe-area-inset-bottom,0));min-height:calc(100vh - env(safe-area-inset-top,0));min-height:calc(100dvh - env(safe-area-inset-top,0))}}@media(display-mode:standalone){.app-layout{padding-top:env(safe-area-inset-top,0)}.main-content{padding-top:16px!important}.home-page{padding-top:0!important}}@media(max-width:1024px)and (display-mode:standalone){.main-content{padding-top:16px!important;padding-bottom:calc(80px + env(safe-area-inset-bottom,0))}}@media(max-width:1024px){html,body{overflow-x:hidden;overflow-y:auto;height:auto;min-height:100%}.app-layout{display:block!important;min-height:100vh;min-height:100dvh;padding-top:0!important}.main-content{display:block!important;margin:0!important;padding:16px 16px 100px!important;min-height:auto!important;height:auto!important;overflow:visible!important}.page-container,.home-page{padding-top:0!important;margin-top:0!important}.home-hero{padding-top:20px!important}}@media(max-width:1024px)and (display-mode:standalone){.app-layout{padding-top:env(safe-area-inset-top,20px)!important}.main-content{padding-bottom:calc(100px + env(safe-area-inset-bottom,0))!important}}@media(max-width:1024px){.sidebar{position:fixed!important;top:0!important;left:-100%!important;width:280px!important;height:100vh!important;height:100dvh!important;z-index:1000!important;transform:none!important}.sidebar.open{left:0!important}.sidebar-overlay{position:fixed!important;inset:0!important;background:#00000080!important;z-index:999!important;display:none}.sidebar.open+.sidebar-overlay,.sidebar.open~.sidebar-overlay{display:block!important}}.archive-new{position:fixed;inset:0;background:#000;display:flex;flex-direction:column;z-index:100;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif}.archive-camera-select{flex:1;display:flex;flex-direction:column;padding:24px;overflow-y:auto;background:linear-gradient(180deg,#0a0a0f,#12121a)}.camera-select-header{text-align:center;margin-bottom:32px;padding-top:40px}.camera-select-header h2{font-size:28px;font-weight:600;color:var(--text-primary);margin:0 0 8px;letter-spacing:-.5px}.camera-select-header p{font-size:15px;color:var(--text-tertiary);margin:0}.camera-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;max-width:800px;margin:0 auto;width:100%}.camera-select-item{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:12px}.camera-select-item:hover{background:#ffffff0f;border-color:#10b98166;transform:translateY(-2px)}.camera-select-thumbnail{width:100%;aspect-ratio:16/9;background:#1a1a24;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center}.camera-select-thumbnail img{width:100%;height:100%;object-fit:cover}.camera-select-name{font-size:13px;font-weight:500;color:var(--text-primary);text-align:center;line-height:1.3}.camera-select-empty{grid-column:1 / -1;text-align:center;padding:60px 20px;color:var(--text-tertiary)}.archive-video-container{flex:1;display:flex;flex-direction:column;position:relative;min-height:0}.archive-top-bar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;padding:12px 16px;background:linear-gradient(180deg,rgba(0,0,0,.7) 0%,transparent 100%);z-index:10;gap:12px}.archive-live-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#ef444433;border:1px solid rgba(239,68,68,.4);border-radius:20px;color:#ef4444;font-size:12px;font-weight:600;letter-spacing:.5px;cursor:pointer;transition:all .2s}.live-dot{width:8px;height:8px;background:#ef4444;border-radius:50%;animation:pulse-live 2s infinite}.archive-thumbnail{max-width:100%;max-height:100%;object-fit:contain;opacity:.8}.archive-video-loading{display:flex;flex-direction:column;align-items:center;gap:16px;color:#6b7280}.archive-video-loading .spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.1);border-top-color:#10b981;border-radius:50%;animation:spin 1s linear infinite}.archive-video-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}.archive-video-error{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#ef4444e6;color:#fff;padding:8px 16px;border-radius:8px;font-size:13px}.archive-recording-indicator{position:absolute;top:16px;right:16px;z-index:5}.rec-dot{display:block;width:12px;height:12px;background:#ef4444;border-radius:50%;box-shadow:0 0 12px #ef444499;animation:pulse-rec 1.5s infinite}@keyframes pulse-rec{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.archive-controls-overlay{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:8px;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:28px;z-index:10}.archive-timeline-section{background:#0d0d14;padding:16px 0;border-top:1px solid rgba(255,255,255,.05)}.archive-time-display{display:flex;align-items:center;justify-content:center;gap:8px;padding:0 16px 16px}.date-nav-btn{width:32px;height:32px;border-radius:8px;background:#ffffff14;border:.5px solid rgba(255,255,255,.12);color:#ffffffb3;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.date-nav-btn:hover:not(:disabled){background:#ffffff1a;color:var(--text-primary)}.current-date-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff1a;border:.5px solid rgba(255,255,255,.15);color:#fff;border-radius:8px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.current-date-btn:hover{background:#ffffff1a}.current-date-btn svg{color:var(--text-tertiary)}.current-time{font-size:24px;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.5px;margin:0 16px;min-width:100px;text-align:center}.timeline-zoom{display:flex;gap:4px;margin-left:auto}.zoom-btn{padding:6px 10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-tertiary);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.zoom-btn.active{background:#10b98126;border-color:#10b9814d;color:#10b981}.date-picker-dropdown{position:absolute;top:60px;left:50%;transform:translate(-50%);background:#1a1a24;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px;z-index:20;box-shadow:0 8px 32px #0006}.date-picker-dropdown input{background:#0d0d14;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px 14px;color:#fff;font-size:14px;color-scheme:dark}.archive-timeline{position:relative;height:100px;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:pan-x}.timeline-markers{position:absolute;top:0;left:50%;height:30px;display:flex;align-items:flex-end}.marker-label{font-size:11px;color:#fff9;font-weight:500;font-variant-numeric:tabular-nums;margin-bottom:4px}.timeline-marker.hour .marker-tick{height:12px;background:#ffffff40}.timeline-activity{position:absolute;top:40px;left:50%;height:50px;display:flex;align-items:flex-end}.activity-bar{position:absolute;width:3px;min-height:4px;border-radius:2px;transform-origin:center bottom}.activity-bar.motion{background:linear-gradient(180deg,#06b6d4,#0891b2)}.activity-bar.person{background:linear-gradient(180deg,#a855f7,#7c3aed)}.activity-bar.vehicle{background:linear-gradient(180deg,#f472b6,#ec4899)}.playhead-arrow{width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid #fff}.playhead-line{width:2px;height:70px;background:linear-gradient(180deg,#fff,#ffffff4d)}.timeline-no-recordings{text-align:center;color:var(--text-tertiary);font-size:13px;padding:8px;margin-top:-8px}@media(max-width:768px){.archive-top-bar{padding:8px 12px}.archive-back-btn{width:36px;height:36px}.archive-camera-name{font-size:14px}.archive-live-btn{padding:6px 10px;font-size:11px}.archive-controls-overlay{bottom:12px;padding:6px}.archive-control-btn{width:40px;height:40px}.archive-time-display{flex-wrap:wrap;gap:8px}.current-time{font-size:20px;margin:0 8px 8px;order:-1;width:100%}.timeline-zoom{margin-left:0}.camera-select-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.camera-select-header{padding-top:20px}.camera-select-header h2{font-size:22px}}@supports (padding-bottom: env(safe-area-inset-bottom)){.archive-timeline-section{padding-bottom:calc(16px + env(safe-area-inset-bottom))}}@media(min-width:769px){.archive-new{left:var(--sidebar-width, 260px)}}.archive-live-btn.active .status-dot.live{background:#ef4444;animation:pulse 1.5s infinite}.status-dot{width:8px;height:8px;border-radius:50%;margin-right:6px}.status-dot.live{background:#ef4444}.current-time-btn{background:#ffffff1a;border:none;color:var(--text-primary);padding:.5rem 1rem;border-radius:6px;font-size:1.25rem;font-family:monospace;cursor:pointer;transition:background .2s}.current-time-btn:hover{background:#fff3}.date-picker-inline,.time-picker-inline{position:absolute;top:100%;left:50%;transform:translate(-50%);background:#1a1a2e;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:.5rem;z-index:100;margin-top:.5rem}.date-picker-inline input,.time-picker-inline input{background:#0a0a0f;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem;border-radius:4px;font-size:1rem}.date-picker-inline input::-webkit-calendar-picker-indicator,.time-picker-inline input::-webkit-calendar-picker-indicator{filter:invert(1)}.archive-time-display{position:relative}.timeline-activity{position:relative;height:60px;display:flex;align-items:flex-end;justify-content:center}.activity-bar{position:absolute;width:3px;min-height:10px;border-radius:2px;bottom:0;opacity:.9}.activity-bar.motion{background:linear-gradient(to top,#06b6d4,#22d3ee)}.activity-bar.person{background:linear-gradient(to top,#8b5cf6,#a78bfa)}.activity-bar.vehicle{background:linear-gradient(to top,#ec4899,#f472b6)}.timeline-filters{display:flex;gap:.5rem;margin-left:1rem}.filter-btn{display:flex;align-items:center;gap:4px;padding:.35rem .6rem;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:#ffffff0d;color:var(--text-secondary);font-size:.7rem;cursor:pointer;transition:all .2s}.filter-btn.active{color:var(--text-primary);border-color:var(--text-secondary)}.filter-btn .filter-dot{width:8px;height:8px;border-radius:50%;opacity:.5}.filter-btn.active .filter-dot{opacity:1}.filter-btn.recordings .filter-dot{background:#06b6d4}.filter-btn.motion .filter-dot{background:#8b5cf6}.filter-btn.analytics .filter-dot{background:#ec4899}.filter-btn.recordings.active{border-color:#06b6d4}.filter-btn.motion.active{border-color:#8b5cf6}.filter-btn.analytics.active{border-color:#ec4899}.timeline-activity{position:relative;height:60px;display:flex;align-items:flex-end}.activity-bar.recordings{background:linear-gradient(to top,#06b6d4,#22d3ee);height:100%!important;opacity:.6;z-index:1}.activity-bar.motion{background:linear-gradient(to top,#8b5cf6,#a78bfa);height:70%!important;opacity:.8;z-index:2}.activity-bar.analytics{background:linear-gradient(to top,#ec4899,#f472b6);height:50%!important;opacity:.9;z-index:3}.archive-timeline-section{padding:1rem;background:linear-gradient(to top,#0a0a0f,#12121a)}.archive-time-display{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;position:relative;margin-bottom:1rem}.current-date-btn,.current-time-btn{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;border:.5px solid rgba(255,255,255,.15);color:#fff;padding:.5rem .75rem;border-radius:6px;font-size:1rem;font-family:inherit;cursor:pointer;transition:background .2s}.picker-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--bg-surface);border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:.75rem;z-index:1000;margin-bottom:.5rem;display:flex;gap:.5rem;align-items:center;box-shadow:0 -4px 20px #00000080}.date-picker-popup{left:80px}.time-picker-popup{left:200px}.picker-popup input{background:#0a0a0f;border:1px solid rgba(255,255,255,.3);color:var(--text-primary);padding:.5rem .75rem;border-radius:4px;font-size:1rem;font-family:inherit}.picker-popup input::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.picker-go-btn{background:#06b6d4;border:none;color:var(--text-primary);padding:.5rem 1rem;border-radius:4px;font-size:.9rem;cursor:pointer;font-weight:500}.picker-go-btn:hover{background:#0891b2}.archive-timeline{position:relative;width:100%;height:100px;background:#0000004d;border-radius:8px;overflow:hidden;cursor:grab;touch-action:pan-x}.timeline-markers{position:absolute;top:0;left:50%;height:30px;display:flex;align-items:flex-start}.timeline-marker .marker-label{font-size:.7rem;color:var(--text-secondary);white-space:nowrap}.timeline-marker.hour .marker-label{color:var(--text-primary);font-weight:500}.timeline-marker .marker-tick{width:1px;height:8px;background:#ffffff4d;margin-top:2px}.timeline-marker.hour .marker-tick{height:12px;background:#fff9}.timeline-activity{position:absolute;bottom:20px;left:50%;right:0;height:50px;display:flex;align-items:flex-end}.activity-bar{position:absolute;bottom:0;border-radius:2px;min-width:2px}.playhead-line{width:2px;height:100%;background:#fff;box-shadow:0 0 10px #ffffff80}.playhead-arrow{position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:10px solid white}.timeline-no-recordings{text-align:center;color:var(--text-secondary);padding:.5rem;font-size:.9rem}.calendar-picker{position:absolute;bottom:100%;left:0;background:#1a1a2e;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:1rem;z-index:1000;margin-bottom:.5rem;box-shadow:0 -8px 30px #0009;min-width:280px}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.cal-month-label{font-weight:600;color:#fff;font-size:1rem}.cal-nav-btn{background:#ffffff1a;border:none;color:#fff;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center}.cal-nav-btn:hover:not(:disabled){background:#fff3}.cal-nav-btn:disabled{opacity:.3;cursor:not-allowed}.calendar-days-header{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.5rem}.cal-day-name{text-align:center;font-size:.75rem;color:#ffffff80;padding:.25rem;font-weight:500}.calendar-body{display:flex;flex-direction:column;gap:2px}.cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-day{text-align:center;padding:.5rem;border-radius:6px;cursor:pointer;font-size:.9rem;color:#fff;transition:all .15s}.cal-day:hover:not(.disabled):not(.selected){background:#ffffff1a}.cal-day.other-month{color:#ffffff4d}.cal-day.today{border:1px solid #06b6d4}.cal-day.selected{background:#06b6d4;color:#fff;font-weight:600}.cal-day.disabled{opacity:.3;cursor:not-allowed}.calendar-footer{margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1);display:flex;gap:.5rem}.cal-today-btn{flex:1;background:#06b6d433;border:1px solid #06b6d4;color:#06b6d4;padding:.5rem;border-radius:6px;cursor:pointer;font-weight:500}.cal-today-btn:hover{background:#06b6d44d}.time-picker{position:absolute;bottom:100%;left:0;background:#1a1a2e;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:1rem;z-index:1000;margin-bottom:.5rem;box-shadow:0 -8px 30px #0009}.time-picker-columns{display:flex;align-items:center;justify-content:center;gap:.25rem}.time-column{display:flex;flex-direction:column;align-items:center;gap:.25rem}.time-column-label{font-size:.7rem;color:#ffffff80;text-transform:uppercase}.time-scroll-btn{background:#ffffff1a;border:none;color:#fff;width:40px;height:28px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.time-scroll-btn:hover{background:#fff3}.time-value{font-size:1.5rem;font-weight:600;color:#fff;font-family:monospace;width:40px;text-align:center;padding:.5rem 0;background:#0000004d;border-radius:6px}.time-separator{font-size:1.5rem;color:#ffffff80;padding:0 .25rem;align-self:center;margin-top:1rem}.time-picker-footer{margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1);display:flex;gap:.5rem}.time-now-btn{flex:1;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem;border-radius:6px;cursor:pointer}.time-now-btn:hover{background:#fff3}.time-confirm-btn{flex:1;background:#06b6d4;border:none;color:var(--text-primary);padding:.5rem;border-radius:6px;cursor:pointer;font-weight:500}.time-confirm-btn:hover{background:#0891b2}.quick-jump-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.quick-jump-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.2);color:var(--text-primary);padding:.35rem .75rem;border-radius:4px;font-size:.75rem;cursor:pointer;transition:all .15s;white-space:nowrap}.quick-jump-btn:hover{background:#ffffff1a;border-color:var(--text-secondary)}.motion-filmstrip{display:flex;gap:.5rem;padding:.75rem;background:#0000004d;border-radius:8px;overflow-x:auto;margin-bottom:1rem}.motion-filmstrip::-webkit-scrollbar{height:6px}.motion-filmstrip::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.motion-filmstrip::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.motion-thumb{flex-shrink:0;width:120px;height:70px;border-radius:6px;overflow:hidden;cursor:pointer;position:relative;border:2px solid transparent;transition:all .15s}.motion-thumb:hover{border-color:#06b6d4;transform:scale(1.05)}.motion-thumb.active{border-color:#06b6d4}.motion-thumb img{width:100%;height:100%;object-fit:cover}.motion-thumb-time{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);color:var(--text-primary);font-size:.65rem;padding:.5rem .25rem .25rem;text-align:center}.motion-thumb-type{position:absolute;top:4px;right:4px;padding:2px 6px;border-radius:3px;font-size:.6rem;font-weight:600;text-transform:uppercase}.motion-thumb-type.motion{background:#8b5cf6;color:var(--text-primary)}.motion-thumb-type.analytics{background:#ec4899;color:var(--text-primary)}.archive-thumbnail-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#000}.archive-thumbnail-img{width:100%;height:100%;object-fit:contain}.archive-thumbnail-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0006;gap:1rem}.archive-play-big-btn{width:80px;height:80px;border-radius:50%;background:#06b6d4e6;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 4px 20px #0006}.archive-play-big-btn:hover{background:#06b6d4;transform:scale(1.1)}.archive-play-big-btn svg{margin-left:4px}.archive-thumbnail-label{color:#fff;font-size:1rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.archive-new{display:flex;flex-direction:column;height:100vh;background:#0a0a0f;overflow:hidden}.archive-player-view{flex:1;display:flex;flex-direction:column;min-height:0}.archive-header{display:flex;align-items:center;padding:.75rem 1rem;background:#12121a;border-bottom:1px solid rgba(255,255,255,.1);gap:1rem}.archive-back-btn{background:none;border:none;color:#fff;cursor:pointer;padding:.5rem;border-radius:8px;display:flex;align-items:center;justify-content:center}.archive-back-btn:hover{background:#ffffff1a}.archive-camera-name{flex:1;font-size:1.1rem;font-weight:500;color:#fff}.archive-live-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;border:none;background:#ffffff1a;color:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.archive-live-btn.active{background:#ef444433;border:1px solid #ef4444}.status-dot.live{background:#ef4444;animation:pulse 1.5s infinite}.archive-video-wrapper{flex:1;position:relative;background:#000;display:flex;align-items:center;justify-content:center;min-height:0}.archive-controls-overlay{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);display:flex;gap:.5rem;z-index:10}.archive-control-btn{width:48px;height:48px;border-radius:50%;background:#0009;border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.archive-control-btn:hover{background:#000c;border-color:#fff6}.archive-timeline-section{background:linear-gradient(to top,#0a0a0f,#12121a);padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.archive-time-display{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem;position:relative}.date-nav-btn{background:#ffffff1a;border:none;color:var(--text-primary);width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center}.date-nav-btn:hover:not(:disabled){background:#fff3}.current-date-btn,.current-time-btn{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;border:.5px solid rgba(255,255,255,.15);color:#fff;padding:.4rem .75rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background .2s}.current-date-btn:hover,.current-time-btn:hover{background:#fff3}.current-time-btn{font-family:monospace;font-size:1rem}.timeline-zoom{display:flex;gap:2px;margin-left:auto}.zoom-btn{padding:.35rem .6rem;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:var(--text-primary);font-size:.75rem;cursor:pointer;transition:all .15s}.zoom-btn:first-child{border-radius:4px 0 0 4px}.zoom-btn:last-child{border-radius:0 4px 4px 0}.zoom-btn.active{background:#06b6d4;border-color:#06b6d4;color:var(--text-primary)}.zoom-btn:hover:not(.active){background:#ffffff1a}.quick-jump-buttons{display:flex;gap:.25rem;margin-left:.5rem}.quick-jump-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.15);color:var(--text-primary);padding:.35rem .5rem;border-radius:4px;font-size:.7rem;cursor:pointer;white-space:nowrap}.quick-jump-btn:hover{background:#ffffff1a;color:var(--text-primary)}.archive-timeline{position:relative;height:80px;background:#0006;border-radius:8px;overflow:hidden;cursor:grab;touch-action:pan-x}.timeline-markers{position:absolute;top:0;left:50%;height:25px}.timeline-marker{position:absolute;display:flex;flex-direction:column;align-items:center;transform:translate(-50%)}.timeline-marker .marker-label{font-size:.65rem;color:var(--text-secondary);white-space:nowrap}.timeline-marker.hour .marker-label,.timeline-marker.major .marker-label{color:var(--text-primary)}.timeline-marker .marker-tick{width:1px;height:6px;background:#fff3;margin-top:2px}.timeline-marker.hour .marker-tick{height:10px;background:#ffffff80}.timeline-activity{position:absolute;inset:30px 0 20px 50%}.activity-bar{position:absolute;bottom:0;border-radius:2px}.activity-bar.recordings{background:linear-gradient(to top,#06b6d4,#22d3ee);height:100%;opacity:.5}.activity-bar.motion{background:linear-gradient(to top,#8b5cf6,#a78bfa);height:70%;opacity:.7}.activity-bar.analytics{background:linear-gradient(to top,#ec4899,#f472b6);height:50%;opacity:.8}.timeline-playhead{position:absolute;left:50%;top:0;bottom:0;transform:translate(-50%);z-index:10;pointer-events:none}.playhead-line{width:2px;height:100%;background:#fff;box-shadow:0 0 8px #ffffff80}.playhead-arrow{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:8px solid white}.archive-camera-select{padding:1rem;height:100%;overflow-y:auto}.camera-select-header{margin-bottom:1rem}.camera-select-header h2{color:var(--text-primary);font-size:1.25rem;margin:0}.camera-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.camera-card{background:#1a1a2e;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;border:2px solid transparent}.camera-card:hover{border-color:#06b6d4;transform:translateY(-2px)}.camera-thumbnail{aspect-ratio:16/9;background:#0a0a0f;overflow:hidden}.camera-name{display:block;padding:.75rem;color:#fff;font-size:.9rem;text-align:center;background:#0000004d}.timeline-no-recordings{text-align:center;color:var(--text-secondary);font-size:.85rem;margin-top:.5rem}.camera-select-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.camera-select-header h2{margin:0;color:var(--text-primary);font-size:1.25rem}.camera-search-wrapper{position:relative;flex:1;max-width:300px}.camera-search-input{width:100%;padding:.6rem 2.5rem .6rem 1rem;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff0d;color:var(--text-primary);font-size:.9rem;outline:none;transition:all .2s}.camera-search-input::placeholder{color:var(--text-secondary)}.camera-search-input:focus{border-color:#06b6d4;background:#ffffff1a}.camera-search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:4px}.camera-search-clear:hover{color:var(--text-primary);background:#ffffff1a}.camera-count{color:var(--text-secondary);font-size:.85rem;white-space:nowrap}.camera-card{background:#1a1a2e;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;border:2px solid transparent;display:flex;flex-direction:column}.camera-card:hover{border-color:#06b6d4;transform:translateY(-2px);box-shadow:0 4px 20px #06b6d433}.camera-thumbnail{aspect-ratio:16/9;background:#0a0a0f;overflow:hidden;position:relative}.camera-name{display:block;padding:.6rem .75rem;color:#fff;font-size:.85rem;background:#00000080;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}.lazy-thumbnail{width:100%;height:100%;position:relative;background:#0a0a0f}.lazy-thumbnail img{width:100%;height:100%;object-fit:cover;transition:opacity .3s}.thumbnail-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0a0a0f}.thumbnail-spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.1);border-top-color:#06b6d4;border-radius:50%;animation:spin 1s linear infinite}.thumbnail-error{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#1a1a2e;color:#fff6;font-size:.75rem}.layout-select{padding:.6rem 1rem;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff0d;color:var(--text-primary);font-size:.9rem;cursor:pointer;outline:none;min-width:150px}.layout-select:focus{border-color:#06b6d4}.layout-select option{background:var(--bg-surface);color:var(--text-primary)}.sidebar-collapse-btn{display:none;width:100%;padding:.5rem;background:#ffffff0d;border:none;border-top:1px solid rgba(255,255,255,.1);color:#fff9;cursor:pointer;transition:all .2s}.sidebar-collapse-btn:hover{background:#ffffff1a;color:#fff}@media(min-width:769px){.sidebar-collapse-btn{display:flex;align-items:center;justify-content:center}.sidebar{transition:width .3s ease,min-width .3s ease}.sidebar.collapsed{width:60px;min-width:60px}.sidebar.collapsed .sidebar-header{padding:.75rem .5rem}.sidebar.collapsed .sidebar-logo,.sidebar.collapsed .sidebar-logo-placeholder{width:32px;height:32px}.sidebar.collapsed .sidebar-tenant,.sidebar.collapsed .sidebar-tenant-single,.sidebar.collapsed .nav-link span,.sidebar.collapsed .nav-section-header span,.sidebar.collapsed .nav-section-header svg:last-child,.sidebar.collapsed .user-name,.sidebar.collapsed .user-role,.sidebar.collapsed .nav-section-items{display:none}.sidebar.collapsed .nav-link{justify-content:center;padding:.75rem}.sidebar.collapsed .nav-link svg{margin-right:0}.sidebar.collapsed .nav-section-header{justify-content:center;padding:.75rem}.sidebar.collapsed .sidebar-footer{padding:.5rem}.sidebar.collapsed .user-info{display:none}.sidebar.collapsed .logout-btn{width:100%;justify-content:center;padding:.75rem}.sidebar.collapsed .logout-btn span{display:none}}.sidebar{position:relative}.sidebar-collapse-btn{position:absolute;right:-12px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;background:#1a1a2e;border:1px solid rgba(255,255,255,.2);color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:100;transition:all .2s;padding:0}.sidebar-collapse-btn:hover{background:#06b6d4;border-color:#06b6d4;color:#fff}.sidebar.collapsed .sidebar-collapse-btn{right:-12px}@media(max-width:768px){.sidebar-collapse-btn{display:none}}.quality-btn{font-size:.7rem;font-weight:700;min-width:48px}.quality-btn.hd{background:#06b6d4cc;border-color:#06b6d4}.archive-new{padding-top:env(safe-area-inset-top)}.archive-header{padding-top:calc(.75rem + env(safe-area-inset-top));min-height:calc(56px + env(safe-area-inset-top))}.archive-camera-select{padding-top:calc(1rem + env(safe-area-inset-top));padding-bottom:calc(1rem + env(safe-area-inset-bottom))}.camera-select-header{padding-top:env(safe-area-inset-top)}.archive-timeline-section{padding-bottom:calc(1rem + env(safe-area-inset-bottom))}@media(orientation:landscape)and (max-height:500px){.archive-new{padding-top:0}.archive-player-view{position:fixed;inset:0;z-index:1000;background:#000}.archive-header{position:absolute;top:0;left:0;right:0;background:linear-gradient(to bottom,rgba(0,0,0,.7),transparent);padding:.5rem 1rem;padding-left:calc(1rem + env(safe-area-inset-left));padding-right:calc(1rem + env(safe-area-inset-right));min-height:auto;z-index:10}.archive-video-wrapper{position:absolute;inset:0}.archive-controls-overlay{bottom:auto;top:50%;transform:translate(-50%,-50%);transition:opacity .3s}.archive-controls-overlay.visible{opacity:1;pointer-events:auto}.archive-controls-overlay.hidden{opacity:0;pointer-events:none}.archive-timeline-section{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);padding:.5rem;padding-left:calc(.5rem + env(safe-area-inset-left));padding-right:calc(.5rem + env(safe-area-inset-right));padding-bottom:calc(.5rem + env(safe-area-inset-bottom));transition:opacity .3s}.archive-timeline-section.visible{opacity:1;pointer-events:auto}.archive-timeline-section.hidden{opacity:0;pointer-events:none}.archive-time-display{gap:.25rem;margin-bottom:.5rem}.quick-jump-buttons,.timeline-filters{display:none}.archive-timeline{height:50px}}@media(max-width:768px)and (orientation:portrait){.archive-header{padding-top:calc(1rem + env(safe-area-inset-top))}.archive-time-display{flex-wrap:wrap;justify-content:center}.quick-jump-buttons{width:100%;justify-content:center;margin-top:.5rem;margin-left:0}.timeline-filters{width:100%;justify-content:center;margin-top:.5rem}}.calendar-picker,.time-picker{position:absolute;bottom:100%;left:0;background:#1a1a2e;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:1rem;z-index:100;box-shadow:0 -4px 20px #00000080;min-width:280px}.calendar-picker{width:300px}.time-picker{width:280px}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.calendar-header button{background:#ffffff1a;border:none;color:#fff;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center}.calendar-header button:hover{background:#fff3}.calendar-month{font-size:1rem;font-weight:600;color:var(--text-primary)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.5rem}.calendar-weekday{text-align:center;font-size:.75rem;color:var(--text-secondary);padding:.25rem}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.875rem;color:var(--text-primary);background:#ffffff0d;border:none;border-radius:6px;cursor:pointer;transition:all .15s}.calendar-day:hover:not(:disabled){background:#06b6d44d}.calendar-day.today{border:1px solid #06b6d4}.calendar-day.selected{background:#06b6d4;color:var(--text-primary)}.calendar-day:disabled{opacity:.3;cursor:not-allowed}.calendar-day.other-month{opacity:.3}.time-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.time-picker-title{font-size:1rem;font-weight:600;color:#fff}.time-picker-now{background:#06b6d4;border:none;color:#fff;padding:.4rem .75rem;border-radius:6px;font-size:.8rem;cursor:pointer}.time-picker-columns{display:flex;gap:.5rem;justify-content:center}.time-picker-column{display:flex;flex-direction:column;align-items:center}.time-picker-label{font-size:.7rem;color:#ffffff80;margin-bottom:.25rem;text-transform:uppercase}.time-picker-scroll{height:150px;overflow-y:auto;width:60px;background:#0000004d;border-radius:8px;-webkit-overflow-scrolling:touch}.time-picker-option{padding:.5rem;text-align:center;font-size:1rem;color:#fff9;cursor:pointer;transition:all .15s}.time-picker-option:hover{background:#ffffff1a;color:#fff}.time-picker-option.selected{background:#06b6d4;color:#fff}.picker-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem}.picker-close:hover{color:var(--text-primary)}.timeline-zoom-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;color:var(--text-primary);padding:.5rem 1rem;border-radius:8px;font-size:.8rem;pointer-events:none;opacity:0;transition:opacity .3s}.archive-timeline.pinching .timeline-zoom-hint{opacity:1}.archive-controls-overlay{transition:opacity .3s ease}.archive-controls-overlay.visible{opacity:1;pointer-events:auto}.archive-timeline-section{transition:opacity .3s ease,transform .3s ease}.archive-timeline-section.hidden{opacity:0;pointer-events:none;transform:translateY(20px)}.archive-timeline-section.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.archive-header{transition:opacity .3s ease}@media(max-width:768px){.archive-controls-overlay.hidden,.archive-timeline-section.hidden{opacity:0}}.archive-timeline{touch-action:none}@media(orientation:landscape)and (max-height:500px){.archive-controls-overlay.visible{opacity:1;pointer-events:auto}.archive-controls-overlay.hidden{opacity:0;pointer-events:none}.archive-timeline-section.visible{opacity:1;pointer-events:auto}.archive-timeline-section.hidden{opacity:0;pointer-events:none}}.archive-timeline{touch-action:none;user-select:none;-webkit-user-select:none}@media(orientation:landscape)and (max-width:1024px){.archive-new{position:fixed;inset:0;padding:0;overflow:hidden}.archive-player-view{position:fixed;inset:0;display:flex;flex-direction:column}.archive-header{position:absolute;top:0;left:0;right:0;z-index:20;background:linear-gradient(to bottom,rgba(0,0,0,.8) 0%,transparent 100%);padding:.5rem 1rem;padding-left:calc(1rem + env(safe-area-inset-left));padding-right:calc(1rem + env(safe-area-inset-right));padding-top:calc(.5rem + env(safe-area-inset-top));min-height:auto;border:none;transition:opacity .3s}.archive-header.hidden{opacity:0;pointer-events:none}.archive-header.visible{opacity:1;pointer-events:auto}.archive-video-wrapper{position:absolute;inset:0;z-index:1}.archive-video-wrapper video{width:100%;height:100%;object-fit:contain}.archive-thumbnail-container{position:absolute;inset:0}.archive-thumbnail-img{width:100%;height:100%;object-fit:contain}.archive-controls-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:15;bottom:auto;flex-direction:row;gap:1rem;transition:opacity .3s}.archive-controls-overlay.hidden{opacity:0;pointer-events:none}.archive-controls-overlay.visible{opacity:1;pointer-events:auto}.archive-timeline-section{position:absolute;bottom:0;left:0;right:0;z-index:20;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.7) 70%,transparent 100%);padding:.75rem;padding-left:calc(.75rem + env(safe-area-inset-left));padding-right:calc(.75rem + env(safe-area-inset-right));padding-bottom:calc(.5rem + env(safe-area-inset-bottom));border:none;transition:opacity .3s,transform .3s}.archive-timeline-section.hidden{opacity:0;pointer-events:none;transform:translateY(100%)}.archive-timeline-section.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.archive-time-display{flex-wrap:nowrap;justify-content:center;gap:.5rem;margin-bottom:.5rem}.date-nav-btn{width:28px;height:28px}.current-date-btn,.current-time-btn{padding:.3rem .5rem;font-size:.8rem}.quick-jump-buttons{display:none}.timeline-filters{position:absolute;right:calc(.75rem + env(safe-area-inset-right));top:.5rem}.filter-btn{padding:.2rem .4rem;font-size:.65rem}.archive-timeline{height:50px}.timeline-markers{height:20px}.timeline-marker .marker-label{font-size:.55rem}.archive-play-big-btn{width:60px;height:60px}.archive-play-big-btn svg{width:32px;height:32px}.archive-thumbnail-label{font-size:.85rem}}@media(orientation:landscape)and (max-width:1024px){.archive-camera-select{padding:.5rem;padding-left:calc(.5rem + env(safe-area-inset-left));padding-right:calc(.5rem + env(safe-area-inset-right));padding-top:calc(.5rem + env(safe-area-inset-top));padding-bottom:calc(.5rem + env(safe-area-inset-bottom))}.camera-select-header{padding-top:0;margin-bottom:.5rem;flex-wrap:nowrap}.camera-select-header h2{font-size:1rem}.camera-search-input{padding:.4rem .75rem;font-size:.85rem}.camera-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem}.camera-name{padding:.4rem;font-size:.75rem}}@media(orientation:landscape)and (max-height:600px){.archive-new{position:fixed;inset:0;padding:0;overflow:hidden}.archive-player-view{position:fixed;inset:0}.archive-header{position:absolute;top:0;left:0;right:0;z-index:50;background:linear-gradient(to bottom,rgba(0,0,0,.8) 0%,transparent 100%);padding:.5rem 1rem;padding-left:calc(1rem + env(safe-area-inset-left));padding-right:calc(1rem + env(safe-area-inset-right));padding-top:calc(.5rem + env(safe-area-inset-top));min-height:auto;border:none}.archive-header.visible{opacity:1!important;pointer-events:auto!important}.archive-header.hidden{opacity:0!important;pointer-events:none!important}.archive-video-wrapper{position:absolute;inset:0;z-index:1}.archive-controls-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:40;bottom:auto;flex-direction:row;gap:1rem}.archive-controls-overlay.visible{opacity:1!important;pointer-events:auto!important}.archive-controls-overlay.hidden{opacity:0!important;pointer-events:none!important}.archive-timeline-section{position:absolute;bottom:0;left:0;right:0;z-index:50;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.7) 50%,transparent 100%);padding:.5rem;padding-left:calc(.5rem + env(safe-area-inset-left));padding-right:calc(.5rem + env(safe-area-inset-right));padding-bottom:calc(.5rem + env(safe-area-inset-bottom))}.archive-timeline-section.visible{opacity:1!important;pointer-events:auto!important;transform:translateY(0)!important}.archive-timeline-section.hidden{opacity:0!important;pointer-events:none!important;transform:translateY(100%)!important}.archive-time-display{flex-wrap:nowrap;gap:.25rem;margin-bottom:.5rem;justify-content:center}.quick-jump-buttons{display:none}.archive-timeline{height:50px}.archive-play-big-btn{width:60px;height:60px}}@media screen and (orientation:landscape)and (max-height:600px){.archive-player-view{position:fixed!important;inset:0!important;z-index:100!important}.archive-header{position:absolute!important;z-index:200!important}.archive-header.visible{opacity:1!important;visibility:visible!important;pointer-events:auto!important}.archive-header.hidden{opacity:0!important;visibility:hidden!important;pointer-events:none!important}.archive-video-wrapper{position:absolute!important;inset:0!important;z-index:1!important}.archive-controls-overlay{position:absolute!important;top:50%!important;left:50%!important;bottom:auto!important;transform:translate(-50%,-50%)!important;z-index:150!important}.archive-controls-overlay.visible{opacity:1!important;visibility:visible!important;pointer-events:auto!important;display:flex!important}.archive-controls-overlay.hidden{opacity:0!important;visibility:hidden!important;pointer-events:none!important}.archive-timeline-section{position:absolute!important;bottom:0!important;left:0!important;right:0!important;z-index:200!important;background:linear-gradient(to top,rgba(0,0,0,.95) 0%,rgba(0,0,0,.8) 60%,transparent 100%)!important}.archive-timeline-section.visible{opacity:1!important;visibility:visible!important;pointer-events:auto!important;transform:translateY(0)!important;display:block!important}.archive-timeline-section.hidden{opacity:0!important;visibility:hidden!important;pointer-events:none!important;transform:translateY(100%)!important}}.archive-timeline{touch-action:pan-x!important;-ms-touch-action:pan-x!important;overscroll-behavior:none}.archive-new{touch-action:manipulation}.timeline-zoom{display:flex;gap:2px;background:#0000004d;border-radius:6px;padding:2px}.zoom-btn{padding:.25rem .5rem;border:none;background:transparent;color:var(--text-secondary);font-size:.7rem;font-weight:500;cursor:pointer;border-radius:4px;transition:all .15s}.zoom-btn:hover{background:#ffffff1a;color:var(--text-primary)}.zoom-btn.active{background:#06b6d4;color:var(--text-primary)}@media screen and (orientation:landscape)and (max-height:600px){.timeline-zoom{display:none}}@media(max-width:480px){.zoom-btn{padding:.2rem .4rem;font-size:.65rem}}.pwa-header-logo{height:clamp(24px,4vw,40px);width:auto;margin-right:clamp(.25rem,1vw,1rem);object-fit:contain}@media(min-width:1200px){.pwa-header-logo{height:40px}}@media(min-width:768px)and (max-width:1199px){.pwa-header-logo{height:36px}}@media(max-width:767px){.pwa-header-logo{height:28px}}@media(orientation:landscape)and (max-height:600px){.pwa-header-logo{height:24px;margin-right:.5rem}}@media(max-width:360px){.pwa-header-logo{height:22px}}.timeline-activity{position:absolute!important;inset:30px 0 20px!important;width:100%!important;pointer-events:none}.activity-bar{position:absolute!important;bottom:0!important;left:50%!important;border-radius:2px!important;min-width:2px!important;pointer-events:none}.activity-bar.recordings{background:linear-gradient(to top,#06b6d4,#22d3ee)!important;height:100%!important;opacity:.6!important;z-index:1!important}.activity-bar.motion{background:linear-gradient(to top,#8b5cf6,#a78bfa)!important;height:70%!important;opacity:.8!important;z-index:2!important}.activity-bar.analytics{background:linear-gradient(to top,#ec4899,#f472b6)!important;height:50%!important;opacity:.9!important;z-index:3!important}.intercom-toast-backdrop{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:99998}.intercom-toast-card{background:var(--bg-surface);border-radius:16px;border:2px solid var(--accent);box-shadow:0 0 60px #00ffc826,var(--shadow-xl);overflow:hidden}.intercom-toast-topbar{height:4px;background:linear-gradient(90deg,var(--accent),var(--accent),var(--accent));background-size:200% 100%;animation:gradient-slide 2s linear infinite}.intercom-toast-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px}.intercom-toast-header-left{display:flex;align-items:center;gap:12px}.intercom-toast-icon{position:relative;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#00ffc833,#00b89433);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;color:var(--accent)}.intercom-toast-pulse{position:absolute;top:-4px;right:-4px;width:14px;height:14px;background:var(--accent-danger);border-radius:50%;border:2px solid var(--bg-surface);animation:pulse 1.5s infinite}.intercom-toast-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0}.intercom-toast-subtitle{font-size:.875rem;font-weight:600;color:var(--accent);margin:0}.intercom-toast-video-container{position:relative;margin:0 16px;border-radius:12px;overflow:hidden;background:#000;aspect-ratio:16/9;border:1px solid var(--border)}.intercom-toast-video-container .webrtc-player{width:100%;height:100%}.intercom-toast-video-container video{width:100%;height:100%;object-fit:cover}.intercom-toast-live-badge{position:absolute;top:10px;left:10px;display:flex;align-items:center;gap:6px;background:var(--accent-danger);padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700;color:var(--text-primary)}.intercom-toast-live-dot{width:6px;height:6px;background:#fff;border-radius:50%;animation:pulse 1s infinite}.intercom-toast-mute-btn{position:absolute;bottom:10px;left:10px;padding:8px;background:#000000b3;border:none;border-radius:50%;cursor:pointer;color:var(--text-primary);display:flex;align-items:center;justify-content:center;transition:background .2s}.intercom-toast-mute-btn:hover{background:#000000e6}.intercom-toast-no-camera{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary)}.intercom-toast-info{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-size:.875rem;color:var(--text-tertiary)}.intercom-toast-badge{padding:4px 12px;background:var(--bg-page);border-radius:20px;text-transform:capitalize}.intercom-toast-buttons{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 16px}.intercom-toast-buttons .btn{width:100%}.intercom-toast-dismiss{width:100%;margin-top:12px;padding:10px 16px;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;font-size:.875rem;transition:color .2s}.intercom-toast-dismiss:hover{color:var(--text-secondary)}.intercom-toast-more{padding:12px 16px;border-top:1px solid var(--border);text-align:center;color:var(--accent);font-weight:500;font-size:.875rem}@keyframes gradient-slide{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.intercom-modal-overlay{position:fixed;inset:0;background:#000000e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem}.intercom-modal{position:relative;width:100%;max-width:900px;background:var(--bg-surface);border-radius:16px;overflow:hidden;box-shadow:0 0 60px #00000080}.intercom-modal-close{position:absolute;top:1rem;right:1rem;z-index:10;width:40px;height:40px;border-radius:50%;background:#0009;border:none;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.intercom-modal-video video,.intercom-modal-video .webrtc-player{width:100%;height:100%}.intercom-modal-video video{object-fit:contain}.intercom-modal-snapshot{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.intercom-modal-snapshot img{width:100%;height:100%;object-fit:contain}.intercom-modal-overlay-controls{position:absolute;inset:0;pointer-events:none}.intercom-modal-live-badge{position:absolute;top:1rem;left:1rem;display:flex;align-items:center;gap:6px;background:var(--accent-danger);padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.intercom-modal-live-badge .live-dot{width:6px;height:6px;background:#fff;border-radius:50%;animation:pulse 1s infinite}.intercom-modal-name{position:absolute;top:1rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:#0009;padding:8px 16px;border-radius:20px;font-size:.875rem;font-weight:600;color:var(--text-primary)}.intercom-modal-mute{position:absolute;bottom:1rem;left:1rem;width:44px;height:44px;border-radius:50%;background:#0009;border:none;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;pointer-events:auto;transition:all .2s}.intercom-modal-mute:hover{background:#000c}.intercom-modal-controls{display:flex;gap:1rem;padding:1.5rem;background:var(--bg-surface);border-top:1px solid var(--border);box-shadow:var(--shadow-sm)}.intercom-modal-controls .btn{flex:1;justify-content:center}.btn-lg{padding:14px 24px;font-size:1rem}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-success:hover{transform:translateY(-1px);box-shadow:0 4px 20px #10b9814d}.intercom-modal-video .webrtc-player .btn-icon{z-index:10}.intercom-modal-video-overlay{pointer-events:none;z-index:5}.intercom-modal-video-overlay>*{pointer-events:auto}.admin-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:0}.admin-tab{display:flex;align-items:center;gap:8px;padding:12px 20px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s ease}.admin-tab:hover{color:var(--text-primary);background:#ffffff05}.admin-tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.admin-tab svg{opacity:.7}.admin-tab-content{animation:fadeIn .2s ease}.tab-panel{display:flex;flex-direction:column;gap:24px}.section-subtitle{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-secondary);margin:16px 0 12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.05)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-header .card-title{margin-bottom:0}.current-site-badge{display:inline-flex;align-items:center;padding:4px 12px;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:16px;font-size:12px;color:#60a5fa;margin-left:12px}.intercom-config{background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:16px;margin-bottom:16px}.intercom-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:500;color:var(--text-primary)}.connection-status{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:4px;font-size:13px;font-weight:500;margin-left:12px}.connection-status.connected{background:#22c55e1a;color:#22c55e}.connection-status.disconnected{background:#ef44441a;color:#ef4444}.placeholder-content{padding:24px;text-align:center;color:var(--text-secondary)}.placeholder-content p{margin-bottom:12px}.license-info{text-align:center}.license-status{margin-bottom:16px}.license-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600}.license-badge.trial{background:#fbbf241a;color:#fbbf24;border:1px solid rgba(251,191,36,.3)}.license-badge.active{background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.license-badge.expired{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.page-title{display:flex;align-items:center;gap:12px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.form-group[style*=grid-column]{grid-column:span 1!important}.admin-tabs{flex-wrap:wrap}.admin-tab{padding:10px 16px;font-size:13px}}.form-hint{color:var(--text-tertiary);font-size:13px}.btn-danger{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444433}.shabbat-container{margin-bottom:1.5rem}.shabbat-box{background:linear-gradient(135deg,#1e1b4b,#312e81);border:1px solid rgba(139,92,246,.3);border-radius:12px;padding:1.25rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.shabbat-box.active{background:linear-gradient(135deg,#312e81,#4c1d95);border-color:#a78bfa80;box-shadow:0 0 20px #8b5cf633}.shabbat-box.loading{justify-content:center;color:#a5b4fc;gap:.75rem}.shabbat-content{display:flex;align-items:center;gap:1rem}.shabbat-icon{width:48px;height:48px;border-radius:12px;background:#8b5cf633;display:flex;align-items:center;justify-content:center;color:#a78bfa}.shabbat-box.active .shabbat-icon{background:#a78bfa4d;color:#c4b5fd}.shabbat-text h3{font-size:1.1rem;font-weight:600;color:#e0e7ff;margin:0 0 .25rem}.shabbat-text p{font-size:.875rem;color:#a5b4fc;margin:0;display:flex;align-items:center;gap:.375rem}.shabbat-status-active{color:#86efac!important}.shabbat-next{color:#fcd34d!important}.shabbat-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.shabbat-schedule{display:flex;flex-direction:column;align-items:flex-end;font-size:.8rem}.shabbat-schedule-label{color:var(--accent);font-size:.75rem}.shabbat-schedule-time{color:#c7d2fe;font-weight:500}.shabbat-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-weight:500;border-radius:8px;transition:all .2s}.shabbat-btn.btn-primary{background:linear-gradient(135deg,#7c3aed,#8b5cf6);border:none;color:#fff}.shabbat-btn.btn-primary:hover{background:linear-gradient(135deg,#6d28d9,#7c3aed);transform:translateY(-1px)}.shabbat-btn.btn-warning{background:linear-gradient(135deg,#d97706,#f59e0b);border:none;color:#fff}.shabbat-btn.btn-warning:hover{background:linear-gradient(135deg,#b45309,#d97706)}.shabbat-modal{max-width:420px}.shabbat-modal h2{color:#f3f4f6;margin:1rem 0 .5rem}.shabbat-modal p{color:var(--text-secondary);line-height:1.6}.shabbat-modal strong{color:var(--text-primary)}@media(max-width:640px){.shabbat-box{flex-direction:column;text-align:center}.shabbat-content{flex-direction:column}.shabbat-actions{width:100%;flex-direction:column}.shabbat-schedule{align-items:center}.shabbat-btn{width:100%;justify-content:center}}.shabbat-settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:640px){.shabbat-settings-grid{grid-template-columns:1fr}.shabbat-settings .page-header h1{font-size:1.25rem}.shabbat-settings .section-header{flex-direction:column;align-items:flex-start;gap:8px}}.notifications-page{padding:1.5rem}@media(max-width:640px){.notifications-page{padding:1rem}.notifications-page .page-header h1{font-size:1.25rem}}.archive-player-view .date-picker-dropdown,.archive-player-view .time-picker-popup,.archive-player-view .calendar-picker,.archive-timeline-section .date-picker-dropdown,.archive-timeline-section .time-picker-popup{z-index:100!important}.archive-header,.archive-timeline-section{z-index:50!important}.archive-controls-overlay{z-index:40!important}.archive-video-wrapper{z-index:1!important}.archive-video-wrapper video,.archive-video-wrapper>div{z-index:1!important}html{overflow-x:hidden;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}body{overflow-x:hidden;-webkit-tap-highlight-color:transparent}input,select,textarea{font-size:16px!important}.page-container,.main-content,.modal-body,.sidebar-nav{-webkit-overflow-scrolling:touch}@media(max-width:1024px){.app-container,.app-layout{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;padding:0!important}.main-content{margin-left:0!important;width:100%!important;max-width:100vw!important;overflow-x:hidden!important;padding:16px!important;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))!important;min-height:calc(100vh - 80px);min-height:calc(100dvh - 80px)}.sidebar{position:fixed!important;left:0;top:0;bottom:0;width:280px!important;min-width:280px!important;z-index:1000;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);padding-top:env(safe-area-inset-top,0);overflow-y:auto}.sidebar.open{transform:translate(0)}.sidebar.collapsed{width:280px!important;min-width:280px!important}.sidebar.collapsed .nav-label,.sidebar.collapsed .sidebar-brand span{display:block!important}.sidebar-collapse-btn,.sidebar-toggle{display:none!important}.sidebar-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:999}.mobile-menu-btn{display:flex!important;position:fixed;bottom:calc(90px + env(safe-area-inset-bottom,0px));right:16px;z-index:998;width:48px;height:48px;border-radius:50%;background:var(--bg-sidebar);border:.5px solid rgba(255,255,255,.08);color:var(--bg-sidebar-text-hover);box-shadow:0 4px 12px #0006;align-items:center;justify-content:center;cursor:pointer}.mobile-header{display:none!important}.page-header{flex-direction:column;align-items:flex-start!important;gap:12px}.camera-grid{grid-template-columns:repeat(2,1fr)!important;gap:12px!important}.bottom-nav{display:flex!important;position:fixed;bottom:0;left:0;right:0;background:var(--bg-surface);border-top:1px solid var(--border);padding:8px 0;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));z-index:100;box-shadow:var(--shadow-sm)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px;color:var(--text-tertiary);font-size:11px;text-decoration:none;background:none;border:none;cursor:pointer;min-height:44px;justify-content:center}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}}@media(max-width:768px){.main-content{padding:12px!important;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))!important}.page-container{padding:12px!important;max-width:100%!important;overflow-x:hidden!important}.page-title{font-size:22px!important;line-height:1.3}.page-subtitle{font-size:13px!important}.card{padding:14px!important;border-radius:10px}.btn{padding:10px 14px!important;font-size:14px!important;min-height:44px;border-radius:8px}.btn-sm{padding:8px 12px!important;font-size:13px!important;min-height:36px}.camera-grid{grid-template-columns:1fr!important;gap:12px!important}.camera-select-header{flex-direction:column;align-items:stretch!important;gap:10px;padding-top:0!important}.camera-search-wrapper{max-width:100%!important;width:100%!important}.camera-search-input{width:100%!important;font-size:16px!important}.layout-select{width:100%!important;min-width:unset!important}.camera-card{border-radius:10px}.camera-card:hover{transform:none!important}.camera-thumbnail{aspect-ratio:16/9}.camera-name{font-size:14px!important;padding:10px 12px!important}.camera-tile,.camera-stream{min-height:auto!important}.grid-controls{flex-direction:column!important;align-items:stretch!important;gap:8px}.grid-controls>*{width:100%}.grid-select{width:100%!important}.grid-options{display:flex;flex-wrap:wrap;gap:6px}.grid-btn{flex:1;min-width:60px;justify-content:center;min-height:40px}.lockdown-bar{flex-direction:column;text-align:center;gap:10px}.lockdown-bar .btn{width:100%}.readers-grid{grid-template-columns:1fr!important;gap:12px}.reader-card{padding:14px}.reader-actions{flex-direction:column;gap:8px}.reader-actions .btn{width:100%;justify-content:center}.access-grid-controls{flex-direction:column!important;align-items:stretch!important;gap:10px}.access-filter-group{width:100%}.access-filter-group select,.access-filter-group .form-select{flex:1;min-width:0!important;width:100%}.access-tabs{flex-wrap:wrap;gap:6px}.access-tabs .btn{flex:1;min-width:80px;justify-content:center;font-size:13px!important}.events-header{flex-direction:column;align-items:flex-start;gap:10px}.events-actions{width:100%;justify-content:space-between}.intercom-grid{grid-template-columns:1fr!important;gap:12px}.setting-row{flex-direction:column;align-items:flex-start!important;gap:12px}.setting-controls{width:100%;justify-content:flex-start}.settings-tabs,.tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:4px;padding-bottom:2px;scrollbar-width:none}.settings-tabs::-webkit-scrollbar,.tabs::-webkit-scrollbar{display:none}.settings-tabs .btn,.tabs .btn,.tab-btn{white-space:nowrap;flex-shrink:0;font-size:13px!important}.admin-grid{grid-template-columns:1fr!important}.form-row{flex-direction:column!important}.form-row .form-group{width:100%!important}.form-input,.form-select,.form-textarea{font-size:16px!important}.table-wrapper,.events-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -12px;padding:0 12px}.events-table th,.events-table td{padding:8px!important;font-size:13px!important;white-space:nowrap}.modal-overlay{padding:0!important;align-items:stretch}.modal-content{width:100%!important;max-width:100%!important;height:100%!important;max-height:100%!important;border-radius:0!important;margin:0!important}.modal-header{padding-top:calc(12px + env(safe-area-inset-top,0))}.modal-footer{padding-bottom:calc(12px + env(safe-area-inset-bottom,0))}.modal-actions{flex-direction:column;gap:8px}.modal-actions .btn{width:100%}.lockdown-box{flex-direction:column;text-align:center}.lockdown-content{flex-direction:column;align-items:center}.home-grid{grid-template-columns:1fr!important;gap:12px}.home-features{grid-template-columns:1fr!important}.notification-bar{flex-direction:column}.notification-item{min-width:100%}.info-banner{font-size:14px;padding:12px}.drag-hint{display:none!important}.filter-group{flex-direction:column;align-items:stretch}.filter-group select{min-width:unset!important;width:100%}}@media(max-width:480px){.main-content{padding:10px!important;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))!important}.page-container{padding:10px!important}.page-title{font-size:20px!important}.page-header{margin-bottom:12px}.card{padding:12px!important}.grid-btn{padding:6px 8px;font-size:12px!important}.grid-btn-badge{display:none}.access-tabs .btn{font-size:12px!important;padding:6px 10px!important}.section-title{font-size:15px!important}.bottom-nav-item{font-size:10px}}@media(max-width:360px){.main-content{padding:8px!important;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))!important}.page-title{font-size:18px!important}.page-subtitle{font-size:12px!important}.btn{padding:8px 10px!important;font-size:13px!important}.camera-name{font-size:13px!important;padding:8px 10px!important}.settings-tabs .btn,.tabs .btn,.tab-btn{font-size:12px!important;padding:6px 10px!important}}@media(max-height:500px)and (orientation:landscape){.camera-grid{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}.camera-tile,.camera-stream{min-height:auto!important}.page-header{padding:6px 0;margin-bottom:8px}.page-title{font-size:18px!important}.grid-controls{padding:6px 0}.bottom-nav{display:none!important}.main-content{padding-bottom:16px!important}}@media(min-width:769px)and (max-width:1024px){.main-content{padding:20px!important;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))!important}.camera-grid{grid-template-columns:repeat(2,1fr)!important;gap:14px!important}.readers-grid,.intercom-grid,.home-grid,.home-features{grid-template-columns:repeat(2,1fr)!important}.camera-select-header{flex-direction:row;align-items:center;flex-wrap:wrap}.camera-search-wrapper{max-width:300px!important;flex:1}}@media(hover:none)and (pointer:coarse){.btn,.grid-btn,.btn-icon,.bottom-nav-item,.nav-item{min-height:44px;min-width:44px}.camera-header button{min-width:36px;min-height:36px}.btn:hover,.grid-btn:hover,.camera-tile:hover,.camera-card:hover,.reader-card:hover,.intercom-card:hover,.nav-item:hover{transform:none!important}.btn:active{opacity:.8;transform:scale(.97)!important}.camera-card:active{opacity:.9}.drag-handle{padding:10px}.toggle-switch{min-width:48px;min-height:28px}}@media(display-mode:standalone){.main-content{padding-top:calc(16px + env(safe-area-inset-top,0))!important}.sidebar{padding-top:env(safe-area-inset-top,0)}.mobile-menu-btn{bottom:calc(90px + env(safe-area-inset-bottom,0px))}}@media(max-width:1024px)and (display-mode:standalone){.main-content{padding-top:calc(12px + env(safe-area-inset-top,0))!important;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))!important}.bottom-nav{padding-bottom:calc(8px + env(safe-area-inset-bottom,0px))}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.page-container>*,.main-content>*,.card>*{max-width:100%;overflow-wrap:break-word;word-wrap:break-word}img,video,canvas,svg{max-width:100%;height:auto}.camera-select-header>*,.grid-controls>*,.access-grid-controls>*,.lockdown-bar>*,.reader-header>*,.events-header>*{min-width:0}@media(max-width:768px){.access-tabs::-webkit-scrollbar,.settings-tabs::-webkit-scrollbar,.tabs::-webkit-scrollbar{display:none}.access-tabs,.settings-tabs,.tabs{scrollbar-width:none}}@media(max-width:768px){.archive-camera-select{padding:12px!important}.archive-camera-select .page-header-with-actions{flex-direction:column!important;align-items:stretch!important;gap:8px;margin-bottom:12px}.archive-camera-select .camera-select-controls{display:flex!important;flex-direction:column!important;width:100%!important;gap:8px}.archive-camera-select .camera-search-wrapper{width:100%!important;max-width:100%!important}.archive-camera-select .layout-select{display:block!important;width:100%!important;min-width:unset!important;font-size:16px!important}.archive-camera-select .camera-count{display:block!important}.archive-camera-select .camera-grid{padding:0!important}}@media(max-width:768px){.admin-tabs{display:flex!important;flex-wrap:nowrap!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:0!important;width:100%}.admin-tabs::-webkit-scrollbar{display:none}.admin-tab{flex:1 1 0!important;min-width:0!important;white-space:nowrap!important;text-align:center;justify-content:center;font-size:13px!important;padding:10px 12px!important}.admin-tab span{overflow:hidden;text-overflow:ellipsis}}@media(max-width:400px){.admin-tab{font-size:12px!important;padding:8px!important}.admin-tab svg{display:none!important}}@media(max-width:768px){.user-profile-tabs{display:flex!important;flex-wrap:nowrap!important;width:100%;gap:0!important}.user-profile-tab{flex:1 1 0!important;min-width:0!important;white-space:nowrap!important;text-align:center;justify-content:center;font-size:13px!important;padding:10px 8px!important}.user-profile-more-wrapper{display:none!important}.overflow-tab{display:flex!important}}@media(max-width:400px){.user-profile-tab{font-size:11px!important;padding:8px 6px!important}}@media(max-width:768px){.access-tabs{display:grid!important;grid-template-columns:auto auto auto;gap:8px!important}.access-tabs>.btn:nth-child(1),.access-tabs>.btn:nth-child(2),.access-tabs>.btn:nth-child(3){white-space:nowrap}.access-tabs>.access-filter-group{grid-column:1 / 3;grid-row:2;margin-left:0!important;display:flex!important;gap:8px;width:100%}.access-tabs>.access-filter-group select{flex:1!important;min-width:0!important}}.access-tabs>.btn:last-child{grid-column:3;grid-row:2;white-space:nowrap}@media(max-width:768px){.md-page .md-stat-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:12px!important}.md-page .md-stat-grid>.md-stat-card{grid-column:span 1!important;width:100%!important}}@media(max-width:360px){.md-page .md-stat-grid{grid-template-columns:1fr!important}}@media(max-width:768px){.md-page .md-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.md-page .md-stat-grid>.md-stat-card{min-width:0!important;overflow:hidden}}.more-drawer{position:fixed;bottom:calc(64px + env(safe-area-inset-bottom,0px));left:0;right:0;max-height:75vh;background:var(--bg-surface);border-top:1px solid var(--border);border-radius:16px 16px 0 0;z-index:1001;display:flex;flex-direction:column;animation:drawer-slide-up .25s ease-out;box-shadow:0 -4px 24px #0006}@keyframes drawer-slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.more-drawer-backdrop{position:fixed;inset:0;background:#00000080;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.more-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.more-drawer-user{display:flex;align-items:center;gap:12px}.more-drawer-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);color:var(--text-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.more-drawer-name{font-weight:600;font-size:15px;color:var(--text-primary)}.more-drawer-role{font-size:12px;color:var(--text-tertiary);text-transform:capitalize}.more-drawer-close{width:36px;height:36px;border-radius:50%;background:var(--bg-page);border:none;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.more-drawer-close:hover,.more-drawer-close:active{background:var(--bg-page);color:var(--text-primary)}.more-drawer-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 0}.more-drawer-section+.more-drawer-section{border-top:1px solid var(--border);margin-top:4px;padding-top:8px}.more-drawer-section-label{padding:8px 20px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary)}.more-drawer-item{display:flex;align-items:center;gap:14px;width:100%;padding:14px 20px;background:none;border:none;color:var(--text-secondary);font-size:15px;cursor:pointer;transition:all .15s;text-align:left}.more-drawer-item:hover,.more-drawer-item:active{background:#10b98114;color:var(--text-primary)}.more-drawer-item.active{background:#10b98126;color:var(--accent)}.more-drawer-item svg{flex-shrink:0}.more-drawer-badge{margin-left:auto;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:#a855f726;color:#a855f7}.more-drawer-footer{border-top:1px solid var(--border);flex-shrink:0;padding-bottom:env(safe-area-inset-bottom,0px)}.more-drawer-logout{color:var(--accent-danger, #ef4444)!important}.more-drawer-logout:hover,.more-drawer-logout:active{background:#ef444414!important}.vw-container{width:100vw;height:100vh;background:#08080c;display:flex;flex-direction:column;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#e0e0e8}.vw-loading{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#08080c;color:#808090}.vw-toolbar{height:48px;min-height:48px;background:#0f0f14;border-bottom:1px solid #1a1a24;display:flex;align-items:center;justify-content:space-between;padding:0 16px;z-index:10}.vw-toolbar-left,.vw-toolbar-right{display:flex;align-items:center;gap:10px}.vw-toolbar-center{display:flex;align-items:center;gap:4px}.vw-toolbar-brand{display:flex;align-items:center;gap:8px;color:var(--accent);font-weight:700;font-size:15px}.vw-toolbar-divider{width:1px;height:24px;background:#2a2a3a}.vw-stream-count{font-size:12px;color:#808090}.vw-layout-btn{padding:5px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid #2a2a3a;background:#1a1a24;color:#808090;transition:all .15s ease}.vw-layout-btn:hover{background:#22222e;color:#a0a0b0}.vw-layout-btn.active{border-color:var(--accent);background:#00d4aa1a;color:var(--accent)}.vw-toolbar-btn{padding:6px 10px;border-radius:6px;border:1px solid #2a2a3a;background:#1a1a24;color:#a0a0b0;cursor:pointer;display:flex;align-items:center;gap:6px;font-size:12px;transition:all .15s ease}.vw-toolbar-btn:hover{background:#22222e;color:#e0e0e8}.vw-main{flex:1;display:flex;overflow:hidden}.vw-sidebar{width:220px;min-width:220px;background:#0c0c12;border-right:1px solid #1a1a24;display:flex;flex-direction:column;z-index:5}.vw-sidebar-collapsed{width:40px;min-width:40px;background:#0c0c12;border-right:1px solid #1a1a24;display:flex;flex-direction:column;align-items:center;padding-top:8px}.vw-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid #1a1a24}.vw-sidebar-title{font-size:13px;font-weight:600;color:#c0c0cc}.vw-sidebar-toggle{background:none;border:none;color:#606070;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center}.vw-sidebar-toggle:hover{color:#a0a0b0;background:#1a1a24}.vw-sidebar-search{padding:8px 12px;position:relative}.vw-sidebar-search input{width:100%;padding:7px 10px 7px 30px;border-radius:6px;border:1px solid #2a2a3a;background:#14141c;color:#e0e0e8;font-size:12px;outline:none;box-sizing:border-box}.vw-sidebar-search input:focus{border-color:var(--accent)}.vw-search-icon{position:absolute;left:22px;top:50%;transform:translateY(-50%);color:#505060}.vw-sidebar-list{flex:1;overflow-y:auto;padding:4px 8px}.vw-sidebar-loading,.vw-sidebar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;color:#505060;font-size:12px}.vw-sidebar-footer{padding:8px 12px;border-top:1px solid #1a1a24;font-size:11px;color:#505060;text-align:center}.vw-camera-group{margin-bottom:4px}.vw-group-header{display:flex;align-items:center;gap:4px;width:100%;padding:6px;border:none;background:none;color:#606070;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;cursor:pointer}.vw-group-header:hover{color:#a0a0b0}.vw-group-count{margin-left:auto;font-size:10px;color:#404050}.vw-camera-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;margin-bottom:1px;cursor:grab;-webkit-user-select:none;user-select:none;transition:all .15s ease;border:1px solid transparent}.vw-camera-item:hover:not(.placed):not(.offline){background:#14141c;border-color:#2a2a3a}.vw-camera-item:active:not(.placed):not(.offline){cursor:grabbing}.vw-camera-item.placed{opacity:.4;cursor:default;background:#00d4aa0a;border-color:#00d4aa1a}.vw-camera-item.offline{opacity:.35;cursor:default}.vw-camera-status{width:7px;height:7px;border-radius:50%;flex-shrink:0}.vw-camera-status.online{background:#22c55e;box-shadow:0 0 6px #22c55e4d}.vw-camera-status.offline{background:var(--text-tertiary)}.vw-camera-name{font-size:12px;color:#c0c0cc;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vw-camera-placed{font-size:9px;color:var(--accent)}.vw-grid-container{flex:1;padding:6px;overflow:hidden}.vw-grid{width:100%;height:100%;display:grid;gap:4px}.vw-cell{border-radius:6px;overflow:hidden;position:relative;transition:border-color .15s ease,background .15s ease}.vw-cell.empty{border:1px dashed #2a2a3a;background:#0a0a0f}.vw-cell.filled{border:1px solid transparent;background:#0a0a10}.vw-cell.drag-over{border:2px solid var(--accent)!important;background:#00d4aa0d}.vw-cell-empty{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#3a3a4a;font-size:12px}.vw-cell.drag-over .vw-cell-empty{color:var(--accent)}.vw-cell-content{width:100%;height:100%;position:relative;background:#000;cursor:pointer}.vw-cell-thumbnail{width:100%;height:100%;object-fit:contain;position:absolute;top:0;left:0}.vw-cell-stream{width:100%;height:100%;position:absolute;top:0;left:0}.vw-cell-stream .webrtc-player{width:100%;height:100%}.vw-cell-stream .webrtc-player video{width:100%;height:100%;object-fit:contain}.vw-cell-loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.vw-cell-overlay-top{position:absolute;top:0;left:0;right:0;padding:8px 10px;background:linear-gradient(180deg,rgba(0,0,0,.7) 0%,transparent 100%);display:flex;justify-content:space-between;align-items:center;opacity:0;transition:opacity .2s ease;z-index:2}.vw-cell-overlay-top.visible,.vw-cell-content:hover .vw-cell-overlay-top{opacity:1}.vw-cell-name{font-size:12px;font-weight:600;color:#ffffffd9;text-shadow:0 1px 3px rgba(0,0,0,.5)}.vw-cell-actions{display:flex;gap:4px}.vw-cell-btn{background:#ffffff26;border:none;border-radius:4px;color:#ffffffb3;width:26px;height:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.vw-cell-btn:hover{background:#ffffff40;color:#fff}.vw-cell-live-badge{position:absolute;bottom:8px;left:10px;display:flex;align-items:center;gap:5px;font-size:10px;font-family:monospace;color:#fff9;z-index:2}.vw-live-dot{width:6px;height:6px;border-radius:50%;background:#ef4444;box-shadow:0 0 6px #ef4444;animation:vw-pulse 2s infinite}@keyframes vw-pulse{0%,to{opacity:1}50%{opacity:.4}}.vw-expanded{flex:1;display:flex;flex-direction:column;background:#000}.vw-expanded-header{height:44px;min-height:44px;background:#0f0f14;border-bottom:1px solid #1a1a24;display:flex;align-items:center;gap:12px;padding:0 16px}.vw-expanded-back{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:6px;border:1px solid #2a2a3a;background:#1a1a24;color:#a0a0b0;cursor:pointer;font-size:12px;transition:all .15s}.vw-expanded-name{font-size:14px;font-weight:600;color:#e0e0e8}.vw-expanded-status{display:flex;align-items:center;gap:4px;font-size:11px;color:#22c55e;margin-left:auto}.vw-expanded-player{flex:1;position:relative}.vw-expanded-player .webrtc-player{width:100%;height:100%}.vw-expanded-player .webrtc-player video{width:100%;height:100%;object-fit:contain}.vw-timeline{height:48px;min-height:48px;background:#0c0c12;border-top:1px solid #1a1a24;display:flex;align-items:center;padding:0 16px;gap:12px;z-index:10}.vw-timeline-controls{display:flex;align-items:center;gap:6px}.vw-live-btn{padding:4px 10px;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid #2a2a3a;background:#1a1a24;color:#808090;display:flex;align-items:center;gap:5px;transition:all .15s}.vw-live-btn.active{border-color:#ef4444;background:#ef44441f;color:#ef4444}.vw-live-btn-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.vw-timeline-bar{flex:1;height:28px;background:#14141c;border-radius:6px;position:relative;cursor:pointer;overflow:hidden}.vw-timeline-track{width:100%;height:100%;position:relative}.vw-timeline-marker{position:absolute;bottom:2px;transform:translate(-50%);font-size:8px;color:#404050;font-family:monospace;pointer-events:none}.vw-timeline-playhead{position:absolute;top:2px;bottom:2px;transform:translate(-50%);z-index:2;pointer-events:none}.vw-timeline-playhead-line{width:2px;height:100%;background:var(--accent);border-radius:1px;box-shadow:0 0 8px #00d4aa66}.vw-timeline-playhead-dot{position:absolute;top:-3px;left:-4px;width:10px;height:10px;background:var(--accent);border-radius:50%}.vw-timeline-time{font-size:12px;font-family:monospace;color:#a0a0b0;min-width:70px;text-align:right}.vw-expanded{position:absolute;inset:48px 0;background:#000;z-index:20}.vw-expanded-back{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:6px;border:1px solid #2a2a3a;background:#1a1a24;color:#a0a0b0;cursor:pointer;font-size:12px;transition:all .15s;white-space:nowrap}.vw-expanded-back:hover{background:#22222e;color:#e0e0e8}.vw-expanded-name{font-size:14px;font-weight:600;color:#e0e0e8;margin-left:12px}.vw-container{position:relative}.intercom-call-controls{position:fixed;bottom:0;left:0;right:0;z-index:999;background:linear-gradient(to top,#111827fa,#111827f2);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(6,182,212,.3);padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom));animation:slideUpCall .3s ease-out}@keyframes slideUpCall{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.intercom-call-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;padding:0 .25rem}.intercom-call-info-left{display:flex;align-items:center;gap:.5rem}.intercom-call-icon{color:#22c55e;animation:pulseGreen 2s infinite}@keyframes pulseGreen{0%,to{opacity:1}50%{opacity:.5}}.intercom-call-name{font-size:.9rem;font-weight:600;color:var(--text-primary)}.intercom-call-connecting{font-size:.8rem;color:#fbbf24;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}.intercom-call-duration{font-size:.875rem;font-weight:500;color:var(--text-secondary);font-variant-numeric:tabular-nums}.intercom-call-level-bar{height:3px;background:var(--bg-page);border-radius:2px;margin-bottom:.75rem;overflow:hidden}.intercom-call-level-fill{height:100%;background:linear-gradient(to right,#22c55e,#06b6d4);border-radius:2px;transition:width .05s ease-out}.intercom-call-buttons{display:flex;align-items:center;justify-content:center;gap:1rem}.intercom-call-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem;min-width:64px;border:none;border-radius:12px;background:var(--bg-page);color:var(--text-secondary);cursor:pointer;transition:all .15s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.intercom-call-btn:hover{background:#6b728066;color:var(--text-primary)}.intercom-call-btn:active{transform:scale(.95)}.intercom-call-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.intercom-call-btn-label{font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.intercom-call-btn-ptt{min-width:80px;padding:1rem;background:#06b6d426;border:2px solid rgba(6,182,212,.3);color:#06b6d4}.intercom-call-btn-ptt:hover{background:#06b6d440;border-color:#06b6d480}.intercom-call-btn-ptt.transmitting{background:#22c55e33;border-color:#22c55e;color:#22c55e;box-shadow:0 0 16px #22c55e4d}.intercom-call-btn-open-mic{min-width:80px;padding:1rem;cursor:default}.intercom-call-btn-open-mic.transmitting{background:#22c55e26;border:2px solid rgba(34,197,94,.3);color:#22c55e}.intercom-call-btn-open-mic.muted{background:#ef44441a;border:2px solid rgba(239,68,68,.2);color:#ef4444}.intercom-call-btn-mode.active{background:#06b6d426;color:#06b6d4}.intercom-call-btn-mute.active{background:#ef444426;color:#ef4444}.intercom-call-btn-end{background:#ef444433;color:#ef4444}.intercom-call-btn-end:hover{background:#ef444459;color:#fca5a5}.intercom-call-hint{text-align:center;font-size:.7rem;color:var(--text-secondary);margin-top:.5rem}.intercom-call-hint kbd{display:inline-block;padding:.1rem .35rem;background:var(--bg-page);border:1px solid rgba(107,114,128,.3);border-radius:3px;font-family:inherit;font-size:.7rem}.intercom-toast-buttons .btn-answer{background:linear-gradient(135deg,#059669,#10b981);color:var(--text-primary);border:none}.intercom-toast-buttons .btn-answer:hover{background:linear-gradient(135deg,#047857,#059669)}.intercom-toast-buttons .btn-answer:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.intercom-call-controls{padding:.5rem .75rem;padding-bottom:calc(.5rem + env(safe-area-inset-bottom))}.intercom-call-buttons{gap:.75rem}.intercom-call-btn{min-width:56px;padding:.625rem}.intercom-call-btn-ptt{min-width:72px;padding:.875rem}.intercom-call-hint{display:none}}@media(max-width:480px){.intercom-call-buttons{gap:.5rem}.intercom-call-btn{min-width:48px;padding:.5rem}.intercom-call-btn-label{font-size:.6rem}}.intercom-action-btn.talk{background:#06b6d426;color:#06b6d4;border:1px solid rgba(6,182,212,.3)}.intercom-action-btn.talk:hover{background:#06b6d440;border-color:#06b6d480}.intercom-action-btn.talk.active{background:#ef444433;color:#ef4444;border-color:#ef444466}.intercom-action-btn.talk.active:hover{background:#ef44444d}.intercom-action-btn.talk:disabled{opacity:.4;cursor:not-allowed}button.nav-link.nav-child{background:none;border:none;width:100%;text-align:left;font:inherit;cursor:pointer;color:var(--bg-sidebar-text)}button.nav-link.nav-child:hover{background:#00d4aa1a;color:var(--accent)}.nav-badge.alert-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:600;padding:1px 6px;border-radius:8px;min-width:18px;text-align:center;line-height:16px;margin-left:auto;animation:badge-pulse 2s ease-in-out infinite}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.7}}.nav-separator{height:1px;background:#ffffff14;margin:8px 16px}.sidebar.collapsed .nav-separator{margin:8px}.devices-tab-bar{display:flex;gap:4px;background:#ffffff0d;border-radius:10px;padding:4px;margin-bottom:20px;width:fit-content}.devices-tab{padding:8px 20px;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid transparent;cursor:pointer;transition:all .15s ease;white-space:nowrap}.devices-tab:hover{color:var(--text-primary);background:#ffffff0d}.devices-tab.active{background:#10b98126;color:#10b981;border-color:#10b9814d}@media(max-width:768px){.devices-tab-bar{width:100%}.devices-tab{flex:1;text-align:center;padding:8px 12px;font-size:12px}}.genetec-player-container canvas,.genetec-player-container video{position:relative;z-index:1}.archive-controls-overlay{z-index:10;pointer-events:auto}.archive-timeline-section{z-index:10;position:relative}.archive-timeline-section:hover~.archive-video-wrapper .archive-controls-overlay,.archive-player-view:hover .archive-controls-overlay,.archive-player-view:hover .archive-timeline-section{opacity:1!important;pointer-events:auto!important}.archive-timeline-section{position:relative;z-index:20}@media(hover:hover)and (pointer:fine){.archive-timeline-section,.archive-timeline-section.hidden{opacity:1!important;visibility:visible!important;pointer-events:auto!important;transform:none!important;display:block!important}}.bottom-nav-item{position:relative}.bottom-nav-badge{position:absolute;top:2px;right:50%;transform:translate(calc(50% + 12px));min-width:18px;height:18px;padding:0 5px;background:#ef4444;color:var(--text-primary);font-size:10px;font-weight:700;line-height:18px;text-align:center;border-radius:9px;pointer-events:none;z-index:2}.more-drawer-content{flex:1;overflow-y:auto;padding:8px 0;-webkit-overflow-scrolling:touch}.more-drawer-section{padding:4px 0}.more-drawer-section+.more-drawer-section{border-top:1px solid rgba(255,255,255,.06);margin-top:4px;padding-top:8px}.more-drawer-section-label{padding:8px 20px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary)}.more-drawer-site-bar{display:flex;align-items:center;gap:10px;width:100%;padding:12px 20px;background:#00d4aa0f;border:none;border-bottom:1px solid var(--border);color:var(--accent);font-size:14px;font-weight:500;cursor:pointer;text-align:left;transition:background .15s}.more-drawer-site-bar:hover,.more-drawer-site-bar:active{background:#00d4aa1f}.more-drawer-site-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.more-drawer-site-chevron{opacity:.6;flex-shrink:0}.site-picker-backdrop{position:fixed;inset:0;z-index:10000;background:#0009;display:flex;align-items:flex-end;justify-content:center;animation:fade-in .15s ease}.site-picker-sheet{background:var(--bg-surface);border-radius:16px 16px 0 0;width:100%;max-width:480px;border:1px solid rgba(255,255,255,.1);border-bottom:none;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0px));animation:slide-up .25s ease;box-shadow:var(--shadow-sm)}.site-picker-handle{display:flex;justify-content:center;padding:12px 0 8px}.site-picker-handle-bar{width:36px;height:4px;border-radius:2px;background:#fff3}.site-picker-header{padding:4px 20px 14px;border-bottom:1px solid rgba(255,255,255,.08)}.site-picker-title{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.site-picker-subtitle{margin:2px 0 0;font-size:12px;color:var(--text-tertiary)}.site-picker-list{padding:8px 0}.site-picker-option{display:flex;align-items:center;gap:14px;width:100%;padding:14px 20px;background:none;border:none;border-left:3px solid transparent;cursor:pointer;text-align:left;color:var(--text-primary);transition:background .15s}.site-picker-option:hover{background:#ffffff0a}.site-picker-option.active{background:#00d4aa14;border-left-color:var(--accent);color:var(--accent)}.site-picker-option-info{flex:1;display:flex;flex-direction:column;min-width:0}.site-picker-option-name{font-size:15px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-picker-option-current{font-size:11px;margin-top:2px;color:var(--accent)}@media(max-width:1024px){.bottom-nav-item.active .bottom-nav-icon{background:var(--accent);color:var(--bg-page);padding:5px 14px;border-radius:20px;transition:all .2s ease}}@media(max-width:1024px){.mobile-menu-btn{display:none!important}.sidebar,.sidebar.open{transform:translate(-100%);pointer-events:none}}@media(max-width:1024px){.main-content{padding-bottom:calc(76px + env(safe-area-inset-bottom,0px))!important}}@media(max-width:768px){.page-content{overflow-x:hidden;max-width:100vw}.page-content .card{overflow:hidden;max-width:100%}.md-table-container,.md-monitored-table-container{overflow-x:hidden!important;max-width:100%}.md-devices-table{max-width:100%}}.sabbath-modal{max-width:480px;padding:1.5rem}.sabbath-modal-header{text-align:center;margin-bottom:1.25rem;display:flex;flex-direction:column;align-items:center}.sabbath-modal-header h2{color:#f3f4f6;margin:.75rem 0 .25rem;font-size:1.25rem}.sabbath-modal-subtitle{color:var(--text-secondary);font-size:.875rem;margin:0}.sabbath-modal .modal-icon{display:none}.sabbath-mode-cards{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.sabbath-mode-card{display:flex!important;flex-direction:row!important;align-items:center!important;gap:1rem;padding:1rem 1.25rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .2s;text-align:left!important}.sabbath-mode-card:hover{background:#ffffff14;border-color:#8b5cf666;transform:translateY(-1px)}.sabbath-mode-card-icon{width:48px;height:48px;min-width:48px;flex-shrink:0;border-radius:10px;display:flex;align-items:center;justify-content:center}.sabbath-mode-card-text{flex:1;min-width:0}.sabbath-mode-card-text h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem;text-align:left}.sabbath-mode-card-text p{font-size:.8rem;color:var(--text-secondary);margin:0;line-height:1.4;text-align:left}.sabbath-mode-card-arrow{color:var(--text-tertiary);min-width:20px;flex-shrink:0;margin-left:auto}.sabbath-confirm-details{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#ffffff08;border-radius:8px;margin-bottom:1.25rem}.sabbath-detail-row{display:flex;align-items:flex-start;gap:.625rem;font-size:.875rem;color:var(--text-secondary);line-height:1.4}.sabbath-detail-row strong{color:#f3f4f6}.sabbath-detail-row svg{margin-top:2px;min-width:16px}.sabbath-holiday-form{margin-bottom:1.25rem}.sabbath-form-group{margin-bottom:.75rem}.sabbath-form-group label{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:.375rem;font-weight:500}.sabbath-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.sabbath-holiday-form .form-input{background:#1e2530;border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:.5rem .75rem;color:var(--text-primary);font-size:.875rem;width:100%}.sabbath-holiday-form .form-input:focus{outline:none;border-color:#7c3aed}.sabbath-holiday-form input[type=date]::-webkit-calendar-picker-indicator,.sabbath-holiday-form input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.sabbath-day-count{font-size:.8rem;color:#a78bfa;padding:.5rem .75rem;background:#8b5cf61a;border-radius:6px;margin-bottom:.75rem}.sabbath-advanced-toggle{display:flex;align-items:center;gap:.375rem;background:none;border:none;color:var(--accent);font-size:.8rem;cursor:pointer;padding:.375rem 0;margin-bottom:.5rem}.sabbath-advanced-toggle:hover{color:#a78bfa}.sabbath-advanced-toggle svg{transition:transform .2s}.sabbath-advanced-toggle svg.rotated{transform:rotate(90deg)}.sabbath-time-grid{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;background:#ffffff05;border-radius:8px;border:1px solid rgba(255,255,255,.06);margin-bottom:.75rem}.sabbath-time-section{display:flex;flex-direction:column;gap:.375rem}.sabbath-time-label{font-size:.75rem;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.03em}.sabbath-active-info{margin-bottom:1.25rem}.sabbath-status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;margin-bottom:1rem}.sabbath-status-badge.active{background:#86efac26;color:#86efac}.sabbath-holiday-info{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem;background:#ffffff08;border-radius:8px;margin-bottom:.75rem}.sabbath-info-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.sabbath-info-label{color:var(--text-secondary)}.sabbath-info-row span:last-child{color:var(--text-primary);font-weight:500}.sabbath-next-action{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#fcd34d;padding:.5rem .75rem;background:#fbbf2414;border-radius:6px}.sabbath-next-time{margin-left:auto;color:#fcd34d;font-weight:500}.sabbath-modal-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.06)}.sabbath-modal-actions .btn{display:flex;align-items:center;gap:.375rem;padding:.625rem 1.25rem;font-weight:500;border-radius:8px}@media(max-width:640px){.sabbath-modal{max-width:100%;margin:.5rem;padding:1.25rem}.sabbath-form-row{grid-template-columns:1fr 1fr;gap:.5rem}.sabbath-modal-actions{flex-direction:column-reverse}.sabbath-modal-actions .btn{width:100%;justify-content:center}.sabbath-mode-card{padding:.875rem}.sabbath-mode-card-icon{width:40px;height:40px;min-width:40px}}.modal-overlay{padding-top:calc(1.5rem + env(safe-area-inset-top,20px));padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,20px));align-items:flex-start;overflow-y:auto;-webkit-overflow-scrolling:touch}.sabbath-modal{margin-top:calc(1rem + env(safe-area-inset-top,20px));margin-bottom:1rem;max-height:none;overflow-y:visible}.sabbath-modal .modal-close{top:.75rem;right:.75rem;z-index:10}.sabbath-modal-header{padding-top:.5rem;margin-right:2rem}@media(max-width:640px){.sabbath-modal{margin:calc(.75rem + env(safe-area-inset-top,20px)) .75rem .75rem;padding:1.25rem 1rem}.sabbath-holiday-form .sabbath-form-group{margin-bottom:.625rem}.sabbath-holiday-form .form-input{font-size:16px}.sabbath-time-grid{padding:.625rem}.sabbath-time-grid .sabbath-form-row{gap:.5rem}.sabbath-time-grid .form-input{font-size:16px;padding:.5rem}}.sabbath-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;z-index:1000;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:calc(2rem + env(safe-area-inset-top,20px)) 1rem calc(1.5rem + env(safe-area-inset-bottom,20px))}.sabbath-overlay .sabbath-modal{max-width:480px;width:100%;background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem;position:relative;margin:0 auto;box-shadow:var(--shadow-sm)}.sabbath-overlay .modal-close{position:absolute;top:1rem;right:1rem;z-index:10;color:var(--text-secondary);padding:.25rem;border-radius:6px;background:none;border:none;cursor:pointer}.sabbath-overlay .modal-close:hover{background:#ffffff1a}@media(max-width:640px){.sabbath-overlay{padding:calc(1rem + env(safe-area-inset-top,20px)) .5rem calc(1rem + env(safe-area-inset-bottom,20px))}.sabbath-overlay .sabbath-modal{padding:1.25rem 1rem;border-radius:12px}.sabbath-overlay .sabbath-holiday-form .form-input,.sabbath-overlay .sabbath-time-grid .form-input{font-size:16px}}.sabbath-holiday-form{overflow:hidden;width:100%}.sabbath-holiday-form .sabbath-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;width:100%;min-width:0}.sabbath-holiday-form .sabbath-form-group{min-width:0;overflow:hidden}.sabbath-holiday-form .form-input{width:100%;min-width:0;box-sizing:border-box}.sabbath-modal{overflow:hidden;box-sizing:border-box}.sabbath-modal *{box-sizing:border-box}.sabbath-time-grid .sabbath-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;width:100%;min-width:0}.sabbath-overlay{overflow-y:scroll!important;-webkit-overflow-scrolling:touch!important;padding-bottom:calc(6rem + env(safe-area-inset-bottom,20px))!important}.sabbath-overlay .sabbath-modal{flex-shrink:0;margin-bottom:2rem}.sabbath-overlay{display:block!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;text-align:center;padding:calc(1.5rem + env(safe-area-inset-top,20px)) .75rem calc(6rem + env(safe-area-inset-bottom,20px))!important}.sabbath-overlay .sabbath-modal{display:inline-block;text-align:left;vertical-align:top;margin:0 auto;flex-shrink:unset}.sabbath-scroll-wrap{width:100%;min-height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;justify-content:center;align-items:flex-start;padding:calc(1.5rem + env(safe-area-inset-top,20px)) .75rem calc(6rem + env(safe-area-inset-bottom,20px))}.sabbath-holiday-form input[type=date],.sabbath-holiday-form input[type=time]{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#1e2530;border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:.5rem .75rem;color:var(--text-primary);font-size:16px;width:100%;box-sizing:border-box;outline:none}.sabbath-holiday-form input[type=date]:focus,.sabbath-holiday-form input[type=time]:focus{border-color:#7c3aed}.sabbath-time-grid input[type=time]{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#1e2530;border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:.5rem .75rem;color:var(--text-primary);font-size:16px;width:100%;box-sizing:border-box;outline:none}.reader-card.held-open{border-left:4px solid #ef4444;background:linear-gradient(90deg,rgba(239,68,68,.12) 0%,transparent 40%);animation:pulse-held 2s ease-in-out infinite}@keyframes pulse-held{0%,to{background:linear-gradient(90deg,rgba(239,68,68,.12) 0%,transparent 40%)}50%{background:linear-gradient(90deg,rgba(239,68,68,.25) 0%,transparent 40%)}}.sabbath-active-info{display:flex;flex-direction:column;align-items:center}.sabbath-active-info .sabbath-holiday-info,.sabbath-active-info .sabbath-next-action{width:100%}.sabbath-fr-now-toggle{display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;background:#ef44440f;border:1px solid rgba(239,68,68,.2);border-radius:8px;cursor:pointer;margin-bottom:.75rem;font-size:.85rem;color:var(--text-secondary)}.sabbath-fr-now-toggle:hover{background:#ef44441a}.sabbath-fr-now-toggle input[type=checkbox]{width:18px;height:18px;accent-color:#ef4444;cursor:pointer;flex-shrink:0}.sabbath-status-badge.scheduled{background:#fbbf2426;color:#fbbf24}.diag-root{display:flex;flex-direction:column;gap:0}.diag-subtabs{display:flex;gap:4px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:20px}.diag-subtab{display:flex;align-items:center;gap:7px;padding:10px 18px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-tertiary);cursor:pointer;font-size:13px;font-weight:500;transition:all .2s;white-space:nowrap}.diag-subtab:hover{color:var(--text-secondary);background:#ffffff0a}.diag-subtab.active{color:var(--accent);border-bottom-color:var(--accent)}.diag-section{display:flex;flex-direction:column;gap:12px}.diag-section-subtitle{font-size:14px;font-weight:600;color:var(--text-secondary);margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.07)}.diag-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.diag-toolbar-wrap{flex-wrap:wrap}.diag-search{flex:1;min-width:180px;display:flex;align-items:center;gap:8px;background:#1a1f2b;border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:0 12px;height:36px;color:var(--text-tertiary)}.diag-search input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:13px}.diag-search input::placeholder{color:#4b5563}.diag-clear-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;padding:0}.diag-clear-btn:hover{color:var(--text-primary)}.diag-select,.diag-input{height:36px;padding:0 10px;background:#1a1f2b;border:1px solid rgba(255,255,255,.12);border-radius:6px;color:var(--text-primary);font-size:13px;cursor:pointer}.diag-select:focus,.diag-input:focus{outline:none;border-color:var(--accent)}.diag-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.diag-status-badge{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.diag-status-badge.connected{background:#34d39926;color:#34d399}.diag-status-badge.disconnected{background:#f8717126;color:#f87171}.diag-line-count{font-size:12px;color:var(--text-tertiary);white-space:nowrap}.diag-filter-badge{font-size:12px;color:var(--text-secondary);background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:6px 12px}.diag-filter-badge code{background:#00d4aa26;color:var(--accent);padding:1px 6px;border-radius:4px;font-size:12px}.diag-log-terminal{background:#0d1117;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:12px 16px;height:480px;overflow-y:auto;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:12px;line-height:1.7;scroll-behavior:smooth}.diag-log-terminal::-webkit-scrollbar{width:6px}.diag-log-terminal::-webkit-scrollbar-track{background:transparent}.diag-log-terminal::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.diag-log-line{word-break:break-all;white-space:pre-wrap}.diag-log-empty{color:#4b5563;text-align:center;margin-top:60px;font-size:13px}.diag-table-meta{font-size:12px;color:var(--text-tertiary)}.diag-table-wrap{border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:hidden;overflow-x:auto}.diag-table{width:100%;border-collapse:collapse;font-size:13px}.diag-table th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap}.diag-table td{padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text-secondary);vertical-align:middle}.diag-table-row{cursor:pointer;transition:background .15s}.diag-table-row:hover{background:#ffffff0a}.diag-expand-row td{background:#0d1117;padding:0}.diag-table-sm td,.diag-table-sm th{padding:7px 12px;font-size:12px}.diag-json-pre{margin:0;padding:12px 16px;font-family:SF Mono,Fira Code,monospace;font-size:11px;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all}.diag-empty-cell{text-align:center;color:#4b5563;padding:40px!important}.diag-mono{font-family:SF Mono,monospace;font-size:12px}.diag-muted{color:var(--text-tertiary)}.diag-action-cell{color:var(--text-primary);font-weight:500}.diag-severity-badge{padding:2px 8px;border-radius:4px;border:1px solid;font-size:11px;font-weight:600;letter-spacing:.3px}.diag-pagination{display:flex;align-items:center;gap:12px;justify-content:flex-end;font-size:13px;color:var(--text-secondary)}.diag-health-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.diag-health-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;overflow:hidden}.diag-health-card-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.06);color:var(--text-secondary)}.diag-health-card-title{font-weight:600;font-size:14px;color:var(--text-primary)}.diag-health-integrations{padding:8px 0}.diag-health-row{display:flex;align-items:center;gap:10px;padding:8px 16px;transition:background .15s}.diag-health-row:hover{background:#ffffff0a}.diag-health-type{font-size:13px;font-weight:500;color:var(--text-secondary)}.diag-latency{font-size:11px;color:#34d399;font-family:monospace}.diag-check-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;color:var(--text-secondary);transition:all .2s;flex-shrink:0}.diag-check-btn:hover:not(:disabled){background:#ffffff1a;color:var(--text-primary)}.diag-check-btn:disabled{opacity:.5;cursor:not-allowed}.diag-health-error-row{display:flex;align-items:flex-start;gap:6px;padding:6px 16px;font-size:11px;color:#f87171;background:#f871710f;border-top:1px solid rgba(248,113,113,.15)}.diag-agents-list{display:flex;flex-direction:column;gap:6px}.diag-agent-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:8px;font-size:13px}.diag-agent-name{font-weight:600;color:var(--text-primary)}.diag-agent-cards{display:flex;flex-direction:column;gap:10px}.diag-agent-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:10px;overflow:hidden}.diag-agent-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;transition:background .15s}.diag-agent-card-header:hover{background:#ffffff0a}.diag-agent-card-title{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text-primary)}.diag-agent-card-meta{display:flex;align-items:center;gap:14px;font-size:12px}.diag-known-issues{padding:0 16px 10px;display:flex;flex-direction:column;gap:6px}.diag-issue{display:flex;align-items:flex-start;gap:7px;padding:7px 12px;border-radius:6px;font-size:12px;line-height:1.4}.diag-issue-warning{background:#fbbf2414;color:#fbbf24;border:1px solid rgba(251,191,36,.2)}.diag-issue-error{background:#f8717114;color:#f87171;border:1px solid rgba(248,113,113,.2)}.diag-agent-detail{border-top:1px solid rgba(255,255,255,.06)}.diag-agent-section{padding:14px 16px}.diag-agent-section+.diag-agent-section{border-top:1px solid rgba(255,255,255,.05)}.diag-agent-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:10px}.diag-loading{display:flex;justify-content:center;align-items:center;padding:60px}.diag-spinner{width:28px;height:28px;border:2px solid rgba(0,212,170,.2);border-top-color:var(--accent);border-radius:50%;animation:diagSpin .8s linear infinite}.diag-spinner-sm{width:12px;height:12px;border-width:1.5px}@keyframes diagSpin{to{transform:rotate(360deg)}}.diag-empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px;color:#4b5563}.diag-empty-state p{margin:0;font-size:14px}@media(max-width:768px){.diag-subtab span{display:none}.diag-subtab{padding:10px 14px}.diag-health-grid{grid-template-columns:1fr}.diag-log-terminal{height:340px}.diag-toolbar{flex-wrap:wrap}.diag-agent-card-meta{display:none}}@media(max-width:480px){.diag-table th:nth-child(n+4),.diag-table td:nth-child(n+4){display:none}}.md-add-device-modal{max-width:680px;width:95vw;max-height:85vh;display:flex;flex-direction:column}.md-add-device-body{overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.md-add-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.md-add-form-row-3{grid-template-columns:1fr 1fr 1fr}.md-add-form-group{display:flex;flex-direction:column;gap:.35rem}.md-add-form-group label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;display:flex;align-items:center;gap:.35rem}.md-add-form-group label .required{color:var(--accent-red, #ef4444)}.md-add-form-group input,.md-add-form-group select,.md-add-form-group textarea{background:var(--bg-page);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);padding:.55rem .75rem;font-size:.875rem;transition:border-color .2s}.md-add-form-group input:focus,.md-add-form-group select:focus,.md-add-form-group textarea:focus{outline:none;border-color:var(--accent-blue, #4299e1);box-shadow:0 0 0 2px #4299e126}.md-add-form-group.has-error input,.md-add-form-group.has-error select{border-color:var(--accent-red, #ef4444)}.md-add-form-group textarea{resize:vertical;min-height:60px;font-family:inherit}.md-add-error{font-size:.75rem;color:var(--accent-red, #ef4444)}.md-add-hint{font-size:.72rem;color:var(--text-tertiary);font-style:italic}.md-add-input-with-status{position:relative;display:flex;align-items:center}.md-add-input-with-status input{width:100%;padding-right:2rem}.md-add-ip-icon{position:absolute;right:.6rem;color:var(--text-tertiary)}.md-add-ip-icon.success{color:var(--accent-green, #48bb78)}.md-add-ip-icon.warning{color:var(--accent-yellow, #ecc94b)}.md-add-ip-icon.error{color:var(--accent-red, #ef4444)}.md-add-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.md-add-type-card{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.55rem .35rem;background:var(--bg-page);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .15s;font-size:.72rem;font-weight:500}.md-add-type-card:hover{border-color:var(--accent-blue, #4299e1);color:var(--text-primary);background:#4299e10f}.md-add-type-card.active{border-color:var(--accent-blue, #4299e1);background:#4299e11f;color:var(--accent-blue, #4299e1);box-shadow:0 0 0 1px var(--accent-blue, #4299e1)}.md-add-type-more{margin-top:.35rem}.md-add-type-more select{background:var(--bg-page);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);padding:.4rem .6rem;font-size:.8rem;cursor:pointer}.md-add-advanced-toggle{background:none;border:none;color:var(--accent-blue, #4299e1);cursor:pointer;font-size:.8rem;padding:.25rem 0;text-align:left;opacity:.85;transition:opacity .15s}.md-add-advanced-toggle:hover{opacity:1}.md-add-advanced{display:flex;flex-direction:column;gap:.85rem;padding:.85rem;background:var(--bg-page);border:1px solid var(--border);border-radius:8px}@media(max-width:768px){.md-add-device-modal{max-width:100%;margin:.5rem}.md-add-form-row,.md-add-form-row-3{grid-template-columns:1fr}.md-add-type-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:480px){.md-add-type-grid{grid-template-columns:repeat(2,1fr)}}.md-add-form-row-3 .md-add-form-group label{min-height:2.4em;display:flex;align-items:flex-end}.md-add-unreachable-banner{margin:0 1.5rem;padding:1rem;background:#ef444414;border:1px solid rgba(239,68,68,.3);border-radius:8px}.md-add-unreachable-content{display:flex;gap:.75rem;align-items:flex-start;color:#ff6b6b}.md-add-unreachable-content strong{display:block;margin-bottom:.25rem;color:#ff6b6b}.md-add-unreachable-content p{margin:0;font-size:.82rem;color:var(--text-secondary);line-height:1.4}.md-add-unreachable-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.75rem}.mdd-page{padding:1.5rem;max-width:1400px;margin:0 auto;animation:mddFadeIn .3s ease}@keyframes mddFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mdd-loading,.mdd-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:400px;color:var(--text-secondary)}.mdd-loading .spin,.mdd-header-actions .spin{animation:spin 1s linear infinite}.mdd-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.mdd-header-left{display:flex;align-items:center;gap:.75rem}.mdd-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;transition:all .2s}.mdd-back-btn:hover{background:var(--bg-surface);color:var(--bg-surface);border-color:var(--accent);box-shadow:var(--shadow-sm)}.mdd-device-icon-wrap{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:14px;border:2px solid;background:var(--bg-surface)}.mdd-header-info{display:flex;flex-direction:column;gap:.25rem}.mdd-device-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.mdd-device-meta{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;font-size:.8rem}.mdd-ip{color:var(--text-secondary);font-family:SF Mono,Fira Code,monospace;font-size:.78rem}.mdd-hostname{color:var(--text-secondary)}.mdd-profile{background:var(--bg-surface);color:#78909c;padding:.1rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;box-shadow:var(--shadow-sm)}.mdd-status-pill{display:inline-flex;align-items:center;gap:4px;padding:.15rem .6rem;border-radius:20px;font-size:.75rem;font-weight:600;border:1px solid}.mdd-header-actions{display:flex;gap:.5rem}.mdd-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}.mdd-stat-card{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;transition:all .2s;box-shadow:var(--shadow-sm)}.mdd-stat-card:hover{border-color:#2a3045;background:var(--bg-surface)}.mdd-stat-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:var(--bg-surface);flex-shrink:0}.mdd-stat-body{display:flex;flex-direction:column}.mdd-stat-value{font-size:1.35rem;font-weight:700;color:var(--text-primary);line-height:1.2}.mdd-stat-value small{font-size:.7rem;color:var(--text-secondary);font-weight:400;margin-left:2px}.mdd-stat-label{font-size:.72rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.mdd-uptime-row{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem;margin-bottom:1.25rem;box-shadow:var(--shadow-sm)}.mdd-section-title{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.5px}.mdd-uptime-bars{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.mdd-uptime-item{display:flex;flex-direction:column;gap:.3rem}.mdd-uptime-label{font-size:.75rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase}.mdd-uptime-bar-track{height:6px;background:var(--bg-surface);border-radius:3px;overflow:hidden;box-shadow:var(--shadow-sm)}.mdd-uptime-bar-fill{height:100%;border-radius:3px;transition:width .6s ease}.mdd-uptime-pct{font-size:1.1rem;font-weight:700}.mdd-uptime-count{font-size:.7rem;color:var(--text-tertiary)}.mdd-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:1.25rem}.mdd-tab{padding:.6rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.mdd-tab:hover{color:var(--text-secondary)}.mdd-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.mdd-overview{display:flex;flex-direction:column;gap:1rem}.mdd-chart-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.mdd-chart-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem 0}.mdd-chart-header h3{font-size:.9rem;font-weight:600;color:var(--text-secondary);margin:0}.mdd-time-selector{display:flex;gap:.25rem}.mdd-time-btn{padding:.25rem .6rem;border-radius:6px;border:1px solid #2a2f3a;background:var(--bg-surface);color:var(--text-secondary);font-size:.72rem;cursor:pointer;transition:all .2s}.mdd-time-btn:hover{color:var(--text-secondary);border-color:#3a3f4a}.mdd-time-btn.active{background:var(--accent-alpha-15);color:var(--accent);border-color:var(--accent-alpha-15)}.mdd-chart-body{padding:1rem}.mdd-no-data{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-tertiary);font-size:.85rem}.mdd-status-timeline{padding:1rem 1.25rem}.mdd-status-blocks{display:flex;gap:1px;height:32px;border-radius:4px;overflow:hidden}.mdd-status-block{flex:1;min-width:2px;cursor:pointer;transition:opacity .15s;opacity:.85}.mdd-status-block:hover{opacity:1;transform:scaleY(1.15)}.mdd-table-wrap{overflow-x:auto}.mdd-table{width:100%;border-collapse:collapse;font-size:.82rem}.mdd-table th{padding:.6rem 1rem;text-align:left;color:var(--text-secondary);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--bg-surface);position:sticky;top:0}.mdd-table td{padding:.5rem 1rem;color:var(--text-secondary);border-bottom:1px solid var(--border)}.mdd-table tr:hover td{background:var(--bg-surface)}.mdd-table tr.poll-fail td{background:#ff174408}.mdd-poll-badge{display:inline-flex;align-items:center;padding:.1rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600}.mdd-poll-badge.success{background:#00c85320;color:#00c853}.mdd-poll-badge.fail{background:#ff174420;color:#ff1744}.mdd-error-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary);font-size:.78rem}.mdd-empty-state{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem;color:var(--text-secondary)}.mdd-alert-list{display:flex;flex-direction:column;gap:.5rem}.mdd-alert-card{padding:1rem 1.25rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;border-left:3px solid #ffaa00;box-shadow:var(--shadow-sm)}.mdd-alert-card.critical{border-left-color:#ff1744}.mdd-alert-card.warning{border-left-color:#fa0}.mdd-alert-card.info{border-left-color:#448aff}.mdd-alert-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem;color:var(--text-secondary);font-size:.8rem}.mdd-alert-type{font-weight:600;color:var(--text-secondary)}.mdd-alert-time{margin-left:auto;font-size:.75rem;color:var(--text-tertiary)}.mdd-alert-msg{margin:0;color:var(--text-secondary);font-size:.85rem}.mdd-alert-resolved{display:inline-block;margin-top:.4rem;font-size:.72rem;color:#00c853}.mdd-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.mdd-info-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem;box-shadow:var(--shadow-sm)}.mdd-info-section h3{font-size:.8rem;font-weight:600;color:var(--accent);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.5px}.mdd-info-section dl{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1rem;margin:0}.mdd-info-section dt{font-size:.78rem;color:var(--text-tertiary)}.mdd-info-section dd{font-size:.78rem;color:var(--text-secondary);margin:0;font-family:SF Mono,Fira Code,monospace}@media(max-width:768px){.mdd-page{padding:1rem}.mdd-stats-row,.mdd-uptime-bars{grid-template-columns:repeat(2,1fr)}.mdd-info-grid{grid-template-columns:1fr}.mdd-header{flex-direction:column;align-items:flex-start}.mdd-chart-header{flex-direction:column;gap:.5rem;align-items:flex-start}}@media(max-width:480px){.mdd-stats-row,.mdd-uptime-bars{grid-template-columns:1fr}}.mdd-camera-card{display:grid;grid-template-columns:1fr 1fr;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.mdd-camera-preview{position:relative;background:#0d1117;min-height:280px;display:flex;align-items:center;justify-content:center}.mdd-snapshot-img{width:100%;height:100%;object-fit:cover;display:block}.mdd-snapshot-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#555;font-size:.85rem}.mdd-camera-info{padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.mdd-camera-info h3{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:var(--text-secondary);margin:0}.mdd-camera-actions{display:flex;gap:.5rem;flex-wrap:wrap}.mdd-camera-details{display:flex;flex-direction:column;gap:.5rem}.mdd-cam-detail{display:flex;flex-direction:column;gap:.2rem}.mdd-cam-detail>span:first-child{font-size:.7rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.mdd-cam-detail code{font-size:.75rem;color:var(--text-secondary);background:var(--bg-surface);padding:.2rem .4rem;border-radius:4px;word-break:break-all;box-shadow:var(--shadow-sm)}.mdd-rtsp-list{display:flex;flex-direction:column;gap:.25rem}.mdd-rtsp-uri{font-size:.72rem;color:var(--accent);background:var(--accent-alpha-08);padding:.2rem .5rem;border-radius:4px;word-break:break-all}@media(max-width:768px){.mdd-camera-card{grid-template-columns:1fr}.mdd-camera-preview{min-height:200px}}.mdd-live-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:mddFadeIn .2s ease}.mdd-live-modal{width:90vw;max-width:960px;background:var(--bg-surface);border:1px solid #2a3045;border-radius:14px;overflow:hidden;box-shadow:0 24px 80px #0009}.mdd-live-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-bottom:1px solid var(--border)}.mdd-live-header h3{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0}.mdd-live-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:6px;transition:all .2s}.mdd-live-close:hover{color:#f44;background:#ff444415}.mdd-live-player{position:relative;width:100%;aspect-ratio:16 / 9;background:#0d1117}.mdd-live-player video{width:100%;height:100%;object-fit:contain}.mdd-stream-status{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;height:100%;color:var(--text-secondary);font-size:.85rem}.mdd-stream-status .spin{animation:mddSpin 1s linear infinite}@keyframes mddSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mdd-stream-error{color:#ff6b6b}.mdd-info-snmp{grid-column:1 / -1}.mdd-snmp-descr{word-break:break-word;font-family:SF Mono,Fira Code,monospace;font-size:.78rem}.mdd-snmp-oid{font-family:SF Mono,Fira Code,monospace;font-size:.78rem;color:var(--text-secondary)}.mdd-snmp-iface-table{width:100%;border-collapse:collapse;font-size:.8rem}.mdd-snmp-iface-table th{text-align:left;padding:6px 10px;font-size:.72rem;font-weight:600;text-transform:uppercase;color:var(--text-tertiary);border-bottom:1px solid var(--border)}.mdd-snmp-iface-table td{padding:5px 10px;border-bottom:1px solid var(--border)}.mdd-snmp-iface-table tr:hover{background:#ffffff08}.mdd-snmp-status{display:inline-block;padding:1px 8px;border-radius:10px;font-size:.72rem;font-weight:600}.mdd-snmp-status.up{background:#4caf5026;color:#4caf50}.mdd-snmp-status.down{background:#f4433626;color:#f44336}.mdd-snmp-health-card{border-left:3px solid #448aff}.mdd-snmp-poll-time{font-size:.75rem;color:var(--text-secondary)}.mdd-snmp-overview{display:flex;gap:2rem;padding:1rem 0;border-bottom:1px solid #2a2f3a;margin-bottom:1rem}.mdd-snmp-stat{display:flex;flex-direction:column;gap:4px}.mdd-snmp-stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.mdd-snmp-stat-value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.mdd-snmp-stat-value.mdd-snmp-ok{color:#00c853}.mdd-snmp-stat-value.mdd-snmp-warn{color:#ff4d4d}.mdd-snmp-subtitle{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:.75rem 0 .5rem}.mdd-snmp-ifaces{margin-bottom:1rem}.mdd-snmp-iface-table{width:100%;border-collapse:collapse;font-size:.85rem}.mdd-snmp-iface-table th{text-align:left;padding:6px 10px;color:var(--text-secondary);font-weight:500;border-bottom:1px solid #2a2f3a;font-size:.75rem;text-transform:uppercase}.mdd-snmp-iface-table td{padding:6px 10px;border-bottom:1px solid #1e2330;color:var(--text-secondary)}.mdd-iface-name{font-family:monospace;color:var(--text-primary)}.mdd-iface-status{font-weight:600;font-size:.8rem}.mdd-iface-status.up{color:#00c853}.mdd-iface-status.down{color:#ff4d4d}.mdd-snmp-flaps{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffaa001a;border:1px solid rgba(255,170,0,.3);border-radius:6px;color:#fa0;font-size:.85rem;margin-bottom:1rem}.mdd-snmp-chart{margin-top:.5rem}.mdd-iface-summary{display:flex;gap:8px;padding:10px 16px;border-top:1px solid #2a2f3a;flex-wrap:wrap}.mdd-iface-pill{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:.8rem;font-family:monospace;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary)}.mdd-iface-pill.up{border-color:#00c8534d}.mdd-iface-pill.down{border-color:#ff4d4d4d}.mdd-iface-dot{width:6px;height:6px;border-radius:50%}.mdd-iface-pill.up .mdd-iface-dot{background:#00c853}.mdd-iface-pill.down .mdd-iface-dot{background:#ff4d4d}.mdd-iface-speed{font-size:.7rem;color:var(--text-secondary)}.mdd-reboot-badge{display:inline-block;padding:2px 8px;margin-left:8px;background:#ff4d4d26;border:1px solid rgba(255,77,77,.3);border-radius:4px;color:#ff4d4d;font-size:.75rem;font-weight:600}.mdd-name-edit{display:flex;align-items:center;gap:6px}.mdd-name-edit .mdd-device-name{cursor:pointer}.mdd-name-edit .mdd-edit-icon{opacity:0;transition:opacity .2s;color:var(--text-secondary)}.mdd-name-edit:hover .mdd-edit-icon{opacity:.7}.mdd-name-input{font-size:1.25rem;font-weight:600;background:var(--bg-surface);border:1px solid var(--accent, var(--accent));border-radius:6px;color:var(--text-primary);padding:4px 10px;outline:none;width:280px;box-shadow:var(--shadow-sm)}.mdd-web-link{color:var(--accent, var(--accent));text-decoration:none;display:inline-flex;align-items:center;gap:4px;font-size:.85rem}.mdd-web-link:hover{text-decoration:underline;opacity:.9}.mdd-hardware{display:flex;flex-direction:column;gap:20px}.mdd-hw-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:16px;box-shadow:var(--shadow-sm)}.mdd-hw-section h3{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.mdd-hw-section h4{font-size:12px;font-weight:500;color:var(--text-secondary);margin:12px 0 6px}.mdd-hw-section dl{display:grid;grid-template-columns:140px 1fr;gap:6px 12px;font-size:13px}.mdd-hw-section dt{color:var(--text-tertiary)}.mdd-hw-section dd{color:var(--text-primary);margin:0}.mdd-hw-status{display:inline-block;font-size:11px;font-weight:500;padding:1px 8px;border-radius:4px;border:1px solid}.mdd-hw-power{font-weight:500}.mdd-hw-power.on{color:#00c853}.mdd-hw-power.off{color:#ff1744}.mdd-hw-table{width:100%;border-collapse:collapse;font-size:12px}.mdd-hw-table th{text-align:left;padding:6px 8px;font-weight:500;color:var(--text-tertiary);border-bottom:1px solid var(--border)}.mdd-hw-table td{padding:6px 8px;color:var(--text-primary);border-bottom:1px solid var(--border)}.mdd-hw-table tr:hover td{background:#ffffff05}.mdd-hw-storage-ctrl{margin-bottom:12px;padding:8px;background:var(--bg-page);border-radius:6px}.mdd-hw-ctrl-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.mdd-hw-ctrl-model,.mdd-hw-ctrl-fw{font-size:11px;color:var(--text-tertiary)}.mdd-hw-redundancy{font-size:12px;margin-bottom:8px;color:var(--text-secondary)}.mdd-hw-fans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.mdd-hw-fan-card{background:var(--bg-page);border-radius:6px;padding:10px;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}.mdd-hw-fan-name{font-size:11px;color:var(--text-tertiary)}.mdd-hw-fan-rpm{font-size:16px;font-weight:600;color:var(--text-primary)}.mdd-hw-temp.ok{color:#00c853}.mdd-hw-temp.warn{color:#fa0}.mdd-hw-temp.critical{color:#ff1744;font-weight:600}.mdd-hw-evt-time{white-space:nowrap;font-size:11px;color:var(--text-tertiary)}.mdd-hw-events td{font-size:12px}.mdp-container{display:flex;flex-direction:column;height:100%;background:var(--bg-page)}.mdp-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--bg-surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}.mdp-toolbar-left{display:flex;align-items:center;gap:16px}.mdp-back-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:none;background:#ffffff0f;border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:13px;transition:all .15s}.mdp-back-btn:hover{background:#ffffff1a;color:var(--text-primary)}.mdp-device-info{display:flex;flex-direction:column}.mdp-device-name{font-size:15px;font-weight:600;color:var(--text-primary)}.mdp-device-addr{font-size:12px;color:var(--text-tertiary);font-family:SF Mono,monospace}.mdp-status{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:16px;background:color-mix(in srgb,var(--status-color) 12%,transparent);color:var(--status-color);font-size:12px;font-weight:500}.mdp-content{flex:1;padding:24px;overflow-y:auto}.mdp-error-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px;text-align:center;color:var(--text-secondary);background:var(--bg-surface);border-radius:12px;border:1px solid var(--border);max-width:480px;margin:48px auto;box-shadow:var(--shadow-sm)}.mdp-error-card h3{color:var(--text-primary);margin:0}.mdp-error-card p{margin:0;line-height:1.6;max-width:360px}.mdp-panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:20px;max-width:900px}.mdp-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow-sm)}.mdp-panel h3{display:flex;align-items:center;gap:8px;margin:0 0 8px;font-size:15px;color:var(--text-primary)}.mdp-panel-desc{color:var(--text-secondary);font-size:13px;margin:0 0 16px;line-height:1.5}.mdp-port-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.mdp-port-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.mdp-port-btn:hover{background:#0096ff14;border-color:#0096ff4d;color:#60a5fa}.mdp-port-btn.active{background:#00c85314;border-color:#00c8534d;color:#00c853}.mdp-port-label{font-size:14px;font-weight:600}.mdp-port-proto{font-size:10px;text-transform:uppercase;opacity:.6}.mdp-probe-info{display:flex;flex-direction:column;gap:8px}.mdp-probe-row{display:flex;justify-content:space-between;font-size:13px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04)}.mdp-probe-row span:first-child{color:var(--text-secondary)}.mdp-probe-row span:last-child{color:var(--text-primary);font-family:SF Mono,monospace;font-size:12px}.mdp-probe-status.ok{color:#00c853}.mdp-probe-status.err{color:#ff1744}.mdp-probe-redirect{color:#60a5fa!important}.mdp-probe-error{display:flex;align-items:center;gap:8px;color:#ff6d00;font-size:13px;padding:10px;background:#ff6d000f;border-radius:8px}@media(max-width:768px){.mdp-content{padding:16px}.mdp-panels{grid-template-columns:1fr}.mdp-port-grid{grid-template-columns:repeat(3,1fr)}}.mdp-port-external{position:absolute;top:8px;right:8px;opacity:.3}.mdp-port-btn{position:relative;text-decoration:none}.mdp-port-btn:hover .mdp-port-external{opacity:.7}.mdp-url-preview{margin-top:16px;padding:12px;background:#ffffff08;border-radius:8px;font-size:12px;display:flex;align-items:center;gap:8px}.mdp-url-label{color:var(--text-tertiary);white-space:nowrap}.mdp-url-preview a{color:#60a5fa;text-decoration:none;font-family:SF Mono,monospace;word-break:break-all}.mdp-url-preview a:hover{text-decoration:underline}.dd-container{padding:1.5rem;max-width:1200px;margin:0 auto}.dd-loading,.dd-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:400px;color:var(--text-secondary)}.dd-not-found h2{color:var(--text-primary)}.dd-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.dd-back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:.875rem;transition:all .15s;box-shadow:var(--shadow-sm)}.dd-back-btn:hover{color:var(--text-primary);border-color:var(--accent, #3b82f6)}.dd-refresh-btn{padding:.5rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm)}.dd-refresh-btn:hover{color:var(--accent, #3b82f6)}.dd-refresh-btn.spinning svg{animation:dd-spin 1s linear infinite}.dd-identity-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.dd-identity-top{display:flex;align-items:flex-start;gap:1.25rem}.dd-device-icon{width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dd-identity-info{flex:1;min-width:0}.dd-device-name{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem;word-break:break-all}.dd-identity-meta{display:flex;flex-wrap:wrap;gap:.5rem}.dd-status-pill,.dd-type-pill,.dd-mfg-pill,.dd-model-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .6rem;border-radius:6px;font-size:.75rem;font-weight:500}.dd-type-pill{background:var(--bg-page);color:var(--text-secondary)}.dd-mfg-pill{background:#3b82f620;color:#60a5fa}.dd-model-pill{background:#8b5cf620;color:#a78bfa}.dd-confidence-section{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border)}.dd-confidence-badge{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary)}.dd-confidence-bar-track{flex:1;max-width:200px;height:6px;background:var(--bg-page);border-radius:3px;overflow:hidden}.dd-confidence-bar-fill{height:100%;border-radius:3px;transition:width .3s}.dd-confidence-score{font-weight:700;font-size:1rem;color:var(--conf-color)}.dd-confidence-label{font-size:.75rem;color:var(--text-dim, var(--text-tertiary))}.dd-confidence-reasons{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.75rem}.dd-reason-tag{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;background:var(--bg-page);border:1px solid var(--border);border-radius:6px;font-size:.7rem;color:var(--text-secondary)}.dd-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:768px){.dd-grid{grid-template-columns:1fr}}.dd-section{background:var(--bg-surface);border:.5px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm)}.dd-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.875rem 1rem;background:none;border:none;color:var(--text-primary);cursor:pointer;font-size:.875rem;font-weight:600;transition:background .15s}.dd-section-header:hover{background:var(--bg-page)}.dd-section-title{display:flex;align-items:center;gap:.5rem}.dd-section-count{background:var(--accent, #3b82f6);color:var(--text-primary);font-size:.65rem;padding:.1rem .4rem;border-radius:4px;font-weight:700}.dd-section-body{padding:0 1rem 1rem}.dd-info-row{display:flex;justify-content:space-between;align-items:baseline;padding:.4rem 0;border-bottom:1px solid rgba(51,65,85,.2);font-size:.8rem;gap:1rem}.dd-info-row:last-child{border-bottom:none}.dd-info-label{color:var(--text-dim, var(--text-tertiary));white-space:nowrap;flex-shrink:0}.dd-info-value{color:var(--text-primary);text-align:right;word-break:break-all;min-width:0}.dd-info-link{color:var(--accent, #3b82f6);text-decoration:none;display:inline-flex;align-items:center;gap:.25rem}.dd-info-link:hover{text-decoration:underline}.dd-mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:.75rem}.dd-sub-section{margin-top:.75rem;padding-top:.5rem;border-top:1px solid rgba(51,65,85,.4)}.dd-sub-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}.dd-table-mini{font-size:.75rem}.dd-table-header{display:grid;grid-template-columns:1fr 1fr 1fr .5fr;gap:.5rem;padding:.4rem 0;color:var(--text-dim, var(--text-tertiary));border-bottom:1px solid var(--border);font-weight:600}.dd-table-row{display:grid;grid-template-columns:1fr 1fr 1fr .5fr;gap:.5rem;padding:.35rem 0;color:var(--text-primary);border-bottom:1px solid rgba(51,65,85,.2)}.dd-hw-card{background:var(--bg-page);border-radius:8px;padding:.75rem;margin-bottom:.5rem}.dd-drive-row{display:flex;justify-content:space-between;padding:.3rem .5rem;font-size:.75rem;color:var(--text-primary)}.dd-vdrive{background:var(--bg-page);border-radius:4px;margin-top:.25rem}.dd-temp-row{display:flex;gap:1rem;align-items:center;padding:.3rem 0;font-size:.8rem;color:var(--text-primary)}.dd-temp-row span:first-child{flex:1;color:var(--text-secondary)}.dd-json-block{background:var(--bg-page);border-radius:6px;padding:.75rem;font-family:JetBrains Mono,monospace;font-size:.7rem;color:var(--text-secondary);overflow-x:auto;white-space:pre-wrap;word-break:break-all;max-height:300px}.dd-text-green{color:#00c853}.dd-text-red{color:#ff1744}.dd-text-dim{color:var(--text-dim, var(--text-tertiary))}@keyframes dd-spin{to{transform:rotate(360deg)}}.spin{animation:dd-spin 1s linear infinite}@media(max-width:480px){.dd-container{padding:1rem}.dd-device-name{font-size:1.2rem}.dd-identity-top{flex-direction:column;align-items:center;text-align:center}.dd-identity-meta{justify-content:center}.dd-info-row{flex-direction:column;gap:.2rem}.dd-info-value{text-align:left}}.ops-tab-bar{display:flex;gap:4px;background:var(--bg-surface);border-radius:var(--radius-lg, 12px);padding:4px;margin-bottom:24px;margin-top:20px;border:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-sm)}.ops-tab{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md, 8px);font-size:14px;font-weight:600;background:transparent;color:var(--text-tertiary);border:1px solid transparent;white-space:nowrap;flex:1;transition:all .15s ease;cursor:pointer}.ops-tab:hover{color:var(--text-secondary);background:#ffffff08}.ops-tab.active{background:var(--bg-page);color:var(--text-primary);border-color:var(--border)}.ops-tab-badge{padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700;min-width:22px;text-align:center;line-height:1.4}.ops-tab-content{animation:opsFadeIn .2s ease}@keyframes opsFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.ops-stats-grid{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.ops-stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md, 10px);padding:16px 20px;display:flex;align-items:center;gap:14px;flex:1;min-width:150px;transition:border-color .15s ease;box-shadow:var(--shadow-sm)}.ops-stat-card:hover{border-color:var(--border)}.ops-stat-icon{width:40px;height:40px;border-radius:var(--radius-md, 10px);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ops-stat-content{display:flex;flex-direction:column}.ops-stat-value{font-size:22px;font-weight:700;color:var(--text-primary);line-height:1.1}.ops-stat-label{font-size:12px;color:var(--text-tertiary);margin-top:2px}.ops-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.ops-filter-tabs{display:flex;gap:6px;flex-wrap:wrap}.ops-filter-btn{padding:7px 14px;border-radius:var(--radius-md, 8px);font-size:13px;font-weight:500;background:var(--bg-page);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;transition:all .15s ease}.ops-filter-btn:hover{background:var(--bg-surface);color:var(--text-primary)}.ops-filter-btn.active{background:var(--accent);color:var(--bg-page);border-color:var(--accent);font-weight:600}.ops-search-wrapper{display:flex;align-items:center;gap:8px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md, 8px);padding:0 12px;color:var(--text-tertiary)}.ops-search-input{background:transparent;border:none;outline:none;color:var(--text-primary);font-size:13px;padding:8px 0;width:180px;font-family:inherit}.ops-search-input::placeholder{color:var(--text-tertiary)}.ops-empty-state{text-align:center;padding:60px 20px;color:var(--text-tertiary)}.ops-empty-state svg{margin-bottom:16px;opacity:.4}.ops-empty-state h3{font-size:18px;color:var(--text-secondary);margin-bottom:8px}.ops-empty-state p{font-size:14px;margin-bottom:20px}.ops-alerts-list{display:flex;flex-direction:column;gap:10px}.ops-alert-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md, 10px);padding:16px;border-left:3px solid;transition:border-color .15s ease;box-shadow:var(--shadow-sm)}.ops-alert-card:hover{border-color:var(--border)}.ops-alert-card.resolved{opacity:.6}.ops-alert-main{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}.ops-alert-info{flex:1;min-width:200px}.ops-alert-header{display:flex;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap}.ops-alert-title{font-weight:600;font-size:14px;color:var(--text-primary)}.ops-acked-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;background:#22c55e1f;color:#22c55e}.ops-alert-message{font-size:13px;color:var(--text-secondary);margin-bottom:6px;line-height:1.5}.ops-alert-meta{display:flex;gap:16px;flex-wrap:wrap}.ops-alert-meta span{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-tertiary)}.ops-alert-actions{display:flex;gap:6px;flex-shrink:0}.ops-action-btn{display:flex;align-items:center;gap:4px;padding:6px 14px;border-radius:var(--radius-sm, 6px);font-size:12px;background:var(--bg-page);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;transition:all .15s ease;white-space:nowrap}.ops-action-btn:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border);box-shadow:var(--shadow-sm)}.ops-action-btn.resolve{background:#22c55e14;color:#22c55e;border-color:#22c55e33}.ops-action-btn.resolve:hover{background:#22c55e26;border-color:#22c55e66}.ops-action-btn.success{color:#22c55e}.ops-action-btn.success:hover{background:#22c55e1a;border-color:#22c55e4d}.ops-action-btn.danger{color:var(--text-secondary)}.ops-action-btn.danger:hover{background:#ef44441a;border-color:#ef44444d;color:var(--accent-danger, #ef4444)}.ops-rules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px}.ops-rule-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg, 12px);padding:18px;display:flex;flex-direction:column;gap:12px;transition:all .2s ease;box-shadow:var(--shadow-sm)}.ops-rule-card:hover{border-color:var(--border);box-shadow:0 4px 20px #0000004d}.ops-rule-card.disabled{opacity:.5}.ops-rule-card.disabled:hover{opacity:.65}.ops-rule-header{display:flex;align-items:flex-start;gap:12px}.ops-rule-icon{width:40px;height:40px;border-radius:var(--radius-md, 8px);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ops-rule-info{flex:1;min-width:0}.ops-rule-name{font-size:15px;font-weight:600;color:var(--text-primary);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ops-rule-type{font-size:12px;color:var(--text-tertiary);text-transform:capitalize}.ops-rule-desc{font-size:13px;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ops-rule-meta{display:flex;flex-wrap:wrap;gap:12px;padding-top:10px;border-top:1px solid var(--border)}.ops-rule-meta span{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-tertiary)}.ops-rule-actions{display:flex;gap:8px;margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}.ops-rule-actions .ops-action-btn{flex:1;justify-content:center}.ops-agents-list{display:flex;flex-direction:column;gap:12px}.ops-agent-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg, 12px);padding:20px;transition:border-color .15s ease;box-shadow:var(--shadow-sm)}.ops-agent-card:hover{border-color:var(--border)}.ops-agent-main{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.ops-agent-status-icon{width:48px;height:48px;border-radius:var(--radius-md, 10px);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ops-agent-status-icon.online{background:#22c55e1f;color:#22c55e}.ops-agent-status-icon.offline{background:#ef44441f;color:#ef4444}.ops-agent-info{flex:1;min-width:150px}.ops-agent-name{font-weight:600;font-size:15px;color:var(--text-primary);margin-bottom:2px}.ops-agent-sub{font-size:12px;color:var(--text-tertiary)}.ops-status-pill{padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;flex-shrink:0}.ops-status-pill.online{background:#22c55e1f;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.ops-status-pill.offline{background:#ef44441f;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.ops-agent-details{display:flex;flex-wrap:wrap;gap:20px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.ops-agent-detail{display:flex;flex-direction:column;gap:2px}.ops-detail-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.ops-detail-value{font-size:13px;color:var(--text-secondary);font-weight:500}.ops-detail-value.code{font-family:JetBrains Mono,monospace;color:var(--accent);cursor:pointer;display:flex;align-items:center;gap:6px}.ops-detail-value.code:hover{color:var(--bg-surface)}.ops-agent-actions{display:flex;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.ops-downloads-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg, 12px);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.ops-downloads-header{margin-bottom:16px}.ops-downloads-header h3{font-size:16px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px;margin-bottom:4px}.ops-downloads-header p{font-size:13px;color:var(--text-tertiary)}.ops-downloads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}.ops-download-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md, 8px);color:var(--text-secondary);text-decoration:none;transition:all .15s ease;cursor:pointer}.ops-download-card:hover{background:var(--bg-surface);border-color:var(--accent);color:var(--text-primary);box-shadow:var(--shadow-sm)}.ops-download-icon{font-size:24px;flex-shrink:0}.ops-download-info{flex:1;min-width:0}.ops-download-info strong{display:block;font-size:13px;color:var(--text-primary);margin-bottom:1px}.ops-download-info span{font-size:11px;color:var(--text-tertiary)}.ops-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:opsFadeIn .15s ease}.ops-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl, 16px);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-sm)}.ops-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.ops-modal-header h2{font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px}.ops-modal-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px}.ops-modal-close:hover{color:var(--text-primary)}.ops-modal-body{padding:24px}.ops-form-field{margin-bottom:16px}.ops-form-field label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.ops-input{width:100%;padding:10px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md, 8px);color:var(--text-primary);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s ease}.ops-input:focus{border-color:var(--accent)}.ops-input::placeholder{color:var(--text-tertiary)}.ops-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.ops-pair-success{text-align:center;padding:20px 0}.ops-pair-success h3{font-size:18px;color:var(--text-primary);margin:16px 0 8px}.ops-pair-success p{font-size:14px;color:var(--text-secondary)}.ops-pairing-code{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;margin:16px 0;background:var(--bg-page);border:2px solid var(--accent);border-radius:var(--radius-lg, 12px);font-family:JetBrains Mono,monospace;font-size:28px;font-weight:700;color:var(--accent);letter-spacing:4px;cursor:pointer;transition:all .15s ease}.ops-pairing-code:hover{background:#00d4aa14}.ops-pair-hint{font-size:12px;color:var(--text-tertiary)}.md-severity-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid;white-space:nowrap}@media(max-width:768px){.ops-tab-bar{margin-top:16px;margin-bottom:16px}.ops-tab{padding:10px 12px;font-size:13px;gap:6px}.ops-stats-grid{gap:8px}.ops-stat-card{min-width:120px;padding:12px 14px}.ops-stat-value{font-size:18px}.ops-toolbar{flex-direction:column;align-items:stretch}.ops-filter-tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:4px}.ops-search-wrapper,.ops-search-input{width:100%}.ops-rules-grid{grid-template-columns:1fr}.ops-alert-actions{width:100%;justify-content:flex-end}.ops-agent-main{flex-direction:column;align-items:flex-start}.ops-agent-details{gap:12px}.ops-downloads-grid{grid-template-columns:1fr}.ops-pairing-code{font-size:22px;letter-spacing:3px;padding:12px 20px}}@media(max-width:480px){.ops-tab-label{display:none}.ops-tab{gap:4px;padding:10px 14px}.ops-stat-card{min-width:100px;padding:10px 12px;gap:10px}.ops-stat-icon{width:34px;height:34px}.ops-stat-value{font-size:16px}.ops-filter-btn{padding:6px 10px;font-size:12px}}@media(display-mode:standalone){.ops-modal-overlay{padding-top:calc(20px + env(safe-area-inset-top,0));padding-bottom:calc(20px + env(safe-area-inset-bottom,0))}}@media(max-width:768px){.ops-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ops-stat-card{min-width:unset;padding:12px;gap:10px;flex-direction:column;align-items:center;text-align:center}.ops-stat-icon{width:36px;height:36px}.ops-stat-value{font-size:20px}.ops-stat-label{font-size:11px;line-height:1.3}}@media(max-width:480px){.ops-stat-card{padding:10px 8px;gap:6px}.ops-stat-icon{width:32px;height:32px}.ops-stat-icon svg{width:16px;height:16px}.ops-stat-value{font-size:18px}.ops-stat-label{font-size:10px}}.ops-stat-card.clickable{cursor:pointer;transition:all .15s ease}.ops-stat-card.clickable:hover{border-color:var(--accent);background:var(--bg-page)}.ops-stat-card.clickable.selected{border-color:var(--accent);background:#00d4aa0f;box-shadow:0 0 0 1px var(--accent)}.ops-rule-meta .md-rule-notify-icons{display:flex;align-items:center;gap:.4rem;margin-left:auto}.ops-rule-meta .md-rule-notify-icons>span{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;background:#ffffff0d;color:var(--text-tertiary);transition:all .15s}.ops-rule-meta .md-rule-notify-icons>span:hover{background:#ffffff1a;color:var(--text-primary)}.ops-rule-meta .md-rule-notify-icons .notify-email{color:#60a5fa}.ops-rule-meta .md-rule-notify-icons .notify-slack{color:#e01e5a}.ops-rule-meta .md-rule-notify-icons .notify-webhook{color:#a78bfa}.ops-rule-meta .md-rule-notify-icons .notify-push{color:#34d399}.agent-update-banner{margin-bottom:16px;border-radius:var(--radius-md, 8px);background:#f59e0b14;border:1px solid rgba(245,158,11,.25);padding:14px 18px;animation:opsFadeIn .3s ease}.agent-update-banner-content{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.agent-update-banner-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:#f59e0b26;color:#f59e0b;flex-shrink:0}.agent-update-banner-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:200px}.agent-update-banner-text strong{font-size:14px;font-weight:600;color:#f59e0b}.agent-update-banner-text span{font-size:13px;color:var(--text-tertiary)}.agent-update-badge{display:inline-flex;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.25);animation:updatePulse 2s ease-in-out infinite;cursor:default;white-space:nowrap}.agent-current-badge{display:inline-flex;align-items:center;gap:4px;margin-left:8px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.2);white-space:nowrap}@keyframes updatePulse{0%,to{opacity:1}50%{opacity:.7}}@media(max-width:768px){.agent-update-banner-content{flex-direction:column;align-items:flex-start;gap:10px}.agent-update-banner-content .btn{width:100%;justify-content:center}.agent-update-badge,.agent-current-badge{margin-left:0;margin-top:4px}}.reports-page{padding:0}.reports-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px}.reports-header-left{display:flex;align-items:flex-start;gap:12px}.reports-back-btn{background:var(--bg-page);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);padding:8px;cursor:pointer;transition:all .2s;margin-top:4px}.reports-back-btn:hover{background:#ffffff14;color:var(--text-primary)}.reports-back-btn:active{transform:scale(.95)}.reports-breadcrumb{display:flex;align-items:center;gap:8px}.breadcrumb-parent{color:var(--text-tertiary);font-weight:400;font-size:16px;cursor:pointer;transition:color .2s}.breadcrumb-parent:hover{color:var(--accent)}.reports-header-actions{display:flex;gap:8px;flex-shrink:0}.reports-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:13px;margin-bottom:16px}.reports-error button{background:none;border:none;color:#ef4444;cursor:pointer;margin-left:auto;padding:2px}.reports-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:24px;gap:0}.reports-tab{padding:10px 20px;font-size:13px;font-weight:500;color:var(--text-tertiary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .2s}.reports-tab:hover{color:var(--text-secondary);background:#ffffff05}.reports-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.report-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.report-type-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:20px;cursor:pointer;transition:all .25s ease;position:relative;box-shadow:var(--shadow-sm)}.report-type-card:hover{border-color:#00d4aa4d;box-shadow:0 4px 20px #0000004d,0 0 0 1px #00d4aa1a;transform:translateY(-2px)}.report-type-card:active{transform:translateY(0);box-shadow:0 2px 8px #0000004d}.report-type-card.disabled{opacity:.5;cursor:not-allowed}.report-type-card.disabled:hover{transform:none;border-color:var(--border);box-shadow:none}.rtc-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.rtc-badge{position:absolute;top:12px;right:12px;font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;text-transform:uppercase}.rtc-name{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.rtc-desc{font-size:12px;color:var(--text-tertiary);line-height:1.5}.rtc-unavailable{font-size:11px;color:#f59e0b;margin-top:8px;font-style:italic}.config-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm)}.config-panel-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:20px;display:flex;align-items:center;gap:8px}.config-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.config-field label{display:block;font-size:12px;font-weight:500;color:var(--text-tertiary);margin-bottom:6px}.config-field select,.config-field input{width:100%;padding:8px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:13px;outline:none;appearance:none;transition:border-color .2s}.config-field select:hover,.config-field input:hover{border-color:#ffffff26}.config-field select:focus,.config-field input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #00d4aa1a}.config-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--border)}.config-hint{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-tertiary);margin-top:16px}.config-hint svg{color:#f59e0b;flex-shrink:0}.generated-runs{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.generated-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border)}.generated-count{font-size:13px;color:var(--text-secondary)}.runs-table{width:100%;border-collapse:collapse}.runs-table th{text-align:left;font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:10px 16px;border-bottom:1px solid var(--border)}.runs-table td{font-size:13px;color:var(--text-secondary);padding:10px 16px;border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s}.runs-table tr:hover td{background:#ffffff08}.run-name{color:var(--text-primary)!important;font-weight:500;cursor:pointer;transition:color .15s}.run-name:hover{color:var(--accent)!important}.run-date{font-size:12px}.run-actions{display:flex;gap:6px}.type-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500}.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500}.btn-icon-sm{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:5px;border-radius:6px;transition:all .15s}.btn-icon-sm:hover{background:#ffffff14;color:var(--text-primary)}.btn-icon-sm:active{transform:scale(.9)}.btn-icon-sm.danger:hover{background:#ef44441f;color:#ef4444}.report-preview{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.preview-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border)}.preview-header-left{display:flex;align-items:center;gap:12px}.preview-title{font-size:14px;font-weight:600;color:var(--text-primary)}.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#00d4aa1a;border:1px solid rgba(0,212,170,.25);border-radius:20px;color:var(--accent);font-size:11px;font-weight:500;cursor:pointer;transition:all .15s}.filter-chip:hover{background:#00d4aa2e;border-color:#00d4aa66}.filter-chip svg:last-child{opacity:.6}.filter-chip:hover svg:last-child{opacity:1}.preview-toggle{display:flex;background:var(--bg-page);border-radius:8px;padding:2px}.toggle-btn{padding:6px 14px;font-size:12px;font-weight:500;border-radius:6px;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .2s}.toggle-btn:hover{color:var(--text-secondary)}.toggle-btn.active{background:var(--bg-surface);color:var(--text-primary);box-shadow:0 1px 3px #0003}.preview-body{padding:20px}.preview-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.stat-card{background:var(--bg-page);border-radius:10px;padding:16px 18px;border-left:3px solid var(--accent);transition:all .2s}.stat-card:hover{box-shadow:0 2px 12px #0003;transform:translateY(-1px)}.stat-card-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-weight:500}.stat-card-value{font-size:24px;font-weight:700;color:var(--text-primary);line-height:1}.preview-chart-card{background:var(--bg-page);border-radius:10px;padding:18px 18px 12px;margin-bottom:16px;border:1px solid transparent;transition:border-color .2s}.preview-chart-card.chart-active-filter{border-color:#00d4aa33}.chart-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.chart-card-header h3{font-size:13px;font-weight:600;color:var(--text-secondary);margin:0}.chart-filter-hint{font-size:11px;color:var(--text-tertiary);font-style:italic}.chart-tooltip{background:#111827;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:10px 14px;box-shadow:0 8px 24px #00000080;min-width:120px}.chart-tooltip-label{font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.chart-tooltip-row{display:flex;align-items:center;gap:8px;padding:3px 0}.chart-tooltip-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.chart-tooltip-name{font-size:12px;color:var(--text-secondary);flex:1}.chart-tooltip-value{font-size:13px;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.chart-legend{display:flex;justify-content:center;gap:16px;padding-top:8px}.chart-legend-item{display:flex;align-items:center;gap:6px}.chart-legend-dot{width:8px;height:8px;border-radius:2px}.chart-legend-text{font-size:11px;color:var(--text-secondary);font-weight:500}.detail-table-wrap{overflow-x:auto}.detail-filter-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#00d4aa0f;border:1px solid rgba(0,212,170,.15);border-radius:8px;margin-bottom:12px;font-size:12px;color:var(--text-secondary)}.detail-filter-bar svg{color:var(--accent);flex-shrink:0}.filter-value{padding:2px 8px;background:#00d4aa1f;border-radius:4px;color:var(--accent);font-weight:500}.filter-clear-btn{display:inline-flex;align-items:center;gap:4px;margin-left:auto;padding:4px 10px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-secondary);font-size:11px;font-weight:500;cursor:pointer;transition:all .15s}.filter-clear-btn:hover{background:#ffffff1a;color:var(--text-primary)}.detail-table{width:100%;border-collapse:collapse}.detail-table th{text-align:left;font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:10px 12px;border-bottom:1px solid var(--border)}.detail-table td{font-size:13px;color:var(--text-secondary);padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s}.detail-table tr:hover td{background:#ffffff08}.td-name{color:var(--text-primary)!important;font-weight:500}.td-mono{font-family:SF Mono,Fira Code,monospace;font-size:12px}.td-date{font-size:12px;white-space:nowrap}.td-warn{color:#f59e0b!important;font-weight:600}.device-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;text-transform:capitalize}.device-badge.camera{background:#00d4aa1f;color:var(--accent)}.device-badge.nvr{background:#ec48991f;color:#ec4899}.device-badge.switch{background:#f59e0b1f;color:#f59e0b}.device-badge.router{background:#3b82f61f;color:#3b82f6}.device-badge.server,.device-badge.door{background:#a78bfa1f;color:#a78bfa}.device-badge.access_point{background:#22c55e1f;color:#22c55e}.device-badge.firewall{background:#ef44441f;color:#ef4444}.device-badge.unknown{background:#64748b1f;color:var(--text-secondary)}.role-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500;background:#3b82f61f;color:#60a5fa;text-transform:capitalize}.status-indicator{display:inline-flex;align-items:center;gap:6px;font-size:12px;text-transform:capitalize}.status-indicator:before{content:"";width:7px;height:7px;border-radius:50%}.status-indicator.online:before{background:#22c55e;box-shadow:0 0 6px #22c55e66}.status-indicator.offline:before{background:#ef4444;box-shadow:0 0 6px #ef444466}.status-indicator.degraded:before{background:#f59e0b;box-shadow:0 0 6px #f59e0b66}.raw-data-view{background:#0f172a;border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:16px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;color:var(--text-secondary);overflow-x:auto;max-height:600px;overflow-y:auto;white-space:pre-wrap;word-break:break-all;line-height:1.6}.reports-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-tertiary)}.reports-empty-state svg{margin-bottom:16px;opacity:.3;color:var(--text-secondary)}.reports-empty-state h3{font-size:16px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.reports-empty-state p{font-size:13px;max-width:420px;line-height:1.6}.reports-empty-state.error svg{color:#ef4444;opacity:.5}.reports-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--text-secondary)}.reports-loading p{margin-top:12px;font-size:14px}.btn-icon{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:6px;border-radius:6px;transition:all .2s}.btn-icon:hover{background:#ffffff14;color:var(--text-primary)}.btn-icon:active{transform:scale(.9)}@media(max-width:1024px){.report-type-grid,.config-grid,.preview-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.reports-header{flex-direction:column}.reports-header-actions{width:100%}.report-type-grid,.config-grid{grid-template-columns:1fr}.preview-stats{grid-template-columns:repeat(2,1fr)}.preview-header{flex-direction:column;gap:10px;align-items:flex-start}.runs-table th:nth-child(5),.runs-table td:nth-child(5){display:none}.detail-filter-bar{flex-wrap:wrap}}@media(max-width:480px){.preview-stats{grid-template-columns:1fr}.preview-toggle{width:100%}.toggle-btn{flex:1;text-align:center}.runs-table th:nth-child(4),.runs-table td:nth-child(4){display:none}.chart-legend{flex-wrap:wrap;gap:8px}}.sw-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.sw-summary-card{display:flex;align-items:center;gap:12px;background:var(--bg-page);border:1px solid var(--border);border-radius:10px;padding:16px}.sw-summary-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sw-summary-icon.online{background:#00d4aa26;color:var(--accent)}.sw-summary-icon.offline{background:#ff4d4d26;color:#ff4d4d}.sw-summary-icon.ports{background:#6366f126;color:var(--accent)}.sw-summary-icon.poe{background:#facc1526;color:#facc15}.sw-summary-value{font-size:20px;font-weight:600;color:var(--text-primary);line-height:1.2}.sw-summary-label{font-size:12px;color:var(--text-tertiary)}.sw-filters{display:flex;gap:10px;margin-bottom:16px;align-items:center}.sw-search-wrap{display:flex;align-items:center;gap:8px;background:var(--bg-page);border:1px solid var(--border);border-radius:8px;padding:8px 12px;flex:1;color:var(--text-tertiary)}.sw-search-wrap input{background:none;border:none;outline:none;color:var(--text-primary);font-size:13px;width:100%}.sw-filters select{background:var(--bg-page);border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text-primary);font-size:13px;cursor:pointer}.sw-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--text-tertiary);text-align:center}.sw-empty p{font-size:16px;margin:16px 0 4px;color:var(--text-primary)}.sw-empty span{font-size:13px}.sw-list{display:flex;flex-direction:column;gap:8px}.sw-card{display:flex;align-items:center;gap:14px;background:var(--bg-page);border:1px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:all .15s ease}.sw-card:hover{border-color:var(--accent);background:#00d4aa08}.sw-card.offline{opacity:.7}.sw-card.offline:hover{opacity:1}.sw-card-status{flex-shrink:0}.sw-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#555}.sw-status-dot.online{background:var(--accent);box-shadow:0 0 6px #00d4aa66}.sw-status-dot.offline{background:#ff4d4d}.sw-status-dot.large{width:10px;height:10px}.sw-card-icon{width:44px;height:44px;border-radius:10px;background:#6366f11a;color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sw-card-info{flex:1;min-width:0}.sw-card-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sw-card-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-tertiary);margin-top:2px}.sw-mfg-badge{padding:1px 8px;border-radius:10px;font-size:11px;font-weight:500}.sw-card-stats{display:flex;gap:20px;flex-shrink:0}.sw-stat{text-align:center}.sw-stat-value{font-size:13px;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:3px;justify-content:center}.sw-stat-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.sw-stat.poe .sw-stat-value{color:#facc15}.sw-card-arrow{color:var(--text-tertiary);flex-shrink:0}.swd-page{font-family:Segoe UI,system-ui,sans-serif;background:#0c111b;color:var(--text-primary);min-height:100vh;padding:20px 24px}.swd-loading{display:flex;align-items:center;justify-content:center;height:300px;gap:10px;color:var(--text-tertiary);font-family:system-ui}.swd-error-wrap{padding:24px;font-family:system-ui}.swd-back-link{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:13px;padding:0}.swd-error-box{display:flex;align-items:center;gap:10px;padding:16px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:8px;color:#ef4444;font-size:13px}.swd-toast{position:fixed;top:24px;right:24px;z-index:9999;padding:12px 18px;border-radius:8px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px}.swd-toast.success{background:#00d4aa26;border:1px solid rgba(0,212,170,.3);color:var(--accent)}.swd-toast.error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#ef4444}.swd-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px}.swd-header-left{display:flex;align-items:center;gap:14px;min-width:0}.swd-breadcrumb-sep{color:var(--text-tertiary)}.swd-header-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.swd-header-icon.online{background:#00d4aa26;border:1px solid #00D4AA44}.swd-header-icon.offline{background:#6b728026;border:.5px solid var(--border-strong)}.swd-header-info{min-width:0}.swd-header-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.swd-header-name{font-size:18px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.swd-status-badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;flex-shrink:0}.swd-status-badge.online{background:#10b98120;color:#10b981}.swd-status-badge.offline{background:#6b72801f;color:var(--text-tertiary)}.swd-header-meta{font-size:12px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.swd-header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.swd-badge-pill{padding:6px 14px;border-radius:8px;background:#131b2e;border:1px solid #1E293B;font-size:12px;color:var(--text-secondary);white-space:nowrap}.swd-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;border:none}.swd-btn:disabled{cursor:default;opacity:.6}.swd-btn.primary{background:#00d4aa26;color:var(--accent);border:none}.swd-btn.secondary{background:#131b2e;color:var(--text-secondary);border:1px solid #1E293B}.swd-stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:20px}.swd-stat-card{background:#131b2e;border:1px solid #1E293B;border-radius:10px;padding:12px 14px}.swd-stat-label{font-size:11px;color:var(--text-tertiary);margin-bottom:4px}.swd-stat-value{font-size:20px;font-weight:700}.swd-stat-total{font-size:13px;color:#475569;font-weight:400}.swd-panel{background:#101827;border:1px solid #1E293B;border-radius:14px;padding:18px 22px;margin-bottom:20px}.swd-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px;flex-wrap:wrap}.swd-panel-title{font-size:12px;font-weight:600;color:var(--text-secondary);letter-spacing:.1em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.swd-panel-legend{display:flex;gap:14px;font-size:11px;flex-wrap:wrap;flex-shrink:0}.swd-legend-item{display:flex;align-items:center;gap:5px}.swd-legend-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.swd-legend-label{color:var(--text-tertiary);white-space:nowrap}.swd-chassis{background:var(--bg-page);border-radius:10px;padding:14px 18px;border:.5px solid var(--border);box-shadow:var(--shadow-sm);overflow-x:auto;-webkit-overflow-scrolling:touch}.swd-port-row{display:grid;gap:5px;margin-bottom:4px}.swd-port-row:last-child{margin-bottom:0}.swd-port-divider{width:100%;height:100%;background:#1e293b22;border-radius:4px;display:flex;align-items:center;justify-content:center}.swd-port-divider-line{width:1px;height:60%;background:#1e293b}.swd-panel-footer{display:flex;gap:16px;margin-top:10px;font-size:11px;color:var(--text-tertiary);flex-wrap:wrap}.swd-panel-footer .count-up{color:#10b981;font-weight:600}.swd-panel-footer .count-err{color:#ef4444;font-weight:600}.swd-panel-footer .count-unused{color:var(--text-tertiary);font-weight:600}.swd-panel-footer .sep{color:var(--text-tertiary)}.swd-port-btn{width:100%;height:32px;border-radius:4px;cursor:pointer;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;transition:all .15s;padding:0;min-width:0}.swd-port-btn.sfp{height:38px;border-radius:6px}.swd-port-btn.selected{border-color:var(--accent)!important;background:#00d4aa18!important;box-shadow:0 0 12px #00d4aa33;transform:scale(1.1)}.swd-port-btn:hover:not(.selected){transform:scale(1.06)}.swd-port-led{width:5px;height:5px;border-radius:50%}.swd-port-label{font-size:9px;font-family:monospace;font-weight:500;color:var(--text-secondary);letter-spacing:-.02em;line-height:1}.swd-port-btn.selected .swd-port-label{font-weight:700;color:var(--accent)}.swd-port-poe-dot{position:absolute;top:-3px;right:-3px;width:7px;height:7px;border-radius:50%;background:#f59e0b;border:1.5px solid #0A0F1A}.swd-port-device-bar{position:absolute;bottom:0;left:2px;right:2px;height:2px;border-radius:0 0 3px 3px;opacity:.7}.swd-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;animation:fadeIn .2s ease}.swd-detail-grid.single-col{grid-template-columns:1fr}.swd-detail-card{background:#131b2e;border:1px solid #1E293B;border-radius:12px;padding:20px}.swd-detail-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.swd-detail-card-title{display:flex;align-items:center;gap:10px}.swd-detail-status-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}.swd-detail-status-dot{width:10px;height:10px;border-radius:50%}.swd-detail-port-name{font-size:15px;font-weight:700}.swd-detail-port-sub{font-size:11px}.swd-close-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;font-size:18px;padding:4px}.swd-section-label{font-size:11px;font-weight:600;color:var(--text-tertiary);margin-bottom:8px;letter-spacing:.08em}.swd-traffic-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.swd-traffic-card{background:#0c111b;border-radius:8px;padding:10px}.swd-traffic-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.swd-traffic-label{font-size:11px;color:var(--text-tertiary)}.swd-traffic-value{font-size:14px;font-weight:700}.swd-traffic-packets{font-size:10px;color:#475569;margin-top:3px}.swd-counter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.swd-counter-card{background:#0c111b;border-radius:8px;padding:8px 10px;text-align:center}.swd-counter-value{font-size:18px;font-weight:700}.swd-counter-value.warn{color:#ef4444}.swd-counter-value.ok{color:#10b981}.swd-counter-label{font-size:10px;color:var(--text-tertiary)}.swd-poe-detail{background:#0c111b;border-radius:8px;padding:12px}.swd-poe-detail-row{display:flex;justify-content:space-between;margin-bottom:6px}.swd-poe-detail-class{font-size:12px;color:var(--text-secondary)}.swd-poe-detail-watts{font-size:14px;font-weight:700;color:#f59e0b}.swd-poe-detail-max{font-size:11px;color:var(--text-tertiary);font-weight:400}.swd-poe-bar-track{height:6px;border-radius:3px;background:#1a2235;overflow:hidden}.swd-poe-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#f59e0b,#fb923c)}.swd-meta-grid{margin-top:14px;display:grid;grid-template-columns:1fr 1fr;gap:6px}.swd-meta-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid #1E293B}.swd-meta-key{font-size:11px;color:var(--text-tertiary)}.swd-meta-val{font-size:11px;color:var(--text-secondary);font-family:monospace;text-transform:capitalize}.swd-device-card{background:#131b2e;border-radius:12px;padding:20px}.swd-device-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.swd-device-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.swd-device-name{font-size:15px;font-weight:700}.swd-device-badges{display:flex;gap:6px;margin-top:3px;flex-wrap:wrap}.swd-device-badge{padding:1px 8px;border-radius:4px;font-size:10px;font-weight:600}.swd-device-badge.connected{background:#10b98120;color:#10b981}.swd-device-info{background:#0c111b;border-radius:8px;padding:12px;margin-bottom:14px}.swd-device-info-row{display:flex;justify-content:space-between;padding:5px 0}.swd-device-info-row:not(:last-child){border-bottom:1px solid #1A2235}.swd-device-info-key{font-size:12px;color:var(--text-tertiary)}.swd-device-info-val{font-size:12px;color:var(--text-primary);font-family:monospace}.swd-bw-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.swd-bw-card{background:#0c111b;border-radius:8px;padding:10px 12px;text-align:center}.swd-bw-label{font-size:11px;margin-bottom:2px}.swd-bw-label.upload{color:#3b82f6}.swd-bw-label.download{color:#10b981}.swd-bw-value{font-size:16px;font-weight:700;color:var(--text-primary)}.swd-netpath{background:#0c111b;border-radius:8px;padding:12px}.swd-netpath-chain{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.swd-netpath-node{padding:4px 10px;border-radius:6px;font-size:11px;white-space:nowrap}.swd-netpath-arrow{color:#334155;font-size:12px}.swd-netpath-sub{font-size:10px;color:#475569;margin-top:8px}.swd-ccm-link{margin-top:14px;padding:10px 14px;border-radius:8px;background:linear-gradient(135deg,var(--accent-alpha-08),#06B6D410);border:1px solid #00D4AA22}.swd-ccm-link-inner{display:flex;align-items:center;justify-content:space-between;gap:8px}.swd-ccm-link-left{display:flex;align-items:center;gap:8px;min-width:0}.swd-ccm-link-title{font-size:12px;font-weight:600;color:var(--accent)}.swd-ccm-link-sub{font-size:10px;color:var(--text-tertiary)}.swd-ccm-link-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;background:var(--accent-alpha-15);color:var(--accent);font-size:11px;font-weight:600;border:none;cursor:pointer;white-space:nowrap}.swd-no-device{background:#131b2e;border:1px solid #1E293B;border-radius:12px;padding:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:140px}.swd-no-device-icon{font-size:36px;margin-bottom:10px;opacity:.2}.swd-no-device-text{font-size:14px;color:var(--text-tertiary);margin-bottom:4px}.swd-no-device-sub{font-size:12px;color:#475569}.swd-table-wrap{background:#131b2e;border:1px solid #1E293B;border-radius:12px;overflow:hidden}.swd-table-header{padding:12px 18px;border-bottom:1px solid #1E293B;display:flex;justify-content:space-between;align-items:center}.swd-table-title{font-size:14px;font-weight:600}.swd-table-meta{font-size:12px;color:var(--text-tertiary)}.swd-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.swd-table{width:100%;border-collapse:collapse;font-size:12px}.swd-table thead tr{background:#0f1629}.swd-table thead th{padding:10px 12px;text-align:left;color:var(--text-tertiary);font-weight:600;font-size:11px;border-bottom:1px solid #1E293B;white-space:nowrap}.swd-table tbody tr{cursor:pointer;border-bottom:1px solid #1A2235;transition:background .15s}.swd-table tbody tr:hover{background:#ffffff04}.swd-table tbody tr.selected{background:#00d4aa08}.swd-table tbody td{padding:8px 12px}.swd-table .col-port{font-family:monospace;font-weight:600;color:var(--text-secondary)}.swd-table tr.selected .col-port{color:var(--accent)}.swd-table .col-status{display:flex;align-items:center;gap:5px}.swd-table .status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.swd-table .status-text{font-size:11px}.swd-table .col-speed{color:var(--text-secondary);font-family:monospace;font-size:11px}.swd-table .col-device{color:var(--text-primary);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.swd-table .col-ip{color:var(--text-secondary);font-family:monospace;font-size:11px}.swd-table .type-badge{padding:1px 8px;border-radius:4px;font-size:10px;font-weight:600}.swd-table .col-poe-active{color:#f59e0b;font-weight:600}.swd-table .col-muted{color:var(--text-tertiary)}.swd-table .col-errors.warn{color:#ef4444;font-weight:600}.swd-table .col-errors.ok{color:#475569;font-weight:400}.swd-empty-ports{display:flex;flex-direction:column;align-items:center;justify-content:center;height:140px;gap:8px;color:var(--text-tertiary)}.swd-empty-ports-icon{font-size:32px;opacity:.2}.swd-empty-ports-text{font-size:13px}.swd-ports-loading{background:#101827;border:1px solid #1E293B;border-radius:14px;padding:40px 22px;margin-bottom:20px;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--text-tertiary)}.sw-poe-budget{background:var(--bg-page);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:20px}.sw-poe-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;color:#facc15}.sw-poe-header h3{margin:0;font-size:16px;color:var(--text-primary)}.sw-poe-bar-wrap{margin-bottom:16px}.sw-poe-bar{height:12px;background:#ffffff0d;border-radius:6px;overflow:hidden}.sw-poe-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#00b4d8);border-radius:6px;transition:width .5s ease}.sw-poe-bar-fill.warning{background:linear-gradient(90deg,#f59e0b,#ef4444)}.sw-poe-bar-fill.critical{background:linear-gradient(90deg,#ef4444,#dc2626)}.sw-poe-numbers{display:flex;justify-content:space-between;font-size:12px;color:var(--text-tertiary);margin-top:6px}.sw-poe-stats{display:flex;gap:32px}.sw-poe-stat-value{font-size:22px;font-weight:600;color:var(--text-primary)}.sw-poe-stat-label{font-size:12px;color:var(--text-tertiary)}.sw-poe-ports h4{margin:0 0 12px;font-size:14px;color:var(--text-primary)}.sw-poe-port-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}.sw-poe-port-card{background:var(--bg-page);border:1px solid var(--border);border-radius:8px;padding:10px}.sw-poe-port-card.delivering{border-color:#facc154d;background:#facc1508}.sw-poe-port-card.fault{border-color:#ef44444d;background:#ef44440d}.sw-poe-port-header{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-tertiary);margin-bottom:4px}.sw-poe-port-header svg{color:#facc15}.sw-poe-port-watts{font-size:18px;font-weight:600;color:var(--text-primary)}.sw-poe-port-meta{display:flex;align-items:center;gap:8px;font-size:10px;color:var(--text-tertiary);margin-top:4px}.sw-poe-port-status{text-transform:capitalize}.sw-poe-port-status.delivering,.sw-poe-port-status.deliveringPower{color:#facc15}.sw-poe-port-status.fault,.sw-poe-port-status.otherFault{color:#ef4444}.sw-poe-port-status.searching{color:var(--text-secondary)}.sw-mac-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:12px}.sw-mac-count{font-size:12px;color:var(--text-tertiary)}.sw-mac-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:10px}.sw-mac-table{width:100%;border-collapse:collapse;font-size:13px}.sw-mac-table thead th{text-align:left;padding:10px 14px;font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);background:#ffffff05;border-bottom:1px solid var(--border)}.sw-mac-table tbody tr{border-bottom:1px solid rgba(255,255,255,.03);transition:background .1s}.sw-mac-table tbody tr:hover{background:#ffffff05}.sw-mac-table tbody td{padding:8px 14px;color:var(--text-primary)}.sw-mac-table .mono{font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:12px}.sw-mac-empty{text-align:center;padding:40px 20px!important;color:var(--text-tertiary)}.sw-detail-header{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}.sw-detail-title{display:flex;align-items:center;gap:10px;flex:1}.sw-detail-title h2{margin:0;font-size:20px}.sw-detail-model{font-size:13px;color:var(--text-tertiary)}.sw-info-bar{display:flex;gap:24px;padding:14px 18px;background:var(--bg-page);border:1px solid var(--border);border-radius:10px;margin-bottom:16px;flex-wrap:wrap}.sw-info-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-tertiary)}.sw-info-label{font-weight:500}.sw-info-value{color:var(--text-primary)}.sw-info-value.mono{font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:12px}.sw-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px}.sw-tab{display:flex;align-items:center;gap:6px;padding:10px 16px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-tertiary);font-size:13px;cursor:pointer;transition:all .15s ease}.sw-tab:hover{color:var(--text-primary)}.sw-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.sw-port-summary{display:flex;align-items:center;gap:16px;margin-bottom:16px;font-size:13px}.sw-port-stat{display:flex;align-items:center;gap:4px}.sw-port-stat.up{color:var(--accent)}.sw-port-stat.down{color:#ff4d4d}.sw-port-stat.disabled{color:var(--text-tertiary)}.sw-port-filter{margin-left:auto}.sw-port-filter select{background:var(--bg-page);border:1px solid var(--border);border-radius:6px;padding:4px 10px;color:var(--text-primary);font-size:12px}.sw-port-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.sw-port-cell{background:var(--bg-page);border:1px solid var(--border);border-radius:8px;padding:10px;text-align:center;position:relative;transition:all .15s ease}.sw-port-cell:hover{border-color:#ffffff26}.sw-port-cell.up{border-color:var(--status-ok);background:var(--status-ok-bg)}.sw-port-cell.down{border-color:var(--border)}.sw-port-cell.admin_down{opacity:.5}.sw-port-indicator{width:100%;height:3px;border-radius:2px;margin-bottom:6px}.sw-port-id{font-size:16px;font-weight:600;color:var(--text-primary)}.sw-port-name{font-size:10px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:2px 0}.sw-port-speed{font-size:11px;color:var(--text-secondary)}.sw-port-poe{display:flex;align-items:center;justify-content:center;gap:2px;font-size:10px;color:#facc15;margin-top:4px}@media(max-width:1024px){.sw-summary-grid{grid-template-columns:repeat(2,1fr)}.sw-card-stats{gap:12px}.sw-info-bar{gap:16px}.swd-stats-grid{grid-template-columns:repeat(3,1fr)}.swd-header-actions{flex-wrap:wrap}}@media(max-width:768px){.sw-summary-grid{grid-template-columns:1fr 1fr}.sw-card{flex-wrap:wrap}.sw-card-stats{width:100%;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.05)}.sw-card-icon{display:none}.sw-filters,.sw-detail-header{flex-wrap:wrap}.sw-info-bar{flex-wrap:wrap;gap:12px}.sw-port-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.sw-poe-stats{gap:16px;flex-wrap:wrap}.swd-page{padding:16px}.swd-header{flex-direction:column;align-items:flex-start}.swd-header-actions{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.swd-badge-pill{font-size:11px;padding:5px 10px}.swd-stats-grid{grid-template-columns:repeat(3,1fr);gap:8px}.swd-stat-card{padding:10px 12px}.swd-stat-value{font-size:16px}.swd-stat-label{font-size:10px}.swd-panel{padding:14px 16px}.swd-panel-header{flex-direction:column;align-items:flex-start;gap:8px}.swd-panel-title{font-size:11px;white-space:normal;line-height:1.4}.swd-panel-legend{gap:10px}.swd-chassis{padding:10px 12px}.swd-detail-grid,.swd-meta-grid{grid-template-columns:1fr}.swd-table .col-type,.swd-table .col-poe,.swd-table .col-errors-cell,.swd-table thead .col-type-h,.swd-table thead .col-poe-h,.swd-table thead .col-errors-h{display:none}}@media(max-width:480px){.sw-summary-grid{grid-template-columns:1fr 1fr}.sw-port-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:4px}.sw-port-cell{padding:6px}.sw-port-name{display:none}.swd-page{padding:12px}.swd-header-name{font-size:16px}.swd-header-meta{font-size:11px}.swd-stats-grid{grid-template-columns:repeat(2,1fr);gap:6px}.swd-stat-value{font-size:14px}.swd-panel{padding:12px;border-radius:10px}.swd-chassis{padding:8px 10px;border-radius:8px}.swd-panel-legend{font-size:10px;gap:8px}.swd-legend-dot{width:6px;height:6px}.swd-port-btn{height:28px}.swd-port-btn.sfp{height:34px}.swd-port-label{font-size:8px}.swd-port-led{width:4px;height:4px}.swd-detail-card,.swd-device-card{padding:14px}.swd-traffic-grid{grid-template-columns:1fr}.swd-counter-grid{grid-template-columns:repeat(3,1fr);gap:6px}.swd-table .col-speed,.swd-table .col-ip-cell,.swd-table thead .col-speed-h,.swd-table thead .col-ip-h{display:none}.swd-table .col-device{max-width:120px}.swd-ccm-link-inner{flex-direction:column;align-items:flex-start}}@supports (padding-bottom: env(safe-area-inset-bottom)){.swd-page{padding-bottom:calc(20px + env(safe-area-inset-bottom,0px))}}.swd-page ::-webkit-scrollbar{height:5px;width:5px}.swd-page ::-webkit-scrollbar-track{background:#0c111b}.swd-page ::-webkit-scrollbar-thumb{background:#1e293b;border-radius:3px}.swd-page button:focus{outline:none}.entry-fleet{max-width:1400px;margin:0 auto;padding:0 4px}.entry-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:80px 0;color:var(--text-secondary)}.entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.entry-header-left h1{display:flex;align-items:center;gap:10px;font-size:22px;font-weight:600;color:var(--text-primary);margin:0}.entry-header-sub{font-size:13px;color:var(--text-tertiary);margin-left:34px;display:block}.entry-header-actions{display:flex;gap:8px}.entry-license-banner{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;margin-bottom:16px;font-size:13px}.entry-license-info{display:flex;align-items:center;gap:10px}.entry-license-sku{background:#3b82f626;color:#60a5fa;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.entry-license-status{font-weight:500}.entry-license-usage{display:flex;gap:16px;color:var(--text-secondary)}.entry-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:16px}.entry-stat-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:14px 16px;text-align:center;cursor:pointer;transition:all .2s}.entry-stat-card:hover{background:#ffffff0f;border-color:#ffffff26}.entry-stat-card.active{border-color:var(--accent);background:#00d4aa14}.entry-stat-value{font-size:24px;font-weight:700;color:var(--text-primary);line-height:1.2}.entry-stat-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.entry-toolbar{display:flex;gap:10px;margin-bottom:16px}.entry-search{display:flex;align-items:center;gap:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:0 12px;flex:1;max-width:400px}.entry-search input{background:transparent;border:none;color:var(--text-primary);font-size:14px;padding:10px 0;width:100%;outline:none}.entry-search input::placeholder{color:var(--text-tertiary)}.entry-search svg{color:var(--text-tertiary);flex-shrink:0}.entry-empty{text-align:center;padding:60px 20px;color:var(--text-tertiary)}.entry-empty h3{color:var(--text-secondary);margin:16px 0 8px;font-size:18px}.entry-empty p{margin-bottom:20px;font-size:14px}.entry-device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:12px}.entry-device-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:16px;cursor:pointer;transition:all .2s}.entry-device-card:hover{background:#ffffff0f;border-color:#ffffff26;transform:translateY(-1px)}.entry-device-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.entry-device-name-row{display:flex;align-items:center;gap:8px}.entry-device-name{font-size:15px;font-weight:600;color:var(--text-primary)}.entry-device-status{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.entry-device-meta{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;margin-bottom:10px}.entry-device-meta-item{display:flex;flex-direction:column}.entry-device-meta-item .meta-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px}.entry-device-meta-item .meta-value{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-device-health{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.entry-health-pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;padding:2px 8px;border-radius:8px;background:#ffffff0a}.entry-device-footer{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid rgba(255,255,255,.06)}.entry-device-lastseen{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-tertiary)}.entry-token-display{text-align:center}.entry-token-box{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;margin-bottom:12px}.entry-token-box code{flex:1;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;color:var(--accent);word-break:break-all;text-align:left}.entry-token-meta{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-tertiary)}@media(max-width:1024px){.entry-stats{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.entry-header{flex-direction:column;align-items:flex-start}.entry-stats{grid-template-columns:repeat(2,1fr)}.entry-device-grid{grid-template-columns:1fr}.entry-license-banner{flex-direction:column;gap:8px;align-items:flex-start}.entry-license-usage{flex-direction:column;gap:4px}}@media(max-width:480px){.entry-stats{grid-template-columns:1fr 1fr}.entry-device-meta{grid-template-columns:1fr}}.entry-grace-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;margin-bottom:12px;font-size:13px;color:#fca5a5}.entry-detail{max-width:1200px;margin:0 auto;padding:0 4px}.entry-detail-loading,.entry-detail-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 0;color:var(--text-secondary)}.entry-detail-empty h3{color:var(--text-secondary)}.entry-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;gap:12px}.entry-detail-header-left{display:flex;align-items:flex-start;gap:12px}.entry-detail-header-left h1{display:flex;align-items:center;gap:8px;font-size:22px;font-weight:600;color:var(--text-primary);margin:0}.entry-detail-subtitle{display:flex;align-items:center;gap:12px;margin-top:4px;font-size:13px;color:var(--text-tertiary)}.entry-detail-subtitle span{display:flex;align-items:center;gap:4px}.entry-detail-id{font-family:JetBrains Mono,Fira Code,monospace;font-size:11px;color:#475569}.entry-detail-header-right{display:flex;align-items:center;gap:8px}.entry-detail-status{display:inline-flex;align-items:center;padding:5px 14px;border-radius:14px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.entry-detail-tabs{display:flex;gap:2px;margin-bottom:20px;border-bottom:1px solid rgba(255,255,255,.08)}.entry-detail-tab{padding:10px 20px;background:transparent;border:none;color:var(--text-tertiary);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.entry-detail-tab:hover{color:var(--text-secondary)}.entry-detail-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.entry-detail-section{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.entry-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}.entry-info-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:16px}.entry-info-card h3{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.06)}.entry-info-rows{display:flex;flex-direction:column;gap:8px}.entry-info-row{display:flex;justify-content:space-between;align-items:center}.entry-info-label{font-size:13px;color:var(--text-tertiary)}.entry-info-value{font-size:13px;color:var(--text-primary);font-weight:500}.entry-info-value.mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:12px}.entry-health-bar-wrap{display:flex;align-items:center;gap:8px}.entry-health-bar-mini{width:60px;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.entry-health-bar-fill{height:100%;border-radius:2px;transition:width .3s}.entry-commands-section{margin-bottom:20px}.entry-commands-section h3{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.entry-commands-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}.entry-command-btn{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:12px 14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s;text-align:left}.entry-command-btn:hover:not(:disabled){background:#ffffff14;border-color:#00d4aa4d}.entry-command-btn:disabled{opacity:.4;cursor:not-allowed}.entry-command-label{font-size:13px;font-weight:600}.entry-command-desc{font-size:11px;color:var(--text-tertiary)}.entry-events-list{display:flex;flex-direction:column;gap:2px}.entry-event-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#ffffff08;border-radius:6px;transition:background .15s}.entry-event-row:hover{background:#ffffff0f}.entry-event-icon{flex-shrink:0}.entry-event-info{flex:1;display:flex;flex-wrap:wrap;align-items:center;gap:8px}.entry-event-type{font-size:13px;font-weight:600}.entry-event-person{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-secondary)}.entry-event-reason{font-size:12px;color:var(--text-tertiary)}.entry-event-meta{display:flex;align-items:center;gap:10px;flex-shrink:0}.entry-event-confidence{font-size:11px;color:#a855f7;font-weight:600}.entry-event-time{font-size:11px;color:var(--text-tertiary)}.entry-commands-list{display:flex;flex-direction:column;gap:6px}.entry-command-row{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 14px;background:#ffffff08;border-radius:6px}.entry-command-type{display:flex;align-items:center;gap:8px}.entry-command-type-label{font-size:13px;font-weight:500;color:var(--text-primary);text-transform:capitalize}.entry-command-status{padding:2px 8px;border-radius:8px;font-size:10px;font-weight:600;text-transform:uppercase}.entry-command-times{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:11px;color:var(--text-tertiary)}.entry-command-error{color:#ef4444}.entry-detail-empty-section{text-align:center;padding:40px 20px;color:var(--text-tertiary)}.entry-detail-empty-section p{margin-top:12px;font-size:13px;max-width:400px;margin-left:auto;margin-right:auto}.entry-warning-card{border-color:#f59e0b4d}.entry-warning-card h3{color:#f59e0b}.entry-danger-card{border-color:#ef444433}.entry-danger-card h3{color:#ef4444}.entry-overrides-pre{background:#0000004d;border-radius:6px;padding:10px 12px;font-size:12px;color:#f59e0b;overflow-x:auto;font-family:JetBrains Mono,Fira Code,monospace}@media(max-width:768px){.entry-detail-header{flex-direction:column}.entry-detail-grid,.entry-commands-grid{grid-template-columns:1fr}.entry-event-row{flex-direction:column;align-items:flex-start;gap:6px}.entry-event-meta{width:100%;justify-content:flex-end}.entry-command-row{flex-direction:column;gap:6px}.entry-command-times{align-items:flex-start}.entry-detail-tabs{overflow-x:auto}}.entry-profile-assign{display:flex;flex-direction:column;gap:10px}.entry-profile-assign-row{display:flex;align-items:center;gap:8px}.entry-profile-assign-select-wrap{flex:1;display:flex;align-items:center;gap:8px}.entry-profile-assign-select-wrap select{flex:1}.entry-profile-assign-actions{display:flex;gap:6px}.entry-profile-assign-info{display:flex;flex-direction:column;gap:6px}.entry-profile-sections-list{display:flex;flex-wrap:wrap;gap:6px}.entry-profile-section-dot{display:inline-flex;align-items:center;gap:3px;font-size:11px;padding:2px 8px;border-radius:8px}.entry-profile-section-dot.active{background:#22c55e1a;color:#22c55e}.entry-profile-section-dot.empty{background:#ffffff0a;color:#475569}.entry-drift-table{display:flex;flex-direction:column;gap:8px}.entry-drift-section{background:#0003;border-radius:6px;overflow:hidden}.entry-drift-section-header{padding:6px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#f59e0b;background:#f59e0b1a}.entry-drift-row{display:flex;align-items:center;gap:8px;padding:6px 12px;border-top:1px solid rgba(255,255,255,.04);font-size:12px}.entry-drift-field{color:var(--text-secondary);min-width:120px;font-weight:500}.entry-drift-profile{color:var(--text-tertiary);font-family:JetBrains Mono,monospace;font-size:11px;text-decoration:line-through}.entry-drift-arrow{color:#f59e0b;font-size:14px}.entry-drift-local{color:#fbbf24;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600}@media(max-width:768px){.entry-profile-assign-row{flex-direction:column;align-items:stretch}.entry-drift-row{flex-wrap:wrap}.entry-drift-field{min-width:auto;width:100%}}.entry-profiles{max-width:1200px;margin:0 auto;padding:0 4px}.entry-profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:12px}.entry-profile-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:16px;transition:all .2s}.entry-profile-card:hover{background:#ffffff0f;border-color:#ffffff26}.entry-profile-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.entry-profile-name{font-size:15px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.entry-profile-default-badge{font-size:10px;font-weight:600;text-transform:uppercase;padding:2px 8px;border-radius:8px;background:#22c55e26;color:#22c55e}.entry-profile-desc{font-size:12px;color:var(--text-tertiary);margin-top:4px}.entry-profile-actions{display:flex;gap:4px}.entry-profile-sections{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.entry-profile-section-pill{font-size:11px;padding:2px 8px;border-radius:8px;background:#ffffff0f;color:var(--text-secondary)}.entry-profile-footer{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid rgba(255,255,255,.06)}.entry-profile-device-count{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-tertiary)}@media(max-width:768px){.entry-profile-grid{grid-template-columns:1fr}}.nc-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.nc-stat-card{background:var(--bg-surface);border:.5px solid var(--border);box-shadow:var(--shadow-sm);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:4px}.nc-stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.nc-stat-value{font-size:24px;font-weight:600;color:var(--text-primary)}.nc-stat-value.critical{color:#ef4444}.nc-stat-value.warning{color:#f59e0b}.nc-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:16px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.nc-tabs::-webkit-scrollbar{display:none}.nc-tab{padding:10px 18px;font-size:13px;color:var(--text-secondary);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;font-weight:400;white-space:nowrap;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:6px}.nc-tab:hover{color:var(--text-primary)}.nc-tab.active{color:var(--text-primary);border-bottom-color:#3b82f6;font-weight:500}.nc-tab-count{font-size:11px;background:#ffffff0f;color:var(--text-secondary);padding:1px 7px;border-radius:8px}.nc-tab.active .nc-tab-count{background:#3b82f626;color:#60a5fa}.nc-controls{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.nc-search{flex:1;min-width:220px;display:flex;align-items:center;gap:8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:0 12px;transition:border-color .15s}.nc-search:focus-within{border-color:#3b82f666}.nc-search svg{width:14px;height:14px;color:#ffffff4d;flex-shrink:0}.nc-search input{background:transparent;border:none;color:var(--text-primary);font-size:13px;padding:9px 0;width:100%;outline:none;font-family:inherit}.nc-search input::placeholder{color:#ffffff4d}.nc-filter-pill{display:flex;align-items:center;gap:5px;font-size:12px;padding:7px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.1);cursor:pointer;color:var(--text-secondary);background:transparent;transition:all .15s;white-space:nowrap;font-family:inherit}.nc-filter-pill:hover{background:#ffffff0a;border-color:#ffffff26}.nc-filter-pill.active{background:#3b82f61a;color:#60a5fa;border-color:#3b82f64d}.nc-filter-pill svg{width:13px;height:13px}.nc-date-filters{display:flex;gap:8px;align-items:center;margin-bottom:16px}.nc-date-input{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;color:var(--text-primary);font-size:12px;padding:7px 10px;font-family:inherit;outline:none}.nc-date-input:focus{border-color:#3b82f666}.nc-date-label{font-size:12px;color:var(--text-secondary)}.nc-date-separator{font-size:11px;color:#ffffff59;padding:14px 0 6px;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.nc-list{display:flex;flex-direction:column;gap:4px}.nc-empty{text-align:center;padding:60px 20px;color:#ffffff59}.nc-empty svg{margin-bottom:12px;opacity:.4}.nc-empty h3{font-size:16px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.nc-empty p{font-size:13px}.nc-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff04;cursor:pointer;transition:background .15s,border-color .15s;position:relative}.nc-item:hover{background:#ffffff09;border-color:#ffffff1a}.nc-item.unread{background:#3b82f60a;border-color:#3b82f61f}.nc-item.unread:hover{background:#3b82f60f}.nc-checkbox{width:15px;height:15px;accent-color:#3b82f6;margin-top:2px;cursor:pointer;flex-shrink:0}.nc-item-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nc-item-icon svg{width:16px;height:16px}.nc-item-icon.critical{background:#ef44441f;color:#ef4444}.nc-item-icon.warning{background:#f59e0b1f;color:#f59e0b}.nc-item-icon.info{background:#3b82f61f;color:#60a5fa}.nc-item-icon.audit{background:#22c55e1f;color:#22c55e}.nc-item-icon.intercom{background:#a855f71f;color:#a855f7}.nc-item-body{flex:1;min-width:0}.nc-item-top{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}.nc-item-title{font-size:13.5px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:400px}.nc-sev-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.nc-sev-badge.critical{background:#ef444426;color:#ef4444}.nc-sev-badge.warning{background:#f59e0b26;color:#f59e0b}.nc-sev-badge.info{background:#3b82f61f;color:#60a5fa}.nc-cat-badge{font-size:10px;padding:2px 8px;border-radius:6px;background:#ffffff0f;color:var(--text-secondary);flex-shrink:0}.nc-cat-badge.system{background:#3b82f61a;color:#60a5fa}.nc-cat-badge.health{background:#f59e0b1a;color:#fbbf24}.nc-cat-badge.audit{background:#22c55e1a;color:#4ade80}.nc-cat-badge.intercom{background:#a855f71a;color:#c084fc}.nc-status-badge{font-size:10px;padding:2px 8px;border-radius:6px;flex-shrink:0}.nc-status-badge.acknowledged{background:#3b82f61a;color:#60a5fa}.nc-status-badge.resolved,.nc-status-badge.auto_resolved{background:#22c55e1a;color:#4ade80}.nc-status-badge.snoozed{background:#a855f71a;color:#c084fc}.nc-status-badge.in_progress{background:#3b82f61a;color:#60a5fa}.nc-bug-badge{font-size:10px;padding:2px 8px;border-radius:6px;background:#f973161f;color:#fb923c;display:flex;align-items:center;gap:3px}.nc-bug-badge svg{width:10px;height:10px}.nc-item-msg{font-size:12.5px;color:var(--text-secondary);line-height:1.5;margin-bottom:6px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.nc-item-meta{display:flex;align-items:center;gap:14px;font-size:11px;color:#ffffff4d;flex-wrap:wrap}.nc-item-meta span{display:flex;align-items:center;gap:4px}.nc-item-meta svg{width:11px;height:11px}.nc-item-actions{display:flex;gap:6px;flex-shrink:0;align-self:center;opacity:0;transition:opacity .15s}.nc-item:hover .nc-item-actions{opacity:1}.nc-item-actions .nc-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);font-size:11px;padding:5px 10px;border-radius:6px;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:4px;white-space:nowrap;transition:all .12s}.nc-item-actions .nc-btn:hover{background:#ffffff14;border-color:#ffffff26}.nc-item-actions .nc-btn svg{width:12px;height:12px}.nc-item-actions .nc-btn.resolve{color:#4ade80;border-color:#22c55e40}.nc-item-actions .nc-btn.resolve:hover{background:#22c55e1a}.nc-item-actions .nc-btn.bug{color:#fb923c;border-color:#f9731640}.nc-item-actions .nc-btn.bug:hover{background:#f973161a}.nc-unread-dot{width:7px;height:7px;border-radius:50%;background:#3b82f6;flex-shrink:0;margin-top:14px}.nc-bulk-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:10px;margin-bottom:12px}.nc-bulk-count{font-size:13px;color:#60a5fa;font-weight:500}.nc-bulk-bar .nc-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);font-size:12px;padding:5px 12px;border-radius:6px;cursor:pointer;font-family:inherit;transition:all .12s}.nc-bulk-bar .nc-btn:hover{background:#ffffff14}.nc-bulk-bar .nc-btn.resolve{color:#4ade80;border-color:#22c55e40}.nc-bulk-bar .nc-btn-clear{background:none;border:none;color:var(--text-secondary);font-size:12px;cursor:pointer;margin-left:auto;font-family:inherit}.nc-pagination{display:flex;align-items:center;justify-content:space-between;padding:16px 0 0;border-top:1px solid rgba(255,255,255,.06);margin-top:16px}.nc-page-info{font-size:12px;color:#ffffff59}.nc-page-buttons{display:flex;gap:6px}.nc-page-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:var(--text-secondary);font-size:12px;padding:6px 14px;border-radius:6px;cursor:pointer;font-family:inherit;transition:all .12s}.nc-page-btn:hover:not(:disabled){background:#ffffff0f;border-color:#ffffff1f}.nc-page-btn:disabled{opacity:.35;cursor:not-allowed}.nc-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.nc-modal{background:var(--bg-surface);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:24px;width:420px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-sm)}.nc-modal h3{font-size:16px;font-weight:500;color:var(--text-primary);margin-bottom:16px}.nc-modal textarea{width:100%;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-primary);font-size:13px;padding:10px 12px;min-height:80px;resize:vertical;font-family:inherit;outline:none;margin-bottom:16px}.nc-modal textarea:focus{border-color:#3b82f666}.nc-modal-actions{display:flex;gap:8px;justify-content:flex-end}.nc-modal-actions button{padding:8px 16px;border-radius:8px;font-size:13px;cursor:pointer;font-family:inherit;border:1px solid rgba(255,255,255,.1);transition:all .12s}.nc-modal-actions .nc-modal-cancel{background:transparent;color:var(--text-secondary)}.nc-modal-actions .nc-modal-cancel:hover{background:#ffffff0a}.nc-modal-actions .nc-modal-submit{background:#3b82f626;color:#60a5fa;border-color:#3b82f64d}.nc-modal-actions .nc-modal-submit:hover{background:#3b82f640}.nc-modal-actions .nc-modal-submit.resolve{background:#22c55e26;color:#4ade80;border-color:#22c55e4d}.nc-modal-actions .nc-modal-submit.bug{background:#f9731626;color:#fb923c;border-color:#f973164d}.nc-loading{display:flex;align-items:center;justify-content:center;padding:60px 20px;color:#ffffff4d;font-size:13px;gap:10px}.nc-loading .spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.1);border-top-color:#3b82f6;border-radius:50%;animation:nc-spin .6s linear infinite}@keyframes nc-spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.nc-stats-grid{grid-template-columns:repeat(2,1fr)}.nc-item-title{max-width:280px}}@media(max-width:768px){.nc-stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.nc-controls{flex-direction:row;flex-wrap:wrap;gap:8px}.nc-search{min-width:100%;order:-1}.nc-filter-pill{flex:0 0 auto;padding:6px 10px;font-size:11px}.nc-item{padding:12px;gap:10px}.nc-item-actions{opacity:1;flex-direction:column;gap:4px}.nc-item-title{max-width:200px}.nc-checkbox{display:none}.nc-tabs{gap:0}.nc-tab{padding:8px 12px;font-size:12px}}@media(max-width:480px){.nc-stats-grid{grid-template-columns:1fr 1fr}.nc-stat-card{padding:10px 12px}.nc-stat-value{font-size:20px}}.nc-item.expanded{background:#ffffff08;border-color:#ffffff1f}.nc-item.expanded .nc-item-actions{opacity:1}.nc-detail{width:100%;padding:14px 0 4px 58px;display:flex;flex-direction:column;gap:12px;border-top:1px solid rgba(255,255,255,.06);margin-top:10px}.nc-detail-section h5{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;display:flex;align-items:center;gap:5px;text-transform:uppercase;letter-spacing:.3px}.nc-detail-section p{font-size:13px;color:var(--text-secondary);line-height:1.6;margin:0}.nc-fix-steps{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:6px}.nc-fix-steps li{font-size:13px;color:#4ade80;line-height:1.5}.nc-ccm-notice{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#f973160f;border:1px solid rgba(249,115,22,.15);border-radius:8px;color:#fb923c}.nc-ccm-notice strong{font-size:13px;display:block;margin-bottom:2px}.nc-ccm-notice p{font-size:12px;color:var(--text-secondary);margin:0}.nc-raw-details{font-size:12px;color:var(--text-secondary)}.nc-raw-details summary{cursor:pointer;font-weight:500;color:var(--text-secondary);padding:4px 0;-webkit-user-select:none;user-select:none}.nc-raw-details summary:hover{color:var(--text-primary)}.nc-raw-details code{display:block;margin-top:8px;padding:10px 12px;background:#0000004d;border-radius:6px;font-family:SF Mono,Fira Code,monospace;font-size:11px;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto}.nc-bugcode{display:inline-block;margin-top:6px;font-size:11px;padding:2px 8px;border-radius:4px;background:#f973161a;color:#fb923c}.nc-detail-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:11px;color:#ffffff4d;padding-top:8px;border-top:1px solid rgba(255,255,255,.04)}.nc-item{flex-wrap:wrap}@media(max-width:768px){.nc-detail{padding-left:0}}.nc-link-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:8px;color:#60a5fa;font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.nc-link-btn:hover{background:#3b82f626;border-color:#3b82f659}.nc-link-btn svg{width:13px;height:13px}.nc-cat-badge.alert-rule{background:#3b82f61a;color:#60a5fa}.nc-cat-badge.device-error{background:#f59e0b1a;color:#fbbf24}.survey-detail-root{display:flex;flex-direction:column;height:100vh;background:#0d0d0d;overflow:hidden;position:relative;scrollbar-width:none}.survey-detail-root::-webkit-scrollbar,.survey-detail-canvas::-webkit-scrollbar{display:none}.survey-detail-topbar{display:flex;align-items:center;gap:16px;padding:12px 20px;background:#161616;border-bottom:1px solid #2a2a2a;z-index:10;flex-shrink:0}.topbar-back{display:flex;align-items:center;gap:6px;background:none;border:none;color:#9ca3af;font-size:13px;cursor:pointer;padding:6px 10px;border-radius:6px;transition:background .15s,color .15s;white-space:nowrap}.topbar-back:hover{background:#232323;color:#e5e7eb}.topbar-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.topbar-map-name{font-size:15px;font-weight:600;color:#f3f4f6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-building,.topbar-floor{font-size:12px;color:#6b7280;white-space:nowrap}.source-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap;letter-spacing:.3px}.badge-satellite{background:#10b98126;color:#34d399}.badge-imported{background:#3b82f626;color:#60a5fa}.topbar-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.device-count-label{font-size:12px;color:#6b7280}.btn-primary{display:flex;align-items:center;gap:6px;background:#16a34a;color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover{background:#15803d}.btn-sm{padding:7px 14px}.btn-secondary{background:#232323;color:#d1d5db;border:1px solid #2a2a2a;border-radius:7px;padding:8px 16px;font-size:13px;cursor:pointer;transition:background .15s}.btn-secondary:hover{background:#2a2a2a}.survey-detail-canvas{flex:1;position:relative;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none}.survey-detail-canvas.is-panning{cursor:grabbing}.floor-plan-image-wrapper{position:relative;display:inline-block}.floor-plan-image{display:block;max-width:none;border-radius:4px;box-shadow:0 0 0 1px #ffffff0f,0 8px 40px #0009;pointer-events:none}.device-marker{position:absolute;width:28px;height:28px;border-radius:50%;background:color-mix(in srgb,var(--marker-color) 20%,#111);border:2px solid var(--marker-color);color:var(--marker-color);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s,box-shadow .15s;z-index:5;padding:0}.device-marker:hover{transform:translate(-50%,-50%) scale(1.25)!important;box-shadow:0 0 0 4px color-mix(in srgb,var(--marker-color) 30%,transparent);z-index:10}.device-marker--selected{box-shadow:0 0 0 3px var(--marker-color),0 0 12px color-mix(in srgb,var(--marker-color) 50%,transparent);z-index:20}.device-marker--selected:after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid var(--marker-color);animation:markerPulse 1.5s ease-out infinite;pointer-events:none}@keyframes markerPulse{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(1.8)}}.device-marker svg,.zoom-controls svg,.topbar-back svg,.topbar-actions svg,.dip-icon svg,.dip-close svg,.canvas-empty-hint svg{width:auto;height:auto;max-width:unset}.zoom-controls{position:absolute;bottom:24px;right:24px;display:flex;flex-direction:column;align-items:center;gap:4px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:10px;padding:6px;z-index:10}.zoom-btn{width:32px;height:32px;background:none;border:none;color:#9ca3af;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.zoom-btn:hover{background:#252525;color:#e5e7eb}.zoom-level{font-size:11px;font-weight:600;color:#6b7280;min-width:36px;text-align:center}.zoom-divider{width:20px;height:1px;background:#2a2a2a;margin:2px 0}.canvas-empty-hint{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:#161616e6;border:1px solid #2a2a2a;border-radius:20px;padding:8px 16px;color:#6b7280;font-size:13px;pointer-events:none;z-index:10;white-space:nowrap}.canvas-empty-hint strong{color:#9ca3af}.survey-detail-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#6b7280;font-size:14px}.spinner{width:28px;height:28px;border:3px solid #2a2a2a;border-top-color:#16a34a;border-radius:50%;animation:spin .7s linear infinite}.device-info-panel{position:absolute;top:16px;right:16px;width:280px;background:#161616;border:1px solid #2a2a2a;border-radius:12px;box-shadow:0 8px 32px #00000080;z-index:30;animation:dipSlideIn .18s ease;overflow:hidden}@keyframes dipSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dip-header{display:flex;align-items:center;gap:12px;padding:14px 14px 12px;border-bottom:1px solid #222}.dip-icon{width:38px;height:38px;border-radius:8px;background:color-mix(in srgb,var(--marker-color) 15%,#111);border:1px solid color-mix(in srgb,var(--marker-color) 40%,transparent);color:var(--marker-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dip-title{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.dip-name{font-size:14px;font-weight:600;color:#f3f4f6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dip-type{font-size:11px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.dip-close{background:none;border:none;color:#4b5563;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:color .12s;flex-shrink:0}.dip-close:hover{color:#9ca3af}.dip-body{padding:10px 14px 14px;display:flex;flex-direction:column;gap:8px}.dip-row{display:flex;justify-content:space-between;gap:8px;font-size:12px}.dip-row-label{color:#6b7280;white-space:nowrap}.dip-row-value{color:#d1d5db;text-align:right;word-break:break-all}.mp-root{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary, #0f172a);overflow:hidden}.mp-loading{display:flex;align-items:center;justify-content:center;gap:12px;height:100vh;color:var(--text-secondary, #94a3b8);font-size:15px}.mp-topbar{display:flex;align-items:center;justify-content:space-between;height:52px;padding:0 16px;background:var(--bg-secondary, #1e293b);border-bottom:1px solid var(--border-color, #334155);flex-shrink:0;z-index:10}.mp-topbar-left{display:flex;align-items:center;gap:12px}.mp-topbar-right{display:flex;align-items:center;gap:10px}.mp-back-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary, #94a3b8);font-size:13px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .15s,background .15s}.mp-back-btn:hover{color:var(--text-primary, #e2e8f0);background:var(--bg-hover, #334155)}.mp-title{font-size:15px;font-weight:600;color:var(--text-primary, #e2e8f0)}.mp-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;background:#00d4aa26;color:#00d4aa;border:1px solid rgba(0,212,170,.3)}.mp-placed-count{font-size:13px;color:var(--text-secondary, #94a3b8)}.mp-body{display:flex;flex:1;overflow:hidden}.mp-sidebar{width:240px;flex-shrink:0;background:var(--bg-secondary, #1e293b);border-right:1px solid var(--border-color, #334155);display:flex;flex-direction:column;overflow:hidden}.mp-sidebar-tabs{display:flex;border-bottom:1px solid var(--border-color, #334155);flex-shrink:0}.mp-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:10px 6px;background:none;border:none;font-size:12px;color:var(--text-secondary, #94a3b8);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.mp-tab:hover{color:var(--text-primary, #e2e8f0)}.mp-tab--active{color:#00d4aa;border-bottom-color:#00d4aa}.mp-sidebar-search{padding:8px 10px;border-bottom:1px solid var(--border-color, #334155);flex-shrink:0}.mp-search-input{width:100%;background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:6px;padding:5px 10px;font-size:12px;color:var(--text-primary, #e2e8f0);outline:none;box-sizing:border-box}.mp-search-input:focus{border-color:#00d4aa}.mp-search-input::placeholder{color:var(--text-muted, #64748b)}.mp-device-list{flex:1;overflow-y:auto;padding:6px}.mp-device-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:6px;cursor:grab;-webkit-user-select:none;user-select:none;transition:background .15s}.mp-device-item:hover{background:var(--bg-hover, #334155)}.mp-device-item:active{cursor:grabbing}.mp-device-item--placed{opacity:.45;cursor:default}.mp-device-icon{width:24px;height:24px;border-radius:50%;background:color-mix(in srgb,var(--marker-color) 20%,transparent);border:1px solid color-mix(in srgb,var(--marker-color) 50%,transparent);display:flex;align-items:center;justify-content:center;color:var(--marker-color);flex-shrink:0}.mp-device-name{font-size:12px;color:var(--text-primary, #e2e8f0);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mp-placed-badge{font-size:11px;color:#10b981;flex-shrink:0}.mp-empty{padding:20px 10px;text-align:center;font-size:12px;color:var(--text-muted, #64748b)}.mp-canvas{flex:1;position:relative;overflow:hidden;cursor:grab;background:#0a0f1a}.mp-canvas.is-panning{cursor:grabbing}.mp-canvas--dragover{outline:2px dashed #00d4aa;outline-offset:-4px}.mp-transform-layer,.mp-canvas--dragover .mp-transform-layer{pointer-events:all}.mp-image-wrapper{position:relative;display:inline-block;pointer-events:all}.mp-floor-image{display:block;max-width:100%;-webkit-user-select:none;user-select:none;pointer-events:none}.mp-placed-marker{position:absolute;width:26px;height:26px;border-radius:50%;background:color-mix(in srgb,var(--marker-color) 25%,#0f172a 75%);border:2px solid var(--marker-color);display:flex;align-items:center;justify-content:center;color:var(--marker-color);cursor:default;pointer-events:all}.mp-remove-btn{position:absolute;top:-5px;right:-5px;width:14px;height:14px;border-radius:50%;background:#ef4444;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s;padding:0}.mp-placed-marker:hover .mp-remove-btn{opacity:1}.mp-zoom-controls{position:absolute;bottom:16px;right:16px;display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;padding:4px;z-index:10}.zoom-btn{width:28px;height:28px;background:none;border:none;color:var(--text-secondary, #94a3b8);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.zoom-btn:hover{color:var(--text-primary, #e2e8f0);background:var(--bg-hover, #334155)}.zoom-level{font-size:11px;color:var(--text-secondary, #94a3b8);min-width:32px;text-align:center;padding:2px 0}.zoom-divider{width:20px;height:1px;background:var(--border-color, #334155);margin:2px 0}.mp-drop-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#00d4aa26;border:2px dashed #00d4aa;color:#00d4aa;font-size:14px;font-weight:600;padding:12px 24px;border-radius:10px;pointer-events:none;z-index:20}.mp-top-tabs{display:flex;border-bottom:1px solid var(--border-color, #334155);flex-shrink:0}.mp-top-tab{flex:1;padding:10px 8px;background:none;border:none;font-size:13px;font-weight:500;color:var(--text-secondary, #94a3b8);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.mp-top-tab:hover{color:var(--text-primary, #e2e8f0)}.mp-top-tab--active{color:#00d4aa;border-bottom-color:#00d4aa}.mp-generic-header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid var(--border-color, #334155);flex-shrink:0}.mp-generic-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted, #64748b)}.mp-add-btn{display:flex;align-items:center;gap:4px;background:#00d4aa1a;border:1px solid rgba(0,212,170,.3);color:#00d4aa;font-size:12px;font-weight:500;padding:3px 10px;border-radius:6px;cursor:pointer;transition:background .15s}.mp-add-btn:hover{background:#00d4aa33}.mp-add-form{padding:10px;border-bottom:1px solid var(--border-color, #334155);display:flex;flex-direction:column;gap:8px;background:var(--bg-primary, #0f172a);flex-shrink:0}.mp-form-row{display:flex;flex-direction:column;gap:3px}.mp-form-row label{font-size:11px;font-weight:500;color:var(--text-muted, #64748b);text-transform:uppercase;letter-spacing:.04em}.mp-form-input{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:6px;padding:5px 8px;font-size:12px;color:var(--text-primary, #e2e8f0);outline:none;width:100%;box-sizing:border-box}.mp-form-input:focus{border-color:#00d4aa}.mp-form-input option{background:var(--bg-secondary, #1e293b)}.mp-form-actions{display:flex;gap:6px;justify-content:flex-end}.mp-form-cancel{background:none;border:1px solid var(--border-color, #334155);color:var(--text-secondary, #94a3b8);font-size:12px;padding:4px 12px;border-radius:6px;cursor:pointer}.mp-form-cancel:hover{color:var(--text-primary, #e2e8f0)}.mp-form-save{background:#00d4aa;border:none;color:#0f172a;font-size:12px;font-weight:600;padding:4px 14px;border-radius:6px;cursor:pointer;transition:background .15s}.mp-form-save:hover{background:#00b894}.mp-form-save:disabled{opacity:.4;cursor:default}.mp-device-info{flex:1;display:flex;flex-direction:column;overflow:hidden}.mp-device-sub{font-size:10px;color:var(--text-muted, #64748b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-remove-generic-btn{background:none;border:none;color:var(--text-muted, #64748b);cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center;opacity:0;transition:opacity .15s,color .15s;flex-shrink:0}.mp-device-item:hover .mp-remove-generic-btn{opacity:1}.mp-remove-generic-btn:hover{color:#ef4444}.mp-canvas--placing,.mp-canvas--placing *{cursor:crosshair!important}.mp-rotation-popover{position:fixed;bottom:80px;left:50%;transform:translate(-50%);width:300px;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;box-shadow:0 8px 32px #0000008c;z-index:40;overflow:hidden;animation:rpSlideUp .18s ease}@keyframes rpSlideUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.mp-rp-header{display:flex;align-items:center;gap:10px;padding:12px 14px 10px;border-bottom:1px solid var(--border-color, #334155)}.mp-rp-device-icon{width:30px;height:30px;border-radius:50%;background:color-mix(in srgb,var(--marker-color) 20%,transparent);border:1.5px solid color-mix(in srgb,var(--marker-color) 50%,transparent);color:var(--marker-color);display:flex;align-items:center;justify-content:center;flex-shrink:0}.mp-rp-title{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.mp-rp-name{font-size:13px;font-weight:600;color:var(--text-primary, #e2e8f0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-rp-sub{font-size:11px;color:var(--text-muted, #64748b)}.mp-rp-deg-badge{font-size:12px;font-weight:700;color:#00d4aa;min-width:60px;text-align:right;flex-shrink:0}.mp-rp-body{padding:12px 14px 10px;display:flex;flex-direction:column;gap:8px}.mp-rp-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted, #64748b);margin-top:2px}.mp-rp-presets{display:flex;gap:6px}.mp-rp-preset{flex:1;padding:5px 0;background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);color:var(--text-secondary, #94a3b8);border-radius:6px;font-size:12px;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.mp-rp-preset:hover{color:var(--text-primary, #e2e8f0);background:var(--bg-hover, #334155)}.mp-rp-preset--active{background:#00d4aa1a;border-color:#00d4aa66;color:#00d4aa}.mp-rp-controls{display:flex;align-items:center;gap:4px}.mp-rp-adj-btn{background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);color:var(--text-secondary, #94a3b8);border-radius:5px;font-size:11px;padding:5px 7px;cursor:pointer;white-space:nowrap;transition:color .12s,background .12s}.mp-rp-adj-btn:hover{color:var(--text-primary, #e2e8f0);background:var(--bg-hover, #334155)}.mp-rp-input{flex:1;min-width:0;background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:6px;padding:4px 6px;font-size:13px;font-weight:600;color:var(--text-primary, #e2e8f0);outline:none;text-align:center}.mp-rp-input:focus{border-color:#00d4aa}.mp-rp-input::-webkit-inner-spin-button,.mp-rp-input::-webkit-outer-spin-button{-webkit-appearance:none}.mp-rp-input[type=number]{-moz-appearance:textfield}.mp-rp-slider{width:100%;accent-color:#00d4aa;cursor:pointer}.mp-rp-footer{display:flex;gap:8px;justify-content:flex-end;padding:10px 14px 12px;border-top:1px solid var(--border-color, #334155)}.mp-rp-skip{background:none;border:1px solid var(--border-color, #334155);color:var(--text-secondary, #94a3b8);font-size:12px;padding:5px 14px;border-radius:6px;cursor:pointer;transition:color .12s}.mp-rp-skip:hover{color:var(--text-primary, #e2e8f0)}.mp-rp-confirm{display:flex;align-items:center;gap:5px;background:#00d4aa;border:none;color:#0f172a;font-size:12px;font-weight:600;padding:5px 16px;border-radius:6px;cursor:pointer;transition:background .12s}.mp-rp-confirm:hover{background:#00b894}svg.mp-fov-cone{overflow:visible!important}.mp-rp-range-row{display:flex;align-items:center;gap:8px}.mp-rp-range-val{font-size:10px;color:var(--text-muted, #64748b);white-space:nowrap;flex-shrink:0}.mp-move-btn{position:absolute;top:-5px;left:-5px;width:14px;height:14px;border-radius:50%;background:#3b82f6;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s;padding:0}.mp-placed-marker:hover .mp-move-btn{opacity:1}.ra-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:60vh;color:var(--text-tertiary)}.ra-loading .spin{animation:ra-spin 1s linear infinite}@keyframes ra-spin{to{transform:rotate(360deg)}}.ra-page{padding:24px;max-width:100%}.ra-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.ra-header-left{display:flex;align-items:center;gap:12px}.ra-header-icon{color:var(--accent)}.ra-header h1{font-size:22px;font-weight:600;color:var(--text-primary);margin:0}.ra-subtitle{font-size:13px;color:var(--text-secondary);margin:2px 0 0}.ra-header-actions{display:flex;align-items:center;gap:10px}.ra-service-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.ra-service-badge.active{background:#22c55e1f;color:#22c55e}.ra-service-badge.inactive{background:#ef44441f;color:#ef4444}.ra-summary-grid{display:grid;grid-template-columns:200px repeat(5,1fr);gap:12px;margin-bottom:24px}.ra-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:var(--shadow-sm)}.ra-gauge-card{display:flex;flex-direction:column;align-items:center;justify-content:center;grid-row:span 1}.ra-gauge-container{position:relative;width:140px;height:80px;overflow:hidden}.ra-gauge-label{position:absolute;bottom:4px;left:50%;transform:translate(-50%);text-align:center}.ra-gauge-value{display:block;font-size:26px;font-weight:700;line-height:1}.ra-gauge-text{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.ra-gauge-status{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;margin-top:8px}.ra-stat-card{display:flex;align-items:center;gap:12px}.ra-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ra-stat-content{display:flex;flex-direction:column}.ra-stat-value{font-size:22px;font-weight:700;color:var(--text-primary);line-height:1}.ra-stat-label{font-size:12px;color:var(--text-secondary);margin-top:2px}.ra-cameras-section{padding:0}.ra-cameras-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:12px}.ra-cameras-header h2{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.ra-cameras-controls{display:flex;align-items:center;gap:8px}.ra-search{display:flex;align-items:center;gap:6px;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:6px 10px;color:var(--text-tertiary);box-shadow:var(--shadow-sm)}.ra-search input{background:none;border:none;outline:none;color:var(--text-primary);font-size:13px;width:140px}.ra-search input::placeholder{color:var(--text-tertiary)}.ra-filter-group{display:flex;align-items:center;gap:6px;color:var(--text-tertiary)}.ra-filter-group select{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:6px 10px;color:var(--text-primary);font-size:13px;outline:none;cursor:pointer;box-shadow:var(--shadow-sm)}.ra-cameras-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;padding:16px}.ra-camera-card{background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid;border-radius:8px;box-shadow:var(--shadow-sm);padding:12px 14px;transition:background .15s}.ra-camera-card:hover{background:var(--bg-page)}.ra-camera-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.ra-camera-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ra-camera-name{flex:1;font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ra-camera-confidence{font-size:14px;font-weight:700;flex-shrink:0}.ra-camera-details{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.ra-camera-tag{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--text-tertiary);background:#ffffff0a;padding:2px 8px;border-radius:4px}.ra-camera-actions{display:flex;justify-content:flex-end}.btn-xs{font-size:11px;padding:3px 8px;gap:4px}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-tertiary);cursor:pointer;border-radius:6px;display:inline-flex;align-items:center;gap:4px;transition:all .15s}.ra-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px;color:var(--text-tertiary)}.spin{animation:ra-spin 1s linear infinite}@media(max-width:1024px){.ra-summary-grid{grid-template-columns:repeat(3,1fr)}.ra-gauge-card{grid-column:span 3}}@media(max-width:768px){.ra-page{padding:16px}.ra-summary-grid{grid-template-columns:repeat(2,1fr)}.ra-gauge-card{grid-column:span 2}.ra-cameras-grid{grid-template-columns:1fr}.ra-cameras-header{flex-direction:column;align-items:flex-start}.ra-cameras-controls{flex-wrap:wrap}}@media(max-width:480px){.ra-summary-grid{grid-template-columns:1fr}.ra-gauge-card{grid-column:span 1}}.ra-gauge-container{position:relative;width:140px;height:90px;overflow:hidden}.ra-gauge-label{position:absolute;bottom:0;left:50%;transform:translate(-50%);text-align:center}.ra-gauge-value{display:block;font-size:22px;font-weight:700;line-height:1}.ra-tooltip-wrapper{position:relative;display:inline-flex;align-items:center;cursor:help}.ra-tooltip-icon{color:var(--text-tertiary);opacity:.5;transition:opacity .15s}.ra-tooltip-wrapper:hover .ra-tooltip-icon{opacity:1}.ra-tooltip-popup{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-size:12px;line-height:1.5;color:var(--text-secondary);width:280px;z-index:100;box-shadow:0 8px 24px #0006;pointer-events:none}.ra-detail-header{display:flex;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}.ra-detail-title{display:flex;align-items:center;gap:10px;flex:1}.ra-detail-title h1{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.ra-detail-title svg{color:var(--accent)}.ra-status-banner{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:12px;border:1px solid;margin-bottom:20px;flex-wrap:wrap}.ra-status-banner-left{display:flex;align-items:center;gap:12px;flex:1}.ra-status-banner-label{font-size:18px;font-weight:600;display:block}.ra-status-banner-score{font-size:13px;color:var(--text-tertiary)}.ra-status-banner-time{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-tertiary)}.ra-root-cause{margin-bottom:20px}.ra-root-cause-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.ra-root-cause-header h3{font-size:15px;font-weight:600;color:var(--text-primary);margin:0}.ra-root-cause-primary{font-size:16px;font-weight:600;margin-bottom:10px}.ra-root-cause-critical .ra-root-cause-header svg,.ra-root-cause-critical .ra-root-cause-primary{color:#ef4444}.ra-root-cause-warning .ra-root-cause-header svg,.ra-root-cause-warning .ra-root-cause-primary{color:#f59e0b}.ra-root-cause-success .ra-root-cause-header svg,.ra-root-cause-success .ra-root-cause-primary{color:#22c55e}.ra-root-cause-info .ra-root-cause-header svg,.ra-root-cause-info .ra-root-cause-primary{color:var(--accent-hover)}.ra-root-cause-details{list-style:none;padding:0;margin:0}.ra-root-cause-details li{font-size:13px;color:var(--text-secondary);line-height:1.6;padding:4px 0 4px 16px;position:relative}.ra-root-cause-details li:before{content:"";position:absolute;left:0;top:11px;width:6px;height:6px;border-radius:50%;background:var(--text-tertiary)}.ra-layers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.ra-layer-card{padding:0}.ra-layer-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text-primary)}.ra-layer-header svg:first-child{color:var(--accent)}.ra-layer-result{margin-left:auto;font-weight:600;font-size:12px;text-transform:uppercase}.ra-layer-body{display:flex;flex-wrap:wrap;gap:16px;padding:14px 16px}.ra-layer-stat{display:flex;flex-direction:column}.ra-layer-stat-value{font-size:20px;font-weight:700;color:var(--text-primary)}.ra-layer-stat-label{font-size:11px;color:var(--text-tertiary);margin-top:2px}.ra-layer-detail{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-tertiary);padding:6px 10px;background:#ffffff08;border-radius:6px;width:100%}.ra-layer-detail-warning{color:#f59e0b;background:#f59e0b14}.ra-layer-detail-ok{color:#22c55e;background:#22c55e14}.ra-layer-empty{padding:14px 16px;font-size:13px;color:var(--text-tertiary);margin:0}.ra-gaps-section{margin-bottom:20px;padding:0}.ra-gaps-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border)}.ra-gaps-header h3{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:var(--text-primary);margin:0}.ra-time-toggle{display:flex;gap:4px}.ra-time-toggle .active{background:#00d4aa26;color:var(--accent);border-color:#00d4aa4d}.ra-gaps-list{padding:12px 16px;display:flex;flex-direction:column;gap:8px}.ra-gap-item{display:flex;align-items:center;gap:16px;padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border);border-left:3px solid;border-radius:8px;flex-wrap:wrap;box-shadow:var(--shadow-sm)}.ra-gap-severity{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;min-width:140px}.ra-gap-times{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);flex:1}.ra-gap-duration{font-size:12px;color:var(--text-tertiary);font-weight:500}.ra-gap-resolved{display:flex;align-items:center;gap:4px;font-size:11px;color:#22c55e}.ra-checks-section{margin-bottom:20px}.ra-checks-section h3{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.ra-checks-table{display:flex;flex-direction:column;gap:2px}.ra-checks-row{display:grid;grid-template-columns:100px 160px 80px 80px;gap:8px;padding:8px 12px;font-size:12px;color:var(--text-secondary);border-radius:6px}.ra-checks-row:nth-child(2n){background:#ffffff05}.ra-checks-header-row{font-weight:600;color:var(--text-tertiary);text-transform:uppercase;font-size:11px;letter-spacing:.5px;border-bottom:1px solid var(--border);padding-bottom:8px;margin-bottom:4px}.ra-check-type{text-transform:capitalize;font-size:11px}.ra-nfg-note{display:flex;align-items:flex-start;gap:10px;font-size:12px;color:var(--text-tertiary);line-height:1.6;border-left:3px solid var(--accent)}.ra-nfg-note svg:first-child{color:var(--accent);flex-shrink:0;margin-top:2px}.ra-camera-card{cursor:pointer}.ra-camera-card:hover{border-color:#ffffff26}@media(max-width:1024px){.ra-layers-grid{grid-template-columns:1fr}}@media(max-width:768px){.ra-detail-header,.ra-status-banner,.ra-gap-item{flex-direction:column;align-items:flex-start}.ra-checks-row{grid-template-columns:80px 120px 60px 60px;font-size:11px}}.ra-learning-banner{display:flex;gap:16px;padding:16px 20px;background:#0ea5e90f;border:1px solid rgba(14,165,233,.2);border-radius:12px;margin-bottom:20px;align-items:flex-start}.ra-learning-banner-icon{width:44px;height:44px;border-radius:10px;background:#0ea5e91f;color:var(--accent-hover);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ra-learning-banner-content{flex:1}.ra-learning-banner-content strong{font-size:14px;color:var(--accent-hover);display:block;margin-bottom:4px}.ra-learning-banner-content p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0 0 10px}.ra-learning-progress{display:flex;align-items:center;gap:10px}.ra-learning-progress-bar{flex:1;height:6px;background:#0ea5e91a;border-radius:3px;overflow:hidden;max-width:200px}.ra-learning-progress-fill{height:100%;background:var(--accent-hover);border-radius:3px;transition:width .3s ease}.ra-learning-progress span{font-size:12px;color:var(--text-tertiary);white-space:nowrap}.ra-gauge-learning .ra-gauge-value{color:var(--accent-hover)}.ra-story-card{margin-bottom:20px}.ra-story-header{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid var(--border);color:var(--text-primary)}.ra-story-header h3{font-size:15px;font-weight:600;margin:0}.ra-story-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:0;padding:0}.ra-story-vms,.ra-story-ra{padding:20px}.ra-story-label{display:flex;align-items:center;gap:8px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;color:var(--text-tertiary);margin-bottom:16px}.ra-story-items{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.ra-story-item{display:flex;justify-content:space-between;align-items:center}.ra-story-key{font-size:13px;color:var(--text-tertiary)}.ra-story-val{font-size:13px;font-weight:600;color:var(--text-primary)}.ra-story-note{font-size:12px;line-height:1.6;color:var(--text-secondary);padding:10px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-surface)}.ra-story-divider{display:flex;align-items:center;justify-content:center;width:48px;position:relative}.ra-story-divider:before{content:"";position:absolute;top:20px;bottom:20px;left:50%;width:1px;background:var(--border)}.ra-story-vs{position:relative;z-index:1;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;letter-spacing:.5px;color:var(--text-tertiary);background:var(--bg-surface);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.ra-tooltip-wrapper{position:relative;display:inline-flex;align-items:center;cursor:help;margin-left:4px}.ra-tooltip-icon{color:var(--text-tertiary);opacity:.5}.ra-tooltip-popup{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);width:260px;padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;font-size:12px;color:var(--text-secondary);line-height:1.5;z-index:100;box-shadow:0 8px 24px #0000004d;pointer-events:none}.ra-tooltip-popup:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--border)}.ra-tab-active{background:#00d4aa1f;color:var(--accent)}@media(max-width:768px){.ra-story-grid{grid-template-columns:1fr}.ra-story-divider{width:100%;height:32px}.ra-story-divider:before{inset:50% 20px auto;width:auto;height:1px}}.ra-heatmap-card{margin-bottom:20px}.ra-heatmap-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);color:var(--text-primary)}.ra-heatmap-header h3{font-size:15px;font-weight:600;margin:0}.ra-heatmap-container{padding:16px 20px;position:relative;overflow-x:auto}.ra-heatmap-grid{display:grid;grid-template-columns:40px repeat(24,1fr);gap:2px;min-width:600px}.ra-heatmap-hour-label{font-size:9px;color:var(--text-tertiary);text-align:center;padding-bottom:4px;-webkit-user-select:none;user-select:none}.ra-heatmap-day-label{font-size:11px;font-weight:600;color:var(--text-tertiary);display:flex;align-items:center;padding-right:6px;-webkit-user-select:none;user-select:none}.ra-heatmap-cell{aspect-ratio:1;border-radius:3px;cursor:crosshair;transition:transform .1s,box-shadow .1s;position:relative;min-height:18px}.ra-heatmap-cell:hover,.ra-heatmap-cell.hovered{transform:scale(1.3);z-index:2;box-shadow:0 0 8px #0006}.ra-heatmap-cell.current{outline:2px solid var(--bg-surface);outline-offset:-1px;z-index:3;border-radius:3px}.ra-heatmap-current-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4px;height:4px;border-radius:50%;background:var(--bg-surface);box-shadow:0 0 4px #fffc}.ra-heatmap-tooltip{position:fixed;bottom:auto;padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;font-size:12px;color:var(--text-secondary);line-height:1.6;z-index:200;box-shadow:0 8px 24px #0006;pointer-events:none;position:absolute;top:8px;right:8px;min-width:180px}.ra-heatmap-tooltip strong{display:block;color:var(--text-primary);margin-bottom:4px;font-size:13px}.ra-heatmap-legend{display:flex;align-items:center;gap:8px;padding:8px 20px 4px}.ra-heatmap-legend-label{font-size:10px;color:var(--text-tertiary);white-space:nowrap}.ra-heatmap-legend-bar{display:flex;flex:1;max-width:200px;height:8px;border-radius:4px;overflow:hidden}.ra-heatmap-insights{padding:12px 20px 16px;display:flex;flex-wrap:wrap;gap:12px}.ra-heatmap-insight{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);padding:6px 12px;background:var(--bg-surface);border-radius:6px;border:.5px solid var(--border);box-shadow:var(--shadow-sm)}.ra-heatmap-insight strong{color:var(--text-primary)}@media(max-width:768px){.ra-heatmap-container{padding:12px}.ra-heatmap-cell{min-height:14px}.ra-heatmap-day-label{font-size:10px}.ra-heatmap-insights{flex-direction:column}}.ra-wizard-page{max-width:900px;margin:0 auto;padding:24px;min-height:calc(100vh - 64px);display:flex;flex-direction:column}.ra-wizard-progress{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:32px;padding:0 20px}.ra-wizard-step{display:flex;align-items:center;gap:8px}.ra-wizard-step-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:2px solid var(--border);color:var(--text-tertiary);transition:all .3s;flex-shrink:0;box-shadow:var(--shadow-sm)}.ra-wizard-step.active .ra-wizard-step-icon{background:#00d4aa26;border-color:var(--accent);color:var(--accent)}.ra-wizard-step.complete .ra-wizard-step-icon{background:var(--accent);border-color:var(--accent);color:var(--bg-surface)}.ra-wizard-step-label{font-size:12px;color:var(--text-tertiary);font-weight:500;white-space:nowrap}.ra-wizard-step.active .ra-wizard-step-label{color:var(--accent)}.ra-wizard-step.complete .ra-wizard-step-label{color:var(--text-primary)}.ra-wizard-step-line{width:40px;height:2px;background:var(--border);margin:0 4px;flex-shrink:0}.ra-wizard-step.complete+.ra-wizard-step .ra-wizard-step-line,.ra-wizard-step.complete .ra-wizard-step-line{background:var(--accent)}.ra-wizard-content{flex:1}.ra-wizard-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:var(--shadow-sm)}.ra-wizard-panel h2{font-size:22px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.ra-wizard-desc{font-size:14px;color:var(--text-tertiary);margin:0 0 24px}.ra-wizard-hero{text-align:center;padding:20px 0 32px}.ra-wizard-hero-icon{color:var(--accent);margin-bottom:16px}.ra-wizard-hero h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.ra-wizard-hero p{font-size:16px;color:var(--text-tertiary);margin:0}.ra-wizard-features{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.ra-wizard-feature{display:flex;gap:14px;padding:16px;background:var(--bg-page);border:1px solid var(--border);border-radius:12px}.ra-wizard-feature-icon{width:44px;height:44px;border-radius:10px;background:#00d4aa1a;color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ra-wizard-feature h3{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.ra-wizard-feature p{font-size:12px;color:var(--text-tertiary);line-height:1.5;margin:0}.ra-wizard-license-info{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px;background:var(--bg-page);border-radius:8px}.ra-wizard-license-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.ra-wizard-license-badge.trial{background:#0ea5e91f;color:var(--accent-hover)}.ra-wizard-license-badge.active{background:#22c55e1f;color:#22c55e}.ra-wizard-license-badge.expired{background:#ef44441f;color:#ef4444}.ra-wizard-license-cameras{font-size:12px;color:var(--text-tertiary)}.ra-wizard-vms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.ra-wizard-vms-card{background:var(--bg-page);border:2px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s;position:relative}.ra-wizard-vms-card:hover{border-color:#ffffff26;background:var(--bg-page)}.ra-wizard-vms-card.selected{border-color:var(--accent);background:#00d4aa0f}.ra-wizard-vms-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--text-tertiary)}.ra-wizard-vms-type{font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.ra-wizard-vms-card h3{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.ra-wizard-vms-host{font-size:12px;color:var(--text-tertiary)}.ra-wizard-vms-check{position:absolute;top:12px;right:12px;color:var(--accent)}.ra-wizard-test-area{display:flex;justify-content:center;align-items:center;min-height:280px}.ra-wizard-testing{text-align:center;color:var(--text-tertiary);display:flex;flex-direction:column;align-items:center;gap:12px}.ra-wizard-testing p{font-size:16px;color:var(--text-primary);margin:0}.ra-wizard-testing-sub{font-size:13px;color:var(--text-tertiary)}.ra-wizard-test-result{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.ra-wizard-test-result.success{color:#22c55e}.ra-wizard-test-result.error{color:#ef4444}.ra-wizard-test-result h3{font-size:20px;margin:0}.ra-wizard-test-result p{color:var(--text-tertiary);font-size:14px;margin:0}.ra-wizard-test-details{display:flex;gap:20px;margin-top:8px;font-size:13px;color:var(--text-secondary)}.ra-wizard-test-details span{display:flex;align-items:center;gap:6px}.ra-wizard-camera-controls{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.ra-wizard-camera-count{margin-left:auto;font-size:13px;color:var(--text-tertiary)}.ra-wizard-over-limit{color:#ef4444;font-weight:600}.ra-wizard-camera-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;max-height:400px;overflow-y:auto;padding-right:4px}.ra-wizard-camera-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s}.ra-wizard-camera-item:hover{background:var(--bg-page)}.ra-wizard-camera-item.selected{border-color:#00d4aa66;background:#00d4aa0f}.ra-wizard-camera-check{width:20px;height:20px;border-radius:4px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}.ra-wizard-camera-check.checked{background:var(--accent);border-color:var(--accent);color:var(--bg-surface)}.ra-wizard-camera-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ra-wizard-camera-meta{font-size:11px;color:var(--text-tertiary);display:flex;align-items:center;gap:4px}.ra-wizard-camera-dot{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary)}.ra-wizard-camera-dot.online{background:#22c55e}.ra-wizard-camera-dot.offline{background:#ef4444}.ra-wizard-review{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.ra-wizard-review-item{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;background:var(--bg-page);border-radius:10px;border:1px solid var(--border)}.ra-wizard-review-item svg{color:var(--accent);margin-top:2px;flex-shrink:0}.ra-wizard-review-item strong{display:block;font-size:13px;color:var(--text-primary);margin-bottom:2px}.ra-wizard-review-item span{font-size:12px;color:var(--text-tertiary)}.ra-wizard-confirm{text-align:center}.ra-wizard-confirm .btn-primary{padding:12px 32px;font-size:15px}.ra-wizard-complete{text-align:center;padding:20px 0}.ra-wizard-complete-icon{color:var(--accent);margin-bottom:16px}.ra-wizard-complete h2{font-size:24px;text-align:center}.ra-wizard-complete>p{font-size:15px;color:var(--text-tertiary);margin-bottom:32px}.ra-wizard-complete-timeline{display:flex;flex-direction:column;gap:0;max-width:400px;margin:0 auto 32px;text-align:left}.ra-wizard-timeline-item{display:flex;gap:14px;padding:12px 0;position:relative}.ra-wizard-timeline-item:before{content:"";position:absolute;left:7px;top:32px;bottom:-12px;width:2px;background:var(--border)}.ra-wizard-timeline-item:last-child:before{display:none}.ra-wizard-timeline-dot{width:16px;height:16px;border-radius:50%;background:var(--bg-page);border:2px solid var(--border);flex-shrink:0;margin-top:2px}.ra-wizard-timeline-item.active .ra-wizard-timeline-dot{background:var(--accent);border-color:var(--accent)}.ra-wizard-timeline-item strong{display:block;font-size:13px;color:var(--text-primary)}.ra-wizard-timeline-item span{font-size:12px;color:var(--text-tertiary)}.ra-wizard-complete-actions{display:flex;justify-content:center;gap:12px}.ra-wizard-empty{text-align:center;padding:40px;color:var(--text-tertiary);display:flex;flex-direction:column;align-items:center;gap:12px}.ra-wizard-nav{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}@media(max-width:768px){.ra-wizard-progress{flex-wrap:wrap;gap:4px}.ra-wizard-step-label{display:none}.ra-wizard-step-line{width:20px}.ra-wizard-features{grid-template-columns:1fr}.ra-wizard-panel{padding:20px}.ra-wizard-camera-grid{grid-template-columns:1fr}.ra-wizard-complete-actions{flex-direction:column}}:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 30px rgba(0,0,0,.12);--shadow-glow: 0 4px 20px rgba(99,102,241,.3);--transition-fast: .15s ease;--transition-normal: .25s ease}:root,[data-theme=indigo]{--accent: #6366F1;--accent-hover: #5558E6;--accent-alpha-08: rgba(99,102,241,.08);--accent-alpha-15: rgba(99,102,241,.15);--bg-page: #F2F2F7;--bg-surface: #FFFFFF;--text-primary: #1D1D1F;--text-secondary: #6E6E73;--text-tertiary: #AEAEB2;--border: rgba(0,0,0,.08);--border-strong: rgba(0,0,0,.15);--status-ok: #34C759;--status-ok-bg: rgba(52,199,89,.1);--status-ok-text: #1B8C3A;--status-warn: #FF9F0A;--status-warn-bg: rgba(255,159,10,.1);--status-warn-text: #996600;--status-error: #FF3B30;--status-error-bg: rgba(255,59,48,.08);--status-error-text: #CC2D25;--bg-sidebar: #13112E;--bg-sidebar-hover: rgba(255,255,255,.12);--bg-sidebar-text: rgba(255,255,255,.92);--bg-sidebar-text-hover: #fff}[data-theme=cobalt]{--accent: #2563EB;--accent-hover: #1D4ED8;--accent-alpha-08: rgba(37,99,235,.08);--accent-alpha-15: rgba(37,99,235,.15);--bg-page: #F0F4F8;--bg-surface: #FFFFFF;--text-primary: #1A202C;--text-secondary: #4A5568;--text-tertiary: #A0AEC0;--border: rgba(0,0,0,.08);--border-strong: rgba(0,0,0,.15);--status-ok: #34C759;--status-ok-bg: rgba(52,199,89,.1);--status-ok-text: #1B8C3A;--status-warn: #FF9F0A;--status-warn-bg: rgba(255,159,10,.1);--status-warn-text: #996600;--status-error: #FF3B30;--status-error-bg: rgba(255,59,48,.08);--status-error-text: #CC2D25;--bg-sidebar: #122840;--bg-sidebar-hover: rgba(255,255,255,.12);--bg-sidebar-text: rgba(255,255,255,.92);--bg-sidebar-text-hover: #fff}[data-theme=violet]{--accent: #7C3AED;--accent-hover: #6D28D9;--accent-alpha-08: rgba(124,58,237,.08);--accent-alpha-15: rgba(124,58,237,.15);--bg-page: #F5F3FF;--bg-surface: #FFFFFF;--text-primary: #1C1917;--text-secondary: #57534E;--text-tertiary: #A8A29E;--border: rgba(0,0,0,.08);--border-strong: rgba(0,0,0,.15);--status-ok: #34C759;--status-ok-bg: rgba(52,199,89,.1);--status-ok-text: #1B8C3A;--status-warn: #FF9F0A;--status-warn-bg: rgba(255,159,10,.1);--status-warn-text: #996600;--status-error: #FF3B30;--status-error-bg: rgba(255,59,48,.08);--status-error-text: #CC2D25;--bg-sidebar: #271350;--bg-sidebar-hover: rgba(255,255,255,.12);--bg-sidebar-text: rgba(255,255,255,.92);--bg-sidebar-text-hover: #fff}[data-theme=emerald]{--accent: #059669;--accent-hover: #047857;--accent-alpha-08: rgba(5,150,105,.08);--accent-alpha-15: rgba(5,150,105,.15);--bg-page: #F0FDF4;--bg-surface: #FFFFFF;--text-primary: #1A202C;--text-secondary: #4A5568;--text-tertiary: #A0AEC0;--border: rgba(0,0,0,.08);--border-strong: rgba(0,0,0,.15);--status-ok: #34C759;--status-ok-bg: rgba(52,199,89,.1);--status-ok-text: #1B8C3A;--status-warn: #FF9F0A;--status-warn-bg: rgba(255,159,10,.1);--status-warn-text: #996600;--status-error: #FF3B30;--status-error-bg: rgba(255,59,48,.08);--status-error-text: #CC2D25;--bg-sidebar: #0D3532;--bg-sidebar-hover: rgba(255,255,255,.12);--bg-sidebar-text: rgba(255,255,255,.92);--bg-sidebar-text-hover: #fff}[data-theme=greyscale]{--accent: #525252;--accent-hover: #404040;--accent-alpha-08: rgba(82,82,82,.08);--accent-alpha-15: rgba(82,82,82,.15);--bg-page: #F5F5F5;--bg-surface: #FFFFFF;--text-primary: #171717;--text-secondary: #525252;--text-tertiary: #A3A3A3;--border: rgba(0,0,0,.1);--border-strong: rgba(0,0,0,.2);--status-ok: #34C759;--status-ok-bg: rgba(52,199,89,.1);--status-ok-text: #1B8C3A;--status-warn: #FF9F0A;--status-warn-bg: rgba(255,159,10,.1);--status-warn-text: #996600;--status-error: #FF3B30;--status-error-bg: rgba(255,59,48,.08);--status-error-text: #CC2D25;--bg-sidebar: #1A1A1A;--bg-sidebar-hover: rgba(255,255,255,.08);--bg-sidebar-text: rgba(255,255,255,.85);--bg-sidebar-text-hover: #fff}[data-theme=midnight]{--accent: #818CF8;--accent-hover: #6366F1;--accent-alpha-08: rgba(129,140,248,.08);--accent-alpha-15: rgba(129,140,248,.15);--bg-page: #000000;--bg-surface: #111111;--text-primary: #F5F5F7;--text-secondary: #A0A0A0;--text-tertiary: #666666;--border: rgba(255,255,255,.1);--border-strong: rgba(255,255,255,.18);--status-ok: #34C759;--status-ok-bg: rgba(52,199,89,.15);--status-ok-text: #4ADE80;--status-warn: #FF9F0A;--status-warn-bg: rgba(255,159,10,.15);--status-warn-text: #FBBF24;--status-error: #FF453A;--status-error-bg: rgba(255,69,58,.15);--status-error-text: #FF6B6B;--bg-sidebar: #000000;--bg-sidebar-hover: rgba(255,255,255,.06);--bg-sidebar-text: rgba(255,255,255,.55);--bg-sidebar-text-hover: rgba(255,255,255,.85);--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 30px rgba(0,0,0,.5)}[data-theme=carbon]{--accent: #60A5FA;--accent-hover: #3B82F6;--accent-alpha-08: rgba(96,165,250,.08);--accent-alpha-15: rgba(96,165,250,.15);--bg-page: #0C1017;--bg-surface: #161B22;--text-primary: #E6EDF3;--text-secondary: #8B949E;--text-tertiary: #6E7681;--border: rgba(255,255,255,.08);--border-strong: rgba(255,255,255,.15);--status-ok: #34C759;--status-ok-bg: rgba(52,199,89,.15);--status-ok-text: #4ADE80;--status-warn: #FF9F0A;--status-warn-bg: rgba(255,159,10,.15);--status-warn-text: #FBBF24;--status-error: #FF453A;--status-error-bg: rgba(255,69,58,.15);--status-error-text: #FF6B6B;--bg-sidebar: #0C1017;--bg-sidebar-hover: rgba(255,255,255,.06);--bg-sidebar-text: rgba(255,255,255,.55);--bg-sidebar-text-hover: rgba(255,255,255,.85);--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 30px rgba(0,0,0,.5)}:root{--bg-primary: var(--bg-page);--bg-secondary: var(--bg-surface);--bg-tertiary: var(--bg-surface);--bg-elevated: var(--bg-surface);--bg-card: var(--bg-surface);--accent-primary: var(--accent);--accent-secondary: var(--accent-hover);--accent-warning: #f59e0b;--accent-danger: #ef4444;--accent-success: #22c55e;--accent-purple: #a855f7;--text-muted: var(--text-tertiary);--border-color: var(--border);--border-light: var(--border);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .6);--font-sans: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", monospace;--sidebar-width: 260px;--sidebar-collapsed: 72px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--transition-fast: .15s ease;--transition-base: .25s ease;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-sans);background:var(--bg-page);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}img{max-width:100%;height:auto}a:focus-visible,button:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}:focus{outline:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;padding:var(--space-sm) var(--space-md);background:var(--accent);color:var(--bg-page);z-index:9999;transition:top var(--transition-fast)}.skip-link:focus{top:0}#root{min-height:100vh}.app-layout,.app-container{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);padding:var(--space-lg);min-height:100vh;background:var(--bg-page);transition:margin-left var(--transition-base);overflow-x:hidden}.main-content.collapsed{margin-left:var(--sidebar-collapsed)}.card,.reader-card,.intercom-card,.ra-camera-card,.ra-card,.nc-item,.dd-section,.md-stat-card,.stat-card,.dashboard-widget,.dashboard-stat,.msw-card,.mdd-stat-card,.mdd-camera-card,.al-card,.reg-card,.widget-settings-modal{box-shadow:var(--shadow-sm)}@media(max-width:1024px){.sidebar{transform:translate(-100%);transition:transform var(--transition-base)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:var(--space-md)}.mobile-menu-btn{display:flex}.sidebar-collapse-btn{display:none}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:99;opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.sidebar.open~.sidebar-overlay{opacity:1;pointer-events:auto}}@media(max-width:768px){.home-grid{grid-template-columns:1fr}.lockdown-box{flex-direction:column;text-align:center}.lockdown-content,.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-sidebar);border-right:.5px solid rgba(255,255,255,.08);display:flex;flex-direction:column;z-index:100;transition:width var(--transition-base)}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-header{padding:var(--space-lg);border-bottom:.5px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center}.sidebar-logo{max-height:40px;width:auto}.sidebar-logo-placeholder{width:40px;height:40px;border-radius:var(--radius-lg);background:var(--accent);display:flex;align-items:center;justify-content:center;color:#fff}.sidebar-tenant{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-color)}.sidebar-tenant-single{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:13px;color:var(--bg-sidebar-text);border-bottom:.5px solid rgba(255,255,255,.08)}.sidebar-tenant-single span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar nav{flex:1;padding:var(--space-md) 0;overflow-y:auto}.nav-link{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);color:var(--bg-sidebar-text);transition:all var(--transition-fast);border-left:3px solid transparent;font-size:14px}.nav-link:hover{background:var(--bg-sidebar-hover);color:var(--bg-sidebar-text-hover)}.nav-link.active{background:var(--accent-alpha-15);color:var(--accent);border-left-color:var(--accent)}.nav-link span{font-size:14px;font-weight:500}.sidebar.collapsed .nav-link span,.sidebar.collapsed .nav-section-header span,.sidebar.collapsed .nav-section-header svg:last-child{display:none}.nav-section{margin-bottom:var(--space-xs)}.nav-section-header{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:var(--space-md) var(--space-lg);color:var(--bg-sidebar-text);font-size:14px;font-weight:500;text-align:left;transition:all var(--transition-fast)}.nav-section-header:hover{background:var(--bg-sidebar-hover);color:var(--bg-sidebar-text-hover)}.nav-section-header span{flex:1}.nav-section-items{padding-left:var(--space-sm);border-left:2px solid rgba(255,255,255,.08);margin-left:calc(var(--space-lg) + 10px)}.nav-link.nav-child{padding:var(--space-sm) var(--space-md);font-size:13px}.sidebar-footer{padding:var(--space-md);border-top:.5px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:var(--space-md)}.user-info{flex:1;min-width:0}.user-name{display:block;font-size:14px;font-weight:500;color:var(--bg-sidebar-text-hover);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{display:block;font-size:12px;color:var(--bg-sidebar-text)}.logout-btn{padding:var(--space-sm);color:var(--bg-sidebar-text);border-radius:var(--radius-md);transition:all var(--transition-fast)}.logout-btn:hover{background:var(--status-error-bg);color:var(--status-error)}.sidebar-collapse-btn{position:absolute;right:-12px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;background:var(--bg-sidebar);border:.5px solid rgba(255,255,255,.08);color:var(--bg-sidebar-text);display:flex;align-items:center;justify-content:center;z-index:101}.sidebar-collapse-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.sidebar-overlay{display:none}.nav-separator{height:1px;background:#ffffff14;margin:var(--space-md) var(--space-lg)}.nav-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px;margin-left:auto}.nav-badge.god-mode{background:#a855f733;color:#a855f7;border:.5px solid rgba(168,85,247,.3)}.nav-link.nav-platform{position:relative}.nav-link.nav-platform:hover{background:#a855f71a}.nav-link.nav-platform.active{background:#a855f726;color:#a855f7;border-left-color:#a855f7}.nav-link[title]:not([title=""]){position:relative}.sidebar.collapsed .nav-link:after{content:attr(title);position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:12px;padding:6px 12px;background:var(--bg-sidebar);color:var(--bg-sidebar-text-hover);border:.5px solid rgba(255,255,255,.12);border-radius:var(--radius-md);font-size:13px;white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:1000;pointer-events:none;box-shadow:var(--shadow-md)}.sidebar.collapsed .nav-link:hover:after{opacity:1;visibility:visible}.sidebar.collapsed .nav-link:before{content:"";position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:4px;border:6px solid transparent;border-right-color:var(--bg-sidebar);opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:1001}.sidebar.collapsed .nav-link:hover:before{opacity:1;visibility:visible}.sidebar:not(.collapsed) .nav-link:after,.sidebar:not(.collapsed) .nav-link:before{display:none}.sidebar-tenant-single span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.sidebar .tenant-name,.sidebar-tenant .tenant-name,.sidebar-tenant-single .tenant-name{color:var(--bg-sidebar-text-hover)!important}.sidebar nav::-webkit-scrollbar{width:6px}.sidebar nav::-webkit-scrollbar-track{background:transparent}.sidebar nav::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}.sidebar nav::-webkit-scrollbar-thumb:hover{background:#ffffff26}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 16px;font-size:14px;font-weight:500;border-radius:var(--radius-md);transition:all var(--transition-fast)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-page);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-surface)}.btn-danger{background:var(--accent-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-success{background:var(--accent-success);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a}.btn:focus{outline:none;box-shadow:0 0 0 3px #00d4aa4d}.btn:focus:not(:focus-visible){box-shadow:none}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px #00d4aa4d}.btn-danger:focus-visible{box-shadow:0 0 0 3px #ef44444d}.btn-secondary:focus-visible{box-shadow:0 0 0 3px #fff3}.tabs-container{margin-bottom:var(--space-lg)}.tabs-list{display:flex;gap:var(--space-xs);border-bottom:1px solid var(--border);padding-bottom:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-button{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;margin-bottom:-1px}.tab-button:hover{color:var(--text-primary);background:#ffffff05}.tab-button.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-button svg{flex-shrink:0}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--bg-page);border-radius:10px;font-size:11px;font-weight:600;color:var(--text-tertiary)}.tab-button.active .tab-badge{background:#00d4aa26;color:var(--accent)}.tab-panel{padding-top:var(--space-lg)}@media(max-width:768px){.tabs-list{gap:0}.tab-button{padding:var(--space-sm) var(--space-md);font-size:13px;flex:1;justify-content:center}.tab-button span:not(.tab-badge){display:none}.tab-button svg{margin:0}}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-fast);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.card:hover{border-color:#00d4aa4d}.card-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.card-header h3,.card-header .card-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.card-body{padding:var(--space-lg)}.card-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);display:flex;align-items:center;gap:var(--space-sm)}.card-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:#00d4aa26;color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.card-icon.warning{background:#f59e0b26;color:var(--accent-warning)}.card-icon.danger{background:#ef444426;color:var(--accent-danger)}.card-icon.success{background:#22c55e26;color:var(--accent-success)}.card-icon.info{background:#0ea5e926;color:var(--accent)}.card-actions{display:flex;gap:var(--space-sm);flex-shrink:0}.card-actions .btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.card-actions .btn-icon:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--accent);box-shadow:var(--shadow-sm)}.card-actions .btn-icon.delete:hover{background:#ef44441a;color:var(--accent-danger);border-color:var(--accent-danger)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-lg)}.card-list{display:flex;flex-direction:column;gap:var(--space-md)}.card-clickable{cursor:pointer}.card-clickable:hover{border-color:var(--accent);box-shadow:0 4px 20px #0000004d}.card-status{position:relative;padding-left:calc(var(--space-lg) + 4px)}.card-status:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.card-status.warning:before{background:var(--accent-warning)}.card-status.danger:before{background:var(--accent-danger)}.card-status.success:before{background:var(--accent-success)}@media(max-width:768px){.card-grid{grid-template-columns:1fr}.card-header{flex-wrap:wrap}.card-body{padding:var(--space-md)}}.card,.polished-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);transition:all var(--transition-base);overflow:hidden;box-shadow:var(--shadow-sm)}.card:hover,.polished-card:hover{border-color:#00d4aa66;box-shadow:0 8px 32px #0000004d}.card-header-polished{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border-bottom:1px solid var(--border)}.card-header-polished .card-icon{width:52px;height:52px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:24px}.card-icon.primary{background:linear-gradient(135deg,#00d4aa33,#00d4aa1a);color:var(--accent);border:1px solid rgba(0,212,170,.3)}.card-icon.secondary{background:linear-gradient(135deg,#0ea5e933,#0ea5e91a);color:var(--accent);border:1px solid rgba(14,165,233,.3)}.card-icon.warning{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);color:var(--accent-warning);border:1px solid rgba(245,158,11,.3)}.card-icon.danger{background:linear-gradient(135deg,#ef444433,#ef44441a);color:var(--accent-danger);border:1px solid rgba(239,68,68,.3)}.card-icon.success{background:linear-gradient(135deg,#22c55e33,#22c55e1a);color:var(--accent-success);border:1px solid rgba(34,197,94,.3)}.card-icon.purple{background:linear-gradient(135deg,#a855f733,#a855f71a);color:var(--accent-purple);border:1px solid rgba(168,85,247,.3)}.card-title-group{flex:1;min-width:0}.card-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 4px;line-height:1.3}.card-subtitle{font-size:13px;color:var(--text-secondary);margin:0;display:flex;align-items:center;gap:var(--space-sm)}.card-subtitle svg{width:14px;height:14px;color:var(--text-tertiary)}.card-header-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-lg);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-active,.badge-success{background:linear-gradient(135deg,#22c55e33,#22c55e1a);color:var(--accent-success);border:1px solid rgba(34,197,94,.3)}.badge-inactive,.badge-suspended,.badge-danger{background:linear-gradient(135deg,#ef444433,#ef44441a);color:var(--accent-danger);border:1px solid rgba(239,68,68,.3)}.badge-pending,.badge-warning{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);color:var(--accent-warning);border:1px solid rgba(245,158,11,.3)}.badge-info,.badge-primary{background:linear-gradient(135deg,#00d4aa33,#00d4aa1a);color:var(--accent);border:1px solid rgba(0,212,170,.3)}.badge-admin{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);color:var(--accent-warning);border:1px solid rgba(245,158,11,.3)}.badge-operator{background:linear-gradient(135deg,#0ea5e933,#0ea5e91a);color:var(--accent);border:1px solid rgba(14,165,233,.3)}.badge-viewer{background:linear-gradient(135deg,#6b728033,#6b72801a);color:var(--text-secondary);border:1px solid rgba(107,114,128,.3)}.badge-platform-admin{background:linear-gradient(135deg,#a855f733,#a855f71a);color:var(--accent-purple);border:1px solid rgba(168,85,247,.3)}.badge-sm{padding:3px 8px;font-size:10px}.badge-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.badge-active .badge-dot{animation:pulse-dot 2s infinite}.card-body-polished{padding:var(--space-lg)}.card-section{padding:var(--space-lg);border-bottom:1px solid var(--border)}.card-section:last-child{border-bottom:none}.card-section-title{display:flex;align-items:center;gap:var(--space-sm);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:var(--space-md)}.card-section-title svg{width:16px;height:16px;color:var(--accent)}.card-meta{display:flex;align-items:center;gap:var(--space-sm);font-size:13px;color:var(--text-secondary);padding:var(--space-sm) 0}.card-meta svg{width:16px;height:16px;color:var(--accent);flex-shrink:0}.card-meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.card-meta-item{display:flex;flex-direction:column;gap:4px}.card-meta-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary)}.card-meta-value{font-size:14px;font-weight:500;color:var(--text-primary)}.card-footer-polished{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-surface);border-top:1px solid var(--border);box-shadow:var(--shadow-sm)}.card-footer-polished.split{justify-content:space-between}.btn-action{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 16px;font-size:13px;font-weight:500;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-page);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-action:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--accent);box-shadow:var(--shadow-sm)}.btn-action.primary{background:var(--accent);border-color:var(--accent);color:var(--bg-page)}.btn-action.primary:hover{background:#00b894;border-color:#00b894}.btn-action.danger{color:var(--accent-danger);border-color:#ef44444d}.btn-action.danger:hover{background:#ef444426;border-color:var(--accent-danger)}.btn-action.success{color:var(--accent-success);border-color:#22c55e4d}.btn-action.success:hover{background:#22c55e26;border-color:var(--accent-success)}.btn-action-icon{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-page);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-action-icon:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-action-icon.danger:hover{background:#ef444426;color:var(--accent-danger);border-color:var(--accent-danger)}.btn-action-icon.success:hover{background:#22c55e26;color:var(--accent-success);border-color:var(--accent-success)}.pill{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:13px;color:var(--text-primary);transition:all var(--transition-fast)}.pill:hover{background:var(--bg-surface);border-color:var(--accent);box-shadow:var(--shadow-sm)}.pill .badge{margin-left:4px}.pill-remove{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff1a;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);margin-left:4px}.pill-remove:hover{background:#ef444433;color:var(--accent-danger)}.pills-container{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.card-expandable .card-expand-trigger{cursor:pointer}.card-expandable .card-expand-icon{transition:transform var(--transition-fast)}.card-expandable.expanded .card-expand-icon{transform:rotate(180deg)}.card-expand-content{max-height:0;overflow:hidden;transition:max-height var(--transition-base)}.card-expandable.expanded .card-expand-content{max-height:1000px}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:var(--space-lg)}.card-grid-2{grid-template-columns:repeat(2,1fr)}.card-grid-3{grid-template-columns:repeat(3,1fr)}@media(max-width:1200px){.card-grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.card-grid,.card-grid-2,.card-grid-3{grid-template-columns:1fr}}.card-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);text-align:center;color:var(--text-tertiary)}.card-empty-icon{width:64px;height:64px;border-radius:var(--radius-xl);background:var(--bg-page);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-md);color:var(--text-tertiary)}.card-empty-title{font-size:16px;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-xs)}.card-empty-description{font-size:14px;color:var(--text-tertiary);max-width:300px;margin-bottom:var(--space-lg)}.platform-site-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:0;overflow:hidden;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.platform-site-card:hover{border-color:#3b82f666;box-shadow:0 8px 32px #0000004d,0 0 0 1px #3b82f61a;transform:translateY(-2px)}.platform-site-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border-bottom:1px solid var(--border);margin-bottom:0}.platform-site-title{display:flex;align-items:center;gap:var(--space-md);flex:1;min-width:0}.platform-site-title h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.platform-card-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.platform-card-icon.site{background:linear-gradient(135deg,#3b82f633,#3b82f61a);color:#60a5fa;border:1px solid rgba(59,130,246,.3)}.platform-card-icon.org{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);color:var(--accent-warning);border:1px solid rgba(245,158,11,.3)}.platform-card-icon.user{background:linear-gradient(135deg,#a855f733,#a855f71a);color:var(--accent-purple);border:1px solid rgba(168,85,247,.3)}.platform-site-meta{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);font-size:13px;color:var(--text-secondary)}.platform-site-meta svg{width:14px;height:14px;color:var(--text-tertiary)}.platform-site-notes{font-size:13px;color:var(--text-secondary);font-style:italic;padding:0 var(--space-lg) var(--space-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.platform-site-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-surface);border-top:1px solid var(--border);box-shadow:var(--shadow-sm)}.platform-site-footer button,.platform-card-actions button{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-page);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.platform-site-footer button:hover,.platform-card-actions button:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.platform-site-footer button.delete:hover,.platform-card-actions button.delete:hover{background:#ef444426;color:var(--accent-danger);border-color:var(--accent-danger)}.platform-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.platform-badge.active{background:linear-gradient(135deg,#22c55e33,#22c55e1a);color:var(--accent-success);border:1px solid rgba(34,197,94,.3)}.platform-badge.admin{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);color:var(--accent-warning);border:1px solid rgba(245,158,11,.3)}.platform-badge.role{background:linear-gradient(135deg,#0ea5e933,#0ea5e91a);color:var(--accent);border:1px solid rgba(14,165,233,.3)}.platform-badge.pending{background:linear-gradient(135deg,#eab30833,#eab3081a);color:#facc15;border:1px solid rgba(234,179,8,.3)}.platform-badge.suspended{background:linear-gradient(135deg,#ef444433,#ef44441a);color:var(--accent-danger);border:1px solid rgba(239,68,68,.3)}.platform-user-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.platform-user-card:hover{border-color:#a855f766;box-shadow:0 8px 32px #0000004d,0 0 0 1px #a855f71a}.platform-user-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);flex-wrap:wrap}.platform-user-name{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:var(--space-xs)}.platform-user-name h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.platform-user-meta{display:flex;align-items:center;gap:var(--space-md);margin-top:var(--space-sm);font-size:12px;color:var(--text-tertiary);flex-wrap:wrap}.platform-user-meta span{display:flex;align-items:center;gap:4px}.platform-user-meta svg{width:12px;height:12px}.platform-user-notes{font-size:13px;color:var(--text-secondary);font-style:italic;padding:var(--space-sm) var(--space-md);margin:0 var(--space-md) var(--space-md);background:#ffffff08;border-left:3px solid rgba(168,85,247,.5);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.platform-user-body{border-top:1px solid var(--border);padding:var(--space-lg);background:var(--bg-surface);display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}.platform-user-section h4{display:flex;align-items:center;gap:var(--space-sm);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin:0 0 var(--space-md) 0}.platform-user-section h4 svg{width:14px;height:14px;color:var(--accent)}.platform-user-org{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary)}.platform-user-site{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;color:var(--text-primary);margin-bottom:var(--space-sm);transition:all var(--transition-fast)}.platform-user-site:hover{border-color:var(--accent);background:var(--bg-surface)}.platform-user-site button{width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.platform-add-site{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--accent);background:none;border:none;cursor:pointer;padding:var(--space-sm) 0;margin-top:var(--space-sm);transition:all var(--transition-fast)}.platform-add-site:hover{color:#00e5b8}.platform-empty-text{font-size:13px;color:var(--text-tertiary);font-style:italic}.platform-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.platform-card:hover{border-color:#f59e0b66;box-shadow:0 8px 32px #0000004d,0 0 0 1px #f59e0b1a}.platform-card-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);cursor:pointer;transition:background var(--transition-fast)}.platform-card-header:hover{background:linear-gradient(135deg,var(--bg-page) 0%,var(--bg-surface) 100%)}.platform-card-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.platform-card-subtitle{font-size:13px;color:var(--text-secondary);margin:2px 0 0}.platform-card-meta{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-xs);font-size:12px;color:var(--text-tertiary)}.platform-card-meta svg{width:12px;height:12px}.platform-card-body{border-top:1px solid var(--border);padding:var(--space-lg);background:var(--bg-surface)}.platform-card-notes{font-size:13px;color:var(--text-secondary);font-style:italic;padding:var(--space-sm) var(--space-md);margin:0 var(--space-md) var(--space-md);background:#ffffff08;border-left:3px solid rgba(245,158,11,.5);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.platform-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl) var(--space-lg);text-align:center}.platform-empty-icon{width:72px;height:72px;border-radius:var(--radius-xl);background:linear-gradient(135deg,var(--bg-page) 0%,var(--bg-surface) 100%);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-lg)}.platform-empty-icon svg{width:32px;height:32px;color:var(--text-tertiary)}.platform-empty h3{font-size:17px;font-weight:600;color:var(--text-secondary);margin:0 0 var(--space-sm) 0}.platform-empty p{font-size:14px;color:var(--text-tertiary);margin:0 0 var(--space-lg) 0}.platform-nested-sites{border-top:1px solid var(--border);background:var(--bg-surface)}.platform-nested-site{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg) var(--space-md) calc(var(--space-xl) + var(--space-lg));border-bottom:1px solid var(--border);transition:background var(--transition-fast)}.platform-nested-site:hover{background:#ffffff05}.platform-nested-site-icon{width:32px;height:32px;border-radius:var(--radius-md);background:linear-gradient(135deg,#3b82f633,#3b82f61a);color:#60a5fa;display:flex;align-items:center;justify-content:center}.platform-nested-site-icon svg{width:14px;height:14px}.platform-nested-site-info{flex:1;min-width:0}.platform-nested-site-info p{margin:0;font-size:13px;color:var(--text-primary)}.platform-nested-site-info span{font-size:12px;color:var(--text-tertiary);display:flex;align-items:center;gap:4px}.platform-nested-site-info span svg{width:12px;height:12px}.platform-nested-empty{padding:var(--space-lg);text-align:center;color:var(--text-tertiary);font-size:13px}.platform-site-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg)}.platform-site-card{display:flex;flex-direction:column;min-height:220px}.platform-site-header{flex-shrink:0}.platform-site-title h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.platform-site-title .org-name{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;margin-top:2px}.platform-site-meta{flex:1;display:flex;align-items:flex-start;padding:var(--space-md) var(--space-lg)}.platform-site-footer{margin-top:auto}.platform-user-header{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%)}.platform-user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.platform-user-name{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:0}.platform-user-name h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 4px 0 0}.platform-user-email{font-size:13px;color:var(--text-secondary);margin:0}.platform-user-meta{display:flex;align-items:center;gap:var(--space-md);margin-top:4px;font-size:12px;color:var(--text-tertiary)}.platform-card-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0;margin-left:auto}.platform-card-actions button{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-page);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.platform-card-actions button:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--accent);box-shadow:var(--shadow-sm)}.platform-card-actions button.delete:hover,.platform-card-actions .btn-deny:hover{background:#ef444426;color:var(--accent-danger);border-color:var(--accent-danger)}.platform-card-actions .btn-approve:hover{background:#22c55e26;color:var(--accent-success);border-color:var(--accent-success)}.platform-user-body{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);padding:var(--space-lg);background:var(--bg-surface);border-top:1px solid var(--border);box-shadow:var(--shadow-sm)}@media(max-width:768px){.platform-user-body{grid-template-columns:1fr}}.platform-user-section{display:flex;flex-direction:column}.platform-user-section h4{display:flex;align-items:center;gap:var(--space-sm);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin:0 0 var(--space-md) 0}.platform-user-section h4 svg{color:var(--accent)}.platform-user-site{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-sm)}.platform-user-site:last-child{margin-bottom:0}.platform-user-site>span:first-child{font-size:13px;color:var(--text-primary)}.platform-user-site .flex-center{display:flex;align-items:center;gap:var(--space-sm)}.platform-user-site button{width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.platform-user-site button:hover{background:#ef444433;color:var(--accent-danger)}.platform-user-section h4{display:flex;align-items:center;width:100%}.platform-user-section h4 .platform-add-site{margin-left:auto;font-size:12px;color:var(--accent);background:none;border:none;cursor:pointer;padding:0;transition:color var(--transition-fast)}.platform-user-section h4 .platform-add-site:hover{color:#00e5b8}.platform-role-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm);margin-top:var(--space-sm)}.platform-role-grid.three{grid-template-columns:repeat(3,1fr)}.platform-role-option{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.platform-role-option:hover{background:var(--bg-surface);border-color:var(--accent);color:var(--text-primary);box-shadow:var(--shadow-sm)}.platform-role-option.selected{background:#00d4aa1a;border-color:var(--accent);color:var(--accent)}.platform-role-option.selected.admin{background:#f59e0b1a;border-color:var(--accent-warning);color:var(--accent-warning)}.platform-role-option svg{width:18px;height:18px;flex-shrink:0}.form-row{display:flex;gap:var(--space-md);margin-bottom:var(--space-md)}.form-row>*{flex:1}label,.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-label.required:after{content:" *";color:var(--accent-danger)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],input[type=url],input[type=search],input[type=date],input[type=time],input[type=datetime-local],textarea{width:100%;padding:10px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-family:inherit;transition:all var(--transition-fast)}input:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa1a}input:disabled,textarea:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-surface)}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}select{width:100%;padding:10px 36px 10px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-family:inherit;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:all var(--transition-fast)}select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa1a}select:disabled{opacity:.6;cursor:not-allowed}select option{background:var(--bg-surface);color:var(--text-primary)}textarea{min-height:100px;resize:vertical}input[type=checkbox],input[type=radio]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.checkbox-label,.radio-label{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;font-size:14px;color:var(--text-primary)}.form-hint{font-size:12px;color:var(--text-tertiary);margin-top:4px}.form-error{font-size:12px;color:var(--accent-danger);margin-top:4px}input.error,select.error,textarea.error{border-color:var(--accent-danger)}.search-input{position:relative}.search-input input{padding-left:40px}.search-input svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);width:18px;height:18px;pointer-events:none}.input-with-icon{position:relative}.input-with-icon input{padding-left:40px}.input-with-icon .input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary)}.input-group{display:flex;align-items:stretch}.input-group input{border-radius:var(--radius-md) 0 0 var(--radius-md);border-right:none}.input-group .input-group-append{padding:0 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:0 var(--radius-md) var(--radius-md) 0;display:flex;align-items:center;color:var(--text-tertiary);font-size:14px}.form-inline{display:flex;align-items:center;gap:var(--space-md)}.form-inline .form-group{margin-bottom:0}.form-section-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border)}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--accent);outline-offset:2px}@media(max-width:768px){.form-row{flex-direction:column}}.modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.modal-content{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);max-width:480px;width:100%;position:relative;box-shadow:var(--shadow-sm)}.modal-close{position:absolute;top:var(--space-md);right:var(--space-md);color:var(--text-tertiary);padding:var(--space-xs);border-radius:var(--radius-sm)}.modal-close:hover{background:var(--bg-page);color:var(--text-primary)}.modal-icon{text-align:center;margin-bottom:var(--space-lg)}.modal-content h2{text-align:center;font-size:20px;font-weight:600;margin-bottom:var(--space-md)}.modal-content>p{text-align:center;color:var(--text-secondary);margin-bottom:var(--space-lg)}.modal-actions{display:flex;gap:var(--space-md);justify-content:center}.page-container{padding:var(--space-lg);min-height:100%}.page-header{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-xl)}.page-title{display:flex;align-items:center;gap:var(--space-sm);font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.page-title svg{flex-shrink:0}.page-subtitle{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:14px;margin:0;flex-wrap:wrap}.current-site-badge{display:inline-flex;align-items:center;padding:4px 12px;background:#00d4aa26;color:var(--accent);border:1px solid rgba(0,212,170,.3);border-radius:var(--radius-md);font-size:12px;font-weight:500}.page-header-with-actions{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-lg);margin-bottom:var(--space-xl)}.page-header-actions{display:flex;gap:var(--space-sm);flex-shrink:0}.page-content{width:100%}@media(max-width:768px){.page-container{padding:var(--space-md)}.page-title{font-size:20px}.page-header-with-actions{flex-direction:column;gap:var(--space-md)}.page-header-actions{width:100%}}@media(max-width:640px){.page-header-actions{flex-direction:column;gap:var(--space-sm)}.page-header-actions .btn{width:100%;justify-content:center}}@media(max-width:480px){.page-title{font-size:18px}.page-subtitle{font-size:13px}.page-container{padding:var(--space-sm)}}.mobile-menu-btn{display:none;position:fixed;top:var(--space-md);left:var(--space-md);z-index:200;padding:var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-page);gap:var(--space-md)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.tenant-selector{position:relative}.tenant-dropdown-btn{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px;text-align:left}.tenant-dropdown-btn:hover{background:var(--bg-elevated)}.tenant-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:var(--space-xs);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:200;max-height:200px;overflow-y:auto}.tenant-option{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);color:var(--text-secondary);font-size:13px;text-align:left;transition:all var(--transition-fast)}.tenant-option:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tenant-option.active{background:#00d4aa1a;color:var(--accent)}.tabs,.admin-tabs,.settings-tabs{display:flex;gap:4px;padding:0 var(--space-md);background:var(--bg-surface);border-bottom:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:var(--shadow-sm)}.tab,.admin-tab,.settings-tab{padding:14px 20px;color:var(--text-secondary);font-size:14px;cursor:pointer;border:none;background:transparent;border-bottom:2px solid transparent;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-sm);margin-bottom:-1px}.tab:hover,.admin-tab:hover,.settings-tab:hover{color:var(--text-primary);background:#ffffff05}.tab.active,.admin-tab.active,.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-badge{background:var(--accent-danger);color:var(--text-primary);font-size:10px;padding:2px 6px;border-radius:10px;font-weight:600}.tab-badge.new{background:var(--accent)}.tab-badge.warning{background:var(--accent-warning)}.tab-count{background:#00d4aa26;color:var(--accent);padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.notification-stack{display:flex;flex-direction:column;gap:var(--space-md)}.notification,.alert-item{padding:var(--space-md);border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--space-md)}.notification.critical,.alert-item.critical{background:#ef444426;border:1px solid rgba(239,68,68,.3)}.notification.action,.alert-item.action,.notification.warning,.alert-item.warning{background:#f59e0b26;border:1px solid rgba(245,158,11,.3)}.notification.info,.alert-item.info{background:#0ea5e926;border:1px solid rgba(14,165,233,.3)}.notification.success,.alert-item.success{background:#22c55e26;border:1px solid rgba(34,197,94,.3)}.notification.status,.alert-item.status{background:var(--bg-page);border:1px solid var(--border)}.notification-icon,.alert-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notification.critical .notification-icon,.alert-item.critical .alert-icon{background:var(--accent-danger);color:var(--text-primary);animation:pulse-icon 1.5s infinite}.notification.action .notification-icon,.notification.warning .notification-icon,.alert-item.action .alert-icon,.alert-item.warning .alert-icon{background:var(--accent-warning);color:var(--bg-page)}.notification.info .notification-icon,.alert-item.info .alert-icon{background:var(--accent);color:var(--text-primary)}.notification.success .notification-icon,.alert-item.success .alert-icon{background:var(--accent-success);color:var(--text-primary)}.notification.status .notification-icon,.alert-item.status .alert-icon{background:var(--bg-surface);color:var(--text-tertiary)}@keyframes pulse-icon{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.notification-content,.alert-content{flex:1;min-width:0}.notification-title,.alert-title{font-weight:600;font-size:15px;color:var(--text-primary);margin-bottom:2px}.notification-subtitle,.notification-message,.alert-subtitle,.alert-message{font-size:13px;color:var(--text-secondary)}.notification-time,.alert-time{font-size:12px;color:var(--text-tertiary);flex-shrink:0}.notification-actions,.alert-actions{display:flex;gap:var(--space-sm);flex-shrink:0}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-surface);border-top:1px solid var(--border);padding:var(--space-sm) 0;padding-bottom:calc(var(--space-sm) + env(safe-area-inset-bottom,0));z-index:100;box-shadow:var(--shadow-sm)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-sm);color:var(--text-tertiary);font-size:11px;cursor:pointer;transition:all var(--transition-fast);background:none;border:none;text-decoration:none}.bottom-nav-item:hover{color:var(--text-primary)}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item.danger{color:var(--accent-danger)}.bottom-nav-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}@media(max-width:1024px){.bottom-nav{display:flex}.main-content{padding-bottom:calc(80px + env(safe-area-inset-bottom,0))}}.intercom-toast{background:var(--bg-surface);border-radius:var(--radius-xl);border:2px solid var(--accent);overflow:hidden;max-width:360px;box-shadow:0 0 60px #00d4aa26,0 25px 50px #00000080}.intercom-toast-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:linear-gradient(135deg,rgba(0,212,170,.1),transparent);border-bottom:1px solid var(--border)}.intercom-toast-icon{width:48px;height:48px;border-radius:50%;background:var(--accent);color:var(--bg-page);display:flex;align-items:center;justify-content:center;flex-shrink:0}.intercom-toast-info{flex:1}.intercom-toast-title{font-weight:600;font-size:15px;color:var(--text-primary)}.intercom-toast-location{font-size:13px;color:var(--accent)}.intercom-toast-body{padding:var(--space-md)}.intercom-toast-preview{aspect-ratio:16/9;background:var(--bg-page);border-radius:var(--radius-md);margin-bottom:var(--space-md);overflow:hidden}.intercom-toast-preview img,.intercom-toast-preview video{width:100%;height:100%;object-fit:cover}.intercom-toast-actions{display:flex;gap:var(--space-sm)}.intercom-toast-actions .btn{flex:1}.nav-item,.nav-link{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);color:var(--bg-sidebar-text);font-size:14px;cursor:pointer;transition:all var(--transition-fast);border-left:3px solid transparent;text-decoration:none}.nav-item:hover,.nav-link:hover{background:var(--bg-sidebar-hover);color:var(--bg-sidebar-text-hover)}.nav-item.active,.nav-link.active{background:var(--accent-alpha-15);color:var(--accent);border-left-color:var(--accent)}.nav-badge{margin-left:auto;background:var(--accent-danger);color:#fff;font-size:10px;padding:2px 6px;border-radius:10px;font-weight:600}.nav-badge.platform{background:var(--accent-purple)}.nav-badge.new{background:var(--accent-secondary)}.card,.status-card,.dashboard-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.card:hover,.status-card:hover{border-color:#00d4aa4d}.card-glow{box-shadow:0 0 20px #00d4aa1a}.status-card.success{border-left:3px solid var(--accent-success)}.status-card.warning{border-left:3px solid var(--accent-warning)}.status-card.danger{border-left:3px solid var(--accent-danger)}.status-card.info{border-left:3px solid var(--accent)}.stat-widget{padding:var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.stat-widget-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-md)}.stat-widget-icon.primary{background:#00d4aa26;color:var(--accent)}.stat-widget-icon.secondary{background:#0ea5e926;color:var(--accent)}.stat-widget-icon.warning{background:#f59e0b26;color:var(--accent-warning)}.stat-widget-icon.danger{background:#ef444426;color:var(--accent-danger)}.stat-widget-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.2}.stat-widget-label{font-size:13px;color:var(--text-tertiary);margin-top:4px}.stat-widget-trend{display:flex;align-items:center;gap:4px;font-size:12px;margin-top:var(--space-sm)}.stat-widget-trend.up{color:var(--accent-success)}.stat-widget-trend.down{color:var(--accent-danger)}.btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:14px 24px;font-size:16px}.btn-ghost{background:transparent;color:var(--text-secondary);border:none}.btn-ghost:hover{background:var(--bg-page);color:var(--text-primary)}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-primary)}.btn-outline:hover{background:var(--bg-page);border-color:var(--accent)}.btn-outline-primary{border-color:var(--accent);color:var(--accent)}.btn-outline-primary:hover{background:#00d4aa1a}.btn-outline-danger{border-color:var(--accent-danger);color:var(--accent-danger)}.btn-outline-danger:hover{background:#ef44441a}.toast-container{position:fixed;z-index:9999;display:flex;flex-direction:column;gap:var(--space-sm);pointer-events:none;padding:var(--space-md)}.toast-container.top-right{top:0;right:0}.toast-container.top-left{top:0;left:0}.toast-container.bottom-right{bottom:0;right:0}.toast-container.bottom-left{bottom:0;left:0}.toast-container.top-center{top:0;left:50%;transform:translate(-50%)}.toast-item{position:relative;display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:320px;max-width:420px;pointer-events:auto;animation:toast-enter .2s ease-out;overflow:hidden}.toast-item.exiting{animation:toast-exit .2s ease-out forwards}@keyframes toast-enter{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toast-exit{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.toast-item.critical{border-color:#ef444466;border-left:4px solid var(--accent-danger)}.toast-item.action,.toast-item.warning{border-color:#f59e0b66;border-left:4px solid var(--accent-warning)}.toast-item.info{border-color:#0ea5e966;border-left:4px solid var(--accent)}.toast-item.success{border-color:#22c55e66;border-left:4px solid var(--accent-success)}.toast-item.status{border-color:var(--border);border-left:4px solid var(--text-tertiary)}.toast-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-primary)}.toast-item.critical .toast-icon{animation:pulse-icon 1.5s infinite}.toast-item.status .toast-icon{color:var(--text-tertiary)}.toast-content{flex:1;min-width:0}.toast-title{font-weight:600;font-size:14px;color:var(--text-primary);margin-bottom:2px}.toast-message{font-size:13px;color:var(--text-secondary);line-height:1.4}.toast-time{font-size:12px;color:var(--text-tertiary);flex-shrink:0}.toast-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.toast-dismiss{position:absolute;top:var(--space-sm);right:var(--space-sm);width:24px;height:24px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.toast-dismiss:hover{background:var(--bg-page);color:var(--text-primary)}.toast-progress{position:absolute;bottom:0;left:0;height:3px;background:var(--accent);animation:toast-progress-shrink linear forwards}.toast-item.critical .toast-progress{background:var(--accent-danger)}.toast-item.warning .toast-progress,.toast-item.action .toast-progress{background:var(--accent-warning)}.toast-item.info .toast-progress{background:var(--accent)}.toast-item.success .toast-progress{background:var(--accent-success)}@keyframes toast-progress-shrink{0%{width:100%}to{width:0%}}@media(max-width:480px){.toast-container{left:0;right:0;padding:var(--space-sm)}.toast-container.top-right,.toast-container.top-left,.toast-container.top-center{transform:none;left:0}.toast-item{min-width:auto;max-width:none;width:100%}}.Toastify__toast-container{z-index:9999}.Toastify__toast{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-family:var(--font-sans)}.Toastify__toast-body{color:var(--text-primary);font-size:14px}.Toastify__progress-bar{background:var(--accent)}.Toastify__close-button{color:var(--text-tertiary)}.Toastify__close-button:hover{color:var(--text-primary)}.Toastify__toast--success{border-left:4px solid var(--accent-success)}.Toastify__toast--success .Toastify__progress-bar{background:var(--accent-success)}.Toastify__toast--error{border-left:4px solid var(--accent-danger)}.Toastify__toast--error .Toastify__progress-bar{background:var(--accent-danger)}.Toastify__toast--warning{border-left:4px solid var(--accent-warning)}.Toastify__toast--warning .Toastify__progress-bar{background:var(--accent-warning)}.Toastify__toast--info{border-left:4px solid var(--accent)}.Toastify__toast--info .Toastify__progress-bar{background:var(--accent)}.Toastify__toast--critical,.toast-lockdown{border-left:4px solid var(--accent-danger);background:linear-gradient(135deg,var(--bg-surface) 0%,rgba(239,68,68,.1) 100%);animation:toast-pulse-bg 2s infinite}.Toastify__toast--critical .Toastify__progress-bar,.toast-lockdown .Toastify__progress-bar{background:var(--accent-danger)}@keyframes toast-pulse-bg{0%,to{box-shadow:0 4px 12px #00000080}50%{box-shadow:0 4px 20px #ef44444d}}.toast-with-icon{display:flex;align-items:center;gap:var(--space-md)}.toast-with-icon .toast-icon-wrapper{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-with-icon .toast-icon-wrapper.critical{background:var(--accent-danger);color:var(--text-primary);animation:pulse-icon 1.5s infinite}.toast-with-icon .toast-icon-wrapper.success{background:var(--accent-success);color:var(--text-primary)}.toast-with-icon .toast-icon-wrapper.warning{background:var(--accent-warning);color:var(--bg-page)}.toast-with-icon .toast-content{flex:1}.toast-with-icon .toast-title{font-weight:600;font-size:14px;margin-bottom:2px}.toast-with-icon .toast-message{font-size:13px;color:var(--text-secondary)}@media(max-width:1024px){.mobile-menu-btn{display:none!important}.sidebar{transform:translate(-100%);pointer-events:none}.main-content{margin-left:0!important;width:100%!important}.bottom-nav{display:flex!important}}.page-content{padding-bottom:calc(80px + env(safe-area-inset-bottom,20px))}.page-content,.main-content{-webkit-overflow-scrolling:touch;overflow-y:auto}body.pwa-mode{overscroll-behavior-y:contain}@supports (padding-top: env(safe-area-inset-top)){.app-container{padding-top:env(safe-area-inset-top)}}@supports (padding-bottom: env(safe-area-inset-bottom)){.bottom-nav{padding-bottom:env(safe-area-inset-bottom)}}@media(max-width:768px){.btn,button,.nav-link,.bottom-nav-item{min-height:44px}}.bottom-nav-item,.more-drawer-item,.nav-link{-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.page-content{transition:opacity .15s ease}.page-loading{opacity:.6;pointer-events:none}@media(max-width:768px){.user-profile-tabs,.admin-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:4px;gap:2px}.user-profile-tabs::-webkit-scrollbar,.admin-tabs::-webkit-scrollbar{display:none}.user-profile-tab,.admin-tab{flex-shrink:0;padding:10px 14px;font-size:13px;white-space:nowrap}}@media(max-width:768px){.events-list .event-card,.live-events-list>div{padding:var(--space-md)}.event-card-content{gap:var(--space-sm)}}@media(max-width:768px){.user-management .section-header,.user-management>div:first-child{flex-wrap:wrap;gap:var(--space-sm)}.user-management .btn{padding:8px 12px;font-size:12px}.user-management .section-header>div{width:100%;display:flex;flex-wrap:wrap;gap:var(--space-xs);justify-content:flex-end}}@media(max-width:768px){.collapsible-header,.collapsible-body{padding:var(--space-md)}}@media(max-width:768px){html,body,#root{overflow-x:hidden;max-width:100vw}.main-content,.page-content,.page-container,.dashboard-page,.md-dashboard,.md-page{overflow-x:hidden;max-width:100%}.main-content table,.page-content table,.md-page table{display:block;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.device-list-item,.device-row,.md-discovery-device,.md-device-row,[class*=device-] .device-url,[class*=device-] .device-hostname,[class*=device-] .device-ip{min-width:0;word-break:break-word;overflow-wrap:anywhere}.stat-summary-row,.stat-row,.stats-grid,.dashboard-widgets,.card-grid,.ra-card-grid{grid-template-columns:repeat(auto-fit,minmax(0,1fr));min-width:0}.stat-summary-row>*,.stat-row>*,.stats-grid>*,.dashboard-widgets>*,.card-grid>*{min-width:0;max-width:100%}.access-review-row,.platform-sites-row,.tenant-row{min-width:0}.access-review-row>*,.platform-sites-row>*,.tenant-row>*{min-width:0;overflow:hidden;text-overflow:ellipsis}}@media(max-width:768px){.ra-infra-chain-scroll{padding:16px!important;overflow-x:visible!important}.ra-infra-chain-nodes{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:16px 8px!important;min-width:0!important;justify-content:stretch!important}.ra-infra-chain-node{width:100%!important}.ra-infra-chain-node>div:first-child{width:100%!important;align-items:center!important}.ra-infra-chain-connector{display:none!important}}.tab-nav-container{margin-bottom:var(--space-xl)}.tab-nav-desktop{display:flex;gap:4px;padding:4px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.tab-nav-item{display:flex;align-items:center;gap:var(--space-sm);padding:12px 20px;background:transparent;border:none;border-radius:var(--radius-lg);color:var(--text-tertiary);cursor:pointer;font-size:14px;font-weight:400;transition:all var(--transition-fast);white-space:nowrap}.tab-nav-item:hover{color:var(--text-primary);background:#ffffff0d}.tab-nav-item.active{color:var(--accent);background:#00d4aa1a;font-weight:500;box-shadow:0 0 0 1px #00d4aa4d}.tab-nav-item svg{width:18px;height:18px;flex-shrink:0}.tab-nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--accent);color:var(--bg-page);border-radius:10px;font-size:11px;font-weight:600}.tab-nav-mobile{display:none;position:relative}.tab-nav-select{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);font-size:15px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.tab-nav-select:hover{border-color:var(--accent)}.tab-nav-select-label{display:flex;align-items:center;gap:var(--space-sm)}.tab-nav-select-label svg{color:var(--accent)}.tab-nav-chevron{color:var(--text-tertiary);transition:transform var(--transition-fast)}.tab-nav-chevron.open{transform:rotate(180deg)}.tab-nav-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 10px 40px #00000080;z-index:9999;overflow:hidden}.tab-nav-dropdown-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:14px 16px;background:transparent;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all var(--transition-fast);text-align:left}.tab-nav-dropdown-item:hover{background:var(--bg-page);color:var(--text-primary)}.tab-nav-dropdown-item.active{background:#00d4aa1a;color:var(--accent)}.tab-nav-dropdown-item svg{flex-shrink:0}.tab-nav-dropdown-item .tab-nav-badge{margin-left:auto}@media(max-width:768px){.tab-nav-desktop{display:none}.tab-nav-mobile{display:block}}.bottom-nav-item.active .bottom-nav-icon{background:var(--accent);color:var(--bg-page);padding:6px 14px;border-radius:20px}@media(max-width:1024px){.mobile-menu-btn{display:none!important}}.intercom-card-actions{display:flex;gap:1px;background:var(--border)}.intercom-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.intercom-action-btn.view{background:linear-gradient(135deg,#0ea5e926,#0ea5e90d);color:var(--accent)}.intercom-action-btn.view:hover{background:linear-gradient(135deg,#0ea5e94d,#0ea5e926);color:#38bdf8}.intercom-action-btn.view:active{background:#0ea5e966;transform:scale(.98)}.intercom-action-btn.unlock{background:linear-gradient(135deg,#00d4aa26,#00d4aa0d);color:var(--accent)}.intercom-action-btn.unlock:hover{background:linear-gradient(135deg,#00d4aa4d,#00d4aa26);color:#0fc}.intercom-action-btn.unlock:active{background:#00d4aa66;transform:scale(.98)}.intercom-action-btn:disabled{background:var(--bg-page);color:var(--text-tertiary);cursor:not-allowed;opacity:.6}.intercom-action-btn:disabled:hover{background:var(--bg-page);color:var(--text-tertiary);transform:none}.intercom-action-btn:not(:disabled):hover svg{transform:scale(1.1)}.intercom-action-btn svg{transition:transform var(--transition-fast)}@media(max-width:768px){.intercom-action-btn{padding:var(--space-md);font-size:13px}.intercom-action-btn span{display:inline}}.more-drawer-backdrop{position:fixed;inset:0;background:#0009;z-index:998;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.more-drawer{position:fixed;bottom:calc(60px + env(safe-area-inset-bottom,0px));left:0;right:0;background:var(--bg-surface);border-top:1px solid var(--border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:999;max-height:70vh;display:flex;flex-direction:column;animation:slide-up .25s ease;box-shadow:var(--shadow-sm)}@keyframes slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.more-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border)}.more-drawer-user{display:flex;align-items:center;gap:var(--space-md)}.more-drawer-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent));display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:var(--bg-page)}.more-drawer-user-info{display:flex;flex-direction:column}.more-drawer-name{font-weight:600;font-size:16px;color:var(--text-primary)}.more-drawer-role{font-size:13px;color:var(--text-tertiary);text-transform:capitalize}.more-drawer-close{width:40px;height:40px;border-radius:var(--radius-md);background:transparent;border:none;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.more-drawer-close:hover{background:var(--bg-page);color:var(--text-primary)}.more-drawer-items{flex:1;overflow-y:auto;padding:var(--space-sm) 0}.more-drawer-item{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:var(--space-md) var(--space-lg);background:transparent;border:none;color:var(--text-secondary);font-size:15px;text-align:left;cursor:pointer;transition:all var(--transition-fast)}.more-drawer-item:hover{background:var(--bg-page);color:var(--text-primary)}.more-drawer-item.active{background:#00d4aa1a;color:var(--accent)}.more-drawer-item.has-badge{color:var(--accent-purple)}.more-drawer-item.has-badge:hover{background:#a855f71a}.more-drawer-badge{margin-left:auto;font-size:10px;font-weight:600;padding:2px 8px;background:#a855f733;color:var(--accent-purple);border-radius:var(--radius-sm);text-transform:uppercase}.more-drawer-divider{height:1px;background:var(--border);margin:var(--space-sm) var(--space-lg)}.more-drawer-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);padding-bottom:calc(var(--space-md) + env(safe-area-inset-bottom,0px))}.more-drawer-logout{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:var(--space-md);background:transparent;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--accent-danger);font-size:15px;cursor:pointer;transition:all var(--transition-fast)}.more-drawer-logout:hover{background:#ef44441a;border-color:var(--accent-danger)}.dashboard-page{padding:clamp(1rem,3vw,2rem);max-width:1600px;margin:0 auto;padding-bottom:calc(6rem + env(safe-area-inset-bottom,20px))}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;flex-wrap:wrap}.dashboard-header-text{display:flex;flex-direction:column;gap:4px}.dashboard-greeting{margin:0;font-size:1.75rem;font-weight:600;color:var(--text-primary)}.dashboard-tenant-name{margin:0;font-size:.875rem;color:var(--text-tertiary)}.dashboard-customize-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-surface);border:.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:13px;font-weight:500;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.dashboard-customize-btn:hover{border-color:var(--accent);color:var(--accent)}.dashboard-customize-btn.active{background:var(--accent);color:var(--bg-page);border-color:var(--accent)}.dashboard-stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.dashboard-stat-card{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-surface);border:.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition-fast)}.dashboard-stat-card:hover{border-color:var(--accent);transform:translateY(-1px)}.dashboard-stat-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:var(--bg-page);color:var(--accent);flex-shrink:0}.dashboard-stat-body{display:flex;flex-direction:column;gap:2px;min-width:0}.dashboard-stat-value{font-size:1.5rem;font-weight:600;color:var(--text-primary);line-height:1}.dashboard-stat-label{font-size:12px;color:var(--text-tertiary)}.dashboard-widget-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.dashboard-widget{background:var(--bg-surface);border:.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;min-height:280px;transition:all var(--transition-fast)}.dashboard-widget.size-full{grid-column:1 / -1}.dashboard-widget.editing{border-style:dashed;border-color:var(--accent);cursor:grab}.dashboard-widget.editing:active{cursor:grabbing}.dashboard-widget.drag-over{background:var(--accent-alpha-08);border-color:var(--accent);transform:scale(1.01)}.dashboard-widget-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:.5px solid var(--border)}.dashboard-widget-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary)}.dashboard-widget-drag{color:var(--text-tertiary);cursor:grab}.dashboard-widget-actions{display:flex;align-items:center;gap:4px}.dashboard-widget-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.dashboard-widget-btn:hover{background:var(--bg-page);color:var(--text-primary);border-color:var(--accent)}.dashboard-widget-btn.danger:hover{color:var(--status-error);border-color:var(--status-error)}.dashboard-widget-viewall{display:inline-flex;align-items:center;gap:2px;background:transparent;border:none;color:var(--accent);font-size:12px;cursor:pointer;padding:4px 6px}.dashboard-widget-viewall:hover{text-decoration:underline}.dashboard-widget-body{flex:1;padding:16px;overflow:auto}.dashboard-widget-skeleton{width:100%;height:160px;background:var(--bg-page);border-radius:var(--radius-md);animation:dashboardPulse 1.4s ease-in-out infinite}@keyframes dashboardPulse{0%,to{opacity:.6}50%{opacity:.85}}.dashboard-widget-empty{display:flex;align-items:center;justify-content:center;height:100%;min-height:120px;color:var(--text-tertiary);font-size:13px}.dashboard-widget-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;height:100%;min-height:120px;color:var(--status-error);font-size:13px}.dashboard-widget-retry{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:.5px solid var(--status-error);border-radius:var(--radius-md);color:var(--status-error);cursor:pointer;font-size:12px}.dashboard-widget-retry:hover{background:var(--status-error);color:var(--bg-page)}.widget-cam-grid{display:grid;gap:8px}.widget-cam-grid.cols-2{grid-template-columns:1fr 1fr}.widget-cam-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.widget-cam-thumb{position:relative;background:var(--bg-page);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;aspect-ratio:16 / 9;transition:transform var(--transition-fast)}.widget-cam-thumb:hover{transform:scale(1.02)}.widget-cam-thumb img{width:100%;height:100%;object-fit:cover}.widget-cam-name{position:absolute;bottom:0;left:0;right:0;padding:6px 8px;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);color:var(--text-primary);font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-doors-list{list-style:none;margin:0;padding:0}.widget-doors-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:.5px solid var(--border);cursor:pointer}.widget-doors-item:last-child{border-bottom:none}.widget-doors-item:hover{background:var(--bg-page)}.widget-doors-main{flex:1;min-width:0}.widget-doors-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-doors-door{font-size:11px;color:var(--text-tertiary)}.widget-doors-badge{font-size:10px;font-weight:600;text-transform:uppercase;padding:3px 8px;border-radius:var(--radius-md)}.widget-doors-badge.granted{background:var(--status-ok-bg);color:var(--status-ok)}.widget-doors-badge.denied{background:var(--status-error-bg);color:var(--status-error)}.widget-doors-time{font-size:11px;color:var(--text-tertiary);flex-shrink:0}.widget-alerts-list{list-style:none;margin:0;padding:0}.widget-alerts-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:.5px solid var(--border);cursor:pointer}.widget-alerts-item:last-child{border-bottom:none}.widget-alerts-item:hover{background:var(--bg-page)}.widget-alerts-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.widget-alerts-dot.sev-critical{background:var(--status-error)}.widget-alerts-dot.sev-warning{background:var(--status-warn)}.widget-alerts-dot.sev-info{background:var(--accent)}.widget-alerts-main{flex:1;min-width:0}.widget-alerts-msg{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-alerts-meta{font-size:11px;color:var(--text-tertiary)}.widget-alerts-badge{font-size:10px;font-weight:600;text-transform:uppercase;padding:3px 8px;border-radius:var(--radius-md);flex-shrink:0}.widget-alerts-badge.sev-critical{background:var(--status-error-bg);color:var(--status-error)}.widget-alerts-badge.sev-warning{background:var(--status-warn-bg);color:var(--status-warn)}.widget-alerts-badge.sev-info{background:var(--accent-alpha-08);color:var(--accent)}.widget-devices-list{list-style:none;margin:0;padding:0}.widget-devices-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:.5px solid var(--border);cursor:pointer}.widget-devices-item:last-child{border-bottom:none}.widget-devices-item:hover{background:var(--bg-page)}.widget-devices-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.widget-devices-dot.ok{background:var(--status-ok)}.widget-devices-dot.fail{background:var(--status-error)}.widget-devices-main{flex:1;min-width:0}.widget-devices-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-devices-meta{font-size:11px;color:var(--text-tertiary)}.widget-devices-status{font-size:10px;font-weight:600;text-transform:uppercase;flex-shrink:0}.widget-devices-status.ok{color:var(--status-ok)}.widget-devices-status.fail{color:var(--status-error)}.widget-recording{display:flex;flex-direction:column;gap:16px;cursor:pointer}.widget-recording-gauge{display:flex;flex-direction:column;align-items:center;padding:16px 0;border-bottom:.5px solid var(--border)}.widget-recording-confidence{font-size:2.5rem;font-weight:700;color:var(--accent);line-height:1}.widget-recording-confidence-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.widget-recording-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.widget-recording-stat{display:flex;flex-direction:column;align-items:center;padding:12px 8px;background:var(--bg-page);border-radius:var(--radius-md)}.widget-recording-stat.ok .widget-recording-num{color:var(--status-ok)}.widget-recording-stat.warn .widget-recording-num{color:var(--status-warn)}.widget-recording-stat.fail .widget-recording-num{color:var(--status-error)}.widget-recording-num{font-size:1.5rem;font-weight:600;line-height:1}.widget-recording-lbl{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;margin-top:4px}.widget-recording-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:11px;color:var(--text-tertiary);padding-top:8px;border-top:.5px solid var(--border)}.widget-recording-svc{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-md);background:var(--bg-page);font-weight:500;text-transform:capitalize}.widget-recording-svc.healthy,.widget-recording-svc.ok{color:var(--status-ok)}.widget-recording-svc.degraded{color:var(--status-warn)}.widget-recording-svc.down,.widget-recording-svc.failed{color:var(--status-error)}.widget-sabbath{display:flex;flex-direction:column;gap:8px;cursor:pointer}.widget-sabbath-name{font-size:14px;font-weight:600;color:var(--text-primary)}.widget-sabbath-badge{display:inline-block;width:fit-content;padding:4px 10px;border-radius:var(--radius-md);font-size:11px;font-weight:600;text-transform:uppercase}.widget-sabbath-badge.active{background:var(--status-ok-bg);color:var(--status-ok)}.widget-sabbath-badge.inactive{background:var(--bg-page);color:var(--text-tertiary)}.widget-sabbath-next{font-size:12px;color:var(--text-secondary)}.dashboard-add-panel{background:var(--bg-surface);border:.5px dashed var(--accent);border-radius:var(--radius-lg);padding:16px;margin-bottom:24px;box-shadow:var(--shadow-sm)}.dashboard-add-title{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.dashboard-add-list{display:flex;flex-wrap:wrap;gap:8px}.dashboard-add-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-page);border:.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:13px;transition:all var(--transition-fast)}.dashboard-add-btn:hover{border-color:var(--accent);color:var(--accent)}.wsm-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.wsm-modal{background:var(--bg-surface);border:.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column}.wsm-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:.5px solid var(--border)}.wsm-title{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.wsm-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer}.wsm-close:hover{background:var(--bg-page);color:var(--text-primary)}.wsm-body{flex:1;padding:20px;overflow-y:auto}.wsm-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:.5px solid var(--border)}.wsm-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);border:.5px solid var(--border)}.wsm-btn-ghost{background:transparent;color:var(--text-secondary)}.wsm-btn-ghost:hover{background:var(--bg-page);color:var(--text-primary)}.wsm-btn-primary{background:var(--accent);color:var(--bg-page);border-color:var(--accent)}.wsm-btn-primary:hover{opacity:.9}.wsm-section{margin-bottom:16px}.wsm-section:last-child{margin-bottom:0}.wsm-section-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.wsm-hint{font-size:12px;color:var(--text-tertiary);margin-bottom:12px}.wsm-loading,.wsm-empty{padding:24px 0;text-align:center;color:var(--text-tertiary);font-size:13px}.wsm-error{padding:24px 0;text-align:center;color:var(--status-error);font-size:13px}.wsm-checklist{display:flex;flex-direction:column;gap:4px;max-height:300px;overflow-y:auto;border:.5px solid var(--border);border-radius:var(--radius-md);padding:4px}.wsm-check-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.wsm-check-item:hover{background:var(--bg-page)}.wsm-check-item.selected{background:var(--accent-alpha-08)}.wsm-check-item.disabled{opacity:.4;cursor:not-allowed}.wsm-check-box{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:.5px solid var(--border);border-radius:4px;background:var(--bg-page);flex-shrink:0}.wsm-check-box.checked{background:var(--accent);border-color:var(--accent);color:var(--bg-page)}.wsm-check-label{font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wsm-chips{display:flex;flex-wrap:wrap;gap:6px}.wsm-chip{padding:6px 12px;background:var(--bg-page);border:.5px solid var(--border);border-radius:var(--radius-md);font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.wsm-chip:hover{border-color:var(--accent)}.wsm-chip.selected{background:var(--accent);color:var(--bg-page);border-color:var(--accent)}.wsm-chip.sev-critical.selected{background:var(--status-error);border-color:var(--status-error)}.wsm-chip.sev-warning.selected{background:var(--status-warn);border-color:var(--status-warn)}.wsm-select{width:100%;padding:8px 12px;background:var(--bg-page);border:.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px;cursor:pointer}@media(max-width:768px){.dashboard-stat-row{grid-template-columns:1fr 1fr}.dashboard-widget-grid{grid-template-columns:1fr}.dashboard-widget.size-full{grid-column:1}.dashboard-greeting{font-size:1.25rem}}.home-page{max-width:1000px;margin:0 auto;padding-bottom:var(--space-2xl)}.home-hero{text-align:center;padding:var(--space-2xl) var(--space-md);margin-bottom:var(--space-xl);background:linear-gradient(180deg,rgba(0,212,170,.05) 0%,transparent 100%);border-radius:var(--radius-xl)}.home-logo-container{margin-bottom:var(--space-lg);position:relative}.home-logo-main{max-height:100px;max-width:280px;filter:drop-shadow(0 4px 12px rgba(0,212,170,.2))}.home-subtitle{font-size:18px;color:var(--text-secondary);margin-bottom:var(--space-sm);font-weight:400}.home-stats{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:14px;color:var(--accent);background:#00d4aa1a;padding:6px 16px;border-radius:20px;font-weight:500}.home-stats:before{content:"";width:8px;height:8px;background:var(--accent-success);border-radius:50%;animation:pulse-dot 2s infinite}.lockdown-container{margin-bottom:var(--space-xl)}.lockdown-box{background:linear-gradient(135deg,#f973161a,#ea580c0d);border:1px solid rgba(249,115,22,.3);border-left:4px solid var(--accent-warning);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;justify-content:space-between;align-items:center;gap:var(--space-lg);flex-wrap:wrap;transition:all var(--transition-fast)}.lockdown-box:hover{background:linear-gradient(135deg,#f9731626,#ea580c14);border-color:#f9731680}.lockdown-box.active{background:linear-gradient(135deg,#ef444426,#dc262614);border-color:#ef444466;border-left-color:var(--accent-danger);animation:pulse-danger 2s infinite}@keyframes pulse-danger{0%,to{box-shadow:0 0 #ef444433}50%{box-shadow:0 0 20px 4px #ef444426}}.lockdown-content{display:flex;align-items:center;gap:var(--space-md)}.lockdown-content>svg{color:var(--accent-warning);flex-shrink:0}.lockdown-box.active .lockdown-content>svg{color:var(--accent-danger);animation:shake .5s ease-in-out infinite}@keyframes shake{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.lockdown-text h3{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.lockdown-text p{font-size:13px;color:var(--text-secondary);margin:0}.lockdown-btn{white-space:nowrap;padding:var(--space-sm) var(--space-lg);font-weight:600;display:flex;align-items:center;gap:var(--space-sm)}.home-section{margin-bottom:var(--space-xl)}.home-section-title{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:var(--space-md);padding-left:var(--space-xs)}.home-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.home-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);transition:all var(--transition-fast);text-decoration:none;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.home-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--card-accent, var(--accent));opacity:0;transition:opacity var(--transition-fast)}.home-card:hover{border-color:transparent;transform:translateY(-4px);box-shadow:0 12px 40px #0000004d}.home-card:hover:before{opacity:1}.home-card-icon{width:52px;height:52px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform var(--transition-fast)}.home-card:hover .home-card-icon{transform:scale(1.1)}.home-card-content{flex:1;min-width:0}.home-card-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.home-card-description{font-size:13px;color:var(--text-tertiary);line-height:1.4}.home-card-arrow{color:var(--text-tertiary);transition:all var(--transition-fast);flex-shrink:0}.home-card:hover .home-card-arrow{transform:translate(6px);color:var(--accent)}.lockdown-modal{text-align:center;max-width:400px}.lockdown-modal .modal-icon{margin-bottom:var(--space-lg)}.lockdown-modal h2{font-size:20px;font-weight:600;margin-bottom:var(--space-md)}.lockdown-modal p{color:var(--text-secondary);margin-bottom:var(--space-xl);line-height:1.6}.lockdown-modal .modal-actions{display:flex;gap:var(--space-md);justify-content:center}.lockdown-modal .modal-actions .btn{flex:1;max-width:160px}.shabbat-mode-section{margin-bottom:var(--space-xl)}@media(max-width:768px){.home-hero{padding:var(--space-xl) var(--space-sm)}.home-logo-main{max-height:80px;max-width:220px}.home-subtitle{font-size:16px}.home-grid{grid-template-columns:1fr}.lockdown-box{flex-direction:column;text-align:center}.lockdown-content{flex-direction:column}.lockdown-btn{width:100%;justify-content:center}.home-card{padding:var(--space-md)}.home-card-icon{width:44px;height:44px}}@media(max-width:1024px){.home-page{padding-bottom:calc(var(--space-2xl) + 80px)}}.shabbat-container{margin-bottom:var(--space-xl)}.shabbat-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.shabbat-box.active{border-color:#00d4aa66;background:linear-gradient(135deg,rgba(0,212,170,.05) 0%,var(--bg-surface) 100%)}.shabbat-box.loading{opacity:.7;pointer-events:none}.shabbat-content{display:flex;align-items:flex-start;gap:var(--space-md)}.shabbat-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:var(--bg-page);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);flex-shrink:0}.shabbat-box.active .shabbat-icon{background:#00d4aa26;color:var(--accent)}.shabbat-status-active{color:var(--accent)}.shabbat-next{font-size:13px;color:var(--text-tertiary)}.shabbat-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap}.shabbat-schedule{display:flex;align-items:center;gap:var(--space-sm);font-size:13px}.shabbat-schedule-label{color:var(--text-tertiary)}.shabbat-schedule-time{color:var(--text-primary);font-weight:500}.shabbat-btn{padding:var(--space-sm) var(--space-md);font-size:13px;font-weight:500;display:flex;align-items:center;gap:var(--space-xs)}.css-version-toggle{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm)}.css-version-toggle span{font-size:14px;color:var(--text-secondary)}.css-version-toggle svg{color:var(--accent)}.home-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);transition:all var(--transition-base);text-decoration:none;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.home-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0006,0 0 0 1px #00d4aa1a}.home-card:has(.home-card-icon[style*="rgb(0, 212, 170)"]):hover,.home-card:has(.home-card-icon[style*="#00d4aa"]):hover{border-color:#00d4aa80;box-shadow:0 12px 40px #0006,0 0 30px #00d4aa26,0 0 0 1px #00d4aa33}.home-card:has(.home-card-icon[style*="rgb(245, 158, 11)"]):hover,.home-card:has(.home-card-icon[style*="#f59e0b"]):hover{border-color:#f59e0b80;box-shadow:0 12px 40px #0006,0 0 30px #f59e0b26,0 0 0 1px #f59e0b33}.home-card:has(.home-card-icon[style*="rgb(168, 85, 247)"]):hover,.home-card:has(.home-card-icon[style*="#a855f7"]):hover{border-color:#a855f780;box-shadow:0 12px 40px #0006,0 0 30px #a855f726,0 0 0 1px #a855f733}.home-card:has(.home-card-icon[style*="rgb(236, 72, 153)"]):hover,.home-card:has(.home-card-icon[style*="#ec4899"]):hover{border-color:#ec489980;box-shadow:0 12px 40px #0006,0 0 30px #ec489926,0 0 0 1px #ec489933}.home-card:has(.home-card-icon[style*="rgb(107, 114, 128)"]):hover,.home-card:has(.home-card-icon[style*="#6b7280"]):hover{border-color:#6b728080;box-shadow:0 12px 40px #0006,0 0 30px #6b728026,0 0 0 1px #6b728033}.home-card-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast);border:1px solid rgba(255,255,255,.1)}.home-card:hover .home-card-icon{transform:scale(1.1);border-color:#fff3}.home-card-arrow{color:var(--text-tertiary);transition:all var(--transition-fast);flex-shrink:0;opacity:.5}.home-card:hover .home-card-arrow{transform:translate(6px);color:currentColor;opacity:1}.shabbat-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.shabbat-box:hover{border-color:#a855f74d;box-shadow:0 8px 32px #0003}.shabbat-box.active{border-color:#00d4aa66;background:linear-gradient(135deg,rgba(0,212,170,.08) 0%,var(--bg-surface) 100%);box-shadow:0 0 30px #00d4aa1a}.shabbat-icon{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#a855f726,#a855f714);border:1px solid rgba(168,85,247,.2);display:flex;align-items:center;justify-content:center;color:var(--accent-purple);flex-shrink:0}.shabbat-box.active .shabbat-icon{background:linear-gradient(135deg,#00d4aa33,#00d4aa1a);border-color:#00d4aa4d;color:var(--accent)}.shabbat-btn{padding:10px var(--space-lg);font-size:13px;font-weight:600;display:flex;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);transition:all var(--transition-fast)}.shabbat-btn.btn-primary{background:var(--accent-purple);border:none;color:#fff}.shabbat-btn.btn-primary:hover{background:#9333ea;box-shadow:0 4px 20px #a855f766;transform:translateY(-2px)}.lockdown-box{background:linear-gradient(135deg,#ef444414,#ef444408);border:1px solid rgba(239,68,68,.25);border-left:4px solid var(--accent-danger);border-radius:var(--radius-xl);padding:var(--space-lg);display:flex;justify-content:space-between;align-items:center;gap:var(--space-lg);flex-wrap:wrap;transition:all var(--transition-base)}.lockdown-box:hover{background:linear-gradient(135deg,#ef44441f,#ef44440d);border-color:#ef444466;box-shadow:0 8px 32px #ef44441a}.lockdown-content>svg{color:var(--accent-danger);flex-shrink:0}.lockdown-btn{padding:12px var(--space-xl);font-size:14px;font-weight:600;display:flex;align-items:center;gap:var(--space-sm);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.lockdown-btn.btn-danger{background:var(--status-error);color:#fff;border:.5px solid var(--status-error)}.lockdown-btn.btn-danger:hover{background:var(--status-error);border-color:var(--status-error);color:#fff;box-shadow:0 4px 20px #ef444466;transform:translateY(-2px)}.shabbat-box{background:linear-gradient(135deg,#a855f714,#a855f708);border:1px solid rgba(168,85,247,.25);border-left:4px solid var(--accent-purple);border-radius:var(--radius-xl);padding:var(--space-lg);display:flex;justify-content:space-between;align-items:center;gap:var(--space-lg);flex-wrap:wrap;transition:all var(--transition-base)}.shabbat-box:hover{background:linear-gradient(135deg,#a855f71f,#a855f70d);border-color:#a855f766;box-shadow:0 8px 32px #a855f71a}.shabbat-box.active{background:linear-gradient(135deg,#00d4aa14,#00d4aa08);border-color:#00d4aa40;border-left-color:var(--accent)}.shabbat-box.active:hover{background:linear-gradient(135deg,#00d4aa1f,#00d4aa0d);border-color:#00d4aa66;box-shadow:0 8px 32px #00d4aa1a}.shabbat-content{display:flex;align-items:center;gap:var(--space-md);flex:1}.shabbat-icon{width:44px;height:44px;border-radius:var(--radius-md);background:transparent;border:none;display:flex;align-items:center;justify-content:center;color:var(--accent-purple);flex-shrink:0}.shabbat-box.active .shabbat-icon{color:var(--accent)}.shabbat-text{flex:1}.shabbat-text h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.shabbat-text p{font-size:13px;color:var(--text-secondary);margin:0}.shabbat-actions{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.shabbat-schedule{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:13px}.shabbat-schedule-label{color:var(--text-tertiary);font-size:12px}.shabbat-schedule-time{color:var(--text-primary);font-weight:600}.shabbat-btn{padding:12px var(--space-xl);font-size:14px;font-weight:600;display:flex;align-items:center;gap:var(--space-sm);border-radius:var(--radius-lg);transition:all var(--transition-fast);white-space:nowrap}.shabbat-btn.btn-primary{background:linear-gradient(135deg,#a855f733,#a855f71a);border:1px solid rgba(168,85,247,.4);color:var(--accent-purple)}.shabbat-btn.btn-primary:hover{background:var(--accent-purple);border-color:var(--accent-purple);color:#fff;box-shadow:0 4px 20px #a855f766;transform:translateY(-2px)}.shabbat-box.active .shabbat-btn.btn-primary{background:linear-gradient(135deg,#00d4aa33,#00d4aa1a);border:1px solid rgba(0,212,170,.4);color:var(--accent)}.shabbat-box.active .shabbat-btn.btn-primary:hover{background:var(--accent);border-color:var(--accent);color:var(--bg-primary);box-shadow:0 4px 20px #00d4aa66}@media(max-width:768px){.shabbat-box{flex-direction:column;text-align:center}.shabbat-content{flex-direction:column}.shabbat-actions{width:100%;justify-content:center}.shabbat-schedule{align-items:center}.shabbat-btn{width:100%;justify-content:center}}.shabbat-box{display:flex;flex-direction:row;justify-content:space-between;align-items:center;text-align:left}.shabbat-content{display:flex;align-items:center;gap:var(--space-md);flex:1;justify-content:flex-start}.shabbat-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.shabbat-text{text-align:left}.shabbat-actions{display:flex;align-items:center;gap:var(--space-md);flex-shrink:0}.shabbat-schedule{display:flex;flex-direction:column;align-items:flex-end;text-align:right}@media(max-width:768px){.shabbat-content{flex-direction:column;align-items:center;text-align:center}.shabbat-text{text-align:center}.shabbat-actions{flex-direction:column;align-items:center;text-align:center}.shabbat-schedule{justify-content:center;flex-direction:column;gap:2px}.shabbat-btn{width:100%}}@media(max-width:768px){.shabbat-schedule{flex-direction:row;gap:var(--space-xs)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-page);padding:var(--space-lg)}.login-container{width:100%;max-width:400px;background:var(--bg-surface);border-radius:var(--radius-xl);padding:var(--space-xl);border:.5px solid var(--border);box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--space-xl)}.login-logo{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:20px;margin-bottom:var(--space-md);color:var(--text-primary)}.login-logo-wrapper{margin-bottom:var(--space-md)}.login-logo-img{max-height:80px;max-width:200px;object-fit:contain}.login-header h1{font-size:24px;font-weight:600;margin-bottom:var(--space-sm)}.login-header p{color:var(--text-secondary)}.logo-light-theme,.logo-dark-theme{display:none}[data-theme=indigo] .logo-light-theme,[data-theme=cobalt] .logo-light-theme,[data-theme=violet] .logo-light-theme,[data-theme=emerald] .logo-light-theme,[data-theme=midnight] .logo-dark-theme,[data-theme=carbon] .logo-dark-theme{display:inline-block}.login-form{display:flex;flex-direction:column;gap:var(--space-lg)}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--accent-danger);padding:var(--space-md);border-radius:var(--radius-md);font-size:14px;text-align:center}.password-input-wrapper .form-input{padding-right:44px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs)}.password-toggle:hover{color:var(--text-primary)}.login-btn{width:100%;padding:14px;font-size:16px}.login-footer{text-align:center;margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid rgba(255,255,255,.1)}.login-footer p{color:var(--text-tertiary);font-size:12px}.login-footer a{color:var(--accent)}.login-footer a:hover{text-decoration:underline}.oauth-divider{display:flex;align-items:center;gap:var(--space-md);margin:var(--space-lg) 0}.oauth-divider span{color:var(--text-tertiary);font-size:14px}.oauth-divider:before,.oauth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.oauth-btn{width:100%;padding:12px;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-weight:500;transition:all var(--transition-fast)}.oauth-btn:hover{background:var(--bg-surface);border-color:var(--text-tertiary);box-shadow:var(--shadow-sm)}.oauth-btn img{width:20px;height:20px}.login-remember{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;font-size:14px;color:var(--text-secondary)}.login-remember input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.login-remember-text{display:flex;align-items:center;gap:var(--space-xs);color:var(--text-secondary)}.oauth-section{margin-top:var(--space-xl)}.oauth-label{text-align:center;color:var(--text-tertiary);font-size:14px;margin-bottom:var(--space-md)}.oauth-buttons{display:flex;gap:var(--space-md);justify-content:center}.oauth-btn{display:flex;align-items:center;gap:var(--space-sm);padding:10px 20px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-weight:500;text-decoration:none;transition:all var(--transition-fast)}.oauth-btn:hover{background:var(--bg-surface);border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.oauth-btn img{width:18px;height:18px}.login-links{text-align:center;margin-top:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.login-link{color:var(--text-tertiary);text-decoration:none;font-size:14px;transition:color var(--transition-fast)}.login-link:hover{color:var(--text-primary)}.login-link.primary{color:var(--accent)}.login-link.primary:hover{color:#00b894}.login-powered-by{text-align:center;margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--border);color:var(--text-tertiary);font-size:12px}.login-remember{display:flex;align-items:center;gap:10px;cursor:pointer;padding:12px;margin-bottom:var(--space-md);background:transparent;border-radius:var(--radius-md);border:1px solid transparent;transition:all var(--transition-fast)}.login-remember.active{background:#00d4aa1a;border-color:#00d4aa4d}.login-remember input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.login-remember svg{color:var(--text-tertiary);transition:color var(--transition-fast)}.login-remember.active svg{color:var(--accent)}.login-remember span{color:var(--text-tertiary);font-size:14px;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast)}.login-remember.active span{color:var(--accent)}.camera-grid{display:grid;gap:var(--space-md);height:calc(100vh - 180px)}.camera-grid.grid-1x1{grid-template-columns:1fr}.camera-grid.grid-2x2{grid-template-columns:repeat(2,1fr)}.camera-grid.grid-3x3{grid-template-columns:repeat(3,1fr)}.camera-grid.grid-4x4{grid-template-columns:repeat(4,1fr)}.camera-cell{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:relative;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.camera-cell:hover{border-color:var(--accent)}.camera-header{padding:10px 14px;background:var(--bg-page);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.camera-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.camera-status.offline{background:var(--accent-danger)}.camera-stream{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-page);position:relative;min-height:120px}.camera-stream img,.camera-stream video{width:100%;height:100%;object-fit:contain}.camera-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);color:var(--text-muted);padding:var(--space-lg);text-align:center}.camera-placeholder svg{opacity:.5}.camera-cell-empty{opacity:.5;border:2px dashed var(--border)}.grid-controls{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.grid-select{padding:10px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:14px;cursor:pointer;min-width:140px}.grid-select:focus{outline:none;border-color:var(--accent)}.camera-tile{cursor:grab;transition:all var(--transition-fast)}.camera-tile.dragging{opacity:.5;cursor:grabbing}.camera-tile.drag-over{border-color:var(--accent);box-shadow:0 0 0 2px #00d4aa4d}.camera-fullscreen-modal{position:fixed;inset:0;background:#000000f2;z-index:1000;display:flex;align-items:center;justify-content:center}.camera-fullscreen-view{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.camera-fullscreen-view video{max-width:100%;max-height:100%;object-fit:contain}.archive-new{display:flex;flex-direction:column;height:calc(100vh - 60px);background:var(--bg-primary)}.archive-camera-select{flex:1;display:flex;flex-direction:column;padding:var(--space-lg);overflow-y:auto}.camera-select-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.camera-search-wrapper{position:relative;flex:1;min-width:200px;max-width:400px}.camera-search-input{width:100%;padding:10px 40px 10px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px}.camera-search-input:focus{outline:none;border-color:var(--accent)}.camera-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px}.camera-search-clear:hover{color:var(--text-primary)}.layout-select{padding:10px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;cursor:pointer;min-width:150px}.camera-count{font-size:14px;color:var(--text-tertiary);white-space:nowrap}.camera-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-lg)}.camera-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all var(--transition-fast)}.camera-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.camera-thumbnail{aspect-ratio:16/9;min-height:120px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden}.camera-thumbnail img{width:100%;height:100%;object-fit:cover}.camera-name{padding:12px;font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.archive-player-view{flex:1;display:flex;flex-direction:column;background:#000;position:relative}.archive-header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;padding:var(--space-md) var(--space-lg);background:linear-gradient(180deg,rgba(0,0,0,.8) 0%,transparent 100%);z-index:10;gap:var(--space-md);transition:opacity .3s ease}.archive-back-btn{width:40px;height:40px;border-radius:50%;background:#ffffff1a;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.archive-back-btn:hover{background:#fff3}.archive-camera-name{flex:1;font-size:16px;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.archive-live-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#ef444433;border:1px solid rgba(239,68,68,.4);border-radius:20px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.archive-live-btn:hover{background:#ef44444d}.archive-live-btn.active{background:#ef44444d;border-color:#ef444499}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.live{background:#ef4444;animation:pulse-live 2s infinite}.status-dot.recorded{background:#f59e0b}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.5}}.archive-video-wrapper{flex:1;display:flex;align-items:center;justify-content:center;background:#000;position:relative;min-height:0}.archive-video-wrapper video{width:100%;height:100%;object-fit:contain}.archive-controls-overlay{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:28px;z-index:10;transition:opacity .3s ease}.archive-control-btn{width:48px;height:48px;border-radius:50%;background:#ffffff1a;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.archive-control-btn:hover{background:#fff3}.archive-thumbnail-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.archive-thumbnail-img{max-width:100%;max-height:100%;object-fit:contain;opacity:.8}.archive-play-big-btn{width:80px;height:80px;border-radius:50%;background:#00d4aae6;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.archive-play-big-btn:hover{background:var(--accent);transform:scale(1.05)}.archive-thumbnail-label{font-size:14px;color:#fffc}.archive-timeline-section{background:var(--bg-secondary);padding:var(--space-md) 0;border-top:1px solid var(--border-color);transition:opacity .3s ease}.archive-time-display{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:0 var(--space-lg) var(--space-md);flex-wrap:wrap}.date-nav-btn{width:32px;height:32px;border-radius:var(--radius-md);background:var(--bg-page);border:1px solid var(--border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.date-nav-btn:hover:not(:disabled){background:var(--bg-surface);color:var(--text-primary)}.date-nav-btn:disabled{opacity:.3;cursor:not-allowed}.current-date-btn,.current-time-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.current-date-btn:hover,.current-time-btn:hover{background:var(--bg-surface);border-color:var(--accent);box-shadow:var(--shadow-sm)}.current-date-btn svg,.current-time-btn svg{color:var(--text-tertiary)}.zoom-btn{padding:6px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.zoom-btn:hover{background:var(--bg-surface);color:var(--text-primary)}.zoom-btn.active{background:var(--accent);border-color:var(--accent);color:#000}.archive-timeline{position:relative;height:60px;background:var(--bg-tertiary);border-radius:var(--radius-md);margin:0 var(--space-lg);overflow:hidden}.timeline-markers{position:absolute;top:0;left:0;right:0;height:20px;display:flex;justify-content:space-between;padding:0 10px}.marker-tick{display:flex;flex-direction:column;align-items:center}.marker-tick:before{content:"";width:1px;height:6px;background:var(--border)}.marker-label{font-size:10px;color:var(--text-tertiary);margin-top:2px}.timeline-activity{position:absolute;bottom:0;left:0;right:0;height:40px}.timeline-playhead{position:absolute;top:0;bottom:0;width:2px;background:var(--accent);z-index:5}.playhead-line{width:100%;height:100%;background:var(--accent)}.playhead-arrow{position:absolute;top:-6px;left:50%;transform:translate(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--accent)}.timeline-no-recordings{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--text-tertiary)}.timeline-filters{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg)}.filter-dot{width:8px;height:8px;border-radius:50%}.quick-jump-buttons{display:flex;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg)}.quick-jump-btn{padding:6px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .2s}.quick-jump-btn:hover{background:var(--bg-surface);color:var(--text-primary)}@media(max-width:768px){.archive-camera-select{padding:var(--space-md)}.camera-select-header{flex-direction:column;align-items:stretch}.camera-search-wrapper{max-width:none}.camera-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-sm)}.archive-time-display{padding:0 var(--space-md) var(--space-sm)}.timeline-zoom{margin-left:0;margin-top:var(--space-sm);width:100%;justify-content:center}.archive-timeline{margin:0 var(--space-md)}}.camera-cell{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-fast);display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.camera-cell:hover{border-color:var(--accent);box-shadow:0 8px 32px #00d4aa26}.camera-cell-empty{opacity:.5}.camera-cell-empty:hover{border-color:var(--border);box-shadow:none}.camera-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border-bottom:1px solid var(--border)}.camera-header .drag-handle{color:var(--text-tertiary);cursor:grab;padding:2px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.camera-header .drag-handle:hover{color:var(--text-primary);background:var(--bg-page)}.camera-header .drag-handle:active{cursor:grabbing}.camera-header .camera-name{flex:1;font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.camera-status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.camera-status.online{background:var(--accent-success);box-shadow:0 0 8px var(--accent-success)}.camera-status.offline{background:var(--text-tertiary)}.live-indicator{font-size:10px;font-weight:700;padding:2px 6px;border-radius:var(--radius-sm);background:#ef444433;color:var(--accent-danger);letter-spacing:.5px}.live-indicator.fallback{background:#f59e0b33;color:var(--accent-warning)}.camera-header .btn-icon{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.camera-header .btn-icon:hover{background:var(--accent);border-color:var(--accent);color:var(--bg-page)}.camera-header .btn-icon.active{background:#ef444433;border-color:var(--accent-danger);color:var(--accent-danger)}.camera-stream{position:relative;aspect-ratio:16/9;background:var(--bg-page);cursor:pointer;overflow:hidden}.camera-stream img,.camera-stream video{width:100%;height:100%;object-fit:cover}.camera-thumbnail-container{width:100%;height:100%}.camera-thumbnail{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.camera-cell:hover .camera-thumbnail{transform:scale(1.03)}.camera-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);color:var(--text-muted);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%)}.camera-placeholder svg{opacity:.4}.camera-placeholder span{font-size:12px}.camera-tile.dragging{opacity:.5;transform:scale(.95)}.camera-tile.drag-over{border:2px dashed var(--accent);border-radius:var(--radius-xl)}.drag-hint{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);background:#00d4aa1a;border:1px solid rgba(0,212,170,.2);border-radius:var(--radius-md);color:var(--accent);font-size:13px}.camera-grid{display:grid;gap:var(--space-md)}.camera-grid-scrollable{max-height:calc(100vh - 200px);overflow-y:auto;padding-right:var(--space-sm)}.camera-fullscreen-modal{max-width:95vw;width:1400px;background:var(--bg-surface);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm)}.camera-fullscreen-modal .modal-header{padding:var(--space-md) var(--space-lg);background:var(--bg-page);border-bottom:1px solid var(--border)}.camera-fullscreen-modal .modal-header h3{font-size:18px;font-weight:600}.camera-fullscreen-modal .modal-body{padding:0}.camera-fullscreen-view{aspect-ratio:16/9;background:#000}.camera-fullscreen-view video{width:100%;height:100%;object-fit:contain}.grid-controls{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap}.grid-selector{display:flex;gap:var(--space-xs)}.grid-selector .btn{min-width:50px}.grid-selector .btn.active{background:var(--accent);color:var(--bg-page)}@media(max-width:768px){.camera-header{padding:var(--space-xs) var(--space-sm)}.camera-header .camera-name{font-size:13px}.camera-header .btn-icon{width:26px;height:26px}.drag-hint{display:none}.grid-controls{flex-direction:column;align-items:stretch}.grid-selector{justify-content:center}}.archive-new .archive-camera-select{background:var(--bg-primary);padding:var(--space-lg)}.camera-select-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap;padding-top:0;text-align:left}.camera-select-header h2{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 auto 0 0}.camera-search-wrapper{position:relative;min-width:250px}.camera-search-input{width:100%;padding:10px 40px 10px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.camera-search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa1a}.camera-search-input::placeholder{color:var(--text-tertiary)}.camera-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast)}.camera-search-clear:hover{background:var(--bg-surface);color:var(--text-primary)}.layout-select{padding:10px 36px 10px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;cursor:pointer;min-width:160px;transition:all var(--transition-fast);-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.layout-select:focus{outline:none;border-color:var(--accent)}.camera-count{display:inline-flex;align-items:center;padding:6px 14px;background:linear-gradient(135deg,#00d4aa26,#00d4aa14);border:1px solid rgba(0,212,170,.3);border-radius:20px;font-size:13px;font-weight:600;color:var(--accent)}.archive-camera-select .camera-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-md);height:auto;max-height:calc(100vh - 180px);overflow-y:auto;padding-right:var(--space-sm)}.camera-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;cursor:pointer;transition:all var(--transition-base);display:flex;flex-direction:column}.camera-card:hover{border-color:#00d4aa80;transform:translateY(-3px);box-shadow:0 12px 40px #0006,0 0 0 1px #00d4aa1a,0 0 30px #00d4aa1a}.camera-card .camera-thumbnail{position:relative;aspect-ratio:16/9;background:var(--bg-secondary);overflow:hidden}.camera-card .camera-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.camera-card:hover .camera-thumbnail img{transform:scale(1.05)}.camera-card .camera-name{display:block;padding:var(--space-md);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-top:1px solid var(--border-color);font-size:13px;font-weight:600;color:var(--text-primary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.camera-select-header{flex-direction:column;align-items:stretch;gap:var(--space-sm)}.camera-select-header h2{text-align:center;margin-right:0}.camera-search-wrapper{min-width:100%}.layout-select{width:100%}.camera-count{align-self:center}.archive-camera-select .camera-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-sm)}}@media(max-width:480px){.archive-camera-select .camera-grid{grid-template-columns:repeat(2,1fr)}}.camera-select-header{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);padding-top:0}.camera-select-header h2{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.camera-search-wrapper{max-width:300px;margin-left:auto}@media(max-width:900px){.camera-select-header{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}.camera-select-header h2{grid-column:1}.camera-search-wrapper{grid-column:2;max-width:100%;margin-left:0}.layout-select{grid-column:1}.camera-count{grid-column:2;justify-self:end}}@media(max-width:600px){.camera-select-header{grid-template-columns:1fr}.camera-select-header h2,.camera-search-wrapper,.layout-select,.camera-count{grid-column:1}.camera-count{justify-self:start}}.archive-header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:linear-gradient(180deg,rgba(0,0,0,.8) 0%,transparent 100%);z-index:10;transition:opacity .3s ease}.archive-header.hidden{opacity:0;pointer-events:none}.archive-header.visible{opacity:1}.archive-back-btn{width:44px;height:44px;border-radius:50%;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.archive-back-btn:hover{background:#fff3;border-color:#ffffff40;transform:scale(1.05)}.archive-camera-name{flex:1;font-size:18px;font-weight:600;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}.archive-live-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:24px;color:#9ca3af;font-size:12px;font-weight:700;letter-spacing:1px;cursor:pointer;transition:all .2s ease}.archive-live-btn:hover{background:#ffffff26}.archive-live-btn.active{background:#ef444433;border-color:#ef444466;color:#ef4444}.archive-live-btn .status-dot{width:10px;height:10px;border-radius:50%;background:#6b7280}.archive-live-btn .status-dot.live{background:#ef4444;box-shadow:0 0 12px #ef444499;animation:pulse-live 1.5s infinite}.archive-live-btn .status-dot.recorded{background:var(--accent)}.archive-controls-overlay{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:12px 16px;background:#000000b3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:32px;z-index:10;transition:opacity .3s ease}.archive-controls-overlay.hidden{opacity:0;pointer-events:none}.archive-controls-overlay.visible{opacity:1}.archive-control-btn{width:52px;height:52px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.archive-control-btn:hover{background:#fff3;border-color:#ffffff4d;transform:scale(1.08)}.archive-control-btn:active{transform:scale(.95)}.archive-thumbnail-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);background:#0006}.archive-play-big-btn{width:80px;height:80px;border-radius:50%;background:#00d4aae6;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 8px 32px #00d4aa66}.archive-play-big-btn:hover{background:var(--accent);transform:scale(1.1);box-shadow:0 12px 40px #00d4aa80}.archive-thumbnail-label{font-size:14px;color:#fffc;text-shadow:0 2px 8px rgba(0,0,0,.5)}.archive-timeline-section{background:linear-gradient(180deg,#0d0d14,#0a0a0f);padding:var(--space-md) 0;border-top:1px solid rgba(255,255,255,.08);transition:opacity .3s ease}.archive-timeline-section.hidden{opacity:0;pointer-events:none}.archive-timeline-section.visible{opacity:1}.archive-time-display{display:flex;align-items:center;justify-content:center;gap:10px;padding:0 var(--space-md) var(--space-md);flex-wrap:wrap}.date-nav-btn{width:36px;height:36px;border-radius:var(--radius-md);background:#ffffff14;border:.5px solid rgba(255,255,255,.12);color:#ffffffb3;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.date-nav-btn:hover:not(:disabled){background:#ffffff1a;border-color:var(--accent);color:var(--text-primary)}.current-date-btn,.current-time-btn{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#ffffff1a;border:.5px solid rgba(255,255,255,.15);border-radius:var(--radius-md);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.current-date-btn:hover,.current-time-btn:hover{background:#ffffff1a;border-color:var(--accent)}.current-date-btn svg{color:var(--accent)}.current-time-btn{font-variant-numeric:tabular-nums;min-width:100px;justify-content:center}.timeline-zoom{display:flex;gap:4px;margin-left:var(--space-md)}.zoom-btn{padding:8px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--text-tertiary);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.zoom-btn:hover{background:#ffffff1a;color:var(--text-secondary)}.zoom-btn.active{background:#00d4aa26;border-color:#00d4aa66;color:var(--accent)}.timeline-filters{display:flex;gap:6px;margin-left:var(--space-md)}.filter-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--text-tertiary);font-size:11px;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:all .2s ease}.filter-btn:hover{background:#ffffff1a}.filter-btn .filter-dot{width:8px;height:8px;border-radius:50%;background:currentColor;opacity:.5}.filter-btn.recordings.active{background:#00d4aa26;border-color:#00d4aa66;color:var(--accent)}.filter-btn.recordings .filter-dot{background:var(--accent)}.filter-btn.motion.active{background:#06b6d426;border-color:#06b6d466;color:#06b6d4}.filter-btn.motion .filter-dot{background:#06b6d4}.filter-btn.analytics.active{background:#a855f726;border-color:#a855f766;color:var(--accent-purple)}.filter-btn.analytics .filter-dot{background:var(--accent-purple)}.filter-btn.active .filter-dot{opacity:1;box-shadow:0 0 8px currentColor}.quick-jump-buttons{display:flex;gap:6px;margin-left:var(--space-md)}.quick-jump-btn{padding:8px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--text-tertiary);font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease}.quick-jump-btn:hover{background:#ffffff1a;border-color:var(--accent);color:var(--text-primary)}.quick-jump-btn:first-child{color:var(--accent);border-color:#00d4aa4d}.quick-jump-btn:first-child:hover{background:#00d4aa26}.archive-timeline{position:relative;height:100px;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:pan-x;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.3) 100%)}.archive-timeline:active{cursor:grabbing}.timeline-playhead{position:absolute;top:20px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;pointer-events:none;z-index:5}.playhead-arrow{width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:10px solid var(--accent);filter:drop-shadow(0 2px 4px rgba(0,212,170,.4))}.playhead-line{width:2px;height:70px;background:linear-gradient(180deg,var(--accent) 0%,rgba(0,212,170,.2) 100%)}@media(max-width:900px){.archive-time-display{gap:6px}.timeline-zoom,.timeline-filters,.quick-jump-buttons{margin-left:0}}@media(max-width:768px){.archive-back-btn{width:40px;height:40px}.archive-camera-name{font-size:16px}.archive-live-btn{padding:8px 12px;font-size:11px}.archive-control-btn{width:44px;height:44px}.archive-play-big-btn{width:64px;height:64px}.archive-time-display{flex-wrap:wrap;justify-content:center}.timeline-zoom{order:10;width:100%;justify-content:center;margin-top:var(--space-sm)}.timeline-filters{order:11;width:100%;justify-content:center;margin-top:var(--space-sm)}.quick-jump-buttons{order:12;width:100%;justify-content:center;margin-top:var(--space-sm)}}.archive-timeline{position:relative;height:100px;width:100%;overflow:hidden}.timeline-markers{position:absolute;top:0;left:50%;height:30px;display:flex;align-items:flex-end;pointer-events:none}.timeline-marker{position:absolute;display:flex;flex-direction:column;align-items:center;transform-origin:center bottom}.marker-label{font-size:11px;color:#fff9;font-weight:500;font-variant-numeric:tabular-nums;margin-bottom:4px;white-space:nowrap}.timeline-marker.hour .marker-label{color:#ffffffd9;font-size:12px}.marker-tick{width:1px;height:8px;background:#ffffff26}.timeline-marker.hour .marker-tick{height:12px;background:#ffffff4d}.timeline-activity{position:absolute;top:40px;left:50%;height:50px;display:flex;align-items:flex-end;pointer-events:none}.activity-bar{position:absolute;min-height:30px;border-radius:2px;transform-origin:center bottom}.activity-bar.recording,.activity-bar:not(.motion):not(.person):not(.vehicle){background:linear-gradient(180deg,var(--accent) 0%,rgba(0,212,170,.7) 100%)}.activity-bar.motion{background:linear-gradient(180deg,#06b6d4,#06b6d4b3)}.activity-bar.person{background:linear-gradient(180deg,var(--accent-purple) 0%,rgba(168,85,247,.7) 100%)}.activity-bar.vehicle{background:linear-gradient(180deg,#f472b6,#f472b6b3)}.timeline-playhead{position:absolute;top:10px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;pointer-events:none;z-index:5}.playhead-arrow{width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:10px solid var(--accent);filter:drop-shadow(0 2px 4px rgba(0,212,170,.5))}.playhead-line{width:2px;height:80px;background:linear-gradient(180deg,var(--accent) 0%,rgba(0,212,170,.3) 100%)}.archive-timeline{padding-top:5px;overflow:visible}.timeline-markers{top:5px}.marker-label{position:relative;z-index:2}.timeline-marker.hour .marker-label{font-weight:600}.camera-select-controls{display:flex;align-items:center;gap:var(--space-sm)}.camera-card .lazy-thumbnail{width:100%;height:100%;position:absolute;inset:0}.camera-card .lazy-thumbnail img{width:100%;height:100%;object-fit:cover}.intercom-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg);padding:var(--space-md) 0}.intercom-cell{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-fast);display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.intercom-cell:hover{border-color:var(--accent);box-shadow:0 4px 20px #00d4aa26;transform:translateY(-2px)}.intercom-cell .camera-header{padding:var(--space-md) var(--space-lg);background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm)}.intercom-cell .camera-name{font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-icon{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--bg-page);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--accent);box-shadow:var(--shadow-sm)}.btn-icon.btn-unlock:hover{background:#00d4aa26;color:var(--accent);border-color:var(--accent)}.btn-icon:disabled{opacity:.4;cursor:not-allowed}.intercom-stream{position:relative;aspect-ratio:16/9;background:var(--bg-page);cursor:pointer;overflow:hidden}.intercom-stream img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-fast)}.intercom-cell:hover .intercom-stream img{transform:scale(1.02)}.intercom-warning-badge{position:absolute;bottom:var(--space-sm);left:var(--space-sm);display:flex;align-items:center;gap:4px;padding:4px 8px;background:#f59e0be6;color:var(--bg-page);font-size:11px;font-weight:600;border-radius:var(--radius-sm)}.intercom-modal-overlay{position:fixed;inset:0;background:#000000e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-md)}.intercom-modal{position:relative;width:100%;max-width:900px;background:var(--bg-surface);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 0 60px #00000080}.intercom-modal-close{position:absolute;top:var(--space-md);right:var(--space-md);z-index:10;width:44px;height:44px;border-radius:50%;background:#0009;border:none;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.intercom-modal-close:hover{background:#000c;transform:scale(1.1)}.intercom-modal-video video,.intercom-modal-video .webrtc-player{width:100%;height:100%;object-fit:contain}.intercom-modal-name{position:absolute;top:var(--space-md);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:#000000b3;border-radius:var(--radius-md);font-weight:600;color:var(--text-primary)}.intercom-modal-live-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:#ef4444e6;border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--text-primary)}.intercom-modal-live-badge .live-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:pulse-icon 1s infinite}.intercom-modal-controls{display:flex;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-surface)}.intercom-modal-controls .btn{flex:1;padding:var(--space-md);font-size:15px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.notification-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--accent-danger);font-size:13px;font-weight:500}.notification-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm)}.notification-card .card-title{display:flex;align-items:center;gap:var(--space-sm);font-size:16px;font-weight:600;margin-bottom:var(--space-md);color:var(--text-primary)}.notification-list{display:flex;flex-direction:column;gap:var(--space-md)}.notification-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.notification-thumbnail{width:80px;height:60px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-page);flex-shrink:0}.no-thumbnail{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.notification-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.notification-event{font-size:13px;color:var(--text-secondary)}.notification-actions{display:flex;gap:var(--space-sm);flex-shrink:0}.intercom-toast-backdrop{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:99998}.intercom-toast-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:99999;width:calc(100% - 2rem);max-width:400px}.intercom-toast-card{background:var(--bg-surface);border-radius:var(--radius-xl);border:2px solid var(--accent);box-shadow:0 0 60px #00d4aa33,0 25px 50px #00000080;overflow:hidden}.intercom-toast-topbar{height:4px;background:linear-gradient(90deg,var(--accent),var(--accent),var(--accent));background-size:200% 100%}.intercom-toast-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-bottom:1px solid var(--border)}.intercom-toast-header-left{display:flex;align-items:center;gap:var(--space-md)}.intercom-toast-icon{position:relative;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#00d4aa33,#0ea5e933);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.intercom-toast-pulse{position:absolute;top:-4px;right:-4px;width:14px;height:14px;background:var(--accent-danger);border-radius:50%;border:2px solid var(--bg-surface);animation:pulse-icon 1.5s infinite}.intercom-toast-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.intercom-toast-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.intercom-toast-video-container{position:relative;width:100%;aspect-ratio:16/9;background:#000;overflow:hidden}.intercom-toast-live-badge{position:absolute;top:var(--space-sm);left:var(--space-sm);display:flex;align-items:center;gap:6px;padding:4px 8px;background:#ef4444e6;border-radius:var(--radius-sm);font-size:11px;font-weight:600;color:var(--text-primary)}.intercom-toast-live-dot{width:6px;height:6px;background:#fff;border-radius:50%;animation:pulse-icon 1s infinite}.intercom-toast-buttons{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);padding:var(--space-md)}.intercom-toast-buttons .btn{padding:var(--space-md);font-size:15px;font-weight:600}.intercom-toast-dismiss{width:100%;padding:var(--space-md);background:transparent;border:none;border-top:1px solid var(--border);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.intercom-toast-dismiss:hover{background:var(--bg-page);color:var(--text-primary)}@media(max-width:768px){.intercom-grid{grid-template-columns:1fr;gap:var(--space-md)}.intercom-modal-overlay{padding:0}.intercom-modal{max-width:none;height:100%;border-radius:0;display:flex;flex-direction:column}.intercom-modal-video{flex:1;aspect-ratio:auto}.intercom-modal-controls{flex-direction:column;padding-bottom:calc(var(--space-md) + env(safe-area-inset-bottom))}.intercom-toast-modal{inset:auto 0 0;transform:none;width:100%;max-width:none;padding:var(--space-sm);padding-bottom:calc(var(--space-sm) + env(safe-area-inset-bottom))}.intercom-toast-card{border-radius:var(--radius-xl) var(--radius-xl) 0 0}.intercom-toast-buttons{grid-template-columns:1fr}.notification-item{flex-wrap:wrap}.notification-actions{width:100%;margin-top:var(--space-sm)}.notification-actions .btn{flex:1}}.intercom-toast-progress{position:absolute;bottom:0;left:0;height:4px;background:var(--accent-warning);border-radius:0 0 var(--radius-lg) var(--radius-lg);animation:toast-progress 30s linear forwards}@keyframes toast-progress{0%{width:100%}to{width:0%}}.intercom-toast-info{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--bg-page);font-size:12px;color:var(--text-tertiary)}.intercom-toast-badge{padding:2px 8px;background:#00d4aa26;color:var(--accent);border-radius:var(--radius-sm);font-weight:500;text-transform:uppercase;font-size:10px}.intercom-toast-mute-btn{position:absolute;bottom:var(--space-sm);right:var(--space-sm);width:36px;height:36px;border-radius:50%;background:#0009;border:none;color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.intercom-toast-mute-btn:hover{background:#000c;transform:scale(1.1)}.intercom-toast-no-camera{display:flex;align-items:center;justify-content:center;height:100%;background:var(--bg-page);color:var(--text-tertiary);font-size:14px}@media(max-width:768px){.intercom-modal-close{top:calc(var(--space-md) + env(safe-area-inset-top));right:var(--space-md);width:48px;height:48px;background:#000000b3;z-index:20}.intercom-modal-video{padding-top:env(safe-area-inset-top)}.intercom-modal-name,.intercom-modal-live-badge{top:calc(var(--space-md) + env(safe-area-inset-top))}}.intercom-cell.camera-cell{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.intercom-cell.camera-cell:hover{border-color:var(--accent);box-shadow:0 8px 32px #00d4aa26;transform:translateY(-2px)}.intercom-cell .camera-header{padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.intercom-cell .camera-name{font-size:16px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.intercom-cell .camera-status{width:10px;height:10px;border-radius:50%;flex-shrink:0}.intercom-cell .camera-status.online{background:var(--accent-success);box-shadow:0 0 8px var(--accent-success)}.intercom-cell .camera-status.offline{background:var(--text-tertiary)}.intercom-cell .btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.intercom-cell .btn-icon svg{width:18px;height:18px}.intercom-cell .btn-icon:hover{background:var(--accent);border-color:var(--accent);color:var(--bg-page);transform:scale(1.05)}.intercom-cell .btn-icon.btn-unlock:hover{background:var(--accent-success);border-color:var(--accent-success)}.intercom-cell .btn-icon:disabled{opacity:.4;cursor:not-allowed;transform:none}.intercom-cell .camera-stream,.intercom-cell .intercom-stream{position:relative;aspect-ratio:16/9;background:var(--bg-page);cursor:pointer;overflow:hidden}.intercom-cell .camera-stream img,.intercom-cell .intercom-stream img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.intercom-cell:hover .camera-stream img,.intercom-cell:hover .intercom-stream img{transform:scale(1.03)}.intercom-cell .camera-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--space-sm);color:var(--text-muted);background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.intercom-cell .camera-placeholder svg{opacity:.5;width:40px;height:40px}.intercom-cell .camera-placeholder span{font-size:13px}.intercom-cell .loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}.intercom-cell .intercom-warning-badge{position:absolute;bottom:var(--space-sm);left:var(--space-sm);display:flex;align-items:center;gap:4px;padding:4px 10px;background:#f59e0bf2;color:var(--bg-page);font-size:11px;font-weight:600;border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.intercom-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-lg)}@media(max-width:768px){.intercom-grid{grid-template-columns:1fr;gap:var(--space-md)}.intercom-cell .camera-header{padding:var(--space-sm) var(--space-md)}.intercom-cell .camera-name{font-size:15px}.intercom-cell .btn-icon{width:32px;height:32px}.intercom-cell .btn-icon svg{width:16px;height:16px}}.intercom-cell .flex{display:flex}.intercom-cell .items-center{align-items:center}.intercom-cell .gap-2{gap:var(--space-sm)}.page-subtitle .device-count,.intercoms-count{display:inline-flex;align-items:center;padding:4px 12px;background:linear-gradient(135deg,#00d4aa26,#00d4aa14);border:1px solid rgba(0,212,170,.3);border-radius:20px;font-size:13px;font-weight:600;color:var(--accent);margin-left:var(--space-sm)}.intercom-card-v2{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base);display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.intercom-card-v2:hover{border-color:#00d4aa80;transform:translateY(-3px);box-shadow:0 12px 40px #0006,0 0 0 1px #00d4aa1a,0 0 30px #00d4aa1a}.intercom-card-image{position:relative;aspect-ratio:16/9;background:var(--bg-surface);cursor:pointer;overflow:hidden}.intercom-card-status{position:absolute;top:var(--space-sm);left:var(--space-sm);display:flex;align-items:center;gap:6px;padding:6px 12px;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;z-index:2}.intercom-card-status .status-dot.online{background:var(--accent-success);box-shadow:0 0 8px var(--accent-success);animation:pulse-live 2s infinite}@keyframes pulse-live{0%,to{opacity:1;box-shadow:0 0 8px var(--accent-success)}50%{opacity:.7;box-shadow:0 0 12px var(--accent-success)}}.intercom-card-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);color:var(--text-tertiary)}.intercom-card-placeholder svg{width:48px;height:48px;opacity:.4}.intercom-card-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast)}.intercom-card-v2:hover .intercom-card-overlay{opacity:1}.intercom-card-overlay .play-btn{width:60px;height:60px;border-radius:50%;background:#00d4aae6;border:none;color:var(--bg-surface);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 20px #00d4aa66}.intercom-card-overlay .play-btn:hover{transform:scale(1.1);background:var(--accent)}.intercom-card-name{padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border-top:1px solid var(--border);font-size:15px;font-weight:600;color:var(--text-primary)}.intercom-card-footer,.intercom-card-actions{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-surface);border-top:1px solid var(--border);box-shadow:var(--shadow-sm)}.intercom-card-footer .btn,.intercom-card-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px var(--space-md);font-size:13px;font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-fast)}.intercom-card-footer .btn-view,.intercom-card-actions .btn:first-child{background:#00d4aa1a;border:1px solid rgba(0,212,170,.3);color:var(--accent)}.intercom-card-footer .btn-view:hover,.intercom-card-actions .btn:first-child:hover{background:#00d4aa33;border-color:var(--accent)}.intercom-card-footer .btn-unlock,.intercom-card-actions .btn:last-child{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:var(--accent-success)}.intercom-card-footer .btn-unlock:hover,.intercom-card-actions .btn:last-child:hover{background:#22c55e33;border-color:var(--accent-success)}.intercom-warning-badge{position:absolute;bottom:var(--space-sm);right:var(--space-sm);display:flex;align-items:center;gap:6px;padding:6px 12px;background:#f59e0bf2;color:var(--bg-page);font-size:11px;font-weight:700;border-radius:20px;animation:pulse-warning 2s infinite;z-index:2}.intercoms-page .grid-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-lg);gap:var(--space-md)}.notification-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;background:var(--accent-danger);color:var(--bg-surface);font-size:12px;font-weight:700;border-radius:11px}.notification-card{margin-bottom:var(--space-lg);background:linear-gradient(135deg,#f59e0b1a,#f59e0b0d);border:1px solid rgba(245,158,11,.3)}.notification-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--border)}.notification-item:last-child{border-bottom:none}.notification-thumbnail{width:80px;height:45px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-page);flex-shrink:0}.notification-thumbnail img{width:100%;height:100%;object-fit:cover}.notification-info{flex:1;display:flex;flex-direction:column;gap:2px}.notification-name{font-weight:600;color:var(--text-primary)}.notification-time{font-size:12px;color:var(--text-tertiary)}.notification-event{font-size:13px;color:var(--accent-warning)}.notification-actions{display:flex;gap:var(--space-sm)}@media(max-width:768px){.intercom-card-footer .btn,.intercom-card-actions .btn{padding:10px var(--space-sm);font-size:12px}}.intercom-modal-overlay{position:fixed;inset:0;background:#000000eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-lg)}.intercom-modal{position:relative;width:100%;max-width:900px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 0 80px #0009,0 0 0 1px #ffffff0d}.intercom-modal-close{position:absolute;top:var(--space-md);right:var(--space-md);z-index:10;width:44px;height:44px;border-radius:50%;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.intercom-modal-close:hover{background:#ef4444cc;border-color:#ef444480;transform:scale(1.1)}.intercom-modal-name{position:absolute;top:var(--space-md);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-lg);background:linear-gradient(135deg,#000c,#0009);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:24px;font-size:15px;font-weight:600;color:var(--text-primary);z-index:5}.intercom-modal-name svg{color:var(--accent)}.intercom-modal-live-badge{position:absolute;top:var(--space-md);left:var(--space-md);display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:linear-gradient(135deg,#22c55ee6,#22c55eb3);border:1px solid rgba(34,197,94,.5);border-radius:20px;font-size:12px;font-weight:700;color:var(--text-primary);letter-spacing:.5px;z-index:5;box-shadow:0 4px 12px #22c55e4d}.intercom-modal-live-badge .live-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:pulse-live-dot 1.5s infinite}@keyframes pulse-live-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.intercom-modal-video{position:relative;width:100%;aspect-ratio:16/9;background:#000}.intercom-modal-controls{display:flex;gap:var(--space-md);padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border-top:1px solid var(--border)}.intercom-modal-controls .btn{flex:1;padding:14px var(--space-lg);font-size:15px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.intercom-modal-controls .btn-primary,.intercom-modal-controls .btn:first-child{background:var(--accent);border:none;color:var(--bg-primary)}.intercom-modal-controls .btn-primary:hover,.intercom-modal-controls .btn:first-child:hover{background:#00b894;box-shadow:0 4px 20px #00d4aa66;transform:translateY(-2px)}.intercom-modal-controls .btn-unlock,.intercom-modal-controls .btn:nth-child(2){background:var(--accent);border:none;color:var(--bg-page)}.intercom-modal-controls .btn-unlock:hover,.intercom-modal-controls .btn:nth-child(2):hover{background:#00b894;box-shadow:0 4px 20px #00d4aa66;transform:translateY(-2px)}.intercom-modal-controls .btn-talk,.intercom-modal-controls .btn-ptt{background:linear-gradient(135deg,#3b82f633,#3b82f61a);border:2px solid rgba(59,130,246,.4);color:#60a5fa;position:relative;overflow:hidden}.intercom-modal-controls .btn-talk:hover,.intercom-modal-controls .btn-ptt:hover{background:linear-gradient(135deg,#3b82f64d,#3b82f633);border-color:#60a5fa;box-shadow:0 4px 20px #3b82f64d;transform:translateY(-2px)}.intercom-modal-controls .btn-talk.active,.intercom-modal-controls .btn-ptt.active,.intercom-modal-controls .btn-talk:active,.intercom-modal-controls .btn-ptt:active{background:linear-gradient(135deg,#3b82f6e6,#3b82f6b3);border-color:#60a5fa;color:var(--text-primary);box-shadow:0 0 30px #3b82f680,inset 0 0 20px #ffffff1a;transform:scale(.98)}.btn-talk.active svg,.btn-ptt.active svg{animation:pulse-mic .5s infinite}@keyframes pulse-mic{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.btn-talk.active:before,.btn-ptt.active:before{content:"";position:absolute;top:8px;right:8px;width:10px;height:10px;background:#ef4444;border-radius:50%;animation:pulse-rec 1s infinite}@keyframes pulse-rec{0%,to{opacity:1}50%{opacity:.4}}.intercom-modal-controls.three-buttons{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-md)}@media(max-width:600px){.intercom-modal-controls.three-buttons{grid-template-columns:1fr}}@media(max-width:768px){.intercom-modal-overlay{padding:var(--space-sm)}.intercom-modal{max-width:100%;border-radius:var(--radius-lg)}.intercom-modal-controls{flex-direction:column;padding:var(--space-md);gap:var(--space-sm)}.intercom-modal-controls .btn{padding:12px var(--space-md)}.intercom-modal-name{font-size:14px;padding:8px var(--space-md)}}.intercom-card-v2{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.intercom-card-v2:hover{border-color:var(--accent);box-shadow:0 8px 32px #00d4aa33;transform:translateY(-2px)}.intercom-card-image{position:relative;aspect-ratio:16/9;background:var(--bg-page);cursor:pointer;overflow:hidden}.intercom-card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-base)}.intercom-card-v2:hover .intercom-card-image img{transform:scale(1.05)}.intercom-card-status{position:absolute;top:var(--space-sm);left:var(--space-sm);display:flex;align-items:center;gap:6px;padding:4px 10px;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-md);z-index:2}.intercom-card-status .status-dot{width:8px;height:8px;border-radius:50%}.intercom-card-status .status-dot.online{background:var(--accent-success);box-shadow:0 0 8px var(--accent-success);animation:pulse-dot 2s infinite}.intercom-card-status .status-dot.offline{background:var(--text-tertiary)}.intercom-card-status .status-text{font-size:11px;font-weight:700;color:var(--accent-success);letter-spacing:.5px}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}.intercom-card-overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--space-xl) var(--space-md) var(--space-md);background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.4) 60%,transparent 100%);z-index:1}.intercom-card-name{font-size:18px;font-weight:600;color:var(--text-primary);text-shadow:0 2px 4px rgba(0,0,0,.5)}.intercom-card-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);color:var(--text-tertiary);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%)}.intercom-card-placeholder svg{opacity:.4}.intercom-card-placeholder span{font-size:13px}.intercom-card-actions{display:flex;border-top:1px solid var(--border)}.intercom-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-surface);border:none;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.intercom-action-btn:first-child{border-right:1px solid var(--border)}.intercom-action-btn:hover{background:var(--bg-page);color:var(--text-primary)}.intercom-action-btn.view:hover{color:var(--accent)}.intercom-action-btn.unlock:hover{background:#00d4aa1a;color:var(--accent)}.intercom-action-btn:disabled{opacity:.4;cursor:not-allowed}.intercom-action-btn:disabled:hover{background:var(--bg-surface);color:var(--text-secondary)}.intercom-card-warning{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm);background:#f59e0b26;border-top:1px solid rgba(245,158,11,.3);color:var(--accent-warning);font-size:12px;font-weight:500}@media(max-width:768px){.intercom-card-name{font-size:16px}.intercom-action-btn{padding:var(--space-sm) var(--space-md);font-size:13px}.intercom-action-btn span{display:none}.intercom-action-btn svg{width:20px;height:20px}}.access-grid-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);gap:var(--space-md);flex-wrap:wrap}.access-filter-group{display:flex;align-items:center;gap:var(--space-sm)}.access-filter-group select,.access-filter-group .form-select{min-width:150px}.access-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.lockdown-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.lockdown-bar.active{background:#ef44441a;border-color:#ef44444d}.lockdown-status{display:flex;align-items:center;gap:var(--space-sm);font-weight:500}.lockdown-bar .lockdown-status svg{color:var(--accent-success)}.lockdown-bar.active .lockdown-status svg{color:var(--accent-danger)}.lockdown-bar.active .lockdown-status span{color:var(--accent-danger);font-weight:600}.readers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-md)}.reader-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);box-shadow:var(--shadow-sm)}.reader-card:hover{border-color:var(--accent)}.reader-card.held-open{border-left:4px solid var(--accent-warning);background:linear-gradient(90deg,rgba(254,243,199,.1) 0%,transparent 30%)}.reader-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.reader-mode{display:flex;align-items:center;gap:6px}.reader-status-held{background-color:#f59e0b33;border:1px solid var(--accent-warning);padding:2px 8px;border-radius:var(--radius-sm);font-weight:600;color:var(--accent-warning);font-size:11px;animation:pulse-warning 2s infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.6}}.reader-status-forced{color:var(--accent-danger);font-size:12px}.reader-info{margin-bottom:var(--space-md)}.reader-info h4{margin:0 0 var(--space-xs) 0;font-size:15px;font-weight:600}.reader-info p{margin:0;font-size:12px;color:var(--text-tertiary)}.reader-actions{display:flex;gap:6px;margin-top:var(--space-md)}.reader-actions .btn{flex:1;padding:6px 8px;font-size:12px;white-space:nowrap}.events-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);flex-wrap:wrap;gap:var(--space-md)}.events-count{font-size:12px;color:var(--text-tertiary)}.events-actions{display:flex;align-items:center;gap:var(--space-sm)}.events-table th{text-align:left;padding:var(--space-sm);border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-secondary)}.events-table td{padding:var(--space-sm);border-bottom:1px solid var(--border);font-size:14px}.events-table tr:hover td{background:var(--bg-page)}.events-table .time-cell{font-size:12px;color:var(--text-tertiary)}.lockdown-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.lockdown-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);max-width:400px;width:90%;box-shadow:var(--shadow-sm)}.lockdown-modal-header{text-align:center;margin-bottom:var(--space-lg)}.lockdown-modal-body{margin-bottom:var(--space-lg)}.lockdown-modal-body.confirm-step{text-align:center}.lockdown-warning{font-size:18px;font-weight:700;color:var(--accent-danger)}.lockdown-modal-actions{display:flex;gap:var(--space-md)}.lockdown-modal-actions .btn{flex:1}@media(max-width:768px){.access-grid-controls{flex-direction:column;align-items:stretch}.access-filter-group{width:100%}.access-filter-group select{flex:1;min-width:0}.access-tabs{flex-wrap:wrap}.access-tabs .btn{flex:1;min-width:100px;justify-content:center}.readers-grid{grid-template-columns:1fr}.events-header{flex-direction:column;align-items:flex-start}.lockdown-modal-actions{flex-direction:column}}.reader-mode.unlocked,.reader-mode[style*="rgb(34, 197, 94)"],.reader-mode[style*="#22c55e"]{color:var(--accent-success)!important}.reader-mode.locked,.reader-mode.card-only,.reader-mode[style*="rgb(14, 165, 233)"],.reader-mode[style*="#0ea5e9"]{color:var(--accent)!important}.reader-mode.disabled,.reader-mode[style*="rgb(107, 114, 128)"],.reader-mode[style*="#6b7280"]{color:var(--text-tertiary)!important}.reader-header svg{flex-shrink:0}.reader-mode svg{color:inherit}.readers-grid .card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.readers-grid .card:hover{border-color:#00d4aa4d}.connection-status{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-tertiary)}.connection-status:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--text-tertiary)}.connection-status.online:before{background:var(--accent-success);box-shadow:0 0 8px var(--accent-success)}.connection-status.offline:before{background:var(--accent-danger)}.lockdown-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-xl);margin-bottom:var(--space-lg)}.lockdown-bar.active{background:linear-gradient(135deg,#ef444426,#ef44440d);border-color:#ef444466;animation:pulse-danger-border 2s infinite}@keyframes pulse-danger-border{0%,to{border-color:#ef444466}50%{border-color:#ef4444cc}}.lockdown-status{display:flex;align-items:center;gap:var(--space-sm);font-size:16px;font-weight:600}.access-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg)}.access-tabs .btn{display:flex;align-items:center;gap:var(--space-sm);padding:10px 18px;font-size:14px;font-weight:500;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.access-tabs .btn.btn-primary{background:var(--accent);color:var(--bg-primary);box-shadow:0 4px 12px #00d4aa4d}.access-tabs .btn.btn-secondary{background:var(--bg-page);border:1px solid var(--border)}.access-tabs .btn.btn-secondary:hover{background:var(--bg-surface);border-color:var(--accent);box-shadow:var(--shadow-sm)}.readers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg)}.reader-card,.readers-grid .card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:0;overflow:hidden;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.reader-card:hover,.readers-grid .card:hover{border-color:#00d4aa66;transform:translateY(-2px);box-shadow:0 8px 32px #0000004d,0 0 0 1px #00d4aa1a}.reader-card.held-open{border-color:#f59e0b66;box-shadow:0 0 0 1px #f59e0b1a}.reader-card.held-open:hover{border-color:#f59e0b99;box-shadow:0 8px 32px #0000004d,0 0 0 1px #f59e0b33}.reader-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border-bottom:1px solid var(--border);margin-bottom:0}.reader-mode{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.reader-mode svg{width:18px;height:18px}.reader-status-held{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);border:1px solid rgba(245,158,11,.4);border-radius:20px;font-size:10px;font-weight:700;color:var(--accent-warning);letter-spacing:.5px;animation:pulse-warning 2s infinite}.reader-status-forced{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:linear-gradient(135deg,#ef444433,#ef44441a);border:1px solid rgba(239,68,68,.4);border-radius:20px;font-size:10px;font-weight:700;color:var(--accent-danger);letter-spacing:.5px}.reader-info{padding:var(--space-md) var(--space-lg)}.reader-info h4{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text-primary)}.reader-info p{margin:0;font-size:13px;color:var(--text-tertiary)}.reader-actions{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-surface);border-top:1px solid var(--border);box-shadow:var(--shadow-sm)}.reader-actions .btn{flex:1;padding:10px 12px;font-size:13px;font-weight:600;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;gap:6px}.reader-actions .btn-primary{background:var(--accent);color:var(--bg-primary)}.reader-actions .btn-primary:hover{background:#00b894}.reader-actions .btn-warning{background:#f59e0b26;border:1px solid rgba(245,158,11,.3);color:var(--accent-warning)}.reader-actions .btn-warning:hover{background:#f59e0b40;border-color:var(--accent-warning)}.reader-actions .btn-secondary{background:var(--bg-page);border:1px solid var(--border);color:var(--text-secondary)}.reader-actions .btn-secondary:hover{background:var(--bg-surface);border-color:var(--accent);color:var(--text-primary);box-shadow:var(--shadow-sm)}.events-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border-bottom:1px solid var(--border);margin:0}.events-title{display:flex;align-items:center;gap:var(--space-sm);margin:0;font-size:18px;font-weight:600}.events-title svg{color:var(--accent)}.events-count{display:inline-flex;align-items:center;padding:4px 10px;background:linear-gradient(135deg,#00d4aa26,#00d4aa14);border:1px solid rgba(0,212,170,.3);border-radius:20px;font-size:12px;font-weight:600;color:var(--accent);margin-left:var(--space-sm)}.events-table-wrapper{overflow-x:auto}.events-table{width:100%;border-collapse:collapse}.events-table th{text-align:left;padding:var(--space-md);background:var(--bg-page);border-bottom:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.events-table td{padding:var(--space-md);border-bottom:1px solid var(--border);font-size:14px;color:var(--text-primary)}.events-table tbody tr{transition:background var(--transition-fast)}.events-table tbody tr:hover{background:#00d4aa0d}.events-table tbody tr:nth-child(2n){background:#ffffff05}.events-table tbody tr:nth-child(2n):hover{background:#00d4aa0d}.events-table .time-cell{font-size:13px;color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.access-grid-controls{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.access-filter-group{display:flex;align-items:center;gap:var(--space-md)}.access-filter-group .form-select{padding:10px 36px 10px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;min-width:160px;cursor:pointer;transition:all var(--transition-fast)}.access-filter-group .form-select:hover,.access-filter-group .form-select:focus{border-color:var(--accent)}@media(max-width:768px){.readers-grid{grid-template-columns:1fr}.reader-actions{flex-wrap:wrap}.reader-actions .btn{min-width:calc(50% - var(--space-xs))}.events-table th,.events-table td{padding:var(--space-sm);font-size:13px}}@media(max-width:768px){.events-table{display:block}.events-table thead{display:none}.events-table tbody{display:flex;flex-direction:column;gap:var(--space-sm)}.events-table tbody tr{display:flex;flex-direction:column;padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);gap:var(--space-xs);box-shadow:var(--shadow-sm)}.events-table tbody tr:nth-child(2n){background:var(--bg-surface)}.events-table tbody tr:hover{border-color:var(--accent)}.events-table td{display:flex;padding:4px 0;border-bottom:none;font-size:13px}.events-table td:before{content:attr(data-label);font-weight:600;color:var(--text-tertiary);min-width:80px;font-size:11px;text-transform:uppercase}.events-table .time-cell{font-size:12px;color:var(--accent);font-weight:500}.events-header{flex-direction:column;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md)}.events-count{font-size:11px;padding:3px 8px}}@media(max-width:480px){.access-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-xs)}.access-tabs .btn{padding:10px 8px;font-size:12px;justify-content:center}.access-tabs .btn svg{display:none}.lockdown-bar{flex-direction:column;gap:var(--space-md);text-align:center}.reader-actions{flex-direction:column}.reader-actions .btn{width:100%}}.coming-soon-hint{font-size:14px;margin-top:8px}.access-tabs .access-filter-group{margin-left:auto}.push-settings{display:flex;flex-direction:column;gap:var(--space-lg);max-width:100%}.push-settings>.setting-row:first-child{background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border:1px solid var(--border);border-left:4px solid var(--accent);padding:var(--space-lg)}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);gap:var(--space-md);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.setting-row:hover{border-color:#00d4aa4d}.setting-info{display:flex;align-items:center;gap:var(--space-md);flex:1}.setting-icon{width:44px;height:44px;border-radius:var(--radius-md);background:#00d4aa1a;display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.setting-label{display:block;font-weight:600;font-size:15px;color:var(--text-primary)}.setting-hint{display:block;font-size:13px;color:var(--text-secondary);margin-top:4px}.setting-controls{display:flex;align-items:center;gap:var(--space-md);flex-shrink:0}.subsection-title{font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--space-md) 0}.notification-types{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.notification-types .setting-row{padding:var(--space-md);background:var(--bg-surface);border-radius:var(--radius-md);margin-bottom:var(--space-sm);border:1px solid transparent;box-shadow:var(--shadow-sm)}.notification-types .setting-row:last-child{margin-bottom:0}.notification-types .setting-row:hover{background:var(--bg-page);border-color:var(--border)}.registered-devices{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.devices-list{display:flex;flex-direction:column;gap:var(--space-sm)}.device-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.device-item:hover{border-color:var(--border-hover);background:var(--bg-page)}.device-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--bg-page);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.device-info{display:flex;flex-direction:column;flex:1;min-width:0}.device-name{font-weight:500;color:var(--text-primary);font-size:14px}.device-meta{font-size:12px;color:var(--text-tertiary);margin-top:2px}.device-item .btn-danger-subtle,.device-item .btn-icon{margin-left:auto;width:36px;height:36px;background:transparent;color:var(--text-muted);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.device-item .btn-danger-subtle:hover,.device-item .btn-icon:hover{background:#ef444426;color:var(--accent-danger)}.info-banner{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);font-size:14px}.info-banner svg{flex-shrink:0;margin-top:2px}.info-banner.warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--accent-warning)}.info-banner.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--accent-danger)}.info-banner.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:var(--accent-success)}.info-banner.info{background:#0ea5e91a;border:1px solid rgba(14,165,233,.3);color:var(--accent)}.info-banner strong{display:block;margin-bottom:var(--space-xs);color:inherit}.info-banner p{margin:0;opacity:.9}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--bg-page);border:1px solid var(--border);border-radius:26px;transition:all var(--transition-fast)}.toggle-slider:before{content:"";position:absolute;height:20px;width:20px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:all var(--transition-fast);box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background:var(--accent);border-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.text-success{color:var(--accent-success)}.text-error{color:var(--accent-danger)}.text-warning{color:var(--accent-warning)}@media(max-width:640px){.setting-row{flex-direction:column;align-items:flex-start;padding:var(--space-md)}.setting-controls{width:100%;justify-content:space-between;margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border)}.setting-info{width:100%}.notification-types,.registered-devices{padding:var(--space-md)}}.platform-tabs{display:flex;gap:4px;margin-bottom:var(--space-lg);border-bottom:1px solid var(--border)}.platform-tab{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast);font-size:14px}.platform-tab:hover{color:var(--text-primary);background:#ffffff0d}.platform-tab-count{background:#0ea5e933;color:var(--accent);padding:2px 8px;border-radius:var(--radius-lg);font-size:12px}.platform-toolbar{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.platform-search{flex:1;min-width:200px;position:relative}.platform-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);width:16px;height:16px}.platform-search input{width:100%;padding:10px 12px 10px 40px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px}.platform-search input:focus{outline:none;border-color:var(--accent)}.platform-filter select{padding:10px 36px 10px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;cursor:pointer}.platform-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-md);overflow:hidden;box-shadow:var(--shadow-sm)}.platform-card-header{display:flex;align-items:center;padding:var(--space-md);cursor:pointer;transition:background var(--transition-fast);gap:var(--space-md)}.platform-card-header:hover{background:#ffffff0d}.platform-card-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.platform-card-icon.org{background:#f59e0b33;color:var(--accent-warning)}.platform-card-icon.site{background:#0ea5e933;color:var(--accent)}.platform-card-icon.user{background:#6b72804d;color:var(--text-secondary)}.platform-card-info{flex:1;min-width:0}.platform-card-title{font-weight:600;font-size:15px;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.platform-card-subtitle{font-size:13px;color:var(--text-tertiary);margin:2px 0 0}.platform-card-meta{display:flex;align-items:center;gap:var(--space-sm);margin-top:4px;font-size:12px;color:var(--text-tertiary)}.platform-card-actions{display:flex;gap:4px;flex-shrink:0}.platform-card-actions button{padding:var(--space-sm);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.platform-card-actions button:hover{background:#ffffff1a;color:var(--text-primary)}.platform-card-actions button.delete:hover{background:#ef444433;color:var(--accent-danger)}.platform-card-body{border-top:1px solid var(--border);padding:var(--space-md);background:#0003}.platform-site-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-md)}.platform-site-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);transition:border-color var(--transition-fast);box-shadow:var(--shadow-sm)}.platform-site-card:hover{border-color:var(--accent);box-shadow:0 4px 20px #0000004d}.platform-site-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-md)}.platform-site-title{display:flex;align-items:center;gap:var(--space-md)}.platform-card-icon.site{width:48px;height:48px;border-radius:var(--radius-md);background:#00d4aa26;color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.platform-site-meta{display:flex;align-items:center;gap:var(--space-sm);font-size:13px;color:var(--text-secondary);margin-bottom:var(--space-sm)}.platform-site-meta svg{color:var(--accent)}.platform-site-notes{font-size:13px;color:var(--text-tertiary);margin:0 0 var(--space-md) 0;padding:var(--space-sm);background:var(--bg-page);border-radius:var(--radius-sm)}.platform-site-footer{display:flex;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--border)}.platform-site-footer .btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.platform-site-footer .btn-icon:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--accent);box-shadow:var(--shadow-sm)}.platform-site-footer .btn-icon.delete:hover{background:#ef44441a;color:var(--accent-danger);border-color:var(--accent-danger)}.platform-user-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-md);overflow:hidden;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.platform-user-card:hover{border-color:#00d4aa4d}.platform-user-header{display:flex;align-items:center;padding:var(--space-lg);gap:var(--space-md);flex-wrap:wrap}.platform-user-info{flex:1;min-width:200px}.platform-user-name{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;margin-bottom:4px}.platform-user-name h3{font-weight:600;font-size:15px;color:var(--text-primary);margin:0}.platform-user-email{font-size:13px;color:var(--text-tertiary);margin:0}.platform-user-meta{display:flex;align-items:center;gap:var(--space-md);margin-top:6px;font-size:12px;color:var(--text-tertiary);flex-wrap:wrap}.platform-user-body{border-top:1px solid var(--border);padding:var(--space-lg);background:var(--bg-surface);display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.platform-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-lg);font-size:11px;font-weight:500}.platform-badge.admin{background:#f59e0b33;color:var(--accent-warning)}.platform-badge.active{background:#22c55e33;color:var(--accent-success)}.platform-badge.pending{background:#f59e0b33;color:var(--accent-warning)}.platform-badge.suspended{background:#ef444433;color:var(--accent-danger)}.platform-badge.role{background:#0ea5e933;color:var(--accent)}.platform-empty{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--text-tertiary)}.platform-empty-icon{width:64px;height:64px;margin:0 auto var(--space-md);background:var(--bg-page);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center}.platform-empty h3{font-size:16px;font-weight:500;color:var(--text-primary);margin:0 0 var(--space-sm) 0}.platform-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-md);z-index:1000}.platform-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.platform-modal.delete{border-color:#ef44444d}.platform-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border)}.platform-modal-header h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:10px}.platform-modal-header button{padding:4px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm)}.platform-modal-header button:hover{background:var(--bg-page);color:var(--text-primary)}.platform-modal-body{padding:var(--space-lg)}.platform-modal-footer{display:flex;gap:var(--space-md);padding:var(--space-lg);border-top:1px solid var(--border)}.platform-modal-footer button{flex:1}.platform-form-group{margin-bottom:var(--space-md)}.platform-form-group label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.platform-form-group input,.platform-form-group select,.platform-form-group textarea{width:100%;padding:10px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px}.platform-form-group input:focus,.platform-form-group select:focus,.platform-form-group textarea:focus{outline:none;border-color:var(--accent)}.platform-form-group textarea{resize:none;min-height:80px}.platform-form-hint{font-size:11px;color:var(--text-tertiary);margin-top:4px}.platform-role-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}.platform-role-option{padding:var(--space-md);background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:center;transition:all var(--transition-fast)}.platform-role-option:hover{border-color:var(--text-tertiary)}.platform-role-option.selected{border-color:var(--accent);background:#0ea5e91a}.platform-role-option.selected.admin{border-color:var(--accent-warning);background:#f59e0b1a}.platform-nested-sites{border-top:1px solid var(--border);background:#0003}.platform-nested-site{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-md) var(--space-md) 56px;border-bottom:1px solid var(--border)}.platform-nested-site:last-child{border-bottom:none}.platform-nested-site-icon{width:28px;height:28px;border-radius:var(--radius-sm);background:#0ea5e933;color:var(--accent);display:flex;align-items:center;justify-content:center}.platform-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl)}.platform-spinner{width:32px;height:32px;border:2px solid rgba(14,165,233,.3);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.platform-user-body{grid-template-columns:1fr}.platform-tabs{gap:2px}.platform-tab{padding:var(--space-md);justify-content:center}}.platform-tabs{display:flex;gap:4px;margin-bottom:var(--space-lg);padding:0 var(--space-md);background:var(--bg-surface);border-bottom:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:var(--shadow-sm)}.platform-tab{display:flex;align-items:center;gap:var(--space-sm);padding:14px 20px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast);font-size:14px;font-weight:500;margin-bottom:-1px}.platform-tab:hover{color:var(--text-primary);background:#ffffff08}.platform-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.platform-tab svg{width:18px;height:18px;opacity:.8}.platform-tab.active svg{opacity:1}.platform-tab-count{background:#00d4aa26;color:var(--accent);padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.platform-tab.active .platform-tab-count{background:#00d4aa40}.icon-danger{color:var(--accent-danger)}.icon-success{color:var(--accent-success)}.icon-warning{color:var(--accent-warning)}.icon-muted{color:var(--text-tertiary)}.icon-primary{color:var(--accent)}.btn-icon-sm{padding:4px;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-approve{background:#22c55e33;border:none;padding:6px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-approve:hover{background:#22c55e4d}.btn-approve svg{color:var(--accent-success)}.btn-deny{background:#ef444433;border:none;padding:6px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-deny:hover{background:#ef44444d}.btn-deny svg{color:var(--accent-danger)}.user-meta{font-size:11px;color:var(--text-tertiary);margin-top:4px;display:flex;align-items:center;gap:4px}.checkbox-row{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.platform-admin-label{display:flex;align-items:center;gap:8px}.platform-admin-label.active{color:var(--accent-warning)}.platform-admin-label.inactive{color:var(--text-secondary)}.gap-sm{gap:var(--space-sm)}.gap-xs{gap:4px}@media(max-width:768px){.platform-admin-page h1,.page-header h1{font-size:20px;word-break:normal}.platform-tab .tab-label{display:inline}}@media(min-width:769px){.platform-more-wrapper{display:none}.platform-tab.overflow-tab{display:flex}}@media(max-width:768px){.platform-tab.overflow-tab{display:none}.platform-more-wrapper{display:block;position:relative}.platform-more-btn .tab-label{display:none}.platform-more-btn svg.rotated{transform:rotate(180deg)}.platform-more-btn svg:last-child{transition:transform var(--transition-fast)}}.platform-more-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0009;z-index:9999;overflow:hidden}.platform-more-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:12px 16px;background:transparent;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all var(--transition-fast);text-align:left}.platform-more-item:hover{background:var(--bg-page);color:var(--text-primary)}.platform-more-item.active{background:#00d4aa1a;color:var(--accent)}.platform-more-item .platform-tab-count{margin-left:auto}.platform-tabs{overflow:visible!important;position:relative;z-index:50}@media(max-width:768px){.platform-more-btn{padding:10px 14px}.platform-more-btn svg:last-child{display:none}.platform-tabs{gap:2px}}.admin-tabs{display:flex;gap:4px;padding:0 var(--space-md);margin-bottom:var(--space-lg);background:var(--bg-surface);border-bottom:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-sm)}.admin-tab{display:flex;align-items:center;gap:var(--space-sm);padding:14px 20px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast);font-size:14px;font-weight:500;white-space:nowrap;margin-bottom:-1px}.admin-tab:hover{color:var(--text-primary);background:#ffffff08}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-tab svg{width:18px;height:18px;opacity:.8}.admin-tab.active svg{opacity:1}.admin-tab-content{min-height:400px}.tab-panel{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.collapsible-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-md);overflow:hidden;box-shadow:var(--shadow-sm)}.collapsible-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.collapsible-header:hover{background:var(--bg-page)}.collapsible-header.expanded{background:var(--bg-surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}.collapsible-header-content{display:flex;align-items:center;gap:var(--space-md)}.collapsible-header-content svg{width:20px;height:20px;color:var(--accent)}.collapsible-header-title{font-size:15px;font-weight:600;color:var(--text-primary)}.collapsible-header-count{font-size:12px;padding:2px 8px;background:#00d4aa26;color:var(--accent);border-radius:var(--radius-md);font-weight:500}.collapsible-body{padding:var(--space-lg);background:var(--bg-surface)}.current-site-badge{display:inline-flex;align-items:center;padding:4px 12px;background:#00d4aa26;color:var(--accent);border-radius:var(--radius-md);font-size:13px;font-weight:500;margin-left:var(--space-sm)}.integration-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm)}.integration-card:hover{border-color:var(--accent)}.integration-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.integration-card-title{display:flex;align-items:center;gap:var(--space-sm);font-size:16px;font-weight:600;color:var(--text-primary)}.integration-card-status{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500}.integration-card-status.connected{color:var(--accent-success)}.integration-card-status.disconnected{color:var(--text-tertiary)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.form-section{margin-bottom:var(--space-xl)}.form-section-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border)}.company-name-input{font-size:16px;font-weight:500}.address-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.address-grid .full-width{grid-column:span 2}.intercom-config-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm)}.intercom-config-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.intercom-config-title{font-weight:600;color:var(--text-primary)}.vms-system-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm)}.vms-system-card:hover{border-color:var(--accent)}.vms-system-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.vms-system-name{display:flex;align-items:center;gap:var(--space-sm);font-size:16px;font-weight:600}.vms-platform-badge{font-size:11px;padding:2px 8px;background:#0ea5e926;color:var(--accent);border-radius:var(--radius-sm);text-transform:uppercase;font-weight:600}.btn-test{display:inline-flex;align-items:center;gap:var(--space-sm)}.btn-test.testing{opacity:.7;pointer-events:none}.btn-test.success{background:var(--accent-success);color:var(--text-primary)}.btn-test.error{background:var(--accent-danger);color:var(--text-primary)}.add-system-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-md);background:transparent;border:2px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.add-system-btn:hover{border-color:var(--accent);color:var(--accent);background:#00d4aa0d}.flex-center{display:flex;align-items:center}.gap-12{gap:12px}.ml-12{margin-left:12px}@media(max-width:768px){.admin-tabs{padding:0 var(--space-sm)}.admin-tab{padding:12px 14px;font-size:13px}.collapsible-header{padding:var(--space-sm) var(--space-md)}.collapsible-body{padding:var(--space-md)}.address-grid{grid-template-columns:1fr}.address-grid .full-width{grid-column:span 1}}.admin-tabs{display:flex;gap:4px;padding:4px;margin-bottom:var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-sm)}.admin-tab{display:flex;align-items:center;gap:var(--space-sm);padding:12px 24px;background:transparent;border:none;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:14px;font-weight:500;white-space:nowrap}.admin-tab:hover{color:var(--text-primary);background:#ffffff0d}.admin-tab.active{color:var(--accent);background:#00d4aa1a;box-shadow:0 0 0 1px #00d4aa4d}.admin-tab svg{width:18px;height:18px}.admin-tab.active svg{color:var(--accent)}.collapsible-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);margin-bottom:var(--space-lg);overflow:hidden;transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.collapsible-section:hover{border-color:#00d4aa4d}.collapsible-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.collapsible-header:hover{background:#00d4aa0d}.collapsible-header.expanded{background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border-bottom:1px solid var(--border)}.collapsible-header-content svg:first-child{color:var(--accent)}.collapsible-header-title{font-size:16px;font-weight:600}.collapsible-header>svg{color:var(--text-tertiary);transition:transform var(--transition-fast)}.collapsible-header.expanded>svg{transform:rotate(90deg);color:var(--accent)}.collapsible-body{padding:var(--space-xl);background:var(--bg-surface)}.integration-card,.vms-system-card,.intercom-config-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-lg);margin-bottom:var(--space-md);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.integration-card:hover,.vms-system-card:hover,.intercom-config-card:hover{border-color:#00d4aa66;box-shadow:0 4px 20px #0003}.integration-card[data-type=vms],.integration-card.vms-type{border-left:4px solid var(--accent)}.integration-card[data-type=access],.integration-card.access-type{border-left:4px solid var(--accent-purple)}.integration-card[data-type=ai],.integration-card.ai-type{border-left:4px solid var(--accent-warning)}.section-category-title{display:flex;align-items:center;gap:var(--space-sm);font-size:14px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin:var(--space-xl) 0 var(--space-md) 0}.section-category-title svg{width:18px;height:18px;color:var(--text-tertiary)}.admin-tab-content .card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm)}.admin-tab-content .card:hover{border-color:#00d4aa33}.admin-tab-content .card-title{display:flex;align-items:center;gap:var(--space-sm);font-size:18px;font-weight:600;margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border)}.admin-tab-content .card-title svg{color:var(--accent)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}.form-grid-full{grid-column:span 2}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-input,.form-select{width:100%;padding:12px var(--space-md);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa1a}.form-input::placeholder{color:var(--text-tertiary)}.section-subtitle{display:flex;align-items:center;gap:var(--space-sm);font-size:14px;font-weight:600;color:var(--text-secondary);margin:var(--space-lg) 0 var(--space-md) 0}.section-subtitle svg{width:16px;height:16px;color:var(--accent)}.license-info{text-align:center;padding:var(--space-lg) 0}.license-status{margin-bottom:var(--space-lg)}.license-badge{display:inline-flex;align-items:center;gap:var(--space-sm);padding:10px 20px;border-radius:30px;font-size:14px;font-weight:600}.license-badge.trial{background:linear-gradient(135deg,#f59e0b33,#f59e0b1a);border:1px solid rgba(245,158,11,.4);color:var(--accent-warning)}.license-badge.active{background:linear-gradient(135deg,#00d4aa33,#00d4aa1a);border:1px solid rgba(0,212,170,.4);color:var(--accent)}.placeholder-content{color:var(--text-secondary);font-size:14px}.placeholder-content p{margin-bottom:var(--space-sm)}.license-list{list-style:none;padding:0;margin:var(--space-md) auto;max-width:300px;text-align:left}.license-list li{position:relative;padding:var(--space-xs) 0 var(--space-xs) var(--space-lg);color:var(--text-tertiary);font-size:13px}.license-list li:before{content:"•";position:absolute;left:0;color:var(--accent)}.user-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.user-stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.user-stat-card:hover{border-color:#00d4aa4d}.user-row{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-sm);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.user-row:hover{border-color:#00d4aa4d;background:#00d4aa05}.admin-tab-content .btn-primary{background:var(--accent);color:var(--bg-primary);border:none;padding:12px 24px;font-weight:600;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.admin-tab-content .btn-primary:hover{background:#00b894;box-shadow:0 4px 15px #00d4aa4d;transform:translateY(-1px)}.admin-tab-content .btn-secondary{background:var(--bg-page);color:var(--text-primary);border:1px solid var(--border);padding:12px 24px;font-weight:500;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.admin-tab-content .btn-secondary:hover{background:var(--bg-surface);border-color:var(--accent);box-shadow:var(--shadow-sm)}@media(max-width:768px){.admin-tabs{border-radius:var(--radius-lg)}.admin-tab{padding:10px 16px;font-size:13px}.form-grid{grid-template-columns:1fr}.form-grid-full{grid-column:span 1}.collapsible-header,.collapsible-body{padding:var(--space-md)}.admin-tab-content .card{padding:var(--space-lg)}}.registration-form{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm)}.registration-step-indicator{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xl);padding:var(--space-lg) 0}.registration-step-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;transition:all var(--transition-fast)}.registration-step-label{font-size:12px;color:var(--text-tertiary);margin-top:var(--space-xs)}.registration-step-line{flex:1;height:2px;max-width:60px;background:var(--border);margin:0 var(--space-xs)}.registration-form-section{text-align:center;margin-bottom:var(--space-xl)}.registration-form-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md)}.registration-form-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.registration-form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-md)}.registration-action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.registration-action-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.registration-action-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}.registration-action-card.selected{border-color:var(--accent);background:#00d4aa0d}.registration-action-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-md)}.registration-action-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-xs)}.registration-action-desc{font-size:12px;color:var(--text-tertiary);margin:0}.registration-photo-buttons{display:flex;gap:var(--space-md);justify-content:center;margin-top:var(--space-md)}.registration-checkbox-input{width:18px;height:18px;accent-color:var(--accent)}@media(max-width:768px){.registration-form{padding:var(--space-md)}.registration-action-grid{grid-template-columns:1fr 1fr}.registration-step-label{display:none}}.registration-footer{display:flex;flex-direction:column;gap:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--border);margin-top:var(--space-lg)}.registration-footer .registration-step-indicator{margin-bottom:0;padding:0}.registration-footer-buttons{display:flex;justify-content:space-between;gap:var(--space-md)}.registration-footer>button{order:1}.registration-footer>.registration-step-indicator{order:0;width:100%}.registration-footer{flex-wrap:wrap}.registration-footer>button:first-of-type{margin-right:auto}.registration-footer>button:last-of-type{margin-left:auto}@media(max-width:768px){.registration-footer{gap:var(--space-md)}.registration-footer>button{flex:1}}.registration-footer>button{padding:.625rem 1.5rem;font-size:.875rem;height:auto;min-height:unset}.registration-footer>button:last-of-type{padding:.625rem 2rem}.reg-page{padding:clamp(1rem,3vw,2rem);max-width:1400px;margin:0 auto;min-height:100vh;padding-bottom:calc(6rem + env(safe-area-inset-bottom,20px))}.reg-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.reg-title{display:flex;align-items:center;gap:12px;font-size:1.5rem;font-weight:600;margin:0;color:var(--text-primary)}.reg-tabs{display:flex;gap:4px;margin-bottom:1.5rem;border-bottom:.5px solid var(--border);overflow-x:auto}.reg-tab{padding:10px 20px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;white-space:nowrap;transition:all .2s}.reg-tab:hover{color:var(--text-primary)}.reg-tab.active{border-bottom-color:var(--accent);color:var(--accent)}.reg-card{background:var(--bg-surface);border:.5px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm)}.reg-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;padding:16px;border-bottom:.5px solid var(--border)}.reg-search-input{flex:1 1 200px;padding:9px 12px 9px 36px;background:var(--bg-page);border:.5px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px;outline:none;min-width:150px}.reg-search-input:focus{border-color:var(--accent)}.reg-select{padding:9px 12px;background:var(--bg-page);border:.5px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:13px;cursor:pointer;outline:none}.reg-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .15s;white-space:nowrap;background:var(--bg-page);color:var(--text-primary);border:.5px solid var(--border)}.reg-btn:hover{border-color:var(--accent)}.reg-btn-primary{background:var(--accent);color:var(--text-primary);border-color:var(--accent)}.reg-btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.reg-btn-danger{background:var(--status-error-bg);color:var(--status-error);border-color:var(--status-error-bg)}.reg-btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.reg-btn-sm{padding:6px 10px;font-size:12px}.reg-table{width:100%;border-collapse:collapse}.reg-th{text-align:left;padding:10px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);border-bottom:.5px solid var(--border)}.reg-td{padding:12px 16px;font-size:14px;border-bottom:.5px solid var(--border);color:var(--text-primary)}.reg-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.reg-modal-content{background:var(--bg-surface);border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;border:.5px solid var(--border);display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.reg-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:.5px solid var(--border)}.reg-modal-body{padding:24px;overflow-y:auto;flex:1}.reg-modal-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-top:.5px solid var(--border)}.reg-form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.reg-form-label{font-size:13px;color:var(--text-secondary);font-weight:500}.reg-form-input{padding:10px 12px;background:var(--bg-page);border:.5px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px;outline:none;width:100%;box-sizing:border-box}.reg-form-input:focus{border-color:var(--accent)}.reg-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.reg-detail-panel{position:fixed;top:0;right:0;bottom:0;width:500px;max-width:100vw;background:var(--bg-surface);z-index:1001;border-left:.5px solid var(--border);display:flex;flex-direction:column;box-shadow:-4px 0 20px #00000026}.reg-overlay{position:fixed;inset:0;background:#00000080;z-index:1000}.reg-empty{text-align:center;padding:60px 20px;color:var(--text-tertiary)}.reg-pagination{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-top:.5px solid var(--border);font-size:13px;color:var(--text-secondary)}.reg-group-card{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-surface);border:.5px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm)}.reg-audit-row{display:flex;gap:16px;padding:12px 16px;align-items:flex-start;border-bottom:.5px solid var(--border);font-size:13px}.reg-provider-card{padding:12px 16px;background:var(--bg-surface);border:.5px solid var(--border);border-radius:8px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow-sm)}.reg-icon-accent{color:var(--accent)}.integrations-manager{padding:var(--space-md) 0}.integrations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.integrations-header h2{margin:0;font-size:24px;font-weight:600}.integration-category{margin-bottom:var(--space-2xl)}.integration-category-title{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);font-size:15px;font-weight:600;color:var(--text-secondary)}.integration-category-title svg{color:var(--text-tertiary)}.integration-empty{padding:var(--space-xl);background:#ffffff08;border:1px dashed var(--border);border-radius:var(--radius-lg);text-align:center;color:var(--text-tertiary);font-size:14px}.integration-cards{display:grid;gap:var(--space-md)}.integration-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);transition:all var(--transition-base);box-shadow:var(--shadow-sm)}.integration-card:hover{border-color:#00d4aa66;transform:translateY(-2px);box-shadow:0 8px 32px #0000004d,0 0 0 1px #00d4aa1a}.integration-card.enabled{border-color:#22c55e4d}.integration-card.enabled:hover{border-color:#22c55e80;box-shadow:0 8px 32px #0000004d,0 0 0 1px #22c55e1a}.integration-card.type-vms{border-left:4px solid var(--accent)}.integration-card.type-access{border-left:4px solid var(--accent-purple)}.integration-card.type-ai{border-left:4px solid var(--accent-warning)}.integration-card.type-intercom{border-left:4px solid var(--accent)}.integration-card-info{display:flex;align-items:center;gap:var(--space-md)}.integration-card-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-page) 100%);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.integration-card.type-vms .integration-card-icon{background:linear-gradient(135deg,#00d4aa26,#00d4aa0d);border-color:#00d4aa33;color:var(--accent)}.integration-card.type-access .integration-card-icon{background:linear-gradient(135deg,#a855f726,#a855f70d);border-color:#a855f733;color:var(--accent-purple)}.integration-card.type-ai .integration-card-icon{background:linear-gradient(135deg,#f59e0b26,#f59e0b0d);border-color:#f59e0b33;color:var(--accent-warning)}.integration-card.type-intercom .integration-card-icon{background:linear-gradient(135deg,#0ea5e926,#0ea5e90d);border-color:#0ea5e933;color:var(--accent)}.integration-card-details{display:flex;flex-direction:column;gap:2px}.integration-card-name{font-size:15px;font-weight:600;color:var(--text-primary)}.integration-card-type{font-size:12px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px}.integration-card-actions{display:flex;gap:var(--space-sm)}.integration-card-actions .btn{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast)}.integration-card-actions .btn-secondary{background:var(--bg-page);border:1px solid var(--border);color:var(--text-secondary)}.integration-card-actions .btn-secondary:hover{background:var(--bg-surface);border-color:var(--accent);color:var(--accent);box-shadow:var(--shadow-sm)}.integration-card-actions .btn-danger{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--accent-danger)}.integration-card-actions .btn-danger:hover{background:#ef444433;border-color:var(--accent-danger)}.integration-modal-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg)}.integration-modal{position:relative;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:0 25px 50px #00000080}.integration-modal-header{padding:var(--space-xl);border-bottom:1px solid var(--border)}.integration-modal-header h2{margin:0 0 var(--space-xs) 0;font-size:20px;font-weight:600}.integration-modal-header p{margin:0;color:var(--text-tertiary);font-size:14px}.integration-modal-close{position:absolute;top:var(--space-lg);right:var(--space-lg);width:36px;height:36px;border-radius:50%;background:var(--bg-page);border:1px solid var(--border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.integration-modal-close:hover{background:#ef44441a;border-color:#ef44444d;color:var(--accent-danger)}.integration-modal-body{padding:var(--space-xl)}.integration-modal-footer{display:flex;justify-content:flex-end;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--border);background:var(--bg-surface)}.integration-form-group{margin-bottom:var(--space-lg)}.integration-form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.integration-form-group label .required{color:var(--accent-danger);margin-left:2px}.integration-form-group .form-hint{font-size:12px;color:var(--text-tertiary);margin-top:var(--space-xs)}.integration-form-group input,.integration-form-group select{width:100%;padding:12px var(--space-md);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.integration-form-group input:focus,.integration-form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa1a}.integration-form-group input::placeholder{color:var(--text-tertiary)}.integration-type-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm);margin-bottom:var(--space-lg)}.integration-type-option{padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:center;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.integration-type-option:hover{border-color:var(--accent)}.integration-type-option.selected{background:#00d4aa1a;border-color:var(--accent)}.integration-type-option svg{margin-bottom:var(--space-xs);color:var(--text-tertiary)}.integration-type-option.selected svg{color:var(--accent)}@media(max-width:768px){.integrations-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.integrations-header .btn{width:100%;justify-content:center}.integration-card{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.integration-card-actions{width:100%;justify-content:flex-end}.integration-modal{max-height:100vh;border-radius:var(--radius-lg)}}.integration-card.type-video-management{border-left:4px solid var(--accent)}.integration-card.type-video-management .integration-card-icon{background:linear-gradient(135deg,#00d4aa26,#00d4aa0d);border-color:#00d4aa33;color:var(--accent)}.integration-card.type-access-control{border-left:4px solid var(--accent-purple)}.integration-card.type-access-control .integration-card-icon{background:linear-gradient(135deg,#a855f726,#a855f70d);border-color:#a855f733;color:var(--accent-purple)}.integration-card.type-ai-analytics{border-left:4px solid var(--accent-warning)}.integration-card.type-ai-analytics .integration-card-icon{background:linear-gradient(135deg,#f59e0b26,#f59e0b0d);border-color:#f59e0b33;color:var(--accent-warning)}@keyframes im-spin{to{transform:rotate(360deg)}}.im-spin{animation:im-spin .8s linear infinite}@keyframes im-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.im-root{display:flex;flex-direction:column;gap:24px}.im-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:48px;color:var(--text-tertiary)}.im-header{display:flex;justify-content:space-between;align-items:center}.im-header__title{margin:0 0 2px;font-size:18px;font-weight:600;color:var(--text-primary)}.im-header__sub{margin:0;font-size:13px;color:var(--text-tertiary)}.im-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .18s}.im-btn:disabled{opacity:.45;cursor:not-allowed}.im-btn--primary{background:var(--accent);color:var(--bg-page)}.im-btn--primary:not(:disabled):hover{filter:brightness(1.1)}.im-btn--save{background:var(--accent-success);color:var(--bg-surface);min-width:160px;justify-content:center}.im-btn--save:not(:disabled):hover{filter:brightness(1.1)}.im-btn--ghost{background:#ffffff0f;color:var(--text-secondary);border:1px solid var(--border)}.im-btn--ghost:hover{background:#ffffff1a;color:var(--text-primary)}.im-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.im-icon-btn:hover{background:#ffffff14;color:var(--text-primary)}.im-icon-btn--danger:hover{background:#ef444426;color:var(--accent-danger);border-color:#ef44444d}.im-category-section{display:flex;flex-direction:column;gap:8px}.im-category-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--cat-color, var(--text-secondary));padding-bottom:8px;border-bottom:1px solid var(--border)}.im-category-count{background:#ffffff14;color:var(--text-tertiary);padding:1px 7px;border-radius:10px;font-size:11px;font-weight:500}.im-empty{font-size:13px;color:var(--text-tertiary);padding:8px 0 4px}.im-cards{display:flex;flex-direction:column;gap:6px}.im-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color .15s;box-shadow:var(--shadow-sm)}.im-card:hover{border-color:#ffffff2e}.im-card__icon{width:34px;height:34px;border-radius:8px;background:#ffffff0f;color:var(--accent));display:flex;align-items:center;justify-content:center;flex-shrink:0}.im-card__body{flex:1;min-width:0}.im-card__name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.im-card__type{font-size:12px;color:var(--text-tertiary)}.im-card__tunnel-badge{display:inline-block;margin-top:3px;padding:1px 7px;border-radius:4px;font-size:10px;background:#00d4aa1f;color:var(--accent);border:1px solid rgba(0,212,170,.25)}.im-card__dot{width:7px;height:7px;border-radius:50%;background:var(--accent-success);flex-shrink:0}.im-card__actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.im-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.im-wizard{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;position:relative;animation:im-fade-in .2s ease;overflow:hidden;box-shadow:0 25px 60px #00000080}.im-wizard__header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.im-wizard__title{font-size:17px;font-weight:600;color:var(--text-primary)}.im-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;transition:all .15s}.im-close:hover{color:var(--text-primary);background:#ffffff0f}.im-wizard__body{flex:1;overflow-y:auto;padding:20px 24px}.im-wizard__footer{display:flex;justify-content:space-between;align-items:center;padding:14px 24px;border-top:1px solid var(--border);flex-shrink:0;background:var(--bg-surface)}.im-wizard__footer-right{display:flex;gap:8px}.im-steps{display:flex;align-items:flex-start;padding:16px 24px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.im-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.im-step__dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;transition:all .2s;z-index:1}.im-step--idle .im-step__dot{background:var(--bg-page);color:var(--text-tertiary);border:1px solid var(--border)}.im-step--active .im-step__dot{background:var(--accent);color:var(--bg-page);box-shadow:0 0 0 3px #00d4aa33}.im-step--done .im-step__dot{background:var(--accent-success);color:var(--bg-surface)}.im-step__label{font-size:10px;margin-top:5px;text-align:center;transition:color .2s;line-height:1.2}.im-step--idle .im-step__label{color:var(--text-tertiary)}.im-step--active .im-step__label{color:var(--accent);font-weight:600}.im-step--done .im-step__label{color:var(--accent-success)}.im-step__line{position:absolute;top:13px;left:50%;right:-50%;height:1px;background:var(--border);z-index:0}.im-step--done .im-step__line{background:var(--accent-success)}.im-choose{display:flex;flex-direction:column;gap:16px;animation:im-fade-in .2s ease}.im-category-tabs{display:flex;gap:6px;flex-wrap:wrap}.im-category-tab{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--bg-page);color:var(--text-tertiary);transition:all .15s}.im-category-tab:hover{background:var(--bg-surface);color:var(--text-primary)}.im-category-tab--active{background:color-mix(in srgb,var(--tab-color) 15%,transparent);border-color:color-mix(in srgb,var(--tab-color) 40%,transparent);color:var(--tab-color)}.im-category-tab__count{background:#ffffff1f;border-radius:8px;padding:1px 6px;font-size:10px}.im-type-grid{display:flex;flex-direction:column;gap:6px}.im-type-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;width:100%;transition:all .15s;color:var(--text-primary);box-shadow:var(--shadow-sm)}.im-type-card:hover{background:color-mix(in srgb,var(--bg-surface)) 60%,transparent);border-color:color-mix(in srgb,var(--accent)) 40%,var(--border))}.im-type-card__icon{width:40px;height:40px;border-radius:10px;background:var(--bg-surface));color:var(--accent));display:flex;align-items:center;justify-content:center;flex-shrink:0}.im-type-card__icon img{width:24px;height:24px;object-fit:contain}.im-type-card__body{flex:1;min-width:0}.im-type-card__name{font-size:14px;font-weight:600;margin-bottom:2px}.im-type-card__desc{font-size:12px;color:var(--text-tertiary)}.im-type-card__arrow{color:var(--text-tertiary);flex-shrink:0;transition:transform .15s,color .15s}.im-type-card:hover .im-type-card__arrow{transform:translate(3px);color:var(--accent))}.im-configure{display:flex;flex-direction:column;gap:20px;animation:im-fade-in .2s ease}.im-system-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:13px;background:color-mix(in srgb,var(--badge-color) 12%,transparent);border:1px solid color-mix(in srgb,var(--badge-color) 30%,transparent);color:var(--badge-color);align-self:flex-start}.im-system-badge__dot{width:6px;height:6px;border-radius:50%;background:var(--badge-color)}.im-system-badge__category{font-size:11px;opacity:.7;border-left:1px solid currentColor;padding-left:8px;margin-left:2px}.im-fields{display:flex;flex-direction:column;gap:14px}.im-field{display:flex;flex-direction:column;gap:5px}.im-field--indent{border-left:2px solid rgba(0,212,170,.25);padding-left:12px;margin-left:4px}.im-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.im-required{color:var(--accent-danger)}.im-label-row{display:flex;justify-content:space-between;align-items:center}.im-link{background:none;border:none;color:var(--accent);font-size:11px;cursor:pointer;padding:0}.im-link:hover{text-decoration:underline}.im-input{width:100%;padding:10px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:border-color .15s;box-sizing:border-box;box-shadow:var(--shadow-sm)}.im-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa1a}.im-input::placeholder{color:var(--text-tertiary)}.im-select{width:100%;padding:10px 36px 10px 12px;background:var(--bg-surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M6 8L1 3h10z'/%3E%3C/svg%3E") no-repeat right 12px center;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;-webkit-appearance:none;appearance:none;cursor:pointer;box-sizing:border-box;box-shadow:var(--shadow-sm)}.im-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa1a}.im-select option{background:var(--bg-surface);color:var(--text-primary)}.im-hint{font-size:11px;color:var(--text-tertiary);margin:0;line-height:1.4}.im-hint--top{margin-bottom:2px}.im-warning{display:flex;align-items:center;gap:6px;padding:10px 12px;background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-md);color:var(--accent-warning);font-size:13px}.im-toggle{display:flex;align-items:center;gap:10px;cursor:pointer}.im-toggle input{display:none}.im-toggle__slider{width:36px;height:20px;border-radius:10px;background:var(--bg-page);position:relative;transition:background .2s;flex-shrink:0}.im-toggle__slider:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--bg-surface);transition:transform .2s}.im-toggle input:checked+.im-toggle__slider{background:var(--accent-success)}.im-toggle input:checked+.im-toggle__slider:after{transform:translate(16px)}.im-toggle__label{font-size:14px;color:var(--text-secondary)}.im-connection-method{padding:14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:10px}.im-section-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.im-method-pills{display:flex;gap:8px}.im-method-pill{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-tertiary);box-shadow:var(--shadow-sm)}.im-method-pill:hover{background:var(--bg-surface);color:var(--text-secondary)}.im-method-pill--active{background:#00d4aa1a;border-color:#00d4aa59;color:var(--accent)}.im-test{display:flex;flex-direction:column;align-items:center;gap:20px;padding:16px 0;animation:im-fade-in .2s ease}.im-test__visual{display:flex;align-items:center;justify-content:center;width:90px;height:90px}.im-test__spinner{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center;color:var(--spin-color, var(--accent))}.im-test__spinner-ring{position:absolute;inset:0;border-radius:50%;border:2px solid transparent;border-top-color:var(--spin-color, var(--accent));animation:im-spin 1s linear infinite}.im-test__result-icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center}.im-test__result-icon--success{background:#10b9811f;color:var(--accent-success);border:2px solid rgba(16,185,129,.3)}.im-test__result-icon--fail{background:#ef44441f;color:var(--accent-danger);border:2px solid rgba(239,68,68,.3)}.im-test__idle{color:var(--text-tertiary)}.im-test__status{text-align:center}.im-test__heading{margin:0 0 6px;font-size:16px;font-weight:600;color:var(--text-primary)}.im-test__heading--success{color:var(--accent-success)}.im-test__heading--fail{color:var(--accent-danger)}.im-test__sub{margin:0;font-size:13px;color:var(--text-tertiary);max-width:360px;line-height:1.5}.im-test__details{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.im-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:14px;font-size:11px;background:var(--bg-page);border:1px solid var(--border);color:var(--text-tertiary)}.im-review{display:flex;flex-direction:column;gap:16px;animation:im-fade-in .2s ease}.im-review__card{display:flex;align-items:center;gap:14px;padding:16px;background:color-mix(in srgb,var(--bg-surface)) 70%,transparent);border:1px solid color-mix(in srgb,var(--accent)) 25%,var(--border));border-radius:var(--radius-lg)}.im-review__card-icon{width:42px;height:42px;border-radius:10px;background:var(--bg-surface));color:var(--accent));display:flex;align-items:center;justify-content:center;flex-shrink:0}.im-review__card-body{flex:1;min-width:0}.im-review__card-name{font-size:15px;font-weight:600;color:var(--text-primary)}.im-review__card-meta{font-size:12px;color:var(--text-tertiary);margin-top:2px}.im-review__test-badge{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:14px;background:#10b9811f;color:var(--accent-success);font-size:11px;font-weight:600;border:1px solid rgba(16,185,129,.25);flex-shrink:0}.im-review__section{background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.im-review__section-label{margin:0;padding:8px 14px;font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;background:#ffffff05;border-bottom:1px solid var(--border)}.im-review__rows{display:flex;flex-direction:column}.im-review__row{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;border-bottom:1px solid rgba(255,255,255,.04);gap:16px}.im-review__row:last-child{border-bottom:none}.im-review__row-key{font-size:13px;color:var(--text-tertiary);flex-shrink:0}.im-review__row-val{font-size:13px;color:var(--text-primary);font-family:var(--font-mono);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:280px}.im-review__test-result{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:500}.im-review__test-result--ok{background:#10b98114;border:1px solid rgba(16,185,129,.2);color:var(--accent-success)}.im-review__test-result--fail{background:#f59e0b14;border:1px solid rgba(245,158,11,.2);color:var(--accent-warning)}@media(max-width:600px){.im-overlay{padding:0;align-items:flex-end}.im-wizard{max-width:100%;max-height:95vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.im-steps{padding:12px 16px 10px}.im-step__label{font-size:9px}.im-wizard__header{padding:16px 16px 12px}.im-wizard__body{padding:16px}.im-wizard__footer{padding:12px 16px}.im-category-tabs{gap:4px}.im-category-tab{padding:6px 10px;font-size:12px}.im-method-pills{flex-direction:column}.im-header{flex-direction:column;align-items:flex-start;gap:12px}.im-header .im-btn{align-self:flex-start}}.user-profile-page{padding:var(--space-xl);margin:0 auto}.user-profile-header{margin-bottom:var(--space-xl)}.user-profile-header h1{font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.user-profile-header p{color:var(--text-tertiary);margin-top:var(--space-sm);font-size:14px}.user-profile-tabs{display:flex;gap:4px;margin-bottom:var(--space-xl);padding:4px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.user-profile-tab{display:flex;align-items:center;gap:var(--space-sm);padding:12px 20px;background:transparent;border:none;border-radius:var(--radius-lg);color:var(--text-tertiary);cursor:pointer;font-size:14px;font-weight:400;transition:all var(--transition-fast)}.user-profile-tab:hover{color:var(--text-primary);background:#ffffff0d}.user-profile-tab.active{color:var(--accent);background:#00d4aa1a;font-weight:500;box-shadow:0 0 0 1px #00d4aa4d}.user-profile-tab svg{width:18px;height:18px}.user-profile-content{min-height:400px}.profile-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-lg);transition:border-color var(--transition-fast);box-shadow:var(--shadow-sm)}.profile-card:hover{border-color:#00d4aa33}.profile-card-title{display:flex;align-items:center;gap:var(--space-sm);font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-lg) 0}.profile-card-title svg{color:var(--accent)}.profile-user-info{display:flex;align-items:center;gap:var(--space-lg)}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#00b894);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600;color:var(--bg-page);flex-shrink:0}.profile-user-details h2{font-size:20px;font-weight:600;margin:0 0 4px;color:var(--text-primary)}.profile-user-email{color:var(--text-tertiary);font-size:14px;display:flex;align-items:center;gap:var(--space-xs)}.profile-user-role{display:inline-flex;align-items:center;gap:var(--space-xs);margin-top:var(--space-sm);padding:4px 12px;background:#00d4aa26;color:var(--accent);border-radius:var(--radius-md);font-size:12px;font-weight:500;text-transform:uppercase}.profile-user-tenant{display:flex;align-items:center;gap:var(--space-xs);margin-top:var(--space-sm);color:var(--text-secondary);font-size:13px}.security-section{display:flex;flex-direction:column;gap:var(--space-lg)}.password-form{display:flex;flex-direction:column;gap:var(--space-md)}.password-input-wrapper{position:relative}.password-input-wrapper input{width:100%;padding:12px var(--space-md);padding-right:48px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.password-input-wrapper input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa1a}.password-toggle-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.password-toggle-btn:hover{color:var(--text-primary)}.sessions-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.sessions-header h3{display:flex;align-items:center;gap:var(--space-sm);font-size:16px;font-weight:600;margin:0}.sessions-header h3 svg{color:var(--accent)}.sessions-actions{display:flex;gap:var(--space-sm)}.sessions-list{display:flex;flex-direction:column;gap:var(--space-sm)}.session-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.session-item:hover{border-color:#00d4aa4d}.session-item.current{border-color:#00d4aa66;background:#00d4aa0d}.session-info{display:flex;align-items:center;gap:var(--space-md)}.session-icon{width:44px;height:44px;border-radius:var(--radius-md);background:var(--bg-page);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.session-item.current .session-icon{background:#00d4aa1a;border-color:#00d4aa4d;color:var(--accent)}.session-details h4{font-size:14px;font-weight:500;margin:0 0 4px;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm)}.session-current-badge{font-size:10px;padding:2px 6px;background:var(--accent);color:var(--bg-page);border-radius:var(--radius-sm);font-weight:600;text-transform:uppercase}.session-meta{font-size:12px;color:var(--text-tertiary);display:flex;flex-direction:column;gap:2px}.session-meta span{display:flex;align-items:center;gap:var(--space-xs)}.notifications-section,.preferences-section{display:flex;flex-direction:column;gap:var(--space-lg)}.preference-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.preference-item:hover{border-color:#00d4aa33}.preference-info h4{font-size:14px;font-weight:500;margin:0 0 4px;color:var(--text-primary)}.preference-info p{font-size:12px;color:var(--text-tertiary);margin:0}.profile-form-group{margin-bottom:var(--space-md)}.profile-form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.profile-form-input{width:100%;padding:12px var(--space-md);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.profile-form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #00d4aa1a}.profile-form-input::placeholder{color:var(--text-tertiary)}.profile-form-input:disabled{opacity:.6;cursor:not-allowed}.profile-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:10px 20px;font-size:14px;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none}.profile-btn-primary{background:var(--accent);color:var(--bg-page)}.profile-btn-primary:hover{background:#00b894;box-shadow:0 4px 15px #00d4aa4d;transform:translateY(-1px)}.profile-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.profile-btn-secondary{background:var(--bg-page);color:var(--text-primary);border:1px solid var(--border)}.profile-btn-secondary:hover{background:var(--bg-surface);border-color:var(--accent);box-shadow:var(--shadow-sm)}.profile-btn-danger{background:#ef44441a;color:var(--accent-danger);border:1px solid rgba(239,68,68,.3)}.profile-btn-danger:hover{background:#ef444433;border-color:var(--accent-danger)}.profile-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-tertiary)}.profile-loading .spin{animation:spin 1s linear infinite}.profile-empty{text-align:center;padding:var(--space-2xl);color:var(--text-tertiary)}.profile-empty svg{opacity:.3;margin-bottom:var(--space-md)}.profile-empty p{margin:0;font-size:14px}@media(max-width:768px){.user-profile-page{padding:var(--space-md)}.user-profile-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.user-profile-tab{padding:10px 14px;font-size:13px;white-space:nowrap}.profile-card{padding:var(--space-lg)}.profile-user-info{flex-direction:column;text-align:center}.profile-user-details{text-align:center}.session-item{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.sessions-actions{width:100%;justify-content:flex-end}}.profile-user-role.platform-admin{background:#a78bfa26;color:#a78bfa}.profile-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.info-field-label{display:block;color:var(--text-tertiary);font-size:12px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.info-field-value{color:var(--text-primary);font-size:14px}.info-field-status{display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-size:14px}.site-access-list{display:flex;flex-direction:column;gap:var(--space-sm)}.site-access-item{padding:var(--space-md) var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;justify-content:space-between;align-items:center;transition:border-color var(--transition-fast);box-shadow:var(--shadow-sm)}.site-access-item:hover{border-color:#00d4aa4d}.site-access-name{color:var(--text-primary);font-weight:500}.site-access-role{padding:4px 10px;background:#00d4aa26;color:var(--accent);border-radius:var(--radius-md);font-size:12px;font-weight:500}.mb-lg{margin-bottom:var(--space-lg)!important}.profile-card-desc{margin:4px 0 0;color:var(--text-tertiary);font-size:13px}.session-details{flex:1}.session-title-row{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:2px;flex-wrap:wrap}.session-device-name{color:var(--text-primary);font-size:14px;font-weight:500}.session-extended-badge{padding:2px 6px;background:#f59e0b26;color:#f59e0b;border-radius:var(--radius-sm);font-size:10px}.session-signout-btn{padding:6px 12px!important;font-size:12px!important}.profile-form-label{display:block;color:var(--text-tertiary);font-size:12px;margin-bottom:6px}.profile-error-message{padding:var(--space-md);background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#f87171;margin-bottom:var(--space-md);font-size:13px}.profile-checkbox-label{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-tertiary);font-size:13px;cursor:pointer}.profile-checkbox-label input[type=checkbox]{accent-color:var(--accent)}.mt-sm{margin-top:var(--space-sm)!important}.mb-md{margin-bottom:var(--space-md)!important}.preference-list{display:flex;flex-direction:column;gap:var(--space-md)}.preference-select{width:auto;padding:8px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;cursor:pointer;transition:all var(--transition-fast)}.preference-select:focus{outline:none;border-color:var(--accent)}.preference-select:hover{border-color:#00d4aa80}@media(max-width:768px){.user-profile-page{padding:var(--space-md)}.user-profile-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.user-profile-tabs::-webkit-scrollbar{display:none}.user-profile-tab{padding:10px 14px;font-size:13px;white-space:nowrap}.profile-card{padding:var(--space-lg)}.profile-user-info{flex-direction:column;text-align:center}.profile-user-details{text-align:center}.session-item{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.sessions-actions{width:100%;justify-content:flex-end}.sessions-header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.sessions-header .sessions-actions{width:100%}.preference-item{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.preference-select{width:100%}}.user-profile-page{overflow-x:hidden}.profile-card{overflow:hidden;word-wrap:break-word}.profile-info-grid{overflow:hidden}.user-profile-more-btn{display:flex;align-items:center;gap:var(--space-xs)}.user-profile-more-btn .rotated{transform:rotate(180deg)}.user-profile-more-btn svg:last-child{transition:transform var(--transition-fast)}.user-profile-more-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000004d;z-index:100;overflow:hidden}.user-profile-more-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:12px 16px;background:transparent;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all var(--transition-fast);text-align:left}.user-profile-more-item:hover{background:var(--bg-page);color:var(--text-primary)}.user-profile-more-item.active{background:#00d4aa1a;color:var(--accent)}.user-profile-more-item svg{flex-shrink:0}@media(min-width:769px){.user-profile-tab span{display:inline}}.user-profile-tabs{position:relative;z-index:10}.user-profile-more-wrapper{position:relative;z-index:100}.user-profile-more-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 10px 40px #00000080;z-index:1000;overflow:hidden}.user-profile-page{overflow-x:hidden;overflow-y:visible}.user-profile-tabs{overflow:visible!important;position:relative;z-index:50}.user-profile-more-wrapper{position:relative}.user-profile-more-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0009;z-index:9999}@media(min-width:769px){.user-profile-more-wrapper{display:none}.user-profile-tab.overflow-tab{display:flex}}@media(max-width:768px){.user-profile-tab.overflow-tab{display:none}.user-profile-more-wrapper{display:block}}@media(max-width:768px){.user-profile-more-btn span{display:none}.user-profile-more-btn svg.rotated,.user-profile-more-btn svg:last-child{display:none}}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-top:16px}.theme-card{position:relative;display:flex;flex-direction:column;background:var(--bg-surface);border:.5px solid var(--border);border-radius:var(--radius-lg);padding:12px;cursor:pointer;transition:all var(--transition-fast);text-align:left;box-shadow:var(--shadow-sm)}.theme-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.theme-card.selected{border-color:var(--accent);border-width:1.5px;box-shadow:0 0 0 3px var(--accent-alpha-15)}.theme-card-preview{display:flex;height:90px;border-radius:var(--radius-md);overflow:hidden;border:.5px solid var(--border)}.theme-card-sidebar{width:22%;flex-shrink:0}.theme-card-page{flex:1;padding:10px;display:flex;flex-direction:column;gap:6px}.theme-card-accent{width:32px;height:6px;border-radius:3px}.theme-card-line{height:4px;background:#80808040;border-radius:2px;width:80%}.theme-card-line.short{width:50%}.theme-card-meta{margin-top:10px;display:flex;align-items:baseline;justify-content:space-between}.theme-card-name{font-size:13px;font-weight:600;color:var(--text-primary)}.theme-card-type{font-size:11px;color:var(--text-tertiary);text-transform:capitalize}.theme-card-check{position:absolute;top:8px;right:8px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:var(--text-primary);display:flex;align-items:center;justify-content:center}.md-agent-status{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-page);border-radius:var(--radius-md);margin-bottom:20px;border:1px solid var(--border)}.md-agent-name{color:var(--text-primary);font-size:13px;font-weight:500}.md-agent-hostname{color:var(--text-tertiary);font-size:12px}.md-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:20px}.md-stat-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--bg-surface);border-radius:var(--radius-lg);border:.5px solid var(--border);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .2s ease}.md-stat-card:hover{border-color:#00d4aa4d;background:var(--bg-page)}.md-stat-card.active{border-color:var(--accent);background:#00d4aa0d}.md-stat-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.md-stat-icon.total,.md-stat-icon.camera{background:#00d4aa26;color:var(--accent)}.md-stat-icon.server{background:#a855f726;color:#a855f7}.md-stat-icon.router{background:#0ea5e926;color:var(--accent-hover)}.md-stat-icon.online{background:#22c55e26;color:#22c55e}.md-stat-info{display:flex;flex-direction:column;min-width:0}.md-stat-value{font-size:24px;font-weight:700;color:var(--text-primary);line-height:1}.md-stat-label{font-size:11px;color:var(--text-tertiary);margin-top:4px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.md-filters{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.md-search{flex:1;min-width:250px;position:relative}.md-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.md-search .form-input{padding-left:40px;width:100%}.md-filters .form-select{min-width:130px}.md-table-container{overflow-x:auto}.md-devices-table{width:100%;border-collapse:collapse}.md-devices-table th{text-align:left;padding:14px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);border-bottom:1px solid var(--border);white-space:nowrap}.md-devices-table td{padding:14px 16px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--border);vertical-align:middle}.md-devices-table tbody tr{transition:background .15s ease}.md-devices-table tbody tr:hover{background:#ffffff05}.md-devices-table tbody tr:last-child td{border-bottom:none}.md-ip-cell{display:flex;flex-direction:column;gap:2px}.md-ip-cell code{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:13px;color:var(--text-primary);font-weight:500}.md-mac{font-size:10px;color:var(--text-tertiary);font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;text-transform:uppercase}.md-hostname-cell{display:block;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.md-time-cell{display:inline-flex;align-items:center;gap:6px;color:var(--text-tertiary);white-space:nowrap;font-size:12px}.md-time-cell svg{opacity:.6}.device-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.device-badge.camera{background:#00d4aa26;color:var(--accent)}.device-badge.server{background:#64748b1f;color:#64748b}.device-badge.router{background:#0ea5e926;color:var(--accent-hover)}.device-badge.switch{background:#f59e0b26;color:#f59e0b}.device-badge.nvr{background:#64748b1f;color:#64748b}.device-badge.access_point{background:#6366f126;color:var(--accent)}.device-badge.access_controller{background:#eab30826;color:#eab308}.device-badge.unknown{background:#9ca3af26;color:var(--text-secondary)}.status-indicator{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;white-space:nowrap}.status-indicator:before{content:"";width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-indicator.online{color:#22c55e}.status-indicator.online:before{background:#22c55e;box-shadow:0 0 8px #22c55e80}.status-indicator.offline{color:#ef4444}.status-indicator.degraded{color:#fa0}.status-indicator.degraded:before{background:#fa0;background:#ef4444}.status-indicator.unknown{color:var(--text-tertiary)}.status-indicator.unknown:before{background:var(--text-tertiary)}.md-table-footer{padding:12px 16px;font-size:12px;color:var(--text-tertiary);border-top:1px solid var(--border);display:flex;align-items:center;gap:12px}.btn-link{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer;padding:0}.btn-link:hover{text-decoration:underline}.md-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-tertiary)}.md-loading svg{color:var(--accent);margin-bottom:16px}.md-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.md-empty svg{color:var(--text-tertiary);margin-bottom:16px;opacity:.5}.md-empty h3{color:var(--text-primary);margin:0 0 8px;font-size:18px}.md-empty p{color:var(--text-tertiary);margin:0 0 20px;font-size:14px}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1024px){.md-stats-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.md-stats-grid{grid-template-columns:repeat(2,1fr)}.md-stat-card{padding:12px;gap:10px}.md-stat-value{font-size:20px}.md-filters{flex-direction:column}.md-search{min-width:100%}.md-filters .form-select,.md-filters .btn{width:100%}.md-devices-table{font-size:12px}.md-devices-table th,.md-devices-table td{padding:10px 12px}.md-devices-table th:nth-child(3),.md-devices-table td:nth-child(3),.md-devices-table th:nth-child(4),.md-devices-table td:nth-child(4){display:none}}@media(max-width:480px){.md-stats-grid{grid-template-columns:repeat(2,1fr)}.md-stat-card:last-child{grid-column:span 2}}.md-checkbox-col{width:40px;text-align:center;padding:.5rem!important}.md-checkbox-col input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent)}.md-row-selected{background:#00d4aa14!important;border-left:2px solid var(--accent)}.md-selection-banner{display:flex;align-items:center;justify-content:space-between;background:#00d4aa1a;border:1px solid rgba(0,212,170,.3);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;color:var(--accent);font-weight:500}.md-selection-actions{display:flex;gap:.5rem}.btn-accent{background:var(--accent);color:#000;border:none;font-weight:600}.btn-accent:hover{background:#00eabb;color:#000}.md-promote-modal{max-width:560px;width:95%}.md-promote-summary{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.5}.md-promote-summary strong{color:var(--accent)}.md-promote-form{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-hint{display:block;font-size:.75rem;color:var(--text-tertiary);margin-top:.25rem}.md-promote-preview{border-top:1px solid rgba(255,255,255,.08);padding-top:1rem}.md-promote-preview h4{font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.md-promote-device-list{max-height:160px;overflow-y:auto;display:flex;flex-direction:column;gap:.35rem}.md-promote-device-item{display:flex;align-items:center;gap:.75rem;padding:.35rem .5rem;background:#ffffff08;border-radius:4px;font-size:.85rem}.md-promote-device-item code{font-size:.8rem;color:var(--text-primary);min-width:120px}.md-promote-device-name{color:var(--text-tertiary);font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.device-badge.sm{font-size:.65rem;padding:.1rem .4rem}@media(max-width:640px){.form-row{grid-template-columns:1fr}.md-selection-banner{flex-direction:column;gap:.5rem;text-align:center}}.md-device-name-cell{display:flex;align-items:center;gap:.6rem}.md-device-name{font-weight:500;color:var(--text-primary);display:block}.md-device-group{font-size:.75rem;color:var(--text-tertiary);display:block}.md-status-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:12px;border:1px solid;font-size:.8rem;font-weight:500;white-space:nowrap}.md-profile-badge{background:#ffffff0f;color:var(--text-secondary);padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.md-source-badge{font-size:.7rem;padding:.15rem .45rem;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.md-source-badge.discovery{background:#00d4aa1f;color:var(--accent)}.md-source-badge.integration{background:#6495ed1f;color:#6495ed}.md-source-badge.manual{background:#ffaa001f;color:#fa0}.md-actions-col{width:160px;text-align:right}.md-action-btns{display:flex;gap:.25rem;justify-content:flex-end}.md-action-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);color:var(--text-secondary);border-radius:4px;padding:.3rem;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.md-action-btn:hover{background:#ffffff1a;color:var(--text-primary)}.md-action-btn.danger:hover{background:#ff4d4d26;color:#ff4d4d;border-color:#ff4d4d4d}.md-rules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1rem;margin-top:1rem}.md-rule-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:1rem;transition:border-color .2s;box-shadow:var(--shadow-sm)}.md-rule-card:hover{border-color:var(--accent)}.md-rule-card.disabled{opacity:.5}.md-rule-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.md-rule-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border-radius:8px;flex-shrink:0}.md-rule-name{font-weight:600;color:var(--text-primary)}.md-rule-type{font-size:.75rem;color:var(--text-tertiary)}.md-rule-severity{font-size:.7rem;padding:.15rem .5rem;border-radius:12px;border:1px solid;font-weight:600;text-transform:uppercase}.md-rule-desc{font-size:.82rem;color:var(--text-secondary);margin-bottom:.5rem;line-height:1.3}.md-rule-meta{display:flex;gap:1rem;font-size:.75rem;color:var(--text-tertiary);margin-bottom:.75rem;flex-wrap:wrap}.md-rule-meta span{display:flex;align-items:center;gap:.3rem}.md-rule-actions{display:flex;gap:.5rem;border-top:1px solid var(--border);padding-top:.75rem}.md-condition-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem;margin-top:.3rem}.md-condition-option{display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s;font-size:.82rem}.md-condition-option:hover{background:#ffffff0a}.md-condition-option.selected{background:#00d4aa14;border-width:2px}.md-condition-label{color:var(--text-primary);white-space:nowrap}.md-notify-grid{display:flex;gap:.5rem;flex-wrap:wrap}.md-notify-option{display:flex;align-items:center;gap:.4rem;padding:.4rem .7rem;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:.82rem;color:var(--text-secondary);transition:all .15s}.md-notify-option input{display:none}.md-notify-option.active{border-color:var(--accent);color:var(--accent);background:#00d4aa14}.md-modal-wide{max-width:700px}.form-section{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border)}.form-section-label{font-weight:600;font-size:.9rem;color:var(--text-primary);margin-bottom:.5rem;display:block}.form-hint-inline{font-weight:400;font-size:.75rem;color:var(--text-tertiary)}.form-row-group{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-row.inline{display:grid;grid-template-columns:140px 1fr;align-items:center;gap:.5rem;margin-bottom:.4rem}.form-row.inline label{font-size:.82rem;color:var(--text-secondary);margin-bottom:0}.md-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-secondary)}.md-empty-state h3{color:var(--text-primary);margin-bottom:.5rem}.md-stat-icon.access-control{background:#a855f726;color:#a855f7}.md-total-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:20px;font-size:13px;color:var(--text-secondary);white-space:nowrap}.md-total-pill span:first-of-type{font-weight:600;color:var(--text-primary)}.md-total-pill-label{font-weight:400}.md-total-pill svg{color:var(--accent)}.md-sync-dropdown-container{position:relative}.md-sync-btn{display:flex;align-items:center;gap:6px}.md-sync-btn svg:last-child{margin-left:2px}.md-sync-dropdown{position:absolute;top:calc(100% + 8px);left:0;width:320px;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 40px #0006;z-index:100;overflow:hidden}.md-sync-dropdown-header{padding:12px 16px;border-bottom:1px solid var(--border);font-weight:600;font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.md-sync-status-list{max-height:200px;overflow-y:auto}.md-sync-status-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:.5px solid var(--border);transition:background .15s ease}.md-sync-status-item:last-child{border-bottom:none}.md-sync-status-item:hover{background:var(--bg-page)}.md-sync-status-info{display:flex;flex-direction:column;gap:2px}.md-sync-status-name{font-weight:500;color:var(--text-primary);font-size:14px}.md-sync-status-type{font-size:12px;color:var(--text-tertiary)}.md-sync-status-count{font-size:13px;color:var(--accent);font-weight:500;padding:4px 10px;background:#00d4aa1a;border-radius:12px}.md-sync-empty{padding:24px 16px;text-align:center;color:var(--text-tertiary);font-size:13px}.md-sync-dropdown-footer{padding:12px 16px;border-top:1px solid var(--border);background:var(--bg-page)}.md-sync-dropdown-footer .btn{width:100%;justify-content:center}.device-badge.access_controller{background:#a855f726;color:#a855f7;border-color:#a855f74d}.md-sync-dropdown,.md-sync-dropdown-container{z-index:1100}.md-monitored-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#00d4aa26;color:var(--accent);border-radius:12px;font-size:12px;font-weight:500}.md-not-monitored{color:var(--text-tertiary)}tr:has(.md-monitored-badge){background:#00d4aa08}.md-protocol-badge{display:inline-flex;align-items:center;padding:1px 6px;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:3px;margin-left:4px;cursor:default;vertical-align:middle}.md-protocol-badge.onvif{background:#00d4aa1f;color:var(--accent);border:1px solid rgba(0,212,170,.2)}.md-protocol-badge.rtsp{background:#6366f11f;color:var(--accent);border:1px solid rgba(99,102,241,.2)}.md-model-cell{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary);font-size:.85rem}.md-selection-actions .btn-danger{background:#ff4d4d26;color:#ff4d4d;border:1px solid rgba(255,77,77,.3)}.md-selection-actions .btn-danger:hover{background:#ff4d4d40}.md-selection-actions .btn-danger:disabled{opacity:.5;cursor:not-allowed}.device-badge.editable{cursor:pointer;transition:background .2s,border-color .2s}.device-badge.editable:hover{border-color:var(--accent, var(--accent));background:#00d4aa1a}.edit-type-icon{margin-left:4px;opacity:0;transition:opacity .2s}.device-badge.editable:hover .edit-type-icon{opacity:.7}.md-type-modal{max-width:400px}.md-type-device-info{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.md-scan-progress{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:12px 16px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.md-scan-progress-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--text-primary);font-size:13px;font-weight:500}.md-scan-progress-bar{height:6px;background:var(--bg-page);border-radius:3px;overflow:hidden;margin-bottom:10px}.md-scan-progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#06b6d4);border-radius:3px;transition:width .5s ease}.md-scan-progress-fill.complete{background:linear-gradient(90deg,#22c55e,#14b8a6)}.md-scan-phases{display:flex;gap:4px;flex-wrap:wrap}.md-scan-phase{font-size:11px;padding:2px 8px;border-radius:4px;background:var(--bg-page);color:var(--text-tertiary);transition:all .3s ease}.md-scan-phase.active{background:#3b82f633;color:#3b82f6;font-weight:500}.md-scan-phase.done{background:#22c55e26;color:#22c55e}.md-stat-icon.all{color:#8b5cf6;background:#8b5cf626}.md-stat-icon.network{color:#f59e0b;background:#f59e0b26}.md-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:12px;color:var(--text-tertiary)}.md-spin{animation:md-spin 1s linear infinite}@keyframes md-spin{to{transform:rotate(360deg)}}.md-page{margin:0 auto}.md-agent-banner{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-radius:var(--radius-md);margin-bottom:20px;border:1px solid}.md-agent-banner.online{background:#22c55e14;border-color:#22c55e40}.md-agent-banner.offline{background:#ef444414;border-color:#ef444440}.md-agent-banner-left{display:flex;align-items:center;gap:10px}.md-agent-banner.online .md-agent-banner-left{color:#22c55e}.md-agent-banner.offline .md-agent-banner-left{color:#ef4444}.md-agent-banner-status{font-weight:600;font-size:13px}.md-agent-banner-name{color:var(--text-secondary);font-size:12px}.btn-ghost{background:transparent;border:none;color:var(--text-secondary);padding:6px 10px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;gap:4px;font-size:12px;font-family:var(--font-sans);transition:all .15s}.btn-ghost:hover{background:#ffffff0d;color:var(--text-primary)}.md-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.md-stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;display:flex;align-items:flex-start;gap:14px;transition:border-color .15s;box-shadow:var(--shadow-sm)}.md-stat-card:hover{border-color:#00d4aa4d}.md-stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.md-stat-content{display:flex;flex-direction:column;min-width:0}.md-stat-label{font-size:12px;color:var(--text-secondary);margin-bottom:2px}.md-stat-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1.1}.md-stat-total{font-size:16px;font-weight:400;color:var(--text-tertiary)}.md-stat-sub{font-size:11px;color:var(--text-secondary);margin-top:3px}.md-charts-row{display:grid;grid-template-columns:260px 1fr 1fr;gap:16px;margin-bottom:20px}.md-chart-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.md-chart-header{padding:12px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.md-chart-title{font-size:13px;font-weight:600;color:var(--text-primary)}.md-chart-subtitle{font-size:11px;color:var(--text-tertiary)}.md-chart-body{padding:14px 8px 8px}.md-chart-empty{display:flex;align-items:center;justify-content:center;height:160px;color:var(--text-tertiary);font-size:13px}.md-chart-tooltip{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:10px 14px;box-shadow:0 8px 32px #00000080}.md-chart-tooltip-label{font-size:11px;color:var(--text-tertiary);margin-bottom:6px}.md-chart-tooltip-item{font-size:12px;display:flex;align-items:center;gap:6px;margin-bottom:2px}.md-chart-tooltip-dot{width:8px;height:8px;border-radius:2px}.md-chart-legend{display:flex;flex-wrap:wrap;gap:4px 10px;padding:8px 14px 12px}.md-legend-item{font-size:10px;color:var(--text-tertiary);display:flex;align-items:center;gap:4px}.md-legend-dot{width:6px;height:6px;border-radius:2px;flex-shrink:0}.md-time-pills{display:flex;gap:2px;background:var(--bg-page);border-radius:6px;padding:2px}.md-time-pill{padding:3px 9px;border-radius:4px;font-size:11px;font-weight:600;border:none;cursor:pointer;font-family:var(--font-sans);background:transparent;color:var(--text-tertiary);transition:all .15s}.md-time-pill.active{background:var(--accent);color:var(--bg-page)}.md-time-pill:hover:not(.active){color:var(--text-secondary)}.md-health-gauge-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 16px}.md-health-gauge-wrapper{position:relative;width:100%;height:120px}.md-health-gauge-label{position:absolute;bottom:0;left:50%;transform:translate(-50%);text-align:center}.md-health-gauge-value{font-size:20px;font-weight:700;line-height:1;display:block}.md-health-gauge-text{font-size:11px;color:var(--text-tertiary);margin-top:2px;display:block}.md-health-status-row{display:flex;gap:20px;margin-top:16px}.md-health-status-item{text-align:center}.md-health-status-value{font-size:18px;font-weight:700;display:block}.md-health-status-label{font-size:10px;color:var(--text-tertiary)}.md-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.md-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.md-panel-header{padding:12px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.md-panel-title{font-size:13px;font-weight:600;color:var(--text-primary)}.md-panel-link{font-size:12px;color:var(--accent);background:none;border:none;cursor:pointer;font-family:var(--font-sans);display:flex;align-items:center;gap:2px}.md-panel-link:hover{text-decoration:underline}.md-panel-body{padding:4px 0}.md-panel-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px;color:var(--text-tertiary);font-size:13px}.md-alert-row{display:flex;align-items:center;gap:10px;padding:10px 18px;border-bottom:1px solid var(--border)}.md-alert-row:last-child{border-bottom:none}.md-alert-row-content{flex:1;min-width:0}.md-alert-row-title{font-size:13px;color:var(--text-primary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.md-alert-row-time{font-size:11px;color:var(--text-tertiary)}.md-device-row{display:flex;align-items:center;gap:10px;padding:10px 18px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.md-device-row:last-child{border-bottom:none}.md-device-row:hover{background:#ffffff05}.md-device-row-content{flex:1;min-width:0}.md-device-row-name{font-size:13px;color:var(--text-primary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.md-device-row-sub{font-size:11px;color:var(--text-tertiary)}.md-device-row-time{font-size:11px;color:var(--text-tertiary);white-space:nowrap}.md-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.md-status-dot.success{background:#22c55e;box-shadow:0 0 6px #22c55e66}.md-status-dot.danger{background:#ef4444}.md-status-dot.warning{background:#f59e0b}.md-status-dot.info{background:var(--accent-hover)}.md-severity-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:5px;font-size:11px;font-weight:600;border:1px solid;white-space:nowrap}.md-quick-actions{display:flex;gap:10px;flex-wrap:wrap}.md-quick-action{display:flex;align-items:center;gap:7px;padding:9px 16px;background:color-mix(in srgb,var(--action-color) 8%,transparent);border:1px solid color-mix(in srgb,var(--action-color) 20%,transparent);border-radius:8px;color:var(--action-color);font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:all .15s}.md-quick-action:hover{background:color-mix(in srgb,var(--action-color) 15%,transparent);border-color:color-mix(in srgb,var(--action-color) 40%,transparent)}.md-quick-action:disabled{opacity:.5;cursor:not-allowed}@media(max-width:1100px){.md-stat-grid{grid-template-columns:repeat(2,1fr)}.md-charts-row{grid-template-columns:1fr 1fr}.md-health-gauge-card{grid-column:span 2}}@media(max-width:768px){.md-stat-grid{grid-template-columns:repeat(2,1fr)}.md-charts-row{grid-template-columns:1fr}.md-health-gauge-card{grid-column:span 1}.md-two-col{grid-template-columns:1fr}.md-agent-banner{flex-direction:column;gap:10px;text-align:center}.md-agent-banner-left{flex-direction:column;gap:6px}.md-quick-actions{flex-direction:column}.md-quick-action{justify-content:center}}.md-license-banner{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-radius:var(--radius-lg);margin-bottom:20px;gap:12px;font-size:13px;border:1px solid}.md-license-banner.trial{background:linear-gradient(135deg,#00d4aa14,#a855f70f);border-color:#00d4aa40;color:var(--text-secondary)}.md-license-banner.trial strong{color:var(--accent)}.md-license-banner.trial.urgent{background:linear-gradient(135deg,#f59e0b1a,#ef44440f);border-color:#f59e0b59;color:#fbbf24}.md-license-banner.expired{background:linear-gradient(135deg,#ef44441a,#ef44440a);border-color:#ef444459;color:#f87171}.md-license-banner.no-license{background:#9ca3af14;border-color:#9ca3af33;color:var(--text-secondary)}.md-license-banner.warning{background:linear-gradient(135deg,#f59e0b1a,#f59e0b0a);border-color:#f59e0b4d;color:#fbbf24}.md-license-banner.info{background:#0ea5e914;border-color:#0ea5e940;color:#38bdf8}.md-license-banner-content{display:flex;align-items:center;gap:10px;flex:1}.md-license-banner-content svg{flex-shrink:0;opacity:.8}.md-license-banner-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.md-license-btn{display:flex;align-items:center;gap:5px;padding:6px 14px;border-radius:6px;border:none;cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font-sans);transition:all .15s}.md-license-btn.upgrade{background:var(--accent);color:#000;box-shadow:0 2px 8px #00d4aa40}.md-license-btn.upgrade:hover{filter:brightness(1.15);box-shadow:0 4px 12px #00d4aa59}.md-license-btn.dismiss{background:transparent;color:inherit;opacity:.5;padding:5px}.md-license-btn.dismiss:hover{opacity:1}@media(max-width:768px){.md-license-banner{flex-direction:column;text-align:center;gap:10px}.md-license-banner-content{flex-direction:column;gap:6px}}.md-lic-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.md-lic-stat{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;text-align:center;box-shadow:var(--shadow-sm)}.md-lic-stat-value{display:block;font-size:28px;font-weight:700;color:var(--text-primary);line-height:1}.md-lic-stat-label{display:block;font-size:12px;color:var(--text-tertiary);margin-top:6px}.md-lic-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.md-lic-search{display:flex;align-items:center;gap:8px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 12px;flex:1;max-width:320px}.md-lic-search svg{color:var(--text-tertiary);flex-shrink:0}.md-lic-search input{background:none;border:none;color:var(--text-primary);font-size:13px;width:100%;outline:none}.md-lic-search input::placeholder{color:var(--text-tertiary)}.md-lic-table-wrap{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.md-lic-table{width:100%;border-collapse:collapse}.md-lic-table thead th{background:var(--bg-page);padding:10px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);text-align:left;border-bottom:1px solid var(--border)}.md-lic-table tbody td{padding:14px 16px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--border);vertical-align:middle}.md-lic-table tbody tr:last-child td{border-bottom:none}.md-lic-table tbody tr:hover{background:#ffffff05}.md-lic-tenant{display:flex;flex-direction:column;gap:2px}.md-lic-tenant-name{font-weight:600;color:var(--text-primary)}.md-lic-tenant-id{font-size:11px;color:var(--text-tertiary);font-family:monospace}.md-lic-sku{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;background:#00d4aa26;color:var(--accent);text-transform:uppercase;letter-spacing:.3px}.md-lic-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.md-lic-trial-days{font-size:10px;font-weight:400;opacity:.8;text-transform:none}.md-lic-usage{display:flex;flex-direction:column;gap:4px;min-width:100px}.md-lic-over{color:#ef4444;font-weight:600}.md-lic-bar{height:4px;background:var(--bg-page);border-radius:2px;overflow:hidden}.md-lic-bar-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .3s}.md-lic-bar-fill.warn{background:#f59e0b}.md-lic-bar-fill.over{background:#ef4444}.md-lic-actions{display:flex;gap:6px}.md-lic-form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media(max-width:1024px){.md-lic-stats{grid-template-columns:repeat(2,1fr)}.md-lic-form-row{grid-template-columns:1fr}}@media(max-width:768px){.md-lic-stats{grid-template-columns:1fr}.md-lic-toolbar{flex-direction:column;align-items:stretch}.md-lic-search{max-width:none}.md-lic-table-wrap{overflow-x:auto}}.md-alert-stats{display:flex;gap:16px;margin-bottom:20px}.md-alert-stat{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 20px;text-align:center;cursor:pointer;transition:border-color .15s;min-width:100px;box-shadow:var(--shadow-sm)}.md-alert-stat:hover{border-color:var(--accent)}.md-alert-stat-value{font-size:24px;font-weight:700;display:block;line-height:1.1}.md-alert-stat-label{font-size:11px;color:var(--text-tertiary);margin-top:2px;display:block}.md-filter-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px}.md-filter-pills{display:flex;gap:6px}.md-filter-pill{padding:7px 14px;border-radius:6px;font-size:12px;font-weight:500;border:none;cursor:pointer;font-family:var(--font-sans);background:var(--bg-page);color:var(--text-secondary);transition:all .15s;display:flex;align-items:center;gap:6px}.md-filter-pill.active{background:var(--accent);color:var(--bg-page)}.md-filter-pill:hover:not(.active){background:var(--bg-surface)}.md-filter-badge{background:#fff3;padding:1px 6px;border-radius:10px;font-size:10px;font-weight:700}.md-filter-pill.active .md-filter-badge{background:#0003}.md-search-box{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;min-width:240px;box-shadow:var(--shadow-sm)}.md-search-box svg{color:var(--text-tertiary);flex-shrink:0}.md-search-box input{background:none;border:none;color:var(--text-primary);font-size:13px;font-family:var(--font-sans);outline:none;width:100%}.md-search-box input::placeholder{color:var(--text-tertiary)}.md-alert-list{display:flex;flex-direction:column;gap:8px}.md-alert-item{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 18px;display:flex;align-items:center;gap:14px;transition:border-color .15s;box-shadow:var(--shadow-sm)}.md-alert-item.critical{border-color:#ef44444d}.md-alert-item-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.md-alert-item-icon[data-severity=CRITICAL]{background:#ef44441f;color:#ef4444}.md-alert-item-icon[data-severity=WARNING]{background:#f59e0b1f;color:#f59e0b}.md-alert-item-icon[data-severity=INFO]{background:#0ea5e91f;color:var(--accent-hover)}.md-alert-item-content{flex:1;min-width:0}.md-alert-item-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.md-alert-item-meta{font-size:12px;color:var(--text-tertiary)}.md-alert-batch-badge{display:inline-block;margin-left:8px;padding:1px 7px;background:#ef444426;border-radius:4px;font-size:10px;color:#ef4444;font-weight:600}.md-alert-item-actions{flex-shrink:0}.md-alert-resolved-badge{display:flex;align-items:center;gap:4px;font-size:12px;color:#22c55e}.btn-sm{padding:6px 12px!important;font-size:12px!important}.md-agents-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.md-agents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:16px}.md-agent-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:border-color .15s;box-shadow:var(--shadow-sm)}.md-agent-card.online{border-color:#22c55e40}.md-agent-card.offline{border-color:var(--border)}.md-agent-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.md-agent-card-title-row{display:flex;align-items:center;gap:12px}.md-agent-card-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.md-agent-card-icon[data-status=online]{background:#22c55e1f;color:#22c55e}.md-agent-card-icon[data-status=offline]{background:#ef44441f;color:#ef4444}.md-agent-card-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.md-agent-card-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-tertiary)}.md-agent-card-actions{display:flex;gap:4px}.md-icon-btn{width:32px;height:32px;border-radius:6px;background:var(--bg-page);border:1px solid var(--border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.md-icon-btn:hover{background:var(--bg-surface);color:var(--text-primary)}.md-icon-btn.danger:hover{background:#ef44441f;color:#ef4444;border-color:#ef44444d}.md-agent-card-details{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.md-agent-detail{background:var(--bg-surface);border-radius:6px;padding:8px 12px;box-shadow:var(--shadow-sm)}.md-agent-detail-label{font-size:10px;color:var(--text-tertiary);display:block;margin-bottom:2px}.md-agent-detail-value{font-size:13px;font-weight:500;color:var(--text-primary)}.md-agent-detail-value.mono{font-family:var(--font-mono);font-size:12px}.md-agent-pairing-code{display:flex;align-items:center;gap:10px;margin-top:14px;padding:10px 14px;background:#00d4aa14;border:1px solid rgba(0,212,170,.2);border-radius:8px}.md-pairing-label{font-size:12px;color:var(--text-secondary)}.md-pairing-value{font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--accent);letter-spacing:2px}.md-pairing-display{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;background:var(--bg-page);border:1px solid var(--border);border-radius:10px;margin:16px 0}.md-pairing-display code{font-family:var(--font-mono);font-size:28px;font-weight:700;color:var(--accent);letter-spacing:4px}.md-pairing-instructions{margin:16px 0;display:flex;flex-direction:column;gap:10px}.md-pairing-step{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-secondary)}.md-pairing-step span:first-child{width:24px;height:24px;border-radius:50%;background:var(--accent);color:var(--bg-page);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.md-pairing-step code{font-family:var(--font-mono);font-size:12px;padding:2px 8px;background:var(--bg-page);border-radius:4px;color:var(--accent)}.md-empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:64px 32px;text-align:center;color:var(--text-tertiary);grid-column:1 / -1}.md-empty-state h3{color:var(--text-primary);font-size:18px;font-weight:600}.md-empty-state p{font-size:14px;max-width:400px}.md-health-device-row{display:flex;align-items:center;gap:14px;padding:12px 18px;border-bottom:1px solid var(--border)}.md-health-device-row:last-child{border-bottom:none}.md-health-device-info{flex:1;min-width:0}.md-health-device-name{font-size:13px;font-weight:500;color:var(--text-primary);display:block}.md-health-device-sub{font-size:11px;color:var(--text-tertiary)}.md-health-device-status{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-tertiary);min-width:90px}.md-health-bar-container{width:80px}.md-health-bar{width:100%;height:6px;border-radius:3px;background:var(--bg-page);overflow:hidden}.md-health-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.md-health-score{font-size:13px;font-weight:600;width:40px;text-align:right}@media(max-width:768px){.md-alert-stats{flex-wrap:wrap}.md-alert-stat{flex:1;min-width:80px}.md-filter-bar{flex-direction:column;align-items:stretch}.md-filter-pills{flex-wrap:wrap}.md-agents-summary,.md-agents-grid{grid-template-columns:1fr}.md-agent-card-details{grid-template-columns:repeat(2,1fr)}.md-health-device-row{flex-wrap:wrap;gap:8px}}.md-downloads-section{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.md-downloads-header{margin-bottom:1.25rem}.md-downloads-title{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 4px}.md-downloads-subtitle{font-size:.85rem;color:var(--text-secondary);margin:0}.md-downloads-loading{display:flex;align-items:center;gap:8px;color:var(--text-secondary);padding:1rem 0}.md-downloads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;margin-bottom:1.25rem}.md-download-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-page);border:1px solid var(--border);border-radius:10px;transition:border-color .2s}.md-download-card:hover{border-color:#fff3}.md-download-card.unavailable{opacity:.5;pointer-events:none}.md-download-card-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#ffffff0d}.md-download-card-info{flex:1;min-width:0;display:flex;flex-direction:column}.md-download-card-label{font-weight:500;font-size:.9rem;color:var(--text-primary)}.md-download-card-meta{font-size:.75rem;color:var(--text-secondary)}.md-downloads-instructions{background:var(--bg-page);border:1px solid var(--border);border-radius:10px;padding:1rem 1.25rem}.md-downloads-instructions h4{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0 0 10px}.md-downloads-steps{display:flex;flex-direction:column;gap:8px}.btn-sm{padding:6px 12px;font-size:.8rem;white-space:nowrap}@media(max-width:600px){.md-downloads-grid{grid-template-columns:1fr}}.md-dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.md-dashboard-stat-card{display:flex;align-items:center;gap:14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg, 12px);padding:18px 20px;transition:all .2s ease;box-shadow:var(--shadow-sm)}.md-dashboard-stat-card:hover{border-color:var(--border-hover, #3a4a5d)}.md-dashboard-stat-icon{width:44px;height:44px;border-radius:var(--radius-md, 8px);background:#64748b26;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.md-dashboard-stat-icon.online{background:#00d4aa1f;color:var(--accent)}.md-dashboard-stat-icon.alert{background:#ef44441f;color:var(--accent-danger, #ef4444)}.md-dashboard-stat-icon.disabled{background:#64748b1f;color:var(--text-tertiary)}.md-dashboard-stat-content{flex:1;min-width:0}.md-dashboard-stat-label{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.md-dashboard-stat-value{font-size:24px;font-weight:700;color:var(--text-primary);line-height:1.1}.md-dashboard-stat-value .text-success{color:var(--accent)}.md-dashboard-stat-total{font-size:16px;font-weight:500;color:var(--text-tertiary)}.md-dashboard-stat-sub{font-size:12px;color:var(--text-tertiary);margin-top:2px}@media(max-width:1024px){.md-dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.md-dashboard-stats{grid-template-columns:1fr}.md-dashboard-stat-card{padding:14px 16px}.md-dashboard-stat-value{font-size:20px}}.md-rules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;margin-top:20px}.md-rule-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg, 12px);padding:18px;transition:all .2s ease;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-sm)}.md-rule-card:hover{border-color:var(--border-hover, #3a4a5d);box-shadow:0 4px 20px #0000004d}.md-rule-card.disabled{opacity:.6}.md-rule-card.disabled:hover{opacity:.75}.md-rule-header{display:flex;align-items:flex-start;gap:12px}.md-rule-icon{width:40px;height:40px;border-radius:var(--radius-md, 8px);background:#ffffff0d;display:flex;align-items:center;justify-content:center;flex-shrink:0}.md-rule-info{flex:1;min-width:0}.md-rule-name{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.md-rule-type{font-size:12px;color:var(--text-tertiary)}.md-rule-severity{padding:3px 10px;border-radius:12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid;flex-shrink:0}.md-rule-desc{font-size:13px;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.md-rule-meta{display:flex;flex-wrap:wrap;gap:12px;padding-top:8px;border-top:1px solid var(--border)}.md-rule-meta span{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-tertiary)}.md-rule-meta svg{opacity:.7}.md-rule-actions{display:flex;gap:8px;margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}.md-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:8px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-sm, 6px);color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s ease}.md-action-btn:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-hover, #3a4a5d);box-shadow:var(--shadow-sm)}.md-action-btn.danger:hover{background:#ef44441a;border-color:#ef44444d;color:var(--accent-danger, #ef4444)}.alert-condition-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.alert-condition-card{display:flex;align-items:flex-start;gap:14px;padding:16px;background:var(--bg-page);border:2px solid var(--border);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all .2s ease;position:relative}.alert-condition-card:hover{background:var(--bg-surface);border-color:var(--text-tertiary);box-shadow:var(--shadow-sm)}.alert-condition-card.selected{background:#00d4aa0a}.alert-condition-icon{width:44px;height:44px;border-radius:var(--radius-md, 8px);background:#ffffff0d;display:flex;align-items:center;justify-content:center;flex-shrink:0}.alert-condition-info{flex:1;min-width:0}.alert-condition-label{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.alert-condition-desc{font-size:12px;color:var(--text-tertiary);line-height:1.4}.alert-condition-check{position:absolute;top:10px;right:10px;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.wizard-params-section{background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md, 8px);padding:16px;margin-bottom:16px}.wizard-params-section>.wizard-label{margin-bottom:12px;font-size:13px;font-weight:600;color:var(--text-secondary)}.wizard-params-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}.wizard-param-field{display:flex;flex-direction:column;gap:6px}.wizard-param-field label{font-size:12px;color:var(--text-tertiary)}.wizard-param-input-wrap{display:flex;align-items:center;gap:8px}.wizard-param-input-wrap .wizard-input{flex:1}.wizard-param-unit{font-size:12px;color:var(--text-tertiary);white-space:nowrap}.wizard-hint{font-size:11px;color:var(--text-tertiary);margin-top:4px}.wizard-severity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.wizard-severity-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 12px;background:var(--bg-surface);border:2px solid var(--border);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all .2s ease;text-align:center;box-shadow:var(--shadow-sm)}.wizard-severity-card:hover{border-color:var(--text-tertiary)}.wizard-severity-card.selected{background:#ffffff08}.wizard-severity-dot{width:12px;height:12px;border-radius:50%}.wizard-severity-card strong{font-size:13px;color:var(--text-primary)}.wizard-severity-card span{font-size:10px;color:var(--text-tertiary);line-height:1.3}.wizard-notify-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.wizard-notify-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--bg-page);border:2px solid var(--border);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all .2s ease;position:relative}.wizard-notify-card:hover{background:var(--bg-surface);border-color:var(--text-tertiary);box-shadow:var(--shadow-sm)}.wizard-notify-card.active{border-color:var(--accent);background:#00d4aa0a}.wizard-notify-card input[type=checkbox]{display:none}.wizard-notify-card>svg{color:var(--text-tertiary);flex-shrink:0;margin-top:2px}.wizard-notify-card.active>svg{color:var(--accent)}.wizard-notify-info{flex:1}.wizard-notify-info strong{display:block;font-size:14px;color:var(--text-primary);margin-bottom:2px}.wizard-notify-info span{font-size:11px;color:var(--text-tertiary);line-height:1.4}.wizard-notify-check{width:22px;height:22px;border-radius:50%;background:var(--bg-surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:transparent;flex-shrink:0;box-shadow:var(--shadow-sm)}.wizard-notify-card.active .wizard-notify-check{background:var(--accent);border-color:var(--accent);color:#000}.wizard-badge.success{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.wizard-badge.muted{background:#94a3b81a;color:var(--text-tertiary);border:1px solid rgba(148,163,184,.2)}@media(max-width:768px){.md-rules-grid,.alert-condition-grid,.wizard-severity-grid,.wizard-notify-grid,.wizard-params-grid{grid-template-columns:1fr}}.md-dashboard-stats{margin-top:20px}.md-rules-grid,.md-empty-state{margin-top:24px}.md-rule-notify-icons{display:flex;align-items:center;gap:.4rem;margin-left:auto}.md-rule-notify-icons>span{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;background:#ffffff0d;color:var(--text-tertiary);transition:all .15s}.md-rule-notify-icons>span:hover{background:#ffffff1a;color:var(--text-primary)}.md-rule-notify-icons .notify-email{color:#60a5fa}.md-rule-notify-icons .notify-slack{color:#e01e5a}.md-rule-notify-icons .notify-webhook{color:#a78bfa}.md-rule-notify-icons .notify-push{color:#34d399}.md-monitored-table-container{overflow-x:hidden}.md-monitored-table-container .md-devices-table{table-layout:fixed;width:100%}.md-monitored-table-container .md-devices-table th,.md-monitored-table-container .md-devices-table td{padding:10px 12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.md-monitored-table-container .md-devices-table th:nth-child(1),.md-monitored-table-container .md-devices-table td:nth-child(1){width:22%}.md-monitored-table-container .md-devices-table th:nth-child(2),.md-monitored-table-container .md-devices-table td:nth-child(2){width:14%}.md-monitored-table-container .md-devices-table th:nth-child(3),.md-monitored-table-container .md-devices-table td:nth-child(3){width:9%}.md-monitored-table-container .md-devices-table th:nth-child(4),.md-monitored-table-container .md-devices-table td:nth-child(4){width:10%}.md-monitored-table-container .md-devices-table th:nth-child(5),.md-monitored-table-container .md-devices-table td:nth-child(5){width:8%}.md-monitored-table-container .md-devices-table th:nth-child(6),.md-monitored-table-container .md-devices-table td:nth-child(6){width:13%}.md-monitored-table-container .md-devices-table th:nth-child(7),.md-monitored-table-container .md-devices-table td:nth-child(7){width:9%}.md-monitored-table-container .md-devices-table th:nth-child(8),.md-monitored-table-container .md-devices-table td:nth-child(8){width:15%}.md-monitored-table-container .md-action-btns{display:flex;gap:4px;flex-wrap:nowrap}.md-monitored-table-container .md-action-btn{width:28px;height:28px;min-width:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease}.md-monitored-table-container .md-action-btn:hover{background:#ffffff14;color:var(--text-primary);border-color:#ffffff26}.md-monitored-table-container .md-action-btn.danger:hover{background:#ef444426;color:#f87171;border-color:#ef44444d}.md-monitored-table-container .md-devices-table td:first-child{font-weight:500;color:var(--text-primary)}.md-monitored-table-container .md-devices-table td:nth-child(2){font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:12px}@media(max-width:1100px){.md-monitored-table-container .md-devices-table th:nth-child(7),.md-monitored-table-container .md-devices-table td:nth-child(7){display:none}.md-monitored-table-container .md-devices-table th:nth-child(1),.md-monitored-table-container .md-devices-table td:nth-child(1){width:24%}.md-monitored-table-container .md-devices-table th:nth-child(2),.md-monitored-table-container .md-devices-table td:nth-child(2){width:16%}.md-monitored-table-container .md-devices-table th:nth-child(8),.md-monitored-table-container .md-devices-table td:nth-child(8){width:16%}}@media(max-width:900px){.md-monitored-table-container .md-devices-table th:nth-child(5),.md-monitored-table-container .md-devices-table td:nth-child(5),.md-monitored-table-container .md-devices-table th:nth-child(6),.md-monitored-table-container .md-devices-table td:nth-child(6){display:none}.md-monitored-table-container .md-devices-table th:nth-child(1),.md-monitored-table-container .md-devices-table td:nth-child(1){width:30%}.md-monitored-table-container .md-devices-table th:nth-child(2),.md-monitored-table-container .md-devices-table td:nth-child(2){width:22%}.md-monitored-table-container .md-devices-table th:nth-child(3),.md-monitored-table-container .md-devices-table td:nth-child(3){width:12%}.md-monitored-table-container .md-devices-table th:nth-child(4),.md-monitored-table-container .md-devices-table td:nth-child(4){width:14%}.md-monitored-table-container .md-devices-table th:nth-child(8),.md-monitored-table-container .md-devices-table td:nth-child(8){width:22%}}.md-mobile-cards{display:none}@media(max-width:768px){.md-mobile-cards{display:flex;flex-direction:column;gap:8px}.md-table-container.md-monitored-table-container{display:none!important}.page-header-with-actions{flex-direction:column!important;align-items:stretch!important;gap:12px!important}.page-header-actions{display:flex;gap:8px;flex-wrap:wrap}.page-header-actions .btn{flex:1;min-width:0;font-size:13px;padding:8px 12px!important;white-space:nowrap}.page-content .md-stats-grid{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}.md-stat-card{padding:10px!important}.md-stat-icon{width:36px!important;height:36px!important}.md-stat-icon svg{width:18px!important;height:18px!important}.md-stat-value{font-size:18px!important}.md-stat-label{font-size:11px!important}.md-filters{flex-direction:column!important;gap:8px!important}.md-search{min-width:100%!important}.md-filters .form-select{width:100%!important}.card{overflow:hidden!important}.page-content{overflow-x:hidden;max-width:100vw}}.md-mobile-card{border:1px solid rgba(255,255,255,.08);border-radius:10px;background:#ffffff05;cursor:pointer;transition:border-color .15s;overflow:hidden}.md-mobile-card:hover{border-color:#ffffff26}.md-mobile-card.expanded{border-color:#00d4aa33}.md-mcard-main{padding:14px}.md-mcard-row1{display:flex;align-items:center;gap:8px;margin-bottom:4px}.md-mcard-name-wrap{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.md-mcard-name-col{display:flex;flex-direction:column;min-width:0}.md-mcard-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.md-mcard-group{font-size:11px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.md-mcard-chevron{color:#fff3;flex-shrink:0;transition:transform .25s ease}.md-mcard-chevron.open{transform:rotate(180deg);color:var(--accent)}.md-mcard-row2{display:flex;align-items:center;gap:6px;padding-left:24px}.md-mcard-row2 code{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:12px;color:var(--text-tertiary)}.md-mcard-expand{max-height:0;overflow:hidden;transition:max-height .25s ease}.md-mcard-expand.open{max-height:300px}.md-mcard-details{padding:12px 14px;border-top:1px solid rgba(255,255,255,.04);display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}.md-mcard-detail{display:flex;flex-direction:column;gap:1px}.md-mcard-detail-label{font-size:11px;color:var(--text-tertiary)}.md-mcard-detail-value{font-size:13px;color:var(--text-secondary)}.md-mcard-actions{grid-column:1 / -1;display:flex;gap:8px;justify-content:flex-end;margin-top:6px;padding-top:10px;border-top:1px solid rgba(255,255,255,.04)}.md-mcard-action-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:transparent;color:var(--text-tertiary);font-size:12px;cursor:pointer;transition:all .15s}.md-mcard-action-btn:hover,.md-mcard-action-btn:active{background:#ffffff0f;color:var(--text-primary);border-color:#fff3}.md-mcard-action-btn.danger{color:var(--accent-danger, #f87171);border-color:#ef444433}.md-mcard-action-btn.danger:hover,.md-mcard-action-btn.danger:active{background:#ef44441a;border-color:#ef44444d}.md-monitored-table-container .md-devices-table td:nth-child(3){overflow:visible}@media(max-width:400px){.page-header-actions .btn{font-size:12px;padding:7px 10px!important}.md-mcard-main{padding:12px}.md-mcard-details{padding:10px 12px}}.md-cred-stats{display:flex;gap:10px;margin-bottom:24px;overflow-x:auto;padding-bottom:4px}.md-cred-stat{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-surface));border:1px solid var(--border);border-left:3px solid;border-radius:8px;min-width:120px;flex-shrink:0;box-shadow:var(--shadow-sm)}.md-cred-stat-icon{display:flex;align-items:center}.md-cred-stat-info{display:flex;flex-direction:column}.md-cred-stat-value{font-size:18px;font-weight:700;color:var(--text-primary);line-height:1}.md-cred-stat-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px}.md-cred-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px}.md-cred-card{background:var(--bg-surface));border:1px solid var(--border);border-radius:10px;padding:16px;transition:border-color .15s ease;box-shadow:var(--shadow-sm)}.md-cred-card:hover{border-color:#ffffff1f}.md-cred-card.disabled{opacity:.5}.md-cred-card-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.md-cred-card-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.md-cred-card-title{flex:1;min-width:0}.md-cred-card-label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.md-cred-card-protocol{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.md-cred-disabled-badge{font-size:10px;padding:2px 8px;border-radius:4px;background:#ef44441f;color:#f87171;text-transform:uppercase;font-weight:600;letter-spacing:.3px}.md-cred-card-actions{display:flex;gap:4px;flex-shrink:0}.md-cred-card-desc{font-size:12px;color:var(--text-tertiary);margin:0 0 10px;padding-left:48px}.md-cred-card-fields{display:flex;flex-wrap:wrap;gap:8px 16px;padding:10px 12px;background:var(--border-strong);border-radius:6px;margin-top:8px}.md-cred-field{display:flex;flex-direction:column;gap:2px;min-width:100px}.md-cred-field-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px}.md-cred-field-value{font-size:13px;color:var(--text-secondary);font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;display:flex;align-items:center;gap:6px}.md-eye-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px;display:inline-flex;transition:color .15s ease}.md-eye-btn:hover{color:var(--text-primary)}.md-delete-confirm{display:flex;gap:4px}.md-cred-card .md-action-btn{width:28px;height:28px;min-width:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease}.md-cred-card .md-action-btn:hover{background:#ffffff14;color:var(--text-primary)}.md-cred-card .md-action-btn.danger:hover{background:#ef444426;color:#f87171}.md-empty-state{text-align:center;padding:60px 20px;color:var(--text-tertiary)}.md-empty-state h3{color:var(--text-primary);margin:16px 0 8px}.md-empty-state p{margin-bottom:20px;max-width:400px;margin-left:auto;margin-right:auto}.md-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:60px 20px;color:var(--text-tertiary)}.md-cred-modal{max-width:520px;width:95vw}.md-cred-proto-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.md-cred-proto-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;border-radius:8px;border:1px solid var(--border);background:transparent;cursor:pointer;transition:all .15s ease;color:var(--text-tertiary)}.md-cred-proto-btn:hover{border-color:#ffffff26;background:#ffffff08}.md-cred-proto-btn.active{color:var(--text-primary)}.md-cred-proto-label{font-size:11px;font-weight:600}.md-cred-proto-desc{font-size:12px;color:var(--text-tertiary);margin:0 0 16px;text-align:center}.md-cred-input-wrap{position:relative}@media(max-width:640px){.md-cred-stats{gap:8px}.md-cred-stat{min-width:100px;padding:8px 10px}.md-cred-list{grid-template-columns:1fr}.md-cred-proto-grid{grid-template-columns:repeat(2,1fr)}.md-cred-card-desc{padding-left:0}.md-cred-modal{max-width:100%}}.pending-loading{padding:20px;text-align:center;color:var(--text-secondary)}.pending-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.pending-title{margin:0;display:flex;align-items:center;gap:8px}.pending-count{background:#f59e0b;color:#000;padding:2px 8px;border-radius:12px;font-size:12px;margin-left:8px}.pending-actions{display:flex;gap:8px}.wave-users-info{color:var(--text-secondary);font-size:12px;margin-bottom:16px}.pending-empty{text-align:center;padding:40px;color:var(--text-secondary)}.pending-empty svg{opacity:.3;margin-bottom:16px}.pending-empty-hint{font-size:13px;color:var(--text-tertiary)}.status-badge-pending{background:#f59e0b;color:#000;padding:2px 6px;border-radius:4px;font-size:10px}.oauth-badge{color:var(--bg-surface);padding:2px 6px;border-radius:4px;font-size:10px}.oauth-badge.microsoft{background:#0078d4}.oauth-badge.google{background:#4285f4}.pending-user-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:16px;margin-bottom:12px}.pending-user-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.pending-user-info{display:flex;align-items:center;gap:8px;margin-bottom:4px}.pending-user-info svg{color:#10b981}.pending-user-name{font-weight:500}.pending-user-email{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:14px}.pending-user-date{display:flex;align-items:center;gap:8px;color:var(--text-tertiary);font-size:12px}.pending-settings-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.pending-field{flex:1;min-width:200px}.pending-field.role-field{flex:0;min-width:120px}.pending-field-label{font-size:12px;color:var(--text-secondary);margin-bottom:4px;display:block}.pending-field-label svg{display:inline;margin-right:4px}.pending-field select{width:100%}.advanced-settings-toggle,.advanced-settings-toggle.expanded{margin-bottom:12px}.advanced-settings-panel{background:#0003;padding:16px;border-radius:6px;margin-bottom:12px}.advanced-settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.settings-section h5{margin:0 0 8px;font-size:14px}.settings-section h5.wave{color:#10b981}.settings-section h5.feenics{color:#3b82f6}.settings-section h5.intercom{color:#f59e0b}.settings-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;margin-bottom:8px}.settings-checkbox:last-child{margin-bottom:0}.denial-section{background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:6px;padding:12px;margin-bottom:12px}.denial-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.denial-header svg{color:#ef4444}.denial-header span{font-size:12px;color:#ef4444;font-weight:500}.denial-options{display:flex;gap:12px;flex-wrap:wrap}.denial-select{flex:1;min-width:200px}.denial-select select{width:100%;font-size:13px}.denial-custom{flex:2;min-width:250px}.denial-custom input{font-size:13px;width:100%}.denial-preview{font-size:12px;color:var(--text-secondary);margin-top:8px;margin-bottom:0}.pending-actions-row{display:flex;gap:8px;justify-content:flex-end}.pending-actions-row .btn{display:flex;align-items:center;gap:4px}@media(max-width:768px){.pending-header{flex-direction:column;align-items:flex-start;gap:12px}.pending-actions{width:100%}.pending-actions .btn{flex:1;justify-content:center}.pending-user-header{flex-direction:column;gap:8px}.pending-settings-row{flex-direction:column;align-items:stretch}.pending-field,.pending-field.role-field{min-width:100%}.advanced-settings-grid{grid-template-columns:1fr}.denial-options{flex-direction:column}.denial-select,.denial-custom{min-width:100%}.pending-actions-row{flex-direction:column}.pending-actions-row .btn{width:100%;justify-content:center}}.wizard-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1100;padding:16px;animation:wizardFadeIn .2s ease}@keyframes wizardFadeIn{0%{opacity:0}to{opacity:1}}.wizard-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl, 16px);width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0009;animation:wizardSlideUp .25s ease}@keyframes wizardSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.wizard-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.wizard-header-left{display:flex;align-items:center;gap:10px;color:var(--accent)}.wizard-header h2{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;text-align:left}.wizard-close{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:6px;border-radius:var(--radius-sm, 4px);transition:all .15s ease}.wizard-close:hover{background:var(--bg-page);color:var(--text-primary)}.wizard-stepper{display:flex;align-items:center;padding:16px 24px;gap:4px;border-bottom:1px solid var(--border);overflow-x:auto}.wizard-stepper-item{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:20px;cursor:default;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.wizard-stepper-item.completed{cursor:pointer}.wizard-stepper-item.completed:hover{background:#00d4aa14}.wizard-stepper-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;background:var(--bg-page);border:2px solid var(--border);color:var(--text-tertiary);transition:all .2s ease;flex-shrink:0}.wizard-stepper-item.active .wizard-stepper-dot{background:var(--accent);border-color:var(--accent);color:#000}.wizard-stepper-item.completed .wizard-stepper-dot{background:#00d4aa26;border-color:var(--accent);color:var(--accent)}.wizard-stepper-label{font-size:12px;font-weight:500;color:var(--text-tertiary);transition:color .2s ease}.wizard-stepper-item.active .wizard-stepper-label{color:var(--text-primary)}.wizard-stepper-item.completed .wizard-stepper-label{color:var(--accent)}.wizard-body{flex:1;overflow-y:auto;padding:24px;min-height:300px}.wizard-step-content{animation:wizardStepFade .2s ease}@keyframes wizardStepFade{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.wizard-step-desc{color:var(--text-secondary);font-size:14px;margin-bottom:20px;line-height:1.5}.wizard-step-desc strong{color:var(--text-primary)}.wizard-user-card{display:flex;align-items:center;gap:16px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-lg, 12px);padding:16px;margin-bottom:20px}.wizard-user-avatar{width:52px;height:52px;border-radius:50%;background:#00d4aa1f;color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.wizard-user-details{flex:1;min-width:0}.wizard-user-details h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 6px}.wizard-user-meta{display:flex;flex-direction:column;gap:4px}.wizard-user-meta span{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.wizard-badge{padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.wizard-badge.pending{background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.wizard-badge.small{font-size:10px;padding:2px 6px;background:#94a3b81a;color:var(--text-secondary)}.wizard-badge.role{font-size:11px}.wizard-badge.role.admin{background:#ef44441f;color:#f87171}.wizard-badge.role.operator{background:#0ea5e91f;color:#38bdf8}.wizard-badge.role.viewer{background:#94a3b81f;color:var(--text-secondary)}.wizard-info-box{display:flex;gap:12px;padding:14px 16px;background:#0ea5e90f;border:1px solid rgba(14,165,233,.15);border-radius:var(--radius-md, 8px);margin-bottom:20px;color:var(--accent))}.wizard-info-box strong{display:block;font-size:13px;margin-bottom:4px;color:var(--text-primary)}.wizard-info-box p{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.wizard-checklist{background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md, 8px);padding:16px}.wizard-checklist h4{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.wizard-checklist-item{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:14px;color:var(--text-secondary)}.wizard-checklist-item:last-child{padding-bottom:0}.wizard-check{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:1px solid var(--border);font-size:11px;font-weight:600;color:var(--text-tertiary);flex-shrink:0;box-shadow:var(--shadow-sm)}.wizard-check.done{background:#00d4aa26;border-color:var(--accent);color:var(--accent)}.wizard-field{margin-bottom:20px}.wizard-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.wizard-select,.wizard-input{width:100%;padding:10px 12px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md, 8px);color:var(--text-primary);font-size:14px;font-family:var(--font-sans, "Plus Jakarta Sans", sans-serif);transition:border-color .15s ease;outline:none}.wizard-select:focus,.wizard-input:focus{border-color:var(--accent)}.wizard-select.compact{padding:7px 10px;font-size:13px}.wizard-select option{background:var(--bg-surface)}.wizard-role-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.wizard-role-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;background:var(--bg-page);border:2px solid var(--border);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all .2s ease;text-align:center;color:var(--text-secondary)}.wizard-role-card:hover{border-color:var(--text-tertiary);background:var(--bg-surface)}.wizard-role-card.selected{border-color:var(--accent);background:#00d4aa0f}.wizard-role-card.selected svg{color:var(--accent)}.wizard-role-card strong{font-size:14px;color:var(--text-primary)}.wizard-role-card span{font-size:11px;line-height:1.4;color:var(--text-tertiary)}.wizard-role-card.selected strong{color:var(--accent)}.wizard-site-add{display:flex;gap:8px}.wizard-site-add .wizard-select{flex:1}.wizard-site-list{display:flex;flex-direction:column;gap:8px;margin-top:16px}.wizard-site-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md, 8px)}.wizard-site-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0;color:var(--text-primary)}.wizard-site-info svg{color:var(--accent);flex-shrink:0}.wizard-site-info strong{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wizard-site-row .wizard-select.compact{width:130px;flex-shrink:0}.wizard-remove-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;border-radius:var(--radius-sm, 4px);transition:all .15s ease;flex-shrink:0}.wizard-remove-btn:hover{background:#ef44441a;color:var(--accent-danger, #ef4444)}.wizard-empty-state{text-align:center;padding:32px 16px;color:var(--text-tertiary)}.wizard-empty-state svg{opacity:.3;margin-bottom:12px}.wizard-empty-state p{font-size:14px;margin-bottom:4px;color:var(--text-secondary)}.wizard-empty-state span{font-size:13px}.wizard-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--text-secondary);font-size:14px}.wizard-integration-list{display:flex;flex-direction:column;gap:16px}.wizard-integration-site{background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md, 8px);padding:14px 16px}.wizard-integration-site-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:var(--text-primary)}.wizard-integration-site-header svg{color:var(--accent)}.wizard-integration-site-header strong{font-size:14px;font-weight:500}.wizard-integration-none{font-size:13px;color:var(--text-tertiary);margin:0}.wizard-integration-fields{display:flex;flex-direction:column;gap:14px}.wizard-integration-block{display:flex;flex-direction:column;gap:6px}.wizard-integration-block .wizard-label{margin-bottom:2px;font-size:12px}.wizard-summary{display:flex;flex-direction:column;gap:16px}.wizard-summary-section{background:var(--bg-page);border:1px solid var(--border);border-radius:var(--radius-md, 8px);padding:14px 16px}.wizard-summary-section h4{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.3px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}.wizard-summary-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:14px}.wizard-summary-row span:first-child{color:var(--text-secondary);display:flex;align-items:center;gap:6px}.wizard-summary-row strong{color:var(--text-primary);font-weight:500}.wizard-summary-row.muted span{color:var(--text-tertiary);font-size:13px}.wizard-summary-sub{padding:4px 0}.wizard-summary-sub-title{font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:4px;display:block}.wizard-summary-sub .wizard-summary-row{padding-left:12px}.wizard-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid var(--border)}.wizard-footer-left,.wizard-footer-right{display:flex;gap:8px}.wizard-btn{display:flex;align-items:center;gap:6px;padding:9px 18px;border:none;border-radius:var(--radius-md, 8px);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;font-family:var(--font-sans, "Plus Jakarta Sans", sans-serif)}.wizard-btn:disabled{opacity:.5;cursor:not-allowed}.wizard-btn.primary{background:var(--accent);color:#000}.wizard-btn.primary:hover:not(:disabled){background:#00eabb}.wizard-btn.secondary{background:var(--bg-page);color:var(--text-secondary);border:1px solid var(--border)}.wizard-btn.secondary:hover:not(:disabled){background:var(--bg-surface);color:var(--text-primary)}.wizard-btn.approve{background:var(--accent-success, #22c55e);color:var(--bg-surface);padding:9px 24px}.wizard-btn.approve:hover:not(:disabled){background:#16a34a}@media(max-width:640px){.wizard-overlay{padding:8px;align-items:flex-end}.wizard-modal{max-height:95vh;border-radius:16px 16px 0 0}.wizard-stepper{padding:12px 16px;gap:2px}.wizard-stepper-label{display:none}.wizard-stepper-item{padding:6px}.wizard-body,.wizard-header{padding:16px}.wizard-footer{padding:12px 16px}.wizard-role-grid{grid-template-columns:1fr;gap:8px}.wizard-role-card{flex-direction:row;text-align:left;padding:12px}.wizard-role-card span{display:none}.wizard-site-row{flex-wrap:wrap}.wizard-site-row .wizard-select.compact{width:100%}.wizard-user-card{flex-direction:column;text-align:center}.wizard-user-meta{align-items:center}}.text-center{text-align:center}.text-muted{color:var(--text-tertiary)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.clickable-row{cursor:pointer}@media(max-width:1024px){.md-two-col{grid-template-columns:1fr!important;display:grid;gap:16px}}@media(max-width:768px){.md-stat-row,.md-dash-stats{grid-template-columns:repeat(2,1fr);gap:10px}.md-chart-body{height:200px!important;padding:10px 4px 4px!important}.md-health-bar-fill{min-width:20px}}@media(max-width:480px){.md-stat-row,.md-dash-stats{grid-template-columns:1fr}.md-chart-body{height:180px!important}}.status-tooltip-wrapper{position:relative;display:inline-flex;cursor:help}.status-tooltip{color:var(--text-secondary);font-style:normal;font-weight:400;text-align:left;line-height:1.5;letter-spacing:normal;white-space:normal;word-wrap:break-word;position:absolute;z-index:1000;width:max-content;max-width:400px;min-width:200px;padding:12px 14px;background:var(--bg-surface);border:1px solid #2a2a3e;border-radius:10px;box-shadow:0 8px 24px #00000080,0 0 0 1px #ffffff0d;pointer-events:none;animation:tooltipFadeIn .15s ease}.status-tooltip-bottom{top:calc(100% + 8px);left:50%;transform:translate(-50%)}.status-tooltip-top{bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.status-tooltip-right{left:calc(100% + 8px);top:50%;transform:translateY(-50%)}.status-tooltip-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}.status-tooltip-title{font-size:13px;font-weight:600}.status-tooltip-desc{color:var(--text-secondary)!important;background:none!important;font-size:12px;line-height:1.5;color:var(--text-secondary);margin:0}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.status-tooltip-top{animation-name:tooltipFadeInTop}@keyframes tooltipFadeInTop{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.md-errors-panel{margin-bottom:20px}.md-errors-panel .md-panel-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.md-panel-header-left{display:flex;align-items:center;gap:12px}.md-panel-header-left .md-panel-title{display:flex;align-items:center;gap:6px}.md-panel-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:32px;color:var(--text-tertiary);font-size:13px}.md-error-filters{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.md-error-filter-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid #2a2a3e;background:transparent;color:var(--text-secondary);transition:all .15s ease}.md-error-filter-pill:hover{background:var(--bg-surface);border-color:#3a3a4e;box-shadow:var(--shadow-sm)}.md-error-filter-pill.active{background:#00d4aa1a;border-color:#00d4aa4d;color:var(--accent)}.md-error-filter-pill.critical.active{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.md-error-filter-pill.warning.active{background:#f59e0b1a;border-color:#f59e0b4d;color:#f59e0b}.md-error-ccm-count{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;font-size:11px;font-weight:500;background:#a855f71a;color:#a855f7;border:1px solid rgba(168,85,247,.2)}.md-error-groups{display:flex;flex-direction:column;gap:2px}.md-error-device-group{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:#0d1117}.md-error-device-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;transition:background .15s ease}.md-error-device-header:hover{background:#111827}.md-error-device-left{display:flex;align-items:center;gap:8px}.md-error-device-info{display:flex;flex-direction:column;gap:1px}.md-error-device-name{font-size:13px;font-weight:600;color:var(--text-primary)}.md-error-device-ip{font-size:11px;color:var(--text-tertiary);font-family:JetBrains Mono,monospace}.md-error-device-right{display:flex;align-items:center;gap:8px}.md-error-device-errors{border-top:1px solid var(--border)}.md-error-row{border-bottom:1px solid #141b24}.md-error-row:last-child{border-bottom:none}.md-error-row-summary{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 8px 28px;cursor:pointer;transition:background .15s ease;gap:8px}.md-error-row-summary:hover{background:#ffffff05}.md-error-row-left{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.md-error-row-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.md-error-severity-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap;flex-shrink:0}.md-error-simple{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.md-error-ccm-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:600;background:#a855f726;color:#a855f7;border:1px solid rgba(168,85,247,.25);white-space:nowrap;flex-shrink:0}.md-error-category{font-size:11px;color:var(--text-tertiary);background:var(--bg-surface);padding:2px 6px;border-radius:3px;white-space:nowrap;box-shadow:var(--shadow-sm)}.md-error-count{font-size:11px;color:var(--text-secondary);font-weight:500}.md-error-time{font-size:11px;color:#475569;white-space:nowrap}.md-error-row-detail{padding:12px 28px 16px;background:var(--border-strong);border-top:1px solid #141b24}.md-error-detail-section{margin-bottom:12px}.md-error-detail-section h5{font-size:12px;font-weight:600;color:var(--text-secondary);margin:0 0 6px;display:flex;align-items:center;gap:4px}.md-error-detail-section p{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0}.md-error-fix-steps{margin:0;padding-left:18px;list-style:decimal}.md-error-fix-steps li{font-size:13px;color:var(--text-secondary);line-height:1.6;padding:2px 0}.md-error-fix-steps li::marker{color:var(--accent);font-weight:600}.md-error-ccm-notice{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;background:#a855f714;border:1px solid rgba(168,85,247,.2);border-radius:8px;margin-bottom:12px;color:#c4b5fd}.md-error-ccm-notice strong{display:block;font-size:13px;margin-bottom:2px;color:#a855f7}.md-error-ccm-notice p{font-size:12px;color:var(--text-secondary);margin:0}.md-error-raw-details{margin-top:8px}.md-error-raw-details summary{font-size:12px;color:var(--text-tertiary);cursor:pointer;padding:4px 0}.md-error-raw-details summary:hover{color:var(--text-secondary)}.md-error-raw-code{display:block;margin-top:6px;padding:8px 10px;background:#0a0a14;border:1px solid var(--border);border-radius:6px;font-size:11px;color:var(--text-secondary);font-family:JetBrains Mono,monospace;word-break:break-all;white-space:pre-wrap;max-height:120px;overflow-y:auto}.md-error-bugcode{display:block;margin-top:4px;font-size:10px;color:#475569;font-family:JetBrains Mono,monospace}.md-error-actions{display:flex;gap:8px;margin-top:10px}.md-error-actions .btn-sm{font-size:12px;padding:4px 10px;display:inline-flex;align-items:center;gap:4px}@media(max-width:768px){.md-errors-panel .md-panel-header{flex-direction:column;align-items:flex-start}.md-error-row-summary{flex-direction:column;align-items:flex-start;gap:6px;padding-left:14px}.md-error-row-right{padding-left:22px}.md-error-row-detail{padding-left:14px}}.md-error-status-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:600;white-space:nowrap;flex-shrink:0}.md-error-notes-display{background:#3b82f60f;border:1px solid rgba(59,130,246,.15);border-radius:6px;padding:8px 12px}.md-error-notes-display h5{color:#60a5fa}.md-error-action-btn{border-radius:6px;cursor:pointer;transition:all .15s ease}.md-error-action-btn.work{background:#3b82f61f;color:#3b82f6;border:1px solid rgba(59,130,246,.25)}.md-error-action-btn.work:hover{background:#3b82f633}.md-error-action-btn.resolve{background:#22c55e1f;color:#22c55e;border:1px solid rgba(34,197,94,.25)}.md-error-action-btn.resolve:hover{background:#22c55e33}.md-error-action-modal{max-width:480px}.md-error-action-context{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#0d1117;border:1px solid var(--border);border-radius:8px;font-size:13px;color:var(--text-secondary)}.md-error-action-device{font-size:12px;color:var(--text-tertiary);margin:6px 0 0}.md-error-action-options{display:flex;flex-direction:column;gap:6px}.md-error-action-option{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s ease;background:#0d1117}.md-error-action-option:hover{border-color:#3a3a4e;background:#111827}.md-error-action-option.selected{border-color:var(--accent-alpha-15);background:#00d4aa0d}.md-error-action-option input[type=radio]{display:none}.md-error-action-option div{display:flex;flex-direction:column;gap:1px}.md-error-action-option strong{font-size:13px;color:var(--text-primary);font-weight:600}.md-error-action-option span{font-size:11px;color:var(--text-tertiary)}.md-error-notes-input{resize:vertical;min-height:60px;font-family:inherit;font-size:13px}.md-error-filter-pill.resolved.active{background:#22c55e1a;border-color:#22c55e4d;color:#22c55e}.md-resolved-panel{opacity:.85;margin-bottom:20px}.md-resolved-panel .md-error-device-group{border-color:#162230}.md-resolved-panel .md-error-row-summary:hover{background:#22c55e08}.bug-reports-tab{padding:0}.bug-stats-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.bug-stat-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid #2a2a3e;background:transparent;color:var(--text-secondary);transition:all .15s ease}.bug-stat-pill:hover{background:var(--bg-surface);border-color:#3a3a4e;box-shadow:var(--shadow-sm)}.bug-stat-pill.active{background:#00d4aa1a;border-color:#00d4aa4d;color:var(--accent)}.bug-stat-pill.open.active{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.bug-stat-pill.acknowledged.active{background:#f59e0b1a;border-color:#f59e0b4d;color:#f59e0b}.bug-stat-pill.resolved.active{background:#22c55e1a;border-color:#22c55e4d;color:#22c55e}.bug-toolbar{display:flex;gap:8px;margin-bottom:16px}.bug-search{flex:1;display:flex;align-items:center;gap:8px;padding:0 12px;background:#0d1117;border:1px solid var(--border);border-radius:8px}.bug-search input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:13px;padding:8px 0;outline:none}.bug-search input::placeholder{color:#475569}.bug-search svg{color:#475569;flex-shrink:0}.bug-list{display:flex;flex-direction:column;gap:4px}.bug-card{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:#0d1117;transition:border-color .15s ease}.bug-card.open{border-left:3px solid #ef4444}.bug-card.acknowledged{border-left:3px solid #f59e0b}.bug-card.resolved{border-left:3px solid #22c55e;opacity:.7}.bug-card-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;gap:12px}.bug-card-header:hover{background:#111827}.bug-card-left{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.bug-card-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.bug-status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap}.bug-code{font-size:11px;color:var(--text-tertiary);font-family:JetBrains Mono,monospace;background:var(--bg-surface);padding:2px 6px;border-radius:3px;white-space:nowrap;box-shadow:var(--shadow-sm)}.bug-simple{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bug-category{font-size:11px;color:var(--text-tertiary);background:var(--bg-surface);padding:2px 6px;border-radius:3px;white-space:nowrap;box-shadow:var(--shadow-sm)}.bug-occurrences{font-size:11px;color:var(--text-secondary);font-weight:500}.bug-time{font-size:11px;color:#475569;white-space:nowrap}.bug-card-detail{padding:14px 18px 16px;background:var(--border-strong);border-top:1px solid #141b24}.bug-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px}.bug-detail-item{display:flex;flex-direction:column;gap:2px}.bug-detail-item label{font-size:11px;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.bug-detail-item span{font-size:13px;color:var(--text-primary)}.bug-detail-section{margin-bottom:12px}.bug-detail-section label{display:block;font-size:11px;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.bug-detail-section p{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.bug-raw-error{display:block;padding:8px 10px;background:#0a0a14;border:1px solid var(--border);border-radius:6px;font-size:11px;color:var(--text-secondary);font-family:JetBrains Mono,monospace;word-break:break-all;white-space:pre-wrap;max-height:120px;overflow-y:auto}.bug-actions{display:flex;gap:8px;margin-top:12px}.bug-actions .btn-sm{font-size:12px;padding:5px 12px;display:inline-flex;align-items:center;gap:4px;border-radius:6px;cursor:pointer}.bug-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--text-tertiary);font-size:13px}.bug-empty{text-align:center;padding:40px 20px;color:var(--text-tertiary)}.bug-empty svg{margin-bottom:12px;opacity:.5}.bug-empty h3{font-size:15px;color:var(--text-secondary);margin:0 0 4px}.bug-empty p{font-size:13px;margin:0}.bug-footer{padding:10px 14px;font-size:12px;color:#475569;text-align:center;border-top:1px solid var(--border)}@media(max-width:768px){.bug-detail-grid{grid-template-columns:repeat(2,1fr)}.bug-card-header{flex-direction:column;align-items:flex-start;gap:6px}}.pn-tab{padding:0}.pn-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.pn-header-desc{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.pn-header-actions{display:flex;gap:8px;flex-shrink:0}.pn-channel-list{display:flex;flex-direction:column;gap:8px}.pn-channel-card{border:1px solid var(--border);border-radius:10px;background:#0d1117;overflow:hidden;transition:border-color .15s ease}.pn-channel-card:hover{border-color:#2a3a4e}.pn-channel-card.disabled{opacity:.55}.pn-channel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;gap:12px}.pn-channel-left{display:flex;align-items:center;gap:12px;min-width:0}.pn-channel-type-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;border:1px solid;white-space:nowrap;flex-shrink:0}.pn-channel-info{display:flex;flex-direction:column;gap:2px;min-width:0}.pn-channel-name{font-size:14px;font-weight:600;color:var(--text-primary)}.pn-channel-url{font-size:11px;color:#475569;font-family:JetBrains Mono,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pn-channel-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.pn-action-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease}.pn-action-btn:hover{background:var(--bg-surface);color:var(--text-secondary)}.pn-action-btn.danger:hover{background:#ef44441a;color:#ef4444}.pn-channel-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 16px 10px;border-top:1px solid #141b24;gap:12px}.pn-channel-events{display:flex;flex-wrap:wrap;gap:4px}.pn-event-tag{display:inline-flex;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:500;background:#00d4aa14;color:var(--accent);border:1px solid rgba(0,212,170,.15)}.pn-no-events{font-size:11px;color:#475569;font-style:italic}.pn-test-result{display:inline-flex;align-items:center;gap:4px;font-size:11px}.pn-test-result.success{color:#22c55e}.pn-test-result.failed{color:#ef4444}.pn-test-time{color:#475569;margin-left:4px}.pn-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:48px;color:var(--text-tertiary);font-size:13px}.pn-empty{text-align:center;padding:48px 20px;color:var(--text-tertiary)}.pn-empty svg{margin-bottom:12px;opacity:.4}.pn-empty h3{font-size:16px;color:var(--text-secondary);margin:0 0 6px}.pn-empty p{font-size:13px;margin:0 0 16px}.pn-modal{max-width:560px}.pn-type-options{display:flex;flex-wrap:wrap;gap:6px}.pn-type-option{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;color:var(--text-secondary);transition:all .15s ease;background:#0d1117}.pn-type-option:hover{border-color:#3a3a4e}.pn-type-option.selected{border-color:var(--accent-alpha-15);background:#00d4aa0d;color:var(--text-primary)}.pn-type-option input[type=radio]{display:none}.pn-type-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pn-select-links{margin-left:8px;font-weight:400}.pn-select-links button{background:none;border:none;color:var(--accent);font-size:11px;cursor:pointer;padding:0;margin-left:6px}.pn-select-links button:hover{text-decoration:underline}.pn-events-grid{display:flex;flex-direction:column;gap:12px;max-height:320px;overflow-y:auto;padding-right:4px}.pn-event-category{display:flex;flex-direction:column;gap:4px}.pn-event-category-label{font-size:10px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;padding:2px 0}.pn-event-checkbox{display:flex;align-items:flex-start;gap:8px;padding:6px 10px;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s ease;background:#0d1117}.pn-event-checkbox:hover{border-color:#2a3a4e}.pn-event-checkbox.checked{border-color:#00d4aa4d;background:#00d4aa0a}.pn-event-checkbox input[type=checkbox]{margin-top:2px;accent-color:var(--accent);flex-shrink:0}.pn-event-checkbox div{display:flex;flex-direction:column;gap:1px}.pn-event-checkbox strong{font-size:12px;font-weight:600;color:var(--text-primary)}.pn-event-checkbox span{font-size:11px;color:var(--text-tertiary)}@media(max-width:768px){.pn-header{flex-direction:column}.pn-channel-header{flex-direction:column;align-items:flex-start;gap:8px}.pn-channel-footer{flex-direction:column;align-items:flex-start}.pn-type-options{flex-direction:column}}.wd-panel{border:1px solid var(--border);border-radius:10px;background:#0d1117;margin-bottom:20px;overflow:hidden}.wd-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;transition:background .15s ease;gap:12px}.wd-panel-header:hover{background:#111827}.wd-panel-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary)}.wd-panel-subtitle{font-size:12px;font-weight:400;color:var(--text-tertiary);margin-left:4px}.wd-panel-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.wd-panel-actions .btn-sm{font-size:11px;padding:4px 8px;display:inline-flex;align-items:center;gap:4px}.wd-panel-body{border-top:1px solid var(--border);padding:12px 16px}.wd-loading,.wd-empty{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px;color:var(--text-tertiary);font-size:13px}.wd-alert-groups{display:flex;flex-direction:column;gap:10px}.wd-alert-group{border:1px solid #162230;border-radius:8px;overflow:hidden}.wd-alert-group-header{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#00d4aa08;font-size:12px;font-weight:600;color:var(--text-secondary)}.wd-alert-count{margin-left:auto;background:var(--bg-surface);padding:1px 6px;border-radius:4px;font-size:10px;color:var(--text-tertiary);box-shadow:var(--shadow-sm)}.wd-alert-items{display:flex;flex-direction:column}.wd-alert-item{display:flex;align-items:center;gap:8px;padding:6px 12px;border-top:1px solid #141b24;font-size:12px}.wd-alert-item:first-child{border-top:none}.wd-alert-level{display:flex;align-items:center;gap:4px;flex-shrink:0}.wd-alert-level-tag{font-size:10px;color:var(--text-tertiary);background:var(--bg-surface);padding:1px 5px;border-radius:3px;font-family:JetBrains Mono,monospace;box-shadow:var(--shadow-sm)}.wd-alert-message{flex:1;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wd-alert-time{font-size:11px;color:#475569;white-space:nowrap;flex-shrink:0}@media(max-width:768px){.wd-panel-header{flex-direction:column;align-items:flex-start;gap:8px}.wd-alert-item{flex-wrap:wrap}.wd-alert-message{white-space:normal;flex-basis:100%;order:3;padding-left:20px}}.cert-panel{margin-bottom:20px}.cert-panel .md-panel-title{display:flex;align-items:center;gap:6px}.cert-list{display:flex;flex-direction:column;gap:2px}.cert-row{border:1px solid var(--border);border-radius:6px;overflow:hidden;background:#0d1117}.cert-row.expired,.cert-row.critical{border-left:3px solid #ef4444}.cert-row.warning{border-left:3px solid #f59e0b}.cert-row.ok{border-left:3px solid #22c55e}.cert-row-summary{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;gap:8px;transition:background .15s ease}.cert-row-summary:hover{background:#111827}.cert-row-left{display:flex;align-items:center;gap:8px;min-width:0}.cert-row-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.cert-status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap;flex-shrink:0}.cert-device-name{font-size:13px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cert-device-ip{font-size:11px;color:#475569;font-family:JetBrains Mono,monospace}.cert-days{font-size:12px;font-weight:600;white-space:nowrap}.cert-self-signed{font-size:10px;color:var(--text-tertiary);background:var(--bg-surface);padding:1px 6px;border-radius:3px;white-space:nowrap;box-shadow:var(--shadow-sm)}.cert-detail{padding:10px 14px;border-top:1px solid #141b24;background:#0000001a}.cert-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.cert-detail-item{display:flex;flex-direction:column;gap:2px}.cert-detail-item label{font-size:10px;color:var(--text-tertiary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.cert-detail-item span{font-size:12px;color:var(--text-primary)}.cert-error{display:flex;align-items:center;gap:6px;margin-top:8px;padding:6px 10px;background:#f59e0b14;border:1px solid rgba(245,158,11,.15);border-radius:6px;font-size:12px;color:#f59e0b}@media(max-width:768px){.cert-detail-grid{grid-template-columns:repeat(2,1fr)}.cert-row-summary{flex-direction:column;align-items:flex-start;gap:4px}}.notif-prefs-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-2xl);color:var(--text-tertiary);font-size:14px}.notif-prefs{display:flex;flex-direction:column;gap:var(--space-lg)}.notif-prefs-save-bar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:10px var(--space-lg);background:#00d4aa1a;border:1px solid rgba(0,212,170,.3);border-radius:var(--radius-md);font-size:13px;color:var(--accent)}.notif-prefs-save-bar .btn-sm{padding:6px 14px;font-size:13px;gap:6px}.notif-prefs-status{display:flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-lg);border-radius:var(--radius-md);font-size:13px}.notif-prefs-status.success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:var(--accent-success)}.notif-prefs-status.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--accent-danger)}.notif-prefs-section{padding:0;overflow:hidden}.notif-prefs-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border)}.notif-prefs-section-title{display:flex;align-items:center;gap:var(--space-md)}.notif-prefs-section-title>svg{color:var(--accent);flex-shrink:0}.notif-prefs-section-title h3{font-size:15px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.notif-prefs-section-title p{font-size:12px;color:var(--text-tertiary);margin:2px 0 0}.notif-prefs-bulk-actions{display:flex;gap:var(--space-xs)}.notif-prefs-bulk-btn{padding:4px 10px;font-size:11px;font-weight:500;color:var(--text-tertiary);background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.notif-prefs-bulk-btn:hover{color:var(--text-primary);border-color:var(--accent);background:#00d4aa0d}.notif-prefs-grid{padding:0}.notif-prefs-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px var(--space-xl);border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s ease}.notif-prefs-toggle-row:last-child{border-bottom:none}.notif-prefs-toggle-row:hover{background:#ffffff05}.notif-prefs-toggle-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1;padding-right:var(--space-lg)}.notif-prefs-toggle-label{font-size:14px;font-weight:500;color:var(--text-primary)}.notif-prefs-toggle-desc{font-size:12px;color:var(--text-tertiary);line-height:1.4}.notif-prefs-switch{position:relative;background:none;border:none;padding:0;cursor:pointer;flex-shrink:0}.notif-prefs-switch-track{display:block;width:40px;height:22px;border-radius:11px;background:var(--bg-page);border:1px solid var(--border);position:relative;transition:all .2s ease}.notif-prefs-switch.on .notif-prefs-switch-track{background:var(--accent);border-color:var(--accent)}.notif-prefs-switch-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--text-tertiary);transition:all .2s ease}.notif-prefs-switch.on .notif-prefs-switch-thumb{left:20px;background:var(--bg-page)}.notif-prefs-push-setup{padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--border)}.notif-prefs-expand-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:color .15s ease}.notif-prefs-expand-btn:hover{color:var(--text-primary)}.notif-prefs-info-banner{display:flex;align-items:flex-start;gap:var(--space-sm);margin:var(--space-md) var(--space-xl);padding:10px var(--space-md);background:#0ea5e914;border:1px solid rgba(14,165,233,.2);border-radius:var(--radius-md);font-size:12px;color:var(--text-secondary);line-height:1.5}.notif-prefs-info-banner svg{color:var(--accent);flex-shrink:0;margin-top:1px}.notif-prefs-webhooks-list{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-md) var(--space-xl)}.notif-prefs-webhook-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-md);transition:border-color .15s ease;box-shadow:var(--shadow-sm)}.notif-prefs-webhook-card:hover{border-color:#ffffff26}.notif-prefs-webhook-card.disabled{opacity:.5}.notif-prefs-webhook-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.notif-prefs-webhook-platform{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;color:var(--platform-color);background:color-mix(in srgb,var(--platform-color) 12%,transparent)}.notif-prefs-webhook-actions{display:flex;align-items:center;gap:4px}.notif-prefs-icon-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.notif-prefs-icon-btn:hover{color:var(--text-primary);background:#ffffff0d}.notif-prefs-icon-btn.danger:hover{color:var(--accent-danger);background:#ef44441a}.notif-prefs-icon-btn .text-success{color:var(--accent-success)}.notif-prefs-webhook-name{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.notif-prefs-webhook-url{font-size:11px;color:var(--text-tertiary);font-family:monospace;margin-bottom:var(--space-sm);word-break:break-all}.notif-prefs-webhook-events{display:flex;flex-wrap:wrap;gap:4px}.notif-prefs-event-tag{padding:2px 8px;font-size:10px;font-weight:500;border-radius:var(--radius-sm);background:#ffffff0f;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.notif-prefs-add-btn{margin:var(--space-md) var(--space-xl) var(--space-lg);gap:6px}.notif-prefs-webhook-form{margin:var(--space-md) var(--space-xl) var(--space-lg);padding:var(--space-lg);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.notif-prefs-webhook-form h4{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-lg) 0}.notif-prefs-form-group{margin-bottom:var(--space-lg)}.notif-prefs-form-group>label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-sm)}.notif-prefs-form-hint{font-size:11px;color:var(--text-tertiary);margin-top:6px;line-height:1.5}.notif-prefs-platform-select{display:flex;gap:var(--space-sm)}.notif-prefs-platform-option{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--text-tertiary);transition:all .15s ease}.notif-prefs-platform-option:hover{border-color:var(--platform-color);color:var(--text-primary)}.notif-prefs-platform-option.active{border-color:var(--platform-color);color:var(--platform-color);background:color-mix(in srgb,var(--platform-color) 10%,transparent)}.notif-prefs-event-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-sm)}.notif-prefs-checkbox{display:flex;align-items:center;gap:var(--space-sm);font-size:13px;color:var(--text-secondary);cursor:pointer;padding:6px 0}.notif-prefs-checkbox input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.notif-prefs-form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;padding-top:var(--space-md);border-top:1px solid var(--border)}@media(max-width:768px){.notif-prefs-section-header{flex-direction:column;align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg)}.notif-prefs-toggle-row{padding:10px var(--space-lg)}.notif-prefs-toggle-desc{display:none}.notif-prefs-push-setup{padding:var(--space-md) var(--space-lg)}.notif-prefs-webhooks-list{padding:var(--space-sm) var(--space-lg)}.notif-prefs-webhook-form{margin:var(--space-sm) var(--space-lg) var(--space-md)}.notif-prefs-platform-select{flex-direction:column}.notif-prefs-event-checkboxes{grid-template-columns:1fr}.notif-prefs-info-banner{margin:var(--space-sm) var(--space-lg)}.notif-prefs-add-btn{margin:var(--space-sm) var(--space-lg) var(--space-md)}.notif-prefs-save-bar{flex-direction:column;gap:var(--space-sm);text-align:center}}@media(max-width:480px){.notif-prefs-bulk-actions{display:none}}.ptz-toggle-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:var(--text-primary);font-size:11px;font-weight:600;letter-spacing:.5px;cursor:pointer;transition:all .2s}.ptz-toggle-btn:hover{background:#ffffff26;color:var(--text-primary)}.ptz-toggle-btn.active{background:#00d4aa33;border-color:#00d4aa66;color:var(--accent)}.ptz-panel{position:absolute;top:60px;right:12px;z-index:25;background:#0d0d14eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:10px;box-shadow:0 8px 32px #00000080;-webkit-user-select:none;user-select:none}.ptz-dpad{display:grid;grid-template-columns:32px 36px 32px;grid-template-rows:32px 36px 32px;gap:2px;justify-items:center;align-items:center}.ptz-dpad-btn{display:flex;align-items:center;justify-content:center;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text-primary);cursor:pointer;transition:all .15s}.ptz-dpad-btn:hover{background:#ffffff26;color:var(--text-primary)}.ptz-dpad-btn.active{background:#00d4aa4d;border-color:#00d4aa80;color:var(--text-primary)}.ptz-dpad-btn:active{background:#00d4aa4d;transform:scale(.95)}.ptz-cardinal{width:36px;height:36px;border-radius:4px}.ptz-cardinal.top{border-radius:4px 4px 2px 2px}.ptz-cardinal.bottom{border-radius:2px 2px 4px 4px}.ptz-cardinal.left{border-radius:4px 2px 2px 4px}.ptz-cardinal.right{border-radius:2px 4px 4px 2px}.ptz-corner{width:32px;height:32px;border-radius:4px}.ptz-corner.tl{border-radius:8px 2px 2px}.ptz-corner.tr{border-radius:2px 8px 2px 2px}.ptz-corner.bl{border-radius:2px 2px 2px 8px}.ptz-corner.br{border-radius:2px 2px 8px}.ptz-center{width:36px;height:36px;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.15)}.ptz-center:hover{background:#00d4aa33;border-color:#00d4aa66}.ptz-zoom-row{display:flex;align-items:center;gap:6px}.ptz-zoom-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-primary);cursor:pointer;transition:all .15s}.ptz-zoom-btn:hover{background:#ffffff26;color:var(--text-primary)}.ptz-zoom-btn.active,.ptz-zoom-btn:active{background:#00d4aa4d;border-color:#00d4aa80}.ptz-speed-slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:#ffffff1a;border-radius:2px;outline:none;cursor:pointer}.ptz-speed-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid rgba(0,0,0,.3);cursor:pointer}.ptz-speed-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid rgba(0,0,0,.3);cursor:pointer}.ptz-presets-toggle{width:100%;padding:6px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--text-secondary);font-size:11px;cursor:pointer;transition:all .2s}.ptz-presets-toggle:hover{background:#ffffff1a;color:var(--text-primary)}.ptz-presets-list{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.ptz-preset-btn{padding:4px 8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:var(--text-primary);font-size:11px;cursor:pointer;transition:all .15s}.ptz-preset-btn:hover{background:#00d4aa33;border-color:#00d4aa66;color:var(--text-primary)}@media(max-width:768px){.ptz-panel{top:auto;bottom:200px;right:8px}}
