/* ============================================================
   RAAS MFI — Premium Design System v3
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ---------- TOKENS ---------- */
:root {
  --pri: #074846;
  --pri-d: #042f2e;
  --pri-l: #0a5e5b;
  --acc: #40aba4;
  --acc-l: #5ec4be;
  --acc-pale: #e8f6f5;
  --gold: #c9a84c;
  --gold-l: #f5e6b8;
  --white: #ffffff;
  --off: #f8fafa;
  --g50: #f0f4f4;
  --g100: #dce5e4;
  --g200: #b8cbc9;
  --g300: #8aa19f;
  --g400: #5d7876;
  --g500: #3e5553;
  --text: #1a2c2b;
  --muted: #5a706e;
  --light: #93aaa8;

  --ff: 'Inter', sans-serif;
  --nav-h: 76px;
  --max-w: 1200px;
  --wide: 1400px;

  --r-sm: 8px;  --r-md: 14px;  --r-lg: 20px;  --r-xl: 28px;  --r-full: 9999px;
  --sh-sm: 0 1px 3px rgba(7,72,70,.05);
  --sh-md: 0 6px 24px rgba(7,72,70,.07);
  --sh-lg: 0 16px 48px rgba(7,72,70,.1);
  --sh-xl: 0 24px 64px rgba(7,72,70,.14);

  --ease: cubic-bezier(.4,0,.2,1);
  --tr: .35s var(--ease);
}

