/**
 * Homepage sections — editorial, color-blocked, grid-driven.
 */

/* ============================================================
   Hero — full-bleed media + sunset scrim + trust band
   ============================================================ */
.hero { position: relative; isolation: isolate; display: flex; flex-direction: column; justify-content: center; min-height: 100vh; min-height: 100svh; overflow: hidden; }
.hero__bg { position: absolute; inset: 0; z-index: -2; }
.hero__bg .scene, .hero__media-fill { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; }
/* On phones the frame is narrow, so bias the crop toward the right of the photo
   to keep the people (who sit center-right) in view. */
@media (max-width: 719px) {
	.hero__media-fill { object-position: 65% center; }
}
/* Minimal dark tint: a touch stronger on the left where the text sits, so the
   white headline stays readable while keeping the photo bright on the right. */
.hero__scrim { position: absolute; inset: 0; z-index: -1; background:
	linear-gradient(90deg, rgba(20,16,12,0.62) 0%, rgba(20,16,12,0.38) 45%, rgba(20,16,12,0.16) 100%),
	linear-gradient(180deg, rgba(20,16,12,0.12) 0%, rgba(20,16,12,0.02) 45%, rgba(20,16,12,0.22) 100%); }

.hero__inner { width: 100%; padding-top: calc(var(--header-h) + var(--space-md)); padding-bottom: var(--space-2xl); }
.hero__content { max-width: 60ch; color: #fff; }
.hero__content .label { margin-bottom: var(--space-sm); color: var(--c-gold); }
.hero__title { margin: 0 0 var(--space-md); color: #fff; }
.hero__line { display: inline-block; overflow: hidden; vertical-align: top; padding-bottom: 0.08em; }
.hero__word { display: inline-block; }
.hero__word--accent { color: var(--c-gold); }
.hero__subhead { color: rgba(255,255,255,0.92); max-width: 48ch; margin-bottom: var(--space-lg); }
.hero__actions { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-sm); }

/* Scroll cue — a soft animated line at the bottom of the full-height hero */
.hero__scroll { position: absolute; left: 50%; bottom: var(--space-md); transform: translateX(-50%); z-index: 1; display: grid; place-items: center; width: 2.4rem; height: 3.4rem; }
.hero__scroll-line { width: 1.5px; height: 2.2rem; background: rgba(255,255,255,0.65); transform-origin: top; animation: lhg-scroll-cue 1.8s var(--ease-in-out) infinite; }
@keyframes lhg-scroll-cue { 0% { transform: scaleY(0); opacity: 0; } 40% { opacity: 1; } 100% { transform: scaleY(1); opacity: 0; } }

@media (min-width: 720px) {
	.hero__content { max-width: 70%; }
}
@media (min-width: 1040px) {
	.hero__content { max-width: 56%; }
}

/* ============================================================
   Intro (navy)
   ============================================================ */
.intro__grid { display: grid; gap: var(--space-lg); }
.intro__statement { max-width: 22ch; }
.intro__statement .word { display: inline-block; }
@media (min-width: 860px) {
	.intro__grid { grid-template-columns: 0.3fr 0.7fr; align-items: start; }
	.intro__label { padding-top: 0.8rem; }
}

/* ============================================================
   Services directory
   ============================================================ */
.services__head { margin-bottom: var(--space-lg); }
.services__title { margin: var(--space-sm) 0 0; max-width: 16ch; }

.directory { border-top: 1px solid var(--rule); }
.dir-row { border-bottom: 1px solid var(--rule); }
.dir-row__link {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: var(--space-md);
	padding: var(--space-lg) 0;
	color: var(--text);
	transition: padding var(--dur) var(--ease-out), color var(--dur) var(--ease-out);
}
.dir-row__num { font-family: var(--font-label); font-size: var(--fs-label); color: var(--text-muted); align-self: start; padding-top: 0.5rem; }
.dir-row__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.6rem, 1rem + 2.6vw, 3rem); letter-spacing: -0.02em; line-height: 1.02; }
.dir-row__desc { display: none; color: var(--text-soft); max-width: 40ch; }
.dir-row__chev { width: 2.6rem; height: 2.6rem; border-radius: 50%; border: 1.5px solid var(--rule-strong); position: relative; flex: none; transition: background-color var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out), transform var(--dur) var(--ease-out); }
.dir-row__chev::after { content: ""; position: absolute; top: 50%; left: 50%; width: 0.5rem; height: 0.5rem; border-top: 1.5px solid currentColor; border-right: 1.5px solid currentColor; transform: translate(-60%, -50%) rotate(45deg); }
.dir-row__link:hover { color: var(--brand-strong); padding-inline: var(--space-md); }
.dir-row__link:hover .dir-row__chev { background: var(--c-orange); border-color: var(--c-orange); color: #fff; transform: rotate(0); }
@media (min-width: 860px) {
	.dir-row__link { grid-template-columns: 4rem minmax(0, 1.1fr) minmax(0, 1fr) auto; }
	.dir-row__desc { display: block; }
	.services__head { display: grid; grid-template-columns: 1fr 1fr; align-items: end; }
	.services__title { margin: 0; }
}

/* ============================================================
   Conditions (orange block) — intro on top, three-column index
   ============================================================ */
.conditions__head { max-width: 38ch; margin-bottom: var(--space-xl); }
.conditions__head .label { color: rgba(42,20,7,0.66); }
.conditions__title { color: #2a1407; margin: var(--space-sm) 0 var(--space-md); max-width: 16ch; }
.conditions__lead { color: rgba(42,20,7,0.84); max-width: 50ch; margin: 0; font-size: var(--fs-lead); line-height: 1.5; }

.conditions__grid { display: grid; grid-template-columns: 1fr; border-top: 1.5px solid rgba(42,20,7,0.22); }
.cond { display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-md) 0; border-bottom: 1px solid rgba(42,20,7,0.22); transition: padding var(--dur) var(--ease-out); }
.cond:hover { padding-inline: var(--space-xs); }
.cond__mark { width: 0.5rem; height: 0.5rem; flex: none; border-radius: 50%; background: #2a1407; opacity: 0.5; transition: opacity var(--dur) var(--ease-out), transform var(--dur) var(--ease-out); }
.cond:hover .cond__mark { opacity: 1; transform: scale(1.3); }
.cond__name { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.1rem, 0.95rem + 0.55vw, 1.5rem); color: #2a1407; letter-spacing: -0.01em; }
@media (min-width: 620px) {
	.conditions__grid { grid-template-columns: 1fr 1fr; column-gap: var(--space-2xl); }
}
@media (min-width: 980px) {
	.conditions__grid { grid-template-columns: 1fr 1fr 1fr; }
}

/* ============================================================
   Care team — provider cards
   ============================================================ */
.team__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-xl); }
.provider-card { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); align-items: center; }
.provider-card__photo { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-lg); }
.provider-card__photo .imgslot { border-radius: var(--radius); }
.provider-card__name { font-size: var(--fs-h2); margin: 0 0 0.3rem; line-height: 1.02; }
.provider-card__role { font-family: var(--font-label); font-size: var(--fs-small); letter-spacing: 0.02em; color: var(--brand-strong); margin: 0 0 var(--space-md); }
.provider-card__creds { color: var(--text-muted); letter-spacing: 0.04em; text-transform: uppercase; font-size: 0.78rem; }
.provider-card__bio { color: var(--text-soft); margin: 0; max-width: 44ch; }
.team__cta { margin-top: var(--space-xl); }
@media (min-width: 560px) {
	.provider-card { grid-template-columns: 0.7fr 1fr; gap: var(--space-lg); }
}
@media (min-width: 920px) {
	.team__grid { grid-template-columns: 1fr 1fr; gap: var(--space-2xl); }
	.provider-card { grid-template-columns: 0.8fr 1fr; }
}

