/* ================================================================
   Design 3 — Mr Rajen Gupta | High-End Boutique Health Brand
   Light luxury · Warm cream · Botanical green · Cormorant serif
   Slider · FAQ accordion · Split screens · Horizontal scroll
   Trending 2026: scroll-reveal, fluid type, minimal whitespace
   ================================================================ */

/* ── Imports & tokens ──────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  /* Palette */
  --cream:       #f8f6f2;
  --cream-2:     #f2ede6;
  --cream-3:     #e8e0d5;
  --white:       #ffffff;
  --ink:         #1a1510;
  --ink-mid:     #3d3530;
  --ink-muted:   #6b6358;
  --ink-dim:     #a09890;

  --green:       #2c4a3e;
  --green-mid:   #3d6b5a;
  --green-light: #5a8f7b;
  --green-pale:  #d4e6df;
  --green-mist:  rgba(44,74,62,0.06);

  --gold:        #c9a96e;
  --gold-light:  #e5c99a;
  --gold-pale:   #f5ecd9;
  --gold-mist:   rgba(201,169,110,0.12);

  --border:      rgba(26,21,16,0.1);
  --border-md:   rgba(26,21,16,0.16);
  --shadow-sm:   0 1px 4px rgba(26,21,16,0.07);
  --shadow-md:   0 8px 32px rgba(26,21,16,0.09);
  --shadow-lg:   0 20px 60px rgba(26,21,16,0.12);

  /* Typography */
  --ff-serif: 'Cormorant Garamond', 'Palatino Linotype', Georgia, serif;
  --ff-sans:  'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  /* Spacing */
  --gap:  1.5rem;
  --sec:  7rem;

  /* Radius */
  --r-sm:   8px;
  --r-md:   16px;
  --r-lg:   28px;
  --r-xl:   48px;
  --r-full: 9999px;

  /* Motion */
  --ease:   cubic-bezier(0.22,1,0.36,1);
  --spring: cubic-bezier(0.34,1.56,0.64,1);
  --fast:   0.18s;
  --mid:    0.38s;
  --slow:   0.65s;
}

/* ── Reset ───────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:var(--ff-sans);
  background:var(--cream);
  color:var(--ink);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img { display:block; max-width:100%; }
a   { text-decoration:none; color:inherit; }
button { border:none; background:none; cursor:pointer; font-family:inherit; }
ul  { list-style:none; }

::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--cream); }
::-webkit-scrollbar-thumb { background:var(--cream-3); border-radius:var(--r-full); }

/* ── Utilities ───────────────────────────────────────────────── */
.container { max-width:1220px; margin:0 auto; padding:0 2.5rem; }
.sec { padding:var(--sec) 0; position:relative; }

.eyebrow {
  display:inline-flex; align-items:center; gap:0.75rem;
  font-family:var(--ff-sans); font-size:0.65rem; font-weight:600;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--green-mid);
}
.eyebrow::before {
  content:''; display:inline-block; width:28px; height:1px;
  background:var(--green-mid);
}

.sec-title {
  font-family:var(--ff-serif);
  font-size:clamp(2.4rem,4vw,3.8rem);
  font-weight:400; line-height:1.1; letter-spacing:-0.01em;
  color:var(--ink); margin-top:0.75rem;
}
.sec-title em { font-style:italic; color:var(--green); }
.sec-title strong { font-weight:600; }

.sec-sub {
  font-size:0.95rem; color:var(--ink-muted); line-height:1.85;
  margin-top:1rem; max-width:480px;
}

/* Reveal */
.rv  { opacity:0; transform:translateY(28px); transition:opacity var(--slow) var(--ease), transform var(--slow) var(--ease); }
.rv.on{ opacity:1; transform:none; }
.rv-l{ opacity:0; transform:translateX(-28px); transition:opacity var(--slow) var(--ease), transform var(--slow) var(--ease); }
.rv-l.on{ opacity:1; transform:none; }
.rv-r{ opacity:0; transform:translateX(28px); transition:opacity var(--slow) var(--ease), transform var(--slow) var(--ease); }
.rv-r.on{ opacity:1; transform:none; }
.d1{transition-delay:.06s!important} .d2{transition-delay:.13s!important}
.d3{transition-delay:.20s!important} .d4{transition-delay:.27s!important}
.d5{transition-delay:.34s!important} .d6{transition-delay:.41s!important}

