/* ==========================================================================
   sections.css - Consolidated Media Queries

   Breakpoints (standardized):
   - xl: max-width 1280px (was 1200, 1300)
   - lg: max-width 1024px (was 900, 1000, 1024, 1100)
   - md: max-width 768px  (was 768, 800)
   - sm: max-width 640px  (was 600, 640)

   Structure:
   1. Base styles (desktop-first)
   2. @media (max-width: 1280px) — narrower than wide
   3. @media (max-width: 1024px) — tablet/laptop
   4. @media (max-width: 768px)  — tablet portrait
   5. @media (max-width: 640px)  — mobile
   ========================================================================== */

/* ==========================================================================
   Emma Landing - Custom Styles
   ========================================================================== */

/* Noise Overlay
   ========================================================================== */

body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
  opacity: 0.03;
  pointer-events: none;
  z-index: 9999;
}

/* Grid Background
   ========================================================================== */

.grid-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(var(--blue-03) 1px, transparent 1px),
    linear-gradient(90deg, var(--blue-03) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: -1;
}

/* ==========================================================================
   Base Section Styles
   ========================================================================== */

/* Section Container */
.section-container {
  max-width: var(--content-max-width);
  margin: 0 auto;
}

/* ==========================================================================
   Header (BEM)
   Docs: output/design-system/docs/header.md
   ========================================================================== */

/* ── Base ── */

.header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: 1.25rem var(--space-10);
  transition: transform var(--duration-normal) var(--easing),
    background var(--duration-normal) var(--easing),
    box-shadow var(--duration-normal) var(--easing);
}

.header__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}

/* ── Logo — left ── */

.header__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  text-decoration: none;
}

.header__logo img {
  height: 40px;
  width: auto;
}

.header__logo-light {
  display: block;
}

.header__logo-dark {
  display: none;
}

/* ── Nav — center (flex:1) ── */

.header__nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2.5rem;
  flex: 1;
}

.header__nav a {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--white-80);
  text-decoration: none;
  transition: color var(--duration-fast) var(--easing);
  white-space: nowrap;
}

.header__nav a:hover {
  color: var(--white-100);
}

/* ── CTA — right ── */

.header__cta {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

/* Header button — extends .btn .btn-sm .btn-ghost */
.header__btn {
  border-radius: var(--radius-sm);
  /* Default: white outline on dark hero */
  border-color: var(--white-40);
  color: var(--white-100);
}

.header__btn:hover {
  border-color: var(--white-100);
  background: var(--white-10);
  color: var(--white-100);
}

/* ── Burger — right, hidden on desktop ── */

.header__burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}

.header__burger span {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--white-100);
  border-radius: 2px;
  transition: all var(--duration-fast) var(--easing);
}

/* ==========================================================================
   Header States
   ========================================================================== */

/* Scrolled — glass background, becomes fixed */
.header--scrolled {
  position: fixed;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--gray-08);
  box-shadow: 0 2px 16px rgba(0, 0, 0, 0.04);
}

.header--scrolled .header__logo-light {
  display: none;
}

.header--scrolled .header__logo-dark {
  display: block;
}

.header--scrolled .header__nav a {
  color: var(--gray-80);
}

.header--scrolled .header__nav a:hover {
  color: var(--blue-100);
}

/* Scrolled button: blue outline */
.header--scrolled .header__btn {
  border-color: var(--blue-100);
  color: var(--blue-100);
}

.header--scrolled .header__btn:hover {
  background: var(--blue-05);
}

.header--scrolled .header__burger span {
  background: var(--gray-100);
}

/* Hidden — slides up */
.header--hidden {
  transform: translateY(-100%);
}

/* ==========================================================================
   Header Mobile
   ========================================================================== */

.header__mobile-menu {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  z-index: 999;
  padding: 100px 2rem 2rem;
  flex-direction: column;
  gap: 2rem;
}

.header--open .header__mobile-menu {
  display: flex;
}

.header__mobile-menu a {
  font-size: var(--text-xl);
  font-weight: var(--font-medium);
  color: var(--gray-100);
  text-decoration: none;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--gray-08);
}

.header__mobile-menu a:hover {
  color: var(--blue-100);
}

.header__mobile-cta {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: auto;
}

.header__mobile-cta .header__btn {
  text-align: center;
  padding: 1rem;
  background: var(--blue-100);
  border-color: var(--blue-100);
  color: var(--white-100);
}

/* Base Section Padding */
section {
  padding: var(--space-8) var(--space-6);
}

/* Lazy render for sections below the fold */
section:not(.hero) {
  content-visibility: auto;
  contain-intrinsic-size: auto 500px;
}

/* Max width for section content (not hero) */
section:not(.hero) > * {
  max-width: var(--content-max-width);
  margin-left: auto;
  margin-right: auto;
}

/* Section Tag */
.section-tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--blue-100);
  margin-top: 2rem;
  margin-bottom: 1rem;
  font-weight: var(--font-medium);
  letter-spacing: 0.05em;
}

/* Section Label (smaller variant) */
.section-label {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  color: var(--blue-100);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
}

/* Section Title */
.section-title {
  font-size: var(--text-7xl);
  font-weight: var(--font-medium);
  color: var(--gray-100);
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
  line-height: var(--leading-sm);
  letter-spacing: var(--letter-spacing-tight);
  text-wrap: balance;
}

.section-title .gradient {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Section Description */
.section-desc {
  font-size: var(--text-lg);
  color: var(--gray-80);
  max-width: 600px;
  line-height: var(--leading-md);
  text-wrap: pretty;
}

/* Section CTA */
.section-cta {
  margin-top: clamp(1.5rem, 3vw, 2.5rem);
  text-align: center;
}

/* Fade In Animation — initial state is in components.css */
/* .visible class is added by JS when element enters viewport */

/* Responsive */

/* 1280px horizontal padding now handled by clamp() in each section file.
   Vertical reduction kept via padding-top/padding-bottom. */

@media (max-width: 768px) {
  .header {
    padding: 1rem var(--space-4);
  }

  .header__nav,
  .header__cta {
    display: none;
  }

  .header__burger {
    display: flex;
  }

  /* Mobile menu open state */
  .header--open .header__burger span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
  }

  .header--open .header__burger span:nth-child(2) {
    opacity: 0;
  }

  .header--open .header__burger span:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
  }
  /* Originally: max-width: 800px */
  .section-title {
    font-size: var(--text-5xl);
  }
}
/* Hero Section
   ========================================================================== */

.hero {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: calc(var(--space-16) + 72px) clamp(1rem, 4vw, 4rem) var(--space-10);
  position: relative;
  background-color: #4361ee;
  background-image: url('../assets/back.jpg');
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  overflow: hidden;
}

/* Extend hero background to cover header area */
.hero::before {
  content: '';
  position: absolute;
  top: -200px;
  left: 0;
  right: 0;
  height: 200px;
  background-color: inherit;
  z-index: -1;
}

.hero-logo {
  position: absolute;
  top: 4rem;
  left: var(--space-10);
  z-index: 10;
}

.hero-logo img {
  height: 42px;
  width: auto;
}

.hero-content {
  max-width: 900px;
  position: relative;
  z-index: 2;
}

.hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  background: var(--white-15);
  border: 1px solid var(--white-25);
  padding: 0.5rem 1rem;
  border-radius: var(--radius-full);
  font-family: var(--font-mono);
  font-size: var(--text-md);
  color: var(--white-90);
  margin-bottom: clamp(1.5rem, 3vw, 2rem);
  font-weight: var(--font-medium);
  animation: fadeInUp 0.8s ease forwards;
}

.hero-tag::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--white-100);
  border-radius: 50%;
  animation: pulse 2s infinite;
}

.hero h1 {
  font-size: var(--text-hero);
  font-weight: var(--font-semibold);
  line-height: var(--leading-xs);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
  letter-spacing: var(--letter-spacing-tighter);
  animation: fadeInUp 0.8s ease 0.1s forwards;
  opacity: 0;
  color: var(--white-100);
}

.hero h1 .highlight {
  background: linear-gradient(
    90deg,
    var(--violet-100) 30%,
    var(--violet-90) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-sub {
  font-size: var(--text-4xl);
  color: var(--white-70);
  max-width: 600px;
  margin-bottom: clamp(2rem, 4vw, 3rem);
  font-weight: var(--font-normal);
  animation: fadeInUp 0.8s ease 0.2s forwards;
  opacity: 0;
}

.hero-ctas {
  display: flex;
  gap: var(--space-4);
  animation: fadeInUp 0.8s ease 0.3s forwards;
  opacity: 0;
}

/* Hero buttons override for dark background */
.hero .btn-primary {
  background: var(--white-100);
  color: var(--blue-100);
  box-shadow: 0 0 30px var(--white-25);
}

.hero .btn-primary:hover {
  box-shadow: 0 0 50px var(--white-30);
}

.hero .btn-ghost {
  color: var(--white-100);
  border-color: var(--white-40);
}

.hero .btn-ghost:hover {
  border-color: var(--white-100);
  color: var(--white-100);
  background: var(--white-10);
}

/* Stats Bar */
.stats-bar {
  display: flex;
  gap: var(--space-10);
  padding-top: clamp(1.5rem, 3vw, 2rem);
  border-top: 1px solid var(--white-20);
  margin-top: clamp(2.5rem, 5vw, 4rem);
  animation: fadeInUp 0.8s ease 0.4s forwards;
  opacity: 0;
}

.stat {
  display: flex;
  flex-direction: column;
}

.stat-value {
  font-family: var(--font-mono);
  font-size: var(--text-5xl);
  font-weight: var(--font-bold);
  color: var(--white-90);
}

.stat-label {
  font-size: var(--text-sm);
  color: var(--white-60);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
}

/* ==========================================================================
   Hero HUD Overlay
   ========================================================================== */

.hero-hud {
  position: absolute;
  top: 0;
  right: 0;
  width: 50%;
  height: 100%;
  pointer-events: none;
  overflow: hidden;
  z-index: 1;
}

/* Layer: Grid (40px) */
.hero-hud__grid {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(
      to right,
      var(--white-05) 1px,
      transparent 1px
    ),
    linear-gradient(to bottom, var(--white-05) 1px, transparent 1px);
  background-size: 40px 40px;
  opacity: 0.8;
  /* Fade out on left edge */
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 30%);
  mask-image: linear-gradient(to right, transparent 0%, black 30%);
}

/* Layer: SVG container */
.hero-hud__svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
  /* Fade out on left edge (same as grid) */
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 30%);
  mask-image: linear-gradient(to right, transparent 0%, black 30%);
}

/* Nodes */
.hero-hud__nodes .node {
  fill: var(--white-100);
  opacity: 0.2;
}

.hero-hud__nodes .node--active {
  opacity: 0.6;
}

/* Safe jurisdiction nodes (green) */
.hero-hud__nodes .node--safe {
  fill: var(--green-100);
  opacity: 0.8;
  transform-origin: center;
  transform-box: fill-box;
  transform: scale(1.25);
}

/* Boundary (allowed zone contour) */
.hero-hud__boundary {
  fill: none;
  stroke: var(--white-100);
  stroke-width: 2;
  opacity: 0.15;
}

/* Shine effect (animated glow traveling along boundary) */
.hero-hud__shine {
  fill: none;
  stroke: var(--white-100);
  stroke-width: 2;
  stroke-linecap: round;
  opacity: 0.35;
  filter: blur(1px);
  animation: boundaryShine 36s linear infinite;
}

@keyframes boundaryShine {
  from {
    stroke-dashoffset: 0;
  }
  to {
    /* Positive value = counter-clockwise direction */
    stroke-dashoffset: var(--path-length);
  }
}

/* Accessibility: disable shine animation for reduced motion */
@media (prefers-reduced-motion: reduce) {
  .hero-hud__shine {
    animation: none;
    opacity: 0.3;
  }
}

/* Routes (connections) */
.hero-hud__routes path {
  fill: none;
  stroke: var(--white-100);
  stroke-width: 1;
  opacity: 0.1;
}

.hero-hud__routes .route--cutoff {
  opacity: 0.12;
}

/* Layer: Micro labels */
.hero-hud__label {
  position: absolute;
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--white-100);
  letter-spacing: 1px;
  text-transform: uppercase;
  white-space: nowrap;
}

/* Dynamic label — jumps between green nodes */
.hero-hud__label--policy {
  display: flex;
  flex-direction: column;
  gap: 2px;
  opacity: 0;
  pointer-events: none;
}

.hero-hud__label-node {
  color: var(--white-100);
}

.hero-hud__label-status {
  color: var(--green-100);
}

/* Pointer line from node to label */
.hero-hud__pointer {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: visible;
}

.hero-hud__pointer-line {
  stroke: var(--green-100);
  stroke-width: 1;
  opacity: 0;
}

/* Breathing animation for active nodes */
@keyframes nodeBreathing {
  0%,
  100% {
    opacity: 0.5;
  }
  50% {
    opacity: 0.7;
  }
}

/* Responsive: hide on mobile, simplify on tablet */

/* Responsive */