/* ============================================================
   Office — inside the practice
   ============================================================ */
.office__head { max-width: 40ch; margin-bottom: var(--space-xl); }
.office__title { margin: var(--space-sm) 0 var(--space-sm); }
.office__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
.office__item { margin: 0; overflow: hidden; border-radius: var(--radius); background: var(--c-warm-2); }
.office__item img { width: 100%; height: 100%; object-fit: cover; display: block; aspect-ratio: 4 / 3; }
@media (min-width: 760px) {
	.office__grid { grid-template-columns: 1fr 1fr; }
	.office__item--lead { grid-column: 1 / -1; }
	.office__item--lead img { aspect-ratio: 16 / 7; }
}

/* ============================================================
   Why (navy grid)
   ============================================================ */
.why__head { margin-bottom: var(--space-xl); }
.why__title { margin: var(--space-sm) 0 0; max-width: 18ch; }
.why__grid { display: grid; grid-template-columns: 1fr; gap: 0; border-top: 1px solid var(--rule-invert); }
.why-item { padding: var(--space-lg) 0; border-bottom: 1px solid var(--rule-invert); }
.why-item__mark { display: block; width: 2rem; height: 3px; border-radius: 2px; background: var(--c-gold); }
.why-item__title { color: var(--c-white); font-size: var(--fs-h3); margin: var(--space-sm) 0 0.5rem; }
.why-item__desc { color: rgba(243,234,217,0.72); margin: 0; max-width: 46ch; }
@media (min-width: 760px) {
	.why__grid { grid-template-columns: 1fr 1fr; column-gap: var(--space-2xl); }
	.why-item { padding: var(--space-lg) 0; }
}

