/* =========================================================
   MAMEMYLY CONSULTING | Design System
   Ingénierie de crédit • Premium institutional aesthetic
   ========================================================= */

/* ---------- Root tokens ---------- */
:root{
  /* Brand */
  --navy-900:#06182B;
  --navy-800:#0B2540;
  --navy-700:#0E2A47;
  --navy-600:#143A5E;
  --navy-500:#1F4E78;

  --emerald-700:#1F7F66;
  --emerald-600:#2A9D7F;
  --emerald-500:#34B493;
  --emerald-300:#7DD3B9;
  --emerald-50:#E8F5EF;

  --gold:#C9A86A;

  /* Neutrals */
  --ink:#0A1422;
  --ink-2:#1A2434;
  --muted:#5B6677;
  --muted-2:#8893A4;
  --line:#E5E9EE;
  --line-2:#EEF1F5;
  --surface:#F7F8FA;
  --surface-2:#FBFCFD;
  --white:#FFFFFF;

  /* Typography */
  --font-sans:'Inter','Manrope',-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;
  --font-display:'Fraunces','Cormorant Garamond',Georgia,serif;

  /* Layout */
  --container:1240px;
  --container-tight:1080px;
  --radius:14px;
  --radius-lg:22px;

  /* Shadow */
  --shadow-sm:0 1px 2px rgba(11,37,64,.06), 0 1px 1px rgba(11,37,64,.04);
  --shadow-md:0 10px 30px -12px rgba(11,37,64,.18), 0 4px 8px rgba(11,37,64,.05);
  --shadow-lg:0 30px 60px -20px rgba(11,37,64,.25), 0 10px 30px -10px rgba(11,37,64,.10);

  /* Easing */
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-bounce:cubic-bezier(.34,1.56,.64,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--white);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}
::selection{background:var(--emerald-600);color:#fff}

/* ---------- Typography ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:var(--emerald-600);
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--emerald-600)}
.eyebrow.light{color:var(--emerald-300)}
.eyebrow.light::before{background:var(--emerald-300)}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;letter-spacing:-.02em;color:var(--navy-700);margin:0}
h1{font-size:clamp(2.6rem,5.6vw,4.6rem);line-height:1.04;font-weight:400}
h2{font-size:clamp(2rem,3.8vw,3.1rem);line-height:1.1}
h3{font-size:clamp(1.35rem,1.8vw,1.6rem);line-height:1.2;letter-spacing:-.015em}
h4{font-size:1.05rem;font-family:var(--font-sans);font-weight:600;letter-spacing:-.01em}
p{margin:0 0 1rem;color:var(--muted)}
strong{color:var(--navy-700);font-weight:600}
.italic{font-style:italic;color:var(--emerald-700)}

/* ---------- Layout ---------- */
.container{width:min(100% - 2.4rem,var(--container));margin-inline:auto}
.container-tight{width:min(100% - 2.4rem,var(--container-tight));margin-inline:auto}
section{padding:7rem 0;position:relative}
@media(max-width:760px){section{padding:4.5rem 0}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.65rem;
  padding:.95rem 1.6rem;border-radius:999px;
  font-weight:600;font-size:.95rem;letter-spacing:.01em;
  transition:transform .35s var(--ease), background .35s var(--ease), color .35s var(--ease), box-shadow .35s var(--ease);
  position:relative;overflow:hidden;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px;transition:transform .35s var(--ease)}
.btn:hover svg{transform:translateX(4px)}

.btn-primary{
  background:var(--navy-700);color:#fff;
  box-shadow:0 10px 30px -10px rgba(14,42,71,.6);
}
.btn-primary:hover{background:var(--navy-800);transform:translateY(-2px);box-shadow:0 16px 36px -10px rgba(14,42,71,.7)}

.btn-accent{
  background:var(--emerald-600);color:#fff;
  box-shadow:0 10px 26px -8px rgba(42,157,127,.55);
}
.btn-accent:hover{background:var(--emerald-700);transform:translateY(-2px);box-shadow:0 16px 36px -10px rgba(42,157,127,.65)}

.btn-ghost{
  background:transparent;color:var(--navy-700);
  border:1px solid var(--line);
}
.btn-ghost:hover{background:var(--navy-700);color:#fff;border-color:var(--navy-700)}

.btn-light{
  background:rgba(255,255,255,.08);color:#fff;
  border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(8px);
}
.btn-light:hover{background:#fff;color:var(--navy-700)}

.btn-text{
  color:var(--navy-700);font-weight:600;padding:.5rem 0;
  border-bottom:1px solid var(--navy-700);border-radius:0;
}
.btn-text:hover{color:var(--emerald-600);border-color:var(--emerald-600)}

/* ---------- Navbar ---------- */
.nav-wrap{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .4s var(--ease)}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 0;
  transition:all .4s var(--ease);
}
.nav-wrap.scrolled{background:rgba(255,255,255,.95);backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--line)}
.nav-wrap.scrolled .nav{padding:.65rem 0}
.nav-wrap.nav-dark .nav-links a,.nav-wrap.nav-dark .brand{color:#fff}
.nav-wrap.nav-dark .nav-burger span{background:#fff}
.nav-wrap.nav-dark.scrolled .nav-links a,.nav-wrap.nav-dark.scrolled .brand{color:var(--ink-2)}
.nav-wrap.nav-dark.scrolled .nav-links a:hover,.nav-wrap.nav-dark.scrolled .nav-links a.active{color:var(--navy-700)}
.nav-wrap.nav-dark.scrolled .nav-burger span{background:var(--navy-700)}

.brand{display:flex;align-items:center;gap:.7rem;color:var(--navy-700);font-weight:700;letter-spacing:.04em;}
.brand-mark{width:48px;height:48px;flex:0 0 48px;border-radius:6px;object-fit:contain}
.brand-text{display:flex;flex-direction:column;line-height:1;font-family:'Montserrat',sans-serif!important;}
.brand-text span{white-space:nowrap;display:block;}
.brand-text .brand-title{font-weight:900;font-size:1.6rem;letter-spacing:0.02em;color:var(--navy-700);line-height:1;}
.brand-text .brand-subtitle{font-weight:600;font-size:1.15rem;letter-spacing:0.25em;color:var(--emerald-600);margin-top:2px;line-height:1;}
.brand-text .brand-tagline{font-weight:500;font-size:0.65rem;letter-spacing:0.05em;color:var(--ink);margin-top:5px;line-height:1;}
.nav-wrap.nav-dark:not(.scrolled) .brand-text .brand-title{color:#fff;}
.nav-wrap.nav-dark:not(.scrolled) .brand-text .brand-tagline{color:rgba(255,255,255,0.8);}
@media(max-width:560px){
  .brand-text .brand-title{font-size:1.4rem;}
  .brand-text .brand-subtitle{font-size:1rem;}
  .brand-text .brand-tagline{font-size:0.55rem;letter-spacing:0.02em;}
}

.nav-links{display:flex;gap:2.2rem;align-items:center}
.nav-links a{
  font-size:.92rem;font-weight:500;color:var(--ink-2);
  position:relative;padding:.4rem 0;transition:color .25s var(--ease);
}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--emerald-600);transform:scaleX(0);transform-origin:right;
  transition:transform .35s var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--navy-700)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);transform-origin:left}
