/* ============================================
   DESIGN TOKENS — babylovegrowth palette
   ============================================ */
:root {
  /* Core palette */
  --ink:      #0a0a0a;
  --ink-2:    #111111;
  --ink-3:    #1a1a1a;
  --white:    #ffffff;
  --off-white:#f8f8f6;

  /* Accent — bright orange-coral (BLG primary) */
  --orange:   #FA5C12;
  --orange-2: #ff7a38;
  --orange-dim: rgba(250,92,18,.12);
  --orange-glow: rgba(250,92,18,.22);

  /* Secondary accents */
  --teal:     #0AA98B;
  --teal-dim: rgba(10,169,139,.12);
  --blue:     #2A76F6;
  --blue-dim: rgba(42,118,246,.1);

  /* Text */
  --text:     #0f0f0f;
  --text-2:   #444444;
  --text-3:   #888888;
  --text-inv: rgba(255,255,255,.88);
  --text-inv2:rgba(255,255,255,.5);
  --text-inv3:rgba(255,255,255,.28);

  /* Borders */
  --border:   #e8e8e8;
  --border-dk:rgba(255,255,255,.1);

  /* Fonts */
  --f-head:   'Plus Jakarta Sans', 'Inter', system-ui, sans-serif;
  --f-body:   'Inter', system-ui, sans-serif;
  --f-accent: 'Raleway', 'Plus Jakarta Sans', sans-serif;

  /* Spacing / shape */
  --nav-h:  68px;
  --r-sm:   6px;
  --r-md:   12px;
  --r-lg:   18px;
  --r-xl:   28px;
  --r-full: 9999px;

  /* Shadows */
  --shadow-sm:   0 1px 4px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --shadow-card: 0 4px 20px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.04);
  --shadow-lift: 0 16px 48px rgba(0,0,0,.14), 0 4px 12px rgba(0,0,0,.06);
  --shadow-orange: 0 8px 32px rgba(250,92,18,.28);
  --shadow-glass: 0 8px 40px rgba(0,0,0,.32);

  --tr: 220ms cubic-bezier(.4,0,.2,1);
}

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

/* ============================================
   TYPOGRAPHY
   ============================================ */
h1,h2,h3,h4,h5,h6{
  font-family:var(--f-head);
  font-weight:700;
  line-height:1.12;
  letter-spacing:-.02em;
  color:var(--text);
}
h1{font-size:clamp(2.6rem,5.5vw,5.2rem);letter-spacing:-.03em}
h2{font-size:clamp(1.9rem,3.5vw,3.2rem)}
h3{font-size:clamp(1.2rem,2vw,1.7rem)}
h4{font-size:1.2rem}
p{margin-bottom:1rem;color:var(--text-2);font-size:.95rem;line-height:1.75}
p:last-child{margin-bottom:0}
.lead{font-size:1.1rem;color:var(--text-2);line-height:1.82}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--orange);
  font-family:var(--f-accent);
}
.eyebrow-teal{color:var(--teal)}
.display-num{
  font-family:var(--f-head);font-size:clamp(3rem,8vw,7rem);
  font-weight:800;line-height:1;letter-spacing:-.04em;
}

/* ============================================
   LAYOUT
   ============================================ */
.container   {max-width:1160px;margin:0 auto;padding:0 24px}
.container-sm{max-width:800px;margin:0 auto;padding:0 24px}
.container-lg{max-width:1360px;margin:0 auto;padding:0 32px}
.section     {padding:100px 0}
.section-sm  {padding:64px 0}
.section-xs  {padding:40px 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.flex{display:flex}
.flex-center{display:flex;align-items:center;justify-content:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}
.text-center{text-align:center}
.text-white{color:var(--white) !important}
.text-inv{color:var(--text-inv)}
.text-inv2{color:var(--text-inv2)}
.text-orange{color:var(--orange)}
.text-teal{color:var(--teal)}
.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}.mt-12{margin-top:48px}
.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}.mb-12{margin-bottom:48px}

/* ============================================
   SECTION BACKGROUNDS
   ============================================ */
.bg-white  {background:var(--white)}
.bg-off    {background:var(--off-white)}
.bg-ink    {background:var(--ink)}
.bg-ink2   {background:var(--ink-2)}
.bg-orange {background:var(--orange)}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 28px;border-radius:var(--r-sm);
  font-size:.9rem;font-weight:700;font-family:var(--f-body);
  letter-spacing:.01em;
  transition:all var(--tr);white-space:nowrap;line-height:1.4;
}
/* Primary — orange */
.btn-primary{background:var(--orange);color:var(--white)}
.btn-primary:hover{background:var(--orange-2);transform:translateY(-2px);box-shadow:var(--shadow-orange)}
.btn-primary:active{transform:translateY(0)}

/* Dark button */
.btn-ink{background:var(--text);color:var(--white)}
.btn-ink:hover{background:#222;transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.24)}

/* Orange outline */
.btn-outline-orange{background:transparent;color:var(--orange);border:2px solid var(--orange)}
.btn-outline-orange:hover{background:var(--orange);color:var(--white);box-shadow:var(--shadow-orange)}

/* White outline (on dark bg) */
.btn-ghost-white{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.25)}
.btn-ghost-white:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.06)}

/* Ghost */
.btn-ghost{background:transparent;color:var(--text-2);border:1.5px solid var(--border)}
.btn-ghost:hover{border-color:var(--text);color:var(--text)}

/* Sizes */
.btn-xl{padding:18px 40px;font-size:1rem;border-radius:var(--r-md)}
.btn-lg{padding:15px 34px;font-size:.95rem}
.btn-sm{padding:9px 20px;font-size:.8rem}

/* Arrow suffix */
.btn-arrow::after{content:'→';margin-left:4px;transition:transform var(--tr)}
.btn-arrow:hover::after{transform:translateX(4px)}

/* ============================================
   BADGES / TAGS
   ============================================ */
