/* ============================================================
   ADSREVIVE — Global Stylesheet
   Shared across index.html / services.html /
   case-studies.html / contact.html
   ============================================================ */

/* ── RESET ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── CSS VARIABLES ───────────────────────────────────────── */
:root {
  --ink:      #08090D;
  --ink2:     #13151F;
  --ink3:     #1B1E2B;
  --soft:     #6B7090;
  --paper:    #F6F5F1;
  --white:    #FFFFFF;
  --border:   #E3E1D9;
  --a:        #7C3AED;
  --a2:       #9B59F5;
  --a-light:  #EDE9FF;
  --gold:     #F59E0B;
  --green:    #10B981;
  --red:      #EF4444;
  --wa:       #25D366;
  --font:     "Plus Jakarta Sans", sans-serif;
  --container: 1100px;
  --section-v: 5.5rem;
  --ease:     cubic-bezier(0.16, 1, 0.3, 1);
  --r-sm:  8px;
  --r-md:  14px;
  --r-lg:  18px;
  --r-xl:  24px;
}

/* ── BASE ────────────────────────────────────────────────── */
html { scroll-behavior: smooth; }
body { font-family: var(--font); background: var(--white); color: var(--ink); line-height: 1.6; overflow-x: hidden; }
img  { display: block; max-width: 100%; }
a    { text-decoration: none; }
button { font-family: var(--font); cursor: pointer; }
section[id] { scroll-margin-top: 70px; }

/* ── TYPOGRAPHY ──────────────────────────────────────────── */
.eyebrow {
  font-size: 0.68rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--a2); margin-bottom: 0.85rem; display: block;
}
.eyebrow.light  { color: var(--a); }
.eyebrow.muted  { color: rgba(255,255,255,0.35); }
.eyebrow.center { text-align: center; }

h1, h2, h3, h4 { letter-spacing: -0.03em; line-height: 1.12; font-weight: 900; }
h2 { font-size: clamp(1.8rem, 3.4vw, 2.55rem); }
h3 { font-size: clamp(1.1rem, 2vw, 1.25rem); font-weight: 800; }

/* ── LAYOUT ──────────────────────────────────────────────── */
.section     { padding: var(--section-v) 5%; }
.container   { max-width: var(--container); margin: 0 auto; }
.bg-dark     { background: var(--ink); }
.bg-dark2    { background: var(--ink2); }
.bg-paper    { background: var(--paper); }
.bg-white    { background: var(--white); }
.divider     { height: 1px; background: var(--border); }
.divider-dark { height: 1px; background: rgba(255,255,255,.07); }

