/* =========================================================================
   WEST U ORTHODONTICS — inner pages styles
   ========================================================================= */

/* ---- PAGE HERO (inner pages) ------------------------------------------- */

.page-hero {
  padding: clamp(48px, 7vw, 96px) 0 clamp(40px, 6vw, 80px);
  background: var(--teal-deep); color: var(--bone); position: relative; overflow: hidden;
}
.page-hero h1 { color: var(--bone); font-size: clamp(34px, 4.5vw, 60px); max-width: 700px; }
.page-hero .lead { color: rgba(250,245,237,.78); max-width: 560px; margin-top: 18px; }
.page-hero__eyebrow { display: flex; align-items: center; gap: 10px; font-family: var(--f-mono); font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--teal-tint); margin-bottom: 18px; }
.page-hero__eyebrow::before { content: ""; width: 24px; height: 1px; background: var(--teal-tint); }
.page-hero__watermark {
  position: absolute; right: -20px; bottom: -30px; opacity: .07; pointer-events: none;
  font-family: var(--f-display); font-size: 220px; font-weight: 400; white-space: nowrap;
  font-variation-settings: "SOFT" 70, "opsz" 144; line-height: 1; color: var(--bone);
  user-select: none;
}

/* ---- DOCTOR PAGE --------------------------------------------------------- */

.doctor-hero {
  padding: var(--section-y) 0;
}
.doctor-hero__inner { display: grid; grid-template-columns: 400px 1fr; gap: 64px; align-items: start; }
.doctor-hero__photo {
  border-radius: var(--r-lg); overflow: hidden; background: var(--teal-tint);
  aspect-ratio: 3/4; box-shadow: var(--shadow-card);
  position: sticky; top: 88px;
}
.doctor-hero__photo img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.doctor-hero__content { padding-top: 8px; }
.doctor-hero__tag {
  display: inline-flex; align-items: center; gap: 8px; margin-bottom: 20px;
  padding: 6px 14px; background: var(--teal-tint);
  border-radius: var(--r-pill); border: 1px solid rgba(10,112,112,.2);
  font-family: var(--f-mono); font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--teal-deep);
}
.doctor-hero__name { font-size: clamp(34px, 4vw, 52px); margin-bottom: 6px; }
.doctor-hero__title { font-family: var(--f-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--teal); margin-bottom: 24px; }
.doctor-hero__lead { font-size: clamp(16.5px, 1.4vw, 19.5px); line-height: 1.58; color: var(--ink-mute); margin-bottom: 32px; }
.doctor-creds {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 32px;
}
.doctor-cred {
  padding: 16px 18px; background: var(--white);
  border-radius: var(--r-md); border: 1px solid var(--rule);
}
.doctor-cred__label { font-family: var(--f-mono); font-size: 9.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--teal-deep); margin-bottom: 4px; }
.doctor-cred__value { font-size: 14px; font-weight: 500; color: var(--ink); line-height: 1.4; }

.doctor-memberships { margin-top: 32px; }
.doctor-memberships h3 { font-size: 17px; margin-bottom: 14px; }
.memberships-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.memberships-list li { font-size: 14.5px; color: var(--ink-mute); display: flex; align-items: center; gap: 10px; }
.memberships-list li::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--teal); flex-shrink: 0; }

.doctor-personal { margin-top: 36px; padding: 28px 26px; background: var(--bone-soft); border-radius: var(--r-md); border: 1px solid var(--rule); }
.doctor-personal h3 { font-size: 17px; margin-bottom: 14px; }
.doctor-personal p { font-size: 15px; color: var(--ink-mute); line-height: 1.6; margin-bottom: 10px; }
.doctor-personal p:last-child { margin-bottom: 0; }

@media (max-width: 900px) {
  .doctor-hero__inner { grid-template-columns: 1fr; gap: 36px; }
  .doctor-hero__photo { aspect-ratio: 4/3; position: static; max-height: 380px; }
  .doctor-creds { grid-template-columns: 1fr; }
}

/* ---- SERVICES PAGE ------------------------------------------------------- */

.services-intro { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-bottom: 56px; align-items: end; }
@media (max-width: 720px) { .services-intro { grid-template-columns: 1fr; gap: 20px; } }

.service-block { padding: var(--section-y) 0; border-bottom: 1px solid var(--rule); }
.service-block:last-child { border-bottom: none; }
.service-block__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.service-block:nth-child(even) .service-block__inner { direction: rtl; }
.service-block:nth-child(even) .service-block__inner > * { direction: ltr; }
.service-block__num { font-family: var(--f-mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: var(--blush); margin-bottom: 12px; }
.service-block h2 { font-size: clamp(26px, 3vw, 40px); margin-bottom: 16px; }
.service-block__body { font-size: 15.5px; color: var(--ink-mute); line-height: 1.62; margin-bottom: 20px; }
.service-block__list { list-style: none; margin: 0 0 24px; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.service-block__list li { font-size: 14.5px; color: var(--ink); display: flex; align-items: flex-start; gap: 10px; line-height: 1.48; }
.service-block__list li::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--teal); flex-shrink: 0; margin-top: 6px; }
.service-block__photo { border-radius: var(--r-lg); overflow: hidden; background: var(--teal-tint); aspect-ratio: 4/3; }
.service-block__photo img { width: 100%; height: 100%; object-fit: cover; }
.service-block__photo--blush { background: var(--blush-tint); }