/* ============================================================
   Testimonials
   ============================================================ */
.testimonials__head { margin-bottom: var(--space-lg); }
.testimonials__featured { margin: 0 0 var(--space-xl); }
.testimonials__quote { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.5rem, 1rem + 2.4vw, 2.85rem); line-height: 1.12; letter-spacing: -0.025em; margin: 0 0 var(--space-md); max-width: 24ch; text-wrap: balance; }
.testimonials__quote::before { content: "“"; color: var(--c-orange); }
.testimonials__author { font-family: var(--font-label); font-size: var(--fs-label); letter-spacing: var(--track-label); text-transform: uppercase; color: var(--text-muted); }
.testimonials__row { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); padding-top: var(--space-lg); }
.note__quote { font-size: var(--fs-lead); line-height: 1.45; margin: 0 0 var(--space-sm); color: var(--text); }
.note__author { font-family: var(--font-label); font-size: var(--fs-label); letter-spacing: var(--track-label); text-transform: uppercase; color: var(--text-muted); }
@media (min-width: 860px) {
	.testimonials__quote { max-width: 28ch; }
	.testimonials__row { grid-template-columns: 1fr 1fr; gap: var(--space-2xl); }
}

/* ============================================================
   CTA band (sunset gradient)
   ============================================================ */
/* ============================================================
   Appointment — closing CTA with booking form (sunset gradient)
   ============================================================ */
