/* ============================================================
   SERVICE DETAIL PAGE  -  shared by all /services/* pages
   Sections: overview, what's involved, prices, what to expect,
   gallery strip, FAQ. Hero comes from page.css.
   ============================================================ */
.svc-overview, .svc-detail, .svc-prices,
.svc-steps, .svc-strip, .svc-faq {
  padding-block: clamp(3.5rem, 3rem + 4vw, 6.5rem);
}
.svc-overview { background: var(--cream); }
.svc-detail   { background: var(--oat); }
.svc-prices   { background: var(--cream); }
.svc-steps    { background: var(--oat); }
.svc-strip    { background: var(--cream); }
.svc-faq      { background: var(--oat); }

/* ---- overview ---- */
.svc-overview-grid { display: grid; gap: clamp(1.75rem, 1rem + 4vw, 3.5rem); }
.svc-overview-media { aspect-ratio: 4 / 5; overflow: hidden; }
.svc-overview-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.svc-overview-body { margin-top: var(--space-m); display: grid; gap: var(--space-s); }
.svc-overview-body p {
  font-size: var(--step-0);
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 56ch;
}
@media (min-width: 820px) {
  .svc-overview-grid {
    grid-template-columns: 0.8fr 1fr;
    align-items: center;
    gap: clamp(2.5rem, 5vw, 4.5rem);
  }
}

/* ---- shared section heads ---- */
.svc-detail-head, .svc-steps-head, .svc-strip-head, .svc-prices-head, .svc-faq-head {
  margin-bottom: clamp(1.75rem, 1rem + 3vw, 3rem);
}

/* ---- what's involved ---- */
.svc-detail-grid { display: grid; }
.svc-item {
  padding-block: clamp(1.25rem, 1rem + 1.5vw, 1.75rem);
  border-top: 1px solid var(--line);
}
.svc-item h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--step-1);
  color: var(--ink);
  margin-bottom: var(--space-xs);
}
.svc-item p {
  font-family: var(--font-body);
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 52ch;
}
@media (min-width: 760px) {
  .svc-detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: clamp(2rem, 5vw, 4rem);
  }
}

/* ---- prices ---- */
.price-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--line);
  max-width: 840px;
  display: grid;
}
.price-list li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding: 0.72rem 0;
  border-bottom: 1px solid var(--line);
}
.price-name { font-family: var(--font-body); font-size: 0.95rem; color: var(--ink); }
.price-figure {
  font-family: var(--font-body);
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  color: var(--ink-soft);
  white-space: nowrap;
}
.price-note {
  margin-top: var(--space-m);
  font-size: 0.85rem;
  line-height: 1.6;
  color: var(--stone);
  max-width: 60ch;
}
.price-note a {
  color: var(--wine);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
  transition: color 0.3s var(--ease);
}
.price-note a:hover { color: var(--wine-deep); }
@media (min-width: 760px) {
  .price-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: clamp(2.5rem, 5vw, 4.5rem);
  }
}

/* ---- what to expect ---- */
.svc-steps-grid { display: grid; gap: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.svc-step { padding-top: var(--space-m); border-top: 1px solid var(--line); }
.svc-step h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--step-1);
  color: var(--ink);
  margin-bottom: var(--space-xs);
}
.svc-step p {
  font-family: var(--font-body);
  font-size: 0.92rem;
  line-height: 1.6;
  color: var(--ink-soft);
}
@media (min-width: 760px) {
  .svc-steps-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(2rem, 4vw, 3rem);
  }
}

/* ---- gallery strip ---- */
.svc-strip-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(0.6rem, 2vw, 1.25rem);
}
.svc-strip-tile { display: block; aspect-ratio: 4 / 5; overflow: hidden; }
.svc-strip-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s var(--ease);
}
.svc-strip-tile:hover img { transform: scale(1.04); }
.svc-strip-foot { margin-top: clamp(1.5rem, 1rem + 2vw, 2.25rem); }
.svc-strip-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-body);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.76rem;
  color: var(--ink);
  text-decoration: none;
  transition: color 0.3s var(--ease);
}
.svc-strip-link svg { transition: transform 0.3s var(--ease); }
.svc-strip-link:hover { color: var(--wine); }
.svc-strip-link:hover svg { transform: translateX(4px); }

/* ---- FAQ (native accordion) ---- */
.faq-list { max-width: 840px; border-top: 1px solid var(--line); }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: clamp(1rem, 0.8rem + 1.2vw, 1.4rem) 0;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-q {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--step-1);
  line-height: 1.2;
  color: var(--ink);
}
.faq-icon { position: relative; flex: none; width: 16px; height: 16px; }
.faq-icon::before, .faq-icon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  background: var(--wine);
}
.faq-icon::before { width: 14px; height: 1.5px; transform: translate(-50%, -50%); }
.faq-icon::after {
  width: 1.5px;
  height: 14px;
  transform: translate(-50%, -50%);
  transition: opacity 0.3s var(--ease), transform 0.3s var(--ease);
}
.faq-item[open] .faq-icon::after { opacity: 0; transform: translate(-50%, -50%) rotate(90deg); }
.faq-answer { padding: 0 0 clamp(1rem, 0.8rem + 1.2vw, 1.4rem); }
.faq-answer p {
  font-family: var(--font-body);
  font-size: 0.95rem;
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 62ch;
}