/* =========================================================================
   Dr. Roger Eduardo — Personal Brand Site
   Design system built on the Omnia Health brand guide
   Palette: Navy #002B56 · Slate #7A92AB · Teal #5E7775
            Gold #BD9A5F · Cream #D6D1C4 · Sage #9BAEAB
   Type:    Cormorant Garamond (display) · Fira Sans (eyebrow) · Inter (body)
   ========================================================================= */

:root{
  /* Brand */
  --navy:#002B56;
  --navy-700:#03203f;
  --navy-900:#021a32;
  --slate:#7A92AB;
  --teal:#5E7775;
  --gold:#BD9A5F;
  --gold-deep:#a9854a;
  --cream:#D6D1C4;
  --sage:#9BAEAB;

  /* Neutrals (warm) */
  --bg:#FBFAF6;
  --bg-alt:#F3F0E8;
  --surface:#ffffff;
  --ink:#1d2733;
  --ink-soft:#46535f;
  --line:#e7e2d6;

  /* Type */
  --display:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --eyebrow:'Fira Sans', system-ui, sans-serif;
  --body:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  /* Rhythm */
  --container:1180px;
  --container-narrow:760px;
  --radius:14px;
  --radius-lg:22px;
  --shadow-sm:0 1px 3px rgba(2,26,50,.06), 0 6px 18px rgba(2,26,50,.05);
  --shadow-md:0 10px 30px rgba(2,26,50,.10), 0 2px 8px rgba(2,26,50,.06);
  --shadow-lg:0 30px 70px rgba(2,26,50,.16);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.7;
  font-size:1.02rem;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--navy);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--gold-deep)}
ul{margin:0;padding:0}
hr{border:none;border-top:1px solid var(--line);margin:0}
::selection{background:var(--gold);color:#fff}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.08;color:var(--navy);margin:0 0 .5em;letter-spacing:.2px}
h1{font-size:clamp(2.6rem,5.4vw,4.6rem);font-weight:600}
h2{font-size:clamp(2rem,3.8vw,3.1rem)}
h3{font-size:clamp(1.4rem,2.2vw,1.9rem)}
h4{font-size:1.2rem}
p{margin:0 0 1.1em}
.lead{font-size:clamp(1.12rem,1.7vw,1.32rem);color:var(--ink-soft);line-height:1.65}
.eyebrow{
  font-family:var(--eyebrow);font-weight:600;text-transform:uppercase;
  letter-spacing:.22em;font-size:.8rem;color:var(--gold-deep);
  margin:0 0 1rem;display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold);display:inline-block}
.eyebrow.center{justify-content:center}
.script{font-style:italic;color:var(--teal)}
em{font-style:italic}