.nav-cta{display:flex;align-items:center;gap:.7rem}

.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem}
.nav-burger span{display:block;width:24px;height:1.5px;background:var(--navy-700);transition:transform .3s var(--ease),opacity .3s}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);background:#fff}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);background:#fff}

.mobile-menu{display:none}
body.menu-open .nav-wrap{background:transparent!important;border-bottom:none!important;backdrop-filter:none!important}
body.menu-open .brand{color:#fff}

@media(max-width:980px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-burger{display:flex}
  .nav-cta{gap:0}
  .mobile-menu{
    display:flex;
    position:fixed;inset:0;
    background:linear-gradient(165deg,var(--navy-800) 0%,var(--navy-700) 50%,#0a1f35 100%);
    color:#fff;z-index:99;flex-direction:column;justify-content:center;align-items:center;
    gap:0;padding:5rem 2rem 3rem;
    opacity:0;pointer-events:none;transform:translateY(-10px);
    transition:opacity .4s var(--ease),transform .4s var(--ease);
  }
  .mobile-menu.open{opacity:1;pointer-events:auto;transform:translateY(0)}
  .mobile-menu a:not(.btn){
    font-family:var(--font-display);font-size:1.6rem;color:rgba(255,255,255,.85);
    font-weight:400;padding:1rem 0;width:100%;text-align:center;
    border-bottom:1px solid rgba(255,255,255,.08);
    transition:color .3s,letter-spacing .3s;
  }
  .mobile-menu a:not(.btn):first-child{border-top:1px solid rgba(255,255,255,.08)}
  .mobile-menu a:not(.btn):hover,.mobile-menu a:not(.btn).active{color:#fff;letter-spacing:.04em}
  .mobile-menu .btn{
    margin-top:2.5rem;width:100%;justify-content:center;
    font-size:1rem;padding:1.1rem 2rem;
  }
}

/* ---------- Hero ---------- */
.hero{
  padding:9.5rem 0 6rem;
  background:
    radial-gradient(60% 80% at 100% 0%,rgba(42,157,127,.08) 0%,rgba(42,157,127,0) 60%),
    radial-gradient(50% 60% at 0% 100%,rgba(14,42,71,.05) 0%,rgba(14,42,71,0) 70%),
    linear-gradient(180deg,#FBFCFD 0%,#F2F5F8 100%);
  position:relative;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(14,42,71,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(14,42,71,.03) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
  pointer-events:none;
}

/* Hero two-column grid */
.hero-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:3rem}}

.hero h1 span.accent{
  background:linear-gradient(120deg,var(--emerald-600) 0%,var(--emerald-500) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-style:italic;font-family:var(--font-display);font-weight:400;
}
.hero-lede{font-size:1.18rem;color:var(--muted);max-width:520px;margin:1.8rem 0 2.2rem;line-height:1.55}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap}

.hero-meta{
  display:flex;gap:2.5rem;margin-top:3.5rem;padding-top:2rem;border-top:1px solid var(--line);
  flex-wrap:wrap;
}
.hero-meta .stat{display:flex;flex-direction:column;gap:.2rem}
.hero-meta .num{font-family:var(--font-display);font-size:2rem;color:var(--navy-700);font-weight:500;letter-spacing:-.02em;line-height:1}
.hero-meta .lbl{font-size:.78rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.14em;font-weight:600}

/* Hero image (legacy) */
.hero-visual{position:relative}
.hero-photo{
  width:100%;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  aspect-ratio:4/3;object-fit:cover;
}
@media(max-width:980px){.hero-photo{aspect-ratio:16/9}}

/* Hero — Centered with blurred background image */
.hero.hero--bg{
  padding:12rem 0 7rem;
  background:var(--navy-900);
  position:relative;overflow:hidden;
}
.hero.hero--bg::before{display:none}
.hero-bg-img{position:absolute;inset:0;z-index:0}
.hero-bg-img img{width:100%;height:100%;object-fit:cover;filter:blur(6px) brightness(.45)}
.hero-center{
  position:relative;z-index:2;
  text-align:center;
  max-width:820px;margin:0 auto;
}
.hero.hero--bg h1{color:#fff}
.hero.hero--bg h1 span.accent{
  background:linear-gradient(120deg,var(--emerald-500) 0%,var(--emerald-300) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-style:italic;font-family:var(--font-display);font-weight:400;
}
.hero.hero--bg .hero-lede{color:rgba(255,255,255,.8);margin:1.8rem auto 2.2rem;max-width:620px}
.hero.hero--bg .hero-cta{justify-content:center}
.hero.hero--bg .hero-meta{
  justify-content:center;border-top-color:rgba(255,255,255,.15);
}
.hero.hero--bg .hero-meta .num{color:#fff}
.hero.hero--bg .hero-meta .lbl{color:rgba(255,255,255,.55)}
@media(max-width:760px){.hero.hero--bg{padding:9rem 0 5rem}}

/* Page hero with background images */
.page-hero-bg{position:absolute;inset:0;z-index:0}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.45}
.page-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(251,252,253,.92) 0%,rgba(242,245,248,.75) 60%,rgba(242,245,248,.55) 100%)}

/* ---------- Trust strip ---------- */
.trust{
  background:var(--navy-700);color:#fff;padding:2.4rem 0;position:relative;overflow:hidden;
}
.trust::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(50% 100% at 50% 100%,rgba(42,157,127,.2),transparent 70%);
}
.trust-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;position:relative}
.trust-lbl{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--emerald-300);font-weight:600}
.trust-stats{display:flex;gap:3.5rem;flex-wrap:wrap}
.trust-stats .stat{display:flex;flex-direction:column}
.trust-stats .num{font-family:var(--font-display);font-size:2.4rem;font-weight:500;letter-spacing:-.02em;line-height:1}
.trust-stats .lbl{font-size:.78rem;color:rgba(255,255,255,.6);letter-spacing:.1em;text-transform:uppercase;margin-top:.3rem}

