/* =====================================================================
   Services pages: category catalog and text-first service detail.
   ===================================================================== */

.svc-page-hero .wrap,
.svc-detail-hero .wrap {
  display: grid;
  gap: var(--space-10);
}

.svc-detail-hero {
  min-block-size: clamp(360px, 44vh, 520px);
  display: flex;
  align-items: end;
}

.svc-detail-hero .wrap {
  padding-block-end: var(--space-8);
}

.svc-detail-hero h1 {
  max-inline-size: 12ch;
}

.screen.page-hero.svc-page-hero,
.screen.page-hero.svc-detail-hero {
  background: var(--ink);
}

.page-hero.svc-page-hero::after,
.page-hero.svc-detail-hero::after {
  display: none;
}

.svc-catalog-intro {
  max-width: var(--container-lg);
  margin-block-end: var(--space-12);
}

.svc-catalog-intro .sec-head {
  margin-block-end: 0;
}

.svc-catalog-tools {
  align-items: center;
  gap: var(--space-6);
  justify-content: space-between;
}

.svc-catalog-tools .svc-tabs {
  flex: 0 1 auto;
  inline-size: fit-content;
  max-inline-size: 100%;
  min-height: 56px;
  align-items: center;
}

.svc-catalog-tools .svc-tab {
  min-height: 46px;
  padding-block: var(--space-4);
  padding-inline: var(--space-7);
  line-height: var(--leading-snug);
}

.svc-catalog-tools .svc-tab.active {
  background: var(--aegold-600);
}

.svc-search {
  flex: 0 0 210px;
  inline-size: 210px;
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: var(--space-4);
  min-height: 56px;
  padding-inline: var(--space-7);
  border: 1px solid var(--line);
  border-radius: var(--radius-full);
  background: var(--bg-surface);
  color: var(--aegold-700);
}

.svc-search input {
  width: 100%;
  min-width: 0;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--fg-primary);
  font: inherit;
}

.svc-search input::placeholder {
  color: var(--fg-tertiary);
}

.svc-search:focus-within {
  border-color: var(--focus-ring);
  box-shadow: var(--shadow-ring);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.svc-catalog-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
  max-width: none;
  margin-inline: 0;
}

.svc-catalog-grid .svc-card {
  min-height: 0;
  gap: var(--space-5);
  padding: var(--space-8);
}

.svc-catalog-grid .svc-card h3 {
  display: -webkit-box;
  min-height: 0;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.svc-catalog-grid .svc-card p {
  display: -webkit-box;
  max-inline-size: 36ch;
  min-height: 0;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.svc-catalog-grid .svc-card .svc-go {
  margin-block-start: var(--space-2);
}

.svc-tag {
  align-self: start;
  display: inline-flex;
  padding-block: 0;
  padding-inline: var(--space-4) 0;
  border: 0;
  border-inline-start: 2px solid var(--aegold-500);
  border-radius: 0;
  background: transparent;
  color: var(--fg-secondary);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  line-height: var(--leading-snug);
}

.svc-card.is-filtered {
  display: none;
}

.svc-empty {
  margin: var(--space-12) 0 0;
  padding: var(--space-10);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--bg-surface);
  color: var(--fg-secondary);
  text-align: center;
}

.svc-detail-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 420px);
  gap: var(--space-12);
  align-items: end;
}

.svc-detail-actions {
  display: flex;
  gap: var(--space-6);
  justify-content: end;
  flex-wrap: wrap;
}

.svc-action {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-5);
  padding-inline: var(--space-10);
  border: 1px solid var(--line);
  border-radius: var(--radius-full);
  font-weight: var(--weight-bold);
  line-height: 1.7;
  text-decoration: none;
}

.svc-action .ic {
  inline-size: 18px;
  block-size: 18px;
  flex: 0 0 auto;
}

.svc-action-light {
  background: var(--bg-surface);
  color: var(--aegold-800);
  border-color: var(--aegold-200);
}

.svc-action-gold {
  background: var(--aegold-600);
  color: var(--fg-on-gold);
  border-color: var(--aegold-600);
  box-shadow: var(--shadow-gold);
}

.svc-action:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.svc-action-gold:hover {
  color: var(--fg-on-gold);
}

.svc-detail-layout {
  display: grid;
  grid-template-columns: minmax(250px, 310px) minmax(0, 1fr);
  gap: var(--space-13);
  align-items: start;
  padding-block-start: var(--space-4);
}

.svc-side {
  position: sticky;
  inset-block-start: calc(var(--hdr) + var(--space-8));
  display: grid;
  gap: var(--space-8);
}

