/* Home page styles — service grid, trust band, pricing tiers */

/* ================== 01 · HOME HERO (wide banner) ================== */
.home-hero {
  padding: 0 0 var(--space-section);
  background: var(--color-canvas);
}
.home-hero__banner {
  width: 100%;
  background: var(--color-surface-card);
  overflow: hidden;
}
.home-hero__banner img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 720px;
  object-fit: cover;
  object-position: center;
}
.home-hero__below {
  padding-top: clamp(40px, 5vw, 64px);
}
.home-hero__intro {
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  align-items: center;
}
.home-hero__intro .kicker { justify-content: center; }
.home-hero__h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(32px, 4.4vw, 52px);
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: var(--color-ink);
  margin: 0;
  max-width: 22ch;
}
.home-hero__lede {
  font-size: 17px;
  line-height: 1.7;
  color: var(--color-body);
  max-width: 64ch;
  margin: 0;
}
.home-hero__ctas {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  justify-content: center;
  margin-top: var(--space-md);
}
@media (max-width: 720px) {
  .home-hero__banner img { max-height: 480px; }
  .home-hero__intro { text-align: left; align-items: flex-start; }
  .home-hero__intro .kicker { justify-content: flex-start; }
  .home-hero__ctas { justify-content: flex-start; width: 100%; }
  .home-hero__ctas .btn { width: 100%; justify-content: center; }
}

/* awards styles moved to site.css for reuse across pages */

/* ================== 03 · DOCTOR FEATURE ================== */
.doctor-feature {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
}
.doctor-feature__portrait {
  position: relative;
  aspect-ratio: 4/5;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--color-surface-card);
}
.doctor-feature__portrait image-slot {
  display: block !important;
  width: 100% !important; height: 100% !important;
  aspect-ratio: auto !important;
  --slot-radius: 0;
  --slot-border: 0;
  --slot-bg: var(--color-surface-card);
}
.doctor-feature__badge {
  position: absolute;
  top: 20px; left: 20px;
  padding: 8px 16px;
  background: var(--color-primary);
  color: var(--color-on-primary);
  border-radius: var(--radius-pill);
  font: var(--type-caption);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  z-index: 2;
  box-shadow: var(--shadow-soft);
}
.doctor-feature__body { display: flex; flex-direction: column; gap: var(--space-md); }
.doctor-feature__body h2 {
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.05;
  font-size: clamp(32px, 4vw, 48px);
  margin: 0;
}
.doctor-feature__lede {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(18px, 1.8vw, 22px);
  color: var(--color-primary);
  margin: 0;
}
.doctor-feature__bio { display: flex; flex-direction: column; gap: var(--space-sm); }
.doctor-feature__bio p {
  font: var(--type-body-md);
  color: var(--color-body);
  line-height: 1.7;
  margin: 0;
}
.doctor-feature__bio strong { color: var(--color-ink); font-weight: 600; }

/* Doctor section on brand-green background — override colors for contrast */
.section--brand .doctor-feature__bio p { color: rgba(255, 255, 255, 0.88); }
.section--brand .doctor-feature__bio strong { color: var(--color-on-primary); }
.section--brand .doctor-feature__lede { color: rgba(255, 255, 255, 0.95); }
.section--brand .doctor-feature__pills {
  border-top-color: rgba(255, 255, 255, 0.18);
}
.section--brand .pill {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.2);
  color: var(--color-on-primary);
}
.section--brand .pill--primary {
  background: var(--color-on-primary);
  color: var(--color-primary-active);
  border-color: var(--color-on-primary);
}
.section--brand .doctor-feature__badge {
  background: var(--color-on-primary);
  color: var(--color-primary-active);
  font-weight: 600;
}
.doctor-feature__pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-hairline);
}
.pill {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  background: var(--color-canvas);
  border: 1px solid var(--color-hairline);
  border-radius: var(--radius-pill);
  font: var(--type-caption);
  color: var(--color-ink);
}
.pill--primary {
  background: var(--color-primary);
  color: var(--color-on-primary);
  border-color: var(--color-primary);
}
.doctor-feature__ctas {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  margin-top: var(--space-sm);
}
@media (max-width: 880px) {
  .doctor-feature { grid-template-columns: 1fr; }
}

