/* ============================================================
   CFF Portfolio Dashboard — Bank of Maldives
   Theme: design_system2 (Prometheus) — azure-blue primary, vivid data
   palette, Cinzel serif wordmark + Plus Jakarta Sans, icon sidebar,
   card grid, header controls. Only the BML logo is retained as brand.
   All text colours are tuned to clear WCAG2AA (4.5:1) — the a11y gate
   scans the rendered DOM, so vivid hues are used only for fills / dots /
   white-text-on-dark, never for small text on white.
   ============================================================ */
:root{
  --pri:#1fa2e0; --pri-dk:#0f6b97; --pri-soft:#e6f4fc; --pri-tint:#f1f9fe;
  /* --pri = bright azure for fills/dots/active-bar/focus (non-text).
     --pri-dk = AA-safe azure for TEXT on light + button backgrounds (white text). */
  --ink:#1a1d24; --ink2:#383e49; --muted:#5f6675; --soft:#5f6675; --faint:#98a1ae;
  --page:#e6e8ec; --card:#ffffff; --main:#f6f7f9; --inset:#f4f6f9;
  --line:#e7e9ef; --line2:#eef0f4; --sidebar:#ffffff;
  --amber:#8a5e08;                 /* AA-dark amber for TEXT */
  --c-purple:#7c5cdb; --c-green:#1fa971; --c-amber:#e8a317; --c-teal:#0ea5b5; --c-rose:#e5484d;
  --pos:#157049; --pos-bg:#e4f6ee;
  --sans:'Plus Jakarta Sans','Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --serif:'Cinzel','Plus Jakarta Sans',Georgia,serif;
  --r:12px; --r-lg:16px; --r-app:24px; --pill:999px;
  --sh-card:0 1px 2px rgba(20,28,42,.05);
  --sh:0 2px 12px rgba(20,28,42,.06);
  --sh-lg:0 30px 72px rgba(20,28,42,.22);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--sans);background:var(--page);color:var(--ink2);font-size:13.5px;line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{margin:0;font-weight:700;color:var(--ink);letter-spacing:-.015em}
button{font-family:inherit;cursor:pointer}
.tnum{font-variant-numeric:tabular-nums lining-nums;font-feature-settings:"tnum" 1}
.hidden{display:none!important}
:focus-visible{outline:2px solid var(--pri);outline-offset:2px;border-radius:6px}
code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11.5px;background:var(--inset);padding:1px 5px;border-radius:5px;color:var(--ink2)}

/* ============ LOGIN ============ */
#login{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(1100px 580px at 70% -10%,#1d2a4a 0%,#161b27 55%,#0f1219 100%)}
.login-card{width:100%;max-width:420px;background:var(--card);border-radius:18px;overflow:hidden;box-shadow:var(--sh-lg)}
.login-head{background:var(--card);padding:24px 26px 18px;border-bottom:1px solid var(--line)}
.login-head .crest{display:flex;align-items:center;gap:12px}
.crest .logo,.crest img{width:44px;height:44px;border-radius:10px;object-fit:cover;display:block;box-shadow:0 3px 10px rgba(20,28,42,.18)}
.login-head h1{font-size:17px;line-height:1.15}
.login-head .sub{font-size:12px;color:var(--muted);margin-top:3px;font-weight:500}
.login-body{padding:20px 26px 24px}
.login-body label{display:block;font-size:11.5px;font-weight:700;color:var(--ink2);margin-bottom:8px}
#login-user,#login-pass{width:100%;padding:10px 12px;margin:6px 0 16px;border:1px solid var(--line);border-radius:10px;font:inherit;font-size:13px;background:var(--inset);color:var(--ink)}
#login-pass:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px var(--pri-soft);background:#fff}
.btn-login{width:100%;background:var(--pri-dk);color:#fff;border:none;padding:12px;border-radius:11px;font:inherit;font-size:14px;font-weight:700}
.btn-login:hover{background:#0b5878}
.login-hint{font-size:11.5px;color:var(--muted);margin-top:14px;line-height:1.5}

/* role badge (login + sidebar) */
.role-badge{display:inline-block;font-size:9.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 8px;border-radius:6px}
.role-admin{background:var(--pri-soft);color:var(--pri-dk)}
.role-viewer{background:var(--inset);color:var(--muted)}

/* ============ APP SHELL ============ */
#app{max-width:1520px;margin:0 auto;padding:18px}
.shell{display:grid;grid-template-columns:256px 1fr;background:var(--card);border-radius:var(--r-app);overflow:hidden;box-shadow:var(--sh);min-height:calc(100vh - 36px)}

/* sidebar */
.side{background:var(--sidebar);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:18px 14px}
.side .brand{display:flex;align-items:center;gap:10px;padding:4px 6px 18px}
.side .brand img{width:36px;height:36px;border-radius:9px;object-fit:cover;box-shadow:0 3px 10px rgba(20,28,42,.18)}
.side .brand .wt{font-family:var(--serif);font-weight:600;font-size:12.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink);line-height:1.15}
.side .seclabel{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:14px 10px 8px}
nav.tabs{display:flex;flex-direction:column;gap:2px}
nav.tabs button{position:relative;display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:transparent;border:none;
  color:var(--muted);font-size:13.5px;font-weight:600;padding:11px 12px;border-radius:10px;transition:.13s}
nav.tabs button svg{width:18px;height:18px;flex:none;opacity:.9;color:var(--faint)}
nav.tabs button:hover{background:var(--inset);color:var(--ink)}
nav.tabs button.active{background:var(--pri-soft);color:var(--pri-dk)}
nav.tabs button.active::before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:3px;background:var(--pri);border-radius:0 3px 3px 0}
nav.tabs button.active svg{opacity:1;color:var(--pri)}
.side .grow{flex:1}
.side .usr{border-top:1px solid var(--line);padding-top:12px;margin-top:8px}
.side .who{display:flex;flex-direction:column;gap:6px;padding:4px 6px}
.side .who .nm{font-size:12.5px;font-weight:700;color:var(--ink)}
.side .scope-chip{font-size:10.5px;color:var(--muted);line-height:1.4}
.btn-out{margin:10px 6px 0;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--inset);border:1px solid var(--line);color:var(--ink2);font-size:12px;font-weight:600;padding:9px;border-radius:10px}
.btn-out:hover{background:var(--pri-soft);color:var(--pri-dk);border-color:var(--pri-soft)}