.tag{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:var(--r-full);font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.tag-orange{background:var(--orange-dim);color:var(--orange);border:1px solid rgba(250,92,18,.2)}
.tag-teal  {background:var(--teal-dim);color:var(--teal);border:1px solid rgba(10,169,139,.2)}
.tag-blue  {background:var(--blue-dim);color:var(--blue);border:1px solid rgba(42,118,246,.15)}
.tag-dark  {background:rgba(255,255,255,.08);color:rgba(255,255,255,.7)}
.tag-gray  {background:#f2f2f2;color:#666}
.tag-success{background:#d1fae5;color:#065f46}

/* ============================================
   NAVIGATION
   ============================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--nav-h);display:flex;align-items:center;transition:var(--tr)}
.nav-glass{background:rgba(10,10,10,.78);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-dk)}
.nav-solid{background:var(--ink);border-bottom:none}
.nav-white{background:var(--white);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1160px;margin:0 auto;padding:0 24px}
.nav-logo{display:flex;align-items:center;gap:10px;color:var(--white);font-family:var(--f-head);font-size:1.1rem;font-weight:800;letter-spacing:-.02em}
.nav-logo-mark{width:32px;height:32px;border-radius:6px;background:var(--orange);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:.9rem;font-weight:900}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-link{padding:7px 13px;color:rgba(255,255,255,.6);font-size:.85rem;font-weight:500;border-radius:6px;transition:color var(--tr)}
.nav-link:hover,.nav-link.active{color:var(--white)}
.nav-cta{background:var(--orange);color:var(--white)!important;padding:8px 18px!important;font-weight:700!important;border-radius:6px}
.nav-cta:hover{background:var(--orange-2)!important;box-shadow:0 4px 16px rgba(250,92,18,.35)!important}
.nav-hamburger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-hamburger span{display:block;width:22px;height:1.5px;background:rgba(255,255,255,.8);border-radius:2px;transition:var(--tr)}
/* Dropdown nav */
.nav-dropdown{position:relative}
.nav-dropdown-menu{display:none;position:absolute;top:100%;left:0;min-width:210px;background:rgba(8,16,40,.97);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:12px 0 8px;z-index:200;backdrop-filter:blur(12px);margin-top:0}
.nav-dropdown-menu li{list-style:none}
.nav-dropdown-menu a{display:block;padding:9px 18px;color:rgba(255,255,255,.7);font-size:.82rem;transition:color .2s,background .2s}
.nav-dropdown-menu a:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav-dropdown:hover .nav-dropdown-menu{display:block}

/* ============================================
   HERO — dark with orange accent
   ============================================ */
.hero{
  position:relative;background:var(--ink);overflow:hidden;
  height:100svh;min-height:640px;max-height:1000px;
  display:flex;align-items:center;
  padding-top:var(--nav-h);
}
/* Hero with form: always flex-start so H1 stays at top, no vertical clip */
.hero.hero-has-form{
  align-items:flex-start !important;
  overflow:visible !important;
  height:auto !important;
  max-height:none !important;
  padding-bottom:48px;
}
/* Glow orbs */
.hero-glow{position:absolute;border-radius:50%;filter:blur(110px);pointer-events:none;}
.hero-glow-1{width:700px;height:700px;background:radial-gradient(circle,color-mix(in srgb,var(--orange) 18%,transparent) 0%,transparent 65%);top:-15%;right:-8%}
.hero-glow-2{width:420px;height:420px;background:radial-gradient(circle,color-mix(in srgb,var(--teal) 10%,transparent) 0%,transparent 70%);bottom:5%;left:10%}
.hero-glow-3{width:320px;height:320px;background:radial-gradient(circle,color-mix(in srgb,var(--blue) 8%,transparent) 0%,transparent 70%);top:30%;left:-5%}

.hero-inner{position:relative;z-index:2;width:100%;padding:28px 0}

/* hero with side form */
.hero-inner.hero-with-form{
  display:grid;
  grid-template-columns:1fr 400px;
  gap:48px;
  align-items:start;
  padding-top:40px;
  padding-bottom:40px;
}
/* Desktop (>960px): side-by-side keeps start alignment */
@media(min-width:961px){
  .hero.hero-has-form .hero-inner.hero-with-form{
    padding-top: max(40px, calc(10vh));
  }
}
/* Tablet + mobile: stack */
@media(max-width:960px){
  .hero-inner.hero-with-form{
    grid-template-columns:1fr;
    gap:24px;
  }
}
@media(max-width:600px){
  .hero-inner.hero-with-form{
    gap:20px;
    padding-top:20px;
    padding-bottom:0;
  }
  .glass{
    padding:20px 16px;
  }
  .hero-form-title{
    font-size:.9rem;
  }
}

/* glass card for hero form */
.glass{
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-xl);
  padding:28px;
}
.hero-form-title{
  font-family:var(--f-head);
  font-size:1rem;
  font-weight:700;
  color:#fff;
  margin-bottom:18px;
}
.glass .form-input,
.glass .form-select,
.glass .form-textarea{
  background:rgba(255,255,255,.08) !important;
  border:1px solid rgba(255,255,255,.18) !important;
  color:#fff !important;
  margin-bottom:10px;
  -webkit-appearance:none;
  appearance:none;
}
/* Force dark autofill */
.glass .form-input:-webkit-autofill,
.glass .form-textarea:-webkit-autofill{
  -webkit-box-shadow:0 0 0 1000px rgba(30,10,60,.9) inset !important;
  -webkit-text-fill-color:#fff !important;
}
.glass .form-input::placeholder,
.glass .form-textarea::placeholder{color:rgba(255,255,255,.35)}
.glass .form-input:focus,
.glass .form-textarea:focus{
  border-color:var(--orange);
  background:rgba(255,255,255,.12);
  outline:none;
}
.glass .btn-primary{background:var(--orange);border-color:var(--orange);}

/* Decorative large number BG */
.hero-bg-num{
  position:absolute;right:-20px;top:50%;transform:translateY(-50%);
  font-family:var(--f-head);font-size:clamp(180px,22vw,320px);
  font-weight:800;color:rgba(255,255,255,.022);line-height:1;
  pointer-events:none;user-select:none;z-index:1;letter-spacing:-.04em;
}

/* Live badge */
.hero-badge{
  display:inline-flex;align-items:center;gap:9px;
  border:1px solid rgba(250,92,18,.3);border-radius:var(--r-full);
  padding:5px 14px;font-size:.68rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--orange);margin-bottom:18px;
  background:rgba(250,92,18,.06);backdrop-filter:blur(4px);
}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 0 rgba(250,92,18,.7)}50%{box-shadow:0 0 0 6px rgba(250,92,18,0)}}

.hero h1{color:var(--white);margin-bottom:14px;font-size:clamp(2rem,4.5vw,4rem)}
.hero h1 .highlight{
  color:var(--orange);
  position:relative;
}

.hero-lead{font-size:1rem;color:rgba(255,255,255,.5);max-width:520px;line-height:1.72;margin-bottom:22px}

/* CTA row */
.hero-cta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}

/* Trust line below CTA */
.hero-trust{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.hero-trust-item{display:flex;align-items:center;gap:7px;font-size:.78rem;color:rgba(255,255,255,.38)}
.hero-trust-icon{font-size:.9rem}

/* Stats row */
.hero-stats{display:flex;align-items:center;gap:0;margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.07)}
.hero-stat{padding:0 32px 0 0;margin:0 32px 0 0;border-right:1px solid rgba(255,255,255,.07)}
.hero-stat:last-child{border-right:none;margin:0;padding:0}
.hero-stat-n{font-family:var(--f-head);font-size:1.9rem;font-weight:800;color:var(--white);line-height:1;letter-spacing:-.04em}
.hero-stat-n span{color:var(--orange)}
.hero-stat-l{font-size:.72rem;color:rgba(255,255,255,.35);margin-top:4px;text-transform:uppercase;letter-spacing:.08em}