/* ──────────────────────────────────────────────────────────────
   NAV — minimal: LOGO+name LEFT | links + CTA RIGHT
────────────────────────────────────────────────────────────── */
.nav {
  position:fixed; inset:0 0 auto 0; z-index:300;
  padding:1.1rem 0;
  background:rgba(255,255,255,0.94);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  transition:padding var(--mid) var(--ease), box-shadow var(--mid) var(--ease);
}
.nav.is-scrolled {
  padding:0.65rem 0;
  box-shadow:var(--shadow-sm);
}
.nav__inner {
  max-width:1220px; margin:0 auto; padding:0 2.5rem;
  display:flex; align-items:center; gap:0.5rem;
}
/* Brand: logo circle + name — left */
.nav__brand {
  display:flex; align-items:center; gap:0.75rem;
  text-decoration:none; margin-right:auto; flex-shrink:0;
}
.nav__logo-img {
  height:38px; width:38px; border-radius:50%;
  border:1.5px solid var(--border-md); object-fit:cover;
  background:var(--cream-2);
}
.nav__brand-name {
  font-family:var(--ff-serif); font-size:1rem; font-weight:600;
  color:var(--ink); letter-spacing:0.01em; line-height:1.2; white-space:nowrap;
}
.nav__brand-sub {
  font-size:0.55rem; letter-spacing:0.13em; text-transform:uppercase;
  color:var(--ink-dim); margin-top:1px;
}
/* Nav links — horizontal list */
.nav__links {
  display:flex; align-items:center; gap:0;
}
.nav__left, .nav__right { display:none; } /* old split-nav divs hidden */
.nav__link {
  position:relative;
  font-size:0.74rem; font-weight:500; letter-spacing:0.04em;
  color:var(--ink-muted); padding:0.4rem 0.65rem;
  transition:color var(--fast); white-space:nowrap;
}
.nav__link::after {
  content:''; position:absolute; bottom:0; left:0.65rem;
  width:calc(100% - 1.3rem); height:1px;
  background:var(--green); transform:scaleX(0); transform-origin:left;
  transition:transform var(--mid) var(--ease);
}
.nav__link:hover { color:var(--ink); }
.nav__link:hover::after { transform:scaleX(1); }
/* Vertical separator */
.nav__sep {
  width:1px; height:16px; background:var(--border-md);
  margin:0 0.25rem; flex-shrink:0;
}
/* CTA pill */
.nav__cta {
  display:inline-flex; align-items:center; margin-left:0.75rem;
  padding:0.45rem 1.15rem; flex-shrink:0;
  font-size:0.7rem; font-weight:600; letter-spacing:0.07em; text-transform:uppercase;
  color:var(--white); background:var(--green); border-radius:var(--r-full);
  transition:background var(--fast), transform var(--fast);
}
.nav__cta:hover { background:var(--green-mid); transform:translateY(-1px); }
/* Hamburger (mobile only) */
.nav__hamburger {
  display:none; flex-direction:column; gap:5px;
  width:38px; height:38px; align-items:center; justify-content:center;
  border:1px solid var(--border); border-radius:var(--r-sm);
  background:transparent; flex-shrink:0; margin-left:0.5rem;
}
.nav__hamburger span { display:block; width:18px; height:1.5px; background:var(--ink); border-radius:2px; transition:all var(--fast); }

/* ──────────────────────────────────────────────────────────────
   HERO — editorial large-type + arched portrait (no split panel)
────────────────────────────────────────────────────────────── */
.hero {
  min-height:100svh;
  background:var(--white);
  display:flex; align-items:center;
  overflow:hidden; position:relative;
  padding:8rem 0 5rem;
}

/* Decorative concentric rings — top-right corner only */
.hero__ring {
  position:absolute; border-radius:50%; pointer-events:none; z-index:0;
}
.hero__ring--1 {
  width:860px; height:860px;
  border:1px solid rgba(201,169,110,0.14);
  top:-340px; right:-260px;
  animation:ringDrift 24s ease-in-out infinite;
}
.hero__ring--2 {
  width:580px; height:580px;
  border:1px solid rgba(44,74,62,0.1);
  top:-160px; right:-60px;
  animation:ringDrift 30s ease-in-out infinite reverse;
}
.hero__ring--3 {
  width:280px; height:280px;
  background:radial-gradient(circle, rgba(201,169,110,0.13) 0%, transparent 70%);
  top:-20px; right:70px;
}
@keyframes ringDrift {
  0%,100%{ transform:translate(0,0) scale(1); }
  50%    { transform:translate(-16px,20px) scale(1.025); }
}

/* Two-column asymmetric: 62% text | 38% portrait */
.hero__inner {
  max-width:1220px; width:100%; margin:0 auto; padding:0 2.5rem;
  display:grid; grid-template-columns:62% 38%;
  gap:3rem; align-items:center; position:relative; z-index:2;
}

/* ─ TEXT COLUMN ─ */
.hero__text {}

.hero__meta {
  display:inline-flex; align-items:center; gap:0.7rem;
  font-size:0.65rem; font-weight:600; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--green-mid); margin-bottom:1.75rem;
  animation:fadeUp 0.7s var(--ease) 0.1s both;
}
.hero__live-dot {
  width:6px; height:6px; border-radius:50%; background:var(--green);
  animation:livePing 2.4s ease-in-out infinite;
}
@keyframes livePing {
  0%   { box-shadow:0 0 0 0 rgba(44,74,62,0.5); }
  70%  { box-shadow:0 0 0 9px rgba(44,74,62,0); }
  100% { box-shadow:0 0 0 0 rgba(44,74,62,0); }
}

.hero__headline {
  font-family:var(--ff-serif);
  font-size:clamp(4.2rem,8.8vw,10rem);
  font-weight:300; line-height:0.93; letter-spacing:-0.03em;
  color:var(--ink);
  animation:fadeUp 0.8s var(--ease) 0.22s both;
}
.hero__headline em {
  font-style:italic; color:var(--green); font-weight:300;
}

/* Gold rule with doctor name centred */
.hero__rule {
  display:flex; align-items:center; gap:1rem;
  margin:2.25rem 0 1.75rem;
  animation:fadeUp 0.7s var(--ease) 0.38s both;
}
.hero__rule-line {
  height:1px; background:var(--gold); opacity:0.5; flex:0 0 60px;
}
.hero__rule-name {
  font-size:0.6rem; font-weight:600; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--ink-dim); white-space:nowrap;
}

.hero__sub {
  font-size:0.97rem; color:var(--ink-muted); line-height:1.85;
  max-width:490px; margin-bottom:1.75rem;
  animation:fadeUp 0.8s var(--ease) 0.44s both;
}
.hero__quals-row {
  display:flex; flex-wrap:wrap; gap:0.45rem; margin-bottom:2.25rem;
  animation:fadeUp 0.8s var(--ease) 0.54s both;
}
.hero__qual {
  font-size:0.6rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--gold); background:var(--gold-pale);
  border:1px solid rgba(201,169,110,0.28); border-radius:var(--r-full);
  padding:0.22rem 0.7rem;
}
.hero__btns {
  display:flex; flex-wrap:wrap; gap:0.9rem;
  animation:fadeUp 0.8s var(--ease) 0.64s both;
}