/* ---------- RESET ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--ff);font-size:1rem;line-height:1.7;color:var(--text);background:var(--white);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color var(--tr)}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:var(--ff)}
h1,h2,h3,h4,h5,h6{line-height:1.15;font-weight:700;color:var(--pri)}
h1{font-size:clamp(2.2rem,5vw,3.8rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.6rem)}
h3{font-size:1.25rem}
h4{font-size:1.1rem}
p{margin-bottom:1rem;color:var(--muted)}

.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 2rem}

/* Native Bootstrap 5 Navbar overrides if needed */

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 30px;font-family:var(--ff);font-size:.85rem;font-weight:600;
  border-radius:var(--r-full);transition:all var(--tr);border:2px solid transparent;white-space:nowrap;
  letter-spacing:.2px;
}
.btn--primary{background:var(--acc);color:var(--white);box-shadow:0 4px 18px rgba(64,171,164,.28)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(64,171,164,.35);background:#38a09a}
.btn--outline{background:transparent;border-color:var(--acc);color:var(--acc)}
.btn--outline:hover{background:var(--acc);color:var(--white);transform:translateY(-2px)}
.btn--dark{background:var(--pri);color:var(--white)}
.btn--dark:hover{background:var(--pri-l);transform:translateY(-2px)}
.btn--white{background:var(--white);color:var(--pri);box-shadow:var(--sh-md)}
.btn--white:hover{transform:translateY(-2px);box-shadow:var(--sh-lg)}
.btn--outline-white{background:transparent;border-color:rgba(255,255,255,.3);color:var(--white)}
.btn--outline-white:hover{background:rgba(255,255,255,.1);border-color:var(--white)}
.btn--gold{background:var(--gold);color:var(--white);box-shadow:0 4px 18px rgba(201,168,76,.3)}
.btn--gold:hover{transform:translateY(-2px);filter:brightness(1.08)}
.btn--sm{padding:10px 22px;font-size:.78rem}
.btn--lg{padding:16px 36px;font-size:.92rem}
.btn--icon{width:48px;height:48px;padding:0;border-radius:50%}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding:6rem 0;position:relative;overflow-x:hidden}
.hero{position:relative;overflow-x:hidden}
.section--gray{background:var(--g50)}
.section--warm{background:linear-gradient(135deg,#faf8f3 0%,var(--acc-pale) 100%)}
.section--dark{background:linear-gradient(135deg,var(--pri-d) 0%,var(--pri) 50%,var(--pri-l) 100%);color:var(--white)}
.section--dark h2,.section--dark h3,.section--dark h4{color:var(--white)}
.section--dark p{color:rgba(255,255,255,.72)}
.section--accent{background:var(--acc-pale)}
.section--mesh{
  background:var(--off);
  background-image:radial-gradient(ellipse at 20% 50%,rgba(64,171,164,.06) 0%,transparent 60%),
                    radial-gradient(ellipse at 80% 20%,rgba(201,168,76,.04) 0%,transparent 60%);
}

/* Image overlay sections */
.section--bg{position:relative;background-size:cover;background-position:center;background-attachment:fixed}
.section--bg::before{content:'';position:absolute;inset:0;z-index:0}
.section--bg>*{position:relative;z-index:1}
.section--bg.ov-dark::before{background:linear-gradient(180deg,rgba(4,47,46,.9) 0%,rgba(7,72,70,.82) 100%)}
.section--bg.ov-soft::before{background:linear-gradient(135deg,rgba(7,72,70,.82) 0%,rgba(64,171,164,.55) 100%)}
.section--bg.ov-left::before{background:linear-gradient(90deg,rgba(4,47,46,.94) 0%,rgba(4,47,46,.7) 50%,transparent 100%)}

.section__header{text-align:center;margin-bottom:3.5rem}
.section__label{
  display:inline-block;font-size:.72rem;font-weight:700;
  text-transform:uppercase;letter-spacing:3px;color:var(--acc);margin-bottom:1rem;
}
.section__label--gold{color:var(--gold)}
.section__title{margin-bottom:.75rem}
.section__sub{font-size:1.05rem;color:var(--muted);max-width:600px;margin:0 auto}
.section--dark .section__label{color:var(--acc-l)}
.section--dark .section__sub{color:rgba(255,255,255,.65)}
.section--bg .section__label{color:var(--gold-l)}
.section--bg .section__title{color:var(--white)}
.section--bg .section__sub{color:rgba(255,255,255,.68)}
.section--bg h2,.section--bg h3,.section--bg h4{color:var(--white)}
.section--bg p{color:rgba(255,255,255,.72)}

.divider{height:3px;width:50px;border-radius:3px;margin:0 auto 1.2rem;background:linear-gradient(90deg,var(--acc),var(--acc-l))}
.divider--gold{background:linear-gradient(90deg,var(--gold),#e8c96a)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:calc(100vh - 76px);display:flex;align-items:center;overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(4,47,46,.94) 0%,rgba(4,47,46,.82) 35%,rgba(7,72,70,.5) 65%,rgba(64,171,164,.15) 100%);
}
.hero__shapes{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.hero__shape{position:absolute;border-radius:50%}
.hero__shape--1{width:600px;height:600px;top:-200px;right:-200px;background:rgba(64,171,164,.06);animation:float 20s ease-in-out infinite}
.hero__shape--2{width:400px;height:400px;bottom:-100px;left:-100px;background:rgba(201,168,76,.04);animation:float 15s ease-in-out infinite reverse}
.hero__shape--3{width:250px;height:250px;top:40%;right:15%;background:rgba(64,171,164,.04);animation:float 12s ease-in-out infinite 3s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}

.hero__content{position:relative;z-index:1;max-width:660px;padding:4rem 0}
.hero__badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(201,168,76,.12);border:1px solid rgba(201,168,76,.25);
  padding:8px 20px;border-radius:var(--r-full);
  font-size:.82rem;font-weight:500;color:var(--gold-l);margin-bottom:1.5rem;
  backdrop-filter:blur(8px);
}
.hero__title{font-size:clamp(2.4rem,5.5vw,4rem);font-weight:900;color:var(--white);margin-bottom:1.2rem;line-height:1.06}
.hero__title span{background:linear-gradient(135deg,var(--acc),var(--acc-l));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero__desc{font-size:1.1rem;color:rgba(255,255,255,.78);margin-bottom:2rem;line-height:1.8}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero__stats{display:flex;gap:3rem;margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08)}
.hero__stat-val{font-size:2.2rem;font-weight:900;color:var(--white);line-height:1;margin-bottom:4px}
.hero__stat-lbl{font-size:.78rem;color:rgba(255,255,255,.5);letter-spacing:.5px}

/* ============================================================
   SPLIT LAYOUT (Image + Text)
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split--reverse{direction:rtl}
.split--reverse>*{direction:ltr}
.split__img{border-radius:var(--r-xl);overflow:hidden;position:relative}
.split__img img{width:100%;height:100%;object-fit:cover;display:block;min-height:360px}
.split__img--deco::after{
  content:'';position:absolute;bottom:-14px;right:-14px;width:110px;height:110px;
  border:3px solid var(--acc);border-radius:var(--r-lg);z-index:-1;
}
.split__img--deco-gold::after{border-color:var(--gold)}
.split__text .section__label{text-align:left}
.split__text h2{text-align:left}
.split__text p{text-align:left}

/* ============================================================
   CARDS — Minimal variety
   ============================================================/* Success Story Card (Impact Page) */
.story-card {
  display: flex;
  background: var(--white);
  border-radius: 2.5rem;
  overflow: hidden;
  box-shadow: var(--sh-xl);
  margin-top: 3rem;
  border: 1px solid rgba(7, 72, 70, 0.05);
}
.story-card__img {
  flex: 0 0 45%;
  position: relative;
  min-height: 500px;
}
.story-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.story-card__content {
  flex: 1;
  padding: 4rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: linear-gradient(165deg, #ffffff 0%, #f7fbfb 100%);
}
.story-card__badge {
  display: inline-block;
  padding: 6px 16px;
  background: var(--gold-l);
  color: var(--pri);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 2px;
  border-radius: 100px;
  margin-bottom: 1.5rem;
}
.story-card__title {
  font-size: 2.4rem;
  font-weight: 900;
  color: var(--pri);
  margin-bottom: 2rem;
  line-height: 1.1;
}
.story-card__text {
  font-size: 1.05rem;
  line-height: 1.9;
  color: var(--muted);
  margin-bottom: 2rem;
}
.story-card__quote {
  font-family: inherit;
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--acc);
  padding-left: 1.5rem;
  border-left: 4px solid var(--gold);
  margin-top: 1rem;
  line-height: 1.5;
}

@media (max-width: 991px) {
  .story-card {
    flex-direction: column;
  }
  .story-card__img {
    min-height: 350px;
  }
  .story-card__content {
    padding: 2.5rem 2rem;
  }
}
.card{
  background:var(--white);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh-sm);transition:all var(--tr);border:1px solid var(--g100);
}
.card:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:var(--acc-pale)}
.card__body{padding:2rem}
.card__icon{
  width:52px;height:52px;display:flex;align-items:center;justify-content:center;
  background:var(--acc-pale);color:var(--acc);border-radius:var(--r-md);
  font-size:1.25rem;margin-bottom:1.2rem;transition:all var(--tr);
}
.card:hover .card__icon{background:var(--acc);color:var(--white);transform:scale(1.06)}
.card__title{font-size:1.05rem;margin-bottom:.5rem}
.card__text{font-size:.88rem;color:var(--muted);line-height:1.7;margin-bottom:0}
.card--top{border-top:3px solid var(--acc)}
.card--top-gold{border-top:3px solid var(--gold)}
.card--img .card__img{height:200px;overflow:hidden}
.card--img .card__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.card--img:hover .card__img img{transform:scale(1.05)}

/* Dark variant — for use on dark/bg sections */
.card--dark{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
}
.card--dark:hover{border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.12);box-shadow:0 12px 40px rgba(0,0,0,.12)}
.card--dark .card__title{color:var(--white)}
.card--dark .card__text{color:rgba(255,255,255,.68)}
.card--dark .card__icon{background:rgba(64,171,164,.15);color:var(--acc-l)}