/* ================== 03.5 · VISIT CLINIC ================== */
.visit-clinic {
  background: var(--color-canvas);
  padding-bottom: var(--space-section);
}
.visit-clinic__media {
  width: 100%;
  margin: 0 0 clamp(40px, 5vw, 64px);
  overflow: hidden;
  background: var(--color-surface-card);
}
.visit-clinic__media img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 640px;
  object-fit: cover;
  object-position: center;
}
.visit-clinic__copy {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  align-items: center;
}
.visit-clinic__copy .kicker { justify-content: center; }
.visit-clinic__copy h2 {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin: 0;
  max-width: 22ch;
}
.visit-clinic__copy p {
  font-size: 17px;
  line-height: 1.7;
  color: var(--color-body);
  max-width: 60ch;
  margin: 0;
}
.visit-clinic__rows {
  width: 100%;
  max-width: 560px;
  margin: var(--space-md) 0 var(--space-sm);
  display: flex;
  flex-direction: column;
  text-align: left;
}
.visit-clinic__row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-top: 1px solid var(--color-hairline);
}
.visit-clinic__row:last-child { border-bottom: 1px solid var(--color-hairline); }
.visit-clinic__row-l {
  font: var(--type-caption-uppercase);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.visit-clinic__row-r { font: var(--type-body-md); color: var(--color-ink); }
.visit-clinic__ctas {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
  justify-content: center;
  margin-top: var(--space-sm);
}
@media (max-width: 720px) {
  .visit-clinic__copy { text-align: left; align-items: flex-start; }
  .visit-clinic__copy .kicker { justify-content: flex-start; }
  .visit-clinic__ctas { justify-content: flex-start; width: 100%; }
  .visit-clinic__ctas .btn { width: 100%; justify-content: center; }
  .visit-clinic__media img { max-height: 420px; }
}

/* ================== 04 · 6 REASONS (horizontal compact) ================== */
.reasons-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}
/* Horizontal layout: icon (column 1) + content stack (column 2) */
.reason {
  background: var(--color-canvas);
  border: 1px solid var(--color-hairline);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  display: grid;
  grid-template-columns: 80px 1fr;
  grid-template-rows: auto auto 1fr;
  column-gap: var(--space-md);
  row-gap: 4px;
  align-items: start;
  transition: border-color 0.25s var(--ease), transform 0.25s var(--ease);
}
.reason:hover {
  border-color: var(--color-primary);
  transform: translateY(-2px);
}
.reason__icon {
  grid-column: 1;
  grid-row: 1 / -1;
  width: 80px;
  height: 80px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  align-self: start;
  margin: 0;
}
.reason__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.reason__num {
  grid-column: 2;
  grid-row: 1;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 18px;
  color: var(--color-primary);
  line-height: 1;
  margin: 0 0 2px;
}
.reason h3 {
  grid-column: 2;
  grid-row: 2;
  font: var(--type-title-md);
  color: var(--color-ink);
  font-weight: 600;
  margin: 0 0 4px;
  letter-spacing: -0.005em;
}
.reason p {
  grid-column: 2;
  grid-row: 3;
  font: var(--type-body-sm);
  color: var(--color-body);
  margin: 0;
}

/* Tablet — keep 2 cols, layout stays horizontal */
@media (max-width: 880px) {
  .reasons-grid { grid-template-columns: 1fr 1fr; }
}
/* Mobile — 1 col, slightly smaller icon */
@media (max-width: 560px) {
  .reasons-grid { grid-template-columns: 1fr; }
  .reason {
    grid-template-columns: 64px 1fr;
    column-gap: var(--space-sm);
    padding: var(--space-md);
  }
  .reason__icon { width: 64px; height: 64px; }
}