/* main */
.main{min-width:0;background:var(--main);display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:16px;padding:20px 26px 14px}
.topbar h1{font-size:23px}
.topbar .crumb{font-size:11.5px;color:var(--muted);font-weight:600}
.scope-pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--muted);background:#fff;border:1px solid var(--line);padding:6px 12px;border-radius:var(--pill)}
.scope-pill svg{width:13px;height:13px;color:var(--pos)}
.main .wrap{padding:6px 26px 30px;overflow:auto}
.view{display:none}
.view.active{display:block;animation:fade .22s ease both}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ============ cards ============ */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-card)}
.card .hd{display:flex;align-items:center;gap:10px;padding:16px 18px 12px}
.card .hd h3{font-size:15px}
.card .cap{font-size:11.5px;color:var(--muted);margin-top:2px}
.card .bd{padding:0 18px 18px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}

/* ============ KPIs ============ */
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-card);padding:16px 18px}
.kpi .lbl{font-size:11.5px;font-weight:700;color:var(--muted)}
.kpi.t .lbl{color:var(--pri-dk)} .kpi.g .lbl{color:var(--pos)} .kpi.a .lbl{color:var(--amber)} .kpi.b .lbl{color:var(--ink2)}
.kpi .val{font-size:25px;font-weight:800;color:var(--ink);margin-top:8px;line-height:1.05}
.kpi .meta{font-size:11.5px;color:var(--muted);margin-top:7px}

/* ============ bars ============ */
.bar-row{display:grid;grid-template-columns:210px 1fr 56px;align-items:center;gap:12px;padding:7px 0}
.bar-row .nm{font-size:12.5px;color:var(--ink2);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.track{height:9px;background:var(--line2);border-radius:var(--pill);overflow:hidden}
.fill{height:100%;border-radius:var(--pill);background:var(--pri)}
.fill.teal{background:var(--pri)}
.bar-row .ct{text-align:right;font-size:12.5px;font-weight:700;color:var(--ink)}

/* status pill */
.pill{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--pill);white-space:nowrap;line-height:1.45}

