/* ==========================================================================
   KNUT CONNECT — Module styles (map, login, member card, CV, profile, SACCO)
   ========================================================================== */

/* ----------------------------- Kenya map --------------------------------- */
.map-host{position:relative}
.kenya-map{width:100%;height:auto;display:block;max-height:600px;margin:0 auto}
.kenya-map .cty{cursor:pointer;transition:fill .25s var(--ease),filter .15s}
.kenya-map .cty.hot{filter:brightness(1.07) saturate(1.05);stroke:#0a1f3d;stroke-width:1.7}
.kenya-map .cty.sel{stroke:var(--gold-500);stroke-width:2.6}
.map-tip{position:absolute;pointer-events:none;opacity:0;transition:opacity .12s;background:var(--navy-900);color:#fff;padding:8px 12px;border-radius:11px;box-shadow:var(--sh-lg);font-size:12px;z-index:20;min-width:128px;transform:translateY(-100%)}
.map-tip b{display:block;font-size:13.5px;font-weight:700}
.map-tip span{display:block;font-size:11px;color:#9fb3d4;margin:2px 0 4px}
.map-tip i{font-style:normal;font-weight:800;color:var(--gold-400);font-size:12.5px}
.map-scale{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.map-scale-bar{width:130px;height:9px;border-radius:99px;border:1px solid var(--line)}

/* ----------------------------- Login / persona portal -------------------- */
.portal{min-height:100vh;display:grid;grid-template-columns:1.05fr 1fr}
.portal-brand{
  position:relative;overflow:hidden;color:#eaf1fb;padding:48px 54px;display:flex;flex-direction:column;
  background:radial-gradient(120% 90% at 0% 0%,rgba(31,111,224,.3),transparent 55%),radial-gradient(90% 80% at 100% 100%,rgba(243,181,31,.18),transparent 50%),linear-gradient(160deg,var(--navy-800),var(--navy-950));
}
.portal-brand::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.04) 1px,transparent 1px);background-size:24px 24px;opacity:.7}
.portal-brand .pb-top{display:flex;align-items:center;gap:13px;position:relative}
.portal-brand .pb-top .crest{width:52px;height:52px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.45))}
.portal-brand .pb-top b{font-family:var(--font-display);font-weight:700;font-size:23px;color:#fff;display:block;line-height:1}
.portal-brand .pb-top span{font-size:10px;font-weight:700;letter-spacing:.24em;color:var(--gold-400)}
.portal-brand .pb-hero{margin-top:auto;position:relative}
.portal-brand .pb-hero h1{font-family:var(--font-display);font-weight:600;font-size:40px;line-height:1.08;color:#fff;letter-spacing:-.02em}
.portal-brand .pb-hero h1 em{font-style:italic;color:var(--gold-400)}
.portal-brand .pb-hero p{color:#a9bdda;font-size:15px;margin-top:16px;max-width:42ch;line-height:1.6}
.portal-feats{display:flex;flex-direction:column;gap:14px;margin-top:30px;position:relative}
.portal-feat{display:flex;align-items:center;gap:13px;color:#cdd9ea;font-size:14px;font-weight:500}
.portal-feat .pf-ico{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);color:var(--gold-400);flex-shrink:0}
.portal-brand .pb-foot{margin-top:40px;position:relative;display:flex;gap:26px;flex-wrap:wrap}
.portal-brand .pb-foot .pbf b{font-family:var(--font-display);font-weight:700;font-size:23px;color:#fff;display:block;line-height:1}
.portal-brand .pb-foot .pbf span{font-size:11px;color:#8aa0bf;font-weight:600}

.portal-login{display:flex;align-items:center;justify-content:center;padding:40px 44px;background:var(--paper);overflow-y:auto}
.portal-login .pl-inner{width:100%;max-width:430px}
.portal-login h2{font-family:var(--font-display);font-weight:600;font-size:26px;color:var(--ink-900)}
.portal-login .pl-sub{color:var(--ink-500);font-size:14px;margin-top:6px;margin-bottom:24px}
.persona{display:flex;align-items:center;gap:14px;padding:15px 16px;border:1.5px solid var(--line);border-radius:var(--r-md);background:var(--surface);cursor:pointer;transition:.18s var(--ease);margin-bottom:11px;position:relative;text-align:left;width:100%}
.persona:hover{border-color:var(--blue-400);box-shadow:var(--sh-md);transform:translateY(-2px)}
.persona .p-ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;flex-shrink:0;color:#fff}
.persona .p-meta{flex:1;min-width:0}
.persona .p-meta b{display:block;font-size:15px;color:var(--ink-900);font-weight:700}
.persona .p-meta span{font-size:12.5px;color:var(--ink-400)}
.persona .p-arrow{color:var(--ink-300);transition:.18s}
.persona:hover .p-arrow{color:var(--blue-600);transform:translateX(3px)}
.persona.gold:hover{border-color:var(--gold-400)}
@media (max-width:880px){.portal{grid-template-columns:1fr}.portal-brand{display:none}.portal-login{min-height:100vh}}

/* ----------------------------- Digital membership card ------------------- */
.memcard{position:relative;overflow:hidden;border-radius:var(--r-lg);padding:22px;color:#eaf1fb;aspect-ratio:1.62/1;max-width:420px;
  background:radial-gradient(120% 120% at 100% 0%,rgba(243,181,31,.28),transparent 46%),linear-gradient(150deg,var(--navy-700),var(--navy-950));box-shadow:var(--sh-lg);border:1px solid #0a1c36}
.memcard::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:18px 18px}
.memcard .mc-top{display:flex;justify-content:space-between;align-items:flex-start;position:relative}
.memcard .mc-top .crest{width:40px;height:40px}
.memcard .mc-org{font-family:var(--font-display);font-weight:700;font-size:15px;color:#fff;line-height:1.1}
.memcard .mc-org span{display:block;font-size:9px;letter-spacing:.18em;color:var(--gold-400);font-weight:700;font-family:var(--font-sans)}
.memcard .mc-chip{width:42px;height:31px;border-radius:7px;background:linear-gradient(135deg,#f3d27a,#c8860b);position:relative;box-shadow:inset 0 0 0 1px rgba(255,255,255,.3)}
.memcard .mc-chip::after{content:"";position:absolute;inset:6px 8px;border:1px solid rgba(0,0,0,.18);border-radius:3px}
.memcard .mc-name{position:relative;margin-top:18px;font-size:19px;font-weight:700;color:#fff;letter-spacing:.01em}
.memcard .mc-row{position:relative;display:flex;gap:30px;margin-top:12px}
.memcard .mc-row .l{font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:#8aa0bf;font-weight:700}
.memcard .mc-row .v{font-family:var(--font-mono);font-size:13px;color:#eaf1fb;margin-top:2px;letter-spacing:.02em}
.memcard .mc-foot{position:relative;display:flex;justify-content:space-between;align-items:flex-end;margin-top:16px}

/* ----------------------------- Profile header ---------------------------- */
.profile-hd{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh-sm)}
.profile-cover{height:118px;background:radial-gradient(120% 160% at 90% 0%,rgba(243,181,31,.3),transparent 50%),linear-gradient(150deg,var(--navy-700),var(--navy-950));position:relative}
.profile-cover::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1px);background-size:22px 22px}
.profile-body{padding:16px 24px 20px;display:flex;gap:14px 20px;align-items:flex-end;position:relative;flex-wrap:wrap}
.profile-body .avatar.xl{margin-top:-58px;align-self:flex-start;box-shadow:0 0 0 5px var(--surface),var(--sh-md)}
.profile-meta{flex:1;min-width:220px;padding-bottom:2px}
.profile-meta h1{font-family:var(--font-display);font-weight:600;font-size:25px;letter-spacing:-.01em}
.profile-meta .pm-sub{color:var(--ink-500);font-size:14px;margin-top:3px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.profile-actions{display:flex;gap:9px;padding-bottom:6px;flex-wrap:wrap}
.factgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line-soft)}
.factgrid .fact{padding:15px 24px;border-right:1px solid var(--line-soft)}
.factgrid .fact:last-child{border-right:0}
.factgrid .fact .k{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-400)}
.factgrid .fact .v{font-size:15px;font-weight:700;color:var(--ink-900);margin-top:4px}
@media (max-width:680px){.factgrid{grid-template-columns:repeat(2,1fr)}.factgrid .fact:nth-child(2n){border-right:0}}

/* ----------------------------- CV document ------------------------------- */
.cv-doc{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--sh-md);padding:40px 44px;max-width:760px;margin:0 auto;color:#2b313b}
.cv-doc .cv-head{border-bottom:3px solid var(--navy-900);padding-bottom:18px;margin-bottom:22px;display:flex;justify-content:space-between;align-items:flex-end;gap:16px}
.cv-doc .cv-head h1{font-family:var(--font-display);font-weight:700;font-size:30px;color:var(--navy-900);letter-spacing:-.01em}
.cv-doc .cv-head .cv-title{color:var(--blue-700);font-weight:600;font-size:14px;margin-top:4px}
.cv-doc .cv-head .cv-contact{text-align:right;font-size:12px;color:var(--ink-500);line-height:1.7}
.cv-sec{margin-bottom:22px}
.cv-sec h3{font-family:var(--font-sans);font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-600);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.cv-sec h3::after{content:"";flex:1;height:1px;background:var(--line)}
.cv-item{margin-bottom:13px}
.cv-item .ci-top{display:flex;justify-content:space-between;gap:12px}
.cv-item .ci-role{font-weight:700;color:var(--ink-900);font-size:14px}
.cv-item .ci-org{color:var(--blue-700);font-size:13px;font-weight:500}
.cv-item .ci-yr{font-size:12px;color:var(--ink-400);font-weight:600;white-space:nowrap;font-family:var(--font-mono)}
.cv-tags{display:flex;flex-wrap:wrap;gap:7px}
.cv-tags span{font-size:12px;font-weight:600;color:var(--ink-700);background:var(--paper-2);border:1px solid var(--line);padding:4px 11px;border-radius:var(--r-pill)}
.cv-watermark{font-size:10px;color:var(--ink-300);text-align:center;margin-top:18px;letter-spacing:.04em}

/* ----------------------------- SACCO loan card --------------------------- */
.loanp{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--r-md);padding:18px;background:var(--surface);box-shadow:var(--sh-sm);transition:.18s var(--ease)}
.loanp:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.loanp .lp-ico{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;color:#fff;margin-bottom:13px}
.loanp h4{font-size:15.5px;color:var(--ink-900)}
.loanp .lp-desc{font-size:12.5px;color:var(--ink-500);margin-top:5px;min-height:34px}
.loanp .lp-meta{display:flex;gap:16px;margin-top:13px;padding-top:13px;border-top:1px solid var(--line-soft)}
.loanp .lp-meta .m b{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--ink-900);display:block}
.loanp .lp-meta .m span{font-size:10.5px;color:var(--ink-400);font-weight:600}

/* mini metric tile */
.mtile{padding:14px 15px;border-radius:var(--r-sm);background:var(--surface-2);border:1px solid var(--line-soft)}
.mtile .mt-k{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-400)}
.mtile .mt-v{font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--ink-900);margin-top:5px;font-variant-numeric:tabular-nums}

/* data definition list */
.dl{display:grid;grid-template-columns:auto 1fr;gap:11px 20px;align-items:baseline}
.dl dt{font-size:12.5px;color:var(--ink-400);font-weight:600}
.dl dd{font-size:13.5px;color:var(--ink-900);font-weight:600;margin:0;text-align:right}

/* quick action tile */
.qa{display:flex;flex-direction:column;gap:9px;padding:16px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--surface);cursor:pointer;transition:.16s var(--ease);align-items:flex-start}
.qa:hover{transform:translateY(-3px);box-shadow:var(--sh-md);border-color:var(--blue-300)}
.qa .qa-ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:#fff}
.qa b{font-size:14px;color:var(--ink-900)}
.qa span{font-size:12px;color:var(--ink-400)}

/* search/filter bar */
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}
.toolbar .input-group{flex:1;min-width:200px;max-width:380px}

/* pagination */
.pager{display:flex;align-items:center;gap:5px;justify-content:flex-end;padding:6px 0}
.pager button{min-width:34px;height:34px;border:1px solid var(--line);background:var(--surface);border-radius:8px;font-size:13px;font-weight:600;color:var(--ink-600);cursor:pointer;transition:.15s;padding:0 9px}
.pager button:hover:not(:disabled){border-color:var(--blue-300);color:var(--blue-700)}
.pager button.active{background:var(--navy-900);color:#fff;border-color:var(--navy-900)}
.pager button:disabled{opacity:.4;cursor:not-allowed}

/* ----------------------------- Marketplace ------------------------------- */
.deal{overflow:hidden;display:flex;flex-direction:column}
.deal-media{position:relative;height:152px;display:grid;place-items:center;color:#fff;overflow:hidden}
.deal-media::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.08) 1px,transparent 1px);background-size:16px 16px}
.deal-media svg{width:62px;height:62px;position:relative;filter:drop-shadow(0 6px 14px rgba(0,0,0,.28))}
.deal-badge{position:absolute;top:12px;left:12px;z-index:2;background:var(--gold-500);color:#3a2906;font-weight:800;font-size:12px;padding:3px 10px;border-radius:var(--r-pill);box-shadow:0 2px 8px rgba(0,0,0,.18)}
.deal-fav{position:absolute;top:11px;right:11px;z-index:2;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(4px);display:grid;place-items:center;color:#fff;border:1px solid rgba(255,255,255,.25);cursor:pointer}
.deal-fav svg{width:16px;height:16px}
.deal-fav.on{background:#fff;color:var(--red-600)}
.deal-body{padding:14px 16px 16px;display:flex;flex-direction:column;flex:1}
.deal-brand{font-size:10.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-400)}
.deal-name{font-size:14.5px;font-weight:700;color:var(--ink-900);margin-top:3px;line-height:1.3;min-height:38px}
.deal-price{display:flex;align-items:baseline;gap:8px;margin-top:9px}
.deal-price .now{font-family:var(--font-display);font-weight:700;font-size:21px;color:var(--ink-900);letter-spacing:-.02em}
.deal-price .was{font-size:13px;color:var(--ink-400);text-decoration:line-through}
.deal-mo{font-size:12px;color:var(--green-600);font-weight:700;margin-top:5px;display:flex;align-items:center;gap:5px}
.deal-mo svg{width:14px;height:14px}
.deal .deal-cta{margin-top:13px}
.mk-featured{position:relative;overflow:hidden;border-radius:var(--r-lg);color:#eaf1fb;padding:0;display:grid;grid-template-columns:1.1fr 1fr;border:1px solid #0a1c36;box-shadow:var(--sh-md)}
.mk-featured .mkf-text{padding:30px 32px}
.mk-featured .mkf-visual{position:relative;display:grid;place-items:center;background:radial-gradient(120% 120% at 100% 0%,rgba(243,181,31,.3),transparent 50%),linear-gradient(150deg,var(--navy-700),var(--navy-950))}
.mk-featured .mkf-visual svg{width:140px;height:140px;color:#fff;filter:drop-shadow(0 14px 30px rgba(0,0,0,.4))}
.mk-featured .mkf-text{background:linear-gradient(150deg,var(--navy-800),var(--navy-950))}
.mk-partner{height:46px;padding:0 18px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--ink-600);letter-spacing:-.01em}
@media (max-width:760px){.mk-featured{grid-template-columns:1fr}.mk-featured .mkf-visual{min-height:160px}}

/* responsive: persona grid for member quick actions */
@media (max-width:680px){.dl dd{text-align:left}.cv-doc{padding:26px 22px}.factgrid .fact{padding:13px 16px}}
