/* =========================================================================
   ETHOS CHIROPRACTIC & WELLNESS — page-specific components
   ========================================================================= */

/* ---- DOCTOR BLOCK (single doctor) --------------------------------------- */

.doctors-intro { display: grid; grid-template-columns: 1fr 1.4fr; gap: clamp(24px, 4vw, 72px); align-items: end; margin-bottom: clamp(40px, 5vw, 72px); }
.doctors-intro h2 { max-width: 18ch; }
.doctors-intro .lead { color: var(--ink); }

.doctor-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 3vw, 48px); }
.doctor-card {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: var(--shadow-soft);
}
.doctor-card__photo {
  aspect-ratio: 4 / 3;
  background: var(--sage-tint);
  position: relative; overflow: hidden;
}
.doctor-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.doctor-card__tag {
  position: absolute; top: 14px; left: 14px;
  background: var(--bone); color: var(--ink);
  padding: 6px 12px; border-radius: var(--r-pill);
  font-family: var(--f-mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase;
}
.doctor-card__body { padding: 30px 28px 32px; flex: 1; display: flex; flex-direction: column; }
.doctor-card__name { font-family: var(--f-display); font-size: clamp(26px, 2.4vw, 32px); line-height: 1.05; margin: 0 0 6px; }
.doctor-card__name span { color: var(--terra-deep); font-size: .65em; vertical-align: super; margin-left: 4px; }
.doctor-card__role { font-family: var(--f-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--sage-deep); margin: 0 0 18px; }
.doctor-card__bio { color: var(--ink-mute); margin: 0 0 22px; font-size: 15.5px; line-height: 1.6; }
.doctor-card__meta { border-top: 1px solid var(--rule); padding-top: 18px; }
.doctor-card__meta dt { font-family: var(--f-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-mute); margin: 0 0 4px; }
.doctor-card__meta dd { margin: 0 0 14px; font-size: 14.5px; }
.doctor-card__meta ul { margin: 0; padding-left: 18px; font-size: 14.5px; line-height: 1.7; color: var(--ink); }

/* single-doctor variant — full width */
.doctor-grid--single { grid-template-columns: 1fr; max-width: 860px; }
.doctor-grid--single .doctor-card { flex-direction: row; }
.doctor-grid--single .doctor-card__photo { aspect-ratio: 1 / 1; min-width: 300px; max-width: 320px; flex: 0 0 auto; }
@media (max-width: 880px) {
  .doctors-intro { grid-template-columns: 1fr; }
  .doctor-grid { grid-template-columns: 1fr; }
  .doctor-grid--single .doctor-card { flex-direction: column; }
  .doctor-grid--single .doctor-card__photo { min-width: 0; max-width: 100%; aspect-ratio: 4/3; }
}

/* ---- PHILOSOPHY ---------------------------------------------------------- */

.philosophy { background: linear-gradient(160deg, var(--slate) 0%, var(--slate-deep) 100%); color: #fff; padding: var(--section-y) 0; position: relative; overflow: hidden; }
.philosophy .wrap { position: relative; z-index: 2; }
.philosophy h2 { color: #fff; max-width: 22ch; margin-bottom: 56px; }
.philosophy .eyebrow { color: var(--bone-soft); }
.philosophy .eyebrow::before { background: var(--bone-soft); }
.philosophy__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(24px, 3vw, 48px); }
.philosophy__cell { border-top: 1px solid rgba(243,237,224,.32); padding: 24px 0 0; }
.philosophy__cell dt { font-family: var(--f-display); font-size: clamp(22px, 2vw, 28px); line-height: 1.1; margin: 0 0 14px; color: var(--bone); }
.philosophy__cell dd { margin: 0; color: rgba(243,237,224,.82); font-size: 15.5px; line-height: 1.65; }
@media (max-width: 880px) { .philosophy__grid { grid-template-columns: 1fr; } }

/* ---- CONDITIONS ---------------------------------------------------------- */

.conditions-head { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(24px, 4vw, 64px); align-items: end; margin-bottom: clamp(40px, 5vw, 72px); }
.conditions-head h2 { max-width: 16ch; }
.conditions { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--rule); border-left: 1px solid var(--rule); }
.condition {
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 28px 24px 32px;
  background: var(--bone);
  transition: background .25s ease;
}
.condition:hover { background: var(--bone-soft); }
.condition__num { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; color: var(--sage-deep); margin-bottom: 18px; }
.condition__name { font-family: var(--f-display); font-size: clamp(20px, 1.8vw, 24px); line-height: 1.15; margin: 0 0 12px; }
.condition__blurb { color: var(--ink-mute); margin: 0; font-size: 14.5px; line-height: 1.6; }
@media (max-width: 1100px) { .conditions { grid-template-columns: repeat(2, 1fr); } .conditions-head { grid-template-columns: 1fr; } }
@media (max-width: 540px)  { .conditions { grid-template-columns: 1fr; } }

/* ---- TREATMENT APPROACH -------------------------------------------------- */

.treatments-head { max-width: 60ch; margin: 0 auto clamp(48px, 6vw, 88px); text-align: center; }
.treatments-head h2 { margin: 16px auto 18px; }
.treatments-head .eyebrow { display: inline-flex; }

.treatment-row {
  display: grid; grid-template-columns: 100px 1fr 2fr;
  gap: clamp(14px, 2vw, 32px); align-items: baseline;
  padding: 28px 0; border-bottom: 1px solid var(--rule);
}
.treatment-row:first-child { border-top: 1px solid var(--rule); }
.treatment-row__num { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-mute); }
.treatment-row__name { font-family: var(--f-display); font-size: clamp(20px, 1.8vw, 24px); color: var(--ink); line-height: 1.2; }
.treatment-row__blurb { color: var(--ink-mute); font-size: 15.5px; line-height: 1.65; margin: 0; }
@media (max-width: 860px) {
  .treatment-row { grid-template-columns: 1fr; gap: 6px; }
  .treatment-row__name { font-size: 20px; }
}

