@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg-primary: #050b14;--color-bg-secondary: rgba(15, 29, 50, .55);--color-bg-card: rgba(20, 34, 56, .65);--color-bg-hover: rgba(26, 45, 74, .85);--color-bg-input: rgba(13, 26, 45, .65);--color-border: rgba(255, 255, 255, .08);--color-border-active: rgba(0, 195, 255, .6);--color-text-primary: #FFFFFF;--color-text-secondary: #94A3B8;--color-text-muted: #64748B;--color-accent: #00E5FF;--color-accent-hover: #00B8D4;--color-accent-glow: rgba(0, 229, 255, .25);--color-green: #00D68F;--color-green-bg: rgba(0, 214, 143, .18);--color-red: #FF3366;--color-red-bg: rgba(255, 51, 102, .15);--color-yellow: #FFC107;--color-yellow-bg: rgba(255, 193, 7, .15);--color-cyan: #00E5FF;--color-purple: #9D4EDD;--glass-blur: blur(20px);--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, .36);--inner-glow: inset 0 1px 1px rgba(255, 255, 255, .12);--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .875rem;--font-size-lg: 1rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px;--transition: .2s ease}html.light{--color-bg-primary: #F0F2F5;--color-bg-secondary: rgba(255, 255, 255, .85);--color-bg-card: rgba(255, 255, 255, .92);--color-bg-hover: rgba(0, 0, 0, .04);--color-bg-input: rgba(0, 0, 0, .04);--color-border: rgba(0, 0, 0, .1);--color-border-active: rgba(0, 150, 200, .5);--color-text-primary: #1A1A2E;--color-text-secondary: #4A5568;--color-text-muted: #A0AEC0;--color-accent: #0097A7;--color-accent-hover: #00838F;--color-accent-glow: rgba(0, 151, 167, .15);--color-green: #00A86B;--color-green-bg: rgba(0, 168, 107, .12);--color-red: #E53E3E;--color-red-bg: rgba(229, 62, 62, .1);--color-yellow: #D69E2E;--color-yellow-bg: rgba(214, 158, 46, .1);--color-cyan: #0097A7;--color-purple: #805AD5;--glass-blur: blur(12px);--glass-shadow: 0 4px 24px rgba(0, 0, 0, .06);--inner-glow: inset 0 1px 1px rgba(255, 255, 255, .6)}html.light body{background-image:radial-gradient(circle at 15% 50%,rgba(0,151,167,.05),transparent 40%),radial-gradient(circle at 85% 30%,rgba(128,90,213,.05),transparent 40%)}html.light .sidebar-brand img{filter:brightness(0) saturate(100%) invert(15%) sepia(10%) saturate(500%) hue-rotate(180deg)}html.light .adm-brand{color:var(--color-text-primary)}html.light .adm-brand .brand-icon{background:var(--color-accent-glow)}html.light tbody tr:hover{box-shadow:inset 3px 0 0 var(--color-accent),inset 0 0 20px #0097a70d}html,body,#root{height:100%;font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-primary);background-image:radial-gradient(circle at 15% 50%,rgba(0,229,255,.08),transparent 40%),radial-gradient(circle at 85% 30%,rgba(157,78,221,.08),transparent 40%);background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-accent);text-decoration:none}a:hover{color:var(--color-accent-hover)}.app-layout{display:flex;height:100vh;overflow:hidden}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.app-content{flex:1;overflow-y:auto;padding:var(--space-6);scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.sidebar{width:var(--sidebar-width);background:var(--color-bg-secondary);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:width var(--transition),background var(--transition);overflow:hidden;flex-shrink:0;z-index:100}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{height:var(--header-height);display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-5);border-bottom:1px solid var(--color-border);font-weight:700;font-size:var(--font-size-lg);white-space:nowrap}.sidebar-brand svg{width:32px;height:32px;color:var(--color-accent);flex-shrink:0}.sidebar-brand span{color:var(--color-green)}.sidebar-nav{flex:1;padding:var(--space-4) var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-section-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-4) var(--space-3) var(--space-2)}.collapsed .sidebar-section-label{display:none}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition);font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;text-decoration:none;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.nav-item.active{background:var(--color-accent-glow);color:var(--color-accent)}.nav-item svg{width:20px;height:20px;flex-shrink:0}.collapsed .nav-item span{display:none}.sidebar-footer{padding:var(--space-4) var(--space-3);border-top:1px solid var(--color-border)}.header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);flex-shrink:0;z-index:90;box-shadow:0 4px 30px #0000001a}.header-left{display:flex;align-items:center;gap:var(--space-4)}.header-toggle{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm)}.header-toggle:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.header-title{font-size:var(--font-size-xl);font-weight:600}.header-right{display:flex;align-items:center;gap:var(--space-3)}.header-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-accent),var(--color-purple));display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600;cursor:pointer}.header-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);position:relative}.header-btn:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.header-badge{position:absolute;top:2px;right:2px;width:8px;height:8px;background:var(--color-red);border-radius:50%}@keyframes glass-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--color-bg-card);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--color-border);box-shadow:var(--glass-shadow);border-radius:var(--radius-lg);padding:var(--space-6);transition:all .3s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden;box-shadow:var(--inner-glow),var(--glass-shadow);animation:glass-fade-in .6s cubic-bezier(.22,1,.36,1) backwards}.card:nth-child(1){animation-delay:.1s}.card:nth-child(2){animation-delay:.2s}.card:nth-child(3){animation-delay:.3s}.card:nth-child(4){animation-delay:.4s}.card:hover{border-color:var(--color-border-active);transform:translateY(-4px);box-shadow:inset 0 1px 1px #fff3,0 12px 40px #0006}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.card-title{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.card-value{font-size:var(--font-size-3xl);font-weight:700;line-height:1.1}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-2)}.card-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.card-icon.blue{background:var(--color-accent-glow);color:var(--color-accent)}.card-icon.green{background:var(--color-green-bg);color:var(--color-green)}.card-icon.red{background:var(--color-red-bg);color:var(--color-red)}.card-icon.yellow{background:var(--color-yellow-bg);color:var(--color-yellow)}.card-icon.purple{background:#7c3aed1f;color:var(--color-purple)}.card-change{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-xs);font-weight:600;padding:2px 8px;border-radius:20px}.card-change.up{color:var(--color-green);background:var(--color-green-bg)}.card-change.down{color:var(--color-red);background:var(--color-red-bg)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6);margin-bottom:var(--space-6)}.kpi-progress{height:4px;background:#ffffff0d;border-radius:2px;margin-top:var(--space-4);overflow:hidden}.kpi-progress-bar{height:100%;border-radius:2px;transition:width .6s ease}.kpi-sparkline{display:flex;align-items:flex-end;gap:4px;height:24px;margin-top:var(--space-4)}.spark-bar{flex:1;background:var(--color-accent);opacity:.3;border-radius:1px;transition:opacity .2s}.spark-bar:last-child{opacity:1}.dashboard-main-grid{display:grid;grid-template-columns:1fr 340px;gap:var(--space-6);margin-bottom:var(--space-6)}@media(max-width:1280px){.dashboard-main-grid{grid-template-columns:1fr}}.network-map-container{height:600px;background-color:#08111e;background-image:radial-gradient(var(--color-border) 1px,transparent 1px);background-size:40px 40px;position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border)}.map-marker{position:absolute;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transform:translate(-50%,-50%);box-shadow:0 0 15px #00000080;transition:transform .2s}.map-marker:hover{transform:translate(-50%,-50%) scale(1.2);z-index:10}.map-marker svg{width:14px;height:14px}.map-marker.available{background:var(--color-green);box-shadow:0 0 12px var(--color-green-bg)}.map-marker.charging{background:var(--color-accent);box-shadow:0 0 12px var(--color-accent-glow)}.map-marker.fault{background:var(--color-red);box-shadow:0 0 12px var(--color-red-bg)}.map-controls{position:absolute;bottom:var(--space-4);right:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.sessions-sidebar{display:flex;flex-direction:column;gap:var(--space-4)}.session-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);transition:all var(--transition)}.session-card:hover{border-color:var(--color-border-active);transform:translateY(-2px)}.session-card-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.session-v-icon{width:32px;height:32px;background:#ffffff0d;border-radius:8px;display:flex;align-items:center;justify-content:center}.session-info{flex:1}.session-v-name{font-weight:600;font-size:var(--font-size-sm)}.session-v-id{font-size:var(--font-size-xs);color:var(--color-text-muted)}.session-tag{font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase}.tag-dc{background:#0066ff1a;color:var(--color-accent)}.tag-ac{background:#00d68f1a;color:var(--color-green)}.tag-ultra{background:#7c3aed1a;color:var(--color-purple)}.session-power-row{display:flex;align-items:center;justify-content:space-between;font-size:var(--font-size-xs);margin-bottom:6px}.session-power-val{font-weight:700;color:var(--color-text-primary)}.session-progress{height:6px;background:#ffffff0d;border-radius:3px;overflow:hidden}.session-progress-bar{height:100%;transition:width .3s ease}.chart-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-6);margin-bottom:var(--space-6)}@media(max-width:1024px){.chart-grid{grid-template-columns:1fr}}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}thead th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);white-space:nowrap}tbody td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;transition:color .2s ease}tbody tr{transition:all .2s cubic-bezier(.25,.8,.25,1)}tbody tr:hover{background:var(--color-bg-hover);box-shadow:inset 3px 0 0 var(--color-accent),inset 0 0 20px #00e5ff0d}tbody tr:hover td{color:var(--color-text-primary)}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:var(--font-size-xs);font-weight:600}.badge:before{content:"";width:6px;height:6px;border-radius:50%}.badge.available{background:var(--color-green-bg);color:var(--color-green)}.badge.available:before{background:var(--color-green)}.badge.charging{background:var(--color-accent-glow);color:var(--color-accent)}.badge.charging:before{background:var(--color-accent)}.badge.faulted{background:var(--color-red-bg);color:var(--color-red)}.badge.faulted:before{background:var(--color-red)}.badge.unavailable{background:var(--color-yellow-bg);color:var(--color-yellow)}.badge.unavailable:before{background:var(--color-yellow)}.badge.preparing,.badge.finishing{background:#00bcd41f;color:var(--color-cyan)}.badge.preparing:before,.badge.finishing:before{background:var(--color-cyan)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;border:1px solid transparent;transition:all var(--transition);font-family:var(--font-family)}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover{background:var(--color-accent-hover)}.btn-outline{background:transparent;border-color:var(--color-border);color:var(--color-text-secondary)}.btn-outline:hover{border-color:var(--color-accent);color:var(--color-accent)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.btn-icon{padding:var(--space-2);background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer}.btn-icon:hover{border-color:var(--color-accent);color:var(--color-accent)}.input,.select{background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);outline:none;transition:border-color var(--transition)}.input:focus,.select:focus{border-color:var(--color-accent)}.input::placeholder{color:var(--color-text-muted)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-4)}.page-title{font-size:var(--font-size-2xl);font-weight:700}.page-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.page-actions{display:flex;gap:var(--space-3);align-items:center}.filters{display:flex;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap;align-items:center}.login-page{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary);background-image:radial-gradient(ellipse at 20% 50%,rgba(0,102,255,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(0,214,143,.05) 0%,transparent 50%)}.login-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-8);width:100%;max-width:420px;display:flex;flex-direction:column;gap:var(--space-4)}.login-logo{display:block;height:72px;max-width:100%;width:auto;object-fit:contain;margin:0 auto var(--space-2)}.login-subtitle{color:var(--color-text-secondary);text-align:center;margin:0 0 var(--space-4);font-size:var(--font-size-base);font-weight:500}.login-card h1{font-size:var(--font-size-2xl);margin-bottom:var(--space-2);text-align:center}.login-card p{color:var(--color-text-secondary);text-align:center;margin-bottom:var(--space-6)}.form-group{margin-bottom:var(--space-4)}.form-group label{display:block;font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--space-2);color:var(--color-text-secondary)}.form-group .input{width:100%;padding:var(--space-3)}.login-error{display:flex;align-items:center;gap:var(--space-2);background:var(--color-red-bg);color:var(--color-red);padding:var(--space-3);border:1px solid var(--color-red);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-2)}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:transparent;border:0;padding:6px;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:color .12s ease,background .12s ease}.password-toggle:hover{color:var(--color-text-primary);background:var(--color-bg-hover, rgba(255, 255, 255, .04))}.password-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.input-with-trailing{padding-right:42px}.login-spinner{animation:login-spin .7s linear infinite}@keyframes login-spin{to{transform:rotate(360deg)}}.login-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3);margin-top:var(--space-2);font-size:var(--font-size-base);font-weight:600}.login-forgot{display:block;text-align:center;margin-top:var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-muted);text-decoration:none;transition:color .12s ease}.login-forgot:hover{color:var(--color-primary)}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--color-border)!important}.recharts-text{fill:var(--color-text-muted)!important;font-size:11px!important}@media(max-width:768px){.sidebar{position:fixed;z-index:100;left:-300px;transition:left .3s ease}.sidebar.open{left:0}.kpi-grid{grid-template-columns:1fr 1fr}.app-content{padding:var(--space-4)}}@media(max-width:480px){.kpi-grid{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--color-text-secondary);margin-bottom:6px}.form-group select{width:100%;padding:10px 12px;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group select:focus{border-color:var(--color-border-active)}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:16px;border-top:1px solid var(--color-border)}.btn-danger{background:var(--color-red);color:#fff}.btn-danger:hover{background:#e63e4d}.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:10px;font-size:14px;font-weight:500;z-index:2000;animation:slideUp .2s ease-out;box-shadow:0 8px 24px #0000004d}.toast-success{background:var(--color-green);color:#000}.toast-error{background:var(--color-red);color:#fff}.admin-layout{--admin-sidebar-w: 232px;background:var(--adm-bg);color:var(--adm-text)}.admin-light{--adm-bg: #F0F4F8;--adm-bg-sidebar: #FFFFFF;--adm-bg-card: #FFFFFF;--adm-bg-topbar: #FFFFFF;--adm-bg-hover: #F3F4F6;--adm-bg-input: #F9FAFB;--adm-bg-table-head: #F9FAFB;--adm-border: #E5E7EB;--adm-border-subtle: #F3F4F6;--adm-text: #111827;--adm-text-secondary: #6B7280;--adm-text-muted: #9CA3AF;--adm-accent: #2563EB;--adm-accent-hover: #1D4ED8;--adm-accent-bg: rgba(37, 99, 235, .08);--adm-green: #10B981;--adm-green-bg: rgba(16, 185, 129, .1);--adm-red: #EF4444;--adm-red-bg: rgba(239, 68, 68, .08);--adm-yellow: #F59E0B;--adm-yellow-bg: rgba(245, 158, 11, .08);--adm-shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--adm-shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--adm-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .06), 0 2px 4px -2px rgba(0, 0, 0, .04);--adm-badge-crit-bg: #FEE2E2;--adm-badge-crit-text: #DC2626;--adm-badge-warn-bg: #FEF3C7;--adm-badge-warn-text: #D97706;--adm-badge-ok-bg: #D1FAE5;--adm-badge-ok-text: #059669;--adm-badge-info-bg: #DBEAFE;--adm-badge-info-text: #2563EB;--adm-avatar-bg: #F3F4F6;--adm-icon-bg-blue: #EFF6FF;--adm-icon-blue: #2563EB;--adm-icon-bg-green: #ECFDF5;--adm-icon-green: #10B981;--adm-icon-bg-purple: #F5F3FF;--adm-icon-purple: #7C3AED;--adm-icon-bg-amber: #FFFBEB;--adm-icon-amber: #F59E0B;--adm-user-hover: #F3F4F6}.admin-dark{--adm-bg: #050b14;--adm-bg-sidebar: rgba(15, 29, 50, .95);--adm-bg-card: rgba(20, 34, 56, .65);--adm-bg-topbar: rgba(15, 29, 50, .55);--adm-bg-hover: rgba(26, 45, 74, .85);--adm-bg-input: rgba(13, 26, 45, .65);--adm-bg-table-head: rgba(255, 255, 255, .03);--adm-border: rgba(255, 255, 255, .08);--adm-border-subtle: rgba(255, 255, 255, .04);--adm-text: #FFFFFF;--adm-text-secondary: #94A3B8;--adm-text-muted: #64748B;--adm-accent: #00E5FF;--adm-accent-hover: #00B8D4;--adm-accent-bg: rgba(0, 229, 255, .1);--adm-green: #00D68F;--adm-green-bg: rgba(0, 214, 143, .18);--adm-red: #FF3366;--adm-red-bg: rgba(255, 51, 102, .15);--adm-yellow: #FFC107;--adm-yellow-bg: rgba(255, 193, 7, .12);--adm-shadow-xs: 0 1px 3px rgba(0, 0, 0, .3);--adm-shadow: 0 2px 8px rgba(0, 0, 0, .4);--adm-shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--adm-badge-crit-bg: rgba(255, 51, 102, .15);--adm-badge-crit-text: #FF3366;--adm-badge-warn-bg: rgba(255, 193, 7, .12);--adm-badge-warn-text: #FFC107;--adm-badge-ok-bg: rgba(0, 214, 143, .18);--adm-badge-ok-text: #00D68F;--adm-badge-info-bg: rgba(0, 229, 255, .1);--adm-badge-info-text: #00E5FF;--adm-avatar-bg: rgba(255, 255, 255, .08);--adm-icon-bg-blue: rgba(37, 99, 235, .12);--adm-icon-blue: #60A5FA;--adm-icon-bg-green: rgba(16, 185, 129, .12);--adm-icon-green: #34D399;--adm-icon-bg-purple: rgba(124, 58, 237, .12);--adm-icon-purple: #A78BFA;--adm-icon-bg-amber: rgba(245, 158, 11, .12);--adm-icon-amber: #FBBF24;--adm-user-hover: rgba(255, 255, 255, .05)}.admin-layout{display:flex;height:100vh;overflow:hidden}.admin-layout .admin-side{width:var(--admin-sidebar-w);background:var(--adm-bg-sidebar);border-right:1px solid var(--adm-border);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s ease;overflow:hidden;z-index:20}.admin-layout .admin-side.collapsed{width:68px}.admin-layout .admin-side .adm-brand{height:64px;display:flex;align-items:center;gap:10px;padding:0 20px;border-bottom:1px solid var(--adm-border);font-weight:700;font-size:17px;color:var(--adm-text);white-space:nowrap}.admin-layout .admin-side .adm-brand .brand-icon{width:36px;height:36px;background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.admin-layout .admin-side .adm-brand span{color:#10b981}.admin-layout .adm-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.admin-layout .adm-nav .nav-section{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--adm-text-muted);padding:16px 12px 6px}.admin-layout .adm-nav .adm-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:var(--adm-text-secondary);font-size:14px;font-weight:500;text-decoration:none;transition:all .15s ease;white-space:nowrap;border:none;background:none;cursor:pointer;width:100%;text-align:left}.admin-layout .adm-nav .adm-link:hover{background:var(--adm-bg-hover);color:var(--adm-text)}.admin-layout .adm-nav .adm-link.active{background:var(--adm-accent-bg);color:var(--adm-accent);font-weight:600}.admin-layout .adm-nav .adm-link.active svg{color:var(--adm-accent)}.admin-layout .adm-nav .adm-link svg{width:20px;height:20px;flex-shrink:0}.admin-layout .adm-user-section{padding:12px;border-top:1px solid var(--adm-border)}.admin-layout .adm-user-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s}.admin-layout .adm-user-card:hover{background:var(--adm-user-hover)}.admin-layout .adm-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#7c3aed);display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:600;flex-shrink:0}.admin-layout .adm-user-info{flex:1;min-width:0}.admin-layout .adm-user-name{font-size:13px;font-weight:600;color:var(--adm-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-layout .adm-user-role{font-size:11px;color:var(--adm-text-muted)}.admin-layout .admin-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.admin-layout .adm-topbar{height:56px;background:var(--adm-bg-topbar);border-bottom:1px solid var(--adm-border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.admin-layout .adm-ticker{flex:1;overflow:hidden;margin:0 24px;-webkit-mask-image:linear-gradient(90deg,transparent 0%,black 10%,black 90%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0%,black 10%,black 90%,transparent 100%)}.admin-layout .adm-ticker-track{display:flex;gap:48px;animation:adminTickerScroll 30s linear infinite;white-space:nowrap}@keyframes adminTickerScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.admin-layout .adm-ticker-item{font-size:12px;color:var(--adm-text-muted);display:inline-flex;align-items:center;gap:6px}.admin-layout .adm-ticker-item .ticker-label{color:var(--adm-text-secondary);font-weight:500}.admin-layout .adm-ticker-item .ticker-val{font-weight:600;color:var(--adm-text)}.admin-layout .adm-ticker-item .ticker-up{color:var(--adm-green);font-size:11px}.admin-layout .adm-ticker-item .ticker-down{color:var(--adm-red);font-size:11px}.admin-layout .adm-topbar-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.admin-layout .adm-status-badge{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--adm-green);background:var(--adm-green-bg);padding:4px 12px;border-radius:20px}.admin-layout .adm-status-dot{width:8px;height:8px;border-radius:50%;background:var(--adm-green);animation:adminPulse 2s infinite}@keyframes adminPulse{0%,to{opacity:1}50%{opacity:.4}}.admin-layout .adm-topbar-btn{width:36px;height:36px;border-radius:8px;border:none;background:none;color:var(--adm-text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative}.admin-layout .adm-topbar-btn:hover{background:var(--adm-bg-hover);color:var(--adm-text)}.admin-layout .adm-topbar-badge{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--adm-red)}.admin-layout .adm-topbar-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#7c3aed);display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600}.admin-layout .adm-content{flex:1;overflow-y:auto;padding:24px;scrollbar-width:thin;scrollbar-color:var(--adm-text-muted) transparent}.admin-layout .card{background:var(--adm-bg-card);border:1px solid var(--adm-border);border-radius:12px;padding:20px;box-shadow:var(--adm-shadow-xs);transition:box-shadow .2s,border-color .2s}.admin-layout .card:hover{border-color:var(--adm-border);box-shadow:var(--adm-shadow)}.admin-layout .card-title{color:var(--adm-text-secondary)}.admin-layout .card-value{color:var(--adm-text)}.adm-kpi-card{background:var(--adm-bg-card);border:1px solid var(--adm-border);border-radius:12px;padding:20px 24px;box-shadow:var(--adm-shadow-xs);position:relative;overflow:hidden}.adm-kpi-card .kpi-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.adm-kpi-card .kpi-label{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--adm-text-muted)}.adm-kpi-card .kpi-info{width:20px;height:20px;border-radius:50%;border:1.5px solid var(--adm-border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--adm-text-muted);cursor:help}.adm-kpi-card .kpi-value-row{display:flex;align-items:baseline;gap:10px;margin-bottom:4px}.adm-kpi-card .kpi-big{font-size:32px;font-weight:700;color:var(--adm-text);line-height:1}.adm-kpi-card .kpi-unit{font-size:16px;font-weight:500;color:var(--adm-text-muted)}.adm-kpi-card .kpi-change{font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:3px}.adm-kpi-card .kpi-change.up{color:var(--adm-green)}.adm-kpi-card .kpi-change.down{color:var(--adm-red)}.adm-kpi-card .kpi-change.stable{color:var(--adm-text-muted)}.adm-kpi-card .kpi-sub{font-size:11px;color:var(--adm-text-muted);margin-top:2px}.adm-kpi-card .kpi-progress{height:5px;background:var(--adm-bg-hover);border-radius:3px;margin-top:14px;overflow:hidden}.adm-kpi-card .kpi-progress-fill{height:100%;border-radius:3px;transition:width .8s ease}.adm-kpi-card .kpi-sparkline{display:flex;align-items:flex-end;gap:3px;height:28px;margin-top:14px}.adm-kpi-card .kpi-spark-bar{flex:1;border-radius:2px;transition:height .3s;min-height:3px}.adm-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.adm-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--adm-text-secondary)}.adm-section-link{font-size:13px;font-weight:500;color:var(--adm-accent);text-decoration:none;display:flex;align-items:center;gap:4px}.adm-section-link:hover{text-decoration:underline}.admin-layout .table{border-collapse:separate;border-spacing:0}.admin-layout .table thead th{background:var(--adm-bg-table-head);color:var(--adm-text-muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:10px 16px;border-bottom:1px solid var(--adm-border)}.admin-layout .table tbody td{padding:12px 16px;font-size:13px;color:var(--adm-text-secondary);border-bottom:1px solid var(--adm-border-subtle)}.admin-layout .table tbody tr:hover{background:var(--adm-bg-hover)}.admin-layout .table tbody tr:last-child td{border-bottom:none}.adm-event-id{font-weight:600;color:var(--adm-accent);cursor:pointer}.adm-event-id:hover{text-decoration:underline}.adm-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:4px;display:inline-block}.adm-badge.critical{background:var(--adm-badge-crit-bg);color:var(--adm-badge-crit-text)}.adm-badge.warning{background:var(--adm-badge-warn-bg);color:var(--adm-badge-warn-text)}.adm-badge.success{background:var(--adm-badge-ok-bg);color:var(--adm-badge-ok-text)}.adm-badge.info{background:var(--adm-badge-info-bg);color:var(--adm-badge-info-text)}.adm-fin-card{background:var(--adm-bg-card);border:1px solid var(--adm-border);border-radius:12px;padding:24px;box-shadow:var(--adm-shadow-xs)}.adm-fin-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--adm-text-secondary);margin-bottom:20px;display:flex;align-items:center;gap:8px}.adm-fin-big{font-size:40px;font-weight:700;color:var(--adm-green);line-height:1}.adm-fin-delta{font-size:13px;font-weight:600;color:var(--adm-green);margin-left:8px}.adm-fin-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-top:1px solid var(--adm-border-subtle);font-size:13px}.adm-fin-label{color:var(--adm-text-secondary)}.adm-fin-val{font-weight:600;color:var(--adm-text)}.adm-fin-bar{height:8px;background:var(--adm-bg-hover);border-radius:4px;margin:12px 0 4px;overflow:hidden;display:flex;gap:2px}.adm-fin-bar>div{height:100%;border-radius:4px}.adm-fin-target{font-size:11px;color:var(--adm-text-muted);text-align:right}.adm-heatmap{background:var(--adm-bg-card);border:1px solid var(--adm-border);border-radius:12px;padding:20px 24px;box-shadow:var(--adm-shadow-xs)}.adm-heatmap-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--adm-text-secondary);margin-bottom:16px;display:flex;align-items:center;gap:8px}.adm-heatmap-grid{display:flex;flex-direction:column;gap:4px}.adm-heatmap-row{display:flex;align-items:center;gap:4px}.adm-heatmap-label{width:32px;font-size:11px;color:var(--adm-text-muted);text-align:right;padding-right:6px;flex-shrink:0}.adm-heatmap-cells{display:flex;gap:2px;flex:1}.adm-heatmap-cell{flex:1;aspect-ratio:1;border-radius:3px;min-width:10px;max-width:18px}.adm-heat-0{background:#f0f4f8}.adm-heat-1{background:#bfdbfe}.adm-heat-2{background:#60a5fa}.adm-heat-3{background:#2563eb}.adm-heat-4{background:#1e40af}.adm-heatmap-times{display:flex;margin-top:6px;padding-left:38px}.adm-heatmap-times span{flex:1;font-size:10px;color:var(--adm-text-muted)}.adm-metric-card{background:var(--adm-bg-card);border:1px solid var(--adm-border);border-radius:12px;padding:20px;box-shadow:var(--adm-shadow-xs);display:flex;align-items:center;gap:16px}.adm-metric-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.adm-metric-icon.blue{background:var(--adm-icon-bg-blue);color:var(--adm-icon-blue)}.adm-metric-icon.green{background:var(--adm-icon-bg-green);color:var(--adm-icon-green)}.adm-metric-icon.purple{background:var(--adm-icon-bg-purple);color:var(--adm-icon-purple)}.adm-metric-icon.amber{background:var(--adm-icon-bg-amber);color:var(--adm-icon-amber)}.adm-metric-body{flex:1}.adm-metric-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--adm-text-muted);margin-bottom:4px}.adm-metric-value{font-size:24px;font-weight:700;color:var(--adm-text);line-height:1}.adm-metric-unit{font-size:14px;font-weight:500;color:var(--adm-text-muted);margin-left:4px}.adm-cx-card{background:var(--adm-bg-card);border:1px solid var(--adm-border);border-radius:12px;padding:24px;box-shadow:var(--adm-shadow-xs)}.adm-cx-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--adm-text-secondary);margin-bottom:20px;display:flex;align-items:center;gap:8px}.adm-cx-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:16px}.adm-cx-metric-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--adm-text-muted);margin-bottom:4px}.adm-cx-metric-big{font-size:28px;font-weight:700;line-height:1.1}.adm-cx-metric-sub{font-size:11px;margin-top:4px}.adm-gauge-wrap{display:flex;align-items:center;gap:16px;padding-top:16px;border-top:1px solid var(--adm-border-subtle)}.adm-gauge{width:64px;height:64px;position:relative}.adm-gauge svg{width:64px;height:64px;transform:rotate(-90deg)}.adm-gauge circle{fill:none;stroke-linecap:round}.adm-gauge .gauge-bg{stroke:var(--adm-bg-hover)}.adm-gauge .gauge-fill{transition:stroke-dashoffset 1s ease}.adm-gauge-pct{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:14px;font-weight:700;color:var(--adm-text)}.adm-gauge-text{flex:1;font-size:12px;color:var(--adm-text-secondary);line-height:1.5}.adm-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.adm-main-grid{display:grid;grid-template-columns:1fr 320px;gap:20px;margin-bottom:20px}.adm-bottom-grid{display:grid;grid-template-columns:1fr 260px 260px 320px;gap:16px}@media(max-width:1400px){.adm-kpi-row{grid-template-columns:repeat(2,1fr)}.adm-main-grid{grid-template-columns:1fr}.adm-bottom-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.adm-kpi-row,.adm-bottom-grid{grid-template-columns:1fr}}.admin-layout .modal-backdrop{background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.admin-layout .modal{background:#fff;border:1px solid #E5E7EB;color:#111827;box-shadow:0 25px 50px -12px #00000026}.admin-layout .modal-title{color:#111827}.admin-layout input,.admin-layout select,.admin-layout textarea{background:#f9fafb;border:1px solid #D1D5DB;color:#111827;border-radius:8px;padding:8px 12px;font-size:14px;transition:border-color .15s}.admin-layout input:focus,.admin-layout select:focus,.admin-layout textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.admin-layout input::placeholder{color:#9ca3af}.admin-layout .btn-primary{background:#2563eb;color:#fff;border:none;border-radius:8px;padding:8px 18px;font-weight:600;cursor:pointer;transition:background .15s}.admin-layout .btn-primary:hover{background:#1d4ed8}.admin-layout .btn-outline{background:#fff;color:#374151;border:1px solid #D1D5DB;border-radius:8px;padding:8px 18px;font-weight:500;cursor:pointer;transition:all .15s}.admin-layout .btn-outline:hover{background:#f9fafb;border-color:#9ca3af}.admin-layout .status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.admin-layout .status-dot.online{background:#10b981}.admin-layout .status-dot.offline{background:#ef4444}.admin-layout .status-dot.warning{background:#f59e0b}.admin-layout .search-input{background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;padding:8px 12px 8px 36px;font-size:14px;color:#111827;width:100%}.admin-layout .search-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb14}.admin-layout .toggle-switch{background:#e5e7eb}.admin-layout .toggle-switch.active{background:#2563eb}.admin-layout .page-title{color:#111827}.admin-layout .page-subtitle{color:#6b7280}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.input-group{position:relative;display:flex;align-items:center}.input-group .input-icon{position:absolute;left:12px;color:var(--color-text-muted);pointer-events:none;z-index:2}.input-group .input{padding-left:38px;width:100%}.admin-layout .recharts-cartesian-grid-horizontal line,.admin-layout .recharts-cartesian-grid-vertical line{stroke:#f3f4f6}.admin-layout .recharts-text{fill:#6b7280}