/* Glass form card */
.hero-glass{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border-radius:var(--r-xl);padding:24px;
  box-shadow:var(--shadow-glass);
}
.hero-split{display:grid;grid-template-columns:1fr 400px;gap:48px;align-items:center}
.hform-title{font-size:1.15rem;font-family:var(--f-head);font-weight:700;color:var(--white);margin-bottom:4px;letter-spacing:-.01em}
.hform-sub{font-size:.78rem;color:rgba(255,255,255,.38);margin-bottom:22px}
.hform-trust{margin-top:16px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hform-trust span{font-size:.69rem;color:rgba(255,255,255,.3);display:flex;align-items:center;gap:4px}

/* ============================================
   LOGOS / TRUST BAR
   ============================================ */
.logos-bar{padding:28px 0;border-bottom:1px solid var(--border);background:var(--white)}
.logos-inner{display:flex;align-items:center;gap:36px;flex-wrap:wrap}
.logos-label{font-size:.68rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--text-3);white-space:nowrap}
.logo-item{font-size:.75rem;font-weight:700;color:var(--text-3);letter-spacing:.05em;text-transform:uppercase;opacity:.4;transition:opacity var(--tr);white-space:nowrap}
.logo-item:hover{opacity:.85}

/* ============================================
   SECTION HEADING
   ============================================ */
.section-head{margin-bottom:60px}
.section-head.center{text-align:center}
.section-head.center .section-sub{margin:0 auto}
.section-sub{font-size:1.05rem;color:var(--text-2);max-width:540px;line-height:1.78;margin-top:12px}
/* Dark variant */
.section-head.dark h2{color:var(--white)}
.section-head.dark .section-sub{color:rgba(255,255,255,.45)}
.section-head.dark .eyebrow{color:var(--orange)}

/* ============================================
   SERVICE CARDS — numbered
   ============================================ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border)}
.svc-card{
  background:var(--white);padding:40px 36px;
  transition:var(--tr);position:relative;overflow:hidden;
}
.svc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--orange);transform:scaleX(0);transform-origin:left;
  transition:transform var(--tr);
}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card:hover{background:var(--off-white)}
.svc-card-num{
  font-family:var(--f-head);font-size:3.5rem;font-weight:800;
  color:rgba(0,0,0,.04);line-height:1;margin-bottom:20px;
  letter-spacing:-.04em;
}
.svc-card-icon{font-size:1.8rem;margin-bottom:14px}
.svc-card-title{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:10px;font-family:var(--f-head);letter-spacing:-.01em}
.svc-card-text{font-size:.85rem;color:var(--text-2);line-height:1.65;margin-bottom:20px}
.svc-card-link{font-size:.8rem;font-weight:700;color:var(--orange);display:inline-flex;align-items:center;gap:5px;transition:gap var(--tr)}
.svc-card:hover .svc-card-link{gap:9px}

/* ============================================
   PAIN / GAIN SPLIT
   ============================================ */
/* ── Service Cards ────────────────────────────────────────────── */
.service-card{
  display:flex;flex-direction:column;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:28px 24px;
  transition:transform var(--tr),box-shadow var(--tr),border-color var(--tr);
  position:relative;
  overflow:hidden;
  color:var(--text);
}
.service-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,color-mix(in srgb,var(--orange) 4%,transparent),transparent 60%);
  opacity:0;
  transition:opacity var(--tr);
}
.service-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lift);
  border-color:color-mix(in srgb,var(--orange) 35%,transparent);
}
.service-card:hover::before{opacity:1}
.service-num{
  font-size:.65rem;font-weight:800;letter-spacing:.12em;
  color:var(--orange);text-transform:uppercase;
  margin-bottom:14px;opacity:.6;
}
.service-icon{
  font-size:1.8rem;margin-bottom:14px;line-height:1;
}
.service-title{
  font-size:1rem;font-weight:700;
  color:var(--text);
  margin-bottom:10px;
  letter-spacing:-.01em;
  line-height:1.3;
}
.service-desc{
  font-size:.85rem;line-height:1.7;
  color:var(--text-2);
  flex:1;
  margin-bottom:16px;
}
.service-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.service-arrow{
  font-size:1rem;color:var(--orange);
  font-weight:700;
  margin-top:auto;
  display:inline-block;
  transition:transform var(--tr);
}
.service-card:hover .service-arrow{transform:translateX(4px)}

/* Section heading helpers */
.section-lead{font-size:1.05rem;color:var(--text-2);max-width:600px;margin:.8rem auto 0;line-height:1.7}

/* ── Pain/Gain ──────────────────────────────────────────────── */
.pg-wrap{display:grid;grid-template-columns:1fr 1fr;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lift)}
.pg-col{padding:52px}
.pg-col-bad{background:#fafafa;border:1px solid var(--border)}
.pg-col-good{background:var(--ink)}
.pg-label{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px;font-family:var(--f-accent)}
.pg-col-bad .pg-label{color:#d43030}
.pg-col-good .pg-label{color:var(--teal)}
.pg-heading{font-size:1.4rem;font-weight:700;margin-bottom:28px;font-family:var(--f-head)}
.pg-col-bad .pg-heading{color:var(--text)}
.pg-col-good .pg-heading{color:var(--white)}
.pg-list{display:flex;flex-direction:column;gap:16px}
.pg-item{display:flex;align-items:flex-start;gap:13px;font-size:.875rem;line-height:1.58}
.pg-col-bad .pg-item{color:var(--text-2)}
.pg-col-good .pg-item{color:rgba(255,255,255,.65)}
.pg-icon{flex-shrink:0;font-size:1rem;margin-top:2px;width:22px;text-align:center}

/* ============================================
   PROCESS STEPS — horizontal timeline
   ============================================ */
/* ── Vertical timeline (process_steps block) ─────────────────── */
.vtl { display:flex; flex-direction:column; max-width:780px; margin:0 auto; }
.vtl-item {
  display:grid;
  grid-template-columns: 72px 1fr;
  gap: 0 24px;
  position: relative;
}
.vtl-left {
  display:flex;
  flex-direction:column;
  align-items:center;
}
.vtl-circle {
  width:48px; height:48px; border-radius:50%;
  background:var(--ink); border:2px solid var(--orange);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-head); font-size:1rem; font-weight:800; color:var(--orange);
  flex-shrink:0; z-index:1;
  box-shadow: 0 0 0 5px color-mix(in srgb, var(--orange) 12%, transparent);
}
.vtl-line {
  flex:1;
  width:2px;
  background:linear-gradient(180deg, var(--orange) 0%, var(--border) 100%);
  margin: 4px 0 0;
  min-height:32px;
}
.vtl-item:last-child .vtl-line { display:none; }
.vtl-content {
  padding-bottom:40px;
}
.vtl-item:last-child .vtl-content { padding-bottom:0; }
.vtl-header {
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:8px;
  min-height:48px;
}
.vtl-title {
  font-size:1rem;
  font-weight:700;
  color:var(--text);
  letter-spacing:-.01em;
}
.vtl-badge {
  font-size:.7rem;
  font-weight:700;
  color:var(--orange);
  background:color-mix(in srgb,var(--orange) 10%,transparent);
  border:1px solid color-mix(in srgb,var(--orange) 25%,transparent);
  border-radius:20px;
  padding:3px 10px;
  white-space:nowrap;
  flex-shrink:0;
}
.vtl-desc {
  font-size:.875rem;
  line-height:1.75;
  color:var(--text-2);
  margin:0;
}
@media(max-width:600px){
  .vtl-item { grid-template-columns: 48px 1fr; gap:0 16px; }
  .vtl-circle { width:38px; height:38px; font-size:.85rem; }
}
/* legacy steps (keep for old pages) */
.step-title{font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:6px}
.step-desc{font-size:.78rem;color:var(--text-3);line-height:1.55}

/* ============================================
   TESTIMONIALS — masonry
   ============================================ */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}
