:root{--navy-950:#061326;--navy-900:#071b35;--navy-850:#092343;--navy-800:#0b315d;--blue-600:#2563eb;--blue-500:#2f6ff2;--green-500:#22c55e;--orange-500:#f59e0b;--red-500:#ef4444;--purple-500:#7c3aed;--cyan-500:#0ea5e9;--surface:#fff;--surface-2:#f8fafc;--line:#d9e2ef;--text:#0f1f33;--muted:#64748b;--shadow:0 8px 20px #0f1f3314;color:var(--text);background:#eaf0f7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,input{font:inherit}button{cursor:pointer}a{color:var(--blue-600);text-decoration:none}#app{min-height:100vh}.app-shell{background:#eef3f9;grid-template-rows:58px minmax(0,1fr) 38px;grid-template-columns:214px minmax(0,1fr);min-height:100vh;display:grid}.topbar{color:#fff;z-index:20;background:linear-gradient(90deg,#061326,#081b33 55%,#061326);border-bottom:1px solid #ffffff14;grid-column:1/-1;grid-template-columns:210px minmax(280px,1fr) auto;align-items:center;gap:16px;padding:0 18px;display:grid;position:relative}.top-left,.top-actions,.top-user,.top-date,.global-search,.sector-select{align-items:center;display:flex}.top-left{gap:14px}.top-title{letter-spacing:0;font-size:23px}.icon-button{color:#fff;background:0 0;border:0;border-radius:6px;place-items:center;width:34px;height:34px;display:grid;position:relative}.icon-button:hover,.sector-select:hover{background:#ffffff14}.has-dot:after{content:"3";background:var(--red-500);color:#fff;border-radius:999px;place-items:center;min-width:15px;height:15px;font-size:10px;font-weight:800;display:grid;position:absolute;top:3px;right:2px}.global-search{background:#0d2340;border:1px solid #1d3b61;border-radius:6px;gap:10px;height:36px;padding:0 13px}.global-search input{color:#fff;background:0 0;border:0;outline:0;width:100%;font-size:13px}.global-search input::placeholder{color:#9fb2cb}.top-actions{gap:10px;position:relative}.sector-select{color:#fff;text-align:left;background:#0a1d36;border:1px solid #1d3b61;border-radius:6px;gap:8px;height:38px;padding:0 10px}.sector-select span,.top-user span,.top-date span{color:#b7c7db;font-size:11px;display:block}.sector-select strong,.top-user strong{color:#fff;font-size:12px;display:block}.avatar{color:#fff;background:linear-gradient(135deg,#f5c99d,#73452d);border:2px solid #fffc;border-radius:50%;flex:none;place-items:center;width:34px;height:34px;font-weight:900;display:grid}.avatar-sm{width:38px;height:38px}.top-user{gap:8px}.top-user-button{color:inherit;text-align:left;background:0 0;border:0}.top-date{gap:15px;margin-left:16px}.top-date span:last-child{gap:6px;display:flex}.sidebar{background:linear-gradient(#061326,#08203d 72%,#061326);flex-direction:column;grid-row:2/3;justify-content:space-between;padding:18px 12px;display:flex;box-shadow:inset -1px 0 #ffffff14}.side-nav{gap:7px;display:grid}.side-nav a{color:#d7e4f5;border-radius:6px;grid-template-columns:24px 1fr 14px;align-items:center;gap:8px;min-height:42px;padding:0 11px;font-size:13px;font-weight:700;display:grid}.side-nav a.router-link-active,.side-nav a:hover{color:#fff;background:linear-gradient(90deg,#1260bf,#0f4f9f)}.nav-chevron{color:#a7bdd9;font-size:18px}.side-user{color:#fff;background:#ffffff0a;border:1px solid #ffffff1f;border-radius:8px;align-items:center;gap:10px;padding:13px;display:flex}.side-user strong,.side-user span{display:block}.side-user span{color:#a9bdd5;font-size:12px}.content{grid-area:2/2;padding:24px 28px 28px;overflow:auto}.app-footer{color:#fff;background:linear-gradient(90deg,#08203d,#0b315d);grid-area:3/1/auto/-1;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px;padding:0 24px;font-size:12px;display:grid}.app-footer span:last-child{justify-self:end}.page-heading{margin-bottom:14px}.page-heading h1{margin:0 0 6px;font-size:22px}.page-heading p{color:var(--muted);margin:0;font-size:13px}.dashboard-grid{grid-template-columns:minmax(0,1fr);align-items:start;gap:24px;display:grid}.stats-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:22px;margin-bottom:26px;display:grid}.stat-card,.dash-card,.module-card{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px}.stat-card{align-items:center;gap:13px;min-height:86px;padding:14px;display:flex}.stat-card span,.stat-card small{color:var(--muted);font-size:11px}.stat-card strong{margin:7px 0 4px;font-size:28px;line-height:1;display:block}.stat-icon,.notification-icon,.report-icon{color:#fff;border-radius:8px;flex:none;place-items:center;display:grid}.stat-icon{width:54px;height:54px}.tone-blue{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.tone-orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.tone-purple{background:linear-gradient(135deg,#7c3aed,#6d28d9)}.tone-green{background:linear-gradient(135deg,#16a34a,#15803d)}.tone-red{background:linear-gradient(135deg,#ef4444,#dc2626)}.tone-cyan{background:linear-gradient(135deg,#06b6d4,#0891b2)}.chart-grid{grid-template-columns:1.05fr 1.35fr 1fr 1fr;gap:24px;margin-bottom:26px;display:grid}.dash-card{padding:14px}.card-title{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.card-title strong{font-size:14px}.card-title span,.card-title a{color:var(--muted);font-size:11px}.donut-layout{grid-template-columns:138px 1fr;align-items:center;gap:13px;display:grid}.donut{border-radius:50%;width:128px;height:128px;position:relative}.donut:after{content:"";background:#fff;border-radius:50%;position:absolute;inset:30px}.donut-requests{background:conic-gradient(#2563eb 0 24%, #22c55e 24% 57%, #0ea5e9 57% 81%, #ef4444 81% 88%, #f59e0b 88% 100%)}.donut-distribution{background:conic-gradient(#2563eb 0 62%, #f59e0b 62% 83%, #22c55e 83% 95%, #ef4444 95% 100%)}.legend-list{gap:7px;margin:0;padding:0;font-size:11px;list-style:none;display:grid}.legend-list li{grid-template-columns:9px 1fr auto;align-items:center;gap:7px;display:grid}.legend-dot,.alert-dot{border-radius:50%;width:9px;height:9px}.blue{background:#2563eb}.orange{background:#f59e0b}.green{background:#22c55e}.red{background:#ef4444}.cyan{background:#0ea5e9}.chart-card footer{color:var(--muted);text-align:center;margin-top:10px;font-size:12px}.chart-legend{color:var(--muted);justify-content:center;gap:16px;font-size:11px;display:flex}.chart-legend span{align-items:center;gap:5px;display:flex}.chart-legend i{border-radius:999px;width:20px;height:3px;display:block}.line-green{background:var(--green-500)}.line-red{background:var(--red-500)}.line-chart{width:100%;height:185px}.grid-lines line{stroke:#e7edf5}.area-green,.area-red{fill:none;stroke-width:12px;stroke-linecap:round;opacity:.08}.area-green{stroke:var(--green-500)}.area-red{stroke:var(--red-500)}.stroke-green,.stroke-red{fill:none;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.stroke-green{stroke:var(--green-500)}.stroke-red{stroke:var(--red-500)}.months text{fill:var(--muted);font-size:12px}.bar-list{gap:10px;display:grid}.bar-row{grid-template-columns:60px 1fr 34px;align-items:center;gap:9px;font-size:11px;display:grid}.bar-track{background:#e9eef6;border-radius:999px;height:10px;overflow:hidden}.bar-track i{border-radius:inherit;height:100%;display:block}.lower-grid{grid-template-columns:1.55fr 1fr 1.1fr;gap:24px;display:grid}.notifications-card{min-height:386px}.notification-trigger{position:relative}.notification-popover{width:360px;max-height:76vh;color:var(--text);z-index:50;position:absolute;top:48px;right:-110px;overflow:auto}.notification-list{display:grid}.notification-item{border-bottom:1px solid var(--line);grid-template-columns:42px 1fr;gap:12px;padding:13px 0;display:grid}.notification-icon{background:#eff6ff;width:36px;height:36px}.notification-icon.tone-blue{color:#2563eb;background:#dbeafe}.notification-icon.tone-orange{color:#f59e0b;background:#fef3c7}.notification-icon.tone-red{color:#ef4444;background:#fee2e2}.notification-icon.tone-green{color:#16a34a;background:#dcfce7}.notification-item strong{font-size:12px;display:block}.notification-item p,.notification-item span{color:var(--muted);margin:2px 0 0;font-size:11px}.panel-link{text-align:center;padding-top:11px;font-size:12px;font-weight:700;display:block}.alert-list{display:grid}.alert-list div{border-bottom:1px solid var(--line);grid-template-columns:18px 1fr;gap:8px;padding:10px 0;display:grid}.alert-list p{margin:0;font-size:12px}.alert-list small{color:var(--muted);margin-top:3px;display:block}.modules-mosaic{grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;margin-top:26px;display:grid}.module-page{gap:18px;padding-top:8px;display:grid}.stock-functional-page{gap:24px;display:grid}.module-stat-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.module-stat-strip div{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:8px;padding:14px 18px}.module-stat-strip span{color:var(--muted);font-size:12px;display:block}.module-stat-strip strong{margin-top:6px;font-size:24px;display:block}.page-fade-enter-active,.page-fade-leave-active,.fade-slide-enter-active,.fade-slide-leave-active{transition:opacity .22s,transform .22s}.page-fade-enter-from,.page-fade-leave-to{opacity:0;transform:translateY(8px)}.fade-slide-enter-from,.fade-slide-leave-to{opacity:0;transform:translateY(-8px)}.module-card{overflow:hidden}.module-card header{color:#fff;background:linear-gradient(90deg,#07305c,#0a4d8e);justify-content:space-between;align-items:center;min-height:42px;padding:0 13px;display:flex}.module-toolbar{border-bottom:1px solid var(--line);background:#fff;align-items:center;gap:12px;padding:12px 14px;display:flex}.module-toolbar input{width:min(360px,100%);height:34px;color:var(--text);border:1px solid #d9e2ef;border-radius:6px;outline:0;padding:0 12px}.module-card h2{margin:0;font-size:15px}.primary-button{color:#fff;background:var(--blue-600);border:0;border-radius:5px;height:30px;padding:0 12px;font-size:11px;font-weight:800}.logout-button,.table-action{color:#fff;background:#ffffff14;border:1px solid #ffffff2e;border-radius:5px;height:28px;padding:0 10px;font-size:11px;font-weight:800}.table-action{color:#991b1b;background:#fee2e2;border-color:#fecaca}.functional-card{min-height:360px}.resource-form{border-bottom:1px solid var(--line);background:#f8fafc;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:14px;display:grid}.resource-form label{color:#34465b;gap:6px;font-size:12px;font-weight:800;display:grid}.resource-form label.wide{grid-column:span 2}.resource-form input,.resource-form select,.resource-form textarea,.approval-detail textarea{width:100%;color:var(--text);background:#fff;border:1px solid #d4deec;border-radius:6px;outline:0;padding:9px 10px}.resource-form textarea,.approval-detail textarea{resize:vertical;min-height:74px}.form-actions{align-items:end;gap:8px;display:flex}.ghost-button{border:1px solid var(--line);height:30px;color:var(--text);background:#fff;border-radius:5px;font-size:11px;font-weight:800}.form-error,.loading-line,.empty-line{color:var(--muted);margin:12px;font-size:12px}.form-error{color:#991b1b;background:#fee2e2;border-radius:6px;padding:10px}.approval-layout{grid-template-columns:260px 1fr;gap:14px;padding:14px;display:grid}.approval-list{border-right:1px solid var(--line);align-content:start;gap:10px;padding-right:14px;display:grid}.approval-item{border:1px solid var(--line);text-align:left;background:#fff;border-radius:7px;gap:4px;padding:10px;display:grid}.approval-item span,.approval-card h3{font-weight:900}.approval-item small{color:var(--muted)}.approval-detail{gap:12px;display:grid}.approval-card{border:1px solid var(--line);border-radius:8px;gap:10px;padding:12px;display:grid}.approval-card h3,.approval-card p,.approval-card ul{margin:0}.success-button{background:var(--green-500)}.reject-button{background:var(--red-500)}.report-summary{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:14px;display:grid}.sector-card-grid{grid-template-columns:repeat(3,minmax(180px,1fr));gap:18px;padding:18px;display:grid}.sector-card{border:1px solid var(--line);background:#fff;border-radius:8px;min-height:170px;padding:18px}.sector-card h3{margin:0 0 12px}.sector-card p,.sector-card span,.sector-card strong{color:#34465b;margin:10px 0;font-size:12px;display:block}.sector-card em{color:#16a34a;font-style:normal}.profile-card{max-width:760px}.profile-content{grid-template-columns:140px 1fr;gap:24px;padding:28px;display:grid}.profile-photo{color:#fff;background:linear-gradient(135deg,#f5c99d,#73452d);border-radius:50%;place-items:center;width:110px;height:110px;font-size:38px;font-weight:900;display:grid}.profile-content dl{grid-template-columns:120px 1fr;gap:14px;margin:0;display:grid}.profile-content dt{color:var(--muted)}.profile-actions{grid-column:1/-1;gap:12px;display:flex}.summary-tile{border:1px solid var(--line);background:#f8fafc;border-radius:8px;padding:14px}.summary-tile span{color:var(--muted);text-transform:capitalize;display:block}.summary-tile strong{margin-top:8px;font-size:28px;display:block}.module-table{background:#fff;padding:0 12px 12px;overflow-x:auto}.module-row{border-bottom:1px solid var(--line);color:#24364b;align-items:center;gap:10px;min-width:620px;padding:12px 8px;font-size:11px;display:grid}.module-row:last-child{border-bottom:0}.module-head{color:#607086;background:#f8fafc;font-weight:800}.status-cell{color:#15803d;background:#dcfce7;border-radius:999px;justify-self:start;padding:4px 8px;font-weight:800}.report-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:16px;display:grid}.report-tile{border:1px solid var(--line);min-height:92px;color:var(--text);background:#fff;border-radius:8px;place-items:center;gap:10px;font-size:12px;font-weight:800;display:grid}.report-icon{width:42px;height:42px}.brand-mark-shield{color:#f7c96b;clip-path:polygon(50% 0,100% 18%,91% 80%,50% 100%,9% 80%,0 18%);background:linear-gradient(160deg,#061326,#0b315d);border:4px solid #d7a84d;place-items:center;width:118px;height:142px;margin:0 auto;padding-top:18px;display:grid;box-shadow:0 10px 24px #00000059}.shield-top{font-size:15px;font-weight:900}.shield-bars{gap:8px;display:flex}.shield-bars span{background:#f7c96b;width:8px;height:44px;display:block}.shield-base{background:#f7c96b;border-radius:999px;width:48px;height:8px}.login-screen{background:linear-gradient(#08182b0a,#08182bb8),radial-gradient(circle at 16% 10%,#ffffffbf,#0000 18%),linear-gradient(115deg,#aeb8c4 0 21%,#6c7884 21% 22%,#c1ccd6 22% 35%,#3d4b5b 35% 36%,#9aa6b3 36% 53%,#364658 53% 54%,#8b98a7 54% 100%);place-items:center;min-height:100vh;display:grid;position:relative;overflow:hidden}.login-screen:before{content:"";background:linear-gradient(90deg,#0000 0 14%,#040f1fd9 14% 15%,#0000 15% 82%,#040f1fbf 82% 83%,#0000 83%),repeating-linear-gradient(90deg,#0613262e 0 2px,#0000 2px 54px),linear-gradient(#0000 0 34%,#05101f33 34% 35%,#0000 35%);position:absolute;inset:0}.login-screen:after{content:"";background:linear-gradient(#03152bd1,#03152bf0),repeating-linear-gradient(90deg,#2f6ff22b 0 1px,#0000 1px 44px),repeating-linear-gradient(0deg,#2f6ff224 0 1px,#0000 1px 44px);height:38%;position:absolute;bottom:0;left:0;right:0}.login-hero{z-index:1;text-align:center;width:min(430px,100vw - 36px);margin-top:-20px;position:relative}.login-title{color:#061326;gap:3px;margin:18px 0 22px;font-size:14px;font-weight:900;display:grid}.login-card{text-align:left;background:#fff;border-radius:8px;width:100%;padding:28px 28px 22px;box-shadow:0 18px 45px #04112259}.login-card h1{text-align:center;margin:0 0 24px;font-size:19px}.login-card label{color:#34465b;gap:7px;margin-bottom:13px;font-size:12px;font-weight:700;display:grid}.input-wrap{color:#7b8ba0;border:1px solid #d4deec;border-radius:5px;grid-template-columns:20px 1fr 20px;align-items:center;gap:8px;height:38px;padding:0 10px;display:grid}.input-wrap input{width:100%;color:var(--text);border:0;outline:0;font-size:13px}.login-card a{margin-bottom:14px;font-size:12px;font-weight:700;display:inline-block}.login-card button{color:#fff;background:linear-gradient(90deg,#072a52,#0a407a);border:0;border-radius:5px;width:100%;height:42px;font-weight:900}.login-card small{color:#6b7d92;justify-content:center;gap:6px;margin-top:18px;font-size:11px;display:flex}.login-error{color:#991b1b;background:#fee2e2;border-radius:5px;margin:0 0 12px;padding:9px;font-size:12px}@media (width<=1180px){.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.chart-grid,.modules-mosaic{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-grid{grid-template-columns:1fr}}@media (width<=980px){.app-shell{grid-template-rows:auto auto minmax(0,1fr) 38px;grid-template-columns:1fr}.topbar{grid-template-columns:1fr;padding:12px}.sidebar{flex-direction:row;grid-row:2;overflow-x:auto}.side-nav{grid-auto-columns:max-content;grid-auto-flow:column}.side-user{display:none}.content{grid-area:3/1}.stats-grid,.chart-grid,.lower-grid,.modules-mosaic{grid-template-columns:1fr}.app-footer{grid-row:4}}
