@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#0d0f14;--bg-surface:#13161e;--bg-card:#1a1e2a;--bg-card-hover:#1f2435;--border:#252a38;--border-light:#2e3448;--text-primary:#e8eaf0;--text-secondary:#8b92a8;--text-muted:#555e78;--accent:#6366f1;--accent-light:#818cf8;--accent-glow:#6366f12e;--green:#22c55e;--green-dim:#22c55e1f;--amber:#f59e0b;--amber-dim:#f59e0b1f;--rose:#f43f5e;--rose-dim:#f43f5e1f;--cyan:#06b6d4;--cyan-dim:#06b6d41f;--sidebar-w:248px;--radius:10px;--radius-sm:7px;--shadow:0 4px 24px #0006}html,body,#root{background:var(--bg-base);height:100%;color:var(--text-primary);font-family:Inter,sans-serif;font-size:13px;line-height:1.55}.app-layout{height:100vh;display:flex;overflow:hidden}.main-wrapper{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.top-bar{background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;height:44px;padding:0 16px;display:flex}.topbar-toggle{border:1px solid var(--border);background:var(--bg-card);width:30px;height:30px;color:var(--text-secondary);cursor:pointer;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex}.topbar-toggle:hover{background:var(--accent-glow);color:var(--accent-light);border-color:#6366f159}.topbar-brand{flex-direction:column;gap:1px;line-height:1.2;display:flex}.topbar-brand-name{color:var(--text-primary);letter-spacing:-.3px;font-size:13px;font-weight:700}.topbar-brand-sub{color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;font-size:9.5px;font-weight:400}.topbar-spacer{flex:1}.topbar-user{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;padding:5px 10px;display:flex}.topbar-user-role{color:var(--accent-light);background:var(--accent-glow);letter-spacing:.3px;white-space:nowrap;border-radius:4px;padding:2px 7px;font-size:10.5px;font-weight:600}.topbar-user-name{color:var(--text-primary);white-space:nowrap;font-size:12.5px;font-weight:600}.main-content{background:var(--bg-base);zoom:.8;flex:1;padding:14px 18px;overflow-y:auto}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);zoom:.9;flex-direction:column;flex-shrink:0;padding:0;transition:width .25s cubic-bezier(.4,0,.2,1),border-color .25s;display:flex;overflow:hidden}.sidebar-collapsed{border-right-color:#0000;width:0}.sidebar-mini{width:60px!important}.sidebar-mini .sidebar-logo-text{justify-content:center;padding:16px 0}.sidebar-logo-icon{justify-content:center;align-items:center;width:100%;padding:4px 0;display:flex}.sidebar-close-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;flex-shrink:0;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.sidebar-close-btn:hover{color:var(--text-primary);background:var(--bg-card)}.nav-item-icon{color:inherit;flex-shrink:0;align-items:center;display:flex}.nav-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.nav-icon-only{justify-content:center;width:100%;padding:9px 0}.nav-chevron-icon{color:var(--text-muted);flex-shrink:0;transition:transform .2s}.nav-chevron-icon.open{transform:rotate(90deg)}.nav-sub-item-deep{padding-left:48px}.nav-mini-divider{background:var(--border);height:1px;margin:6px 10px}.sidebar-footer-mini{justify-content:center;padding:8px 0;display:flex}.sidebar-logo-text{border-bottom:1px solid var(--border);flex-shrink:0;padding:9px 14px 8px}.sidebar-logo-text h2{color:var(--text-primary);letter-spacing:-.3px;white-space:nowrap;font-size:13.5px;font-weight:700}.sidebar-logo-text span{color:var(--text-muted);white-space:nowrap;font-size:10.5px;font-weight:400}.sidebar-section-label{color:var(--text-muted);letter-spacing:1.2px;text-transform:uppercase;padding:8px 16px 4px;font-size:10.5px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:0;padding:4px 8px;display:flex;overflow-y:auto}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:5px 9px;font-size:13.5px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-card);color:var(--text-primary)}.nav-item.active{background:var(--accent-glow);color:var(--accent-light);border:1px solid #6366f140}.nav-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:8px 10px}.sidebar-user{background:var(--bg-card);border-radius:var(--radius-sm);align-items:center;gap:10px;margin-bottom:6px;padding:8px 10px;display:flex}.user-avatar{background:var(--accent-glow);width:36px;height:36px;color:var(--accent-light);border:2px solid var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);text-transform:capitalize;font-size:11px}.logout-button{background:0 0;border:none;font-family:Inter,sans-serif;color:#f43f5e!important}.logout-button:hover{background:var(--rose-dim);color:var(--rose)!important}.nav-group{flex-direction:column;display:flex}.nav-group-header{justify-content:flex-start}.group-active{color:var(--text-primary)}.nav-chevron{color:var(--text-muted);flex-shrink:0;font-size:14px;font-weight:700;line-height:1;transition:transform .2s}.nav-chevron.open{transform:rotate(90deg)}.nav-sub-list{flex-direction:column;gap:0;margin-bottom:1px;display:flex}.nav-sub-item{color:var(--text-muted);padding:5px 10px 5px 28px;font-size:12px}.nav-sub-item:hover{background:var(--bg-card);color:var(--text-primary)}.nav-sub-item.active{background:var(--accent-glow);color:var(--accent-light);border:1px solid #6366f140;font-weight:600}.nav-sub-icon{margin-right:2px;font-size:13px}.logout-button .nav-dot{background:var(--rose)!important}.sidebar-nav .nav-item.active,.sidebar-nav .sb-item-active{color:#38bdf8;background:#0ea5e924;border:1px solid #0ea5e947;font-weight:600}.sidebar-nav .nav-item.active:hover,.sidebar-nav .sb-item-active:hover{background:#0ea5e933}.sb-section{flex-direction:column;margin-bottom:2px;display:flex}.sb-section-header{border-radius:var(--radius-sm);cursor:pointer;text-align:left;width:100%;color:var(--text-secondary);background:0 0;border:none;align-items:center;gap:9px;padding:6px 8px;font-size:12px;font-weight:600;transition:background .14s,color .14s;display:flex}.sb-section-header:hover{background:var(--bg-card);color:var(--text-primary)}.sb-section-has-active{color:var(--text-primary)}.sb-section-direct{text-decoration:none;display:flex}.sb-section-icon-wrap{flex-shrink:0;justify-content:center;align-items:center;width:16px;display:flex}.sb-section-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sb-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .2s}.sb-chevron.open{transform:rotate(90deg)}.sb-sub-list{flex-direction:column;gap:1px;margin-top:1px;margin-bottom:1px;padding-left:16px;display:flex}.sb-sub-item{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;align-items:center;gap:8px;width:100%;padding:5px 8px 5px 10px;font-size:12px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex}.sb-sub-item:hover{background:var(--bg-card);color:var(--text-primary)}.sb-deep-item{padding-left:24px}.sb-item-icon{color:inherit;flex-shrink:0;align-items:center;display:flex}.sb-item-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sb-nested-group{flex-direction:column;display:flex}.sb-nested-header{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;align-items:center;gap:8px;width:100%;padding:5px 8px 5px 10px;font-size:12px;font-weight:500;transition:background .12s,color .12s;display:flex}.sb-nested-header:hover{background:var(--bg-card);color:var(--text-primary)}.page-header{margin-bottom:12px}.page-header h1{color:var(--text-primary);letter-spacing:-.3px;font-size:16px;font-weight:700}.page-header p{color:var(--text-secondary);margin-top:2px;font-size:11.5px}.kpi-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;transition:border-color .2s,transform .2s;position:relative;overflow:hidden}.kpi-card:before{content:"";border-radius:var(--radius) var(--radius) 0 0;height:2px;position:absolute;top:0;left:0;right:0}.kpi-card.green:before{background:var(--green)}.kpi-card.amber:before{background:var(--amber)}.kpi-card.cyan:before{background:var(--cyan)}.kpi-card.accent:before{background:var(--accent)}.kpi-card:hover{border-color:var(--border-light);transform:translateY(-2px)}.kpi-label{color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase;margin-bottom:6px;font-size:9.5px;font-weight:600}.kpi-icon{margin-bottom:4px;font-size:14px}.kpi-value{color:var(--text-primary);letter-spacing:-.5px;font-size:22px;font-weight:700;line-height:1}.kpi-sub{flex-direction:column;gap:4px;max-height:80px;margin-top:6px;display:flex;overflow-y:auto}.kpi-sub-row{justify-content:space-between;align-items:center;font-size:11.5px;display:flex}.kpi-sub-label{color:var(--text-secondary)}.kpi-sub-val{color:var(--text-primary);font-weight:600}.filter-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:12px;padding:8px 14px;display:flex}.filter-group{flex-direction:column;gap:6px;display:flex}.filter-group label{color:var(--text-muted);letter-spacing:.6px;text-transform:uppercase;font-size:11px;font-weight:600}.filter-group select,.filter-group input{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;min-width:120px;padding:6px 10px;font-family:Inter,sans-serif;font-size:12px;transition:border-color .15s}.filter-group select:focus,.filter-group input:focus{border-color:var(--accent)}.filter-group input::placeholder{color:var(--text-muted)}.filter-apply{background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--bg-primary);cursor:pointer;align-self:flex-end;padding:6px 16px;font-family:Inter,sans-serif;font-size:12px;font-weight:500;transition:all .15s}.filter-apply:hover{background:var(--accent-light);border-color:var(--accent-light);transform:translateY(-1px);box-shadow:0 2px 8px #6366f14d}.filter-apply:active{transform:translateY(0)}.filter-reset{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;align-self:flex-end;padding:6px 12px;font-family:Inter,sans-serif;font-size:12px;transition:all .15s}.filter-reset:hover{border-color:var(--accent);color:var(--accent-light)}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:16px;padding:16px 20px}.chart-card h3{color:var(--text-primary);margin-bottom:2px;font-size:13px;font-weight:600}.chart-card p{color:var(--text-muted);margin-bottom:16px;font-size:11px}.table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;overflow:hidden}.table-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:9px 14px;display:flex}.table-header h3{color:var(--text-primary);font-size:13px;font-weight:600}.table-header span{color:var(--text-muted);font-size:11px}.table-header-right{align-items:center;gap:10px;display:flex}.excel-download-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#1d6f42;border:none;border-radius:5px;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;transition:background .2s;display:inline-flex}.excel-download-btn:hover{background:#155232}.table-wrap{max-height:420px;overflow:auto}table{border-collapse:collapse;width:100%}thead th{background:var(--bg-surface);text-align:left;color:var(--text-muted);letter-spacing:.8px;text-transform:uppercase;z-index:1;border-bottom:1px solid var(--border);padding:8px 12px;font-size:10px;font-weight:600;position:sticky;top:0}tbody tr{border-bottom:1px solid var(--border);transition:background .1s}tbody tr:hover{background:var(--bg-card-hover)}tbody tr:last-child{border-bottom:none}tbody td{color:var(--text-secondary);padding:8px 12px;font-size:12px}tbody td:first-child{color:var(--text-primary);font-weight:500}.table-total{background:var(--bg-surface);border-top:2px solid var(--border-light)}.table-total td{padding:9px 12px;font-weight:700;color:var(--text-primary)!important}.table-footer-fixed{background:var(--bg-surface);border-top:2px solid var(--border-light);z-index:2;position:sticky;bottom:0;left:0;right:0}.table-footer-content{justify-content:space-between;align-items:center;padding:10px 18px;display:flex}.footer-label{color:var(--text-primary);text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:600}.footer-value{color:var(--accent-light);letter-spacing:-.3px;font-size:14px;font-weight:700}.cc-summary-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px;display:grid}.cc-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;padding:11px 13px;text-decoration:none;transition:all .2s}.cc-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 16px #6366f11a}.cc-card-name{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px;font-size:11px;font-weight:600}.cc-card-value{color:var(--text-primary);letter-spacing:-.5px;font-size:20px;font-weight:700}.cc-card-label{color:var(--text-secondary);margin-top:2px;font-size:11px}.loading-state{height:200px;color:var(--text-muted);justify-content:center;align-items:center;gap:10px;font-size:14px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.badge{border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{background:var(--green-dim);color:var(--green)}.badge-amber{background:var(--amber-dim);color:var(--amber)}.badge-rose{background:var(--rose-dim);color:var(--rose)}.badge-cyan{background:var(--cyan-dim);color:var(--cyan)}.badge-accent{background:var(--accent-glow);color:var(--accent-light)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}@media (width<=1024px){:root{--sidebar-w:220px}.main-content{padding:14px 18px}.kpi-grid{gap:10px;grid-template-columns:repeat(2,1fr)!important}.cc-summary-grid{grid-template-columns:repeat(2,1fr);gap:10px}.filter-bar{flex-wrap:wrap;gap:8px}}@media (width<=768px){.sidebar{z-index:1000;height:100vh;transform:translateX(calc(-1 * var(--sidebar-w)));transition:transform .28s cubic-bezier(.4,0,.2,1),box-shadow .28s;position:fixed;top:0;left:0;box-shadow:0 0 40px #0009;width:var(--sidebar-w)!important}.sidebar-mini{transform:translateX(calc(-1 * var(--sidebar-w)));width:var(--sidebar-w)!important}.sidebar.sidebar-mobile-open{width:var(--sidebar-w)!important;transform:translate(0)!important}.sidebar-backdrop{z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;animation:.2s forwards backdropFadeIn;position:fixed;inset:0}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.main-wrapper{width:100%}.top-bar{z-index:100;height:50px;padding:0 14px;position:sticky;top:0}.topbar-toggle{width:38px;min-width:38px;height:38px}.topbar-brand-sub{display:none}.main-content{padding:12px 14px}.kpi-grid{gap:10px;grid-template-columns:repeat(2,1fr)!important}.kpi-value{font-size:20px}.kpi-card{padding:12px 14px}.cc-summary-grid{grid-template-columns:repeat(2,1fr);gap:10px}.cc-card-value{font-size:20px}.filter-bar{flex-direction:column;align-items:stretch;gap:10px;padding:12px}.filter-group{width:100%}.filter-group select,.filter-group input{width:100%;min-width:unset;padding:9px 12px;font-size:13px}.filter-apply,.filter-reset{text-align:center;justify-content:center;width:100%;padding:9px 16px;font-size:13px}.table-wrap{max-height:340px}.table-card{overflow-x:auto}.chart-card{padding:12px 14px}.page-header h1{font-size:16px}.page-header p{font-size:11px}.topbar-user{gap:6px;padding:4px 8px}.topbar-user-role{padding:2px 5px;font-size:10px}.topbar-user-name{text-overflow:ellipsis;max-width:90px;font-size:11px;overflow:hidden}}@media (width<=480px){.top-bar{gap:10px;padding:0 10px}.main-content{padding:10px}.kpi-grid{gap:8px;grid-template-columns:1fr!important}.cc-summary-grid{grid-template-columns:repeat(2,1fr);gap:8px}.kpi-value{font-size:22px}.cc-card-value{font-size:20px}.filter-bar{padding:10px}thead th{padding:7px 10px;font-size:9.5px}tbody td{padding:7px 10px;font-size:11.5px}.page-header{margin-bottom:12px}.page-header h1{font-size:14px}.topbar-user-role{display:none}.topbar-user{padding:4px 7px}.topbar-user-name{max-width:60px}}@media (width>=1440px){.main-content{padding:20px 32px}.kpi-grid{grid-template-columns:repeat(4,1fr)!important}.cc-summary-grid{grid-template-columns:repeat(4,1fr)}}.sidebar{transition:width .25s cubic-bezier(.4,0,.2,1),transform .28s cubic-bezier(.4,0,.2,1),border-color .25s,box-shadow .28s}@media (hover:none) and (pointer:coarse){.nav-item{min-height:42px;padding:10px 12px}.filter-apply,.filter-reset{min-height:42px}.topbar-toggle{min-width:42px;min-height:42px}.kpi-card:hover,.cc-card:hover{transform:none}}.chart-card .recharts-responsive-container{min-height:200px}.table-card{-webkit-overflow-scrolling:touch;overflow-x:auto}@media (width<=768px){.kpi-sub{max-height:72px}}.login-container{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow);padding:40px}.login-header{text-align:center;margin-bottom:32px}.login-logo{justify-content:center;align-items:center;gap:12px;margin-bottom:12px;display:flex}.logo-icon{font-size:32px}.login-logo h1{color:var(--text-primary);letter-spacing:-.5px;margin:0;font-size:24px;font-weight:700}.login-subtitle{color:var(--text-secondary);margin:0;font-size:13px}.login-form{flex-direction:column;gap:20px;display:flex}.login-error{background:var(--rose-dim);border:1px solid var(--rose);border-radius:var(--radius-sm);color:var(--rose);align-items:center;gap:10px;padding:12px 16px;font-size:13px;font-weight:500;display:flex}.error-icon{flex-shrink:0;font-size:16px}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-secondary);letter-spacing:.3px;font-size:12px;font-weight:600}.form-group input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:12px 14px;font-family:Inter,sans-serif;font-size:14px;transition:all .2s}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.form-group input:disabled{opacity:.6;cursor:not-allowed}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{width:100%;padding-right:45px}.password-toggle{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px 8px;font-size:18px;transition:all .2s;display:flex;position:absolute;right:12px}.password-toggle:hover:not(:disabled){color:var(--text-secondary);background:var(--bg-base)}.password-toggle:disabled{opacity:.5;cursor:not-allowed}.login-button{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;margin-top:4px;padding:12px 20px;font-family:Inter,sans-serif;font-size:14px;font-weight:600;transition:all .2s;display:flex}.login-button:hover:not(:disabled){background:var(--accent-light);box-shadow:0 4px 12px var(--accent-glow);transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin}.login-footer{border-top:1px solid var(--border);text-align:center;margin-top:24px;padding-top:24px}.login-footer p{color:var(--text-muted);margin:0;font-size:12px}.role-badge{background:var(--accent-glow);color:var(--accent-light);border-radius:6px;margin:0 4px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}@media (width<=480px){.login-box{border-radius:12px;padding:28px 20px}.login-logo h1{font-size:20px}.logo-icon{font-size:26px}.login-button{min-height:46px;padding:13px 20px;font-size:15px}.form-group input{padding:13px 14px;font-size:15px}.login-container{padding:16px}}