.panel-quote {
  margin-top: clamp(48px, 6vw, 80px);
  padding: 40px 48px;
  background: var(--slate);
  border-radius: var(--r-lg);
  color: var(--bone);
  position: relative;
}
.panel-quote::before {
  content: "\201C";
  font-family: var(--f-display); font-size: 120px; line-height: 1; color: var(--cyan);
  opacity: .3; position: absolute; top: -8px; left: 32px;
  font-variation-settings: "SOFT" 100;
}
.panel-quote p { font-family: var(--f-display); font-size: clamp(22px, 2.4vw, 30px); line-height: 1.35; margin: 0 0 18px; color: var(--bone); position: relative; z-index: 2; }
.panel-quote cite { font-family: var(--f-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--cyan-tint); opacity: .9; font-style: normal; }
@media (max-width: 640px) { .panel-quote { padding: 28px 24px; } }

/* ---- PHOTO STRIP --------------------------------------------------------- */

.strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(10px, 1.5vw, 20px); margin: clamp(32px, 5vw, 72px) 0; border-radius: var(--r-lg); overflow: hidden; }
.strip__tile { aspect-ratio: 4/3; overflow: hidden; background: var(--sage-tint); }
.strip__tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .9s cubic-bezier(.2,.7,.2,1); }
.strip__tile:hover img { transform: scale(1.06); }
@media (max-width: 640px) { .strip { grid-template-columns: 1fr; } }

/* ---- NEW PATIENT --------------------------------------------------------- */