@media (max-width: 1024px) {
  .hero-tag {
    font-size: var(--text-sm);
  }

  .hero-hud {
    width: 40%;
    opacity: 0.5;
  }

  .hero-hud__nodes,
  .hero-hud__routes,
  .hero-hud__label {
    display: none;
  }
  .hero {
    padding-top: calc(4rem + 60px);
    padding-bottom: 4rem;
  }

  .hero-logo {
    left: 2rem;
  }
  .stats-bar {
    flex-wrap: wrap;
    gap: var(--space-6);
  }
  /* Originally: max-width: 900px */
  .hero-ctas {
    flex-direction: column;
    align-items: stretch;
  }

  .hero-ctas .btn {
    justify-content: center;
  }
}

@media (max-width: 768px) {
  .hero-hud {
    display: none;
  }
}
/* Problem Section
   ========================================================================== */

.problem-section {
  background: var(--gradient-section-down);
}

.problem-section > .fade-in:first-child {
  text-align: center;
}

.problem-section .section-desc {
  margin-left: auto;
  margin-right: auto;
}

.problem-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: clamp(1rem, 2.5vw, 1.5rem);
  margin-top: clamp(2rem, 4vw, 4rem);
}

.problem-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: clamp(1rem, 2.5vw, 1.5rem);
  position: relative;
  overflow: hidden;
  transition: all var(--duration-slow) var(--easing);
}

.problem-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--pink-100), transparent);
  opacity: 0;
  transition: opacity var(--duration-normal);
}

.problem-card:hover::before {
  opacity: 1;
}

.problem-card:hover {
  transform: translateY(-5px);
  border-color: var(--pink-30);
}

.problem-card .icon {
  font-size: var(--text-6xl);
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
}

.problem-card h3 {
  font-size: var(--text-2xl);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
  color: var(--pink-100);
  font-weight: var(--font-semibold);
}

.problem-card p {
  color: var(--gray-80);
  font-size: var(--text-md);
}


/* Responsive */

@media (max-width: 1024px) {
  .problem-card {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    text-align: left;
    gap: var(--space-3);
  }

  .problem-card .icon {
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .problem-card h3 {
    flex: 1;
    margin-bottom: 0;
    align-self: center;
  }

  .problem-card p {
    width: 100%;
    margin-top: var(--space-2);
  }
}
/* Solution Section
   ========================================================================== */

.solution-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 6rem);
}

.solution-section .section-container {
  padding: clamp(1rem, 4vw, 4rem) clamp(1rem, 3vw, 3rem) clamp(1rem, 3vw, 3rem);
  background: linear-gradient(180deg, var(--green-05) 0%, var(--green-10) 100%);
  border-radius: var(--radius-xl);
}

.solution-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  max-width: 900px;
  margin: clamp(1.5rem, 3vw, 3rem) auto 0;
}

.solution-header {
  text-align: center;
  margin-bottom: clamp(1.5rem, 3vw, 3rem);
}

.solution-header .section-desc {
  margin-left: auto;
  margin-right: auto;
}

.solution-header h2 .gradient {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.solution-icon {
  width: 56px;
  height: 56px;
  margin: 0 auto clamp(0.75rem, 1.5vw, 1.25rem);
  background: var(--green-10);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
}

.solution-icon svg {
  width: 28px;
  height: 28px;
  stroke: var(--green-100);
}

.solution-card {
  display: flex;
  flex-direction: column;
  background: var(--white-30);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: clamp(1rem, 2.5vw, 1.5rem);
  transition: all var(--duration-slow);
}

.solution-card:hover {
  transform: translateY(-5px);
  border-color: var(--green-70);
  box-shadow: 0 20px 60px var(--blue-10);
}

.solution-card h3 {
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  margin-bottom: clamp(0.25rem, 0.75vw, 0.5rem);
  text-align: center;
  color: var(--gray-100);
}

.solution-card p {
  font-size: var(--text-base);
  color: var(--gray-80);
  line-height: var(--leading-lg);
  text-align: center;
}

.solution-highlight {
  font-family: var(--font-mono);
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--green-100);
  margin-top: auto;
  padding-top: 0.75rem;
  text-align: center;
}

.solution-cta {
  display: flex;
  justify-content: center;
  margin-top: clamp(1.5rem, 3vw, 3rem);
}


/* Responsive */

@media (max-width: 1024px) {
  .solution-grid {
    grid-template-columns: repeat(2, 1fr);
    max-width: 100%;
  }

  .solution-card {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    text-align: left;
    gap: var(--space-3);
  }

  .solution-card .solution-icon {
    margin: 0;
    flex-shrink: 0;
  }

  .solution-card h3 {
    flex: 1;
    text-align: left;
    align-self: center;
    margin-bottom: 0;
  }

  .solution-card p {
    width: 100%;
    text-align: left;
    margin-top: var(--space-2);
  }

  .solution-highlight {
    width: 100%;
    text-align: left;
    margin-top: var(--space-3);
  }
}

@media (max-width: 768px) {
  .solution-grid {
    grid-template-columns: 1fr;
  }
}
/* Company Section
   ========================================================================== */

.company-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 6rem) 0;
}

.company-section .section-container {
  padding: clamp(1rem, 4vw, 4rem) clamp(1rem, 3vw, 3rem) clamp(1rem, 3vw, 3rem);
  background: linear-gradient(180deg, var(--blue-05) 0%, var(--blue-10) 100%);
  border-radius: var(--radius-xl);
}

.company-header--centered {
  text-align: center;
}

.company-stats {
  display: flex;
  justify-content: center;
  gap: var(--space-16);
  margin-top: clamp(2rem, 4vw, 4rem);
}

.company-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.company-stat__value {
  font-family: var(--font-mono);
  font-size: var(--text-9xl);
  font-weight: var(--font-medium);
  color: var(--blue-100);
  line-height: var(--leading-xs);
}

.company-stat__label {
  margin-top: var(--space-2);
  font-size: var(--text-base);
  color: var(--gray-60);
}

/* Slot machine counter animation */
.company-stat__value {
  display: flex;
  justify-content: center;
  align-items: center;
}

.slot-char {
  display: inline-block;
}

.slot-digit {
  display: inline-block;
  height: 1.05em;
  overflow: hidden;
  position: relative;
}

.slot-digit__reel {
  display: flex;
  flex-direction: column;
  transition: transform 1.5s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.slot-digit__reel span {
  display: block;
  height: 1.05em;
  line-height: 1.05;
}

/* Reduced motion: no animation */
@media (prefers-reduced-motion: reduce) {
  .slot-digit__reel {
    transition: none;
  }
}

.company-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  margin-top: clamp(2rem, 4vw, 4rem);
}

.company-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: var(--white-30);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: clamp(1rem, 2.5vw, 1.5rem);
  transition: all var(--duration-slow);
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

.company-card:focus {
  outline: 2px solid var(--blue-50);
  outline-offset: 2px;
}

.company-card:hover {
  transform: translateY(-5px);
  border-color: var(--blue-70);
  box-shadow: 0 20px 60px var(--blue-10);
}

.company-card h3 {
  color: var(--gray-100);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
  font-weight: var(--font-semibold);
}

.company-icon {
  width: 48px;
  height: 48px;
  background: var(--blue-10);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
  color: var(--blue-100);
}

.company-highlight {
  display: inline-block;
  margin-top: clamp(0.75rem, 1.5vw, 1rem);
  padding: var(--space-1) var(--space-3);
  background: var(--blue-10);
  color: var(--blue-100);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  border-radius: var(--radius-full);
}

.company-divider {
  border: none;
  border-top: 1px solid var(--gray-10);
  margin: clamp(1rem, 2vw, 1.5rem) 0;
}

.company-investors {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-10);
}

.company-investors__label {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--gray-50);
  margin-right: clamp(0.75rem, 1.5vw, 1rem);
}

.company-investors img {
  width: auto;
  opacity: 0.5;
  transition: opacity var(--duration-normal) var(--easing);
}

/* Individual logo sizes for visual balance */
.company-investors img:nth-child(2) {
  height: 20px;
} /* BlackRock - wide text */
.company-investors img:nth-child(3) {
  height: 36px;
} /* RTP Global - with circle */
.company-investors img:nth-child(4) {
  height: 24px;
} /* Smartfin */
.company-investors img:nth-child(5) {
  height: 28px;
} /* deep.vc */
.company-investors img:nth-child(6) {
  height: 32px;
} /* ALTAIR - with icon */
.company-investors img:nth-child(7) {
  height: 40px;
} /* CircleRock - square icon */

.company-investors img:hover {
  opacity: 0.8;
}

.company-cta {
  display: flex;
  justify-content: center;
  margin-top: clamp(1.5rem, 3vw, 3rem);
}

/* Tablet: cards stack, icon + title inline */

/* Responsive */

@media (max-width: 1024px) {
  .company-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .company-card {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    text-align: left;
    gap: var(--space-3);
  }

  .company-card .company-icon {
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .company-card h3 {
    flex: 1;
    margin-bottom: 0;
    align-self: center;
  }

  .company-card p {
    width: 100%;
    margin-top: var(--space-2);
  }
}

@media (max-width: 768px) {
  .company-grid {
    grid-template-columns: 1fr;
  }

  .company-stats {
    flex-wrap: wrap;
    gap: var(--space-8) var(--space-10);
  }

  .company-stat {
    flex: 0 0 calc(50% - var(--space-5));
  }

  .company-investors {
    gap: var(--space-6) var(--space-8);
  }

  .company-investors__label {
    width: 100%;
    text-align: center;
    margin-right: 0;
    margin-bottom: var(--space-2);
  }

  .company-investors img:nth-child(2) {
    height: 16px;
  }
  .company-investors img:nth-child(3) {
    height: 28px;
  }
  .company-investors img:nth-child(4) {
    height: 18px;
  }
  .company-investors img:nth-child(5) {
    height: 22px;
  }
  .company-investors img:nth-child(6) {
    height: 24px;
  }
  .company-investors img:nth-child(7) {
    height: 30px;
  }
}
/* Features Section
   ========================================================================== */

.features-section {
  background: var(--gray-03);
}

.features-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--gray-08);
  margin-top: clamp(2rem, 4vw, 4rem);
  border: 1px solid var(--gray-08);
}

.feature {
  background: var(--gray-03);
  padding: clamp(1rem, 4vw, 4rem) clamp(1rem, 3vw, 3rem) clamp(1rem, 3vw, 3rem);
  position: relative;
  transition: all var(--duration-slow);
}

.feature::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 2px;
  background: var(--blue-100);
  transition: all var(--duration-slow);
  transform: translateX(-50%);
}

.feature:hover {
  background: var(--white-100);
}

.feature:hover::after {
  width: 80%;
}

.feature-icon {
  width: 48px;
  height: 48px;
  background: var(--blue-10);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
  font-size: var(--text-4xl);
}

.feature h3 {
  font-size: var(--text-3xl);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
  font-weight: var(--font-semibold);
}

.feature p {
  color: var(--gray-80);
  font-size: var(--text-md);
}


/* Responsive */

@media (max-width: 1024px) {
  .features-grid {
    grid-template-columns: 1fr;
  }
}
/* Platform Section
   ========================================================================== */

.platform-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--gradient-section-up);
}

.platform-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  max-width: 1100px;
  margin: clamp(1.5rem, 3vw, 3rem) auto 0;
}

.platform-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-xl);
  padding: clamp(1rem, 2.5vw, 1.5rem);
  transition: all var(--duration-normal) ease;
}

.platform-card:hover {
  border-color: var(--blue-100);
  transform: translateY(-4px);
}

.platform-icon {
  width: 56px;
  height: 56px;
  background: var(--blue-10);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.platform-icon svg {
  stroke: var(--blue-100);
}

.platform-card h4 {
  font-size: var(--text-xl);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
  color: var(--gray-100);
}

.platform-card p {
  color: var(--gray-80);
  font-size: var(--text-md);
  line-height: var(--leading-lg);
}


/* Responsive */

@media (max-width: 1024px) {
  .platform-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .platform-card {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    text-align: left;
    gap: var(--space-3);
  }

  .platform-card .platform-icon {
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .platform-card h4 {
    flex: 1;
    margin-bottom: 0;
    align-self: center;
  }

  .platform-card p {
    width: 100%;
    margin-top: var(--space-2);
  }
}

@media (max-width: 768px) {
  .platform-grid {
    grid-template-columns: 1fr;
  }
}
/* Code Section
   ========================================================================== */

.code-section {
  background: var(--white-100);
  overflow: hidden;
}

.code-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  align-items: center;
  margin-top: clamp(2rem, 4vw, 4rem);
}


/* Responsive */

@media (max-width: 1024px) {
  .code-container {
    grid-template-columns: 1fr;
  }
}
/* Comparison Section
   ========================================================================== */

.comparison-section {
  background: var(--gray-03);
}

.comparison-table {
  margin-top: clamp(2rem, 4vw, 4rem);
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.comparison-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  border-bottom: 1px solid var(--gray-08);
}

.comparison-row:last-child {
  border-bottom: none;
}

.comparison-cell {
  padding: 1.25rem 1.5rem;
  font-size: var(--text-base);
}

.comparison-header {
  background: var(--gray-03);
  font-weight: var(--font-semibold);
}

.comparison-header .comparison-cell:first-child {
  color: var(--gray-50);
}

.comparison-cell.emma {
  background: var(--blue-05);
  color: var(--blue-100);
  font-weight: var(--font-semibold);
}

.comparison-disclaimer {
  max-width: 700px;
  margin: clamp(1.5rem, 3vw, 2rem) auto 0;
  text-align: center;
  color: var(--gray-50);
  font-size: var(--text-base);
  font-style: italic;
}


/* Responsive */

@media (max-width: 1024px) {
  .comparison-row {
    grid-template-columns: 2fr 1fr 1fr;
  }

  .comparison-cell:nth-child(4),
  .comparison-cell:nth-child(5) {
    display: none;
  }
}
/* CTA Section
   ========================================================================== */

.cta-section {
  background: var(--gradient-section-up);
  text-align: center;
  padding: clamp(4rem, 8vw, 10rem) clamp(1rem, 4vw, 4rem);
  position: relative;
}

.cta-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 800px;
  height: 800px;
  background: var(--gradient-orb-primary);
  opacity: 0.1;
  filter: blur(100px);
}