@media(max-width:900px){.testi-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.testi-grid{grid-template-columns:1fr}}
.testi-card{
  break-inside:avoid;border-radius:var(--r-lg);padding:26px;margin-bottom:20px;
  transition:transform var(--tr),box-shadow var(--tr);
}
.testi-card.dark{background:var(--ink-3);border:1px solid rgba(255,255,255,.07)}
.testi-card.light{background:var(--white);border:1px solid var(--border);box-shadow:var(--shadow-card)}
.testi-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift)}
.testi-stars{display:flex;gap:2px;margin-bottom:12px}
.testi-star{color:#f59e0b;font-size:.85rem}
.testi-text{font-size:.85rem;line-height:1.72;margin-bottom:16px}
.testi-card.dark .testi-text{color:rgba(255,255,255,.6)}
.testi-card.light .testi-text{color:var(--text-2)}
.testi-name{font-size:.78rem;font-weight:700}
.testi-card.dark .testi-name{color:var(--white)}
.testi-card.light .testi-name{color:var(--text)}
.testi-geo{font-size:.7rem;margin-top:2px}
.testi-card.dark .testi-geo{color:rgba(255,255,255,.28)}
.testi-card.light .testi-geo{color:var(--text-3)}
.testi-av{
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.75rem;flex-shrink:0;
}
.testi-card.dark .testi-av{background:color-mix(in srgb,var(--orange) 15%,transparent);color:var(--orange)}
.testi-card.light .testi-av{background:var(--off-white);color:var(--text-2)}
.testi-author{display:flex;align-items:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(128,128,128,.12)}

/* ============================================
   CTA STRIP — orange gradient
   ============================================ */
.cta-strip{
  background:var(--ink);padding:96px 0;position:relative;overflow:hidden;
}
.cta-strip::before{
  content:'';position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  width:800px;height:400px;
  background:radial-gradient(ellipse,rgba(250,92,18,.18) 0%,transparent 65%);
  pointer-events:none;
}
.cta-strip-inner{position:relative;z-index:1;max-width:680px;margin:0 auto;text-align:center}
.cta-strip-inner h2{color:var(--white);margin-bottom:14px}
.cta-strip-inner p{color:rgba(255,255,255,.45);font-size:1.05rem;margin-bottom:36px}
.cta-guarantee{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:24px;flex-wrap:wrap}
.cta-guarantee-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:rgba(255,255,255,.35)}
.cta-guarantee-item .ico{color:var(--teal)}

/* ============================================
   ORANGE BAND
   ============================================ */
.orange-band{background:var(--orange);padding:28px 0}
.orange-band-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.orange-band p{color:rgba(255,255,255,.85);font-size:1rem;font-weight:500;margin:0}
.orange-band strong{color:var(--white);font-size:1.1rem}
.btn-white-solid{background:var(--white);color:var(--orange);font-weight:700}
.btn-white-solid:hover{background:var(--off-white);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.15)}

/* ============================================
   FAQ ACCORDION
   ============================================ */
.faq-list{display:flex;flex-direction:column;gap:2px}
.faq-item{border-left:3px solid transparent;border-radius:var(--r-sm);overflow:hidden;background:var(--white);border:1px solid var(--border);transition:border-color var(--tr)}
.faq-item[open]{border-color:var(--orange);border-left-color:var(--orange)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;cursor:pointer;font-weight:600;font-size:.9rem;color:var(--text);list-style:none;gap:16px}
.faq-q::-webkit-details-marker{display:none}
details[open] .faq-q{color:var(--orange)}
.faq-ico{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-3);font-size:1.1rem;font-weight:300;transition:transform var(--tr),border-color var(--tr)}
details[open] .faq-ico{transform:rotate(45deg);border-color:var(--orange);color:var(--orange)}
.faq-body{padding:0 24px 22px;color:var(--text-2);line-height:1.78;font-size:.875rem}

/* ============================================
   FORMS
   ============================================ */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:.75rem;font-weight:600;color:var(--text-2);margin-bottom:5px;letter-spacing:.02em;text-transform:uppercase}
.form-input,.form-select,.form-textarea{
  width:100%;padding:11px 14px;
  border:1.5px solid var(--border);border-radius:var(--r-md);
  font-size:.9rem;font-family:var(--f-body);color:var(--text);
  background:var(--white);
  transition:border-color var(--tr),box-shadow var(--tr);outline:none;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(250,92,18,.12);
}
.form-textarea{min-height:110px;resize:vertical}
/* Dark / glass form */
.form-dark .form-input,.form-dark .form-select,.form-dark .form-textarea{
  background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.12);
  color:rgba(255,255,255,.9);border-radius:var(--r-md);
}
.form-dark .form-input::placeholder,.form-dark .form-textarea::placeholder{color:rgba(255,255,255,.28)}
.form-dark .form-input:focus,.form-dark .form-textarea:focus{border-color:var(--orange);background:rgba(255,255,255,.1)}
.form-dark .form-label{color:rgba(255,255,255,.42)}
.form-privacy{font-size:.68rem;color:rgba(255,255,255,.28);line-height:1.5;margin-top:10px}

/* ============================================
   PAGE HERO (sub-pages)
   ============================================ */
.page-hero{background:var(--ink);padding:0;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;right:-5%;top:-20%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(250,92,18,.09) 0%,transparent 70%);pointer-events:none}
.page-hero-inner{position:relative;z-index:1}
.page-hero h1{color:var(--white);margin:10px 0 12px}
.page-hero-lead{color:rgba(255,255,255,.5);font-size:1.05rem;max-width:580px;line-height:1.78}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.75rem;color:rgba(255,255,255,.35)}
.breadcrumb a{color:rgba(255,255,255,.5);transition:color var(--tr)}
.breadcrumb a:hover{color:var(--orange)}
.breadcrumb-sep{color:rgba(255,255,255,.18)}
.breadcrumb-current{color:var(--orange)}

/* ============================================
   TEAM CARDS
   ============================================ */