/* ─ PORTRAIT COLUMN ─ */
.hero__portrait-col {
  display:flex; flex-direction:column; align-items:center; gap:1.25rem;
  position:relative;
  animation:fadeUp 0.9s var(--ease) 0.28s both;
}
/* Decorative ring behind arch */
.hero__portrait-col::before {
  content:''; position:absolute;
  width:108%; aspect-ratio:1;
  border-radius:50%;
  border:1px solid rgba(201,169,110,0.22);
  top:50%; left:50%; transform:translate(-50%,-50%);
  pointer-events:none; z-index:0;
}
.hero__portrait-col::after {
  content:''; position:absolute;
  width:85%; aspect-ratio:1;
  border-radius:50%;
  border:1px solid rgba(44,74,62,0.1);
  top:50%; left:50%; transform:translate(-50%,-50%);
  pointer-events:none; z-index:0;
}
/* Arch frame: rounded top = arch shape, flat bottom */
.hero__arch {
  width:100%; max-width:320px;
  aspect-ratio:3/4.2;
  border-radius:999px 999px var(--r-xl) var(--r-xl);
  overflow:hidden;
  background:var(--cream-2);
  border:3px solid var(--cream-3);
  box-shadow:0 24px 64px rgba(26,21,16,0.14);
  position:relative; z-index:1;
  transition:transform 0.55s var(--ease);
}
.hero__arch:hover { transform:scale(1.025) translateY(-4px); }
.hero__photo {
  width:100%; height:100%;
  object-fit:cover; object-position:top center;
  filter:sepia(0.06) saturate(0.92) contrast(1.03);
  transform:scale(1.05);
  transition:transform 5s var(--ease);
}
.hero__photo.loaded { transform:scale(1); }
.hero__arch::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:28%;
  background:linear-gradient(to top, rgba(26,21,16,0.2), transparent);
  pointer-events:none;
}

/* Info card below the arch */
.hero__portrait-info {
  background:var(--cream); border:1px solid var(--border);
  border-radius:var(--r-md); padding:1rem 1.4rem;
  width:100%; max-width:320px;
  box-shadow:var(--shadow-sm); text-align:center; position:relative; z-index:1;
}
.hero__portrait-name {
  font-family:var(--ff-serif); font-size:1rem; font-weight:600; color:var(--ink);
}
.hero__portrait-title {
  font-size:0.6rem; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--ink-dim); margin-top:0.2rem;
}
.hero__portrait-quals {
  display:flex; flex-wrap:wrap; justify-content:center; gap:0.3rem; margin-top:0.65rem;
}
.hero__portrait-q {
  font-size:0.56rem; font-weight:700; letter-spacing:0.09em; text-transform:uppercase;
  color:var(--green); background:var(--green-mist);
  border:1px solid rgba(44,74,62,0.14); border-radius:var(--r-full);
  padding:0.15rem 0.55rem;
}

/* Scroll cue */
.hero__scroll {
  position:absolute; bottom:2.25rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:0.45rem;
  font-size:0.56rem; font-weight:600; letter-spacing:0.17em; text-transform:uppercase;
  color:var(--ink-dim); z-index:3;
  animation:fadeUp 0.8s var(--ease) 1.1s both;
}
.hero__scroll-line {
  width:1px; height:40px;
  background:linear-gradient(to bottom, var(--green), transparent);
  animation:scrollPulse 2.2s ease-in-out infinite;
}
@keyframes scrollPulse { 0%,100%{opacity:1;} 50%{opacity:0.28;} }

@keyframes fadeUp { from{opacity:0;transform:translateY(22px);} to{opacity:1;transform:none;} }
/* alias for older usage in subsequent sections */
@keyframes fadeIn { from{opacity:0;transform:translateY(20px);} to{opacity:1;transform:none;} }

/* ──────────────────────────────────────────────────────────────
   BUTTONS
────────────────────────────────────────────────────────────── */
.btn-primary {
  display:inline-flex; align-items:center; gap:0.6rem;
  padding:0.85rem 2.1rem; font-size:0.8rem; font-weight:600;
  letter-spacing:0.05em; text-transform:uppercase;
  color:var(--white); background:var(--green); border-radius:var(--r-full);
  box-shadow:0 4px 22px rgba(44,74,62,0.24);
  transition:background var(--fast), transform var(--mid) var(--spring), box-shadow var(--fast);
}
.btn-primary:hover { background:var(--green-mid); transform:translateY(-2px); box-shadow:0 8px 30px rgba(44,74,62,0.3); }
.btn-secondary {
  display:inline-flex; align-items:center; gap:0.6rem;
  padding:0.85rem 2.1rem; font-size:0.8rem; font-weight:600;
  letter-spacing:0.05em; text-transform:uppercase;
  color:var(--ink); border:1px solid var(--border-md); border-radius:var(--r-full);
  transition:border-color var(--fast), color var(--fast), background var(--fast);
}
.btn-secondary:hover { border-color:var(--green-light); color:var(--green); background:var(--green-mist); }