.cta-content {
  position: relative;
  z-index: 2;
}

.cta-title {
  font-size: var(--text-display);
  font-weight: var(--font-extrabold);
  letter-spacing: var(--letter-spacing-tight);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.cta-desc {
  font-size: var(--text-3xl);
  color: var(--gray-80);
  margin-bottom: clamp(1.5rem, 3vw, 3rem);
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.cta-buttons {
  display: flex;
  justify-content: center;
  gap: var(--space-4);
}


/* Responsive */

@media (max-width: 640px) {
  .cta-buttons {
    flex-direction: column;
    align-items: center;
  }
}
/* AI Section
   ========================================================================== */

.ai-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--gradient-section-down);
}

.ai-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  margin-top: clamp(2rem, 4vw, 4rem);
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.ai-card {
  background: var(--gray-03);
  border: 1px solid var(--gray-12);
  border-radius: var(--radius-lg);
  padding: clamp(1rem, 2.5vw, 1.5rem);
  transition: all var(--duration-normal);
}

.ai-card:hover {
  border-color: var(--blue-100);
  transform: translateY(-4px);
}

.ai-card-header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
}

.ai-card-header h3 {
  font-size: var(--text-2xl);
  font-weight: var(--font-semibold);
}

.ai-card p {
  color: var(--gray-80);
  font-size: var(--text-md);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.ai-stat {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  padding-top: 1rem;
  border-top: 1px solid var(--gray-08);
}

.ai-stat-value {
  font-size: var(--text-6xl);
  font-weight: var(--font-bold);
  color: var(--blue-100);
}

.ai-stat-label {
  color: var(--gray-50);
  font-size: var(--text-sm);
}


/* Responsive */

@media (max-width: 1024px) {
  .ai-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .ai-grid {
    grid-template-columns: 1fr;
  }
}
/* K8s Section
   ========================================================================== */

.k8s-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--gradient-section-up);
}

.k8s-container {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--space-10);
  align-items: center;
}

.k8s-features {
  list-style: none;
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.k8s-features li {
  padding: 0.75rem 0;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  color: var(--gray-80);
}

.check-icon {
  color: var(--blue-100);
  font-weight: bold;
}

.k8s-visual {
  background: var(--gray-03);
  border: 1px solid var(--gray-15);
  border-radius: var(--radius-xl);
  padding: clamp(1rem, 2.5vw, 1.5rem);
}

.k8s-control {
  text-align: center;
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
}

.k8s-control-label {
  color: var(--blue-100);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  margin-bottom: 0.5rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.k8s-control-box {
  background: var(--blue-10);
  border: 1px solid var(--blue-100);
  border-radius: var(--radius-md);
  padding: 1rem;
  display: flex;
  justify-content: center;
  gap: var(--space-5);
  font-size: var(--text-sm);
  color: var(--gray-100);
}

.k8s-arrow {
  display: flex;
  justify-content: center;
  margin: clamp(0.75rem, 1.5vw, 1rem) 0;
}

.k8s-workers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.k8s-worker {
  background: var(--white-100);
  border-radius: var(--radius-md);
  padding: 1rem;
  text-align: center;
}

.k8s-worker.aws {
  border-top: 3px solid var(--brand-aws);
}
.k8s-worker.azure {
  border-top: 3px solid var(--brand-azure);
}
.k8s-worker.lambda {
  border-top: 3px solid var(--brand-purple);
}

.worker-header {
  font-weight: var(--font-semibold);
  font-size: var(--text-base);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
  color: var(--gray-100);
}

.worker-gpus {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  justify-content: center;
  margin-bottom: clamp(0.25rem, 0.75vw, 0.5rem);
}

.gpu-chip {
  background: var(--gray-15);
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
  font-size: var(--text-2xs);
  font-family: var(--font-mono);
}

.gpu-chip.spot {
  background: var(--blue-20);
  color: var(--blue-100);
}

.worker-cost {
  font-size: var(--text-sm);
  color: var(--gray-50);
}

.worker-cost.best {
  color: var(--blue-100);
  font-weight: var(--font-semibold);
}

.k8s-workload {
  background: var(--gradient-accent-h);
  border-radius: var(--radius-md);
  padding: 1rem;
  text-align: center;
}

.workload-label {
  font-weight: var(--font-semibold);
  color: var(--white-100);
  font-size: var(--text-base);
}

.workload-arrow {
  font-size: var(--text-xs);
  color: var(--white-100);
  margin-top: 0.25rem;
}


/* Responsive */

@media (max-width: 1024px) {
  .k8s-container {
    grid-template-columns: 1fr;
  }

  .k8s-workers {
    grid-template-columns: 1fr;
  }
}
/* Network Section
   ========================================================================== */

.network-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--white-100);
}

.network-container {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  align-items: center;
}

.network-stats {
  display: flex;
  gap: var(--space-6);
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.network-stat {
  display: flex;
  flex-direction: column;
}

.network-stat-value {
  font-size: var(--text-6xl);
  font-weight: var(--font-bold);
  color: var(--violet-100);
}

.network-stat-label {
  color: var(--gray-50);
  font-size: var(--text-sm);
}

.network-visual {
  position: relative;
  height: 300px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.network-node {
  position: absolute;
  padding: 1rem 1.5rem;
  background: var(--gray-03);
  border: 1px solid var(--gray-15);
  border-radius: var(--radius-md);
  font-weight: var(--font-semibold);
  font-size: var(--text-base);
}

.network-node.aws {
  top: 10%;
  left: 10%;
  border-color: var(--brand-aws);
  color: var(--brand-aws);
}
.network-node.azure {
  top: 10%;
  right: 10%;
  border-color: var(--brand-azure);
  color: var(--brand-azure);
}
.network-node.gcp {
  bottom: 10%;
  left: 20%;
  border-color: var(--brand-google);
  color: var(--brand-google);
}
.network-node.regional {
  bottom: 10%;
  right: 10%;
  border-color: var(--violet-100);
  color: var(--violet-100);
}
.network-node.emma-core {
  background: var(--blue-100);
  color: var(--white-100);
  font-size: var(--text-2xl);
  padding: 1.5rem 2rem;
  box-shadow: 0 0 60px var(--blue-25);
}

.network-how {
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.network-how details {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-md);
  padding: 1rem;
}

.network-how summary {
  cursor: pointer;
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--gray-100);
}

.network-how summary:hover {
  color: var(--blue-100);
}

.network-how ul {
  list-style: none;
  margin: 1rem 0 0 0;
  padding: 0;
}

.network-how li {
  padding: 0.5rem 0;
  font-size: var(--text-sm);
  color: var(--gray-80);
  border-top: 1px solid var(--gray-08);
}

.network-how li strong {
  color: var(--gray-100);
}


/* Responsive */

@media (max-width: 1024px) {
  .network-container {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .network-stats {
    flex-direction: column;
    gap: var(--space-4);
  }
}
/* Developer Section
   ========================================================================== */

.dev-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--gray-03);
}

.dev-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  margin-top: clamp(2rem, 4vw, 4rem);
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.dev-card {
  background: var(--gray-03);
  border: 1px solid var(--gray-12);
  border-radius: var(--radius-lg);
  padding: clamp(1rem, 2vw, 1.25rem);
  text-decoration: none;
  transition: all var(--duration-normal);
  display: block;
}

.dev-card:hover {
  border-color: var(--blue-100);
  transform: translateY(-4px);
}

.dev-icon {
  color: var(--blue-100);
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
}

.dev-card h4 {
  color: var(--gray-100);
  font-size: var(--text-xl);
  margin-bottom: clamp(0.25rem, 0.75vw, 0.5rem);
}

.dev-card p {
  color: var(--gray-80);
  font-size: var(--text-sm);
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
}

.dev-card code {
  display: block;
  background: var(--blue-10);
  color: var(--blue-100);
  padding: 0.5rem;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}


/* Responsive */

@media (max-width: 1024px) {
  .dev-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .dev-grid {
    grid-template-columns: 1fr;
  }
}
/* Trust Section
   ========================================================================== */

.trust-section {
  padding: clamp(3rem, 5vw, 6rem) clamp(1rem, 4vw, 4rem);
  background: var(--white-100);
  text-align: center;
}

.trust-badges {
  display: flex;
  justify-content: center;
  gap: var(--space-6);
  margin-top: clamp(1.5rem, 3vw, 3rem);
  flex-wrap: wrap;
}

.trust-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
}

.badge-icon {
  width: 60px;
  height: 60px;
  border-radius: var(--radius-lg);
  background: var(--blue-10);
  border: 1px solid var(--blue-30);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-bold);
  font-size: var(--text-sm);
  color: var(--blue-100);
}

.badge-label {
  color: var(--gray-80);
  font-size: var(--text-xs);
}

.trust-note {
  margin-top: clamp(1.5rem, 3vw, 2rem);
  color: var(--gray-50);
  font-size: var(--text-base);
}

.operational-proof {
  margin-top: clamp(2rem, 4vw, 4rem);
  padding-top: clamp(1.5rem, 3vw, 3rem);
  border-top: 1px solid var(--gray-08);
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
}

.operational-proof h4 {
  font-size: var(--text-base);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gray-50);
  margin-bottom: clamp(1.5rem, 3vw, 2rem);
  text-align: center;
}

.proof-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
}

.proof-item {
  text-align: center;
}

.proof-icon {
  display: block;
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
  color: var(--blue-100);
}

.proof-icon svg {
  stroke: var(--blue-100);
}

.proof-label {
  display: block;
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--gray-100);
  margin-bottom: clamp(0.25rem, 0.75vw, 0.5rem);
}

.proof-item p {
  color: var(--gray-80);
  font-size: var(--text-sm);
  line-height: var(--leading-md);
  margin: 0;
}

.proof-item a {
  color: var(--blue-100);
  text-decoration: none;
}


/* Responsive */

@media (max-width: 1024px) {
  .proof-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .proof-grid {
    grid-template-columns: 1fr;
  }
}
/* ICP Section
   ========================================================================== */

.icp-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--white-100);
}

.icp-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  max-width: 1000px;
  margin: clamp(1.5rem, 3vw, 3rem) auto 0;
}

.icp-card {
  padding: clamp(1rem, 2.5vw, 1.5rem);
  border-radius: var(--radius-xl);
  border: 1px solid var(--gray-08);
}

.icp-card.for {
  background: var(--gradient-card-accent);
  border-color: var(--blue-20);
}

.icp-card.not {
  background: var(--gray-03);
}

.icp-card h4 {
  font-size: var(--text-xl);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
  color: var(--gray-100);
}

.icp-card.for h4 {
  color: var(--blue-100);
}

.icp-card ul {
  list-style: none;
}

.icp-card li {
  padding: 0.5rem 0;
  padding-left: 1.5rem;
  position: relative;
  color: var(--gray-80);
  font-size: var(--text-md);
}

.icp-card.for li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--blue-100);
}

.icp-card.not li::before {
  content: '✗';
  position: absolute;
  left: 0;
  color: var(--gray-50);
}

.icp-honest {
  margin-top: clamp(1rem, 2vw, 1.5rem);
  padding-top: 1rem;
  border-top: 1px solid var(--gray-08);
  color: var(--gray-50);
  font-size: var(--text-base);
  font-style: italic;
}


/* Responsive */

@media (max-width: 768px) {
  .icp-grid {
    grid-template-columns: 1fr;
  }
}
/* Pricing Section
   ========================================================================== */

.pricing-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--gradient-section-down);
}

.pricing-card {
  max-width: 700px;
  margin: clamp(1.5rem, 3vw, 3rem) auto 0;
  background: var(--gray-03);
  border: 2px solid var(--blue-100);
  border-radius: var(--radius-2xl);
  padding: clamp(1rem, 4vw, 4rem) clamp(1rem, 3vw, 3rem) clamp(1rem, 3vw, 3rem);
  position: relative;
}