.team-card{background:var(--white);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);transition:var(--tr)}
.team-card:hover{box-shadow:var(--shadow-lift);transform:translateY(-3px)}
.team-photo{height:220px;background:var(--ink-2);display:flex;align-items:flex-end;justify-content:center;position:relative;overflow:hidden}
.team-av{width:84px;height:84px;border-radius:50%;border:3px solid var(--orange);background:var(--ink-3);display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;color:var(--orange);font-family:var(--f-head);position:absolute;bottom:24px}
.team-body{padding:24px}
.team-name{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:2px;letter-spacing:-.01em}
.team-role{font-size:.72rem;color:var(--orange);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.team-bio{font-size:.825rem;color:var(--text-2);margin-bottom:14px;line-height:1.6}
.team-tags{display:flex;flex-wrap:wrap;gap:6px}
.team-social{width:28px;height:28px;border-radius:5px;background:var(--off-white);display:flex;align-items:center;justify-content:center;font-size:.72rem;color:var(--text-3);transition:var(--tr)}
.team-social:hover{background:var(--orange-dim);color:var(--orange)}

/* ============================================
   ARTICLE / SIDEBAR
   ============================================ */
.layout-sidebar{display:grid;grid-template-columns:1fr 300px;gap:60px;align-items:start}
.sidebar{position:sticky;top:calc(var(--nav-h) + 24px)}
.sidebar-card{background:var(--white);border-radius:var(--r-lg);padding:24px;border:1px solid var(--border);margin-bottom:20px}
.sidebar-title{font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--orange)}
.article-content h2{font-size:1.65rem;margin:44px 0 12px;letter-spacing:-.02em}
.article-content h3{font-size:1.25rem;margin:28px 0 8px}
.article-content p{line-height:1.85}
.article-content ul,.article-content ol{margin:12px 0 20px 24px}
.article-content li{margin-bottom:6px;color:var(--text-2);font-size:.9rem}
.article-content ul li::marker{color:var(--orange)}
.article-content blockquote{border-left:3px solid var(--orange);padding:18px 24px;background:var(--orange-dim);border-radius:0 var(--r-md) var(--r-md) 0;margin:24px 0}
.article-content table{width:100%;border-collapse:collapse;margin:24px 0;border-radius:var(--r-md);overflow:hidden}
.article-content th{background:var(--ink);color:var(--white);padding:11px 18px;text-align:left;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.article-content td{padding:11px 18px;border-bottom:1px solid var(--border);font-size:.875rem}
.article-content tr:nth-child(even) td{background:var(--off-white)}

/* ============================================
   BLOG CARDS
   ============================================ */
.blog-card{background:var(--white);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);transition:var(--tr);display:flex;flex-direction:column}
.blog-card:hover{box-shadow:var(--shadow-lift);transform:translateY(-3px);border-color:transparent}
.blog-card-img{height:172px;background:linear-gradient(135deg,var(--ink),var(--ink-3));display:flex;align-items:center;justify-content:center;font-size:2.5rem}
.blog-card-body{padding:24px;flex:1}
.blog-card-meta{display:flex;align-items:center;gap:12px;font-size:.72rem;color:var(--text-3);margin-bottom:8px}
.blog-card-title{font-size:.98rem;font-weight:700;color:var(--text);margin-bottom:8px;font-family:var(--f-head);line-height:1.35;letter-spacing:-.01em}
.blog-card-title:hover{color:var(--orange)}
.blog-card-excerpt{font-size:.82rem;color:var(--text-2);line-height:1.65}
.blog-card-footer{padding:14px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}

/* ============================================
   FOOTER
   ============================================ */
.footer{background:var(--ink-2);border-top:1px solid rgba(255,255,255,.05)}
.footer-main{padding:72px 0 48px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand-logo{font-family:var(--f-head);font-size:1.2rem;font-weight:800;color:var(--white);letter-spacing:-.02em;display:flex;align-items:center;gap:10px;margin-bottom:16px}
.footer-brand-mark{width:30px;height:30px;border-radius:6px;background:var(--orange);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:.85rem;font-weight:900}
.footer-brand p{color:rgba(255,255,255,.36);font-size:.8rem;margin:0;line-height:1.72}
.footer-col-h{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);margin-bottom:20px;font-family:var(--f-accent)}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-link{font-size:.8rem;color:rgba(255,255,255,.38);transition:color var(--tr)}
.footer-link:hover{color:rgba(255,255,255,.78)}
.footer-bottom{padding:20px 0;border-top:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:space-between;font-size:.72rem;color:rgba(255,255,255,.22);flex-wrap:wrap;gap:12px}

/* ============================================
   UTILITY
   ============================================ */
.divider{height:1px;background:var(--border);margin:24px 0}
.divider-dk{height:1px;background:rgba(255,255,255,.07);margin:24px 0}
.check-list{display:flex;flex-direction:column;gap:12px}
.check-list li{display:flex;align-items:flex-start;gap:10px;font-size:.875rem;color:var(--text-2)}
.check-list li::before{content:'✓';width:20px;height:20px;background:var(--orange-dim);color:var(--orange);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;flex-shrink:0;margin-top:2px}
.check-list.dark li{color:rgba(255,255,255,.6)}
.check-list.dark li::before{background:rgba(250,92,18,.15)}

/* Urgency */
.urgency-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#ef4444;animation:udot 1.5s ease-in-out infinite;flex-shrink:0}
@keyframes udot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.3)}}

/* Number highlight */
.num-big{font-family:var(--f-head);font-size:clamp(2.5rem,5vw,4.5rem);font-weight:800;line-height:1;letter-spacing:-.04em;color:var(--orange)}

/* ============================================
   FLOATING + STICKY
   ============================================ */
