/* =========================================================================
   GEO SOLUTIONS — SERVICES PAGE v4.2 (Altrum-style 10 groups)
   Generated: May 2026
   Pattern: Service groups with large title + lead, sub-services with thumbs
   ========================================================================= */

/* =========================================================================
   1. SERVICES HERO
   ========================================================================= */

.services-hero {
  padding: 180px 0 var(--space-16);
}

.services-hero__title {
  font-family: var(--font-display);
  font-size: clamp(4rem, 14vw, 12rem);
  font-weight: var(--weight-semibold);
  line-height: 0.9;
  letter-spacing: var(--tracking-tighter);
  color: var(--color-text-primary);
  margin: 0;
}

.services-hero__title sup {
  font-size: 0.4em;
  font-family: var(--font-mono);
  font-weight: var(--weight-medium);
  vertical-align: super;
  letter-spacing: var(--tracking-wide);
  margin-left: var(--space-3);
  color: var(--color-text-tertiary);
}

@media (max-width: 767px) {
  .services-hero {
    padding-top: 130px;
  }
}

.services-hero__row {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--space-8);
}

@media (max-width: 767px) {
  .services-hero__row {
    flex-direction: column;
    align-items: stretch;
  }
}

/* =========================================================================
   3. SERVICE GROUP BLOCK (Altrum 10-group pattern)
   ========================================================================= */

.service-groups {
  padding: var(--space-8) 0 var(--divider-3xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.service-group {
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-lg);
  background-color: var(--color-bg-surface-1);
  padding: var(--space-12) var(--space-10);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
}

@media (max-width: 991px) {
  .service-group {
    grid-template-columns: 1fr;
    padding: var(--space-8) var(--space-6);
    gap: var(--space-8);
  }
}

/* Left column — group title + lead */
.service-group__intro {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 280px;
}

.service-group__num {
  font-family: var(--font-mono);
  font-size: var(--text-mono-sm);
  color: var(--color-text-tertiary);
  letter-spacing: var(--tracking-wide);
}

.service-group__title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: var(--weight-semibold);
  line-height: 1;
  letter-spacing: var(--tracking-tighter);
  color: var(--color-text-primary);
  margin: var(--space-2) 0 var(--space-8);
}

.service-group__lead {
  font-size: var(--text-body);
  line-height: var(--leading-normal);
  color: var(--color-text-tertiary);
  margin: 0;
  max-width: 42ch;
}

/* Right column — sub-services list */
.service-group__list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--color-border-faint);
}

/* =========================================================================
   SUB-SERVICE — native <details>/<summary> accordion (v37)
   Each row expands on click revealing a brief description.
   No more visual frames; the green animated plus is the only marker.
   ========================================================================= */

.sub-service {
  display: block;
  border-bottom: 1px solid var(--color-border-faint);
}

/* native disclosure marker off (Safari + Firefox) */
.sub-service > summary { list-style: none; }
.sub-service > summary::-webkit-details-marker { display: none; }
.sub-service > summary::marker { display: none; }

/* The clickable trigger row — what was previously the .sub-service div itself */
.sub-service__trigger {
  display: grid;
  grid-template-columns: 1fr 32px;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5) 0;
  cursor: pointer;
  transition:
    padding var(--duration-medium) var(--ease-default),
    background-color var(--duration-medium) var(--ease-default);
  outline: none;
}

.sub-service__trigger:hover {
  padding-left: var(--space-3);
  padding-right: var(--space-3);
  background-color: var(--color-bg-surface-2);
  border-radius: var(--radius-sm);
}

.sub-service[open] > .sub-service__trigger {
  /* slight bg highlight while open so context is preserved */
  background-color: var(--color-bg-surface-2);
  padding-left: var(--space-3);
  padding-right: var(--space-3);
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}

.sub-service__trigger:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 4px;
  border-radius: var(--radius-sm);
}