/* ──────────────────────────────────────────────────────────────
   AT A GLANCE — horizontal stat strip
────────────────────────────────────────────────────────────── */
.glance-strip {
  background:var(--green); color:var(--white);
  padding:4rem 0;
}
.glance-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0; text-align:center;
}
.glance-item { position:relative; padding:0 2rem; }
.glance-item:not(:last-child)::after {
  content:''; position:absolute; right:0; top:10%; bottom:10%; width:1px;
  background:rgba(255,255,255,0.2);
}
.glance-num {
  font-family:var(--ff-serif); font-size:clamp(2.6rem,4.5vw,4rem);
  font-weight:300; line-height:1; letter-spacing:-0.03em;
  color:var(--gold-light);
}
.glance-label {
  font-size:0.68rem; font-weight:500; letter-spacing:0.1em; text-transform:uppercase;
  color:rgba(255,255,255,0.65); margin-top:0.5rem;
}

/* ──────────────────────────────────────────────────────────────
   ABOUT — sticky split
────────────────────────────────────────────────────────────── */
.about-split {
  display:grid; grid-template-columns:1fr 1fr;
  min-height:80vh;
}
.about__sticky-col {
  position:sticky; top:0; height:100svh;
  overflow:hidden; background:var(--cream-2);
}
.about__sticky-img {
  width:100%; height:100%;
  object-fit:cover; object-position:top center;
  filter:sepia(0.06) saturate(0.88);
}
.about__sticky-overlay {
  position:absolute; bottom:0; left:0; right:0;
  padding:3rem;
  background:linear-gradient(to top, rgba(26,21,16,0.72) 0%, transparent 100%);
  color:#fff;
}
.about__sticky-name  { font-family:var(--ff-serif); font-size:1.4rem; font-weight:500; }
.about__sticky-title { font-size:0.68rem; letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,255,255,0.55); margin-top:0.3rem; }

.about__scroll-col {
  padding:7rem 5rem 7rem 5.5rem; background:var(--cream);
  display:flex; flex-direction:column; justify-content:center;
}
.about-lead { font-size:1.05rem; color:var(--ink-muted); line-height:1.85; margin-bottom:2.5rem; }

/* Qual chips in about */
.qual-row { display:flex; flex-wrap:wrap; gap:0.5rem; margin-bottom:2.5rem; }
.qual-badge {
  font-size:0.62rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--green); background:var(--green-mist);
  border:1px solid rgba(44,74,62,0.18); border-radius:var(--r-full);
  padding:0.3rem 0.85rem;
}

/* Feature list */
.feat-list { display:flex; flex-direction:column; gap:1rem; margin-bottom:2.5rem; }
.feat-item {
  display:flex; align-items:flex-start; gap:1rem;
  padding:1.25rem 1.5rem;
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r-md); transition:border-color var(--fast), box-shadow var(--fast);
}
.feat-item:hover { border-color:var(--green-pale); box-shadow:var(--shadow-sm); }
.feat-ico {
  width:40px; height:40px; flex-shrink:0;
  border-radius:var(--r-sm); background:var(--green-mist);
  border:1px solid rgba(44,74,62,0.15);
  display:flex; align-items:center; justify-content:center; font-size:1rem;
  transition:transform var(--mid) var(--spring);
}
.feat-item:hover .feat-ico { transform:rotate(8deg) scale(1.12); }
.feat-txt { font-size:0.88rem; color:var(--ink-muted); line-height:1.65; }
.feat-txt strong { color:var(--ink); font-weight:600; display:block; margin-bottom:0.15rem; font-size:0.9rem; }

.about-quote {
  padding:2rem 2.5rem; margin-top:0.5rem;
  background:var(--gold-pale); border-left:3px solid var(--gold);
  border-radius:0 var(--r-md) var(--r-md) 0;
}
.about-quote-text { font-family:var(--ff-serif); font-size:1.15rem; font-style:italic; color:var(--ink); line-height:1.65; }
.about-quote-attr { margin-top:0.75rem; font-size:0.68rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-dim); }

/* ──────────────────────────────────────────────────────────────
   SERVICES — horizontal scroll cards
────────────────────────────────────────────────────────────── */
.services-sec { background:var(--white); }
.services-hdr { max-width:640px; margin-bottom:3.5rem; }

.services-track-wrap {
  overflow-x:auto; overflow-y:visible;
  padding-bottom:1.5rem; margin:0 -2.5rem;
  scrollbar-width:thin; scrollbar-color:var(--cream-3) transparent;
  cursor:grab;
}
.services-track-wrap::-webkit-scrollbar { height:4px; }
.services-track-wrap::-webkit-scrollbar-thumb { background:var(--cream-3); border-radius:var(--r-full); }
.services-track {
  display:flex; gap:1.25rem;
  padding:0 2.5rem; width:max-content;
}
.svc-card {
  width:290px; flex-shrink:0;
  padding:2.5rem 2rem;
  background:var(--cream);
  border:1px solid var(--border); border-radius:var(--r-lg);
  transition:transform var(--mid) var(--spring), box-shadow var(--mid) var(--ease), border-color var(--fast), background var(--fast);
  display:flex; flex-direction:column;
}
.svc-card:hover {
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  border-color:var(--green-pale);
  background:var(--white);
}
.svc-ico {
  width:52px; height:52px; border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center; font-size:1.4rem;
  margin-bottom:1.75rem;
  background:var(--green-mist); border:1px solid rgba(44,74,62,0.14);
  transition:transform var(--mid) var(--spring);
}
.svc-card:hover .svc-ico { transform:rotate(8deg) scale(1.1); }
.svc-tag {
  font-size:0.58rem; font-weight:700; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--green-light); margin-bottom:0.5rem;
}
.svc-title {
  font-family:var(--ff-serif); font-size:1.25rem; font-weight:500;
  color:var(--ink); line-height:1.25; margin-bottom:0.75rem;
}
.svc-desc { font-size:0.83rem; color:var(--ink-muted); line-height:1.72; flex:1; }
.svc-link {
  display:inline-flex; align-items:center; gap:0.4rem;
  font-size:0.75rem; font-weight:600; letter-spacing:0.04em;
  color:var(--green); margin-top:1.5rem;
  transition:gap var(--fast);
}
.svc-card:hover .svc-link { gap:0.75rem; }