/* ============================================================
   PRODUCT TILES — unique for services page
   ============================================================ */
.product{
  display:flex;gap:1.5rem;align-items:flex-start;padding:2rem;
  background:var(--white);border-radius:var(--r-lg);border:1px solid var(--g100);
  box-shadow:var(--sh-sm);transition:all var(--tr);
}
.product:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:var(--acc-pale)}
.product__icon{
  width:56px;height:56px;min-width:56px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--r-md);font-size:1.3rem;transition:all var(--tr);
}
.product__icon--teal{background:var(--acc-pale);color:var(--acc)}
.product__icon--gold{background:var(--gold-l);color:var(--gold)}
.product:hover .product__icon{transform:scale(1.08) rotate(3deg)}
.product:hover .product__icon--teal{background:var(--acc);color:var(--white)}
.product:hover .product__icon--gold{background:var(--gold);color:var(--white)}
.product__title{font-size:1rem;margin-bottom:.4rem}
.product__desc{font-size:.85rem;color:var(--muted);line-height:1.65;margin-bottom:.6rem}
.product__tag{
  display:inline-block;padding:3px 12px;border-radius:var(--r-full);
  font-size:.7rem;font-weight:600;letter-spacing:.5px;
}
.product__tag--teal{background:var(--acc-pale);color:var(--acc)}
.product__tag--gold{background:var(--gold-l);color:var(--gold)}

/* ============================================================
   VALUE CARDS
   ============================================================ */
.vcard{
  padding:2.2rem;background:var(--white);border-radius:var(--r-lg);
  box-shadow:var(--sh-sm);border:1px solid var(--g100);
  transition:all var(--tr);text-align:center;
}
.vcard:hover{transform:translateY(-5px);box-shadow:var(--sh-lg);border-color:var(--acc)}
.vcard__icon{
  width:64px;height:64px;display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.2rem;background:var(--acc-pale);color:var(--acc);
  border-radius:var(--r-lg);font-size:1.5rem;transition:all var(--tr);
}
.vcard:hover .vcard__icon{background:var(--acc);color:var(--white);transform:scale(1.08) rotate(5deg)}
.vcard__title{font-size:.95rem;font-weight:700;margin-bottom:.5rem}
.vcard__text{font-size:.85rem;color:var(--muted);margin-bottom:0}

/* ============================================================
   PERSON CARDS
   ============================================================ */
.person{
  text-align:center;padding:2rem;background:var(--white);
  border-radius:var(--r-lg);box-shadow:var(--sh-sm);border:1px solid var(--g100);
  transition:all var(--tr);
}
.person:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.person__av{
  width:110px;height:110px;border-radius:50%;margin:0 auto 1rem;
  overflow:hidden;padding:3px;background:linear-gradient(135deg,var(--acc),var(--acc-l));
}
.person__av img{width:100%;height:100%;border-radius:50%;object-fit:cover;background:var(--g100)}
.person__name{font-size:1rem;font-weight:700;color:var(--pri);margin-bottom:2px}
.person__role{font-size:.82rem;color:var(--acc);font-weight:500;margin-bottom:0}

/* ============================================================
   LOGO GRID — uniform sizing
   ============================================================ */
.logos{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1.5rem;align-items:stretch}
.logos__item{
  display:flex;align-items:center;justify-content:center;
  padding:1.5rem;background:var(--white);
  border-radius:var(--r-md);border:1px solid var(--g100);
  transition:all var(--tr);aspect-ratio:16/9;
}
.logos__item:hover{border-color:var(--acc-pale);box-shadow:var(--sh-md);transform:translateY(-3px)}
.logos__item img{max-height:52px;max-width:120px;object-fit:contain;filter:grayscale(20%);opacity:.85;transition:all var(--tr)}
.logos__item:hover img{filter:grayscale(0%);opacity:1}

/* ============================================================
   STATS
   ============================================================ */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.stat{text-align:center;padding:2rem 1rem}
