/* css/pages.css — section + page-specific styles. Populated in later tasks. */

/* ========== Hero ========== */
.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: center;
  padding-top: 120px;
  overflow: hidden;
  isolation: isolate;
  background: var(--bg);
}
.hero__silk {
  position: absolute; inset: -10%;
  z-index: -1;
  background:
    radial-gradient(ellipse 80% 50% at 20% 30%, rgba(255,255,255,0.7), transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 70%, rgba(160,122,61,0.22), transparent 60%),
    radial-gradient(ellipse 70% 50% at 50% 100%, rgba(229,212,184,0.5), transparent 60%),
    linear-gradient(140deg, var(--c-cream) 0%, var(--c-silk) 60%, var(--c-champagne) 100%);
  filter: blur(2px);
  animation: silk-drift 22s var(--ease-silk) infinite alternate;
}
@keyframes silk-drift {
  0%   { transform: translate3d(0,0,0) scale(1); }
  50%  { transform: translate3d(-3%, 2%, 0) scale(1.05); }
  100% { transform: translate3d(2%, -2%, 0) scale(1.02); }
}
@media (prefers-reduced-motion: reduce) {
  .hero__silk { animation: none; }
}

.hero__inner { max-width: 980px; }
.hero__title {
  font-size: var(--fs-4xl);
  line-height: var(--lh-tight);
  color: var(--fg-strong);
  font-weight: 300;
  margin-block: var(--sp-6) var(--sp-6);
}
.hero__title em {
  font-style: italic;
  color: var(--accent);
  font-weight: 400;
}
.hero__sub {
  font-size: var(--fs-lg);
  max-width: 640px;
  color: var(--fg);
  margin-bottom: var(--sp-8);
  line-height: var(--lh-normal);
}
.hero__cta { display: flex; flex-wrap: wrap; gap: var(--sp-6); align-items: center; }

.hero__scrollcue {
  position: absolute; left: 50%; bottom: var(--sp-8);
  transform: translateX(-50%);
  width: 24px; height: 44px;
  display: flex; justify-content: center;
  opacity: 0.6;
}
.hero__scrollcue span {
  display: block; width: 1px; height: 36px; background: var(--accent);
  transform-origin: top;
  animation: scrollcue 2.2s ease-in-out infinite;
}
@keyframes scrollcue {
  0%   { transform: scaleY(0); transform-origin: top; }
  50%  { transform: scaleY(1); transform-origin: top; }
  51%  { transform: scaleY(1); transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

@media (max-width: 640px) {
  .hero { padding-top: 100px; }
  .hero__cta .btn--text { margin-left: 0; }
}

/* ========== Opening passage ========== */
.opening { text-align: left; }
.opening__lead {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  line-height: var(--lh-snug);
  color: var(--fg-strong);
  font-style: italic;
  font-weight: 400;
  margin-block: var(--sp-6) var(--sp-6);
  max-width: 22ch;
}
.opening__pull {
  margin-top: var(--sp-12);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--border);
  text-align: center;
  font-size: var(--fs-xl);
  color: var(--fg-strong);
  font-family: var(--font-display);
}
.opening__pull em { color: var(--accent); }
.opening__pull cite {
  display: block; margin-top: var(--sp-4);
  font-family: var(--font-body); font-style: normal;
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--fg-muted);
}

/* ========== Section header shared ========== */
.section__header { margin-bottom: var(--sp-16); max-width: 780px; }
.section__header h2 { margin-top: var(--sp-4); }
.section__header .eyebrow { margin-bottom: var(--sp-4); }

/* ========== Services grid ========== */
.services__grid {
  display: grid; gap: var(--sp-6);
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 900px) { .services__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .services__grid { grid-template-columns: 1fr; } }

/* ========== Signature / features ========== */
.feature {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-16);
  align-items: center;
  margin-bottom: var(--sp-24);
}
.feature:last-child { margin-bottom: 0; }
.feature--reverse .feature__media { order: 2; }
.feature__media {
  overflow: hidden;
  border-radius: var(--radius);
  aspect-ratio: 4 / 5;
  background: var(--c-silk);
}
.feature__media img { width: 100%; height: 100%; object-fit: cover; }
.feature__body { padding-inline: var(--sp-4); }
.feature__index {
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  color: var(--accent);
  margin-bottom: var(--sp-4);
  font-style: italic;
}
.feature__title {
  font-size: var(--fs-2xl);
  margin-bottom: var(--sp-6);
}
.feature p { margin-bottom: var(--sp-6); }

@media (max-width: 900px) {
  .feature, .feature--reverse { grid-template-columns: 1fr; gap: var(--sp-8); margin-bottom: var(--sp-16); }
  .feature--reverse .feature__media { order: 0; }
}

