/* ── Services page overrides ─────────────────────────── */

body.services-body {
  overflow-x: hidden;
}

/* ── Layout ──────────────────────────────────────────── */

.svc-main {
  padding-top: clamp(72px, 10vh, 100px);
  min-height: 100dvh;
  background: var(--charcoal);
}

/* ── Page hero ───────────────────────────────────────── */

.svc-page-hero {
  padding: clamp(48px, 8vh, 96px) clamp(20px, 6vw, 80px) clamp(28px, 5vh, 56px);
  border-bottom: 1px solid var(--line);
}

.svc-page-hero .eyebrow {
  margin: 0 0 10px;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--copper);
}

.svc-page-hero h1 {
  margin: 0;
  font-size: clamp(3.6rem, 10vw, 8rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--ink);
}

/* ── Catalog grid ────────────────────────────────────── */

.svc-catalog {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(260px, 100%), 1fr));
  gap: 0;
  padding: 0 clamp(20px, 6vw, 80px) clamp(48px, 8vh, 96px);
}

/* ── Category section ────────────────────────────────── */

.svc-cat {
  padding: clamp(32px, 5vh, 56px) 0;
  border-bottom: 1px solid var(--line);
}

.svc-catalog .svc-cat:not(:last-child) {
  border-right: 1px solid var(--line);
  padding-right: clamp(24px, 4vw, 52px);
}

.svc-catalog .svc-cat:not(:first-child) {
  padding-left: clamp(24px, 4vw, 52px);
}

.svc-cat-title {
  margin: 0 0 clamp(16px, 2.8vh, 28px);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--rose);
  display: flex;
  align-items: center;
  gap: 14px;
  white-space: nowrap;
}

.svc-cat-title::after {
  content: "";
  display: block;
  flex: 1;
  height: 1px;
  background: var(--line);
  min-width: 24px;
}

/* ── Service list ────────────────────────────────────── */

.svc-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.svc-item {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  font-size: clamp(1.05rem, 2vw, 1.35rem);
  font-weight: 500;
  color: var(--muted);
  padding: clamp(10px, 1.6vh, 16px) 0;
  border-bottom: 1px solid rgba(249, 243, 236, 0.07);
  padding-inline-start: 0;
  transition:
    color 180ms ease,
    padding-inline-start 180ms ease;
  cursor: default;
}

.svc-item:last-child {
  border-bottom: none;
}

.svc-item:hover {
  color: var(--ink);
  padding-inline-start: 10px;
}

.svc-name { flex: 1; }

.svc-price {
  font-size: 0.78em;
  font-weight: 700;
  color: var(--copper);
  white-space: nowrap;
  text-align: end;
  flex-shrink: 0;
}

.svc-price-from,
.svc-price-range,
.svc-price-varies {
  font-weight: 600;
  opacity: 0.85;
}

/* ── RTL ─────────────────────────────────────────────── */

[dir="rtl"] .svc-page-hero .eyebrow,
[dir="rtl"] .svc-cat-title {
  letter-spacing: 0;
  text-transform: none;
}

[dir="rtl"] .svc-cat-title::after {
  order: -1;
}

[dir="rtl"] .svc-page-hero h1 {
  letter-spacing: 0;
}

/* ── Responsive: stack on narrow ─────────────────────── */

@media (max-width: 640px) {
  .svc-catalog {
    grid-template-columns: 1fr;
  }

  .svc-catalog .svc-cat:not(:last-child) {
    border-right: none;
    padding-right: 0;
  }

  .svc-catalog .svc-cat:not(:first-child) {
    padding-left: 0;
  }
}