@media (max-width: 860px) {
  .service-block__inner { grid-template-columns: 1fr; gap: 32px; }
  .service-block:nth-child(even) .service-block__inner { direction: ltr; }
}

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

.np-page-hero .page-hero__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.np-page-hero .page-hero__photo { border-radius: var(--r-lg); overflow: hidden; aspect-ratio: 4/3; background: rgba(255,255,255,.15); }
.np-page-hero .page-hero__photo img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 760px) { .np-page-hero .page-hero__inner { grid-template-columns: 1fr; } .np-page-hero .page-hero__photo { display: none; } }

.np-section { padding: var(--section-y) 0; }

.bring-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 14px; margin-top: 28px; }
.bring-card { padding: 20px 18px; background: var(--white); border-radius: var(--r-md); border: 1px solid var(--rule); box-shadow: var(--shadow-soft); }
.bring-card__icon { font-size: 22px; margin-bottom: 10px; }
.bring-card h4 { font-size: 15px; margin-bottom: 6px; }
.bring-card p { font-size: 13.5px; color: var(--ink-mute); margin: 0; line-height: 1.5; }

.np-timeline { display: flex; flex-direction: column; gap: 0; margin-top: 32px; }
.np-timeline-item { display: flex; gap: 24px; padding: 24px 0; position: relative; }
.np-timeline-item:not(:last-child)::after { content: ""; position: absolute; left: 19px; top: 68px; bottom: 0; width: 1px; background: var(--teal-tint); }
.np-timeline-num { width: 40px; height: 40px; border-radius: 50%; background: var(--teal); color: var(--white); display: flex; align-items: center; justify-content: center; font-family: var(--f-mono); font-size: 12px; font-weight: 500; flex-shrink: 0; margin-top: 2px; }
.np-timeline-item h3 { font-size: clamp(17px, 1.4vw, 20px); margin-bottom: 8px; }
.np-timeline-item p { font-size: 15px; color: var(--ink-mute); line-height: 1.58; margin: 0; }

.np-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
@media (max-width: 720px) { .np-two-col { grid-template-columns: 1fr; gap: 32px; } }

/* ---- BOOK PAGE ----------------------------------------------------------- */

.book-page { padding: var(--section-y) 0; }
.book-page__inner { display: grid; grid-template-columns: 380px 1fr; gap: 56px; align-items: start; }
.book-info { position: sticky; top: 88px; }
.book-info h2 { font-size: clamp(26px, 2.8vw, 38px); margin-bottom: 16px; }
.book-info__lead { font-size: 15.5px; color: var(--ink-mute); margin-bottom: 28px; line-height: 1.6; }
.book-info__card { background: var(--white); border-radius: var(--r-md); border: 1px solid var(--rule); padding: 22px 20px; margin-bottom: 14px; }
.book-info__card h4 { font-size: 13px; text-transform: uppercase; letter-spacing: .06em; font-family: var(--f-mono); color: var(--teal-deep); margin-bottom: 8px; }
.book-info__card p, .book-info__card a { font-size: 15px; color: var(--ink); margin: 0; }
.book-info__card a { color: var(--teal); }
.book-info__card a:hover { text-decoration: underline; }

@media (max-width: 860px) {
  .book-page__inner { grid-template-columns: 1fr; gap: 40px; }
  .book-info { position: static; }
}

/* ---- TEAM GRID ----------------------------------------------------------- */
.team-section { padding: var(--section-y) 0; }
.team-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 20px; margin-top: 32px; }
.team-card { background: var(--white); border-radius: var(--r-md); overflow: hidden; border: 1px solid var(--rule); box-shadow: var(--shadow-soft); }
.team-card__photo { aspect-ratio: 1/1; background: var(--bone-soft); overflow: hidden; }
.team-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.team-card__body { padding: 16px 18px; }
.team-card__name { font-size: 16px; margin-bottom: 2px; }
.team-card__role { font-family: var(--f-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--teal-deep); }

/* ---- ABO BADGE STRIP ----------------------------------------------------- */
.abo-strip { padding: 32px 0; background: var(--blush-tint); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.abo-strip__inner { display: flex; align-items: center; justify-content: center; gap: 24px; flex-wrap: wrap; text-align: center; }
.abo-badge { display: flex; align-items: center; gap: 14px; padding: 14px 22px; background: var(--white); border-radius: var(--r-md); border: 1px solid var(--rule); box-shadow: var(--shadow-soft); }
.abo-badge__icon { width: 40px; height: 40px; border-radius: 50%; background: var(--teal); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.abo-badge__icon svg { width: 20px; height: 20px; color: var(--white); }
.abo-badge__text { display: flex; flex-direction: column; }
.abo-badge__text strong { font-size: 15px; font-weight: 600; color: var(--ink); }
.abo-badge__text span { font-size: 12px; color: var(--ink-mute); }