.np-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(40px, 6vw, 96px); align-items: start; }
.np-steps { list-style: none; margin: 36px 0 0; padding: 0; display: flex; flex-direction: column; gap: 0; }
.np-step { display: flex; gap: 20px; padding: 22px 0; border-bottom: 1px solid var(--rule); }
.np-step__num {
  flex: 0 0 40px; height: 40px;
  border-radius: 50%; background: var(--slate); color: #fff;
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 13px; font-weight: 500;
}
.np-step h4 { margin: 0 0 6px; }
.np-step p { margin: 0; color: var(--ink-mute); font-size: 15px; }
.np-photo { aspect-ratio: 4/5; border-radius: var(--r-lg); overflow: hidden; background: var(--sage-tint); box-shadow: var(--shadow-card); }
.np-photo img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 880px) { .np-grid { grid-template-columns: 1fr; } .np-photo { max-height: 480px; } }

/* ---- INSURANCE BAND ------------------------------------------------------ */

.insurance { background: var(--bone-soft); padding: var(--section-y) 0; }
.insurance__inner { display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(40px, 6vw, 96px); align-items: start; }
.insurance__notes { display: flex; flex-direction: column; gap: 24px; margin-top: 32px; }
.insurance__note { padding: 20px 24px; background: var(--white); border: 1px solid var(--rule); border-radius: var(--r-md); }
.insurance__note h4 { margin: 0 0 8px; }
.insurance__note p { margin: 0; color: var(--ink-mute); font-size: 14.5px; }
.insurance__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0; }
.insurance__list li { padding: 12px 0; border-bottom: 1px solid var(--rule); font-size: 15px; display: flex; align-items: center; gap: 10px; }
.insurance__list li::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--cyan); flex: 0 0 auto; }
@media (max-width: 880px) { .insurance__inner { grid-template-columns: 1fr; } }

/* ---- REVIEWS ------------------------------------------------------------- */

.reviews-head { text-align: center; margin-bottom: clamp(40px, 5vw, 64px); }
.reviews-head h2 { max-width: 24ch; margin: 0 auto 16px; }
.star { color: var(--terra); font-size: 20px; }

.review-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(18px, 2.4vw, 32px); }
.review {
  background: var(--white); border: 1px solid var(--rule); border-radius: var(--r-lg);
  padding: 32px; position: relative; overflow: hidden;
  box-shadow: var(--shadow-soft);
}
.review__mark { font-family: var(--f-display); font-size: 80px; line-height: 1; color: var(--cyan); opacity: .2; position: absolute; top: 8px; left: 20px; font-variation-settings: "SOFT" 100; }
.review p { position: relative; z-index: 2; color: var(--ink); font-size: 16px; line-height: 1.65; margin: 0 0 18px; font-style: italic; }
.review__by { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--sage-deep); }
@media (max-width: 640px) { .review-grid { grid-template-columns: 1fr; } }

/* ---- FAQ ----------------------------------------------------------------- */

.faq-head { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(24px, 4vw, 64px); align-items: end; margin-bottom: clamp(40px, 5vw, 64px); }
.faq-list { display: flex; flex-direction: column; gap: 0; }
.faq-item {
  border-bottom: 1px solid var(--rule);
  padding: 0;
  cursor: pointer;
}
.faq-item:first-child { border-top: 1px solid var(--rule); }
.faq-item summary {
  padding: 22px 0;
  font-family: var(--f-display); font-size: clamp(18px, 1.6vw, 22px);
  color: var(--ink); cursor: pointer; list-style: none;
  display: flex; justify-content: space-between; align-items: center; gap: 14px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; font-size: 24px; font-weight: 300; color: var(--sage); flex: 0 0 auto; transition: transform .2s ease; }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item p { padding: 0 0 22px; margin: 0; color: var(--ink-mute); font-size: 15.5px; line-height: 1.65; max-width: 72ch; }
@media (max-width: 880px) { .faq-head { grid-template-columns: 1fr; } }

/* ---- BOOK (contact form) ------------------------------------------------- */