/* ---------- Layout ---------- */
.container{width:min(100% - 2.6rem, var(--container));margin-inline:auto}
.narrow{max-width:var(--container-narrow);margin-inline:auto}
section{padding:clamp(3.6rem,8vw,7rem) 0}
.section-tight{padding:clamp(2.4rem,5vw,4rem) 0}
.bg-alt{background:var(--bg-alt)}
.bg-navy{background:var(--navy);color:#eaf0f6}
.bg-navy h1,.bg-navy h2,.bg-navy h3{color:#fff}
.bg-navy .lead{color:#c6d3e0}
.bg-navy a:not(.btn){color:var(--gold)}
.center{text-align:center}
.grid{display:grid;gap:1.6rem}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.section-head{max-width:680px;margin:0 0 2.8rem}
.section-head.center{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--eyebrow);font-weight:600;font-size:.94rem;letter-spacing:.02em;
  padding:.92rem 1.6rem;border-radius:999px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
  text-align:center;line-height:1;
}
.btn .arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:var(--navy);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--navy-700);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-gold{background:var(--gold);color:#2a2008}
.btn-gold:hover{background:var(--gold-deep);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-outline{background:transparent;border-color:var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.45);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.12);color:#fff;border-color:#fff}
.btn-lg{padding:1.05rem 2rem;font-size:1rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.textlink{font-family:var(--eyebrow);font-weight:600;color:var(--gold-deep);display:inline-flex;gap:.4rem;align-items:center}
.textlink .arrow{transition:transform .25s var(--ease)}
.textlink:hover .arrow{transform:translateX(4px)}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,250,246,.82);backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s, box-shadow .3s, background .3s;
}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px rgba(2,26,50,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:.9rem 0}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand img{width:46px;height:46px;object-fit:contain;flex-shrink:0}
.brand .name{font-family:var(--display);font-weight:600;font-size:1.32rem;color:var(--navy);line-height:1}
.brand .name small{display:block;font-family:var(--eyebrow);font-weight:500;font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep);margin-top:.28rem}
.nav-links{display:flex;align-items:center;gap:1.7rem;list-style:none}
.nav-links a{font-family:var(--eyebrow);font-weight:500;font-size:.95rem;color:var(--ink);position:relative;padding:.2rem 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--gold);transition:width .28s var(--ease)}
.nav-links a:hover{color:var(--navy)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:.7rem}
/* Hide the in-menu "Book a Consult" button on desktop so it isn't duplicated next to the right-side CTA. It returns inside the mobile menu via the 760px rule below. */
.nav-links li:has(.btn){display:none}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:.4rem;width:44px;height:44px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px auto;transition:.3s var(--ease)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,#fff 0%, var(--bg) 55%, var(--bg-alt) 100%)}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;opacity:.10;
  background:url('../img/gold-texture.jpg') center/cover no-repeat;mix-blend-mode:multiply;
}
.hero .container{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;padding:clamp(3rem,7vw,6rem) 0}
.hero h1{margin-bottom:.3em}
.hero h1 .script{display:block;font-size:.92em}
.hero .credentials{font-family:var(--eyebrow);font-weight:600;letter-spacing:.14em;text-transform:uppercase;font-size:.82rem;color:var(--teal);margin-bottom:1.1rem}
.hero-portrait{position:relative;justify-self:center}
.hero-portrait .ring{
  position:relative;width:min(420px,80vw);aspect-ratio:1;border-radius:50%;
  background:linear-gradient(150deg,var(--navy),var(--teal));padding:10px;box-shadow:var(--shadow-lg);
}
.hero-portrait .ring img{width:100%;height:100%;object-fit:cover;border-radius:50%;border:5px solid var(--bg)}
.hero-portrait .badge{
  position:absolute;bottom:14px;left:-10px;background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow-md);padding:.85rem 1.1rem;display:flex;align-items:center;gap:.7rem;
}
.hero-portrait .badge .stars{color:var(--gold);font-size:1rem;letter-spacing:1px}
.hero-portrait .badge strong{font-family:var(--display);font-size:1.5rem;color:var(--navy);line-height:1}
.hero-portrait .badge small{font-family:var(--eyebrow);font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-soft)}
.hero-portrait .chip{
  position:absolute;top:18px;right:-6px;background:var(--navy);color:#fff;border-radius:999px;
  padding:.5rem 1rem;font-family:var(--eyebrow);font-weight:600;font-size:.74rem;letter-spacing:.1em;
  text-transform:uppercase;box-shadow:var(--shadow-md);
}

/* ---------- Stat strip ---------- */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;text-align:center}
.stat .num{font-family:var(--display);font-weight:600;font-size:clamp(2.2rem,4vw,3.2rem);color:var(--navy);line-height:1}
.bg-navy .stat .num{color:var(--gold)}
.stat .lbl{font-family:var(--eyebrow);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.bg-navy .stat .lbl{color:#aebfd1}

/* ---------- Cards ---------- */
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2rem 1.8rem;box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  position:relative;overflow:hidden;height:100%;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--cream)}
.card .icon{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:1.1rem;background:var(--bg-alt)}
.card .icon svg{width:28px;height:28px}
.card h3{margin-bottom:.4rem}
.card p{color:var(--ink-soft);margin-bottom:1rem;font-size:.98rem}
.service-card{border-top:4px solid var(--gold)}
.service-card .kw{font-family:var(--eyebrow);font-size:.78rem;color:var(--teal);letter-spacing:.04em;margin-bottom:1rem;display:block}
/* Full-bleed illustration banner for service cards */
.service-illo{margin:-2rem -1.8rem 1.4rem;display:block;border-bottom:1px solid var(--line)}
.service-illo img{width:100%;height:158px;object-fit:cover;display:block}

/* feature pill list */
.pill-list{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem}
.pill-list li{font-family:var(--eyebrow);font-size:.82rem;background:var(--bg-alt);color:var(--navy);padding:.4rem .85rem;border-radius:999px;border:1px solid var(--line)}
.check-list{list-style:none;display:grid;gap:.8rem}
.check-list li{position:relative;padding-left:2rem;color:var(--ink-soft)}
.check-list li::before{content:"";position:absolute;left:0;top:.45em;width:14px;height:14px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(94,119,117,.15)}