.pricing-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--gradient-accent-h);
  border-radius: var(--radius-2xl) var(--radius-2xl) 0 0;
}

.pricing-main {
  text-align: center;
  margin-bottom: 2rem;
}

.pricing-amount {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.25rem;
}

.currency {
  font-size: var(--text-6xl);
  font-weight: var(--font-semibold);
  color: var(--gray-80);
}

.price {
  font-size: var(--text-8xl);
  font-weight: var(--font-extrabold);
  letter-spacing: -0.03em;
  color: var(--gray-100);
}

.period {
  font-size: var(--text-2xl);
  color: var(--gray-50);
}

.pricing-sub {
  color: var(--gray-50);
  font-size: var(--text-base);
  margin-top: 0.5rem;
}

.pricing-hosts {
  background: var(--gray-03);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  margin-bottom: 2rem;
}

.pricing-hosts h4 {
  font-size: var(--text-base);
  color: var(--blue-100);
  margin-bottom: 1rem;
  font-family: var(--font-mono);
}

.host-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}

.host-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.75rem;
  background: var(--gray-03);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--gray-80);
}

.host-icon {
  color: var(--blue-100);
  font-size: var(--text-lg);
}

.pricing-egress {
  margin-bottom: 2rem;
}

.egress-compare {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.egress-item {
  text-align: center;
  padding: 1rem 1.5rem;
  border-radius: var(--radius-md);
}

.egress-item.bad {
  background: var(--accent-orange-10);
  border: 1px solid var(--accent-orange-30);
}

.egress-item.good {
  background: var(--blue-10);
  border: 1px solid var(--blue-30);
}

.egress-label {
  display: block;
  font-size: var(--text-xs);
  color: var(--gray-50);
  margin-bottom: 0.25rem;
}

.egress-price {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
}

.egress-item.bad .egress-price {
  color: var(--pink-100);
  text-decoration: line-through;
}

.egress-item.good .egress-price {
  color: var(--blue-100);
}

.egress-arrow {
  color: var(--gray-50);
  font-size: var(--text-4xl);
}

.egress-savings {
  background: var(--violet-100);
  color: var(--white-100);
  padding: 0.5rem 1rem;
  border-radius: var(--radius-full);
  font-weight: var(--font-bold);
  font-size: var(--text-sm);
}

.pricing-cta {
  text-align: center;
  margin-bottom: 1.5rem;
}

.pricing-cta .btn {
  padding: 1rem 2rem;
  font-size: var(--text-lg);
}

.pricing-fine-print {
  text-align: center;
  color: var(--gray-50);
  font-size: var(--text-xs);
}

.exit-plan {
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid var(--gray-08);
  text-align: left;
}

.exit-plan h4 {
  font-size: var(--text-base);
  color: var(--gray-100);
  margin-bottom: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.exit-plan ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.exit-plan li {
  padding: 0.5rem 0;
  padding-left: 1.5rem;
  position: relative;
  color: var(--gray-80);
  font-size: var(--text-base);
}

.exit-plan li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--blue-100);
}


/* Responsive */

@media (max-width: 1024px) {
  .host-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .host-grid {
    grid-template-columns: 1fr;
  }
  .egress-compare {
    flex-direction: column;
  }
  .price {
    font-size: var(--text-display-sm);
  }
}
/* Why Section
   ========================================================================== */

.why-section {
  padding: clamp(3rem, 5vw, 6rem) clamp(1rem, 4vw, 4rem);
  background: var(--white-100);
}

.why-grid {
  max-width: 1000px;
  margin: clamp(1.5rem, 3vw, 3rem) auto 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
}

.why-card {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: clamp(1rem, 2vw, 1.25rem);
}

.why-card h4 {
  font-size: var(--text-lg);
  color: var(--blue-100);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
}

.why-card p {
  color: var(--gray-80);
  font-size: var(--text-base);
  line-height: var(--leading-md);
}


/* Responsive */

@media (max-width: 1024px) {
  .why-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .why-grid {
    grid-template-columns: 1fr;
  }
}
/* Objections Section
   ========================================================================== */

.objections-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--gray-03);
}

.objections-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  max-width: 1100px;
  margin: clamp(1.5rem, 3vw, 3rem) auto 0;
}

.objection-item {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: clamp(1rem, 2.5vw, 1.5rem);
}

.objection-item h4 {
  font-size: var(--text-lg);
  color: var(--gray-100);
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
}

.objection-item p {
  color: var(--gray-80);
  font-size: var(--text-md);
  line-height: var(--leading-lg);
  margin: 0;
}

/* Responsive - Emma Specific
   ========================================================================== */

/* Hero CTA buttons stack earlier to prevent text wrapping */


/* Responsive */

@media (max-width: 640px) {
  .objections-grid {
    grid-template-columns: 1fr;
  }
}
/* ==========================================================================
   Calculator Section
   ========================================================================== */

.calculator-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--gradient-section-down);
}

.calculator-container {
  max-width: 800px;
  margin: 0 auto;
}

.calculator-header {
  text-align: center;
  margin-bottom: clamp(1.5rem, 3vw, 3rem);
}

.calculator-card {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-2xl);
  padding: clamp(1rem, 4vw, 4rem) clamp(1rem, 3vw, 3rem) clamp(1rem, 3vw, 3rem);
  position: relative;
  overflow: hidden;
}

.calculator-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--gradient-accent-h);
}

/* Form */
.calculator-form {
  margin-bottom: 0;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form-group-wide {
  grid-column: 1 / -1;
}

.form-group label {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--gray-100);
  letter-spacing: var(--letter-spacing-wide);
}

.form-group input {
  background: var(--gray-03);
  border: 1px solid var(--gray-15);
  border-radius: var(--radius-md);
  padding: 1rem 1.25rem;
  font-size: var(--text-lg);
  font-family: var(--font-mono);
  color: var(--gray-100);
  transition: all var(--duration-normal) var(--easing);
  width: 100%;
}

.form-group input:focus {
  outline: none;
  border-color: var(--blue-100);
  box-shadow: 0 0 0 3px var(--blue-20);
}

.form-group input::placeholder {
  color: var(--gray-50);
}

.form-hint {
  font-size: var(--text-xs);
  color: var(--gray-50);
}

.input-with-prefix {
  position: relative;
  display: flex;
  align-items: center;
}

.input-prefix {
  position: absolute;
  left: 1.25rem;
  font-size: var(--text-lg);
  font-family: var(--font-mono);
  color: var(--gray-50);
  pointer-events: none;
}

.input-with-prefix input {
  padding-left: 2.5rem;
}

.btn-calc {
  width: 100%;
  justify-content: center;
  padding: 1.25rem 2rem;
  font-size: var(--text-lg);
}

.btn-calc .btn-icon {
  transition: transform var(--duration-normal) var(--easing);
}

.btn-calc:hover .btn-icon {
  transform: translateX(4px);
}

/* Results */
.calculator-result {
  margin-top: clamp(1.5rem, 3vw, 3rem);
  padding-top: clamp(1.5rem, 3vw, 3rem);
  border-top: 1px solid var(--gray-15);
  opacity: 0;
  transform: translateY(20px);
  transition: all var(--duration-slow) var(--easing);
}

.calculator-result.visible {
  opacity: 1;
  transform: translateY(0);
}

.result-comparison {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-6);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
  flex-wrap: wrap;
}

.result-item {
  text-align: center;
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  min-width: 200px;
}

.result-old {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
}

.result-new {
  background: var(--pink-30);
  border: 1px solid var(--pink-100);
}

.result-label {
  display: block;
  font-size: var(--text-xs);
  color: var(--gray-50);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  margin-bottom: var(--space-2);
}

.result-value {
  display: block;
  font-size: var(--text-5xl);
  font-weight: var(--font-extrabold);
  font-family: var(--font-mono);
  letter-spacing: var(--letter-spacing-snug);
}

.result-old .result-value {
  color: var(--gray-100);
}

.result-new .result-value {
  color: var(--pink-100);
}

.result-period {
  font-size: var(--text-sm);
  color: var(--gray-50);
}

.result-arrow {
  color: var(--gray-50);
}

.result-arrow svg {
  stroke: currentColor;
}

/* Impact Cards */
.result-impact {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-4);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.impact-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
}

.impact-icon {
  font-size: var(--text-4xl);
  line-height: 1;
}

.impact-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.impact-label {
  font-size: var(--text-xs);
  color: var(--gray-50);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
}

.impact-value {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  font-family: var(--font-mono);
}

.impact-increase .impact-value {
  color: var(--pink-100);
}

.impact-overpay .impact-value {
  color: var(--violet-100);
}

.impact-absolute {
  font-size: var(--text-sm);
  color: var(--gray-80);
  font-family: var(--font-mono);
}

.impact-warning {
  background: var(--accent-orange-10);
  border-color: var(--accent-orange-30);
}

.impact-warning .impact-value {
  color: var(--color-warning);
}

.impact-note {
  font-size: var(--text-xs);
  color: var(--gray-50);
}

/* Result CTA */
.result-cta {
  text-align: center;
  padding-top: var(--space-6);
  border-top: 1px solid var(--gray-08);
}

.result-cta-title {
  font-size: var(--text-lg);
  color: var(--gray-100);
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
  font-weight: var(--font-medium);
}

.result-cta .btn {
  margin: 0 var(--space-2);
}

/* Calculator Responsive */


/* Responsive */

@media (max-width: 768px) {
  .result-comparison {
    flex-direction: column;
    gap: var(--space-4);
  }

  .result-arrow {
    transform: rotate(90deg);
  }

  .result-item {
    width: 100%;
    min-width: unset;
  }

  .result-cta .btn {
    display: block;
    margin: var(--space-2) 0;
  }
}
/* ==========================================================================
   NEW SECTIONS (from Mac Mini landing)
   ========================================================================== */

/* Hero Alternate
   ========================================================================== */

.hero-alternate .hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  background: var(--blue-10);
  border: 1px solid var(--blue-30);
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--blue-100);
  margin-bottom: 2.5rem;
  animation: fadeInUp 0.6s ease;
}

.hero-alternate .badge-dot {
  width: 10px;
  height: 10px;
  background: var(--blue-100);
  border-radius: 50%;
  animation: pulse 2s ease-in-out infinite;
  box-shadow: 0 0 8px var(--blue-100);
}

.hero-alternate h1 .gradient {
  background: linear-gradient(
    90deg,
    var(--blue-100) 0%,
    var(--violet-100) 50%,
    var(--blue-100) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-social-proof {
  margin-top: 2rem;
  font-size: var(--text-sm);
  color: var(--gray-50);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  animation: fadeInUp 0.6s ease 0.4s both;
  opacity: 0;
}

.hero-social-proof::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--blue-100);
  border-radius: 50%;
  opacity: 0.6;
}

/* Comparison VS Section
   ========================================================================== */

.comparison-vs-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--white-100);
  border-top: 1px solid var(--gray-08);
  border-bottom: 1px solid var(--gray-08);
}

.comparison-vs-section .comparison-header {
  text-align: center;
  margin-bottom: clamp(2rem, 4vw, 4rem);
}

.comparison-vs-table {
  max-width: 900px;
  margin: 0 auto;
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--gray-15);
  background: var(--gray-03);
}

.comparison-vs-row {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  border-bottom: 1px solid var(--gray-08);
}

.comparison-vs-row:last-child {
  border-bottom: none;
}

.comparison-vs-row-header {
  background: var(--gray-03);
}

.comparison-vs-cell {
  padding: 1.25rem 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.comparison-vs-metric {
  font-weight: var(--font-semibold);
  color: var(--gray-80);
  font-size: var(--text-sm);
}

.comparison-vs-competitor {
  background: rgba(255, 107, 107, 0.05);
  text-align: center;
  align-items: center;
}

.comparison-vs-product {
  background: var(--blue-05);
  text-align: center;
  align-items: center;
}

.comparison-vs-row-header .comparison-vs-competitor {
  color: var(--pink-100);
  font-weight: var(--font-bold);
  font-size: var(--text-base);
}

.comparison-vs-row-header .comparison-vs-product {
  color: var(--blue-100);
  font-weight: var(--font-bold);
  font-size: var(--text-base);
}

.cell-value {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
}

.cell-value-bad {
  color: var(--pink-100);
}

.cell-value-good {
  color: var(--blue-100);
}

.cell-note {
  font-size: var(--text-xs);
  color: var(--gray-50);
  margin-top: 0.25rem;
}

/* Pain Grid */
.pain-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  max-width: 900px;
  margin: clamp(1.5rem, 3vw, 3rem) auto 0;
}

.pain-card {
  background: var(--gray-03);
  border: 1px solid rgba(255, 107, 107, 0.2);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  text-align: center;
  transition: all var(--duration-normal) var(--easing);
}

.pain-card:hover {
  border-color: var(--pink-100);
  transform: translateY(-4px);
}

.pain-icon {
  width: 40px;
  height: 40px;
  margin: 0 auto 0.75rem;
  color: var(--pink-100);
}

