:root{--bg-primary: #0F172A;--bg-secondary: #1E293B;--bg-tertiary: #334155;--border-default: #475569;--border-light: rgba(71, 85, 105, .4);--text-primary: #F1F5F9;--text-secondary: #94A3B8;--text-muted: #64748B;--accent-primary: #3B82F6;--accent-hover: #2563EB;--status-up: #22C55E;--status-warning: #EAB308;--status-critical: #EF4444;--status-unknown: #6B7280;--status-acknowledged: #3B82F6;--chart-in: #3B82F6;--chart-out: #F97316;--space-1: 2px;--space-2: 4px;--space-3: 8px;--space-4: 12px;--space-5: 16px;--space-6: 24px;--space-7: 32px;--space-8: 48px;--sidebar-width: 240px;--radius: 8px;--radius-sm: 6px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;line-height:1.5;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--accent-primary);text-decoration:none}a:hover{color:var(--accent-hover)}h1{font-size:24px;font-weight:600;line-height:1.2}h2{font-size:18px;font-weight:600;line-height:1.3}h3{font-size:14px;font-weight:600}h4{font-size:13px;font-weight:600;color:var(--text-secondary)}code,.mono{font-family:Fira Code,monospace;font-size:12px}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-default);display:flex;flex-direction:column;overflow-y:auto;transition:width .25s ease,min-width .25s ease}.sidebar--collapsed{width:60px;min-width:60px}.sidebar-header{height:46px;min-height:46px;padding:0 20px;border-bottom:1px solid var(--border-light);display:flex;flex-wrap:nowrap;align-items:center;gap:8px;position:relative}.sidebar--collapsed .sidebar-header{padding:0 10px;justify-content:center}.sidebar-collapse-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s;margin-left:auto}.sidebar-collapse-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.sidebar--collapsed .sidebar-collapse-btn{margin:4px auto 0}.sidebar-section-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:.75rem 1rem .25rem;white-space:nowrap;overflow:hidden}.sidebar-brand{font-size:18px;font-weight:700;letter-spacing:-.5px;line-height:1}.sidebar-subtitle{font-size:10px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:1px}.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;font-weight:500;transition:all .15s ease;text-decoration:none}.sidebar-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-link--active{background:#3b82f626;color:var(--accent-primary)}.sidebar-link__icon{font-size:16px;width:22px;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-link__label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar--collapsed .sidebar-link{justify-content:center;padding:10px 8px}.sidebar--collapsed .sidebar-link__icon{width:auto}.sidebar--collapsed .sidebar-nav{padding:12px 6px}.sidebar-footer{height:36px;min-height:36px;padding:0 16px;border-top:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between;gap:8px}.sidebar--collapsed .sidebar-footer{flex-direction:column;height:auto;min-height:36px;padding:6px;gap:6px}.sidebar-user{display:flex;align-items:center;gap:10px;min-width:0}.sidebar-user__avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.sidebar-user__info{display:flex;flex-direction:column;min-width:0}.sidebar-user__name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user__role{font-size:11px;color:var(--text-muted);text-transform:capitalize}.main-content{flex:1;overflow-y:auto;padding:28px 32px;background:var(--bg-primary)}.main-wrapper{display:flex;flex-direction:column;flex:1;min-width:0;height:100vh;overflow:hidden}.main-wrapper>.main-content{flex:1;overflow-y:auto}.app-top-header{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:46px;min-height:46px;background:var(--bg-secondary);border-bottom:1px solid var(--border-light)}.app-top-header__left{display:flex;align-items:center;gap:10px;flex:1}.app-top-header__center{display:flex;align-items:center;justify-content:center;flex:1}.app-top-header__brand{font-size:14px;font-weight:600;color:var(--text-primary);letter-spacing:.2px}.app-top-header__right{display:flex;align-items:center;justify-content:flex-end;gap:10px;font-size:13px;flex:1}.app-top-header__user{color:var(--text-secondary)}.app-top-header__role{font-size:10px;padding:2px 8px;border-radius:10px;background:#3b82f61f;color:var(--accent-primary);text-transform:capitalize;font-weight:600}.app-footer{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:36px;min-height:36px;background:var(--bg-secondary);border-top:1px solid var(--border-light);font-size:11px;color:var(--text-muted)}.app-footer__left,.app-footer__right{display:flex;align-items:center;gap:6px}.app-footer__sep{opacity:.4}.sidebar-expand-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:4px;display:flex;align-items:center;transition:color .15s,background .15s}.sidebar-expand-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.sidebar-children{padding-left:14px}.sidebar-link--child{font-size:13px;padding:6px 12px 6px 18px;color:var(--text-secondary)}.sidebar-link--child:hover{color:var(--text-primary)}.sidebar-link--child .sidebar-link__icon{width:24px;height:24px;min-width:24px}.page{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-title{font-size:22px;font-weight:700;color:var(--text-primary)}.page-loading{display:flex;align-items:center;justify-content:center;height:60vh;color:var(--text-secondary);font-size:15px}.loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-secondary);font-size:16px}.login-card{width:100%;max-width:420px;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:16px;padding:44px 40px 36px;box-shadow:0 0 0 1px #3b82f614,0 20px 60px #00000073,0 4px 16px #0003}.login-logo{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:32px}.login-logo__icon{margin-bottom:4px}.login-logo__title{font-size:30px;font-weight:700;letter-spacing:-.5px;color:var(--text-primary);margin:0}.login-logo__subtitle{font-size:13px;color:var(--text-muted);font-weight:500;letter-spacing:.3px;margin:0}.login-error{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--status-critical);background:#ef44441a;border:1px solid rgba(239,68,68,.25);margin-bottom:8px}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:7px}.login-field label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.login-field input{width:100%;padding:11px 14px;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s;outline:none}.login-field input::placeholder{color:var(--text-muted)}.login-field input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f62e}.login-submit{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;margin-top:4px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s,transform .1s}.login-submit:hover:not(:disabled){background:var(--accent-hover)}.login-submit:active:not(:disabled){transform:scale(.98)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.login-footer{text-align:center;font-size:11px;color:var(--text-muted);margin-top:24px;letter-spacing:.3px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus,.btn:focus-visible{outline:none;box-shadow:none}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--border-default)}.btn-danger{background:var(--status-critical);color:#fff}.btn-danger:hover{background:#dc2626}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-sm{padding:5px 10px;font-size:12px}.btn-block{width:100%}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:11px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.form-control{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:9px 12px;font-size:13px;font-family:inherit;width:100%;transition:border-color .15s,box-shadow .15s}.form-control:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f626}.form-check{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);cursor:pointer;white-space:nowrap}.form-check input[type=checkbox]{width:auto;accent-color:var(--accent-primary)}input,select,textarea{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:9px 12px;font-size:13px;font-family:inherit}select{cursor:pointer}.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500}.alert-danger{background:#ef444426;color:var(--status-critical);border:1px solid rgba(239,68,68,.3)}.card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-light)}.card-body{padding:16px 18px}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:10px 14px;border-bottom:1px solid var(--border-default);background:#0f172a66}.table td{padding:11px 14px;border-bottom:1px solid var(--border-light);font-size:13px;vertical-align:middle}.table tbody tr{transition:background .1s}.table tbody tr:hover{background:#33415540}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:9999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.badge--critical{background:#ef444426;color:var(--status-critical)}.badge--warning{background:#eab30826;color:var(--status-warning)}.badge--info{background:#3b82f626;color:var(--accent-primary)}.badge--open{background:#eab30826;color:var(--status-warning)}.badge--resolved{background:#22c55e26;color:var(--status-up)}.badge--acknowledged{background:#3b82f626;color:var(--status-acknowledged)}.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--status-unknown);flex-shrink:0}.status-dot.online{background:var(--status-up);box-shadow:0 0 6px #22c55e80}.status-dot.offline{background:var(--status-critical);box-shadow:0 0 6px #ef444466}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:24px}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius);padding:18px 20px;text-align:center;transition:border-color .15s}.stat-card:hover{border-color:var(--border-default)}.stat-card--success{border-left:3px solid var(--status-up)}.stat-card--warning{border-left:3px solid var(--status-warning)}.stat-card--danger{border-left:3px solid var(--status-critical)}.stat-card__value{display:block;font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.1}.stat-card__label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-top:6px}.stat-card--clickable{cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s}.stat-card--clickable:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #00000040}.stat-card__icon-wrap{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;margin:0 auto 8px;background:#3b82f61a;color:var(--accent-primary)}.filter-bar{display:flex;gap:10px;margin-bottom:18px}.filter-bar .form-control{max-width:280px}.filter-bar select.form-control{max-width:200px}.inline-form{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}.inline-form .form-control{width:auto;min-width:140px;flex:1}.dashboard-panels{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 1100px){.dashboard-panels{grid-template-columns:1fr}}.dashboard-panel{min-height:300px}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.device-tile{display:flex;flex-direction:column;gap:4px;padding:12px 14px;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm);transition:all .15s;text-decoration:none;color:var(--text-primary)}.device-tile:hover{border-color:var(--accent-primary);background:#3b82f60f;color:var(--text-primary)}.device-tile__status{align-self:flex-start}.device-tile__name{font-weight:600;font-size:13px}.device-tile__type{font-size:11px;color:var(--text-muted);text-transform:capitalize}.device-tile__ip{font-family:Fira Code,monospace;font-size:11px;color:var(--text-secondary)}.tab-bar{display:flex;align-items:center;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border-light);padding-bottom:0}.tab{padding:10px 18px;border:none;background:none;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;font-family:inherit}.tab:hover{color:var(--text-primary)}.tab--active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.tab-bar__right{margin-left:auto;display:flex;gap:4px;padding-bottom:6px}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}@media (max-width: 1000px){.charts-grid{grid-template-columns:1fr}}.chart-card{padding:18px}.chart-card h4{margin-bottom:14px}.chart-wrapper{height:220px;position:relative}.link{color:var(--accent-primary);text-decoration:none;font-weight:500}.link:hover{text-decoration:underline}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-default)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.alert:before{font-size:1rem;flex-shrink:0}.alert-danger{background:#ef444426;border:1px solid var(--status-critical);color:var(--status-critical)}.alert-danger:before{content:"⛔"}.alert-warning{background:#eab30826;border:1px solid var(--status-warning);color:var(--status-warning)}.alert-warning:before{content:"⚠️"}.alert-success{background:#22c55e26;border:1px solid var(--status-up);color:var(--status-up)}.alert-success:before{content:"✅"}.alert-info{background:#3b82f626;border:1px solid var(--accent-primary);color:var(--accent-primary)}.alert-info:before{content:"ℹ️"}.toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer;gap:8px}.toggle__input{width:0;height:0;opacity:0;position:absolute}.toggle__track{width:36px;height:20px;border-radius:10px;background:var(--bg-tertiary);border:1px solid var(--border-default);transition:background .2s,border-color .2s;position:relative}.toggle__input:checked+.toggle__track{background:var(--accent-primary);border-color:var(--accent-primary)}.toggle__track:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s}.toggle__input:checked+.toggle__track:after{transform:translate(16px)}.toggle__label{font-size:13px;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.tooltip-wrapper{position:relative;display:inline-block}.tooltip-wrapper .tooltip-text{visibility:hidden;opacity:0;position:absolute;z-index:100;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);white-space:nowrap;padding:5px 10px;border-radius:6px;font-size:12px;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-default);box-shadow:0 4px 12px #0000004d;transition:opacity .15s,visibility .15s;pointer-events:none}.tooltip-wrapper:hover .tooltip-text{visibility:visible;opacity:1}.badge-info{background:#3b82f62e;color:#60a5fa}.page-subtitle{color:var(--text-muted);font-size:13px;margin:-4px 0 8px}.stat-cards-row{display:flex;gap:12px;margin-bottom:18px;flex-wrap:wrap}.stat-mini{flex:1 1 140px;min-width:130px;max-width:220px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:10px;padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:border-color .15s,background .15s}.stat-mini:hover{border-color:var(--accent-primary)}.stat-mini--active{border-color:var(--accent-primary);background:#3b82f60f}.stat-mini--success{border-left:3px solid var(--status-up)}.stat-mini--danger{border-left:3px solid var(--status-critical)}.stat-mini__icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;background:#3b82f61a;color:var(--accent-primary);flex-shrink:0}.stat-mini--success .stat-mini__icon{background:#22c55e1f;color:var(--status-up)}.stat-mini--danger .stat-mini__icon{background:#ef44441f;color:var(--status-critical)}.stat-mini__value{font-size:20px;font-weight:700;color:var(--text-primary);line-height:1}.stat-mini__label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}.devices-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.devices-toolbar__search{position:relative;flex:1 1 240px;max-width:360px}.devices-toolbar__search-icon{position:absolute;top:50%;left:10px;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.devices-toolbar__search .form-control{padding-left:34px}.devices-toolbar__filters{display:flex;gap:8px;align-items:center}.btn-group{display:inline-flex;border:1px solid var(--border-default);border-radius:8px;overflow:hidden}.btn-group .btn{border-radius:0;border:none;border-right:1px solid var(--border-default);font-size:12px;padding:6px 12px;text-decoration:none;outline:none;box-shadow:none}.btn-group .btn:focus,.btn-group .btn:focus-visible{outline:none;box-shadow:none}.btn-group .btn:last-child{border-right:none}.btn-group .btn-primary{background:var(--accent-primary);color:#fff}.btn-group .btn-ghost{background:var(--bg-secondary);color:var(--text-secondary)}.btn-group .btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.device-group-section{margin-bottom:8px;border:1px solid var(--border-default);border-radius:10px;overflow:hidden;background:var(--bg-secondary)}.device-group-header{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s}.device-group-header:hover{background:#3b82f60a}.device-group-header svg:first-child{transition:transform .2s;color:var(--text-muted)}.device-group-header--expanded svg:first-child{transform:rotate(90deg)}.device-group-header__label{font-weight:600;font-size:14px;color:var(--text-primary);flex:1}.device-group-header__count{font-size:12px;color:var(--text-muted);margin-right:4px}.device-group-body{padding:4px 12px 12px;display:flex;flex-direction:column;gap:6px}.device-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-primary);border:1px solid var(--border-default);border-radius:8px;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s}.device-card:hover{border-color:var(--accent-primary);box-shadow:0 2px 8px #3b82f61a}.device-card--selected{border-color:var(--accent-primary);background:#3b82f60a}.device-card__select{flex-shrink:0}.device-card__status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.device-card__status--online{background:var(--status-up);box-shadow:0 0 6px #22c55e80}.device-card__status--offline{background:var(--status-critical);box-shadow:0 0 6px #ef444466}.device-card__icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:7px;background:#3b82f614;color:var(--accent-primary);flex-shrink:0}.device-card__info{flex:1;min-width:0}.device-card__name{font-weight:600;font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.device-card__meta{font-size:11px;color:var(--text-muted);display:flex;gap:6px;align-items:center;margin-top:2px}.device-card__sep{color:var(--border-default)}.device-card__stats{display:flex;gap:12px;flex-shrink:0}.device-card__stat{font-size:11px;color:var(--text-secondary);white-space:nowrap}.device-card__stat strong{font-weight:600}.device-card__heartbeat{font-size:11px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.device-card__actions{flex-shrink:0;display:flex;gap:4px}.status-pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.status-pill--success{background:#22c55e26;color:var(--status-up)}.status-pill--danger{background:#ef444426;color:var(--status-critical)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .12s,color .12s;padding:0}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon--danger:hover{background:#ef44441f;color:var(--status-critical)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:30vh;color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:20vh;color:var(--text-muted);font-size:14px}.clickable-row{cursor:pointer;transition:background .12s}.clickable-row:hover{background:#3b82f60a}.row--selected{background:#3b82f614!important}.form-control--sm{height:32px;font-size:12px;padding:4px 10px}.spin{animation:spin 1s linear infinite}.text-success{color:var(--status-up)!important}.text-danger{color:var(--status-critical)!important}.text-warning{color:var(--status-warning)!important}.mono{font-family:JetBrains Mono,Fira Code,monospace}.detail-header{margin-bottom:16px}.detail-header__back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);text-decoration:none;margin-bottom:10px;transition:color .15s}.detail-header__back:hover{color:var(--accent-primary)}.detail-header__main{display:flex;flex-direction:column;gap:4px}.detail-header__title-row{display:flex;align-items:center;gap:10px}.detail-header__name{font-size:22px;font-weight:700;color:var(--text-primary);margin:0}.status-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0}.status-indicator--online{background:var(--status-up);box-shadow:0 0 8px #22c55e80}.status-indicator--offline{background:var(--status-critical);box-shadow:0 0 8px #ef444480}.detail-header__subtitle{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);flex-wrap:wrap}.detail-sep{color:var(--border-default);font-size:10px}.detail-sys-info{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.sys-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:8px;background:var(--bg-secondary);border:1px solid var(--border-default);font-size:12px;color:var(--text-secondary);white-space:nowrap}.sys-pill svg{color:var(--text-muted);flex-shrink:0}.sys-pill strong{color:var(--text-primary);font-weight:600;margin-right:2px}.detail-hero-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:18px}.detail-hero-card{display:flex;align-items:stretch;gap:14px;padding:16px 18px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:12px;transition:border-color .15s}.detail-hero-card:hover{border-color:var(--accent-primary)}.detail-hero-card__icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:#3b82f614;flex-shrink:0}.detail-hero-card__body{flex:1}.detail-hero-card__label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:2px}.detail-hero-card__value{font-size:24px;font-weight:700;color:var(--text-primary);line-height:1.1}.detail-hero-card__detail{font-size:12px;color:var(--text-muted);margin-top:4px}.detail-hero-card__bar{width:6px;border-radius:3px;flex-shrink:0;display:flex;align-items:flex-end}.detail-hero-card__bar-track{width:100%;height:48px;border-radius:3px;background:var(--bg-primary);overflow:hidden;display:flex;align-items:flex-end}.detail-hero-card__bar-fill{width:100%;border-radius:3px;transition:height .4s ease}.detail-snmp-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 16px;margin-bottom:16px;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:10px;font-size:12px}.detail-snmp-bar__title{font-weight:700;color:var(--text-primary);margin-right:4px}.chart-card__header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.chart-card__header h4{margin:0;flex:1}.chart-card__badge{display:inline-block;font-size:13px;font-weight:700;padding:2px 10px;border-radius:8px;background:#3b82f61f;color:var(--accent-primary)}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.hamburger-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s;padding:0}.hamburger-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:998;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 1024px){.main-content{padding:20px}.app-top-header,.app-footer{padding:0 20px}.filter-bar{flex-wrap:wrap}.filter-bar .form-control{max-width:100%}.stat-cards-row{gap:8px}.stat-mini{min-width:110px;padding:10px 12px}.detail-hero-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (max-width: 768px){.hamburger-btn{display:flex}.sidebar{position:fixed;z-index:999;top:0;left:0;height:100vh;width:var(--sidebar-width);min-width:var(--sidebar-width);transform:translate(-100%);transition:transform .3s ease;box-shadow:none}.sidebar--mobile-open{transform:translate(0);box-shadow:4px 0 24px #0006}.sidebar-overlay--visible{display:block}.main-wrapper{width:100%}.main-content{padding:16px 14px}.app-top-header,.app-footer{padding:0 14px}.page-header{flex-direction:column;align-items:flex-start;gap:10px}.page-title{font-size:18px}.app-top-header__center{display:none}.app-top-header__right{gap:6px;font-size:12px}.app-top-header__user{display:none}.app-footer{flex-direction:column;height:auto;padding:8px 14px;gap:2px;text-align:center}.app-footer__left,.app-footer__right{justify-content:center}.table-wrapper{margin:0 -14px;padding:0 14px}.table th,.table td{padding:8px 10px;font-size:12px}.table th{font-size:10px}.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card__value{font-size:22px}.stat-cards-row{gap:6px}.stat-mini{min-width:0;flex:1 1 calc(50% - 6px);max-width:none;padding:10px}.stat-mini__value{font-size:16px}.stat-mini__icon{width:30px;height:30px}.filter-bar{flex-direction:column;gap:8px}.filter-bar .form-control,.filter-bar select.form-control{max-width:100%}.devices-toolbar{flex-direction:column;align-items:stretch;gap:8px}.devices-toolbar__search{max-width:100%;flex:1 1 100%}.devices-toolbar__filters{flex-wrap:wrap;width:100%}.devices-toolbar__filters select,.devices-toolbar__filters .form-control{flex:1;min-width:0}.btn-group .btn{padding:6px 10px;font-size:11px}.device-card{flex-wrap:wrap;gap:8px;padding:10px 12px}.device-card__stats{display:none}.device-card__heartbeat{font-size:10px}.dashboard-panels{grid-template-columns:1fr;gap:14px}.charts-grid{grid-template-columns:1fr}.chart-wrapper{height:180px}.detail-hero-row{grid-template-columns:1fr}.detail-hero-card{padding:12px 14px}.detail-hero-card__value{font-size:20px}.detail-header__name{font-size:18px}.detail-sys-info{gap:6px}.sys-pill{font-size:11px;padding:4px 10px}.detail-snmp-bar{flex-direction:column;align-items:flex-start;gap:6px;font-size:11px}.card-header{padding:10px 14px}.card-body{padding:12px 14px}.tab-bar{gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{padding:8px 12px;font-size:12px;white-space:nowrap}.tab-bar__right{padding-bottom:4px}.inline-form{flex-direction:column}.inline-form .form-control{width:100%;min-width:0}.login-card{padding:28px 20px 24px;border-radius:12px;margin:0 12px}.login-logo__title{font-size:24px}.device-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}}@media (max-width: 480px){.main-content{padding:12px 10px}.stat-grid{grid-template-columns:1fr}.stat-mini{flex:1 1 100%}.page-title{font-size:16px}h2{font-size:15px}.detail-hero-card__icon{width:36px;height:36px}.detail-hero-card__value{font-size:18px}.btn{padding:7px 12px;font-size:12px}.btn-sm{padding:4px 8px;font-size:11px}.badge{font-size:10px;padding:2px 8px}}