.sub-service__content {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sub-service__num {
  font-family: var(--font-mono);
  font-size: var(--text-mono-sm);
  color: var(--color-text-tertiary);
  letter-spacing: var(--tracking-wide);
}

.sub-service__name {
  font-family: var(--font-display);
  font-size: var(--text-body-lg);
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
  letter-spacing: var(--tracking-tight);
  margin: 0;
}

/* GREEN ANIMATED PLUS — rotates 45° to "×" on open */
.sub-service__plus {
  width: 32px;
  height: 32px;
  position: relative;
  flex-shrink: 0;
  opacity: 0.85;
  color: var(--color-accent);
  transition:
    transform 320ms cubic-bezier(0.34, 1.36, 0.64, 1),
    opacity var(--duration-medium) var(--ease-default);
}

.sub-service__trigger:hover .sub-service__plus {
  opacity: 1;
}

.sub-service__plus::before,
.sub-service__plus::after {
  content: '';
  position: absolute;
  background-color: currentColor;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 1px;
  transition: background-color var(--duration-medium) var(--ease-default);
}

.sub-service__plus::before { width: 16px; height: 2px; }
.sub-service__plus::after  { width: 2px;  height: 16px; }

/* Open state — plus rotates 45° → becomes × */
.sub-service[open] > .sub-service__trigger .sub-service__plus {
  transform: rotate(45deg);
  opacity: 1;
}

/* BODY — brief description revealed on open */
.sub-service__body {
  padding: 0 var(--space-3) var(--space-6);
  background-color: var(--color-bg-surface-2);
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  /* fade-in animation on open */
  animation: subServiceReveal 360ms cubic-bezier(0.22, 1, 0.36, 1);
}

@keyframes subServiceReveal {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.sub-service__body p {
  font-family: var(--font-display);
  font-size: var(--text-body);
  line-height: 1.55;
  color: var(--color-text-secondary);
  margin: 0;
  max-width: 70ch;
}

/* Smooth height animation in browsers that support interpolate-size
   (Chrome 129+, Safari 18.4+). Other browsers get instant reveal,
   the plus rotation + body fade-in still gives a satisfying interaction. */
@supports (interpolate-size: allow-keywords) {
  :root { interpolate-size: allow-keywords; }
  .sub-service::details-content {
    block-size: 0;
    overflow: clip;
    transition: block-size 320ms cubic-bezier(0.22, 1, 0.36, 1), content-visibility 320ms allow-discrete;
  }
  .sub-service[open]::details-content { block-size: auto; }
}

@media (max-width: 479px) {
  .sub-service__trigger {
    grid-template-columns: 1fr 24px;
    gap: var(--space-3);
  }
  .sub-service__plus { width: 24px; height: 24px; }
  .sub-service__plus::before { width: 12px; }
  .sub-service__plus::after  { height: 12px; }
}

@media (prefers-reduced-motion: reduce) {
  .sub-service__plus,
  .sub-service__trigger,
  .sub-service__body {
    transition: none !important;
    animation: none !important;
  }
}

/* =========================================================================
   SERVICES BANNER — Altrum-style FULL-VIEWPORT hero with "Services" overlay
   v1.0 (added in v25) — sits at top of /services, mirrors .about-banner pattern
   ─────────────────────────────────────────────────────────────────────────
   Layout:
     [Full-viewport image]              <- .services-banner (88vh)
       ↳ .services-banner__title    ←— huge "Services" overlay, vertically centered
       ↳ .services-banner__plus-row ← 5 plus-marks evenly along bottom edge
     [Black thin meta bar]              <- .services-banner-meta
   Scroll behavior: image translateY parallax + slow scale-up (driven by
   js/about-banner-scroll.js v3.1 — generalized for .about-banner / .contact-banner / .services-banner)
   ========================================================================= */

.services-banner {
  position: relative;
  width: 100%;
  height: 88vh;
  min-height: 580px;
  max-height: 1000px;
  overflow: hidden;
  background: #000;
  margin: 0;
  padding: 0;
}

@media (max-width: 767px) {
  .services-banner { height: 75vh; min-height: 480px; }
}

/* ── full-bleed image (oversized for parallax overshoot) ─────────────── */
.services-banner__media {
  position: absolute;
  inset: -8%;
  width: 116%;
  height: 116%;
  display: block;
}

.services-banner__media picture,
.services-banner__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* image has dark left zone + green vertical bands on the right —
     keeping center crop preserves both headline shade area + the green pattern */
  object-position: center center;
  display: block;
  transform-origin: center center;
  transform: translate3d(0, 0, 0) scale(1);
  will-change: transform;
}

/* ── soft shade gradient: deepens the left side a touch for headline contrast ── */
.services-banner__shade {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(to right, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.25) 38%, rgba(0,0,0,0) 60%),
    linear-gradient(to bottom, rgba(0,0,0,0) 60%, rgba(0,0,0,0.55) 100%);
  z-index: 1;
}

/* ── content block: title + mission, vertically centered, left-aligned ─── */
.services-banner__content {
  position: absolute;
  top: 50%;
  left: clamp(20px, 5vw, 80px);
  right: clamp(20px, 5vw, 80px);
  transform: translateY(-50%);
  z-index: 2;
  max-width: 1100px;
  pointer-events: none;
}

.services-banner__title {
  margin: 0 0 clamp(16px, 2.5vw, 36px) 0;
  font-family: var(--font-display);
  font-weight: var(--weight-medium, 500);
  font-size: clamp(96px, 18vw, 320px);
  line-height: 0.92;
  letter-spacing: -0.04em;
  color: #FFFFFF;
  text-shadow: 0 4px 80px rgba(0, 0, 0, 0.55);
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 900ms cubic-bezier(0.22, 1, 0.36, 1) 100ms,
              transform 900ms cubic-bezier(0.22, 1, 0.36, 1) 100ms;
}

.services-banner.is-visible .services-banner__title {
  opacity: 1;
  transform: translateY(0);
}

/* ── mission text under headline ──────────────────────────────────────── */
.services-banner__mission {
  margin: 0;
  max-width: 640px;
  font-family: var(--font-display);
  font-size: clamp(18px, 1.7vw, 26px);
  line-height: 1.4;
  font-weight: 400;
  letter-spacing: -0.005em;
  color: #FFFFFF;
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.6);
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 900ms cubic-bezier(0.22, 1, 0.36, 1) 380ms,
              transform 900ms cubic-bezier(0.22, 1, 0.36, 1) 380ms;
}

