*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit}input,textarea,select{font:inherit}img{max-width:100%;display:block}ul,ol{list-style:none}:root[data-theme=light]{--color-bg-primary: #FFFFFF;--color-bg-secondary: #F5F7FA;--color-bg-tertiary: #EEF1F6;--color-bg-overlay: rgba(0, 0, 0, .3);--color-surface-default: #FFFFFF;--color-surface-raised: #FFFFFF;--color-surface-overlay: #F9FAFB;--color-brand-primary: #1A6FBF;--color-brand-secondary: #0EA5E9;--color-brand-accent: #F59E0B;--color-text-primary: #111827;--color-text-secondary: #4B5563;--color-text-tertiary: #9CA3AF;--color-text-disabled: #D1D5DB;--color-text-on-brand: #FFFFFF;--color-border-default: #E5E7EB;--color-border-strong: #D1D5DB;--color-border-focus: #1A6FBF;--color-status-good: #10B981;--color-status-warning: #F59E0B;--color-status-alarm: #EF4444;--color-status-critical: #7C3AED;--color-status-offline: #6B7280;--color-status-uncertain: #F97316;--color-alarm-critical: #EF4444;--color-alarm-high: #F97316;--color-alarm-medium: #F59E0B;--color-alarm-low: #3B82F6;--color-alarm-info: #6B7280;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px rgba(0,0,0,.07);--shadow-lg: 0 10px 15px rgba(0,0,0,.1);--color-primary: var(--color-brand-primary);--color-border: var(--color-border-default);--sidebar-width: 240px;--topbar-height: 56px}:root[data-theme=dark]{--color-bg-primary: #0F1117;--color-bg-secondary: #1A1D27;--color-bg-tertiary: #242736;--color-bg-overlay: rgba(0, 0, 0, .5);--color-surface-default: #1E2130;--color-surface-raised: #252840;--color-surface-overlay: #2D3148;--color-brand-primary: #3B82F6;--color-brand-secondary: #38BDF8;--color-brand-accent: #FBBF24;--color-text-primary: #F9FAFB;--color-text-secondary: #D1D5DB;--color-text-tertiary: #9CA3AF;--color-text-disabled: #4B5563;--color-text-on-brand: #FFFFFF;--color-border-default: #2D3148;--color-border-strong: #3D4263;--color-border-focus: #3B82F6;--color-status-good: #34D399;--color-status-warning: #FBBF24;--color-status-alarm: #F87171;--color-status-critical: #A78BFA;--color-status-offline: #9CA3AF;--color-status-uncertain: #FB923C;--color-alarm-critical: #F87171;--color-alarm-high: #FB923C;--color-alarm-medium: #FBBF24;--color-alarm-low: #60A5FA;--color-alarm-info: #9CA3AF;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 6px rgba(0,0,0,.4);--shadow-lg: 0 10px 15px rgba(0,0,0,.5);--color-primary: var(--color-brand-primary);--color-border: var(--color-border-default);--sidebar-width: 240px;--topbar-height: 56px}body{background-color:var(--color-bg-primary);color:var(--color-text-primary);transition:background-color .15s ease,color .15s ease}.app-layout{display:flex;min-height:100vh}.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-height);background:var(--color-surface-default);border-bottom:1px solid var(--color-border-default);display:flex;align-items:center;padding:0 16px;z-index:100;box-shadow:var(--shadow-sm);transition:background-color .15s ease,border-color .15s ease}.topbar__logo{font-size:18px;font-weight:700;color:var(--color-brand-primary);display:flex;align-items:center;gap:8px;margin-right:24px}.topbar__logo-icon{width:28px;height:28px}.topbar__search{flex:1;max-width:400px;position:relative}.topbar__search input{width:100%;padding:6px 12px 6px 36px;border-radius:8px;border:1px solid var(--color-border-default);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:14px;transition:border-color .15s ease,background-color .15s ease}.topbar__search input:focus{outline:none;border-color:var(--color-border-focus);background:var(--color-surface-default)}.topbar__actions{display:flex;align-items:center;gap:8px;margin-left:auto}.topbar__btn{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:background-color .15s ease,color .15s ease;position:relative}.topbar__btn:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.topbar__badge{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--color-alarm-critical)}.sidebar{position:fixed;top:var(--topbar-height);left:0;bottom:0;width:var(--sidebar-width);background:var(--color-surface-default);border-right:1px solid var(--color-border-default);padding:12px 8px;display:flex;flex-direction:column;overflow-y:auto;z-index:90;transition:background-color .15s ease,border-color .15s ease,transform .3s ease}.sidebar--collapsed{transform:translate(-100%)}.sidebar__nav{flex:1}.sidebar__link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;font-size:14px;font-weight:500;color:var(--color-text-secondary);transition:background-color .15s ease,color .15s ease;margin-bottom:2px}.sidebar__link:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.sidebar__link--active{background:color-mix(in srgb,var(--color-brand-primary) 12%,transparent);color:var(--color-brand-primary)}.sidebar__link svg{width:20px;height:20px;flex-shrink:0}.sidebar__divider{height:1px;background:var(--color-border-default);margin:12px 0}.sidebar__status{padding:12px;font-size:12px;color:var(--color-text-tertiary)}.sidebar__status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}.sidebar__status-dot--online{background:var(--color-status-good)}.sidebar__status-dot--offline{background:var(--color-status-offline)}.main-content{margin-left:var(--sidebar-width);margin-top:var(--topbar-height);padding:24px;flex:1;min-height:calc(100vh - var(--topbar-height));background:var(--color-bg-secondary);transition:background-color .15s ease,margin-left .3s ease}.main-content--full{margin-left:0}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header__title{font-size:24px;font-weight:700;color:var(--color-text-primary)}.page-header__subtitle{font-size:14px;color:var(--color-text-secondary);margin-top:4px}.card{background:var(--color-surface-default);border:1px solid var(--color-border-default);border-radius:12px;padding:20px;box-shadow:var(--shadow-sm);transition:background-color .15s ease,border-color .15s ease}.card--clickable:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-strong)}.card__title{font-size:14px;font-weight:600;color:var(--color-text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.card__value{font-size:32px;font-weight:700;color:var(--color-text-primary);line-height:1.2}.card__unit{font-size:16px;font-weight:400;color:var(--color-text-secondary);margin-left:4px}.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;transition:all .15s ease;border:1px solid transparent}.btn:disabled{opacity:.5;filter:grayscale(.5);cursor:not-allowed}.btn--primary{background:var(--color-brand-primary);color:var(--color-text-on-brand)}.btn--primary:hover{background:color-mix(in srgb,var(--color-brand-primary) 85%,black)}.btn--secondary{background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border-default)}.btn--secondary:hover{background:var(--color-bg-tertiary)}.btn--danger{background:var(--color-alarm-critical);color:#fff}.btn--accent{background:var(--color-brand-accent);color:#1f2937}.btn--accent:hover{background:color-mix(in srgb,var(--color-brand-accent) 85%,black)}.btn--sm{padding:4px 10px;font-size:13px}.btn--lg{padding:12px 24px;font-size:16px}.table-container{overflow-x:auto;border-radius:12px;border:1px solid var(--color-border-default);background:var(--color-surface-default)}.table{width:100%;border-collapse:collapse}.table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border-default);background:var(--color-bg-secondary)}.table td{padding:12px 16px;font-size:14px;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-default)}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--color-bg-secondary)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:500;color:var(--color-text-secondary);margin-bottom:6px}.form-input{width:100%;padding:8px 12px;border-radius:8px;border:1px solid var(--color-border-default);background:var(--color-surface-default);color:var(--color-text-primary);font-size:14px;transition:border-color .15s ease}.form-input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-brand-primary) 20%,transparent)}.quality-good{color:var(--color-status-good)}.quality-bad{color:var(--color-status-alarm)}.quality-uncertain{color:var(--color-status-uncertain)}.quality-stale{color:var(--color-status-offline)}.alarm-critical{background:var(--color-alarm-critical);color:#fff}.alarm-high{background:var(--color-alarm-high);color:#fff}.alarm-medium{background:var(--color-alarm-medium);color:#000}.alarm-low{background:var(--color-alarm-low);color:#fff}.alarm-info{background:var(--color-alarm-info);color:#fff}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.grid{display:grid;gap:16px}.grid--2{grid-template-columns:repeat(2,1fr)}.grid--3{grid-template-columns:repeat(3,1fr)}.grid--4{grid-template-columns:repeat(4,1fr)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:85;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media(max-width:1024px){.grid--4,.grid--3{grid-template-columns:repeat(2,1fr)}.sidebar{transform:translate(-100%);z-index:95;box-shadow:var(--shadow-lg)}.sidebar--open{transform:translate(0)}.sidebar-backdrop--visible{display:block}.main-content{margin-left:0}.topbar__search{max-width:260px}}@media(max-width:768px){:root[data-theme=light],:root[data-theme=dark]{--topbar-height: 50px}.sidebar{transform:translate(-100%);width:260px;z-index:95;box-shadow:var(--shadow-lg)}.sidebar--open{transform:translate(0)}.sidebar-backdrop--visible{display:block}.main-content{margin-left:0;padding:16px}.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.page-header__title{font-size:20px}.topbar__logo span:last-child{display:none}.topbar__search{display:none}.topbar__btn{width:36px;height:36px;min-width:36px;flex-shrink:0}.topbar{overflow:hidden;gap:4px}.topbar__actions{gap:4px;flex-shrink:1;overflow:hidden}.topbar__username{display:none}.main-content{overflow-x:hidden;max-width:100vw;box-sizing:border-box}.sidebar__link{padding:12px 14px;font-size:15px;min-height:44px}.btn{min-height:40px;padding:10px 16px}.btn--sm{min-height:36px;padding:6px 12px}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.table th,.table td{padding:10px 12px;white-space:nowrap}.modal-overlay{padding:8px;align-items:flex-end}.modal-content,.modal-content--sm,.modal-content--lg{max-width:100%;max-height:calc(100vh - 16px);border-radius:16px 16px 0 0}.modal-body{padding:16px}.modal-header{padding:14px 16px}.modal-footer{padding:12px 16px}}@media(max-width:480px){.main-content{padding:12px}.page-header__title{font-size:18px}.card{padding:14px;border-radius:10px}.card__value{font-size:24px}.login-card{padding:24px;margin:12px;border-radius:12px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-primary) 0%,var(--color-bg-tertiary) 100%)}.login-card{width:100%;max-width:420px;padding:40px;background:var(--color-surface-default);border-radius:16px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border-default)}.login-card__logo{text-align:center;margin-bottom:32px}.login-card__title{font-size:24px;font-weight:700;color:var(--color-brand-primary)}.login-card__subtitle{font-size:14px;color:var(--color-text-secondary);margin-top:4px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn--ghost{background:transparent;color:var(--color-text-secondary);border:1px solid transparent}.btn--ghost:hover{background:var(--color-bg-secondary);color:var(--color-text-primary);border-color:var(--color-border-default)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg-overlay);backdrop-filter:none;-webkit-backdrop-filter:none;display:grid;place-items:center;padding:24px;z-index:900;animation:modal-fade-in .2s ease-out}.modal-content{background:var(--color-surface-raised);border:1px solid var(--color-border-default);border-radius:16px;width:100%;max-width:520px;max-height:calc(100vh - 48px);display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040,0 12px 24px -10px #0000001a;animation:modal-zoom-in .2s cubic-bezier(.16,1,.3,1);overflow:hidden;position:relative}.modal-content--sm{max-width:400px}.modal-content--lg{max-width:800px}.modal-content--xl{max-width:1100px}.modal-header{padding:16px 24px;border-bottom:1px solid var(--color-border-default);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal-header__title{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary)}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid var(--color-border-default);display:flex;justify-content:flex-end;gap:12px;background:var(--color-bg-secondary)}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-zoom-in{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}:fullscreen .topbar,:fullscreen .sidebar{display:none!important}:fullscreen .main-content{margin-left:0!important;margin-top:0!important;min-height:100vh}