.float-wa{position:fixed;bottom:86px;right:22px;z-index:800;width:52px;height:52px;border-radius:50%;background:#25D366;box-shadow:0 4px 20px rgba(37,211,102,.4);display:flex;align-items:center;justify-content:center;font-size:1.5rem;transition:transform var(--tr)}
.float-wa:hover{transform:scale(1.1)}
.float-wa-badge{position:absolute;top:-3px;right:-3px;width:14px;height:14px;background:#ef4444;border-radius:50%;border:2px solid var(--white)}
.sticky-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:790;background:var(--ink);padding:10px 16px;gap:10px;align-items:center;border-top:1px solid rgba(255,255,255,.08)}
.sticky-bar a{flex:1;text-align:center;justify-content:center}

/* ============================================
   PPC TOPBAR
   ============================================ */
.ppc-bar{position:fixed;top:0;left:0;right:0;z-index:900;background:var(--ink);height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 28px;border-bottom:1px solid rgba(255,255,255,.07)}
.ppc-trust{display:flex;align-items:center;gap:20px;font-size:.73rem;color:rgba(255,255,255,.38)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .layout-sidebar{grid-template-columns:1fr}
  .sidebar{position:static}
  .testi-grid{columns:2}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:780px){
  /* Hero — fix overflow clip on mobile */
  .hero{
    height:auto;
    min-height:100svh;
    max-height:none;
    overflow-x:hidden;
    overflow-y:visible;
    align-items:flex-start;
    padding-bottom:40px;
  }
  .hero-split{grid-template-columns:1fr}
  /* Hide side form on mobile — use CTA button instead */
  .hero-glass{display:none}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .pg-wrap{grid-template-columns:1fr;border-radius:var(--r-xl)}
  .steps-timeline{grid-template-columns:1fr 1fr;gap:28px}
  .steps-timeline::before{display:none}
  .testi-grid{columns:1}
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .logos-inner{gap:16px}
  .hero-stats{flex-wrap:wrap;gap:20px}
  .hero-stat{border:none!important;padding:0!important;margin:0!important}
  .svc-grid{grid-template-columns:1fr}
  .orange-band-inner{flex-direction:column;text-align:center}
}
@media(max-width:520px){
  .steps-timeline{grid-template-columns:1fr}
  .sticky-bar{display:flex}
  body{padding-bottom:68px}
  .ppc-trust{display:none}
  .section{padding:72px 0}
}

/* ============================================
   SCROLL REVEAL
   ============================================ */
/* reveal: starts visible, JS adds class 'js-loaded' to body to enable animation */
.js-loaded .reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}
.js-loaded .reveal.visible{opacity:1;transform:none}
/* fallback when no JS */
.reveal{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* ── Accessibility / SEO utilities ───────────────────────────────── */
.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ── GEO / LLM / Accessibility ───────────────────────────────────── */

/* Skip link — виден для screen readers + роботов */
.skip-link {
  position: absolute;
  top: -100px;
  left: 16px;
  background: var(--orange);
  color: #fff;
  padding: 8px 16px;
  border-radius: 4px;
  font-weight: 600;
  z-index: 10000;
  transition: top .15s;
}
.skip-link:focus { top: 16px; }

/* GEO summary block — dense anchor text для LLM парсеров */
.geo-summary {
  background: color-mix(in srgb, var(--orange) 5%, transparent);
  border-left: 3px solid var(--orange);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  padding: 18px 22px;
  margin: 24px 0;
  font-size: .95rem;
  line-height: 1.7;
}
.geo-summary strong { color: var(--text); }

/* ── Article layout: grid-article (article + sidebar) ────────────────── */
.grid-article {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 48px;
  align-items: start;
}
@media(max-width:900px){
  .grid-article { grid-template-columns: 1fr; }
  .article-sidebar { order: -1; }
}

/* ── intro_text block layout ──────────────────────────────── */
.intro-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 56px;
  align-items: start;
}
@media(max-width:960px){ .intro-grid { grid-template-columns: 1fr; } }

.intro-h2 { font-size: clamp(1.5rem, 3vw, 2.1rem); line-height:1.2; margin-bottom:20px; }
.intro-p  { font-size:.95rem; line-height:1.82; color:var(--text-2); margin-bottom:14px; }

/* Glance card */
.glance-card {
  border: 1px solid var(--border);
  border-top: 3px solid var(--orange);
  border-radius: var(--r-lg);
  overflow: hidden;
  position: sticky;
  top: 88px;
}
.glance-label {
  background: var(--off-white);
  border-bottom: 1px solid var(--border);
  padding: 10px 20px;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--orange);
}
.glance-body {
  padding: 18px 20px;
  font-size: .875rem;
  line-height: 1.78;
  color: var(--text-2);
}
.glance-body strong { color: var(--text); }
.glance-body dfn {
  font-style:italic;
  color: var(--text);
  border-bottom: 1px dashed var(--orange);
}

/* Story hook — opening narrative paragraph */
.story-hook {
  border-left: 3px solid var(--orange);
  padding: 18px 22px;
  background: var(--orange-dim);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  margin: 0 0 32px;
  font-size: .925rem;
  color: var(--text-2);
  line-height: 1.82;
}
.story-hook em { font-style: italic; }

/* Practitioner note — aside block */
aside.practitioner-note {
  border: 1px solid var(--border);
  border-left: 4px solid var(--teal);
  background: #f0faf8;
  border-radius: 0 var(--r-md) var(--r-md) 0;
  padding: 18px 22px;
  margin: 28px 0;
  font-size: .875rem;
  color: var(--text-2);
  line-height: 1.78;
}
aside.practitioner-note strong {
  color: var(--teal-dark, #078069);
  font-weight: 700;
}

/* dfn — определение термина */
dfn {
  font-style: normal;
  border-bottom: 1px dashed var(--orange);
  cursor: help;
  color: var(--text);
}
dfn abbr { text-decoration: none; }

/* Inline citation / source */
.cite-source {
  font-size: .75rem;
  color: var(--muted);
  display: block;
  margin-top: 6px;
}
.cite-source a { color: var(--teal); }

/* Stat claim block — машиночитаемая статистика */
.stat-claim {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 6px 14px;
  margin: 4px 0;
}
.stat-claim-n {
  font-family: var(--f-head);
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--orange);
}
.stat-claim-desc { font-size: .82rem; color: var(--muted); }

/* Passage section — каждая секция как самостоятельный смысловой блок */
.passage {
  scroll-margin-top: 90px;
}

/* ══════════════════════════════════════════════════════════════════
   PAGE TRANSITIONS
   Primary: View Transitions API (Chrome 111+, Edge, partial Safari)
   Fallback: JS fade handled in main.js
═══════════════════════════════════════════════════════════════════ */

/* Native view transitions */
@view-transition { navigation: auto; }

@keyframes vt-fade-out {
  from { opacity: 1; transform: translateY(0); }
  to   { opacity: 0; transform: translateY(-8px); }
}
@keyframes vt-fade-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

::view-transition-old(root) {
  animation: 220ms cubic-bezier(.4,0,1,1) both vt-fade-out;
}
::view-transition-new(root) {
  animation: 320ms cubic-bezier(0,0,.2,1) both vt-fade-in;
}

/* JS fallback: body fade class */
body.page-leaving {
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 200ms ease, transform 200ms ease;
  pointer-events: none;
}
body {
  transition: opacity 280ms ease, transform 280ms ease;
}

/* ══════════════════════════════════════════════════════════════════
   PAGE-HERO — full first screen (service / inner pages)
═══════════════════════════════════════════════════════════════════ */
.page-hero {
  min-height: 100svh;
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding-top: 0;
  padding-bottom: 0;
}
.page-hero-inner {
  padding: calc(var(--nav-h) + 48px) 0 64px;
  width: 100%;
}

/* Limit max so it doesn't overstretch on tall screens */
@media (min-height: 900px) {
  .page-hero { min-height: min(100svh, 900px); }
}

/* ══════════════════════════════════════════════════════════════════
   NAV-GLASS — unified: solid on scroll, glass at top
   Used on ALL pages for consistent look during page transitions
═══════════════════════════════════════════════════════════════════ */
.nav-glass {
  /* At page top = glassmorphism over dark hero */
  background: rgba(10,10,10,.82);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,.06);
  transition: background .25s ease, border-color .25s ease;
}
.nav-glass.scrolled {
  background: rgba(10,10,10,.98);
  border-bottom-color: rgba(255,255,255,.1);
}

/* ── GEO-SUMMARY inside article content ── */
.layout-sidebar .geo-summary,
.article-lead {
  display: block !important;   /* visible in content */
  position: static !important;
  width: auto;
  clip: auto;
  height: auto;
  overflow: visible;
}

/* ═══════════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — comprehensive fixes
═══════════════════════════════════════════════════════════════════ */