/* ========== Experience ========== */
.experience__steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-8);
  counter-reset: step;
  position: relative;
}
.experience__steps::before {
  content: ''; position: absolute;
  top: 38px; left: 5%; right: 5%; height: 1px;
  background: var(--border);
  z-index: 0;
}
.experience__step {
  position: relative; z-index: 1;
  padding-top: var(--sp-20);
  text-align: center;
}
.experience__num {
  position: absolute; top: 0; left: 50%;
  transform: translateX(-50%);
  width: 72px; height: 72px;
  border-radius: 50%;
  background: var(--c-offwhite);
  border: 1px solid var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  color: var(--accent);
  font-style: italic;
}
.experience__step h4 { font-size: var(--fs-lg); margin-bottom: var(--sp-3); }
.experience__step p { font-size: var(--fs-sm); margin-inline: auto; max-width: 26ch; }

@media (max-width: 900px) {
  .experience__steps { grid-template-columns: 1fr; gap: var(--sp-8); }
  .experience__steps::before { display: none; }
  .experience__step { text-align: left; padding-left: 100px; padding-top: var(--sp-2); }
  .experience__num { left: 0; transform: none; top: 0; }
  .experience__step h4 { margin-top: var(--sp-3); }
  .experience__step p { margin-inline: 0; }
}

/* ========== Doctor ========== */
.doctor__grid {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--sp-16);
  align-items: center;
}
.doctor__media { position: relative; }
.doctor__frame {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--c-silk);
}
.doctor__frame img { width: 100%; height: 100%; object-fit: cover; }
.doctor__caption {
  display: block;
  margin-top: var(--sp-4);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--fg-muted);
}
.doctor__creds {
  margin-block: var(--sp-8);
  display: grid; gap: var(--sp-3);
  border-top: 1px solid var(--border);
  padding-top: var(--sp-6);
}
.doctor__creds li {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--sp-4);
  padding-block: var(--sp-2);
  border-bottom: 1px solid var(--border);
}
.cred__label {
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--fg-muted);
}
.cred__value { font-family: var(--font-display); font-size: var(--fs-lg); color: var(--fg-strong); }

@media (max-width: 900px) {
  .doctor__grid { grid-template-columns: 1fr; gap: var(--sp-10); }
  .doctor__creds li { grid-template-columns: 120px 1fr; }
}

/* ========== Testimonials ========== */
.testim { margin-top: var(--sp-8); text-align: center; }
.testim__stage { position: relative; min-height: 240px; }
.testim__slide {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; gap: var(--sp-4);
  opacity: 0; visibility: hidden;
  transition: opacity var(--dur) var(--ease);
}
.testim__slide.is-active { opacity: 1; visibility: visible; position: relative; }
.testim__stars { color: var(--accent); letter-spacing: 4px; font-size: var(--fs-base); }
.testim__slide blockquote {
  font-family: var(--font-display); font-size: var(--fs-xl); color: var(--fg-strong);
  max-width: 58ch; line-height: var(--lh-snug);
}
.testim__slide figcaption { font-size: var(--fs-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--fg-muted); }

.testim__controls {
  margin-top: var(--sp-8);
  display: flex; align-items: center; justify-content: center; gap: var(--sp-6);
}
.testim__prev, .testim__next {
  width: 44px; height: 44px;
  border: 1px solid var(--border); border-radius: 50%;
  color: var(--accent);
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.testim__prev:hover, .testim__next:hover { background: var(--accent); color: var(--c-offwhite); }
.testim__dots { display: flex; gap: var(--sp-2); }
.testim__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--border);
  transition: background var(--dur-fast) var(--ease), width var(--dur) var(--ease);
}
.testim__dot.is-active { background: var(--accent); width: 22px; border-radius: 4px; }

/* ========== Visit ========== */
.visit__grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-16); align-items: start;
}
.visit__dl {
  margin-top: var(--sp-6);
  display: grid; grid-template-columns: 120px 1fr; gap: var(--sp-3) var(--sp-6);
  border-top: 1px solid var(--border);
  padding-top: var(--sp-6);
}
.visit__dl dt {
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--fg-muted);
  padding-top: var(--sp-1);
}
.visit__dl dd {
  margin: 0; padding-bottom: var(--sp-3); border-bottom: 1px solid var(--border);
  font-family: var(--font-display); font-size: var(--fs-lg); color: var(--fg-strong);
  font-weight: 400;
}
.visit__dl a { color: var(--accent); border-bottom: 1px solid var(--accent); }
.visit__map {
  aspect-ratio: 5 / 4;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--c-silk);
}
.visit__map iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.visit__map-placeholder { position: absolute; inset: 0; pointer-events: none; }
.visit__map iframe[src="REPLACE_ME_MAP"] { display: none; }
.visit__map iframe[src="REPLACE_ME_MAP"] + .visit__map-placeholder { pointer-events: auto; }

@media (max-width: 900px) {
  .visit__grid { grid-template-columns: 1fr; gap: var(--sp-8); }
  .visit__dl { grid-template-columns: 100px 1fr; }
}