.stat__val{font-size:clamp(2rem,4vw,3rem);font-weight:900;line-height:1;margin-bottom:.35rem}
.stat__val--teal{color:var(--acc)}
.stat__val--gold{color:var(--gold)}
.stat__val--white{color:var(--white)}
.stat__lbl{font-size:.78rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}
.section--dark .stat__lbl,.section--bg .stat__lbl{color:rgba(255,255,255,.5)}

/* Impact cards */
.icard{
  padding:2rem;border-radius:var(--r-lg);text-align:center;
  background:var(--white);box-shadow:var(--sh-sm);border:1px solid var(--g100);
  transition:all var(--tr);
}
.icard:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.icard__val{font-size:2.6rem;font-weight:900;color:var(--acc);line-height:1;margin-bottom:.3rem}
.icard__val--gold{color:var(--gold)}
.icard__lbl{font-size:.85rem;font-weight:600;color:var(--pri);margin-bottom:.3rem}
.icard__text{font-size:.78rem;color:var(--muted);margin-bottom:0}

/* ============================================================
   TIMELINE — fixed alignment
   ============================================================ */
.timeline{position:relative;padding-left:3rem}
.timeline::before{content:'';position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--acc),var(--gold))}
.tl-item{position:relative;padding-bottom:2.5rem}
.tl-item:last-child{padding-bottom:0}
.tl-dot{
  position:absolute;left:-3rem;top:4px;
  width:24px;height:24px;border-radius:50%;
  background:var(--white);border:3px solid var(--acc);
  display:flex;align-items:center;justify-content:center;
}
.tl-dot::after{content:'';width:8px;height:8px;border-radius:50%;background:var(--acc)}
.tl-item:nth-child(even) .tl-dot{border-color:var(--gold)}
.tl-item:nth-child(even) .tl-dot::after{background:var(--gold)}
.tl-title{font-size:.95rem;font-weight:700;margin-bottom:.35rem}
.tl-text{font-size:.85rem;color:var(--muted);line-height:1.7;margin-bottom:0}
.tl-meta{font-size:.75rem;color:var(--acc);font-weight:600;margin-bottom:.3rem}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quote{
  padding:2rem;background:var(--white);border-radius:var(--r-lg);
  box-shadow:var(--sh-sm);border:1px solid var(--g100);position:relative;
}
.quote__text{font-size:1rem;font-style:italic;color:var(--text);line-height:1.8;margin-bottom:1.2rem;padding-left:1.2rem;border-left:3px solid var(--acc)}
.quote__author{display:flex;align-items:center;gap:1rem}
.quote__av{width:44px;height:44px;border-radius:50%;overflow:hidden;background:var(--acc-pale)}
.quote__av img{width:100%;height:100%;object-fit:cover}
.quote__name{font-weight:600;color:var(--pri);font-size:.85rem}
.quote__title{font-size:.75rem;color:var(--muted)}

/* ============================================================
   ACCORDION
   ============================================================ */
.acc-item{border:1px solid var(--g100);border-radius:var(--r-md);margin-bottom:.75rem;overflow:hidden;transition:all var(--tr);background:var(--white)}
.acc-item.active{border-color:var(--acc);box-shadow:var(--sh-md)}
.acc-btn{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:1.1rem 1.5rem;font-size:.92rem;font-weight:600;color:var(--pri);cursor:pointer;
  transition:all .2s;text-align:left;
}
.acc-btn:hover{background:var(--g50)}
.acc-icon{font-size:1rem;color:var(--acc);transition:transform var(--tr)}
.acc-item.active .acc-icon{transform:rotate(180deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.acc-inner{padding:0 1.5rem 1.2rem;font-size:.88rem;color:var(--muted);line-height:1.8}

/* ============================================================
   BLOG CARDS
   ============================================================ */
.blog{
  background:var(--white);border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--g100);box-shadow:var(--sh-sm);transition:all var(--tr);
}
.blog:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.blog__img{height:200px;overflow:hidden;background:var(--acc-pale)}
.blog__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.blog:hover .blog__img img{transform:scale(1.05)}
.blog__body{padding:1.5rem}
.blog__tag{display:inline-block;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gold);margin-bottom:.5rem}
.blog__title{font-size:.95rem;font-weight:700;margin-bottom:.5rem}
.blog__excerpt{font-size:.85rem;color:var(--muted);margin-bottom:.8rem;line-height:1.6}
.blog__link{font-size:.82rem;font-weight:600;color:var(--acc);display:inline-flex;align-items:center;gap:5px;transition:gap var(--tr)}
.blog__link:hover{gap:10px}

/* ============================================================
   CONTACT FORM — Premium
   ============================================================ */
.c-form{
  background:var(--white);border-radius:var(--r-xl);padding:3rem;
  box-shadow:var(--sh-xl);border:1px solid var(--g100);
}
.fg{margin-bottom:1.2rem}
.fg label{display:block;font-size:.82rem;font-weight:600;color:var(--pri);margin-bottom:.4rem}
.fg input,.fg textarea,.fg select{
  width:100%;padding:14px 18px;border:1.5px solid var(--g200);
  border-radius:var(--r-md);font-family:var(--ff);font-size:.88rem;
  color:var(--text);background:var(--white);transition:all .2s;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 4px rgba(64,171,164,.12)}
