/* ============================================================
   Sanctuary Insurance: services.html page-scoped layer
   Inherits the locked system from styles.css (read-only).
   Everything here is scoped under body.page-services so it can
   never leak into the shell or another inner page.
   Hero VARIANT: a compact photographic split band (NOT the home
   layered-parallax scene), so this page reads as secondary.
   No em/en dashes. Mobile-first (375 base).
   ============================================================ */

/* ---------- HERO VARIANT: split copy + photo on the dark canvas ---------- */
.page-services .svc-hero {
  position: relative;
  background: var(--canvas);
  color: var(--ink-inverse);
  overflow: clip;
  isolation: isolate;
}
/* quiet warm wash so the variant keeps the brand temperature without the full scene */
.page-services .svc-hero::before {
  content: "";
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(90% 70% at 88% 0%, rgba(237,206,104,.16) 0%, rgba(237,206,104,0) 46%),
    radial-gradient(80% 60% at 4% 8%, rgba(244,169,192,.12) 0%, rgba(244,169,192,0) 44%);
}
.page-services .svc-hero .wrap { position: relative; z-index: 1; }
.page-services .svc-hero-grid {
  display: grid; grid-template-columns: 1fr; gap: 1.6rem; align-items: center;
  padding-block: clamp(2.2rem, 1.6rem + 4vw, 4rem);
}
.page-services .svc-hero .eyebrow {
  color: var(--warm); font-weight: 600; font-size: var(--fs-small); margin-bottom: .6rem;
}
.page-services .svc-hero h1 { color: var(--ink-inverse); max-width: 16ch; }
.page-services .svc-hero .lede {
  color: var(--ink-inverse-soft); font-size: clamp(1rem, .95rem + .3vw, 1.15rem);
  max-width: 46ch; margin-top: 1rem;
}
.page-services .svc-hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; margin-top: 1.5rem; }
.page-services .svc-hero-actions .btn-link { color: var(--ink-inverse); }
.page-services .svc-hero-stats {
  display: flex; flex-wrap: wrap; gap: .6rem 1.4rem; margin-top: 1.6rem;
  padding-top: 1.4rem; border-top: 1px solid var(--line-dark);
}
.page-services .svc-hero-stats .stat { display: flex; flex-direction: column; }
.page-services .svc-hero-stats .stat b { font-size: 1.5rem; font-weight: 700; color: var(--warm); line-height: 1.1; }
.page-services .svc-hero-stats .stat span { font-size: var(--fs-xs); color: var(--ink-inverse-soft); }
.page-services .svc-hero-media {
  position: relative; border-radius: var(--radius-lg); overflow: clip;
  box-shadow: var(--shadow-float);
  aspect-ratio: 16 / 11;
}
.page-services .svc-hero-media img { width: 100%; height: 100%; object-fit: cover; }
.page-services .svc-hero-media .media-badge {
  position: absolute; left: .9rem; bottom: .9rem;
  background: rgba(32,38,43,.86); color: var(--ink-inverse);
  border-radius: var(--radius); padding: .55rem .8rem;
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: var(--fs-xs); font-weight: 600;
  backdrop-filter: blur(4px);
}
.page-services .svc-hero-media .media-badge svg { width: 16px; height: 16px; color: var(--warm); }

/* ---------- COVER INDEX: the full twelve lines (icon-led tiles) ---------- */
.page-services .cover-grid { display: grid; grid-template-columns: 1fr; gap: .9rem; }
.page-services .cover-card {
  background: var(--surface); color: var(--ink);
  border: 1px solid var(--line-soft); border-radius: var(--radius);
  padding: 1.2rem; display: flex; flex-direction: column; gap: .5rem;
  transition: transform .18s var(--ease-out), box-shadow .18s var(--ease-out), border-color .18s var(--ease-out);
  scroll-margin-top: 5rem;
}
.page-services .cover-card:hover {
  transform: translateY(-3px); box-shadow: var(--shadow-card); border-color: var(--surface);
}
.page-services .cover-card:target { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(238,29,35,.18); }
.page-services .cover-ico {
  width: 42px; height: 42px; border-radius: 11px;
  display: grid; place-items: center; flex: 0 0 auto;
  background: var(--surface-2);
}
.page-services .cover-ico svg { width: 22px; height: 22px; color: var(--accent); }
.page-services .cover-card h3 { font-size: 1.1rem; }
.page-services .cover-card p { font-size: var(--fs-small); color: var(--ink-soft); line-height: 1.55; }
.page-services .cover-card .cover-link {
  margin-top: auto; padding-top: .4rem;
  font-size: var(--fs-small); font-weight: 600; color: var(--accent-deep);
  display: inline-flex; align-items: center; gap: .35rem;
}
.page-services .cover-card .cover-link svg { width: 15px; height: 15px; transition: transform .16s var(--ease-out); }
.page-services .cover-card:hover .cover-link svg { transform: translateX(3px); }

/* ---------- FEATURED DETAIL BANDS: alternating photo + copy ---------- */
.page-services .svc-detail { padding-block: clamp(2.6rem, 2rem + 4vw, 5rem); scroll-margin-top: 4.5rem; }
.page-services .svc-detail-grid {
  display: grid; grid-template-columns: 1fr; gap: 1.4rem; align-items: center;
}
.page-services .svc-detail-media {
  border-radius: var(--radius-lg); overflow: clip; box-shadow: var(--shadow-card);
  aspect-ratio: 16 / 11;
}
.page-services .svc-detail-media img { width: 100%; height: 100%; object-fit: cover; }
.page-services .svc-detail .eyebrow { font-size: var(--fs-small); font-weight: 600; color: var(--accent); margin-bottom: .5rem; }
.page-services .svc-detail.on-dark .eyebrow { color: var(--warm); }
.page-services .svc-detail h2 { max-width: 18ch; }
.page-services .svc-detail .detail-lede { margin-top: .8rem; max-width: 48ch; color: var(--ink-soft); }
.page-services .svc-detail.on-dark .detail-lede { color: var(--ink-inverse-soft); }
.page-services .svc-detail .detail-list { display: grid; gap: .6rem; margin-top: 1.2rem; }
.page-services .svc-detail .detail-list li { display: flex; gap: .55rem; font-size: var(--fs-small); align-items: flex-start; }
.page-services .svc-detail .detail-list .tick { flex: 0 0 auto; width: 18px; height: 18px; margin-top: 2px; color: var(--accent); }
.page-services .svc-detail.on-dark .detail-list .tick { color: var(--warm); }
.page-services .svc-detail .detail-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 1.5rem; }

/* ---------- RESPONSIVE ---------- */
@media (min-width: 720px) {
  .page-services .cover-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .page-services .svc-hero-grid { grid-template-columns: 1.05fr .95fr; gap: 2.2rem; }
  .page-services .svc-detail-grid { grid-template-columns: 1fr 1fr; gap: 2.2rem; }
  /* even detail bands flip the media to the right for rhythm */
  .page-services .svc-detail.flip .svc-detail-media { order: 2; }
}
@media (min-width: 980px) {
  .page-services .cover-grid { grid-template-columns: repeat(3, 1fr); }
  .page-services .svc-hero-grid { gap: 3rem; }
}

/* ---------- REDUCED MOTION (inherits styles.css; belt and braces) ---------- */
@media (prefers-reduced-motion: reduce) {
  .page-services .cover-card,
  .page-services .cover-card .cover-link svg { transition: none; }
}