/* ──────────────────────────────────────────────────────────────
   SPECIALTY — icon grid
────────────────────────────────────────────────────────────── */
.specialty-sec { background:var(--cream); }
.specialty-hdr { text-align:center; max-width:520px; margin:0 auto 4rem; }

.specialty-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem;
}
.spec-card {
  padding:2.5rem 1.75rem; text-align:center;
  background:var(--white); border:1px solid var(--border); border-radius:var(--r-lg);
  transition:transform var(--mid) var(--spring), box-shadow var(--mid) var(--ease), border-color var(--fast);
}
.spec-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); border-color:var(--green-pale); }
.spec-num {
  display:block; font-size:0.56rem; font-weight:700; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--ink-dim); margin-bottom:1.25rem;
}
.spec-ico-wrap {
  width:64px; height:64px; border-radius:50%;
  background:var(--green-mist); border:1px solid rgba(44,74,62,0.15);
  display:flex; align-items:center; justify-content:center; font-size:1.6rem;
  margin:0 auto 1.5rem;
  transition:transform var(--mid) var(--spring), background var(--fast);
}
.spec-card:hover .spec-ico-wrap { transform:scale(1.12) rotate(-5deg); background:var(--green-pale); }
.spec-title { font-family:var(--ff-serif); font-size:1.1rem; font-weight:500; color:var(--ink); margin-bottom:0.75rem; }
.spec-desc  { font-size:0.82rem; color:var(--ink-muted); line-height:1.72; }

/* ──────────────────────────────────────────────────────────────
   PUBLICATIONS — alternating timeline
────────────────────────────────────────────────────────────── */
.pub-sec { background:var(--white); }
.pub-hdr { text-align:center; max-width:520px; margin:0 auto 5rem; }

.pub-timeline {
  position:relative; max-width:860px; margin:0 auto;
}
.pub-timeline::before {
  content:''; position:absolute;
  left:50%; top:0; bottom:0; width:1px;
  background:linear-gradient(to bottom, transparent, var(--border-md) 15%, var(--border-md) 85%, transparent);
  transform:translateX(-50%);
}
.pub-block {
  display:grid; grid-template-columns:1fr 60px 1fr;
  align-items:center; margin-bottom:5rem;
}
.pub-block:nth-child(odd)  .pub-content { grid-column:1; text-align:right; padding-right:3rem; }
.pub-block:nth-child(odd)  .pub-dot     { grid-column:2; }
.pub-block:nth-child(odd)  .pub-empty   { grid-column:3; }
.pub-block:nth-child(even) .pub-empty   { grid-column:1; }
.pub-block:nth-child(even) .pub-dot     { grid-column:2; }
.pub-block:nth-child(even) .pub-content { grid-column:3; text-align:left; padding-left:3rem; }
.pub-dot {
  width:14px; height:14px; border-radius:50%;
  background:var(--gold); border:2px solid var(--white);
  box-shadow:0 0 0 3px var(--gold-light);
  margin:0 auto; flex-shrink:0;
}
.pub-badge {
  display:inline-block; font-size:0.56rem; font-weight:700; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--green); background:var(--green-mist); border:1px solid rgba(44,74,62,0.18);
  border-radius:var(--r-full); padding:0.2rem 0.75rem; margin-bottom:0.75rem;
}
.pub-title {
  font-family:var(--ff-serif); font-size:1.3rem; font-weight:500;
  color:var(--ink); line-height:1.3; margin-bottom:0.75rem;
}
.pub-body { font-size:0.84rem; color:var(--ink-muted); line-height:1.82; }
.pub-link {
  display:inline-flex; align-items:center; gap:0.4rem;
  font-size:0.75rem; font-weight:600; color:var(--green-light);
  padding:0.5rem 1.2rem; margin-top:1.25rem;
  border:1px solid rgba(90,143,123,0.3); border-radius:var(--r-full);
  background:var(--green-mist); transition:all var(--fast);
}
.pub-link:hover { background:var(--green-pale); color:var(--green); border-color:var(--green-light); }

/* ──────────────────────────────────────────────────────────────
   COST / PRICING
────────────────────────────────────────────────────────────── */
.cost-sec { background:var(--cream-2); }
.cost-hdr { text-align:center; max-width:520px; margin:0 auto 4rem; }

