/* ═══════════════════════════════════════════════════════════════
   SERVICES INDEX (page-services.php)
   Hero, service grid, guide, retainer band
   ═══════════════════════════════════════════════════════════════ */

.page-services-index {
  --c-wp:   #1E3A5F;
  --c-wc:   #6B21A8;
  --c-seo:  #065F46;
  --c-ai:   #1C1C1C;
  --c-ret:  #E84E0A;
  --c-tr:   #92400E;
}

/* Breadcrumb */
.page-services-index .breadcrumb-services {
  margin-top: var(--nav-h);
  background: var(--cream-2);
  border-bottom: 1px solid rgba(26,20,16,.08);
  padding: 14px 56px;
}
.page-services-index .breadcrumb-services .breadcrumb-inner {
  max-width: var(--max);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 10px;
}
.page-services-index .breadcrumb-services a,
.page-services-index .breadcrumb-services span {
  font-family: var(--ff-m);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.page-services-index .breadcrumb-services a:hover { color: var(--orange); }
.page-services-index .breadcrumb-services .sep { opacity: .35; }
.page-services-index .breadcrumb-services .current { color: var(--ink); }

/* ── PAGE HERO ───────────────────────────────────────────────── */
.page-services-index .svc-idx-hero {
  padding-top: var(--nav-h);
  background: var(--ink);
  min-height: 52vh;
  display: flex;
  align-items: flex-end;
  position: relative;
  overflow: hidden;
}
.page-services-index .svc-idx-hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(232,78,10,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(232,78,10,.05) 1px, transparent 1px);
  background-size: 56px 56px;
  animation: svc-idx-gd 40s linear infinite;
}
@keyframes svc-idx-gd { to { background-position: 56px 56px; } }
.page-services-index .svc-idx-hero-inner {
  position: relative;
  z-index: 2;
  max-width: var(--max);
  width: 100%;
  margin: 0 auto;
  padding: 80px 56px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: end;
}
.page-services-index .svc-idx-eyebrow {
  font-family: var(--ff-m);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 20px;
}
.page-services-index .svc-idx-h1 {
  font-family: var(--ff-d);
  font-size: clamp(56px, 6.5vw, 96px);
  line-height: .93;
  letter-spacing: .01em;
  color: var(--cream);
}
.page-services-index .svc-idx-h1 em {
  font-family: var(--ff-s);
  font-style: italic;
  font-weight: 300;
  font-size: .85em;
  color: rgba(244,239,230,.5);
}
.page-services-index .svc-idx-h1 .o { color: var(--orange); }
.page-services-index .svc-idx-hero-right p {
  font-size: 18px;
  color: rgba(244,239,230,.55);
  line-height: 1.7;
  max-width: 420px;
}
.page-services-index .svc-idx-hero-right p em { font-style: italic; color: rgba(244,239,230,.8); }
.page-services-index .visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.page-services-index .svc-idx-hero-ctas {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
.page-services-index .svc-idx-hero-cta {
  font-family: var(--ff-m);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(244,239,230,.5);
  border-bottom: 1px solid rgba(244,239,230,.2);
  padding-bottom: 2px;
  transition: color .2s, border-color .2s;
  text-decoration: none;
}
.page-services-index .svc-idx-hero-cta:hover { color: var(--orange); border-color: var(--orange); }

/* ── CASE STUDIES ─────────────────────────────────────────────── */
.page-services-index .svc-idx-case {
  max-width: var(--max);
  margin: 0 auto;
  padding: 72px 56px;
  background: var(--cream-2);
}
.page-services-index .svc-idx-case-inner { border-top: 1px solid rgba(26,20,16,.08); padding-top: 48px; }
.page-services-index .svc-idx-case-eyebrow {
  font-family: var(--ff-m);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 28px;
}
.page-services-index .svc-idx-case-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2px;
  background: rgba(26,20,16,.08);
}
.page-services-index .svc-idx-case-card {
  background: var(--cream);
  padding: 32px 36px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: background .3s;
}
.page-services-index .svc-idx-case-card:hover { background: var(--white); }
.page-services-index .svc-idx-case-client {
  font-family: var(--ff-d);
  font-size: 22px;
  letter-spacing: .02em;
  color: var(--ink);
}
.page-services-index .svc-idx-case-result {
  font-family: var(--ff-m);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--orange);
}