.fg textarea{min-height:130px;resize:vertical}

/* Contact info cards */
.ci{
  display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;
  background:var(--white);border-radius:var(--r-md);border:1px solid var(--g100);transition:all var(--tr);
}
.ci:hover{border-color:var(--acc);box-shadow:var(--sh-md)}
.ci__icon{
  width:48px;height:48px;display:flex;align-items:center;justify-content:center;
  background:var(--acc-pale);color:var(--acc);border-radius:var(--r-md);
  font-size:1.1rem;flex-shrink:0;
}
.ci__icon--gold{background:var(--gold-l);color:var(--gold)}
.ci__title{font-size:.85rem;font-weight:700;margin-bottom:3px}
.ci__text{font-size:.85rem;color:var(--muted);margin-bottom:0}

/* Contact highlight strip — top of contact page */
.contact-strip{
  display:grid;grid-template-columns:repeat(4,1fr);
  background:var(--pri);border-radius:var(--r-xl);overflow:hidden;
}
.contact-strip__item{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:2.2rem 1.5rem;position:relative;transition:background var(--tr);
}
.contact-strip__item:hover{background:rgba(255,255,255,.05)}
.contact-strip__item+.contact-strip__item::before{
  content:'';position:absolute;left:0;top:20%;bottom:20%;width:1px;background:rgba(255,255,255,.1);
}
.contact-strip__icon{
  width:50px;height:50px;display:flex;align-items:center;justify-content:center;
  background:rgba(64,171,164,.15);color:var(--acc-l);border-radius:50%;
  font-size:1.2rem;margin-bottom:1rem;
}
.contact-strip__title{font-size:.78rem;font-weight:600;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.4rem}
.contact-strip__val{font-size:.92rem;font-weight:600;color:var(--white)}
.contact-strip__val a{color:var(--acc-l);transition:color var(--tr)}
.contact-strip__val a:hover{color:var(--white)}

/* Map */
.map{width:100%;height:320px;border-radius:var(--r-lg);background:var(--g50);border:1px solid var(--g100);overflow:hidden}
.map iframe{width:100%;height:100%;border:none}

/* ============================================================
   STEPS / PROCESS — connected
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;counter-reset:step;position:relative}
.step{text-align:center;position:relative;padding:0 1.5rem}
.step__num{
  display:flex;align-items:center;justify-content:center;
  width:56px;height:56px;margin:0 auto 1.2rem;
  background:linear-gradient(135deg,var(--acc),var(--acc-l));color:var(--white);
  border-radius:50%;font-size:1.2rem;font-weight:800;position:relative;z-index:2;
  box-shadow:0 4px 16px rgba(64,171,164,.3);
}
/* connector line between steps */
.step::after{
  content:'';position:absolute;top:28px;left:calc(50% + 28px);right:calc(-50% + 28px);
  height:3px;background:linear-gradient(90deg,var(--acc),var(--g200));z-index:1;
}
.step:last-child::after{display:none}
.step__title{font-size:.88rem;font-weight:700;margin-bottom:.4rem}
.step__text{font-size:.78rem;color:var(--muted);margin-bottom:0}

/* ============================================================
   ORG CHART - WIRING DIAGRAM (MATCHING IMAGE EXACTLY)
   ============================================================ */
.org-container { padding: 4rem 1rem; background: var(--white); overflow-x: auto; display: flex; justify-content: center; min-width: 0; }
@media (max-width: 768px) {
    .org-container { justify-content: flex-start; padding-left: 2rem; padding-right: 2rem; }
}
.org-node {
    background: linear-gradient(135deg, #074846 0%, #40aba4 100%);
    color: #fff;
    padding: 1rem 1.5rem;
    font-size: 0.75rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    text-transform: uppercase;
    box-shadow: 0 4px 15px rgba(7, 72, 70, 0.15);
    line-height: 1.4;
    letter-spacing: 0.5px;
    text-align: center;
}
.connector-line {
    background-color: var(--pri);
    position: absolute;
    z-index: 0;
}

/* ============================================================
   CTA SECTION
   ============================================================ */
.cta{
  padding:6rem 0;text-align:center;position:relative;overflow:hidden;
  background-size:cover;background-position:center;
}
.cta::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(7,72,70,.88) 0%,rgba(64,171,164,.6) 100%)}
.cta>*{position:relative;z-index:1}
.cta h2{color:var(--white);margin-bottom:.75rem}
.cta p{color:rgba(255,255,255,.75);max-width:560px;margin:0 auto 2rem;font-size:1.05rem}
.cta__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--pri-d);color:rgba(255,255,255,.8);padding:5rem 0 1.5rem;position:relative;
}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--acc),var(--gold),var(--acc))}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer__brand p{color:rgba(255,255,255,.5);font-size:.85rem;margin-top:.75rem;line-height:1.7}
.footer__logo img{height:38px;filter:brightness(0) invert(1)}
.footer__heading{font-size:.72rem;font-weight:700;color:var(--acc-l);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:1.2rem}
.footer__links li{margin-bottom:.4rem}
.footer__links a{font-size:.85rem;color:rgba(255,255,255,.5);transition:color var(--tr)}
.footer__links a:hover{color:var(--acc-l)}
.footer__social{display:flex;gap:.75rem;margin-top:1.2rem}
.footer__social a{
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;background:rgba(255,255,255,.06);color:rgba(255,255,255,.5);
  transition:all var(--tr);font-size:.9rem;
}
.footer__social a:hover{background:var(--acc);color:var(--white);transform:translateY(-3px)}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.06);padding-top:1.2rem;
  display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:rgba(255,255,255,.3);
}
.footer__bottom-links{display:flex;gap:1.5rem}
.footer__bottom-links a{color:rgba(255,255,255,.3)}
.footer__bottom-links a:hover{color:var(--acc-l)}