/* ================== 05 · SERVICES (10 · compact) ================== */
.svc-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-auto-rows: 1fr;
  gap: var(--space-sm);
}
.svc-grid .svc-card--featured {
  grid-column: span 2;
  grid-row: span 3;  /* keep 3 to fit 9 small cards in 3×3 alongside */
}
.svc-card {
  background: var(--color-canvas);
  border: 1px solid var(--color-hairline);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color 0.2s var(--ease), transform 0.2s var(--ease);
}
.svc-card:hover {
  border-color: var(--color-primary);
  transform: translateY(-2px);
}
.svc-card__image {
  aspect-ratio: 4/3;  /* was 1/1 — landscape saves vertical */
  background: var(--color-surface-card);
  overflow: hidden;
}
.svc-card__meta {
  padding: var(--space-sm) var(--space-md);  /* tighter padding for small cards */
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.svc-card--featured .svc-card__image { aspect-ratio: 4/3; }
.svc-grid .svc-card--featured .svc-card__image {
  aspect-ratio: auto;
  flex: 1;
  min-height: 220px;  /* was 320 — shorter featured */
}
.svc-grid .svc-card--featured .svc-card__meta {
  flex-shrink: 0;
}
.svc-card__image image-slot {
  display: block !important;
  width: 100% !important; height: 100% !important;
  aspect-ratio: auto !important;
  --slot-radius: 0;
  --slot-border: 0;
  --slot-bg: var(--color-surface-card);
}
/* (Old svc-card__meta rule consolidated above with compact padding) */
.svc-card--featured .svc-card__meta { padding: var(--space-md) var(--space-lg); gap: var(--space-xs); }
.svc-card__kicker { font: var(--type-caption); color: var(--color-muted); }
.svc-card h3 {
  font: var(--type-title-sm);
  color: var(--color-ink);
  font-weight: 500;
  margin: 0;
}
.svc-card--featured h3 {
  font-family: var(--font-display);
  font-size: clamp(22px, 2vw, 28px);
  font-weight: 600;
  letter-spacing: -0.025em;
}
.svc-card__link {
  font: var(--type-caption);
  color: var(--color-primary);
  margin-top: auto;
}
.svc-card--featured .svc-card__link {
  font: var(--type-button);
  margin-top: var(--space-sm);
}

@media (max-width: 980px) {
  .svc-grid { grid-template-columns: repeat(3, 1fr); }
  .svc-grid .svc-card--featured { grid-column: span 3; grid-row: auto; }
  .svc-card--featured .svc-card__image { aspect-ratio: 16/9; }
}
@media (max-width: 560px) {
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  .svc-grid .svc-card--featured { grid-column: span 2; }
}

/* ================== 06 · CELEBRITY REVIEWS ================== */
.celeb-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}
.celeb-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.celeb-card__thumb {
  position: relative;
  aspect-ratio: 9/16;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-surface-card);
}
.celeb-card__thumb image-slot {
  display: block !important;
  width: 100% !important; height: 100% !important;
  aspect-ratio: auto !important;
  --slot-radius: 0;
  --slot-border: 0;
  --slot-bg: var(--color-surface-card);
}
.celeb-card__play {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--color-canvas);
  color: var(--color-primary);
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
}
.celeb-card__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 18px;
  color: var(--color-ink);
  margin: 0;
  text-align: center;
  padding: 0 var(--space-sm);
}

@media (max-width: 720px) { .celeb-grid { grid-template-columns: 1fr; max-width: 320px; margin: 0 auto; } }

/* ================== Section foot (link-coral row) ================== */
.section-foot {
  display: flex;
  justify-content: center;
  margin-top: var(--space-xxl);
}

/* ================== 08 · BLOG (compact — fits 6 cards in viewport) ================== */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}
/* Override the shared .article-card to a denser layout for the home preview */
.blog-grid .article-card__cover { aspect-ratio: 16/9; }
.blog-grid .article-card__num {
  top: 10px; left: 10px;
  font-size: 14px;
  padding: 2px 10px;
}
.blog-grid .article-card__meta {
  padding: 14px 18px 16px;
  gap: 6px;
}
.blog-grid .article-card__tag {
  font-size: 11px;
  letter-spacing: 0.1em;
}
.blog-grid .article-card__title {
  font-size: 16.5px;
  line-height: 1.32;
}
/* Hide long excerpt to save vertical space — title + tag carry the message */
.blog-grid .article-card__excerpt { display: none; }
.blog-grid .article-card__date {
  font-size: 11px;
  padding-top: 8px;
  margin-top: 0;
}
.blog-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.blog-card__cover {
  aspect-ratio: 4/3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-surface-card);
  margin-bottom: var(--space-xs);
}
.blog-card__cover image-slot {
  display: block !important;
  width: 100% !important; height: 100% !important;
  aspect-ratio: auto !important;
  --slot-radius: 0;
  --slot-border: 0;
  --slot-bg: var(--color-surface-card);
}
.blog-card__tag {
  font: var(--type-caption);
  color: var(--color-muted);
  letter-spacing: 0.04em;
}
.blog-card h3 {
  font: var(--type-title-md);
  color: var(--color-ink);
  font-weight: 500;
  line-height: 1.35;
  margin: 0;
}
.blog-card:hover h3 { color: var(--color-primary); }

@media (max-width: 880px) { .blog-grid { grid-template-columns: 1fr; } }