.svc-index,
.svc-side-cta {
  background: var(--bg-surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
}

.svc-index {
  padding: var(--space-8);
}

.svc-index h2 {
  font-size: var(--text-h6);
  margin: 0 0 var(--space-8);
}

.svc-index a {
  display: block;
  padding-block: var(--space-6);
  padding-inline: var(--space-6);
  border-block-start: 1px solid var(--border-subtle);
  color: var(--fg-primary);
  text-decoration: none;
  font-weight: var(--weight-semibold);
}

.svc-index a:hover {
  color: var(--aegold-700);
  background: var(--aegold-50);
}

.svc-side-cta {
  padding: var(--space-8);
}

.svc-side-cta p {
  margin: 0 0 var(--space-8);
  color: var(--fg-secondary);
  line-height: var(--leading-loose);
}

.svc-side-cta .svc-action {
  width: 100%;
}

.svc-side-tools {
  display: grid;
  gap: var(--space-4);
  margin-block-start: var(--space-6);
}

.svc-tool {
  min-height: 46px;
  display: flex;
  align-items: center;
  gap: var(--space-5);
  padding-block: var(--space-4);
  padding-inline: var(--space-6);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-surface);
  color: var(--fg-primary);
  font-weight: var(--weight-semibold);
  line-height: var(--leading-snug);
  text-decoration: none;
}

.svc-tool .ic {
  inline-size: 20px;
  block-size: 20px;
  flex: 0 0 auto;
  color: var(--aegold-700);
}

.svc-tool:hover {
  border-color: var(--aegold-200);
  background: var(--aegold-50);
  color: var(--aegold-800);
}

.svc-detail-main {
  display: grid;
  gap: var(--space-12);
}

.svc-text-section {
  scroll-margin-top: calc(var(--hdr) + var(--space-10));
  padding-block-end: var(--space-12);
  border-block-end: 1px solid var(--border-subtle);
}

.svc-text-section:last-child {
  border-block-end: 0;
  padding-block-end: 0;
}

.svc-section-kicker {
  margin: 0 0 var(--space-5);
  color: var(--aegold-700);
  font-weight: var(--weight-bold);
}

.svc-text-section h2 {
  font-size: clamp(26px, 2.6vw, 38px);
  margin-block-end: var(--space-8);
}

.svc-lead {
  font-size: var(--text-lg);
  line-height: var(--leading-loose);
  color: var(--fg-primary);
}

.svc-text-section p {
  color: var(--fg-secondary);
  line-height: var(--leading-loose);
}

.svc-inline-steps {
  display: grid;
  gap: var(--space-5);
  margin-block: var(--space-8) 0;
  padding-inline-start: var(--space-11);
  color: var(--fg-primary);
}

.svc-inline-steps li {
  padding-block: var(--space-5);
  padding-inline: var(--space-6);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-surface);
  line-height: var(--leading-loose);
}

.svc-inline-steps strong,
.svc-inline-steps span {
  display: block;
}

.svc-inline-steps span {
  margin-block-start: var(--space-2);
  color: var(--fg-secondary);
}

.svc-chip-list {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin: 0 0 var(--space-8);
  padding: 0;
}

.svc-chip-list li {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding-inline: var(--space-6);
  border: 1px solid var(--aegold-200);
  border-radius: var(--radius-full);
  background: var(--bg-surface);
  color: var(--aegold-800);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  line-height: var(--leading-snug);
}

.svc-text-list {
  display: grid;
  gap: var(--space-6);
  margin: 0;
  padding-inline-start: var(--space-11);
  color: var(--fg-primary);
  line-height: var(--leading-loose);
}

.svc-inner-list,
.svc-link-list {
  display: grid;
  gap: var(--space-5);
  margin: 0;
  padding-inline-start: var(--space-10);
  color: var(--fg-secondary);
  line-height: var(--leading-loose);
}

.svc-link-list a {
  color: var(--aegold-700);
  font-weight: var(--weight-semibold);
}

.svc-text-steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-8);
}

.svc-text-steps li {
  display: grid;
  gap: var(--space-3);
  padding-block-end: var(--space-8);
  border-block-end: 1px solid var(--border-subtle);
}

.svc-text-steps li:last-child {
  border-block-end: 0;
  padding-block-end: 0;
}

.svc-text-steps strong {
  color: var(--fg-primary);
}

.svc-text-steps span {
  color: var(--fg-secondary);
  line-height: var(--leading-loose);
}

.svc-accordion {
  display: grid;
  gap: var(--space-4);
}

.svc-accordion details {
  background: var(--bg-surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.svc-accordion summary {
  cursor: pointer;
  padding: var(--space-8) var(--space-10);
  font-weight: var(--weight-bold);
  color: var(--fg-primary);
}

.svc-accordion summary::marker {
  color: var(--aegold-700);
}

.svc-accordion details > div {
  padding: 0 var(--space-10) var(--space-9);
}

.svc-accordion details > div p {
  margin: 0;
}

@media (max-width: 1080px) {
  .svc-detail-hero-grid,
  .svc-detail-layout {
    grid-template-columns: 1fr;
  }

  .svc-catalog-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: none;
    margin-inline: 0;
  }

  .svc-detail-actions {
    justify-content: start;
  }

  .svc-side {
    position: static;
  }

  .svc-detail {
    padding-block-start: var(--space-13);
  }
}

@media (max-width: 760px) {
  .svc-catalog-tools {
    align-items: stretch;
  }

  .svc-tabs,
  .svc-search {
    inline-size: 100%;
  }

  .svc-search {
    flex-basis: auto;
    min-width: 0;
  }

  .svc-catalog-grid {
    grid-template-columns: 1fr;
    max-width: 460px;
    margin-inline: auto;
  }

  .svc-detail-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .svc-action {
    width: 100%;
  }
}