.pricing-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem; align-items:start;
}
.price-card {
  background:var(--white); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:2.5rem 2rem; display:flex; flex-direction:column;
  transition:transform var(--mid) var(--spring), box-shadow var(--mid) var(--ease), border-color var(--fast);
}
.price-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.price-card--feat {
  background:var(--green) !important;
  border-color:var(--green) !important;
  color:var(--white);
  position:relative;
  box-shadow:0 12px 48px rgba(44,74,62,0.28);
}
.price-card--feat .price-label,
.price-card--feat .price-from,
.price-card--feat .price-unit,
.price-card--feat .price-feature { color:rgba(255,255,255,0.65); }
.price-card--feat .price-title,
.price-card--feat .price-value { color:var(--white); }
.price-card--feat::before {
  content:'Most Popular';
  position:absolute; top:-1px; left:50%; transform:translateX(-50%);
  font-size:0.55rem; font-weight:700; letter-spacing:0.18em; text-transform:uppercase;
  background:var(--gold); color:var(--ink);
  padding:0.28rem 1rem; border-radius:0 0 var(--r-md) var(--r-md);
  white-space:nowrap;
}
.price-ico {
  width:46px; height:46px; border-radius:var(--r-sm);
  display:flex; align-items:center; justify-content:center; font-size:1.2rem;
  margin-bottom:1.5rem;
  background:var(--green-mist); border:1px solid rgba(44,74,62,0.12);
  transition:transform var(--mid) var(--spring);
}
.price-card--feat .price-ico { background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.2); }
.price-card:hover .price-ico { transform:rotate(8deg) scale(1.1); }
.price-label {
  font-size:0.58rem; font-weight:700; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--green-light); margin-bottom:0.4rem;
}
.price-title {
  font-family:var(--ff-serif); font-size:1.2rem; font-weight:500;
  color:var(--ink); line-height:1.25; margin-bottom:1.25rem;
}
.price-from {
  font-size:0.68rem; font-weight:500; text-transform:uppercase; letter-spacing:0.08em;
  color:var(--ink-dim); margin-bottom:0.25rem;
}
.price-amount { display:flex; align-items:baseline; gap:0.2rem; }
.price-currency { font-family:var(--ff-serif); font-size:1.4rem; font-weight:400; color:var(--ink-muted); }
.price-card--feat .price-currency { color:rgba(255,255,255,0.7); }
.price-value {
  font-family:var(--ff-serif); font-size:3rem; font-weight:300; letter-spacing:-0.04em;
  line-height:1; color:var(--green);
}
.price-value--enquire { font-size:1.8rem; color:var(--green-light); }
.price-unit {
  font-size:0.7rem; color:var(--ink-muted); margin-bottom:1.5rem;
}
.price-divider {
  width:100%; height:1px; background:var(--border); margin:1.25rem 0;
}
.price-card--feat .price-divider { background:rgba(255,255,255,0.15); }
.price-features { display:flex; flex-direction:column; gap:0.6rem; margin-bottom:1.75rem; }
.price-feature {
  font-size:0.82rem; color:var(--ink-muted);
  display:flex; align-items:flex-start; gap:0.6rem; line-height:1.5;
}
.price-feature::before { content:'✓'; flex-shrink:0; font-size:0.7rem; font-weight:700; color:var(--green-light); margin-top:0.1rem; }
.price-card--feat .price-feature::before { color:var(--gold-light); }
.price-cta {
  display:inline-flex; align-items:center; justify-content:center; gap:0.5rem;
  padding:0.75rem 1.5rem; font-size:0.76rem; font-weight:600; letter-spacing:0.04em;
  border-radius:var(--r-full); margin-top:auto;
  border:1px solid var(--border-md); color:var(--ink-muted);
  transition:all var(--fast);
}
.price-cta:hover { border-color:var(--green-light); color:var(--green); background:var(--green-mist); }
.price-card--feat .price-cta {
  background:var(--gold); border-color:var(--gold); color:var(--ink);
  font-weight:700;
}
.price-card--feat .price-cta:hover { background:var(--gold-light); }
.price-note {
  text-align:center; margin:3rem auto 0;
  font-size:0.8rem; color:var(--ink-dim); max-width:520px;
  padding:1rem 2rem;
  background:var(--white); border:1px solid var(--border); border-radius:var(--r-md);
}
.price-note a { color:var(--green); text-decoration:underline; text-underline-offset:3px; }

/* ──────────────────────────────────────────────────────────────
   TESTIMONIALS — slider
────────────────────────────────────────────────────────────── */
.testimonials-sec { background:var(--green); overflow:hidden; }
.testimonials-sec .eyebrow { color:rgba(255,255,255,0.55); }
.testimonials-sec .eyebrow::before { background:rgba(255,255,255,0.4); }
.testimonials-sec .sec-title { color:var(--white); }

.slider-wrap { position:relative; overflow:hidden; margin-top:3.5rem; }
.slider-track {
  display:flex; gap:0; transition:transform 0.6s var(--ease);
}
.slide {
  min-width:100%; padding:0 10%;
  display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center;
}
.slide-quote {
  font-family:var(--ff-serif); font-size:1.85rem; font-weight:300; font-style:italic;
  line-height:1.5; color:var(--white);
}
.slide-quote::before {
  content:'\201C'; font-size:5rem; line-height:0.6; color:var(--gold); display:block;
  margin-bottom:0.75rem; font-style:normal;
}
.slide-meta { display:flex; flex-direction:column; gap:1.5rem; }
.slide-stars { font-size:1rem; letter-spacing:0.12em; color:var(--gold); }
.slide-author {
  display:flex; align-items:center; gap:1rem;
}
.slide-av {
  width:52px; height:52px; border-radius:50%;
  background:rgba(255,255,255,0.15); border:1px solid rgba(255,255,255,0.25);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-serif); font-size:1.1rem; color:var(--white); font-weight:500;
}
.slide-name { font-size:0.95rem; font-weight:600; color:var(--white); }
.slide-loc  { font-size:0.72rem; color:rgba(255,255,255,0.5); margin-top:0.15rem; }
.slide-detail {
  font-size:0.85rem; color:rgba(255,255,255,0.65); line-height:1.7;
  padding:1.25rem 1.5rem;
  border-left:2px solid var(--gold);
}

