/* =========================
   SERVICES PAGE
========================= */
.services-page {
  background: #ffffff;
  overflow-x: hidden;
}

/* =========================
   HERO — LOAD ANIMATIONS
========================= */
.services-hero {
  position: relative;
  min-height: calc(100vh - var(--header-h));
  display: flex;
  align-items: center;
  overflow: hidden;
  background: #081a35;
}

.services-hero-bg {
  position: absolute;
  inset: 0;
  background:
    url("../img/services-hero.png") center center / cover no-repeat,
    linear-gradient(135deg, #0c2347, #081a35);
  transform: scale(1.08);
  will-change: transform;
  animation: svcHeroBg 8s var(--ease) forwards;
}
@keyframes svcHeroBg {
  from { transform: scale(1.08); }
  to   { transform: scale(1.02); }
}

.services-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(100deg, rgba(4,14,31,.92) 0%, rgba(4,14,31,.66) 45%, rgba(4,14,31,.54) 100%),
    radial-gradient(700px 420px at 22% 24%, rgba(212,166,42,.14), transparent 60%);
  animation: overlayBreath 9s ease-in-out infinite;
}
@keyframes overlayBreath {
  0%,100% { opacity: 1; }
  50%      { opacity: .88; }
}

.services-hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0,1.15fr) minmax(300px,400px);
  gap: 54px;
  align-items: center;
  padding: 92px 0;
}

/* Copy — slides in from left, staggered */
.svc-anim-eyebrow  { animation: svcSlideLeft .8s var(--ease) .1s  both; }
.svc-anim-h1       { animation: svcSlideLeft .85s var(--ease) .25s both; }
.svc-anim-text     { animation: svcSlideLeft .85s var(--ease) .4s  both; }
.svc-anim-actions  { animation: svcSlideLeft .85s var(--ease) .55s both; }