/* ---------- Section heading ---------- */
.section-head{max-width:780px;margin-bottom:4rem}
.section-head h2{margin-top:1rem}
.section-head p{margin-top:1.2rem;font-size:1.1rem;line-height:1.6}

/* ---------- Pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media(max-width:880px){.pillars{grid-template-columns:1fr!important}}
.pillar{
  padding:2.4rem 2rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  position:relative;overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease);
}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.pillar .num{
  font-family:var(--font-display);font-size:.9rem;color:var(--emerald-600);
  font-weight:500;letter-spacing:.1em;
}
.pillar h3{margin-top:1.4rem;margin-bottom:.8rem}
.pillar p{color:var(--muted);margin:0;font-size:.95rem}
.pillar::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:3px;
  background:linear-gradient(90deg,var(--emerald-600),var(--emerald-500));
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);
}
.pillar:hover::after{transform:scaleX(1)}

/* ---------- Method (numbered timeline) ---------- */
.method{background:var(--surface)}
.method-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:5rem;align-items:flex-start}
@media(max-width:980px){.method-grid{grid-template-columns:1fr;gap:3rem}}

.method-list{display:flex;flex-direction:column;gap:1rem;position:relative}
.method-step{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.6rem 1.8rem;display:grid;grid-template-columns:48px 1fr;gap:1.4rem;align-items:flex-start;
  transition:all .4s var(--ease);cursor:default;
}
.method-step:hover{border-color:var(--emerald-600);box-shadow:var(--shadow-md);transform:translateX(6px)}
.method-step .step-num{
  width:48px;height:48px;border-radius:50%;
  background:var(--navy-700);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:1.1rem;font-weight:500;
  transition:all .4s var(--ease);
}
.method-step:hover .step-num{background:var(--emerald-600);transform:rotate(360deg)}
.method-step h4{color:var(--navy-700);margin:.3rem 0 .35rem;font-size:1.1rem}
.method-step p{margin:0;font-size:.92rem;line-height:1.55}

.method-aside{
  position:sticky;top:120px;
  background:linear-gradient(160deg,var(--navy-800),var(--navy-700));
  color:#fff;border-radius:var(--radius-lg);padding:2.6rem;
  box-shadow:var(--shadow-lg);overflow:hidden;position:relative;
}
.method-aside::before{
  content:"";position:absolute;top:-50%;right:-30%;width:120%;height:120%;
  background:radial-gradient(closest-side,rgba(42,157,127,.35),transparent);
  pointer-events:none;
}
.method-aside .eyebrow{position:relative}
.method-aside h3{color:#fff;margin:1.2rem 0;position:relative;font-size:1.7rem;line-height:1.2}
.method-aside p{color:rgba(255,255,255,.75);position:relative;font-size:.95rem}
.method-aside .quote{
  font-family:var(--font-display);font-style:italic;font-size:1.4rem;
  line-height:1.4;color:#fff;margin:1.5rem 0;position:relative;
}
.method-aside .quote::before{
  content:"\201C";font-size:5rem;line-height:.7;color:var(--emerald-500);
  position:absolute;top:-1rem;left:-1.5rem;font-family:Georgia,serif;
}
.method-aside-author{display:flex;align-items:center;gap:.8rem;margin-top:1.5rem;position:relative}
.method-aside-author .av{
  width:40px;height:40px;border-radius:50%;background:var(--emerald-600);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;
}
.method-aside-author .nm{font-weight:600;color:#fff;font-size:.95rem}
.method-aside-author .rl{font-size:.78rem;color:rgba(255,255,255,.6)}

/* ---------- Services grid ---------- */
.services{position:relative}
.svc-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.4rem}
.svc{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2.2rem;position:relative;overflow:hidden;
  transition:all .5s var(--ease);
  display:flex;flex-direction:column;
}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc-1{grid-column:span 6}
.svc-2{grid-column:span 6}
.svc-3{grid-column:span 4}
.svc-4{grid-column:span 4}
.svc-5{grid-column:span 4}
@media(max-width:980px){.svc{grid-column:span 12!important}}
.svc-tag{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
  font-weight:700;color:var(--emerald-700);
  padding:.35rem .7rem;background:var(--emerald-50);border-radius:999px;
  margin-bottom:1.2rem;align-self:flex-start;
}
.svc-ic{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg,var(--navy-700),var(--navy-600));
  color:#fff;display:flex;align-items:center;justify-content:center;
  margin-bottom:1.4rem;transition:transform .5s var(--ease);
}
.svc:hover .svc-ic{transform:rotate(-6deg) scale(1.08)}
.svc h3{margin-bottom:.7rem}
.svc p{font-size:.93rem;line-height:1.6;margin-bottom:1.2rem;color:var(--muted);flex:1}
.svc-features{list-style:none;padding:0;margin:0 0 1.3rem;display:flex;flex-direction:column;gap:.5rem}
.svc-features li{font-size:.85rem;color:var(--ink-2);display:flex;gap:.55rem;align-items:flex-start;line-height:1.4}
.svc-features li::before{
  content:"";width:5px;height:5px;background:var(--emerald-600);border-radius:50%;
  flex:0 0 5px;margin-top:.55rem;
}
.svc-link{color:var(--navy-700);font-weight:600;font-size:.9rem;display:inline-flex;gap:.4rem;align-items:center;margin-top:auto}
.svc-link svg{width:16px;transition:transform .3s var(--ease)}
.svc:hover .svc-link svg{transform:translateX(4px)}
.svc-link.accent{color:var(--emerald-600)}