.appointment { background: var(--gradient-cta); color: #fff; overflow: hidden; }
.appointment__inner { display: grid; gap: var(--space-xl); align-items: center; }
.appointment__intro .label { color: rgba(255,255,255,0.85); margin-bottom: var(--space-md); }
.appointment__title { color: #fff; margin: 0 0 var(--space-md); max-width: 14ch; }
.appointment__lead { color: rgba(255,255,255,0.92); margin-bottom: var(--space-lg); max-width: 40ch; }
.appointment__phone { display: inline-flex; flex-direction: column; gap: 0.2rem; color: #fff; }
.appointment__phone:hover { color: #fff; }
.appointment__phone-k { font-family: var(--font-label); font-size: var(--fs-label); letter-spacing: var(--track-label); text-transform: uppercase; opacity: 0.85; }
.appointment__phone-v { font-family: var(--font-display); font-weight: 700; font-size: 1.6rem; }
.appointment__panel { background: #fff; color: var(--text); border-radius: var(--radius-lg); padding: var(--space-lg); box-shadow: var(--shadow-lg); }
.appointment__fallback { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.appointment__hint { flex-basis: 100%; margin: var(--space-sm) 0 0; font-size: var(--fs-small); color: var(--text-muted); }
@media (min-width: 900px) {
	.appointment__inner { grid-template-columns: 1fr 1fr; gap: var(--space-2xl); }
}

/* ============================================================
   Welcome (editorial two-column text intro)
   ============================================================ */
.welcome__grid { display: grid; gap: var(--space-lg); }
.welcome__head .label { margin-bottom: var(--space-sm); }
.welcome__title { margin: 0; }
.welcome__lead { margin-bottom: var(--space-lg); }
.welcome__actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
@media (min-width: 900px) {
	.welcome__grid { grid-template-columns: 0.85fr 1fr; gap: var(--space-2xl); align-items: start; }
	.welcome__title { font-size: var(--fs-display); }
}

/* ============================================================
   Service cards
   ============================================================ */
.services__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); }
.svc-card { background: #fff; border: 1px solid var(--rule); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); transition: transform var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out); }
.svc-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.svc-card__link { display: block; color: inherit; }
.svc-card__media { border-radius: 0; }
.svc-card__body { position: relative; padding: var(--space-lg); }
.svc-card__icon { position: absolute; top: calc(-1.5rem); left: var(--space-lg); display: grid; place-items: center; width: 3rem; height: 3rem; border-radius: 50%; background: var(--gradient-sun); color: #fff; box-shadow: var(--shadow-brand); }
.svc-card__icon .icon { width: 1.4rem; height: 1.4rem; }
.svc-card__title { margin: var(--space-sm) 0 0.4rem; font-size: var(--fs-h3); }
.svc-card__desc { color: var(--text-soft); margin: 0 0 var(--space-sm); font-size: var(--fs-small); }
.svc-card__more { font-family: var(--font-label); font-weight: 600; font-size: var(--fs-small); color: var(--brand-strong); }
@media (min-width: 600px) { .services__grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1040px) { .services__grid { grid-template-columns: repeat(4, 1fr); } }

/* ============================================================
   FAQ
   ============================================================ */
.faq__grid { display: grid; gap: var(--space-lg); }
.faq__intro .label { margin-bottom: var(--space-sm); }
.faq__title { margin: 0 0 var(--space-sm); }
.faq__lead { margin-bottom: var(--space-md); }
.faq__list { display: flex; flex-direction: column; }
.faq-item { border-top: 1px solid var(--rule); }
.faq-item:last-child { border-bottom: 1px solid var(--rule); }
.faq-item__q { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); cursor: pointer; list-style: none; font-family: var(--font-display); font-weight: 700; font-size: var(--fs-h3); padding: var(--space-md) 0; }
.faq-item__q::-webkit-details-marker { display: none; }
.faq-item__mark { position: relative; width: 1.2rem; height: 1.2rem; flex: none; }
.faq-item__mark::before, .faq-item__mark::after { content: ""; position: absolute; top: 50%; left: 0; width: 100%; height: 2px; background: var(--brand); transform: translateY(-50%); transition: transform var(--dur) var(--ease-out), opacity var(--dur) var(--ease-out); }
.faq-item__mark::after { transform: translateY(-50%) rotate(90deg); }
.faq-item[open] .faq-item__mark::after { transform: translateY(-50%) rotate(0); opacity: 0; }
.faq-item__a { color: var(--text-soft); padding: 0 0 var(--space-md); max-width: 62ch; }
@media (min-width: 900px) { .faq__grid { grid-template-columns: 0.8fr 1fr; gap: var(--space-2xl); align-items: start; } }

/* ============================================================
   Procedures — editorial index with icons
   ============================================================ */
.procedures__grid { display: grid; grid-template-columns: 1fr; border-top: 1px solid var(--rule); }
.proc { display: grid; grid-template-columns: auto 1fr; gap: var(--space-md); padding: var(--space-lg) 0; border-bottom: 1px solid var(--rule); }
.proc__icon { display: grid; place-items: center; width: 3rem; height: 3rem; flex: none; border-radius: 50%; background: var(--c-warm-2); color: var(--brand-strong); }
.proc__icon .icon { width: 1.4rem; height: 1.4rem; }
.proc__title { font-size: var(--fs-h3); margin: 0 0 0.4rem; }
.proc__desc { color: var(--text-soft); margin: 0; max-width: 54ch; }
@media (min-width: 760px) {
	.procedures__grid { grid-template-columns: 1fr 1fr; column-gap: var(--space-2xl); }
}

/* ============================================================
   Patient resources — quick links
   ============================================================ */
.resources__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-md); margin-top: var(--space-lg); }
.res-card { display: flex; align-items: center; gap: var(--space-md); padding: var(--space-lg); background: var(--bg); border: 1px solid var(--rule); border-radius: var(--radius); color: var(--text); transition: transform var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out), border-color var(--dur) var(--ease-out); }
.res-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: transparent; color: var(--text); }
.res-card__icon { display: grid; place-items: center; width: 3rem; height: 3rem; flex: none; border-radius: 50%; background: var(--gradient-sun); color: #fff; box-shadow: var(--shadow-brand); }
.res-card__icon .icon { width: 1.4rem; height: 1.4rem; }
.res-card__text { display: flex; flex-direction: column; }
.res-card__title { font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; line-height: 1.1; }
.res-card__sub { font-size: var(--fs-small); color: var(--text-soft); margin-top: 0.15rem; }
.res-card__arrow { margin-left: auto; color: var(--brand-strong); font-size: 1.2rem; transition: transform var(--dur) var(--ease-out); }
.res-card:hover .res-card__arrow { transform: translateX(4px); }
@media (min-width: 640px) { .resources__grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1040px) { .resources__grid { grid-template-columns: repeat(4, 1fr); } }

/* ============================================================
   Shared section heading
   ============================================================ */
.section-head { display: grid; gap: var(--space-sm); margin-bottom: var(--space-xl); }
.section-head .label { margin-bottom: var(--space-2xs); }
.section-head__title { font-size: var(--fs-display); max-width: 18ch; margin: 0; }
.section-head__lead { max-width: 46ch; }
@media (min-width: 900px) { .section-head { grid-template-columns: 1.15fr 1fr; align-items: end; gap: var(--space-lg); } }