.services-banner.is-visible .services-banner__mission {
  opacity: 1;
  transform: translateY(0);
}

/* ── green highlight on closing line ──────────────────────────────────── */
.services-banner__highlight {
  display: inline;
  background: var(--color-accent);
  color: #0A1A0E;
  padding: 0.15em 0.45em;
  font-weight: var(--weight-medium, 500);
  text-shadow: none;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  margin-left: -0.05em;
  white-space: normal;
}

@media (max-width: 767px) {
  .services-banner__content { top: 46%; }
  .services-banner__mission { max-width: 100%; }
  /* "Services" has 8 chars vs "About" 5 — needs a smaller mobile cap */
  .services-banner__title  { font-size: clamp(54px, 14vw, 96px); letter-spacing: -0.035em; }
}

/* ── 5 plus-marks evenly distributed along bottom edge of banner ─────── */
.services-banner__plus-row {
  position: absolute;
  left: 5%;
  right: 5%;
  bottom: 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 2;
  pointer-events: none;
}

.services-banner__plus-row span {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 300;
  line-height: 1;
  color: rgba(255, 255, 255, 0.55);
  user-select: none;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 600ms cubic-bezier(0.22, 1, 0.36, 1),
              transform 600ms cubic-bezier(0.22, 1, 0.36, 1);
}

.services-banner.is-visible .services-banner__plus-row span:nth-child(1) { transition-delay: 300ms; opacity: 1; transform: translateY(0); }
.services-banner.is-visible .services-banner__plus-row span:nth-child(2) { transition-delay: 380ms; opacity: 1; transform: translateY(0); }
.services-banner.is-visible .services-banner__plus-row span:nth-child(3) { transition-delay: 460ms; opacity: 1; transform: translateY(0); }
.services-banner.is-visible .services-banner__plus-row span:nth-child(4) { transition-delay: 540ms; opacity: 1; transform: translateY(0); }
.services-banner.is-visible .services-banner__plus-row span:nth-child(5) { transition-delay: 620ms; opacity: 1; transform: translateY(0); }

@media (max-width: 767px) {
  .services-banner__plus-row span { font-size: 14px; }
  .services-banner__plus-row     { bottom: 12px; }
}

/* ── reduced-motion: disable transforms + transitions ────────────────── */
@media (prefers-reduced-motion: reduce) {
  .services-banner__media img {
    transform: none !important;
  }
  .services-banner__title,
  .services-banner__mission,
  .services-banner__plus-row span {
    opacity: 1 !important;
    transition: none !important;
  }
  .services-banner__title,
  .services-banner__mission { transform: translateY(0) !important; }
  .services-banner__plus-row span { transform: none !important; }
}

/* =========================================================================
   SERVICES BANNER META — black thin bar beneath hero
   "+ Geo Solutions Services"  |  ©Edition 03  |  ↗
   ========================================================================= */

.services-banner-meta {
  width: 100%;
  background: var(--color-bg-base);
  border-bottom: 1px solid var(--color-border-faint);
  padding: var(--space-5) 0;
}

.services-banner-meta__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-6);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--color-text-secondary);
}

@media (min-width: 768px) {
  .services-banner-meta__inner {
    padding: 0 var(--space-8);
  }
}

.services-banner-meta__left {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  justify-self: start;
}

.services-banner-meta__plus {
  font-size: 14px;
  font-weight: 400;
  color: var(--color-text-tertiary);
}

.services-banner-meta__center {
  justify-self: center;
  color: var(--color-text-tertiary);
}

.services-banner-meta__right {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  color: var(--color-text-secondary);
}

@media (max-width: 767px) {
  .services-banner-meta { padding: var(--space-4) 0; }
  .services-banner-meta__inner {
    font-size: 10px;
    grid-template-columns: 1fr auto auto;
    gap: 12px;
  }
}

/* =========================================================================
   SERVICES HERO — adjustments for v25 (banner now lives above)
   The big <h1>Services(10)</h1> moved up into the banner. The hero row
   keeps the talk-card + a narrative subhead block on the left.
   ========================================================================= */

.services-hero--with-banner {
  /* drop the giant top-padding now that the banner provides the "wow" moment */
  padding: var(--space-16) 0 var(--space-12);
}

.services-hero__lede {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-width: 620px;
}

.services-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--color-text-tertiary);
  text-transform: uppercase;
}

.services-hero__eyebrow-num {
  color: var(--color-accent);
  font-weight: var(--weight-medium, 500);
}

.services-hero__subhead {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.15;
  letter-spacing: -0.015em;
  font-weight: var(--weight-medium, 500);
  color: var(--color-text-primary);
  margin: 0;
}

@media (max-width: 767px) {
  .services-hero--with-banner { padding: var(--space-10) 0 var(--space-8); }
}

/* =========================================================================
   END OF services.css v4.3 (v25 — services banner)
   ========================================================================= */