/* ── SERVICE GRID ────────────────────────────────────────────── */
.page-services-index .svc-idx-section {
  max-width: var(--max);
  margin: 0 auto;
  padding: 96px 56px;
}
.page-services-index .svc-idx-section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 56px;
}
.page-services-index .svc-idx-section-header h2 {
  font-family: var(--ff-d);
  font-size: clamp(36px, 4vw, 52px);
  letter-spacing: .02em;
  color: var(--ink);
}
.page-services-index .svc-idx-count {
  font-family: var(--ff-m);
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
.page-services-index .svc-idx-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: rgba(26,20,16,.1);
}

/* Service card */
.page-services-index .svc-idx-card {
  background: var(--cream);
  padding: 52px 44px 100px;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: background .3s;
  text-decoration: none;
  color: inherit;
}
.page-services-index .svc-idx-card:hover { background: var(--white); }
.page-services-index .svc-idx-card::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .5s var(--ease);
}
.page-services-index .svc-idx-card[data-c="wp"]  { --cc: var(--c-wp);  }
.page-services-index .svc-idx-card[data-c="wc"]  { --cc: var(--c-wc);  }
.page-services-index .svc-idx-card[data-c="seo"] { --cc: var(--c-seo); }
.page-services-index .svc-idx-card[data-c="ai"]  { --cc: var(--c-ai);  }
.page-services-index .svc-idx-card[data-c="ret"] { --cc: var(--c-ret); }
.page-services-index .svc-idx-card[data-c="tr"]  { --cc: var(--c-tr);  }
.page-services-index .svc-idx-card::after { background: var(--cc, var(--orange)); }
.page-services-index .svc-idx-card:hover::after { transform: scaleX(1); }

.page-services-index .svc-idx-card-num {
  font-family: var(--ff-m);
  font-size: 10px;
  letter-spacing: .2em;
  color: var(--ink-muted);
  margin-bottom: 32px;
}
.page-services-index .svc-idx-card-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1.5px solid rgba(26,20,16,.14);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 28px;
  transition: background .3s, border-color .3s;
}
.page-services-index .svc-idx-card:hover .svc-idx-card-icon {
  background: var(--cc, var(--orange));
  border-color: var(--cc, var(--orange));
}
.page-services-index .svc-idx-card:hover .svc-idx-card-icon svg { stroke: var(--white); }
.page-services-index .svc-idx-card-name {
  font-family: var(--ff-d);
  font-size: 28px;
  letter-spacing: .02em;
  color: var(--ink);
  margin-bottom: 14px;
  line-height: 1.05;
}
.page-services-index .svc-idx-card-desc {
  font-size: 15px;
  color: var(--ink-muted);
  line-height: 1.65;
  flex: 1;
}
.page-services-index .svc-idx-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 24px;
}
.page-services-index .svc-idx-card-tag {
  font-family: var(--ff-m);
  font-size: 9px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-muted);
  border: 1px solid rgba(26,20,16,.14);
  padding: 4px 10px;
  border-radius: 2px;
}
.page-services-index .svc-idx-card-arrow {
  position: absolute;
  bottom: 44px;
  right: 44px;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(26,20,16,.15);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .25s, border-color .25s, transform .35s var(--ease);
}
.page-services-index .svc-idx-card:hover .svc-idx-card-arrow {
  background: var(--cc, var(--orange));
  border-color: var(--cc, var(--orange));
  transform: rotate(45deg);
}
.page-services-index .svc-idx-card:hover .svc-idx-card-arrow svg { stroke: var(--white); }