/* Slider controls */
.slider-controls {
  display:flex; align-items:center; justify-content:center; gap:1.5rem;
  margin-top:3rem;
}
.slider-btn {
  width:44px; height:44px; border-radius:50%;
  border:1px solid rgba(255,255,255,0.25);
  color:var(--white); font-size:1.1rem;
  display:flex; align-items:center; justify-content:center;
  transition:background var(--fast), border-color var(--fast);
}
.slider-btn:hover { background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.5); }
.slider-dots { display:flex; gap:0.5rem; }
.slider-dot {
  width:6px; height:6px; border-radius:50%;
  background:rgba(255,255,255,0.3);
  transition:background var(--fast), width var(--fast);
  cursor:pointer;
}
.slider-dot.active { background:var(--gold); width:20px; border-radius:3px; }

/* ──────────────────────────────────────────────────────────────
   INSURANCE
────────────────────────────────────────────────────────────── */
.insurance-sec { background:var(--white); }
.insurance-inner { text-align:center; max-width:600px; margin:0 auto; }
.ins-chips { display:flex; flex-wrap:wrap; justify-content:center; gap:1rem; margin-top:2.5rem; }
.ins-chip {
  padding:0.85rem 2.5rem; font-size:0.9rem; font-weight:600; letter-spacing:0.04em;
  color:var(--ink-muted); background:var(--cream); border:1px solid var(--border);
  border-radius:var(--r-full);
  transition:all var(--fast);
}
.ins-chip:hover { border-color:var(--green-light); color:var(--green); background:var(--green-mist); transform:translateY(-3px); box-shadow:var(--shadow-sm); }

/* ──────────────────────────────────────────────────────────────
   FAQ — accordion
────────────────────────────────────────────────────────────── */
.faq-sec { background:var(--cream); }
.faq-hdr { text-align:center; max-width:520px; margin:0 auto 4rem; }

.faq-list { max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:0.75rem; }
.faq-item {
  background:var(--white); border:1px solid var(--border); border-radius:var(--r-md);
  overflow:hidden; transition:border-color var(--fast), box-shadow var(--fast);
}
.faq-item.open { border-color:var(--green-pale); box-shadow:var(--shadow-sm); }
.faq-q {
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1.4rem 2rem; text-align:left;
  font-size:0.95rem; font-weight:500; color:var(--ink);
  cursor:pointer; transition:background var(--fast);
}
.faq-q:hover { background:var(--cream); }
.faq-icon {
  width:28px; height:28px; flex-shrink:0;
  border-radius:50%; border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; color:var(--green);
  transition:transform var(--mid) var(--ease), background var(--fast), border-color var(--fast);
}
.faq-item.open .faq-icon { transform:rotate(45deg); background:var(--green); border-color:var(--green); color:var(--white); }
.faq-a {
  max-height:0; overflow:hidden;
  transition:max-height 0.45s var(--ease), padding 0.35s var(--ease);
  padding:0 2rem;
}
.faq-a-inner {
  font-size:0.88rem; color:var(--ink-muted); line-height:1.82;
  padding:0 0 1.5rem;
}
.faq-item.open .faq-a { max-height:400px; padding:0 2rem; }

/* ──────────────────────────────────────────────────────────────
   CONTACT
────────────────────────────────────────────────────────────── */
.contact-sec { background:var(--white); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start; margin-top:4rem; }
.contact-hdr-col .sec-sub { max-width:360px; }
.contact-badge {
  display:inline-flex; align-items:center; gap:0.65rem;
  padding:0.5rem 1rem 0.5rem 0.75rem;
  background:var(--green-mist); border:1px solid rgba(44,74,62,0.2); border-radius:var(--r-full);
  margin-top:2rem;
}
.contact-badge-dot { width:6px; height:6px; border-radius:50%; background:var(--green); animation:dotPing 2s infinite; }
@keyframes dotPing {
  0%  { box-shadow:0 0 0 0 rgba(44,74,62,0.5); }
  70% { box-shadow:0 0 0 8px rgba(44,74,62,0); }
  100%{ box-shadow:0 0 0 0 rgba(44,74,62,0); }
}
.contact-badge-text { font-size:0.7rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--green); }

.contact-cards { display:flex; flex-direction:column; gap:1.25rem; }
.clinic-card {
  padding:2rem 2.5rem;
  background:var(--cream); border:1px solid var(--border); border-radius:var(--r-lg);
  transition:border-color var(--fast), box-shadow var(--fast), transform var(--mid) var(--spring);
}
.clinic-card:hover { border-color:var(--green-pale); box-shadow:var(--shadow-md); transform:translateY(-4px); }
.clinic-tag {
  display:inline-block; font-size:0.56rem; font-weight:700; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--green-light); margin-bottom:0.75rem;
}
.clinic-name { font-family:var(--ff-serif); font-size:1.25rem; font-weight:500; color:var(--ink); margin-bottom:0.6rem; }
.clinic-addr { font-size:0.84rem; color:var(--ink-muted); line-height:1.75; margin-bottom:1.25rem; }
.clinic-link {
  display:inline-flex; align-items:center; gap:0.4rem;
  font-size:0.76rem; font-weight:600; color:var(--green);
  transition:gap var(--fast);
}
.clinic-link:hover { gap:0.75rem; }

.contact-cta-row { text-align:center; margin-top:4rem; }