.pain-icon svg {
  width: 100%;
  height: 100%;
  stroke: var(--pink-100);
}

.pain-title {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--gray-100);
  margin-bottom: 0.25rem;
}

.pain-desc {
  font-size: var(--text-xs);
  color: var(--gray-50);
}


/* Responsive */

@media (max-width: 768px) {
  .comparison-vs-row {
    grid-template-columns: 1fr;
  }

  .comparison-vs-cell {
    text-align: left;
    padding: 1rem;
  }

  .comparison-vs-metric {
    background: var(--gray-03);
    font-weight: var(--font-bold);
  }
}
/* Mini CTA Section
   ========================================================================== */

.mini-cta-section {
  padding: 2rem 0;
  background: var(--gray-03);
  border-top: 1px solid var(--gray-08);
  border-bottom: 1px solid var(--gray-08);
}

.mini-cta-content {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.mini-cta-text {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--gray-80);
}

.btn-sm {
  padding: 0.75rem 1.5rem;
  font-size: var(--text-sm);
}

/* Pricing Cards Section
   ========================================================================== */

.pricing-cards-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--white-100);
  border-top: 1px solid var(--gray-08);
}

.pricing-cards-header {
  text-align: center;
  margin-bottom: clamp(1.5rem, 3vw, 3rem);
}

.pricing-hero-card {
  max-width: 600px;
  margin: 0 auto clamp(2rem, 4vw, 3rem);
  padding: clamp(1rem, 4vw, 4rem) clamp(1rem, 3vw, 3rem) clamp(1rem, 3vw, 3rem);
  background: var(--gradient-card-accent);
  border: 2px solid var(--blue-30);
  border-radius: var(--radius-2xl);
  text-align: center;
}

.pricing-hero-badge {
  display: inline-block;
  background: var(--blue-100);
  color: var(--white-100);
  font-size: var(--text-2xs);
  font-weight: var(--font-bold);
  padding: 0.375rem 0.875rem;
  border-radius: var(--radius-full);
  margin-bottom: clamp(0.75rem, 1.5vw, 1.25rem);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.pricing-hero-name {
  font-family: var(--font-mono);
  font-size: var(--text-section);
  font-weight: var(--font-bold);
  margin-bottom: 0.5rem;
  color: var(--gray-100);
}

.pricing-hero-spec {
  font-size: var(--text-base);
  color: var(--gray-50);
  margin-bottom: clamp(1.5rem, 3vw, 2rem);
}

.pricing-hero-features {
  display: flex;
  justify-content: center;
  gap: 2rem;
  margin-bottom: clamp(1.5rem, 3vw, 2rem);
  flex-wrap: wrap;
}

.pricing-hero-feature {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.pricing-hero-feature .feature-label {
  font-size: var(--text-xs);
  color: var(--gray-50);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.pricing-hero-feature .feature-value {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--blue-100);
}

.pricing-other-header {
  text-align: center;
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
  font-size: var(--text-sm);
  color: var(--gray-50);
}

.pricing-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  max-width: 800px;
  margin: 0 auto;
}

.pricing-card-mini {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  text-align: center;
  transition: all var(--duration-normal) var(--easing);
}

.pricing-card-mini:hover {
  border-color: var(--blue-100);
  transform: translateY(-4px);
}

.pricing-card-name {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  margin-bottom: 0.25rem;
  color: var(--gray-100);
}

.pricing-card-spec {
  font-size: var(--text-xs);
  color: var(--gray-50);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
}

.pricing-card-price {
  font-family: var(--font-mono);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--blue-100);
  margin-bottom: clamp(0.25rem, 0.75vw, 0.5rem);
}

.pricing-card-price span {
  font-size: var(--text-sm);
  font-weight: var(--font-normal);
  color: var(--gray-50);
}

.pricing-card-note {
  font-size: var(--text-xs);
  color: var(--gray-50);
}


/* Responsive */

@media (max-width: 1024px) {
  .pricing-cards-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .pain-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .pricing-cards-grid {
    grid-template-columns: 1fr;
  }
}
/* Usecases Section
   ========================================================================== */

.usecases-section {
  padding: 0 clamp(1rem, 4vw, 6rem) clamp(3rem, 6vw, 8rem);
  background: transparent;
}

.usecases-header {
  text-align: center;
  margin-bottom: clamp(2rem, 4vw, 4rem);
}

/* Usecase Item (zigzag layout) */
.usecase-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  margin-bottom: clamp(4.5rem, 5vw, 6.5rem);
}

.usecase-item:last-child {
  margin-bottom: 0;
}

.usecase-image {
  flex: 1;
}

.usecase-image img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-xl);
}

.usecase-image .code-block {
  width: 100%;
  aspect-ratio: 4 / 3;
  display: flex;
  flex-direction: column;
}

.usecase-image .code-header {
  justify-content: flex-start;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

.usecase-image .code-content {
  flex: 1;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: var(--space-4);
  overflow: hidden;
}

.usecase-image .code-content pre {
  white-space: pre-wrap;
  font-size: var(--text-xs);
  line-height: var(--leading-md);
}

@media (min-width: 768px) {
  .usecase-image .code-content {
    align-items: center;
    justify-content: center;
  }
  .usecase-image .code-content pre {
    white-space: pre;
    font-size: var(--text-md);
  }
}

.usecase-placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  background: var(--white-100);
  border: 1px solid var(--gray-10);
  border-radius: var(--radius-xl);
}

.usecase-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-4);
}

.usecase-tag {
  display: inline-block;
  width: fit-content;
  background: var(--blue-10);
  color: var(--blue-100);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  padding: 0.25rem 0.75rem;
  border-radius: var(--radius-full);
}

.usecase-tag--orange {
  background: var(--orange-10);
  color: var(--orange-100);
}

.usecase-tag--green {
  background: var(--green-10);
  color: var(--green-100);
}

.usecase-tag--violet {
  background: var(--violet-10);
  color: var(--violet-100);
}

.usecase-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.usecase-title {
  font-size: var(--text-3xl);
  font-weight: var(--font-semibold);
  color: var(--gray-100);
  line-height: var(--leading-sm);
}

.usecase-desc {
  font-size: var(--text-xl);
  color: var(--gray-80);
  line-height: var(--leading-lg);
}

.usecase-item .btn {
  width: fit-content;
  margin-top: clamp(1rem, 2vw, 1.5rem);
}

/* Comparison columns */
.usecase-comparison {
  display: flex;
  gap: var(--space-6);
  margin-top: clamp(0.75rem, 1.5vw, 1.25rem);
  background: var(--gray-03);
  padding: var(--space-5) var(--space-6);
  border-radius: var(--radius-lg);
}

.usecase-column {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.usecase-column {
  flex: 1;
}

.usecase-column:last-child {
  border-left: 1px solid var(--gray-15);
  padding-left: var(--space-6);
}

.usecase-column-title {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-2xs);
  font-weight: var(--font-semibold);
  color: var(--gray-50);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
}

.usecase-column-title img {
  width: 1em;
  height: 1em;
}

.usecase-column-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: var(--text-base);
  color: var(--gray-80);
  line-height: var(--leading-md);
}

.usecase-column-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  height: calc(1em * var(--leading-md));
}

.usecase-column-icon svg {
  width: 1em;
  height: 1em;
}

.usecase-column--you .usecase-column-icon svg {
  stroke: var(--gray-50);
}

.usecase-column--emma .usecase-column-title {
  color: var(--blue-100);
}

.usecase-column--emma .usecase-column-icon svg {
  stroke: var(--blue-100);
}

/* Mobile: comparison columns stack vertically */

/* Desktop: zigzag layout */


/* Responsive */

@media (max-width: 1280px) {
  /* Originally: max-width: 1200px */
  .usecase-comparison {
    flex-direction: column;
    gap: var(--space-3);
  }

  .usecase-column:last-child {
    border-left: none;
    padding-left: 0;
    border-top: 1px solid var(--gray-15);
    padding-top: var(--space-4);
  }
}

@media (max-width: 768px) {
  .usecases-grid {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 768px) {
  .usecase-item {
    flex-direction: row;
    align-items: flex-start;
    gap: var(--space-10);
  }

  .usecase-item--reverse {
    flex-direction: row-reverse;
  }

  .usecase-image,
  .usecase-content {
    flex: 1;
  }

  .usecase-title {
    font-size: var(--text-5xl);
  }
}
}
/* Promo Box Section
   ========================================================================== */

.promo-box-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--white-100);
  border-top: 1px solid var(--gray-08);
}

.promo-box {
  max-width: 700px;
  margin: 0 auto;
  text-align: center;
  padding: clamp(1rem, 4vw, 4rem) clamp(1rem, 3vw, 3rem) clamp(1rem, 3vw, 3rem);
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-xl);
}

.promo-label {
  display: inline-block;
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--gray-50);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
}

.promo-title {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
  letter-spacing: var(--letter-spacing-snug);
  color: var(--gray-100);
}

.promo-desc {
  font-size: var(--text-base);
  color: var(--gray-80);
  max-width: 500px;
  margin: 0 auto clamp(1rem, 2.5vw, 1.75rem);
  line-height: var(--leading-lg);
}

.promo-desc strong {
  color: var(--blue-100);
  font-weight: var(--font-bold);
}

.promo-features {
  display: flex;
  justify-content: center;
  gap: 2rem;
  flex-wrap: wrap;
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.promo-feature {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--text-sm);
  color: var(--gray-80);
}

.promo-feature svg {
  width: 18px;
  height: 18px;
  stroke: var(--blue-100);
}


/* Responsive */

@media (max-width: 768px) {
  .promo-features {
    flex-direction: column;
    gap: 0.75rem;
  }
}
/* Form Section
   ========================================================================== */

.form-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
}

.form-header {
  text-align: center;
  margin-bottom: clamp(1.5rem, 3vw, 3rem);
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.form-header .section-desc {
  margin-left: auto;
  margin-right: auto;
}

.form-layout {
  display: grid;
  grid-template-columns: 1fr 2fr 1fr;
  gap: var(--space-6);
  align-items: stretch;
}

.form-box {
  background: var(--gray-03);
  border: 1px solid var(--gray-15);
  border-radius: var(--radius-xl);
  padding: clamp(1rem, 3.5vw, 3.5rem) clamp(1rem, 3vw, 2.5rem) clamp(1rem, 3vw, 2.5rem);
}

.form-legal {
  font-size: var(--text-xs);
  color: var(--gray-50);
}

.form-legal a {
  color: var(--gray-60);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color var(--duration-fast);
}

.form-legal a:hover {
  color: var(--blue-100);
}

/* Timeline (What happens next) */
.form-timeline {
  position: relative;
  padding-top: var(--space-4);
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* Vertical line spanning full block height */
.form-timeline::before {
  content: '';
  position: absolute;
  left: 15px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(
    180deg,
    transparent 0%,
    var(--gray-06) 10%,
    var(--gray-06) 90%,
    transparent 100%
  );
}

.form-timeline__title {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  color: var(--gray-50);
  padding-left: 30px;
  margin-top: var(--space-2);
}

.form-timeline__subtitle {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  color: var(--gray-50);
  padding-left: 30px;
  margin-bottom: var(--space-2);
}

.timeline {
  position: relative;
  margin: auto 0;
}

.timeline__item {
  display: flex;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
  position: relative;
}

.timeline__item:last-child {
  margin-bottom: 0;
}

.timeline__marker {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  background: linear-gradient(var(--green-10), var(--green-10)),
    var(--white-100);
  border-radius: 50%;
  border: 1px solid var(--green-15);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  margin-left: -20px;
}

.timeline__number {
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  color: var(--green-100);
}

.timeline__content {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.timeline__icon {
  width: 24px;
  height: 24px;
  color: var(--green-100);
  flex-shrink: 0;
}

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

.timeline__heading {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  line-height: var(--leading-xs);
  color: var(--gray-90);
}

.timeline__desc {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  line-height: var(--leading-sm);
  color: var(--gray-50);
}

/* Form section — decorative grid (left column) */
.form-grid {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 300px;
  background-image:
    /* Vertical lines */ linear-gradient(
      90deg,
      var(--gray-10) 1px,
      transparent 1px
    ),
    /* Horizontal lines */
      linear-gradient(0deg, var(--gray-10) 1px, transparent 1px);
  background-size: 30px 30px;
  background-position: 0 0;
  /* Fade out to the left */
  mask-image: linear-gradient(to left, rgba(0, 0, 0, 0.5) 0%, transparent 85%);
  -webkit-mask-image: linear-gradient(
    to left,
    rgba(0, 0, 0, 0.5) 0%,
    transparent 85%
  );
}

/* Animated dots on grid intersections */
.form-grid__dot {
  position: absolute;
  width: 4px;
  height: 4px;
  background: var(--green-100);
  border-radius: 50%;
  opacity: 0;
  box-shadow: 0 0 6px var(--green-50);
}

/* Hide grid on mobile/tablet */

/* Form layout responsive */

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
}

.form-group {
  margin-bottom: 1rem;
}

.form-group label {
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  margin-bottom: 0.5rem;
  color: var(--gray-80);
}

.form-group input,
.form-group select {
  width: 100%;
  padding: 0.875rem 1rem;
  background: var(--white-100);
  border: 1px solid var(--gray-15);
  border-radius: var(--radius-md);
  color: var(--gray-100);
  font-size: var(--text-base);
  font-family: inherit;
  transition: border-color var(--duration-fast) var(--easing);
}

.form-group input:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--blue-100);
}

