/* ════════════════════════════════
   SERVICES PAGE — full standalone /services
   Match CLVN dark theme, Aktiv Grotesk, lime accent
════════════════════════════════ */

.page-services {
  background: var(--color-bg);
  color: var(--color-white);
  position: relative;
  z-index: 2;
}

/* ════════════════════════════════
   1. HERO
════════════════════════════════ */

.svc-hero {
  padding: clamp(120px, 14vw, 200px) clamp(20px, 3.5vw, 50px) clamp(60px, 6vw, 100px);
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 2vw, 32px);
  position: relative;
}

.svc-hero__eyebrow {
  font-family: var(--font-mono);
  font-size: clamp(11px, 1vw, 14px);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-text-muted);
  margin: 0;
}

.svc-hero__heading {
  font-family: var(--font-display);
  font-size: clamp(48px, 7vw, 120px);
  font-weight: var(--weight-medium);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
  color: var(--color-white);
  margin: 0;
  text-transform: uppercase;
  max-width: 16ch;
}

.svc-hero__intro {
  font-family: var(--font-display);
  font-size: clamp(16px, 1.6vw, 24px);
  font-weight: 400;
  line-height: 1.45;
  color: var(--color-text-muted);
  margin: 0;
  max-width: 60ch;
}

/* ════════════════════════════════
   2. SERVICES LIST — 3 cards
════════════════════════════════ */

.svc-list {
  padding: clamp(40px, 4vw, 80px) clamp(20px, 3.5vw, 50px);
}

.svc-list__head {
  margin-bottom: clamp(40px, 4vw, 64px);
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 0.8vw, 14px);
}

.svc-list__label {
  font-family: var(--font-mono);
  font-size: clamp(11px, 1vw, 14px);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-text-muted);
  margin: 0;
}

.svc-list__heading {
  font-family: var(--font-display);
  font-size: var(--text-h2);
  font-weight: var(--weight-medium);
  line-height: 1.05;
  letter-spacing: var(--tracking-tight);
  color: var(--color-white);
  margin: 0;
  text-transform: uppercase;
  max-width: 18ch;
}

/* Grid */
.svc-list__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 1.5vw, 24px);
}

/* Card */
.svc-card {
  background: var(--color-bg-surface);
  border-radius: 0;
  padding: clamp(28px, 2.6vw, 44px);
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 2vw, 32px);
  min-height: clamp(420px, 38vw, 540px);
  transition: background 0.3s var(--ease-out);
}

.svc-card:hover {
  background: rgba(255, 255, 255, 0.04);
}

.svc-card__num {
  font-family: var(--font-mono);
  font-size: clamp(13px, 1.1vw, 16px);
  font-weight: 400;
  letter-spacing: var(--tracking-wide);
  color: var(--color-accent);
  margin: 0;
}

.svc-card__title {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.2vw, 32px);
  font-weight: var(--weight-medium);
  line-height: 1.1;
  letter-spacing: var(--tracking-tight);
  color: var(--color-white);
  margin: 0;
  text-transform: uppercase;
}

.svc-card__tagline {
  font-family: var(--font-display);
  font-size: clamp(14px, 1.2vw, 17px);
  font-weight: 400;
  line-height: 1.5;
  color: var(--color-text-muted);
  margin: 0;
}

.svc-card__divider {
  height: 1px;
  background: var(--color-border);
  width: 100%;
}

.svc-card__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 0.8vw, 12px);
}

.svc-card__list li {
  font-family: var(--font-mono);
  font-size: clamp(12px, 1vw, 14px);
  font-weight: 400;
  letter-spacing: 0.02em;
  color: var(--color-white);
  text-transform: uppercase;
  padding-left: 18px;
  position: relative;
  line-height: 1.4;
}

.svc-card__list li::before {
  content: '+';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-accent);
}

.svc-card__bestfor {
  font-family: var(--font-mono);
  font-size: clamp(11px, 0.95vw, 13px);
  font-weight: 400;
  letter-spacing: var(--tracking-wide);
  color: var(--color-text-muted);
  margin: 0;
  text-transform: uppercase;
  margin-top: auto;
}