@keyframes svcSlideLeft {
  from { opacity: 0; transform: translateX(-65px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* Panel — bounces in from right */
.svc-anim-panel {
  animation: svcSlideRight 1s cubic-bezier(.34,1.56,.64,1) .35s both;
}
@keyframes svcSlideRight {
  from { opacity: 0; transform: translateX(70px) scale(.94); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}

/* Panel list items stagger */
.svc-panel-item {
  opacity: 0;
  transform: translateY(18px);
  animation: svcPanelItem .6s var(--ease) calc(.62s + var(--i) * .12s) both;
  transition: background .3s, transform .3s var(--ease);
}
@keyframes svcPanelItem {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}
.svc-panel-item:hover {
  background: rgba(255,255,255,.14) !important;
  transform: translateX(6px);
}

.services-hero-copy h1 {
  margin: 0; color: #fff;
  font-size: clamp(2.6rem, 5.8vw, 5.6rem);
  line-height: .95; letter-spacing: -.05em; font-weight: 800;
}
.services-hero-copy h1 span { display: block; color: rgba(255,255,255,.78); }
.services-hero-text {
  margin: 22px 0 0; color: rgba(255,255,255,.78);
  font-size: 1.04rem; max-width: 56ch; line-height: 1.8;
}
.services-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }

.services-hero-panel {
  padding: 26px; border-radius: 28px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(18px);
  box-shadow: 0 26px 70px rgba(0,0,0,.22);
}
.services-panel-label {
  display: inline-flex; min-height: 34px; align-items: center;
  padding: 0 12px; border-radius: 999px; margin-bottom: 18px;
  font-size: .8rem; font-weight: 700; color: #ffe39a;
  background: rgba(212,166,42,.14); border: 1px solid rgba(212,166,42,.2);
}
.services-panel-list { display: grid; gap: 12px; }
.services-panel-list article {
  padding: 16px; border-radius: 18px;
  background: rgba(255,255,255,.08); cursor: default;
}
.services-panel-list strong { display: block; color: #fff; margin-bottom: 6px; font-size: .98rem; }
.services-panel-list p { margin: 0; color: rgba(255,255,255,.72); font-size: .92rem; line-height: 1.6; }

/* =========================
   ANCHOR NAV
========================= */
.services-anchor-strip {
  position: relative; z-index: 20; margin-top: -34px;
}
.services-anchor-nav {
  display: flex; gap: 8px; flex-wrap: wrap; padding: 10px;
  width: fit-content;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 999px;
  box-shadow: 0 18px 44px rgba(15,23,42,.1);
  backdrop-filter: blur(14px);
}
.svc-anchor-drop { animation: svcAnchorDrop .7s var(--ease) .9s both; }
@keyframes svcAnchorDrop {
  from { opacity: 0; transform: translateY(-16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.services-anchor-nav a {
  min-height: 40px; padding: 0 16px; border-radius: 999px;
  display: inline-flex; align-items: center;
  text-decoration: none; color: var(--navy);
  font-weight: 700; font-size: .88rem; white-space: nowrap;
  transition: background .25s var(--ease), color .25s, transform .25s var(--ease);
}
.services-anchor-nav a:hover { background: rgba(9,42,87,.08); transform: translateY(-2px); }
.services-anchor-nav a.is-current { background: var(--navy); color: #fff; }

/* =========================
   SUMMARY CARDS — bounce in
========================= */
.services-summary {
  padding-top: 128px;
  background:
    radial-gradient(680px 320px at 100% 0%, rgba(212,166,42,.08), transparent 60%),
    #fff;
}
.summary-grid {
  display: grid;
  grid-template-columns: repeat(5,1fr);
  gap: 18px;
}
.summary-card {
  padding: 24px; border-radius: 24px;
  background: linear-gradient(to bottom, #fff, #fbfdff);
  border: 1px solid rgba(15,23,42,.06);
  box-shadow: var(--shadow-sm);
  overflow: hidden; position: relative;
  will-change: transform;
  transition: box-shadow .4s var(--ease), border-color .35s;
}
/* Shimmer sweep */
.summary-card::after {
  content: '';
  position: absolute; top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.5), transparent);
  transition: left .55s var(--ease);
}
.summary-card:hover::after { left: 150%; }
.summary-card:hover { box-shadow: var(--shadow-md); border-color: rgba(13,59,122,.12); }

.summary-card span,
.service-row-no,
.compliance-card-service span {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 44px; height: 34px; padding: 0 10px;
  border-radius: 12px; margin-bottom: 14px;
  font-size: .74rem; font-weight: 800; letter-spacing: .12em;
  background: rgba(13,59,122,.08); color: var(--blue);
  transition: transform .3s var(--ease), background .3s;
}
.summary-card:hover span { transform: scale(1.1) rotate(-4deg); background: rgba(13,59,122,.14); }

.summary-card h3 { margin: 0 0 8px; font-size: 1.05rem; letter-spacing: -.02em; }
.summary-card p  { margin: 0; color: var(--muted); font-size: .88rem; }

/* =========================
   SERVICE ROWS — slide in from sides alternating
========================= */
.services-list { background: #fff; }

.service-stack { display: grid; gap: 22px; }

.service-row {
  display: grid;
  grid-template-columns: 170px minmax(0,1fr) 300px;
  gap: 28px; align-items: start;
  padding: 30px; border-radius: 28px;
  background: linear-gradient(to bottom, #fff, #fbfdff);
  border: 1px solid rgba(15,23,42,.06);
  box-shadow: var(--shadow-sm);
  overflow: hidden; position: relative;
  /* will animate via JS */
  opacity: 0;
  transform: translateX(-60px);
  transition: opacity .7s var(--ease), transform .7s var(--ease),
              box-shadow .4s var(--ease), border-color .35s;
}
.service-row.svc-row-visible {
  opacity: 1 !important;
  transform: none !important;
}
/* Hover lift */
.service-row:hover {
  box-shadow: var(--shadow-lg);
  border-color: rgba(13,59,122,.12);
}
/* Left accent bar expands on hover */
.service-row::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 4px;
  background: linear-gradient(to bottom, var(--gold), var(--blue-2));
  transform: scaleY(0); transform-origin: top;
  transition: transform .45s var(--ease);
}
.service-row:hover::before { transform: scaleY(1); }

.service-row-feature {
  background:
    radial-gradient(260px 140px at 100% 0%, rgba(212,166,42,.12), transparent 60%),
    linear-gradient(to bottom, #fff, #fbfdff);
}
/* Feature row pulsing ring on the number */
.service-row-feature .service-row-no {
  background: rgba(212,166,42,.14);
  color: var(--gold);
  position: relative;
}
.service-row-feature .service-row-no::after {
  content: '';
  position: absolute; inset: -5px;
  border-radius: 16px;
  border: 2px solid var(--gold);
  opacity: 0;
  animation: rowNumPulse 2.4s ease-out infinite;
}
@keyframes rowNumPulse {
  0%   { transform: scale(1);    opacity: .5; }
  100% { transform: scale(1.22); opacity: 0; }
}

.service-row-meta { display: grid; gap: 10px; align-content: start; }
.service-row-label { margin: 0; color: #647084; font-size: .92rem; line-height: 1.5; }
.service-row-main h3 { margin: 0 0 12px; font-size: 1.4rem; line-height: 1.1; letter-spacing: -.03em; }
.service-row-main p  { margin: 0; color: var(--muted); line-height: 1.8; }
.service-row-main small { display: block; margin-top: 12px; color: #7b8697; }

.service-row-side {
  padding-left: 24px;
  border-left: 1px solid rgba(15,23,42,.08);
}
.service-row-side h4 {
  margin: 0 0 12px; font-size: .88rem; color: var(--navy);
  text-transform: uppercase; letter-spacing: .1em;
}
.service-row-side ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 9px; }
.service-row-side li {
  position: relative; padding-left: 16px;
  color: #5d6878; font-size: .9rem; line-height: 1.55;
  transition: color .2s, transform .25s var(--ease);
}
.service-row-side li::before {
  content: '';
  position: absolute; left: 0; top: .6em;
  width: 7px; height: 7px; border-radius: 50%;
  background: rgba(212,166,42,.46);
  border: 1px solid rgba(212,166,42,.4);
  transition: background .25s, transform .25s var(--ease);
}
.service-row:hover .service-row-side li::before {
  background: var(--gold); transform: scale(1.2);
}

.text-link {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 14px; font-weight: 700; text-decoration: none; color: var(--blue);
  transition: color .25s, gap .3s var(--ease);
}
.text-link:hover { color: var(--navy); gap: 10px; }

/* =========================
   PROCESS — grid + stagger
========================= */
.services-process {
  position: relative; overflow: hidden;
  background:
    radial-gradient(760px 440px at 16% 12%, rgba(212,166,42,.12), transparent 60%),
    radial-gradient(760px 420px at 84% 26%, rgba(13,59,122,.28), transparent 60%),
    linear-gradient(to bottom, #07142a, #081b38);
}
/* Animated background grid */
.services-process::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 60px 60px;
  animation: svcGrid 30s linear infinite;
}
@keyframes svcGrid {
  from { background-position: 0 0; }
  to   { background-position: 60px 60px; }
}

.process-grid-services {
  display: grid;
  grid-template-columns: minmax(0,.9fr) minmax(0,1.1fr);
  gap: 42px; align-items: start;
  position: relative; z-index: 1;
}
.process-copy-services h2 {
  margin: 0; color: #fff;
  font-size: clamp(1.9rem,3vw,3rem);
  line-height: 1.05; letter-spacing: -.04em;
}

.process-timeline-services { position: relative; display: grid; gap: 18px; }
.process-timeline-services::before {
  content: '';
  position: absolute; left: 26px; top: 16px; bottom: 16px; width: 2px;
  background: linear-gradient(to bottom,
    rgba(212,166,42,.08), rgba(212,166,42,.6),
    rgba(13,59,122,.5), rgba(212,166,42,.08));
}

.process-step-service {
  position: relative;
  display: grid; grid-template-columns: 64px 1fr;
  gap: 18px; align-items: start;
  opacity: 0; transform: translateX(60px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
.process-step-service.svc-step-visible {
  opacity: 1 !important; transform: none !important;
}

.process-step-service-no {
  position: relative; z-index: 2;
  width: 52px; height: 52px; border-radius: 18px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, rgba(212,166,42,.2), rgba(13,59,122,.2));
  border: 1px solid rgba(255,255,255,.14);
  color: #fff; font-size: .8rem; font-weight: 800; letter-spacing: .12em;
  backdrop-filter: blur(10px);
  transition: transform .4s var(--ease), background .4s;
}
.process-step-service:hover .process-step-service-no {
  transform: scale(1.15) rotate(6deg);
  background: linear-gradient(135deg, rgba(212,166,42,.35), rgba(13,59,122,.35));
}

.process-step-service-card {
  padding: 22px; border-radius: 22px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(14px);
  box-shadow: 0 16px 44px rgba(0,0,0,.14);
  overflow: hidden; position: relative;
  transition: transform .4s var(--ease), background .4s, border-color .4s;
}
/* Shimmer */
.process-step-service-card::after {
  content: '';
  position: absolute; top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.07), transparent);
  transition: left .55s var(--ease);
}
.process-step-service:hover .process-step-service-card::after { left: 150%; }
.process-step-service:hover .process-step-service-card {
  transform: translateX(8px) translateY(-4px);
  background: rgba(255,255,255,.11);
  border-color: rgba(212,166,42,.22);
}
.process-step-service-card h3 { margin: 0 0 8px; color: #fff; font-size: 1.1rem; }
.process-step-service-card p  { margin: 0; color: rgba(255,255,255,.72); font-size: .9rem; line-height: 1.75; }

/* =========================
   COMPLIANCE
========================= */
.services-compliance { background: #07142a; }
.services-compliance .section-intro h2 { color: #fff; max-width: 14ch; }
.services-compliance .eyebrow { color: rgba(255,255,255,.7); }

.compliance-grid-services {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 20px;
}
.compliance-card-service {
  padding: 28px; border-radius: 24px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 18px 44px rgba(0,0,0,.16);
  overflow: hidden; position: relative;
  will-change: transform;
  opacity: 0; transform: translateY(40px) scale(.96);
  transition: opacity .7s var(--ease), transform .7s cubic-bezier(.34,1.56,.64,1),
              background .4s, border-color .4s, box-shadow .4s;
}
.compliance-card-service.svc-comp-visible {
  opacity: 1 !important; transform: none !important;
}
.compliance-card-service::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(to bottom, var(--gold), var(--blue-2));
  transform: scaleY(0); transform-origin: top;
  transition: transform .4s var(--ease);
}
.compliance-card-service:hover::before { transform: scaleY(1); }
.compliance-card-service:hover {
  transform: translateY(-6px) scale(1.01) !important;
  background: rgba(255,255,255,.09);
  border-color: rgba(212,166,42,.2);
  box-shadow: 0 28px 60px rgba(0,0,0,.24);
}
.compliance-card-service span { background: rgba(212,166,42,.12); color: #ffd86a; }
.compliance-card-service h3 { margin: 0 0 10px; color: #fff; font-size: 1.1rem; }
.compliance-card-service p  { margin: 0; color: rgba(255,255,255,.72); font-size: .9rem; line-height: 1.7; }

/* =========================
   CLOSING
========================= */
.services-closing {
  position: relative; min-height: 78vh;
  display: flex; align-items: center;
  overflow: hidden; background: #081a35;
}
.services-closing-bg {
  position: absolute; inset: 0;
  background:
    url("../img/services.png") center center / cover no-repeat,
    linear-gradient(135deg, #0c2347, #081a35);
  transform: scale(1.04); will-change: transform;
}
.services-closing-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(4,14,31,.86) 0%, rgba(4,14,31,.66) 48%, rgba(4,14,31,.54) 100%),
    radial-gradient(700px 420px at 20% 24%, rgba(212,166,42,.12), transparent 60%);
}
.services-closing-wrap { position: relative; z-index: 2; padding: 84px 0; }

.services-closing-card {
  max-width: 760px; padding: 38px; border-radius: 30px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(18px);
  box-shadow: 0 28px 80px rgba(0,0,0,.2);
  transition: transform .5s var(--ease), box-shadow .5s;
}
.services-closing-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 40px 100px rgba(0,0,0,.3);
}
.services-closing-card h2 {
  margin: 0; color: #fff;
  font-size: clamp(1.9rem,3.2vw,3.2rem);
  line-height: 1.05; letter-spacing: -.04em;
}
.services-closing-card p    { margin: 16px 0 0; color: rgba(255,255,255,.76); max-width: 56ch; line-height: 1.8; }
.services-closing-card small{ display: block; margin-top: 14px; color: rgba(255,255,255,.5); }
.services-closing-actions   { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 26px; }

/* =========================================================
   REVEAL (shared with style.css — ensure they exist here)
========================================================= */
.reveal {
  opacity: 0;
  transition: opacity .85s var(--ease), transform .85s var(--ease);
}
.reveal.is-visible { opacity: 1 !important; transform: none !important; }
.reveal-up    { transform: translateY(50px); }
.reveal-left  { transform: translateX(-70px); }
.reveal-right { transform: translateX(70px); }
.reveal-scale { transform: scale(.88) translateY(24px); }
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }

/* =========================================================
   RESPONSIVE — 1100px
========================================================= */
@media (max-width: 1100px) {
  .services-hero-grid,
  .process-grid-services { grid-template-columns: 1fr; gap: 36px; }
  .services-hero-grid    { padding: 72px 0 80px; }

  .summary-grid { grid-template-columns: repeat(3,1fr); gap: 16px; }

  .service-row { grid-template-columns: 140px 1fr; }
  .service-row-side {
    grid-column: 1 / -1;
    padding-left: 0; border-left: 0;
    padding-top: 16px; border-top: 1px solid rgba(15,23,42,.08);
  }

  .compliance-grid-services { grid-template-columns: repeat(2,1fr); }
  .services-anchor-strip { margin-top: -24px; }
}

/* =========================================================
   RESPONSIVE — 900px
========================================================= */
@media (max-width: 900px) {
  .services-hero,
  .services-closing { min-height: auto; }
  .services-hero-grid,
  .services-closing-wrap { padding: 64px 0 72px; }

  .services-anchor-nav {
    width: 100%; border-radius: 20px; justify-content: center;
  }
  .services-anchor-nav a { font-size: .84rem; padding: 0 12px; min-height: 38px; }

  .services-hero-copy h1 { font-size: clamp(2.4rem,7vw,3.6rem); max-width: none; }
  .process-copy-services h2,
  .services-closing-card h2,
  .services-compliance .section-intro h2 { max-width: none; }

  .summary-grid { grid-template-columns: repeat(2,1fr); gap: 14px; }

  .service-row {
    grid-template-columns: 1fr;
    gap: 16px; padding: 22px;
  }
  .service-row-meta {
    display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  }
  .service-row-meta .service-row-no { margin-bottom: 0; }
  .service-row-side { grid-column: unset; }

  .process-step-service { grid-template-columns: 56px 1fr; gap: 14px; }
  .process-timeline-services::before { left: 21px; }
  .process-step-service-no { width: 44px; height: 44px; }
}

/* =========================================================
   RESPONSIVE — 768px
========================================================= */
@media (max-width: 768px) {
  .section { padding: 70px 0; }

  .services-hero-grid { padding: 52px 0 60px; gap: 24px; }
  .services-hero-copy h1 { font-size: clamp(2.1rem,8vw,3rem); }
  .services-hero-text { font-size: .94rem; }
  .services-hero-actions,
  .services-closing-actions { flex-direction: column; align-items: stretch; gap: 10px; }
  .services-hero-panel { padding: 20px; }
  .services-panel-list article { padding: 13px; }

  .services-summary { padding-top: 80px; }
  .summary-grid { grid-template-columns: repeat(2,1fr); gap: 12px; }
  .summary-card { padding: 20px 16px; }

  .service-stack { gap: 16px; }
  .service-row { padding: 18px 16px; border-radius: 20px; }
  .service-row-main h3 { font-size: 1.2rem; }

  .compliance-grid-services { grid-template-columns: 1fr; gap: 14px; }
  .compliance-card-service { padding: 22px 18px; }

  .services-closing-wrap { padding: 52px 0 56px; }
  .services-closing-card { padding: 26px 20px; border-radius: 22px; max-width: 100%; }

  .btn, .btn-primary, .btn-secondary { width: 100%; justify-content: center; }
}

/* =========================================================
   RESPONSIVE — 540px
========================================================= */
@media (max-width: 540px) {
  .summary-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .services-anchor-nav { gap: 4px; padding: 8px; }
  .services-anchor-nav a { font-size: .78rem; padding: 0 10px; min-height: 36px; }
}

/* =========================================================
   RESPONSIVE — 480px
========================================================= */
@media (max-width: 480px) {
  :root { --header-h: 68px; }

  .services-hero-grid { padding: 42px 0 50px; gap: 20px; }
  .services-hero-copy h1 { font-size: clamp(1.8rem,9vw,2.6rem); }
  .services-hero-text { font-size: .88rem; }
  .services-hero-panel { padding: 16px; border-radius: 20px; }
  .services-panel-label { font-size: .72rem; min-height: 30px; }
  .services-panel-list article { padding: 12px; }
  .services-panel-list strong { font-size: .88rem; }
  .services-panel-list p { font-size: .82rem; }

  .services-anchor-strip { margin-top: -18px; }
  .services-anchor-nav {
    overflow-x: auto; flex-wrap: nowrap;
    border-radius: 14px; gap: 3px; padding: 6px;
    scrollbar-width: none; -ms-overflow-style: none;
  }
  .services-anchor-nav::-webkit-scrollbar { display: none; }
  .services-anchor-nav a { font-size: .74rem; padding: 0 10px; flex-shrink: 0; min-height: 34px; }

  .services-summary { padding-top: 64px; }
  .summary-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .summary-card { padding: 16px 14px; border-radius: 18px; }
  .summary-card h3 { font-size: .94rem; }

  .service-row { padding: 16px 14px; border-radius: 18px; gap: 14px; }
  .service-row-main h3 { font-size: 1.1rem; }
  .service-row-main p  { font-size: .88rem; }
  .service-row-side h4 { font-size: .82rem; }
  .service-row-side li { font-size: .84rem; }

  .process-grid-services { gap: 24px; }
  .process-copy-services h2 { font-size: clamp(1.55rem,7vw,2.2rem); }
  .process-step-service { grid-template-columns: 46px 1fr; gap: 10px; }
  .process-timeline-services::before { left: 17px; }
  .process-step-service-no { width: 38px; height: 38px; border-radius: 12px; font-size: .72rem; }
  .process-step-service-card { padding: 16px; border-radius: 16px; }
  .process-step-service-card h3 { font-size: 1rem; }

  .services-compliance .section-intro h2 { font-size: clamp(1.55rem,7vw,2.2rem); }
  .compliance-card-service { padding: 18px 16px; border-radius: 18px; }
  .compliance-card-service h3 { font-size: 1rem; }

  .services-closing { min-height: auto; }
  .services-closing-wrap { padding: 44px 0 48px; }
  .services-closing-card { padding: 20px 16px; border-radius: 18px; }
  .services-closing-card h2 { font-size: clamp(1.5rem,7vw,2rem); }
  .services-closing-actions { gap: 10px; }
}

/* =========================================================
   RESPONSIVE — 360px
========================================================= */
@media (max-width: 360px) {
  .services-hero-copy h1 { font-size: 1.7rem; }
  .summary-grid { grid-template-columns: 1fr; }
  .process-step-service { grid-template-columns: 38px 1fr; gap: 8px; }
  .process-step-service-no { width: 32px; height: 32px; }
  .services-closing-card h2 { font-size: 1.4rem; }
}

/* =========================================================
   REDUCED MOTION
========================================================= */
@media (prefers-reduced-motion: reduce) {
  .svc-anim-eyebrow, .svc-anim-h1, .svc-anim-text,
  .svc-anim-actions, .svc-anim-panel, .svc-panel-item,
  .svc-anchor-drop, .services-hero-bg, .services-hero-overlay {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
  .service-row, .process-step-service, .compliance-card-service {
    opacity: 1 !important;
    transform: none !important;
  }
}