.form-group input::placeholder {
  color: var(--gray-50);
}

.form-group select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235c5c7a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 3rem;
}

.form-submit {
  width: 100%;
  padding: 1.125rem;
  margin-top: 0.5rem;
  font-size: var(--text-base);
  font-weight: var(--font-bold);
}

.form-speed {
  text-align: center;
  margin-top: 1rem;
  font-size: var(--text-sm);
  color: var(--blue-100);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
}

.form-speed::before {
  content: '\u26A1';
}

.form-note {
  text-align: center;
  font-size: var(--text-xs);
  color: var(--gray-50);
  margin-top: 1.25rem;
}

.form-note a {
  color: var(--gray-80);
  text-decoration: none;
}

.form-note a:hover {
  color: var(--blue-100);
}


/* Responsive */

@media (max-width: 1024px) {
  /* Originally: max-width: 900px */
  .form-grid {
    display: none;
  }

  /* Originally: max-width: 900px */
  .form-layout {
    grid-template-columns: 1fr;
  }

  .form-container {
    max-width: 100%;
  }

  .form-timeline {
    padding-left: 0;
  }

  .form-timeline::before {
    display: none;
  }

  .form-header {
    margin-bottom: var(--space-2);
  }

  .form-timeline__title,
  .form-timeline__subtitle {
    text-align: center;
    margin-bottom: var(--space-6);
    font-size: var(--text-md);
  }

  /* Timeline horizontal layout for tablet (640-1024px) */
  .timeline {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-4);
    max-width: 100%;
    margin: 0 auto;
  }

  .timeline__item {
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 0;
  }

  .timeline__content {
    flex-direction: column;
    align-items: center;
  }

  .timeline__text {
    align-items: center;
  }

  /* Horizontal line connecting markers */
  .timeline::before {
    content: '';
    position: absolute;
    top: 16px;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(
      90deg,
      transparent 0%,
      var(--gray-06) 10%,
      var(--gray-06) 90%,
      transparent 100%
    );
  }
}

@media (max-width: 768px) {
  .form-grid {
    grid-template-columns: 1fr;
  }
  .form-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .form-header {
    margin-bottom: 0;
  }

  /* Timeline back to vertical for mobile */
  .timeline {
    display: block;
    max-width: 400px;
  }

  .timeline__item {
    flex-direction: row;
    align-items: flex-start;
    text-align: left;
    margin-bottom: var(--space-6);
  }

  .timeline__item:last-child {
    margin-bottom: 0;
  }

  .timeline__content {
    flex-direction: row;
    align-items: flex-start;
  }

  .timeline__text {
    align-items: flex-start;
  }

  /* Vertical line for mobile */
  .timeline::before {
    top: 0;
    bottom: 0;
    left: -5px;
    right: auto;
    width: 2px;
    height: auto;
    background: linear-gradient(
      180deg,
      transparent 0%,
      var(--gray-06) 10%,
      var(--gray-06) 90%,
      transparent 100%
    );
  }
}
/* Steps Section
   ========================================================================== */

.steps-section {
  padding: clamp(2rem, 4vw, 4rem) clamp(1rem, 4vw, 4rem);
}

.steps-header {
  text-align: center;
  margin-bottom: clamp(1.5rem, 3vw, 2.5rem);
}

.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  max-width: 800px;
  margin: 0 auto;
}

.step-card {
  text-align: center;
  padding: 1.5rem;
}

.step-number {
  width: 32px;
  height: 32px;
  background: var(--blue-10);
  border: 1px solid var(--blue-30);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1rem;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  color: var(--blue-100);
}

.step-icon {
  width: 40px;
  height: 40px;
  margin: 0 auto 0.75rem;
  color: var(--gray-50);
}

.step-icon svg {
  width: 100%;
  height: 100%;
  stroke: currentColor;
}

.step-title {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  margin-bottom: 0.25rem;
  color: var(--gray-100);
}

.step-desc {
  font-size: var(--text-xs);
  color: var(--gray-50);
}

.steps-note {
  text-align: center;
  font-size: var(--text-xs);
  color: var(--gray-50);
  margin-top: clamp(1.5rem, 3vw, 2rem);
}


/* Responsive */

@media (max-width: 1024px) {
  .steps-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .steps-grid {
    grid-template-columns: 1fr;
  }
}
/* ==========================================================================
   Responsive for New Sections
   ========================================================================== */

/* ==========================================================================
   CREDITS LANDING SECTIONS (from credits.emma.ms)
   ========================================================================== */

/* GPU Catalog Section
   ========================================================================== */

.gpu-catalog-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 6rem);
  background: var(--gray-03);
}

.gpu-catalog-header {
  text-align: center;
  margin-bottom: clamp(1.5rem, 3vw, 3rem);
}

.gpu-catalog-header .section-desc {
  margin-left: auto;
  margin-right: auto;
}

.gpu-catalog-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1rem;
  margin-bottom: clamp(1.5rem, 3vw, 2rem);
  justify-content: center;
}

.gpu-catalog-card {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  min-height: 220px;
  width: 100%;
  max-width: 250px;
  transition: all var(--duration-normal) var(--easing);
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

.gpu-catalog-card:hover {
  border-color: var(--blue-30);
  transform: translateY(-4px);
}

.gpu-catalog-card:focus {
  outline: 2px solid var(--blue-50);
  outline-offset: 2px;
}

.gpu-availability {
  display: inline-block;
  font-size: var(--text-2xs);
  color: var(--blue-100);
  background: var(--blue-10);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
  font-weight: var(--font-semibold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
}

.gpu-name {
  font-family: var(--font-mono);
  font-size: var(--text-5xl);
  font-weight: var(--font-bold);
  margin-bottom: clamp(0.25rem, 0.5vw, 0.375rem);
  color: var(--gray-100);
}

.gpu-spec {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--gray-80);
  margin-bottom: clamp(0.25rem, 0.75vw, 0.5rem);
}

.gpu-use {
  font-size: var(--text-sm);
  color: var(--gray-50);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
  line-height: var(--leading-md);
  flex-grow: 1;
}

.gpu-price {
  font-family: var(--font-mono);
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--blue-100);
  margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
}

.gpu-price span {
  display: block;
  font-size: var(--text-2xs);
  font-weight: var(--font-normal);
  color: var(--gray-50);
  margin-top: 0.25rem;
}

.gpu-status {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  font-size: var(--text-xs);
  color: var(--blue-100);
  margin-top: auto;
}

.status-dot {
  width: 6px;
  height: 6px;
  background: var(--blue-100);
  border-radius: 50%;
  animation: pulse 2s ease-in-out infinite;
}

.gpu-catalog-footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-6);
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--gray-90);
  border-top: 1px solid var(--gray-10);
  padding-top: var(--space-6);
  margin-top: clamp(1rem, 2vw, 1.5rem);
}

.gpu-catalog-footer__item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.gpu-catalog-footer__icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  color: var(--green-100);
}

.gpu-catalog-cta {
  text-align: center;
  margin-top: clamp(2rem, 4vw, 4rem);
}


/* Responsive */

@media (max-width: 1024px) {
  /* Originally: max-width: 1100px */
  .gpu-catalog-grid {
    grid-template-columns: repeat(3, 250px);
  }

  /* Originally: max-width: 900px */
  .gpu-catalog-grid {
    grid-template-columns: repeat(2, 250px);
  }
}

@media (max-width: 768px) {
  .gpu-catalog-footer {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }
}

@media (max-width: 640px) {
  /* Originally: max-width: 600px */
  .gpu-catalog-grid {
    grid-template-columns: 1fr;
    justify-items: center;
  }
}
/* Flow Comparison Section
   ========================================================================== */

.flow-comparison-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  background: var(--white-100);
  border-top: 1px solid var(--gray-08);
  border-bottom: 1px solid var(--gray-08);
}

.flow-comparison-header {
  text-align: center;
  margin-bottom: clamp(2rem, 4vw, 4rem);
}

.flow-comparison-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  max-width: 900px;
  margin: 0 auto clamp(2rem, 4vw, 3rem);
}

.flow-box {
  padding: clamp(1rem, 3vw, 3rem) clamp(1rem, 2.5vw, 2rem) clamp(1rem, 2.5vw, 2rem);
  background: var(--gray-03);
  border: 1px solid var(--gray-15);
  border-radius: var(--radius-xl);
}

.flow-box-problem {
  border-color: rgba(255, 107, 107, 0.3);
}

.flow-box-solution {
  border-color: var(--blue-30);
  background: var(--gradient-card-accent);
}

.flow-box-label {
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: clamp(0.75rem, 1.5vw, 1.25rem);
  text-align: center;
}

.flow-box-problem .flow-box-label {
  color: var(--pink-100);
}

.flow-box-solution .flow-box-label {
  color: var(--blue-100);
}

.flow-diagram {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.flow-diagram-hub {
  gap: 0.5rem;
}

.flow-node {
  background: var(--white-100);
  border: 1px solid var(--gray-15);
  border-radius: var(--radius-md);
  padding: 0.875rem 1.25rem;
  text-align: center;
  min-width: 80px;
}

.flow-node-highlight {
  border-color: var(--blue-100);
  background: var(--blue-10);
}

.flow-node-label {
  font-size: var(--text-2xs);
  color: var(--gray-50);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.125rem;
}

.flow-node-name {
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  color: var(--gray-100);
}

.hub-connector {
  width: 20px;
  height: 2px;
  background: var(--blue-100);
}

.flow-arrow {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.125rem;
}

.flow-arrow svg {
  width: 28px;
  height: 20px;
}

.flow-box-problem .flow-arrow svg {
  stroke: var(--pink-100);
}

.flow-box-solution .flow-arrow svg {
  stroke: var(--blue-100);
}

.flow-arrow-cost {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: var(--font-semibold);
}

.flow-box-problem .flow-arrow-cost {
  color: var(--pink-100);
}

.flow-box-solution .flow-arrow-cost {
  color: var(--blue-100);
}

.flow-box-bottom {
  margin-top: clamp(0.75rem, 1.5vw, 1.25rem);
  padding-top: 1rem;
  border-top: 1px solid var(--gray-08);
  text-align: center;
}

.flow-box-stat {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  margin-bottom: 0.25rem;
}

.flow-box-problem .flow-box-stat {
  color: var(--pink-100);
}

.flow-box-solution .flow-box-stat {
  color: var(--blue-100);
}

.flow-box-stat-label {
  font-size: var(--text-xs);
  color: var(--gray-50);
}

.flow-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}

.flow-stat {
  padding: 1.25rem;
}

.flow-stat-value {
  font-family: var(--font-mono);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--pink-100);
  margin-bottom: 0.25rem;
}

.flow-stat-label {
  font-size: var(--text-sm);
  color: var(--gray-50);
}


/* Responsive */

@media (max-width: 768px) {
  .flow-comparison-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .flow-stats {
    grid-template-columns: 1fr;
  }
}
/* Logos Bar Section
   ========================================================================== */

.logos-bar-section {
  padding: clamp(1.5rem, 3vw, 3rem) clamp(1rem, 4vw, 4rem);
  border-top: 1px solid var(--gray-08);
  border-bottom: 1px solid var(--gray-08);
  background: var(--white-100);
}

.logos-bar-label {
  text-align: center;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--gray-50);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.logos-bar-grid {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2.5rem;
  flex-wrap: wrap;
}

.logo-item {
  opacity: 0.6;
  transition: opacity var(--duration-fast) var(--easing);
}

.logo-item:hover {
  opacity: 0.9;
}

.logo-item img {
  max-height: 32px;
  width: auto;
}

.logo-text {
  color: var(--gray-50);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
}


/* Responsive */

@media (max-width: 640px) {
  .logos-bar-grid {
    gap: 1.5rem;
  }
}
/* Benefits Grid Section
   ========================================================================== */

.benefits-grid-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  border-top: 1px solid var(--gray-08);
}

.benefits-header {
  text-align: center;
  margin-bottom: clamp(1.5rem, 3vw, 3rem);
}

.benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  max-width: 1000px;
  margin: 0 auto;
}

.benefit-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  transition: all var(--duration-normal) var(--easing);
}

.benefit-card:hover {
  border-color: var(--blue-30);
  transform: translateY(-4px);
}

.benefit-card-featured {
  border-color: var(--blue-30);
  background: var(--gradient-card-accent);
}

.benefit-icon {
  width: 48px;
  height: 48px;
  background: var(--blue-10);
  border: 1px solid var(--blue-20);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: clamp(0.75rem, 1.5vw, 1.25rem);
}