/* ---------- Audience ---------- */
.audience{background:var(--surface)}
.aud-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
@media(max-width:880px){.aud-grid{grid-template-columns:1fr}}
.aud-card{
  background:#fff;border-radius:var(--radius-lg);padding:2.6rem;border:1px solid var(--line);
  position:relative;overflow:hidden;transition:all .5s var(--ease);
}
.aud-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.aud-card .ic{
  width:60px;height:60px;border-radius:14px;background:var(--emerald-50);color:var(--emerald-700);
  display:flex;align-items:center;justify-content:center;margin-bottom:1.4rem;
}
.aud-card h3{margin-bottom:.8rem}
.aud-list{list-style:none;padding:0;margin:1.4rem 0 0;display:flex;flex-direction:column;gap:.7rem}
.aud-list li{display:flex;gap:.7rem;align-items:flex-start;font-size:.95rem;color:var(--ink-2)}
.aud-list svg{width:18px;height:18px;color:var(--emerald-600);flex:0 0 18px;margin-top:.15rem}

/* ---------- Process timeline ---------- */
.process-bar{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;
  margin-top:3rem;
}
.process-bar::before{
  content:"";position:absolute;left:5%;right:5%;top:24px;height:2px;
  background:linear-gradient(90deg,var(--emerald-600) 0%,var(--navy-700) 100%);
  opacity:.25;
}
.process-step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 1rem;position:relative}
.process-step .num{
  width:48px;height:48px;border-radius:50%;background:#fff;border:2px solid var(--emerald-600);
  color:var(--navy-700);font-weight:700;font-family:var(--font-display);font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;
  box-shadow:0 0 0 6px #fff;
}
.process-step h4{margin-bottom:.4rem;color:var(--navy-700)}
.process-step p{font-size:.85rem;margin:0}
@media(max-width:760px){
  .process-bar{grid-template-columns:1fr;gap:1.6rem}
  .process-bar::before{display:none}
}

/* ---------- Why us ---------- */
.why{position:relative}
.why-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:5rem;align-items:center}
@media(max-width:980px){.why-grid{grid-template-columns:1fr;gap:3rem}}