/* ---------- Story / image+text ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split.reverse .split-media{order:2}
.split-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%}
.framed{position:relative}
.framed::after{content:"";position:absolute;inset:14px -14px -14px 14px;border:2px solid var(--gold);border-radius:var(--radius-lg);z-index:-1}

/* ---------- Quote / testimonials ---------- */
.quote-feature{font-family:var(--display);font-size:clamp(1.6rem,3vw,2.5rem);line-height:1.3;color:var(--navy);font-style:italic}
.review-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.9rem;height:100%}
.review-card .stars{color:var(--gold);letter-spacing:2px}
.review-card p{color:var(--ink);font-size:.98rem;margin:0}
.review-card .who{display:flex;align-items:center;gap:.7rem;margin-top:auto}
.review-card .avatar{width:42px;height:42px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-family:var(--display);font-size:1.1rem}
.review-card .who b{display:block;font-size:.92rem}
.review-card .who small{color:var(--ink-soft);font-size:.78rem}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--navy),var(--navy-900));color:#fff;padding:clamp(2.4rem,5vw,4rem);text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.14;background:url('../img/warm-streak.jpg') center/cover}
.cta-band > *{position:relative;z-index:1}
.cta-band h2{color:#fff}
.cta-band .lead{color:#cdd9e6;max-width:600px;margin-inline:auto}

/* ---------- Resource / offer cards ---------- */
.offer{display:flex;flex-direction:column;gap:1rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.8rem;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.offer:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.offer .tag{font-family:var(--eyebrow);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep)}
.offer .tag.soon{color:var(--slate)}
/* Push each card's CTA to the bottom so buttons align across cards */
.offer .btn,.offer .textlink{margin-top:auto;align-self:flex-start}

/* ---------- Blog ---------- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.8rem}
.post-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s var(--ease);height:100%}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.post-card .thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--navy),var(--teal));position:relative;display:grid;place-items:center}
.post-card .thumb.g2{background:linear-gradient(135deg,var(--teal),var(--sage))}
.post-card .thumb.g3{background:linear-gradient(135deg,var(--slate),var(--navy))}
.post-card .thumb span{font-family:var(--eyebrow);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.22);padding:.35rem .8rem;border-radius:999px;position:absolute;top:1rem;left:1rem}
.post-card .thumb img.mk{width:64px;opacity:.5}
.post-card .body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.post-card .meta{font-family:var(--eyebrow);font-size:.76rem;color:var(--ink-soft);letter-spacing:.04em}
.post-card h3{font-size:1.32rem;margin:0}
.post-card p{color:var(--ink-soft);font-size:.95rem;margin:0}
.post-card .textlink{margin-top:auto}

/* ---------- Article ---------- */
.article{max-width:740px;margin-inline:auto}
.article-hero{padding:clamp(2.4rem,5vw,4rem) 0 0}
.article .meta{font-family:var(--eyebrow);font-size:.85rem;color:var(--ink-soft);letter-spacing:.05em;margin-bottom:1rem}
.article h1{margin-bottom:.4em}
.prose{font-size:1.09rem;line-height:1.8;color:#27313c}
.prose h2{margin-top:2.2em;font-size:clamp(1.6rem,2.6vw,2.1rem)}
.prose h3{margin-top:1.6em}
.prose p{margin-bottom:1.3em}
.prose ul,.prose ol{margin:0 0 1.3em;padding-left:1.3em}
.prose li{margin-bottom:.5em}
.prose blockquote{margin:1.8em 0;padding:1.2em 1.6em;border-left:4px solid var(--gold);background:var(--bg-alt);border-radius:0 var(--radius) var(--radius) 0;font-family:var(--display);font-style:italic;font-size:1.3rem;color:var(--navy)}
.prose strong{color:var(--navy)}
.callout{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.6rem;margin:1.8em 0}
.callout .eyebrow{margin-bottom:.5rem}

/* ---------- FAQ accordion ---------- */
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:1.4rem 3rem 1.4rem 0;font-family:var(--display);font-size:1.28rem;color:var(--navy);position:relative;line-height:1.3}
.faq-q::after{content:"+";position:absolute;right:.2rem;top:50%;transform:translateY(-50%);font-family:var(--body);font-size:1.7rem;color:var(--gold-deep);transition:transform .3s var(--ease)}
.faq-item.open .faq-q::after{content:"–"}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a-inner{padding:0 0 1.4rem;color:var(--ink-soft)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-900);color:#bcccdd;padding:4rem 0 2rem;font-size:.94rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2.2rem;margin-bottom:2.5rem}
.site-footer h4{color:#fff;font-family:var(--eyebrow);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;margin-bottom:1.1rem}
.site-footer a{color:#bcccdd}
.site-footer a:hover{color:var(--gold)}
.footer-links{list-style:none;display:grid;gap:.6rem}
.footer-brand .name{font-family:var(--display);font-size:1.5rem;color:#fff;display:flex;align-items:center;gap:.6rem}
.footer-brand .name img{width:40px}
.footer-brand p{margin-top:1rem;color:#9fb2c6;max-width:32ch}
.social{display:flex;gap:.7rem;margin-top:1.2rem}
.social a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;color:#cdd9e6}
.social a:hover{background:var(--gold);border-color:var(--gold);color:var(--navy)}
.social svg{width:18px;height:18px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:#8ea3ba}
.footer-bottom .disclaimer{max-width:62ch;line-height:1.6}

/* ---------- Breadcrumb ---------- */
.breadcrumb{font-family:var(--eyebrow);font-size:.82rem;color:var(--ink-soft);padding:1.4rem 0 0}
.breadcrumb a{color:var(--ink-soft)}
.breadcrumb a:hover{color:var(--gold-deep)}

/* ---------- Page hero (interior) ---------- */
.page-hero{background:linear-gradient(160deg,#fff,var(--bg-alt));padding:clamp(2.6rem,6vw,5rem) 0 clamp(2rem,4vw,3rem);position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(189,154,95,.16),transparent 70%)}
.page-hero .container{position:relative}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero .eyebrow{justify-content:center}
  .hero-portrait{order:-1}
  .split,.split.reverse .split-media{grid-template-columns:1fr;order:0}
  .cols-4,.stat-strip{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:block}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;
    gap:0;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:var(--shadow-md);
    padding:.5rem 1.3rem 1.3rem;max-height:0;overflow:hidden;transition:max-height .4s var(--ease);
  }
  .nav-links li:has(.btn){display:block}
  .nav-links.open{max-height:460px;display:flex}
  .nav-links a{width:100%;padding:.9rem 0;border-bottom:1px solid var(--line)}
  .nav-links .btn{display:inline-flex;margin-top:.8rem}
  .cols-2,.cols-3,.post-grid{grid-template-columns:1fr}
  .hero-portrait .badge{left:0}
}
.video-embed{position:relative;aspect-ratio:16/9;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);background:linear-gradient(150deg,var(--navy),var(--teal));display:grid;place-items:center}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-embed .play{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;box-shadow:var(--shadow-md)}
.video-embed .play::after{content:"";border-left:20px solid var(--navy);border-top:12px solid transparent;border-bottom:12px solid transparent;margin-left:5px}
.video-embed .vlabel{position:absolute;bottom:1rem;left:1rem;color:#fff;font-family:var(--eyebrow);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(0,0,0,.3);padding:.3rem .7rem;border-radius:999px}
@media (max-width:760px){.detail-grid{grid-template-columns:1fr !important}}
@media (max-width:460px){
  .cols-4,.stat-strip,.footer-grid{grid-template-columns:1fr}
  .stat-strip{gap:2rem}
}

/* ===== Before & After ===== */
/* "Coming soon" panel shown until real transformations are added */
.ba-soon{max-width:760px;margin:0 auto;text-align:center;background:linear-gradient(160deg,var(--navy),var(--navy-900));color:#fff;border-radius:var(--radius-lg);padding:3.4rem 2rem;box-shadow:var(--shadow-md);position:relative;overflow:hidden}
.ba-soon::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 0%,rgba(189,154,95,.22),transparent 60%);pointer-events:none}
.ba-soon img{display:block;width:80px;height:auto;margin:0 auto 1.1rem;position:relative}
.ba-soon .tag{display:inline-block;font-family:var(--eyebrow);font-weight:600;text-transform:uppercase;letter-spacing:.22em;font-size:.74rem;color:var(--gold);margin-bottom:1rem}
.ba-soon p.headline{font-family:var(--display);font-style:italic;font-weight:500;font-size:clamp(1.5rem,3vw,2.1rem);line-height:1.25;color:#fff;margin:0 auto;max-width:560px;position:relative}
.ba-soon .sub{font-size:.92rem;color:rgba(255,255,255,.72);margin:1.4rem auto 0;max-width:480px;position:relative}
/* Card used for each real transformation (see template in reviews.html) */
.ba-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.8rem;max-width:980px;margin:0 auto}
.ba-card{background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);margin:0}
.ba-photos{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--line);position:relative}
.ba-photos figure{margin:0;position:relative;aspect-ratio:3/4;overflow:hidden}
.ba-photos img{width:100%;height:100%;object-fit:cover;display:block}
.ba-photos figcaption{position:absolute;top:.7rem;left:.7rem;font-family:var(--eyebrow);font-weight:600;letter-spacing:.14em;font-size:.66rem;text-transform:uppercase;color:#fff;background:rgba(2,26,50,.6);padding:.25rem .6rem;border-radius:999px}
.ba-body{padding:1.4rem 1.5rem 1.6rem}
.ba-body .stars{color:var(--gold);letter-spacing:.1em;font-size:.95rem}
.ba-body blockquote{font-family:var(--display);font-size:1.18rem;line-height:1.5;color:var(--navy);margin:.6rem 0 1rem;font-style:italic}
.ba-body .who{display:flex;align-items:center;gap:.7rem}
.ba-body .who b{color:var(--navy)}
.ba-body .who small{display:block;color:var(--ink-soft)}
.ba-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.8rem}
.ba-meta span{font-family:var(--eyebrow);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-deep);background:rgba(189,154,95,.12);padding:.25rem .6rem;border-radius:999px}
@media (max-width:760px){.ba-grid{grid-template-columns:1fr}}