.svc-card__bestfor strong {
  color: var(--color-white);
  font-weight: 400;
}

/* ════════════════════════════════
   3. PROCESS TIMELINE — Significa-style
════════════════════════════════ */

.svc-process {
  padding: clamp(80px, 8vw, 140px) clamp(20px, 3.5vw, 50px);
  background: var(--color-bg);
}

.svc-process__head {
  margin-bottom: clamp(48px, 5vw, 80px);
  max-width: 1100px;
}

.svc-process__label {
  font-family: var(--font-mono);
  font-size: clamp(11px, 1vw, 14px);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-text-muted);
  margin: 0 0 clamp(8px, 0.8vw, 14px);
}

.svc-process__heading {
  font-family: var(--font-display);
  font-size: var(--text-h2);
  font-weight: var(--weight-medium);
  line-height: 1.05;
  letter-spacing: var(--tracking-tight);
  color: var(--color-white);
  margin: 0;
  text-transform: uppercase;
}

.svc-process__heading em {
  color: var(--color-text-muted);
  font-style: normal;
}

/* Lane palette */
.svc-process {
  --lane-purple: #a855f7;
  --lane-orange: #ff7a3d;
  --lane-blue:   #4fb8ff;
  --lane-yellow: #fbbf24;
  --lane-gray:   #6b7280;
}

/* Hidden defs */
.svc-process__defs {
  position: absolute;
  width: 0;
  height: 0;
  pointer-events: none;
}

/* Board: avatar + lanes */
.svc-process__board {
  display: grid;
  grid-template-columns: clamp(80px, 8vw, 120px) 1fr;
  gap: clamp(24px, 2.4vw, 40px);
  position: relative;
}

/* Rail (avatar + vertical line) */
.svc-process__rail {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.svc-process__avatar {
  width: clamp(60px, 6vw, 88px);
  height: clamp(60px, 6vw, 88px);
  border-radius: 50%;
  background: var(--color-accent);
  display: grid;
  place-items: center;
  position: relative;
  z-index: 2;
  box-shadow: 0 0 0 4px var(--color-bg);
}

.svc-process__avatar img {
  width: 60%;
  height: 60%;
  object-fit: contain;
  filter: brightness(0);   /* black logo on lime bg */
}

.svc-process__line {
  position: absolute;
  top: clamp(60px, 6vw, 88px);
  bottom: 0;
  left: 50%;
  width: 2px;
  background: var(--color-white);
  transform: translateX(-50%);
  z-index: 1;
}

/* Lanes wrapper */
.svc-process__lanes {
  display: flex;
  flex-direction: column;
  gap: clamp(28px, 3vw, 48px);
  padding-top: clamp(8px, 0.8vw, 14px);
}

/* Single lane */
.svc-lane {
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 1vw, 14px);
}

.svc-lane__name {
  font-family: var(--font-mono);
  font-size: clamp(11px, 1vw, 14px);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-text-muted);
}

.svc-lane__row {
  display: grid;
  grid-template-columns: repeat(13, 1fr);
  gap: clamp(8px, 0.8vw, 14px);
  align-items: center;
}