.why-features{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:2rem}
@media(max-width:560px){.why-features{grid-template-columns:1fr}}
.why-feat{
  padding:1.3rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  transition:all .4s var(--ease);
}
.why-feat:hover{border-color:var(--emerald-600);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.why-feat .ic{width:36px;height:36px;border-radius:10px;background:var(--emerald-50);color:var(--emerald-700);display:flex;align-items:center;justify-content:center;margin-bottom:.9rem}
.why-feat h4{font-size:.98rem;margin-bottom:.3rem}
.why-feat p{font-size:.83rem;margin:0;line-height:1.5}

.why-visual{position:relative}
.why-card{
  background:#fff;border-radius:var(--radius-lg);padding:2.2rem;border:1px solid var(--line);
  box-shadow:var(--shadow-lg);
}
.compare{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:1.5rem}
.compare-col{padding:1.5rem;border-radius:var(--radius)}
.compare-col.bad{background:#FBF5F4;border:1px solid #F0DEDA}
.compare-col.good{background:linear-gradient(160deg,var(--navy-800),var(--navy-700));color:#fff}
.compare-ttl{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:1rem}
.compare-col.bad .compare-ttl{color:#A85046}
.compare-col.good .compare-ttl{color:var(--emerald-300)}
.compare-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;font-size:.85rem;border-bottom:1px solid rgba(255,255,255,.08)}
.compare-col.bad .compare-row{border-bottom-color:#EBD4CF;color:#7A463F}
.compare-col.good .compare-row{color:rgba(255,255,255,.9)}
.compare-row:last-child{border-bottom:none}
.compare-row b{font-family:var(--font-display);font-weight:500}

/* ---------- Testimonials ---------- */
.testimonials{background:var(--surface);position:relative;overflow:hidden}

.test-rating-badge{display:flex;align-items:center;gap:.6rem;justify-content:center;margin-top:1.2rem}
.test-google-stars{display:flex;gap:.15rem}
.test-google-stars svg{width:18px;height:18px;fill:#FBBC04}
.test-score{font-weight:700;font-size:1.1rem;color:var(--ink)}
.test-count{font-size:.82rem;color:var(--muted-2)}

.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
@media(max-width:880px){.test-grid{grid-template-columns:1fr;gap:1.2rem}}
.test-card{
  padding:2rem;border-radius:var(--radius-lg);
  display:flex;flex-direction:column;gap:1.2rem;position:relative;overflow:hidden;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.test-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}
.test-quote-icon{
  position:absolute;top:1.2rem;right:1.4rem;
  color:var(--emerald-300);opacity:.35;
}
.test-quote-icon svg{width:32px;height:32px}
.test-stars{display:flex;gap:.2rem;color:#FBBC04}
.test-stars svg{width:16px;height:16px;fill:currentColor}
.test-body{
  font-size:.96rem;line-height:1.6;color:var(--ink-2);
  font-family:var(--font-display);font-style:italic;font-weight:400;
}
.test-foot{display:flex;align-items:center;gap:.8rem;padding-top:1rem;border-top:1px solid var(--line-2);margin-top:auto}
.test-foot .av{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--emerald-600),var(--emerald-500));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.95rem;
  box-shadow:0 3px 8px rgba(42,157,127,.25);
}
.test-foot .nm{font-weight:600;font-size:.92rem}
.test-foot .rl{font-size:.78rem;color:var(--muted-2)}

/* ---------- Big CTA ---------- */
.cta-band{
  background:linear-gradient(135deg,var(--navy-800) 0%,var(--navy-700) 50%,var(--navy-600) 100%);
  color:#fff;position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(40% 60% at 80% 30%,rgba(42,157,127,.25),transparent 70%),
    radial-gradient(40% 60% at 20% 80%,rgba(125,211,185,.15),transparent 70%);
}
.cta-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:4rem;align-items:center;position:relative}
@media(max-width:880px){.cta-grid{grid-template-columns:1fr;gap:2rem}}
.cta-band h2{color:#fff;font-size:clamp(2rem,4vw,3rem)}
.cta-band p{color:rgba(255,255,255,.75);font-size:1.1rem;margin-top:1.2rem;max-width:520px}
.cta-actions{display:flex;flex-direction:column;gap:.9rem;align-items:flex-start}
.cta-actions .meta{font-size:.85rem;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:.5rem}
.cta-actions .meta svg{width:16px;color:var(--emerald-300)}

/* ---------- Footer ---------- */
footer{background:var(--navy-900);color:rgba(255,255,255,.7);padding:5rem 0 2rem;position:relative;overflow:hidden}
footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--emerald-600),transparent);
}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.08)}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}}
.foot-brand{display:flex;align-items:center;gap:.7rem;margin-bottom:1.2rem}
.foot-brand-text{display:flex;flex-direction:column;line-height:1;font-family:'Montserrat',sans-serif!important;}
.foot-brand-text span{white-space:nowrap;display:block;}
.foot-brand-text .brand-title{font-weight:900;font-size:1.5rem;letter-spacing:0.02em;color:#fff;line-height:1;}
.foot-brand-text .brand-subtitle{font-weight:600;font-size:1.05rem;letter-spacing:0.25em;color:var(--emerald-500);margin-top:2px;line-height:1;}
.foot-brand-text .brand-tagline{font-weight:500;font-size:0.65rem;letter-spacing:0.05em;color:rgba(255,255,255,0.7);margin-top:5px;line-height:1;}
@media(max-width:560px){
  .foot-brand-text .brand-title{font-size:1.3rem;}
  .foot-brand-text .brand-subtitle{font-size:0.9rem;}
  .foot-brand-text .brand-tagline{font-size:0.55rem;letter-spacing:0.02em;}
}
.foot-about{font-size:.92rem;line-height:1.6;max-width:340px}
footer h5{color:#fff;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;margin:0 0 1.4rem;font-weight:600;font-family:var(--font-sans)}
.foot-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.7rem}
.foot-links a{color:rgba(255,255,255,.65);font-size:.92rem;transition:color .3s var(--ease),padding .3s var(--ease)}
.foot-links a:hover{color:var(--emerald-300);padding-left:4px}
.foot-contact{display:flex;flex-direction:column;gap:.9rem;font-size:.92rem}
.foot-contact div{display:flex;gap:.7rem;align-items:flex-start;color:rgba(255,255,255,.75)}
.foot-contact svg{width:18px;height:18px;color:var(--emerald-500);flex:0 0 18px;margin-top:.15rem}
.foot-contact a{color:rgba(255,255,255,.75)}
.foot-contact a:hover{color:#fff}
.foot-social{display:flex;gap:.7rem;margin-top:1.4rem}
.foot-social a{
  width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.06);color:#fff;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.08);transition:all .3s var(--ease);
}
.foot-social a:hover{background:var(--emerald-600);border-color:var(--emerald-600);transform:translateY(-3px)}
.foot-social svg{width:18px;height:18px}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;font-size:.82rem;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:1rem}
.foot-bot a:hover{color:#fff}
.foot-credit{opacity:.6;font-size:.75rem;letter-spacing:.02em}
.foot-credit a{color:var(--emerald-300);text-decoration:none;font-weight:600}
.foot-credit a:hover{color:#fff}

/* ---------- Page hero (interior) ---------- */
.page-hero{
  padding:11rem 0 5rem;
  background:
    radial-gradient(60% 80% at 100% 0%,rgba(42,157,127,.08) 0%,rgba(42,157,127,0) 60%),
    linear-gradient(180deg,#FBFCFD,#F2F5F8);
  border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(14,42,71,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(14,42,71,.03) 1px,transparent 1px);
  background-size:50px 50px;
  mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
  pointer-events:none;
}
.page-hero-inner{max-width:840px;position:relative;z-index:1}
.crumb{display:flex;gap:.5rem;font-size:.82rem;color:var(--muted-2);margin-bottom:1.4rem;align-items:center}
.crumb a:hover{color:var(--emerald-600)}
.crumb svg{width:12px}
.page-hero h1{margin-top:.8rem;font-size:clamp(2.2rem,4.5vw,3.8rem)}
.page-hero p{margin-top:1.5rem;font-size:1.15rem;line-height:1.6;max-width:680px}

/* ---------- Expertise page ---------- */
.expertise-blocks{display:flex;flex-direction:column;gap:6rem}
.expertise-block{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.expertise-block.reverse{direction:rtl}
.expertise-block.reverse > *{direction:ltr}
@media(max-width:980px){.expertise-block{grid-template-columns:1fr;gap:2.5rem;direction:ltr}}
.expertise-text .eyebrow{margin-bottom:1.2rem}
.expertise-text h2{margin-bottom:1.4rem}
.expertise-text ul{list-style:none;padding:0;margin:1.6rem 0 0;display:flex;flex-direction:column;gap:.8rem}
.expertise-text ul li{display:flex;gap:.8rem;align-items:flex-start;font-size:.97rem;color:var(--ink-2)}
.expertise-text ul li svg{width:20px;color:var(--emerald-600);flex:0 0 20px;margin-top:.15rem}
.expertise-visual{
  background:linear-gradient(160deg,var(--surface),var(--surface-2));
  border-radius:var(--radius-lg);padding:2.5rem;border:1px solid var(--line);
  aspect-ratio:1.1/1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;
}

/* Stats numbers */
.stat-circle{
  width:180px;height:180px;border-radius:50%;
  background:conic-gradient(var(--emerald-600) 0% var(--p,75%),var(--line-2) 0%);
  display:flex;align-items:center;justify-content:center;position:relative;
}
.stat-circle::before{content:"";position:absolute;inset:14px;background:#fff;border-radius:50%}
.stat-circle .val{position:relative;font-family:var(--font-display);font-size:2.6rem;color:var(--navy-700);font-weight:500}

/* ---------- Audit page (form) ---------- */
.audit-wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:4rem;align-items:flex-start}
@media(max-width:980px){.audit-wrap{grid-template-columns:1fr;gap:2rem}}

.form-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2.6rem;box-shadow:var(--shadow-md);
}
.form-progress{display:flex;gap:.4rem;margin-bottom:2rem}
.form-progress span{height:3px;flex:1;background:var(--line-2);border-radius:999px;transition:background .4s var(--ease)}
.form-progress span.active{background:var(--emerald-600)}
.form-step{display:none}
.form-step.active{display:block;animation:fadeStep .4s var(--ease)}
@keyframes fadeStep{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.form-step h3{margin-bottom:.4rem;font-size:1.4rem}
.form-step .sub{color:var(--muted);font-size:.95rem;margin-bottom:1.8rem}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.field label{font-size:.83rem;font-weight:600;color:var(--navy-700);letter-spacing:.02em}
.field input,.field select,.field textarea{
  padding:.85rem 1rem;border:1px solid var(--line);border-radius:10px;background:#fff;
  font-size:.95rem;transition:border-color .25s var(--ease),box-shadow .25s var(--ease);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--emerald-600);box-shadow:0 0 0 4px rgba(42,157,127,.12);
}
.field textarea{resize:vertical;min-height:110px}
.field .hint{font-size:.77rem;color:var(--muted-2)}

.choices{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:1.4rem}
@media(max-width:560px){.choices{grid-template-columns:1fr}}
.choice{
  border:1px solid var(--line);border-radius:12px;padding:1rem 1.1rem;cursor:pointer;
  transition:all .25s var(--ease);display:flex;gap:.8rem;align-items:flex-start;background:#fff;
}
.choice:hover{border-color:var(--emerald-600);background:var(--surface-2)}
.choice input{display:none}
.choice .dot{
  width:18px;height:18px;border-radius:50%;border:2px solid var(--line);flex:0 0 18px;margin-top:.15rem;
  position:relative;transition:all .25s var(--ease);
}
.choice input:checked + .dot{border-color:var(--emerald-600)}
.choice input:checked + .dot::after{content:"";position:absolute;inset:3px;background:var(--emerald-600);border-radius:50%}
.choice:has(input:checked){border-color:var(--emerald-600);background:var(--emerald-50)}
.choice .t{font-size:.95rem;font-weight:600;color:var(--navy-700)}
.choice .s{font-size:.82rem;color:var(--muted)}

.form-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:1.5rem;align-items:center}
.form-back{color:var(--muted);font-weight:500;font-size:.92rem;display:inline-flex;align-items:center;gap:.4rem}
.form-back:hover{color:var(--navy-700)}
.form-back svg{width:14px}

.audit-aside{position:sticky;top:120px;display:flex;flex-direction:column;gap:1.4rem}
.audit-aside .info-card{
  background:linear-gradient(160deg,var(--navy-800),var(--navy-700));color:#fff;
  border-radius:var(--radius-lg);padding:2rem;position:relative;overflow:hidden;
}
.audit-aside .info-card::before{content:"";position:absolute;top:-50%;right:-30%;width:120%;height:120%;background:radial-gradient(closest-side,rgba(42,157,127,.3),transparent)}
.audit-aside .info-card h4{color:#fff;position:relative;margin-bottom:1rem}
.audit-aside .info-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.8rem;position:relative}
.audit-aside .info-card ul li{display:flex;gap:.7rem;align-items:flex-start;font-size:.9rem;color:rgba(255,255,255,.8)}
.audit-aside .info-card svg{width:18px;color:var(--emerald-300);flex:0 0 18px;margin-top:.15rem}

.audit-aside .help-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.6rem;display:flex;gap:1rem;align-items:flex-start}
.audit-aside .help-card .ic{width:42px;height:42px;border-radius:10px;background:var(--emerald-50);color:var(--emerald-700);display:flex;align-items:center;justify-content:center;flex:0 0 42px}
.audit-aside .help-card .ttl{font-weight:600;font-size:.95rem;color:var(--navy-700)}
.audit-aside .help-card .sub{font-size:.82rem;color:var(--muted);margin-top:.2rem}
.audit-aside .help-card a{display:inline-block;margin-top:.4rem;font-size:.85rem;color:var(--emerald-600);font-weight:600}

/* Form submitted state */
.form-done{display:none;text-align:center;padding:2rem 0}
.form-done.show{display:block}
.form-done .ok{width:80px;height:80px;border-radius:50%;background:var(--emerald-50);color:var(--emerald-600);display:inline-flex;align-items:center;justify-content:center;margin-bottom:1.5rem}
.form-done h3{margin-bottom:.8rem;font-size:1.6rem}

/* ---------- Contact page ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem}
@media(max-width:980px){.contact-grid{grid-template-columns:1fr;gap:2.5rem}}
.contact-info{display:flex;flex-direction:column;gap:1.6rem}
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.8rem;
  display:flex;gap:1.2rem;align-items:flex-start;transition:all .35s var(--ease);
}
.contact-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--emerald-600)}
.contact-card .ic{width:48px;height:48px;border-radius:12px;background:var(--emerald-50);color:var(--emerald-700);display:flex;align-items:center;justify-content:center;flex:0 0 48px}
.contact-card h4{margin-bottom:.3rem}
.contact-card a{color:var(--navy-700);font-weight:600}
.contact-card a:hover{color:var(--emerald-600)}
.contact-card p{font-size:.9rem;margin:0;color:var(--muted)}

/* ---------- Solutions page ---------- */
.solutions-grid{display:flex;flex-direction:column;gap:1.5rem}
.solution-row{
  display:grid;grid-template-columns:90px 1fr 1.2fr;gap:3rem;align-items:center;
  padding:2.4rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  transition:all .4s var(--ease);
}
.solution-row:hover{box-shadow:var(--shadow-lg);border-color:transparent;transform:translateY(-3px)}
@media(max-width:880px){.solution-row{grid-template-columns:1fr;gap:1.5rem}}
.solution-num{
  font-family:var(--font-display);font-size:3.5rem;color:var(--emerald-600);font-weight:500;line-height:1;
  letter-spacing:-.04em;
}
.solution-main h3{margin-bottom:.6rem}
.solution-main p{margin:0;font-size:.95rem}
.solution-deliv{display:flex;flex-direction:column;gap:.6rem;border-left:2px solid var(--emerald-600);padding-left:1.4rem}
.solution-deliv .lbl{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--emerald-700);font-weight:700;margin-bottom:.2rem}
.solution-deliv ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}
.solution-deliv li{font-size:.88rem;color:var(--ink-2);display:flex;gap:.5rem;align-items:flex-start}
.solution-deliv li::before{content:"\203A";color:var(--emerald-600);font-weight:700}
.sol-features{list-style:none;padding:0;margin:1rem 0 0;display:flex;flex-wrap:wrap;gap:.5rem}
.sol-features li{font-size:.85rem;padding:.35rem .8rem;background:var(--surface);border-radius:999px;color:var(--ink-2)}