.benefit-icon svg {
  width: 24px;
  height: 24px;
  color: var(--blue-100);
  stroke: var(--blue-100);
}

.benefit-card h3 {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  margin-bottom: clamp(0.25rem, 0.75vw, 0.5rem);
  color: var(--gray-100);
}

.benefit-value {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--blue-100);
  margin-bottom: 0.75rem;
}

.benefit-card p {
  color: var(--gray-50);
  font-size: var(--text-sm);
  line-height: var(--leading-lg);
}


/* Responsive */

@media (max-width: 1024px) {
  .benefits-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .benefit-card {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
    text-align: left;
    gap: var(--space-3);
  }

  .benefit-card .benefit-icon {
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .benefit-card h3 {
    flex: 1;
    margin-bottom: 0;
    align-self: center;
  }

  .benefit-value,
  .benefit-card p {
    width: 100%;
    margin-top: var(--space-2);
  }
}

@media (max-width: 768px) {
  .benefits-grid {
    grid-template-columns: 1fr;
  }
}
/* Eligibility Section
   ========================================================================== */

.eligibility-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
  border-top: 1px solid var(--gray-08);
}

.eligibility-content {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: clamp(2.5rem, 5vw, 4rem);
  align-items: start;
  max-width: 1000px;
  margin: 0 auto;
}

.eligibility-left .section-title {
  text-align: left;
}

.eligibility-left .section-desc {
  text-align: left;
  max-width: none;
}

.eligibility-right {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.eligibility-item {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.eligibility-check {
  width: 32px;
  height: 32px;
  background: var(--blue-15);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.eligibility-check svg {
  width: 16px;
  height: 16px;
  stroke: var(--blue-100);
}

.eligibility-text strong {
  display: block;
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  margin-bottom: 0.125rem;
  color: var(--gray-100);
}

.eligibility-text span {
  font-size: var(--text-sm);
  color: var(--gray-50);
}

/* Modal
   ========================================================================== */

.modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(8px);
  z-index: 1000;
  justify-content: center;
  align-items: center;
}

.modal.active {
  display: flex;
}

.modal-content {
  background: var(--gray-03);
  border: 1px solid var(--gray-15);
  border-radius: var(--radius-xl);
  padding: 3rem;
  max-width: 400px;
  text-align: center;
  animation: modalIn 0.3s var(--easing);
}

@keyframes modalIn {
  from {
    opacity: 0;
    transform: scale(0.95) translateY(10px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.modal-icon {
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.modal-icon svg {
  stroke: var(--blue-100);
}

.modal-content h3 {
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  margin-bottom: clamp(0.5rem, 1vw, 0.75rem);
  color: var(--gray-100);
}

.modal-content p {
  color: var(--gray-80);
  margin-bottom: 0.5rem;
  font-size: var(--text-base);
}

.modal-highlight {
  margin-top: clamp(0.75rem, 1.5vw, 1rem);
  padding: 0.875rem;
  background: var(--blue-10);
  border-radius: var(--radius-md);
  color: var(--gray-100);
  font-size: var(--text-sm);
}

.modal-highlight strong {
  color: var(--blue-100);
}

.modal-close-btn {
  margin-top: clamp(1rem, 2vw, 1.5rem);
}


/* Responsive */

@media (max-width: 768px) {
  .eligibility-content {
    grid-template-columns: 1fr;
  }

  .eligibility-left .section-title,
  .eligibility-left .section-desc {
    text-align: center;
  }
}

@media (max-width: 640px) {
  .modal-content {
    padding: 2rem 1.5rem;
    margin: 1rem;
  }
}
/* ==========================================================================
   Responsive for Credits Landing Sections
   ========================================================================== */

/* ==========================================================================
   Content Width Override
   ========================================================================== */

/* All grids use content max-width */
[class*='-grid'],
[class*='-cards'],
[class*='-header'] {
  max-width: var(--content-max-width);
  margin-left: auto;
  margin-right: auto;
}

/* ==========================================================================
   Legal Framework Section
   ========================================================================== */

.legal-section {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 6rem);
  background: linear-gradient(180deg, var(--white-100) 0%, var(--pink-05) 100%);
  position: relative;
  overflow: clip; /* Clips content without breaking position: sticky */
}

/* Vertical line spanning full section height */
.legal-section::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(
    180deg,
    transparent 0%,
    var(--pink-10) 15%,
    var(--pink-10) 85%,
    transparent 100%
  );
  transform: translateX(-50%);
}

.legal-layout {
  --layout-gap: 4rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--layout-gap);
  max-width: calc(var(--content-max-width) - var(--layout-gap));
  margin: 0 auto;
  align-items: start;
  position: relative;
}

.legal-layout__left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: sticky;
  top: 6rem;
  z-index: 1;
}

.legal-layout__left .section-tag {
  margin-bottom: 1rem;
}

.legal-layout__left .section-title {
  text-align: left;
  margin-bottom: 1.5rem;
}

.legal-layout__left .sovereign-questions {
  position: relative;
  min-height: 6em; /* Space for one question */
  margin-bottom: 0;
  align-self: stretch; /* Override flex-start from parent — take full width */
}

.legal-layout__left .sovereign-questions p {
  position: absolute;
  top: 0;
  left: 0;
  right: 0; /* Stretch to full width of parent */
  font-size: var(--text-5xl);
  font-weight: var(--font-medium);
  color: var(--pink-100);
  line-height: var(--leading-md);
  letter-spacing: var(--letter-spacing-snug);
  margin: 0;
  opacity: 0; /* Hidden by default, animated via JS */
}

/* First question visible by default (fallback if JS fails) */
.legal-layout__left .sovereign-questions p:first-child {
  opacity: 1;
}

/* Grid pattern with pink lines — animated dots added via JS */
/* Inside sticky container, positioned absolutely so doesn't affect parent height */
.legal-grid-dots {
  position: absolute;
  top: 380px;
  left: -20%;
  width: 140%;
  height: 320px;
  z-index: -1;
  pointer-events: none;
  background-image:
    /* Vertical lines */ linear-gradient(
      90deg,
      var(--pink-10) 1px,
      transparent 1px
    ),
    /* Horizontal lines */
      linear-gradient(0deg, var(--pink-10) 1px, transparent 1px);
  background-size: 30px 30px;
  background-position: 0 0;
  mask-image: radial-gradient(
    ellipse 60% 60% at center,
    rgba(0, 0, 0, 0.5) 0%,
    rgba(0, 0, 0, 0.3) 50%,
    transparent 75%
  );
  -webkit-mask-image: radial-gradient(
    ellipse 60% 60% at center,
    rgba(0, 0, 0, 0.5) 0%,
    rgba(0, 0, 0, 0.3) 50%,
    transparent 75%
  );
}

/* Animated dots on grid intersections */
.legal-grid-dots__dot {
  position: absolute;
  width: 4px;
  height: 4px;
  background: var(--pink-100);
  border-radius: 50%;
  opacity: 0;
  box-shadow: 0 0 6px var(--pink-50);
}

.legal-grid {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-top: clamp(1.5rem, 3vw, 3rem);
  position: relative;
}

.legal-card {
  background: var(--white-90);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  position: relative;
}

/* Glowing dot on timeline */
.legal-card::before {
  content: '';
  position: absolute;
  left: calc(var(--layout-gap) / -2);
  top: 1.5rem;
  width: 14px;
  height: 14px;
  background: var(--pink-100);
  border-radius: 50%;
  box-shadow: 0 0 12px var(--pink-40), 0 0 24px var(--pink-25);
  transform: translateX(-50%);
  z-index: 2;
}

/* Horizontal connector line */
.legal-card::after {
  content: '';
  position: absolute;
  left: calc(var(--layout-gap) / -2 + 7px);
  top: calc(1.5rem + 6px);
  width: calc(var(--layout-gap) / 2 - 7px);
  height: 2px;
  background: var(--pink-30);
  z-index: 1;
}

.legal-card__content {
  padding: 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.legal-card__quote {
  font-family: Georgia, serif;
  font-style: italic;
  font-size: var(--text-xl);
  color: var(--gray-100);
  margin-bottom: 1.5rem;
  line-height: var(--leading-md);
  flex: 1;
}

.legal-card__source {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: var(--leading-sm);
}

.legal-card__source img {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
}

.legal-card__source-text {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.legal-card__source-name {
  font-weight: var(--font-medium);
  color: var(--gray-100);
}

.legal-card__source-ref {
  color: var(--gray-80);
}

.legal-card__date {
  color: var(--gray-50);
  font-weight: var(--font-bold);
}

.legal-card__footer {
  padding: 1rem 1.5rem;
  font-size: var(--text-sm);
  line-height: var(--leading-md);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}

.legal-card__footer--warning {
  background: var(--gray-05);
  color: var(--gray-100);
}

.legal-card__footer--danger {
  background: var(--pink-15);
  color: var(--pink-100);
}

.legal-card__footer--critical {
  background: var(--pink-100);
  color: white;
}

/* Responsive Legal Section */

/* Responsive */

@media (max-width: 1024px) {
  .legal-layout {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

  .legal-layout__left {
    position: static;
  }

  /* Hide timeline and decorative grid on tablets */
  .legal-section::before,
  .legal-card::before,
  .legal-card::after,
  .legal-grid-dots {
    display: none;
  }
}

@media (max-width: 768px) {
  .legal-layout__left .sovereign-questions {
    min-height: 2.5em;
  }

  .legal-layout__left .sovereign-questions p {
    font-size: var(--text-xl);
  }
}
/* Hero v2 — centered layout variant
   ========================================================================== */

/* Centered layout modifier */
.hero--v2 {
  align-items: center;
  text-align: center;
}

.hero--v2 .hero-content {
  max-width: 1200px;
}

.hero--v2 .hero-sub {
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
  text-wrap: pretty;
}

.hero--v2 .hero-ctas {
  display: grid;
  grid-template-columns: 1fr 1fr;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.hero--v2 .hero-ctas .btn {
  justify-content: center;
}

/* Backed by bar */
.hero-backed {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(1.5rem, 3vw, 2.5rem);
  padding-top: clamp(1.5rem, 3vw, 2rem);
  border-top: 1px solid var(--white-15);
  margin-top: clamp(2rem, 4vw, 3rem);
  animation: fadeInUp 0.8s ease 0.4s forwards;
  opacity: 0;
}

.hero-backed__logos {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(1.5rem, 3vw, 2.5rem);
  flex-wrap: wrap;
}

.hero-backed__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--white-40);
  white-space: nowrap;
}

.hero-backed__logos img {
  height: 24px;
  width: auto;
  filter: brightness(0) invert(1);
  opacity: 1;
  transition: opacity var(--duration-fast) var(--easing);
}

.hero-backed__logos img[alt='BlackRock'] {
  height: 18px;
}

.hero-backed__logos img[alt='RTP Global'] {
  height: 30px;
}

.hero-backed__logos img:hover {
  opacity: 0.85;
}

.hero-backed__stats {
  display: flex;
  gap: clamp(2rem, 5vw, 4rem);
  border-left: 1px solid var(--white-15);
  padding-left: clamp(1.5rem, 3vw, 2.5rem);
}

.hero-backed__stat {
  display: flex;
  flex-direction: column;
}

.hero-backed__stat-val {
  font-family: var(--font-mono);
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--cyan-100);
}

.hero-backed__stat-label {
  font-size: var(--text-xs);
  color: var(--white-40);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
}

/* Two-tier headline */
.hero-lead {
  font-size: var(--text-6xl);
  font-weight: var(--font-medium);
  color: var(--white-60);
  line-height: var(--leading-md);
  text-wrap: balance;
  animation: fadeInUp 0.8s ease forwards;
  opacity: 0;
  margin-bottom: clamp(1rem, 1vw, 3rem);
}

.hero--v2 h1 {
  font-size: var(--text-9xl);
  text-wrap: balance;
  font-weight: var(--font-semibold);
  margin-bottom: clamp(2rem, 2vw, 4rem);
}

.hero-val--bad {
  color: var(--pink-100);
  display: inline-block;
}

.hero-val--good {
  color: var(--cyan-100);
  display: inline-block;
}

/* Sequential line animation */
.hero--v2 h1 {
  position: relative;
  min-height: calc(var(--text-9xl) * var(--leading-md));
}

.hero-line {
  display: block;
  opacity: 0;
  transition: none;
}

.hero-line--first {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
}

.hero-line--second {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
}

/* Accessibility: show both lines immediately for reduced motion */
@media (prefers-reduced-motion: reduce) {
  .hero-line {
    opacity: 1 !important;
    transition: none !important;
  }
  .hero-line--second {
    position: relative !important;
  }
}

.hero-sub__accent {
  color: var(--white-100);
}

.hero-note {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--white-40);
  letter-spacing: var(--letter-spacing-wide);
  margin-top: var(--space-4);
  animation: fadeInUp 0.8s ease 0.35s forwards;
  opacity: 0;
}


/* Responsive */

@media (max-width: 768px) {
  .hero-backed {
    flex-direction: column;
  }

  .hero-backed__stats {
    border-left: none;
    padding-left: 0;
    border-top: 1px solid var(--white-15);
    padding-top: clamp(1rem, 2vw, 1.5rem);
    justify-content: center;
  }
}
/* Sticky Bar
   ========================================================================== */

.sticky-bar {
  position: fixed;
  bottom: -5rem;
  left: 0;
  right: 0;
  z-index: var(--z-sticky);
  background: var(--white-90);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--gray-08);
  padding: var(--space-3) clamp(1.5rem, 4vw, 4rem);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(0.75rem, 1.5vw, 1.5rem);
  transition: bottom var(--duration-slow) var(--easing);
}

.sticky-bar--visible {
  bottom: 0;
}

.sticky-bar__text {
  font-size: clamp(0.75rem, 1.5vw, 0.875rem);
  color: var(--gray-60);
  font-family: var(--font-mono);
}

.sticky-bar__text strong {
  color: var(--pink-100);
  font-weight: var(--font-bold);
}

.sticky-bar__btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--blue-100);
  color: var(--white-100);
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-md);
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  text-decoration: none;
  white-space: nowrap;
  transition: all var(--duration-fast);
}