/* ============ activity line chart ============ */
.chartwrap{width:100%}
.chartwrap svg{width:100%;height:auto;display:block}
.chart-grid line{stroke:var(--line2);stroke-width:1}
.chart-axis{fill:var(--muted);font-size:10px;font-weight:600}
.chart-dot{stroke:#fff;stroke-width:1.5}

/* ============ toolbar + table ============ */
.toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:9px;margin-bottom:14px}
.toolbar .search{flex:1;min-width:220px;border:1px solid var(--line);background:#fff;border-radius:10px;padding:9px 13px;font:inherit;font-size:12.5px;color:var(--ink)}
.toolbar select{appearance:none;-webkit-appearance:none;border:1px solid var(--line);background:#fff;border-radius:10px;padding:9px 30px 9px 12px;font:inherit;font-size:12.5px;font-weight:600;color:var(--ink2);cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239aa1ad' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 10px center}
.toolbar .search:focus,.toolbar select:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px var(--pri-soft)}
.rescount{font-size:12px;color:var(--muted);font-weight:600}
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:#fff;color:var(--ink2);font:inherit;font-size:12.5px;font-weight:600;padding:9px 14px;border-radius:10px;transition:.13s;white-space:nowrap}
.btn:hover{background:var(--inset);border-color:var(--faint)}
.btn-primary{background:var(--pri-dk);border-color:var(--pri-dk);color:#fff}
.btn-primary:hover{background:#0b5878;border-color:#0b5878}
.btn-ghost{border-color:transparent;background:transparent;color:var(--muted)}
.btn-ghost:hover{background:var(--inset);color:var(--ink2)}
.btn-danger{background:#fff;color:#b3303a;border-color:#f0c9cc}
.btn-danger:hover{background:var(--c-rose);color:#fff;border-color:var(--c-rose)}

.tablewrap{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-card);overflow:hidden}
table{width:100%;border-collapse:collapse}
thead th{background:var(--inset);text-align:left;padding:11px 16px;font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:700;border-bottom:1px solid var(--line);white-space:nowrap;cursor:pointer;user-select:none}
thead th.no-sort{cursor:default}
thead th[aria-sort]{color:var(--pri-dk)}
.sort-ind{font-size:9px;font-weight:700;color:var(--pri-dk)}
thead th.num,td.num{text-align:right}
td.num{white-space:nowrap}
tbody td{padding:12px 16px;border-bottom:1px solid var(--line2);font-size:13px;color:var(--ink2);vertical-align:middle}
tbody tr{transition:background .1s}
tbody tr:hover{background:var(--inset);cursor:pointer}
tbody tr:last-child td{border-bottom:none}
.pname{font-weight:600;color:var(--ink)}
.ploc{font-size:11.5px;color:var(--muted);margin-top:1px}
.mini-prog{display:inline-block;width:54px;height:6px;background:var(--line2);border-radius:4px;overflow:hidden;vertical-align:middle;margin-right:6px}
.mini-prog i{display:block;height:100%;background:var(--c-green);border-radius:4px}
.rowacts{display:flex;gap:5px;justify-content:flex-end}
.icon-btn{border:1px solid var(--line);background:#fff;border-radius:8px;padding:5px 9px;font-size:12px;font-weight:600;color:var(--muted)}
.icon-btn:hover{border-color:var(--faint);color:var(--ink)}
.icon-btn.del:hover{border-color:var(--c-rose);color:var(--c-rose);background:#fdeaeb}
.empty{padding:26px;text-align:center;color:var(--muted);font-size:13px}
.footer-note{font-size:11.5px;color:var(--muted);margin-top:14px;line-height:1.55}
.footer-note b{color:var(--ink2)}
.print-head{display:none}

/* ============ by ministry ============ */
.minlist{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.mincard{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-card);padding:18px 19px;cursor:pointer;transition:.14s}
.mincard:hover{box-shadow:var(--sh);transform:translateY(-2px);border-color:var(--faint)}
.mincard .mn{font-size:14.5px;font-weight:700;color:var(--ink);line-height:1.25}
.mincard .mrow{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:var(--muted);margin-top:9px}
.mincard .mrow b{color:var(--ink);font-weight:700}
.detail-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.detail-head>div:first-child{flex:1;min-width:0}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.detail-head h2{font-size:21px;line-height:1.2;margin-top:6px}
.dmeta{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:10px;font-size:12.5px;color:var(--muted);align-items:center}
.dmeta b{color:var(--ink2);font-weight:600}
.kv{display:flex;flex-direction:column}
.kv .row{display:flex;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px solid var(--line2);font-size:12.5px}
.kv .row:last-child{border-bottom:none}
.kv .k{color:var(--muted)} .kv .v{color:var(--ink);font-weight:600;text-align:right}

/* ============ project detail ============ */
.dgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}
.dstat{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-card);padding:14px 16px}
.dstat .l{font-size:10.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--muted)}
.dstat .v{font-size:21px;font-weight:800;color:var(--ink);margin-top:6px;font-variant-numeric:tabular-nums}
.dstat .m{font-size:11px;margin-top:4px}
.block{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-card);padding:16px 18px;margin-bottom:16px}
.block h3{font-size:15px;margin-bottom:12px}
.stacked{display:flex;height:42px;border-radius:11px;overflow:hidden;border:1px solid var(--line)}
.stacked span{display:flex;align-items:center;padding:0 12px;color:#fff;font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;font-variant-numeric:tabular-nums}
.legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:13px;font-size:12px;color:var(--muted)}
.legend span{display:inline-flex;align-items:center;gap:7px}
.legend i{width:11px;height:11px;border-radius:3px;display:inline-block}
.emi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:6px}
.emi-cell{border-radius:9px;padding:8px 6px;text-align:center;font-size:11px;font-weight:700;font-variant-numeric:tabular-nums}
.emi-cell .mm{display:block;font-size:9.5px;font-weight:600;color:var(--muted);margin-bottom:3px}
.emi-grace{background:var(--inset);color:var(--muted)}
.emi-pay{background:var(--pri-soft);color:#155b87}
.emi-pay .mm{color:#3d7ba0}

/* ============ form modal ============ */
.modal-back{position:fixed;inset:0;background:rgba(16,20,28,.45);backdrop-filter:blur(3px);z-index:60;display:flex;align-items:flex-start;justify-content:center;padding:42px 20px;overflow:auto}
.modal{background:var(--card);border-radius:20px;box-shadow:var(--sh-lg);width:100%;max-width:760px;animation:pop .2s ease both}
.modal.sm{max-width:460px}
@keyframes pop{from{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:none}}
.mhd{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line2)}
.mhd h3{font-size:16px}
.mhd .x{margin-left:auto;border:none;background:var(--inset);color:var(--muted);width:32px;height:32px;border-radius:10px;font-size:18px;line-height:1;display:grid;place-items:center}
.mhd .x:hover{background:var(--pri-soft);color:var(--pri-dk)}
.mbd{padding:20px 22px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px}
.fsec{grid-column:1/-1;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--pri-dk);padding-top:6px;border-top:1px solid var(--line2);margin-top:4px}
.fsec:first-child{border-top:none;margin-top:0;padding-top:0}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:11.5px;font-weight:700;color:var(--ink2)}
.field .req{color:#b3303a}
.field input,.field select,.field textarea{border:1px solid var(--line);background:var(--inset);border-radius:10px;padding:9px 11px;font:inherit;font-size:13px;color:var(--ink)}
.field textarea{min-height:64px;resize:vertical}
.field select{appearance:none;-webkit-appearance:none;padding-right:30px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239aa1ad' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 11px center}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--pri);box-shadow:0 0 0 3px var(--pri-soft);background:#fff}
.field .err{display:none;font-size:11px;color:var(--c-rose);font-weight:600}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--c-rose);box-shadow:0 0 0 3px #fdeaeb}
.field.invalid .err{display:block}
.warnbox{display:none;margin-top:14px;padding:11px 13px;border-radius:10px;background:#fcf1da;color:var(--amber);font-size:12px;line-height:1.5}
.warnbox.show{display:block}
.mft{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--line2);background:var(--inset);border-radius:0 0 20px 20px}
.confirm-txt{font-size:13px;color:var(--ink2);line-height:1.6}

/* ============ audit ============ */
.act{display:inline-flex;align-items:center;font-size:10.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:2px 9px;border-radius:var(--pill)}
.act-create{background:var(--pos-bg);color:var(--pos)}
.act-update{background:var(--pri-soft);color:var(--pri-dk)}
.act-delete{background:#fdeaeb;color:#b3303a}
.diff{font-size:12px;color:var(--ink2);margin:2px 0}

/* ============ toast ============ */
#toast{position:fixed;right:20px;bottom:20px;z-index:80;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--ink);color:#fff;font-size:12.5px;font-weight:600;padding:11px 15px;border-radius:11px;box-shadow:var(--sh-lg);max-width:320px}
.toast.ok{background:var(--pos)} .toast.err{background:#b3303a}

/* ============ responsive ============ */
@media(max-width:1080px){
  .shell{grid-template-columns:1fr}
  .side{flex-direction:row;align-items:center;overflow-x:auto;padding:10px 14px}
  .side .seclabel,.side .grow,.side .scope-chip{display:none}
  nav.tabs{flex-direction:row}
  nav.tabs button.active::before{left:8px;right:8px;top:auto;bottom:-4px;width:auto;height:3px;border-radius:3px}
  .side .usr{border-top:none;border-left:1px solid var(--line);padding:0 0 0 12px;margin:0}
  .grid2,.minlist{grid-template-columns:1fr}
  .kpis,.dgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){.kpis,.dgrid,.fgrid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ============ print ============ */
@media print{
  body{background:#fff}
  #login,.side,.topbar,.toolbar,.rowacts,#toast,#modal-host,.btn,.footer-note{display:none!important}
  #ptable thead th:last-child,#ptable tbody td:last-child{display:none!important}
  #app{max-width:none;padding:0}
  .shell{display:block;box-shadow:none;border-radius:0}
  .main{background:#fff}
  .print-head{display:block;margin-bottom:14px}
  .print-head h2{font-size:18px}
  .print-head .pmeta{font-size:11px;color:#555;margin-top:4px}
  .card,.tablewrap,.kpi,.dstat,.block{box-shadow:none;border-color:#ccc;break-inside:avoid}
}
