/* ═══════════════════════════════════════════════
   CHReaD · v9 — Fixed, Visual, Creative
   ═══════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,400;0,600;0,700;0,800;0,900;1,700;1,800;1,900&family=Roboto:wght@300;400;500&family=Staatliches&display=swap');
@import url('https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css');

/* ── TOKENS ───────────────────────────────────── */
:root {
  --orange:   #F17D01;
  --orange-d: #C56400;
  --orange-lt:#FFF4E6;
  --pink:     #E61F93;
  --purple:   #7C3AED;
  --navy:     #0B2D5C;
  --navy-d:   #060F20;
  --teal:     #296975;
  --teal-d:   #1a4550;
  --teal-lt:  #E8F5F7;
  --green:    #279545;
  --green-lt: #EDFAF1;
  --blue:     #3B82F6;
  --cream:    #FAF8F5;
  --off:      #F4F4F2;
  --white:    #FFFFFF;
  --border:   #E5E7EB;
  --text:     #111827;
  --muted:    #6B7280;

  --PAT1: url('https://chread.africa/Primary%20Pattern%202.png');
  --PAT2: url('https://chread.africa/Secondary%20Pattern%201.png');

  --font: 'Montserrat', sans-serif;
  --body: 'Roboto', sans-serif;

  --ease:    cubic-bezier(.4,0,.2,1);
  --spring:  cubic-bezier(.34,1.56,.64,1);
  --t:       .3s var(--ease);
  --r:  10px; --rL: 20px; --rXL: 28px; --rF: 9999px;
  --sh: 0 4px 20px rgba(0,0,0,.10);
  --sh-md: 0 8px 36px rgba(0,0,0,.14);
  --sh-lg: 0 16px 60px rgba(0,0,0,.18);
  --sh-xl: 0 28px 88px rgba(0,0,0,.24);
}

/* ── ANIMATIONS ───────────────────────────────── */
@keyframes float   { 0%,100%{transform:translateY(0)rotate(0)} 50%{transform:translateY(-22px)rotate(5deg)} }
@keyframes float2  { 0%,100%{transform:translateY(0)rotate(0)} 50%{transform:translateY(-14px)rotate(-7deg)} }
@keyframes float3  { 0%,100%{transform:translateY(0)rotate(0)} 50%{transform:translateY(-28px)rotate(4deg)} }
@keyframes pulse   { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.7)} }
@keyframes blink   { 0%,100%{opacity:1} 50%{opacity:.3} }
@keyframes gradPan { from{background-position:0% center} to{background-position:300% center} }
@keyframes gradShift{ from{background-position:0% 50%} to{background-position:100% 50%} }
@keyframes slideUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:none} }
@keyframes shimmer { from{transform:translateX(-100%)} to{transform:translateX(300%)} }
@keyframes spin    { from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes ringPulse{0%{box-shadow:0 0 0 0 rgba(241,125,1,.35)} 70%{box-shadow:0 0 0 12px rgba(241,125,1,0)} 100%{box-shadow:0 0 0 0 rgba(241,125,1,0)}}

/* Animated gradient text */
.grad-text {
  background: linear-gradient(135deg, var(--orange) 0%, #FFD580 30%, #FF6B35 60%, var(--orange) 100%);
  background-size: 300%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradPan 3s linear infinite;
}

/* ── RESET ────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--body);color:var(--text);background:#fff;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--t)}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}

/* ── TYPE ─────────────────────────────────────── */
h1,h2,h3,h4,h5{font-family:var(--font);font-weight:800;line-height:1.12;letter-spacing:-.01em}
p{color:var(--muted);line-height:1.75}
.disp    {font-family:var(--font);font-size:clamp(3rem,6.5vw,6.5rem);font-weight:900;line-height:.93;letter-spacing:-.03em;text-transform:uppercase}
.disp-sm {font-family:var(--font);font-size:clamp(2rem,4vw,3.5rem);font-weight:900;line-height:1.05;letter-spacing:-.02em;text-transform:uppercase}
.kicker  {font-family:var(--font);font-size:.64rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;gap:.65rem;margin-bottom:1.25rem}
.kicker::before{content:'';display:block;width:22px;height:2.5px;background:var(--orange);border-radius:2px;flex-shrink:0}
.kicker.center{justify-content:center}.kicker.center::before{display:none}
.kicker.white{color:rgba(255,255,255,.65)}.kicker.white::before{background:rgba(255,255,255,.5)}
.kicker.dark{color:var(--navy)}.kicker.dark::before{background:var(--navy)}

/* ── LAYOUT ───────────────────────────────────── */
.wrap{width:100%;max-width:1200px;margin:0 auto;padding:0 2rem}
.sec{padding:90px 0}
.sec-lg{padding:120px 0}
.sec-sm{padding:52px 0}
/* All sections — wrap above pattern pseudo-elements */
.sec > .wrap,.sec-lg > .wrap,.sec-sm > .wrap{position:relative;z-index:1}

/* Wave dividers */
.wave-divider{line-height:0;overflow:hidden}
.wave-divider svg{display:block;width:100%}

/* Pattern flanks */
.flanked{position:relative;overflow:hidden}
.flanked .pat-l,.flanked .pat-r{position:absolute;top:0;bottom:0;width:140px;background-image:var(--PAT1);background-size:auto 100%;background-repeat:no-repeat;z-index:0;pointer-events:none}
.flanked .pat-l{left:0;background-position:left center}
.flanked .pat-r{right:0;background-position:right center;transform:scaleX(-1)}
.flanked>.wrap{position:relative;z-index:1}

/* Cursor spotlight */
.cursor-spot{position:fixed;width:480px;height:480px;border-radius:50%;pointer-events:none;z-index:2;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(241,125,1,.12) 0%,transparent 60%);opacity:0;transition:opacity .4s ease;will-change:left,top}
.cursor-spot.active{opacity:1}

/* ── BUTTONS ──────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--font);font-size:.72rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:.82rem 1.85rem;border-radius:var(--rF);border:2px solid transparent;cursor:pointer;transition:all .3s var(--ease);white-space:nowrap;line-height:1;position:relative;overflow:hidden}
.btn i{font-size:.85em;transition:transform .25s var(--ease)}
.btn:hover i.bi-arrow-right{transform:translateX(4px)}
.btn::after{content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);transform:skewX(-20deg);transition:left .6s ease;pointer-events:none}
.btn:hover::after{left:150%}
.btn-o{background:var(--orange);color:#fff;border-color:var(--orange);box-shadow:0 4px 16px rgba(241,125,1,.35)}
.btn-o:hover{background:var(--orange-d);transform:translateY(-3px);box-shadow:0 10px 30px rgba(241,125,1,.45);color:#fff}
.btn-n{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-n:hover{background:#082040;transform:translateY(-3px);color:#fff}
.btn-t{background:var(--teal);color:#fff;border-color:var(--teal)}
.btn-t:hover{background:var(--teal-d);transform:translateY(-3px);color:#fff}
.btn-g{background:var(--green);color:#fff;border-color:var(--green)}
.btn-g:hover{background:#1c7035;transform:translateY(-3px);color:#fff}
.btn-wh{background:#fff;color:var(--navy);border-color:#fff}
.btn-wh:hover{background:var(--orange);color:#fff;border-color:var(--orange);transform:translateY(-3px)}
.btn-wo{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-wo:hover{background:rgba(255,255,255,.15);border-color:#fff;transform:translateY(-2px)}
.btn-on{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-on:hover{background:var(--navy);color:#fff}
.btn-ot{background:transparent;color:var(--orange);border-color:var(--orange)}
.btn-ot:hover{background:var(--orange);color:#fff}
.btn-pink{background:var(--pink);color:#fff;border-color:var(--pink)}
.btn-pink:hover{background:#C01680;transform:translateY(-3px);color:#fff}
.btn-sm{padding:.58rem 1.35rem;font-size:.68rem}
.btn-lg{padding:1rem 2.4rem;font-size:.78rem}

/* ══════════════════════════════════════════════
   HEADER — always visible, solid white
══════════════════════════════════════════════ */
.hdr{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:66px;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(16px);
  box-shadow:0 1px 0 var(--border);
  transition:box-shadow .3s var(--ease);
}
.hdr.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.08)}

.hdr-inner{max-width:1200px;margin:0 auto;padding:0 2rem;height:100%;display:flex;align-items:center;gap:1.25rem}
.hdr-logo img{height:36px;display:block;transition:opacity var(--t)}
.hdr-logo:hover img{opacity:.72}

.hdr-nav{display:flex;align-items:center;margin-left:auto}
.hdr-nav>ul{display:flex;align-items:center}
.hdr-nav>ul>li{position:relative}
.hdr-nav>ul>li>a{
  font-family:var(--font);font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);padding:0 .8rem;height:66px;
  display:flex;align-items:center;gap:3px;
  transition:color var(--t);position:relative;
}
.hdr-nav>ul>li>a:hover{color:var(--navy)}
.hdr-nav>ul>li>a.active{color:var(--orange)}
.hdr-nav>ul>li>a.active::after{content:'';position:absolute;bottom:0;left:.8rem;right:.8rem;height:2px;background:var(--orange);border-radius:2px 2px 0 0}

/* Dropdown */
.hdr-nav .dd>a::after{content:'\F282';font-family:'Bootstrap Icons';font-size:.58rem;margin-left:2px;opacity:.5}
.hdr-nav .dd>a.active::after{content:'\F282' !important;height:auto !important;background:none !important;bottom:auto !important;position:relative !important;left:auto !important;right:auto !important}
.hdr-nav .dd .dd-menu{display:none;position:absolute;top:calc(100% + 4px);left:0;min-width:196px;background:#fff;border-radius:var(--rL);box-shadow:var(--sh-lg),0 0 0 1px rgba(0,0,0,.04);overflow:hidden;z-index:200}
.hdr-nav .dd:hover .dd-menu{display:block}
.hdr-nav .dd .dd-menu::before{content:'';display:block;height:2px;background:linear-gradient(90deg,var(--orange),var(--pink))}
.hdr-nav .dd .dd-menu li a{display:block;font-family:var(--font);font-size:.68rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);padding:.75rem 1.15rem;border-bottom:1px solid var(--border);transition:all var(--t)}
.hdr-nav .dd .dd-menu li a:hover{color:var(--orange);background:var(--orange-lt);padding-left:1.4rem}
.hdr-nav .dd .dd-menu li:last-child a{border-bottom:none}

.hdr-cta{flex-shrink:0;margin-left:.5rem}
.hdr-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;width:38px;height:38px;gap:5px;border-radius:var(--r);border:1.5px solid var(--border);background:transparent;transition:border-color var(--t)}
.hdr-toggle:hover{border-color:var(--orange)}
.hdr-toggle span{display:block;width:20px;height:2px;background:var(--navy);border-radius:2px;transition:all var(--t)}
.hdr-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hdr-toggle.open span:nth-child(2){opacity:0}
.hdr-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ══════════════════════════════════════════════
   HERO — refined mosaic
══════════════════════════════════════════════ */
.hero{min-height:100vh;padding-top:66px;display:grid;grid-template-columns:55% 45%;grid-template-rows:1fr 200px;overflow:hidden}

/* Left panel — navy with decorative elements */
.hero-a{grid-column:1;grid-row:1;background:var(--navy);display:flex;flex-direction:column;justify-content:center;padding:4rem 4rem 4rem 0;position:relative;overflow:hidden}

/* Decorative accent line along left edge */
.hero-a-stripe{position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(to bottom,var(--orange),var(--pink),var(--teal));z-index:2}

/* Soft glow orbs */
.hero-a::before{content:'';position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(241,125,1,.12) 0%,transparent 60%);right:-80px;top:-60px;pointer-events:none}
.hero-a::after{content:'';position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(39,149,69,.1) 0%,transparent 65%);left:-60px;bottom:-50px;pointer-events:none}

/* Floating accent blobs */
.hero-blob{position:absolute;border-radius:50%;pointer-events:none;z-index:0}
.hero-blob-1{width:160px;height:160px;background:radial-gradient(circle,rgba(124,58,237,.18),transparent);right:18%;top:22%;animation:float2 7s ease-in-out infinite 1s}
.hero-blob-2{width:80px;height:80px;background:radial-gradient(circle,rgba(59,130,246,.18),transparent);left:12%;top:38%;animation:float 9s ease-in-out infinite 3s}
.hero-blob-3{width:50px;height:50px;border:2px solid rgba(241,125,1,.25);right:30%;bottom:25%;border-radius:12px;transform:rotate(30deg);animation:spin 25s linear infinite}

.hero-a-inner{position:relative;z-index:1}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.55rem;margin-bottom:1.75rem}
.hero-eyebrow-dot{width:7px;height:7px;border-radius:50%;background:var(--orange);animation:blink 2s ease infinite;flex-shrink:0}
.hero-eyebrow span{font-family:var(--font);font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.5)}

.hero-a h1{font-family:var(--font);font-weight:900;font-size:clamp(3rem,5.5vw,5.5rem);line-height:.93;letter-spacing:-.03em;color:#fff;text-transform:uppercase;margin-bottom:2rem}
.hero-a h1 .animated-word{display:inline-block;background:linear-gradient(135deg,var(--orange) 0%,#FFD580 30%,#FF6B35 60%,var(--orange) 100%);background-size:300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradPan 3s linear infinite;font-style:italic}

.hero-desc{font-size:.98rem;color:rgba(255,255,255,.55);max-width:400px;line-height:1.75;margin-bottom:2.5rem}
.hero-acts{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}

/* Stat pills */
.hero-pills{display:flex;flex-wrap:wrap;gap:.75rem;border-top:1px solid rgba(255,255,255,.08);padding-top:2rem}
.hero-pill{display:flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--rF);padding:.5rem 1rem;transition:all var(--t)}
.hero-pill:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.22);transform:translateY(-2px)}
.hp-n{font-family:'Staatliches',sans-serif;font-size:1.8rem;color:var(--orange);line-height:1}
.hp-l{font-family:var(--font);font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.4)}

/* Right panel — CHReaD pattern with reduced intensity */
.hero-b{grid-column:2;grid-row:1;background-image:var(--PAT1);background-size:cover;background-position:center;position:relative;overflow:hidden}
/* Softer overlay to reduce loudness */
.hero-b::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(11,45,92,.2) 0%,rgba(11,45,92,.05) 40%,transparent 70%);pointer-events:none;z-index:1}
/* Subtle white vignette at edges */
.hero-b::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,transparent 40%,rgba(0,0,0,.1) 100%);pointer-events:none;z-index:1}

