@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-primary:#2563eb;--color-primary-dark:#1d4ed8;--color-primary-light:#3b82f6;--color-primary-glow:#2563eb66;--color-accent:#06b6d4;--color-accent-light:#22d3ee;--color-bg-dark:#0f1631;--color-bg-card:#121c34cc;--color-bg-card-hover:#182441e0;--color-surface:#1c2a488c;--color-border:#506eaa38;--color-border-focus:#3878f099;--color-text-primary:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--color-success:#10b981;--color-error:#ef4444;--color-warning:#f59e0b;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-glow:0 0 30px #2563eb26, 0 0 60px #06b6d414;--shadow-card:0 8px 32px #0000004d, 0 2px 8px #0003;--shadow-input:0 2px 8px #00000026;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);color:var(--color-text-primary);background:var(--color-bg-dark);min-height:100vh;line-height:1.6;overflow-x:hidden}a{color:var(--color-primary-light);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-accent-light)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.app-layout{background:var(--color-bg-dark);min-height:100vh;display:flex}.main-area{flex-direction:column;flex:1;min-width:0;margin-left:260px;transition:margin-left .3s cubic-bezier(.4,0,.2,1);display:flex}.sidebar-collapsed .main-area{margin-left:72px}.main-content{flex:1;padding:24px;overflow-y:auto}.sidebar{border-right:1px solid var(--color-border);z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0c1228f2;flex-direction:column;width:260px;height:100vh;transition:width .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0}.sidebar.collapsed{width:72px}.sidebar-overlay{display:none}.sidebar-header{border-bottom:1px solid var(--color-border);flex-shrink:0;padding:18px 16px}.sidebar-logo{align-items:center;gap:12px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;font-weight:800;display:flex}.logo-text{color:var(--color-text-primary);white-space:nowrap;font-size:16px;font-weight:700}.sidebar-nav{flex:1;padding:12px 0;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:#64748b4d;border-radius:4px}.sidebar-menu{margin:0;padding:0;list-style:none}.sidebar-item{margin:1px 8px}.sidebar-link{color:var(--color-text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;width:100%;padding:10px 12px;font-family:inherit;font-size:13.5px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.sidebar-link:hover{color:var(--color-text-primary);background:#3878f01a}.sidebar-link.active{color:var(--color-primary-light);background:linear-gradient(135deg,#3878f033 0%,#3878f01a 100%);font-weight:600}.sidebar-link.active .sidebar-icon{color:var(--color-primary-light)}.sidebar-icon{color:var(--color-text-muted);flex-shrink:0;align-items:center;transition:color .2s;display:flex}.sidebar-text{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sidebar-arrow{color:var(--color-text-muted);flex-shrink:0;align-items:center;transition:transform .2s;display:flex}.sidebar-submenu{border-left:1px solid #64748b26;margin:0 0 0 20px;padding:2px 0 2px 12px;list-style:none}.sidebar-submenu .sidebar-link{padding:7px 12px;font-size:12.5px}.sidebar-submenu .sidebar-submenu{margin-left:16px}.sidebar-footer{border-top:1px solid var(--color-border);flex-shrink:0;padding:12px 16px}.sidebar-version{color:var(--color-text-muted);text-align:center;font-size:11px}.topbar{border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:50;background:#0c1228cc;flex-shrink:0;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:16px;display:flex}.topbar-toggle{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;padding:8px;transition:all .2s;display:flex}.topbar-toggle:hover{color:var(--color-text-primary);background:#3878f01a}.topbar-greeting{color:var(--color-text-secondary);font-size:14px}.topbar-greeting strong{color:var(--color-text-primary)}.topbar-right{align-items:center;gap:8px;display:flex}.topbar-btn{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;padding:8px;transition:all .2s;display:flex}.topbar-btn:hover{color:var(--color-text-primary);background:#3878f01a}.topbar-logout:hover{color:#ef4444;background:#ef444426}.topbar-user{border:1px solid var(--color-border);background:#1c2a4880;border-radius:10px;align-items:center;gap:10px;padding:4px 12px 4px 4px;display:flex}.topbar-avatar{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.topbar-user-info{flex-direction:column;display:flex}.topbar-user-name{color:var(--color-text-primary);font-size:13px;font-weight:600;line-height:1.2}.topbar-user-role{color:var(--color-text-muted);text-transform:capitalize;font-size:11px}.coming-soon{justify-content:center;align-items:center;min-height:calc(100vh - 120px);display:flex}.coming-soon-card{text-align:center;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:16px;max-width:420px;padding:48px}.coming-soon-icon{color:var(--color-primary);opacity:.6;margin-bottom:16px}.coming-soon-card h2{color:var(--color-text-primary);margin:0 0 8px;font-size:24px;font-weight:700}.coming-soon-title{color:var(--color-primary-light);margin:0 0 12px;font-size:14px;font-weight:600}.coming-soon-desc{color:var(--color-text-muted);margin:0;font-size:13px;line-height:1.6}@media (width<=768px){.sidebar{width:280px;transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay{z-index:99;background:#00000080;display:block;position:fixed;inset:0}.main-area{margin-left:0!important}.main-content{padding:16px}.topbar-user-info,.topbar-greeting{display:none}}@media (width<=480px){.topbar{padding:0 12px}.main-content{padding:12px}}.login-page{background:var(--color-bg-dark);min-height:100vh;padding:var(--space-md);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-bg{z-index:0;position:absolute;inset:0}.login-bg canvas{width:100%;height:100%}.login-bg:after{content:"";pointer-events:none;background:radial-gradient(at 30% 20%,#2563eb1f 0%,#0000 60%),radial-gradient(at 70% 80%,#06b6d414 0%,#0000 60%);position:absolute;inset:0}.login-card{z-index:1;background:var(--color-bg-card);-webkit-backdrop-filter:blur(24px)saturate(1.2);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:440px;padding:var(--space-2xl) var(--space-xl);box-shadow:var(--shadow-card), var(--shadow-glow);animation:.6s ease-out cardFadeIn;position:relative}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.login-brand{text-align:center;margin-bottom:var(--space-xl)}.login-logo{width:64px;height:64px;margin:0 auto var(--space-md);background:linear-gradient(135deg, var(--color-primary), var(--color-accent));border-radius:var(--radius-md);color:#fff;letter-spacing:-1px;box-shadow:0 4px 20px var(--color-primary-glow);justify-content:center;align-items:center;font-size:1.75rem;font-weight:800;display:flex}.login-brand h1{color:var(--color-text-primary);margin-bottom:var(--space-xs);letter-spacing:-.5px;font-size:1.5rem;font-weight:700}.login-brand p{color:var(--color-text-muted);letter-spacing:1.5px;text-transform:uppercase;font-size:.85rem;font-weight:400}.login-tabs{gap:var(--space-xs);margin-bottom:var(--space-xl);background:var(--color-surface);border-radius:var(--radius-sm);padding:4px;display:flex}.login-tab{color:var(--color-text-muted);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-base);justify-content:center;align-items:center;gap:var(--space-sm);background:0 0;border:none;border-radius:6px;flex:1;padding:10px 16px;font-size:.85rem;font-weight:500;display:flex;position:relative}.login-tab:hover{color:var(--color-text-secondary)}.login-tab.active{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px var(--color-primary-glow)}.login-tab svg{width:16px;height:16px}.login-form{gap:var(--space-md);flex-direction:column;display:flex}.form-group{gap:var(--space-xs);flex-direction:column;display:flex}.form-label{color:var(--color-text-secondary);letter-spacing:.3px;font-size:.8rem;font-weight:500}.form-input-wrapper{position:relative}.form-input-wrapper svg{width:18px;height:18px;color:var(--color-text-muted);transition:color var(--transition-fast);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.form-input{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text-primary);font-family:var(--font-family);transition:all var(--transition-base);box-shadow:var(--shadow-input);outline:none;padding:12px 14px 12px 44px;font-size:.95rem}.form-input::placeholder{color:var(--color-text-muted)}.form-input:focus{border-color:var(--color-border-focus);box-shadow:var(--shadow-input), 0 0 0 3px #2563eb26}.form-input:focus+svg,.form-input:focus~svg{color:var(--color-primary-light)}.password-toggle{color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.password-toggle:hover{color:var(--color-text-secondary)}.password-toggle svg{width:18px;height:18px;position:static;transform:none}.form-options{margin:var(--space-xs) 0;justify-content:space-between;align-items:center;display:flex}.remember-me{align-items:center;gap:var(--space-sm);cursor:pointer;display:flex}.remember-me input[type=checkbox]{appearance:none;border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;width:18px;height:18px;transition:all var(--transition-fast);border-radius:4px;position:relative}.remember-me input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}.remember-me input[type=checkbox]:checked:after{content:"✓";color:#fff;font-size:12px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.remember-me span{color:var(--color-text-secondary);font-size:.85rem}.login-btn{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;border-radius:var(--radius-sm);width:100%;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-base);letter-spacing:.3px;margin-top:var(--space-sm);border:none;padding:14px 24px;font-size:.95rem;font-weight:600;position:relative;overflow:hidden}.login-btn:before{content:"";background:linear-gradient(135deg,#0000,#ffffff1a,#0000);transition:transform .5s;position:absolute;inset:0;transform:translate(-100%)}.login-btn:hover:not(:disabled):before{transform:translate(100%)}.login-btn:hover:not(:disabled){box-shadow:0 4px 20px var(--color-primary-glow);transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-btn .spinner{vertical-align:middle;width:18px;height:18px;margin-right:var(--space-sm);border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.otp-sent-info{text-align:center;padding:var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-sm);background:#10b98114;border:1px solid #10b98133}.otp-sent-info p{color:var(--color-success);margin-bottom:var(--space-xs);font-size:.85rem}.otp-sent-info strong{color:var(--color-text-primary);font-weight:600}.otp-resend{justify-content:center;align-items:center;gap:var(--space-xs);margin-top:var(--space-sm);display:flex}.otp-resend button{color:var(--color-primary-light);font-family:var(--font-family);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:.85rem;text-decoration:underline}.otp-resend button:hover{color:var(--color-accent-light)}.otp-resend button:disabled{color:var(--color-text-muted);cursor:not-allowed;text-decoration:none}.login-footer{text-align:center;margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--color-border)}.login-footer p{color:var(--color-text-muted);font-size:.78rem}.login-error{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);color:var(--color-error);text-align:center;background:#ef444414;border:1px solid #ef444433;font-size:.85rem;animation:.4s shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}@media (width<=480px){.login-card{padding:var(--space-xl) var(--space-lg);border-radius:var(--radius-lg)}.login-logo{width:56px;height:56px;font-size:1.5rem}.login-brand h1{font-size:1.3rem}.login-tab{padding:8px 12px;font-size:.8rem}}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.dashboard-header-text h1{color:var(--color-text-primary);margin:0 0 4px;font-size:24px;font-weight:800}.dashboard-header-text p{color:var(--color-text-muted);margin:0;font-size:13px}.dashboard-filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.filter-group{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;align-items:center;gap:8px;padding:6px 12px;display:flex;position:relative}.filter-group select{color:var(--color-text-primary);cursor:pointer;appearance:none;background:0 0;border:none;outline:none;min-width:100px;padding-right:18px;font-family:inherit;font-size:13px;font-weight:600}.filter-group option{color:var(--color-text-primary);background:#1a2340}.filter-chevron{color:var(--color-text-muted);pointer-events:none;position:absolute;right:10px}.filter-group svg:first-child{color:var(--color-text-muted);flex-shrink:0}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:18px;display:grid}.kpi-grid-2{grid-template-columns:repeat(2,1fr)}.kpi-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:14px;padding:22px;transition:transform .25s,box-shadow .25s,border-color .25s;position:relative;overflow:hidden}.kpi-card:before{content:"";background:linear-gradient(90deg, var(--color-primary), var(--color-accent));opacity:0;height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.kpi-card:hover{border-color:#3878f04d;transform:translateY(-3px);box-shadow:0 12px 32px #0003}.kpi-card:hover:before{opacity:1}.kpi-header{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex}.kpi-icon{color:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.kpi-trend{border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:700;display:flex}.trend-up{color:#22c55e;background:#22c55e26}.trend-down{color:#ef4444;background:#ef444426}.kpi-value{color:var(--color-text-primary);letter-spacing:-.5px;margin-bottom:4px;font-size:28px;font-weight:800;line-height:1.2}.kpi-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:4px;font-size:11px;font-weight:700}.kpi-sub{color:var(--color-text-muted);font-size:11px;font-weight:500}.kpi-progress{background:#64748b26;border-radius:3px;height:6px;margin-top:12px;overflow:hidden}.kpi-progress-bar{border-radius:3px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1)}.bg-gradient-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.bg-gradient-success{background:linear-gradient(135deg,#11998e 0%,#38ef7d 100%)}.bg-gradient-warning{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%)}.bg-gradient-info{background:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%)}.bg-gradient-danger{background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%)}.text-success{color:#22c55e!important}.text-warning{color:#f59e0b!important}.text-danger{color:#ef4444!important}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:.5s cubic-bezier(.4,0,.2,1) both fadeInUp}.kpi-loading{grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:18px;display:grid}.kpi-skeleton{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:14px;height:160px;position:relative;overflow:hidden}.kpi-skeleton:after{content:"";background:linear-gradient(90deg,#0000 0%,#64748b14 50%,#0000 100%);animation:1.5s infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.kpi-error{text-align:center;color:var(--color-text-muted);padding:48px;font-size:14px}@media (width<=1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.kpi-grid,.kpi-loading{grid-template-columns:1fr}.dashboard-header{flex-direction:column}.dashboard-filters{width:100%}.filter-group{flex:1}.kpi-value{font-size:24px}}