/* ── GUIDE ───────────────────────────────────────────────────── */
.page-services-index .svc-idx-guide {
  background: var(--ink);
  padding: 96px 56px;
}
.page-services-index .svc-idx-guide-inner {
  max-width: var(--max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 96px;
  align-items: start;
}
.page-services-index .svc-idx-guide-eyebrow {
  font-family: var(--ff-m);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 20px;
}
.page-services-index .svc-idx-guide-title {
  font-family: var(--ff-s);
  font-size: clamp(26px, 2.8vw, 38px);
  font-weight: 300;
  line-height: 1.25;
  color: var(--cream);
}
.page-services-index .svc-idx-guide-title em { font-style: italic; }
.page-services-index .svc-idx-guide-intro {
  margin-top: 16px;
  font-size: 15px;
  color: rgba(244,239,230,.45);
  line-height: 1.7;
}
.page-services-index .svc-idx-guide-rows { display: flex; flex-direction: column; }
.page-services-index .svc-idx-guide-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 22px 0;
  border-bottom: 1px solid rgba(244,239,230,.07);
  transition: background .2s;
  text-decoration: none;
  color: inherit;
}
.page-services-index .svc-idx-guide-row:first-child { border-top: 1px solid rgba(244,239,230,.07); }
.page-services-index .svc-idx-guide-row:hover { padding-left: 8px; }
.page-services-index .svc-idx-guide-if {
  font-family: var(--ff-m);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--orange);
  width: 28px;
  flex-shrink: 0;
}
.page-services-index .svc-idx-guide-text {
  font-family: var(--ff-s);
  font-size: 16px;
  font-weight: 300;
  color: rgba(244,239,230,.7);
  line-height: 1.45;
}
.page-services-index .svc-idx-guide-text strong {
  font-weight: 300;
  font-style: italic;
  color: var(--cream);
}
.page-services-index .svc-idx-guide-link {
  font-family: var(--ff-m);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(244,239,230,.28);
  border-bottom: 1px solid rgba(244,239,230,.12);
  padding-bottom: 2px;
  white-space: nowrap;
  transition: color .2s, border-color .2s;
}
.page-services-index .svc-idx-guide-row:hover .svc-idx-guide-link { color: var(--orange-hot); border-color: var(--orange); }

/* ── RETAINER BAND ───────────────────────────────────────────── */
.page-services-index .svc-idx-ret-band {
  background: var(--orange);
  padding: 80px 56px;
}
.page-services-index .svc-idx-ret-band-inner {
  max-width: var(--max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 48px;
  align-items: center;
}
.page-services-index .svc-idx-ret-band-h2 {
  font-family: var(--ff-d);
  font-size: clamp(32px, 4vw, 58px);
  letter-spacing: .02em;
  color: var(--white);
  line-height: .96;
}
.page-services-index .svc-idx-ret-band-p {
  margin-top: 12px;
  font-size: 16px;
  color: rgba(253,250,244,.72);
  max-width: 520px;
}
.page-services-index .svc-idx-ret-band-btns {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-end;
}
.page-services-index .svc-idx-btn-ret-p {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--ff-m);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--orange);
  background: var(--white);
  padding: 14px 28px;
  border-radius: 2px;
  white-space: nowrap;
  transition: background .2s, color .2s;
  text-decoration: none;
}
.page-services-index .svc-idx-btn-ret-p:hover { background: var(--ink); color: var(--white); }
.page-services-index .svc-idx-btn-ret-g {
  font-family: var(--ff-m);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(253,250,244,.65);
  border-bottom: 1px solid rgba(253,250,244,.3);
  padding-bottom: 2px;
  transition: color .2s, border-color .2s;
  text-decoration: none;
}
.page-services-index .svc-idx-btn-ret-g:hover { color: var(--white); border-color: var(--white); }

/* Reveal */
.page-services-index .rv { opacity: 0; transform: translateY(24px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.page-services-index .rv.on { opacity: 1; transform: none; }
.page-services-index .rv.d1 { transition-delay: .1s; }
.page-services-index .rv.d2 { transition-delay: .2s; }
.page-services-index .rv.d3 { transition-delay: .3s; }
.page-services-index .rv.d4 { transition-delay: .4s; }
.page-services-index .rv.d5 { transition-delay: .5s; }

/* ── RESPONSIVE ───────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .page-services-index .svc-idx-hero-inner { grid-template-columns: 1fr; gap: 32px; }
  .page-services-index .svc-idx-grid { grid-template-columns: 1fr 1fr; }
  .page-services-index .svc-idx-guide-inner { grid-template-columns: 1fr; gap: 48px; }
  .page-services-index .svc-idx-ret-band-inner { grid-template-columns: 1fr; }
  .page-services-index .svc-idx-ret-band-btns { align-items: flex-start; flex-direction: row; }
}
@media (max-width: 640px) {
  .page-services-index .breadcrumb-services { padding: 14px 20px; }
  .page-services-index .svc-idx-hero-inner { padding: 56px 20px; }
  .page-services-index .svc-idx-section { padding: 64px 20px; }
  .page-services-index .svc-idx-case { padding: 56px 20px; }
  .page-services-index .svc-idx-case-grid { grid-template-columns: 1fr; }
  .page-services-index .svc-idx-grid { grid-template-columns: 1fr; }
  .page-services-index .svc-idx-guide { padding: 64px 20px; }
  .page-services-index .svc-idx-ret-band { padding: 64px 20px; }
}