/* ========== Booking ========== */
.booking__grid {
  display: grid; grid-template-columns: 5fr 6fr; gap: var(--sp-16); align-items: start;
}
.booking h2 { font-size: var(--fs-3xl); }
.booking .eyebrow { color: var(--c-champagne); } /* cream-toned: 7.2:1 on dark bg — WCAG AA pass (gold was 3.36:1) */
.booking p { color: rgba(245, 237, 225, 0.85); }
.booking .field__label { color: rgba(245, 237, 225, 0.7); }
.booking .field__input,
.booking .field__select,
.booking .field__textarea {
  background: rgba(255,255,255,0.06);
  border-color: rgba(245, 237, 225, 0.2);
  color: var(--c-offwhite);
}
.booking .field__input:focus,
.booking .field__select:focus,
.booking .field__textarea:focus {
  border-color: var(--accent);
  background: rgba(255,255,255,0.1);
}
/* .booking .btn--primary inherits --accent-text (#7a5c2c, 5.74:1 with off-white) from base rule */
.form__note {
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: rgba(245, 237, 225, 0.6);
  margin-top: var(--sp-3);
}

@media (max-width: 900px) {
  .booking__grid { grid-template-columns: 1fr; gap: var(--sp-10); }
}

/* ========== Footer ========== */
.footer {
  background: var(--bg-dark);
  color: rgba(245, 237, 225, 0.85);
  padding: var(--sp-20) 0 var(--sp-8);
}
.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: var(--sp-12);
  margin-bottom: var(--sp-16);
}
.footer__logo { height: 44px; filter: brightness(0) invert(1) sepia(0.4) saturate(3) hue-rotate(-20deg); }
.footer__tag { font-family: var(--font-display); font-style: italic; font-size: var(--fs-lg); max-width: 24ch; margin-top: var(--sp-4); color: rgba(245, 237, 225, 0.8); }
.footer h4 {
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--accent);
  margin-bottom: var(--sp-4); font-family: var(--font-body); font-weight: 500;
}
.footer__nav ul { display: grid; gap: var(--sp-2); }
.footer__nav a, .footer__contact a { color: inherit; transition: color var(--dur-fast) var(--ease); }
.footer__nav a:hover, .footer__contact a:hover { color: var(--accent); }
.footer__contact address { font-style: normal; line-height: var(--lh-loose); }
.footer__socials { margin-top: var(--sp-4); }
.footer__socials a { border-bottom: 1px solid var(--accent); padding-bottom: 2px; }
.footer__base {
  display: flex; justify-content: space-between;
  padding-top: var(--sp-6);
  border-top: 1px solid rgba(245, 237, 225, 0.12);
  font-size: var(--fs-xs); color: rgba(245, 237, 225, 0.5);
  letter-spacing: var(--tracking-wide); text-transform: uppercase;
}
@media (max-width: 900px) {
  .footer__grid { grid-template-columns: 1fr; gap: var(--sp-8); }
  .footer__base { flex-direction: column; gap: var(--sp-3); }
}

/* ========== Service pages ========== */
.svc-hero {
  min-height: 70vh;
  padding-top: 160px;
  padding-bottom: var(--sp-16);
  position: relative;
  background: linear-gradient(140deg, var(--c-cream) 0%, var(--c-silk) 50%, var(--c-champagne) 100%);
  overflow: hidden;
}
.svc-hero__inner { position: relative; z-index: 2; }
.svc-hero h1 {
  font-size: var(--fs-4xl);
  max-width: 18ch;
  margin-block: var(--sp-6) var(--sp-6);
}
.svc-hero__sub { max-width: 52ch; font-size: var(--fs-lg); }
.svc-grid-3 {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-8);
}
@media (max-width: 900px) { .svc-grid-3 { grid-template-columns: 1fr; } }
.svc-concern__list {
  display: grid; gap: var(--sp-3); margin-top: var(--sp-6);
}
.svc-concern__list li {
  display: flex; align-items: baseline; gap: var(--sp-3);
  padding-block: var(--sp-3); border-bottom: 1px solid var(--border);
  font-family: var(--font-display); font-size: var(--fs-lg); color: var(--fg-strong);
}
.svc-concern__list li::before { content: '—'; color: var(--accent); flex-shrink: 0; }
.svc-stage {
  padding: var(--sp-8);
  background: var(--bg-alt);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.svc-stage h4 {
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--accent);
  margin-bottom: var(--sp-4); font-family: var(--font-body); font-weight: 500;
}
.svc-timeline {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-8);
  position: relative;
}
.svc-timeline::before {
  content: ''; position: absolute; top: 20px; left: 10%; right: 10%; height: 1px; background: var(--border);
}
.svc-timeline__item { text-align: center; position: relative; padding-top: 50px; }
.svc-timeline__dot {
  position: absolute; top: 13px; left: 50%; transform: translateX(-50%);
  width: 14px; height: 14px; border-radius: 50%; background: var(--accent);
}
.svc-timeline__label {
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--fg-muted); margin-bottom: var(--sp-2);
}
.svc-timeline__title { font-family: var(--font-display); font-size: var(--fs-lg); }
@media (max-width: 900px) {
  .svc-timeline { grid-template-columns: 1fr; gap: var(--sp-6); }
  .svc-timeline::before { display: none; }
}
.svc-related {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-6);
}
@media (max-width: 640px) { .svc-related { grid-template-columns: 1fr; } }