/* ================== 10 · PARTNERS ================== */
.partners-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  background: var(--color-hairline);
  border: 1px solid var(--color-hairline);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.partner {
  background: var(--color-canvas);
  aspect-ratio: 3/2;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg) var(--space-md);
  transition: background 0.2s var(--ease), transform 0.2s var(--ease);
}
.partner:hover {
  background: var(--color-surface-soft);
  transform: translateY(-2px);
}
.partner img {
  max-width: 100%;
  max-height: 60%;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}
.partner span {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--color-muted);
}

@media (max-width: 880px) { .partners-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .partners-grid { grid-template-columns: repeat(2, 1fr); } }

.services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.service-card {
  background: var(--color-canvas);
  border: 1px solid var(--color-hairline);
  border-radius: var(--radius-lg);
  padding: 28px;
  display: flex; flex-direction: column; gap: 12px;
  min-height: 280px;
  transition: background 0.25s var(--ease), border-color 0.25s var(--ease);
}
.service-card:hover { background: var(--color-surface-card); border-color: var(--color-surface-card); }
.service-card--coral { background: var(--color-primary); color: var(--color-on-primary); border-color: transparent; }
.service-card--coral:hover { background: var(--color-primary-active); border-color: transparent; }
.service-card--coral .service-card__body { color: rgba(255,255,255,0.85); }
.service-card__kicker { font: var(--type-caption); color: var(--color-muted); }
.service-card--coral .service-card__kicker { color: rgba(255,255,255,0.7); }
.service-card__title {
  font-family: var(--font-display);
  font-size: clamp(26px, 2.4vw, 32px);
  font-weight: 600;
  line-height: 1.05;
  color: inherit;
  margin: 0;
}
.service-card__body { font: var(--type-body-sm); color: var(--color-body); flex: 1; }
.service-card .link-coral { margin-top: 8px; }

.trust-band {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
.trust-band__video {
  position: relative;
  aspect-ratio: 16/10;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-surface-card);
  display: block;
}
.trust-band__video::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(20,20,19,0.55) 100%);
  z-index: 1;
}
.trust-band__video image-slot {
  display: block !important;
  width: 100% !important; height: 100% !important;
  aspect-ratio: auto !important;
  --slot-radius: 0;
  --slot-border: 0;
  --slot-bg: var(--color-surface-card);
}
.trust-band__play {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 80px; height: 80px;
  border-radius: 50%;
  background: rgba(250,249,245,0.95);
  color: var(--color-primary);
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
}
.trust-band__video-overlay {
  position: absolute;
  bottom: 24px; left: 24px; right: 24px;
  z-index: 2;
  color: var(--color-on-dark);
}
.trust-band__side { display: flex; }
.trust-band__side .card { width: 100%; }

.trust-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.trust-grid .card { min-height: 200px; }
.trust-grid .card__title { font-size: 17px; }

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  max-width: 900px;
  margin: 0 auto;
}
.tier {
  background: var(--color-canvas);
  border: 1px solid var(--color-hairline);
  border-radius: var(--radius-lg);
  padding: 32px;
  display: flex; flex-direction: column; gap: 16px;
}
.tier--featured { background: var(--color-surface-dark); border: 0; }
.tier__head { display: flex; justify-content: space-between; align-items: center; }
.tier__name { font-family: var(--font-display); font-size: 24px; font-weight: 600; margin: 0; }
.tier__desc { font: var(--type-body-sm); color: var(--color-body); }
.tier__price { font-family: var(--font-display); display: flex; align-items: baseline; gap: 8px; }
.tier__price strong { font-size: 48px; font-weight: 400; letter-spacing: -0.4px; color: var(--color-ink); }
.tier__price span { font: var(--type-body-sm); color: var(--color-muted); }
.tier__cta { align-self: stretch; }
.tier__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.tier__list li { font: var(--type-body-sm); color: var(--color-body); padding-left: 22px; position: relative; }
.tier__list li::before {
  content: "";
  position: absolute;
  left: 0; top: 7px;
  width: 12px; height: 6px;
  border-left: 1.5px solid var(--color-primary);
  border-bottom: 1.5px solid var(--color-primary);
  transform: rotate(-45deg);
}
.tier__list--dark li { color: var(--color-on-dark-soft); }

@media (max-width: 960px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .trust-band { grid-template-columns: 1fr; }
  .trust-grid { grid-template-columns: 1fr; }
  .pricing-grid { grid-template-columns: 1fr; }
  .stats-strip > div { border-right: 0; border-bottom: 1px solid var(--color-hairline); padding: 16px 0; }
  .stats-strip > div:last-child { border-bottom: 0; }
  .hero__grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .services-grid { grid-template-columns: 1fr; }
}