/* ── Contact page inline grids ─────────────────────────────────── */
@media (max-width:860px) {
  /* form + sidebar */
  div[style*="grid-template-columns:1fr 360px"],
  div[style*="grid-template-columns: 1fr 360px"] {
    display: block !important;
  }
  div[style*="position:sticky"] { position: static !important; }
  /* offices 3-col */
  div[style*="grid-template-columns:repeat(3,1fr)"],
  div[style*="grid-template-columns: repeat(3, 1fr)"] {
    grid-template-columns: 1fr !important;
  }
  /* inline 2-col grids */
  div[style*="grid-template-columns:1fr 1fr"],
  div[style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  /* CTA "still have questions" row */
  div[style*="justify-content:space-between"][style*="align-items:center"] {
    flex-direction: column !important;
    text-align: center !important;
  }
}

/* ── Service page / inner pages ─────────────────────────────────── */
@media (max-width:780px) {
  .page-hero-inner { padding-top: calc(var(--nav-h) + 32px); }
  .hero-stats { flex-wrap: wrap; gap: 16px 28px; }

  /* Card grids with inline repeat(2,1fr) */
  div[style*="grid-template-columns:repeat(2,1fr)"],
  div[style*="grid-template-columns: repeat(2, 1fr)"] {
    grid-template-columns: 1fr !important;
  }

  /* Text inside dark section CTA strip */
  .cta-strip-inner { text-align: center; padding: 40px 20px; }
  .cta-strip-inner [style*="justify-content:flex-end"] { justify-content: center !important; }
  .cta-strip-inner [style*="text-align:right"] { text-align: center !important; }

  /* page-hero h1 */
  .page-hero h1 { font-size: clamp(1.75rem, 6vw, 3rem); }
}

/* ── FAQ tabs — horizontal scroll on small screens ────────────── */
@media (max-width:620px) {
  .faq-tabs {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 4px;
  }
  .faq-tabs::-webkit-scrollbar { display: none; }
  .faq-tab-btn { white-space: nowrap; flex-shrink: 0; }
}

/* ── RTL page grids ─────────────────────────────────────────────── */
@media (max-width:780px) {
  /* ar/he 2-col layout */
  [dir="rtl"] div[style*="grid-template-columns:1fr 1fr"],
  [dir="rtl"] div[style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  [dir="rtl"] div[style*="grid-template-columns:repeat(3,1fr)"],
  [dir="rtl"] div[style*="grid-template-columns: repeat(3, 1fr)"] {
    grid-template-columns: 1fr !important;
  }
  /* RTL hero buttons row */
  [dir="rtl"] .page-hero-inner div[style*="flex-direction:row-reverse"] {
    flex-direction: row !important;
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
  }
  /* RTL process steps */
  .process-step-rtl {
    flex-direction: column-reverse !important;
    gap: 12px !important;
  }
}

/* ── Hamburger overlay close ────────────────────────────────────── */
.nav-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 898;
  opacity: 0;
  transition: opacity .2s;
}
.nav-overlay.active { display: block; opacity: 1; }

/* Mobile nav menu open state */
@media (max-width:780px) {
  .nav-links.open {
    display: flex !important;
    flex-direction: column;
    position: fixed;
    top: var(--nav-h);
    left: 0; right: 0; bottom: 0;
    background: rgba(10,10,10,.99);
    padding: 28px 24px;
    gap: 4px;
    z-index: 899;
    overflow-y: auto;
    border-top: 1px solid rgba(255,255,255,.08);
  }
  .nav-links.open .nav-link {
    padding: 14px 0;
    font-size: 1.1rem;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }
  .nav-links.open .nav-cta {
    margin-top: 12px;
    text-align: center;
    padding: 14px;
    border-radius: 12px;
    font-size: 1rem;
  }
}

/* ── prefers-reduced-motion ─────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
  .reveal { opacity: 1 !important; transform: none !important; }
  ::view-transition-old(root),
  ::view-transition-new(root) { animation: none !important; }
}

/* ── Hero mobile CTA block ─────────────────────────────────────── */
.hero-mobile-cta { display: none; margin-top: 28px; width: 100%; }
@media (max-width:780px) {
  .hero-mobile-cta { display: block; }

  /* Stats: 2×2 grid instead of single row */
  .hero-stats {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    padding-top: 24px;
    border-top: 1px solid rgba(255,255,255,.07);
    margin-top: 24px;
  }
  .hero-stat {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }
  .hero-stat-n { font-size: 1.6rem; }

  /* CTA row: stack buttons */
  .hero-cta-row {
    flex-direction: column;
    gap: 10px;
    align-items: stretch;
  }
  .hero-cta-row .btn { justify-content: center; width: 100%; }

  /* Trust items: wrap tighter */
  .hero-trust { gap: 14px; }
  .hero-trust-item { font-size: .72rem; }
}

/* ═══════════════════════════════════════════════════════════════════
   MOBILE — COMPREHENSIVE v2
   Tested breakpoints: 375px, 390px, 430px, 520px, 640px, 780px
═══════════════════════════════════════════════════════════════════ */

/* ── Global ─────────────────────────────────────────────────────── */
@media (max-width:780px) {
  :root { --nav-h: 60px; }

  .container { padding: 0 18px; }

  .section { padding: 56px 0; }

  /* All inline flex rows that could overflow — force wrap */
  [style*="display:flex"][style*="gap"] {
    flex-wrap: wrap;
  }

  /* Page hero height: no min-height 100svh on inner pages (too tall) */
  .page-hero {
    min-height: auto !important;
  }
  .page-hero-inner {
    padding-top: calc(var(--nav-h) + 28px);
    padding-bottom: 40px;
  }

  /* H1 on inner pages */
  .page-hero h1 { font-size: clamp(1.6rem, 7vw, 2.4rem); }
  .page-hero .page-hero-lead { font-size: .9rem; }

  /* Eyebrow on mobile */
  .eyebrow { font-size: .68rem; }
}

/* ── Tablet (1024→780) ──────────────────────────────────────────── */
@media (max-width:1024px) {
  .section { padding: 80px 0; }
}

/* ── Footer ─────────────────────────────────────────────────────── */
@media (max-width:640px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 28px !important;
  }
}
@media (max-width:420px) {
  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .footer-bottom {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }
}

/* ── Nav hamburger open: font size ──────────────────────────────── */
@media (max-width:780px) {
  .nav-inner { padding: 0 16px; }
  .nav-logo { font-size: .95rem; }
}

/* ── Sticky bar: always visible on mobile (not just ≤520) ───────── */
@media (max-width:780px) {
  .sticky-bar { display: flex; }
  body { padding-bottom: 64px; }
  .float-wa { bottom: 78px; right: 16px; width: 46px; height: 46px; font-size: 1.3rem; }
}

/* ── Article ────────────────────────────────────────────────────── */
@media (max-width:780px) {
  /* Table horizontal scroll */
  .article-content table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
    border-radius: 8px;
  }
  /* Article cover emoji box */
  div[style*="height:340px"] {
    height: 200px !important;
    font-size: 3.5rem !important;
    margin-bottom: 28px !important;
  }
  /* TOC sidebar on mobile */
  .sidebar-card { padding: 18px; }
  .layout-sidebar { gap: 32px; }
}

