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

.svc-detail .wrap {
  min-width: 0;
  max-width: 100%;
}

main:has(.svc-detail) {
  min-width: 0;
}

.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: 100%;
  overflow-wrap: anywhere;
}

.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: 1 1 320px;
  inline-size: clamp(300px, 30vw, 520px);
  max-inline-size: 520px;
  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(3, minmax(0, 1fr));
  align-items: stretch;
  max-width: none;
  margin-inline: 0;
}

.svc-catalog-grid .svc-card {
  min-height: 224px;
  gap: var(--space-6);
}

.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: block;
  max-inline-size: none;
  min-height: 0;
  overflow: visible;
}

.svc-catalog-grid .svc-card .svc-go {
  margin-block-start: auto;
}

/* Category: a light gold badge (pill) rather than a start-border tick. */
.svc-tag {
  align-self: start;
  display: inline-flex;
  align-items: center;
  padding-block: var(--space-2);
  padding-inline: var(--space-5);
  border: 0;
  border-radius: var(--radius-full);
  background: var(--aegold-100);
  color: var(--aegold-700);
  font-size: 0.8125rem;
  font-weight: var(--weight-bold);
  line-height: var(--leading-snug);
}

/* The category badge is shown only in the "all" view. Inside a single-category
   panel every card already shares that category (the active tab names it), so
   the badge would just repeat it: hide it there. */
.svc-grid[data-panel]:not([data-panel="all"]) .svc-tag {
  display: none;
}

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

.svc-card-static {
  cursor: default;
}

.svc-card-static:hover {
  background: var(--bg-surface);
  border-color: var(--line);
  transform: none;
  box-shadow: none;
}

.svc-card-static:hover .svc-ic {
  background: var(--aegold-50);
}

.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);
  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;
  transition: color var(--duration-base) var(--ease-standard),
              background var(--duration-base) var(--ease-standard),
              border-color var(--duration-base) var(--ease-standard),
              transform var(--duration-base) var(--ease-standard),
              box-shadow var(--duration-base) var(--ease-standard);
}

.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(0, 1fr);
  gap: var(--space-10);
  align-items: start;
  padding-block-start: var(--space-4);
}

.svc-detail-layout > * {
  min-width: 0;
  max-width: 100%;
}

.svc-detail-main {
  display: grid;
  gap: var(--space-12);
  min-width: 0;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.svc-side {
  position: static;
  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);
  transition: color var(--duration-base) var(--ease-standard),
              background var(--duration-base) var(--ease-standard);
}

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

.svc-side-cta {
  padding: var(--space-8);
  display: grid;
  gap: var(--space-5);
}

.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-1);
}

.svc-side-btn {
  width: 100%;
  justify-content: flex-start;
}

.svc-side-btn .btnx-label {
  flex: 1;
}

.svc-side-btn .btnx-label .t1,
.svc-side-btn .btnx-label .t2 {
  text-align: start;
}

.svc-tool {
  min-height: 44px;
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding-block: var(--space-3);
  padding-inline: var(--space-5);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--fg-secondary);
  font-weight: var(--weight-semibold);
  font-size: 14.5px;
  line-height: var(--leading-snug);
  text-decoration: none;
  transition: color var(--duration-base) var(--ease-standard),
              background var(--duration-base) var(--ease-standard),
              border-color var(--duration-base) var(--ease-standard);
}

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

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

.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);
  min-width: 0;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.svc-text-section :where(p, li, h2, h3, summary, strong, .svc-lead, .svc-section-kicker) {
  overflow-wrap: anywhere;
  word-break: normal;
  max-inline-size: 100%;
}

.svc-index a,
.svc-side-cta p,
.svc-tool span {
  overflow-wrap: anywhere;
}

.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-text-section h3 {
  font-size: var(--text-xl);
  margin-block: var(--space-8) var(--space-5);
  color: var(--fg-primary);
}

.svc-text-section h2 + h3 {
  margin-block-start: 0;
}

.svc-table-wrap {
  overflow-x: auto;
  width: 100%;
  max-width: 100%;
  margin-block-start: var(--space-6);
  -webkit-overflow-scrolling: touch;
}