.hero-circle{position:absolute;top:50%;left:50%;transform:translate(-50%,-52%);z-index:2;width:min(340px,76%);aspect-ratio:1;border-radius:50%;overflow:hidden;border:6px solid rgba(255,255,255,.95);box-shadow:var(--sh-xl),0 0 0 14px rgba(255,255,255,.2),0 0 0 28px rgba(255,255,255,.08)}
.hero-circle img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;bottom:1.75rem;left:1.5rem;right:1.5rem;z-index:3;background:rgba(6,30,62,.72);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:var(--rL);padding:1.1rem 1.4rem;display:flex;align-items:center;gap:.85rem}
.hbdot{width:8px;height:8px;border-radius:50%;background:var(--orange);flex-shrink:0;animation:blink 2s ease infinite}
.hbtext{flex:1}
.hbpre{font-family:var(--font);font-size:.55rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:.15rem}
.hbtitle{font-family:var(--font);font-size:.86rem;font-weight:800;color:#fff}

/* Bottom stat row */
.hero-stats-row{grid-column:1/3;grid-row:2;display:grid;grid-template-columns:repeat(4,1fr)}
.hstat{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;padding:1.75rem 1.5rem;position:relative;overflow:hidden;border-right:1px solid rgba(255,255,255,.12);transition:filter .3s;cursor:default}
.hstat:last-child{border-right:none}
.hstat:hover{filter:brightness(1.1)}
.hstat::after{content:'';position:absolute;bottom:0;left:50%;right:50%;height:3px;background:rgba(255,255,255,.4);transition:all .4s var(--ease)}
.hstat:hover::after{left:10%;right:10%}
.hs-1{background:linear-gradient(135deg,var(--orange),#FF6B35)}
.hs-2{background:linear-gradient(135deg,var(--teal),#1D9E90)}
.hs-3{background:linear-gradient(135deg,var(--green),#1D9E50)}
.hs-4{background:linear-gradient(135deg,var(--navy),#1a3e72)}
.hstat-n{font-family:'Staatliches',sans-serif;font-size:3.5rem;color:#fff;line-height:1;display:block}
.hstat-l{font-family:var(--font);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.82)}

/* ══════════════════════════════════════════════
   ABOUT — teal gradient
══════════════════════════════════════════════ */
.about-sec{background:linear-gradient(135deg,var(--teal) 0%,#1D9E90 50%,#296975 100%);position:relative;overflow:hidden}
.about-sec::before{content:'';position:absolute;inset:0;background-image:var(--PAT2);background-size:30%;background-position:left bottom;background-repeat:no-repeat;opacity:.18;pointer-events:none}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;position:relative;z-index:1}
.about-img-col{position:relative}
.about-img-frame{border-radius:var(--rXL);overflow:hidden;box-shadow:var(--sh-xl)}
/* Full image — not cropped, shows complete people */
.about-img-frame img{width:100%;object-fit:cover;display:block;transition:transform 8s ease}
.about-img-frame:hover img{transform:scale(1.04)}
.about-accent-card{position:absolute;bottom:-1.5rem;right:-1.5rem;background:linear-gradient(135deg,var(--orange),#FF6B35);border-radius:var(--rXL);padding:1.25rem 1.75rem;box-shadow:var(--sh-xl);text-align:center}
.about-accent-card .big{font-family:'Staatliches',sans-serif;font-size:3rem;color:#fff;line-height:1;display:block}
.about-accent-card .small{font-family:var(--font);font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.75)}
/* Explicit white text — always visible on teal bg */
.about-content h2{color:#fff !important;text-transform:uppercase;margin-bottom:1.25rem;font-size:clamp(2rem,3.5vw,3rem)}
.about-content p{color:rgba(255,255,255,.82) !important;max-width:420px;margin-bottom:1.25rem}
.about-content .vm-label{color:rgba(255,255,255,.55) !important}
.about-content .vm-box p{color:#fff !important}
.vm-pair{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1.75rem 0}
.vm-box{background:rgba(255,255,255,.12);border-radius:var(--r);padding:1.25rem;border:1px solid rgba(255,255,255,.2);transition:all var(--t)}
.vm-box:hover{background:rgba(255,255,255,.22);transform:translateY(-2px)}
.vm-label{font-family:var(--font);font-size:.6rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:.45rem}
.vm-box p{font-size:.84rem;line-height:1.6;margin:0;color:#fff}

/* ══════════════════════════════════════════════
   PARTNER LOGOS — white cards, full-colour logos
══════════════════════════════════════════════ */
.partners-sec{
  background:linear-gradient(rgba(6,15,32,.86),rgba(6,15,32,.86)),
    url('https://chread.africa/wp-content/uploads/2026/02/4-1024x1024.png') center/cover no-repeat;
  padding:72px 0;position:relative;overflow:hidden}
.partners-sec::before{content:'';position:absolute;inset:0;background-image:var(--PAT2);background-size:300px;background-repeat:repeat;opacity:.09;pointer-events:none}
.partners-head{text-align:center;margin-bottom:3rem;position:relative;z-index:1}
.partners-head p{font-family:var(--font);font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-top:.5rem}
.partner-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;position:relative;z-index:1}

.partner-card{
  background:#fff;
  border-radius:var(--rL);
  padding:2rem 1.5rem;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.85rem;cursor:pointer;min-height:148px;
  border:2px solid transparent;
  transition:all .4s var(--spring);
  position:relative;overflow:hidden;
}
/* Bottom gradient reveal */
.partner-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--orange),var(--pink));transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.partner-card:hover{transform:translateY(-7px);box-shadow:0 20px 50px rgba(0,0,0,.25);border-color:rgba(241,125,1,.25)}
.partner-card:hover::after{transform:scaleX(1)}

/* Full colour logos — NO filter */
.partner-logo-img{
  height:48px;width:auto;max-width:140px;
  object-fit:contain;
  filter:none;
  transition:transform .3s var(--ease);
  display:block;
}
.partner-card:hover .partner-logo-img{transform:scale(1.06)}

.partner-name{font-family:var(--font);font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:center;transition:color var(--t)}
.partner-card:hover .partner-name{color:var(--orange)}
.partner-type{font-family:var(--font);font-size:.56rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#ccc;text-align:center}

/* ══════════════════════════════════════════════
   CoS 2026 — festival poster
══════════════════════════════════════════════ */
.cos-festival{background:linear-gradient(135deg,#FF6B35 0%,var(--orange) 20%,var(--pink) 55%,var(--purple) 80%,#1a0540 100%);background-size:200% 200%;animation:gradShift 8s ease infinite alternate;position:relative;overflow:hidden;min-height:700px;display:flex;align-items:center}
.cos-festival::before{content:'';position:absolute;inset:0;background-image:var(--PAT1);background-size:cover;background-position:center;opacity:.22;mix-blend-mode:overlay;pointer-events:none}
.cos-festival::after{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 65%);top:-200px;right:-150px;pointer-events:none;animation:float 10s ease-in-out infinite}
.cos-fest-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.cos-fest-title{font-family:var(--font);font-weight:900;font-size:clamp(2.5rem,5vw,5rem);line-height:.95;letter-spacing:-.03em;text-transform:uppercase;color:#fff;margin:1.25rem 0 1.5rem}
.cos-fest-title span{display:block;font-style:italic;-webkit-text-fill-color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.75);color:transparent}
.countdown{display:flex;align-items:center;gap:.75rem;margin:2rem 0}
.cd-cell{text-align:center;background:rgba(0,0,0,.25);backdrop-filter:blur(8px);border-radius:var(--r);padding:.85rem 1.25rem;border:1px solid rgba(255,255,255,.2);min-width:72px}
.cd-num{font-family:'Staatliches',sans-serif;font-size:3rem;color:#fff;line-height:1;display:block}
.cd-lbl{font-family:var(--font);font-size:.56rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.cd-sep{font-family:'Staatliches',sans-serif;font-size:3rem;color:rgba(255,255,255,.3);line-height:1}
.cos-fest-dates{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem}
.cos-fd{display:flex;align-items:center;gap:.85rem;padding:.7rem 1rem;background:rgba(0,0,0,.2);border-radius:var(--r);border-left:3px solid rgba(255,255,255,.35);transition:all var(--t)}
.cos-fd:hover{background:rgba(0,0,0,.35);transform:translateX(4px)}
.cos-fdt{background:rgba(255,255,255,.15);backdrop-filter:blur(4px);color:#fff;font-family:var(--font);font-size:.56rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:.32rem .55rem;border-radius:6px;min-width:44px;text-align:center;line-height:1.3;flex-shrink:0}
.cos-fdl{font-family:var(--font);font-size:.84rem;font-weight:600;color:rgba(255,255,255,.85)}
.cos-fest-visual{position:relative}
.cos-fest-img{border-radius:var(--rXL);overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.4);transform:rotate(-2deg) translateY(8px);transition:all .6s var(--spring)}
.cos-fest-img:hover{transform:rotate(0) translateY(0) scale(1.02)}
.cos-fest-img img{width:100%;display:block}
.cos-fest-badge{position:absolute;top:2rem;right:-1.5rem;background:var(--orange);color:#fff;border-radius:var(--rXL);padding:1.25rem 1.5rem;box-shadow:var(--sh-xl);text-align:center;font-family:var(--font)}
.cfb-n{font-size:2.5rem;font-weight:900;display:block;line-height:1}
.cfb-l{font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.8}

/* ══════════════════════════════════════════════
   THEMES
══════════════════════════════════════════════ */
.themes-sec{
  background:linear-gradient(rgba(11,45,92,.83),rgba(11,45,92,.83)),
    url('https://chread.africa/wp-content/uploads/2026/02/1-1.png') center/cover no-repeat;
  position:relative;overflow:hidden}
.themes-head{text-align:center;margin-bottom:3.5rem}
.themes-head h2{text-transform:uppercase;font-size:clamp(2rem,4vw,3rem);color:#fff}
.themes-head p{color:rgba(255,255,255,.72);max-width:480px;margin:.75rem auto 0}
.theme-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.t-card{border-radius:var(--rXL);padding:2.25rem 1.75rem;position:relative;overflow:hidden;cursor:default;min-height:300px;display:flex;flex-direction:column;transition:transform .45s var(--spring),box-shadow .45s var(--ease);transform-style:preserve-3d}
.tc-1{background:linear-gradient(145deg,#8B1A1A,#C0392B,#E74C3C)}
.tc-2{background:linear-gradient(145deg,#4A2A7A,#7C3AED,#9D69F5)}
.tc-3{background:linear-gradient(145deg,#9B5700,var(--orange),#FFB347)}
.tc-4{background:linear-gradient(145deg,#0B2D5C,#1a4a8a,#2980b9)}
.t-card::before{content:'';position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(120deg,transparent 20%,rgba(255,255,255,.14) 50%,transparent 80%);transform:skewX(-20deg);transition:left .7s ease;pointer-events:none;z-index:1}
.t-card:hover::before{left:150%}
.t-pat{position:absolute;inset:0;background-image:var(--PAT2);background-size:70%;background-position:bottom right;background-repeat:no-repeat;opacity:.08;pointer-events:none}
.t-num{font-family:'Staatliches',sans-serif;font-size:6rem;color:rgba(255,255,255,.1);line-height:.85;position:absolute !important;bottom:.25rem;right:1rem;z-index:0;pointer-events:none;transition:all .5s}
.t-card:hover .t-num{color:rgba(255,255,255,.2)}
.t-icon{width:56px;height:56px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.5rem;transition:all .45s var(--spring);background:rgba(255,255,255,.18);color:#fff;position:relative;z-index:1}
.t-card:hover{box-shadow:var(--sh-xl)}
.t-card:hover .t-icon{background:rgba(255,255,255,.3);transform:scale(1.12) rotate(-5deg)}
.tc-1:hover{box-shadow:0 20px 60px rgba(231,76,60,.35),var(--sh-xl)}
.tc-2:hover{box-shadow:0 20px 60px rgba(157,105,245,.35),var(--sh-xl)}
.tc-3:hover{box-shadow:0 20px 60px rgba(241,125,1,.35),var(--sh-xl)}
.tc-4:hover{box-shadow:0 20px 60px rgba(41,128,185,.35),var(--sh-xl)}
.t-card h3{color:#fff;font-size:.9rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;line-height:1.3;margin-bottom:.75rem;position:relative;z-index:1}
.t-card p{color:rgba(255,255,255,.65);font-size:.82rem;line-height:1.6;margin:0;max-height:0;overflow:hidden;transition:max-height .55s var(--ease),opacity .4s;opacity:0;position:relative;z-index:1}
.t-card:hover p{max-height:180px;opacity:1}

/* ══════════════════════════════════════════════
   ZONES — orange, interactive tabs
══════════════════════════════════════════════ */
.zones-sec{background:linear-gradient(135deg,var(--orange) 0%,#FF6B35 40%,#E55A0F 100%);position:relative;overflow:hidden}
.zones-sec::before{content:'';position:absolute;inset:0;background-image:var(--PAT1);background-size:cover;opacity:.22;mix-blend-mode:overlay;pointer-events:none}
.zone-tabs{display:flex;gap:.5rem;margin-bottom:2.5rem;flex-wrap:wrap;position:relative;z-index:1}
.zone-tab{font-family:var(--font);font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.65rem 1.35rem;border-radius:var(--rF);border:2px solid rgba(255,255,255,.35);color:rgba(255,255,255,.7);cursor:pointer;transition:all .3s var(--ease);background:transparent}
.zone-tab:hover{border-color:rgba(255,255,255,.7);color:#fff;background:rgba(255,255,255,.1)}
.zone-tab.active{background:#fff;color:var(--orange);border-color:#fff;box-shadow:var(--sh)}
.zone-panels{position:relative;z-index:1}
.zone-panel{display:none;gap:2rem;align-items:center}
.zone-panel.active{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:2rem;animation:slideUp .4s var(--ease) both}
.zp-icon{width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.2);border:3px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;font-size:3rem;color:#fff;flex-shrink:0;margin:0 auto;box-shadow:0 8px 32px rgba(0,0,0,.2)}
.zp-content h3{color:#fff;font-size:1.3rem;font-weight:800;text-transform:uppercase;margin-bottom:.75rem}
.zp-content p{color:rgba(255,255,255,.8);font-size:.96rem;line-height:1.7;margin-bottom:1.5rem}
.zp-img{border-radius:var(--rXL);overflow:hidden;height:260px;position:relative}
.zp-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--ease)}
.zp-img:hover img{transform:scale(1.05)}
.zp-img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(241,125,1,.25) 0%,transparent 60%);pointer-events:none}

/* ══════════════════════════════════════════════
   TIMELINE
══════════════════════════════════════════════ */
.timeline-sec{
  background:linear-gradient(rgba(27,101,48,.85),rgba(27,101,48,.85)),
    url('https://chread.africa/wp-content/uploads/2025/12/1-1-1024x1024.png') center/cover no-repeat;
  position:relative;overflow:hidden}
.timeline-sec::before{content:'';position:absolute;inset:0;background-image:var(--PAT2);background-size:300px;background-repeat:repeat;opacity:.09;pointer-events:none}
.tl-head h2{color:#fff;text-transform:uppercase;margin-bottom:.5rem}
.tl-head p{color:rgba(255,255,255,.75);max-width:500px}
.timeline{position:relative;margin-top:3.5rem;padding-bottom:1rem}
.timeline::before{content:'';position:absolute;left:0;right:0;top:24px;height:3px;background:rgba(255,255,255,.2);z-index:0}
.tl-items{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;z-index:2}
.tl-item{display:flex;flex-direction:column;align-items:center;padding:0 .5rem;cursor:default;transition:all var(--t)}
.tl-item:hover .tl-dot{transform:scale(1.3);box-shadow:0 0 0 8px rgba(255,255,255,.15),0 0 0 16px rgba(255,255,255,.07)}
.tl-item:hover .tl-content{transform:translateY(-4px)}
.tl-dot{width:48px;height:48px;border-radius:50%;border:4px solid #fff;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;transition:all .4s var(--spring);flex-shrink:0;position:relative;z-index:2;box-shadow:0 4px 16px rgba(0,0,0,.2)}
.tl-dot i{font-size:1.1rem;color:#fff}
.tld-1{background:var(--orange)}.tld-2{background:var(--teal)}.tld-3{background:var(--blue)}.tld-4{background:var(--purple)}.tld-5{background:var(--pink)}
.tl-content{text-align:center;transition:transform .35s var(--ease)}
.tl-date{font-family:var(--font);font-size:.56rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.72);margin-bottom:.4rem;white-space:nowrap}
.tl-item h3{color:#fff;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.35rem;line-height:1.25}
.tl-item p{color:rgba(255,255,255,.78);font-size:.72rem;line-height:1.5;max-height:0;overflow:hidden;transition:max-height .4s,opacity .4s;opacity:0}
.tl-item:hover p{max-height:100px;opacity:1}
.tl-cta{text-align:center;margin-top:2.5rem;position:relative;z-index:1}

/* ══════════════════════════════════════════════
   AGENDA
══════════════════════════════════════════════ */
.agenda-sec{background:linear-gradient(160deg,var(--teal-lt) 0%,#D4EEF2 100%);position:relative;overflow:hidden}
.agenda-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:6rem;align-items:center}
.agenda-l .disp-sm em{font-style:italic;color:var(--orange)}
.agenda-l p{max-width:380px;margin:.85rem 0 2rem}
.a-item{display:flex;align-items:flex-start;gap:1.5rem;padding:1.25rem;margin-bottom:.75rem;border-radius:var(--rL);border:1.5px solid rgba(41,105,117,.15);background:#fff;transition:all .35s var(--spring);position:relative;cursor:default;overflow:hidden}
.a-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--orange);transform:scaleY(0);transform-origin:bottom;transition:transform .35s var(--ease)}
.a-item:last-child{margin-bottom:0}
.a-item:hover{border-color:transparent;box-shadow:var(--sh-md);transform:translateX(6px)}
.a-item:hover::before{transform:scaleY(1)}
.a-num{font-family:'Staatliches',sans-serif;font-size:3rem;color:rgba(41,105,117,.2);line-height:.85;flex-shrink:0;width:2.5rem;text-align:center;transition:color .35s}
.a-item:hover .a-num{color:var(--orange)}
.a-body h4{font-family:var(--font);font-weight:800;font-size:.88rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text);margin-bottom:.3rem;transition:color var(--t)}
.a-body p{font-size:.8rem;line-height:1.55;margin:0}
.a-item:hover .a-body h4{color:var(--teal)}

/* ══════════════════════════════════════════════
   TEAM — org logo grid (rounded squares)
══════════════════════════════════════════════ */
.team-sec{
  background:linear-gradient(rgba(11,45,92,.88),rgba(6,15,32,.92)),
    url('https://chread.africa/wp-content/uploads/2026/02/3-1024x1024.png') center/cover no-repeat;
  position:relative;overflow:hidden}
.team-sec::before{content:'';position:absolute;inset:0;background-image:var(--PAT2);background-size:300px;background-repeat:repeat;opacity:.09;pointer-events:none}
.team-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:3rem;position:relative;z-index:1}
.team-head h2{text-transform:uppercase;color:#fff}
.team-head p{color:rgba(255,255,255,.45);max-width:280px;font-size:.88rem}

/* Logo grid — rounded squares, white bg, contain logos */
.team-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(110px,1fr));
  gap:1rem;
  position:relative;z-index:1;
}
.t-photo{
  border-radius:var(--rL);
  overflow:hidden;
  aspect-ratio:1;
  background:#fff;
  border:2px solid rgba(255,255,255,.15);
  transition:all .4s var(--spring);
  cursor:pointer;
  position:relative;
  display:flex;align-items:center;justify-content:center;
  padding:.5rem;
}
.t-photo::after{content:'';position:absolute;inset:-2px;border-radius:var(--rL);border:2px solid transparent;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,var(--orange),var(--pink)) border-box;opacity:0;transition:opacity .35s var(--ease)}
.t-photo:hover{transform:scale(1.08) translateY(-4px);border-color:transparent;box-shadow:0 12px 32px rgba(241,125,1,.3)}
.t-photo:hover::after{opacity:1}
/* Full logo visible — contain, no crop */
.t-photo img{
  width:100%;height:100%;
  object-fit:contain;
  display:block;
  transition:transform .4s var(--ease);
}
.t-photo:hover img{transform:scale(1.05)}

/* ══════════════════════════════════════════════
   BLOGS — magazine editorial layout
══════════════════════════════════════════════ */
.blogs-sec{background:var(--cream);position:relative;overflow:hidden}
.blogs-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:3rem;flex-wrap:wrap;gap:1rem}
.blogs-head h2{text-transform:uppercase}

/* Magazine layout: 1 featured + 2 columns */
.blog-magazine{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.blog-featured{grid-column:1;grid-row:1/3}

/* Each blog card — full image overlay */
.b-card{
  border-radius:var(--rXL);overflow:hidden;
  position:relative;cursor:pointer;
  transition:transform .5s var(--spring),box-shadow .5s var(--ease);
}
.b-card:hover{transform:translateY(-8px) scale(1.015);box-shadow:var(--sh-lg)}

.b-card-inner{position:relative;height:100%}
.b-card-img-wrap{overflow:hidden;position:relative}
.b-card img{width:100%;object-fit:cover;transition:transform .8s var(--ease);display:block}
.b-card:hover img{transform:scale(1.06)}

/* Full overlay gradient */
.b-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(6,15,32,.9) 0%,rgba(6,15,32,.4) 50%,transparent 100%);
  transition:background .4s var(--ease);
}
.b-card:hover .b-overlay{background:linear-gradient(to top,rgba(6,15,32,.95) 0%,rgba(6,15,32,.55) 55%,rgba(6,15,32,.1) 100%)}

/* Content sits on top of the overlay */
.b-content{
  position:absolute;bottom:0;left:0;right:0;
  padding:2rem;
}

.b-cat{font-family:var(--font);font-size:.56rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:.25rem .7rem;border-radius:var(--rF);display:inline-block;margin-bottom:.75rem;align-self:flex-start}
.b-cat-orange{background:var(--orange);color:#fff}
.b-cat-teal{background:var(--teal);color:#fff}
.b-cat-navy{background:var(--navy);color:#fff}
.b-cat-green{background:var(--green);color:#fff}
.b-cat-pink{background:var(--pink);color:#fff}

.b-card h3{font-size:.96rem;color:#fff;line-height:1.35;text-transform:uppercase;letter-spacing:.02em;margin-bottom:.85rem;font-family:var(--font);font-weight:800}
.blog-featured h3{font-size:1.35rem}

.b-link{font-family:var(--font);font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;gap:.3rem;transition:gap var(--t)}
.b-link i{transition:transform .3s}
.b-link:hover{gap:.65rem}.b-link:hover i{transform:translateX(4px)}

/* Featured card tall image */
.blog-featured .b-card-img-wrap{height:100%;min-height:480px}
.blog-featured img{height:100%;width:100%}

/* Smaller cards */
.b-card-sm .b-card-img-wrap{height:220px}
.b-card-sm img{height:100%;width:100%}

/* ══════════════════════════════════════════════
   CTA BAND — animated gradient
══════════════════════════════════════════════ */
.cta-band{position:relative;overflow:hidden;min-height:440px;display:flex;align-items:center;background:linear-gradient(135deg,var(--navy-d) 0%,var(--navy) 30%,var(--purple) 60%,var(--pink) 100%)}
.cta-band-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--navy-d) 0%,var(--navy) 30%,var(--purple) 60%,var(--pink) 100%);background-size:200% 200%;animation:gradShift 6s ease infinite alternate}
.cta-band-pat{position:absolute;inset:0;background-image:var(--PAT1);background-size:cover;background-position:center;opacity:.22;mix-blend-mode:overlay}
.cta-band-body{position:relative;z-index:1;text-align:center;width:100%}
.cta-band-body h2{color:#fff;font-size:clamp(2.2rem,5vw,4rem);text-transform:uppercase;margin-bottom:1.25rem}
.cta-band-body h2 em{font-style:italic;background:linear-gradient(135deg,var(--orange),#FFD580);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cta-band-body p{color:rgba(255,255,255,.68);max-width:460px;margin:0 auto 2.5rem}

/* ══════════════════════════════════════════════
   NEWSLETTER
══════════════════════════════════════════════ */
.nl-sec{
  background:linear-gradient(rgba(41,105,117,.88),rgba(27,101,48,.88)),
    url('https://chread.africa/wp-content/uploads/2026/01/Landscape-Banners-1-2048x1024.png') center/cover no-repeat;
  position:relative;overflow:hidden}
.nl-sec::before{content:'';position:absolute;inset:0;background-image:var(--PAT2);background-size:300px;background-repeat:repeat;opacity:.09;pointer-events:none}
.nl-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;position:relative;z-index:1}
.nl-inner h2{text-transform:uppercase;margin-bottom:.75rem;color:#fff}
.nl-inner p{color:rgba(255,255,255,.65);max-width:380px}
.nl-row{display:flex;border-radius:var(--rF);overflow:hidden;box-shadow:var(--sh-xl);border:3px solid rgba(255,255,255,.2)}
.nl-input{flex:1;padding:.92rem 1.5rem;border:none;font-family:var(--body);font-size:.9rem;outline:none;color:var(--text);background:#fff}
.nl-sub{background:var(--orange);color:#fff;border:none;padding:.92rem 1.75rem;font-family:var(--font);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background var(--t);white-space:nowrap;display:flex;align-items:center;gap:.4rem}
.nl-sub:hover{background:var(--orange-d)}
.nl-note{font-size:.7rem;color:rgba(255,255,255,.45);margin-top:.75rem;display:flex;align-items:center;gap:.35rem}

/* ══════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════ */
.ftr{background:var(--navy-d);position:relative;overflow:hidden}
.ftr::before{content:'';position:absolute;inset:0;background-image:var(--PAT2);background-size:18%;background-position:right bottom;background-repeat:no-repeat;opacity:.16;pointer-events:none}
.ftr-main{padding:4.5rem 0 3rem;position:relative;z-index:1}
.ftr-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3.5rem}
.ftr-logo img{height:38px;filter:brightness(0) invert(1);margin-bottom:1.25rem;display:block}
.ftr-desc{font-size:.82rem;color:rgba(255,255,255,.72);line-height:1.7;max-width:260px;margin-bottom:1.5rem}
.ftr-social{display:flex;gap:.5rem}
.ftr-soc{width:34px;height:34px;border-radius:8px;border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;font-size:.88rem;transition:all .35s var(--spring)}
.ftr-soc:hover{transform:translateY(-4px) scale(1.1)}
.ftr-soc:nth-child(1):hover{background:var(--orange);border-color:var(--orange);color:#fff;box-shadow:0 6px 20px rgba(241,125,1,.35)}
.ftr-soc:nth-child(2):hover{background:#0A66C2;border-color:#0A66C2;color:#fff}
.ftr-soc:nth-child(3):hover{background:#1877F2;border-color:#1877F2;color:#fff}
.ftr-col h5{font-family:var(--font);font-size:.62rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);margin-bottom:1.25rem}
.ftr-links{display:flex;flex-direction:column;gap:.55rem}
.ftr-links a{font-size:.8rem;color:rgba(255,255,255,.72);transition:all .3s var(--ease)}
.ftr-links a::before{content:'›';opacity:0;transform:translateX(-4px);transition:all .25s;margin-right:.3rem;display:inline-block}
.ftr-links a:hover{color:rgba(255,255,255,.85);padding-left:.4rem}
.ftr-links a:hover::before{opacity:1;transform:none}
.ftr-ctas{display:flex;flex-direction:column;gap:.75rem;margin-top:.25rem}
.ftr-ctas .btn{justify-content:center}
.ftr-bottom{border-top:1px solid rgba(255,255,255,.07);padding:1.5rem 0;position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.ftr-bottom p{font-size:.75rem;color:rgba(255,255,255,.55);margin:0}
.ftr-social-sm{display:flex;gap:.75rem}
.ftr-social-sm a{color:rgba(255,255,255,.6);font-size:.95rem;transition:color var(--t)}
.ftr-social-sm a:hover{color:rgba(255,255,255,.7)}

/* ══════════════════════════════════════════════
   PAGE HEROES (inner pages)
══════════════════════════════════════════════ */
.pg-hero{padding:calc(66px + 4rem) 0 4rem;position:relative;overflow:hidden}
.pg-teal{background:linear-gradient(135deg,var(--teal) 0%,#1D9E90 100%)}
.pg-navy{background:linear-gradient(135deg,var(--navy) 0%,#1a3e72 100%)}
.pg-orange{background:linear-gradient(135deg,var(--orange) 0%,#FF6B35 60%,var(--pink) 100%)}
.pg-green{background:linear-gradient(135deg,var(--green) 0%,#1D9E50 100%)}
.pg-grey{background:var(--off);border-bottom:1px solid var(--border)}
.pg-cream{background:var(--cream);border-bottom:1px solid var(--border)}
.pg-hero .pat-bg{position:absolute;inset:0;background-image:var(--PAT1);background-size:280px;background-repeat:repeat;opacity:.22;pointer-events:none}
.pg-grey .pat-bg,.pg-cream .pat-bg{opacity:.08}
.pg-hero-inner{position:relative;z-index:1}
.pg-crumb{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:.74rem}
.pg-crumb a{color:rgba(255,255,255,.5);transition:color var(--t)}.pg-crumb a:hover{color:rgba(255,255,255,.9)}
.pg-crumb span:last-child{color:rgba(255,255,255,.8)}.pg-crumb .sep{color:rgba(255,255,255,.25)}
.pg-grey .pg-crumb a,.pg-cream .pg-crumb a{color:var(--muted)}.pg-grey .pg-crumb a:hover,.pg-cream .pg-crumb a:hover{color:var(--orange)}
.pg-grey .pg-crumb span:last-child,.pg-cream .pg-crumb span:last-child{color:var(--text)}.pg-grey .pg-crumb .sep,.pg-cream .pg-crumb .sep{color:var(--border)}
.pg-hero h1{color:#fff;text-transform:uppercase;margin-bottom:1rem;font-size:clamp(2.5rem,5vw,4rem)}
.pg-grey h1,.pg-cream h1{color:var(--text)}
.pg-hero .lead{color:rgba(255,255,255,.68);max-width:600px;font-size:1rem;line-height:1.75}
.pg-grey .lead,.pg-cream .lead{color:var(--muted)}

/* ── FEAT CARDS — bold, creative, colourful ────────────── */
/* Each card = full-colour gradient, big icon, hover reveals text */
.feat-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
}

.feat-card{
  border-radius:var(--rXL);
  padding:2.25rem 2rem;
  min-height:300px;
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  cursor:default;
  transition:transform .45s var(--spring),box-shadow .45s var(--ease);
  transform-style:preserve-3d;
}
.feat-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:var(--sh-xl)}

/* Per-card gradients */
.fc-1{background:linear-gradient(155deg,#F17D01 0%,#E55A0F 60%,#C04A05 100%)}
.fc-2{background:linear-gradient(155deg,#296975 0%,#1D8A94 55%,#145563 100%)}
.fc-3{background:linear-gradient(155deg,#0B2D5C 0%,#1a4a8a 55%,#0A2447 100%)}
.fc-4{background:linear-gradient(155deg,#279545 0%,#1D9E60 55%,#1A7A35 100%)}
.fc-5{background:linear-gradient(155deg,#7C3AED 0%,#9D69F5 55%,#5B21B6 100%)}
.fc-6{background:linear-gradient(155deg,#E61F93 0%,#F559B0 55%,#C01680 100%)}

/* Shimmer sweep on hover */
.feat-card::before{
  content:'';position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent 25%,rgba(255,255,255,.14) 50%,transparent 75%);
  transform:skewX(-18deg);transition:left .7s ease;pointer-events:none;z-index:1;
}
.feat-card:hover::before{left:150%}

/* CHReaD pattern as subtle texture */
.feat-card-pat{
  position:absolute;inset:0;
  background-image:var(--PAT2);
  background-size:55%;background-position:bottom right;background-repeat:no-repeat;
  opacity:.09;pointer-events:none;z-index:0;transition:opacity .4s;
}
.feat-card:hover .feat-card-pat{opacity:.16}

/* Big background number */
.feat-card-num{
  position:absolute;top:.75rem;right:1.25rem;
  font-family:'Staatliches',sans-serif;font-size:6.5rem;
  color:rgba(255,255,255,.1);line-height:.85;
  z-index:0;pointer-events:none;transition:all .5s;letter-spacing:-.05em;
}
.feat-card:hover .feat-card-num{color:rgba(255,255,255,.22);transform:scale(1.08)}

/* Icon — rounded square, top-left */
.feat-card-icon{
  width:64px;height:64px;
  border-radius:18px;
  background:rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;
  font-size:1.7rem;color:#fff;
  margin-bottom:auto;padding-top:.5rem;
  position:relative;z-index:1;
  transition:all .45s var(--spring);
  box-shadow:0 4px 16px rgba(0,0,0,.15);
}
.feat-card:hover .feat-card-icon{
  background:rgba(255,255,255,.3);
  transform:scale(1.1) rotate(-8deg);
  box-shadow:0 8px 28px rgba(0,0,0,.25);
}

/* Bottom text area */
.feat-card-body{
  position:relative;z-index:1;
  padding-top:1.5rem;
  border-top:1px solid rgba(255,255,255,.15);
  margin-top:2rem;
}
.feat-card h3{
  color:#fff;
  font-size:.92rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.05em;
  margin-bottom:.65rem;line-height:1.3;
}
.feat-card p{
  color:rgba(255,255,255,.72);
  font-size:.8rem;line-height:1.6;margin:0;
  max-height:0;overflow:hidden;
  transition:max-height .5s var(--ease),opacity .4s;
  opacity:0;
}
.feat-card:hover p{max-height:120px;opacity:1}

/* Glow shadow per card */
.fc-1:hover{box-shadow:0 24px 70px rgba(241,125,1,.4),var(--sh-xl)}
.fc-2:hover{box-shadow:0 24px 70px rgba(41,105,117,.4),var(--sh-xl)}
.fc-3:hover{box-shadow:0 24px 70px rgba(11,45,92,.4),var(--sh-xl)}
.fc-4:hover{box-shadow:0 24px 70px rgba(39,149,69,.4),var(--sh-xl)}
.fc-5:hover{box-shadow:0 24px 70px rgba(124,58,237,.4),var(--sh-xl)}
.fc-6:hover{box-shadow:0 24px 70px rgba(230,31,147,.4),var(--sh-xl)}

/* ── INNER PAGE COMPONENTS ────────────────── */
.ic-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem}
.ic-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.ic-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.75rem}

.wcard{background:#fff;border-radius:var(--rXL);padding:2.25rem;box-shadow:0 2px 12px rgba(0,0,0,.07);border:1.5px solid var(--border);transition:all .4s var(--spring)}
.wcard:hover{box-shadow:var(--sh-lg);transform:translateY(-5px) scale(1.01);border-color:transparent}

.res-item{display:flex;align-items:center;gap:1.25rem;background:#fff;border-radius:var(--r);padding:1.25rem 1.5rem;box-shadow:0 2px 10px rgba(0,0,0,.06);border-left:4px solid var(--border);text-decoration:none;color:inherit;transition:all .35s var(--spring);position:relative;overflow:hidden}
.res-item:hover{border-left-color:var(--orange);box-shadow:var(--sh-md);transform:translateX(8px) scale(1.01)}
.res-icon{width:44px;height:44px;border-radius:var(--r);flex-shrink:0;background:var(--orange-lt);color:var(--orange);display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all .3s var(--ease)}
.res-item:hover .res-icon{background:var(--orange);color:#fff;transform:scale(1.08) rotate(-5deg)}
.res-body{flex:1}.res-body h4{font-family:var(--font);font-size:.88rem;font-weight:700;color:var(--text);margin-bottom:.15rem}
.res-body p{font-size:.78rem;margin:0;line-height:1.4}
.res-dl{color:var(--border);font-size:.95rem;flex-shrink:0;transition:all .3s}
.res-item:hover .res-dl{color:var(--orange);transform:translateY(-2px)}

.form-col{display:flex;flex-direction:column;gap:1.1rem}
.form-2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field label{display:block;font-family:var(--font);font-size:.66rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text);margin-bottom:.4rem}
.field input,.field select,.field textarea{width:100%;padding:.85rem 1.1rem;border:1.5px solid var(--border);border-radius:var(--r);font-family:var(--body);font-size:.9rem;color:var(--text);outline:none;background:#fff;transition:border-color .3s,box-shadow .3s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(241,125,1,.08)}
.field textarea{resize:vertical;min-height:120px}

/* REVEAL */
.rv{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* 3D tilt */
.tilt-card{will-change:transform;transform-style:preserve-3d}

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
@media(max-width:1100px){
  .hero{grid-template-columns:1fr;grid-template-rows:auto 180px}.hero-b{display:none}.hero-a{padding:5rem 0}
  .hero-a::before,.hero-a::after{display:none}
  .about-inner{grid-template-columns:1fr}.about-img-col{display:none}
  .cos-fest-inner{grid-template-columns:1fr}.cos-fest-visual{display:none}
  .theme-grid{grid-template-columns:1fr 1fr}.zone-panel.active{grid-template-columns:1fr}
  .tl-items{grid-template-columns:1fr;gap:2rem}
  .timeline::before,.timeline::after{display:none}
  .agenda-inner{grid-template-columns:1fr;gap:3rem}
  .ftr-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
  .nl-inner{grid-template-columns:1fr;gap:3rem}
  .flanked .pat-l,.flanked .pat-r{width:100px}
  .partner-grid{grid-template-columns:repeat(4,1fr)}
  .hero-stats-row{grid-template-columns:repeat(4,1fr)}
  .blog-magazine{grid-template-columns:1fr}
  .blog-featured{grid-column:auto;grid-row:auto}
  .blog-featured .b-card-img-wrap{height:300px}
  .work-grid{grid-template-columns:1fr 1fr}
}

@media(max-width:991px){
  .hdr-toggle{display:flex}
  .hdr-nav{position:fixed;top:66px;left:0;right:0;bottom:0;background:#fff;padding:1.5rem;overflow-y:auto;transform:translateX(-100%);transition:transform var(--t);z-index:999;display:flex;flex-direction:column;margin-left:0}
  .hdr-nav.open{transform:none}
  .hdr-nav>ul{flex-direction:column;width:100%}
  .hdr-nav>ul>li>a{height:auto;padding:.9rem 0;border-bottom:1px solid var(--border);font-size:.86rem;color:var(--text) !important}
  .hdr-nav>ul>li>a.active{color:var(--orange) !important}
  .hdr-nav>ul>li>a.active::after{display:none}
  .hdr-nav .dd .dd-menu{position:static;box-shadow:none;border:none;border-radius:var(--r);background:var(--off);display:none;margin:.4rem 0}
  .hdr-nav .dd .dd-menu::before{display:none}
  .hdr-nav .dd.open .dd-menu{display:block}.hdr-nav .dd:hover .dd-menu{display:none}
  .hdr-cta{display:none}
  .theme-grid,.ic-grid-3,.ic-grid-4,.work-grid{grid-template-columns:1fr}
  .ic-grid-2,.form-2{grid-template-columns:1fr}
  .partner-grid{grid-template-columns:1fr 1fr;gap:1rem}
  .hero-stats-row{grid-template-columns:1fr 1fr}
  .hstat{border-right:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12)}
  .hstat:nth-child(2n){border-right:none}
  .hstat:nth-child(3),.hstat:nth-child(4){border-bottom:none}
  .ftr-grid{grid-template-columns:1fr}
  .ftr-bottom{flex-direction:column;text-align:center}
  .flanked .pat-l,.flanked .pat-r{display:none}
  .nl-row{flex-direction:column;border-radius:var(--r)}
  .nl-input,.nl-sub{border-radius:var(--r)}
  .hero-acts{flex-direction:column}.btn{justify-content:center}
  .t-card p{max-height:180px;opacity:1}
  .zone-tabs{justify-content:center}
  .vm-pair{grid-template-columns:1fr}
  .countdown{justify-content:center}
  .team-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem}
}

@media(max-width:480px){
  .hero-stats-row{grid-template-columns:1fr 1fr}
  .partner-grid{grid-template-columns:1fr 1fr}
  .tl-items{gap:1.5rem}
  .team-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}
}


/* ══════════════════════════════════════════════
   NEW HEADER v2 — Cultural split brand panel
   Left: CHReaD pattern + navy + white logo
   Right: Clean white + nav + CTA
══════════════════════════════════════════════ */
.hdr {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000;
  height: 66px;
  display: flex;
  align-items: stretch;
  background: #fff;
  box-shadow: 0 1px 0 var(--border);
  transition: box-shadow .3s var(--ease);
}
.hdr.scrolled { box-shadow: 0 3px 24px rgba(0,0,0,.10); }

/* LEFT: Pattern brand band */
.hdr-left-band {
  width: 220px;
  flex-shrink: 0;
  background: var(--navy-d);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 0 1.5rem;
  text-decoration: none;
  cursor: pointer;
}
/* Orange pattern overlaid on navy */
.hdr-left-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--PAT1);
  background-size: cover;
  background-position: center;
  opacity: .28;
  mix-blend-mode: screen;
  pointer-events: none;
}
/* Orange accent right edge */
.hdr-left-band::after {
  content: "";
  position: absolute;
  right: 0; top: 8px; bottom: 8px;
  width: 3px;
  background: linear-gradient(to bottom, transparent, var(--orange), transparent);
  border-radius: 2px;
}
.hdr-left-band img {
  height: 34px;
  filter: brightness(0) invert(1);
  position: relative;
  z-index: 1;
  transition: opacity .2s;
  display: block;
}
.hdr-left-band:hover img { opacity: .78; }

/* RIGHT: Nav + CTA */
.hdr-right {
  flex: 1;
  display: flex;
  align-items: center;
  padding: 0 1.75rem;
  gap: 0;
  background: #fff;
  overflow: hidden;
}
.hdr-right .hdr-nav {
  margin-left: auto;
  display: flex;
  align-items: center;
}
.hdr-right .hdr-nav > ul {
  display: flex;
  align-items: center;
}
.hdr-right .hdr-nav > ul > li { position: relative; }
.hdr-right .hdr-nav > ul > li > a {
  font-family: var(--font);
  font-size: .67rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 0 .78rem;
  height: 66px;
  display: flex;
  align-items: center;
  gap: 3px;
  transition: color var(--t);
  position: relative;
}
.hdr-right .hdr-nav > ul > li > a:hover { color: var(--navy); }
.hdr-right .hdr-nav > ul > li > a.active { color: var(--orange); }
.hdr-right .hdr-nav > ul > li > a.active::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: .78rem;
  right: .78rem;
  height: 2px;
  background: var(--orange);
  border-radius: 2px 2px 0 0;
}
/* Dropdown */
.hdr-right .hdr-nav .dd > a::after {
  content: "\F282";
  font-family: "Bootstrap Icons";
  font-size: .55rem;
  margin-left: 2px;
  opacity: .5;
}
.hdr-right .hdr-nav .dd > a.active::after {
  content: "\F282" !important;
  height: auto !important;
  background: none !important;
  bottom: auto !important;
  position: relative !important;
  left: auto !important;
  right: auto !important;
}
.hdr-right .hdr-nav .dd .dd-menu {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  min-width: 200px;
  background: #fff;
  border-radius: var(--rL);
  box-shadow: var(--sh-lg), 0 0 0 1px rgba(0,0,0,.04);
  overflow: hidden;
  z-index: 200;
}
.hdr-right .hdr-nav .dd:hover .dd-menu { display: block; }
.hdr-right .hdr-nav .dd .dd-menu::before {
  content: "";
  display: block;
  height: 2px;
  background: linear-gradient(90deg, var(--orange), var(--pink));
}
.hdr-right .hdr-nav .dd .dd-menu li a {
  display: block;
  font-family: var(--font);
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--muted);
  padding: .75rem 1.15rem;
  border-bottom: 1px solid var(--border);
  transition: all var(--t);
}
.hdr-right .hdr-nav .dd .dd-menu li a:hover {
  color: var(--orange);
  background: var(--orange-lt);
  padding-left: 1.4rem;
}
.hdr-right .hdr-nav .dd .dd-menu li:last-child a { border-bottom: none; }
.hdr-cta { flex-shrink: 0; margin-left: .85rem; }

/* Mobile toggle */
.hdr-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 38px; height: 38px;
  gap: 5px;
  border-radius: var(--r);
  border: 1.5px solid var(--border);
  background: transparent;
  transition: border-color var(--t);
  margin-left: .5rem;
  cursor: pointer;
  flex-shrink: 0;
}
.hdr-toggle:hover { border-color: var(--orange); }
.hdr-toggle span {
  display: block;
  width: 20px; height: 2px;
  background: var(--navy);
  border-radius: 2px;
  transition: all var(--t);
}
.hdr-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hdr-toggle.open span:nth-child(2) { opacity: 0; }
.hdr-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile full-screen nav overlay */
@media(max-width: 768px) {
  .hdr-left-band { width: 160px; }
  .hdr-toggle { display: flex; }
  .hdr-cta { display: none; }
  .hdr-right .hdr-nav {
    position: fixed;
    top: 66px; left: 0; right: 0; bottom: 0;
    background: #fff;
    flex-direction: column;
    align-items: stretch;
    padding: 1.5rem;
    overflow-y: auto;
    transform: translateX(-100%);
    transition: transform var(--t);
    z-index: 999;
    margin-left: 0;
  }
  .hdr-right .hdr-nav.open { transform: none; }
  .hdr-right .hdr-nav > ul { flex-direction: column; width: 100%; }
  .hdr-right .hdr-nav > ul > li > a {
    height: auto;
    padding: .9rem 0;
    border-bottom: 1px solid var(--border);
    font-size: .88rem;
    color: var(--text);
  }
  .hdr-right .hdr-nav > ul > li > a.active { color: var(--orange); }
  .hdr-right .hdr-nav > ul > li > a.active::after { display: none; }
  .hdr-right .hdr-nav .dd .dd-menu {
    position: static;
    box-shadow: none;
    border: none;
    border-radius: var(--r);
    background: var(--off);
    display: none;
    margin: .4rem 0;
  }
  .hdr-right .hdr-nav .dd .dd-menu::before { display: none; }
  .hdr-right .hdr-nav .dd.open .dd-menu { display: block; }
  .hdr-right .hdr-nav .dd:hover .dd-menu { display: none; }
}

/* ══════════════════════════════════════════════
   NEW FOOTER v2 — Visual, Cultural, Photo-rich
══════════════════════════════════════════════ */

/* ── PHOTO GALLERY STRIP (auto-scroll) ──── */
.ftr-photos {
  height: 200px;
  overflow: hidden;
  background: var(--navy-d);
  position: relative;
}
.ftr-photos::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 120px;
  background: linear-gradient(to right, var(--navy-d), transparent);
  z-index: 2; pointer-events: none;
}
.ftr-photos::after {
  content: "";
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 120px;
  background: linear-gradient(to left, var(--navy-d), transparent);
  z-index: 2; pointer-events: none;
}
.ftr-photo-track {
  display: flex;
  height: 100%;
  width: max-content;
  animation: ftrScroll 50s linear infinite;
}
.ftr-photo-track:hover { animation-play-state: paused; }
@keyframes ftrScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.ftr-photo-item {
  width: 240px;
  height: 100%;
  flex-shrink: 0;
  overflow: hidden;
  position: relative;
  border-right: 2px solid var(--navy-d);
}
.ftr-photo-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .72;
  transition: opacity .4s, transform .5s var(--ease);
}
.ftr-photo-item:hover img { opacity: 1; transform: scale(1.06); }

/* ── STATEMENT + NEWSLETTER BAND ──────── */
.ftr-statement {
  background: linear-gradient(135deg, var(--orange) 0%, #E55A0F 40%, var(--pink) 100%);
  padding: 4.5rem 0;
  position: relative;
  overflow: hidden;
}
.ftr-statement::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--PAT1);
  background-size: cover;
  background-position: center;
  opacity: .14;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.ftr-statement-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
  position: relative;
  z-index: 1;
}
.ftr-stmt-text h2 {
  font-family: var(--font);
  font-weight: 900;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  line-height: 1.1;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: -.02em;
  margin-bottom: .85rem;
}
.ftr-stmt-text p { color: rgba(255,255,255,.72); max-width: 380px; }
.ftr-stmt-form .nl-row {
  border: 3px solid rgba(255,255,255,.3);
  box-shadow: var(--sh-xl);
}
.ftr-stmt-form .nl-input { background: rgba(255,255,255,.95); }
.ftr-stmt-form .nl-sub { background: var(--navy-d); }
.ftr-stmt-form .nl-sub:hover { background: var(--navy); }
.ftr-stmt-form .nl-note { color: rgba(255,255,255,.68); margin-top: .75rem; }

/* ── MAIN FOOTER SPLIT ─────────────────── */
.ftr-main-split {
  display: grid;
  grid-template-columns: 280px 1fr;
  min-height: 320px;
}

/* Left: Pattern brand panel */
.ftr-brand-panel {
  background-image: var(--PAT1);
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 3rem 2rem;
}
.ftr-brand-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(155deg, rgba(6,15,32,.72) 0%, rgba(11,45,92,.80) 100%);
}
/* ftr-brand-panel::after removed — no orange divider line */
.ftr-brand-content { position: relative; z-index: 1; }
.ftr-brand-content img {
  height: 40px;
  filter: brightness(0) invert(1);
  margin-bottom: 1.1rem;
  display: block;
}
.ftr-brand-content p {
  color: rgba(255,255,255,.75);
  font-size: .8rem;
  line-height: 1.7;
  margin-bottom: 1.25rem;
  max-width: 220px;
}
.ftr-brand-social { display: flex; gap: .45rem; flex-wrap: wrap; margin-top: 1.25rem; }
.ftr-soc-sm {
  width: 34px; height: 34px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.5);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  transition: all .35s var(--spring);
}
.ftr-soc-sm:hover {
  transform: translateY(-4px) scale(1.1);
  color: #fff;
}
.ftr-soc-sm:nth-child(1):hover { background: var(--orange); border-color: var(--orange); box-shadow: 0 6px 18px rgba(241,125,1,.35); }
.ftr-soc-sm:nth-child(2):hover { background: #0A66C2; border-color: #0A66C2; }
.ftr-soc-sm:nth-child(3):hover { background: #1877F2; border-color: #1877F2; }

/* Right: Links grid */
.ftr-links-panel {
  background: var(--navy-d);
  padding: 3rem 3rem 3rem 3rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  position: relative;
}
.ftr-links-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--PAT2);
  background-size: 25%;
  background-position: right bottom;
  background-repeat: no-repeat;
  opacity: .04;
  pointer-events: none;
}
.ftr-col { position: relative; z-index: 1; }
.ftr-col h5 {
  font-family: var(--font);
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 1.25rem;
}
.ftr-links { display: flex; flex-direction: column; gap: .55rem; }
.ftr-links a {
  font-size: .8rem;
  color: rgba(255,255,255,.72);
  transition: all .3s var(--ease);
}
.ftr-links a:hover { color: rgba(255,255,255,.85); padding-left: .4rem; }
.ftr-links a::before {
  content: "›";
  opacity: 0;
  transform: translateX(-4px);
  transition: all .25s;
  margin-right: .3rem;
  display: inline-block;
}
.ftr-links a:hover::before { opacity: 1; transform: none; }

/* Contact item */
.ftr-contact-item {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .8rem;
  color: rgba(255,255,255,.72);
  margin-bottom: .6rem;
  transition: color .3s;
}
.ftr-contact-item:hover { color: #fff; }
.ftr-contact-item i { color: var(--orange); font-size: .88rem; flex-shrink: 0; }

/* CTA buttons in footer */
.ftr-ctas { display: flex; flex-direction: column; gap: .65rem; margin-top: 1.5rem; }
.ftr-ctas .btn { justify-content: center; }

/* ── BOTTOM BAR ─────────────────────────── */
.ftr-bottom-bar {
  background: var(--navy-d);
  border-top: 1px solid rgba(255,255,255,.06);
  padding: 1.25rem 0;
}
.ftr-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}
.ftr-bottom-bar p {
  font-size: .74rem;
  color: rgba(255,255,255,.55);
  margin: 0;
}
.ftr-bottom-soc { display: flex; gap: .65rem; align-items: center; }
.ftr-bottom-soc a { color: rgba(255,255,255,.6); font-size: .9rem; transition: color .3s; }
.ftr-bottom-soc a:hover { color: rgba(255,255,255,.6); }

/* RESPONSIVE */
@media(max-width: 1024px) {
  .ftr-main-split { grid-template-columns: 1fr; }
  .ftr-brand-panel { min-height: 200px; justify-content: center; }
  .ftr-links-panel { grid-template-columns: 1fr 1fr; }
  .ftr-statement-inner { grid-template-columns: 1fr; gap: 2.5rem; }
}
@media(max-width: 768px) {
  .hdr-left-band { width: 120px; padding: 0 1rem; }
  .ftr-links-panel { grid-template-columns: 1fr; padding: 2rem; }
  .ftr-photo-item { width: 180px; }
  .ftr-bottom-inner { flex-direction: column; text-align: center; }
}

/* ══════════════════════════════════════════════
   CREATIVE CARD SYSTEM v2
   Photo-backed · Split-accent · Full-colour
══════════════════════════════════════════════ */

/* 1. PHOTO MEMBERSHIP CARDS (about.html) */
.mem-cards-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.25rem; }
.mem-photo-card {
  border-radius:var(--rXL); overflow:hidden; position:relative;
  height:460px; cursor:pointer; display:block;
  transition:transform .55s cubic-bezier(.34,1.56,.64,1), box-shadow .55s var(--ease);
}
.mem-photo-card:hover { transform:translateY(-14px) scale(1.02); box-shadow:0 48px 96px rgba(0,0,0,.28); }
.mem-photo-bg { position:absolute; inset:0; background-size:cover; background-position:center top; transition:transform .9s var(--ease); }
.mem-photo-card:hover .mem-photo-bg { transform:scale(1.08); }
.mem-photo-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(6,15,32,1) 0%, rgba(6,15,32,.72) 40%, rgba(6,15,32,.2) 75%, transparent 100%);
  transition:background .4s;
}
.mem-photo-card:hover .mem-photo-overlay { background:linear-gradient(to top, rgba(6,15,32,1) 0%, rgba(6,15,32,.9) 52%, rgba(6,15,32,.5) 80%, rgba(6,15,32,.15) 100%); }
.mem-photo-pat { position:absolute; inset:0; background-image:var(--PAT1); background-size:cover; opacity:.07; mix-blend-mode:screen; pointer-events:none; z-index:1; }
.mem-photo-card::before { content:""; position:absolute; top:0; left:0; right:0; height:4px; z-index:3; border-radius:var(--rXL) var(--rXL) 0 0; }
.mpc-orange::before { background:linear-gradient(90deg,var(--orange),#FFD580); }
.mpc-teal::before   { background:linear-gradient(90deg,var(--teal),#27BDBD); }
.mpc-green::before  { background:linear-gradient(90deg,var(--green),#27BD45); }
.mpc-purple::before { background:linear-gradient(90deg,var(--purple),#9D69F5); }
.mem-photo-body { position:absolute; bottom:0; left:0; right:0; padding:2.25rem; z-index:2; }
.mem-tier { display:inline-flex; align-items:center; gap:.45rem; border-radius:var(--rF); padding:.32rem .85rem; font-family:var(--font); font-size:.58rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; margin-bottom:.85rem; backdrop-filter:blur(8px); }
.mt-orange { background:var(--orange); color:#fff; }
.mt-teal   { background:var(--teal);   color:#fff; }
.mt-green  { background:var(--green);  color:#fff; }
.mt-purple { background:var(--purple); color:#fff; }
.mem-photo-body h3 { color:#fff; font-family:var(--font); font-size:1.55rem; font-weight:900; text-transform:uppercase; line-height:1.05; letter-spacing:-.01em; margin-bottom:.75rem; }
.mem-divider { width:40px; height:2px; background:rgba(255,255,255,.3); border-radius:2px; margin-bottom:.85rem; transition:width .4s var(--ease),background .3s; }
.mem-photo-card:hover .mem-divider { width:80px; background:var(--orange); }
.mem-photo-body p { color:rgba(255,255,255,.78); font-size:.87rem; line-height:1.72; max-height:0; overflow:hidden; transition:max-height .55s var(--ease),opacity .45s,margin .45s; opacity:0; margin-bottom:0; }
.mem-photo-card:hover .mem-photo-body p { max-height:200px; opacity:1; margin-bottom:1.5rem; }
.mem-photo-body .btn { opacity:0; transform:translateY(12px); transition:opacity .4s,transform .4s; }
.mem-photo-card:hover .mem-photo-body .btn { opacity:1; transform:translateY(0); }

/* 2. SPLIT ACCENT TYPE CARDS (members.html) */
.type-cards-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.type-card { border-radius:var(--rXL); overflow:hidden; display:grid; grid-template-columns:140px 1fr; min-height:190px; transition:transform .45s cubic-bezier(.34,1.56,.64,1),box-shadow .45s; cursor:default; position:relative; }
.type-card:hover { transform:translateY(-8px) scale(1.015); box-shadow:var(--sh-xl); }
.type-card-left { position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:.6rem; padding:1.5rem; }
.type-card-left::before { content:""; position:absolute; inset:0; background-image:var(--PAT2); background-size:80%; background-position:center; background-repeat:no-repeat; opacity:.12; pointer-events:none; }
.tc-o .type-card-left { background:linear-gradient(145deg,var(--orange),#C04A05); }
.tc-t .type-card-left { background:linear-gradient(145deg,var(--teal),#1a5563); }
.tc-n .type-card-left { background:linear-gradient(145deg,var(--navy),#0A2447); }
.tc-g .type-card-left { background:linear-gradient(145deg,var(--green),#1A7A35); }
.tc-p .type-card-left { background:linear-gradient(145deg,var(--purple),#5B21B6); }
.tc-pk .type-card-left { background:linear-gradient(145deg,var(--pink),#C01680); }
.type-icon-box { width:64px; height:64px; border-radius:18px; background:rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; font-size:1.9rem; color:#fff; transition:all .45s cubic-bezier(.34,1.56,.64,1); position:relative; z-index:1; box-shadow:0 6px 20px rgba(0,0,0,.2); }
.type-card:hover .type-icon-box { background:rgba(255,255,255,.3); transform:scale(1.12) rotate(-8deg); box-shadow:0 10px 32px rgba(0,0,0,.3); }
.type-card-label { font-family:var(--font); font-size:.56rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.6); position:relative; z-index:1; text-align:center; }
.type-card-right { background:#fff; padding:2rem 1.75rem; display:flex; flex-direction:column; justify-content:center; position:relative; }
.type-card-right::before { content:""; position:absolute; left:0; top:18%; bottom:18%; width:3px; border-radius:0 3px 3px 0; transition:background .3s; }
.tc-o .type-card-right::before  { background:var(--orange); }
.tc-t .type-card-right::before  { background:var(--teal); }
.tc-n .type-card-right::before  { background:var(--navy); }
.tc-g .type-card-right::before  { background:var(--green); }
.tc-p .type-card-right::before  { background:var(--purple); }
.tc-pk .type-card-right::before { background:var(--pink); }
.type-card-right h3 { font-family:var(--font); font-size:.95rem; font-weight:800; text-transform:uppercase; color:var(--text); margin-bottom:.6rem; letter-spacing:.04em; transition:color .25s; }
.type-card:hover .type-card-right h3 { color:var(--navy); }
.type-card-right p { font-size:.85rem; line-height:1.72; color:#555; margin:0; }
.type-card::after { content:""; position:absolute; top:0; left:-100%; width:50%; height:100%; background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.12) 50%,transparent 70%); transform:skewX(-18deg); transition:left .65s ease; pointer-events:none; z-index:10; }
.type-card:hover::after { left:150%; }

/* 3. FULL-COLOUR GOVERNANCE BODY CARDS */
.gov-body-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.gov-body-card { border-radius:var(--rXL); padding:2.5rem; min-height:280px; position:relative; overflow:hidden; display:flex; flex-direction:column; cursor:default; transition:transform .5s cubic-bezier(.34,1.56,.64,1),box-shadow .5s; }
.gov-body-card:hover { transform:translateY(-10px) scale(1.02); }
.gbc-orange { background:linear-gradient(145deg,var(--orange),#C04A05); }
.gbc-teal   { background:linear-gradient(145deg,var(--teal),#1a5563); }
.gbc-green  { background:linear-gradient(145deg,var(--green),#1A7A35); }
.gbc-purple { background:linear-gradient(145deg,var(--purple),#5B21B6); }
.gbc-orange:hover { box-shadow:0 32px 80px rgba(241,125,1,.35),var(--sh-xl); }
.gbc-teal:hover   { box-shadow:0 32px 80px rgba(41,105,117,.35),var(--sh-xl); }
.gbc-green:hover  { box-shadow:0 32px 80px rgba(39,149,69,.35),var(--sh-xl); }
.gbc-purple:hover { box-shadow:0 32px 80px rgba(124,58,237,.35),var(--sh-xl); }
.gov-body-card::before { content:""; position:absolute; inset:0; background-image:var(--PAT2); background-size:55%; background-position:bottom right; background-repeat:no-repeat; opacity:.09; pointer-events:none; z-index:0; transition:opacity .4s; }
.gov-body-card:hover::before { opacity:.16; }
.gov-body-card::after { content:""; position:absolute; top:0; left:-120%; width:60%; height:100%; background:linear-gradient(120deg,transparent 25%,rgba(255,255,255,.14) 50%,transparent 75%); transform:skewX(-20deg); transition:left .75s ease; pointer-events:none; z-index:1; }
.gov-body-card:hover::after { left:150%; }
.gbc-num { font-family:"Staatliches",sans-serif; font-size:7rem; color:rgba(255,255,255,.1); line-height:.85; position:absolute; bottom:.5rem; right:1.25rem; pointer-events:none; z-index:0; transition:color .5s,transform .5s; letter-spacing:-.05em; }
.gov-body-card:hover .gbc-num { color:rgba(255,255,255,.2); transform:scale(1.08); }
.gbc-icon { width:68px; height:68px; border-radius:20px; background:rgba(255,255,255,.18); display:flex; align-items:center; justify-content:center; font-size:1.8rem; color:#fff; margin-bottom:1.75rem; transition:all .45s cubic-bezier(.34,1.56,.64,1); position:relative; z-index:1; box-shadow:0 6px 20px rgba(0,0,0,.2); }
.gov-body-card:hover .gbc-icon { background:rgba(255,255,255,.3); transform:scale(1.1) rotate(-7deg); box-shadow:0 10px 32px rgba(0,0,0,.28); }
.gov-body-card h3 { color:#fff; font-size:.95rem; font-weight:800; text-transform:uppercase; letter-spacing:.04em; margin-bottom:.75rem; line-height:1.2; position:relative; z-index:1; font-family:var(--font); }
.gov-body-card p { color:rgba(255,255,255,.75); font-size:.85rem; line-height:1.7; margin:0; position:relative; z-index:1; }

/* 4. RESPONSIVE */
@media(max-width:900px) {
  .mem-cards-grid { grid-template-columns:1fr; }
  .mem-photo-card { height:340px; }
  .type-cards-grid { grid-template-columns:1fr; }
  .gov-body-grid { grid-template-columns:1fr; }
}
@media(max-width:600px) {
  .type-card { grid-template-columns:100px 1fr; }
  .type-icon-box { width:52px; height:52px; font-size:1.5rem; }
}

/* ══════════════════════════════════════════════
   HERO v4 — Cinematic editorial, no split panels
   Floating photo collage + massive typography
══════════════════════════════════════════════ */
/* ── Hero: exactly fills the viewport ── */
.hero-v4 {
  height:100vh;
  min-height:600px;
  padding-top:66px;
  /* Rich multi-tone gradient background — not flat black */
  background:linear-gradient(135deg, #060F20 0%, #0B1F3A 35%, #071428 65%, #0D0818 100%);
  position:relative; overflow:hidden; display:flex; flex-direction:column;
}
/* Rainbow accent line at very top */
.hero-v4::before {
  content:"";
  position:absolute; top:0; left:0; right:0; height:3px; z-index:10;
  background:linear-gradient(90deg,var(--orange),var(--pink),var(--purple),var(--teal),var(--green),var(--orange));
  background-size:300%; animation:gradShift 6s linear infinite;
}

/* Pattern: brighter and more orange/vibrant */
.hv4-pat {
  position:absolute; right:0; top:0; width:52%; height:100%;
  background-image:var(--PAT1); background-size:cover; background-position:center;
  /* Radial fade from right edge inward */
  -webkit-mask-image:linear-gradient(to left, rgba(0,0,0,.7) 0%, rgba(0,0,0,.4) 40%, transparent 75%);
  mask-image:linear-gradient(to left, rgba(0,0,0,.7) 0%, rgba(0,0,0,.4) 40%, transparent 75%);
  pointer-events:none; z-index:0;
  /* Mix with screen so orange pops through */
  mix-blend-mode:screen;
  opacity:.8;
}

/* Vibrant ambient colour glows — much more saturated */
.hv4-glow { position:absolute; border-radius:50%; pointer-events:none; z-index:0; }
.hg-a { width:560px; height:560px; background:radial-gradient(circle,rgba(241,125,1,.28) 0%,transparent 60%); top:-120px; right:18%; animation:float 12s ease-in-out infinite; }
.hg-b { width:400px; height:400px; background:radial-gradient(circle,rgba(230,31,147,.18) 0%,transparent 60%); bottom:-60px; right:5%; animation:float2 10s ease-in-out infinite 3s; }
.hg-c { width:320px; height:320px; background:radial-gradient(circle,rgba(39,189,189,.15) 0%,transparent 60%); top:25%; left:38%; animation:float3 14s ease-in-out infinite 5s; }
/* Extra left-side warm glow */
.hg-d { width:280px; height:280px; background:radial-gradient(circle,rgba(39,149,69,.12) 0%,transparent 65%); bottom:20%; left:5%; animation:float 16s ease-in-out infinite 7s; position:absolute; border-radius:50%; pointer-events:none; z-index:0; }

/* Main canvas — fills remaining height, content centred */
.hv4-canvas {
  flex:1;
  position:relative; z-index:1;
  display:grid; grid-template-columns:52% 48%; align-items:center; gap:2rem;
  max-width:1200px; margin:0 auto; padding:2rem 2rem 1.5rem; width:100%;
  min-height:0; /* critical: allows flex child to shrink */
}

/* === TEXT SIDE === */
.hv4-text {}
.hv4-eyebrow {
  display:inline-flex; align-items:center; gap:.6rem; margin-bottom:1.25rem;
}
.hv4-eyebrow-dot { width:7px; height:7px; border-radius:50%; background:var(--orange); animation:blink 2s ease infinite; flex-shrink:0; }
.hv4-eyebrow span { font-family:var(--font); font-size:.63rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.45); }

/* Headline — sized to fit viewport */
.hv4-title {
  font-family:var(--font); font-weight:900;
  font-size:clamp(2.4rem,3.8vw,4.6rem);
  line-height:.92; letter-spacing:-.03em;
  text-transform:uppercase; color:#fff; margin-bottom:1.5rem;
}
.hv4-title em {
  display:block; font-style:italic;
  background:linear-gradient(135deg,var(--orange) 0%,#FFD580 40%,#FF6B35 70%,var(--orange) 100%);
  background-size:300%; -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; animation:gradPan 3s linear infinite;
}

.hv4-desc { font-size:.95rem; color:rgba(255,255,255,.58); max-width:440px; line-height:1.75; margin-bottom:1.5rem; }
.hv4-acts { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:1.75rem; }

/* Inline stat pills */
.hv4-stats { display:flex; gap:2.5rem; padding-top:2rem; border-top:1px solid rgba(255,255,255,.1); flex-wrap:wrap; }
.hv4-stat-n { font-family:'Staatliches',sans-serif; font-size:2.6rem; color:var(--orange); line-height:1; display:block; }
.hv4-stat-l { font-family:var(--font); font-size:.6rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.38); margin-top:.2rem; }

/* === PHOTO COLLAGE SIDE === */
.hv4-photos { position:relative; height:580px; }

/* Main tall photo — slightly tilted */
.hv4-ph-main {
  position:absolute; left:50%; top:50%;
  transform:translate(-45%,-55%) rotate(2.5deg);
  width:clamp(200px,26vw,340px);
  border-radius:22px; overflow:hidden;
  box-shadow:0 48px 100px rgba(0,0,0,.55), 0 0 0 5px rgba(255,255,255,.07);
  transition:transform .8s cubic-bezier(.34,1.56,.64,1);
}
.hv4-ph-main:hover { transform:translate(-45%,-55%) rotate(0deg) scale(1.03); box-shadow:0 60px 120px rgba(0,0,0,.6); }
.hv4-ph-main img { width:100%; display:block; aspect-ratio:3/4; object-fit:cover; object-position:center top; }

/* Second photo — top-right offset */
.hv4-ph-sm {
  position:absolute; right:2%; top:6%;
  width:clamp(120px,15vw,190px);
  border-radius:18px; overflow:hidden;
  box-shadow:0 28px 65px rgba(0,0,0,.5), 0 0 0 4px rgba(255,255,255,.1);
  transform:rotate(-4deg); z-index:2;
  transition:transform .65s cubic-bezier(.34,1.56,.64,1);
}
.hv4-ph-sm:hover { transform:rotate(-1deg) scale(1.07); }
.hv4-ph-sm img { width:100%; display:block; aspect-ratio:1; object-fit:cover; }

/* Third photo — bottom-left accent */
.hv4-ph-xs {
  position:absolute; left:0; bottom:10%;
  width:clamp(95px,11vw,148px);
  border-radius:15px; overflow:hidden;
  box-shadow:0 20px 50px rgba(0,0,0,.5), 0 0 0 3px rgba(255,255,255,.08);
  transform:rotate(5deg); z-index:2;
  transition:transform .55s cubic-bezier(.34,1.56,.64,1);
}
.hv4-ph-xs:hover { transform:rotate(1.5deg) scale(1.09); }
.hv4-ph-xs img { width:100%; display:block; aspect-ratio:1; object-fit:cover; }

/* Orange pattern accent circle behind main photo */
.hv4-pat-circle {
  position:absolute; left:30%; top:50%;
  transform:translate(-50%,-50%);
  width:clamp(220px,28vw,360px); height:clamp(220px,28vw,360px);
  border-radius:50%;
  background-image:var(--PAT1); background-size:cover;
  opacity:.22; z-index:0;
  animation:spin 60s linear infinite;
}

/* CoS badge near photos */
.hv4-badge {
  position:absolute; bottom:1.5rem; right:1%;
  z-index:5; background:rgba(6,30,62,.8);
  backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--rL); padding:1.1rem 1.4rem;
  display:flex; align-items:center; gap:.85rem;
  width:clamp(240px,26vw,320px);
}

/* Stat row at bottom — same as before */
.hv4-stats-row { display:grid; grid-template-columns:repeat(4,1fr); position:relative; z-index:1; }

/* Responsive */
@media(max-width:1100px) {
  .hv4-canvas { grid-template-columns:1fr; }
  .hv4-photos { display:none; }
  .hv4-title { font-size:clamp(3.5rem,10vw,7rem); }
}
@media(max-width:768px) {
  .hv4-stats-row { grid-template-columns:1fr 1fr; }
  .hstat { border-bottom:1px solid rgba(255,255,255,.1); }
  .hstat:nth-child(2n) { border-right:none; }
  .hstat:nth-child(3), .hstat:nth-child(4) { border-bottom:none; }
}

/* ══════════════════════════════════════════════
   HERO v4 — VIEWPORT FIT + FONT + COLOUR FIXES
══════════════════════════════════════════════ */

/* 1. Exact viewport height */
.hero-v4 {
  height:100vh !important;
  min-height:620px !important;
  /* Richer background — not flat black */
  background:linear-gradient(150deg,
    #08122A 0%, #0D1F3C 30%,
    #0A142A 60%, #060D1C 100%) !important;
}

/* 2. Rainbow top accent line for instant colour */
.hero-v4::before {
  content:"" !important;
  position:absolute; top:0; left:0; right:0; height:3px; z-index:10;
  background:linear-gradient(90deg,
    var(--orange) 0%, var(--pink) 25%,
    var(--purple) 50%, var(--teal) 75%,
    var(--green) 90%, var(--orange) 100%);
  background-size:200%; animation:gradShift 5s linear infinite;
}

/* 3. Pattern — vibrant, not blended dark */
.hv4-pat {
  mix-blend-mode:normal !important;
  opacity:.45 !important;
  /* Warm orange tint overlaid to boost vibrancy */
  filter:sepia(30%) saturate(180%) hue-rotate(-10deg);
  -webkit-mask-image:linear-gradient(to left,
    rgba(0,0,0,.65) 0%, rgba(0,0,0,.35) 45%, transparent 80%) !important;
  mask-image:linear-gradient(to left,
    rgba(0,0,0,.65) 0%, rgba(0,0,0,.35) 45%, transparent 80%) !important;
}

/* 4. Stronger, more colourful glows */
.hg-a { background:radial-gradient(circle,rgba(241,125,1,.32) 0%,transparent 60%) !important; }
.hg-b { background:radial-gradient(circle,rgba(230,31,147,.22) 0%,transparent 60%) !important; }
.hg-c { background:radial-gradient(circle,rgba(39,189,189,.18) 0%,transparent 60%) !important; }

/* 5. Canvas — compact padding, centred */
.hv4-canvas {
  padding:1.75rem 2rem 1rem !important;
  align-items:center;
}

/* 6. Font — fits 4 lines + content in viewport */
.hv4-title {
  font-size:clamp(1.9rem, 2.8vw, 3.4rem) !important;
  line-height:.92 !important;
  margin-bottom:1rem !important;
}
.hv4-title em { display:block; }

/* 7. Tighter element spacing */
.hv4-eyebrow  { margin-bottom:.9rem !important; }
.hv4-desc     { font-size:.9rem !important; margin-bottom:1.25rem !important; line-height:1.72 !important; }
.hv4-acts     { margin-bottom:1.5rem !important; }
.hv4-stats    { padding-top:1rem !important; gap:1.5rem !important; }
.hv4-stat-n   { font-size:2rem !important; }
.hv4-stat-l   { font-size:.55rem !important; color:rgba(255,255,255,.38) !important; }

/* 8. Colour accent — orange left border on text panel */
.hv4-text {
  padding-left:1.5rem !important;
  border-left:3px solid var(--orange) !important;
  position:relative !important;
}

/* 9. Photo sizes — scale for viewport */
.hv4-photos   { height:min(460px, calc(100vh - 360px)) !important; }
.hv4-ph-main  {
  width:clamp(160px, 20vw, 270px) !important;
  border:3px solid rgba(241,125,1,.45) !important;
}
.hv4-ph-sm {
  width:clamp(100px, 12vw, 155px) !important;
  border:3px solid rgba(39,189,189,.5) !important;
}
.hv4-ph-xs {
  width:clamp(75px, 9vw, 120px) !important;
  border:3px solid rgba(124,58,237,.5) !important;
}

/* 10. Pattern accent circle — more colourful */
.hv4-pat-circle { opacity:.35 !important; filter:saturate(160%); }

/* 11. Badge — compact */
.hv4-badge {
  bottom:.75rem !important;
  width:clamp(220px, 24vw, 290px) !important;
  padding:.9rem 1.2rem !important;
}
.hbtitle { font-size:.78rem !important; }

/* 12. Responsive overrides */
@media(max-width:1100px) {
  .hv4-title { font-size:clamp(2.2rem, 6vw, 4rem) !important; }
  .hv4-photos { display:none !important; }
  .hv4-text { border-left:none !important; padding-left:0 !important; }
}
@media(max-width:768px) {
  .hero-v4 { height:auto !important; min-height:100vh !important; }
  .hv4-title { font-size:clamp(2rem, 8vw, 3.2rem) !important; }
  .hv4-canvas { padding:1.5rem 1.5rem .75rem !important; }
}

/* ══════════════════════════════════════════════
   HERO V5 — Clean two-panel split
   Left: dark navy text panel | Right: full photo
══════════════════════════════════════════════ */
.hero-v5 {
  height: 100vh; min-height: 640px;
  padding-top: 66px;
  display: grid;
  grid-template-columns: 44fr 56fr;
  grid-template-rows: 1fr 88px;
  overflow: hidden;
  background: var(--navy-d);
}

/* LEFT: dark text panel */
.hv5-left {
  position: relative; overflow: hidden;
  display: flex; align-items: center;
  border-right: 5px solid var(--orange);
}
/* Pattern texture in left panel */
.hv5-left::before {
  content: "";
  position: absolute; inset: 0;
  background-image: var(--PAT2);
  background-size: 260px; background-repeat: repeat;
  opacity: .12; pointer-events: none;
}
/* Subtle glow orb */
.hv5-left::after {
  content: "";
  position: absolute;
  width: 400px; height: 400px; border-radius: 50%;
  background: radial-gradient(circle, rgba(241,125,1,.12) 0%, transparent 65%);
  right: -100px; bottom: -100px; pointer-events: none;
}
.hv5-left-inner {
  position: relative; z-index: 1;
  padding: 2rem 3rem 2rem 4.5vw;
  width: 100%;
}

/* RIGHT: full-bleed photo */
.hv5-right {
  position: relative; overflow: hidden;
}
.hv5-right > img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 15%;
  display: block;
}
/* Bottom gradient for badge readability */
.hv5-right::after {
  content: "";
  position: absolute; left: 0; right: 0; bottom: 0; height: 55%;
  background: linear-gradient(to top, rgba(6,15,32,.75) 0%, transparent 100%);
  z-index: 1; pointer-events: none;
}
/* Pattern texture over photo */
.hv5-pat {
  position: absolute; inset: 0;
  background-image: var(--PAT1);
  background-size: 260px; background-repeat: repeat;
  opacity: .13; mix-blend-mode: overlay;
  z-index: 2; pointer-events: none;
}

/* Stats row spans full width */
.hv5-stats-row { grid-column: 1 / 3; }

/* Eyebrow */
.hv5-eyebrow {
  display: flex; align-items: center; gap: .6rem;
  margin-bottom: 1.5rem;
}
.hv5-edot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--orange); flex-shrink: 0;
  animation: blink 2s infinite;
}
.hv5-eyebrow span {
  font-family: var(--font); font-size: .6rem;
  font-weight: 700; letter-spacing: .18em;
  text-transform: uppercase; color: rgba(255,255,255,.58);
}

/* Headline — balanced proportions */
.hv5-h1 {
  font-family: var(--font); font-weight: 900;
  text-transform: uppercase; letter-spacing: -.03em;
  line-height: .9; margin-bottom: 1.5rem;
}
.hv5-l1 {
  display: block; color: rgba(255,255,255,.45);
  font-size: clamp(1.2rem, 1.8vw, 2rem); line-height: 1.2;
}
.hv5-l2 {
  display: block; font-style: italic;
  font-size: clamp(3rem, 5.5vw, 5.8rem); line-height: .88;
  color: var(--orange);
}
.hv5-l3 {
  display: block; color: #fff;
  font-size: clamp(2.2rem, 4vw, 4.4rem); line-height: .95;
}
.hv5-l4 {
  display: block; color: #fff;
  font-size: clamp(2.2rem, 4vw, 4.4rem); line-height: .95;
}

.hv5-rule {
  width: 64px; height: 4px;
  background: linear-gradient(to right, var(--orange), var(--pink));
  border-radius: 2px; margin-bottom: 1.25rem;
}
.hv5-desc {
  font-size: .96rem; color: rgba(255,255,255,.78);
  line-height: 1.78; margin-bottom: 1.75rem; max-width: 400px;
}
.hv5-acts { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 2rem; }

/* Inline stats */
.hv5-stats {
  display: flex; align-items: center; gap: 1.75rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(255,255,255,.1);
}
.hv5-stat-n {
  font-family: 'Staatliches', sans-serif;
  font-size: 2.2rem; color: var(--orange);
  display: block; line-height: 1;
}
.hv5-stat-l {
  font-family: var(--font); font-size: .53rem;
  font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: rgba(255,255,255,.6);
  display: block;
}
.hv5-stat-sep { width: 1px; height: 30px; background: rgba(255,255,255,.14); flex-shrink: 0; }

/* Floating CoS badge — bottom right of photo */
.hv5-badge {
  position: absolute;
  right: 2rem; bottom: 2rem;
  z-index: 6;
  background: rgba(6,15,32,.78);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--rXL); padding: 1.1rem 1.4rem;
  display: flex; align-items: center; gap: 1rem;
  min-width: 290px; max-width: 340px;
}
.hv5-bdot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--orange); flex-shrink: 0;
  animation: blink 2s infinite;
  box-shadow: 0 0 0 5px rgba(241,125,1,.22);
}
.hv5-btext { flex: 1; }
.hv5-bpre {
  font-family: var(--font); font-size: .53rem;
  font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: rgba(255,255,255,.44);
  margin-bottom: .2rem;
}
.hv5-btitle { font-family: var(--font); font-size: .86rem; font-weight: 800; color: #fff; }

@media(max-width: 960px) {
  /* Row 2 must be AUTO so the 2x2 stat grid isn't clipped to 88px */
  .hero-v5 { grid-template-columns: 1fr; grid-template-rows: auto auto; height: auto; overflow: visible; }
  .hv5-left { border-right: none; border-bottom: 4px solid var(--orange); }
  .hv5-right { display: none; }
  .hv5-stats-row { grid-column: 1; }
  /* 2x2 stat tiles — show all four */
  .hv5-stats-row, .hv4-stats-row { grid-template-columns: 1fr 1fr !important; }
  .hv5-stats-row .hstat, .hv4-stats-row .hstat { min-height: 96px; }
}
@media(max-width: 600px) {
  .hero-v5 { height: auto; min-height: auto; }
  .hv5-left-inner { padding: 2rem 1.5rem; }
  .hv5-l2 { font-size: clamp(2.5rem, 10vw, 4rem); }
  .hv5-l3, .hv5-l4 { font-size: clamp(1.8rem, 7vw, 3rem); }
}

/* ══════════════════════════════════════════════
   CULTURAL PATTERN SIDES
   Adds the CHReaD tribal pattern to left & right
   edges of any section — dark and light variants
══════════════════════════════════════════════ */

/* Base: dark sections (nav, teal, green, orange backgrounds) */
.pat-sides {
  position: relative;
  overflow: hidden;
}
.pat-sides::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: min(200px, 14vw);
  background-image: var(--PAT1);
  background-size: auto 100%;
  background-position: left center;
  background-repeat: no-repeat;
  opacity: .22;
  pointer-events: none;
  z-index: 0;
  transition: opacity .4s;
}
.pat-sides::after {
  content: "";
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: min(200px, 14vw);
  background-image: var(--PAT1);
  background-size: auto 100%;
  background-position: right center;
  background-repeat: no-repeat;
  transform: scaleX(-1);
  opacity: .22;
  pointer-events: none;
  z-index: 0;
  transition: opacity .4s;
}

/* Light variant: white / cream / off-white sections */
.pat-sides-lt::before,
.pat-sides-lt::after {
  opacity: .10 !important;
}

/* Coloured variant: boosted for very dark sections */
.pat-sides-bold::before,
.pat-sides-bold::after {
  opacity: .2 !important;
}

/* Ensure section content sits above pattern */
.pat-sides > .wrap,
.pat-sides > .container,
.pat-sides > div:not(.pat-sides-inner) {
  position: relative;
  z-index: 1;
}

/* Also boost existing flanked section pattern visibility */
.flanked .pat-l,
.flanked .pat-r {
  width: min(165px, 12vw) !important;
  opacity: .85;
}

/* themes-sec and blogs-sec — z-index for content above pattern */
.themes-head, .theme-grid { position: relative; z-index: 1; }
.blogs-head, .blog-magazine, .blog-grid { position: relative; z-index: 1; }
.blogs-head, .blog-grid, .blog-magazine { position: relative; z-index: 1; }
.blogs-sec { overflow: hidden; }

/* about-sec — subtle texture */
.about-sec::before {
  background-size: 300px !important;
  background-repeat: repeat !important;
  background-position: center !important;
  opacity: .10 !important;
}

/* Zones-sec orange — already has pattern, boost */
.zones-sec::before { opacity: .25 !important; }

/* Partners section — subtle texture over photo */
.partners-sec::before {
  background-size: 300px !important;
  background-repeat: repeat !important;
  background-position: center !important;
  opacity: .09 !important;
}

/* Timeline/Key Moments — subtle texture over photo */
.timeline-sec::before {
  background-size: 300px !important;
  background-repeat: repeat !important;
  background-position: center !important;
  opacity: .09 !important;
}

/* Agenda section — full tile on light teal */
.agenda-sec {
  position: relative;
  overflow: hidden;
}
.agenda-sec::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--PAT2);
  background-size: 280px;
  background-repeat: repeat;
  opacity: .09;
  pointer-events: none;
  z-index: 0;
}
.agenda-inner { position: relative; z-index: 1; }

/* Blogs section — full tile on cream */
.blogs-sec::before {
  left: 0 !important; right: 0 !important;
  width: 100% !important;
  background-image: var(--PAT2) !important;
  background-size: 280px !important;
  background-repeat: repeat !important;
  background-position: center !important;
  opacity: .08 !important;
}
.blogs-sec::after { display: none !important; }

/* Hide patterns on very small screens to keep layout clean */
@media(max-width: 768px) {
  .pat-sides::before,
  .pat-sides::after,
  .themes-sec::before,
  .themes-sec::after,
  .blogs-sec::before,
  .blogs-sec::after { display: none !important; }
}

/* ══════════════════════════════════════════════
   FULL BACKGROUND PATTERN — like chread.africa reference
   Tiles the tribal pattern across entire section bg
══════════════════════════════════════════════ */
.pat-bg {
  position: relative;
  overflow: hidden;
}
.pat-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--PAT2);
  background-size: 300px;
  background-repeat: repeat;
  opacity: .22;
  pointer-events: none;
  z-index: 0;
}
.pat-bg > .wrap,
.pat-bg > [class],
.pat-bg > div {
  position: relative;
  z-index: 1;
}

/* Light variant for white/off sections */
.pat-bg-lt::before {
  opacity: .09 !important;
}

/* themes-sec — subtle texture over photo */
.themes-sec::before {
  left: 0 !important; right: 0 !important;
  width: 100% !important;
  background-image: var(--PAT2) !important;
  background-size: 300px !important;
  background-repeat: repeat !important;
  background-position: center !important;
  opacity: .09 !important;
}
.themes-sec::after { display: none !important; }

/* team-sec — subtle texture over photo */
.team-sec::before {
  background-size: 300px !important;
  background-repeat: repeat !important;
  background-position: center !important;
  opacity: .09 !important;
}

/* nl-sec — subtle texture over photo */
.nl-sec::before {
  background-size: 300px !important;
  background-repeat: repeat !important;
  background-position: center !important;
  opacity: .09 !important;
}

/* ══════════════════════════════════════════════
   FLOATING CoS 2026 POPUP
══════════════════════════════════════════════ */
.cos-popup {
  position: fixed;
  bottom: 2rem; right: 2rem;
  width: 340px;
  background: linear-gradient(145deg, var(--navy-d) 0%, #1a0540 100%);
  border-radius: var(--rXL);
  box-shadow: 0 32px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.1);
  z-index: 9999;
  overflow: hidden;
  transform: translateY(120%) scale(.9);
  opacity: 0;
  transition: transform .6s cubic-bezier(.34,1.56,.64,1), opacity .5s;
}
.cos-popup.show {
  transform: translateY(0) scale(1);
  opacity: 1;
}
.cos-popup-pat {
  position: absolute; inset: 0;
  background-image: var(--PAT1);
  background-size: 220px; background-repeat: repeat;
  opacity: .1; pointer-events: none;
}
.cos-popup-inner { position: relative; z-index: 1; padding: 1.5rem; }
.cos-popup-close {
  position: absolute; top: .9rem; right: .9rem; z-index: 10;
  width: 30px; height: 30px; border-radius: 50%;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  color: #fff; font-size: .9rem; display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all .3s;
}
.cos-popup-close:hover { background: rgba(255,255,255,.25); transform: rotate(90deg); }
.cos-popup-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  background: rgba(241,125,1,.2); border: 1px solid rgba(241,125,1,.4);
  border-radius: var(--rF); padding: .3rem .75rem;
  font-family: var(--font); font-size: .58rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase; color: var(--orange);
  margin-bottom: 1rem;
}
.cpp-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--orange); animation: blink 2s infinite;
}
.cos-popup-img {
  width: 100%; height: 140px; border-radius: var(--rL);
  overflow: hidden; margin-bottom: 1rem;
}
.cos-popup-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cos-popup-title {
  font-family: var(--font); font-size: 1.4rem; font-weight: 900;
  text-transform: uppercase; color: #fff; line-height: 1.1; margin-bottom: .4rem;
}
.cos-popup-title em {
  font-style: italic;
  background: linear-gradient(135deg, var(--orange), #FFD580);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.cos-popup-sub {
  font-family: var(--font); font-size: .7rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.55);
  margin-bottom: 1rem;
}
.cos-popup-countdown {
  display: flex; align-items: center; justify-content: center;
  gap: .5rem; margin-bottom: .5rem;
  background: rgba(255,255,255,.06); border-radius: var(--r);
  padding: .75rem;
}
.cpp-cd { text-align: center; }
.cpp-n {
  font-family: 'Staatliches', sans-serif; font-size: 2rem;
  color: var(--orange); display: block; line-height: 1;
}
.cpp-l {
  font-family: var(--font); font-size: .5rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.4);
}
.cpp-sep {
  font-family: 'Staatliches', sans-serif; font-size: 1.8rem;
  color: rgba(255,255,255,.25); line-height: 1; margin-top: -.3rem;
}
.cos-popup-remind {
  display: block; text-align: center; margin-top: .75rem;
  font-family: var(--font); font-size: .68rem; font-weight: 600;
  color: rgba(255,255,255,.35); text-decoration: none; transition: color .3s;
}
.cos-popup-remind:hover { color: rgba(255,255,255,.7); }
.cos-popup-overlay { display: none; }
@media(max-width: 480px) {
  .cos-popup { bottom: 1rem; right: 1rem; left: 1rem; width: auto; }
}

/* ══════════════════════════════════════════════
   HEADER v3 — clean minimal with orange accent
══════════════════════════════════════════════ */
.hdr {
  background: #fff !important;
  border-bottom: 3px solid var(--orange) !important;
  box-shadow: 0 4px 28px rgba(0,0,0,.07) !important;
}
.hdr-left-band {
  background: var(--navy-d) !important;
  width: 200px !important;
  padding: 0 1.5rem !important;
  display: flex !important;
  align-items: center !important;
  text-decoration: none !important;
}
.hdr-left-band img { height: 36px !important; filter: brightness(0) invert(1) !important; }
.hdr-right {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2rem;
}
.hdr-nav ul { display: flex; align-items: center; gap: 0; list-style: none; }
.hdr-nav ul li a {
  display: block;
  padding: .6rem 1rem;
  font-family: var(--font);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--navy);
  text-decoration: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -3px;
  transition: color .25s, border-color .25s;
}
.hdr-nav ul li a:hover,
.hdr-nav ul li a.active {
  color: var(--orange);
  border-bottom-color: var(--orange);
}
.hdr-cta { margin-left: 1.5rem; }

/* ══════════════════════════════════════════════
   FOOTER v3 — clean 3-column layout
══════════════════════════════════════════════ */
footer .ftr-main-split {
  background: var(--navy-d) !important;
  grid-template-columns: 280px 1fr !important;
}
footer .ftr-brand-panel {
  background: var(--navy-d) !important;
  border-right: 1px solid rgba(255,255,255,.08) !important;
}
footer .ftr-links-panel {
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 2rem !important;
  padding: 3rem 2.5rem !important;
}
footer .ftr-col h5 {
  font-size: .6rem !important;
  letter-spacing: .16em !important;
  margin-bottom: 1rem !important;
}
footer .ftr-bottom-bar {
  background: #060F20 !important;
}

/* feat-grid-4col: 4 columns on desktop */
.feat-grid-4col { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.25rem; }

/* Photo strip (MEDIA images row) */
.photo-strip { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; height: 280px; overflow: hidden; }
.photo-strip-item { position: relative; overflow: hidden; }
.photo-strip-item img { width:100%; height:100%; object-fit:cover; display:block; transition: transform .8s cubic-bezier(.4,0,.2,1); }
.photo-strip-item:hover img { transform: scale(1.08); }
.photo-strip-item::after { content:""; position:absolute; inset:0; background:linear-gradient(to top,rgba(11,45,92,.5) 0%,transparent 60%); opacity:0; transition:opacity .4s; }
.photo-strip-item:hover::after { opacity:1; }

/* ══════════════════════════════════════════════
   MOBILE RESPONSIVENESS — v3 optimised
══════════════════════════════════════════════ */
@media(max-width: 768px) {
  /* Hero v5 */
  .photo-strip { grid-template-columns: 1fr 1fr; height: 200px; }
  .hero-v5 { grid-template-columns: 1fr; grid-template-rows: auto 80px; height: auto; min-height: 100svh; }
  .hv5-right { display: none; }
  .hv5-left { border-right: none; border-bottom: 4px solid var(--orange); padding-top: 2rem; }
  .hv5-left-inner { padding: 1.5rem; }
  .hv5-h1 { margin-bottom: 1rem; }
  .hv5-l2 { font-size: clamp(2.8rem, 12vw, 4.5rem) !important; }
  .hv5-l3, .hv5-l4 { font-size: clamp(1.6rem, 7vw, 2.8rem) !important; }
  .hv5-acts { flex-wrap: wrap; }
  .hv5-stats { gap: 1rem; }
  .hv4-stats-row { grid-template-columns: 1fr 1fr; }

  /* Header */
  .hdr-left-band { width: 160px !important; padding: 0 1rem !important; }
  .hdr-nav { display: none; }
  .hdr-nav.open { display: block; position: fixed; inset: 66px 0 0; background: #fff; z-index: 999; overflow-y: auto; }
  .hdr-nav.open ul { flex-direction: column; padding: 1.5rem; gap: 0; }
  .hdr-nav.open ul li a { padding: 1rem; border-bottom: 1px solid var(--border); font-size: .82rem; }
  .hdr-cta { display: none; }
  .hdr-toggle { display: flex !important; }

  /* Sections */
  .about-inner { grid-template-columns: 1fr; gap: 2rem; }
  .about-img-col { display: none; }
  .cos-fest-inner { grid-template-columns: 1fr; }
  .cos-fest-visual { display: none; }
  .theme-grid { grid-template-columns: 1fr 1fr; }
  .zone-panel.active { grid-template-columns: 1fr; }
  .zp-img { display: none; }
  .zone-tabs { flex-wrap: wrap; }
  .tl-items { grid-template-columns: 1fr 1fr; gap: 1.5rem; }
  .timeline::before { display: none; }
  .agenda-inner { grid-template-columns: 1fr; gap: 2rem; }
  .gov-body-grid { grid-template-columns: 1fr; }
  .engage-grid { grid-template-columns: 1fr; }
  .cc-grid { grid-template-columns: 1fr; }
  .type-cards-grid { grid-template-columns: 1fr; }
  .fl, .flr { grid-template-columns: 1fr; }
  .fr2 { grid-template-columns: 1fr; }
  .blog-magazine { grid-template-columns: 1fr; }
  .nl-inner { grid-template-columns: 1fr; gap: 2rem; }

  /* Thematic 4-col grid */
  .feat-grid-4col { grid-template-columns: 1fr 1fr !important; }

  /* Footer */
  .ftr-main-split { grid-template-columns: 1fr !important; }
  .ftr-links-panel { grid-template-columns: 1fr 1fr !important; padding: 2rem 1.5rem !important; }
  .ftr-statement-inner { grid-template-columns: 1fr; gap: 2rem; }
  .ftr-photos { height: 120px; }
  .ftr-photo-item { width: 160px; }

  /* Popup */
  .cos-popup { bottom: 1rem; right: 1rem; left: 1rem; width: auto; }

  /* Misc */
  .vm-pair { grid-template-columns: 1fr; }
  .feat-grid { grid-template-columns: 1fr; }
  .mem-cards-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: repeat(3, 1fr); gap: .75rem; }
  .wrap { padding: 0 1.25rem; }
  .sec { padding: 60px 0; }
  .sec-lg { padding: 80px 0; }
  h1 { font-size: clamp(2rem, 8vw, 3rem); }
  .disp-sm { font-size: clamp(1.6rem, 6vw, 2.5rem); }
}

@media(max-width: 480px) {
  .hv4-stats-row { grid-template-columns: 1fr 1fr; }
  .evt-grid { grid-template-columns: 1fr; }
  .doc-grid { grid-template-columns: 1fr; }
  .theme-grid { grid-template-columns: 1fr; }
  .feat-grid-4col { grid-template-columns: 1fr !important; }
  .team-grid { grid-template-columns: repeat(2, 1fr); }
  .partner-grid { grid-template-columns: 1fr 1fr; }
  .cos-popup-countdown { gap: .3rem; }
  .cpp-n { font-size: 1.6rem; }
}

/* ═══════════════════════════════════════════════
   HEADER MOBILE FIX — toggle to the right + visible menu items
   ═══════════════════════════════════════════════ */
/* Always push hamburger toggle to the right edge of the header + force-visible bars */
.hdr-toggle { margin-left: auto !important; }

@media (max-width: 991px) {
  /* Toggle MUST be visible on tablet/phone, dark bars on the white header */
  .hdr-toggle {
    display: flex !important;
    z-index: 9995 !important;
    position: relative !important;
    flex: 0 0 auto !important;
    width: 42px !important;
    height: 42px !important;
    border: 1.5px solid var(--orange) !important;
    background: #fff !important;
  }
  .hdr-toggle span { background: var(--navy) !important; display: block !important; width: 20px !important; height: 2px !important; }

  /* Make sure the right panel doesn't clip the toggle or the fixed slide-in nav */
  .hdr-right { overflow: visible !important; justify-content: flex-end !important; }

  /* Mobile menu panel — explicit, robust visibility */
  .hdr-nav {
    position: fixed !important;
    top: 66px !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: calc(100vh - 66px) !important;
    background: #ffffff !important;
    padding: 1.5rem 1.25rem !important;
    z-index: 9990 !important;
    transform: translateX(-100%);
    transition: transform .3s ease !important;
    display: flex !important;
    flex-direction: column !important;
    overflow-y: auto !important;
    visibility: visible !important;
    opacity: 1 !important;
    margin: 0 !important;
  }
  .hdr-nav.open { transform: translateX(0) !important; }
  .hdr-nav > ul,
  .hdr-nav ul {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  .hdr-nav > ul > li,
  .hdr-nav ul li {
    width: 100% !important;
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  .hdr-nav > ul > li > a,
  .hdr-nav ul li a {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    height: auto !important;
    padding: 1.05rem 0 !important;
    font-family: var(--font) !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--navy) !important;
    text-transform: uppercase !important;
    letter-spacing: .06em !important;
    border-bottom: 1px solid var(--border) !important;
    text-decoration: none !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  .hdr-nav > ul > li > a.active,
  .hdr-nav ul li a.active { color: var(--orange) !important; }
  .hdr-toggle {
    display: flex !important;
    z-index: 9995 !important;
    position: relative !important;
  }
}

/* ═══════════════════════════════════════════════
   STAT TILES — mobile fix so cards don't clip the wave divider
   ═══════════════════════════════════════════════ */
@media (max-width: 768px) {
  .hv4-stats-row, .hv5-stats-row {
    grid-template-columns: 1fr 1fr !important;
    position: relative;
    z-index: 2;
  }
  .hstat {
    padding: 1.4rem 1rem !important;
    gap: .35rem !important;
    text-align: center;
    min-height: 110px;
  }
  .hstat-n {
    font-size: 2.2rem !important;
    line-height: 1 !important;
    word-break: break-word;
  }
  .hstat-l {
    font-size: .58rem !important;
    letter-spacing: .08em !important;
    line-height: 1.3 !important;
    max-width: 100%;
  }
}
@media (max-width: 480px) {
  .hstat { padding: 1.1rem .75rem !important; min-height: 96px; }
  .hstat-n { font-size: 1.7rem !important; }
  .hstat-l { font-size: .52rem !important; }
}