/* ============================================================
   GRIDS
   ============================================================ */
.grid{display:grid;gap:1.5rem}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

/* ============================================================
   ANIMATIONS
   ============================================================ */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fade-in-left{opacity:0;transform:translateX(-40px);transition:opacity .7s ease,transform .7s ease}
.fade-in-left.visible{opacity:1;transform:translateX(0)}
.fade-in-right{opacity:0;transform:translateX(40px);transition:opacity .7s ease,transform .7s ease}
.fade-in-right.visible{opacity:1;transform:translateX(0)}
.scale-in{opacity:0;transform:scale(.92);transition:opacity .6s ease,transform .6s ease}
.scale-in.visible{opacity:1;transform:scale(1)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .g4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .step::after{display:none}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:2rem}
  .split--reverse{direction:ltr}
  .contact-strip{grid-template-columns:repeat(2,1fr)}
  .contact-strip__item+.contact-strip__item::before{display:none}
}
@media(max-width:768px){
  :root{--nav-h:64px}
  .section{padding:4rem 0}
  .container{padding:0 1.2rem}
  .hero__title{font-size:clamp(1.6rem,6vw,2.4rem)}
  .hero__stats{flex-direction:column;gap:1rem}
  .hero__actions{flex-direction:column;align-items:flex-start}
  .navbar__hamburger{display:flex}
  .navbar__menu{
    position:fixed;top:0;right:-100%;width:300px;height:100vh;
    background:var(--white);box-shadow:var(--sh-xl);
    padding:calc(var(--nav-h)+2rem) 1.5rem 2rem;
    transition:right .4s var(--ease);flex-direction:column;z-index:999;
  }
  .navbar__menu.open{right:0}
  .navbar__links{flex-direction:column;align-items:flex-start;gap:4px}
  .navbar__link{font-size:.95rem;padding:10px 14px;width:100%;border-radius:var(--r-md)}
  .navbar__cta{margin-top:1.5rem;margin-left:0}
  .navbar__overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:998}
  .navbar__overlay.active{display:block}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr;gap:1.5rem}
  .step::after{display:none}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr;gap:1.5rem}
  .footer__bottom{flex-direction:column;gap:.75rem;text-align:center}
  .logos{grid-template-columns:repeat(2,1fr)}
  .contact-strip{grid-template-columns:1fr}
  .contact-strip__item+.contact-strip__item::before{display:none}
}
@media(max-width:480px){
  .stats-row{grid-template-columns:1fr}
  .logos{grid-template-columns:1fr 1fr}
}

/* ============================================================
   Redesign Utilities (Bootstrap overrides & enhancements)
   ============================================================ */
.custom-hover-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.custom-hover-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(7, 72, 70, 0.12) !important;
}
.custom-link-hover:hover {
  text-decoration: underline !important;
  color: var(--acc) !important;
}
.custom-link-hover i {
  transition: transform 0.3s ease;
}
.custom-link-hover:hover i {
  transform: translateX(4px);
}

/* Premium Navbar Links */
.nav-hover-line {
  position: relative;
  transition: color 0.3s ease;
  color: var(--pri) !important;
}
.nav-hover-line::after {
  content: '';
  position: absolute;
  width: 0;
  height: 2px;
  bottom: 0px;
  left: 50%;
  background-color: var(--gold);
  transition: all 0.3s ease;
  transform: translateX(-50%);
}
.nav-hover-line:hover::after, .active-nav-line::after {
  width: 80%;
}
.active-nav-line {
  color: var(--acc) !important;
}

.icon-gold {
  background-color: var(--gold-l);
  color: var(--gold);
}
.tracking-tight { letter-spacing: -0.02em; }
.tracking-wider { letter-spacing: 0.05em; }
.leading-tight { line-height: 1.15; }
.process-step {
  border: 1px solid var(--g100);
  border-radius: 1rem;
  transition: all 0.3s ease;
}
.process-step:hover {
  box-shadow: 0 16px 40px rgba(7, 72, 70, 0.08);
  border-color: rgba(64, 171, 164, 0.3);
}
.process-step-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 1.25rem;
  margin: 0 auto 1.5rem;
  transition: transform 0.3s ease;
  position: relative;
  z-index: 10;
}
.process-step:hover .process-step-icon {
  transform: scale(1.1);
}