/* Box base */
.svc-box {
  grid-column: var(--col-start) / span var(--col-span);
  font-family: var(--font-mono);
  font-size: clamp(11px, 0.95vw, 14px);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  padding: clamp(10px, 1vw, 16px) clamp(12px, 1.2vw, 20px);
  text-align: center;
  position: relative;
  filter: url(#svc-rough);
  transition: transform 0.35s var(--ease-out), filter 0.35s var(--ease-out);
  cursor: default;
  white-space: nowrap;
  overflow: visible;
}

.svc-box:hover {
  transform: translateY(-3px) rotate(-0.5deg);
  filter: url(#svc-rough-strong);
}

/* Color variants */
.svc-box--purple { background: var(--lane-purple); color: var(--color-white); }
.svc-box--orange { background: var(--lane-orange); color: var(--color-black); }
.svc-box--blue   { background: var(--lane-blue);   color: var(--color-black); }
.svc-box--yellow { background: var(--lane-yellow); color: var(--color-black); }
.svc-box--gray   { background: var(--lane-gray);   color: var(--color-white); }

/* Stripes overlay (for Liquid Build) */
.svc-box--stripes {
  background:
    repeating-linear-gradient(45deg,
      rgba(0,0,0,0.55) 0 4px,
      transparent 4px 8px),
    var(--lane-blue);
}

/* Decorative accents */
.svc-deco {
  position: absolute;
  font-family: var(--font-mono);
  pointer-events: none;
  filter: none; /* keep crisp, ignore parent rough filter */
}

.svc-deco--star {
  top: -16px;
  right: -10px;
  font-size: 20px;
  color: var(--lane-purple);
  transform: rotate(12deg);
}

.svc-deco--spark {
  top: -14px;
  right: -8px;
  font-size: 18px;
  color: var(--color-white);
  text-shadow: 0 0 0 var(--color-black);
}

/* ════════════════════════════════
   4. CTA SECTION
════════════════════════════════ */

.svc-cta {
  padding: clamp(80px, 8vw, 140px) clamp(20px, 3.5vw, 50px) clamp(120px, 12vw, 200px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: clamp(24px, 2.5vw, 40px);
  background: var(--color-bg);
}

.svc-cta__eyebrow {
  font-family: var(--font-mono);
  font-size: clamp(11px, 1vw, 14px);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-text-muted);
  margin: 0;
}

.svc-cta__heading {
  font-family: var(--font-display);
  font-size: clamp(48px, 6vw, 96px);
  font-weight: var(--weight-medium);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
  color: var(--color-white);
  margin: 0;
  text-transform: uppercase;
  max-width: 18ch;
}

.svc-cta__row {
  display: flex;
  gap: clamp(16px, 1.5vw, 24px);
  align-items: center;
  margin-top: clamp(8px, 1vw, 16px);
  flex-wrap: wrap;
}

.svc-cta__btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: clamp(14px, 1.4vw, 18px) clamp(22px, 2vw, 32px);
  background: var(--color-accent);
  color: var(--color-black);
  border-radius: 0;
  font-family: var(--font-mono);
  font-size: clamp(12px, 1vw, 14px);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  text-decoration: none;
  position: relative;
  overflow: hidden;
}

/* Slide-up hover (matches homepage) */
.svc-cta__btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--color-black);
  transform: translateY(101%);
  transition: transform 0.35s var(--ease-out);
}

.svc-cta__btn > * {
  position: relative;
  z-index: 1;
  transition: color 0.3s var(--ease-out);
}

.svc-cta__btn:hover::before { transform: translateY(0); }
.svc-cta__btn:hover > * { color: var(--color-white); }

.svc-cta__email {
  font-family: var(--font-display);
  font-size: clamp(18px, 1.8vw, 28px);
  font-weight: 400;
  color: var(--color-white);
  text-decoration: none;
  letter-spacing: var(--tracking-tight);
  transition: opacity 0.25s ease;
}

.svc-cta__email:hover { opacity: 0.65; }

/* ════════════════════════════════
   RESPONSIVE
════════════════════════════════ */

@media (max-width: 1024px) {
  .svc-list__grid {
    grid-template-columns: 1fr;
  }
  .svc-card {
    min-height: auto;
  }
}

@media (max-width: 768px) {
  .svc-hero { padding: 100px 20px 40px; }
  .svc-list { padding: 40px 20px; }
  .svc-process { padding: 60px 20px; }
  .svc-cta { padding: 60px 20px 100px; }

  .svc-process__board {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .svc-process__rail {
    flex-direction: row;
    align-items: center;
    gap: 12px;
  }
  .svc-process__line {
    position: static;
    width: 100%;
    height: 2px;
    transform: none;
  }
  .svc-lane__row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  .svc-box {
    grid-column: auto;
    white-space: normal;
  }
}