/* ── Team grid ──────────────────────────────────────────────────── */
@media (max-width:780px) {
  .grid-3 { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width:500px) {
  .grid-3 { grid-template-columns: 1fr !important; }
  .team-photo { height: 180px; }
}

/* ── About page ─────────────────────────────────────────────────── */
@media (max-width:780px) {
  /* stats grid */
  .grid-2 > div[style*="grid-template-columns:1fr 1fr"],
  .grid-2 > div[style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr 1fr !important;
  }
  /* Mission/values section gap */
  .grid-2.reveal[style*="gap:72px"] {
    gap: 36px !important;
  }
}

/* ── Service page ────────────────────────────────────────────────── */
@media (max-width:780px) {
  /* Process steps list: reduce padding */
  div[style*="padding:22px 24px"] {
    padding: 16px !important;
  }
  /* Stats row inline */
  div[style*="grid-template-columns:repeat(4,1fr)"],
  div[style*="grid-template-columns: repeat(4, 1fr)"] {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* ── Contact page ───────────────────────────────────────────────── */
@media (max-width:860px) {
  /* Form card: full bleed on mobile */
  div[style*="border-radius:20px;padding:40px"] {
    padding: 24px 18px !important;
    border-radius: 16px !important;
  }
  /* Sidebar sticky → stacks below */
  div[style*="position:sticky;top:calc"] {
    position: static !important;
  }
  /* Emergency number: bigger */
  a[href^="tel"][style*="font-size:1.15rem"] {
    font-size: 1rem !important;
  }
}

/* ── Blog ────────────────────────────────────────────────────────── */
@media (max-width:640px) {
  .blog-feat-cover { height: 180px !important; font-size: 4rem !important; }
  .blog-feat-body { padding: 20px !important; }
  .blog-feat-title { font-size: 1.1rem !important; }
  .blog-feat-excerpt { display: none; }  /* hide on very small to reduce scroll */
}

/* ── FAQ tabs ────────────────────────────────────────────────────── */
@media (max-width:520px) {
  .faq-tab-btn { padding: 7px 14px; font-size: .78rem; }
  .faq-q { font-size: .9rem; padding: 14px 16px; }
}

/* ── Quiz ────────────────────────────────────────────────────────── */
@media (max-width:520px) {
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:12px"] {
    grid-template-columns: 1fr !important;
  }
  .quiz-shell { padding: 0; }
}

/* ── CTA strip ───────────────────────────────────────────────────── */
@media (max-width:640px) {
  .cta-strip-inner { padding: 48px 20px; }
  .cta-strip-inner h2 { font-size: clamp(1.5rem, 6vw, 2.2rem); }
}

/* ── Trustpilot section ──────────────────────────────────────────── */
@media (max-width:640px) {
  /* Divider between score blocks */
  div[style*="width:1px;height:72px"] {
    width: 100% !important;
    height: 1px !important;
  }
}

/* ── Section headings on mobile ─────────────────────────────────── */
@media (max-width:520px) {
  h2 { font-size: clamp(1.4rem, 7vw, 1.9rem); }
  h3 { font-size: clamp(1.1rem, 5vw, 1.4rem); }

  .section { padding: 48px 0; }

  /* Remove large top padding from sections with big padding-top overrides */
  section[style*="padding-top:64px"] { padding-top: 40px !important; }
  section[style*="padding-top:72px"] { padding-top: 48px !important; }

  /* Buttons: don't go too wide */
  .btn-xl { padding: 13px 22px; font-size: .95rem; }
  .btn-lg { padding: 11px 20px; font-size: .875rem; }
}

/* ── RTL mobile ──────────────────────────────────────────────────── */
@media (max-width:780px) {
  [dir="rtl"] .cta-strip-inner { text-align: center !important; }
  [dir="rtl"] .cta-strip-inner div[style*="justify-content:flex-end"] {
    justify-content: center !important;
  }
  [dir="rtl"] .hero-stats { flex-direction: row !important; flex-wrap: wrap !important; }
}

/* ── Orange band / partner logos ─────────────────────────────────── */
@media (max-width:640px) {
  .logos-inner img { height: 28px !important; }
  .orange-band-inner h2 { font-size: 1.4rem; }
}

/* ── Back-to-top button: above sticky bar ─────────────────────────── */
@media (max-width:780px) {
  #back-to-top { bottom: 80px; right: 16px; }
}

/* ── iOS Safe Area (notch / home bar) ───────────────────────────── */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  .sticky-bar {
    padding-bottom: calc(10px + env(safe-area-inset-bottom));
  }
  body { padding-bottom: calc(64px + env(safe-area-inset-bottom)); }
  .float-wa { bottom: calc(78px + env(safe-area-inset-bottom)); }
  #back-to-top { bottom: calc(80px + env(safe-area-inset-bottom)); }
}

/* ═══════════════════════════════════════════════════════════════════
   HERO MOBILE — TARGETED OVERRIDE (with !important)
═══════════════════════════════════════════════════════════════════ */
@media (max-width: 780px) {
  /* Kill the overflow clip that cuts badge+H1+lead above viewport */
  .hero {
    height: auto !important;
    min-height: 100svh !important;
    max-height: none !important;
    overflow: visible !important;
    align-items: flex-start !important;
    padding-bottom: 48px !important;
  }

  /* Hide glass form on mobile — replaced by hero-mobile-cta */
  .hero-glass { display: none !important; }

  /* Stats: 2×2 grid */
  .hero-stats {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    flex-wrap: unset !important;
    gap: 14px 24px !important;
    margin-top: 24px !important;
    padding-top: 20px !important;
    border-top: 1px solid rgba(255,255,255,.07) !important;
    width: 100%;
  }
  .hero-stat {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }
  .hero-stat-n { font-size: 1.8rem !important; }

  /* Hero inner: proper top padding for nav */
  .hero-inner {
    padding-top: 24px !important;
    padding-bottom: 0 !important;
  }

  /* Badge, h1, lead: make sure visible */
  .hero-badge { margin-bottom: 14px; }
  .hero .highlight { display: inline; }
  .hero h1 {
    font-size: clamp(2rem, 8vw, 2.8rem) !important;
    margin-bottom: 14px !important;
  }
  .hero-lead { font-size: .9rem !important; max-width: 100% !important; }

  /* Trust row */
  .hero-trust {
    gap: 12px !important;
    flex-wrap: wrap !important;
    margin-bottom: 0 !important;
  }

  /* CTA row on mobile: stack vertically */
  .hero-cta-row {
    flex-direction: column !important;
    gap: 10px !important;
    align-items: stretch !important;
    margin-bottom: 16px !important;
  }
  .hero-cta-row .btn {
    width: 100% !important;
    justify-content: center !important;
  }

  /* Mobile CTA block (below stats) */
  .hero-mobile-cta { display: block !important; margin-top: 20px !important; }
}

/* Hero glows wrapper — contains absolutely positioned orbs */
.hero-glows {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
}
.hero-glows .hero-glow,
.hero-glows .hero-bg-num {
  position: absolute;
}