/* ---------- Blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
@media(max-width:980px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.blog-grid{grid-template-columns:1fr}}
.blog-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;transition:all .4s var(--ease);display:flex;flex-direction:column;
}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.blog-img{aspect-ratio:1.5/1;background:linear-gradient(135deg,var(--navy-700),var(--emerald-600));position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#fff}
.blog-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .5s var(--ease)}
.blog-card:hover .blog-img img{transform:scale(1.05)}
.blog-img.v2{background:linear-gradient(135deg,#1F4E78,#2A9D7F)}
.blog-img.v3{background:linear-gradient(135deg,#0E2A47,#143A5E)}
.blog-img.v4{background:linear-gradient(135deg,#2A9D7F,#34B493)}
.blog-img.v5{background:linear-gradient(135deg,#143A5E,#1F7F66)}
.blog-img.v6{background:linear-gradient(135deg,#0B2540,#1F4E78)}
.blog-img svg{width:54px;height:54px;opacity:.4}
.blog-body{padding:1.6rem;display:flex;flex-direction:column;gap:.7rem;flex:1}
.blog-meta{display:flex;gap:.7rem;align-items:center;font-size:.78rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.blog-meta span.tag{color:var(--emerald-600)}
.blog-card h3{font-size:1.15rem;line-height:1.3}
.blog-card p{font-size:.9rem;margin:0;flex:1}
.blog-card .read{color:var(--navy-700);font-weight:600;font-size:.85rem;display:inline-flex;gap:.4rem;align-items:center;margin-top:.5rem}
.blog-card .read svg{width:14px;transition:transform .3s var(--ease)}
.blog-card:hover .read svg{transform:translateX(4px)}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:.1s}
.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}
.reveal.d4{transition-delay:.4s}
.reveal.d5{transition-delay:.5s}

/* ---------- Floating WhatsApp ---------- */
.wa-fab{
  position:fixed;bottom:24px;right:24px;z-index:90;
  width:58px;height:58px;border-radius:50%;background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px -8px rgba(37,211,102,.5);
  transition:transform .35s var(--ease);
}
.wa-fab:hover{transform:scale(1.1)}
.wa-fab svg{width:28px;height:28px}
.wa-fab::before{
  content:"";position:absolute;inset:0;border-radius:50%;
  border:2px solid #25D366;animation:waPulse 2.4s infinite;
}
@keyframes waPulse{0%{transform:scale(1);opacity:.5}100%{transform:scale(1.6);opacity:0}}