.svc-data-table {
  width: 100%;
  min-inline-size: 520px;
  border-collapse: collapse;
  background: var(--bg-surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  overflow: hidden;
  font-size: var(--text-sm);
  line-height: var(--leading-loose);
}

.svc-data-table caption {
  padding: 0;
}

.svc-data-table th,
.svc-data-table td {
  padding: var(--space-5) var(--space-6);
  border: 1px solid var(--line);
  text-align: center;
  vertical-align: middle;
  color: var(--fg-primary);
  overflow-wrap: anywhere;
  word-break: normal;
}

.svc-data-table thead th {
  background: var(--aegold-50);
  color: var(--aegold-800);
  font-weight: var(--weight-bold);
}

.svc-data-table tbody td p {
  margin: 0 0 var(--space-3);
  color: var(--fg-primary);
}

.svc-table-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
  text-align: start;
}

.svc-table-list li {
  position: relative;
  padding-inline-start: var(--space-6);
  color: var(--fg-secondary);
}

.svc-table-list li::before {
  content: "-";
  position: absolute;
  inset-inline-start: 0;
  color: var(--aegold-700);
}

.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 {
  list-style: none;
  counter-reset: svc-summary;
  display: grid;
  gap: var(--space-5);
  margin-block: var(--space-8) 0;
  padding: 0;
  color: var(--fg-primary);
}

.svc-inline-steps li {
  counter-increment: svc-summary;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  column-gap: var(--space-6);
  row-gap: var(--space-2);
  align-items: start;
  padding: var(--space-7);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-surface);
}

.svc-inline-steps li::before {
  content: counter(svc-summary);
  inline-size: 34px;
  block-size: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  background: var(--aegold-50);
  border: 1px solid var(--aegold-200);
  color: var(--aegold-800);
  font-family: var(--font-heading-ar);
  font-size: 15px;
  font-weight: var(--weight-bold);
  line-height: 1;
  grid-row: 1 / -1;
}

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

.svc-inline-steps strong {
  line-height: var(--leading-snug);
  color: var(--fg-primary);
}

.svc-inline-steps span {
  margin-block-start: 0;
  line-height: var(--leading-normal);
  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-2);
  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);
  line-height: var(--leading-snug);
}

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

.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 (min-width: 1081px) {
  .svc-detail-layout {
    grid-template-columns: minmax(250px, 310px) minmax(0, 1fr);
    gap: var(--space-13);
  }

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

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

@media (max-width: 1080px) {
  .svc-detail-hero {
    min-block-size: auto;
  }

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

  .svc-detail-hero .page-crumb {
    flex-wrap: wrap;
    row-gap: var(--space-2);
    font-size: 13px;
    line-height: 1.55;
  }

  .svc-detail-hero .page-crumb > a,
  .svc-detail-hero .page-crumb > span.sep,
  .svc-detail-hero .page-crumb > [aria-current="page"] {
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
  }

  .svc-detail-hero h1 {
    font-size: clamp(28px, 7.5vw, 40px);
    line-height: 1.25;
    text-wrap: balance;
  }

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

  .svc-text-section {
    scroll-margin-top: calc(var(--hdr) + var(--space-6));
    padding-block-end: var(--space-10);
  }

  .svc-text-section h2 {
    font-size: clamp(22px, 5.8vw, 30px);
    line-height: 1.3;
  }

  .svc-text-section h3 {
    font-size: clamp(17px, 4.6vw, 20px);
    line-height: 1.35;
  }

  .svc-lead {
    font-size: var(--text-base);
    line-height: var(--leading-loose);
  }

  .svc-text-section p,
  .svc-text-list,
  .svc-inner-list,
  .svc-link-list {
    font-size: 15px;
    line-height: 1.75;
  }

  .svc-text-list,
  .svc-inner-list,
  .svc-link-list {
    padding-inline-start: var(--space-8);
  }

  .svc-accordion summary {
    padding: var(--space-6) var(--space-7);
    font-size: 15px;
    line-height: 1.45;
  }

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

  .svc-side-btn .btnx-label .t1,
  .svc-side-btn .btnx-label .t2 {
    white-space: normal;
  }

  .svc-data-table {
    min-inline-size: 0;
    width: 100%;
    font-size: 13.5px;
  }

  .svc-data-table th,
  .svc-data-table td {
    padding: var(--space-4) var(--space-5);
    text-align: start;
  }

  .svc-table-wrap {
    margin-inline: 0;
    padding-inline: 0;
  }

  .svc-catalog-tools {
    flex-direction: column;
    align-items: stretch;
  }

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

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

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

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

@media (max-width: 760px) {
  .svc-catalog-tools .svc-tabs {
    order: 2;
  }

  .svc-catalog-tools .svc-search {
    order: 1;
  }

  .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%;
  }
}