.sticky-bar__btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-glow-blue);
}
/* Provider Badges
   ========================================================================== */

.provider-badges {
  display: flex;
  justify-content: center;
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.provider-badges__badge {
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--white-100);
  border: 2px solid var(--white-100);
  border-radius: 50%;
  box-shadow: 0 0 0 1px var(--gray-08);
  margin-left: -8px;
  position: relative;
}

.provider-badges__badge:first-child {
  margin-left: 0;
}

.provider-badges__badge img {
  width: 18px;
  height: 18px;
}

.provider-badges__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--letter-spacing-widest);
  text-transform: uppercase;
  color: var(--gray-40);
  text-align: center;
  margin-top: var(--space-3);
}


/* Responsive */

@media (max-width: 1024px) {
  .provider-badges__badge:nth-child(n + 17) {
    display: none;
  }
}

@media (max-width: 768px) {
  .provider-badges__badge:nth-child(n + 13) {
    display: none;
  }
}

@media (max-width: 640px) {
  .provider-badges__badge:nth-child(n + 9) {
    display: none;
  }
}
/* Comparison Table
   ========================================================================== */

.comparison-table {
  max-width: var(--container-lg);
  margin: clamp(2rem, 4vw, 3rem) auto 0;
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.comparison-table table {
  width: 100%;
  border-collapse: collapse;
}

.comparison-table th,
.comparison-table td {
  padding: clamp(0.75rem, 1.5vw, 1.25rem) clamp(1rem, 2vw, 1.75rem);
  text-align: left;
  font-size: var(--text-sm);
  border-bottom: 1px solid var(--gray-06);
}

.comparison-table thead th {
  background: var(--gray-05);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--gray-50);
  font-weight: var(--font-medium);
}

.comparison-table thead th:last-child {
  color: var(--blue-100);
}

.comparison-table tbody tr {
  background: var(--white-100);
  transition: background var(--duration-fast) var(--easing);
}

.comparison-table tbody tr:hover {
  background: var(--blue-05);
}

.comparison-table tbody td {
  color: var(--gray-60);
}

.comparison-table tbody td:first-child {
  font-weight: var(--font-semibold);
  color: var(--gray-100);
}

.comparison-table tbody tr:last-child td {
  border-bottom: none;
}

.comparison-table .val-bad {
  color: var(--pink-100);
  font-weight: var(--font-semibold);
}

.comparison-table .val-good {
  color: var(--green-100);
  font-weight: var(--font-semibold);
}


/* Responsive */

@media (max-width: 768px) {
  .comparison-table th:nth-child(2),
  .comparison-table td:nth-child(2) {
    display: none;
  }
}
/* Icon Grid
   ========================================================================== */

.icon-grid {
  display: flex;
  justify-content: space-between;
  gap: clamp(1rem, 2vw, 1.5rem);
  max-width: var(--container-lg);
  margin: clamp(2rem, 4vw, 3rem) auto 0;
  padding: clamp(1rem, 2vw, 1.5rem) 0 0;
  border-top: 1px solid var(--gray-08);
  flex-wrap: nowrap;
}

.icon-grid__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-sm);
}

.icon-grid__icon {
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-base);
  flex-shrink: 0;
}

.icon-grid__icon--pink {
  background: var(--pink-10);
  color: var(--pink-100);
}

.icon-grid__icon--green {
  background: var(--green-10);
  color: var(--green-100);
}

.icon-grid__icon--blue {
  background: var(--blue-10);
  color: var(--blue-100);
}

.icon-grid__text {
  color: var(--gray-60);
  font-size: var(--text-sm);
}

.icon-grid__text strong {
  color: var(--gray-100);
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
}


/* Responsive */

@media (max-width: 900px) {
  .icon-grid {
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .icon-grid__item {
    flex: 0 0 calc(50% - 0.5rem);
  }
}

@media (max-width: 768px) {
  .icon-grid {
    flex-direction: column;
    align-items: flex-start;
  }
}
/* Case Study
   ========================================================================== */

.case-study {
  max-width: var(--container-lg);
  margin: clamp(2rem, 4vw, 3rem) auto 0;
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-xl);
  padding: clamp(2rem, 4vw, 4rem);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
}

.case-study__quote {
  font-size: var(--text-xl);
  font-weight: var(--font-medium);
  line-height: var(--leading-lg);
  color: var(--gray-80);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
  font-style: italic;
}

.case-study__quote em {
  font-style: normal;
  color: var(--blue-100);
  font-weight: var(--font-bold);
}

.case-study__author {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--gray-50);
}

.case-study__metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1rem, 2vw, 1.5rem);
}

.case-study__metric {
  padding: clamp(1rem, 2vw, 1.75rem);
  background: var(--white-100);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
}

.case-study__metric-val {
  font-weight: var(--font-extrabold);
  font-size: var(--text-7xl);
  line-height: var(--leading-xs);
  margin-bottom: var(--space-2);
}

.case-study__metric-val--green {
  color: var(--green-100);
}

.case-study__metric-val--blue {
  color: var(--blue-100);
}

.case-study__metric-label {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  color: var(--gray-50);
}


/* Responsive */

@media (max-width: 1024px) {
  .case-study {
    grid-template-columns: 1fr;
    gap: clamp(1.5rem, 3vw, 2rem);
  }
}

@media (max-width: 640px) {
  .case-study__metrics {
    grid-template-columns: 1fr;
  }
}
/* Testimonial
   ========================================================================== */

.testimonial-large {
  max-width: 800px;
  margin: 0 auto;
  padding: clamp(1rem, 3vw, 4rem) 0 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(1rem, 2vw, 1.5rem);
  align-items: start;
  letter-spacing: var(--letter-spacing-snug);
}

.testimonial-large__quote-mark {
  color: var(--gray-10);
}

.testimonial-large__text {
  font-size: var(--text-7xl);
  font-weight: var(--font-normal);
  color: var(--gray-100);
  line-height: var(--leading-md);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
  text-wrap: balance;
}

.testimonial-large__body {
  font-size: var(--text-base);
  color: var(--gray-60);
  line-height: var(--leading-lg);
  max-width: 640px;
  margin-bottom: var(--space-4);
  letter-spacing: var(--letter-spacing-normal);
}

.testimonial-large__author {
  font-size: var(--text-sm);
  color: var(--gray-50);
}


/* Responsive */

@media (max-width: 640px) {
  .testimonial-large {
    grid-template-columns: 1fr;
  }
}
/* Apply Form with Timeline
   ========================================================================== */

.apply-form {
  padding: clamp(3rem, 6vw, 8rem) clamp(1rem, 4vw, 4rem);
}

.apply-form__header {
  max-width: var(--container-lg);
  margin: 0 auto clamp(1.5rem, 3vw, 2rem);
}

.apply-form__header .section-title {
  text-align: left;
}

.apply-form__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 4vw, 3rem);
  max-width: var(--container-lg);
  margin: 0 auto;
  position: relative;
}

.apply-form__form {
  background: var(--white-100);
  border: 1px solid var(--green-10);
  border-radius: var(--radius-lg);
  padding: clamp(1.5rem, 3vw, 2rem);
}

.apply-form__sidebar {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: clamp(1.5rem, 3vw, 2rem);
}

.apply-form__sidebar .form-timeline {
  flex: 1;
}

.apply-form__sidebar .timeline__desc strong {
  color: var(--gray-100);
  font-weight: var(--font-semibold);
}

.apply-form__sidebar .form-timeline__title {
  padding-left: 0;
  margin-left: 28px;
  margin-bottom: var(--space-4);
}

/* Decorative grid (top right corner) */
.apply-form__grid-decoration {
  position: absolute;
  top: 0;
  right: 0;
  width: 400px;
  height: 400px;
  pointer-events: none;
  overflow: hidden;
}

/* Grid pattern */
.apply-form .form-grid {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 300px;
  background-image:
    /* Vertical lines */
    linear-gradient(90deg, var(--gray-10) 1px, transparent 1px),
    /* Horizontal lines */
    linear-gradient(0deg, var(--gray-10) 1px, transparent 1px);
  background-size: 30px 30px;
  background-position: 0 0;
}

/* Animated dots on grid intersections */
.apply-form .form-grid__dot {
  position: absolute;
  width: 4px;
  height: 4px;
  background: var(--green-100);
  border-radius: 50%;
  opacity: 0;
  box-shadow: 0 0 6px var(--green-50);
}


/* Responsive */

@media (max-width: 1024px) {
  .apply-form__grid-decoration {
    display: none;
  }
}

@media (max-width: 768px) {
  .apply-form__grid {
    grid-template-columns: 1fr;
  }

  /* Минимальный отступ между формой и таймлайном на мобильных */
  .apply-form__sidebar {
    margin-top: 0.5rem !important;
  }
}
/* Dashboard Mockup
   ========================================================================== */

.dashboard-mockup {
  max-width: var(--container-lg);
  margin: clamp(2rem, 4vw, 3rem) auto 0;
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-glow-blue);
}

.dashboard-mockup__topbar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  background: var(--gray-05);
  border-bottom: 1px solid var(--gray-08);
}

.dashboard-mockup__dot {
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 50%;
}

.dashboard-mockup__dot--r {
  background: var(--macos-close);
}
.dashboard-mockup__dot--y {
  background: var(--macos-minimize);
}
.dashboard-mockup__dot--g {
  background: var(--macos-maximize);
}

.dashboard-mockup__url {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--gray-50);
  background: var(--gray-03);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  flex: 1;
  text-align: center;
}

.dashboard-mockup__body {
  display: grid;
  grid-template-columns: 12.5rem 1fr;
  min-height: 25rem;
}

.dashboard-mockup__sidebar {
  background: var(--gray-05);
  border-right: 1px solid var(--gray-08);
  padding: var(--space-5) 0;
}

.dashboard-mockup__sidebar-item {
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-sm);
  color: var(--gray-50);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.dashboard-mockup__sidebar-item--active {
  color: var(--blue-100);
  background: var(--blue-05);
  border-right: 2px solid var(--blue-100);
}

.dashboard-mockup__content {
  padding: var(--space-5);
}

.dashboard-mockup__content-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-5);
}

.dashboard-mockup__content-title {
  font-weight: var(--font-bold);
  font-size: var(--text-lg);
  color: var(--gray-100);
}

.dashboard-mockup__content-badge {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--blue-100);
  background: var(--blue-05);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
}

.dashboard-mockup__table {
  width: 100%;
  border-collapse: collapse;
}

.dashboard-mockup__table th {
  text-align: left;
  padding: var(--space-2) var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--gray-50);
  letter-spacing: var(--letter-spacing-wider);
  text-transform: uppercase;
  border-bottom: 1px solid var(--gray-08);
}

.dashboard-mockup__table td {
  padding: var(--space-3);
  font-size: var(--text-sm);
  color: var(--gray-80);
  border-bottom: 1px solid var(--gray-06);
}

.dashboard-mockup__provider {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: var(--font-medium);
}

.dashboard-mockup__provider-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
}

.dashboard-mockup__provider-dot--azure {
  background: var(--brand-azure);
}
.dashboard-mockup__provider-dot--gcp {
  background: var(--brand-google);
}
.dashboard-mockup__provider-dot--aws {
  background: var(--brand-aws);
}
.dashboard-mockup__provider-dot--gpu {
  background: var(--brand-purple);
}

.dashboard-mockup__margin {
  font-family: var(--font-mono);
  color: var(--green-100);
  font-weight: var(--font-bold);
}

.dashboard-mockup__spend {
  font-family: var(--font-mono);
  color: var(--gray-100);
}

.dashboard-mockup__note {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--gray-40);
  text-align: center;
  margin-top: var(--space-3);
}


/* Responsive */

@media (max-width: 1024px) {
  .dashboard-mockup__body {
    grid-template-columns: 1fr;
  }

  .dashboard-mockup__sidebar {
    display: none;
  }
}

@media (max-width: 640px) {
  .dashboard-mockup {
    border-radius: var(--radius-lg);
  }
}