.book { background: linear-gradient(160deg, var(--slate) 0%, var(--slate-deep) 100%); color: var(--bone); padding: var(--section-y) 0; }
.book__grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(40px, 6vw, 96px); align-items: start; }
.book h2, .book .eyebrow { color: var(--bone); }
.book .eyebrow::before { background: var(--terra-tint); }
.book__intro { color: rgba(243,237,224,.8); font-size: 16px; line-height: 1.6; margin: 18px 0 0; max-width: 40ch; }
.book__phone {
  display: inline-flex; align-items: center; gap: 16px;
  margin-top: 32px; padding: 16px 24px;
  background: rgba(243,237,224,.12); border: 1px solid rgba(243,237,224,.28);
  border-radius: var(--r-md); color: var(--bone);
  transition: background .2s ease;
}
.book__phone:hover { background: rgba(243,237,224,.2); }
.book__phone svg { width: 24px; height: 24px; color: var(--cyan); flex: 0 0 auto; }
.book__phone small { display: block; font-family: var(--f-mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--cyan-tint); }
.book__phone strong { display: block; font-family: var(--f-display); font-size: 24px; font-weight: 380; margin-top: 2px; }

.form { display: flex; flex-direction: column; gap: 16px; }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form__row--single { grid-template-columns: 1fr; }
.form__field { display: flex; flex-direction: column; gap: 6px; }
.form__field label { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; color: rgba(243,237,224,.75); }
.form__field input, .form__field select, .form__field textarea {
  background: rgba(243,237,224,.1); border: 1px solid rgba(243,237,224,.28);
  color: var(--bone); border-radius: var(--r-md);
  padding: 12px 16px; font: 15px/1.4 var(--f-body);
  transition: border-color .2s ease, background .2s ease;
}
.form__field input:focus, .form__field select:focus, .form__field textarea:focus {
  outline: none; border-color: var(--cyan); background: rgba(74,158,143,.12);
}
.form__field input::placeholder, .form__field textarea::placeholder { color: rgba(243,237,224,.38); }
.form__field select option { background: var(--slate); color: var(--bone); }
.form__field textarea { resize: vertical; min-height: 100px; }
.form__notice { font-size: 12.5px; color: rgba(243,237,224,.5); line-height: 1.5; }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 640px) { .form__row { grid-template-columns: 1fr; } }
@media (max-width: 880px) { .book__grid { grid-template-columns: 1fr; } }

/* ---- VISIT / MAP --------------------------------------------------------- */

.visit__grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: clamp(32px, 5vw, 80px); align-items: start; margin-top: 48px; }
.visit__details { display: flex; flex-direction: column; gap: 0; }
.visit__row { display: grid; grid-template-columns: 120px 1fr; gap: 14px; padding: 20px 0; border-bottom: 1px solid var(--rule); font-size: 15px; }
.visit__row:first-child { border-top: 1px solid var(--rule); }
.visit__row dt { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-mute); padding-top: 3px; }
.visit__row dd { margin: 0; color: var(--ink); line-height: 1.6; }
.visit__row dd a { color: var(--terra-deep); }
.visit__row small { display: block; color: var(--ink-mute); font-size: 13.5px; margin-top: 4px; }
.visit__hours { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.visit__hours li { display: flex; justify-content: space-between; gap: 8px; font-size: 14.5px; }
.visit__map { border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-soft); }
.visit__map iframe { width: 100%; height: 420px; border: 0; display: block; }
@media (max-width: 880px) { .visit__grid { grid-template-columns: 1fr; } }

/* ---- CTA BAND ------------------------------------------------------------ */

.cta-band { background: var(--terra); padding: clamp(56px, 7vw, 100px) 0; }
.cta-band__inner { display: flex; align-items: center; justify-content: space-between; gap: clamp(24px, 4vw, 64px); flex-wrap: wrap; }
.cta-band h2 { color: #fff; max-width: 22ch; }
.cta-band h2 em { color: rgba(255,255,255,.78); }
.cta-band .lead { color: rgba(255,255,255,.88); margin: 8px 0 0; max-width: 46ch; }
.cta-band__actions { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; flex: 0 0 auto; }
@media (max-width: 880px) { .cta-band__inner { flex-direction: column; align-items: flex-start; } }