/* ---------- Small utility ---------- */
.text-center{text-align:center}
.mt-0{margin-top:0!important}
.divider{height:1px;background:var(--line);margin:5rem 0}

/* ---------- Article pages ---------- */
.article-hero .page-hero-bg::after{background:linear-gradient(180deg,rgba(14,42,71,.85) 0%,rgba(14,42,71,.7) 100%)}
.article-body{max-width:720px;margin:0 auto;font-size:1.05rem;line-height:1.75;color:var(--ink-2)}
.article-body h2{margin:2.5rem 0 1rem;font-size:1.6rem;color:var(--navy-700)}
.article-body h3{margin:2rem 0 .8rem;font-size:1.25rem;color:var(--navy-700)}
.article-body p{margin-bottom:1.2rem}
.article-body ul,.article-body ol{padding-left:1.5rem;margin-bottom:1.5rem}
.article-body li{margin-bottom:.6rem}
.article-body a{color:var(--emerald-600);text-decoration:underline;text-underline-offset:3px}
.article-body a:hover{color:var(--emerald-700)}
.article-intro{font-size:1.2rem;line-height:1.7;color:var(--ink);font-weight:400;border-left:3px solid var(--emerald-600);padding-left:1.2rem;margin-bottom:2.5rem}
.article-cta{margin-top:3rem;padding:2.5rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);text-align:center}
.article-cta h3{margin:0 0 .5rem;font-size:1.3rem}
.article-cta p{color:var(--muted);margin-bottom:1.5rem}