/* Incredible Senior Management - Modern Executive Style */
.leadership-card {
  display: flex;
  background: var(--white);
  border-radius: 1.5rem;
  padding: 3rem;
  margin-bottom: 4rem;
  gap: 4rem;
  align-items: center;
  box-shadow: 0 15px 45px rgba(7, 72, 70, 0.05);
  border: 1px solid rgba(7, 72, 70, 0.03);
  transition: all 0.4s var(--ease);
  position: relative;
}
.leadership-card:hover {
  transform: translateX(10px);
  box-shadow: 0 25px 65px rgba(7, 72, 70, 0.1);
  border-color: var(--acc-pale);
}
.leadership-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; width: 4px; height: 100%;
  background: var(--acc);
  border-radius: 4px 0 0 4px;
  opacity: 0;
  transition: opacity 0.4s var(--ease);
}
.leadership-card:hover::before {
  opacity: 1;
}
.leadership-card__img-container {
  flex: 0 0 260px;
  height: 320px;
  position: relative;
}
.leadership-card__img {
  width: 100%;
  height: 100%;
  border-radius: 1.25rem;
  overflow: hidden;
  box-shadow: 12px 12px 0 var(--acc-pale);
  transition: all 0.4s var(--ease);
  background: var(--g50);
}
.leadership-card:hover .leadership-card__img {
  transform: translate(-8px, -8px);
  box-shadow: 20px 20px 0 rgba(64, 171, 164, 0.15);
}
.leadership-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.leadership-card__content {
  flex: 1;
}
.leadership-card__name {
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--pri);
  margin-bottom: 0.4rem;
  letter-spacing: -0.5px;
}
.leadership-card__role {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--acc);
  text-transform: uppercase;
  letter-spacing: 2.5px;
  margin-bottom: 1.8rem;
  display: block;
}
.leadership-card__bio {
  font-size: 1.1rem;
  line-height: 1.9;
  color: var(--muted);
  max-width: 95%;
}
.leadership-card__bio {
  font-size: 1.1rem;
  line-height: 1.85;
  color: var(--muted);
  font-weight: 400;
  max-width: 90%;
}

/* Incredible Board Cards */
.board-card {
  display: flex;
  gap: 3rem;
  margin-bottom: 5rem;
  align-items: center;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.board-card__av-container {
  flex: 0 0 200px;
  position: relative;
}
.board-card__av {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  overflow: hidden;
  border: 6px solid var(--white);
  box-shadow: var(--sh-lg);
  position: relative;
  z-index: 2;
}
.board-card__av img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.board-card__decoration {
  position: absolute;
  inset: -15px;
  border: 1px dashed var(--gold);
  border-radius: 50%;
  opacity: 0.4;
  animation: rotate 20s linear infinite;
}
@keyframes rotate { from { transform: rotate(0); } to { transform: rotate(360deg); } }

.board-card__content {
  flex: 1;
}
.board-card__name {
  font-size: 1.7rem;
  font-weight: 900;
  color: var(--pri);
  margin-bottom: 0.25rem;
}
.board-card__role {
  font-size: 1rem;
  font-weight: 600;
  color: var(--acc);
  margin-bottom: 1.5rem;
  display: block;
}
.board-card__bio {
  font-size: 1.05rem;
  line-height: 1.8;
  color: var(--muted);
  position: relative;
  padding-left: 1.5rem;
  border-left: 3px solid var(--gold-l);
}

@media (max-width: 991px) {
  .leadership-card {
    flex-direction: column;
  }
  .leadership-card__img-side {
    flex: 0 0 350px;
  }
  .leadership-card__info-side {
    padding: 2.5rem 2rem;
  }
  .board-card {
    flex-direction: column;
    text-align: center;
  }
  .board-card__bio {
    padding-left: 0;
    border-left: none;
    border-top: 3px solid var(--gold-l);
    padding-top: 1.5rem;
  }
}

/* Statement Split (Mission/Vision 2.0) */
.statement-split {
  display: flex;
  align-items: center;
  gap: 0;
  overflow: hidden;
  border-radius: 2rem;
  background: var(--white);
  box-shadow: 0 30px 60px -12px rgba(7, 72, 70, 0.12);
  margin-bottom: 4rem;
  min-height: 500px;
}
.statement-split--rev {
  flex-direction: row-reverse;
}
.statement-split__img {
  flex: 1;
  height: 500px;
  position: relative;
}
.statement-split__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.statement-split__content {
  flex: 1;
  padding: 4rem 5rem;
  position: relative;
}
.statement-split__icon {
  width: 80px;
  height: 80px;
  background: var(--acc-pale);
  color: var(--pri);
  border-radius: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin-bottom: 2.5rem;
  box-shadow: 0 10px 20px rgba(7, 72, 70, 0.05);
}
.statement-split--gold .statement-split__icon {
  background: var(--gold-l);
  color: var(--gold);
}
.statement-split__title {
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--pri);
  margin-bottom: 1.5rem;
  letter-spacing: -1px;
}
.statement-split__text {
  font-size: 1.15rem;
  line-height: 1.9;
  color: var(--muted);
  font-weight: 400;
}

