/*
Theme Name: Bulilima-Mangwe Institute of Technology
Theme URI: https://imfundospace.com
Description: Kadence child theme for Bulilima-Mangwe Institute of Technology (BMIT) — tuition-free online institute of technology. Navy-led institutional register, blue for action, crest gold + forest green accents. Fraunces + Inter.
Author: Flashcloud
Template: kadence
Version: 1.0.0
*/

/* ============================================================
   1. FONTS (self-hosted variable woff2, latin subset)
   ============================================================ */
@font-face{font-family:"Fraunces";src:url("fonts/fraunces-var.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("fonts/inter-var.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}

/* ============================================================
   2. TOKENS — anchored from the BMIT crest
   navy = grounds/ink · blue = ACTION only · gold + green = accents · red sparingly
   ============================================================ */
:root{
  --bm-navy:#1B324F;        /* primary section ground + ink */
  --bm-navy-900:#11202D;    /* deepest ground (footer, hero base) */
  --bm-navy-700:#274566;    /* mid navy */
  --bm-slate:#33506B;       /* prefooter / secondary ground */
  --bm-blue:#2563EB;        /* ACTION: buttons, links, focus */
  --bm-blue-600:#1F4FC4;    /* button hover */
  --bm-blue-300:#7DA2F2;    /* link on dark */
  --bm-gold:#D59E24;        /* crest gold accent */
  --bm-gold-600:#B5851A;
  --bm-gold-300:#E7C16B;
  --bm-green:#1D5918;       /* crest forest green accent */
  --bm-green-600:#164312;
  --bm-red:#A22916;         /* crest brick red, used sparingly */
  --bm-paper:#F7F4EC;       /* warm page ground */
  --bm-paper-2:#FBF9F3;     /* lighter section ground */
  --bm-sand-300:#E4DDCD;    /* warm hairline / card border */
  --bm-ink:#16202B;         /* body text on light */
  --bm-text-muted:#5A6B7A;  /* secondary text on light */
  --bm-stone:#7A8794;
  --bm-text-ondark:#EAF0F5;
  --bm-text-ondark-muted:#B7C5D1;
  --bm-line:#E4DDCD;
  --bm-line-dark:rgba(234,240,245,.16);
  --bm-font-display:"Fraunces",Georgia,serif;
  --bm-font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --bm-r-sm:8px;--bm-r-md:14px;--bm-r-lg:18px;--bm-r-pill:999px;
  --bm-shadow-card:0 14px 38px -18px rgba(17,32,45,.24);
  --bm-shadow-soft:0 6px 20px -10px rgba(17,32,45,.18);
  --bm-container:1180px;
}

/* ============================================================
   3. FRAME KILLERS (Kadence light-theme defaults → edge-to-edge)
   Paper on BODY only (never .site-container — cascades into dark footer).
   ============================================================ */
body{background:var(--bm-paper);color:var(--bm-ink);font-family:var(--bm-font-body);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased}
.site-container,.content-container,.content-area,.site-main,.entry-content{background:transparent}
.single-page .entry-content,.page .entry-content{margin-top:0!important}
.content-area{margin:0!important}
.page .entry-hero,.entry-hero.page-hero-section{display:none!important}
.page .entry-content>*{margin-top:0;margin-bottom:0}
.wp-site-blocks>main{flex:0 0 auto!important}
.entry-content .wp-block-group,.single-page .entry-content{max-width:none}

/* ============================================================
   4. TYPOGRAPHY + PRIMITIVES
   ============================================================ */
h1,h2,h3,h4{font-family:var(--bm-font-display);font-weight:600;line-height:1.14;letter-spacing:-.01em;color:var(--bm-navy)}
a{color:var(--bm-blue)}
.bm-wrap{max-width:var(--bm-container);margin:0 auto;padding:0 40px}
.bm-section{padding:84px 0}
.bm-center{text-align:center}
.bm-eyebrow{font-family:var(--bm-font-body);font-size:12.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--bm-green);margin:0 0 14px}
.bm-eyebrow.on-dark{color:var(--bm-gold-300)}
.bm-lede{font-size:1.22rem;line-height:1.62;color:var(--bm-text-muted);max-width:62ch}
.bm-secthead{max-width:680px;margin:0 auto 42px}
.bm-secthead h2{font-size:clamp(1.9rem,3vw,2.6rem);margin:0 0 12px}
.bm-secthead .bm-lede{margin-left:auto;margin-right:auto}

