.notification-item{display:flex;align-items:flex-start;padding:16px 20px;border-bottom:1px solid var(--sidebar-border);cursor:pointer;transition:all .2s ease;position:relative;background-color:var(--sidebar-bg);color:var(--sidebar-text-primary)}.notification-item:hover{background-color:var(--sidebar-hover-bg)}.notification-item:active{background-color:var(--sidebar-active-bg)}.notification-item.unread{background-color:var(--sidebar-active-bg);border-left:4px solid var(--btn-primary-bg)}.notification-item.unread:hover{background-color:var(--sidebar-hover-bg)}.notification-item.selected{background-color:var(--btn-primary-bg)!important;border-left:4px solid var(--color-warning);box-shadow:0 0 0 2px var(--btn-primary-bg),0 0 0 4px rgba(var(--color-warning-rgb),.3);transform:scale(1.02)}.notification-item.selected:hover{background-color:var(--btn-primary-bg)!important}.notification-item.selected .notification-facility strong,.notification-item.selected .notification-time,.notification-item.selected .notification-message{color:#fff!important}.notification-alert-indicator{flex-shrink:0;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-right:12px;position:relative;box-shadow:var(--shadow-sm);color:#fff}.notification-alert-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.notification-content{flex:1;min-width:0}.notification-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px;gap:8px}.notification-facility{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.notification-facility strong{font-size:14px;font-weight:600;color:var(--sidebar-text-primary)}.notification-level{display:inline-block;padding:2px 8px;background-color:var(--bg-secondary);color:var(--sidebar-text-secondary);font-size:11px;font-weight:500;border-radius:12px;white-space:nowrap}.notification-time{font-size:12px;color:var(--sidebar-text-muted);white-space:nowrap;flex-shrink:0}.notification-message{font-size:13px;color:var(--sidebar-text-secondary);line-height:1.4;margin-bottom:8px;word-break:break-word}.notification-footer{display:flex;justify-content:space-between;align-items:center;gap:8px}.notification-read-status{font-size:11px;font-weight:500;padding:2px 6px;border-radius:8px}.notification-read-status.unread{background-color:var(--btn-primary-bg);color:#fff}.notification-read-status.read{background-color:var(--alert-normal-bg);color:var(--alert-normal-text)}.notification-unread-dot{position:absolute;top:18px;right:12px;width:8px;height:8px;background-color:var(--btn-primary-bg);border-radius:50%;box-shadow:0 0 0 2px var(--sidebar-bg)}.notification-item[data-alert-num="4"] .notification-level,.notification-item[data-alert-num="3"] .notification-level{background-color:var(--alert-danger-bg);color:var(--alert-danger-text)}.notification-item[data-alert-num="2"] .notification-level{background-color:var(--alert-warning-bg);color:var(--alert-warning-text)}.notification-item[data-alert-num="1"] .notification-level{background-color:var(--alert-caution-bg);color:var(--alert-caution-text)}.notification-item[data-alert-num="0"] .notification-level{background-color:var(--alert-normal-bg);color:var(--alert-normal-text)}.notification-item.loading{opacity:.6;pointer-events:none}.notification-item.loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;border:2px solid var(--bg-tertiary);border-top:2px solid var(--btn-primary-bg);border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 480px){.notification-item{padding:12px 16px}.notification-alert-indicator{width:32px;height:32px;margin-right:8px}.notification-alert-icon{width:16px;height:16px}.notification-header,.notification-facility{flex-direction:column;align-items:flex-start;gap:4px}.notification-time{font-size:11px}.notification-message{font-size:12px}.notification-unread-dot{width:6px;height:6px;top:14px;right:8px}}.dark .notification-item{background-color:var(--sidebar-bg);border-bottom-color:var(--sidebar-border);color:var(--sidebar-text-primary)}.dark .notification-item:hover{background-color:var(--sidebar-hover-bg)}.dark .notification-item:active{background-color:var(--sidebar-active-bg)}.dark .notification-item.unread{background-color:var(--sidebar-active-bg);border-left-color:var(--btn-primary-bg)}.dark .notification-item.unread:hover{background-color:var(--sidebar-hover-bg)}.dark .notification-facility strong{color:var(--sidebar-text-primary)}.dark .notification-level{background-color:var(--bg-secondary);color:var(--sidebar-text-secondary)}.dark .notification-time{color:var(--sidebar-text-muted)}.dark .notification-message{color:var(--sidebar-text-secondary)}.dark .notification-read-status.unread{background-color:var(--btn-primary-bg);color:#fff}.dark .notification-read-status.read{background-color:var(--alert-normal-bg);color:var(--alert-normal-text)}.dark .notification-unread-dot{background-color:var(--status-danger-color);box-shadow:0 0 0 2px var(--sidebar-bg)}.notification-item:focus{outline:2px solid var(--btn-primary-bg);outline-offset:-2px}.notification-item{animation:slideInRight .3s ease-out}.notification-item.removing{animation:slideOutRight .3s ease-in}.mui-sidebar-layout{position:relative;width:100%;height:100%}.sidebar-resize-handle{position:absolute;left:0;top:0;bottom:0;width:4px;cursor:col-resize;z-index:10;transition:background-color .2s ease}.sidebar-resize-handle:hover{background-color:var(--border-secondary)!important}.sidebar-resize-handle:active{background-color:var(--text-secondary)!important}body.resizing-sidebar{cursor:col-resize!important;-webkit-user-select:none!important;user-select:none!important}.mui-sidebar-main-content{width:100%;height:100%;background-color:var(--bg-primary);color:var(--text-primary);transition:all .3s ease}.mui-drawer-content{display:flex;flex-direction:column;height:100%;background-color:var(--bg-card)!important;color:var(--text-primary)!important}.mui-drawer-header{flex-shrink:0;border-bottom:1px solid var(--border-primary);background-color:var(--bg-secondary)}.mui-drawer-title{color:var(--text-primary)}.mui-drawer-actions{display:flex;gap:8px}.mui-drawer-body{flex:1;overflow-y:auto;background-color:var(--bg-card);color:var(--text-primary);scrollbar-width:thin;scrollbar-color:var(--border-secondary) transparent}.mui-drawer-body::-webkit-scrollbar{width:8px}.mui-drawer-body::-webkit-scrollbar-track{background:transparent}.mui-drawer-body::-webkit-scrollbar-thumb{background-color:var(--border-secondary);border-radius:4px}.mui-drawer-body::-webkit-scrollbar-thumb:hover{background-color:var(--text-tertiary)}.MuiDrawer-paper.mui-drawer-content,.MuiDrawer-paper{background-color:var(--bg-card)!important;color:var(--text-primary)!important}.dark .MuiDrawer-paper,.dark .mui-drawer-content,.dark .fixed-sidebar{background-color:var(--bg-card)!important;color:var(--text-primary)!important;border-color:var(--border-primary)!important}.dark .mui-drawer-header,.dark .mui-drawer-body{background-color:var(--bg-card)!important;color:var(--text-primary)!important}.fixed-sidebar{background-color:var(--bg-card)!important;color:var(--text-primary)!important;border-left:1px solid var(--border-primary)!important}.fixed-sidebar .mui-drawer-header{background-color:var(--bg-secondary)!important;border-bottom:1px solid var(--border-primary)!important}.fixed-sidebar .mui-drawer-body{background-color:var(--bg-card)!important}@media (max-width: 768px){.mui-drawer-header{padding:12px 16px!important}.mui-drawer-body{padding:16px!important}}@media (max-width: 480px){.mui-drawer-header{padding:8px 12px!important}.mui-drawer-body{padding:12px!important}}.mui-drawer-content .sensor-selection-toggle,.fixed-sidebar .sensor-selection-toggle{display:none}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);z-index:1999;opacity:0;visibility:hidden;transition:all .3s ease}.sidebar-overlay.active,.sidebar.active~.sidebar-overlay,.right-sidebar.active~.sidebar-overlay{opacity:1;visibility:visible}.sidebar,.right-sidebar{position:fixed;top:0;right:-500px;width:500px;height:100vh;background:var(--sidebar-bg);box-shadow:var(--sidebar-shadow);z-index:2000;display:flex;flex-direction:column;transition:right .3s ease;overflow-y:auto}.sidebar.active,.right-sidebar.active{right:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--sidebar-border);background:var(--sidebar-header-bg)}.sidebar-header-actions{display:flex;align-items:center;gap:8px}.sidebar-header h3{margin:0;color:var(--sidebar-text-primary);font-size:18px;font-weight:600}.sidebar-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--sidebar-text-muted);padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.sidebar-close:hover{background:var(--sidebar-hover-bg)}.sidebar-tabs{display:flex;align-items:center;border-bottom:1px solid var(--sidebar-border);background:var(--sidebar-bg);padding:0 12px;min-height:48px}.sidebar-tab{padding:12px 16px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:500;color:var(--sidebar-text-muted);position:relative;transition:all .2s;border-bottom:3px solid transparent;margin-right:8px}.sidebar-tab:hover{color:var(--sidebar-text-primary)}.sidebar-tab.active{color:var(--sidebar-text-primary);border-bottom-color:var(--sidebar-text-primary);font-weight:600}.sidebar-actions{padding:8px 20px;border-bottom:1px solid var(--sidebar-border);background:var(--sidebar-bg);display:flex;justify-content:flex-end;align-items:center}.btn-mark-all-read{background:var(--btn-primary-bg);color:#fff;border:none;padding:6px 12px;border-radius:4px;font-size:12px;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.btn-mark-all-read:hover{background:var(--btn-primary-hover)}.sidebar-filters{padding:10px 20px;border-bottom:1px solid var(--sidebar-border);background:var(--sidebar-bg)}.filter-tab{padding:6px 12px;margin-right:8px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:16px;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s}.filter-tab:hover{background:var(--sidebar-hover-bg);color:var(--text-primary)}.filter-tab.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.search-box{display:flex;margin-bottom:12px;gap:8px}.search-box input{flex:1;padding:8px 12px;border:1px solid var(--sidebar-border);border-radius:4px;font-size:14px;background:var(--sidebar-bg);color:var(--sidebar-text-primary)}.search-box input:focus{outline:none;border-color:var(--btn-primary-bg);box-shadow:var(--input-focus-shadow)}.search-box button{padding:8px 12px;background:var(--sidebar-hover-bg);border:1px solid var(--sidebar-border);border-radius:4px;cursor:pointer;transition:background-color .2s ease;color:var(--sidebar-text-primary)}.search-box button:hover{background:var(--sidebar-active-bg)}.filter-row{display:flex;gap:8px;align-items:center}.filter-row select{flex:1;padding:6px 8px;border:1px solid var(--sidebar-border);border-radius:4px;font-size:13px;background:var(--sidebar-bg);color:var(--sidebar-text-primary)}.filter-row select:focus{outline:none;border-color:var(--btn-primary-bg)}.btn-reset{padding:6px 12px;background:var(--sidebar-hover-bg);border:1px solid var(--sidebar-border);border-radius:4px;font-size:13px;cursor:pointer;transition:background-color .2s ease;color:var(--sidebar-text-primary)}.btn-reset:hover{background:var(--sidebar-active-bg)}.sidebar-content{flex:1;overflow-y:auto;background:var(--sidebar-bg)}.sidebar-loading,.sidebar-loading-more{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--sidebar-text-muted)}.sidebar-loading-more{padding:20px}.sidebar-loading .spinner,.sidebar-loading-more .spinner{width:24px;height:24px;border:3px solid var(--sidebar-border);border-top:3px solid var(--btn-primary-bg);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.sidebar-loading span,.sidebar-loading-more span{font-size:14px}.sidebar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--sidebar-text-muted);text-align:center}.sidebar-empty span{font-size:48px;margin-bottom:16px;opacity:.5}.sidebar-empty p{margin:0;font-size:16px}.sidebar-end{text-align:center;padding:20px;color:var(--sidebar-text-muted);font-size:14px;border-top:1px solid var(--sidebar-border)}@media (max-width: 768px){.sidebar{width:100vw;right:-100vw}.sidebar.active{right:0}}@media (max-width: 480px){.sidebar-filters{padding:12px 16px}.filter-row{flex-direction:column;gap:8px}.filter-row select,.btn-reset{width:100%}}.sidebar:focus-within{outline:none}.sidebar-tab:focus,.sidebar-close:focus,.btn-mark-all-read:focus,.search-box button:focus,.btn-reset:focus{outline:2px solid var(--btn-primary-bg);outline-offset:2px}.search-box input:focus,.filter-row select:focus{box-shadow:var(--input-focus-shadow)}.sidebar-tabs .btn-text{color:var(--sidebar-text-muted);font-size:14px;font-weight:500;padding:4px 8px}.sidebar-tabs .btn-text:hover{color:var(--sidebar-text-primary);background:var(--sidebar-hover-bg)}.toggle-switch-container{display:flex;align-items:center;gap:8px}.toggle-label{font-size:14px;font-weight:500;color:var(--color-basic-text);cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-switch{position:relative;display:inline-block;background:var(--toggle-off-bg);border:none;border-radius:20px;cursor:pointer;transition:all .3s ease;outline:none;padding:0;margin:0}.toggle-switch:focus{box-shadow:0 0 0 2px #4a7cff33}.toggle-switch:hover:not(.disabled){background:var(--toggle-off-hover)}.toggle-switch.active{background:var(--toggle-on-bg)}.toggle-switch.active:hover:not(.disabled){background:var(--toggle-on-hover)}.toggle-switch.disabled{background:var(--bg-tertiary);cursor:not-allowed;opacity:.6}.toggle-handle{position:absolute;top:50%;left:2px;width:16px;height:16px;background:var(--bg-card);border-radius:50%;transition:all .3s ease;transform:translateY(-50%)}.toggle-switch.active .toggle-handle{transform:translate(20px) translateY(-50%)}.toggle-switch.with-text{position:relative;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--text-primary)}.toggle-text{position:absolute;top:50%;right:6px;transform:translateY(-50%);pointer-events:none;z-index:1;white-space:nowrap}.toggle-switch.active .toggle-text{right:auto;left:6px}.toggle-switch.small{width:46px;height:20px}.toggle-switch.small .toggle-handle{width:14px;height:14px}.toggle-switch.small.active .toggle-handle{transform:translate(28px) translateY(-50%)}.toggle-switch.small.with-text{font-size:8px}.toggle-switch.medium{width:50px;height:24px}.toggle-switch.medium .toggle-handle{width:18px;height:18px}.toggle-switch.medium.active .toggle-handle{transform:translate(26px) translateY(-50%)}.toggle-switch.medium.with-text{font-size:10px}.toggle-switch.large{width:60px;height:28px}.toggle-switch.large .toggle-handle{width:22px;height:22px}.toggle-switch.large.active .toggle-handle{transform:translate(34px) translateY(-50%)}.toggle-switch.blue.active{background:var(--color-blue-default)}.toggle-switch.blue.active:hover:not(.disabled){background:var(--color-blue-hover)}.toggle-switch.green.active{background:var(--color-green-default)}.toggle-switch.green.active:hover:not(.disabled){background:var(--color-green-hover)}.toggle-switch.red.active{background:var(--color-red-default)}.toggle-switch.red.active:hover:not(.disabled){background:var(--color-red-hover)}.toggle-switch.yellow.active{background:var(--color-yellow-default)}.toggle-switch.yellow.active:hover:not(.disabled){background:var(--color-yellow-hover)}.dark .toggle-switch{background:var(--toggle-off-bg)}.dark .toggle-switch:hover:not(.disabled){background:var(--toggle-off-hover)}.dark .toggle-switch.active{background:var(--toggle-on-bg)}.dark .toggle-switch.active:hover:not(.disabled){background:var(--toggle-on-hover)}.dark .toggle-switch.disabled{background:var(--bg-tertiary)}.dark .toggle-label{color:var(--text-primary)}.toggle-switch.with-text,.dark .toggle-switch.with-text{color:#fff}} .push-notification-settings{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-primary);padding:var(--spacing-lg);margin:var(--spacing-md) 0}.push-notification-settings .settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:12px;border-bottom:2px solid var(--border-secondary)}.push-notification-settings .settings-header h3{margin:0;color:var(--text-primary);font-size:18px;font-weight:600}.push-notification-settings .status-indicator{display:flex;align-items:center;gap:var(--spacing-sm)}.push-notification-settings .status-dot{width:8px;height:8px;border-radius:50%;transition:background-color .2s ease}.push-notification-settings .status-dot.active{background-color:var(--status-success);box-shadow:0 0 0 2px rgba(var(--status-success),.3)}.push-notification-settings .status-dot.inactive{background-color:var(--text-muted)}.push-notification-settings .status-text{font-size:13px;font-weight:500;color:var(--text-secondary)}.push-notification-settings .settings-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.push-notification-settings .status-message{display:flex;align-items:flex-start;gap:12px;padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid}.push-notification-settings .status-message.error{background:var(--alert-danger-bg);border-color:var(--status-error);color:var(--alert-danger-text)}.push-notification-settings .status-message.warning{background:var(--alert-warning-bg);border-color:var(--status-warning);color:var(--alert-warning-text)}.push-notification-settings .status-message.info{background:var(--alert-info-bg);border-color:var(--status-info);color:var(--alert-info-text)}.push-notification-settings .status-message .icon{font-size:18px;line-height:1}.push-notification-settings .status-message p{margin:0 0 var(--spacing-sm) 0;font-weight:500}.push-notification-settings .status-message small{display:block;font-size:13px;opacity:.8;margin-top:var(--spacing-xs)}.push-notification-settings .subscription-controls{border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--spacing-lg)}.push-notification-settings .control-group{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.push-notification-settings .control-info{flex:1}.push-notification-settings .control-info h4{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:16px;font-weight:600}.push-notification-settings .control-info p{margin:0;color:var(--text-secondary);font-size:14px;line-height:1.5}.push-notification-settings .control-actions{flex-shrink:0}.push-notification-settings .toggle-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.push-notification-settings .toggle-status-label{font-size:13px;font-weight:500;color:var(--text-secondary);text-align:center;white-space:nowrap}.push-notification-settings .push-notification-toggle{cursor:pointer}.push-notification-settings .test-section{border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--spacing-md);background:var(--bg-secondary)}.push-notification-settings .test-section h4{margin:0 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:14px;font-weight:600}.push-notification-settings .test-section p{margin:0 0 12px;color:var(--text-secondary);font-size:13px}.push-notification-settings .subscription-info{border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--spacing-md)}.push-notification-settings .subscription-info h4{margin:0 0 12px;color:var(--text-primary);font-size:14px;font-weight:600}.push-notification-settings .info-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-sm)}.push-notification-settings .info-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.push-notification-settings .info-item .label{font-size:13px;color:var(--text-secondary);font-weight:500}.push-notification-settings .info-item .value{font-size:13px;color:var(--text-primary);font-weight:400}.push-notification-settings .info-item .value.success{color:var(--status-success);font-weight:500}.push-notification-settings .help-section{border-top:1px solid var(--border-primary);padding-top:var(--spacing-md)}.push-notification-settings .help-section details{cursor:pointer}.push-notification-settings .help-section summary{font-size:14px;font-weight:500;color:var(--status-info);padding:var(--spacing-sm) 0;outline:none;-webkit-user-select:none;user-select:none}.push-notification-settings .help-section summary:hover{text-decoration:underline}.push-notification-settings .help-content{padding:12px 0;color:var(--text-secondary);font-size:13px;line-height:1.5}.push-notification-settings .help-content h5{margin:var(--spacing-md) 0 var(--spacing-sm) 0;color:var(--text-primary);font-size:14px;font-weight:600}.push-notification-settings .help-content h5:first-child{margin-top:0}.push-notification-settings .help-content ul{margin:0;padding-left:20px}.push-notification-settings .help-content li{margin:var(--spacing-xs) 0}.push-notification-settings .btn-primary{background:var(--btn-primary-bg);color:#fff;border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.push-notification-settings .btn-primary:hover:not(:disabled){background:var(--btn-primary-hover)}.push-notification-settings .btn-primary:disabled{background:var(--color-basic-disabled);color:var(--color-basic-text-disabled);cursor:not-allowed}.push-notification-settings .btn-secondary{background:var(--bg-card);color:var(--status-info);border:1px solid var(--border-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.push-notification-settings .btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--status-info)}.push-notification-settings .btn-secondary:disabled{background:var(--color-basic-disabled);color:var(--color-basic-text-disabled);border-color:var(--color-basic-border-disabled);cursor:not-allowed}.push-notification-settings .btn-text{background:none;color:var(--status-info);border:none;padding:var(--spacing-xs) var(--spacing-sm);font-size:13px;font-weight:500;cursor:pointer;text-decoration:underline}.push-notification-settings .btn-text:hover{text-decoration:none}@media (max-width: 768px){.push-notification-settings{padding:var(--spacing-md);margin:12px 0}.push-notification-settings .control-group{flex-direction:column;gap:var(--spacing-md)}.push-notification-settings .control-actions{align-self:flex-start}.push-notification-settings .info-grid{gap:12px}.push-notification-settings .info-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}.settings-tabs{display:flex;border-bottom:1px solid var(--border-primary);margin-bottom:0}.settings-tab{flex:1;padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.settings-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.settings-tab.active{color:var(--btn-primary-bg);border-bottom-color:var(--btn-primary-bg);background:var(--bg-secondary)}.settings-container{width:100%}.settings-section{background:var(--bg-card);border-radius:8px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border-primary)}.setting-group{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border-primary)}.setting-group:last-child{border-bottom:none;margin-bottom:0}.setting-group.reset-section{border-top:2px solid var(--border-primary);padding-top:24px;margin-top:16px}.setting-subtitle{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.settings-section h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid var(--border-primary)}.setting-subsection h4{font-size:14px;font-weight:500;color:var(--text-secondary);margin:0 0 12px;padding-left:8px;border-left:3px solid var(--btn-primary-bg)}.setting-subsection{margin-bottom:20px;padding:12px;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-secondary)}.setting-subsection:last-child{margin-bottom:0}.setting-item{margin-bottom:20px}.setting-item:last-child{margin-bottom:0}.setting-label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.radio-group{display:flex;flex-direction:column;gap:12px}.radio-option{display:flex;align-items:center;cursor:pointer;padding:8px 0}.radio-input{width:16px;height:16px;margin-right:12px;accent-color:var(--btn-primary-bg)}.radio-label{font-size:14px;color:var(--text-primary)}.select-input{width:200px;padding:8px 12px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;transition:border-color .2s,box-shadow .2s}.select-input:focus{outline:none;border-color:var(--btn-primary-bg);box-shadow:0 0 0 2px rgba(var(--btn-primary-rgb),.2)}.toggle-option{display:flex;align-items:center;cursor:pointer}.toggle-input{width:20px;height:20px;margin-right:8px;accent-color:var(--btn-primary-bg)}.dark .toggle-label{color:var(--text-primary);opacity:.9}.light .toggle-label{color:var(--text-primary)}.reset-description{font-size:12px;color:var(--text-secondary);margin-top:8px;margin-bottom:0}.settings-actions{margin-top:32px;padding-top:24px;border-top:2px solid var(--border-primary)}.button-group{display:flex;justify-content:flex-end;gap:16px}.button-group .btn{min-width:100px;padding:12px 24px;font-size:14px}.help-text{text-align:center;font-size:12px;color:var(--text-secondary);margin-top:8px;margin-bottom:0}.loading-container{display:flex;justify-content:center;align-items:center;height:200px}.loading-text{font-size:14px;color:var(--text-secondary)}@media (max-width: 768px){.settings-container{padding:0 16px}.settings-section{padding:16px}.select-input{width:100%}}.theme-selector{display:flex;gap:0;margin-top:12px;border:1px solid var(--border-primary);border-radius:8px;overflow:hidden}.theme-option{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:center;padding:12px 16px;border:none;border-right:1px solid var(--border-primary);background:var(--bg-secondary);cursor:pointer;transition:all .2s ease;min-height:48px;opacity:.3;gap:8px}.theme-option:last-child{border-right:none}.theme-option.active{background:var(--bg-card);border-bottom:3px solid #6a6a6a;font-weight:600;opacity:1;box-shadow:0 2px 4px #0000001a}.theme-option:hover{border-color:var(--btn-primary-bg);background:var(--bg-tertiary);transform:translateY(-2px);opacity:.8}.theme-option.active:hover{opacity:1}.theme-option.active{border-color:#6a6a6a;background:#6a6a6a;color:var(--text-inverse);box-shadow:var(--btn-primary-shadow)}.theme-option[data-theme=light]{background:#fff;color:#333}.theme-option[data-theme=light]:hover{background:#e8e8e8}.theme-option[data-theme=light].active{background:#fff;color:#333;border-color:#6a6a6a}.theme-option[data-theme=dark]{background:#1a1a1a;color:#fff}.theme-option[data-theme=dark]:hover{background:#2a2a2a}.theme-option[data-theme=dark].active{background:#1a1a1a;color:#fff;border-color:#6a6a6a}.theme-option[data-theme=system]{background:var(--bg-primary);color:var(--text-primary)}.theme-option[data-theme=system]:hover{background:var(--bg-tertiary)}.theme-option[data-theme=system].active{background:var(--bg-primary);color:var(--text-primary);border-color:#6a6a6a}.dark .theme-option[data-theme=system]{background:#1a1a1a;color:#fff}.dark .theme-option[data-theme=system]:hover{background:#2a2a2a}.dark .theme-option[data-theme=system].active{background:#1a1a1a;color:#fff;border-color:#6a6a6a}.light .theme-option[data-theme=system]{background:#fff;color:#333}.light .theme-option[data-theme=system]:hover{background:#f8f9fa}.light .theme-option[data-theme=system].active{background:#1a1a1a;color:#fff;border-color:#6a6a6a}.theme-icon{font-size:20px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0}.theme-icon img{transition:filter .2s ease}.theme-option[data-theme=light] .theme-icon img{filter:brightness(0) saturate(100%) invert(20%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(100%) contrast(100%)}.theme-option[data-theme=dark] .theme-icon img{filter:brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(100%) contrast(100%)}.theme-option[data-theme=system] .theme-icon img{filter:var(--icon-filter-secondary)}.dark .theme-option[data-theme=system] .theme-icon img{filter:var(--icon-filter-white)}.light .theme-option[data-theme=system] .theme-icon img{filter:var(--icon-filter-light)}.theme-label{font-size:14px;font-weight:500;text-align:center;line-height:20px;height:20px;display:flex;align-items:center}.theme-option.active .theme-label{color:var(--text-inverse)}@media (max-width: 480px){.theme-selector{flex-direction:column;gap:12px}.theme-option{min-height:auto;padding:12px 16px}.theme-icon{font-size:20px}}.error-handling-toast{position:fixed;width:var(--error-handling-toast-width-desktop);max-width:var(--error-handling-toast-max-width);min-height:var(--error-handling-toast-min-height);padding:var(--error-handling-toast-padding);background:var(--error-handling-toast-bg);box-shadow:var(--error-handling-shadow-toast);z-index:var(--error-handling-z-toast);color:var(--error-handling-toast-text);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);transform:translate(100%);opacity:0;transition:all var(--error-handling-transition-normal);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans KR,sans-serif;font-size:15px;line-height:1.5;font-weight:500;position:relative}.error-handling-toast:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}@media (max-width: 768px){.error-handling-toast{width:var(--error-handling-toast-width-mobile);max-width:calc(100vw - 32px);margin:0 16px}}.error-handling-toast--top-right{top:20px;right:20px}.error-handling-toast--top-left{top:20px;left:20px;transform:translate(-100%)}.error-handling-toast--bottom-right{bottom:20px;right:20px}.error-handling-toast--bottom-left{bottom:20px;left:20px;transform:translate(-100%)}.error-handling-toast--visible{transform:translate(0);opacity:1}.error-handling-toast--closing{transform:translate(100%);opacity:0}.error-handling-toast--top-left.error-handling-toast--closing,.error-handling-toast--bottom-left.error-handling-toast--closing{transform:translate(-100%)}.error-handling-toast--success:before{background:var(--error-handling-toast-success-accent)}.error-handling-toast--warning:before{background:var(--error-handling-toast-warning-accent)}.error-handling-toast--error:before{background:var(--error-handling-toast-error-accent)}.error-handling-toast--info:before{background:var(--error-handling-toast-info-accent)}.error-handling-toast__content{display:flex;align-items:flex-start;gap:12px}.error-handling-toast__icon-wrapper{flex-shrink:0;width:var(--error-handling-icon-size-md);height:var(--error-handling-icon-size-md);margin-top:2px}.error-handling-toast__icon{width:100%;height:100%}.error-handling-toast--success .error-handling-toast__icon{color:var(--error-handling-toast-success-accent)}.error-handling-toast--warning .error-handling-toast__icon{color:var(--error-handling-toast-warning-accent)}.error-handling-toast--error .error-handling-toast__icon{color:var(--error-handling-toast-error-accent)}.error-handling-toast--info .error-handling-toast__icon{color:var(--error-handling-toast-info-accent)}.error-handling-toast__text{flex:1;min-width:0}.error-handling-toast__title{font-weight:600;font-size:16px;margin-bottom:6px;word-wrap:break-word;color:inherit}.error-handling-toast__message{font-size:14px;line-height:1.5;word-wrap:break-word;opacity:.8;color:inherit}.error-handling-toast__close{flex-shrink:0;width:20px;height:20px;margin-top:2px;padding:0;background:none;border:none;cursor:pointer;color:currentColor;opacity:.5;transition:opacity var(--error-handling-transition-fast);border-radius:var(--border-radius-sm)}.error-handling-toast__close:hover{opacity:.8}.error-handling-toast__close:focus{outline:2px solid currentColor;outline-offset:2px;opacity:1}.error-handling-toast__close svg{width:100%;height:100%}.error-handling-toast__progress{position:absolute;bottom:0;left:0;height:3px;width:100%;background:currentColor;opacity:.3;border-radius:0;transform-origin:left;animation:error-handling-toast-progress linear forwards}@keyframes error-handling-toast-progress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}@media (prefers-reduced-motion: reduce){.error-handling-toast{transition:none}.error-handling-toast__progress{animation:none}}@media (prefers-contrast: high){.error-handling-toast{border-width:2px}.error-handling-toast__close:focus{outline-width:3px}}.error-handling-toast-container{position:fixed;z-index:var(--error-handling-z-toast);pointer-events:none}.error-handling-toast-container--top-right{top:20px;right:20px}.error-handling-toast-container--top-left{top:20px;left:20px}.error-handling-toast-container--bottom-right{bottom:20px;right:20px}.error-handling-toast-container--bottom-left{bottom:20px;left:20px}.error-handling-toast-container .error-handling-toast{position:relative;top:auto;right:auto;bottom:auto;left:auto;margin-bottom:12px;pointer-events:auto}.error-handling-toast-container .error-handling-toast:last-child{margin-bottom:0}.header-left{display:flex;align-items:center;gap:var(--spacing-md);flex:1;min-width:0;overflow:hidden}.header-center{display:flex;align-items:center;justify-content:center;flex:1;margin:0 var(--spacing-lg)}.header-right{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.header-buttons{display:flex;align-items:center;gap:var(--spacing-xs)}.logo{margin-right:var(--spacing-sm);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl)}.site-title{cursor:pointer;transition:color .2s;-webkit-user-select:none;user-select:none;font-size:var(--font-md);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.site-title:hover{color:var(--btn-primary-bg)}.user-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:6px;transition:all .2s ease}.user-name{font-weight:600;color:var(--text-primary);font-size:var(--font-md);white-space:nowrap}.user-role{font-size:var(--font-xs);color:var(--text-tertiary);margin-left:var(--spacing-xs);white-space:nowrap}.header-btn,.menu-btn,.btn-settings,.btn-logout,.notification-btn{background:none;border:none;cursor:pointer;padding:var(--spacing-sm);border-radius:50%;transition:all .2s ease;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;position:relative;color:var(--text-primary);outline:none;-webkit-user-select:none;user-select:none}.header-btn .icon,.menu-btn .icon,.btn-settings .icon,.btn-logout .icon,.notification-btn .icon{cursor:pointer;pointer-events:none}.icon.clickable{cursor:pointer!important;-webkit-user-select:none;user-select:none}.icon.clickable:hover{opacity:.8}.icon.clickable:active{transform:scale(.95)}.header-btn:hover,.menu-btn:hover,.btn-settings:hover,.btn-logout:hover,.notification-btn:hover{background:var(--bg-tertiary);transform:translateY(-1px)}.header-btn:active,.menu-btn:active,.btn-settings:active,.btn-logout:active,.notification-btn:active{transform:translateY(0)}.notification-container .notification-btn:hover:not(:disabled){background:var(--bg-tertiary)!important;transform:translateY(-1px)!important}.notification-container .notification-btn:active:not(:disabled){transform:translateY(0)!important}.notification-container .notification-btn.realtime:hover:not(:disabled){background:var(--bg-tertiary)!important;transform:translateY(-1px)!important}.badge{position:absolute;top:0;right:0;background:var(--status-error);color:#fff;border-radius:50%;width:18px;height:18px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.menu-sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--overlay-bg);z-index:1999;opacity:0;visibility:hidden;transition:all .3s ease}.menu-sidebar-overlay.active{opacity:1;visibility:visible}.menu-sidebar{position:fixed;top:0;left:-380px;width:380px;height:100vh;background:var(--sidebar-bg);box-shadow:2px 0 20px #00000026;z-index:2000;transition:left .3s ease;overflow-y:auto;display:flex;flex-direction:column}.menu-sidebar.active{left:0}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--sidebar-border);background:var(--sidebar-header-bg);flex-shrink:0}.sidebar-header-controls{display:flex;align-items:center;gap:var(--spacing-sm)}.sidebar-header h3{margin:0;color:var(--sidebar-text-primary);font-size:var(--font-lg);font-weight:600}.sidebar-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--sidebar-text-muted);padding:var(--spacing-xs);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.sidebar-close:hover{background:var(--sidebar-hover-bg);color:var(--sidebar-text-primary)}.sidebar-content{padding:var(--spacing-sm) 0;flex:1;overflow-y:auto}.sidebar-menu-item{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;transition:all .2s ease;border-left:4px solid transparent;text-decoration:none;color:inherit}.sidebar-menu-item:hover{background:var(--sidebar-hover-bg)}.sidebar-menu-item.active{background:var(--sidebar-active-bg);border-left-color:var(--sidebar-active-border)}.sidebar-menu-icon{margin-right:var(--spacing-md);width:40px;display:flex;align-items:center;justify-content:center;font-size:18px}.dark .sidebar-menu-icon img,.dark img[src*=chevron-down-small],.dark img[src*=chevron-right-small]{filter:brightness(0) invert(1)!important}.sidebar-menu-content{flex:1;min-width:0}.sidebar-menu-title{font-size:var(--font-md);font-weight:600;color:var(--sidebar-text-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-menu-description{font-size:var(--font-xs);color:var(--sidebar-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-menu-arrow{font-size:12px;color:var(--sidebar-text-muted);margin-left:auto;transition:transform .2s}.sidebar-submenu{background:var(--sidebar-hover-bg);border-left:4px solid var(--sidebar-border);margin-left:var(--spacing-lg)}.sidebar-submenu-item{display:flex;align-items:center;padding:var(--spacing-sm) var(--spacing-lg);cursor:pointer;transition:all .2s ease;border-left:4px solid transparent}.sidebar-submenu-item:hover{background:var(--sidebar-bg);border-left-color:var(--sidebar-text-muted)}.sidebar-submenu-item.disabled{cursor:not-allowed;opacity:.6}.submenu-icon{font-size:16px;margin-right:var(--spacing-sm);width:24px;text-align:center}.submenu-content{flex:1;min-width:0}.submenu-title{font-size:var(--font-sm);font-weight:500;color:var(--sidebar-text-secondary);margin-bottom:2px}.submenu-description{font-size:11px;color:var(--sidebar-text-muted)}.menu-sidebar .sidebar-company-select .MuiFormControl-root,.menu-sidebar .sidebar-company-select .MuiSelect-root,.menu-sidebar .sidebar-company-select .MuiOutlinedInput-root{z-index:2050}@media (max-width: 575.98px){header{padding:0 var(--spacing-sm);min-height:56px}.header-left{gap:var(--spacing-sm)}.header-right{gap:var(--spacing-xs)}.header-btn,.menu-btn,.btn-settings,.btn-logout,.notification-btn{min-width:40px;min-height:40px;padding:var(--spacing-xs)}.logo{font-size:20px}.site-title{font-size:var(--font-md);max-width:120px}.user-name{font-size:var(--font-sm);max-width:80px}.user-role,.logout-text{display:none}.menu-sidebar{width:320px;left:-320px}.sidebar-header{padding:var(--spacing-md)}.sidebar-menu-item{padding:var(--spacing-sm) var(--spacing-md)}}@media (min-width: 576px) and (max-width: 767.98px){header{min-height:60px}.site-title{font-size:var(--font-lg);max-width:150px}.user-name{max-width:100px}.menu-sidebar{width:350px;left:-350px}}@media (min-width: 768px) and (max-width: 991.98px){.site-title{max-width:200px}.user-name{max-width:120px}}@media (min-width: 992px){.site-title,.user-name{max-width:none}.sidebar-header{padding:var(--spacing-xl)}.sidebar-menu-item{padding:var(--spacing-md) var(--spacing-xl)}}.sidebar-menu-section{margin-bottom:var(--spacing-md);width:100%;overflow:hidden}.sidebar-section-header{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);margin-bottom:var(--spacing-xs);background:var(--bg-secondary);border-radius:var(--radius-sm);border-left:3px solid var(--color-primary);width:100%;box-sizing:border-box;overflow:hidden}.sidebar-section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.sidebar-menu-section .sidebar-menu-item{margin-left:var(--spacing-md);border-left:2px solid transparent;width:calc(100% - var(--spacing-md));box-sizing:border-box;overflow:hidden}.sidebar-menu-section .sidebar-menu-item:hover{border-left-color:var(--color-primary);background:var(--bg-hover)}.sidebar-menu-section .sidebar-menu-item.active{border-left-color:var(--color-primary);background:var(--bg-selected)}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.menu-btn img,.btn-settings img,.sidebar-menu-icon img{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}.dark .sidebar-close{color:var(--text-primary)}.dark .sidebar-close:hover{color:var(--text-primary);background:var(--sidebar-hover-bg)}@media (prefers-reduced-motion: reduce){.header-btn,.menu-btn,.btn-settings,.btn-logout,.notification-btn,.menu-sidebar,.menu-sidebar-overlay{transition:none}}.header-btn:focus,.menu-btn:focus,.btn-settings:focus,.btn-logout:focus,.notification-btn:focus,.sidebar-close:focus,.sidebar-menu-item:focus{outline:2px solid var(--primary-color);outline-offset:2px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--border-primary);background:var(--bg-primary)}.sidebar-logo{display:flex;align-items:center;justify-content:center}.sidebar-header-controls{display:flex;align-items:center;gap:var(--spacing-xs)}.sidebar-content{display:flex;flex-direction:column;height:100%}.sidebar-user-info{padding:var(--spacing-md);border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.sidebar-user-details{display:flex;align-items:center;justify-content:space-between;width:100%}.sidebar-user-left{display:flex;align-items:center;gap:var(--spacing-sm)}.sidebar-user-name{font-size:var(--font-md);font-weight:500;color:var(--text-primary)}.sidebar-user-role{font-size:var(--font-sm);color:var(--text-secondary);background:var(--bg-tertiary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);display:inline-block;white-space:nowrap}.sidebar-action-btn.logout.inline{color:var(--danger-color);margin:0;background:none;border:none;padding:var(--spacing-xs);min-width:auto;width:auto;min-height:auto;flex:none}.sidebar-company-select{margin-top:var(--spacing-md);width:100%}.sidebar-menu-items{flex:1;overflow-y:auto;padding:var(--spacing-sm) 0}.sidebar-bottom-actions{padding:var(--spacing-md);border-top:1px solid var(--border-primary);background:var(--bg-secondary);display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:auto}.sidebar-action-section{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.sidebar-action-buttons{display:flex;gap:var(--spacing-sm);justify-content:space-between}.sidebar-action-btn{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);background:var(--bg-tertiary);border:none;border-radius:var(--border-radius);color:var(--text-secondary);font-size:var(--font-md);font-weight:500;cursor:pointer;transition:all .2s ease;flex:1;min-height:40px;text-align:center}.sidebar-action-btn:hover{background:var(--bg-hover);color:var(--text-primary);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.sidebar-action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.sidebar-action-btn:disabled:hover{background:none;color:var(--text-secondary);transform:none}.sidebar-action-btn.logout{color:var(--danger-color);margin-top:var(--spacing-sm);border-top:1px solid var(--border-primary);padding-top:var(--spacing-md)}.sidebar-action-btn.logout:hover{background:var(--danger-bg);color:var(--danger-color)}.sidebar-theme-toggle{width:100%}.company-filter-mui{display:flex;align-items:center;gap:var(--spacing-xs)}.company-filter-container{position:relative;display:flex;align-items:center}.company-filter-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;font-size:var(--font-sm);color:var(--text-primary);min-height:36px;outline:none}.company-filter-btn:hover{background:var(--bg-tertiary);border-color:var(--border-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.company-filter-btn:focus{outline:2px solid var(--primary-color);outline-offset:2px}.company-filter-text{font-weight:500;white-space:nowrap;max-width:150px;overflow:hidden;text-overflow:ellipsis}.company-filter-dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:250px;background:var(--bg-card);border:1px solid var(--border-secondary);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);z-index:1001;overflow:hidden}.company-filter-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-secondary);font-size:var(--font-sm);font-weight:600;color:var(--text-secondary)}.company-filter-close{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text-tertiary);padding:2px;border-radius:2px;transition:all .2s ease}.company-filter-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.company-filter-list{max-height:300px;overflow-y:auto}.company-filter-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:all .2s ease;border:none;background:none;width:100%;text-align:left;font-size:var(--font-sm);color:var(--text-primary)}.company-filter-item:hover{background:var(--bg-hover)}.company-filter-item.active{background:var(--bg-selected);color:var(--primary-color);font-weight:500}.company-filter-item span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.company-filter-footer{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-secondary);border-top:1px solid var(--border-secondary);color:var(--text-tertiary);text-align:center}@media (max-width: 767.98px){.header-center{margin:0 var(--spacing-sm)}.company-filter-text{max-width:100px}.company-filter-dropdown{min-width:200px;right:0;left:auto}}@media (max-width: 575.98px){.header-center{display:none}}@media (hover: none) and (pointer: coarse){.header-btn:hover,.menu-btn:hover,.btn-settings:hover,.btn-logout:hover,.notification-btn:hover,.notification-container .notification-btn:hover,.notification-container .notification-btn.realtime:hover,.sidebar-menu-item:hover,.sidebar-action-btn:hover,.company-filter-btn:hover,.company-filter-item:hover{transform:none;background:var(--bg-tertiary)}}.sidebar-company-filter-badge{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,var(--color-primary-light, #e3f2fd) 0%,var(--color-primary-lighter, #bbdefb) 100%);border:1px solid var(--color-primary, #1976d2);border-radius:var(--radius-md);box-shadow:0 2px 4px #0000001a}.filter-badge-content{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-primary-dark, #1565c0);font-weight:500}.filter-badge-content svg{font-size:18px;color:var(--color-primary, #1976d2)}.filter-badge-label{font-size:var(--font-sm);color:var(--text-secondary);font-weight:400}.filter-company-name{font-size:var(--font-sm);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.filter-clear-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--bg-primary);border:1px solid var(--color-primary, #1976d2);border-radius:50%;color:var(--color-primary, #1976d2);font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;flex-shrink:0}.filter-clear-btn:hover{background:var(--color-primary, #1976d2);color:#fff;transform:scale(1.1)}.dark .sidebar-company-filter-badge{background:linear-gradient(135deg,#1976d233,#1976d21a);border-color:var(--color-primary, #42a5f5)}.dark .filter-badge-content{color:var(--color-primary-light, #90caf9)}.dark .filter-badge-content svg{color:var(--color-primary-light, #90caf9)}.dark .filter-badge-label{color:var(--text-secondary)}.dark .filter-company-name{color:var(--color-primary-light, #90caf9)}.dark .filter-clear-btn{background:var(--bg-secondary);border-color:var(--color-primary-light, #90caf9);color:var(--color-primary-light, #90caf9)}.dark .filter-clear-btn:hover{background:var(--color-primary, #42a5f5);color:var(--bg-primary)}.sidebar-admin-home-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);width:100%;padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-sm);cursor:pointer;transition:all .2s ease}.sidebar-admin-home-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--color-primary)}.sidebar-admin-home-btn svg{font-size:16px}footer{background-color:var(--bg-secondary);transition:all .3s ease;overflow:hidden}footer.expanded{height:auto;max-height:120px}footer:not(.expanded){height:40px;max-height:40px}.footer-content{transition:all .3s ease;height:100%;display:flex;align-items:center;padding:0 20px}.footer-simple{display:flex;justify-content:space-between;align-items:center;width:100%}.footer-simple-left{display:flex;align-items:center;gap:12px}.footer-logo{height:17px;width:auto;object-fit:contain;margin:4px 0 4px 4px}.footer-expanded-header{display:flex;align-items:center;gap:12px}.footer-expanded{display:none}footer.expanded .footer-expanded{display:flex;justify-content:space-between;align-items:center;gap:10px;width:100%}.company{font-weight:600;color:var(--text-primary);font-size:14px}.copyright{color:var(--text-tertiary);font-size:12px}.footer-left{display:flex;align-items:center;gap:16px;height:100%}.footer-left .logo{width:auto;height:45px;object-fit:contain}.footer-info{display:flex;flex-direction:column;gap:0}.footer-info .copyright{font-size:12px;color:var(--text-tertiary);line-height:1.4;margin:4px 0}.footer-info .company{font-size:16px;font-weight:700;color:var(--text-primary);line-height:1.4}.footer-info .copyright{font-size:12px;color:var(--text-tertiary);line-height:1.4}.footer-right{display:flex;align-items:center}.contact{text-align:right}.contact p{margin:0;color:var(--text-secondary);font-size:14px;line-height:1.4}.contact .address{color:var(--text-tertiary);font-size:12px}@media (max-width: 768px){.footer-content{padding:0 16px}footer.expanded .footer-expanded{display:none!important}footer.expanded .footer-simple{display:flex!important}.footer-left{flex-direction:column;gap:12px}.contact{text-align:center}.footer-info .company{font-size:14px}}footer{transition:opacity .3s ease}footer.hidden{display:none}.common-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:modal-overlay-fade-in .2s ease-out}@keyframes modal-overlay-fade-in{0%{opacity:0}to{opacity:1}}.common-modal{background:var(--surface-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:90vh;outline:none;animation:modal-slide-up .25s ease-out}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.common-modal-xs{width:100%;max-width:400px}.common-modal-sm{width:100%;max-width:520px}.common-modal-md{width:100%;max-width:680px}.common-modal-lg{width:100%;max-width:900px}.common-modal-xl{width:100%;max-width:1100px}.common-modal-full{width:95vw;max-width:none;height:90vh}.common-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-primary);background:var(--surface-secondary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;flex-shrink:0}.modal-header-content{display:flex;align-items:center;gap:var(--spacing-sm);min-width:0;flex:1}.modal-header-icon{width:24px;height:24px;color:var(--primary-600);flex-shrink:0}.modal-title-wrapper{display:flex;flex-direction:column;gap:var(--spacing-2xs);min-width:0}.modal-title{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);line-height:1.3}.modal-subtitle{margin:0;font-size:var(--font-size-sm);color:var(--text-secondary)}.common-modal-header .modal-close-btn{position:static!important;top:auto!important;right:auto!important;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;margin-left:var(--spacing-sm)}.common-modal-header .modal-close-btn:hover{background:var(--surface-tertiary);color:var(--text-primary)}.common-modal-header .modal-close-btn svg{width:20px;height:20px}.common-modal-body{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.common-modal-full .common-modal-body{padding:var(--spacing-xl)}.common-modal-footer{display:flex;justify-content:flex-end;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-primary);background:var(--surface-secondary);border-radius:0 0 var(--radius-xl) var(--radius-xl);flex-shrink:0}.btn-modal{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-sm);border:none;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);min-width:80px}.btn-modal:disabled{cursor:not-allowed}.btn-modal svg{width:18px;height:18px}.btn-modal.btn-cancel{background:var(--surface-tertiary);color:var(--text-secondary)}.btn-modal.btn-cancel:hover{background:var(--surface-primary);color:var(--text-primary)}.btn-modal.btn-primary{background:var(--primary-600);color:#fff}.btn-modal.btn-primary:hover{background:var(--primary-700)}.btn-modal.btn-primary:disabled{background:var(--primary-300)}.btn-modal.btn-danger{background:var(--danger-600);color:#fff}.btn-modal.btn-danger:hover{background:var(--danger-700)}.btn-modal.btn-warning{background:var(--warning-600);color:#fff}.btn-modal.btn-warning:hover{background:var(--warning-700)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);width:100%}@media (max-width: 480px){.modal-actions{flex-direction:column}}.confirm-dialog-message{margin:0;font-size:var(--font-size-md);color:var(--text-primary);line-height:1.6;text-align:center;padding:var(--spacing-md) 0}.confirm-dialog-actions{display:flex;gap:var(--spacing-sm);width:100%}.confirm-dialog-actions .btn-modal{flex:1}.alert-dialog-message{margin:0;font-size:var(--font-size-md);color:var(--text-primary);line-height:1.6;text-align:center;padding:var(--spacing-md) 0}.alert-dialog-actions{display:flex;justify-content:center;width:100%}.alert-dialog-actions .btn-modal{min-width:120px}.alert-dialog-info .modal-header-icon{color:var(--info-600)}.alert-dialog-success .modal-header-icon{color:var(--success-600)}.alert-dialog-warning .modal-header-icon{color:var(--warning-600)}.alert-dialog-error .modal-header-icon{color:var(--danger-600)}[data-theme=dark] .common-modal{background:var(--surface-primary)}[data-theme=dark] .common-modal-header{background:var(--surface-secondary)}[data-theme=dark] .common-modal-header .modal-close-btn:hover{background:var(--surface-tertiary)}[data-theme=dark] .common-modal-footer,[data-theme=dark] .btn-modal.btn-cancel{background:var(--surface-secondary)}[data-theme=dark] .btn-modal.btn-cancel:hover{background:var(--surface-tertiary)}@media (max-width: 768px){.common-modal-overlay{padding:var(--spacing-sm)}.common-modal{max-height:95vh}.common-modal-header{padding:var(--spacing-sm) var(--spacing-md)}.modal-title{font-size:var(--font-size-md)}.common-modal-body{padding:var(--spacing-md)}.common-modal-footer{padding:var(--spacing-sm) var(--spacing-md);flex-wrap:wrap}.btn-modal{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-xs)}.common-modal-xs,.common-modal-sm{max-width:calc(100% - var(--spacing-md))}}@media (max-width: 480px){.confirm-dialog-actions,.alert-dialog-actions{flex-direction:column}.confirm-dialog-actions .btn-modal,.alert-dialog-actions .btn-modal{width:100%}}:root{--red-200: #F59B90;--red-400: #D9483B;--red-500: #C73C32;--red-600: #B03028;--red-800: #99261F;--red-900: #7F1F19;--red-1000: #611611;--yellow-200: #FFE58A;--yellow-400: #FFD84D;--yellow-500: #FFD133;--yellow-600: #FFC933;--yellow-800: #FFB800;--yellow-900: #E6A500;--yellow-1000: #CC9100;--green-100: #52B572;--green-200: #389A58;--green-400: #198038;--green-500: #146C2E;--green-600: #0F5824;--green-800: #073714;--green-900: #05290F;--green-1000: #041F0B;--orange-200: #FFD1A3;--orange-400: #F57C00;--orange-500: #E86E00;--orange-600: #D95F00;--orange-800: #BF4A00;--orange-900: #A63E00;--orange-1000: #802E00;--neutral-100: #E2E2E2;--neutral-200: #C8C8C8;--neutral-400: #5A5A5A;--neutral-500: #4F4F4F;--neutral-600: #444444;--neutral-800: #333333;--neutral-900: #262626;--neutral-1000: #141414;--blue-200: #8AC1F5;--blue-400: #1E75CC;--blue-500: #1B68B8;--blue-600: #175AA3;--blue-800: #124786;--blue-900: #0D3669;--blue-1000: #09284D;--primary-200: #A9C7E1;--primary-400: #4A84BD;--primary-500: #4175A9;--primary-600: #386695;--primary-800: #315683;--primary-900: #27466B;--primary-1000: #1D3450;--soft-blue-075: #B0C6E5;--soft-blue-050: #c3d9f3;--soft-blue-025: #eef1fb;--soft-blue-015: #F9F9FC;--soft-green-075: #A5D0B6;--soft-green-050: #C0DDC8;--soft-green-025: #E7F5EA;--soft-green-015: #F2FBF4;--soft-neutral-075: #C8C8C8;--soft-neutral-050: #D8D8D8;--soft-neutral-025: #F0F0F0;--soft-neutral-015: #F9F9F9;--soft-neutral-000: #f8f9fa;--bg-primary: #f4f5f5;--bg-secondary:#f6f6f7;--bg-tertiary: #e8eaed;--bg-card: #f6f6f7;--bg-panel: #f8f9fa;--bg-modal: #f8f9fa;--bg-tertiary2: #f0f1f3;--bg-soft: #ececee;--surface-primary: #ffffff;--surface-secondary: #f8f9fa;--surface-tertiary: #f1f3f4;--text-primary: #1a202c;--text-secondary: #4a5568;--text-tertiary: #718096;--text-muted: #a0aec0;--border-primary: #d1d5db;--border-secondary: #cbd5e0;--border-focus: var(--blue-400);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1), inset 0 1px 0 rgba(255, 255, 255, .6);--shadow-md: 0 4px 24px rgba(0, 0, 0, .08), 0 1px 3px rgba(0, 0, 0, .06), inset 0 1px 0 rgba(255, 255, 255, .7);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12), 0 3px 8px rgba(0, 0, 0, .08), inset 0 1px 0 rgba(255, 255, 255, .8);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .15), 0 8px 16px rgba(0, 0, 0, .06), inset 0 1px 0 rgba(255, 255, 255, .8);--btn-primary-bg: var(--primary-color);--btn-primary-hover: var(--primary-hover);--btn-secondary-bg: var(--neutral-400);--btn-secondary-hover: var(--neutral-600);--btn-success-bg: var(--green-400);--btn-success-hover: var(--green-600);--btn-danger-bg: var(--red-400);--btn-danger-hover: var(--red-600);--btn-white-bg: #ffffff;--btn-white-hover: #f9fafb;--input-bg: rgba(255, 255, 255, .8);--input-border: #e5e7eb;--input-focus-border: var(--blue-400);--status-success: var(--green-400);--status-warning: var(--yellow-400);--status-error: var(--red-400);--status-info: var(--blue-400);--status-success-bg: rgba(76, 175, 80, .08);--status-success-border: rgba(76, 175, 80, .2);--status-success-shadow: rgba(76, 175, 80, .1);--status-warning-bg: rgba(245, 158, 11, .08);--status-warning-border: rgba(245, 158, 11, .2);--status-warning-shadow: rgba(245, 158, 11, .1);--status-error-bg: rgba(239, 68, 68, .08);--status-error-border: rgba(239, 68, 68, .2);--status-error-shadow: rgba(239, 68, 68, .1);--status-info-bg: rgba(59, 130, 246, .08);--status-info-border: rgba(59, 130, 246, .2);--status-info-shadow: rgba(59, 130, 246, .1);--status-normal-color: var(--green-400);--status-caution-color: var(--yellow-400);--status-warning-color: var(--orange-400);--status-danger-color: var(--red-400);--status-unknown-color: var(--neutral-400);--color-normal: #3b4cf0;--color-caution: #0ca678;--color-warning: #ea8b08;--color-danger: #e73c3c;--color-unknown: var(--status-unknown-color);--color-muted: var(--neutral-400);--icon-normal: url("data:image/svg+xml,%3csvg%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3c!--%20정상:%20원%20안에%20체크마크%20-%20안정감과%20완료의%20느낌%20--%3e%3ccircle%20cx='12'%20cy='12'%20r='10'%20stroke='currentColor'%20stroke-width='2'%20fill='none'/%3e%3cpath%20d='M7.5%2012.5L10.5%2015.5L16.5%209.5'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%20fill='none'/%3e%3c/svg%3e");--icon-caution: url("data:image/svg+xml,%3csvg%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3c!--%20주의:%20원%20안에%20느낌표%20-%20주목이%20필요한%20상태%20--%3e%3ccircle%20cx='12'%20cy='12'%20r='10'%20stroke='currentColor'%20stroke-width='2'%20fill='none'/%3e%3cline%20x1='12'%20y1='7'%20x2='12'%20y2='13'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'/%3e%3ccircle%20cx='12'%20cy='16.5'%20r='1.25'%20fill='currentColor'/%3e%3c/svg%3e");--icon-warning: url("data:image/svg+xml,%3csvg%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3c!--%20경고:%20삼각형%20안에%20느낌표%20-%20전통적인%20경고%20심볼%20--%3e%3cpath%20d='M12%203L21.5%2020H2.5L12%203Z'%20stroke='currentColor'%20stroke-width='2'%20stroke-linejoin='round'%20fill='none'/%3e%3cline%20x1='12'%20y1='9'%20x2='12'%20y2='14'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'/%3e%3ccircle%20cx='12'%20cy='17'%20r='1.25'%20fill='currentColor'/%3e%3c/svg%3e");--icon-danger: url("data:image/svg+xml,%3csvg%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3c!--%20위험:%20팔각형(정지%20표지판)%20안에%20X%20-%20긴급%20위험%20상태%20--%3e%3cpath%20d='M7.86%202H16.14L22%207.86V16.14L16.14%2022H7.86L2%2016.14V7.86L7.86%202Z'%20stroke='currentColor'%20stroke-width='2'%20stroke-linejoin='round'%20fill='none'/%3e%3cpath%20d='M15%209L9%2015M9%209L15%2015'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'/%3e%3c/svg%3e");--icon-unknown: url("data:image/svg+xml,%3csvg%20width='16'%20height='16'%20viewBox='0%200%2016%2016'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M8%201.5C4.5%201.5%201.5%204.5%201.5%208S4.5%2014.5%208%2014.5%2014.5%2011.5%2014.5%208%2011.5%201.5%208%201.5ZM9%2012.5H7V10.5H9V12.5ZM10%209.5C10%208.5%209.5%207.5%208.5%207.5S7%208.5%207%209.5H5C5%207.5%206.5%205.5%208.5%205.5S12%207.5%2012%209.5C12%2010.5%2011.5%2011.5%2010.5%2012L10%209.5Z'%20fill='currentColor'/%3e%3c/svg%3e");--color-basic-default: var(--btn-white-bg);--color-basic-border: var(--soft-neutral-075);--color-basic-text: var(--neutral-600);--color-basic-hover: var(--btn-white-hover);--color-basic-disabled: var(--soft-neutral-025);--color-basic-text-disabled: var(--soft-neutral-075);--color-basic-border-disabled: var(--soft-neutral-075);--color-black-default: #343a40;--color-black-border: #343a40;--color-black-text: #ffffff;--color-black-hover: #23272b;--color-black-disabled: #6c757d;--color-black-text-disabled: #adb5bd;--color-blue-default: var(--blue-400);--color-blue-border: var(--blue-400);--color-blue-text: #ffffff;--color-blue-hover: var(--blue-600);--color-blue-disabled: var(--soft-neutral-025);--color-blue-text-disabled: var(--soft-neutral-075);--color-blue-border-disabled: var(--soft-neutral-075);--color-green-default: var(--green-400);--color-green-border: var(--green-400);--color-green-text: #ffffff;--color-green-hover: var(--green-600);--color-green-disabled: var(--soft-neutral-025);--color-green-text-disabled: var(--soft-neutral-075);--color-green-border-disabled: var(--soft-neutral-075);--color-yellow-default: var(--yellow-400);--color-yellow-border: var(--yellow-400);--color-yellow-text: #ffffff;--color-yellow-hover: var(--yellow-1000);--color-yellow-disabled: var(--soft-neutral-025);--color-yellow-text-disabled: var(--soft-neutral-075);--color-yellow-border-disabled: var(--soft-neutral-075);--color-red-default: var(--red-400);--color-red-border: var(--red-400);--color-red-text: #ffffff;--color-red-hover: var(--red-600);--color-red-disabled: var(--soft-neutral-025);--color-red-text-disabled: var(--soft-neutral-075);--color-red-border-disabled: var(--soft-neutral-075);--color-purple-default: var(--primary-400);--color-purple-border: var(--primary-400);--color-purple-text: #ffffff;--color-purple-hover: var(--primary-600);--color-purple-disabled: var(--soft-neutral-025);--color-purple-text-disabled: var(--soft-neutral-075);--color-purple-border-disabled: var(--soft-neutral-075);--status-normal-bg: rgba(76, 175, 80, .1);--status-normal-border: rgba(50, 179, 104, .2);--status-caution-bg: rgba(255, 213, 79, .1);--status-caution-border: rgba(255, 213, 79, .2);--status-danger-bg: rgba(235, 106, 89, .1);--status-danger-border: rgba(244, 67, 54, .2);--alert-bg: #ffffff;--alert-border: #d1d5db;--alert-text-primary: #000000;--alert-text-secondary: #374151;--alert-danger-bg: rgba(239, 68, 68, .15);--alert-warning-bg: rgba(217, 119, 6, .15);--alert-caution-bg: rgba(217, 119, 6, .15);--alert-normal-bg: rgba(5, 150, 105, .15);--alert-info-bg: rgba(74, 124, 255, .15);--sidebar-bg: #ffffff;--sidebar-header-bg: #f8fafc;--sidebar-border: #e2e8f0;--sidebar-text-primary: #1a202c;--sidebar-text-secondary: #4a5568;--sidebar-text-muted: #a0aec0;--sidebar-hover-bg: #f1f5f9;--sidebar-active-bg: rgba(74, 124, 255, .1);--sidebar-active-border: #4A7CFF;--primary-color: #3B5BDB;--primary-hover: #2D4BC8;--secondary-color: #6c757d;--success-color: #28a745;--warning-color: #ffc107;--danger-color: #dc3545;--info-color: #17a2b8;--border-color: #e5e7eb;--border-light: #f0f0f0;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-md: 18px;--font-size-lg: 20px;--font-size-xl: 22px;--font-size-2xl: 26px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--login-bg-primary: #f8fafc;--login-bg-secondary: #e2e8f0;--login-card-bg: rgba(255, 255, 255, .95);--login-title-color: #1a202c;--login-subtitle-color: #4a5568;--login-label-color: #1a202c;--login-input-bg: rgba(255, 255, 255, .8);--login-input-border: #e5e7eb;--login-input-placeholder: #9ca3af;--login-info-bg: #f8fafc;--login-info-border: #e2e8f0;--login-info-text: #4a5568;--login-account-bg: #ffffff;--login-account-border: #4A7CFF;--login-account-text: #1a202c;--login-account-hover-bg: #f1f5f9;--login-accent-1: rgba(74, 124, 255, .1);--login-accent-2: rgba(0, 102, 255, .1);--login-accent-3: rgba(74, 124, 255, .05);--login-accent-primary: #4A7CFF;--login-accent-secondary: #0066FF;--login-card-shadow-1: rgba(74, 124, 255, .1);--login-card-shadow-2: rgba(0, 0, 0, .05);--login-card-highlight: rgba(255, 255, 255, .8);--login-logo-shadow: rgba(74, 124, 255, .2);--login-input-focus-shadow: rgba(74, 124, 255, .15);--login-input-focus-ring: rgba(74, 124, 255, .1);--login-toggle-focus: #4A7CFF;--login-caps-warning-icon: #f59e0b;--login-button-hover-shadow: rgba(74, 124, 255, .3);--login-button-shine: rgba(255, 255, 255, .2);--login-input-error-ring: rgba(239, 68, 68, .1);--alert-bg: #1a1a1a;--alert-border: #3a3a3a;--alert-text-primary: #ffffff;--alert-text-secondary: rgba(255, 255, 255, .6);--alert-danger-bg: rgba(239, 68, 68, .2);--alert-danger-text: #DC2626;--alert-warning-bg: rgba(217, 119, 6, .2);--alert-warning-text: #D97706;--alert-caution-bg: rgba(217, 119, 6, .2);--alert-caution-text: #D97706;--alert-normal-bg: rgba(5, 150, 105, .2);--alert-normal-text: #059669;--alert-info-bg: rgba(74, 124, 255, .2);--alert-info-text: #4A7CFF;--overlay-bg: rgba(0, 0, 0, .5);--badge-shadow: 0 1px 3px rgba(0, 0, 0, .1);--spinner-bg: #f3f3f3;--toggle-off-bg: #e5e7eb;--toggle-off-hover: #d1d5db;--toggle-on-bg: var(--green-600);--toggle-on-hover: var(--green-800);--caps-warning-bg: #fff3cd;--caps-warning-border: #ffeaa7;--caps-warning-text: #856404;--error-bg: #ffe6e6;--error-border: #ffcccc;--error-text: #e74c3c;--success-bg: #d5f4e6;--success-border: #27ae60;--success-text: #27ae60}.dark{--bg-primary: #121212;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--bg-card: #1e1e1e;--bg-panel: #0f0f0f;--bg-modal: rgba(18, 18, 18, .95);--surface-primary: #1e1e1e;--surface-secondary: #2a2a2a;--surface-tertiary: #3a3a3a;--text-primary: rgba(255, 255, 255, .97);--text-secondary: rgba(255, 255, 255, .6);--text-tertiary: rgba(255, 255, 255, .6);--text-muted: rgba(255, 255, 255, .38);--border-primary: #3a3a3a;--border-secondary: #4a4a4a;--border-focus: var(--blue-400);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3), inset 0 1px 0 rgba(255, 255, 255, .1);--shadow-md: 0 4px 24px rgba(0, 0, 0, .3), 0 1px 3px rgba(0, 0, 0, .15), inset 0 1px 0 rgba(255, 255, 255, .1);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4), 0 3px 8px rgba(0, 0, 0, .2), inset 0 1px 0 rgba(255, 255, 255, .15);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .5), 0 8px 16px rgba(0, 0, 0, .3), inset 0 1px 0 rgba(255, 255, 255, .1);--btn-primary-bg: var(--primary-color);--btn-primary-hover: var(--primary-hover);--btn-secondary-bg: var(--neutral-600);--btn-secondary-hover: var(--neutral-800);--btn-success-bg: var(--green-600);--btn-success-hover: var(--green-800);--btn-danger-bg: var(--red-600);--btn-danger-hover: var(--red-800);--btn-white-bg: #2a2a2a;--btn-white-hover: #3a3a3a;--input-bg: rgba(26, 26, 26, .8);--input-border: #3a3a3a;--input-focus-border: var(--blue-400);--status-success: #047857;--status-warning: #92400e;--status-error: #B91C1C;--status-info: #3B5BDB;--status-success-bg: rgba(16, 185, 129, .1);--status-success-border: rgba(16, 185, 129, .3);--status-success-shadow: rgba(16, 185, 129, .15);--status-warning-bg: rgba(245, 158, 11, .1);--status-warning-border: rgba(245, 158, 11, .3);--status-warning-shadow: rgba(245, 158, 11, .15);--status-error-bg: rgba(239, 68, 68, .1);--status-error-border: rgba(239, 68, 68, .3);--status-error-shadow: rgba(239, 68, 68, .15);--status-info-bg: rgba(59, 130, 246, .1);--status-info-border: rgba(59, 130, 246, .3);--status-info-shadow: rgba(59, 130, 246, .15);--sensor-mgmt-status-normal-color: var(--green-600);--sensor-mgmt-status-caution-color: var(--yellow-800);--sensor-mgmt-status-warning-color: var(--orange-600);--sensor-mgmt-status-danger-color: var(--red-600);--sensor-mgmt-status-unknown-color: var(--neutral-600);--color-basic-default: #2a2a2a;--color-basic-border: #3a3a3a;--color-basic-text: rgba(255, 255, 255, .97);--color-basic-hover: #3a3a3a;--color-basic-disabled: #2a2a2a;--color-basic-text-disabled: rgba(255, 255, 255, .38);--color-black-default: #1a1a1a;--color-black-border: #3a3a3a;--color-black-text: rgba(255, 255, 255, .97);--color-black-hover: #2a2a2a;--color-black-disabled: #1a1a1a;--color-black-text-disabled: rgba(255, 255, 255, .25);--color-blue-default: var(--blue-600);--color-blue-border: var(--blue-600);--color-blue-text: #ffffff;--color-blue-hover: var(--blue-800);--color-blue-disabled: var(--neutral-800);--color-blue-text-disabled: var(--neutral-200);--color-green-default: var(--green-600);--color-green-border: var(--green-600);--color-green-text: #ffffff;--color-green-hover: var(--green-800);--color-green-disabled: var(--neutral-800);--color-green-text-disabled: var(--neutral-200);--color-yellow-default: var(--yellow-800);--color-yellow-border: var(--yellow-800);--color-yellow-text: #ffffff;--color-yellow-hover: var(--yellow-1000);--color-yellow-disabled: var(--neutral-800);--color-yellow-text-disabled: var(--neutral-200);--color-red-default: var(--red-600);--color-red-border: var(--red-600);--color-red-text: #ffffff;--color-red-hover: var(--red-800);--color-red-disabled: var(--neutral-800);--color-red-text-disabled: var(--neutral-200);--color-purple-default: var(--primary-600);--color-purple-border: var(--primary-600);--color-purple-text: #ffffff;--color-purple-hover: var(--primary-800);--color-purple-disabled: var(--neutral-800);--color-purple-text-disabled: var(--neutral-200);--status-normal-bg: rgba(4, 120, 87, .1);--status-normal-color: var(--green-600);--status-normal-border: rgba(21, 127, 64, .2);--status-danger-bg: rgba(206, 52, 38, .1);--status-danger-color: var(--red-600);--status-danger-border: rgba(206, 52, 38, .2);--status-warning-bg: rgba(255, 130, 5, .1);--status-warning-color: var(--orange-600);--status-caution-bg: rgba(255, 193, 7, .1);--status-caution-color: var(--yellow-600);--status-caution-border: rgba(180, 83, 9, .2);--color-normal: #5856f5;--color-caution: #12c590;--color-warning: #f2970d;--color-danger: #f05555;--color-unknown: var(--status-unknown-color);--color-muted: var(--neutral-600);--icon-normal: url("data:image/svg+xml,%3csvg%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3c!--%20정상:%20원%20안에%20체크마크%20-%20안정감과%20완료의%20느낌%20--%3e%3ccircle%20cx='12'%20cy='12'%20r='10'%20stroke='currentColor'%20stroke-width='2'%20fill='none'/%3e%3cpath%20d='M7.5%2012.5L10.5%2015.5L16.5%209.5'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%20fill='none'/%3e%3c/svg%3e");--icon-caution: url("data:image/svg+xml,%3csvg%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3c!--%20주의:%20원%20안에%20느낌표%20-%20주목이%20필요한%20상태%20--%3e%3ccircle%20cx='12'%20cy='12'%20r='10'%20stroke='currentColor'%20stroke-width='2'%20fill='none'/%3e%3cline%20x1='12'%20y1='7'%20x2='12'%20y2='13'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'/%3e%3ccircle%20cx='12'%20cy='16.5'%20r='1.25'%20fill='currentColor'/%3e%3c/svg%3e");--icon-warning: url("data:image/svg+xml,%3csvg%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3c!--%20경고:%20삼각형%20안에%20느낌표%20-%20전통적인%20경고%20심볼%20--%3e%3cpath%20d='M12%203L21.5%2020H2.5L12%203Z'%20stroke='currentColor'%20stroke-width='2'%20stroke-linejoin='round'%20fill='none'/%3e%3cline%20x1='12'%20y1='9'%20x2='12'%20y2='14'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'/%3e%3ccircle%20cx='12'%20cy='17'%20r='1.25'%20fill='currentColor'/%3e%3c/svg%3e");--icon-danger: url("data:image/svg+xml,%3csvg%20width='24'%20height='24'%20viewBox='0%200%2024%2024'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3c!--%20위험:%20팔각형(정지%20표지판)%20안에%20X%20-%20긴급%20위험%20상태%20--%3e%3cpath%20d='M7.86%202H16.14L22%207.86V16.14L16.14%2022H7.86L2%2016.14V7.86L7.86%202Z'%20stroke='currentColor'%20stroke-width='2'%20stroke-linejoin='round'%20fill='none'/%3e%3cpath%20d='M15%209L9%2015M9%209L15%2015'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'/%3e%3c/svg%3e");--icon-unknown: url("data:image/svg+xml,%3csvg%20width='16'%20height='16'%20viewBox='0%200%2016%2016'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cpath%20d='M8%201.5C4.5%201.5%201.5%204.5%201.5%208S4.5%2014.5%208%2014.5%2014.5%2011.5%2014.5%208%2011.5%201.5%208%201.5ZM9%2012.5H7V10.5H9V12.5ZM10%209.5C10%208.5%209.5%207.5%208.5%207.5S7%208.5%207%209.5H5C5%207.5%206.5%205.5%208.5%205.5S12%207.5%2012%209.5C12%2010.5%2011.5%2011.5%2010.5%2012L10%209.5Z'%20fill='currentColor'/%3e%3c/svg%3e");--status-unknown-color: var(--neutral-600);--primary-color: #3B5BDB;--primary-hover: #2D4BC8;--secondary-color: #6B7280;--success-color: #047857;--warning-color: #B45309;--danger-color: #B91C1C;--info-color: #3B5BDB;--border-color: #4B5563;--border-light: #6B7280;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 16px;--font-size-md: 18px;--font-size-lg: 20px;--font-size-xl: 22px;--font-size-2xl: 26px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--sidebar-bg: #1a1a1a;--sidebar-header-bg: #2a2a2a;--sidebar-border: #3a3a3a;--sidebar-text-primary: rgba(255, 255, 255, .97);--sidebar-text-secondary: rgba(255, 255, 255, .6);--sidebar-text-muted: rgba(255, 255, 255, .38);--sidebar-hover-bg: #3a3a3a;--sidebar-active-bg: rgba(74, 124, 255, .2);--sidebar-active-border: #4A7CFF;--login-bg-primary: #121212;--login-bg-secondary: #1a1a1a;--login-card-bg: rgba(26, 26, 26, .95);--login-title-color: rgba(255, 255, 255, .97);--login-subtitle-color: rgba(255, 255, 255, .6);--login-label-color: rgba(255, 255, 255, .6);--login-input-bg: rgba(26, 26, 26, .8);--login-input-border: #3a3a3a;--login-input-placeholder: rgba(255, 255, 255, .38);--login-info-bg: #2a2a2a;--login-info-border: #3a3a3a;--login-info-text: rgba(255, 255, 255, .6);--login-account-bg: #1a1a1a;--login-account-border: #4A7CFF;--login-account-text: rgba(255, 255, 255, .6);--login-account-hover-bg: #2a2a2a;--login-accent-1: rgba(74, 124, 255, .15);--login-accent-2: rgba(0, 102, 255, .15);--login-accent-3: rgba(74, 124, 255, .08);--login-accent-primary: #4A7CFF;--login-accent-secondary: #0066FF;--login-card-shadow-1: rgba(74, 124, 255, .15);--login-card-shadow-2: rgba(0, 0, 0, .3);--login-card-highlight: rgba(255, 255, 255, .1);--login-logo-shadow: rgba(74, 124, 255, .3);--login-input-focus-shadow: rgba(74, 124, 255, .2);--login-input-focus-ring: rgba(74, 124, 255, .15);--login-toggle-focus: #4A7CFF;--login-caps-warning-icon: #fbbf24;--login-button-hover-shadow: rgba(74, 124, 255, .4);--login-button-shine: rgba(255, 255, 255, .1);--login-input-error-ring: rgba(239, 68, 68, .2);--overlay-bg: rgba(0, 0, 0, .7);--badge-shadow: 0 1px 3px rgba(0, 0, 0, .3);--spinner-bg: #4a5568;--toggle-off-bg: #4a4a4a;--toggle-off-hover: #5a5a5a;--toggle-on-bg: var(--green-600);--toggle-on-hover: var(--green-800);--caps-warning-bg: rgba(245, 158, 11, .1);--caps-warning-border: rgba(245, 158, 11, .3);--caps-warning-text: #FBBF24;--error-bg: rgba(239, 68, 68, .1);--error-border: rgba(239, 68, 68, .3);--error-text: #F87171;--success-bg: rgba(16, 185, 129, .1);--success-border: rgba(16, 185, 129, .3);--success-text: #34D399;--icon-filter-light: brightness(0) saturate(0) invert(.2);--icon-filter-medium: brightness(0) saturate(0) invert(.4);--icon-filter-dark: brightness(0) saturate(0) invert(.6);--icon-filter-white: brightness(0) invert(1);--icon-filter-primary: brightness(0) invert(.97);--icon-filter-secondary: brightness(0) invert(.6);--icon-filter-muted: brightness(0) invert(.38);--sensor-danger: #F44336;--sensor-warning: #FF9800;--sensor-caution: #FFC107;--sensor-normal: #4CAF50;--sensor-unknown: #9CA3AF;--chart-color-1: #2563eb;--chart-color-2: #9333ea;--chart-color-3: #10b981;--form-bg: #f8f9fa;--form-border: #e9ecef;--form-input-bg: white;--form-input-border: #ced4da;--form-label-color: #666;--form-section-border: #eee;--form-section-title: #333;--tooltip-danger: #ff6b6b;--tooltip-warning: #ffa726;--tooltip-caution: #ffca28;--tooltip-normal: #4caf50;--sensor-danger: #DC2626;--sensor-warning: #EA580C;--sensor-caution: #D97706;--sensor-normal: #059669;--sensor-unknown: #6B7280;--chart-color-1: #3b82f6;--chart-color-2: #a855f7;--chart-color-7: #84cc16;--chart-color-4: #f97316;--chart-color-5: #06b6d4;--chart-color-6: #ec4899;--chart-color-3: #34d399;--chart-color-8: #14b8a6;--form-bg: #1a1a1a;--form-border: #3a3a3a;--form-input-bg: #1a1a1a;--form-input-border: #3a3a3a;--form-label-color: rgba(255, 255, 255, .6);--form-section-border: #3a3a3a;--form-section-title: rgba(255, 255, 255, .97);--tooltip-danger: #DC2626;--tooltip-warning: #EA580C;--tooltip-caution: #D97706;--tooltip-normal: #059669}.ol-zoom button,.ol-control button,.ol-full-screen button,.ol-rotate button,.ol-attribution button{background-color:var(--bg-card)!important;color:var(--text-secondary)!important;border:1px solid var(--border-primary)!important;border-radius:var(--radius-sm)!important;box-shadow:var(--shadow-sm)!important;transition:all .3s ease!important;font-family:inherit!important;cursor:pointer!important}.ol-zoom button:hover,.ol-control button:hover,.ol-full-screen button:hover,.ol-rotate button:hover,.ol-attribution button:hover{background-color:var(--bg-tertiary)!important;border-color:var(--border-secondary)!important}body{background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.card{background-color:var(--bg-card);border:1px solid var(--border-primary);box-shadow:var(--shadow-md)}.input{background-color:var(--input-bg);border:1px solid var(--input-border);color:var(--text-primary)}.input:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px #3b82f61a}input,select,textarea{background-color:var(--input-bg);border:1px solid var(--input-border);color:var(--text-primary)}input:focus,select:focus,textarea:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px #3b82f61a;background-color:var(--bg-card)}.btn-primary{background-color:var(--btn-primary-bg);color:#fff}.btn-primary:hover{background-color:var(--btn-primary-hover)}.btn-secondary{background-color:var(--btn-secondary-bg);color:#fff}.btn-secondary:hover{background-color:var(--btn-secondary-hover)}.btn-white{background-color:var(--btn-white-bg);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-white:hover{background-color:var(--btn-white-hover)}:root{--user-mgmt-text-primary: #2c3e50;--user-mgmt-text-secondary: #6c757d;--user-mgmt-text-muted: #7f8c8d;--user-mgmt-text-light: #8c8c8c;--user-mgmt-text-dark: #495057;--user-mgmt-text-warning: #92400e;--user-mgmt-text-info: #0369a1;--user-mgmt-text-error: #e74c3c;--user-mgmt-text-success: #2e7d32;--user-mgmt-bg-primary: #ffffff;--user-mgmt-bg-secondary: #f8f9fa;--user-mgmt-bg-tertiary: #e9ecef;--user-mgmt-bg-light: #f5f5f5;--user-mgmt-bg-info: #f0f9ff;--user-mgmt-bg-success: #e8f5e9;--user-mgmt-bg-warning: #fef3c7;--user-mgmt-bg-error: #fff3e0;--user-mgmt-border-primary: #dee2e6;--user-mgmt-border-secondary: #e9ecef;--user-mgmt-border-light: #d9d9d9;--user-mgmt-border-info: #bae6fd;--user-mgmt-border-success: #4caf50;--user-mgmt-border-warning: #f59e0b;--user-mgmt-border-error: #ff9800;--user-mgmt-border-dashed: #bdbdbd;--user-mgmt-shadow-light: rgba(0, 0, 0, .08);--user-mgmt-shadow-medium: rgba(0, 0, 0, .1);--user-mgmt-shadow-focus: rgba(59, 130, 246, .1);--user-mgmt-shadow-primary: rgba(66, 99, 235, .1);--user-mgmt-accent-blue: #2563eb;--user-mgmt-accent-blue-hover: #1d4ed8;--user-mgmt-accent-info: #3498db;--user-mgmt-accent-muted: #95a5a6;--user-mgmt-accent-gradient-1: #667eea;--user-mgmt-accent-gradient-2: #764ba2;--user-mgmt-status-none: #8c8c8c;--user-mgmt-status-none-bg: #f5f5f5;--user-mgmt-status-none-border: #d9d9d9;--user-mgmt-status-none-hover: #52c41a;--user-mgmt-status-none-hover-bg: #f6ffed;--user-mgmt-status-none-hover-border: #b7eb8f;--user-mgmt-permission-bg-1: rgba(16, 185, 129, .1);--user-mgmt-permission-bg-2: rgba(251, 191, 36, .1);--user-mgmt-permission-bg-3: rgba(251, 191, 36, .2);--user-mgmt-permission-bg-4: rgba(239, 68, 68, .1);--user-mgmt-gradient-1: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);--user-mgmt-gradient-2: linear-gradient(135deg, #e8f5e9 0%, #c8e6c9 100%);--user-mgmt-gradient-3: linear-gradient(135deg, #fafafa 0%, #f0f0f0 100%);--user-mgmt-gradient-4: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);--user-mgmt-gradient-5: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);--user-mgmt-gradient-6: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.dark{--user-mgmt-text-primary: rgba(255, 255, 255, .9);--user-mgmt-text-secondary: rgba(255, 255, 255, .7);--user-mgmt-text-muted: rgba(255, 255, 255, .5);--user-mgmt-text-light: rgba(255, 255, 255, .4);--user-mgmt-text-dark: rgba(255, 255, 255, .8);--user-mgmt-text-warning: #fbbf24;--user-mgmt-text-info: #60a5fa;--user-mgmt-text-error: #f87171;--user-mgmt-text-success: #34d399;--user-mgmt-bg-primary: #1a1a1a;--user-mgmt-bg-secondary: #2a2a2a;--user-mgmt-bg-tertiary: #3a3a3a;--user-mgmt-bg-light: #2a2a2a;--user-mgmt-bg-info: #1e3a8a;--user-mgmt-bg-success: #064e3b;--user-mgmt-bg-warning: #451a03;--user-mgmt-bg-error: #7c2d12;--user-mgmt-border-primary: #3a3a3a;--user-mgmt-border-secondary: #2a2a2a;--user-mgmt-border-light: #3a3a3a;--user-mgmt-border-info: #1e40af;--user-mgmt-border-success: #059669;--user-mgmt-border-warning: #d97706;--user-mgmt-border-error: #ea580c;--user-mgmt-border-dashed: #4a4a4a;--user-mgmt-shadow-light: rgba(0, 0, 0, .3);--user-mgmt-shadow-medium: rgba(0, 0, 0, .4);--user-mgmt-shadow-focus: rgba(59, 130, 246, .2);--user-mgmt-shadow-primary: rgba(66, 99, 235, .2);--user-mgmt-accent-blue: #3b82f6;--user-mgmt-accent-blue-hover: #2563eb;--user-mgmt-accent-info: #60a5fa;--user-mgmt-accent-muted: #6b7280;--user-mgmt-accent-gradient-1: #8b5cf6;--user-mgmt-accent-gradient-2: #a855f7;--user-mgmt-status-none: #6b7280;--user-mgmt-status-none-bg: #2a2a2a;--user-mgmt-status-none-border: #3a3a3a;--user-mgmt-status-none-hover: #34d399;--user-mgmt-status-none-hover-bg: #064e3b;--user-mgmt-status-none-hover-border: #059669;--user-mgmt-permission-bg-1: rgba(5, 46, 22, .1);--user-mgmt-permission-bg-2: rgba(78, 50, 3, .1);--user-mgmt-permission-bg-3: rgba(78, 50, 3, .2);--user-mgmt-permission-bg-4: rgba(60, 17, 17, .1);--user-mgmt-gradient-1: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);--user-mgmt-gradient-2: linear-gradient(135deg, #064e3b 0%, #022c22 100%);--user-mgmt-gradient-3: linear-gradient(135deg, #1a1a1a 0%, #0a0a0a 100%);--user-mgmt-gradient-4: linear-gradient(135deg, #1e3a8a 0%, #1e40af 100%);--user-mgmt-gradient-5: linear-gradient(135deg, #1e40af 0%, #1d4ed8 100%);--user-mgmt-gradient-6: linear-gradient(135deg, #8b5cf6 0%, #a855f7 100%)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease;padding:20px;box-sizing:border-box}@keyframes fadeIn{from {opacity: 0;} .modal-container {background: var(--bg-primary); border-radius: var(--radius-md); max-width: 90vw; max-height: calc(100vh - 40px) ; overflow: auto; box-shadow: var(--shadow-lg); box-sizing: border-box; animation: slideIn .2s ease;} .modal-md {width: 500px;} .modal-lg {width: 700px;} .modal-xl {width: 900px;} .modal-body {padding: var(--spacing-lg);} .modal-footer {display: flex; justify-content: flex-end; gap: var(--spacing-sm); padding: var(--spacing-md) var(--spacing-lg); border-top: 1px solid var(--border-color); background: var(--bg-secondary);} .modal-close-btn {background: transparent; border: none; color: var(--text-secondary); cursor: pointer; padding: 4px; border-radius: 4px; display: flex; align-items: center; justify-content: center; transition: all .2s ease;} .modal-close-btn:hover {background: var(--bg-hover); color: var(--text-primary);} .modal-title {margin: 0; font-size: 18px; font-weight: 600; color: var(--text-primary);} .modal-error {padding: 12px 16px; background: rgba(239,68,68,.1); border: 1px solid var(--status-error); border-radius: 8px; color: var(--status-error); font-size: 14px; margin-bottom: 16px;} .readonly-field {padding: 10px 12px; background: var(--bg-tertiary); border: 1px solid var(--border-primary); border-radius: 6px; color: var(--text-secondary); font-size: 14px;} .form-hint {font-size: 12px; color: var(--text-muted); margin-top: 4px;} .info-box {padding: 12px 16px; border-radius: 8px; font-size: 13px;} .info-box p {margin: 0;} .info-purple {background: rgba(156,39,176,.1); border: 1px solid rgba(156,39,176,.3); color: #9c27b0;} .dark .info-purple {background: rgba(186,104,200,.15); border-color: rgba(186,104,200,.3); color: #ba68c8;} to {opacity: 1;} .modal-container {background: var(--bg-primary); border-radius: var(--radius-md); max-width: 90vw; max-height: calc(100vh - 40px) ; overflow: auto; box-shadow: var(--shadow-lg); box-sizing: border-box; animation: slideIn .2s ease;} .modal-md {width: 500px;} .modal-lg {width: 700px;} .modal-xl {width: 900px;} .modal-body {padding: var(--spacing-lg);} .modal-footer {display: flex; justify-content: flex-end; gap: var(--spacing-sm); padding: var(--spacing-md) var(--spacing-lg); border-top: 1px solid var(--border-color); background: var(--bg-secondary);} .modal-close-btn {background: transparent; border: none; color: var(--text-secondary); cursor: pointer; padding: 4px; border-radius: 4px; display: flex; align-items: center; justify-content: center; transition: all .2s ease;} .modal-close-btn:hover {background: var(--bg-hover); color: var(--text-primary);} .modal-title {margin: 0; font-size: 18px; font-weight: 600; color: var(--text-primary);} .modal-error {padding: 12px 16px; background: rgba(239,68,68,.1); border: 1px solid var(--status-error); border-radius: 8px; color: var(--status-error); font-size: 14px; margin-bottom: 16px;} .readonly-field {padding: 10px 12px; background: var(--bg-tertiary); border: 1px solid var(--border-primary); border-radius: 6px; color: var(--text-secondary); font-size: 14px;} .form-hint {font-size: 12px; color: var(--text-muted); margin-top: 4px;} .info-box {padding: 12px 16px; border-radius: 8px; font-size: 13px;} .info-box p {margin: 0;} .info-purple {background: rgba(156,39,176,.1); border: 1px solid rgba(156,39,176,.3); color: #9c27b0;} .dark .info-purple {background: rgba(186,104,200,.15); border-color: rgba(186,104,200,.3); color: #ba68c8;}}@keyframes slideIn{from {opacity: 0; transform: translateY(-20px) scale(.95);} .modal-container {background: var(--bg-primary); border-radius: var(--radius-md); max-width: 90vw; max-height: calc(100vh - 40px) ; overflow: auto; box-shadow: var(--shadow-lg); box-sizing: border-box; animation: slideIn .2s ease;} .modal-md {width: 500px;} .modal-lg {width: 700px;} .modal-xl {width: 900px;} .modal-body {padding: var(--spacing-lg);} .modal-footer {display: flex; justify-content: flex-end; gap: var(--spacing-sm); padding: var(--spacing-md) var(--spacing-lg); border-top: 1px solid var(--border-color); background: var(--bg-secondary);} .modal-close-btn {background: transparent; border: none; color: var(--text-secondary); cursor: pointer; padding: 4px; border-radius: 4px; display: flex; align-items: center; justify-content: center; transition: all .2s ease;} .modal-close-btn:hover {background: var(--bg-hover); color: var(--text-primary);} .modal-title {margin: 0; font-size: 18px; font-weight: 600; color: var(--text-primary);} .modal-error {padding: 12px 16px; background: rgba(239,68,68,.1); border: 1px solid var(--status-error); border-radius: 8px; color: var(--status-error); font-size: 14px; margin-bottom: 16px;} .readonly-field {padding: 10px 12px; background: var(--bg-tertiary); border: 1px solid var(--border-primary); border-radius: 6px; color: var(--text-secondary); font-size: 14px;} .form-hint {font-size: 12px; color: var(--text-muted); margin-top: 4px;} .info-box {padding: 12px 16px; border-radius: 8px; font-size: 13px;} .info-box p {margin: 0;} .info-purple {background: rgba(156,39,176,.1); border: 1px solid rgba(156,39,176,.3); color: #9c27b0;} .dark .info-purple {background: rgba(186,104,200,.15); border-color: rgba(186,104,200,.3); color: #ba68c8;} to {opacity: 1; transform: translateY(0) scale(1);} .modal-container {background: var(--bg-primary); border-radius: var(--radius-md); max-width: 90vw; max-height: calc(100vh - 40px) ; overflow: auto; box-shadow: var(--shadow-lg); box-sizing: border-box; animation: slideIn .2s ease;} .modal-md {width: 500px;} .modal-lg {width: 700px;} .modal-xl {width: 900px;} .modal-body {padding: var(--spacing-lg);} .modal-footer {display: flex; justify-content: flex-end; gap: var(--spacing-sm); padding: var(--spacing-md) var(--spacing-lg); border-top: 1px solid var(--border-color); background: var(--bg-secondary);} .modal-close-btn {background: transparent; border: none; color: var(--text-secondary); cursor: pointer; padding: 4px; border-radius: 4px; display: flex; align-items: center; justify-content: center; transition: all .2s ease;} .modal-close-btn:hover {background: var(--bg-hover); color: var(--text-primary);} .modal-title {margin: 0; font-size: 18px; font-weight: 600; color: var(--text-primary);} .modal-error {padding: 12px 16px; background: rgba(239,68,68,.1); border: 1px solid var(--status-error); border-radius: 8px; color: var(--status-error); font-size: 14px; margin-bottom: 16px;} .readonly-field {padding: 10px 12px; background: var(--bg-tertiary); border: 1px solid var(--border-primary); border-radius: 6px; color: var(--text-secondary); font-size: 14px;} .form-hint {font-size: 12px; color: var(--text-muted); margin-top: 4px;} .info-box {padding: 12px 16px; border-radius: 8px; font-size: 13px;} .info-box p {margin: 0;} .info-purple {background: rgba(156,39,176,.1); border: 1px solid rgba(156,39,176,.3); color: #9c27b0;} .dark .info-purple {background: rgba(186,104,200,.15); border-color: rgba(186,104,200,.3); color: #ba68c8;}}.modal,.modal-content,.alarm-setting-modal,.alarm-status-modal,.alarm-history-modal,.sensor-list-modal,.sensor-summary-modal,.district-summary-modal,.maintenance-modal{background:var(--bg-primary);border-radius:var(--radius-md);width:700px!important;max-width:90vw;max-height:calc(100vh - 40px);overflow:auto;box-shadow:var(--shadow-lg);box-sizing:border-box;animation:slideIn .2s ease}.sensor-list-modal{display:flex;flex-direction:column}.modal-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;position:relative;width:100%;box-sizing:border-box}.sensor-list-modal .modal-header h3{margin:0;color:#fff;font-size:1.4em;font-weight:600}.modal-header h2,.modal-header h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.close-button,.close-btn{background:#fff3;border:none;font-size:20px;cursor:pointer;padding:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#fff;border-radius:50%;transition:all .2s ease;position:relative}.close-button:before,.close-btn:before{content:"";position:absolute;width:16px;height:2px;background-color:currentColor;transform:rotate(45deg)}.close-button:after,.close-btn:after{content:"";position:absolute;width:16px;height:2px;background-color:currentColor;transform:rotate(-45deg)}.close-button:hover,.close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.modal-header .close-button,.modal-header .close-btn{background:#f3f4f6;color:#6b7280}.modal-header .close-button:hover,.modal-header .close-btn:hover{background:#e5e7eb;color:#374151}.dark .modal-header .close-button,.dark .modal-header .close-btn{background:var(--bg-tertiary);color:var(--text-primary)}.dark .modal-header .close-button:hover,.dark .modal-header .close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-header .close-button:before,.modal-header .close-button:after,.modal-header .close-btn:before,.modal-header .close-btn:after{background-color:currentColor}.dark .modal-header .close-button:before,.dark .modal-header .close-button:after,.dark .modal-header .close-btn:before,.dark .modal-header .close-btn:after{background-color:var(--text-primary)}.modal-form,.alarm-settings-form,.alarm-status-form,.maintenance-form{padding:var(--spacing-lg)}.modal-content{padding:var(--spacing-md) var(--spacing-lg);width:100%;box-sizing:border-box}.form-group{margin-bottom:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;box-sizing:border-box;background:var(--input-bg);color:var(--text-primary)}.form-group textarea{resize:vertical;min-height:80px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4263eb1a;background:var(--bg-card)}.modal-actions,.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-color);background:transparent}.dark .modal-actions,.dark .form-actions{border-top-color:var(--border-primary);background:transparent}.btn{padding:12px 24px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border:2px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;box-shadow:0 1px 3px #0000001a;position:relative;overflow:hidden;text-decoration:none;white-space:nowrap;letter-spacing:.025em}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .6s ease}.btn:hover:before{left:100%}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.btn:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.cancel-btn,.btn-secondary{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:#475569;border:2px solid #e2e8f0;font-weight:600}.cancel-btn:hover,.btn-secondary:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#334155;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.dark .cancel-btn,.dark .btn-secondary{background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);color:var(--text-primary);border:2px solid var(--border-primary)}.dark .cancel-btn:hover,.dark .btn-secondary:hover{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);color:var(--text-primary);border-color:var(--border-secondary);box-shadow:var(--shadow-md)}.submit-btn,.save-btn,.primary-btn,.btn-primary{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-weight:600;border:2px solid #6366f1}.submit-btn:hover,.save-btn:hover,.primary-btn:hover,.btn-primary:hover{background:linear-gradient(135deg,#4f46e5,#4338ca);border-color:#4f46e5;transform:translateY(-1px);box-shadow:0 4px 12px #6366f140}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-weight:600;border:2px solid #10b981}.btn-success:hover{background:linear-gradient(135deg,#059669,#047857);border-color:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b98140}.dark .btn-success{background:linear-gradient(135deg,var(--status-success) 0%,#059669 100%);color:#fff;border:2px solid var(--status-success)}.dark .btn-success:hover{background:linear-gradient(135deg,#059669,#047857);border-color:#059669;box-shadow:0 4px 12px #10b9814d}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-weight:600;border:2px solid #f59e0b}.btn-warning:hover{background:linear-gradient(135deg,#d97706,#b45309);border-color:#d97706;transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b40}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-weight:600;border:2px solid #ef4444}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);border-color:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef444440}.btn-info{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff;font-weight:600;border:2px solid #06b6d4}.btn-info:hover{background:linear-gradient(135deg,#0891b2,#0e7490);border-color:#0891b2;transform:translateY(-1px);box-shadow:0 4px 12px #06b6d440}.btn-sm{padding:8px 16px;font-size:13px;min-height:36px;border-radius:8px;font-weight:600}.btn-lg{padding:16px 32px;font-size:16px;min-height:52px;border-radius:16px;font-weight:600}.btn-icon{padding:10px;min-width:44px;min-height:44px;border-radius:50%;font-size:18px;font-weight:600}.btn-icon.btn-sm{padding:8px;min-width:36px;min-height:36px;font-size:16px}.btn-icon.btn-lg{padding:14px;min-width:52px;min-height:52px;font-size:20px}.settings-grid{display:grid;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.setting-item{display:flex;flex-direction:column;gap:var(--spacing-sm)}.setting-item label{font-size:14px;color:var(--text-secondary)}.maintenance-form .form-group:last-child{margin-bottom:0}.maintenance-modal form{padding:var(--spacing-md) var(--spacing-lg)}.site-edit-form{padding:var(--spacing-md) var(--spacing-lg)}.history-content{padding:var(--spacing-lg);max-height:500px;overflow-y:auto}.alarm-info{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.alarm-info h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md) 0}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-item label{font-size:14px;color:var(--text-secondary);font-weight:500}.info-item span{font-size:14px;color:var(--text-primary)}.action-history h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-md) 0}.history-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.history-item{padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-sm);border-left:3px solid var(--primary-color)}.history-time{font-size:12px;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.history-action{font-size:14px;color:var(--text-primary);font-weight:500;margin-bottom:2px}.history-user{font-size:12px;color:var(--text-secondary)}.no-history{text-align:center;color:var(--text-muted);font-style:italic;padding:var(--spacing-lg)}.modal::-webkit-scrollbar,.modal-content::-webkit-scrollbar{width:6px}.modal::-webkit-scrollbar-track,.modal-content::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.modal::-webkit-scrollbar-thumb,.modal-content::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}.modal::-webkit-scrollbar-thumb:hover,.modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.modal-content.chart-popup-modal{width:900px!important;max-width:95vw!important;min-height:600px!important;max-height:90vh!important}@media (max-width: 768px){.modal-overlay{padding:20px 10px 10px;align-items:flex-start}.modal-content.chart-popup-modal{width:95vw!important;min-height:80vh!important;padding:16px!important}.modal,.modal-content,.alarm-setting-modal,.alarm-status-modal,.alarm-history-modal,.sensor-list-modal,.sensor-summary-modal,.district-summary-modal,.maintenance-modal{width:100%!important;max-width:none!important;margin:0;max-height:calc(100vh - 40px);font-size:14px}.modal-header{padding:12px 16px;flex-wrap:wrap;gap:8px}.modal-header h2,.modal-header h3{font-size:16px;flex:1;min-width:0}.close-button,.close-btn{width:32px;height:32px;font-size:16px;flex-shrink:0}.modal-form,.alarm-settings-form,.alarm-status-form,.maintenance-form,.modal-content{padding:12px 16px}.form-group{margin-bottom:12px}.form-group label{font-size:13px;margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{padding:8px 12px;font-size:14px}.btn{padding:10px 16px;font-size:13px;min-height:40px}.btn-sm{padding:6px 12px;font-size:12px;min-height:32px}.modal-actions,.form-actions{margin-top:16px;padding-top:12px;gap:8px;flex-wrap:wrap}.info-grid{grid-template-columns:1fr;gap:12px}.history-content{padding:12px 16px;max-height:400px}.alarm-info{margin-bottom:16px;padding-bottom:12px}.history-item{padding:12px}.modal-container{background:var(--bg-primary);border-radius:var(--radius-md);max-width:90vw;max-height:calc(100vh - 40px);overflow:auto;box-shadow:var(--shadow-lg);box-sizing:border-box;animation:slideIn .2s ease}.modal-md{width:500px}.modal-lg{width:700px}.modal-xl{width:900px}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.modal-close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-title{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-error{padding:12px 16px;background:#ef44441a;border:1px solid var(--status-error);border-radius:8px;color:var(--status-error);font-size:14px;margin-bottom:16px}.readonly-field{padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);font-size:14px}.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.info-box{padding:12px 16px;border-radius:8px;font-size:13px}.info-box p{margin:0}.info-purple{background:#9c27b01a;border:1px solid rgba(156,39,176,.3);color:#9c27b0}.dark .info-purple{background:#ba68c826;border-color:#ba68c84d;color:#ba68c8}}@media (max-width: 480px){.modal-overlay{padding:10px 5px 5px}.modal,.modal-content,.alarm-setting-modal,.alarm-status-modal,.alarm-history-modal,.sensor-list-modal,.sensor-summary-modal,.district-summary-modal,.maintenance-modal{font-size:13px;border-radius:8px}.modal-header{padding:8px 12px}.modal-header h2,.modal-header h3{font-size:14px}.close-button,.close-btn{width:28px;height:28px;font-size:14px}.modal-form,.alarm-settings-form,.alarm-status-form,.maintenance-form,.modal-content{padding:8px 12px}.form-group{margin-bottom:8px}.form-group label{font-size:12px;margin-bottom:3px}.form-group input,.form-group select,.form-group textarea{padding:6px 10px;font-size:13px}.btn{padding:8px 12px;font-size:12px;min-height:36px;border-radius:8px}.btn-sm{padding:4px 8px;font-size:11px;min-height:28px;border-radius:6px}.modal-actions,.form-actions{margin-top:12px!important;padding-top:8px!important;gap:6px!important;flex-wrap:nowrap!important;flex-direction:row!important;justify-content:center!important;display:flex!important}.form-actions .btn-functional{min-width:36px!important;min-height:36px!important;padding:8px!important;border-radius:50%!important;overflow:hidden!important;flex-shrink:0!important}.form-actions .btn-functional .text,.form-actions .btn-functional span.text,.modal-actions .btn-functional .text,.modal-actions .btn-functional span.text{display:none!important;visibility:hidden!important;width:0!important;height:0!important;overflow:hidden!important;position:absolute!important;left:-9999px!important}.form-actions .btn-functional .icon{margin:0!important;width:20px!important;height:20px!important}.history-content{padding:8px 12px;max-height:300px}.alarm-info{margin-bottom:12px;padding-bottom:8px}.history-item{padding:8px}.info-item label{font-size:11px}.info-item span{font-size:12px}.modal-container{background:var(--bg-primary);border-radius:var(--radius-md);max-width:90vw;max-height:calc(100vh - 40px);overflow:auto;box-shadow:var(--shadow-lg);box-sizing:border-box;animation:slideIn .2s ease}.modal-md{width:500px}.modal-lg{width:700px}.modal-xl{width:900px}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.modal-close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-title{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-error{padding:12px 16px;background:#ef44441a;border:1px solid var(--status-error);border-radius:8px;color:var(--status-error);font-size:14px;margin-bottom:16px}.readonly-field{padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);font-size:14px}.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.info-box{padding:12px 16px;border-radius:8px;font-size:13px}.info-box p{margin:0}.info-purple{background:#9c27b01a;border:1px solid rgba(156,39,176,.3);color:#9c27b0}.dark .info-purple{background:#ba68c826;border-color:#ba68c84d;color:#ba68c8}}.modal-level{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;border-radius:16px;font-size:13px;font-weight:600;min-width:60px;white-space:nowrap}.modal-level.normal{background:#4caf5026;color:#2e7d32;border:1px solid rgba(76,175,80,.3)}.modal-level.caution{background:#ffc10726;color:#f57f17;border:1px solid rgba(255,193,7,.3)}.modal-level.warning{background:#ff980026;color:#ef6c00;border:1px solid rgba(255,152,0,.3)}.modal-level.danger{background:#f4433626;color:#c62828;border:1px solid rgba(244,67,54,.3)}.modal-level.critical{background:#9c27b026;color:#7b1fa2;border:1px solid rgba(156,39,176,.3)}.modal-level.unknown{background:#9e9e9e26;color:#616161;border:1px solid rgba(158,158,158,.3)}@media (max-width: 768px){.form-actions,.modal-actions{flex-wrap:nowrap!important;flex-direction:row!important;justify-content:center!important;gap:8px!important}.form-actions .btn-functional,.modal-actions .btn-functional{min-width:40px!important;min-height:40px!important;max-width:40px!important;max-height:40px!important;padding:8px!important;border-radius:50%!important;overflow:hidden!important;flex-shrink:0!important}.form-actions .btn-functional .text,.form-actions .btn-functional span.text,.modal-actions .btn-functional .text,.modal-actions .btn-functional span.text{display:none!important;visibility:hidden!important;width:0!important;height:0!important;overflow:hidden!important;position:absolute!important;left:-9999px!important}.form-actions .btn-functional .icon,.modal-actions .btn-functional .icon{margin:0!important;width:24px!important;height:24px!important}.modal-container{background:var(--bg-primary);border-radius:var(--radius-md);max-width:90vw;max-height:calc(100vh - 40px);overflow:auto;box-shadow:var(--shadow-lg);box-sizing:border-box;animation:slideIn .2s ease}.modal-md{width:500px}.modal-lg{width:700px}.modal-xl{width:900px}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.modal-close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-title{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-error{padding:12px 16px;background:#ef44441a;border:1px solid var(--status-error);border-radius:8px;color:var(--status-error);font-size:14px;margin-bottom:16px}.readonly-field{padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);font-size:14px}.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.info-box{padding:12px 16px;border-radius:8px;font-size:13px}.info-box p{margin:0}.info-purple{background:#9c27b01a;border:1px solid rgba(156,39,176,.3);color:#9c27b0}.dark .info-purple{background:#ba68c826;border-color:#ba68c84d;color:#ba68c8}}.modal-container{background:var(--bg-primary);border-radius:var(--radius-md);max-width:90vw;max-height:calc(100vh - 40px);overflow:auto;box-shadow:var(--shadow-lg);box-sizing:border-box;animation:slideIn .2s ease}.modal-md{width:500px}.modal-lg{width:700px}.modal-xl{width:900px}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.modal-close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-title{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.modal-error{padding:12px 16px;background:#ef44441a;border:1px solid var(--status-error);border-radius:8px;color:var(--status-error);font-size:14px;margin-bottom:16px}.readonly-field{padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);font-size:14px}.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.info-box{padding:12px 16px;border-radius:8px;font-size:13px}.info-box p{margin:0}.info-purple{background:#9c27b01a;border:1px solid rgba(156,39,176,.3);color:#9c27b0}.dark .info-purple{background:#ba68c826;border-color:#ba68c84d;color:#ba68c8}.btn{padding:10px 24px;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;text-decoration:none;white-space:nowrap;text-transform:none;letter-spacing:.25px}.btn.btn-basic{background:var(--btn-white-bg);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:20px;padding:8px 12px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:100px;min-height:32px;text-decoration:none;box-shadow:var(--shadow-sm)}.btn.btn-basic:hover{background:var(--btn-white-hover);border-color:var(--border-secondary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn.btn-basic:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn.btn-basic:disabled{background:var(--bg-tertiary);color:var(--text-muted);border-color:var(--border-primary);cursor:not-allowed;transform:none;box-shadow:none}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn:disabled:before{display:none}.btn-functional{background:var(--btn-white-bg);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:20px;padding:12px 20px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;min-width:100px;min-height:32px;text-decoration:none;box-shadow:var(--shadow-sm)}.btn-icon-circle{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:50%!important;padding:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-width:60px;min-height:60px;max-width:60px;max-height:60px;width:60px;height:60px;text-decoration:none;box-shadow:var(--shadow-sm);flex-shrink:0;box-sizing:border-box}.btn-icon-circle .icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.btn-icon-circle .icon img{width:100%;height:100%;object-fit:contain}.btn-icon-circle:hover{background:var(--bg-secondary);border-color:var(--border-secondary);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-icon-circle:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.btn-icon-circle:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-icon-circle .icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-secondary)}.btn-icon-circle .text{font-size:12px;font-weight:500;text-align:center;line-height:1.2;color:var(--text-primary)}.btn-icon-only{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:50%!important;padding:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;min-height:32px;max-width:32px;max-height:32px;width:32px;height:32px;text-decoration:none;flex-shrink:0;box-sizing:border-box}.btn-icon-only.btn-white{background-color:var(--btn-white-bg);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-icon-only:hover:not(.btn-blue):not(.btn-green):not(.btn-yellow):not(.btn-red):not(.btn-basic):not(.btn-black){background:var(--bg-secondary);border-color:var(--border-secondary);transform:translateY(-1px)}.btn-icon-only:active{transform:translateY(0)}.btn-icon-only:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-icon-only .icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.btn-icon-only .icon img{width:100%;height:100%;object-fit:contain}.btn-icon-only.btn-blue{background:var(--color-blue-default);border-color:var(--color-blue-border);color:var(--color-blue-text)}.btn-icon-only.btn-green{background:var(--color-green-default);border-color:var(--color-green-border);color:var(--color-green-text)}.btn-icon-only.btn-yellow{background:var(--color-yellow-default);border-color:var(--color-yellow-border);color:var(--color-yellow-text)}.btn-icon-only.btn-red{background:var(--color-red-default);border-color:var(--color-red-border);color:var(--color-red-text)}.btn-icon-only.btn-basic{background:var(--color-basic-default);border-color:var(--color-basic-border);color:var(--color-basic-text)}.btn-icon-only.btn-black{background:var(--color-black-default);border-color:var(--color-black-border);color:var(--color-black-text)}.btn-icon-only.btn-blue:hover{background:var(--color-blue-hover);border-color:var(--color-blue-hover);transform:translateY(-1px)}.btn-icon-only.btn-green:hover{background:var(--color-green-hover);border-color:var(--color-green-hover);transform:translateY(-1px)}.btn-icon-only.btn-yellow:hover{background:var(--color-yellow-hover);border-color:var(--color-yellow-hover);transform:translateY(-1px)}.btn-icon-only.btn-red:hover{background:var(--color-red-hover);border-color:var(--color-red-hover);transform:translateY(-1px)}.btn-icon-only.btn-basic:hover{background:var(--color-basic-hover);border-color:var(--color-basic-hover);transform:translateY(-1px)}.btn-icon-only.btn-black:hover{background:var(--color-black-hover);border-color:var(--color-black-hover);transform:translateY(-1px)}.btn-state .icon{width:14px;height:14px;display:flex;align-items:center;justify-content:center}.btn-state .icon img{width:100%;height:100%;object-fit:contain}.btn-state.btn-blue .icon img,.btn-state.btn-blue .icon svg{filter:brightness(0) invert(1)}.btn-state.btn-green .icon img,.btn-state.btn-green .icon svg{filter:brightness(0) invert(1)}.btn-state.btn-yellow .icon img,.btn-state.btn-yellow .icon svg{filter:brightness(0) invert(1)}.btn-state.btn-red .icon img,.btn-state.btn-red .icon svg{filter:brightness(0) invert(1)}.btn-state.btn-basic .icon img,.btn-state.btn-basic .icon svg{filter:brightness(0) saturate(0) invert(.6)}.btn-state.btn-black .icon img,.btn-state.btn-black .icon svg{filter:brightness(0) invert(1)}.btn-icon-circle.btn-blue .icon img,.btn-icon-circle.btn-blue .icon svg{filter:brightness(0) invert(1)}.btn-icon-circle.btn-green .icon img,.btn-icon-circle.btn-green .icon svg{filter:brightness(0) invert(1)}.btn-icon-circle.btn-yellow .icon img,.btn-icon-circle.btn-yellow .icon svg{filter:brightness(0) invert(1)}.btn-icon-circle.btn-red .icon img,.btn-icon-circle.btn-red .icon svg{filter:brightness(0) invert(1)}.btn-icon-circle.btn-basic .icon img,.btn-icon-circle.btn-basic .icon svg{filter:brightness(0) saturate(0) invert(.6)}.btn-icon-circle.btn-black .icon img,.btn-icon-circle.btn-black .icon svg{filter:brightness(0) invert(1)}.btn-icon-only.btn-blue .icon img,.btn-icon-only.btn-blue .icon svg{filter:brightness(0) invert(1)}.btn-icon-only.btn-green .icon img,.btn-icon-only.btn-green .icon svg{filter:brightness(0) invert(1)}.btn-icon-only.btn-yellow .icon img,.btn-icon-only.btn-yellow .icon svg{filter:brightness(0) invert(1)}.btn-icon-only.btn-red .icon img,.btn-icon-only.btn-red .icon svg{filter:brightness(0) invert(1)}.btn-icon-only.btn-basic .icon img,.btn-icon-only.btn-basic .icon svg{filter:brightness(0) saturate(0) invert(.6)}.btn-icon-only.btn-black .icon img,.btn-icon-only.btn-black .icon svg{filter:brightness(0) invert(1)}.btn-icon-only.btn-sm{min-width:40px;min-height:40px;max-width:40px;max-height:40px;width:40px;height:40px;padding:8px;border-radius:50%!important;flex-shrink:0;box-sizing:border-box}.btn-icon-only.btn-sm .icon{width:20px;height:20px;font-size:16px}.btn-icon-only.btn-lg{min-width:56px;min-height:56px;max-width:56px;max-height:56px;width:56px;height:56px;padding:16px;border-radius:50%!important;flex-shrink:0;box-sizing:border-box}.btn-icon-only.btn-lg .icon{width:28px;height:28px;font-size:20px}.btn-functional:hover{background:var(--btn-white-hover);border-color:var(--border-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-functional:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.btn-functional:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-functional .icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.btn-functional .icon img{width:100%;height:100%;object-fit:contain}.btn-functional .text{font-size:11px;font-weight:500;text-align:center;line-height:1.2;color:var(--text-primary)}.btn-functional.btn-blue{background:var(--color-blue-default);color:var(--color-blue-text);border-color:var(--color-blue-border)}.btn-functional.btn-blue .icon img,.btn-functional.btn-blue .icon svg{filter:brightness(0) invert(1)}.btn-functional.btn-blue .text{color:#fff}.btn-functional.btn-blue:hover{background:var(--color-blue-hover);border-color:var(--color-blue-hover)}.btn-functional.btn-basic{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-primary)}.btn-functional.btn-basic .icon img,.btn-functional.btn-basic .icon svg{filter:none;color:var(--text-primary)}.btn-functional.btn-basic .text{color:var(--text-primary)}.btn-functional.btn-basic:hover{background:var(--bg-tertiary);border-color:var(--border-secondary)}.btn-functional.btn-black{background:var(--color-black-default);color:#fff;border-color:var(--color-black-border)}.btn-functional.btn-black .icon img,.btn-functional.btn-black .icon svg{filter:brightness(0) invert(1)}.btn-functional.btn-black .text{color:#fff}.btn-functional.btn-black:hover{background:var(--color-black-hover);border-color:var(--color-black-hover)}.btn-functional.btn-yellow{background:var(--color-yellow-default);color:#fff;border-color:var(--color-yellow-default)}.btn-functional.btn-yellow .icon img,.btn-functional.btn-yellow .icon svg{filter:brightness(0) invert(1)}.btn-functional.btn-yellow .text{color:#fff}.btn-functional.btn-yellow:hover{background:var(--color-yellow-hover);border-color:var(--color-yellow-hover)}.btn-functional.btn-green{background:var(--color-green-default);color:#fff;border-color:var(--color-green-default)}.btn-functional.btn-green .icon img,.btn-functional.btn-green .icon svg{filter:brightness(0) invert(1)}.btn-functional.btn-green .text{color:#fff}.btn-functional.btn-green:hover{background:var(--color-green-hover);border-color:var(--color-green-hover)}.btn-functional.btn-white{background:var(--btn-white-bg);color:var(--text-primary);border-color:var(--border-primary)}.btn-functional.btn-white .icon img,.btn-functional.btn-white .icon svg{filter:brightness(0) saturate(0) invert(.6)}.btn-functional.btn-white .text{color:var(--text-primary)}.btn-functional.btn-white:hover{background:var(--btn-white-hover);border-color:var(--border-secondary)}.btn-state{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:20px;padding:6px 12px;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;min-height:28px;text-decoration:none}.btn-state.btn-basic{background:var(--color-basic-default);color:var(--color-basic-text);border-color:var(--color-basic-border)}.btn-state.btn-basic:hover,.btn-state.btn-basic.active{background:var(--color-basic-hover);border-color:var(--color-basic-border);color:var(--color-basic-text)}.btn-state.btn-basic:disabled{background:var(--color-basic-disabled);color:var(--color-basic-text-disabled);border-color:var(--color-basic-border-disabled);cursor:not-allowed}.btn-state.btn-black{background:var(--color-black-default);color:var(--color-black-text);border-color:var(--color-black-border)}.btn-state.btn-black:hover,.btn-state.btn-black.active{background:var(--color-black-hover);border-color:var(--color-black-hover)}.btn-state.btn-black:disabled{background:var(--color-black-disabled);color:var(--color-black-text-disabled);border-color:var(--color-basic-border);cursor:not-allowed}.btn-state.btn-blue{background:var(--color-blue-default);color:var(--color-blue-text);border-color:var(--color-blue-border)}.btn-state.btn-blue:hover,.btn-state.btn-blue.active{background:var(--color-blue-hover);border-color:var(--color-blue-hover)}.btn-state.btn-blue:disabled{background:var(--color-blue-disabled);color:var(--color-blue-text-disabled);border-color:var(--color-blue-border-disabled);cursor:not-allowed}.btn-state.btn-green{background:var(--color-green-default);color:var(--color-green-text);border-color:var(--color-green-border)}.btn-state.btn-green:hover,.btn-state.btn-green.active{background:var(--color-green-hover);border-color:var(--color-green-hover)}.btn-state.btn-green:disabled{background:var(--color-green-disabled);color:var(--color-green-text-disabled);border-color:var(--color-green-border-disabled);cursor:not-allowed}.btn-state.btn-yellow{background:var(--color-yellow-default);color:var(--color-yellow-text);border-color:var(--color-yellow-border)}.btn-state.btn-yellow:hover,.btn-state.btn-yellow.active{background:var(--color-yellow-hover);border-color:var(--color-yellow-hover)}.btn-state.btn-yellow:disabled{background:var(--color-yellow-disabled);color:var(--color-yellow-text-disabled);border-color:var(--color-yellow-border-disabled);cursor:not-allowed}.btn-state.btn-red{background:var(--color-red-default);color:var(--color-red-text);border-color:var(--color-red-border)}.btn-state.btn-red:hover,.btn-state.btn-red.active{background:var(--color-red-hover);border-color:var(--color-red-hover)}.btn-state.btn-red:disabled{background:var(--color-red-disabled);color:var(--color-red-text-disabled);border-color:var(--color-red-border-disabled);cursor:not-allowed}.btn-state.btn-white{background:var(--bg-card);color:var(--text-primary);border-color:#e0e0e0}.btn-state.btn-white:hover,.btn-state.btn-white.active{background:var(--bg-secondary);border-color:var(--border-secondary)}.btn-state.btn-white:disabled{background:var(--bg-secondary);color:var(--text-muted);border-color:#e0e0e0;cursor:not-allowed}.dark .btn-state.btn-basic{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-primary)}.dark .btn-state.btn-basic:hover,.dark .btn-state.btn-basic.active{background:var(--bg-secondary);border-color:var(--border-secondary)}.dark .btn-state.btn-white{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-primary)}.dark .btn-state.btn-white:hover,.dark .btn-state.btn-white.active{background:var(--bg-secondary);border-color:var(--border-secondary)}.dark .btn-state.btn-red{background:var(--status-error);color:#fff;border-color:var(--status-error)}.dark .btn-state.btn-red:hover,.dark .btn-state.btn-red.active{background:var(--btn-danger-hover);border-color:var(--btn-danger-hover)}.dark .btn-state.btn-green{background:var(--status-success);color:#fff;border-color:var(--status-success)}.dark .btn-state.btn-green:hover,.dark .btn-state.btn-green.active{background:var(--btn-success-hover);border-color:var(--btn-success-hover)}.btn-functional.btn-gray{background:var(--btn-secondary-bg);color:#fff;border-color:var(--btn-secondary-bg)}.btn-functional.btn-gray:hover{background:var(--btn-secondary-hover);border-color:var(--btn-secondary-hover)}.btn-functional.btn-gray .icon img,.btn-functional.btn-gray .icon svg{filter:brightness(0) invert(1)}.btn-functional.btn-gray .text{color:#fff}.btn-text{background:transparent;color:var(--btn-primary-bg);border:none;padding:8px 16px;min-height:36px;cursor:pointer}.btn-text:hover:not(:disabled){background:#4a7cff0a}.btn-fab{background:var(--btn-primary-bg);color:#fff;border:none;border-radius:50%;padding:16px;min-width:56px;min-height:56px;box-shadow:0 3px 5px -1px #0003,0 6px 10px #00000024,0 1px 18px #0000001f;font-size:24px}.btn-fab:hover:not(:disabled){background:var(--btn-primary-hover);box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.btn-fab.btn-sm{min-width:40px;min-height:40px;padding:12px;font-size:20px}.btn-fab.btn-lg{min-width:72px;min-height:72px;padding:20px;font-size:28px}.btn-primary{background:var(--btn-primary-bg);color:#fff;border:1px solid var(--btn-primary-bg)}.btn-primary:hover:not(:disabled){background:var(--btn-primary-hover);border-color:var(--btn-primary-hover)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-secondary)}.btn-outline{background:transparent;color:#1976d2;border:1px solid var(--btn-primary-bg)}.btn-outline:hover:not(:disabled){background:#1976d20a;border-color:#1976d2}.btn-outline-blue{background:transparent;color:var(--color-blue-default);border:2px solid var(--color-blue-border)}.btn-outline-blue:hover:not(:disabled){background:var(--color-blue-default);color:var(--color-blue-text);border-color:var(--color-blue-hover)}.btn-outline-green{background:transparent;color:var(--color-green-default);border:2px solid var(--color-green-border)}.btn-outline-green:hover:not(:disabled){background:var(--color-green-default);color:var(--color-green-text);border-color:var(--color-green-hover)}.btn-outline-red{background:transparent;color:var(--color-red-default);border:2px solid var(--color-red-border)}.btn-outline-red:hover:not(:disabled){background:var(--color-red-default);color:var(--color-red-text);border-color:var(--color-red-hover)}.btn-outline-yellow{background:transparent;color:var(--color-yellow-default);border:2px solid var(--color-yellow-border)}.btn-outline-yellow:hover:not(:disabled){background:var(--color-yellow-default);color:var(--color-yellow-text);border-color:var(--color-yellow-hover)}.btn-outline-basic{background:transparent;color:var(--color-basic-default);border:2px solid var(--color-basic-border)}.btn-outline-basic:hover:not(:disabled){background:var(--color-basic-default);color:var(--color-basic-text);border-color:var(--color-basic-hover)}.btn-outline-black{background:transparent;color:var(--color-black-default);border:2px solid var(--color-black-border)}.btn-outline-black:hover:not(:disabled){background:var(--color-black-default);color:var(--color-black-text);border-color:var(--color-black-hover)}.btn-functional-outline{background:transparent;color:var(--text-primary);border:2px solid var(--border-primary);border-radius:20px;padding:10px 18px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;min-width:100px;min-height:32px;text-decoration:none}.btn-functional-outline:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--border-secondary);transform:translateY(-1px)}.btn-functional-outline .icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.btn-functional-outline .text{font-size:11px;font-weight:500;text-align:center;line-height:1.2;color:var(--text-primary)}.btn-success{background:var(--btn-success-bg);color:#fff;border:1px solid var(--btn-success-bg)}.btn-success:hover:not(:disabled){background:var(--btn-success-hover);border-color:var(--btn-success-hover)}.btn-warning{background:#ed6c02;color:#fff;border:1px solid #ed6c02}.btn-warning:hover:not(:disabled){background:#e65100;border-color:#e65100}.btn-danger{background:var(--btn-danger-bg);color:#fff;border:1px solid var(--btn-danger-bg)}.btn-danger:hover:not(:disabled){background:var(--btn-danger-hover);border-color:var(--btn-danger-hover)}.btn-info{background:#0288d1;color:#fff;border:1px solid #0288d1}.btn-info:hover:not(:disabled){background:#0277bd;border-color:#0277bd}.btn-sm{padding:8px 16px;font-size:13px;min-height:36px;border-radius:4px}.btn-lg{padding:12px 32px;font-size:16px;min-height:48px;border-radius:4px}.btn-icon{padding:12px;min-width:48px;min-height:48px;border-radius:50%;font-size:20px;font-weight:500}.btn-edit,.edit-btn{background:linear-gradient(135deg,#64b5f6,#1976d2);color:#000;border:none;border-radius:50%;padding:12px;min-width:48px;min-height:48px;font-size:20px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000001a;position:relative}.btn-edit:before,.edit-btn:before{content:"";position:absolute;width:20px;height:20px;background-image:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3cpath%20d='M11%204H4a2%202%200%200%200-2%202v14a2%202%200%200%200%202%202h14a2%202%200%200%200%202-2v-7'/%3e%3cpath%20d='M18.5%202.5a2.121%202.121%200%200%201%203%203L12%2015l-4%201%201-4%209.5-9.5z'/%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat;background-position:center}.btn-edit:hover,.edit-btn:hover{background:linear-gradient(135deg,#42a5f5,#1565c0);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.btn-edit:active,.edit-btn:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.btn-edit.btn-sm,.edit-btn.btn-sm{padding:8px;min-width:40px;min-height:40px;font-size:18px}.btn-edit.btn-lg,.edit-btn.btn-lg{padding:16px;min-width:56px;min-height:56px;font-size:24px}.btn-icon.btn-sm{padding:8px;min-width:40px;min-height:40px;font-size:18px}.btn-icon.btn-lg{padding:16px;min-width:56px;min-height:56px;font-size:24px}.modal-close-btn,.close-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:16px}.modal-close-btn{position:absolute;top:8px;right:8px;z-index:10}.modal-close-btn:hover,.close-btn:hover{color:var(--text-primary)}.submit-btn,.save-btn,.primary-btn{background:var(--btn-primary-bg);color:#fff;border:1px solid var(--btn-primary-bg)}.submit-btn:hover,.save-btn:hover,.primary-btn:hover{background:var(--btn-primary-hover);border-color:var(--btn-primary-hover)}.cancel-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary)}.cancel-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-secondary)}.toggle-btn{position:relative;width:50px;height:24px;background:var(--border-primary);border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center}.toggle-btn:before{content:"";position:absolute;width:18px;height:18px;background-image:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3crect%20x='1'%20y='5'%20width='22'%20height='14'%20rx='7'%20ry='7'%3e%3c/rect%3e%3ccircle%20cx='8'%20cy='12'%20r='3'%3e%3c/circle%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat;background-position:center;left:3px;transition:all .3s ease}.toggle-btn.active{background:var(--btn-primary-bg)}.toggle-btn.active:before{background-image:url("data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='currentColor'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3e%3crect%20x='1'%20y='5'%20width='22'%20height='14'%20rx='7'%20ry='7'%3e%3c/rect%3e%3ccircle%20cx='16'%20cy='12'%20r='3'%3e%3c/circle%3e%3c/svg%3e");left:29px}.toggle-btn:hover{background:#d0d0d0}.toggle-btn.active:hover{background:var(--btn-primary-hover)}.toggle-btn.btn-sm{width:40px;height:20px;border-radius:10px}.toggle-btn.btn-sm:before{width:14px;height:14px;left:3px}.toggle-btn.btn-sm.active:before{left:23px}.toggle-btn.btn-lg{width:60px;height:28px;border-radius:14px}.toggle-btn.btn-lg:before{width:22px;height:22px;left:3px}.toggle-btn.btn-lg.active:before{left:35px}.btn-account-add,.account-add-btn{background:transparent;color:var(--text-muted);border:none;padding:8px 12px;min-width:40px;min-height:40px;border-radius:50%;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative}.btn-account-add:before,.account-add-btn:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background-size:contain;background-repeat:no-repeat;background-position:center}.btn-account-add:hover,.account-add-btn:hover{background:#0000000a;color:var(--text-primary)}.btn-account-add:active,.account-add-btn:active{background:#00000014}.btn-permission-manage,.permission-manage-btn{background:transparent;color:var(--text-muted);border:none;padding:8px 12px;min-width:40px;min-height:40px;border-radius:50%;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative}.btn-permission-manage:before,.permission-manage-btn:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background-size:contain;background-repeat:no-repeat;background-position:center}.btn-permission-manage:hover,.permission-manage-btn:hover{background:#0000000a;color:var(--text-primary)}.btn-permission-manage:active,.permission-manage-btn:active{background:#00000014}.btn-permission-tab,.permission-tab-btn{background:transparent;color:var(--text-muted);border:none;padding:8px 12px;min-width:40px;min-height:40px;border-radius:50%;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative}.btn-permission-tab:before,.permission-tab-btn:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background-size:contain;background-repeat:no-repeat;background-position:center}.btn-permission-tab:hover,.permission-tab-btn:hover{background:#0000000a;color:var(--text-primary)}.btn-permission-tab:active,.permission-tab-btn:active{background:#00000014}.btn-permission-tab.btn-primary,.permission-tab-btn.btn-primary{background:#1976d21a;color:#1976d2}.btn-modal-close{position:absolute;top:16px;right:16px;z-index:10;background:none;border:none;font-size:24px;cursor:pointer;padding:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s ease}.btn-modal-close:hover{color:#374151}.btn-modal-close:focus{outline:none;color:#374151}.dark .btn-functional.btn-black{background-color:var(--color-black-default);border-color:var(--color-black-border);color:#fff}.dark .btn-functional.btn-black:hover{background-color:var(--color-black-hover);border-color:var(--color-black-hover)}.dark .btn-icon-only.btn-black{background-color:var(--color-black-default);border-color:var(--color-black-border);color:#fff}.dark .btn-icon-only.btn-black:hover{background-color:var(--color-black-hover);border-color:var(--color-black-hover)}.dark .btn-icon-circle.btn-black{background-color:var(--color-black-default);border-color:var(--color-black-border);color:#fff}.dark .btn-icon-circle.btn-black:hover{background-color:var(--color-black-hover);border-color:var(--color-black-hover)}.checkbox-container{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;color:var(--text-primary);font-weight:500}.checkbox-label input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border:2px solid #6B7280;border-radius:4px;background:transparent;cursor:pointer;position:relative;transition:all .2s ease;margin:0}.checkbox-label:hover input[type=checkbox]{border-color:#4b5563;background:#6b72800d}.checkbox-label input[type=checkbox]:checked{background:#6b7280;border-color:#6b7280}.checkbox-label input[type=checkbox]:checked:after{content:"";position:absolute;left:50%;top:50%;width:6px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:translate(-50%,-60%) rotate(45deg)}.checkbox-label input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 2px #4a7cff33}.checkbox-label input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.checkbox-label:has(input[type=checkbox]:disabled){opacity:.5;cursor:not-allowed}.dark .checkbox-label{color:var(--text-primary)}.dark .checkbox-label input[type=checkbox]{border-color:#9ca3af}.dark .checkbox-label:hover input[type=checkbox]{border-color:#d1d5db;background:#9ca3af1a}.dark .checkbox-label input[type=checkbox]:checked{background:#9ca3af;border-color:#9ca3af}.dropdown-container{position:relative;width:100%}.dropdown-label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:8px;font-size:14px}.dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:1px solid --border-color;border-radius:6px;background:#fff;cursor:pointer;font-size:16px;color:var(--text-primary);transition:border-color .2s ease,box-shadow .2s ease;min-height:44px;box-sizing:border-box}.dropdown-header:hover{border-color:#d1d5db}.dropdown-header:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4a7cff1a}.dropdown-selected-text{flex:1;color:var(--text-primary);text-align:left}.dropdown-arrow{font-size:12px;color:#6b7280;transition:transform .2s ease;margin-left:8px}.dropdown-header.open .dropdown-arrow{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px --border-color;border-top:none;border-radius:0 0 6px 6px;max-height:300px;overflow-y:auto;z-index:1500;box-shadow:0 4px 6px -1px #0000001a}.dropdown-group{border-bottom:1px solid #f3f4f6}.dropdown-group:last-child{border-bottom:none}.dropdown-group-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#fff;cursor:pointer;transition:background-color .2s ease;font-weight:600;color:var(--text-primary);border-bottom:1px solid #f3f4f6}.dropdown-group-header:hover{background:#f9fafb}.dropdown-group-header.selected{background:#f3f4f6;color:var(--text-primary)}.dropdown-group-name{font-size:14px;font-weight:600}.dropdown-group-controls{display:flex;align-items:center;gap:8px}.dropdown-group-count{font-size:12px;color:#6b7280;font-weight:400}.dropdown-toggle-icon{font-size:10px;color:#6b7280;transition:transform .2s ease}.dropdown-item-list{background:#fff}.dropdown-item{padding:10px 16px;cursor:pointer;background:#fff;font-size:14px;color:var(--text-primary);transition:background-color .2s ease;display:flex;align-items:center;gap:8px;width:100%;box-sizing:border-box;white-space:nowrap;overflow:hidden;border:none;text-align:left;border-bottom:1px solid #f3f4f6}.dropdown-item:hover{background:#f9fafb}.dropdown-item.selected{background:#f3f4f6;color:var(--text-primary);font-weight:500}.dropdown-item:last-child{border-bottom:none}.dropdown-header.disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary)}.dropdown-header.disabled:hover{border-color:var(--border-primary);background:var(--bg-tertiary)}.dark .dropdown-header{background:#374151;border-color:#4b5563;color:#fff}.dark .dropdown-header:hover{background:#4b5563;border-color:#6b7280}.dark .dropdown-menu{background:#374151;border-color:#4b5563}.dark .dropdown-group-header{background:#374151;color:#fff;border-bottom-color:#4b5563}.dark .dropdown-group-header:hover,.dark .dropdown-group-header.selected{background:#4b5563}.dark .dropdown-item-list{background:#374151}.dark .dropdown-item{background:#374151;color:#fff;border-bottom-color:#4b5563}.dark .dropdown-item:hover{background:#4b5563}.dark .dropdown-item.selected{background:#4b5563;color:#fff}.dark .dropdown-group{border-bottom-color:#4b5563}.dark .dropdown-group-count,.dark .dropdown-toggle-icon{color:#9ca3af}select,.form-group select,.sensor-add-form select{width:100%!important;padding:8px 40px 8px 12px!important;border:1px solid --border-color;border-radius:6px!important;background:#fff!important;color:--text-primary!important;font-size:14px!important;cursor:pointer!important;transition:border-color .2s ease,box-shadow .2s ease!important;box-sizing:border-box!important;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e")!important;background-position:right 12px center!important;background-repeat:no-repeat!important;background-size:16px!important}select:hover{border-color:#d1d5db}select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4a7cff1a}select:disabled{opacity:.5;cursor:not-allowed;background-color:#f9fafb}select option{background:#fff;color:var(--text-primary);padding:8px 12px}.dark select,.dark .form-group select,.dark .sensor-add-form select{background:var(--bg-card)!important;border-color:var(--border-primary)!important;color:var(--text-primary)!important;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%239ca3af' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e")!important;background-position:right 12px center!important;background-repeat:no-repeat!important;background-size:16px!important}.dark select:hover{border-color:#6b7280!important}.dark select:focus{border-color:var(--primary-color)!important;box-shadow:0 0 0 2px #4a7cff1a!important}.dark select:disabled{background-color:#4b5563!important}.dark select option{background:#374151!important;color:#fff!important}.chart-container{width:100%;overflow:hidden;box-sizing:border-box}.chart-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:8px;margin-bottom:16px}.recharts-responsive-container{width:100%!important;max-width:100%!important}.recharts-cartesian-axis-tick-value,.recharts-legend-item-text{font-size:12px!important}@media (max-width: 768px){.chart-header{flex-direction:column;align-items:stretch;gap:12px}.segment-button-group{width:100%;min-width:auto}.segment-button{padding:10px 8px;font-size:12px;min-height:40px}.chart-container h2,.chart-container h3{font-size:16px!important}.chart-container canvas{max-height:350px!important}.recharts-responsive-container{height:300px!important;min-height:300px!important}.recharts-cartesian-axis-tick-value,.recharts-legend-item-text{font-size:10px!important}.recharts-tooltip-wrapper{font-size:11px!important}.chart-container div[style*="줌 사용법"]{display:none!important}.download-menu-container{width:100%;position:relative}}@media (max-width: 480px){.chart-container{padding:8px!important}.segment-button{padding:8px 4px;font-size:11px;min-height:36px}.chart-container canvas{max-height:250px!important}.recharts-responsive-container{height:250px!important;min-height:250px!important}.recharts-cartesian-axis-tick-value,.recharts-legend-item-text{font-size:9px!important}.recharts-tooltip-wrapper{font-size:10px!important}.chart-container h2,.chart-container h3{font-size:14px!important}}.modal-content.chart-popup{min-width:900px;max-width:95vw;min-height:600px;max-height:90vh}@media (max-width: 768px){.modal-content.chart-popup{min-width:95vw;min-height:80vh;padding:16px}.modal-content.chart-popup .chart-header{margin-bottom:8px;padding:0}.modal-content.chart-popup h2{font-size:18px!important;margin-bottom:12px!important}}@media (hover: none) and (pointer: coarse){.segment-button,.download-menu-container button{min-height:44px;padding:12px 16px}}@media (max-width: 768px){.chart-container div[style*="minWidth: '320px'"]{min-width:100%!important;max-width:100%!important}.chart-container div[style*="gridTemplateColumns: 'repeat(7, 1fr)'"]{font-size:12px!important}}@media (max-width: 768px){.recharts-cartesian-axis-tick text{font-size:10px!important}}@media (max-width: 768px){.chart-container .recharts-responsive-container[style*="height: 200"]{height:180px!important}}@media (max-width: 480px){.chart-container .recharts-responsive-container[style*="height: 200"]{height:160px!important}}.status-badge{font-size:12px;padding:4px 8px;border-radius:4px;font-weight:500;text-align:center;display:inline-block;min-width:60px;white-space:nowrap}.status-badge.normal{background-color:color-mix(in srgb,var(--color-normal) 15%,transparent);color:var(--color-normal)}.status-badge.caution{background-color:color-mix(in srgb,var(--color-caution) 15%,transparent);color:var(--color-caution)}.status-badge.warning{background-color:color-mix(in srgb,var(--color-warning) 15%,transparent);color:var(--color-warning)}.status-badge.danger{background-color:color-mix(in srgb,var(--color-danger) 15%,transparent);color:var(--color-danger)}.status-badge.unknown{background-color:color-mix(in srgb,var(--color-unknown) 15%,transparent);color:var(--color-unknown)}.status-badge.critical{background-color:color-mix(in srgb,var(--color-purple-default) 15%,transparent);color:var(--color-purple-default)}.status-badge.measurement-ended{background-color:color-mix(in srgb,var(--color-gray-dark) 15%,transparent);color:var(--color-gray-dark);border:1px dashed var(--color-gray-light)}.status-badge.offline{background-color:color-mix(in srgb,var(--color-unknown) 15%,transparent);color:var(--color-unknown)}.status-badge.error{background-color:color-mix(in srgb,var(--color-danger) 15%,transparent);color:var(--color-danger)}.status-badge.active{background-color:color-mix(in srgb,var(--color-normal) 15%,transparent);color:var(--color-normal)}.status-badge.inactive{background-color:color-mix(in srgb,var(--color-unknown) 15%,transparent);color:var(--color-unknown)}@media (max-width: 768px){.status-badge{font-size:11px;padding:3px 6px;min-width:50px}}@media (max-width: 480px){.status-badge{font-size:10px;padding:2px 5px;min-width:45px}}:root{--sensor-type-color-1: var(--primary-color);--sensor-type-color-2: #9c27b0;--sensor-type-color-3: var(--green-400);--sensor-type-color-4: var(--orange-400);--sensor-type-color-5: var(--red-400);--sensor-type-color-6: var(--blue-400);--sensor-type-color-7: #ff5722;--sensor-type-color-8: #00bcd4}.dark{--sensor-type-color-1: var(--primary-600);--sensor-type-color-2: #ce93d8;--sensor-type-color-3: var(--green-600);--sensor-type-color-4: var(--orange-600);--sensor-type-color-5: var(--red-600);--sensor-type-color-6: var(--blue-600);--sensor-type-color-7: #ff8a65;--sensor-type-color-8: #4dd0e1}.sensor-type-group-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-card);border-radius:6px;cursor:pointer;transition:background-color .2s ease}.sensor-type-group-header:hover{background:var(--bg-tertiary)}.sensor-type-group-header__left{display:flex;align-items:center;gap:8px}.sensor-type-group-header__right{display:flex;align-items:center;gap:6px}.sensor-type-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.sensor-type-status-dot.normal{background-color:var(--color-normal);box-shadow:0 0 6px var(--color-normal)}.sensor-type-status-dot.caution{background-color:var(--color-caution);box-shadow:0 0 6px var(--color-caution)}.sensor-type-status-dot.warning{background-color:var(--color-warning);box-shadow:0 0 6px var(--color-warning)}.sensor-type-status-dot.danger{background-color:var(--color-danger);box-shadow:0 0 6px var(--color-danger)}.sensor-type-status-dot.unknown{background-color:var(--color-unknown);box-shadow:0 0 6px var(--color-unknown)}.sensor-type-name{font-weight:600;font-size:13px;color:var(--text-primary)}.sensor-type-count{font-size:12px;color:var(--text-secondary)}.sensor-type-max-risk{font-size:11px;color:var(--text-secondary)}.sensor-type-expand-icon{color:var(--text-secondary);transition:transform .2s ease}.sensor-type-expand-icon.expanded{transform:rotate(180deg)}.sensor-type-chip{display:inline-flex;align-items:center;padding:4px 12px;border-radius:16px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .2s ease;white-space:nowrap}.sensor-type-chip.outlined{background-color:transparent;color:var(--text-muted);border-color:var(--border-primary);opacity:.65}.sensor-type-chip.outlined:hover{opacity:1;border-color:var(--text-secondary);color:var(--text-primary);background-color:color-mix(in srgb,var(--text-secondary) 10%,transparent)}.sensor-type-chip.filled{background-color:var(--chip-color, var(--primary-color));color:#fff;border-color:var(--chip-color, var(--primary-color));opacity:1}.sensor-type-chip.filled:hover{background-color:color-mix(in srgb,var(--chip-color, var(--primary-color)) 80%,transparent)}.sensor-type-chip.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.sensor-type-chip.small{padding:2px 8px;font-size:12px;border-radius:12px}.sensor-type-chip.large{padding:6px 16px;font-size:14px;border-radius:20px}.sensor-type-chip-container{display:flex;flex-wrap:nowrap;gap:8px;overflow-x:auto;min-width:fit-content}.sensor-type-chip-container::-webkit-scrollbar{height:4px}.sensor-type-chip-container::-webkit-scrollbar-track{background:var(--border-primary);border-radius:2px}.sensor-type-chip-container::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:2px}.sensor-type-chip-container.wrap{flex-wrap:wrap}.threshold-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap}.threshold-badge.threshold-caution{background-color:color-mix(in srgb,var(--color-caution) 15%,transparent);color:var(--color-caution)}.threshold-badge.threshold-warning{background-color:color-mix(in srgb,var(--color-warning) 15%,transparent);color:var(--color-warning)}.threshold-badge.threshold-danger{background-color:color-mix(in srgb,var(--color-danger) 15%,transparent);color:var(--color-danger)}.threshold-badges{display:flex;flex-wrap:wrap;gap:4px}.sensor-type-icon-preview{width:36px;height:36px;border-radius:var(--radius-md);background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-base)}.sensor-type-icon-preview.large{width:64px;height:64px;border-radius:var(--radius-lg);font-size:var(--font-size-2xl);border:2px solid var(--border-primary)}.sensor-type-icon-cell{display:flex;align-items:center;justify-content:center}.sensor-type-filter-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);margin-bottom:8px}@media (max-width: 768px){.sensor-type-group-header{padding:8px 10px}.sensor-type-name{font-size:12px}.sensor-type-count{font-size:11px}.sensor-type-max-risk{font-size:10px}.sensor-type-chip{padding:3px 10px;font-size:12px}.threshold-badge{font-size:11px;padding:2px 6px}}@media (max-width: 480px){.sensor-type-status-dot{width:8px;height:8px}.sensor-type-chip{padding:2px 8px;font-size:11px}.threshold-badge{font-size:10px;padding:1px 5px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}img[src$=".svg"]{transition:filter .3s ease}.dark img[src$=".svg"]{filter:brightness(0) invert(1)!important}.dark img[src*=sun-icon],.dark img[src*=moon-icon],.dark img[src*=chart-icon],.dark img[src*=check-icon],.dark img[src*=cancel-icon],.dark img[src*=warning-icon],.dark img[src*=success-icon],.dark img[src*=info-icon]{filter:none!important}.dark img[src*=menu-icon],.dark img[src*=settings-icon],.dark img[src*=refresh-icon],.dark img[src*=dashboard-icon],.dark img[src*=sensor-icon],.dark img[src*=alarm-icon],.dark img[src*=users-icon],.dark img[src*=monitoring-icon],.dark img[src*=chevron-down-small],.dark img[src*=chevron-right-small]{filter:brightness(0) invert(1)!important}input[type=datetime-local]{background:var(--input-bg);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:var(--spacing-sm);font-size:14px;transition:all .3s ease}input[type=datetime-local]:focus{outline:none;border-color:var(--input-focus-border);background:var(--bg-card);box-shadow:0 0 0 3px #4a7cff1a}input[type=datetime-local]:hover:not(:focus){border-color:var(--border-secondary)}.dark input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.dark input[type=datetime-local]{color-scheme:dark}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}footer{background:var(--bg-secondary);padding:6px 24px;color:var(--text-secondary);font-size:14px;width:100%;box-sizing:border-box;position:fixed;bottom:0;left:0;transition:all .3s ease;height:32px;overflow:hidden}footer.expanded{height:80px;padding:12px 24px}.footer-content{width:100%;margin:0}.footer-simple{display:flex;justify-content:center;align-items:center;gap:16px;height:24px}.footer-expanded{display:none;justify-content:space-between;align-items:flex-start;padding-top:8px}footer.expanded .footer-simple{display:none}footer.expanded .footer-expanded{display:flex}.footer-left{display:flex;align-items:flex-start;gap:16px}.footer-info{text-align:left}.footer-info p{margin:4px 0}.footer-info .company{font-weight:600;color:var(--text-primary)}.footer-info .address{color:var(--text-secondary)}.footer-right{text-align:right}.contact p{margin:4px 0}.container{padding:90px 0 32px}.stats-cards{display:flex;flex-direction:column;gap:12px;flex-shrink:0;margin-bottom:20px;min-height:0}.stat-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-card{background:var(--bg-card);border-radius:8px;padding:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;cursor:default;transition:none;gap:8px}.stat-card-large{padding:16px 20px;min-height:60px}.stat-label{font-size:14px;color:var(--text-primary);text-align:left!important;font-weight:500}.stat-value{display:flex;align-items:center;justify-content:flex-start;font-size:32px;font-weight:700;gap:14px;color:var(--text-primary)}.stat-card .value{font-size:20px;font-weight:600;line-height:1.2}@media (max-width: 767.98px){.stat-value{font-size:30px;gap:12px}.icon{width:30px;height:30px}.icon img{width:19px;height:19px}.icon.copy{font-size:17px}}@media (max-width: 575.98px){.stat-card .value{font-size:18px;font-weight:600}.stat-value{font-size:26px;font-weight:700;gap:10px}.icon{width:28px;height:28px}.icon img{width:18px;height:18px}.icon.copy{font-size:16px}}.value:not(.normal):not(.caution):not(.warning):not(.danger):not(.unknown):not(.muted){color:var(--primary-color)}.value.normal{color:var(--color-normal)}.value.caution{color:var(--color-caution)}.value.warning{color:var(--color-warning)}.value.danger{color:var(--color-danger)}.value.unknown{color:var(--status-unknown-color)}.value.muted{color:var(--color-muted)}.icon{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:16px}.icon.normal{background:var(--color-normal);color:#fff}.icon.caution{background:var(--color-caution);color:#fff}.icon.warning{background:var(--color-warning);color:#fff}.icon.danger{background:var(--color-danger);color:#fff}.icon.unknown{background:var(--status-unknown-color);color:#fff}.icon.copy{background:var(--bg-tertiary);color:var(--text-secondary);font-size:18px}.icon img{width:20px;height:20px;filter:brightness(0) invert(1)}.btn-reverse{background:transparent!important;color:var(--text-primary);border:1px solid var(--border-primary);border-radius:6px;padding:8px 16px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px;text-decoration:none;min-height:32px}.btn-reverse:hover{background:var(--bg-tertiary)!important;border-color:var(--border-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-reverse:active{transform:translateY(0)}.btn-reverse .icon{display:flex;align-items:center;justify-content:center}.btn-reverse .icon img{width:14px;height:14px;object-fit:contain;filter:brightness(0) saturate(100%) invert(50%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(100%) contrast(100%)}.btn-reverse.btn-blue{background:#2196f31a!important;color:var(--color-blue-default);border-color:var(--color-blue-default)}.btn-reverse.btn-blue:hover{background:#2196f333!important;border-color:var(--color-blue-hover)}.btn-reverse.btn-green{background:#4caf501a!important;color:var(--color-green-default);border-color:var(--color-green-default)}.btn-reverse.btn-green:hover{background:#4caf5033!important;border-color:var(--color-green-hover)}.btn-reverse.btn-yellow{background:color-mix(in srgb,var(--color-warning) 10%,transparent)!important;color:var(--color-warning);border-color:var(--color-warning)}.btn-reverse.btn-yellow:hover{background:color-mix(in srgb,var(--color-warning) 20%,transparent)!important;border-color:var(--color-warning)}.btn-reverse.btn-red{background:color-mix(in srgb,var(--color-danger) 10%,transparent)!important;color:var(--color-danger);border-color:var(--color-danger)}.btn-reverse.btn-red:hover{background:color-mix(in srgb,var(--color-danger) 20%,transparent)!important;border-color:var(--color-danger)}.btn-reverse.btn-purple{background:#9c27b01a!important;color:var(--color-purple-default);border-color:var(--color-purple-default)}.btn-reverse.btn-purple:hover{background:#9c27b033!important;border-color:var(--color-purple-hover)}.segment-button-group{display:flex;background:transparent;border-radius:0;padding:0;gap:0;border:none;position:relative}.segment-button{display:flex;align-items:center;justify-content:center;padding:8px 16px;border:none;background:transparent;border-radius:0;cursor:pointer;transition:all .3s ease;font-size:12px;font-weight:500;color:var(--text-secondary);white-space:nowrap;flex:1;min-height:32px;text-decoration:none;letter-spacing:.25px;position:relative;border-bottom:2px solid transparent}.segment-button:hover{color:var(--text-primary)}.segment-button.active{color:var(--color-blue-default);font-weight:600;border-bottom:2px solid var(--color-blue-default);background:transparent}.segment-button.active img{color:var(--color-blue-default)}.segment-button.active:hover{color:var(--color-blue-default);border-bottom-color:var(--color-blue-default)}.dark .segment-button{background:transparent}.dark .segment-button:hover{color:var(--text-primary)}.dark .segment-button.active{color:var(--color-blue-default);border-bottom-color:var(--color-blue-default)}.dark .segment-button.active img{filter:brightness(0) saturate(0) invert(.8)}.dark .segment-button:not(.active) img{filter:brightness(0) saturate(0) invert(.6)}.alerts-list{display:flex;flex-direction:column;gap:8px;flex:1;overflow-y:auto;min-height:0}.alerts-content{flex:1;display:flex;flex-direction:column;min-height:0}.alert-item{padding:12px;background:var(--bg-secondary);transition:all .2s ease;flex-shrink:0}.alert-item:hover{background:var(--bg-tertiary)}.alert-item:last-child{margin-bottom:0}.real-time-alerts{flex:1;display:flex;flex-direction:column;background:var(--bg-card);border-radius:8px;border:1px solid var(--border-primary);overflow:hidden;transition:all .3s ease;min-height:0}.alerts-header{padding:16px;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.alerts-header h3{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.alert-count{display:flex;align-items:center;gap:8px}.count-badge{background:var(--btn-primary-bg);color:#fff;font-size:12px;font-weight:700;padding:4px 8px;border-radius:12px;min-width:20px;text-align:center}.refresh-indicator{font-size:14px}.refresh-indicator.loading{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.no-alerts{text-align:center;padding:40px 20px;color:var(--text-secondary)}.no-alerts-icon{font-size:48px;margin-bottom:16px}.no-alerts-text{font-size:16px;font-weight:500;margin-bottom:8px;color:var(--text-primary)}.no-alerts-subtext{font-size:14px;color:var(--text-secondary)}.alert-content{display:flex;flex-direction:column;gap:8px;padding:0 12px}.alert-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.alert-item .alert-location{font-weight:600;color:#000;font-size:14px;flex:1}.dark .alert-item .alert-location{color:#fff}.alert-status-badge{padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;flex-shrink:0;border:1px solid transparent}.alert-status-badge.danger{background:var(--alert-danger-bg);color:var(--alert-danger-text);border-color:var(--alert-danger-text)}.alert-status-badge.warning{background:var(--alert-warning-bg);color:var(--alert-warning-text);border-color:var(--alert-warning-text)}.alert-status-badge.caution{background:var(--alert-caution-bg);color:var(--alert-caution-text);border-color:var(--alert-caution-text)}.alert-status-badge.normal{background:var(--alert-normal-bg);color:var(--alert-normal-text);border-color:var(--alert-normal-text)}.alert-details{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--alert-text-secondary, #374151)}.alert-item .alert-time{font-size:11px;color:#374151}.dark .alert-item .alert-time{color:#fff9}.alert-item .alert-value{font-weight:500;color:#000}.dark .alert-item .alert-value{color:#fff}.loading,.error-message{text-align:center;padding:40px 20px;color:var(--alert-text-secondary)}.error-message{color:var(--status-error)}.refresh-button{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:4px;cursor:pointer;color:var(--alert-text-primary)}.refresh-button:hover{background:var(--bg-secondary)}.error-message{background:var(--error-bg);color:var(--error-text);padding:12px;border-radius:4px;margin-bottom:20px;border:1px solid var(--error-border)}.card{background:var(--bg-card);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary)}.card-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-primary)}.card-subtitle{font-size:14px;color:var(--text-secondary);margin:var(--spacing-xs) 0 0 0}.form-control{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.form-control:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4263eb1a}.form-control::placeholder{color:var(--text-muted)}.table{width:100%;border-collapse:collapse;background:var(--bg-primary);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.table th,.table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-light)}.table th{background:var(--bg-secondary);font-weight:600;color:var(--text-primary);font-size:14px}.table td{color:var(--text-primary);font-size:14px}.table tbody tr:hover{background:var(--bg-secondary)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.025em;min-width:90px;text-align:center;justify-content:center}.badge-normal{background:var(--alert-normal-bg);color:var(--alert-normal-text);border:2px solid var(--alert-normal-text);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-caution{background:var(--alert-caution-bg);color:var(--alert-caution-text);border:2px solid var(--alert-caution-text);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-warning{background:var(--alert-warning-bg);color:var(--alert-warning-text);border:2px solid var(--alert-warning-text);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-danger{background:var(--alert-danger-bg);color:var(--alert-danger-text);border:2px solid var(--alert-danger-text);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-unknown{background:#9ca3af1a;color:var(--status-unknown-color);border:2px solid var(--status-unknown-color);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-success{background:#28a7451a;color:var(--success-color)}.badge-info{background:#17a2b81a;color:var(--info-color)}.loading{display:flex;justify-content:center;align-items:center;padding:var(--spacing-xl);color:var(--text-secondary);font-size:16px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--text-muted);text-align:center}.empty-state-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.empty-state-text{font-size:16px;margin-bottom:var(--spacing-sm)}.empty-state-subtext{font-size:14px;color:var(--text-muted)}.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.sr-only-focusable:focus{position:static!important;width:auto!important;height:auto!important;padding:inherit!important;margin:inherit!important;overflow:visible!important;clip:auto!important;white-space:normal!important}*:focus{outline:2px solid var(--primary-color)!important;outline-offset:2px!important}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid var(--primary-color)!important;outline-offset:2px!important}.keyboard-navigation button:focus,.keyboard-navigation input:focus,.keyboard-navigation select:focus,.keyboard-navigation textarea:focus{box-shadow:0 0 0 2px var(--primary-color)!important}.d-none{display:none!important}.d-block{display:block!important}.d-flex{display:flex!important}.d-grid{display:grid!important}.text-center{text-align:center!important}.text-left{text-align:left!important}.text-right{text-align:right!important}.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:var(--spacing-xs)!important}.mb-2{margin-bottom:var(--spacing-sm)!important}.mb-3{margin-bottom:var(--spacing-md)!important}.mb-4{margin-bottom:var(--spacing-lg)!important}.mb-5{margin-bottom:var(--spacing-xl)!important}.mt-0{margin-top:0!important}.mt-1{margin-top:var(--spacing-xs)!important}.mt-2{margin-top:var(--spacing-sm)!important}.mt-3{margin-top:var(--spacing-md)!important}.mt-4{margin-top:var(--spacing-lg)!important}.mt-5{margin-top:var(--spacing-xl)!important}.page-container{padding:24px;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.page-header h1{margin:0;font-size:28px;font-weight:600;color:var(--text-primary)}.page-actions{display:flex;gap:12px}.tabs{display:flex;border-bottom:1px solid var(--border-primary);margin-bottom:24px}.tab{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:16px;font-weight:500;color:var(--text-secondary);transition:all .2s ease}.tab:hover{color:var(--primary-color);background:var(--bg-secondary)}.tab.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background:var(--bg-secondary)}.tab:disabled{opacity:.5;cursor:not-allowed}.tab-content{min-height:400px}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px 0}.table-title h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.table-actions{display:flex;gap:12px;align-items:center}.search-input{padding:8px 12px;border:1px solid var(--border-primary);border-radius:6px;font-size:14px;width:240px;transition:border-color .2s ease;background:var(--bg-primary);color:var(--text-primary)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4a7cff1a}.action-buttons{display:flex;gap:6px}.action-buttons .btn{font-size:12px;padding:4px 8px}.font-mono{font-family:Monaco,Menlo,Ubuntu Mono,monospace}.text-sm{font-size:13px}.table-hover tbody tr:hover{background-color:var(--bg-secondary);cursor:pointer}@media (max-width: 768px){.page-container{padding:16px}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.table-header{flex-direction:column;align-items:stretch;gap:12px}.table-actions{flex-direction:column;align-items:stretch}.search-input{width:100%}.tabs{overflow-x:auto}.tab{flex-shrink:0;padding:12px 16px}}:root{--bp-xs: 320px;--bp-sm: 576px;--bp-md: 768px;--bp-lg: 992px;--bp-xl: 1200px;--bp-xxl: 1400px;--container-xs: 100%;--container-sm: 540px;--container-md: 720px;--container-lg: 960px;--container-xl: 1140px;--container-xxl: 1320px;--space-xs: clamp(4px, 1vw, 8px);--space-sm: clamp(8px, 2vw, 16px);--space-md: clamp(16px, 3vw, 24px);--space-lg: clamp(24px, 4vw, 32px);--space-xl: clamp(32px, 5vw, 48px);--space-xxl: clamp(48px, 6vw, 64px);--text-xs: clamp(10px, 2.5vw, 12px);--text-sm: clamp(12px, 3vw, 14px);--text-base: clamp(14px, 3.5vw, 16px);--text-lg: clamp(16px, 4vw, 18px);--text-xl: clamp(18px, 4.5vw, 20px);--text-2xl: clamp(20px, 5vw, 24px);--text-3xl: clamp(24px, 6vw, 32px);--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75}*{box-sizing:border-box}html{font-size:clamp(14px,2vw,16px);scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}.unified-container{width:100%;max-width:var(--container-xxl);margin:0 auto;padding:0 var(--space-md);transition:padding .2s ease}@media (max-width: 575.98px){.unified-container{max-width:var(--container-xs);padding:0 var(--space-sm)}}@media (min-width: 576px) and (max-width: 767.98px){.unified-container{max-width:var(--container-sm)}}@media (min-width: 768px) and (max-width: 991.98px){.unified-container{max-width:var(--container-md)}}@media (min-width: 992px) and (max-width: 1199.98px){.unified-container{max-width:var(--container-lg)}}@media (min-width: 1200px){.unified-container{max-width:var(--container-xl)}}.unified-grid{display:grid;gap:var(--space-md);width:100%;transition:gap .2s ease}.grid-auto-fill{grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr))}.grid-auto-fit{grid-template-columns:repeat(auto-fit,minmax(min(250px,100%),1fr))}.grid-1{grid-template-columns:1fr}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 575.98px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr!important}.unified-grid{gap:var(--space-sm)}}@media (min-width: 576px) and (max-width: 767.98px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)!important}}@media (min-width: 768px) and (max-width: 991.98px){.grid-4{grid-template-columns:repeat(3,1fr)!important}}.multi-column-layout{display:grid;gap:var(--space-lg);align-items:start;transition:all .3s ease}.layout-3-column{grid-template-columns:1fr 2fr 1fr;grid-template-areas:"sidebar-left main sidebar-right"}.layout-2-column{grid-template-columns:300px 1fr;grid-template-areas:"sidebar main"}.layout-main-sidebar{grid-template-columns:1fr 300px;grid-template-areas:"main sidebar"}@media (max-width: 991.98px){.layout-3-column{grid-template-columns:1fr;grid-template-areas:"sidebar-left" "main" "sidebar-right"}.layout-2-column,.layout-main-sidebar{grid-template-columns:1fr;grid-template-areas:"sidebar" "main"}}@media (min-width: 768px) and (max-width: 991.98px){.layout-3-column{grid-template-columns:1fr 1fr;grid-template-areas:"sidebar-left main" "sidebar-right main"}}.unified-flex{display:flex;gap:var(--space-md);flex-wrap:wrap;align-items:center;transition:all .2s ease}.flex-column{flex-direction:column;align-items:stretch}.flex-row-reverse{flex-direction:row-reverse}.flex-column-reverse{flex-direction:column-reverse}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-evenly{justify-content:space-evenly}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}@media (max-width: 767.98px){.unified-flex:not(.flex-keep-row){flex-direction:column;align-items:stretch;gap:var(--space-sm)}}.unified-card{background:var(--bg-card);border-radius:clamp(6px,1vw,12px);padding:var(--space-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);transition:all .3s ease;overflow:hidden}.unified-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.unified-card.compact{padding:var(--space-sm)}.unified-card.spacious{padding:var(--space-lg)}@media (max-width: 575.98px){.unified-card{border-radius:6px;padding:var(--space-sm)}.unified-card.spacious{padding:var(--space-md)}}.unified-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border:none;border-radius:clamp(4px,1vw,8px);font-size:var(--text-base);font-weight:500;line-height:1.2;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap;min-height:44px;-webkit-user-select:none;user-select:none}.unified-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.unified-btn:active{transform:translateY(0)}.unified-btn:focus{outline:2px solid var(--primary-color);outline-offset:2px}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:var(--text-sm);min-height:36px}.btn-lg{padding:var(--space-md) var(--space-lg);font-size:var(--text-lg);min-height:52px}@media (max-width: 575.98px){.unified-btn{padding:var(--space-sm);min-height:48px;font-size:var(--text-sm)}.btn-sm{min-height:40px}.btn-lg{padding:var(--space-md);min-height:56px}}.unified-text{font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.leading-tight{line-height:var(--leading-tight)}.leading-normal{line-height:var(--leading-normal)}.leading-relaxed{line-height:var(--leading-relaxed)}.unified-heading{font-weight:600;line-height:var(--leading-tight);margin-bottom:var(--space-sm);color:var(--text-primary)}.unified-heading.h1{font-size:var(--text-3xl)}.unified-heading.h2{font-size:var(--text-2xl)}.unified-heading.h3{font-size:var(--text-xl)}.unified-heading.h4{font-size:var(--text-lg)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.break-words{word-break:break-word;overflow-wrap:break-word}@media (max-width: 575.98px){.truncate-mobile{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}}.space-y-xs>*+*{margin-top:var(--space-xs)}.space-y-sm>*+*{margin-top:var(--space-sm)}.space-y-md>*+*{margin-top:var(--space-md)}.space-y-lg>*+*{margin-top:var(--space-lg)}.space-y-xl>*+*{margin-top:var(--space-xl)}.space-x-xs>*+*{margin-left:var(--space-xs)}.space-x-sm>*+*{margin-left:var(--space-sm)}.space-x-md>*+*{margin-left:var(--space-md)}.space-x-lg>*+*{margin-left:var(--space-lg)}.space-x-xl>*+*{margin-left:var(--space-xl)}.hidden{display:none!important}.visible{display:block!important}@media (max-width: 575.98px){.hidden-xs{display:none!important}.visible-xs{display:block!important}}@media (min-width: 576px) and (max-width: 767.98px){.hidden-sm{display:none!important}.visible-sm{display:block!important}}@media (min-width: 768px) and (max-width: 991.98px){.hidden-md{display:none!important}.visible-md{display:block!important}}@media (min-width: 992px) and (max-width: 1199.98px){.hidden-lg{display:none!important}.visible-lg{display:block!important}}@media (min-width: 1200px){.hidden-xl{display:none!important}.visible-xl{display:block!important}}.scroll-smooth{scroll-behavior:smooth}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-scroll{overflow:scroll}.overflow-x-hidden{overflow-x:hidden}.overflow-x-auto{overflow-x:auto}.overflow-x-scroll{overflow-x:scroll}.overflow-y-hidden{overflow-y:hidden}.overflow-y-auto{overflow-y:auto}.overflow-y-scroll{overflow-y:scroll}.custom-scrollbar{scrollbar-width:thin;scrollbar-color:var(--border-secondary) var(--bg-secondary)}.custom-scrollbar::-webkit-scrollbar{width:8px;height:8px}.custom-scrollbar::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (hover: none) and (pointer: coarse){.touch-friendly{min-height:44px;min-width:44px;padding:var(--space-sm)}.unified-card:hover,.unified-btn:hover{transform:none;box-shadow:inherit}}.focus-visible{outline:2px solid var(--primary-color);outline-offset:2px;border-radius:4px}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.sharp-image{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media (prefers-color-scheme: dark){.auto-dark{background:var(--bg-dark, #1a1a1a);color:var(--text-dark, #ffffff)}}.debug-grid *{outline:1px solid rgba(255,0,0,.3)!important}.debug-spacing{background:linear-gradient(45deg,rgba(255,0,0,.1) 25%,transparent 25%),linear-gradient(-45deg,rgba(255,0,0,.1) 25%,transparent 25%);background-size:8px 8px}@media print{.no-print{display:none!important}.unified-card{box-shadow:none;border:1px solid #ccc;break-inside:avoid}.unified-btn{border:1px solid #000}}.unified-page-header{display:flex;justify-content:space-between;align-items:center;padding-top:0;position:relative;z-index:10}.unified-page-header__left{display:flex;flex-direction:row;align-items:center;gap:var(--space-sm);flex:1;min-width:0}.unified-page-header__center{display:flex;align-items:center;flex-shrink:0;height:auto;min-height:0}.unified-page-header__right{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.unified-breadcrumb{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-sm);color:var(--text-secondary)}.unified-breadcrumb__link{color:var(--primary-color);text-decoration:none;transition:color .2s ease}.unified-breadcrumb__link:hover{color:var(--primary-hover)}.unified-breadcrumb__separator{color:var(--text-muted);font-size:12px}.unified-breadcrumb__current{color:var(--text-primary);font-weight:500}.unified-page-title-group{display:flex;align-items:baseline;gap:var(--space-sm);flex-wrap:wrap}.unified-page-title{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin:0;line-height:var(--leading-tight);letter-spacing:-.5px}.unified-page-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin:0;font-weight:400;line-height:var(--leading-normal)}.unified-page-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:12px;font-size:var(--text-xs);font-weight:600;line-height:1}.unified-page-badge--success{background:var(--soft-green-025);color:var(--green-600);border:1px solid var(--green-200)}.unified-page-badge--warning{background:var(--alert-warning-bg);color:var(--alert-warning-text);border:1px solid var(--yellow-200)}.unified-page-badge--danger{background:var(--alert-danger-bg);color:var(--alert-danger-text);border:1px solid var(--red-200)}.unified-page-badge--info{background:var(--alert-info-bg);color:var(--alert-info-text);border:1px solid var(--blue-200)}@media (max-width: 767.98px){.unified-page-header{flex-direction:row;justify-content:space-between;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0;min-height:auto}.unified-page-header__left{flex:1;min-width:0}.unified-page-header__right{flex-shrink:0;justify-content:flex-end}.unified-page-title{font-size:var(--text-2xl)}.unified-page-subtitle{font-size:var(--text-base)}.unified-page-title-group{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}}@media (max-width: 575.98px){.unified-page-header{padding:var(--space-xs) 0;margin-bottom:var(--space-md)}.unified-page-title{font-size:var(--text-xl);line-height:var(--leading-normal)}.unified-page-subtitle{font-size:var(--text-sm)}.unified-breadcrumb{font-size:12px}.unified-page-header__right{flex-direction:column;gap:var(--space-xs)}.unified-page-title{word-break:keep-all;overflow-wrap:break-word}}@media (max-width: 319.98px){.unified-page-title{font-size:var(--text-lg)}.unified-page-header{padding:12px 0}}.unified-page-layout{min-height:calc(100vh - 120px);padding:var(--space-lg);max-width:1920px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-lg)}.unified-page-content{flex:1;display:flex;flex-direction:column;gap:var(--space-lg);min-height:0}@media (max-width: 767.98px){.unified-page-layout{padding:var(--space-md);gap:var(--space-md)}.unified-page-content{gap:var(--space-md)}}@media (max-width: 575.98px){.unified-page-layout{padding:var(--space-sm);gap:var(--space-sm)}.unified-page-content{gap:var(--space-sm)}}.unified-list-header{display:flex;flex-direction:column;padding:var(--space-s);background:transparent;border:none;border-radius:0;gap:var(--space-sm)}.unified-list-header__title-row{display:flex;justify-content:space-between;align-items:center;width:100%;gap:var(--space-sm)}.unified-list-header__title{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0;flex:1}.unified-list-header__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm);width:100%}.unified-list-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:var(--primary-color);color:#fff;font-size:var(--text-sm);font-weight:600;border-radius:12px;line-height:1}.unified-list-count--success{background:var(--green-400)}.unified-list-count--warning{background:var(--yellow-400)}.unified-list-count--danger{background:var(--red-400)}.unified-list-count--info{background:var(--blue-400)}.unified-list-count--muted{background:var(--neutral-400);color:#fff}.unified-list-search-group{display:flex;align-items:center;gap:var(--space-xs)}.unified-list-search{width:200px;padding:6px 12px;border:1px solid var(--border-primary);border-radius:var(--border-radius-sm);font-size:var(--text-sm);background:var(--input-bg);color:var(--text-primary);transition:border-color .2s ease}.unified-list-search:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(var(--primary-color),.1)}.unified-list-filter{padding:6px 12px;border:1px solid var(--border-primary);border-radius:var(--border-radius-sm);font-size:var(--text-sm);background:var(--input-bg);color:var(--text-primary);min-width:120px}.unified-list-filter:focus{outline:none;border-color:var(--primary-color)}.unified-list-actions{display:flex;align-items:center;gap:var(--space-xs)}@media (max-width: 767.98px){.unified-list-header{padding:var(--space-sm) var(--space-md);gap:var(--space-sm)}.unified-list-header__title{font-size:var(--text-base)}.unified-list-search{width:140px}.unified-list-filter{min-width:90px}}@media (max-width: 575.98px){.unified-list-header{padding:var(--space-sm);gap:var(--space-sm)}.unified-list-header__title{font-size:var(--text-base);font-weight:600}.unified-list-header__title-row{gap:var(--space-xs)}.unified-list-header__actions{gap:var(--space-xs);justify-content:center}.unified-list-search-group{gap:var(--space-xs)}.unified-list-search{width:120px;padding:6px 8px;font-size:var(--text-sm)}.unified-list-filter{min-width:80px;padding:6px 8px;font-size:var(--text-sm)}.toggle-filter{gap:4px}}@media (max-width: 375px){.unified-list-header__title{font-size:var(--text-sm)}.unified-list-header__title-row{gap:4px}.unified-list-search{width:100px;font-size:var(--text-xs)}.unified-list-filter{min-width:70px;font-size:var(--text-xs)}.toggle-filter .toggle-switch{transform:scale(.9)}}.unified-list-search:focus,.unified-list-filter:focus{box-shadow:0 0 0 2px var(--primary-color)}@media (prefers-contrast: high){.unified-list-header,.unified-list-search,.unified-list-filter{border-width:2px}}@media (prefers-reduced-motion: reduce){.unified-list-search,.unified-list-filter{transition:none}}@media (hover: none) and (pointer: coarse){.unified-list-search,.unified-list-filter{min-height:44px}.unified-list-actions .unified-btn{min-height:44px;padding:12px 16px}}.unified-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-lg)}.unified-pagination__info{color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;margin:0;white-space:nowrap}.unified-pagination__controls{display:flex;align-items:center;gap:var(--space-sm)}.unified-pagination__button{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:var(--space-xs) var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none;box-sizing:border-box;-webkit-user-select:none;user-select:none}.unified-pagination__button:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-secondary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.unified-pagination__button:active:not(:disabled){transform:translateY(0);background:var(--bg-quaternary)}.unified-pagination__button:disabled{background:var(--bg-muted);color:var(--text-muted);cursor:not-allowed;border-color:var(--border-muted);opacity:.6}.unified-pagination__button.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);font-weight:600}.unified-pagination__button.active:hover{background:var(--primary-hover);border-color:var(--primary-hover);transform:none}.unified-pagination__page{min-width:36px;text-align:center}.unified-pagination__nav{padding:var(--space-xs) var(--space-md);min-width:auto;gap:var(--space-xs)}.unified-pagination__jump{padding:var(--space-xs) var(--space-sm);font-size:var(--text-xs);min-width:28px;height:28px}.unified-pagination__ellipsis{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;color:var(--text-muted);font-size:var(--text-sm);font-weight:500;-webkit-user-select:none;user-select:none}@media (max-width: 575.98px){.unified-pagination{flex-direction:column;gap:var(--space-sm);padding:var(--space-md)}.unified-pagination__info{font-size:var(--text-xs);text-align:center;order:2}.unified-pagination__controls{gap:var(--space-xs);flex-wrap:wrap;justify-content:center;order:1}.unified-pagination__button{min-width:32px;height:32px;font-size:var(--text-xs)}.unified-pagination__nav{padding:var(--space-xs) var(--space-sm);font-size:var(--text-xs);min-width:28px;height:32px}.unified-pagination__jump{min-width:24px;height:32px;padding:var(--space-xs)}.unified-pagination__nav .btn-text-mobile-hide{display:none}.unified-pagination__nav .btn-icon-mobile-show{display:inline}.unified-pagination__page.mobile-hide{display:none}}@media (min-width: 576px){.unified-pagination__nav .btn-text-mobile-hide{display:inline}.unified-pagination__nav .btn-icon-mobile-show{display:none}}@media (min-width: 576px) and (max-width: 767.98px){.unified-pagination{padding:var(--space-md) var(--space-lg)}.unified-pagination__button{min-width:34px;height:34px}.unified-pagination__nav{padding:var(--space-xs) var(--space-md)}}.unified-pagination--loading{opacity:.6;pointer-events:none}.unified-pagination--loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border:2px solid var(--border-muted);border-top:2px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.unified-pagination--small{padding:var(--space-sm)}.unified-pagination--small .unified-pagination__button{min-width:28px;height:28px;font-size:var(--text-xs);padding:4px 8px}.unified-pagination--small .unified-pagination__info{font-size:var(--text-xs)}.unified-pagination--compact{padding:var(--space-sm) var(--space-md);gap:var(--space-sm)}.unified-pagination--compact .unified-pagination__button{min-width:28px;height:28px;font-size:var(--text-xs)}.unified-pagination--compact .unified-pagination__controls{gap:4px}.dark .unified-pagination{background:var(--bg-card);border-top-color:var(--border-primary)}.dark .unified-pagination__button{background:var(--bg-secondary);border-color:var(--border-primary);color:var(--text-primary)}.dark .unified-pagination__button:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-secondary)}.dark .unified-pagination__button:disabled{background:var(--bg-muted);color:var(--text-muted);border-color:var(--border-muted)}.dark .unified-pagination__button.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.dark .unified-pagination__ellipsis{color:var(--text-muted)}@media (prefers-contrast: high){.unified-pagination__button{border-width:2px}.unified-pagination__button.active{border-width:2px;outline:2px solid var(--text-primary);outline-offset:1px}}.unified-pagination__button:focus{outline:2px solid var(--primary-color);outline-offset:2px}@media (hover: none) and (pointer: coarse){.unified-pagination__button{min-height:44px;min-width:44px}.unified-pagination__nav{min-height:44px;padding:var(--space-sm) var(--space-md)}}:root{--breakpoint-xs: 320px;--breakpoint-sm: 576px;--breakpoint-md: 768px;--breakpoint-lg: 992px;--breakpoint-xl: 1200px;--breakpoint-xxl: 1400px;--container-xs: 100%;--container-sm: 540px;--container-md: 720px;--container-lg: 960px;--container-xl: 1140px;--container-xxl: 1280px;--spacing-xs: clamp(2px, .4vw, 5px);--spacing-sm: clamp(4px, .5vw, 8px);--spacing-md: clamp(6px, .8vw, 12px);--spacing-lg: clamp(10px, 1vw, 16px);--spacing-xl: clamp(12px, 1.2vw, 18px);--spacing-xxl: clamp(14px, 1.5vw, 20px);--font-xs: clamp(10px, 2vw, 11px);--font-sm: clamp(12px, 2.5vw, 13px);--font-md: clamp(13px, 3vw, 15px);--font-lg: clamp(14px, 3.5vw, 16px);--font-xl: clamp(16px, 4vw, 18px);--font-xxl: clamp(18px, 4.5vw, 22px);--font-xxxl: clamp(20px, 5vw, 28px);--line-height-tight: 1.3;--line-height-normal: 1.5;--line-height-relaxed: 1.7}.responsive-container{width:100%;max-width:var(--container-xxl);margin:0 auto;padding:0 var(--spacing-md)}@media (max-width: 575.98px){.responsive-container{max-width:var(--container-xs);padding:0 var(--spacing-sm)}}@media (min-width: 576px) and (max-width: 767.98px){.responsive-container{max-width:var(--container-sm);padding:0 var(--spacing-md)}}@media (min-width: 768px) and (max-width: 991.98px){.responsive-container{max-width:var(--container-md);padding:0 var(--spacing-lg)}}@media (min-width: 992px) and (max-width: 1199.98px){.responsive-container{max-width:var(--container-lg);padding:0 var(--spacing-xl)}}@media (min-width: 1200px){.responsive-container{max-width:var(--container-xl);padding:0 var(--spacing-xl)}}.responsive-grid{display:grid;gap:var(--spacing-md);width:100%}.grid-3-col{grid-template-columns:1fr 2fr 1fr}.grid-2-col{grid-template-columns:1fr 1fr}.grid-1-col{grid-template-columns:1fr}.grid-auto-responsive{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}@media (max-width: 575.98px){:root{--current-spacing: var(--spacing-sm);--current-font: var(--font-sm)}.responsive-grid{grid-template-columns:1fr!important;gap:var(--spacing-sm)}.hide-xs{display:none!important}.show-xs-only{display:block!important}}@media (min-width: 576px) and (max-width: 767.98px){:root{--current-spacing: var(--spacing-md);--current-font: var(--font-md)}.responsive-grid{grid-template-columns:1fr!important;gap:var(--spacing-md)}.hide-sm{display:none!important}.show-sm-only{display:block!important}}@media (min-width: 768px) and (max-width: 991.98px){:root{--current-spacing: var(--spacing-md);--current-font: var(--font-md)}.grid-3-col{grid-template-columns:1fr 1fr!important}.hide-md{display:none!important}.show-md-only{display:block!important}}@media (min-width: 992px) and (max-width: 1199.98px){:root{--current-spacing: var(--spacing-lg);--current-font: var(--font-lg)}.hide-lg{display:none!important}.show-lg-only{display:block!important}}@media (min-width: 1200px){:root{--current-spacing: var(--spacing-xl);--current-font: var(--font-xl)}.hide-xl{display:none!important}.show-xl-only{display:block!important}}.responsive-card{background:var(--bg-card);border-radius:8px;padding:var(--current-spacing, var(--spacing-md));box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);transition:all .3s ease}@media (max-width: 767.98px){.responsive-card{border-radius:6px;padding:var(--spacing-sm)}}.responsive-btn{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--current-font, var(--font-md));border-radius:6px;transition:all .2s ease;cursor:pointer;border:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}@media (max-width: 767.98px){.responsive-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-sm);min-height:44px}}.responsive-text{font-size:var(--current-font, var(--font-md));line-height:1.5}.responsive-text-lg{font-size:calc(var(--current-font, var(--font-md)) * 1.25);line-height:1.4}.responsive-text-sm{font-size:calc(var(--current-font, var(--font-md)) * .875);line-height:1.6}.responsive-flex{display:flex;gap:var(--current-spacing, var(--spacing-md));flex-wrap:wrap;align-items:center}@media (max-width: 767.98px){.responsive-flex{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}}.responsive-gap{gap:var(--current-spacing, var(--spacing-md))}.responsive-padding{padding:var(--current-spacing, var(--spacing-md))}.responsive-margin{margin:var(--current-spacing, var(--spacing-md))}.responsive-scroll{overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--text-muted) transparent}.responsive-scroll::-webkit-scrollbar{height:6px}.responsive-scroll::-webkit-scrollbar-track{background:transparent}.responsive-scroll::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}@media (max-width: 767.98px){.touch-friendly{min-height:44px;min-width:44px;padding:var(--spacing-sm)}.touch-target:after{content:"";position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px;z-index:-1}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.debug-responsive *{outline:1px solid red!important}.debug-responsive .responsive-grid{background:#ff00001a!important}.debug-responsive .responsive-card{background:#00ff001a!important}.main-layout-container{width:100%;min-height:100vh;padding:var(--spacing-md);box-sizing:border-box;margin-top:clamp(56px,8vh,72px);transition:all .3s ease}.dashboard-main-grid{display:grid;gap:var(--spacing-lg);width:100%;max-width:var(--container-xxl);margin:0 auto;grid-template-columns:1fr 2fr 1fr;grid-template-areas:"sidebar-left main-content sidebar-right" "sidebar-left main-content sidebar-right";align-items:start}.area-sidebar-left{grid-area:sidebar-left}.area-main-content{grid-area:main-content}.area-sidebar-right{grid-area:sidebar-right}.layout-2-column{display:grid;gap:var(--spacing-lg);grid-template-columns:minmax(300px,350px) 1fr;grid-template-areas:"sidebar main";align-items:start}.area-sidebar{grid-area:sidebar}.area-main{grid-area:main}.monitoring-layout{display:grid;gap:var(--spacing-md);grid-template-columns:1fr;grid-template-areas:"summary" "filters" "content"}.area-summary{grid-area:summary}.area-filters{grid-area:filters}.area-content{grid-area:content}.sensor-management-layout{display:grid;gap:var(--spacing-md);grid-template-columns:350px 1fr;grid-template-areas:"controls content" "controls content";align-items:start}.area-controls{grid-area:controls}.responsive-card-container{background:var(--bg-card);border-radius:clamp(6px,1vw,12px);padding:var(--spacing-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);transition:all .3s ease;height:fit-content;overflow:hidden}.responsive-card-container.sticky{position:sticky;top:calc(clamp(56px,8vh,72px) + var(--spacing-md))}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-primary);flex-wrap:wrap;gap:var(--spacing-sm)}.section-header h2{margin:0;font-size:var(--font-xl);font-weight:600;color:var(--text-primary);flex:1;min-width:0}.section-header-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.stats-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:var(--spacing-lg)}.table-container{background:var(--bg-card);border-radius:clamp(6px,1vw,12px);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-primary)}.table-responsive{overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--border-secondary) var(--bg-secondary)}.table-responsive::-webkit-scrollbar{height:8px}.table-responsive::-webkit-scrollbar-track{background:var(--bg-secondary)}.table-responsive::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:4px}.filters-container{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:clamp(6px,1vw,12px);border:1px solid var(--border-primary)}.filter-group{display:flex;align-items:center;gap:var(--spacing-sm)}.filter-group label{font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);white-space:nowrap}.filter-group select,.filter-group input{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-card);color:var(--text-primary);font-size:var(--font-sm);min-width:120px}@media (min-width: 1200px){.dashboard-main-grid{grid-template-columns:minmax(280px,320px) 1fr minmax(280px,320px);gap:var(--spacing-xl)}.layout-2-column{grid-template-columns:minmax(350px,400px) 1fr;gap:var(--spacing-xl)}.sensor-management-layout{grid-template-columns:400px 1fr}}@media (min-width: 992px) and (max-width: 1199.98px){.dashboard-main-grid{grid-template-columns:minmax(250px,300px) 1fr minmax(250px,300px)}.layout-2-column{grid-template-columns:minmax(300px,350px) 1fr}.sensor-management-layout{grid-template-columns:350px 1fr}}@media (min-width: 768px) and (max-width: 991.98px){.main-layout-container{padding:var(--spacing-sm)}.dashboard-main-grid{grid-template-columns:1fr 1fr;grid-template-areas:"sidebar-left main-content" "sidebar-right main-content";gap:var(--spacing-md)}.layout-2-column{grid-template-columns:1fr;grid-template-areas:"sidebar" "main";gap:var(--spacing-md)}.sensor-management-layout{grid-template-columns:1fr;grid-template-areas:"controls" "content"}.filters-container{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.filter-group{justify-content:space-between}.filter-group select,.filter-group input{min-width:100px;flex:1}.section-header{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.section-header h2{text-align:center}.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}}@media (min-width: 576px) and (max-width: 767.98px){.main-layout-container{padding:12px;margin-top:60px}.dashboard-main-grid,.layout-2-column,.sensor-management-layout,.monitoring-layout{grid-template-columns:1fr!important;grid-template-areas:"sidebar-left" "main-content" "sidebar-right"!important;gap:8px}.layout-2-column{grid-template-areas:"sidebar" "main"!important;gap:8px}.sensor-management-layout{grid-template-areas:"controls" "content"!important;gap:8px}.responsive-card-container{padding:12px;border-radius:6px;margin-bottom:8px}.filters-container{flex-direction:column;align-items:stretch;padding:var(--spacing-sm)}.stats-grid{grid-template-columns:1fr;gap:var(--spacing-sm)}.table-responsive{font-size:var(--font-sm)}}@media (max-width: 575.98px){.main-layout-container{padding:8px;margin-top:56px}.dashboard-main-grid,.layout-2-column,.sensor-management-layout,.monitoring-layout{grid-template-columns:1fr!important;grid-template-areas:"sidebar-left" "main-content" "sidebar-right"!important;gap:6px}.layout-2-column{grid-template-areas:"sidebar" "main"!important;gap:6px}.sensor-management-layout{grid-template-areas:"controls" "content"!important;gap:6px}.responsive-card-container{padding:8px;border-radius:4px;margin-bottom:6px}.section-header{margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs)}.section-header h2{font-size:var(--font-lg)}.filters-container{padding:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.filter-group{flex-direction:column;align-items:stretch;gap:var(--spacing-xs)}.filter-group select,.filter-group input{min-width:100%;padding:var(--spacing-sm);font-size:var(--font-base);min-height:44px}.stats-grid{grid-template-columns:1fr;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.table-responsive{font-size:var(--font-xs)}.section-header-actions{flex-direction:column;width:100%;gap:var(--spacing-xs)}.section-header-actions button{width:100%;min-height:44px}}.layout-fullscreen{grid-template-columns:1fr!important;grid-template-areas:"main-content"!important}.layout-fullscreen .area-sidebar-left,.layout-fullscreen .area-sidebar-right,.layout-fullscreen .area-sidebar{display:none!important}.layout-map-focused .area-main-content{order:-1}@media (max-width: 991.98px){.layout-map-focused{grid-template-areas:"main-content" "sidebar-left" "sidebar-right"!important}}.sidebar-sticky{position:sticky;top:calc(clamp(56px,8vh,72px) + var(--spacing-md));max-height:calc(100vh - clamp(56px,8vh,72px) - var(--spacing-lg));overflow-y:auto}@media (max-width: 991.98px){.sidebar-sticky{position:static;max-height:none;overflow-y:visible}}.layout-transition{transition:grid-template-columns .3s ease,grid-template-areas .3s ease,gap .3s ease}@media (prefers-reduced-motion: reduce){.layout-transition{transition:none}}.debug-layout *{outline:1px solid rgba(255,0,0,.3)!important}.debug-layout .dashboard-main-grid{background:linear-gradient(45deg,rgba(255,0,0,.1) 25%,transparent 25%)}.debug-layout .area-sidebar-left{background:#00ff001a}.debug-layout .area-main-content{background:#0000ff1a}.debug-layout .area-sidebar-right{background:#ffff001a}.card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all .3s ease;overflow:hidden}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.card-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.card-subtitle{font-size:14px;color:var(--text-secondary);margin:4px 0 0}.card-content{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-primary);background:var(--bg-secondary)}.card-sm{padding:var(--spacing-sm)}.card-md{padding:var(--spacing-md)}.card-lg{padding:var(--spacing-lg)}.card-primary{border-color:var(--btn-primary-bg)}.card-primary .card-header{background:var(--btn-primary-bg);color:#fff}.card-success{border-color:var(--status-success)}.card-warning{border-color:var(--status-warning)}.card-danger{border-color:var(--status-error)}.card-info{border-color:var(--status-info)}.section{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all .3s ease;overflow:hidden}.section-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-primary);background:var(--bg-secondary);display:flex;justify-content:space-between;align-items:center}.section-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.section-subtitle{font-size:14px;color:var(--text-secondary);margin:4px 0 0}.section-content{padding:var(--spacing-lg)}.section-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border-primary);background:var(--bg-secondary)}.section-sm{padding:var(--spacing-sm)}.section-md{padding:var(--spacing-md)}.section-lg{padding:var(--spacing-lg)}.section-primary{border-color:var(--btn-primary-bg)}.section-primary .section-header{background:var(--btn-primary-bg);color:#fff}.section-success{border-color:var(--status-success)}.section-warning{border-color:var(--status-warning)}.section-danger{border-color:var(--status-error)}.section-info{border-color:var(--status-info)}.section-grid{display:grid;gap:var(--spacing-md)}.section-grid-2{grid-template-columns:repeat(2,1fr)}.section-grid-3{grid-template-columns:repeat(3,1fr)}.section-grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.section-grid-2,.section-grid-3,.section-grid-4{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}}.table{width:100%;border-collapse:collapse;background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-primary)}.table th{background:var(--bg-secondary);color:var(--text-primary);font-weight:600;padding:var(--spacing-md);text-align:center;border-bottom:1px solid var(--border-primary);font-size:14px}.table td{padding:var(--spacing-md);border-bottom:1px solid var(--border-primary);color:var(--text-primary);font-size:14px;text-align:center}.table tbody tr:hover{background:var(--bg-tertiary)}.table tbody tr:last-child td{border-bottom:none}.table-sm th,.table-sm td{padding:var(--spacing-sm);font-size:13px}.table-lg th,.table-lg td{padding:var(--spacing-lg);font-size:16px}.table-primary th{background:var(--btn-primary-bg);color:#fff}.table-success th{background:var(--status-success);color:#fff}.table-warning th{background:var(--status-warning);color:#fff}.table-danger th{background:var(--status-error);color:#fff}.table-info th{background:var(--status-info);color:#fff}.table-container{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-primary);overflow:hidden;box-shadow:var(--shadow-sm)}.table-header{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.table-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.table-subtitle{font-size:14px;color:var(--text-secondary);margin:4px 0 0}.table-content{overflow-x:auto}.table-footer{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-top:1px solid var(--border-primary)}.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease}.badge-sm{padding:2px 6px;font-size:10px}.badge-lg{padding:6px 12px;font-size:14px}.badge-primary{background:var(--btn-primary-bg);color:#fff}.badge-secondary{background:var(--btn-secondary-bg);color:#fff}.badge-success{background:var(--status-success);color:#fff}.badge-warning{background:var(--status-warning);color:#fff}.badge-danger{background:var(--status-error);color:#fff}.badge-info{background:var(--status-info);color:#fff}.badge-light{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-primary)}.badge-dark{background:var(--text-primary);color:var(--bg-primary)}.badge-normal{background:var(--color-normal);color:#fff}.badge-caution{background:var(--color-caution);color:#fff}.badge-warning-status{background:var(--color-warning);color:#fff}.badge-danger-status{background:var(--color-danger);color:#fff}.badge-unknown{background:var(--color-unknown);color:#fff}.badge-icon{margin-right:4px;width:12px;height:12px}.badge-icon-sm{margin-right:2px;width:10px;height:10px}.badge-icon-lg{margin-right:6px;width:14px;height:14px}.badge-group{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.dark .badge-normal{background:var(--color-normal);color:#fff}.dark .badge-caution{background:var(--color-caution);color:#fff}.dark .badge-warning-status{background:var(--color-warning);color:#fff}.dark .badge-danger-status{background:var(--color-danger);color:#fff}.dark .badge-unknown{background:var(--color-unknown);color:#fff}.notification-badge{position:absolute;top:-6px;right:-6px;background:var(--status-error);color:#fff;font-size:10px;padding:2px 6px;border-radius:10px;min-width:16px;text-align:center;font-weight:600;border:2px solid var(--bg-card)}.map-container{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;transition:all .3s ease}.map-header{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center}.map-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.map-subtitle{font-size:14px;color:var(--text-secondary);margin:4px 0 0}.map-content{position:relative;background:var(--bg-card)}.map-controls{position:absolute;top:var(--spacing-md);right:var(--spacing-md);z-index:1000;display:flex;flex-direction:column;gap:var(--spacing-sm)}[data-view-mode=BLUEPRINT] .map-controls,[data-view-mode=BLUEPRINT] .mode-buttons,[data-view-mode=BLUEPRINT] .map-layer-controls,[data-view-mode=BLUEPRINT] .map-view-mode-selector,[data-view-mode=BLUEPRINT] .map-controls-row{z-index:5000!important}.map-control-button{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:var(--spacing-sm);cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-sm)}.map-control-button:hover{background:var(--bg-tertiary);border-color:var(--border-secondary)}.map-control-button.active{background:var(--btn-primary-bg);color:#fff;border-color:var(--btn-primary-bg)}.map-legend{position:absolute;bottom:var(--spacing-md);left:var(--spacing-md);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:var(--spacing-md);box-shadow:var(--shadow-sm);z-index:1000}.map-legend-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-sm) 0}.map-legend-item{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.map-legend-color{width:16px;height:16px;border-radius:var(--radius-sm);border:1px solid var(--border-primary)}.map-legend-label{font-size:12px;color:var(--text-secondary)}.map-marker{background:var(--bg-card);border:2px solid var(--border-primary);border-radius:50%;box-shadow:var(--shadow-sm);transition:all .3s ease}.map-marker:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.map-marker.normal{border-color:var(--color-normal)}.map-marker.caution{border-color:var(--color-caution)}.map-marker.warning{border-color:var(--color-warning)}.map-marker.danger{border-color:var(--color-danger)}.map-marker.critical{border-color:#9c27b0}.map-marker.unknown{border-color:var(--status-unknown-color)}.map-popup{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--spacing-md);max-width:300px}.map-popup-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-sm) 0}.map-popup-content{font-size:14px;color:var(--text-secondary);line-height:1.4}.map-popup-footer{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--border-primary)}.map-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-lg);z-index:1000}.map-loading-text{color:var(--text-secondary);font-size:14px;text-align:center}@media (max-width: 768px){.map-controls{position:static;flex-direction:row;justify-content:center;margin-bottom:var(--spacing-md)}.map-legend{position:static;margin-top:var(--spacing-md)}}.form{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all .3s ease}.form-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-primary)}.form-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.form-subtitle{font-size:14px;color:var(--text-secondary);margin:4px 0 0}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-primary);border-radius:var(--radius-sm);background:var(--input-bg);color:var(--text-primary);font-size:14px;transition:all .3s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:var(--input-focus-border);box-shadow:0 0 0 3px #4a7cff1a;background:var(--bg-card)}.form-input:hover:not(:focus){border-color:var(--border-secondary)}.form-input::placeholder{color:var(--text-muted)}.form-input:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.form-input.error{border-color:var(--status-error);box-shadow:0 0 0 3px #ef44441a}.form-textarea{resize:vertical;min-height:80px}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:16px;padding-right:32px}.form-checkbox,.form-radio{width:auto;margin-right:var(--spacing-sm)}.form-checkbox-label,.form-radio-label{display:flex;align-items:center;cursor:pointer;font-size:14px;color:var(--text-primary)}.form-help{font-size:12px;color:var(--text-muted);margin-top:var(--spacing-xs)}.form-error{font-size:12px;color:var(--status-error);margin-top:var(--spacing-xs)}.form-success{font-size:12px;color:var(--status-success);margin-top:var(--spacing-xs)}.form-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--border-primary)}.form-actions.justify-end{justify-content:flex-end}.form-actions.justify-center{justify-content:center}.form-actions.justify-between{justify-content:space-between}.form-grid{display:grid;gap:var(--spacing-md)}.form-grid-2{grid-template-columns:repeat(2,1fr)}.form-grid-3{grid-template-columns:repeat(3,1fr)}.form-grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.form-grid-2,.form-grid-3,.form-grid-4{grid-template-columns:1fr}}.login-page{min-height:100vh;display:flex;font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.login-brand{flex:1;background:linear-gradient(160deg,#f0f4f8,#e2e8f0,#f1f5f9);display:flex;flex-direction:column;justify-content:center;padding:60px 80px;position:relative;overflow:hidden}.login-brand:before{content:"";position:absolute;top:20%;left:50%;transform:translate(-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(59,130,246,.08) 0%,transparent 70%);pointer-events:none;filter:blur(60px)}.login-brand:after{content:"";position:absolute;bottom:-20%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(16,185,129,.06) 0%,transparent 60%);pointer-events:none;filter:blur(80px)}.dark .login-brand{background:linear-gradient(160deg,#0a0f1a,#111827,#0f172a)}.dark .login-brand:before{background:radial-gradient(circle,rgba(59,130,246,.12) 0%,transparent 70%)}.dark .login-brand:after{background:radial-gradient(circle,rgba(16,185,129,.08) 0%,transparent 60%)}.brand-company-logo{position:absolute;top:40px;left:40px;z-index:2}.brand-company-logo img.logo-light{display:block}.brand-company-logo img.logo-dark,.dark .brand-company-logo img.logo-light{display:none}.dark .brand-company-logo img.logo-dark{display:block}.brand-company-logo img{height:24px;width:auto;opacity:.85}.brand-content{position:relative;z-index:1;width:100%}.brand-text{margin-top:120px;margin-bottom:64px}.brand-title{font-size:44px;font-weight:700;color:#1e293b;line-height:1.25;margin:0 0 24px;letter-spacing:-1px}.dark .brand-title{color:#fff}.brand-desc{font-size:17px;color:#1e293b99;line-height:1.8;margin:0;font-weight:400}.dark .brand-desc{color:#ffffff80}.brand-features{display:none}.brand-mockup{position:relative;margin-top:-20px;width:100%;margin-left:-220px}.brand-mockup img{width:140%;max-width:none;height:auto;object-fit:contain;filter:drop-shadow(0 60px 100px rgba(0,0,0,.35)) drop-shadow(0 25px 50px rgba(0,0,0,.25));transition:filter .3s ease}.brand-mockup img.mockup-light{display:block}.brand-mockup img.mockup-dark,.dark .brand-mockup img.mockup-light{display:none}.dark .brand-mockup img.mockup-dark{display:block}.dark .brand-mockup img{filter:drop-shadow(0 60px 100px rgba(0,0,0,.8)) drop-shadow(0 25px 50px rgba(0,0,0,.5))}.brand-footer{position:absolute;bottom:40px;left:80px;z-index:1}.brand-footer p{font-size:13px;color:#1e293b66;margin:0;font-weight:400}.dark .brand-footer p{color:#ffffff4d}.login-form-section{flex:1;display:flex;align-items:center;justify-content:center;padding:60px;background:var(--bg-primary);position:relative}.login-form-section:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(ellipse at 0% 50%,rgba(59,130,246,.03) 0%,transparent 50%);pointer-events:none}.login-form-wrapper{width:100%;max-width:400px;position:relative;z-index:1}.login-header{margin-bottom:40px;text-align:center}.login-logo{margin-bottom:20px}.login-subtitle{font-size:15px;color:var(--text-secondary);margin:0;font-weight:400}.login-logo .platform-logo{display:block;margin:0 auto}.login-logo .platform-logo.logo-light{display:block}.login-logo .platform-logo.logo-dark,.dark .login-logo .platform-logo.logo-light{display:none}.dark .login-logo .platform-logo.logo-dark{display:block}.login-form{margin-bottom:32px}.form-group{margin-bottom:24px}.form-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:10px}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:18px;color:var(--text-muted);pointer-events:none;z-index:1}.login-input{width:100%;padding:16px 52px;border:1.5px solid var(--border-primary);border-radius:14px;font-size:15px;transition:all .25s ease;background:var(--bg-secondary);box-sizing:border-box;color:var(--text-primary)}.login-input:focus{outline:none;border-color:var(--primary-color);background:var(--bg-card);box-shadow:0 0 0 4px #3b82f61a}.login-input:hover:not(:focus){border-color:var(--border-secondary)}.login-input::placeholder{color:var(--text-muted);font-weight:400}.password-toggle{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:8px;border-radius:10px;color:var(--text-muted);transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:1}.password-toggle:hover{color:var(--primary-color);background:var(--bg-tertiary)}.caps-lock-warning{display:flex;align-items:center;gap:8px;margin-top:12px;padding:12px 16px;background:var(--caps-warning-bg);border:1px solid var(--caps-warning-border);border-radius:10px;font-size:13px;color:var(--caps-warning-text)}.login-error{display:flex;align-items:center;gap:12px;background:var(--error-bg);color:var(--error-text);padding:16px 18px;border-radius:14px;font-size:14px;margin-bottom:24px;border:1px solid var(--error-border)}.login-button{width:100%;padding:18px 28px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px;position:relative;overflow:hidden}.login-button:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #3b82f666}.login-button:active:not(:disabled){transform:translateY(0);box-shadow:0 6px 20px #3b82f64d}.login-button:disabled{opacity:.7;cursor:not-allowed}.button-spinner{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.login-help{text-align:center;padding-top:28px;border-top:1px solid var(--border-primary)}.login-help p{font-size:14px;color:var(--text-secondary);margin:0}.login-help a{color:var(--primary-color);text-decoration:none;font-weight:500;transition:color .2s ease}.login-help a:hover{color:#2563eb}@media (max-width: 1200px){.login-brand{padding:48px 60px}.brand-company-logo{left:60px}.brand-title{font-size:38px}.brand-footer{left:60px;bottom:32px}.login-form-section{padding:48px}}@media (max-width: 900px){.login-page{flex-direction:column}.login-brand{flex:none;min-height:auto;padding:48px 32px;text-align:center}.brand-company-logo{position:static;margin-bottom:24px}.brand-content{max-width:100%}.brand-text{margin-bottom:0}.brand-title{font-size:28px}.brand-desc{font-size:15px}.brand-features,.brand-mockup,.brand-footer{display:none}.login-form-section{flex:1;padding:48px 24px}}@media (max-width: 480px){.login-brand{padding:32px 24px}.brand-logo{margin-bottom:24px}.brand-title{font-size:24px}.brand-desc{font-size:14px}.login-form-section{padding:32px 20px}.login-title{font-size:26px}.login-input{padding:14px 48px;font-size:15px}.login-button{padding:16px 24px;font-size:15px}}.dark .login-form-section{background:var(--bg-primary)}.dark .login-form-section:before{background:radial-gradient(ellipse at 0% 50%,rgba(59,130,246,.05) 0%,transparent 50%)}.dark .login-input{background:var(--bg-secondary);border-color:var(--border-primary);color:var(--text-primary)}.dark .login-input:focus{border-color:var(--primary-color);background:var(--bg-card);box-shadow:0 0 0 4px #3b82f626}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:root{--sensor-mgmt-status-normal-bg: color-mix(in srgb, var(--color-normal) 10%, transparent);--sensor-mgmt-status-normal-color: var(--color-normal);--sensor-mgmt-status-normal-border: color-mix(in srgb, var(--color-normal) 20%, transparent);--sensor-mgmt-status-caution-bg: color-mix(in srgb, var(--color-caution) 10%, transparent);--sensor-mgmt-status-caution-color: var(--color-caution);--sensor-mgmt-status-caution-border: color-mix(in srgb, var(--color-caution) 20%, transparent);--sensor-mgmt-status-warning-bg: color-mix(in srgb, var(--color-warning) 10%, transparent);--sensor-mgmt-status-warning-color: var(--color-warning);--sensor-mgmt-status-warning-border: color-mix(in srgb, var(--color-warning) 20%, transparent);--sensor-mgmt-status-danger-bg: color-mix(in srgb, var(--color-danger) 10%, transparent);--sensor-mgmt-status-danger-color: var(--color-danger);--sensor-mgmt-status-danger-border: color-mix(in srgb, var(--color-danger) 20%, transparent);--sensor-mgmt-status-critical-bg: color-mix(in srgb, var(--color-purple-default) 10%, transparent);--sensor-mgmt-status-critical-color: var(--color-purple-default);--sensor-mgmt-status-critical-border: color-mix(in srgb, var(--color-purple-default) 20%, transparent);--sensor-mgmt-status-unknown-bg: color-mix(in srgb, var(--color-unknown) 10%, transparent);--sensor-mgmt-status-unknown-color: var(--color-unknown);--sensor-mgmt-status-unknown-border: color-mix(in srgb, var(--color-unknown) 20%, transparent)}.dark{--sensor-mgmt-status-normal-bg: color-mix(in srgb, var(--color-normal) 10%, transparent);--sensor-mgmt-status-normal-color: var(--color-normal);--sensor-mgmt-status-normal-border: color-mix(in srgb, var(--color-normal) 20%, transparent);--sensor-mgmt-status-caution-bg: color-mix(in srgb, var(--color-caution) 10%, transparent);--sensor-mgmt-status-caution-color: var(--color-caution);--sensor-mgmt-status-caution-border: color-mix(in srgb, var(--color-caution) 20%, transparent);--sensor-mgmt-status-warning-bg: color-mix(in srgb, var(--color-warning) 10%, transparent);--sensor-mgmt-status-warning-color: var(--color-warning);--sensor-mgmt-status-warning-border: color-mix(in srgb, var(--color-warning) 20%, transparent);--sensor-mgmt-status-danger-bg: color-mix(in srgb, var(--color-danger) 10%, transparent);--sensor-mgmt-status-danger-color: var(--color-danger);--sensor-mgmt-status-danger-border: color-mix(in srgb, var(--color-danger) 20%, transparent);--sensor-mgmt-status-critical-bg: color-mix(in srgb, var(--color-purple-default) 10%, transparent);--sensor-mgmt-status-critical-color: var(--color-purple-default);--sensor-mgmt-status-critical-border: color-mix(in srgb, var(--color-purple-default) 20%, transparent);--sensor-mgmt-status-unknown-bg: color-mix(in srgb, var(--color-unknown) 10%, transparent);--sensor-mgmt-status-unknown-color: var(--color-unknown);--sensor-mgmt-status-unknown-border: color-mix(in srgb, var(--color-unknown) 20%, transparent)}.sensor-mgmt-status-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.025em;border:1px solid;transition:all .15s ease}.sensor-mgmt-status-badge.normal{background:var(--sensor-mgmt-status-normal-bg);color:var(--sensor-mgmt-status-normal-color);border-color:var(--sensor-mgmt-status-normal-border)}.sensor-mgmt-status-badge.caution{background:var(--sensor-mgmt-status-caution-bg);color:var(--sensor-mgmt-status-caution-color);border-color:var(--sensor-mgmt-status-caution-border)}.sensor-mgmt-status-badge.warning{background:var(--sensor-mgmt-status-warning-bg);color:var(--sensor-mgmt-status-warning-color);border-color:var(--sensor-mgmt-status-warning-border)}.sensor-mgmt-status-badge.danger{background:var(--sensor-mgmt-status-danger-bg);color:var(--sensor-mgmt-status-danger-color);border-color:var(--sensor-mgmt-status-danger-border)}.sensor-mgmt-status-badge.critical{background:var(--sensor-mgmt-status-critical-bg);color:var(--sensor-mgmt-status-critical-color);border-color:var(--sensor-mgmt-status-critical-border)}.sensor-mgmt-status-badge.unknown{background:var(--sensor-mgmt-status-unknown-bg);color:var(--sensor-mgmt-status-unknown-color);border-color:var(--sensor-mgmt-status-unknown-border)}.mgmt-content{padding:var(--spacing-lg)}.sensor-mgmt-site-count{font-size:16px;color:var(--text-primary);font-weight:600;margin-bottom:var(--spacing-md)}.add-site-btn{background:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:4px}.add-site-btn:hover{background:#2563eb}.filter-controls{display:flex;align-items:center;gap:var(--spacing-md)}.toggle-switch{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-switch input[type=checkbox]{display:none}.toggle-slider{position:relative;width:44px;height:24px;background:#ccc;border-radius:12px;transition:background .3s}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s}.toggle-switch input[type=checkbox]:checked+.toggle-slider{background:#4caf50}.toggle-switch input[type=checkbox]:checked+.toggle-slider:before{transform:translate(20px)}.toggle-label{font-size:14px;color:var(--text-primary);font-weight:500}.sensor-mgmt-project-name-container{display:flex;align-items:center;gap:8px}.sensor-mgmt-project-type-tag{background:var(--bg-tertiary);color:var(--text-secondary);padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.sensor-mgmt-project-name{font-weight:500;color:var(--text-primary)}.sensor-mgmt-table{background:var(--bg-primary);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-color)}.sensor-mgmt-table table{width:100%;border-collapse:collapse;table-layout:auto}.sensor-mgmt-table th{padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);text-align:center;font-weight:600;color:var(--text-primary);font-size:14px;white-space:nowrap}.sensor-mgmt-table td{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);font-size:14px;color:var(--text-primary);vertical-align:middle;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sensor-mgmt-table td:last-child{overflow:visible;text-overflow:clip}.sensor-detail-btn{display:inline-block;margin:0 auto;padding:6px 12px;font-size:12px;min-width:auto}.sensor-mgmt-expandable-cell{display:flex;align-items:center;gap:8px}.sensor-mgmt-expand-icon{color:#6b7280;width:16px;height:16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;border-radius:4px;background:transparent;padding:2px}.sensor-mgmt-expand-icon:hover{background:#eff6ff;transform:scale(1.1)}.sensor-mgmt-expand-icon img{width:100%;height:100%;object-fit:contain;filter:brightness(0) saturate(0) invert(.6);transition:filter .2s ease}.sensor-mgmt-expand-icon:hover img{filter:brightness(0) saturate(0) invert(.4)}.sensor-mgmt-project-name{color:var(--text-primary);font-weight:500}.sensor-mgmt-status{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:12px;font-weight:600;letter-spacing:.025em}.sensor-mgmt-status.normal{background:var(--sensor-mgmt-status-normal-bg);color:var(--sensor-mgmt-status-normal-color);border:1px solid var(--sensor-mgmt-status-normal-border)}.sensor-mgmt-status.caution{background:var(--sensor-mgmt-status-caution-bg);color:var(--sensor-mgmt-status-caution-color);border:1px solid var(--sensor-mgmt-status-caution-border)}.sensor-mgmt-status.warning{background:var(--sensor-mgmt-status-warning-bg);color:var(--sensor-mgmt-status-warning-color);border:1px solid var(--sensor-mgmt-status-warning-border)}.sensor-mgmt-status.danger{background:var(--sensor-mgmt-status-danger-bg);color:var(--sensor-mgmt-status-danger-color);border:1px solid var(--sensor-mgmt-status-danger-border)}.sensor-mgmt-status.critical{background:var(--sensor-mgmt-status-critical-bg);color:var(--sensor-mgmt-status-critical-color);border:1px solid var(--sensor-mgmt-status-critical-border)}.sensor-mgmt-status.unknown{background:var(--sensor-mgmt-status-unknown-bg);color:var(--sensor-mgmt-status-unknown-color);border:1px solid var(--sensor-mgmt-status-unknown-border)}.sensor-mgmt-battery{display:flex;align-items:center;gap:8px}.sensor-mgmt-battery-icon{width:50px;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;position:relative}.sensor-mgmt-battery-level{height:100%;border-radius:4px;transition:width .3s ease}.sensor-mgmt-site-detail-row{background:var(--bg-secondary)}.sensor-mgmt-site-detail-content{padding:24px}.sensor-mgmt-site-common-info{background:var(--bg-card);border-radius:8px;padding:12px;margin:12px 20px;border:1px solid var(--border-primary)}.sensor-mgmt-site-common-info h4{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--text-primary);letter-spacing:-.025em}.sensor-mgmt-common-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px}.sensor-mgmt-site-info-item{background:var(--bg-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;padding:8px 12px;border:1px solid var(--border-primary);transition:all .3s ease;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.sensor-mgmt-site-info-item:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#3b82f6,#8b5cf6);opacity:0;transition:opacity .3s ease}.sensor-mgmt-site-info-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-focus)}.sensor-mgmt-site-info-item:hover:before{opacity:1}.sensor-mgmt-site-info-item .info-text{color:var(--text-primary);font-weight:600;font-size:13px;letter-spacing:-.025em;line-height:1.3;width:100%}.sensor-mgmt-info-item{background:var(--bg-secondary);border-radius:6px;padding:8px 10px;border:none;transition:all .15s ease}.sensor-mgmt-info-item:hover{background:var(--bg-tertiary)}.sensor-mgmt-info-item .info-text{display:flex;align-items:center;justify-content:space-between;width:100%}.sensor-mgmt-info-item .info-label{color:var(--text-primary);font-weight:700;font-size:12px;letter-spacing:-.025em;min-width:fit-content}.sensor-mgmt-info-item .info-value{color:var(--text-primary);font-weight:500;font-size:12px;letter-spacing:-.025em}.sensor-mgmt-individual-sensors{background:var(--bg-card);border-radius:8px;padding:12px;margin:12px 20px;border:1px solid var(--border-primary)}.sensor-mgmt-sensors-header{display:grid;grid-template-columns:2fr 2fr 1fr 2fr 1fr;gap:12px;padding:8px 12px;background:var(--bg-secondary);border-radius:6px;font-weight:600;font-size:12px;color:var(--text-primary);margin-bottom:8px;border:1px solid var(--border-primary);letter-spacing:-.025em;text-align:center}.sensor-mgmt-sensors-list{display:flex;flex-direction:column;gap:6px}.sensor-mgmt-sensor-item{display:grid;grid-template-columns:2fr 2fr 1fr 2fr 1fr;gap:12px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:6px;font-size:12px;align-items:center;justify-items:center;transition:all .15s ease;text-align:center}.sensor-mgmt-sensor-item:hover{background:var(--bg-secondary);border-color:var(--border-secondary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.sensor-mgmt-sensor-status{font-weight:600;padding:6px 12px;border-radius:6px;font-size:12px;letter-spacing:.025em}.sensor-mgmt-sensor-status.danger{background:var(--sensor-mgmt-status-danger-bg);color:var(--sensor-mgmt-status-danger-color);border:1px solid var(--sensor-mgmt-status-danger-border)}.sensor-mgmt-sensor-status.critical{background:var(--sensor-mgmt-status-critical-bg);color:var(--sensor-mgmt-status-critical-color);border:1px solid var(--sensor-mgmt-status-critical-border)}.sensor-mgmt-sensor-status.warning{background:var(--sensor-mgmt-status-warning-bg);color:var(--sensor-mgmt-status-warning-color);border:1px solid var(--sensor-mgmt-status-warning-border)}.sensor-mgmt-sensor-status.caution{background:var(--sensor-mgmt-status-caution-bg);color:var(--sensor-mgmt-status-caution-color);border:1px solid var(--sensor-mgmt-status-caution-border)}.sensor-mgmt-sensor-status.normal{background:var(--sensor-mgmt-status-normal-bg);color:var(--sensor-mgmt-status-normal-color);border:1px solid var(--sensor-mgmt-status-normal-border)}.sensor-mgmt-sensor-status.unknown{background:var(--sensor-mgmt-status-unknown-bg);color:var(--sensor-mgmt-status-unknown-color);border:1px solid var(--sensor-mgmt-status-unknown-border)}.sensor-mgmt-loading,.sensor-mgmt-empty-state{text-align:center;padding:40px;color:#6b7280;font-size:16px}.sensor-mgmt-error-message{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:16px;border:1px solid #fecaca;font-size:14px}.toggle-filter{display:flex;align-items:center;gap:8px}.toggle-filter .toggle-switch-label,.toggle-filter .heatmap-toggle-switch .toggle-label{font-size:14px;font-weight:500;color:var(--text-secondary)}.toggle-filter .heatmap-toggle-switch .toggle-switch{background:var(--toggle-off-bg)}.toggle-filter .heatmap-toggle-switch .toggle-switch:hover:not(.disabled){background:var(--toggle-off-hover)}.toggle-filter .heatmap-toggle-switch .toggle-switch.active{background:var(--toggle-on-bg)}.toggle-filter .heatmap-toggle-switch .toggle-switch.active:hover:not(.disabled){background:var(--toggle-on-hover)}.toggle-filter .heatmap-toggle-switch .toggle-switch.with-text{font-size:8px}.toggle-filter .heatmap-toggle-switch .toggle-text{font-size:8px;font-weight:600}@media (max-width: 768px){.mgmt-content{padding:16px}.sensor-mgmt-table th,.sensor-mgmt-table td{padding:12px 16px;font-size:13px}.sensor-mgmt-site-common-info{padding:4px 8px;margin-bottom:6px}.sensor-mgmt-site-common-info h4{display:none}.sensor-mgmt-common-info-grid{display:flex;flex-wrap:wrap;gap:4px;font-size:11px}.sensor-mgmt-site-info-item{padding:2px 6px;border-radius:4px;background:var(--bg-tertiary);flex:0 0 auto;margin:1px}.sensor-mgmt-site-info-item .info-text{font-size:10px;line-height:1.2;white-space:nowrap}.sensor-mgmt-info-item{padding:2px 6px;border-radius:4px;background:var(--bg-tertiary);flex:0 0 auto;margin:1px 5px}.sensor-mgmt-info-item .info-label,.sensor-mgmt-info-item .info-value{font-size:10px;line-height:1.2;display:inline}.sensor-mgmt-info-item .info-label{font-weight:600;margin-right:3px}.sensor-mgmt-info-item .info-label:after{content:":"}.sensor-mgmt-individual-sensors{padding:8px}.sensor-mgmt-sensors-header,.sensor-mgmt-sensor-item{grid-template-columns:1fr 1fr 1fr 1fr 1fr;gap:6px;padding:8px 12px;font-size:12px}}@media (max-width: 480px){.sensor-mgmt-site-common-info{padding:4px 8px;margin-bottom:4px;overflow-x:auto;box-sizing:border-box}.sensor-mgmt-site-common-info h4{display:none}.sensor-mgmt-common-info-grid{display:flex;flex-wrap:nowrap;gap:6px;font-size:10px;min-width:600px}.sensor-mgmt-site-info-item{padding:3px 6px;min-width:0;border-radius:4px;flex:0 0 auto;background:var(--bg-tertiary);margin:2px}.sensor-mgmt-site-info-item .info-text{font-size:9px;line-height:1.2;white-space:nowrap}.sensor-mgmt-info-item{padding:3px 6px;min-width:0;border-radius:4px;flex:0 0 auto;background:var(--bg-tertiary);margin:2px}.sensor-mgmt-info-item .info-label,.sensor-mgmt-info-item .info-value{font-size:9px;line-height:1.2;display:inline}.sensor-mgmt-info-item .info-label{font-weight:600;margin-right:4px}.sensor-mgmt-info-item .info-label:after{content:":"}.sensor-mgmt-individual-sensors{padding:4px;overflow-x:auto;box-sizing:border-box}.sensor-mgmt-sensors-header,.sensor-mgmt-sensor-item{gap:4px;padding:4px 8px;font-size:10px;grid-template-columns:1.5fr 1fr .8fr 1fr .8fr;min-width:400px;border-radius:4px}.sensor-mgmt-sensors-header{font-weight:700;background:var(--bg-tertiary)}.sensor-mgmt-sensors-header>*,.sensor-mgmt-sensor-item>*{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;line-height:1.1}.sensor-mgmt-sensor-status{padding:1px 3px!important;font-size:7px!important;border-radius:3px;font-weight:600}}.sensor-type-groups{margin-top:var(--spacing-md)}.sensor-type-group{margin-bottom:var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.sensor-type-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--bg-secondary);cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid var(--border-color)}.sensor-type-header:hover{background:var(--bg-tertiary)}.sensor-type-info{display:flex;align-items:center;gap:var(--spacing-sm)}.status-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0}.sensor-type-name{font-weight:600;color:var(--text-primary);font-size:14px}.sensor-count{color:var(--text-secondary);font-size:13px}.toggle-icon{color:var(--text-secondary);font-size:12px;transition:transform .2s ease}.sensor-type-content{padding:var(--spacing-md);background:var(--bg-primary)}.detail-sensors-table{display:flex;flex-direction:column;gap:var(--spacing-xs)}.detail-sensor-header{display:grid;grid-template-columns:1fr 2fr 1fr 1fr 1fr;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-sm);font-weight:600;font-size:12px;color:var(--text-primary);text-align:center}.detail-sensor-row{display:grid;grid-template-columns:1fr 2fr 1fr 1fr 1fr;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:12px;align-items:center;text-align:center;transition:all .2s ease}.detail-sensor-row:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.detail-sensor-row .status-badge{justify-self:center}@media (max-width: 768px){.detail-sensor-header,.detail-sensor-row{grid-template-columns:1fr 1.5fr .8fr 1fr .8fr;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);font-size:11px}.sensor-type-header,.sensor-type-content{padding:var(--spacing-sm)}}.site-management-tabs{display:flex;gap:2px;margin-bottom:24px;background-color:var(--bg-secondary);border-radius:var(--border-radius-lg);padding:4px}.tab-button{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;background-color:transparent;color:var(--text-secondary);border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:var(--font-weight-medium);transition:all .2s ease;flex:1;justify-content:center}.tab-button:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.tab-button.active{background-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.tab-button.active:hover{background-color:var(--primary-dark)}.site-management-content{min-height:400px}.sensor-hardware-management{display:flex;flex-direction:column;gap:20px}.hardware-submenu{display:flex;gap:1px;background-color:var(--bg-secondary);border-radius:var(--border-radius);padding:3px}.submenu-button{flex:1;padding:10px 16px;border:none;background-color:transparent;color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;font-size:13px;font-weight:var(--font-weight-medium);transition:all .2s ease;text-align:center}.submenu-button:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.submenu-button.active{background-color:var(--bg-primary);color:var(--text-primary);box-shadow:var(--shadow-sm)}.hardware-content{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:32px;min-height:300px;display:flex;align-items:center;justify-content:center}.hardware-info-management,.maintenance-management,.status-monitoring{text-align:center;color:var(--text-secondary)}.hardware-info-management h3,.maintenance-management h3,.status-monitoring h3{color:var(--text-primary);margin-bottom:16px;font-size:18px}.hardware-info-management p,.maintenance-management p,.status-monitoring p{margin-bottom:8px;line-height:1.5}@media (max-width: 768px){.site-management-tabs{flex-direction:column;gap:1px}.tab-button{justify-content:flex-start}.hardware-submenu{flex-direction:column;gap:1px}.hardware-content{padding:20px}}[data-theme=dark] .site-management-tabs,[data-theme=dark] .hardware-submenu{background-color:var(--bg-secondary)}[data-theme=dark] .hardware-content{background-color:var(--bg-primary);border-color:var(--border-color)}.sensor-detail-container{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%;min-height:0}.sensor-detail-container.no-header{height:calc(100vh - 60px);min-height:400px}.sub-view-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:8px}.sub-view-header .header-title{display:flex;align-items:center;gap:12px;flex:1}.sub-view-header .header-title h3{margin:0;font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}.sub-view-header .header-icon{color:var(--primary-color);margin-right:8px}.sub-view-header .header-actions{display:flex;align-items:center;gap:8px}.sub-view-back-btn{background:none!important;border:none!important;padding:8px!important;border-radius:4px;cursor:pointer;color:var(--text-primary);transition:background .2s;z-index:9999!important;position:relative}.sub-view-back-btn:hover{background:var(--bg-hover)!important}.sub-view-close-btn{background:none!important;border:none!important;padding:8px!important;border-radius:4px;cursor:pointer;color:var(--text-primary);transition:background .2s;z-index:10!important;position:relative}.sub-view-close-btn:hover{background:var(--bg-hover)!important}.sensor-detail-tabs .tabs-content{flex:1;overflow:hidden;padding:0;height:calc(100vh - 180px)}.site-summary-card{display:flex;justify-content:space-between;align-items:flex-start;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin-bottom:16px}.site-info h3{margin:0 0 8px;font-size:var(--font-size-xl);color:var(--text-primary);font-weight:600}.site-address{margin:0 0 12px;color:var(--text-secondary);font-size:var(--font-size-base);line-height:1.5}.site-stats{display:flex;align-items:center;gap:8px;font-size:var(--font-size-sm);color:var(--text-muted)}.stat-item{display:inline-flex;align-items:center}.stat-separator{color:var(--border-color);font-weight:700}.info-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-bottom:16px}.info-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:0;overflow:hidden}.info-card-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.info-card-header .card-icon{color:var(--primary-color);flex-shrink:0}.info-card-header h4{margin:0;font-size:var(--font-size-base);font-weight:600;color:var(--text-primary)}.info-card-content{padding:16px}.info-list{display:flex;flex-direction:column;gap:12px}.info-list-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-light)}.info-list-item:last-child{border-bottom:none}.info-list-item label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:500}.info-list-item span{font-size:var(--font-size-sm);color:var(--text-primary);text-align:right}.section-icon{color:var(--primary-color)}.sensor-total-count{margin-left:auto;padding:4px 12px;background:var(--primary-light);color:var(--primary-color);border-radius:16px;font-size:var(--font-size-sm);font-weight:600}.site-status{display:flex;align-items:center}.status-indicator{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;font-size:var(--font-size-sm)}.status-indicator.sensor-detail-comm-normal{background:var(--success-light);color:var(--success-color)}.status-indicator.sensor-detail-comm-warning{background:var(--warning-light);color:var(--warning-color)}.status-indicator.sensor-detail-comm-emergency{background:var(--error-light);color:var(--error-color)}.no-data-message{text-align:center;padding:20px;color:var(--text-muted);font-size:var(--font-size-sm)}.expand-icon{transition:transform .3s ease;color:var(--text-secondary)}.expand-icon.expanded{transform:rotate(180deg)}@media (max-width: 768px){.site-summary-card{flex-direction:column;gap:16px;align-items:stretch}.management-actions-grid,.info-cards-grid{grid-template-columns:1fr}.management-action-card{padding:16px}.action-icon{width:40px;height:40px}.info-card-header{padding:12px 16px}.info-card-content{padding:16px}}.address-input-container{display:flex;gap:8px;align-items:center}.header-actions-container{display:flex;gap:12px;align-items:center}.btn-small{font-size:var(--font-size-sm)!important;padding:4px 8px!important}.icon-small{width:16px!important;height:16px!important}.info-item.full-width{grid-column:1 / -1}.site-name{display:flex;align-items:center;gap:4px;font-size:var(--font-size-base)}.comm-timestamp{font-size:var(--font-size-sm);color:var(--text-muted);font-style:italic;margin-top:2px}.sensor-type-group{margin-bottom:var(--spacing-md);border:none;border-radius:var(--radius-md);overflow:hidden}.sensor-type-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--border-radius-md);cursor:pointer;border:none}.sensor-type-header-left{display:flex;align-items:center;gap:var(--spacing-sm)}.sensor-type-status-dot{width:var(--spacing-md);height:var(--spacing-md);border-radius:50%;border:none;position:relative;animation:pulse-glow 2s ease-in-out infinite;box-shadow:0 0 8px #4a7cff4d,0 0 16px #4a7cff1a,inset 0 0 4px #ffffff4d}.sensor-type-status-dot.normal{box-shadow:0 0 8px #4caf5066,0 0 16px #4caf5033,inset 0 0 4px #ffffff4d}.sensor-type-status-dot.caution{box-shadow:0 0 8px #ffd54f66,0 0 16px #ffd54f33,inset 0 0 4px #ffffff4d}.sensor-type-status-dot.warning{box-shadow:0 0 8px #ffc10766,0 0 16px #ffc10733,inset 0 0 4px #ffffff4d}.sensor-type-status-dot.danger{box-shadow:0 0 8px #f4433666,0 0 16px #f4433633,inset 0 0 4px #ffffff4d;animation:danger-pulse 1.5s ease-in-out infinite}@keyframes pulse-glow{0%,to{filter:brightness(1)}50%{filter:brightness(1.1)}}@keyframes danger-pulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.2)}}.sensor-type-name{font-weight:700;color:var(--text-primary)}.sensor-count{color:var(--text-secondary);font-size:var(--font-size-sm)}.sensor-type-header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.max-risk-label{font-size:var(--text-sm);color:var(--text-secondary)}.sensor-type-content{margin-top:var(--spacing-sm)}.sensor-content-padding{padding:var(--spacing-md);background-color:var(--bg-panel)}.sensor-item{margin-bottom:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-panel);border-radius:var(--border-radius-sm);border:1px solid var(--border-primary)}.sensor-meta{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--bg-secondary);border-radius:var(--border-radius-xs)}.text-center{text-align:center}.text-small{font-size:var(--font-size-sm)}.text-medium{font-size:var(--font-size-base)}.flex-header{display:flex;gap:8px;align-items:center}.flex-column{display:flex;flex-direction:column;gap:4px}.section-subtitle{margin-bottom:var(--spacing-sm);color:var(--text-primary);font-size:var(--font-size-md)}.header-button-style{font-size:var(--font-size-sm);padding:4px 8px}.form-section{border-top:1px solid var(--form-section-border);padding-top:12px;margin-top:12px}.site-info-panel{background:var(--bg-panel);border-radius:12px;box-shadow:0 4px 20px #00000014,0 2px 8px #0000000a,inset 0 1px #ffffff1a,0 0 20px #3b82f626,0 0 40px #3b82f614;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.site-info-panel .info-section{padding:16px;background-color:var(--bg-secondary)}.site-info-panel .info-section:last-child{margin-bottom:0}.site-info-panel .section-title{font-size:var(--font-size-md);font-weight:700;color:var(--text-primary);margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--btn-primary-bg);display:flex;align-items:center}.site-info-panel .section-title:before{content:"";width:4px;height:16px;background-color:var(--btn-primary-bg);margin-right:8px;border-radius:2px}.main-layout{display:grid;grid-template-columns:1.22fr 1fr;gap:24px;width:100%;max-width:100%;grid-template-rows:1fr}.left-section{display:flex;flex-direction:column;gap:16px}.right-section{display:flex;flex-direction:column}.top-section{display:grid;grid-template-columns:1fr 1fr;gap:16px;height:100%}.chart-section{height:100%}.section-card{background:var(--bg-panel);border-radius:8px;padding:16px;width:100%;max-width:100%;box-sizing:border-box}.chart-info.section-card{height:100%;overflow:hidden}.chart-info.section-card{background:var(--bg-panel)!important;border-radius:12px;box-shadow:0 4px 20px #00000014,0 2px 8px #0000000a,inset 0 1px #ffffff1a,0 0 20px #3b82f626,0 0 40px #3b82f614;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dark .section-card{background:var(--bg-panel)}.section-title{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid var(--border-primary)}.section-card h2{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid var(--border-primary)}.chart-info h2{margin:0!important;padding-bottom:0!important;border-bottom:none!important;color:var(--text-primary)!important}.info-section{padding:12px;background:var(--bg-secondary);border-radius:6px}.info-section:last-child{margin-bottom:0}.section-title{font-size:var(--font-size-md);font-weight:600;color:var(--text-secondary);margin:0 0 8px;padding-bottom:4px;border-bottom:1px solid var(--border-primary)}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px}.info-item{display:flex;flex-direction:column;gap:2px;padding:4px 0}.info-item label{color:var(--text-secondary);font-weight:600;font-size:var(--font-size-sm)}.info-value{color:var(--text-primary);font-weight:500;font-size:var(--font-size-md);padding:2px 0;word-break:break-all}.info-value.coordinates{font-family:Courier New,monospace;background:var(--bg-tertiary);padding:3px 6px;border-radius:3px;font-size:var(--font-size-sm)}.info-value.business-name{display:flex;flex-direction:row;gap:8px;align-items:center}.site-info-panel .business-type{font-family:Courier New,monospace;background:var(--bg-tertiary);padding:2px 4px;border-radius:3px;font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:400;display:inline-block}.business-name-text{font-size:var(--font-size-md);color:var(--text-primary);font-weight:500}.coordinate-item{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:500;line-height:1.3}.info-value.site-position,.info-value.device-id,.info-value.serial,.info-value.modem,.info-value.mac,.info-value.device-company,.info-value.device-name,.info-value.firmware,.info-value.update-date,.info-value.install-date,.info-value.drill-depth{font-family:Courier New,monospace;background:var(--bg-tertiary);padding:3px 6px;border-radius:3px;font-size:var(--font-size-sm)}.info-value.status.completed{color:var(--color-normal);font-weight:600}.info-value.status.pending{color:var(--color-warning);font-weight:600}.info-value.status.normal{color:var(--color-normal);font-weight:600}.info-value.status.warning{color:var(--color-warning);font-weight:600}.info-value.date{color:var(--text-secondary);font-size:var(--font-size-sm)}.info-value.battery.good{color:var(--color-normal);font-weight:600}.info-value.battery.warning{color:var(--color-warning);font-weight:600}.info-value.battery.low{color:var(--color-danger);font-weight:600}.table-header{display:grid;grid-template-columns:1.5fr 1fr 2fr 1fr;padding:8px 0;font-weight:600;color:var(--text-secondary);margin-bottom:8px;border-bottom:1px solid var(--border-primary);font-size:var(--font-size-md)}.table-header span{text-align:center}@media (max-width: 991.98px){.table-body{max-height:none!important;overflow-y:visible!important}}.table-row{display:grid;grid-template-columns:1.5fr 1fr 2fr 1fr;padding:6px 0;align-items:center}.table-row:hover{background:var(--bg-tertiary);border-radius:4px;padding:6px 8px}.table-row span{font-size:var(--font-size-md);color:var(--text-primary);text-align:center;font-weight:500}.table-row span:first-child{font-size:var(--font-size-sm);text-align:left}.no-data{text-align:center;padding:20px;color:var(--text-secondary);font-style:italic}.chart-info{display:flex;flex-direction:column;height:100%}.chart-container{flex:1;overflow-y:auto}@media (max-width: 991.98px){.chart-info,.chart-container{min-height:auto!important;overflow:visible!important}}.chart-container>div[ref]{z-index:1;position:relative}.chart-container svg{z-index:-100!important;position:relative}.chart-container svg *{z-index:-100!important}.chart-controls,.chart-controls *,.chart-controls>div,.chart-controls>div>div,.chart-controls button,.download-menu-container,.download-menu-container *,.download-menu-container button,.chart-section button,.sensor-controls-panel,.sensor-controls-panel *,.sensor-controls-panel button,.sensor-controls-panel .control-icon,.period-chip,.view-btn,.download-button,.custom-date-calendar,.calendar-nav,.sensor-selection-toggle,.sensor-selection-toggle *,.selection-header,.selection-content,.type-chip,.sensor-card,.toggle-button{z-index:100!important;position:relative}.chart-controls{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-size:var(--font-size-md);position:relative;z-index:1000!important}.chart-controls input{padding:4px 8px;border:1px solid var(--border-primary);border-radius:4px;font-size:var(--font-size-sm);background:var(--bg-card);color:var(--text-primary)}.download-menu-container{position:relative;display:inline-block;margin-left:auto;z-index:1000!important}.export-btn{padding:6px 12px;background:var(--btn-success-bg);color:#fff;border:none;border-radius:4px;font-size:var(--font-size-sm);cursor:pointer;display:flex;align-items:center;gap:6px}.export-btn:hover{background:var(--btn-success-hover)}.chart-legend{display:flex;gap:16px;margin-bottom:4px;flex-wrap:wrap;align-items:center}.legend-item{display:flex;align-items:center;gap:8px;font-size:var(--font-size-md);color:var(--text-primary);padding:6px 10px;background:transparent;border:none;border-radius:4px}.legend-item:hover{background:var(--bg-tertiary)}.legend-item input[type=checkbox]{width:16px;height:16px;cursor:pointer;margin:0;border:1px solid var(--border-primary);border-radius:3px;background:var(--bg-card)}.legend-color{width:12px;height:12px;border-radius:2px}.legend-color.sensor-1{background-color:var(--color-danger)}.legend-color.sensor-2{background-color:var(--color-normal)}.legend-color.sensor-3{background-color:var(--btn-primary-bg)}.legend-color.sensor-4{background-color:var(--color-warning)}.loading{text-align:center;padding:40px;color:var(--text-secondary);font-size:var(--font-size-lg)}.error-message{background:color-mix(in srgb,var(--color-danger) 10%,transparent);color:var(--color-danger);padding:12px 16px;border-radius:8px;margin-bottom:16px;border:1px solid color-mix(in srgb,var(--color-danger) 20%,transparent);font-size:var(--font-size-md)}.modal-section-title{margin-bottom:16px;color:var(--form-section-title);border-bottom:2px solid var(--btn-primary-bg);padding-bottom:8px;font-size:var(--font-size-lg);font-weight:600}.modal-section-title-warning{border-bottom-color:var(--color-warning)}.coordinates-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.sensor-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;padding:12px;border:1px solid var(--border-primary);border-radius:4px;background:var(--bg-secondary)}.form-input-disabled{background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed}@media (min-width: 992px) and (max-width: 1199.98px){.main-layout,.top-section{grid-template-columns:1fr;gap:4px}.chart-section,.chart-info{min-height:auto}.overview-tab,.monitoring-tab,.maintenance-tab,.management-tab{height:calc(100vh - 220px);min-height:400px}}@media (min-width: 768px) and (max-width: 991.98px){.main-layout,.top-section{grid-template-columns:1fr;gap:2px}.left-section{order:1}.chart-section{order:2;min-height:auto}.chart-info{min-height:auto}.overview-tab,.monitoring-tab,.maintenance-tab,.management-tab{height:calc(100vh - 200px);min-height:350px}.chart-controls{flex-wrap:wrap}.table-header,.table-row{grid-template-columns:120px 80px 1fr 80px}.info-grid{grid-template-columns:1fr;gap:8px}.info-section{padding:12px}.site-info-panel{padding:16px}}@media (min-width: 576px) and (max-width: 767.98px){.main-layout,.top-section{grid-template-columns:1fr;gap:2px}.left-section{order:1;gap:2px}.chart-section{order:2;min-height:auto}.chart-info{min-height:auto}.overview-tab,.monitoring-tab,.maintenance-tab,.management-tab{height:calc(100vh - 180px);min-height:300px}.site-info-panel h2{font-size:var(--font-size-xl)}.section-title{font-size:var(--font-size-md)}.info-value.coordinates,.info-value.device-id,.info-value.serial,.info-value.modem,.info-value.mac{padding:3px 6px}.chart-controls{flex-wrap:wrap;gap:2px}.table-header,.table-row{grid-template-columns:100px 60px 1fr 60px;font-size:var(--font-sm)}.info-section{padding:var(--spacing-sm)}}@media (max-width: 575.98px){.main-layout,.top-section{grid-template-columns:1fr;gap:1px}.left-section{order:1;gap:1px}.chart-section{order:2;min-height:auto}.chart-info{min-height:auto}.overview-tab,.monitoring-tab,.maintenance-tab,.management-tab{height:calc(100vh - 160px);min-height:250px}.site-info-panel,.sensors-info-panel,.section-card{padding:var(--spacing-xs)}.site-info-panel h2{font-size:var(--font-md)}.section-title{font-size:var(--font-sm)}.info-value.coordinates,.info-value.device-id,.info-value.serial,.info-value.modem,.info-value.mac{padding:2px 4px;font-size:var(--font-size-sm)}.chart-controls{flex-direction:column;gap:1px;align-items:stretch}.table-header,.table-row{grid-template-columns:80px 50px 1fr 50px;font-size:var(--font-size-sm);padding:4px 0}.info-section{padding:var(--spacing-xs)}.info-grid{grid-template-columns:1fr;gap:4px}.btn-functional{min-height:44px;font-size:var(--font-base)}}@media (max-width: 991.98px){.main-layout,.top-section{grid-template-columns:1fr!important}.chart-section,.chart-info{min-height:auto!important}}@media (max-width: 991.98px){.chart-header{flex-direction:column!important;align-items:stretch!important;gap:12px!important}.chart-container div[style*="display: flex"]{flex-wrap:wrap!important;gap:8px!important}.segment-button-group{min-width:100%!important;display:flex!important}.segment-button{flex:1!important;font-size:var(--font-size-sm)!important;padding:8px 4px!important}.download-menu-container{width:100%!important;margin-left:0!important}.chart-container div[style*="marginBottom: '15px'"]{display:none!important}}@media (max-width: 767px){.chart-header{padding:4px 0!important;margin-bottom:8px!important}.chart-container div[style*="fontSize: '20px'"]{font-size:var(--font-size-lg)!important}.segment-button{font-size:var(--font-size-sm)!important;padding:6px 2px!important}.chart-container div[style*="minWidth: '320px'"]{min-width:100%!important}}@media (max-width: 480px){.chart-container{padding:8px!important}.chart-container div[style*="height: 450"]{height:300px!important}.chart-container div[style*="height={200}"]{height:200px!important}.segment-button{font-size:var(--font-size-xs)!important;padding:4px 2px!important;min-height:32px!important}}@media (hover: none) and (pointer: coarse){.btn-functional,.btn-state{min-height:48px;font-size:var(--font-base)}.btn-icon-only{width:48px;height:48px;min-width:48px;min-height:48px;max-width:48px;max-height:48px}.btn-icon-only .icon img{width:24px;height:24px}.chart-controls input{min-height:44px;padding:var(--spacing-sm)}.segment-button{min-height:44px!important;padding:8px 12px!important}}.sensors-info-panel{background:var(--bg-panel);border-radius:12px;box-shadow:0 4px 20px #00000014,0 2px 8px #0000000a,inset 0 1px #ffffff1a,0 0 20px #3b82f626,0 0 40px #3b82f614;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.address-input-flex{flex:1}.sensor-list-container{padding:12px;background-color:var(--bg-secondary)}.sensor-item-card{margin-bottom:12px;padding:12px;background-color:var(--bg-tertiary);border-radius:4px;border:1px solid var(--border-color-light)}.sensor-info-label{font-size:var(--font-size-sm);font-weight:700;color:var(--text-secondary)}.sensor-info-value{font-size:var(--font-size-base)}.hardware-info-title{margin-bottom:var(--spacing-sm);color:var(--text-primary);font-size:var(--font-size-md)}.no-hardware-message{color:var(--text-muted);font-style:italic;text-align:center;padding:20px}.detail-sensor-row-header{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;text-align:center;background-color:var(--bg-tertiary);font-weight:700;font-size:var(--font-size-sm);padding:4px}.detail-sensor-row-data{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;text-align:center;font-size:var(--font-size-base);padding:4px}.detail-header-cell,.detail-cell{text-align:center}.detail-status-badge{font-size:var(--font-size-sm)}.alarm-management{height:calc(100vh - 140px);max-height:calc(100vh - 140px);display:flex;flex-direction:column;gap:0;overflow:hidden;box-sizing:border-box}.spatial-editor-main{display:flex;gap:16px;flex:1;min-height:0}.content-section{padding:20px;height:100%;display:flex;flex-direction:column;overflow:hidden}.type-cards,.group-cards{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:16px;padding-right:8px}.type-cards::-webkit-scrollbar,.group-cards::-webkit-scrollbar{width:6px}.type-cards::-webkit-scrollbar-track,.group-cards::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.type-cards::-webkit-scrollbar-thumb,.group-cards::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.type-cards::-webkit-scrollbar-thumb:hover,.group-cards::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.content-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-color);gap:16px}.content-header h3{margin:0;font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);flex:1}.content-header .content-subtitle{font-size:var(--font-size-sm);font-weight:400;color:var(--text-secondary)}.search-container{display:flex;align-items:center;gap:8px}.search-input-wrapper{position:relative;display:flex;align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:8px 12px;min-width:280px;transition:all .2s ease}.search-input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.1)}.search-icon{color:var(--text-secondary);margin-right:8px;flex-shrink:0}.search-input{flex:1;background:none;border:none!important;outline:none;color:var(--text-primary);font-size:14px;padding:0;box-shadow:none!important}.search-input::placeholder{color:var(--text-secondary)}.search-clear-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);margin-left:4px;transition:all .2s ease}.search-clear-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.toolbar-section{display:flex;flex-direction:column;gap:8px;align-items:stretch}.section-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.stats-cards{display:flex;flex-direction:column;gap:8px}.stat-card.tab-card{cursor:pointer;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-card);padding:16px;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between;text-align:left}.stat-card.tab-card:hover{background:var(--bg-hover);border-color:var(--primary-light);transform:translateY(-1px)}.stat-card.tab-card.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.stat-card.tab-card.active .stat-number{color:#fff}.stat-card.tab-card .stat-content{display:flex;align-items:center;gap:12px}.stat-card.tab-card .stat-icon{opacity:.7;flex-shrink:0}.stat-card.tab-card.active .stat-icon{opacity:1}.stat-card.tab-card .stat-number{font-size:24px;font-weight:700;flex-shrink:0}.stat-card.tab-card .stat-description{font-size:var(--font-size-sm);opacity:.8;font-weight:500}.stat-card.tab-card.active .stat-description{opacity:.9}.sensor-card-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;transition:all .2s ease}.sensor-card-item:hover{background:var(--bg-hover);border-color:var(--primary-light)}.sensor-card-item .sensor-info h4{margin:0;font-size:var(--font-size-md);font-weight:500;color:var(--text-primary)}.sensor-card-item .sensor-info .sensor-type-inline{font-size:var(--font-size-sm);color:var(--primary-color);font-weight:500;margin-left:8px}.btn-icon-only{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.btn-icon-only:hover{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.setting-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;cursor:pointer}.alarm-list{background:var(--bg-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}table{width:100%;border-collapse:collapse}th{padding:var(--spacing-md);text-align:center;font-weight:600;color:var(--text-secondary);font-size:14px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}td{padding:var(--spacing-md);font-size:14px;border-bottom:1px solid var(--border-color);text-align:center}.status{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:13px;width:60px}.status.caution{display:inline-flex;align-items:center;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.025em;border:1px solid;transition:all .15s ease;min-width:60px;white-space:nowrap;justify-content:center;background:color-mix(in srgb,var(--color-caution) 10%,transparent);color:var(--color-caution);border-color:color-mix(in srgb,var(--color-caution) 20%,transparent)}.status.warning{display:inline-flex;align-items:center;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.025em;border:1px solid;transition:all .15s ease;min-width:60px;white-space:nowrap;justify-content:center;background:color-mix(in srgb,var(--color-warning) 10%,transparent);color:var(--color-warning);border-color:color-mix(in srgb,var(--color-warning) 20%,transparent)}.status.normal{display:inline-flex;align-items:center;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.025em;border:1px solid;transition:all .15s ease;min-width:60px;white-space:nowrap;justify-content:center;background:color-mix(in srgb,var(--color-normal) 10%,transparent);color:var(--color-normal);border-color:color-mix(in srgb,var(--color-normal) 20%,transparent)}.status.unknown{display:inline-flex;align-items:center;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.025em;border:1px solid;transition:all .15s ease;min-width:60px;white-space:nowrap;justify-content:center;background:color-mix(in srgb,var(--color-unknown) 10%,transparent);color:var(--color-unknown);border-color:color-mix(in srgb,var(--color-unknown) 20%,transparent)}.level{display:inline-flex;align-items:center;justify-content:center;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:600;min-width:50px;white-space:nowrap}.alarm-management .level.normal,.data-table .level.normal{background:color-mix(in srgb,var(--color-normal) 15%,transparent);color:var(--color-normal);border:1px solid color-mix(in srgb,var(--color-normal) 30%,transparent)}.alarm-management .level.caution,.data-table .level.caution{background:color-mix(in srgb,var(--color-caution) 15%,transparent);color:var(--color-caution);border:1px solid color-mix(in srgb,var(--color-caution) 30%,transparent)}.alarm-management .level.warning,.data-table .level.warning{background:color-mix(in srgb,var(--color-warning) 15%,transparent);color:var(--color-warning);border:1px solid color-mix(in srgb,var(--color-warning) 30%,transparent)}.alarm-management .level.danger,.data-table .level.danger{background:color-mix(in srgb,var(--color-danger) 15%,transparent);color:var(--color-danger);border:1px solid color-mix(in srgb,var(--color-danger) 30%,transparent)}.alarm-management .level.critical,.data-table .level.critical{background:color-mix(in srgb,var(--color-purple-default) 15%,transparent);color:var(--color-purple-default);border:1px solid color-mix(in srgb,var(--color-purple-default) 30%,transparent)}.alarm-management .level.unknown,.data-table .level.unknown{background:color-mix(in srgb,var(--color-unknown) 15%,transparent);color:var(--color-unknown);border:1px solid color-mix(in srgb,var(--color-unknown) 30%,transparent)}.action-buttons{display:flex;justify-content:center;gap:var(--spacing-sm)}.action-buttons .btn-functional{padding:6px 12px;font-size:12px;min-width:auto}.alarm-setting-modal .settings-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.alarm-setting-modal .setting-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.alarm-setting-modal .setting-item label{font-size:14px;font-weight:500;color:var(--text-primary)}.alarm-setting-modal .setting-item input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px}.alarm-setting-modal .settings-info{background:color-mix(in srgb,var(--color-info) 5%,transparent);border:1px solid color-mix(in srgb,var(--color-info) 20%,transparent);border-radius:var(--radius-sm);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.alarm-setting-modal .settings-info p{margin:var(--spacing-xs) 0;font-size:14px;color:var(--text-secondary)}.alarm-setting-modal .settings-info p:first-child{font-weight:500;color:var(--primary-color)}.alarm-setting-modal .setting-item{position:relative}.alarm-setting-modal .setting-item .unit{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-secondary);font-size:14px;margin-top:20px}.alarm-setting-modal .loading-content{padding:var(--spacing-xl);text-align:center}.alarm-setting-modal .setting-item input:disabled{background-color:var(--bg-secondary);color:var(--text-secondary);cursor:not-allowed}.alarm-setting-modal .modal-header{display:flex;align-items:center;justify-content:space-between;position:relative}.alarm-setting-modal .modal-header h2{margin:0;flex:1}.alarm-setting-modal .modal-header .apply-option{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);margin-left:16px;margin-right:30px}.alarm-setting-modal .modal-header .close-btn{position:absolute;top:0;right:0;background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.location-cell{text-align:left;line-height:1.4}.location-cell .main-location{font-size:14px;color:var(--text-primary);margin-bottom:2px}.location-cell .address-location{font-size:12px;color:var(--text-secondary)}.alarm-management-new{display:flex;flex-direction:column;height:100%;min-height:100vh;background:var(--bg-color);color:var(--text-color)}.alarm-management-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color);background:var(--card-bg);position:sticky;top:0;z-index:10}.alarm-management-header .header-title{display:flex;align-items:center;gap:8px}.alarm-management-header .header-title h3{margin:0;font-size:18px;font-weight:600}.alarm-management-header .header-icon{color:var(--primary-color)}.alarm-management-content{flex:1;display:flex;flex-direction:column;padding:24px;gap:24px}.section-tabs{display:flex;gap:8px;background:var(--card-bg);padding:8px;border-radius:8px;border:1px solid var(--border-color);width:fit-content}.tab-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;border-radius:6px;background:transparent;color:var(--text-color-muted);cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500}.tab-btn:hover{background:var(--hover-bg);color:var(--text-color)}.tab-btn.active{background:var(--primary-color);color:#fff}.overview-section{display:flex;flex-direction:column;gap:24px}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-card{background:var(--card-bg);padding:24px;border-radius:12px;border:1px solid var(--border-color);text-align:center;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card)}.stat-number{font-size:32px;font-weight:700;color:var(--primary-color);margin-bottom:8px}.stat-label{font-size:14px;color:var(--text-color-muted)}.overview-info{background:var(--card-bg);padding:24px;border-radius:12px;border:1px solid var(--border-color)}.overview-info h4{margin:0 0 16px;font-size:16px;font-weight:600;color:var(--text-color)}.overview-info ol{margin:0;padding-left:20px}.overview-info li{margin-bottom:8px;color:var(--text-color-muted);line-height:1.5}.overview-info strong{color:var(--text-color);font-weight:600}.group-cards,.type-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.group-card,.type-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:all .2s ease}.group-card:hover,.type-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card)}.group-header,.type-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.group-header h4,.type-header h4{margin:0;font-size:16px;font-weight:600;color:var(--text-color)}.group-info,.type-info{display:flex;flex-direction:column;gap:4px;align-items:flex-end}.sensor-type{background:var(--primary-color-light);color:var(--primary-color);padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.sensor-count{color:var(--text-color-muted);font-size:12px}.current-settings{background:var(--bg-secondary);padding:12px;border-radius:8px;margin-bottom:16px}.settings-label{color:var(--text-color-muted);font-size:12px;margin-bottom:8px;display:block}.threshold-values{display:flex;flex-direction:column;gap:4px}.threshold-values span{font-size:13px;color:var(--text-color);font-family:monospace}.group-actions,.type-actions{display:flex;gap:8px;justify-content:flex-end}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:var(--text-color-muted)}.empty-state p{margin:16px 0 0;font-size:16px}.threshold-form-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.form-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.threshold-form{position:relative;background:var(--card-bg);border-radius:16px;border:1px solid var(--border-color);width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-modal)}.form-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 20px;border-bottom:1px solid var(--border-color)}.form-header h4{margin:0;font-size:18px;font-weight:600;color:var(--text-color)}.form-close-btn{background:none;border:none;color:var(--text-color-muted);cursor:pointer;padding:4px;border-radius:4px;font-size:20px;line-height:1;transition:all .2s ease}.form-close-btn:hover{background:var(--hover-bg);color:var(--text-color)}.form-content{flex:1;padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.threshold-group{display:flex;flex-direction:column;gap:16px}.threshold-group h5{margin:0;font-size:16px;font-weight:600;color:var(--text-color);padding-bottom:8px;border-bottom:1px solid var(--border-color)}.threshold-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{font-size:14px;font-weight:500;color:var(--text-color)}.input-group input,.input-group textarea{padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--input-bg);color:var(--text-color);font-size:14px;transition:all .2s ease}.input-group input:focus,.input-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-light)}.input-group input::placeholder,.input-group textarea::placeholder{color:var(--text-color-muted)}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px 24px;border-top:1px solid var(--border-color)}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1100}.loading-spinner{background:var(--card-bg);padding:24px 32px;border-radius:12px;border:1px solid var(--border-color);color:var(--text-color);font-size:16px;font-weight:500;box-shadow:var(--shadow-modal)}.alarm-measured-values{display:flex;align-items:center;gap:6px;font-family:SF Mono,Monaco,Consolas,monospace}.alarm-measured-values__item{display:inline-flex;align-items:center;gap:4px;background:#3b82f61a;padding:5px 10px;border-radius:6px;border:1px solid rgba(59,130,246,.25)}.alarm-measured-values__label{color:#2563eb;font-weight:700;font-size:11px}.alarm-measured-values__value{color:#0f172a;font-weight:700;font-size:13px;min-width:50px;text-align:right}.alarm-measured-values__time{font-size:11px;color:#475569;font-family:SF Mono,Monaco,Consolas,monospace;font-weight:600;white-space:nowrap;background:#64748b1f;padding:5px 8px;border-radius:6px}.dark .alarm-measured-values__item,[data-theme=dark] .alarm-measured-values__item{background:#3b82f626;border-color:#3b82f64d}.dark .alarm-measured-values__label,[data-theme=dark] .alarm-measured-values__label{color:#60a5fa}.dark .alarm-measured-values__value,[data-theme=dark] .alarm-measured-values__value{color:#f8fafc}.dark .alarm-measured-values__time,[data-theme=dark] .alarm-measured-values__time{color:#cbd5e1;background:#64748b33}@media (max-width: 768px){.alarm-management-content{padding:16px;gap:16px}.stats-cards,.group-cards,.type-cards,.threshold-inputs{grid-template-columns:1fr}.threshold-form{margin:10px;max-height:85vh}.section-tabs{width:100%;justify-content:center}}@media (max-width: 480px){.alarm-management-header{padding:16px}.alarm-management-content{padding:12px}.form-content,.form-header,.form-actions{padding:16px}}.user-management{padding:var(--spacing-lg);min-height:calc(100vh - 160px)}.filters{display:flex;gap:8px}.tab-buttons{display:flex;gap:var(--spacing-sm)}.users-table-container{background:var(--bg-primary);border-radius:var(--radius-md);padding:var(--spacing-lg)}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:var(--spacing-md);text-align:center;border-bottom:1px solid var(--border-light);vertical-align:middle;height:48px}.users-table td button{margin:0 auto;display:block}.users-table td span{display:inline-block}.users-table th{background:var(--bg-secondary);font-weight:600;color:var(--text-primary)}.profile-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.025em;border:1px solid;transition:all .15s ease}.profile-badge.system-admin{background:#dc267f1a;color:#dc267f;border-color:#dc267f33}.profile-badge.platform-admin{background:#8b5cf61a;color:#8b5cf6;border-color:#8b5cf633}.profile-badge.company-admin{background:#3b82f61a;color:#3b82f6;border-color:#3b82f633}.profile-badge.site-admin{background:#10b9811a;color:#10b981;border-color:#10b98133}.profile-badge.normal{background:#6b72801a;color:#6b7280;border-color:#6b728033}.dark .profile-badge.system-admin{background:#dc267f26;color:#f472b6;border-color:#dc267f4d}.dark .profile-badge.platform-admin{background:#8b5cf626;color:#a78bfa;border-color:#8b5cf64d}.dark .profile-badge.company-admin{background:#3b82f626;color:#60a5fa;border-color:#3b82f64d}.dark .profile-badge.site-admin{background:#10b98126;color:#34d399;border-color:#10b9814d}.dark .profile-badge.normal{background:#6b728026;color:#9ca3af;border-color:#6b72804d}.action-buttons{display:flex;gap:8px;justify-content:center;align-items:center;height:100%;min-height:48px}.session-status-container{display:flex;justify-content:center;align-items:center;gap:8px;height:100%;min-height:48px}.permissions-tab{background:var(--bg-card);border-radius:8px;padding:20px;box-shadow:var(--shadow-md)}.permission-group h3{margin-bottom:20px;color:var(--text-primary)}.user-permission-row{display:flex;align-items:center;justify-content:space-between;padding:15px;border-bottom:1px solid var(--border-color)}.user-info{display:flex;align-items:center;gap:10px}.user-name{font-weight:600;color:var(--text-primary)}.user-role{background:var(--bg-tertiary);color:var(--text-secondary);padding:2px 8px;border-radius:10px;font-size:12px}.filters-section{display:flex;gap:20px;padding:20px;background:var(--bg-tertiary);border-radius:8px;margin-bottom:20px}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{font-weight:600;color:var(--text-primary);font-size:14px}.filter-group select{padding:6px 10px;border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-size:14px;min-width:200px;background:var(--bg-card);color:var(--text-primary)}.user-row{cursor:pointer;transition:background-color .2s}.user-row:hover{background-color:var(--bg-secondary)}.business-permissions{padding:20px}.business-selector{display:flex;flex-direction:column;gap:15px}.business-permissions-container{border:1px solid var(--border-primary);border-radius:6px;background:var(--bg-card);overflow:hidden}.business-toolbar{display:flex;align-items:center;gap:12px;padding:12px 15px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.business-search{flex:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-size:14px;background:var(--bg-card);color:var(--text-primary)}.business-search::placeholder{color:var(--text-muted)}.business-search:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4263eb1a}.expand-collapse-toggle{font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s;white-space:nowrap;display:flex;align-items:center;gap:4px;padding:4px 6px;border-radius:4px}.expand-collapse-toggle:hover{color:var(--text-primary);background:var(--bg-tertiary)}.business-view-modes{display:flex;gap:15px;align-items:center}.business-view-modes label{display:flex;align-items:center;gap:5px;cursor:pointer;font-size:14px;font-weight:500}.business-view-modes input[type=radio]{width:auto;margin:0}.district-group{border-bottom:1px solid var(--border-secondary)}.district-group:last-child{border-bottom:none}.district-header{background:var(--bg-tertiary);padding:12px 15px;display:flex;justify-content:space-between;align-items:center;font-weight:600;color:var(--text-primary);cursor:pointer;transition:background-color .2s}.district-header:hover{background:var(--bg-card)}.district-header-left{display:flex;align-items:center;gap:8px;flex:1}.district-header-right{display:flex;align-items:center;gap:8px}.collapse-icon{font-size:12px;color:var(--text-secondary);width:16px;text-align:center;transition:transform .2s}.district-header-left:hover .collapse-icon{transform:scale(1.2)}.district-toggle-btn{font-size:11px;font-weight:500;padding:4px 8px;border-radius:12px;cursor:pointer;transition:all .2s;white-space:nowrap;border:1px solid transparent;width:100%;display:flex;justify-content:space-between;align-items:center;min-height:36px}.district-toggle-btn.none-selected{color:var(--user-mgmt-status-none);background:var(--user-mgmt-status-none-bg);border-color:var(--user-mgmt-status-none-border)}.district-toggle-btn.none-selected:hover{color:var(--user-mgmt-status-none-hover);background:var(--user-mgmt-status-none-hover-bg);border-color:var(--user-mgmt-status-none-hover-border)}.district-toggle-btn.some-selected{color:var(--status-warning);background:var(--user-mgmt-permission-bg-2);border-color:var(--status-warning)}.district-toggle-btn.some-selected:hover{color:var(--status-warning);background:var(--user-mgmt-permission-bg-3);border-color:var(--status-warning)}.district-toggle-btn.all-selected{color:var(--status-success);background:var(--user-mgmt-permission-bg-1);border-color:var(--status-success)}.district-toggle-btn.all-selected:hover{color:var(--status-error);background:var(--user-mgmt-permission-bg-4);border-color:var(--status-error)}.dark .district-toggle-btn.some-selected{color:var(--status-warning);background:var(--user-mgmt-permission-bg-2);border-color:var(--status-warning)}.dark .district-toggle-btn.some-selected:hover{color:var(--status-warning);background:var(--user-mgmt-permission-bg-3);border-color:var(--status-warning)}.dark .district-toggle-btn.all-selected{color:var(--status-success);background:var(--user-mgmt-permission-bg-1);border-color:var(--status-success)}.dark .district-toggle-btn.all-selected:hover{color:var(--status-error);background:var(--user-mgmt-permission-bg-4);border-color:var(--status-error)}.district-header.all-selected{background:var(--user-mgmt-permission-bg-1);border-left:4px solid var(--status-success)}.district-header.some-selected{background:var(--user-mgmt-permission-bg-2);border-left:4px solid var(--status-warning)}.dark .district-header.all-selected{background:var(--user-mgmt-permission-bg-1);border-left:4px solid var(--status-success)}.dark .district-header.some-selected{background:var(--user-mgmt-permission-bg-2);border-left:4px solid var(--status-warning)}.district-name{display:flex;align-items:center;gap:8px}.district-name strong{font-size:14px;font-weight:500}.business-count{font-size:12px;color:var(--text-secondary);font-weight:400}.district-businesses{padding:0 15px 15px;background:var(--bg-secondary)}.business-list-view{display:flex;flex-wrap:wrap;gap:8px;padding:10px;border:1px solid var(--border-primary);border-radius:4px;min-height:40px;background:var(--bg-card)}.business-list{display:flex;flex-wrap:wrap;gap:8px}.business-tag{background:var(--user-mgmt-accent-info);color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;white-space:nowrap}.business-tag.unknown{background:var(--user-mgmt-accent-muted)}.no-access{color:var(--user-mgmt-accent-muted);font-style:italic}.business-checkboxes{max-height:400px;overflow-y:auto;padding:0}.business-checkbox{display:flex;align-items:flex-start;gap:8px;cursor:pointer;padding:8px;border-radius:4px;margin-bottom:8px}.business-checkbox:hover{background:var(--bg-secondary)}.user-permission-card{background:var(--bg-card);border-radius:12px;box-shadow:0 2px 12px var(--user-mgmt-shadow-light);margin-bottom:20px;overflow:hidden;border:1px solid var(--user-mgmt-border-secondary)}.user-info-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:var(--user-mgmt-gradient-1);border-bottom:1px solid var(--user-mgmt-border-primary)}.user-details{display:flex;align-items:center;gap:12px}.user-details h4{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.business-access{padding:20px}.all-access-card{text-align:center;padding:30px;background:var(--user-mgmt-gradient-2);border-radius:8px;border:2px dashed var(--user-mgmt-border-success)}.all-access-text{font-size:16px;font-weight:600;color:var(--user-mgmt-text-success)}.no-access-card{text-align:center;padding:30px;background:var(--user-mgmt-gradient-3);border-radius:8px;border:2px dashed var(--user-mgmt-border-dashed)}.no-access-text{font-size:16px;font-weight:500;color:var(--user-mgmt-text-light)}.business-permissions-grid{display:flex;flex-direction:column;gap:16px}.district-permission-group{background:var(--bg-secondary);border-radius:8px;overflow:hidden;border:1px solid var(--user-mgmt-border-secondary)}.district-permission-group .district-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-tertiary);border-bottom:1px solid var(--user-mgmt-border-primary)}.district-permission-group .district-header h5{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.district-permission-group .business-count{font-size:12px;color:var(--text-secondary);background:var(--bg-card);padding:2px 8px;border-radius:12px;font-weight:500}.business-grid{padding:12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px}.business-permission-card{background:var(--bg-card);padding:12px;border-radius:6px;border:1px solid var(--user-mgmt-border-secondary);box-shadow:0 1px 3px var(--user-mgmt-shadow-medium)}.business-permission-card{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.business-permission-card .business-type{color:var(--text-secondary);font-weight:400}.business-permission-card .business-code{font-size:12px;color:var(--text-secondary);font-family:monospace;background:var(--bg-secondary);padding:2px 6px;border-radius:3px;display:inline-block}.login-status{display:flex;flex-direction:column;gap:8px}.login-status.normal-user{padding:12px;background:var(--user-mgmt-bg-success);border-radius:6px;border-left:4px solid var(--user-mgmt-border-success)}.login-status.first-login-user{padding:20px;background:var(--user-mgmt-bg-error);border-radius:8px;border-left:4px solid var(--user-mgmt-border-error)}.status-header{margin-bottom:12px}.status-content{display:flex;flex-direction:column;gap:12px}.status-label{font-weight:600;font-size:14px;color:var(--text-primary)}.status-label.first-login{color:var(--user-mgmt-text-warning)}.status-description{font-size:13px;color:var(--text-secondary);line-height:1.4;margin:0}.action-section{display:flex;justify-content:flex-start;margin-top:8px}.last-login{font-size:12px;color:var(--text-secondary);font-style:italic}.session-status-container{display:flex;align-items:center;justify-content:center;gap:8px}.password-display{display:flex;flex-direction:column;gap:24px}.success-message{text-align:center;padding:20px;background:var(--user-mgmt-gradient-4);border-radius:12px;border:1px solid var(--user-mgmt-border-info)}.success-icon{width:48px;height:48px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}.success-icon img{width:100%;height:100%;object-fit:contain}.success-message h4{margin:0 0 16px;font-size:20px;font-weight:600;color:var(--user-mgmt-text-info)}.warning-box{display:flex;align-items:flex-start;gap:12px;padding:16px;background:var(--user-mgmt-bg-warning);border-radius:8px;border:1px solid var(--user-mgmt-border-warning)}.warning-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.warning-icon img{width:100%;height:100%;object-fit:contain}.warning-text{color:var(--user-mgmt-text-warning);font-size:14px;line-height:1.5}.password-section{display:flex;flex-direction:column;gap:12px}.password-label{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.password-input-group{display:flex;gap:12px;align-items:center}.password-input{flex:1;padding:12px 16px;border:2px solid var(--user-mgmt-border-light);border-radius:8px;font-size:16px;font-family:Courier New,monospace;background:var(--bg-secondary);color:var(--text-primary);font-weight:600;letter-spacing:1px}.password-input:focus{outline:none;border-color:var(--user-mgmt-accent-blue);box-shadow:0 0 0 3px var(--user-mgmt-shadow-focus)}.password-info{display:flex;flex-direction:column;gap:12px;padding:20px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--user-mgmt-border-secondary)}.info-item{display:flex;align-items:flex-start;gap:12px}.info-icon{width:16px;height:16px;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center}.info-icon img{width:100%;height:100%;object-fit:contain}.info-text{color:var(--text-secondary);font-size:14px;line-height:1.5}.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:18px;color:var(--text-muted)}.bdongcd-groups{display:flex;flex-direction:column;gap:16px}.bdongcd-group{background:var(--bg-secondary);border-radius:8px;overflow:hidden;border:1px solid var(--user-mgmt-border-secondary);box-shadow:0 1px 3px var(--user-mgmt-shadow-medium)}.bdongcd-header{background:var(--user-mgmt-gradient-5);padding:12px 16px;border-bottom:1px solid var(--border-secondary);border-left:4px solid var(--user-mgmt-accent-info)}.bdongcd-name{display:flex;align-items:center;gap:8px;color:var(--user-mgmt-text-info);font-weight:600}.bdongcd-name strong{font-size:14px;font-weight:600}.bdongcd-name .business-count{font-size:12px;color:var(--user-mgmt-text-info);background:#ffffffb3;padding:2px 8px;border-radius:12px;font-weight:500}.bdongcd-businesses{padding:12px;background:var(--bg-card)}.ds-type-tag{color:var(--text-secondary);padding:2px 8px;margin-right:4px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.ds-name{flex:1;display:flex;align-items:center;gap:8px;order:1}.ds-name-text{color:var(--text-primary);font-weight:500;font-size:14px}.ds-item.form-checkbox-label{display:flex;align-items:center;justify-content:space-between;flex-direction:row}.ds-item .form-checkbox{width:18px!important;height:18px!important;margin:0!important;padding:0!important;flex-shrink:0;cursor:pointer;order:2;appearance:none;-webkit-appearance:none;-moz-appearance:none;background:var(--bg-card);border:2px solid var(--border-light);border-radius:4px;position:relative;transition:all .2s ease}.ds-item .form-checkbox:hover{border-color:var(--border-color);box-shadow:0 0 0 2px var(--border-light)}.ds-item .form-checkbox:checked{background:var(--bg-secondary);border-color:var(--border-color)}.ds-item .form-checkbox:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23495057'%3e%3cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat;background-position:center}.dark .ds-item .form-checkbox{background:var(--bg-secondary);border-color:var(--border-primary)}.dark .ds-item .form-checkbox:hover{border-color:var(--border-color);box-shadow:0 0 0 2px var(--border-primary)}.dark .ds-item .form-checkbox:checked{background:var(--bg-tertiary);border-color:var(--border-color)}.dark .ds-item .form-checkbox:checked:after{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23ffffff'%3e%3cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3e%3c/svg%3e")}.district-businesses{padding:12px 15px;background:var(--bg-secondary);border-top:1px solid var(--border-secondary)}.ds-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;margin-bottom:4px;background:var(--bg-tertiary2);border-bottom:1px solid var(--border-secondary);border-left:4px solid var(--bg-tertiary);cursor:pointer;transition:all .2s;min-height:40px;border-radius:4px}.ds-item:last-child{margin-bottom:0}.ds-item:hover{background:var(--bg-secondary);transform:translate(2px)}.ds-item.selected{background:var(--soft-blue-025);border-bottom:1px solid var(--soft-blue-050);border-left:4px solid var(--soft-blue-075);border-radius:0}.ds-item.selected:hover{background:var(--soft-blue-025);opacity:.9}.business-access.enhanced{padding:20px}.all-access-card.enhanced{display:flex;align-items:center;gap:16px;padding:20px;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:12px;border:2px dashed #4caf50}.access-icon{font-size:24px}.access-content{flex:1}.access-content .all-access-text{display:block;font-size:16px;font-weight:600;color:#2e7d32;margin-bottom:4px}.access-content small{color:#388e3c;font-size:13px}.permissions-summary{margin-bottom:20px;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.summary-text{display:block;margin-bottom:12px;color:#2c3e50;font-size:14px}.permissions-preview{display:flex;flex-wrap:wrap;gap:8px}.business-preview-tag{background:#e3f2fd;color:#1976d2;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.more-businesses{background:transparent;color:#6c757d;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;border:1px solid transparent}.more-businesses.toggle-trigger{cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.more-businesses.toggle-trigger:hover{background:#fff3cd;color:#856404;border-color:#ffeaa7;transform:scale(1.05)}.more-businesses.toggle-trigger:active{transform:scale(.95)}.permissions-detail-content{display:none}.user-permission-card.enhanced.expanded .permissions-detail-content{display:block}.district-permission-group.enhanced{background:#f8f9fa;border-radius:8px;overflow:hidden;border:1px solid #e9ecef;margin-bottom:16px}.district-header.enhanced{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#e9ecef;border-bottom:1px solid #dee2e6}.district-header.enhanced h5{margin:0;font-size:14px;font-weight:600;color:#495057}.business-count.enhanced{font-size:12px;color:#6c757d;background:#fff;padding:4px 8px;border-radius:12px;font-weight:500}.business-grid.enhanced{padding:12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:8px}.business-permission-item{background:#fff;padding:12px;border-radius:6px;border:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center}.business-info{flex:1}.business-info{font-size:13px;font-weight:500;color:#2c3e50;margin-bottom:4px}.business-info .business-code{font-size:11px;color:#6c757d;font-family:monospace}.business-status{display:flex;align-items:center;gap:6px}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.active{background:#4caf50}.status-text{font-size:11px;color:#4caf50;font-weight:500}.no-access-card.enhanced{display:flex;align-items:center;gap:16px;padding:20px;background:linear-gradient(135deg,#fafafa,#f0f0f0);border-radius:12px;border:2px dashed #bdbdbd}.no-access-card.enhanced .access-icon{font-size:24px}.no-access-card.enhanced .access-content .no-access-text{display:block;font-size:16px;font-weight:600;color:#757575;margin-bottom:4px}.no-access-card.enhanced .access-content small{color:#9e9e9e;font-size:13px}.input-help{margin-top:8px;padding:8px 12px;background:var(--bg-secondary);border-radius:6px;border-left:3px solid var(--primary-color)}.input-help p{margin:2px 0;font-size:12px;color:var(--text-secondary);line-height:1.4}.validation-message{margin-top:8px;padding:8px 12px;border-radius:6px;font-size:13px;font-weight:500;display:flex;align-items:center;gap:6px}.validation-message.success{background:var(--status-success-bg);color:var(--status-success);border:1px solid var(--status-success-border)}.validation-message.error{background:var(--status-error-bg);color:var(--status-error);border:1px solid var(--status-error-border)}.validation-message:before{content:"";width:12px;height:12px;border-radius:50%;flex-shrink:0}.validation-message.success:before{background:var(--status-success)}.validation-message.error:before{background:var(--status-error)}input.valid{border-color:var(--status-success)!important;box-shadow:0 0 0 2px var(--status-success-shadow)!important}input.invalid{border-color:var(--status-error)!important;box-shadow:0 0 0 2px var(--status-error-shadow)!important}.toggle-icon{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);margin-right:8px;transition:color .2s}.district-header:hover .toggle-icon{color:var(--text-primary)}.dark .district-businesses{background:var(--bg-primary)}.dark .business-item:hover{background-color:#ffffff1a}.dark .business-item.selected:hover{background-color:var(--status-success-bg);opacity:.8}.dark .ds-item{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);border-left:4px solid var(--bg-card);color:var(--text-primary)}.dark .ds-item:hover{background:var(--bg-tertiary)}.dark .ds-item.selected{background:var(--bg-card);border-bottom:1px solid var(--border-secondary);border-left:4px solid var(--primary-color)}.dark .ds-item.selected:hover{background:var(--bg-card);opacity:.9}.district-select-all-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-card);cursor:pointer;transition:all .2s ease;min-height:36px;min-width:120px;font-size:13px;font-weight:500;box-sizing:border-box;overflow:visible}.district-select-all-btn:hover{background:var(--bg-secondary);border-color:var(--primary-color)}.district-select-all-btn.all-selected{background:var(--status-error);border-color:var(--status-error);color:#fff;box-shadow:0 0 0 2px #ef444433}.district-select-all-btn.all-selected:hover{background:var(--status-error);border-color:var(--status-error);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.district-select-all-btn.some-selected{background:var(--status-warning);border-color:var(--status-warning);color:#fff;box-shadow:0 0 0 2px #f59e0b33}.district-select-all-btn.some-selected:hover{background:var(--status-warning);border-color:var(--status-warning);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #f59e0b4d}.district-select-all-text{flex:1;text-align:left;-webkit-user-select:none;user-select:none;white-space:nowrap}.district-select-all-checkbox{width:18px!important;height:18px!important;flex-shrink:0;cursor:pointer;margin:0!important;padding:0!important;box-sizing:border-box;position:relative;vertical-align:middle;max-width:18px;max-height:18px;appearance:none;-webkit-appearance:none;-moz-appearance:none;background:var(--bg-card);border:2px solid var(--border-light);border-radius:4px;transition:all .2s ease}.district-select-all-checkbox:hover{border-color:var(--border-color);box-shadow:0 0 0 2px var(--border-light)}.district-select-all-checkbox:checked{background:var(--bg-secondary);border-color:var(--border-color)}.district-select-all-checkbox:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23495057'%3e%3cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat;background-position:center}.dark .district-select-all-checkbox{background:var(--bg-secondary);border-color:var(--border-primary)}.dark .district-select-all-checkbox:hover{border-color:var(--border-color);box-shadow:0 0 0 2px var(--border-primary)}.dark .district-select-all-checkbox:checked{background:var(--bg-tertiary);border-color:var(--border-color)}.dark .district-select-all-checkbox:checked:after{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23ffffff'%3e%3cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3e%3c/svg%3e")}.dark .district-select-all-btn{background:var(--bg-secondary);border-color:var(--border-primary);color:var(--text-primary)}.dark .district-select-all-btn:hover{background:var(--bg-tertiary);border-color:var(--primary-color)}.dark .district-select-all-btn.all-selected{background:var(--status-error);border-color:var(--status-error);color:#fff;box-shadow:0 0 0 2px #ef44444d}.dark .district-select-all-btn.all-selected:hover{background:var(--status-error);border-color:var(--status-error);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #ef444466}.dark .district-select-all-btn.some-selected{background:var(--status-warning);border-color:var(--status-warning);color:#fff;box-shadow:0 0 0 2px #f59e0b4d}.dark .district-select-all-btn.some-selected:hover{background:var(--status-warning);border-color:var(--status-warning);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #f59e0b66}.permission-selector{display:flex;flex-direction:column;gap:16px;padding:16px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-primary)}.permission-hint{display:block;margin-top:4px;font-size:12px;color:var(--text-secondary);font-weight:400}.readonly-value{padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:14px}.readonly-value small{font-size:12px;color:var(--text-secondary);margin-left:8px}.no-sites{text-align:center;padding:20px;color:var(--text-muted);font-style:italic}.site-checkboxes{max-height:300px;overflow-y:auto;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:6px;padding:12px;display:flex;flex-direction:column;gap:8px}.site-item.form-checkbox-label{background:var(--bg-card);padding:12px;border-radius:8px;border:1px solid var(--user-mgmt-border-secondary);box-shadow:0 1px 3px var(--user-mgmt-shadow-medium);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between;margin:0}.site-item.form-checkbox-label:hover{transform:translateY(-1px);box-shadow:0 2px 8px var(--user-mgmt-shadow-medium);border-color:var(--primary-color)}.site-item.form-checkbox-label.selected{background:var(--user-mgmt-gradient-2);border-color:var(--status-success);border-left:4px solid var(--status-success);box-shadow:0 2px 8px #10b98126}.site-item.form-checkbox-label.selected:hover{background:var(--user-mgmt-gradient-2);transform:translateY(-1px);box-shadow:0 3px 12px #10b98140}.site-item .site-name{flex:1;display:flex;flex-direction:column;gap:4px;order:1}.site-item .site-name-text{font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.4}.site-item .site-address{font-size:12px;color:var(--text-secondary);line-height:1.3}.site-item .form-checkbox{width:18px!important;height:18px!important;margin:0!important;padding:0!important;flex-shrink:0;cursor:pointer;order:2;appearance:none;-webkit-appearance:none;-moz-appearance:none;background:var(--bg-card);border:2px solid var(--border-light);border-radius:4px;position:relative;transition:all .2s ease}.site-item .form-checkbox:hover{border-color:var(--border-color);box-shadow:0 0 0 2px var(--border-light)}.site-item .form-checkbox:checked{background:var(--status-success);border-color:var(--status-success)}.site-item .form-checkbox:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23ffffff'%3e%3cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3e%3c/svg%3e");background-size:contain;background-repeat:no-repeat;background-position:center}.dark .site-item.form-checkbox-label{background:var(--bg-secondary);border-color:var(--border-primary);box-shadow:0 1px 3px #0003}.dark .site-item.form-checkbox-label:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #0000004d}.dark .site-item.form-checkbox-label.selected{background:var(--bg-card);border-color:var(--status-success);border-left:4px solid var(--status-success);box-shadow:0 2px 8px #10b98140}.dark .site-item .form-checkbox{background:var(--bg-secondary);border-color:var(--border-primary)}.dark .site-item .form-checkbox:hover{border-color:var(--border-color);box-shadow:0 0 0 2px var(--border-primary)}.dark .site-item .form-checkbox:checked{background:var(--status-success);border-color:var(--status-success)}.selected-sites-view{max-height:300px;overflow-y:auto;padding:8px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px}.pagination-container{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-lg);padding:var(--spacing-md) 0}.pagination{display:flex;gap:var(--spacing-xs);align-items:center}.pagination-btn{background:transparent;border:none;color:var(--neutral-600);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500}.pagination-btn:hover:not(:disabled){background:var(--neutral-100);color:var(--neutral-700)}.pagination-btn.active{background:var(--neutral-200);color:var(--neutral-800)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{color:var(--neutral-600);font-size:14px}.form-label-with-controls{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--spacing-sm)}.form-label-with-controls label{flex:1;min-width:200px}.site-selection-controls{display:flex;gap:var(--spacing-xs);align-items:center}.btn-text{background:none;border:none;color:var(--primary-600);text-decoration:underline;cursor:pointer;padding:var(--spacing-xs);font-size:12px}.btn-text:hover{color:var(--primary-700);background:var(--primary-50);border-radius:var(--radius-sm)}.btn-small{font-size:11px;padding:2px 6px}.role-hint{display:block;margin-top:4px;font-weight:400;line-height:1.3}.company-role{color:var(--info-600)}.site-worker-role{color:var(--warning-600)}.site-selection-summary{margin-bottom:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--neutral-50);border-radius:var(--radius-sm);border-left:3px solid var(--primary-500)}.selection-count{font-size:13px;color:var(--neutral-700);font-weight:500}.site-checkboxes{max-height:200px;overflow-y:auto;border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:var(--spacing-sm)}.site-item.selected{background:var(--primary-50);border-color:var(--primary-200)}.site-item:hover{background:var(--neutral-25)}.form-checkbox-label{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm);border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:var(--spacing-xs);cursor:pointer;transition:all .2s ease}.site-name{flex:1;text-align:left}.site-name-text{font-weight:500;color:var(--text-primary)}.form-checkbox{margin-left:var(--spacing-sm);cursor:pointer}@media (max-width: 768px){.pagination-container{flex-direction:column;gap:var(--spacing-md)}.pagination-btn{min-width:32px;height:32px;padding:var(--spacing-xs) var(--spacing-sm)}.form-label-with-controls{flex-direction:column;align-items:stretch}.site-selection-controls{justify-content:flex-end;margin-top:var(--spacing-xs)}}.company-table-container{background:var(--surface-primary);border-radius:12px;border:1px solid var(--border-primary);overflow:hidden}.company-table-header{padding:20px;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center}.company-table-title{font-size:18px;font-weight:600;color:var(--text-primary)}.company-table-toolbar{display:flex;gap:12px;align-items:center}.company-search-input{width:250px}.company-filter-select{min-width:150px}.company-status-chip{border-radius:16px;font-size:12px;font-weight:600;padding:4px 12px}.company-status-active{background-color:var(--success-light);color:var(--success-main)}.company-status-suspended{background-color:var(--warning-light);color:var(--warning-main)}.company-status-expiring{background-color:var(--error-light);color:var(--error-main)}.company-status-expired{background-color:var(--grey-300);color:var(--grey-700)}.company-status-terminated{background-color:var(--grey-400);color:var(--grey-800)}.company-type-chip{border-radius:12px;font-size:11px;font-weight:500;padding:2px 8px}.company-type-large{background-color:var(--primary-light);color:var(--primary-main)}.company-type-medium{background-color:var(--info-light);color:var(--info-main)}.company-type-small{background-color:var(--secondary-light);color:var(--secondary-main)}.company-type-specialized{background-color:var(--warning-light);color:var(--warning-main)}.company-type-public{background-color:var(--success-light);color:var(--success-main)}.company-modal{background:var(--surface-primary);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.company-modal-header{padding:24px 24px 0;border-bottom:1px solid var(--border-primary)}.company-modal-title{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.company-modal-content{padding:24px}.company-modal-actions{padding:16px 24px;border-top:1px solid var(--border-primary);display:flex;justify-content:flex-end;gap:12px}.company-form{display:flex;flex-direction:column;gap:20px}.company-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.company-form-row.single{grid-template-columns:1fr}.company-form-field{display:flex;flex-direction:column;gap:8px}.company-form-label{font-size:14px;font-weight:600;color:var(--text-primary)}.company-form-input{width:100%}.company-form-textarea{width:100%;min-height:100px;resize:vertical}.company-detail{display:flex;flex-direction:column;gap:24px}.company-detail-section{background:var(--surface-secondary);border-radius:8px;padding:20px}.company-detail-section-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.company-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.company-detail-field{display:flex;flex-direction:column;gap:4px}.company-detail-label{font-size:12px;font-weight:500;color:var(--text-secondary);text-transform:uppercase}.company-detail-value{font-size:14px;font-weight:400;color:var(--text-primary)}.company-users-section{margin-top:20px}.company-users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.company-users-title{font-size:16px;font-weight:600;color:var(--text-primary)}.company-users-table{background:var(--surface-primary);border-radius:8px;overflow:hidden}.master-account-modal{background:var(--surface-primary);border-radius:12px;max-width:500px;width:100%}.master-account-form{display:flex;flex-direction:column;gap:16px;padding:24px}.master-account-result{background:var(--success-light);border:1px solid var(--success-main);border-radius:8px;padding:16px;margin-top:16px}.master-account-password{font-family:Courier New,monospace;font-size:16px;font-weight:600;color:var(--success-main);background:var(--surface-primary);padding:12px;border-radius:4px;border:1px solid var(--border-primary);margin-top:8px;text-align:center}@media (max-width: 768px){.company-management{padding:16px}.company-management-header{flex-direction:column;align-items:stretch}.company-table-header{flex-direction:column;gap:16px}.company-table-toolbar{flex-wrap:wrap}.company-search-input{width:100%}.company-form-row,.company-detail-grid{grid-template-columns:1fr}}@media (max-width: 480px){.company-management-actions{flex-direction:column;width:100%}.company-modal{margin:16px;max-height:calc(100vh - 32px)}}[data-theme=dark] .company-status-chip,[data-theme=dark] .company-type-chip{opacity:.9}[data-theme=dark] .company-detail-section{background:var(--surface-tertiary)}[data-theme=dark] .master-account-result{background:#4caf501a;border-color:#4caf504d}[data-theme=dark] .master-account-password{background:var(--surface-secondary)}.permission-management{padding:0}.permission-matrix-container{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.permission-matrix-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border-color);background:var(--surface-color)}.permission-matrix-toolbar{display:flex;align-items:center;gap:12px}.permission-matrix-grid{overflow-x:auto;max-height:70vh;background:var(--background-color)}.permission-matrix-table{display:flex;flex-direction:column;min-width:600px}.permission-matrix-row{display:flex;border-bottom:1px solid var(--border-color)}.permission-matrix-row:last-child{border-bottom:none}.permission-matrix-header-row{background:var(--surface-secondary-color);position:sticky;top:0;z-index:1}.permission-matrix-cell{padding:12px 16px;border-right:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;min-height:60px}.permission-matrix-cell:last-child{border-right:none}.permission-matrix-feature-header,.permission-matrix-feature-cell{width:200px;min-width:200px;justify-content:flex-start;background:var(--surface-color);position:sticky;left:0;z-index:1}.permission-matrix-feature-header{font-weight:600;background:var(--surface-secondary-color)}.permission-matrix-role-header{width:120px;min-width:120px;font-weight:600;text-align:center}.permission-matrix-feature-cell{flex-direction:column;align-items:flex-start}.permission-level-chip{cursor:pointer;transition:all .2s ease}.permission-level-chip:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.permission-level-none{background-color:var(--gray-100);color:var(--gray-600)}.permission-level-read{background-color:var(--info-100);color:var(--info-700)}.permission-level-write{background-color:var(--warning-100);color:var(--warning-700)}.permission-level-full{background-color:var(--error-100);color:var(--error-700)}[data-theme=dark] .permission-level-none{background-color:var(--gray-800);color:var(--gray-300)}[data-theme=dark] .permission-level-read{background-color:var(--info-900);color:var(--info-200)}[data-theme=dark] .permission-level-write{background-color:var(--warning-900);color:var(--warning-200)}[data-theme=dark] .permission-level-full{background-color:var(--error-900);color:var(--error-200)}.permission-list-container{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.permission-statistics-chart{background:var(--surface-color);border-radius:var(--border-radius);padding:16px}.permission-edit-form{display:flex;flex-direction:column;gap:20px;margin-top:16px}.permission-edit-section{padding:16px;border:1px solid var(--border-color);border-radius:var(--border-radius);background:var(--surface-secondary-color)}.permission-edit-section-title{margin-bottom:12px;font-weight:600;color:var(--text-primary)}.permission-description{padding:12px;background:var(--info-50);border:1px solid var(--info-200);border-radius:var(--border-radius);margin:8px 0}[data-theme=dark] .permission-description{background:var(--info-900);border-color:var(--info-700)}@media (max-width: 768px){.permission-matrix-header{flex-direction:column;align-items:flex-start;gap:12px}.permission-matrix-toolbar{width:100%;justify-content:flex-end}.permission-matrix-feature-header,.permission-matrix-feature-cell{width:150px;min-width:150px}.permission-matrix-role-header{width:100px;min-width:100px}.permission-matrix-cell{padding:8px 12px;min-height:50px}}.permission-matrix-grid::-webkit-scrollbar{height:8px}.permission-matrix-grid::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px}.permission-matrix-grid::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:4px}.permission-matrix-grid::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}[data-theme=dark] .permission-matrix-grid::-webkit-scrollbar-track{background:var(--gray-800)}[data-theme=dark] .permission-matrix-grid::-webkit-scrollbar-thumb{background:var(--gray-600)}[data-theme=dark] .permission-matrix-grid::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.permission-matrix-row{transition:background-color .2s ease}.permission-matrix-row:hover{background-color:var(--hover-color)}.permission-matrix-cell .MuiChip-root{transition:all .2s ease}.permission-matrix-cell .MuiChip-root:hover{transform:scale(1.05)}.permission-loading{display:flex;justify-content:center;align-items:center;min-height:300px;background:var(--surface-color);border-radius:var(--border-radius)}.permission-empty{text-align:center;padding:40px 20px;color:var(--text-secondary)}.permission-empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.permission-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;cursor:pointer}.permission-badge:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.permission-filters{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.permission-filter-item{min-width:120px}@media (max-width: 768px){.permission-filters{flex-direction:column}.permission-filter-item{width:100%}}.dashboard-layout{display:grid;grid-template-areas:"seoul-left-panel seoul-middle-panel seoul-right-panel";grid-template-columns:minmax(280px,22%) 1fr minmax(320px,25%);grid-template-rows:1fr;gap:var(--spacing-md);height:calc(100vh - 80px);min-height:calc(100vh - 80px);padding:var(--spacing-xs) 0px}.dashboard-layout:not(:has(.seoul-right-panel)){grid-template-areas:"seoul-left-panel seoul-middle-panel";grid-template-columns:minmax(280px,25%) 1fr}.seoul-left-panel{grid-area:seoul-left-panel;display:flex;flex-direction:column;height:100%;overflow-y:auto;overflow-x:hidden;min-height:0;background:var(--bg-panel);border-radius:12px;padding:var(--spacing-md);border:1px solid var(--border-primary);box-shadow:0 1px 3px #0000000d}.seoul-right-panel{grid-area:seoul-right-panel;display:flex;flex-direction:column;height:100%;overflow-y:auto;overflow-x:hidden;min-height:0;background:var(--bg-panel);border-radius:12px;padding:var(--spacing-md);border:1px solid var(--border-primary);box-shadow:0 1px 3px #0000000d}.site-cards-container{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-sm);background:transparent}.site-card{background:var(--bg-card);border-radius:10px;padding:var(--spacing-md);transition:all .2s ease;cursor:pointer;position:relative;box-shadow:0 1px 2px #0000000d;border:1px solid var(--border-primary)}.site-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014;border-color:var(--border-secondary)}.site-card.site-card-normal:hover{border-color:var(--color-normal)}.site-card.site-card-caution:hover{border-color:var(--color-caution)}.site-card.site-card-warning:hover{border-color:var(--color-warning)}.site-card.site-card-danger:hover{border-color:var(--color-danger)}.site-card-selected{background:var(--bg-card)!important;transform:translateY(-2px)!important;border:1px solid var(--primary-color)!important;box-shadow:0 4px 12px #3b82f626!important;position:relative;overflow:hidden}.site-card-selected:before{display:none}.site-card-selected .site-card-title{color:var(--primary-color)!important;font-weight:700}.site-card-selected .site-status-icon{border:2px solid var(--primary-color)}[data-theme=dark] .site-card-selected{background-color:var(--bg-card)!important;border-color:var(--primary-color)!important;box-shadow:0 4px 12px #3b82f633!important}[data-theme=dark] .site-card-selected .site-card-title{color:var(--primary-color)!important}[data-theme=dark] .site-card-selected .site-status-icon{border-color:var(--primary-color)}.site-card-header{display:flex;justify-content:space-between;align-items:center}.site-card-title-container{display:flex;align-items:center;gap:8px;flex:1}.site-status-icon{width:10px;height:10px;border-radius:50%;flex-shrink:0;position:relative}.site-status-icon.normal{background-color:var(--color-normal)}.site-status-icon.caution{background-color:var(--color-caution)}.site-status-icon.warning{background-color:var(--color-warning)}.site-status-icon.danger{background-color:var(--color-danger);animation:danger-pulse 2s ease-in-out infinite}@keyframes danger-pulse{0%,to{opacity:1}50%{opacity:.7}}.site-card-title{font-size:var(--font-size-base);font-weight:600;color:var(--text-color);margin:0;word-break:break-all;line-height:1.3}.site-card-link-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;border-radius:4px;font-size:var(--font-size-md);font-weight:700}.site-card-link-icon:hover{color:var(--primary-color);background-color:var(--bg-secondary);transform:translate(2px)}.site-card-monitoring-btn{opacity:.9!important;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow-sm)!important;transition:all .3s ease!important}.site-card-monitoring-btn:hover{opacity:1!important;transform:translate(2px) scale(1.1)!important;box-shadow:var(--shadow-lg)!important}.site-card-content{display:flex;flex-direction:column}.site-card-progress-container{position:relative;margin-top:8px}.progress-labels{display:flex;position:relative;height:20px;margin-bottom:4px}.progress-labels .progress-label{position:absolute;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:opacity .2s ease}.progress-labels .progress-label:hover{opacity:.8}.progress-labels .progress-label.normal{color:var(--color-normal)}.progress-labels .progress-label.caution{color:var(--color-caution)}.progress-labels .progress-label.warning{color:var(--color-warning)}.progress-labels .progress-label.danger{color:var(--color-danger)}.site-card-progress{height:8px;background-color:var(--bg-secondary);border-radius:4px;overflow:hidden;position:relative}.progress-bar{height:100%;position:relative}.progress-fill{height:100%;position:absolute;top:0;transition:width .3s ease;cursor:pointer}.progress-fill.normal{background-color:var(--color-normal)}.progress-fill.caution{background-color:var(--color-caution)}.progress-fill.warning{background-color:var(--color-warning)}.progress-fill.danger{background-color:var(--color-danger)}[data-theme=dark] .site-card{background-color:var(--bg-card);border-color:var(--border-color)}[data-theme=dark] .site-card:hover{box-shadow:var(--shadow-lg)}[data-theme=dark] .stat-item:hover{background-color:color-mix(in srgb,white 5%,transparent)}[data-theme=dark] .site-card-progress{background-color:color-mix(in srgb,white 10%,transparent)}[data-theme=dark] .seoul-left-panel,[data-theme=dark] .seoul-middle-panel{border-color:var(--border-primary);box-shadow:0 1px 3px #0003}@media (max-width: 1400px){.site-card-stats{grid-template-columns:repeat(5,1fr);font-size:var(--font-size-sm)}.stat-value{font-size:var(--font-size-base)}}.seoul-middle-panel{grid-area:seoul-middle-panel;background:var(--bg-panel);border-radius:12px;padding:var(--spacing-sm);border:1px solid var(--border-primary);box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.map-section{background:transparent;border-radius:8px;transition:all .3s ease;overflow:hidden;display:flex;flex-direction:column;flex:1;min-height:0;height:100%}.map-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-shrink:0}.map-section h2{margin:0;font-size:var(--font-size-md);font-weight:600}.heatmap-toggle{display:flex;align-items:center;gap:8px}.heatmap-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-basic-text)}.map-area{flex:1;position:relative;border-radius:8px;overflow:hidden;height:100%;min-height:0}.company-stats{background:transparent;transition:all .3s ease;display:flex;flex-direction:column;overflow:hidden;flex:1;margin-top:10px;padding-top:8px}.company-stats-header{margin:0 0 12px;font-size:var(--font-size-lg);font-weight:600;position:relative;color:var(--text-primary);padding-bottom:8px;border-bottom:2px solid var(--border-primary);flex-shrink:0}.company-stats>div{overflow-y:auto;overflow-x:hidden}.site-table{width:100%;border-collapse:collapse}.site-table th,.site-table td{padding:8px;text-align:center;border-bottom:1px solid var(--border-primary)}.site-table th{font-weight:600;color:var(--text-primary)}.site-table td{padding:6px 8px;text-align:center;border-bottom:1px solid var(--border-primary);font-weight:500;font-size:var(--font-size-base);transition:all .2s ease;cursor:pointer;position:relative}.site-table th{cursor:pointer}.site-table td:hover{background:color-mix(in srgb,var(--primary-dark) 5%,transparent);transform:translateY(-1px);border-radius:4px}.site-table td:active{background:color-mix(in srgb,var(--primary-dark) 10%,transparent);transform:translateY(0);outline:none!important;border:none!important;box-shadow:none!important}.site-table td:focus{outline:none!important;border:none!important;box-shadow:none!important}.site-table td:focus-visible{outline:none!important;border:none!important;box-shadow:none!important}.site-table td:first-child{text-align:left;padding-left:16px}.district-number-cell{font-weight:600;font-size:var(--font-size-md);color:var(--text-primary);transition:all .2s ease;padding:8px 12px;border-radius:4px;background:var(--bg-tertiary);border:1px solid transparent}.district-number-cell:hover{background:var(--btn-primary-bg);border-color:var(--btn-primary-bg);transform:translateY(-1px);box-shadow:var(--shadow-md)}.site-table td.normal{color:var(--color-normal);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.site-table td.caution{color:var(--color-caution);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.site-table td.warning{color:var(--color-warning);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.site-table td.danger{color:var(--color-danger);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.site-table td.unknown{color:var(--status-unknown-color);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.district-sort-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:clamp(4px,1vw,8px);font-size:var(--font-sm);background:var(--bg-card);color:var(--text-primary);cursor:pointer;min-height:44px;transition:all .2s ease}.district-sort-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 25%,transparent)}.district-sort-select option{background:var(--bg-card);color:var(--text-primary)}.site-table th:first-child{text-align:left;padding:8px 16px}.district-name-link{display:flex;justify-content:space-between;align-items:center;width:100%;cursor:pointer;color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.dashboard-section{background:var(--bg-card);border-radius:clamp(6px,1vw,12px);padding:var(--spacing-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);margin-bottom:var(--spacing-md);height:fit-content}.dashboard-section.sticky{position:sticky;top:calc(clamp(56px,8vh,72px) + var(--spacing-md))}.dashboard-section h3{margin:0 0 var(--spacing-md) 0;font-size:var(--font-lg);font-weight:600;color:var(--text-primary);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-primary)}@media (min-width: 768px) and (max-width: 991.98px){.dashboard-layout{grid-template-columns:1fr;grid-template-areas:"seoul-left-panel" "seoul-middle-panel" "seoul-right-panel";height:auto;gap:4px}.seoul-left-panel,.seoul-right-panel{height:auto;max-height:400px;overflow-y:auto}.seoul-middle-panel{height:500px;min-height:500px}.toolbar{justify-content:center;margin-bottom:8px!important}.district-sort-select{width:100%;max-width:200px}}@media (min-width: 576px) and (max-width: 767.98px){.dashboard-layout{grid-template-columns:1fr;grid-template-areas:"seoul-left-panel" "seoul-middle-panel" "seoul-right-panel";height:auto;gap:2px}.seoul-left-panel,.seoul-right-panel{height:auto;max-height:350px;overflow-y:auto}.seoul-middle-panel{height:400px;min-height:400px}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.district-sort-select{width:100%;font-size:var(--font-base);min-height:48px}}@media (max-width: 575.98px){.dashboard-layout{grid-template-columns:1fr;grid-template-areas:"seoul-left-panel" "seoul-middle-panel" "seoul-right-panel";height:auto;gap:1px}.seoul-left-panel,.seoul-right-panel{height:auto;max-height:300px;overflow-y:auto}.seoul-middle-panel{height:350px;min-height:350px}.toolbar{margin-bottom:var(--spacing-xs)!important;gap:var(--spacing-xs)!important}.district-sort-select{width:100%;padding:var(--spacing-sm);font-size:var(--font-base);min-height:48px}.table{font-size:var(--font-xs)}.table th,.table td{padding:var(--spacing-xs)}}.dashboard-layout.map-focused .dashboard-main-content{grid-column:1 / -1}.dashboard-layout.map-focused .dashboard-left-sidebar,.dashboard-layout.map-focused .dashboard-right-sidebar{display:none}@media (max-width: 991.98px){.dashboard-layout.map-focused{grid-template-areas:"main-content"}}@media (hover: none) and (pointer: coarse){.district-sort-select{min-height:48px;padding:var(--spacing-sm) var(--spacing-md)}.dashboard-section:hover{transform:none;box-shadow:var(--shadow-sm)}}.map-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--bg-card);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:var(--font-size-base);z-index:10}.sensor-status-section{margin-top:var(--spacing-xl);margin-bottom:var(--spacing-md)}.site-detail-sidebar .sensor-status-overview-sidebar{margin-top:calc(var(--spacing-xl) + var(--spacing-md))}.info-tab .site-info-main-card{margin-bottom:calc(var(--spacing-xl) + var(--spacing-md))}.seoul-left-panel .sensor-status-section{width:100%}@media (max-width: 768px){.sensor-status-section{margin-top:16px;margin-bottom:12px}}.status-tab{display:flex;flex-direction:column;gap:var(--spacing-lg);padding:0}.status-tab .sensor-status-overview-sidebar,.status-tab .sensor-install-status-sidebar{margin-top:0}.status-tab>*{background:var(--bg-card);border-radius:var(--radius-md);padding:var(--spacing-md)}.page-layout{min-height:calc(100vh - 120px);padding:var(--spacing-lg);max-width:1920px;margin:0 var(--spacing-xl) 80px var(--spacing-xl);display:flex;flex-direction:column;gap:8px}@media (max-width: 768px){.page-layout{min-height:calc(100vh - 140px);margin:80px var(--spacing-xs) 120px var(--spacing-xs);padding:var(--spacing-md);gap:var(--spacing-md)}}@media (max-width: 480px){.page-layout{min-height:calc(100vh - 120px);margin:80px 5px 150px;padding:var(--spacing-sm);gap:var(--spacing-sm)}}@media (min-width: 1200px){.page-layout{padding:var(--spacing-lg)}}@media (min-width: 1600px){.page-layout{padding:var(--spacing-lg) var(--spacing-sm)}}@media (max-width: 480px){.page-content{max-height:calc(100vh - 180px);padding-bottom:30px}}.seoul-left-panel{padding:var(--spacing-lg) var(--spacing-md) var(--spacing-md) var(--spacing-md);border-radius:var(--radius-sm);display:flex;flex-direction:column}.seoul-middle-panel,.seoul-right-panel{padding:var(--spacing-md);border-radius:var(--radius-sm);display:flex;flex-direction:column}.monitoring-stats-cards{display:flex;flex-direction:column;gap:var(--spacing-sm);flex-shrink:0;margin-bottom:var(--spacing-md)}.monitoring-stat-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.monitoring-stat-card{background:var(--bg-card);border-radius:var(--radius-sm);padding:var(--spacing-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;transition:all .3s ease}.monitoring-stat-card-large{padding:var(--spacing-md) var(--spacing-md);min-height:60px}.monitoring-section{background:var(--bg-card);border-radius:var(--radius-sm);padding:var(--spacing-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);transition:all .3s ease;display:flex;flex-direction:column;overflow:hidden;flex:1}.monitoring-section h2{margin:0 0 var(--spacing-md);font-size:16px;font-weight:600;position:relative;background:var(--bg-card);color:var(--text-primary);z-index:1;padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--border-primary);flex-shrink:0}.monitoring-section>div{flex:1;overflow-y:auto;border:1px solid var(--border-primary);border-radius:var(--radius-xs);overflow-x:hidden}@media (max-width: 480px){.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.header-actions{width:100%;justify-content:flex-end}.page-title{font-size:20px}}.breadcrumb{display:flex;align-items:center;gap:8px;padding:var(--spacing-sm) 0;font-size:14px;color:var(--text-secondary);margin-bottom:4px}.breadcrumb-link{color:var(--btn-primary-bg);text-decoration:none;transition:color .2s}.breadcrumb-link:hover{color:var(--btn-primary-hover)}.breadcrumb-separator{color:var(--text-muted);margin:0 var(--spacing-xs);font-size:12px}.breadcrumb-current{color:var(--text-primary);font-weight:500}.page-title-section{display:flex;flex-direction:column;gap:var(--spacing-xs)}.page-subtitle{font-size:14px;color:var(--text-secondary);margin:0;font-weight:400}@media (max-width: 768px){.unified-page-header{flex-wrap:wrap;gap:var(--spacing-sm)}.unified-page-header__left{flex:1;min-width:200px;display:flex;align-items:center;gap:var(--spacing-sm)}.unified-page-header__right{flex-shrink:0}.unified-page-header .btn-functional .text,.unified-page-header .btn-state .text,.unified-page-header .btn-functional span:not(.icon),.unified-page-header .btn-state span:not(.icon){display:none!important}.unified-page-header .btn-functional,.unified-page-header .btn-state{font-size:0!important}.unified-page-header .btn-functional .icon,.unified-page-header .btn-state .icon{font-size:16px!important;margin:0!important}.unified-page-header .btn-functional .icon[style*=marginRight],.unified-page-header .btn-state .icon[style*=marginRight]{margin-right:0!important}.unified-page-header .btn-functional,.unified-page-header .btn-state{min-width:40px!important;min-height:40px!important;width:40px!important;height:40px!important;max-width:40px!important;max-height:40px!important;padding:0!important;margin:0!important;border-radius:50%!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;box-sizing:border-box!important;text-align:center!important;gap:0!important;overflow:hidden!important}.unified-page-header .btn-functional:hover,.unified-page-header .btn-state:hover{transform:scale(1.05)!important}.unified-page-header .btn-functional .icon,.unified-page-header .btn-state .icon{margin:0!important}}@media (max-width: 480px){.unified-page-header .btn-functional,.unified-page-header .btn-state{min-width:36px!important;min-height:36px!important;width:36px!important;height:36px!important;max-width:36px!important;max-height:36px!important;padding:0!important;margin:0!important;border-radius:50%!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;flex-shrink:0!important;box-sizing:border-box!important;text-align:center!important;gap:0!important;overflow:hidden!important}.unified-page-header__left{min-width:150px}}.page-tabs-container{margin-bottom:var(--spacing-md)}.page-tabs-wrapper{position:relative;border-bottom:1px solid var(--border-primary)}.page-tabs{display:flex;align-items:center;gap:0;background:transparent;padding:0;border:none;position:relative;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.page-tabs::-webkit-scrollbar{display:none}.page-tabs-border{position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--border-primary)}.page-tab{display:flex;align-items:center;gap:8px;padding:0 var(--spacing-md);background:transparent;border:none!important;border-bottom:2px solid transparent!important;border-top:none!important;border-left:none!important;border-right:none!important;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;font-size:14px;min-height:32px;position:relative;border-radius:0;outline:none!important}.page-tab:hover:not(.active){background:var(--bg-hover);color:var(--text-primary);border:none!important;border-bottom:2px solid transparent!important;border-top:none!important;border-left:none!important;border-right:none!important;outline:none!important}.page-tab.active{background:transparent;color:var(--primary);border:none!important;border-bottom:2px solid var(--primary)!important;border-top:none!important;border-left:none!important;border-right:none!important;font-weight:600;outline:none!important}.page-tab,.page-tab:hover,.page-tab:focus,.page-tab:focus-visible,.page-tab:active,.page-tab:visited,.page-tab.active,.page-tab.active:hover,.page-tab.active:focus,.page-tab.active:focus-visible,.page-tab.active:active{border-top:0!important;border-left:0!important;border-right:0!important;border-top-width:0!important;border-left-width:0!important;border-right-width:0!important;border-top-style:none!important;border-left-style:none!important;border-right-style:none!important;outline:0!important;outline-width:0!important;outline-style:none!important;box-shadow:none!important}.page-tab.active,.page-tab.active:hover,.page-tab.active:focus,.page-tab.active:focus-visible,.page-tab.active:active{border-bottom:2px solid var(--primary)!important;border-bottom-width:2px!important;border-bottom-style:solid!important;border-bottom-color:var(--primary)!important}.page-tab:not(.active){border-bottom:2px solid transparent!important;border-bottom-width:2px!important;border-bottom-style:solid!important;border-bottom-color:transparent!important}.page-tab .tab-icon{width:16px;height:16px;flex-shrink:0;color:currentColor}.page-tab .tab-label{color:currentColor}.tab-button{display:flex;align-items:center;gap:8px;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--border-radius-sm);color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.tab-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tab-button.active{background:var(--bg-primary);color:var(--primary);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.tab-icon{width:16px;height:16px;flex-shrink:0}.tab-label{font-size:14px}@media (max-width: 768px){.page-tab{padding:0 var(--spacing-sm);min-width:fit-content;font-size:13px}.page-tab .tab-icon{width:14px;height:14px}.page-tab .tab-label{font-size:13px}}@media (max-width: 480px){.page-tab{padding:0 var(--spacing-xs);gap:var(--spacing-xs);font-size:12px;min-height:28px}.page-tab .tab-icon{width:12px;height:12px}.page-tab .tab-label{font-size:12px}}.page-content{flex:1;display:flex;flex-direction:column;min-height:0;padding-bottom:60px}.page-layout.sensor-detail-page{gap:0}.page-layout.sensor-detail-page .page-content{padding-bottom:40px;height:calc(100vh - 180px);overflow:hidden;min-height:0}.page-menu-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px;background:transparent;border:none;border-radius:50%;color:var(--text-primary);cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);min-width:40px;min-height:40px;margin-right:var(--spacing-sm);font-size:0;outline:none}.page-menu-btn:hover{background-color:#0000000a;transform:none;box-shadow:none}.page-menu-btn:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.page-menu-btn:active{background-color:#0000001a;transition:background-color .15s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .page-menu-btn:hover{background-color:#ffffff14}[data-theme=dark] .page-menu-btn:active{background-color:#ffffff1f}.unified-page-header__left{display:flex;align-items:center;gap:var(--spacing-sm)}.common-filter{background:transparent;padding:16px;border-radius:6px;margin-bottom:16px;border:none;width:100%;box-sizing:border-box}.filter-row{display:flex;justify-content:flex-start;align-items:end;gap:4px;flex-wrap:nowrap}.right-controls{display:flex;gap:4px;align-items:end;flex-wrap:nowrap;margin-left:auto}.search-input-container{position:relative;min-width:60px;flex-shrink:5;max-width:120px;width:120px}.search-input{width:100%;padding:8px 40px 8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;background:var(--bg-card);color:var(--text-primary)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4263eb40}.search-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.filter-controls{display:flex;gap:4px;align-items:end;flex-wrap:nowrap}.filter-item{display:flex;flex-direction:column;gap:4px;min-width:60px;flex-shrink:1}.filter-item label{font-size:12px;font-weight:500;color:var(--text-muted)}.filter-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:14px;background:var(--bg-card);color:var(--text-primary);cursor:pointer}.filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4263eb40}.active-filters{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.active-filters-label{font-size:12px;font-weight:500;color:var(--text-muted);margin-bottom:8px}.active-filters-list{display:flex;gap:8px;flex-wrap:wrap}.active-filter-tag{display:inline-flex;align-items:center;background:var(--primary-color);color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;gap:6px}.filter-remove-btn{background:none;border:none;color:#fff;font-size:14px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;margin-left:2px}.filter-remove-btn:hover{background:#fff3}.sort-filter{min-width:140px}@media (max-width: 768px){.filter-row{flex-direction:column;align-items:stretch}.search-input-container{min-width:auto}.right-controls{flex-direction:column;align-items:stretch}.filter-controls{justify-content:flex-start}.filter-item{min-width:100px;flex:1}.active-filters-list{gap:6px}.active-filter-tag{font-size:11px;padding:3px 6px}}:root{--error-handling-toast-bg: rgba(255, 255, 255, .6);--error-handling-toast-border: var(--border-light);--error-handling-toast-text: #1f2937;--error-handling-toast-success-accent: var(--status-success);--error-handling-toast-warning-accent: var(--status-warning);--error-handling-toast-error-accent: var(--status-error);--error-handling-toast-info-accent: var(--status-info);--error-handling-modal-backdrop: var(--overlay-bg);--error-handling-modal-bg: var(--bg-card);--error-handling-modal-border: var(--border-primary);--error-handling-modal-text: var(--text-primary);--error-handling-modal-shadow: var(--shadow-xl);--error-handling-form-error-bg: var(--error-bg);--error-handling-form-error-border: var(--error-border);--error-handling-form-error-text: var(--error-text);--error-handling-spinner-primary: var(--primary-color);--error-handling-spinner-bg: var(--spinner-bg);--error-handling-toast-width-mobile: 92vw;--error-handling-toast-width-desktop: 420px;--error-handling-toast-max-width: 550px;--error-handling-toast-min-height: 72px;--error-handling-toast-padding: 18px 24px;--error-handling-modal-max-width: 500px;--error-handling-modal-min-width: 320px;--error-handling-modal-padding: var(--spacing-xl);--error-handling-form-error-padding: var(--spacing-sm) var(--spacing-md);--error-handling-form-error-margin-top: var(--spacing-xs);--error-handling-form-error-font-size: .875rem;--error-handling-border-radius: var(--radius-md);--error-handling-border-width: 2px;--error-handling-shadow-toast: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .05);--error-handling-shadow-modal: var(--shadow-xl);--error-handling-z-toast: 1070;--error-handling-z-modal: 1050;--error-handling-z-loading: 1060;--error-handling-transition-fast: .15s ease-in-out;--error-handling-transition-normal: .25s ease-in-out;--error-handling-transition-slow: .35s ease-in-out;--error-handling-toast-duration-success: 4s;--error-handling-toast-duration-info: 5s;--error-handling-toast-duration-warning: 6s;--error-handling-toast-duration-error: 8s;--error-handling-icon-size-sm: 16px;--error-handling-icon-size-md: 20px;--error-handling-icon-size-lg: 24px}@media (prefers-color-scheme: dark){:root{--color-gray-50: #111827;--color-gray-100: #1f2937;--color-gray-200: #374151;--color-gray-300: #4b5563;--color-gray-400: #6b7280;--color-gray-500: #9ca3af;--color-gray-600: #d1d5db;--color-gray-700: #e5e7eb;--color-gray-800: #f3f4f6;--color-gray-900: #f9fafb;--modal-content-bg: var(--color-gray-100);--modal-backdrop-bg: rgba(0, 0, 0, .7);--error-handling-toast-bg: rgba(26, 26, 26, .6);--error-handling-toast-border: var(--border-primary);--error-handling-toast-text: #f9fafb}}.text-success{color:var(--color-success-600)}.text-warning{color:var(--color-warning-600)}.text-danger{color:var(--color-danger-600)}.text-info{color:var(--color-info-600)}.bg-success{background-color:var(--color-success-50)}.bg-warning{background-color:var(--color-warning-50)}.bg-danger{background-color:var(--color-danger-50)}.bg-info{background-color:var(--color-info-50)}.border-success{border-color:var(--color-success-200)}.border-warning{border-color:var(--color-warning-200)}.border-danger{border-color:var(--color-danger-200)}.border-info{border-color:var(--color-info-200)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.system-status{display:flex;align-items:center;justify-content:center;min-height:200px;padding:var(--spacing-6);text-align:center}.system-status__content{max-width:400px;padding:var(--spacing-6);border-radius:var(--border-radius-lg);background:var(--color-background-elevated);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm)}.system-status__icon{font-size:2.5rem;margin-bottom:var(--spacing-4)}.system-status__title{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-3);color:var(--color-text-primary)}.system-status__message{font-size:.95rem;color:var(--color-text-secondary);line-height:1.5;margin-bottom:24px}.system-status__actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}.system-status__notice{margin:16px 0;padding:8px 12px;background-color:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:4px}.system-status__notice small{color:#856404;font-size:.85rem;line-height:1.4;font-weight:500}.system-status--loading .system-status__content{background:var(--color-info-light);border-color:var(--color-info-border)}.system-status--loading .system-status__title{color:var(--color-info)}.system-status--network .system-status__content{background:var(--color-warning-light);border-color:var(--color-warning-border)}.system-status--network .system-status__title{color:var(--color-warning)}.system-status--auth .system-status__content{background:var(--color-warning-light);border-color:var(--color-warning-border)}.system-status--auth .system-status__title{color:var(--color-warning)}.system-status--error .system-status__content{background:var(--color-error-light);border-color:var(--color-error-border)}.system-status--error .system-status__title{color:var(--color-error)}.system-status--empty .system-status__content{background:var(--color-background-elevated);border-color:var(--color-border-subtle)}.system-status--empty .system-status__title{color:var(--color-text-secondary)}@media (max-width: 768px){.system-status{min-height:150px;padding:var(--spacing-4)}.system-status__content{padding:var(--spacing-4)}.system-status__icon{font-size:2rem}.system-status__title{font-size:1.1rem}.system-status__message{font-size:.9rem}.system-status__actions{flex-direction:column;align-items:center}}[data-theme=dark] .system-status__content{background:var(--color-dark-surface);border-color:var(--color-dark-border)}[data-theme=dark] .system-status__title{color:var(--color-dark-text-primary)}[data-theme=dark] .system-status__message{color:var(--color-dark-text-secondary)}[data-theme=dark] .system-status__notice small{color:var(--color-dark-text-tertiary)}
