@layer components {
  .services-page {
    --services-carbon: oklch(14% 0.01 245);
    --services-graphite: oklch(21% 0.012 245);
    --services-porcelain: oklch(96.5% 0.012 80);
    --services-paper: oklch(91% 0.012 80);
    --services-line: oklch(73% 0.008 245);
    --services-muted: oklch(55% 0.012 245);
    --services-ink: oklch(20% 0.012 245);
    --services-cyan: oklch(76% 0.16 215);
    --services-burgundy: oklch(29% 0.085 20);
    --services-brass: oklch(66% 0.035 78);
    --services-font: "Outfit", "Aptos", "Helvetica Neue", Arial, sans-serif;

    background: var(--services-porcelain);
    color: var(--services-ink);
  }

  .services-page .site-header {
    background: color-mix(in oklch, var(--services-porcelain) 88%, transparent);
    -webkit-backdrop-filter: blur(18px) saturate(1.1);
    backdrop-filter: blur(18px) saturate(1.1);
    border-bottom-color: color-mix(in oklch, var(--services-line), transparent 38%);
  }

  .services-page .site-logo,
  .services-page .nav-links a,
  .services-page .language-switcher,
  .services-page .btn {
    font-family: var(--services-font);
  }

  .services-page .nav-links a::after {
    height: 1px;
    background: var(--services-cyan);
  }

  .services-page .nav-links a:hover,
  .services-page .nav-links a.is-active {
    color: var(--services-carbon);
  }

  .services-page .btn {
    min-height: 2.75rem;
    border-radius: 0;
    letter-spacing: -0.01em;
    transition:
      background var(--transition-base),
      border-color var(--transition-base),
      color var(--transition-base),
      transform var(--transition-base) var(--ease-out-expo);
  }

  .services-page .btn:hover {
    transform: translateY(-1px);
  }

  .services-page .btn-primary {
    background: var(--services-carbon);
    color: var(--services-porcelain);
    border: 1px solid var(--services-carbon);
  }

  .services-page .btn-primary:hover {
    background: var(--services-cyan);
    border-color: var(--services-cyan);
    color: var(--services-carbon);
    opacity: 1;
  }

  .services-page .page-section {
    padding-block: clamp(4.5rem, 9vw, 8rem);
    background: var(--services-porcelain);
  }

  .services-page .page-section + .page-section {
    padding-block-start: clamp(4.5rem, 9vw, 8rem);
  }

  .services-page .container {
    max-width: min(88rem, calc(100vw - 2rem));
  }

  .services-page .section-badge {
    color: var(--services-cyan);
    font-family: var(--services-font);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    margin-block-end: 1rem;
  }

  .services-page .section-heading {
    color: inherit;
    font-family: var(--services-font);
    font-size: clamp(2.2rem, 4.6vw, 4.9rem);
    font-weight: 500;
    letter-spacing: -0.055em;
    line-height: 1.02;
    margin: 0;
    max-width: 11ch;
    text-align: left;
    text-wrap: balance;
  }

  .services-page .section-subtitle {
    color: var(--services-muted);
    font-family: var(--services-font);
    font-size: clamp(1rem, 1.35vw, 1.18rem);
    line-height: 1.7;
    margin: 0;
    max-width: 38rem;
    text-align: left;
    text-wrap: pretty;
  }

  .services-page [data-controller="scroll-reveal"] {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .services-hero {
    min-height: auto;
    background:
      linear-gradient(90deg, var(--services-carbon) 0 50%, var(--services-porcelain) 50% 100%);
    color: var(--services-porcelain);
    isolation: isolate;
    overflow: clip;
    position: relative;
  }

  .services-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -2;
    background-image:
      linear-gradient(color-mix(in oklch, var(--services-line), transparent 72%) 1px, transparent 1px),
      linear-gradient(90deg, color-mix(in oklch, var(--services-line), transparent 72%) 1px, transparent 1px);
    background-position: center top;
    background-size: 48px 48px;
    opacity: 0.22;
  }

  .services-hero::after {
    content: "";
    position: absolute;
    inset-block: 0;
    left: 50%;
    z-index: -1;
    width: 1px;
    background: color-mix(in oklch, var(--services-line), transparent 18%);
  }

  .services-hero-shell {
    display: grid;
    grid-template-columns: minmax(19rem, 0.82fr) minmax(24rem, 1.18fr);
    align-items: center;
    gap: clamp(2rem, 5vw, 5rem);
    min-height: clamp(42rem, calc(100svh - var(--header-height) - 5rem), 48rem);
    padding: clamp(2rem, 5vw, 4.5rem) clamp(1.5rem, 5vw, 5.5rem);
  }

  .services-hero-copy {
    opacity: 0;
    transform: translateY(12px);
    animation: services-panel-in 700ms var(--ease-out-expo) 120ms forwards;
  }

  .hero-badge {
    color: var(--services-cyan);
    display: inline-block;
    font-family: var(--services-font);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    margin-block-end: 1.15rem;
    text-transform: uppercase;
  }

  .services-hero h1 {
    color: var(--services-porcelain);
    font-family: var(--services-font);
    font-size: clamp(3rem, 5.5vw, 5.35rem);
    font-weight: 500;
    letter-spacing: -0.055em;
    line-height: 0.98;
    margin: 0 0 1.35rem -0.08em;
    max-width: 12ch;
    text-wrap: balance;
  }

  .services-hero h1 em {
    color: inherit;
    font-style: normal;
  }

  .services-hero .hero-subtitle {
    color: color-mix(in oklch, var(--services-porcelain), transparent 28%);
    font-family: var(--services-font);
    font-size: clamp(1rem, 1.45vw, 1.22rem);
    line-height: 1.58;
    margin: 0 0 1.35rem;
    max-width: 34rem;
    text-wrap: pretty;
  }

  .services-hero .btn-primary {
    background: var(--services-porcelain);
    border-color: var(--services-porcelain);
    color: var(--services-carbon);
  }

  .services-hero .btn-primary:hover {
    background: var(--services-cyan);
    border-color: var(--services-cyan);
    color: var(--services-carbon);
  }

  .services-instrument {
    display: grid;
    grid-template-columns: minmax(12rem, 0.42fr) minmax(18rem, 0.58fr);
    min-height: clamp(30rem, 67vh, 42rem);
    border: 1px solid color-mix(in oklch, var(--services-line), transparent 18%);
    box-shadow: 0 2rem 5rem color-mix(in oklch, var(--services-carbon), transparent 82%);
    opacity: 0;
    position: relative;
    transform: translateY(16px);
    animation: services-panel-in 800ms var(--ease-out-expo) 260ms forwards;
  }

  .services-instrument::before,
  .services-instrument::after {
    content: "";
    position: absolute;
    z-index: 4;
    pointer-events: none;
  }

  .services-instrument::before {
    inset: 1.15rem;
    border: 1px solid color-mix(in oklch, var(--services-line), transparent 38%);
  }

  .services-instrument::after {
    top: 48%;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--services-cyan) 47%, transparent 74%);
    opacity: 0.78;
  }

  .services-instrument__panel {
    overflow: hidden;
    position: relative;
  }

  .services-instrument__panel--dark {
    background:
      linear-gradient(160deg, color-mix(in oklch, var(--services-graphite), transparent 6%), var(--services-carbon) 58%),
      var(--services-carbon);
    border-inline-end: 1px solid color-mix(in oklch, var(--services-line), transparent 22%);
  }

  .services-instrument__panel--dark::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(color-mix(in oklch, var(--services-line), transparent 86%) 1px, transparent 1px),
      linear-gradient(90deg, color-mix(in oklch, var(--services-line), transparent 86%) 1px, transparent 1px);
    background-size: 28px 28px;
    mask-image: linear-gradient(180deg, black, transparent 76%);
    opacity: 0.38;
  }

  .services-instrument__panel--light {
    background:
      linear-gradient(180deg, color-mix(in oklch, var(--services-porcelain), var(--services-brass) 4%), var(--services-porcelain)),
      var(--services-porcelain);
  }

  .services-instrument__panel--light::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(color-mix(in oklch, var(--services-line), transparent 62%) 1px, transparent 1px),
      linear-gradient(90deg, color-mix(in oklch, var(--services-line), transparent 62%) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.38;
  }

  .services-instrument__label {
    color: color-mix(in oklch, var(--services-porcelain), transparent 34%);
    font-family: var(--services-font);
    font-size: 0.72rem;
    font-weight: 700;
    left: 2rem;
    letter-spacing: 0.14em;
    position: absolute;
    text-transform: uppercase;
    top: 2rem;
    z-index: 2;
  }

  .services-instrument__glyphs {
    border-left: 1px solid color-mix(in oklch, var(--services-line), transparent 72%);
    border-top: 1px solid color-mix(in oklch, var(--services-line), transparent 72%);
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    inset: 6rem 2rem auto;
    position: absolute;
    z-index: 2;
  }

  .services-instrument__glyphs span {
    align-items: center;
    aspect-ratio: 1;
    border-bottom: 1px solid color-mix(in oklch, var(--services-line), transparent 72%);
    border-right: 1px solid color-mix(in oklch, var(--services-line), transparent 72%);
    color: color-mix(in oklch, var(--services-porcelain), transparent 42%);
    display: flex;
    font-family: var(--services-font);
    font-size: clamp(1.1rem, 3vw, 2rem);
    font-weight: 500;
    justify-content: center;
    letter-spacing: -0.05em;
  }

  .services-signal {
    border-bottom: 2px solid var(--services-cyan);
    border-right: 2px solid var(--services-cyan);
    border-top: 2px solid var(--services-cyan);
    inset: 18% 15% 23% 17%;
    opacity: 0.82;
    position: absolute;
    z-index: 2;
  }

  .services-signal::before {
    background: var(--services-cyan);
    border-radius: 50%;
    box-shadow: 0 0 0 0.4rem color-mix(in oklch, var(--services-cyan), transparent 84%);
    content: "";
    height: 0.7rem;
    left: -0.35rem;
    position: absolute;
    top: -0.35rem;
    width: 0.7rem;
  }

  .hero-capabilities {
    display: grid;
    gap: 0.75rem;
    inset: auto 2rem 2rem 2rem;
    position: absolute;
    z-index: 3;
  }

  .hero-capability {
    background: color-mix(in oklch, var(--services-porcelain), transparent 4%);
    border: 1px solid color-mix(in oklch, var(--services-ink), transparent 72%);
    color: var(--services-ink);
    display: grid;
    gap: 0.25rem;
    min-height: 5.4rem;
    padding: 0.9rem 1rem;
  }

  .hero-capability:first-child {
    border-color: var(--services-cyan);
    box-shadow: 0 0 0 1px color-mix(in oklch, var(--services-cyan), transparent 72%);
  }

  .capability-label {
    color: var(--services-ink);
    font-family: var(--services-font);
    font-size: clamp(1rem, 1.45vw, 1.18rem);
    font-weight: 600;
    letter-spacing: -0.04em;
    line-height: 1.1;
  }

  .capability-desc {
    color: var(--services-muted);
    font-family: var(--services-font);
    font-size: var(--font-size-sm);
    line-height: 1.45;
  }

  .services-section-intro {
    align-items: end;
    display: grid;
    grid-template-columns: minmax(16rem, 0.62fr) minmax(18rem, 0.38fr);
    gap: clamp(2rem, 6vw, 6rem);
    margin-block-end: clamp(2rem, 5vw, 4rem);
  }

  .services-page .product-studio-section {
    background: var(--services-carbon);
    color: var(--services-porcelain);
    border-block: 1px solid color-mix(in oklch, var(--services-cyan), transparent 72%);
  }

  .services-page .product-studio-section .section-subtitle {
    color: color-mix(in oklch, var(--services-porcelain), transparent 32%);
  }

  .services-grid {
    border-block: 1px solid color-mix(in oklch, var(--services-line), transparent 18%);
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .product-studio-section .services-grid {
    border-color: color-mix(in oklch, var(--services-porcelain), transparent 84%);
  }

  .service-card {
    background: color-mix(in oklch, var(--services-porcelain), transparent 6%);
    color: var(--services-ink);
    display: grid;
    gap: clamp(0.8rem, 1.8vw, 1.2rem);
    min-height: clamp(16rem, 24vw, 20rem);
    padding: clamp(1.25rem, 3vw, 2.2rem);
    position: relative;
    text-align: left;
    transition:
      background var(--transition-base),
      color var(--transition-base),
      transform var(--transition-base) var(--ease-out-expo);
  }

  .service-card + .service-card {
    border-inline-start: 1px solid color-mix(in oklch, var(--services-line), transparent 18%);
  }

  .product-studio-section .service-card {
    background: color-mix(in oklch, var(--services-graphite), transparent 18%);
    color: var(--services-porcelain);
  }

  .product-studio-section .service-card + .service-card {
    border-inline-start-color: color-mix(in oklch, var(--services-porcelain), transparent 84%);
  }

  .service-card:hover {
    background: color-mix(in oklch, var(--services-cyan), var(--services-porcelain) 88%);
    color: var(--services-carbon);
    transform: translateY(-2px);
  }

  .product-studio-section .service-card:hover {
    background: color-mix(in oklch, var(--services-cyan), var(--services-carbon) 86%);
    color: var(--services-porcelain);
  }

  .service-card__index {
    color: var(--services-cyan);
    font-family: var(--services-font);
    font-size: 0.78rem;
    font-variant-numeric: tabular-nums;
    font-weight: 700;
  }

  .service-card h3 {
    color: inherit;
    font-family: var(--services-font);
    font-size: clamp(1.35rem, 2.4vw, 2rem);
    font-weight: 500;
    letter-spacing: -0.045em;
    line-height: 1.08;
    margin: auto 0 0;
    max-width: 12ch;
  }

  .service-card p {
    color: var(--services-muted);
    font-family: var(--services-font);
    font-size: var(--font-size-base);
    line-height: 1.62;
    margin: 0;
    max-width: 25rem;
  }

  .product-studio-section .service-card p {
    color: color-mix(in oklch, var(--services-porcelain), transparent 34%);
  }

  .service-card:hover p {
    color: color-mix(in oklch, var(--services-carbon), transparent 18%);
  }

  .product-studio-section .service-card:hover p {
    color: color-mix(in oklch, var(--services-porcelain), transparent 24%);
  }

  .section-image {
    margin-block-start: clamp(1.25rem, 3vw, 2rem);
    overflow: hidden;
    position: relative;
  }

  .section-image::before {
    border: 1px solid color-mix(in oklch, var(--services-line), transparent 38%);
    content: "";
    inset: 1rem;
    pointer-events: none;
    position: absolute;
    z-index: 2;
  }

  .product-studio-section .section-image::before {
    border-color: color-mix(in oklch, var(--services-porcelain), transparent 76%);
  }

  .section-image img {
    aspect-ratio: 21 / 8;
    display: block;
    filter: saturate(0.68) contrast(1.08);
    height: auto;
    object-fit: cover;
    width: 100%;
  }

  .services-page .services-cta-section {
    background:
      linear-gradient(90deg, var(--services-carbon) 0 52%, var(--services-porcelain) 52% 100%);
    color: var(--services-porcelain);
    overflow: clip;
    position: relative;
  }

  .services-page .services-cta-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(color-mix(in oklch, var(--services-line), transparent 76%) 1px, transparent 1px),
      linear-gradient(90deg, color-mix(in oklch, var(--services-line), transparent 76%) 1px, transparent 1px);
    background-size: 48px 48px;
    opacity: 0.18;
  }

  .services-page .services-cta-section .container {
    display: grid;
    gap: 1.25rem;
    justify-items: start;
    max-width: min(66rem, calc(100vw - 2rem));
    position: relative;
    z-index: 1;
  }

  .services-page .services-cta-section .section-heading {
    color: var(--services-porcelain);
    max-width: 12ch;
  }

  .services-page .services-cta-section p {
    color: color-mix(in oklch, var(--services-porcelain), transparent 28%);
    font-family: var(--services-font);
    font-size: clamp(1rem, 1.35vw, 1.18rem);
    line-height: 1.65;
    margin: 0;
    max-width: 38rem;
  }

  .services-page .services-cta-section .btn-primary {
    background: var(--services-porcelain);
    border-color: var(--services-porcelain);
    color: var(--services-carbon);
  }

  .services-page .services-cta-section .btn-primary:hover {
    background: var(--services-cyan);
    border-color: var(--services-cyan);
    color: var(--services-carbon);
  }

  @keyframes services-panel-in {
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  @media (max-width: 68rem) {
    .services-hero {
      background: var(--services-carbon);
    }

    .services-hero::after {
      display: none;
    }

    .services-hero-shell,
    .services-section-intro {
      grid-template-columns: 1fr;
    }

    .services-instrument {
      grid-template-columns: 0.8fr 1.2fr;
      min-height: 34rem;
    }

    .services-grid {
      grid-template-columns: 1fr;
    }

    .service-card + .service-card,
    .product-studio-section .service-card + .service-card {
      border-block-start: 1px solid color-mix(in oklch, var(--services-line), transparent 18%);
      border-inline-start: 0;
    }

    .product-studio-section .service-card + .service-card {
      border-block-start-color: color-mix(in oklch, var(--services-porcelain), transparent 84%);
    }
  }

  @media (max-width: 42rem) {
    .services-page .container {
      max-width: min(100% - 2rem, 88rem);
    }

    .services-hero-shell {
      gap: 1.5rem;
      padding: clamp(2rem, 8vw, 3rem) 1rem;
    }

    .services-hero h1 {
      font-size: clamp(2.55rem, 14vw, 3.55rem);
    }

    .services-hero .hero-subtitle {
      font-size: 0.95rem;
      line-height: 1.5;
    }

    .services-instrument {
      grid-template-columns: 1fr;
      min-height: auto;
    }

    .services-instrument::after,
    .services-signal {
      display: none;
    }

    .services-instrument__panel--dark {
      display: none;
    }

    .services-instrument__panel--light {
      min-height: 18rem;
    }

    .services-instrument__glyphs {
      inset: 4.25rem 1.5rem 1.25rem;
    }

    .hero-capabilities {
      gap: 0.55rem;
      inset: 1.25rem;
    }

    .hero-capability {
      min-height: 4.6rem;
      padding: 0.75rem 0.85rem;
    }

    .capability-label {
      font-size: 0.94rem;
    }

    .capability-desc {
      font-size: 0.78rem;
    }

    .service-card {
      min-height: 15rem;
    }

    .section-image img {
      aspect-ratio: 4 / 3;
    }

    .services-page .services-cta-section {
      background: var(--services-carbon);
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .services-page .btn,
    .service-card {
      transition: none;
    }

    .services-page .btn:hover,
    .service-card:hover {
      transform: none;
    }

    .services-hero-copy,
    .services-instrument {
      opacity: 1;
      transform: none;
      animation: none;
    }
  }
}
