/* ── Service page shared styles ─────────────────────────────── services.css */

/* Hero */
.svc-hero { background: var(--canvas); padding: 64px 0 80px; }
.svc-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.svc-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--mute); margin-bottom: 20px;
}
.svc-breadcrumb a { color: var(--body); text-decoration: none; }
.svc-breadcrumb a:hover { color: var(--charcoal); }
.svc-hero-h1 {
  font-family: var(--font-display);
  font-size: clamp(38px, 5vw, 58px);
  font-weight: 600;
  line-height: 1.06;
  letter-spacing: -0.6px;
  color: var(--charcoal);
  margin: 0 0 20px;
}
.svc-hero-desc {
  font-size: 18px;
  line-height: 1.65;
  color: var(--body);
  margin: 0 0 32px;
  max-width: 480px;
}
.svc-hero-actions { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; margin-bottom: 28px; }
.svc-hero-phone {
  display: flex; align-items: center; gap: 8px;
  font-size: 15px; font-weight: 500; color: var(--charcoal);
  text-decoration: none;
}
.svc-hero-phone:hover { color: var(--bronze); }
.svc-hero-trust { display: flex; flex-direction: column; gap: 8px; }
.svc-trust-item {
  display: flex; align-items: center; gap: 8px;
  font-size: 14px; color: var(--body-mid);
}
.svc-hero-img-wrap { position: relative; }
.svc-hero-img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  border-radius: var(--radius-lg);
  display: block;
}
.svc-hero-badge {
  position: absolute;
  bottom: 24px;
  left: -24px;
  background: #fff;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-2);
  padding: 14px 20px;
  min-width: 180px;
}
.svc-hero-badge-num {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 700;
  color: var(--charcoal);
  line-height: 1;
}
.svc-hero-badge-label {
  font-size: 12px;
  color: var(--mute);
  margin-top: 4px;
  line-height: 1.4;
}

/* Split sections */
.svc-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}
.svc-split-img img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: var(--radius-lg);
  display: block;
}
.svc-split-img { position: relative; }
.svc-section-h2 {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.5vw, 38px);
  font-weight: 600;
  letter-spacing: -0.4px;
  color: var(--charcoal);
  margin: 0 0 16px;
}
.svc-body-p {
  font-size: 16px;
  line-height: 1.75;
  color: var(--body);
  margin: 0 0 16px;
}
.svc-checklist { display: flex; flex-direction: column; gap: 12px; margin-top: 24px; }
.svc-check-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 15px;
  color: var(--body);
  line-height: 1.5;
}
.svc-check-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 2px;
  stroke: var(--bronze);
}

/* Benefits grid */
.svc-benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.svc-benefit-card {
  background: #fff;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  padding: 28px 24px;
}
.svc-benefit-icon {
  width: 44px; height: 44px;
  background: var(--canvas-soft);
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.svc-benefit-h3 {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--charcoal);
  margin: 0 0 8px;
}
.svc-benefit-p {
  font-size: 14px;
  line-height: 1.65;
  color: var(--body);
  margin: 0;
}

/* Process band */
.svc-process-band {
  background: var(--charcoal);
  padding: 88px 0;
}
.svc-steps {
  display: flex;
  align-items: flex-start;
  gap: 0;
}
.svc-step {
  flex: 1;
  padding: 0 32px;
}
.svc-step:first-child { padding-left: 0; }
.svc-step:last-child  { padding-right: 0; }
.svc-step-divider {
  width: 1px;
  background: rgba(255,255,255,0.12);
  align-self: stretch;
  flex-shrink: 0;
}
.svc-step-num {
  font-family: var(--font-display);
  font-size: 40px;
  font-weight: 700;
  color: var(--bronze-light);
  line-height: 1;
  margin-bottom: 16px;
}
.svc-step-h3 {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 600;
  color: #fff;
  margin: 0 0 12px;
}
.svc-step-p {
  font-size: 15px;
  line-height: 1.7;
  color: rgba(255,255,255,0.65);
  margin: 0;
}

/* Pull quote */
.svc-pullquote {
  text-align: center;
  padding: 0 24px;
}
.svc-pullquote-mark {
  font-family: var(--font-display);
  font-size: 80px;
  line-height: 0.5;
  color: var(--bronze-light);
  margin-bottom: 24px;
}
.svc-pullquote-text {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.5vw, 26px);
  font-weight: 500;
  line-height: 1.45;
  color: var(--charcoal);
  margin: 0 0 32px;
  letter-spacing: -0.2px;
}
.svc-pullquote-attr {
  display: flex; align-items: center; gap: 12px;
  justify-content: center;
}
.svc-pullquote-avatar {
  width: 44px; height: 44px;
  border-radius: 9999px;
  background: var(--charcoal);
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  display: flex; align-items: center; justify-content: center;
}
.svc-pullquote-name  { font-size: 15px; font-weight: 600; color: var(--charcoal); }
.svc-pullquote-detail { font-size: 13px; color: var(--mute); margin-top: 2px; }

