*{box-sizing:border-box}
:root{--dark:#071017;--green:#07a64f;--green2:#05d06b;--bg:#f4f7fa;--line:#e2e8ee;--text:#101820;--muted:#60707b}
body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}
.layout{display:flex;min-height:100vh}
.sidebar{width:250px;background:linear-gradient(180deg,#071017,#010509);color:white;position:fixed;top:0;bottom:0;left:0;padding:28px 20px}
.logo strong{font-size:62px;letter-spacing:-6px;line-height:.85;display:block}
.logo span{font-size:12px;letter-spacing:3px;color:#9fb0bb;font-weight:800}
.sidebar nav{margin-top:32px}
.sidebar nav a{display:flex;align-items:center;gap:10px;padding:13px 15px;margin:5px 0;border-radius:9px;color:#e8f0f4;font-weight:800}
.sidebar nav a.active,.sidebar nav a:hover{background:#075d35;box-shadow:inset 4px 0 0 var(--green2)}
.sidebar-card{position:absolute;left:20px;right:20px;bottom:26px;border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:18px;background:rgba(255,255,255,.04)}
.sidebar-card p{color:#dce6ea;line-height:1.45;margin-bottom:0}
.content{margin-left:250px;width:calc(100% - 250px);padding:28px 30px 60px}
.topbar{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px}
.eyebrow{text-transform:uppercase;color:var(--green);font-size:12px;font-weight:900;letter-spacing:1px}
h1{font-size:34px;margin:4px 0 4px;letter-spacing:-1px}
h2{font-size:14px;text-transform:uppercase;margin:0 0 16px;font-weight:900}
.topbar p{margin:0;color:var(--muted)}
.topbar-actions{display:flex;align-items:center;gap:12px}
.period{background:white;border:1px solid var(--line);border-radius:10px;padding:10px 18px;color:#44515b;font-size:12px}
.button{border:0;border-radius:10px;padding:12px 18px;font-weight:900;display:inline-block}
.button.dark{background:var(--dark);color:white}.button.green{background:var(--green);color:white}.button.light{background:white;border:1px solid var(--line)}
.health-panel{background:linear-gradient(135deg,#071017,#09351f);color:white;border-radius:18px;padding:22px;margin-bottom:18px;box-shadow:0 12px 35px rgba(0,0,0,.12)}
.health-panel span{color:#b9c7cf;font-size:13px;text-transform:uppercase;font-weight:900}
.health-panel strong{display:block;font-size:42px;margin:4px 0}.health-panel p{margin:0;color:#dce6ea}
.health-meter{height:12px;background:rgba(255,255,255,.14);border-radius:99px;margin-top:18px;overflow:hidden}.health-meter b{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--green2))}
.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:16px}
.kpi,.panel,.module-hero{background:white;border:1px solid var(--line);border-radius:14px;box-shadow:0 9px 25px rgba(0,0,0,.045)}
.kpi{padding:17px}.kpi span{display:block;text-transform:uppercase;font-size:12px;font-weight:900;color:#41505a}.kpi strong{display:block;font-size:28px;margin:9px 0}.kpi em{font-style:normal;color:var(--green);font-weight:900}
.main-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px;margin-bottom:16px}
.bottom-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:16px}
.panel{padding:19px}.panel.wide{min-height:360px}.panel-head{display:flex;justify-content:space-between;align-items:center}.panel-head span{color:var(--muted);font-size:12px}
.alerts{display:grid;gap:10px}.alert{padding:12px;border-radius:10px;font-weight:800;font-size:13px}.alert.ok{background:#e8f8ef;color:#04733a}.alert.warn{background:#fff7e5;color:#9a6500}
table{width:100%;border-collapse:collapse;font-size:13px}th,td{padding:12px 8px;border-bottom:1px solid #e8edf1;text-align:left}
.goal{margin:15px 0}.goal div{display:flex;justify-content:space-between;font-size:13px;font-weight:900}.goal b{display:block;height:14px;background:#edf2f5;border-radius:99px;margin-top:8px;overflow:hidden}.goal i{display:block;height:100%;background:var(--green)}
.module-hero{padding:28px;max-width:900px}.module-hero h2{font-size:24px;text-transform:none}.module-actions{display:flex;gap:12px;margin-top:20px}
.expense-grid{display:grid;grid-template-columns:1fr 360px;gap:16px}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}
label{display:block;font-size:13px;font-weight:900;margin-bottom:13px}input,select,textarea{width:100%;padding:12px;border:1px solid #cfd8df;border-radius:9px;margin-top:6px;font-family:inherit}textarea{min-height:80px}
.dropzone{border:2px dashed #a8b8ff;border-radius:14px;padding:24px;background:#fbfcff;margin:15px 0}.dropzone p{color:var(--muted)}
.success{background:#e8f8ef;color:#04733a;border:1px solid #bfeccf;border-radius:12px;padding:14px;font-weight:900;margin-bottom:16px}
.roadmap-list{display:flex;gap:8px;flex-wrap:wrap}.roadmap-list span,.pill-ok{background:#e8f8ef;color:#04733a;border-radius:99px;padding:7px 10px;font-size:12px;font-weight:900}
.login-screen{min-height:100vh;background:radial-gradient(circle at top left,#0b492b,#071017 45%,#020506);display:flex;align-items:center;justify-content:center}
.login-shell{width:min(980px,92vw);display:grid;grid-template-columns:1.2fr 420px;gap:28px;align-items:center}.login-brand{color:white}.brand-mark{font-size:92px;font-weight:900;letter-spacing:-8px;color:var(--green2)}.login-brand h1{font-size:54px}.login-brand p{font-size:20px;color:#cdd8df}.login-bullets{display:flex;gap:10px;flex-wrap:wrap}.login-bullets span{background:rgba(255,255,255,.1);padding:9px 12px;border-radius:99px}
.login-card{background:white;border-radius:20px;padding:32px;box-shadow:0 30px 90px rgba(0,0,0,.3)}.login-card h2{font-size:28px;text-transform:none;margin-bottom:4px}.login-card p{color:var(--muted)}.login-card button{width:100%;background:var(--green);border:0;color:white;padding:14px;border-radius:10px;font-weight:900}.alert-error{background:#ffe8e8;color:#b00020;border-radius:10px;padding:12px;font-weight:900;margin:12px 0}.login-card small{display:block;color:var(--muted);margin-top:14px}
@media(max-width:1200px){.sidebar{display:none}.content{margin-left:0;width:100%}.kpi-grid{grid-template-columns:repeat(2,1fr)}.main-grid,.bottom-grid,.expense-grid,.form-grid,.login-shell{grid-template-columns:1fr}}