/* ---------- Mobile responsive fixes ---------- */
@media(max-width:680px){
  .hero{padding:7.5rem 0 3.5rem}
  .hero-grid{gap:2rem}
  .hero-content .btn{width:100%;justify-content:center}
  .hero-lede{font-size:1rem}

  .compare{grid-template-columns:1fr;gap:.8rem}

  .test-card{padding:1.5rem}
  .test-quote-icon{display:none}

  .foot-grid{gap:2.5rem}
  .foot-brand{font-size:1.1rem}
  .foot-brand img{width:30px}
  .foot-about{font-size:.85rem}
  .foot-bot{flex-direction:column;align-items:flex-start;gap:.8rem}

  .page-hero{padding:8.5rem 0 3.5rem}
  .page-hero h1{font-size:clamp(1.8rem,7vw,2.6rem)}
  .page-hero p{font-size:1rem;margin-top:1rem}

  .cta-band{padding:4rem 0}
  .cta-grid{gap:2rem}
  .cta-band h2{font-size:clamp(1.6rem,6vw,2.2rem)}

  .process-bar{gap:1.2rem}
  .process-step{padding:0}

  .expertise-block{gap:2rem}
  .expertise-text ul{gap:.6rem}
  .expertise-visual{aspect-ratio:auto;padding:1.8rem;min-height:auto}
  .expertise-visual > div{max-width:100%!important}

  .why-grid{gap:2rem}

  .blog-grid{gap:1.2rem}
  .blog-card .blog-body{padding:1.2rem}

  .solution-row{gap:1.2rem}

  .contact-grid{gap:2rem}
  .contact-card{padding:1.3rem;gap:1rem}
  .contact-card .ic{width:40px;height:40px;flex:0 0 40px}
  .contact-info{gap:1rem}

  .hero-meta{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;justify-items:center;text-align:center}
  .trust-stats{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;justify-items:center;text-align:center}

  .trust-inner{flex-direction:column;gap:1.5rem;text-align:center}

  .wa-fab{width:50px;height:50px;bottom:1.2rem;right:1.2rem}

  .section-head h2{font-size:clamp(1.6rem,6vw,2.2rem)}
}

@media(max-width:420px){
  .container{width:min(100% - 1.6rem,var(--container))}
  h1{font-size:clamp(2.2rem,8vw,3rem)}
  .btn{padding:.85rem 1.3rem;font-size:.88rem}
  .brand-mark{width:38px;height:38px;flex:0 0 38px}
  .brand-text span:first-child{font-size:.85rem}
  .nav{padding:.8rem 0}
}

/* ---------- Print friendly ---------- */
@media print{.nav-wrap,.wa-fab,footer{display:none}}

/* ---------- Testimonial profile photos ---------- */
.av-img{
  width:46px;height:46px;border-radius:50%;object-fit:cover;
  flex:0 0 46px;border:2px solid var(--line)
}
.test-foot{display:flex;align-items:center;gap:.8rem}

/* ---------- Legal pages ---------- */
.legal-content{
  max-width:800px;margin:0 auto;
  font-size:1rem;line-height:1.75;color:var(--ink-2)
}
.legal-content h2{
  font-family:var(--font-display);
  font-size:1.3rem;color:var(--navy-700);
  margin:2.8rem 0 1rem;padding-bottom:.6rem;
  border-bottom:1px solid var(--line)
}
.legal-content h3{
  font-size:1.08rem;color:var(--navy-600);
  margin:2rem 0 .8rem
}
.legal-content ul{
  list-style:none;padding:0;margin:1rem 0
}
.legal-content ul li{
  padding:.4rem 0 .4rem 1.4rem;position:relative
}
.legal-content ul li::before{
  content:'';position:absolute;left:0;top:.85rem;
  width:6px;height:6px;border-radius:50%;
  background:var(--emerald-500)
}
.legal-content table{border-radius:var(--radius);overflow:hidden}
.legal-content p{margin-bottom:1rem}

/* ---------- Section decorative images ---------- */
.section-deco{
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-md)
}
.section-deco img{
  width:100%;height:100%;object-fit:cover;display:block
}

