@import"https://fonts.googleapis.com/css2?family=Barlow:wght@400;500;600;700&family=Rajdhani:wght@600;700&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{--background: #eaf1fb;--surface: #ffffff;--surface-soft: #f6f9ff;--foreground: #172333;--muted: #edf3fb;--muted-foreground: #5b6b84;--accent: #0091db;--accent-foreground: #ffffff;--border: #c8d4e8;--border-light: #dde6f4;--ring: #004ea2;--primary: #004ea2;--primary-hover: #003f84;--primary-foreground: #ffffff;--brand-cyan: #0091db;--brand-grey-dark: #4c4948;--brand-grey-light: #c1c6c8;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--font-display: "Rajdhani", "Barlow", "Segoe UI", "Microsoft YaHei", sans-serif;--font-body: "Barlow", "Segoe UI", "Microsoft YaHei", sans-serif;--font-mono: "IBM Plex Mono", "Cascadia Code", "Consolas", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-8: 3rem;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 10px rgba(7, 31, 71, .08);--shadow-md: 0 10px 24px rgba(7, 31, 71, .12);--shadow-lg: 0 18px 38px rgba(7, 31, 71, .16);--shadow-xl: 0 26px 60px rgba(7, 31, 71, .2);--sidebar-width: 268px;--topbar-height: 64px}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);background:radial-gradient(55rem 26rem at -5% -10%,rgba(0,78,162,.18) 0%,transparent 56%),radial-gradient(48rem 22rem at 100% 0%,rgba(0,145,219,.14) 0%,transparent 58%),repeating-linear-gradient(135deg,rgba(0,78,162,.03) 0px,rgba(0,78,162,.03) 1px,transparent 1px,transparent 14px),var(--background);color:var(--foreground);line-height:1.45;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100vh;overflow:hidden}#app{height:100vh;overflow:hidden}a{color:var(--accent);text-decoration:none;transition:color .2s ease,opacity .2s ease}a:hover{opacity:.7}button{font-family:var(--font-body);cursor:pointer}input,textarea,select{font-family:var(--font-body)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--foreground);letter-spacing:.01em}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl);font-weight:600}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-6)}*::selection{background:#0091db38;color:#0f172a}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#e7eef8;border-radius:999px}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#95afd2,#7b9ec8);border-radius:999px;border:2px solid #e7eef8}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#7f9fc9,#678bb8)}.loading{display:flex;align-items:center;justify-content:center;padding:var(--space-8);font-family:var(--font-body);font-size:var(--text-base);color:var(--muted-foreground)}.empty-state{text-align:center;padding:var(--space-8) var(--space-6);border:1px solid var(--border-light);border-radius:var(--radius-md)}.empty-state-title{font-family:var(--font-display);font-size:var(--text-xl);margin-bottom:var(--space-2);font-weight:600}.empty-state-text{font-family:var(--font-body);font-size:var(--text-base);color:var(--muted-foreground)}.version-badge{display:inline-block;font-family:var(--font-mono);font-size:var(--text-xs);padding:var(--space-1) var(--space-3);background:linear-gradient(180deg,#f5f9ff,#e8f1ff);color:#154072;border-radius:var(--radius-sm);border:1px solid #c2d5ee}.section-divider{height:1px;background:var(--border-light);margin:var(--space-6) 0}@media (max-width: 1024px){html{font-size:15px}}@media (max-width: 768px){html{font-size:14px}}.btn{font-family:var(--font-body);font-size:var(--text-sm);font-weight:700;padding:.5rem .88rem;border:1px solid var(--border);background:linear-gradient(180deg,#fff,#eef4ff);color:var(--foreground);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);box-shadow:0 1px #ffffffbf inset,0 3px 10px #0d295414;text-transform:uppercase;letter-spacing:.03em}.btn:hover{border-color:#92add2;transform:translateY(-1px);box-shadow:0 8px 18px #0d295424}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,#004ea2,#006fc1 42%,#0091db);color:var(--primary-foreground);border-color:#0a5eb5}.btn-primary:hover{background:linear-gradient(135deg,#003f84,#005ea7 42%,#007fc2)}.btn-secondary{background:linear-gradient(135deg,#29466d,#3b618f);border-color:#3b618f;color:#fff}.btn-secondary:hover{filter:brightness(1.04)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;color:var(--foreground);margin-bottom:var(--space-2)}.form-input{width:100%;padding:.58rem .72rem;font-family:var(--font-body);font-size:var(--text-sm);border:1px solid #b9cbe4;background:linear-gradient(180deg,#fff,#f5f9ff);color:var(--foreground);border-radius:var(--radius-sm);transition:all .2s ease}.form-input:focus{outline:none;border-color:#0b67c2;box-shadow:0 0 0 3px #0065bd33}.form-input::placeholder{color:var(--muted-foreground)}.card{background:var(--surface);border:1px solid #d4e0f2;padding:var(--space-5);border-radius:var(--radius-md);box-shadow:0 8px 20px #09274e14;transition:all .2s ease;position:relative;overflow:hidden}.card:hover{box-shadow:0 16px 30px #09274e21;border-color:#afc4e2}.card:before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:2px;background:linear-gradient(90deg,#004ea2,#0091db)}.card-label{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;color:var(--muted-foreground);margin-bottom:var(--space-2)}.card-value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:700;line-height:1;color:var(--foreground)}.card-unit{font-family:var(--font-body);font-size:var(--text-sm);color:var(--muted-foreground);margin-top:var(--space-2)}.grid{display:grid;gap:var(--space-5)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.table-wrapper{border:1px solid #cdd9eb;border-radius:var(--radius-md);overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 280px);background:var(--surface);box-shadow:0 8px 18px #08224814}.table-wrapper thead th{position:sticky;top:0;z-index:3;background:linear-gradient(180deg,#f4f8ff,#e9f1fe)}table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}th{font-family:var(--font-body);font-size:var(--text-xs);letter-spacing:.04em;text-transform:uppercase;font-weight:700;text-align:left;padding:.72rem .84rem;background:linear-gradient(180deg,#f4f8ff,#e9f1fe);color:#254164;border-bottom:1px solid #cfddef;white-space:nowrap}td{padding:.68rem .84rem;border-bottom:1px solid #edf2f8;font-family:var(--font-body);font-size:var(--text-sm);color:var(--foreground)}tr:last-child td{border-bottom:none}tr:hover td{background:#f2f7ff}.tabs{display:flex;border-bottom:1px solid var(--border-light);margin-bottom:var(--space-5);gap:var(--space-1)}.tab{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;padding:.6rem .95rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted-foreground);cursor:pointer;transition:all .15s ease;margin-bottom:-1px;border-top-left-radius:var(--radius-sm);border-top-right-radius:var(--radius-sm)}.tab:hover{color:var(--foreground);background:#f2f6fd}.tab.active{color:var(--primary);border-bottom-color:var(--primary);background:#ecf4ff}.page{padding:var(--space-6);height:calc(100vh - var(--topbar-height));overflow:hidden;display:flex;flex-direction:column;background:radial-gradient(80rem 34rem at 15% -15%,rgba(0,78,162,.14) 0%,transparent 60%),radial-gradient(72rem 30rem at 100% 0%,rgba(0,145,219,.12) 0%,transparent 56%),repeating-linear-gradient(135deg,rgba(0,78,162,.02) 0px,rgba(0,78,162,.02) 1px,transparent 1px,transparent 12px),var(--background);animation:pageFadeIn .35s ease}.page-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.table-container{flex:1;overflow:auto;position:relative;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md)}.table-container table{min-width:100%}.table-container th.sticky-left,.table-container td.sticky-left{position:sticky;left:0;z-index:2;background:var(--surface)}.table-container th.sticky-left-80,.table-container td.sticky-left-80{position:sticky;left:80px;z-index:2;background:var(--surface)}.table-container thead th{position:sticky;top:0;z-index:3;background:#eef3fb}.table-container thead th.sticky-left{z-index:4}.page-header{display:none!important}.page-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;line-height:1.2;margin-bottom:var(--space-1);letter-spacing:-.01em}.page-subtitle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--muted-foreground)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-5)}.stat-card{padding:var(--space-5);background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border-light);transition:all .2s ease;box-shadow:var(--shadow-sm)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-label{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;color:var(--muted-foreground);margin-bottom:var(--space-2)}.stat-value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:800;line-height:1;margin-bottom:var(--space-2)}.stat-unit{font-family:var(--font-body);font-size:var(--text-sm);color:var(--muted-foreground)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.dashboard-actions{display:flex;gap:var(--space-3);align-items:center}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:radial-gradient(44rem 28rem at 0% 0%,rgba(0,78,162,.15) 0%,transparent 62%),radial-gradient(44rem 28rem at 100% 100%,rgba(0,145,219,.14) 0%,transparent 62%),var(--background)}.login-container{width:100%;max-width:440px}.login-header{text-align:center;margin-bottom:var(--space-6)}.login-title{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:800;line-height:1.05;margin-bottom:var(--space-2)}.login-subtitle{font-family:var(--font-body);font-size:var(--text-base);color:var(--muted-foreground)}.login-form{background:var(--surface);padding:var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border-light)}.login-footer{margin-top:var(--space-5);text-align:center;font-family:var(--font-body);font-size:var(--text-sm);color:var(--muted-foreground)}.notification,.toast{position:fixed;top:var(--space-5);right:var(--space-5);padding:.75rem 1rem;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-family:var(--font-body);font-size:var(--text-sm);z-index:2000;min-width:260px;animation:slideIn .2s ease-out}.notification,.toast{background:#0f172a;color:#fff}.toast.success,.notification.success{background:var(--success)}.toast.error,.notification.error{background:var(--error)}.toast.warning,.notification.warning{background:var(--warning)}@keyframes slideIn{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{width:min(520px,92vw);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border:1px solid var(--border-light);padding:var(--space-6)}.modal-header{margin-bottom:var(--space-5)}.modal-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-xl)}.modal-body{margin-bottom:var(--space-5)}.modal-footer{display:flex;gap:var(--space-3);justify-content:flex-end}.sidebar{width:var(--sidebar-width);background:linear-gradient(190deg,#0f2b4f,#123763 45%,#114a7d);border-right:1px solid rgba(124,160,206,.35);padding:var(--space-5) 0;position:fixed;height:100vh;overflow-y:auto;box-shadow:8px 0 24px #05183338}.sidebar-header{padding:0 var(--space-5) var(--space-5);border-bottom:1px solid rgba(156,187,225,.25);margin-bottom:var(--space-4)}.sidebar-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;color:#f2f7ff;letter-spacing:-.01em}.sidebar-subtitle{font-family:var(--font-body);font-size:var(--text-sm);color:#c4d9f4;margin-top:var(--space-1)}.nav-menu{list-style:none;padding:0}.nav-item{padding:0}.nav-link{display:block;margin:.1rem .55rem;padding:.56rem .78rem;font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;color:#d7e7fc;text-decoration:none;transition:all .15s ease;border-radius:10px}.nav-link:hover{background:#76abea33;color:#fff}.nav-link.active{background:linear-gradient(135deg,#0a69c0,#0b8ad5 55%,#27acef);color:#fff;box-shadow:0 8px 20px #0f9eff52}.nav-section{padding:var(--space-3) var(--space-5);font-family:var(--font-body);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#9ebce2;margin-top:var(--space-3)}.main-content{flex:1;margin-left:var(--sidebar-width);height:100vh;background:var(--background);display:flex;flex-direction:column;overflow:hidden}.topbar{height:var(--topbar-height);background:#fffc;border-bottom:1px solid #cfdced;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);position:sticky;top:0;z-index:100}.topbar-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;letter-spacing:.02em;color:#183154}.topbar-user{font-family:var(--font-body);font-size:var(--text-sm);display:flex;align-items:center;gap:var(--space-4);color:var(--muted-foreground)}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1024px){.stats-grid,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid var(--border-light)}.main-content{margin-left:0}.stats-grid,.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.dashboard-header{flex-direction:column;gap:var(--space-4);align-items:flex-start}}
