:root{--accent: #D4654A;--accent-hover: #c0563c;--accent-light: #fdf0ed;--accent-10: rgba(212, 101, 74, .1);--accent-20: rgba(212, 101, 74, .2);--accent-dark: #1a1a1a;--accent-gradient: linear-gradient(135deg, #D4654A, #e8856c);--color-success: #22c55e;--color-success-bg: #f0fdf4;--color-success-border: #a7f0ba;--color-warning: #f59e0b;--color-warning-bg: #fff8e1;--color-warning-border: #fddc69;--color-danger: #ef4444;--color-danger-bg: #fef2f2;--color-danger-border: #fecaca;--bg-body: #f5f4f1;--bg-card: #ffffff;--bg-sidebar: #1e1e2d;--bg-sidebar-hover: #2a2a3c;--bg-sidebar-active: rgba(212, 101, 74, .15);--bg-header: #1e1e2d;--bg-input: #f4f4f4;--bg-input-hover: #e8e8e8;--bg-table-head: #faf9f7;--bg-hover-row: rgba(212, 101, 74, .03);--border-color: #eae8e4;--border-light: #f0efec;--text-primary: #1a1a1a;--text-secondary: #525252;--text-muted: #6f6f6f;--text-label: #a8a8a8;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs: .625rem;--font-sm: .6875rem;--font-base: .8125rem;--font-md: .875rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--font-4xl: 2.25rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-base: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 2.5rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-card: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .02);--shadow-card-hover: 0 8px 24px rgba(0, 0, 0, .08);--shadow-widget: 0 2px 12px rgba(0, 0, 0, .06);--shadow-widget-hover: 0 8px 28px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 220px;--header-height: 72px;--content-max-width: 1600px;--electica-blue: var(--accent);--electica-blue-hover: var(--accent-hover);--electica-blue-light: var(--accent-light);--electica-blue-10: var(--accent-10);--electica-blue-20: var(--accent-20)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family);font-size:var(--font-md);line-height:1.6;color:var(--text-primary);background:var(--bg-body);min-height:100vh;overflow-x:hidden}img,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}input,select,textarea{font:inherit;color:inherit;background:none;border:none;outline:none}ul,ol{list-style:none}table{border-collapse:collapse;width:100%}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#c1c1c1}::selection{background:var(--electica-blue);color:#fff}#app{display:flex;min-height:100vh;max-width:1920px;margin:0 auto;background:var(--bg-body)}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--bg-sidebar);display:flex;flex-direction:column;justify-content:space-between;z-index:100}.sidebar-inner{display:flex;flex-direction:column;height:100%}.sidebar-brand{height:var(--header-height);display:flex;align-items:center;padding:0 1.25rem;gap:var(--space-md)}.sidebar-brand-icon{width:36px;height:36px;background:var(--accent);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #d4654a59}.sidebar-brand-icon .material-symbols-outlined{font-size:20px;color:#fff}.sidebar-brand-name{font-size:var(--font-lg);font-weight:700;color:#fff;letter-spacing:-.01em}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-base) .75rem}.sidebar-section-label{font-size:var(--font-xs);font-weight:600;color:#ffffff4d;text-transform:uppercase;letter-spacing:.08em;padding:0 .75rem;margin-bottom:var(--space-sm)}.sidebar-section-label:not(:first-child){margin-top:1.5rem}.sidebar-link{display:flex;align-items:center;gap:var(--space-md);padding:10px 12px;border-radius:var(--radius-md);font-size:var(--font-md);font-weight:500;color:#fff9;cursor:pointer;transition:all var(--transition-base);margin-bottom:2px}.sidebar-link .material-symbols-outlined{font-size:20px;color:#fff6;transition:color var(--transition-fast)}.sidebar-link:hover{background:var(--bg-sidebar-hover);color:#ffffffe6}.sidebar-link:hover .material-symbols-outlined{color:#ffffffb3}.sidebar-link.active{background:transparent;color:var(--accent);font-weight:600}.sidebar-link.active .material-symbols-outlined{color:var(--accent)}.sidebar-footer{padding:.75rem;border-top:1px solid rgba(255,255,255,.08)}.sidebar-user{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) .5rem;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.sidebar-user:hover{background:var(--bg-sidebar-hover)}.sidebar-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:#ffffff1a;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.sidebar-avatar img{width:100%;height:100%;object-fit:cover}.sidebar-user-name{font-size:var(--font-base);font-weight:600;color:#ffffffd9}.sidebar-user-role{font-size:var(--font-xs);color:#fff6}.main-wrapper{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column;min-height:100vh;background:var(--bg-body)}.header{position:sticky;top:0;z-index:50;height:var(--header-height);background:var(--bg-header);display:flex;align-items:center;justify-content:space-between;padding:0 2rem}.header-left{display:flex;align-items:center;gap:1.25rem}.header-title{font-size:var(--font-xl);font-weight:700;color:#fff;letter-spacing:-.01em}.header-subtitle{font-size:var(--font-sm);color:#ffffff73;font-weight:500;margin-top:2px}.header-divider{width:1px;height:32px;background:#ffffff1a}.header-search{position:relative;width:280px}.header-search .material-symbols-outlined{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:20px;color:#fff6}.header-search input{width:100%;background:#ffffff14;border:0;border-radius:var(--radius-md);padding:8px 16px 8px 40px;font-size:var(--font-md);font-weight:500;color:#ffffffe6;transition:all var(--transition-base)}.header-search input::placeholder{color:#ffffff59}.header-search input:hover{background:#ffffff1f}.header-search input:focus{background:#ffffff26;box-shadow:0 0 0 2px var(--accent-20)}.header-right{display:flex;align-items:center;gap:.75rem}.header-icon-btn{position:relative;width:38px;height:38px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#ffffff80;transition:all var(--transition-fast)}.header-icon-btn:hover{background:#ffffff1a;color:#ffffffe6}.header-icon-btn .material-symbols-outlined{font-size:22px}.header-notification-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--accent);border-radius:50%;border:2px solid var(--bg-header)}.header-user-info{display:flex;align-items:center;gap:.625rem;margin-left:.5rem}.header-user-name{font-size:var(--font-base);font-weight:600;color:#ffffffe6;text-align:right;line-height:1.2}.header-user-role{font-size:var(--font-xs);color:#fff6;text-align:right}.header-user-avatar{width:38px;height:38px;border-radius:var(--radius-full);background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:var(--font-base);font-weight:700;color:#fff;flex-shrink:0}.btn-header{display:flex;align-items:center;gap:var(--space-sm);padding:8px 16px;font-size:var(--font-base);font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-base)}.btn-header .material-symbols-outlined{font-size:16px}.btn-header-outline{background:transparent;border:1px solid rgba(255,255,255,.15);color:#ffffffb3}.btn-header-outline:hover{background:#ffffff14;color:#fffffff2}.btn-header-primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px #d4654a4d}.btn-header-primary:hover{background:var(--accent-hover);box-shadow:0 4px 16px #d4654a59;transform:translateY(-1px)}.main-content{flex:1;padding:1.5rem 2rem;max-width:100%;width:100%;box-sizing:border-box;overflow-x:hidden}.sidebar{transition:width .35s cubic-bezier(.22,1,.36,1);overflow:hidden;will-change:width}.main-wrapper{transition:margin-left .35s cubic-bezier(.22,1,.36,1);will-change:margin-left}.sidebar-brand-name,.sidebar-section-label,.sidebar-link-text,.sidebar-user-info-text{opacity:1;max-width:180px;overflow:hidden;white-space:nowrap;transform:translate(0);transition:opacity .25s cubic-bezier(.4,0,.2,1) .1s,max-width .3s cubic-bezier(.22,1,.36,1) .05s,transform .25s cubic-bezier(.4,0,.2,1) .1s}.sidebar-brand{transition:padding .35s cubic-bezier(.22,1,.36,1),justify-content .35s}.sidebar-nav{transition:padding .35s cubic-bezier(.22,1,.36,1)}.sidebar-link{transition:all .25s cubic-bezier(.4,0,.2,1),padding .3s cubic-bezier(.22,1,.36,1),justify-content .3s}.sidebar-link .material-symbols-outlined{transition:color .15s ease,transform .3s cubic-bezier(.22,1,.36,1)}.sidebar-footer{transition:padding .35s cubic-bezier(.22,1,.36,1)}.sidebar-user{transition:justify-content .3s,background .15s}.sidebar-collapse-btn{transition:all .3s cubic-bezier(.22,1,.36,1)!important}.sidebar-collapsed .sidebar{width:68px}.sidebar-collapsed .main-wrapper{margin-left:68px}.sidebar-collapsed .sidebar-brand-name,.sidebar-collapsed .sidebar-section-label,.sidebar-collapsed .sidebar-link-text,.sidebar-collapsed .sidebar-user-info-text{opacity:0;max-width:0;transform:translate(-8px);transition:opacity .15s cubic-bezier(.4,0,.2,1),max-width .25s cubic-bezier(.22,1,.36,1) .05s,transform .15s cubic-bezier(.4,0,.2,1)}.sidebar-collapsed .sidebar-brand{justify-content:center;padding:0 .5rem}.sidebar-collapsed .sidebar-collapse-btn{display:flex!important;margin-left:0!important;position:absolute;right:-14px;top:26px;width:28px;height:28px;background:var(--accent)!important;color:#fff!important;border-radius:50%!important;box-shadow:0 2px 8px #00000040,0 0 0 3px #d4654a26;z-index:101;transform:scale(1)}.sidebar-collapsed .sidebar-collapse-btn:hover{transform:scale(1.1)!important;box-shadow:0 4px 12px #0000004d,0 0 0 4px #d4654a33!important}.sidebar-collapsed .sidebar-nav{padding:1rem .5rem}.sidebar-collapsed .sidebar-link{justify-content:center;padding:10px}.sidebar-collapsed .sidebar-link .material-symbols-outlined{margin:0;transform:scale(1.05)}.sidebar-collapsed .sidebar-link:hover .material-symbols-outlined{transform:scale(1.15)}.sidebar-collapsed .sidebar-link{position:relative}.sidebar-collapsed .sidebar-link:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%) scale(.9);background:#0f172a;color:#fff;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;white-space:nowrap;opacity:0;pointer-events:none;box-shadow:0 4px 12px #00000040;transition:opacity .2s,transform .2s cubic-bezier(.22,1,.36,1);z-index:200}.sidebar-collapsed .sidebar-link:hover:after{opacity:1;transform:translateY(-50%) scale(1)}.sidebar-collapsed .sidebar-footer{padding:.75rem .5rem}.sidebar-collapsed .sidebar-user{justify-content:center}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@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)}}.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);transition:all var(--transition-base);box-shadow:var(--shadow-card)}.card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xl) var(--space-xl) var(--space-base)}.card-title{font-size:var(--font-lg);font-weight:700;color:var(--text-primary)}.card-subtitle{font-size:var(--font-md);color:#6b7280;font-weight:500;margin-top:2px}.card-body{padding:var(--space-base) var(--space-xl) var(--space-xl)}.card-link{font-size:var(--font-sm);font-weight:700;color:var(--text-label);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:4px;cursor:pointer;transition:color var(--transition-fast)}.card-link:hover{color:var(--accent)}.card-link .material-symbols-outlined{font-size:14px}.widget-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:1.25rem;box-shadow:var(--shadow-widget);transition:all var(--transition-base);position:relative;overflow:hidden;border:1px solid transparent;display:flex;flex-direction:column}.widget-card:hover{box-shadow:var(--shadow-widget-hover);transform:translateY(-2px);border-color:var(--accent-10)}.widget-card-dark{background:var(--accent-dark);color:#fff}.widget-card-dark:hover{border-color:#ffffff1a}.widget-card-accent{background:var(--accent);color:#fff}.widget-card-accent:hover{border-color:#fff3}.widget-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.widget-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:var(--accent-light)}.widget-icon .material-symbols-outlined{font-size:22px;color:var(--accent)}.widget-card-dark .widget-icon{background:#ffffff1f}.widget-card-dark .widget-icon .material-symbols-outlined{color:#fff}.widget-card-accent .widget-icon{background:#fff3}.widget-card-accent .widget-icon .material-symbols-outlined{color:#fff}.widget-badge{font-size:var(--font-xs);font-weight:700;padding:4px 10px;border-radius:var(--radius-full);background:var(--accent-light);color:var(--accent);display:inline-flex;align-items:center;gap:3px}.widget-card-dark .widget-badge{background:#ffffff1f;color:#ffffffe6}.widget-value{font-size:var(--font-3xl);font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:4px}.widget-card-dark .widget-value,.widget-card-accent .widget-value{color:#fff}.widget-label{font-size:var(--font-sm);font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.06em}.widget-card-dark .widget-label{color:#fff9}.widget-card-accent .widget-label{color:#fffc}.widget-sublabel{font-size:var(--font-md);color:#6b7280;font-weight:500;margin-top:2px}.widget-actions{display:flex;gap:.5rem;margin-top:.75rem}.widget-action-btn{padding:6px 16px;font-size:var(--font-sm);font-weight:600;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.widget-action-btn-fill{background:var(--accent);color:#fff}.widget-action-btn-fill:hover{background:var(--accent-hover)}.widget-action-btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.widget-action-btn-outline:hover{border-color:var(--accent);color:var(--accent)}.widget-card-dark .widget-action-btn-outline{border-color:#fff3;color:#fffc}.widget-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(0,auto);gap:.875rem;margin-bottom:.875rem;align-items:stretch}.widget-grid>*{min-height:0}.widget-grid .span-2{grid-column:span 2}.widget-grid .span-3{grid-column:span 3}.widget-grid .span-4{grid-column:span 4}.widget-grid .row-span-2{grid-row:span 2}.greeting-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem;gap:1rem}.greeting-left{display:flex;align-items:center;gap:.875rem;flex-shrink:0}.greeting-date-circle{width:50px;height:50px;border-radius:var(--radius-full);border:2px solid var(--text-primary);display:flex;align-items:center;justify-content:center;font-size:var(--font-xl);font-weight:700;color:var(--text-primary);flex-shrink:0}.greeting-day-info{display:flex;flex-direction:column;gap:1px}.greeting-day-name{font-size:var(--font-base);font-weight:600;color:var(--text-primary);line-height:1}.greeting-month{font-size:var(--font-base);font-weight:500;color:var(--text-muted)}.greeting-cta{display:inline-flex;align-items:center;gap:.5rem;padding:8px 20px;background:var(--accent);color:#fff;border-radius:var(--radius-full);font-size:var(--font-base);font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:0 2px 8px #d4654a40;white-space:nowrap}.greeting-cta:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px #d4654a4d}.greeting-cta .material-symbols-outlined{font-size:16px}.greeting-right{text-align:right;flex-shrink:0}.greeting-title{font-size:var(--font-2xl);font-weight:700;color:var(--text-primary);line-height:1.2}.greeting-subtitle{font-size:var(--font-md);color:var(--text-muted);font-weight:400}.dot-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:.5rem}.dot-grid-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);opacity:.3;transition:opacity var(--transition-fast)}.dot-grid-dot.active{opacity:1}.dot-grid-dot.warning{background:var(--color-warning);opacity:1}.dot-grid-dot.danger{background:var(--color-danger);opacity:1}.circular-progress{position:relative;width:80px;height:80px}.circular-progress svg{transform:rotate(-90deg);width:80px;height:80px}.circular-progress .track{fill:none;stroke:#f0efec;stroke-width:6}.circular-progress .fill{fill:none;stroke:var(--accent);stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.4,0,.2,1)}.circular-progress-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.circular-progress-value{font-size:var(--font-lg);font-weight:700;color:var(--text-primary);line-height:1}.circular-progress-unit{font-size:var(--font-xs);color:var(--text-muted);font-weight:600}.circular-progress-lg{width:100px;height:100px}.circular-progress-lg svg{width:100px;height:100px}.circular-progress-lg .track,.circular-progress-lg .fill{stroke-width:7}.circular-progress-lg .circular-progress-value{font-size:var(--font-xl)}.activity-section{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-widget);overflow:hidden;display:flex;flex-direction:column;border:1px solid transparent;transition:all var(--transition-base)}.activity-section:hover{box-shadow:var(--shadow-widget-hover);transform:translateY(-2px)}.activity-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem .75rem}.activity-title{font-size:var(--font-lg);font-weight:700;color:var(--text-primary)}.activity-filters{display:flex;gap:.5rem;padding:0 1.25rem .75rem}.activity-filter{display:inline-flex;align-items:center;gap:4px;padding:5px 14px;border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:1px solid var(--border-color);background:#fff;color:var(--text-secondary)}.activity-filter.active{background:var(--accent);color:#fff;border-color:var(--accent)}.activity-filter:hover:not(.active){border-color:var(--accent);color:var(--accent)}.activity-filter .close-x{font-size:12px;cursor:pointer;opacity:.8}.activity-list{list-style:none;padding:0;margin:0;flex:1;overflow-y:auto}.activity-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-top:1px solid var(--border-light);transition:background var(--transition-fast);cursor:pointer}.activity-item:hover{background:var(--bg-hover-row)}.activity-icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon.swap{background:var(--accent-light);color:var(--accent)}.activity-icon.charge{background:var(--color-success-bg);color:var(--color-success)}.activity-icon.alert{background:var(--color-warning-bg);color:var(--color-warning)}.activity-icon.error{background:var(--color-danger-bg);color:var(--color-danger)}.activity-icon.verification{background:#f0fdf4;color:#16a34a}.activity-icon .material-symbols-outlined{font-size:18px}.activity-content{flex:1;min-width:0}.activity-text{font-size:var(--font-md);color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-time{font-size:var(--font-sm);color:var(--text-muted);white-space:nowrap}.metric-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:1.25rem 1rem;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;transition:all var(--transition-base);min-height:0;box-shadow:var(--shadow-card)}.metric-card:hover{border-color:var(--accent-10);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.metric-card .material-symbols-outlined{font-size:24px;color:var(--accent);margin-bottom:var(--space-sm)}.metric-value{font-size:var(--font-2xl);font-weight:700;color:#111827;line-height:1}.metric-value .unit{font-size:var(--font-md);font-weight:400;color:#6b7280;margin-left:2px}.metric-label{font-size:var(--font-sm);font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;margin-top:6px;margin-bottom:8px}.metric-trend{display:inline-flex;align-items:center;gap:2px;padding:2px 8px;border-radius:4px;font-size:var(--font-sm);font-weight:700}.metric-trend .material-symbols-outlined{font-size:14px;margin:0;color:inherit}.metric-trend.up{background:#f0fdf4;color:#15803d}.metric-trend.down{background:var(--color-danger-bg);color:var(--color-danger)}.metric-trend.neutral{background:#f9fafb;color:#6b7280}.metric-trend.peak{background:#fefce8;color:#a16207}.metric-trend.optimal{background:#f0fdf4;color:#15803d}.metric-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;margin-bottom:2rem}.kpi-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:var(--space-xl);transition:all var(--transition-base);box-shadow:var(--shadow-card)}.kpi-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.kpi-icon{width:44px;height:44px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:var(--accent-light)}.kpi-icon .material-symbols-outlined{font-size:22px;color:var(--accent)}.kpi-value{font-size:var(--font-2xl);font-weight:700;color:#111827;line-height:1.1}.kpi-label{font-size:var(--font-md);color:#6b7280;font-weight:500;margin-top:4px}.station-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:1.25rem;transition:all var(--transition-base);cursor:pointer;box-shadow:var(--shadow-card);display:flex;flex-direction:column}.station-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px);border-color:var(--accent-10)}.station-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.station-card-icon{width:40px;height:40px;border-radius:var(--radius-md);background:var(--accent-light);display:flex;align-items:center;justify-content:center}.station-card-icon .material-symbols-outlined{font-size:22px;color:var(--accent)}.station-id{font-size:var(--font-xs);font-weight:700;color:var(--accent);background:var(--accent-light);padding:3px 10px;border-radius:4px;letter-spacing:.02em;display:inline-block;margin-top:.5rem}.station-name{font-size:1rem;font-weight:700;color:#111827;margin-bottom:2px}.station-location{font-size:var(--font-sm);color:#6b7280;display:flex;align-items:center;gap:4px;margin-bottom:0}.station-location .material-symbols-outlined{font-size:14px}.station-detail-rows{display:flex;flex-direction:column;gap:0;margin-top:.875rem;padding-top:.875rem;border-top:1px solid var(--border-light)}.station-detail-row{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0}.station-detail-row+.station-detail-row{border-top:1px solid var(--border-light)}.station-detail-label{display:flex;align-items:center;gap:.375rem;font-size:var(--font-sm);font-weight:600;color:#6b7280}.station-detail-label .material-symbols-outlined{font-size:16px}.station-detail-value{font-size:var(--font-sm);font-weight:700;color:var(--text-primary)}.station-detail-value.highlight-success{color:var(--color-success)}.station-detail-value.highlight-accent{color:var(--accent)}.station-detail-value.highlight-warning{color:var(--color-warning)}.station-card-footer{margin-top:.875rem;padding-top:.875rem;border-top:1px solid var(--border-light)}.station-revenue-block{display:flex;align-items:center;justify-content:space-between}.station-revenue-label{font-size:var(--font-xs);font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.06em}.station-revenue-value{font-size:var(--font-lg);font-weight:700;color:#111827}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:700;letter-spacing:.02em}.badge-dot{width:6px;height:6px;border-radius:50%}.badge.online,.badge.operational,.badge.available{background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}.badge.online .badge-dot,.badge.operational .badge-dot{background:#22c55e}.badge.maintenance{background:#fefce8;color:#a16207;border:1px solid #fde68a}.badge.maintenance .badge-dot{background:#f59e0b}.badge.offline,.badge.fault{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border)}.badge.charging{background:var(--accent-light);color:var(--accent);border:1px solid rgba(212,101,74,.2)}.badge.charging .badge-dot{background:var(--accent)}.badge.empty{background:#f9fafb;color:#9ca3af;border:1px solid #e5e7eb}.data-table-wrap{overflow-x:auto}.data-table{width:100%;text-align:left}.data-table thead{background:var(--bg-table-head)}.data-table thead th{padding:16px 24px;font-size:var(--font-xs);font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.data-table tbody tr{border-bottom:1px solid var(--border-light);transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-hover-row)}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody td{padding:16px 24px;font-size:var(--font-md);color:#525252;font-weight:500}.data-table tbody td.bold{font-weight:700;color:#111827}.pod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:var(--space-base)}.pod-slot{aspect-ratio:1;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:var(--font-xs);font-weight:700;transition:all var(--transition-base);cursor:pointer;border:1px solid}.pod-slot:hover{transform:scale(1.05)}.pod-slot .material-symbols-outlined{font-size:24px}.pod-slot-id{font-size:10px;font-weight:700}.pod-slot-soc{font-size:var(--font-sm);font-weight:700}.pod-slot.ready{background:#d4654a0f;border-color:#d4654a33;color:var(--accent)}.pod-slot.charging{background:#f8fafc;border-color:#e2e8f0;color:#94a3b8}.pod-slot.empty{background:#f8fafc80;border:2px dashed #e2e8f0;color:#cbd5e1}.pod-slot.fault{background:#fef2f2;border-color:#fecaca;color:#ef4444}.progress-bar{height:6px;background:#f3f4f6;border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-full);transition:width .6s ease}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.25rem}.page-title{font-size:var(--font-3xl);font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.page-desc{font-size:var(--font-md);color:#6b7280;font-weight:500;margin-top:8px}.time-tabs{display:flex;background:var(--bg-body);border-radius:var(--radius-md);padding:4px;border:1px solid var(--border-light)}.time-tab{padding:8px 20px;font-size:var(--font-sm);font-weight:700;color:#6b7280;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.time-tab:hover{color:var(--text-primary)}.time-tab.active{background:#fff;color:var(--text-primary);box-shadow:0 1px 2px #0000000d;border:1px solid var(--border-light)}.filter-bar{display:flex;gap:var(--space-sm);flex-wrap:wrap}.filter-chip{padding:6px 16px;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-base);font-weight:500;color:#525252;cursor:pointer;transition:all var(--transition-fast)}.filter-chip:hover,.filter-chip.active{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);font-weight:600;border-radius:var(--radius-lg);transition:all var(--transition-base);font-size:var(--font-md)}.btn .material-symbols-outlined{font-size:18px}.btn-primary{padding:10px 20px;background:var(--accent);color:#fff;box-shadow:0 2px 8px #d4654a40}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 16px #d4654a4d;transform:translateY(-1px)}.btn-outline{padding:10px 20px;border:1px solid var(--border-color);color:#374151;background:#fff}.btn-outline:hover{background:var(--accent-light);border-color:var(--accent-10);color:var(--accent)}.chart-legend{display:flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap}.chart-legend-item{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-sm);font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.04em}.chart-legend-dot{width:8px;height:8px;border-radius:50%}.back-link{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:var(--font-md);font-weight:500;color:#6b7280;cursor:pointer;margin-bottom:var(--space-lg);transition:color var(--transition-fast)}.back-link:hover{color:var(--accent)}.back-link .material-symbols-outlined{font-size:18px}.app-footer{padding:2rem;text-align:center;color:#9ca3af;font-size:var(--font-md);font-weight:500;border-top:1px solid var(--border-light);margin-top:auto}.app-footer a{color:#9ca3af;font-weight:500;transition:color var(--transition-fast)}.app-footer a:hover{color:var(--accent)}.soc-bar{width:52px;height:5px;background:#f3f4f6;border-radius:var(--radius-full);overflow:hidden;display:inline-block;vertical-align:middle;margin-right:var(--space-sm)}.soc-fill{height:100%;border-radius:var(--radius-full)}.inventory-controls{display:flex;align-items:center;justify-content:space-between;gap:var(--space-base);margin-bottom:var(--space-lg);flex-wrap:wrap}.inventory-search{display:flex;align-items:center;gap:var(--space-sm);background:var(--bg-body);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:8px 16px;min-width:280px;transition:all var(--transition-base)}.inventory-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-20)}.inventory-search .material-symbols-outlined{font-size:18px;color:#9ca3af}.inventory-search input{flex:1;font-size:var(--font-md);background:transparent}.inventory-search input::placeholder{color:#9ca3af}.content-sidebar{display:grid;grid-template-columns:1fr 340px;gap:.875rem;margin-bottom:.875rem}.quick-action-card{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-widget);padding:1.25rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.5rem;transition:all var(--transition-base);border:1px solid transparent}.quick-action-card:hover{box-shadow:var(--shadow-widget-hover);transform:translateY(-2px);border-color:var(--accent-10)}.quick-action-icon{width:48px;height:48px;border-radius:var(--radius-full);background:var(--accent-light);display:flex;align-items:center;justify-content:center}.quick-action-icon .material-symbols-outlined{font-size:24px;color:var(--accent)}.quick-action-title{font-size:var(--font-md);font-weight:700;color:var(--text-primary)}.quick-action-desc{font-size:var(--font-sm);color:var(--text-muted);line-height:1.4}.quick-action-btn{padding:8px 24px;background:var(--accent);color:#fff;border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.quick-action-btn:hover{background:var(--accent-hover)}.sparkline-wrap{height:40px;margin-top:.5rem}.sparkline-wrap canvas{width:100%!important;height:100%!important}.mini-bars{display:flex;align-items:flex-end;gap:3px;height:40px;margin-top:.5rem}.mini-bar{flex:1;border-radius:2px;transition:height .5s cubic-bezier(.4,0,.2,1);min-width:4px}.station-mini{display:flex;align-items:center;gap:.5rem;padding:.5rem 0}.station-mini-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.station-mini-name{flex:1;font-size:var(--font-md);font-weight:600;color:var(--text-primary)}.station-mini-val{font-size:var(--font-md);font-weight:700;color:var(--text-primary)}.full-width-section{grid-column:1 / -1}.rev-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.rev-title{font-size:var(--font-3xl);font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.1}.rev-subtitle{font-size:var(--font-md);color:var(--text-muted);margin-top:4px;font-weight:500}.rev-btn-outline{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--font-md);font-weight:600;color:var(--text-secondary);background:#fff;cursor:pointer;transition:all var(--transition-fast)}.rev-btn-outline:hover{border-color:var(--accent);color:var(--accent)}.rev-btn-dark{display:inline-flex;align-items:center;gap:6px;padding:9px 20px;border-radius:var(--radius-full);font-size:var(--font-md);font-weight:600;color:#fff;background:#1a1a1a;cursor:pointer;transition:all var(--transition-fast)}.rev-btn-dark:hover{background:#333}.rev-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.25rem}.rev-kpi-card{background:#fff;border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-card);border:1px solid var(--border-light);position:relative;overflow:hidden}.rev-kpi-decor{position:absolute;top:-24px;right:-24px;width:110px;height:110px;border-radius:50%;background:#d4654a1a;pointer-events:none}.rev-kpi-label{font-size:var(--font-xs);font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.07em;margin-bottom:.375rem}.rev-kpi-value{font-size:2.25rem;font-weight:700;color:var(--text-primary);line-height:1.1;margin-bottom:.5rem;letter-spacing:-.02em}.rev-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:700}.rev-badge-up{background:#dcfce7;color:#15803d}.rev-badge-down{background:#fef2f2;color:#dc2626}.rev-badge-track{background:var(--accent-light);color:var(--accent)}.rev-charts-row{display:grid;grid-template-columns:3fr 2fr;gap:1rem;margin-bottom:1.25rem}.rev-lower-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}.rev-card{background:#fff;border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-card);border:1px solid var(--border-light)}.rev-card-title{font-size:var(--font-lg);font-weight:700;color:var(--text-primary)}.rev-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.rev-link{font-size:var(--font-sm);font-weight:600;color:var(--accent);cursor:pointer;transition:opacity var(--transition-fast)}.rev-link:hover{opacity:.75}.rev-donut-wrap{position:relative;width:160px;height:160px;margin:1.25rem auto 0}.rev-donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.rev-donut-pct{font-size:var(--font-2xl);font-weight:700;color:var(--text-primary);line-height:1}.rev-donut-lbl{font-size:var(--font-xs);color:#9ca3af;font-weight:600;margin-top:3px}.rev-attr-legend{margin-top:1.25rem;display:flex;flex-direction:column;gap:.75rem}.rev-attr-row{display:flex;align-items:center;justify-content:space-between}.rev-station-item{margin-bottom:1.125rem}.rev-station-item:last-child{margin-bottom:0}.rev-station-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}.rev-station-bar{height:5px;background:#f3f4f6;border-radius:var(--radius-full);overflow:hidden}.rev-station-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width .6s ease}.hm-grid{display:flex;flex-direction:column;gap:6px}.hm-row{display:flex;align-items:center;gap:6px}.hm-week-label{font-size:10px;font-weight:600;color:var(--text-muted);width:40px;text-align:right;flex-shrink:0}.hm-day-label{flex:1;font-size:10px;font-weight:700;color:#9ca3af;text-align:center}.hm-cell{flex:1;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;cursor:pointer;transition:transform .22s cubic-bezier(.22,1,.36,1),opacity .22s ease,background .22s ease,box-shadow .22s ease}.hm-grid:hover .hm-cell{opacity:.32;transform:scale(.97)}.hm-grid:hover .hm-cell:hover{opacity:1;transform:scale(1.1);background:#db3912!important;color:#fff!important;box-shadow:0 6px 20px #db391259;z-index:2;position:relative}.hm-lvl-0{background:#f5ebe8;color:transparent}.hm-lvl-1{background:#f0c9b8;color:var(--text-muted)}.hm-lvl-2{background:#e8a48e;color:var(--text-secondary)}.hm-lvl-3{background:#d4654a;color:#fff}.hm-lvl-4{background:#db3912;color:#fff}.hm-grid:hover .hm-lvl-0:hover{color:var(--text-muted)}.hm-legend{display:flex;align-items:center;gap:6px;margin-top:14px;justify-content:flex-end}.hm-legend-text{font-size:10px;color:var(--text-muted);font-weight:500}.hm-legend-swatch{width:16px;height:16px;border-radius:4px}.rev-table-card{margin-bottom:1.25rem}.rev-table{width:100%;border-collapse:collapse}.rev-table thead th{padding:14px 20px;font-size:var(--font-xs);font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-light);text-align:left;white-space:nowrap}.rev-table tbody td{padding:15px 20px;font-size:var(--font-md);color:var(--text-secondary);font-weight:500;border-bottom:1px solid var(--border-light)}.rev-table-row:last-child td{border-bottom:none}.rev-table-row{transition:background var(--transition-fast)}.rev-table-row:hover{background:var(--bg-hover-row)}.rev-eff-bar{display:flex;align-items:center;gap:8px}.rev-eff-track{width:64px;height:5px;background:#f3f4f6;border-radius:var(--radius-full);overflow:hidden;flex-shrink:0}.rev-eff-fill{height:100%;background:var(--accent);border-radius:var(--radius-full)}.rev-icon-btn{width:34px;height:34px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:var(--bg-body);border:1px solid var(--border-light);cursor:pointer;color:var(--text-muted);transition:all var(--transition-fast)}.rev-icon-btn:hover{border-color:var(--accent);color:var(--accent)}.rev-icon-btn .material-symbols-outlined{font-size:17px}.rev-sort-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border-color);background:var(--bg-card);border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.rev-sort-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-10)}.rev-sort-btn .material-symbols-outlined{font-size:16px}.rev-chart-tooltip{position:absolute;pointer-events:none;z-index:999;opacity:0;transition:opacity .12s ease;min-width:148px;background:#111;border-radius:16px;padding:14px 16px;box-shadow:0 16px 48px #0006,0 0 0 1px #ffffff12}.rev-tt-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;gap:8px}.rev-tt-month{font-size:10px;font-weight:700;color:#ffffff61;text-transform:uppercase;letter-spacing:.09em}.rev-tt-mom{font-size:10px;font-weight:700;padding:2px 7px;border-radius:99px}.rev-tt-mom.up{background:#4ade8026;color:#4ade80}.rev-tt-mom.down{background:#f8717126;color:#f87171}.rev-tt-mom.neutral{background:#ffffff14;color:#ffffff59}.rev-tt-value{font-size:26px;font-weight:800;color:#fff;line-height:1;margin-bottom:12px;letter-spacing:-.5px}.rev-tt-unit{font-size:14px;font-weight:600;color:#ffffff73;margin-left:2px}.rev-tt-track{height:4px;background:#ffffff14;border-radius:99px;overflow:hidden;margin-bottom:8px}.rev-tt-fill{height:100%;background:linear-gradient(90deg,#d4654a99,#d4654a);border-radius:99px;transition:width .2s ease}.rev-tt-sub{font-size:10px;color:#ffffff4d;font-weight:500}.rev-tt-rows{display:flex;flex-direction:column;gap:7px;margin:10px 0 4px}.rev-tt-row{display:flex;align-items:center;gap:8px}.rev-tt-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.rev-tt-lbl{font-size:11px;color:#ffffff73;font-weight:500;flex:1}.rev-tt-val{font-size:11px;color:#fff;font-weight:700}.chart-tabs{display:flex;gap:2px;background:#f9fafb;border-radius:var(--radius-md);padding:4px;border:1px solid var(--border-light)}.chart-tab{padding:8px 20px;border-radius:6px;font-size:var(--font-sm);font-weight:700;color:#6b7280;cursor:pointer;transition:all var(--transition-fast)}.chart-tab:hover{color:#111827}.chart-tab.active{background:#fff;color:#111827;box-shadow:0 1px 2px #0000000d;border:1px solid var(--border-light)}.metric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-base);margin-bottom:2rem}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg);margin-bottom:2.5rem}.content-sidebar{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-lg);margin-bottom:2.5rem}.full-width-section{margin-bottom:2.5rem}.station-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg)}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-lg);margin-bottom:2.5rem}.revenue-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:var(--space-lg);margin-bottom:2.5rem}.chart-container{position:relative;width:100%}.chart-container canvas{max-width:100%}@media(min-width:1400px){.metric-grid{grid-template-columns:repeat(6,1fr)}}@media(max-width:1024px){.metric-grid{grid-template-columns:repeat(2,1fr)}.content-sidebar,.detail-grid,.revenue-grid{grid-template-columns:1fr}}