/* grid helpers */
.grid-2    { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.grid-3    { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
.grid-4    { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; }

/* ── SECTION HEADER ─────────────────────────────────────── */
.section-header               { margin-bottom: 2.75rem; }
.section-header.center        { text-align: center; }
.section-header h2            { margin-bottom: 0; }
.section-header .sub          { color: var(--soft); font-size: .95rem; line-height: 1.8; max-width: 560px; margin-top: .85rem; }
.section-header.center .sub   { margin-left: auto; margin-right: auto; }
.section-header .sub.white    { color: rgba(255,255,255,.48); }
.section-header h2.white      { color: #fff; }

/* ── NAVIGATION ─────────────────────────────────────────── */
.nav {
  position: sticky; top: 0; z-index: 500;
  height: 66px;
  background: rgba(8,9,13,.97);
  border-bottom: 1px solid rgba(255,255,255,.06);
  backdrop-filter: blur(14px);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 5%; gap: 2rem;
}
.nav-logo {
  font-weight: 900; font-size: 1.2rem;
  letter-spacing: -0.04em; color: #FFFFFF !important; flex-shrink: 0;
  text-decoration: none;
}
.nav-logo span { color: var(--a2) !important; -webkit-text-fill-color: initial; }
.nav-links { display: flex; align-items: center; gap: 1.75rem; list-style: none; flex: 1; }
.nav-links a {
  color: rgba(255,255,255,.5); font-size: .82rem; font-weight: 600;
  transition: color .2s; letter-spacing: -.01em;
}
.nav-links a:hover, .nav-links a.active { color: #fff; }
.nav-right { display: flex; align-items: center; gap: .65rem; flex-shrink: 0; }

/* hamburger */
.nav-hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; padding: 6px;
}
.nav-hamburger span {
  display: block; width: 22px; height: 2px;
  background: rgba(255,255,255,.7); border-radius: 2px; transition: all .25s;
}
.nav-hamburger.open span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.nav-hamburger.open span:nth-child(2) { opacity: 0; }
.nav-hamburger.open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }

/* mobile drawer */
.nav-drawer {
  position: fixed; top: 66px; left: 0; right: 0; bottom: 0;
  background: var(--ink); border-top: 1px solid rgba(255,255,255,.07);
  padding: 1.5rem 5%; z-index: 490;
  display: flex; flex-direction: column;
  transform: translateY(-8px); opacity: 0; visibility: hidden;
  transition: transform .28s var(--ease), opacity .28s ease, visibility .28s;
  overflow-y: auto;
}
.nav-drawer.open { visibility: visible; transform: translateY(0); opacity: 1; }
.nav-drawer a {
  color: rgba(255,255,255,.65); font-size: 1.1rem; font-weight: 600;
  padding: 1.25rem 0; border-bottom: 1px solid rgba(255,255,255,.06);
  transition: color .2s;
}
.nav-drawer a:hover { color: #fff; }
.drawer-ctas { display: flex; gap: .65rem; margin-top: 1.25rem; flex-wrap: wrap; }

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: .45rem;
  font-weight: 700; font-size: .82rem; border-radius: var(--r-sm);
  border: none; transition: all .2s; line-height: 1; white-space: nowrap;
  font-family: var(--font);
}
/* Primary */
.btn-primary { background: var(--a); color: #fff; padding: .58rem 1.15rem; }
.btn-primary:hover { background: var(--a2); transform: translateY(-1px); box-shadow: 0 8px 22px rgba(124,58,237,.28); }
/* Primary large */
.btn-primary-lg { background: var(--a); color: #fff; padding: .95rem 2rem; font-size: .95rem; border-radius: 10px; }
.btn-primary-lg:hover { background: var(--a2); transform: translateY(-2px); box-shadow: 0 12px 32px rgba(124,58,237,.32); }
/* WhatsApp */
.btn-wa { background: rgba(37,211,102,.1); border: 1px solid rgba(37,211,102,.25); color: var(--wa); padding: .58rem 1rem; }
.btn-wa:hover { background: rgba(37,211,102,.18); }
/* WhatsApp large */
.btn-wa-lg { background: rgba(37,211,102,.12); border: 1px solid rgba(37,211,102,.28); color: var(--wa); padding: .95rem 1.7rem; font-size: .92rem; border-radius: 10px; }
.btn-wa-lg:hover { background: rgba(37,211,102,.2); transform: translateY(-2px); }
/* Ghost */
.btn-ghost { background: transparent; border: 1px solid rgba(255,255,255,.2); color: rgba(255,255,255,.75); padding: .58rem 1.15rem; }
.btn-ghost:hover { border-color: rgba(255,255,255,.5); color: #fff; }
/* WhatsApp block */
.btn-wa-block {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  background: var(--wa); color: #fff; padding: .85rem; border-radius: var(--r-sm);
  font-weight: 700; font-size: .87rem; font-family: var(--font); transition: all .2s;
}
.btn-wa-block:hover { background: #1DAB56; transform: translateY(-1px); }

/* ── HERO (home) ─────────────────────────────────────────── */
.hero {
  min-height: 93vh; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 7rem 5% 4rem; position: relative;
  overflow: hidden; text-align: center; background: var(--ink);
}
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(124,58,237,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124,58,237,.07) 1px, transparent 1px);
  background-size: 50px 50px;
  mask-image: radial-gradient(ellipse 80% 75% at 50% 35%, black 30%, transparent 100%);
  animation: gridDrift 32s linear infinite;
}
@keyframes gridDrift { 100% { background-position: 50px 50px, 50px 50px; } }
.hero-glow {
  position: absolute; top: -12%; left: 50%; transform: translateX(-50%);
  width: 780px; height: 560px;
  background: radial-gradient(ellipse, rgba(124,58,237,.2) 0%, transparent 65%);
  pointer-events: none; animation: glowBreathe 7s ease-in-out infinite;
}
@keyframes glowBreathe {
  0%,100% { opacity: 1; transform: translateX(-50%) scale(1); }
  50%      { opacity: .65; transform: translateX(-50%) scale(1.08); }
}
.hero-mesh { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.mesh-orb {
  position: absolute; border-radius: 50%;
  filter: blur(60px); opacity: .26;
  animation: meshFloat 15s ease-in-out infinite;
}
.mesh-orb.m1 { width:280px;height:280px;background:radial-gradient(circle,rgba(124,58,237,.5),transparent 70%);top:8%;left:6%; }
.mesh-orb.m2 { width:240px;height:240px;background:radial-gradient(circle,rgba(16,185,129,.4),transparent 70%);bottom:10%;right:8%;animation-delay:3s; }
@keyframes meshFloat { 50% { transform: translate(22px,-18px) scale(1.05); } }
.particles { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.particle { position:absolute;border-radius:50%;background:rgba(255,255,255,.4);animation:rise linear infinite; }
@keyframes rise {
  0%{transform:translateY(0);opacity:0;} 10%{opacity:.5;}
  90%{opacity:.35;} 100%{transform:translateY(-92vh) translateX(16px);opacity:0;}
}
.hero-inner { position: relative; z-index: 1; max-width: 860px; }
.hero-tag {
  display: inline-flex; align-items: center; gap: .5rem;
  background: rgba(124,58,237,.15); border: 1px solid rgba(124,58,237,.3);
  color: var(--a2); font-size: .72rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  padding: .38rem 1rem; border-radius: 100px; margin-bottom: 1.75rem;
  opacity: 0; animation: fadeSoft .75s ease forwards;
}
.blink-dot { width:6px;height:6px;border-radius:50%;background:var(--green);animation:blink 2s infinite;display:inline-block; }
@keyframes blink { 50% { opacity: .3; } }
.hero h1 {
  font-weight: 900; font-size: clamp(2.1rem,5vw,3.7rem);
  line-height: 1.1; letter-spacing: -.04em; color: #fff;
  margin-bottom: 1.4rem; opacity: 0;
}
.hero h1.reveal { opacity: 1; }
.hero h1 .line { display:block;opacity:0;transform:translateY(20px);animation:lineUp .85s cubic-bezier(.16,1,.3,1) forwards; }
.hero h1.reveal .line:nth-child(1){animation-delay:.05s;}
.hero h1.reveal .line:nth-child(2){animation-delay:.18s;}
.hero h1.reveal .line:nth-child(3){animation-delay:.31s;}
@keyframes lineUp { to { opacity:1;transform:translateY(0); } }
.hero h1 .c-gold  { color: var(--gold); }
.hero h1 .c-green { color: var(--green); }
.hero-sub {
  font-size: 1.05rem; color: rgba(255,255,255,.52); line-height: 1.85;
  max-width: 620px; margin: 0 auto 2.25rem;
  opacity: 0; animation: fadeSoft .75s ease forwards; animation-delay: .6s;
}
@keyframes fadeSoft { from{transform:translateY(12px);opacity:0;} to{opacity:1;transform:translateY(0);} }
.hero-proof-row {
  display: flex; justify-content: center; gap: 1.75rem; flex-wrap: wrap;
  margin-bottom: 2.25rem; opacity: 0; animation: fadeSoft .75s ease forwards; animation-delay: .72s;
}
.proof-item { font-size: .8rem; color: rgba(255,255,255,.45); display: flex; align-items: center; gap: .4rem; }
.check { color: var(--green); font-weight: 800; }
.hero-btns {
  display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap;
  margin-bottom: 1.1rem; opacity: 0; animation: fadeSoft .75s ease forwards; animation-delay: .84s;
}
.hero-note { font-size: .74rem; color: rgba(255,255,255,.28); opacity:0;animation:fadeSoft .75s ease forwards;animation-delay:.95s; }
.scroll-cue {
  margin-top:2.25rem;display:flex;flex-direction:column;align-items:center;gap:.4rem;
  opacity:0;animation:fadeSoft .75s ease forwards,cueBob 2.4s ease-in-out infinite;
  animation-delay:1.05s,1.3s;
}
.scroll-cue span { font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.3); }
.scroll-cue svg { width:14px;height:14px;color:rgba(255,255,255,.3); }
@keyframes cueBob { 50% { transform: translateY(6px); } }

/* ── PAGE HERO (inner pages) ─────────────────────────────── */
.page-hero {
  background: var(--ink); padding: 5.5rem 5% 4rem;
  position: relative; overflow: hidden; text-align: center;
}
.page-hero-grid {
  position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(124,58,237,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(124,58,237,.055) 1px,transparent 1px);
  background-size:48px 48px;
}
.page-hero-glow {
  position:absolute;top:-10%;left:50%;transform:translateX(-50%);
  width:600px;height:400px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(124,58,237,.18) 0%,transparent 65%);pointer-events:none;
}
.page-hero-inner { max-width:720px;margin:0 auto;position:relative;z-index:1; }
.page-tag {
  display:inline-flex;align-items:center;gap:.45rem;
  background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);
  color:#6EE7B7;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:.3rem .85rem;border-radius:100px;margin-bottom:1.4rem;
}
.page-hero h1 { font-weight:900;font-size:clamp(1.9rem,4vw,3rem);letter-spacing:-.04em;color:#fff;margin-bottom:1rem; }
.page-hero p  { font-size:1rem;color:rgba(255,255,255,.5);line-height:1.8;max-width:580px;margin:0 auto; }

/* ── SERVICE JUMP LINKS ──────────────────────────────────── */
.service-jumps {
  display:flex;justify-content:center;gap:.65rem;flex-wrap:wrap;margin-top:1.75rem;
}
.sj-link {
  display:inline-flex;align-items:center;gap:.38rem;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.65);font-size:.78rem;font-weight:600;
  padding:.45rem .95rem;border-radius:100px;transition:all .2s;
}
.sj-link:hover { background:rgba(124,58,237,.18);border-color:rgba(124,58,237,.35);color:#fff; }

/* ── TRUST STRIP ─────────────────────────────────────────── */
.trust-strip {
  background:var(--ink2);padding:2.75rem 5%;
  border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05);
}
.trust-inner {
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center;
}
.trust-num { font-weight:900;font-size:2rem;color:#fff;letter-spacing:-.035em; }
.trust-num span { color:var(--a2); }
.trust-label { font-size:.73rem;color:rgba(255,255,255,.38);margin-top:.3rem; }

/* ── PAIN SECTION ────────────────────────────────────────── */
.pain-inner { max-width:840px;margin:0 auto; }
.pain-checklist { display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin:1.75rem 0; }
.pain-chip {
  display:flex;gap:.55rem;align-items:flex-start;font-size:.87rem;color:#2A2D3A;
  background:rgba(239,68,68,.04);border:1px solid rgba(239,68,68,.14);
  border-radius:var(--r-sm);padding:.8rem 1rem;
}
.pain-chip .x { color:var(--red);font-weight:800;flex-shrink:0;margin-top:.05rem; }
.pain-letter {
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:2.5rem;margin-top:2rem;
}
.pain-letter p { font-size:1rem;color:#2A2D3A;line-height:1.95;margin-bottom:1.1rem; }
.pain-letter p.lead { font-size:1.08rem;font-weight:600; }
.pain-letter strong { color:var(--ink); }
.pain-sign { margin-top:1.75rem;padding-top:1.5rem;border-top:1px solid var(--border); }
.pain-sign .name { font-weight:800;font-size:.95rem; }
.pain-sign .role { font-size:.8rem;color:var(--soft); }

/* ── SERVICE CARDS (home) ────────────────────────────────── */
.serv-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.5rem; }
.serv-card {
  border:1px solid var(--border);border-radius:var(--r-lg);padding:1.9rem;
  transition:all .25s;position:relative;background:var(--white);display:flex;flex-direction:column;
}
.serv-card:hover { border-color:rgba(124,58,237,.3);transform:translateY(-3px);box-shadow:0 12px 32px rgba(124,58,237,.08); }
.serv-icon { width:48px;height:48px;border-radius:12px;background:var(--a-light);display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--a);margin-bottom:1.1rem; }
.serv-card h3 { margin-bottom:.55rem; }
.serv-card p  { font-size:.85rem;color:var(--soft);line-height:1.75;flex:1; }
.serv-list { margin-top:.9rem;display:flex;flex-direction:column;gap:.38rem; }
.serv-list span { font-size:.78rem;color:#2A2D3A;display:flex;align-items:center;gap:.45rem; }
.serv-list .ck { color:var(--green);font-weight:800; }
.serv-more {
  display:flex;align-items:center;gap:.35rem;font-size:.78rem;
  font-weight:700;color:var(--a);margin-top:1.25rem;transition:gap .2s;
}
.serv-card:hover .serv-more { gap:.55rem; }

/* ── STACK / OFFER (dark) ────────────────────────────────── */
.stack-inner { max-width:900px;margin:0 auto; }
.stack-items { margin-top:2.5rem; }
.stack-item {
  display:flex;gap:1.1rem;background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);border-radius:var(--r-md);
  padding:1.4rem 1.6rem;margin-bottom:.85rem;transition:all .25s;
}
.stack-item:hover { transform:translateX(4px);border-color:rgba(124,58,237,.3); }
.si-icon { width:38px;height:38px;border-radius:9px;background:rgba(124,58,237,.15);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--a2);flex-shrink:0; }
.si-body { flex:1; }
.si-head { display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:.35rem; }
.si-name { font-weight:700;font-size:.92rem;color:#fff; }
.si-tag  { font-size:.67rem;font-weight:700;background:#DCFCE7;color:#166534;padding:.16rem .6rem;border-radius:20px; }
.si-desc { font-size:.83rem;color:rgba(255,255,255,.42);line-height:1.7; }
.stack-note {
  background:rgba(124,58,237,.07);border:1px solid rgba(124,58,237,.2);
  border-radius:var(--r-md);padding:1.1rem 1.4rem;margin-top:1.25rem;
  font-size:.83rem;color:rgba(255,255,255,.52);line-height:1.8;
}
.stack-note strong { color:#fff; }

/* ── RESULTS CARDS ───────────────────────────────────────── */
.res-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.5rem; }
.rc-link { text-decoration:none;color:inherit;display:block; }
.rc {
  background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:1.75rem;transition:all .25s;cursor:pointer;height:100%;
}
.rc:hover { border-color:rgba(124,58,237,.35);transform:translateY(-4px);box-shadow:0 16px 40px rgba(124,58,237,.1); }
.rc-cat   { font-size:.73rem;font-weight:700;color:var(--a);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.85rem; }
.rc-num   { font-weight:900;font-size:2.1rem;letter-spacing:-.04em;color:var(--ink);line-height:1; }
.rc-num span { color:var(--a); }
.rc-label { font-size:.81rem;color:var(--soft);margin-top:.35rem; }
.rc-badge { display:inline-block;margin-top:.85rem;font-size:.73rem;font-weight:700;color:#0E7C5E;background:#E8F9F1;padding:.24rem .65rem;border-radius:20px; }
.rc-bar   { height:4px;background:var(--border);border-radius:10px;margin-top:1rem;overflow:hidden; }
.rc-fill  { height:100%;background:linear-gradient(90deg,var(--a),var(--a2));border-radius:10px;transition:width 1.4s cubic-bezier(.16,1,.3,1); }
.rc-more  { display:flex;align-items:center;gap:.35rem;font-size:.77rem;font-weight:700;color:var(--a);margin-top:1rem;transition:gap .2s; }
.rc:hover .rc-more { gap:.55rem; }
.res-cta  { text-align:center;margin-top:2.5rem; }

/* ── PROCESS ─────────────────────────────────────────────── */
.process-section { padding: var(--section-v) 5%; position:relative;overflow:hidden; }
.process-section::before {
  content:"";position:absolute;top:10%;left:-5%;width:420px;height:420px;
  border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,.1),transparent 70%);pointer-events:none;
}
.proc-inner { max-width:1100px;margin:0 auto;position:relative; }
.proc-track { margin-top:3.5rem;display:flex;flex-direction:column;gap:0; }
.proc-row {
  display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;
  align-items:center;padding:3rem 0;position:relative;
}
.proc-row:not(:last-child) { border-bottom:1px solid rgba(255,255,255,.06); }
.proc-row.flip { direction:rtl; }
.proc-row.flip > * { direction:ltr; }
.proc-visual { position:relative;height:280px;display:flex;align-items:center;justify-content:center; }
.proc-mock   { position:relative;width:100%;max-width:340px; }
.mock-card   { background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.35);transition:transform .4s var(--ease); }
.proc-row:hover .mock-card { transform:translateY(-6px); }
.mock-head { padding:.7rem 1rem;font-size:.72rem;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:space-between; }
.mock-head.orange { background:linear-gradient(90deg,#F59E0B,#F97316); }
.mock-head.purple { background:linear-gradient(90deg,var(--a),var(--a2)); }
.mock-head.teal   { background:linear-gradient(90deg,#0EA5E9,#06B6D4); }
.mock-head.green  { background:linear-gradient(90deg,#10B981,#34D399); }
.mock-body { padding:1.25rem;background:rgba(255,255,255,.02); }
/* audit rows */
.audit-row { display:flex;align-items:center;gap:.6rem;padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.06); }
.audit-row:last-child { border-bottom:none; }
.audit-check { width:18px;height:18px;border-radius:5px;background:rgba(16,185,129,.18);border:1px solid rgba(16,185,129,.4);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:.65rem;flex-shrink:0; }
.audit-check.pending { background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.15);color:transparent; }
.audit-label { font-size:.78rem;color:rgba(255,255,255,.6); }
/* target rows */
.target-row { display:flex;justify-content:space-between;align-items:center;padding:.65rem 0;border-bottom:1px solid rgba(255,255,255,.06); }
.target-row:last-child { border-bottom:none; }
.target-label { font-size:.76rem;color:rgba(255,255,255,.45); }
.target-val   { font-size:.85rem;font-weight:800;color:#fff; }
.target-val.green { color:var(--green); }
/* build bars */
.build-item { margin-bottom:.85rem; }
.build-item:last-child { margin-bottom:0; }
.build-top { display:flex;justify-content:space-between;font-size:.74rem;color:rgba(255,255,255,.55);margin-bottom:.4rem; }
.build-bar { height:6px;background:rgba(255,255,255,.07);border-radius:10px;overflow:hidden; }
.build-fill { height:100%;border-radius:10px;background:linear-gradient(90deg,#0EA5E9,#22D3EE);width:0;transition:width 1.2s var(--ease); }
/* chart */
.chart-wrap { position:relative;height:130px; }
.chart-svg  { width:100%;height:100%; }
.chart-stat { position:absolute;top:0;left:0; }
.chart-stat .big   { font-weight:900;font-size:1.5rem;color:#fff;letter-spacing:-.03em; }
.chart-stat .small { font-size:.7rem;color:rgba(255,255,255,.4); }
/* proc text */
.proc-text { padding:0 .5rem; }
.proc-tag  { display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.1rem; }
.num-pill  { width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:900;color:#fff; }
.proc-text h3 { font-weight:900;font-size:1.55rem;color:#fff;letter-spacing:-.03em;margin-bottom:.45rem;line-height:1.2; }
.proc-kicker  { font-size:.83rem;font-weight:700;margin-bottom:.95rem; }
.proc-text p  { font-size:.9rem;color:rgba(255,255,255,.48);line-height:1.85;margin-bottom:1.2rem; }
.proc-feats   { display:grid;grid-template-columns:1fr 1fr;gap:.6rem; }
.proc-feat    { display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:rgba(255,255,255,.62); }
.dot-feat     { width:6px;height:6px;border-radius:50%;flex-shrink:0; }

/* ── TESTIMONIALS ────────────────────────────────────────── */
.tg { display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.5rem; }
.tc { background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);padding:1.6rem;transition:all .25s; }
.tc:hover { border-color:rgba(124,58,237,.3);transform:translateY(-3px); }
.stars { color:var(--gold);font-size:.9rem;margin-bottom:.85rem;letter-spacing:.04em; }
.tc-quote  { font-size:.87rem;color:rgba(255,255,255,.58);line-height:1.85;margin-bottom:1rem; }
.tc-result { font-size:.74rem;font-weight:700;color:var(--green);background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.22);padding:.28rem .7rem;border-radius:20px;display:inline-block;margin-bottom:1rem; }
.tc-author { display:flex;align-items:center;gap:.7rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.07); }
.av { width:36px;height:36px;border-radius:50%;background:var(--a);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.78rem;color:#fff;flex-shrink:0; }
.an { font-weight:700;font-size:.84rem;color:#fff; }
.am { font-size:.72rem;color:rgba(255,255,255,.35); }

/* ── FAQ ─────────────────────────────────────────────────── */
.faq-inner { max-width:900px;margin:0 auto; }
.obj-grid  { display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;margin-top:2.5rem; }
.ob { border:1px solid var(--border);border-radius:var(--r-md);padding:1.4rem 1.6rem;transition:border-color .2s; }
.ob:hover { border-color:rgba(124,58,237,.3); }
.ob-q { font-weight:700;font-size:.91rem;margin-bottom:.52rem;display:flex;align-items:center;gap:.5rem;color:var(--ink); }
.ob-q i { color:var(--a); }
.ob-a { font-size:.84rem;color:var(--soft);line-height:1.8; }

/* ── CTA SECTION ─────────────────────────────────────────── */
.cta-section { padding: var(--section-v) 5%;text-align:center;position:relative;overflow:hidden; }
.cta-glow {
  position:absolute;top:-10%;left:50%;transform:translateX(-50%);
  width:600px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,58,237,.16) 0%,transparent 65%);pointer-events:none;
}
.cta-inner { position:relative;z-index:1;max-width:640px;margin:0 auto; }
.cta-section h2 { color:#fff;margin-bottom:.85rem; }
.cta-section p  { color:rgba(255,255,255,.48);font-size:.95rem;line-height:1.8;margin-bottom:2rem; }
.cta-btns { display:flex;justify-content:center;gap:1rem;flex-wrap:wrap; }
.cta-note { font-size:.74rem;color:rgba(255,255,255,.28);margin-top:1rem; }

/* ── SERVICES PAGE ───────────────────────────────────────── */
.sd-section { padding: var(--section-v) 5%; }
.sd-container { max-width:var(--container);margin:0 auto; }
.sd-layout { display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:start; }
.sd-number {
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.1rem;
}
.sd-pill { width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:900;color:#fff; }
.sd-section h2 { font-size:clamp(1.5rem,2.8vw,2.1rem);margin-bottom:.7rem; }
.sd-section h2.white { color:#fff; }
.sd-intro { font-size:.95rem;color:var(--soft);line-height:1.8;margin-bottom:1.75rem; }
.sd-intro.white { color:rgba(255,255,255,.5); }

/* pain items (services page) */
.sd-pain-list { display:grid;gap:.65rem;margin:1.25rem 0 1.75rem; }
.sd-pain-item {
  background:rgba(239,68,68,.04);border:1px solid rgba(239,68,68,.15);
  border-left:3px solid var(--red);border-radius:var(--r-sm);
  padding:.85rem 1.1rem;font-size:.85rem;color:var(--soft);line-height:1.6;
}
.sd-pain-item strong { color:var(--ink);font-weight:700; }
.sd-pain-item.dark   { background:rgba(239,68,68,.06);color:rgba(255,255,255,.45); }
.sd-pain-item.dark strong { color:#fff; }

/* phase cards */
.sd-phase-grid { display:grid;gap:.85rem;margin:1.25rem 0 1.75rem; }
.sd-phase-card { background:var(--paper);border:1px solid var(--border);border-radius:var(--r-md);padding:1.35rem; }
.sd-phase-card.dark { background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.1); }
.sd-phase-tag { display:inline-block;background:var(--a-light);color:var(--a);font-size:.67rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.22rem .7rem;border-radius:100px;margin-bottom:.6rem; }
.sd-phase-tag.dark { background:rgba(124,58,237,.15);color:var(--a2); }
.sd-phase-card h4 { font-size:.93rem;font-weight:700;color:var(--ink);margin-bottom:.38rem;letter-spacing:-.01em; }
.sd-phase-card.dark h4 { color:#fff; }
.sd-phase-card p  { font-size:.83rem;color:var(--soft);line-height:1.65; }
.sd-phase-card.dark p { color:rgba(255,255,255,.45); }

/* deliverables */
.sd-deliverables { display:flex;flex-direction:column;gap:.55rem;margin:1.25rem 0 1.75rem; }
.sd-deliv { display:flex;align-items:flex-start;gap:.65rem;font-size:.86rem;color:#2A2D3A; }
.sd-deliv.white { color:rgba(255,255,255,.65); }
.sd-deliv-icon { color:var(--green);font-size:.9rem;flex-shrink:0;margin-top:.05rem; }

/* outcome stat row */
.sd-outcomes { display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-top:2rem; }
.sd-outcome-card { background:var(--white);padding:1.35rem 1rem;text-align:center; }
.sd-outcome-card.dark { background:rgba(255,255,255,.04); }
.sd-oc-num   { font-weight:900;font-size:1.55rem;letter-spacing:-.03em;line-height:1.1;margin-bottom:.32rem; }
.sd-oc-label { font-size:.73rem;color:var(--soft);line-height:1.4; }
.sd-outcome-card.dark .sd-oc-label { color:rgba(255,255,255,.4); }

/* service visual mock */
.sd-visual-wrap { position:sticky;top:80px; }
.sd-mock { border-radius:var(--r-lg);overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.1);border:1px solid var(--border);background:var(--white); }
.sd-mock.dark { border-color:rgba(255,255,255,.09);box-shadow:0 24px 60px rgba(0,0,0,.45);background:rgba(255,255,255,.04); }
.sdm-head { padding:.75rem 1.1rem;font-size:.72rem;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:space-between; }
.sdm-body { padding:1.35rem; }
.sdm-body.dark { background:rgba(255,255,255,.02); }
.sdm-row  { display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid var(--border);font-size:.82rem; }
.sdm-row:last-child { border-bottom:none; }
.sdm-row.dark-row { border-color:rgba(255,255,255,.07); }
.sdm-key   { color:var(--soft);font-weight:600; }
.sdm-key.dark   { color:rgba(255,255,255,.45); }
.sdm-val   { font-weight:800;color:var(--ink); }
.sdm-val.dark   { color:#fff; }
.sdm-val.green  { color:var(--green); }
.sdm-bar  { margin:.5rem 0; }
.sdm-bar-label { display:flex;justify-content:space-between;font-size:.73rem;color:var(--soft);margin-bottom:.38rem; }
.sdm-bar-track { height:5px;background:var(--border);border-radius:10px;overflow:hidden; }
.sdm-bar-fill  { height:100%;background:linear-gradient(90deg,var(--a),var(--a2));border-radius:10px; }

/* ── CASE STUDY PAGE ─────────────────────────────────────── */
.cs-list { max-width:980px;margin:0 auto;display:flex;flex-direction:column;gap:1rem; }
.cs-item { border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--white);transition:border-color .2s; }
.cs-item.open { border-color:rgba(124,58,237,.3); }
.cs-head { display:flex;align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;cursor:pointer;user-select:none; }
.cs-thumb { width:64px;height:64px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden; }
.cs-thumb svg { width:100%;height:100%; }
.cs-headtext { flex:1;min-width:0; }
.cs-headtag   { display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.18rem .65rem;border-radius:100px;margin-bottom:.42rem; }
.cs-headtitle { font-size:1rem;font-weight:800;color:var(--ink);letter-spacing:-.01em;line-height:1.3;margin-bottom:.28rem; }
.cs-headmeta  { font-size:.78rem;color:var(--soft); }
.cs-headstat  { flex-shrink:0;text-align:right;padding-right:.75rem;display:none; }
.cs-headstat .num { font-weight:900;font-size:1.3rem;color:var(--a);letter-spacing:-.02em;line-height:1.1; }
.cs-headstat .lbl { font-size:.7rem;color:var(--soft);margin-top:.15rem; }
.cs-chevron { flex-shrink:0;width:32px;height:32px;border-radius:50%;background:var(--paper);display:flex;align-items:center;justify-content:center;transition:transform .3s,background .2s;color:var(--soft); }
.cs-item.open .cs-chevron { transform:rotate(180deg);background:var(--a-light);color:var(--a); }
.cs-body { max-height:0;overflow:hidden;transition:max-height .45s ease; }
.cs-item.open .cs-body { max-height:6000px; }
.cs-body-inner { padding:.5rem 1.5rem 2.25rem;border-top:1px solid var(--border); }
.case-meta { display:flex;gap:1rem;flex-wrap:wrap;font-size:.77rem;color:var(--soft);margin:1.25rem 0 1.5rem; }
.case-meta span { display:flex;align-items:center;gap:.4rem; }
.mdot { width:4px;height:4px;border-radius:50%;background:var(--soft); }
.metric-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin:1rem 0 2rem; }
.metric-card { background:var(--paper);padding:1.35rem 1.1rem;text-align:center; }
.metric-num   { font-weight:900;font-size:1.5rem;letter-spacing:-.03em;line-height:1.1;margin-bottom:.32rem; }
.metric-label { font-size:.73rem;color:var(--soft);line-height:1.4; }
.cs-subhead   { font-size:1rem;font-weight:700;margin-bottom:.6rem;color:var(--ink); }
.cs-body-text { color:var(--soft);font-size:.94rem;line-height:1.75;max-width:760px; }
.cs-pain-list { display:grid;gap:.65rem;margin:1.2rem 0 1.75rem; }
.cs-pain-item { background:rgba(239,68,68,.04);border:1px solid rgba(239,68,68,.16);border-left:3px solid var(--red);border-radius:var(--r-sm);padding:.82rem 1.1rem;font-size:.85rem;color:var(--soft);line-height:1.6; }
.cs-pain-item strong { color:var(--ink);font-weight:700; }
.cs-phase-list { display:grid;gap:.85rem;margin:1.25rem 0 1.75rem; }
.cs-phase-card { background:var(--paper);border:1px solid var(--border);border-radius:var(--r-md);padding:1.35rem; }
.cs-phase-tag  { display:inline-block;background:var(--a-light);color:var(--a);font-size:.67rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.22rem .7rem;border-radius:100px;margin-bottom:.6rem; }
.cs-phase-card h4 { font-size:.93rem;font-weight:700;color:var(--ink);margin-bottom:.38rem;letter-spacing:-.01em; }
.cs-phase-card p  { font-size:.83rem;color:var(--soft);line-height:1.65; }
.ba-table { width:100%;border-collapse:collapse;background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin:1.2rem 0 1.75rem;font-size:.81rem; }
.ba-table th,.ba-table td { padding:.8rem 1rem;text-align:left;border-bottom:1px solid var(--border); }
.ba-table th { background:var(--paper);color:var(--soft);font-weight:700;font-size:.67rem;letter-spacing:.06em;text-transform:uppercase; }
.ba-table td:first-child { color:var(--ink);font-weight:700; }
.ba-table td.before { color:#A8A6A0; }
.ba-table td.after  { color:#0E7C5E;font-weight:600; }
.ba-table tr:last-child td { border-bottom:none; }
.insight-box { background:var(--ink2);border-radius:var(--r-lg);padding:1.75rem;margin-top:.5rem; }
.insight-eyebrow { font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1rem; }
.insight-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem; }
.insight-item h5 { font-size:.87rem;font-weight:700;color:#fff;margin-bottom:.38rem; }
.insight-item p  { font-size:.81rem;color:rgba(255,255,255,.48);line-height:1.6; }

/* ── CONTACT PAGE ────────────────────────────────────────── */
.contact-layout { display:grid;grid-template-columns:1.25fr 1fr;gap:3rem;align-items:start;max-width:var(--container);margin:0 auto; }
.contact-sidebar { display:flex;flex-direction:column;gap:1.25rem; }
.info-card { background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.6rem; }
.info-card-title { font-weight:800;font-size:.9rem;color:var(--ink);margin-bottom:1.1rem; }
.info-row { display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.9rem; }
.info-row:last-child { margin-bottom:0; }
.info-icon { width:34px;height:34px;border-radius:9px;background:var(--a-light);color:var(--a);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.9rem; }
.info-row strong { display:block;color:var(--ink);font-size:.83rem;font-weight:700;margin-bottom:.15rem; }
.info-row span   { font-size:.82rem;color:var(--soft);line-height:1.6; }
.wa-contact-card { background:linear-gradient(135deg,rgba(37,211,102,.07),rgba(37,211,102,.02));border:1px solid rgba(37,211,102,.22);border-radius:var(--r-lg);padding:1.6rem;text-align:center; }
.wa-contact-card h4 { font-size:.95rem;font-weight:700;color:var(--ink);margin-bottom:.5rem; }
.wa-contact-card p  { font-size:.83rem;color:var(--soft);line-height:1.7;margin-bottom:1.1rem; }
.contact-trust { display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center;margin-top:1rem; }
.ct-item { display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--soft); }
.ct-item i { color:var(--green); }

/* ── FORMS ───────────────────────────────────────────────── */
.form-card { background:var(--white);border:1px solid var(--border);border-radius:var(--r-xl);padding:2.25rem;box-shadow:0 12px 40px rgba(0,0,0,.05); }
.fsteps { display:flex;gap:.5rem;margin-bottom:1.75rem; }
.fstep  { flex:1;height:4px;border-radius:4px;background:var(--border);transition:background .3s; }
.fstep.active,.fstep.done { background:var(--a); }
.step-label { font-size:.71rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--a);margin-bottom:1.35rem; }
.f-row   { display:grid;grid-template-columns:1fr 1fr;gap:1rem; }
.f-group { margin-bottom:1.1rem; }
.f-label { display:block;font-size:.81rem;font-weight:600;color:#2A2D3A;margin-bottom:.45rem; }
.f-input,.f-select,.f-textarea {
  width:100%;border:1px solid var(--border);border-radius:var(--r-sm);
  padding:.75rem .95rem;font-family:var(--font);font-size:.87rem;
  color:var(--ink);transition:border-color .2s,box-shadow .2s;background:var(--white);
}
.f-input:focus,.f-select:focus,.f-textarea:focus { outline:none;border-color:var(--a);box-shadow:0 0 0 3px rgba(124,58,237,.08); }
.f-textarea { min-height:90px;resize:vertical; }
.f-radio-group { display:grid;grid-template-columns:1fr 1fr;gap:.6rem; }
.f-radio { border:1px solid var(--border);border-radius:var(--r-sm);padding:.7rem .9rem;display:flex;align-items:center;gap:.55rem;cursor:pointer;transition:all .2s; }
.f-radio:hover { border-color:rgba(124,58,237,.4); }
.f-radio.selected { border-color:var(--a);background:var(--a-light); }
.f-radio input { display:none; }
.f-radio-dot { width:16px;height:16px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;position:relative;transition:border-color .2s; }
.f-radio.selected .f-radio-dot { border-color:var(--a); }
.f-radio.selected .f-radio-dot::after { content:"";position:absolute;inset:2px;border-radius:50%;background:var(--a); }
.f-radio-label { font-size:.81rem;color:#2A2D3A; }
.form-nav { display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;gap:.75rem; }
.btn-next,.btn-submit {
  background:var(--a);color:#fff;border:none;
  padding:.85rem 1.5rem;border-radius:var(--r-sm);font-family:var(--font);
  font-weight:700;font-size:.86rem;display:flex;align-items:center;gap:.5rem;
  transition:all .2s;margin-left:auto;
}
.btn-next:hover,.btn-submit:hover { background:var(--a2);transform:translateY(-1px); }
.btn-back { background:none;border:none;color:var(--soft);font-family:var(--font);font-weight:600;font-size:.84rem;display:flex;align-items:center;gap:.38rem; }
.form-divider { text-align:center;font-size:.75rem;color:var(--soft);margin:1.35rem 0 1rem; }
.btn-wa-form { display:flex;align-items:center;justify-content:center;gap:.5rem;background:rgba(37,211,102,.08);border:1px solid rgba(37,211,102,.25);color:#1A9C53;padding:.8rem;border-radius:var(--r-sm);font-weight:700;font-size:.84rem;transition:all .2s;font-family:var(--font); }
.btn-wa-form:hover { background:rgba(37,211,102,.16); }
.success-state { display:none;text-align:center;padding:1.5rem 0; }
.s-icon { width:56px;height:56px;border-radius:50%;background:#DCFCE7;color:#166534;display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin:0 auto 1.25rem; }
.success-state h3 { font-weight:800;font-size:1.15rem;margin-bottom:.75rem; }
.success-state p  { font-size:.86rem;color:var(--soft);line-height:1.8;margin-bottom:1.25rem; }
.wa-final { display:inline-flex;align-items:center;gap:.5rem;background:var(--wa);color:#fff;padding:.8rem 1.5rem;border-radius:var(--r-sm);font-weight:700;font-size:.84rem;font-family:var(--font); }

/* ── MID-PAGE CTA BANNER ─────────────────────────────────── */
.inline-cta { border:1px solid rgba(124,58,237,.2);border-radius:var(--r-lg);background:rgba(124,58,237,.05);padding:1.75rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.25rem;flex-wrap:wrap;margin-top:3rem; }
.inline-cta p { font-size:.9rem;color:var(--soft);max-width:440px;line-height:1.7; }
.inline-cta.dark { border-color:rgba(124,58,237,.25);background:rgba(124,58,237,.08); }
.inline-cta.dark p { color:rgba(255,255,255,.5); }

/* ── FOOTER ──────────────────────────────────────────────── */
footer {
  background:var(--ink);padding:2.25rem 5%;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1.25rem;border-top:1px solid rgba(255,255,255,.06);
}
.foot-logo { font-weight:900;font-size:1rem;letter-spacing:-.04em;color:#fff; }
.foot-logo span { color:var(--a2); }
.foot-links { display:flex;gap:1.75rem;list-style:none;flex-wrap:wrap; }
.foot-links a { color:rgba(255,255,255,.3);font-size:.75rem;transition:color .2s; }
.foot-links a:hover { color:#fff; }
.foot-right { display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap; }
.footer-copy { color:rgba(255,255,255,.2);font-size:.7rem; }

/* ── SCROLL REVEAL ───────────────────────────────────────── */
.reveal-up { opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal-up.in { opacity:1;transform:translateY(0); }
.reveal-stagger > * { opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease); }
.reveal-stagger.in > * { opacity:1;transform:translateY(0); }
.reveal-stagger.in > *:nth-child(1){transition-delay:.04s;}
.reveal-stagger.in > *:nth-child(2){transition-delay:.1s;}
.reveal-stagger.in > *:nth-child(3){transition-delay:.16s;}
.reveal-stagger.in > *:nth-child(4){transition-delay:.22s;}
.reveal-stagger.in > *:nth-child(5){transition-delay:.28s;}
.reveal-stagger.in > *:nth-child(6){transition-delay:.34s;}

/* ── REDUCED MOTION ──────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;}
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:1024px){
  .sd-layout{ grid-template-columns:1fr; gap:2.5rem; }
  .sd-visual-wrap{ display:none; }
  .sd-outcomes{ grid-template-columns:1fr 1fr; }
}
@media(max-width:900px){
  :root{ --section-v:4rem; }
  .trust-inner{ grid-template-columns:1fr 1fr; }
  .pain-checklist{ grid-template-columns:1fr; }
  .serv-grid{ grid-template-columns:1fr 1fr; }
  .res-grid{ grid-template-columns:1fr; }
  .proc-row,.proc-row.flip{ grid-template-columns:1fr;direction:ltr;gap:1.75rem; }
  .proc-visual{ height:220px; }
  .proc-feats{ grid-template-columns:1fr; }
  .tg{ grid-template-columns:1fr 1fr; }
  .obj-grid{ grid-template-columns:1fr; }
  .nav-links{ display:none; }
  .nav-hamburger{ display:flex; }
  .contact-layout{ grid-template-columns:1fr; }
  .grid-3{ grid-template-columns:1fr 1fr; }
  .grid-4{ grid-template-columns:1fr 1fr; }
  .sd-outcomes{ grid-template-columns:1fr 1fr; }
}
@media(max-width:620px){
  :root{ --section-v:3.5rem; }
  .serv-grid,.tg,.grid-3{ grid-template-columns:1fr; }
  .f-row,.f-radio-group{ grid-template-columns:1fr; }
  .hero-proof-row{ flex-direction:column;align-items:center;gap:.6rem; }
  .trust-inner{ grid-template-columns:1fr 1fr; }
  .cs-headstat{ display:none !important; }
  .grid-2{ grid-template-columns:1fr; }
  .grid-4{ grid-template-columns:1fr 1fr; }
  .sd-outcomes{ grid-template-columns:1fr 1fr; }
  .inline-cta{ flex-direction:column;align-items:flex-start; }
}
@media(min-width:701px){ .cs-headstat{ display:block; } }


    /* Contact Page Specific Styles */
    .contact-hero {
      padding: 160px 5% 80px;
      position: relative;
      background: var(--ink);
      color: #fff;
      overflow: hidden;
      text-align: center;
    }
    .contact-hero h1 {
      font-size: clamp(2.5rem, 5vw, 4rem);
      margin-bottom: 20px;
      line-height: 1.1;
    }
    .contact-hero p {
      font-size: 1.125rem;
      color: rgba(255, 255, 255, 0.7);
      max-width: 600px;
      margin: 0 auto 40px;
    }
    .application-container {
      max-width: 800px;
      margin: -40px auto 80px;
      position: relative;
      z-index: 10;
      padding: 0 5%;
    }
    .app-box {
      background: var(--paper);
      border-radius: 24px;
      padding: 40px;
      box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
      color: var(--ink);
    }
    .form-step {
      display: none;
      animation: fadeIn 0.4s ease forwards;
    }
    .form-step.active {
      display: block;
    }
    @keyframes fadeIn {
      from { opacity: 0; transform: translateY(10px); }
      to { opacity: 1; transform: translateY(0); }
    }
    .step-indicator {
      display: flex;
      justify-content: space-between;
      margin-bottom: 40px;
      position: relative;
    }
    .step-indicator::before {
      content: '';
      position: absolute;
      top: 50%;
      left: 0;
      right: 0;
      height: 2px;
      background: #e2e8f0;
      z-index: 1;
      transform: translateY(-50%);
    }
    .step-dot {
      width: 32px;
      height: 32px;
      border-radius: 50%;
      background: #e2e8f0;
      color: var(--ink);
      display: flex;
      align-items: center;
      justify-content: center;
      font-weight: 700;
      position: relative;
      z-index: 2;
      transition: all 0.3s ease;
    }
    .step-dot.completed {
      background: var(--green);
      color: #fff;
    }
    .step-dot.active {
      background: var(--a);
      color: #fff;
      box-shadow: 0 0 0 4px rgba(124, 58, 237, 0.2);
    }
    .form-group {
      margin-bottom: 24px;
      text-align: left;
    }
    .form-group label {
      display: block;
      font-weight: 600;
      margin-bottom: 8px;
      color: var(--ink);
    }
    .form-group input {
      width: 100%;
      padding: 16px;
      border: 2px solid #e2e8f0;
      border-radius: 12px;
      font-family: inherit;
      font-size: 1rem;
      transition: all 0.3s ease;
      background: #fff;
    }
    .form-group input:focus {
      outline: none;
      border-color: var(--a);
      box-shadow: 0 0 0 4px rgba(124, 58, 237, 0.1);
    }
    .options-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
      gap: 16px;
      margin-bottom: 32px;
    }
    .option-card {
      padding: 20px;
      border: 2px solid #e2e8f0;
      border-radius: 12px;
      cursor: pointer;
      font-weight: 600;
      transition: all 0.3s ease;
      text-align: center;
      background: #fff;
    }
    .option-card:hover {
      border-color: var(--a);
      background: rgba(124, 58, 237, 0.02);
    }
    .option-card.selected {
      border-color: var(--a);
      background: var(--a);
      color: #fff;
    }
    .form-actions {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-top: 32px;
    }
    .btn-back {
      background: none;
      border: none;
      color: #64748b;
      font-weight: 600;
      cursor: pointer;
      display: flex;
      align-items: center;
      gap: 8px;
      font-family: inherit;
      font-size: 1rem;
      transition: color 0.3s ease;
    }
    .btn-back:hover {
      color: var(--ink);
    }
    .success-message {
      text-align: center;
      padding: 40px 0;
      display: none;
    }
    .success-icon {
      width: 64px;
      height: 64px;
      background: var(--green);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: #fff;
      font-size: 32px;
      margin: 0 auto 20px;
    }
    
    .contact-direct {
      padding: 80px 5%;
      background: #fff;
      text-align: center;
    }
    .contact-direct-inner {
      max-width: 600px;
      margin: 0 auto;
    }
    .contact-direct h2 {
      font-size: 2rem;
      margin-bottom: 16px;
    }
    .contact-direct p {
      color: #64748b;
      margin-bottom: 32px;
    }
    .direct-methods {
      display: flex;
      gap: 20px;
      justify-content: center;
      flex-wrap: wrap;
    }
    .method-card {
      flex: 1;
      min-width: 250px;
      padding: 32px;
      background: var(--paper);
      border-radius: 16px;
      text-decoration: none;
      color: var(--ink);
      transition: all 0.3s ease;
    }
    .method-card:hover {
      transform: translateY(-5px);
      box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    }
    .method-card i {
      font-size: 32px;
      margin-bottom: 16px;
      display: inline-block;
    }
    .method-card.wa-method i {
      color: #25D366;
    }
    .method-card.email-method i {
      color: var(--a);
    }
  
  @media(max-width: 768px) {
    body, section, div, h1, h2, h3, p, span {
      max-width: 100vw !important;
      word-wrap: break-word !important;
      overflow-wrap: break-word !important;
    }
    .section, section, .contact-hero, .page-hero {
      padding: 2.5rem 4% !important; /* Prevents side-bleeding */
    }
    h1 { font-size: clamp(1.8rem, 7vw, 2.3rem) !important; }
    h2 { font-size: clamp(1.4rem, 5vw, 1.8rem) !important; }
    h3 { font-size: clamp(1.1rem, 4vw, 1.3rem) !important; }
    
    /* Stack all grids into a single clean column layout */
    .trust-inner, .serv-grid, .res-grid, .options-grid, .grid-2, .grid-3, .grid-4, .sd-layout, .contact-layout {
      grid-template-columns: 1fr !important;
      gap: 1.5rem !important;
    }
    .app-box {
      padding: 20px !important;
      width: 100% !important;
    }
    .nav {
      padding: 0 4% !important;
      justify-content: space-between !important;
    }
    .nav-right {
      display: none !important; /* Safely removes overcrowding up top */
    }
    .nav-hamburger {
      display: flex !important; /* Restores the missing menu button */
    }
    .nav-hamburger span {
      background: #FFFFFF !important; /* High-contrast white */
    }
    html, body {
      max-width: 100% !important;
      overflow-x: hidden !important;
    }
  }