/* buttons — BLUE is the action colour, gold is the on-dark "portal" CTA */
.bm-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--bm-font-body);font-weight:600;font-size:1rem;padding:.9rem 1.65rem;border-radius:var(--bm-r-md);text-decoration:none;border:1.5px solid transparent;transition:background .2s,color .2s,border-color .2s;cursor:pointer;line-height:1}
.bm-btn-primary{background:var(--bm-blue);color:#fff}
.bm-btn-primary:hover{background:var(--bm-blue-600);color:#fff}
.bm-btn-gold{background:var(--bm-gold);color:#241a00}
.bm-btn-gold:hover{background:var(--bm-gold-600);color:#fff}
.bm-btn-ghost{background:transparent;color:#fff;border-color:rgba(234,240,245,.46)}
.bm-btn-ghost:hover{background:rgba(234,240,245,.12);color:#fff}
.bm-btn-ghost.on-light{color:var(--bm-navy);border-color:var(--bm-navy)}
.bm-btn-ghost.on-light:hover{background:var(--bm-navy);color:#fff}

/* ============================================================
   5. HERO (Home)
   ============================================================ */
.bm-hero{position:relative;min-height:660px;display:flex;align-items:center;background:#0d1a26;
  width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.bm-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.34}
.bm-hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(120deg,rgba(15,26,38,.94) 0%,rgba(20,40,56,.78) 46%,rgba(20,40,56,.42) 100%)}
.bm-hero-inner{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:120px 0 96px}
.bm-hero-h{font-size:clamp(2.6rem,5vw,3.9rem);color:#fff;max-width:16ch;margin:18px 0 0;line-height:1.04}
.bm-hero-h .acc{color:var(--bm-gold)}
.bm-hero-lede{color:var(--bm-text-ondark);font-size:clamp(1.08rem,1.4vw,1.22rem);line-height:1.6;max-width:48ch;margin:22px 0 0}
.bm-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}
.bm-hero-fig{position:relative;aspect-ratio:4/3;border-radius:var(--bm-r-lg);overflow:hidden;box-shadow:0 30px 70px -24px rgba(0,0,0,.65);border:1px solid rgba(234,240,245,.14)}
.bm-hero-fig img{width:100%;height:100%;object-fit:cover}

/* ============================================================
   6. PAGE HERO (interior pages — compact)
   ============================================================ */
.bm-pagehero{position:relative;overflow:hidden;background:var(--bm-navy);color:var(--bm-text-ondark);
  padding:118px 0 66px;text-align:center;
  width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.bm-pagehero::before{content:"";position:absolute;inset:0;background:var(--bm-pagehero-bg) center/cover;opacity:.16}
.bm-pagehero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,40,56,.55),rgba(17,32,45,.85))}
.bm-pagehero .bm-wrap{position:relative;z-index:2}
.bm-pagehero h1{font-size:clamp(2.2rem,4vw,3.2rem);color:#fff;margin:0 0 14px}
.bm-pagehero .bm-lede{margin:0 auto;color:var(--bm-text-ondark-muted)}
.bm-pagehero .bm-eyebrow{color:var(--bm-gold-300)}

/* ============================================================
   7. PROMISE BAND (stats / markers)
   ============================================================ */
.bm-promise{background:var(--bm-paper);width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);border-bottom:1px solid var(--bm-line)}
.bm-promise>.bm-wrap{max-width:var(--bm-container);margin:0 auto;padding:54px 40px}
.bm-promise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.bm-pcard{background:#fff;border:1px solid var(--bm-line);border-radius:var(--bm-r-md);padding:30px 28px;box-shadow:var(--bm-shadow-soft)}
.bm-pcard-ic{width:48px;height:48px;border-radius:12px;background:#eef2fb;color:var(--bm-blue);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.bm-pcard-ic svg{width:24px;height:24px}
.bm-pcard h3{font-size:1.3rem;color:var(--bm-navy);margin:0 0 8px}
.bm-pcard p{font-size:.98rem;color:var(--bm-text-muted);line-height:1.55;margin:0}

/* ============================================================
   8. FULL-BLEED SECTION GROUNDS
   ============================================================ */
.bm-paper2{background:var(--bm-paper-2);width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.bm-paper2>.bm-wrap{max-width:var(--bm-container);margin:0 auto;padding:0 40px}
.bm-indigo{background:var(--bm-navy);color:var(--bm-text-ondark);width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.bm-indigo>.bm-wrap{max-width:var(--bm-container);margin:0 auto;padding:0 40px}
.bm-indigo h2,.bm-indigo h3,.bm-indigo h4{color:#fff}
.bm-indigo p{color:var(--bm-text-ondark-muted)}

/* ============================================================
   9. FACULTIES GRID
   ============================================================ */
.bm-facs{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.bm-fac{background:#fff;border:1px solid var(--bm-line);border-radius:var(--bm-r-md);overflow:hidden;box-shadow:var(--bm-shadow-card);display:flex;flex-direction:column;text-decoration:none;transition:transform .2s,box-shadow .2s}
a.bm-fac:hover{transform:translateY(-3px);box-shadow:0 22px 48px -20px rgba(17,32,45,.32)}
.bm-fac-ph{aspect-ratio:16/9;position:relative;overflow:hidden;background:var(--bm-navy-700)}
.bm-fac-ph img{width:100%;height:100%;object-fit:cover}
.bm-fac-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.bm-fac h3{font-size:1.18rem;color:var(--bm-navy);line-height:1.2;margin:0 0 8px}
.bm-fac p{font-size:.95rem;color:var(--bm-text-muted);line-height:1.55;margin:0 0 16px}
.bm-fac-go{margin-top:auto;font-weight:600;color:var(--bm-blue);font-size:.94rem}
/* faculties that are NOT links (no detail page yet) lose the hover lift cursor */
span.bm-fac{cursor:default}

/* ============================================================
   10. VISION / SPLIT PROSE (image + text)
   ============================================================ */
.bm-split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.bm-split.img-right .bm-split-fig{order:2}
.bm-split-text h2{font-size:clamp(1.7rem,2.6vw,2.4rem);margin:12px 0 16px}
.bm-split-text p{font-size:1.08rem;line-height:1.65;margin:0 0 16px}
.bm-split-text .bm-btn{margin-top:10px}
.bm-split-fig{aspect-ratio:4/3;border-radius:var(--bm-r-lg);overflow:hidden;box-shadow:var(--bm-shadow-card)}
.bm-split-fig img{width:100%;height:100%;object-fit:cover}
.bm-indigo .bm-split-text p{color:var(--bm-text-ondark-muted)}
.bm-indigo .bm-split-text p strong{color:#fff}

/* prose-only split (legal / about long copy): single readable column */
.bm-prose{max-width:760px;margin:0 auto}
.bm-prose h2{font-size:clamp(1.5rem,2.3vw,1.95rem);margin:30px 0 14px}
.bm-prose h3{font-size:1.25rem;margin:24px 0 10px}
.bm-prose p{font-size:1.06rem;line-height:1.7;color:var(--bm-ink);margin:0 0 16px}
.bm-prose ul{margin:0 0 16px 1.2rem;line-height:1.7}
.bm-prose li{margin-bottom:8px}
.bm-prose a{color:var(--bm-blue);text-decoration:underline}
.bm-prose strong{color:var(--bm-navy)}

/* ============================================================
   11. LEADERSHIP / FEATURE CARDS (about)
   ============================================================ */
.bm-leaders{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;max-width:840px;margin:0 auto}
.bm-leaders.is-single{grid-template-columns:1fr;max-width:680px}
.bm-leader{background:#fff;border:1px solid var(--bm-line);border-radius:var(--bm-r-md);padding:28px;box-shadow:var(--bm-shadow-soft)}
.bm-leader.has-photo{display:flex;gap:24px;align-items:center;padding:24px}
.bm-leader-ph{flex:none;width:128px;height:128px;border-radius:14px;overflow:hidden;background:var(--bm-navy-700)}
.bm-leader-ph img{width:100%;height:100%;object-fit:cover;object-position:top center}
.bm-leader .role{font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--bm-green)}
.bm-leader h3{font-size:1.3rem;color:var(--bm-navy);margin:8px 0 6px}
.bm-leader p{font-size:.97rem;color:var(--bm-text-muted);line-height:1.6;margin:0}
@media(max-width:560px){.bm-leader.has-photo{flex-direction:column;text-align:center}.bm-leader-ph{width:110px;height:110px}}

/* ============================================================
   12. CONTACT BLOCK
   ============================================================ */
.bm-contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:start}
.bm-contact-stack h2{font-size:1.9rem;margin:12px 0 24px}
.bm-contact-row{display:flex;gap:16px;align-items:flex-start;margin-bottom:22px}
.bm-contact-ic{width:46px;height:46px;flex:none;border-radius:12px;background:#eef2fb;display:flex;align-items:center;justify-content:center}
.bm-contact-ic svg{width:22px;height:22px;color:var(--bm-blue)}
.bm-contact-row b{font-family:var(--bm-font-display);font-size:1.05rem;color:var(--bm-navy);display:block;margin-bottom:2px}
.bm-contact-row span,.bm-contact-row a{color:var(--bm-text-muted);font-size:1rem;text-decoration:none}
.bm-contact-row a:hover{color:var(--bm-blue)}
.bm-wa{display:inline-flex;align-items:center;gap:10px;background:#25D366;color:#0b3d23;font-weight:700;padding:.85rem 1.5rem;border-radius:var(--bm-r-md);text-decoration:none;margin-top:6px}
.bm-wa:hover{background:#1ebe5a;color:#0b3d23}
.bm-wa svg{width:22px;height:22px;fill:#0b3d23}
.bm-portal-links{margin-top:26px;border-top:1px solid var(--bm-line);padding-top:22px;display:flex;flex-direction:column;gap:12px}
.bm-portal-links a{display:inline-flex;align-items:center;gap:8px;color:var(--bm-blue);font-weight:600;text-decoration:none}
.bm-portal-links a:hover{color:var(--bm-blue-600)}
.bm-form-card{background:#fff;border:1px solid var(--bm-line);border-radius:var(--bm-r-lg);box-shadow:var(--bm-shadow-card);padding:34px}
.bm-form-card h3{font-size:1.5rem;margin:0 0 6px}
.bm-form-sub{color:var(--bm-text-muted);font-size:.97rem;margin:0 0 22px}
/* WPForms branded */
.bm-form-card .wpforms-field-label{font-family:var(--bm-font-body);font-weight:600;font-size:.9rem;color:var(--bm-ink)}
.bm-form-card .wpforms-field input[type=text],
.bm-form-card .wpforms-field input[type=email],
.bm-form-card .wpforms-field textarea,
.bm-form-card .wpforms-field select{border:1.5px solid var(--bm-line)!important;border-radius:10px!important;background:#FCFAF5!important;color:var(--bm-ink)!important;font-family:var(--bm-font-body)!important;padding:.8rem 1rem!important}
.bm-form-card .wpforms-field input:focus,
.bm-form-card .wpforms-field textarea:focus,
.bm-form-card .wpforms-field select:focus{border-color:var(--bm-blue)!important;outline:none!important;box-shadow:0 0 0 3px rgba(37,99,235,.16)!important}
.bm-form-card .wpforms-submit{background:var(--bm-blue)!important;color:#fff!important;border:none!important;font-family:var(--bm-font-body)!important;font-weight:700!important;font-size:1.02rem!important;padding:.85rem 2rem!important;border-radius:var(--bm-r-md)!important;cursor:pointer;transition:background .2s}
.bm-form-card .wpforms-submit:hover{background:var(--bm-blue-600)!important;color:#fff!important}
.bm-form-card .wpforms-required-label{color:var(--bm-red)}

/* ============================================================
   13. PREFOOTER / CTA BAND (blue — the action band)
   ============================================================ */
.bm-cta{background:linear-gradient(120deg,var(--bm-blue),var(--bm-blue-600));text-align:center;padding:80px 0;
  width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.bm-cta .bm-wrap{max-width:760px;margin:0 auto;padding:0 40px}
.bm-cta h2{font-size:clamp(1.9rem,2.8vw,2.6rem);color:#fff;margin:0 0 14px}
.bm-cta .bm-lede{margin:0 auto 28px;color:#e0e9fb}
.bm-cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ============================================================
   14. RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .bm-hero-inner{grid-template-columns:1fr;gap:36px;padding:110px 0 72px}
  .bm-hero-fig{max-width:560px}
  .bm-facs{grid-template-columns:repeat(2,1fr)}
  .bm-promise-grid{grid-template-columns:repeat(3,1fr);gap:18px}
}
@media(max-width:782px){
  .bm-section{padding:58px 0}
  .bm-wrap,.bm-paper2>.bm-wrap,.bm-indigo>.bm-wrap,.bm-cta .bm-wrap,.bm-promise>.bm-wrap{padding-left:22px;padding-right:22px}
  .bm-hero{min-height:0}
  .bm-hero-inner{padding-top:104px;padding-bottom:60px}
  .bm-hero-h{font-size:clamp(2.1rem,8vw,2.7rem)}
  .bm-facs{grid-template-columns:1fr}
  .bm-promise-grid{grid-template-columns:1fr;gap:16px}
  .bm-split{grid-template-columns:1fr;gap:28px}
  .bm-split.img-right .bm-split-fig{order:0}
  .bm-leaders{grid-template-columns:1fr}
  .bm-contact-grid{grid-template-columns:1fr;gap:32px}
  .bm-pagehero{padding:94px 0 50px}
  .bm-form-card{padding:24px}
}
