:root{--primary:#2d4aff;--primary-light:#5c72ff;--primary-lighter:#eef0ff;--primary-dark:#1a35e8;--primary-bg:#2d4aff0f;--primary-border:#2d4aff33;--text:#5b6b82;--text-h:#0a1628;--text-secondary:#8d9bb0;--bg:#fff;--bg-page:#f5f7fa;--bg-sidebar:#0b1426;--bg-hover:#edf0f7;--border:#dfe3ec;--border-light:#edf0f7;--danger:#ef4444;--danger-bg:#ef444414;--warning:#f59e0b;--success:#00d4aa;--info:#2d4aff;--shadow-sm:0 1px 2px #0a16280a;--shadow:0 1px 3px #0a162814, 0 1px 2px #0a16280a;--shadow-md:0 4px 12px #0a162814, 0 2px 4px #0a16280a;--shadow-lg:0 12px 24px #0a16281a, 0 4px 8px #0a16280f;--sans:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Noto Sans SC", sans-serif;--mono:ui-monospace, "SF Mono", Consolas, "Liberation Mono", monospace;--radius:8px;--radius-lg:12px;font:14px/1.6 var(--sans);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--primary:#5c72ff;--primary-light:#8b9dff;--primary-lighter:#5c72ff1f;--primary-dark:#2d4aff;--primary-bg:#5c72ff1a;--primary-border:#5c72ff40;--text:#8d9bb5;--text-h:#e8ecf4;--text-secondary:#5b6b82;--bg:#0f1a2e;--bg-page:#060d1a;--bg-sidebar:#060d1a;--bg-hover:#1a2640;--border:#1a2640;--border-light:#1a2640;--shadow-sm:0 1px 2px #0000004d;--shadow:0 1px 3px #0006, 0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006, 0 2px 4px #0000004d;--shadow-lg:0 12px 24px #00000080, 0 4px 8px #0006}}*{box-sizing:border-box}body{margin:0}h1,h2,h3,h4{color:var(--text-h);margin:0;font-weight:600}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-sidebar);z-index:30;border-right:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;width:240px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar ::-webkit-scrollbar-thumb{background:#ffffff1f}.sidebar ::-webkit-scrollbar-thumb:hover{background:#ffffff40}.sidebar-header{border-bottom:1px solid #ffffff14;align-items:center;gap:12px;padding:20px;display:flex}.sidebar-logo{color:#5c72ff;background:#2d4aff1f;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.sidebar-logo svg{width:34px;height:34px}.sidebar-brand{flex-direction:column;display:flex}.sidebar-brand h2{letter-spacing:-.01em;color:#fff;font-size:16px;font-weight:700;line-height:1.2}.sidebar-brand span{color:#fff6;font-size:11px;font-weight:400}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px;display:flex;overflow-y:auto}.nav-link{border-radius:var(--radius);color:#ffffff8c;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:450;text-decoration:none;transition:all .15s;display:flex;position:relative}.nav-link:hover{color:#ffffffe6;background:#ffffff0f}.nav-link.active,.nav-link.router-link-exact-active{color:#7b8aff;background:#2d4aff26;font-weight:600}.nav-link.active:before,.nav-link.router-link-exact-active:before{content:"";background:#2d4aff;border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-icon{opacity:.5;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-link:hover .nav-icon{opacity:.8}.nav-link.active .nav-icon,.nav-link.router-link-exact-active .nav-icon{opacity:1}.sidebar-footer{color:#ffffff47;border-top:1px solid #ffffff14;padding:16px 20px;font-size:11px}.main-area{flex-direction:column;flex:1;min-width:0;margin-left:240px;display:flex}.topbar{border-bottom:1px solid var(--border);background:var(--bg);z-index:20;flex-shrink:0;justify-content:space-between;align-items:center;height:60px;padding:0 28px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-right{align-items:center;gap:16px;display:flex}.user-avatar{background:var(--primary-bg);border:2px solid var(--primary-border);width:34px;height:34px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.user-name{color:var(--text-h);font-size:14px;font-weight:500}.page-content{flex:1;padding:28px;overflow-y:auto}.page-title{letter-spacing:-.01em;margin-bottom:24px;font-size:22px;font-weight:700}.card-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px;display:grid}.summary-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);padding:22px;transition:all .25s;position:relative;overflow:hidden}.summary-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-border);transform:translateY(-2px)}.summary-card:before{content:"";background:linear-gradient(90deg, var(--primary), var(--primary-light), #00d4aa);opacity:0;height:3px;transition:opacity .25s;position:absolute;top:0;left:0;right:0}.summary-card:hover:before{opacity:1}.card-icon{border-radius:10px;justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:14px;font-size:20px;display:flex}.card-icon.green{color:#00d4aa;background:#00d4aa1a}.card-icon.blue{color:#2d4aff;background:#2d4aff14}.card-icon.purple{color:#7c3aed;background:#7c3aed1a}.card-icon.amber{color:#f59e0b;background:#f59e0b1a}.card-icon.rose{color:#ff3860;background:#ff38601a}.card-icon.cyan{color:#00b8d4;background:#00b8d41a}.card-value{color:var(--text-h);letter-spacing:-.02em;margin-bottom:4px;font-size:28px;font-weight:700;line-height:1.2}.card-label{color:var(--text-secondary);font-size:13px;font-weight:450}.table-wrap{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);margin-bottom:16px;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}th,td{text-align:left;border-bottom:1px solid var(--border-light);white-space:nowrap;padding:12px 16px}th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;background:var(--bg);border-bottom:1px solid var(--border);font-size:12px;font-weight:600;position:sticky;top:0}tbody tr{transition:background .15s}tbody tr:hover td{background:var(--bg-hover)}tbody tr:last-child td{border-bottom:none}.text-center{text-align:center;color:var(--text-secondary);padding:40px 0}.tables-row{grid-template-columns:1fr 1fr;gap:24px;display:grid}.table-section{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.table-section h3{border-bottom:1px solid var(--border);margin:0;padding:16px 20px;font-size:15px}.table-section .table-wrap{border:none;border-radius:0;margin-bottom:0}@media (width<=1024px){.tables-row{grid-template-columns:1fr}}.filter-bar{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;padding:16px 20px;display:flex}.filter-bar span{color:var(--text-secondary);font-size:13px}.form-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-h);font-size:14px;font-family:var(--sans);outline:none;padding:8px 14px;transition:all .2s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.form-input::placeholder{color:var(--text-secondary)}select.form-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238D9BB0' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;font-size:14px;font-weight:500;font-family:var(--sans);border:none;align-items:center;gap:6px;padding:8px 20px;transition:all .2s;display:inline-flex}.btn-primary:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sm{padding:6px 14px;font-size:13px}.btn-text{border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:var(--radius);font-size:13px;font-family:var(--sans);background:0 0;padding:6px 14px;font-weight:450;transition:all .15s}.btn-text:hover{color:var(--primary);border-color:var(--primary-border);background:var(--primary-bg)}.pagination{justify-content:center;align-items:center;gap:12px;margin-top:20px;padding-top:16px;display:flex}.pagination button{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text-h);cursor:pointer;font-size:13px;font-weight:450;font-family:var(--sans);padding:7px 16px;transition:all .15s}.pagination button:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.page-info{color:var(--text-secondary);font-size:13px}.login-page{background:linear-gradient(160deg,#0b1426 0%,#0f1f3d 40%,#162955 70%,#1a3570 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(at 25%,#2d4aff1f 0%,#0000 60%),radial-gradient(at 75% 25%,#5c72ff14 0%,#0000 50%),radial-gradient(at 50% 80%,#00d4aa0d 0%,#0000 50%);position:absolute;inset:0}.login-page:after{content:"";background-image:radial-gradient(#ffffff0a 1px,#0000 1px);background-size:32px 32px;position:absolute;inset:0}.login-card{text-align:center;-webkit-backdrop-filter:blur(24px)saturate(150%);z-index:1;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:24px;width:420px;padding:48px 40px;animation:.6s ease-out cardFloat;position:relative;box-shadow:0 25px 60px #0000004d,inset 0 1px #ffffff14}@keyframes cardFloat{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.login-logo{color:#5c72ff;filter:drop-shadow(0 0 16px #2d4aff59);justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 28px;display:flex}.login-logo svg{width:80px;height:80px}@keyframes logoGlow{0%,to{filter:drop-shadow(0 0 16px #2d4aff4d)}50%{filter:drop-shadow(0 0 24px #2d4aff80)}}.login-logo{animation:3s ease-in-out infinite logoGlow}.login-card h1{letter-spacing:-.02em;color:#fff;margin:0 0 6px;font-size:26px;font-weight:700}.login-subtitle{color:#ffffff80;margin-bottom:36px;font-size:14px}.login-card form{flex-direction:column;gap:14px;display:flex}.login-card .form-input{color:#fff;background:#ffffff12;border-color:#ffffff1f;width:100%;padding:12px 16px;font-size:15px}.login-card .form-input::placeholder{color:#ffffff59}.login-card .form-input:focus{background:#ffffff1a;border-color:#5c72ff99;box-shadow:0 0 0 3px #2d4aff33}.login-card .btn-primary{background:linear-gradient(135deg,#2d4aff,#5c72ff);justify-content:center;width:100%;margin-top:6px;padding:12px;font-size:15px;font-weight:600;box-shadow:0 4px 15px #2d4aff59}.login-card .btn-primary:hover{background:linear-gradient(135deg,#1a35e8,#4a62ff);box-shadow:0 6px 20px #2d4aff73}.login-card .error-text{color:#ff6b6b;border-radius:var(--radius);background:#ef44441f;margin:0;padding:10px 14px;font-size:13px}.error-text{color:var(--danger);background:var(--danger-bg);border-radius:var(--radius);margin:0;padding:10px 14px;font-size:13px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-content>div{animation:.25s fadeIn}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.loading-text{color:var(--text-secondary);justify-content:center;align-items:center;gap:8px;padding:48px 0;font-size:14px;display:flex}.loading-text:before{content:"";border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-area{margin-left:0}.page-content{padding:20px 16px}.topbar{padding:0 16px}.card-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}