/* Premium Goal List (Replaces Goal Cards) */
.goal-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  max-width: 900px;
  margin: 0 auto;
}
.goal-item {
  display: flex;
  align-items: flex-start;
  gap: 2rem;
  padding: 2.5rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 1.5rem;
  transition: all 0.4s var(--ease);
}
.goal-item:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: var(--gold);
  transform: translateX(10px);
}
.goal-item__num {
  font-size: 3rem;
  font-weight: 900;
  color: var(--gold);
  opacity: 0.3;
  line-height: 1;
}
.goal-item:hover .goal-item__num {
  opacity: 1;
}
.goal-item__content {
  flex: 1;
}
.goal-item__title {
  font-size: 1.4rem;
  color: var(--white);
  margin-bottom: 0.5rem;
  font-weight: 700;
}
.goal-item__text {
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.6;
  font-size: 1rem;
}

/* Refined Core Values */
.vcard {
  padding: 3rem 2rem;
  border-radius: 1.5rem;
  background: var(--white);
  border: 1px solid rgba(7, 72, 70, 0.05);
  transition: all 0.4s var(--ease);
  text-align: center;
  height: 100%;
}
.vcard:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 40px rgba(7, 72, 70, 0.08);
  border-color: var(--acc-pale);
}
.vcard__icon {
  width: 64px;
  height: 64px;
  background: var(--g50);
  color: var(--pri);
  border-radius: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin: 0 auto 2rem;
  transition: all 0.4s var(--ease);
}
.vcard:hover .vcard__icon {
  background: var(--pri);
  color: var(--white);
  transform: rotate(10deg);
}

@media (max-width: 991px) {
  .statement-split {
    flex-direction: column !important;
    min-height: auto;
  }
  .statement-split__img {
    height: 350px;
    width: 100%;
  }
  .goal-item {
    flex-direction: column;
    gap: 1rem;
    padding: 2rem;
  }
}

/* Compact Mission/Vision Boxes */
.mv-box {
  background: var(--white);
  padding: 2rem;
  border-radius: 1.5rem;
  border: 1px solid rgba(7, 72, 70, 0.05);
  height: 100%;
  transition: all 0.4s var(--ease);
  box-shadow: var(--sh-md);
  display: flex;
  flex-direction: column;
}
.mv-box:hover {
  transform: translateY(-5px);
  box-shadow: var(--sh-lg);
  border-color: var(--acc-pale);
}
.mv-box__icon {
  width: 54px;
  height: 54px;
  background: var(--acc-pale);
  color: var(--acc);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  font-size: 1.4rem;
  margin-bottom: 1.5rem;
  flex-shrink: 0;
}
.mv-box--gold .mv-box__icon {
  background: #fdf8e7;
  color: var(--gold);
}
.mv-box__title {
  font-size: 1.5rem;
  font-weight: 800;
  margin-bottom: 1rem;
  color: var(--pri);
}
.mv-box__text {
  font-size: 0.92rem;
  line-height: 1.8;
  color: var(--muted);
  margin: 0;
}

/* Areas of Operation (Premium Pills) */
.area-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1.5rem;
  max-width: 1000px;
  margin: 0 auto;
}
.area-pill {
  padding: 1.25rem 2rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 100px;
  display: flex;
  align-items: center;
  gap: 1.25rem;
  transition: all 0.4s var(--ease);
}
.area-pill:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: var(--gold);
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}
.area-pill i {
  color: var(--gold);
  font-size: 1.1rem;
}
.area-pill__name {
  font-weight: 700;
  color: var(--white);
  font-size: 1.05rem;
}
.area-pill__note {
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.5);
  margin-left: auto;
  font-weight: 500;
}

@media (max-width: 576px) {
  .area-pill {
    padding: 1rem 1.5rem;
  }
  .area-pill__note {
    display: none;
  }
}

/* Mission & Vision Simple Cards (V3) */
.mv-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 2rem;
  max-width: 1100px;
  margin: 0 auto;
}
.mv-simple {
  background: var(--white);
  padding: 3rem;
  border-radius: 1.5rem;
  box-shadow: 0 10px 40px rgba(7, 72, 70, 0.04);
  border: 1px solid rgba(7, 72, 70, 0.06);
  height: 100%;
  transition: all 0.4s var(--ease);
  position: relative;
}
.mv-simple:hover {
  transform: translateY(-8px);
  box-shadow: 0 15px 50px rgba(7, 72, 70, 0.1);
}
.mv-simple--gold { border-top: 5px solid var(--gold); }
.mv-simple--pri { border-top: 5px solid var(--pri); }
.mv-simple__icon {
  width: 4rem;
  height: 4rem;
  background: var(--acc-pale);
  color: var(--pri);
  border-radius: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 2rem;
}
.mv-simple--gold .mv-simple__icon {
  background: rgba(201, 168, 76, 0.15);
  color: var(--gold);
}
.mv-simple__title {
  font-size: 1.5rem;
  font-weight: 800;
  margin-bottom: 1.25rem;
  color: var(--pri);
}
.mv-simple__desc {
  color: var(--text-muted);
  line-height: 1.7;
  font-size: 1rem;
}

/* Who We Are Dual Image Grid */
.who-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-bottom: 3rem;
}
.who-grid__img {
  height: 250px;
  border-radius: 1.5rem;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,0.1);
}
.who-grid__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--ease);
}
.who-grid__img:hover img { transform: scale(1.08); }

@media (max-width: 768px) {
  .who-grid { grid-template-columns: 1fr; }
  .mv-simple { padding: 2rem; }
}