/* ──────────────────────────────────────────────────────────────
   FOOTER
────────────────────────────────────────────────────────────── */
.footer {
  background:var(--ink); color:rgba(255,255,255,0.75);
  padding:5rem 0 2.5rem;
}
.footer__grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:3rem; margin-bottom:3rem;
}
.footer__brand {
  font-family:var(--ff-serif); font-size:1.35rem; font-weight:500;
  color:var(--white); margin-bottom:0.75rem;
}
.footer__tagline { font-size:0.84rem; line-height:1.75; max-width:260px; }
.footer__col-hd {
  font-size:0.6rem; font-weight:700; letter-spacing:0.18em; text-transform:uppercase;
  color:rgba(255,255,255,0.3); margin-bottom:1.25rem;
}
.footer__links li { margin-bottom:0.65rem; }
.footer__links a {
  font-size:0.84rem; color:rgba(255,255,255,0.6);
  transition:color var(--fast);
}
.footer__links a:hover { color:var(--white); }
.footer__addr { font-size:0.84rem; line-height:1.82; }
.footer__hr { border:none; border-top:1px solid rgba(255,255,255,0.1); margin-bottom:1.5rem; }
.footer__btm { display:flex; justify-content:space-between; align-items:center; font-size:0.74rem; color:rgba(255,255,255,0.3); }
.footer__quals { display:flex; flex-wrap:wrap; gap:0.5rem; }
.footer__qual {
  font-size:0.56rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase;
  color:rgba(255,255,255,0.4);
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--r-full); padding:0.2rem 0.65rem;
}

/* Section nav dots */
.sec-nav {
  position:fixed; right:1.75rem; top:50%; transform:translateY(-50%);
  z-index:200; display:flex; flex-direction:column; gap:0.6rem;
}
.sec-dot {
  width:7px; height:7px; border-radius:50%; cursor:pointer;
  background:rgba(26,21,16,0.18);
  border:1px solid rgba(26,21,16,0.1);
  transition:background var(--fast), height var(--fast), transform var(--fast);
}
.sec-dot.active { background:var(--green); height:18px; border-radius:4px; border-color:var(--green); }
.sec-dot[data-label]:hover::before {
  content:attr(data-label);
  position:absolute; right:1.4rem; top:50%; transform:translateY(-50%);
  font-size:0.65rem; font-weight:500; letter-spacing:0.04em; white-space:nowrap;
  color:var(--ink); background:var(--white); border:1px solid var(--border);
  padding:0.25rem 0.75rem; border-radius:var(--r-full); box-shadow:var(--shadow-sm);
}
.sec-dot { position:relative; }

/* ──────────────────────────────────────────────────────────────
   RESPONSIVE
────────────────────────────────────────────────────────────── */
@media(max-width:1200px){
  .pricing-grid { grid-template-columns:repeat(2,1fr); }
  .specialty-grid { grid-template-columns:repeat(2,1fr); }
  .hero__inner { grid-template-columns:58% 42%; gap:2rem; }
  .sec-nav { display:none; }
  .pub-timeline::before { display:none; }
  .pub-block { grid-template-columns:1fr; gap:0; }
  .pub-block:nth-child(odd)  .pub-content,
  .pub-block:nth-child(even) .pub-content { grid-column:1; text-align:left; padding:0; }
  .pub-block:nth-child(odd)  .pub-dot,
  .pub-block:nth-child(even) .pub-dot,
  .pub-block .pub-empty { display:none; }
  .pub-content { margin-bottom:2rem; }
  .slide { grid-template-columns:1fr; padding:0 5%; gap:2rem; }
}
@media(max-width:1024px){
  .about-split { grid-template-columns:1fr; }
  .about__sticky-col { position:relative; height:380px; top:auto; }
  .contact-grid { grid-template-columns:1fr; gap:3rem; }
  .footer__grid { grid-template-columns:1fr 1fr; }
  /* Hero: stack portrait above text on tablet */
  .hero__inner { grid-template-columns:1fr; }
  .hero__portrait-col { order:-1; flex-direction:row; justify-content:center; align-items:flex-end; }
  .hero__arch { max-width:220px; }
  .hero__portrait-info { max-width:260px; }
  .hero__portrait-col::before, .hero__portrait-col::after { display:none; }
}
@media(max-width:820px){
  .glance-grid { grid-template-columns:repeat(2,1fr); gap:2rem; }
  .glance-item:not(:last-child)::after { display:none; }
  .about__scroll-col { padding:4rem 2.5rem; }
  .specialty-grid { grid-template-columns:1fr 1fr; }
  /* Hide nav links, show hamburger */
  .nav__links { display:none; }
  .nav__cta   { display:none; }
  .nav__hamburger { display:flex; }
  /* Mobile drawer */
  .mobile-menu-open .nav__links {
    display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1rem;
    position:fixed; inset:0; z-index:299;
    background:rgba(255,255,255,0.98); backdrop-filter:blur(20px);
    padding:5rem 2rem;
  }
  .mobile-menu-open .nav__links .nav__link { font-size:1.25rem; font-weight:500; color:var(--ink); }
  .mobile-menu-open .nav__links .nav__sep  { width:60px; height:1px; background:var(--border); margin:0.5rem 0; }
}
@media(max-width:768px){
  .specialty-grid { grid-template-columns:1fr; }
  .pricing-grid { grid-template-columns:1fr; }
  .footer__grid { grid-template-columns:1fr; }
  .faq-q { padding:1.25rem 1.5rem; }
  .faq-item.open .faq-a { padding:0 1.5rem; }
  :root { --sec: 5rem; }
  .hero { padding:7rem 0 4rem; }
  .hero__portrait-col { flex-direction:column; }
  .hero__arch { max-width:240px; }
  .hero__headline { font-size:clamp(3.2rem,10vw,5.5rem); }
}
@media(max-width:480px){
  .container { padding:0 1.25rem; }
  .hero__inner { padding:0 1.25rem; }
  .hero__arch { max-width:200px; }
  .glance-grid { grid-template-columns:1fr 1fr; gap:1.5rem; }
  .services-track-wrap { margin:0 -1.25rem; }
  .services-track { padding:0 1.25rem; }
}