/* FAQ */
.svc-faq { display: flex; flex-direction: column; gap: 0; border: 1px solid var(--hairline); border-radius: var(--radius-md); overflow: hidden; }
.svc-faq-item {
  border-bottom: 1px solid var(--hairline);
  background: #fff;
}
.svc-faq-item:last-child { border-bottom: none; }
.svc-faq-q {
  list-style: none;
  padding: 20px 24px;
  font-size: 16px;
  font-weight: 500;
  color: var(--charcoal);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  user-select: none;
}
.svc-faq-q::-webkit-details-marker { display: none; }
.svc-faq-q::after {
  content: '+';
  font-size: 22px;
  font-weight: 300;
  color: var(--mute);
  flex-shrink: 0;
  transition: transform .2s ease;
}
details[open] .svc-faq-q::after { content: '−'; }
.svc-faq-a {
  padding: 0 24px 20px;
  border-top: 1px solid var(--hairline);
}
.svc-faq-a p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--body);
  margin: 16px 0 0;
}

/* Denture-specific: comparison table */
.svc-compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 15px;
}
.svc-compare-table th {
  background: var(--charcoal);
  color: #fff;
  padding: 14px 20px;
  text-align: left;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.3px;
}
.svc-compare-table th:first-child { border-radius: var(--radius-sm) 0 0 0; }
.svc-compare-table th:last-child  { border-radius: 0 var(--radius-sm) 0 0; }
.svc-compare-table td {
  padding: 14px 20px;
  border-bottom: 1px solid var(--hairline);
  vertical-align: top;
  color: var(--body);
  line-height: 1.5;
}
.svc-compare-table tr:last-child td { border-bottom: none; }
.svc-compare-table tr:nth-child(even) td { background: var(--canvas-soft); }
.svc-compare-table td:first-child { font-weight: 500; color: var(--charcoal); }
.svc-compare-icon-yes { color: #16a34a; }
.svc-compare-icon-no  { color: #dc2626; }

/* ── PAGE-LEVEL RESPONSIVE GRID CLASSES ─────────────────────────────────── */

/* Hero 2-col (used on services, dental-implants, denture-solutions) */
.page-hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 56px;
  align-items: end;
}

/* Alternating section splits */
.svc-section-split {
  display: grid;
  gap: 56px;
  align-items: center;
}
.svc-section-split--img-left  { grid-template-columns: 0.9fr 1.1fr; }
.svc-section-split--img-right { grid-template-columns: 1.1fr 0.9fr; }

/* Services family layout: sticky eyebrow + scrollable row list */
.svc-family-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 48px;
  align-items: start;
}

/* 3-column band (How It Works) */
.svc-3col-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}

/* ── RESPONSIVE ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .svc-benefits-grid { grid-template-columns: repeat(2, 1fr); }
  .svc-steps { flex-direction: column; gap: 40px; }
  .svc-step { padding: 0 !important; }
  .svc-step-divider { width: 100%; height: 1px; align-self: auto; }
}

@media (max-width: 768px) {
  .svc-hero { padding: 48px 0 56px; }
  .svc-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .svc-hero-img-wrap { order: 1; }
  .svc-hero-badge { left: 0; bottom: 16px; }
  .svc-split { grid-template-columns: 1fr; gap: 36px; }
  .svc-split-img { order: -1 !important; }
  .svc-benefits-grid { grid-template-columns: 1fr; }
  .svc-process-band { padding: 56px 0; }
  .svc-pullquote-text { font-size: 19px; }
  .svc-compare-table { font-size: 13px; }
  .svc-compare-table th,
  .svc-compare-table td { padding: 10px 12px; }
}

@media (max-width: 480px) {
  .svc-hero-h1 { font-size: 32px; }
  .svc-hero-desc { font-size: 16px; }
  .svc-hero-actions { flex-direction: column; align-items: flex-start; gap: 12px; }
  .svc-hero-badge { position: relative; bottom: auto; left: auto; margin-top: 16px; }
  .svc-section-h2 { font-size: 26px; }
}

/* 2-col equal cards grid */
.svc-2col-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}

/* ── PAGE-LEVEL GRID BREAKPOINTS ─────────────────────────────────────────── */
@media (max-width: 768px) {
  /* Hero collapses to single column */
  .page-hero-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  /* Hero h1 and CTA column go full-width */
  .page-hero-grid > div:last-child {
    padding-bottom: 0;
  }

  /* Alternating splits → single column, image always on top */
  .svc-section-split,
  .svc-section-split--img-left,
  .svc-section-split--img-right {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  /* img-right: image is last child → pull it above text */
  .svc-section-split--img-right > div:last-child {
    order: -1;
  }

  /* Family sidebar collapses: remove sticky, go full-width */
  .svc-family-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .svc-family-grid > div:first-child {
    position: static !important;
  }

  /* 3-col → 1-col */
  .svc-3col-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  /* 2-col cards → 1-col */
  .svc-2col-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  /* Page-level heading sizes */
  .page-hero-h1  { font-size: 38px !important; line-height: 1.08 !important; }
  .page-section-h2 { font-size: 28px !important; }
}

@media (max-width: 480px) {
  .page-hero-h1  { font-size: 30px !important; }
  .page-section-h2 { font-size: 24px !important; }
}
