/* ==========================================================================
   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)
   ========================================================================== */

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

.header__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1400px;
  margin: 0 auto;
}

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

.header__logo img {
  height: 28px;
  width: auto;
  transition: opacity var(--duration-fast) var(--easing);
}

.header__logo-light {
  display: block;
}

.header__logo-dark {
  display: none;
}

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

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

.header__nav a:hover {
  color: #fff;
}

/* CTA Buttons */
.header__cta {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}

.header__btn {
  padding: 0.625rem 1.25rem;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--duration-fast) var(--easing);
}

.header__btn--outline {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: #fff;
}

.header__btn--outline:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.5);
}

.header__btn--primary {
  background: #fff;
  border: 1px solid #fff;
  color: var(--gray-100);
}

.header__btn--primary:hover {
  background: rgba(255, 255, 255, 0.9);
}

/* Burger (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: #fff;
  border-radius: 2px;
  transition: all var(--duration-fast) var(--easing);
}

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

/* Scrolled state - fixed with blur background */
.header--scrolled {
  position: fixed;
  background: rgba(255, 255, 255, 0.85);
  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);
}

.header--scrolled .header__btn--outline {
  background: transparent;
  border-color: var(--gray-15);
  color: var(--gray-100);
}

.header--scrolled .header__btn--outline:hover {
  background: var(--gray-06);
  border-color: var(--gray-25);
}

.header--scrolled .header__btn--primary {
  background: var(--blue-100);
  border-color: var(--blue-100);
  color: #fff;
}

.header--scrolled .header__btn--primary:hover {
  background: var(--violet-100);
  border-color: var(--violet-100);
}

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

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

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

/* Mobile menu overlay */
.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;
}

.header__mobile-cta .header__btn--outline {
  background: transparent;
  border-color: var(--gray-15);
  color: var(--gray-100);
}

.header__mobile-cta .header__btn--primary {
  background: var(--blue-100);
  border-color: var(--blue-100);
  color: #fff;
}

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

/* 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-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: 0.75rem;
}

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

.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);
}

/* Section CTA */
.section-cta {
  margin-top: 2.5rem;
  text-align: center;
}

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

/* Hero Section
   ========================================================================== */

.hero {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: calc(var(--space-16) + 72px) var(--space-10) 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: 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: 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: 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: 2rem;
  border-top: 1px solid var(--white-20);
  margin-top: 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 */

/* 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: var(--space-6);
  margin-top: 4rem;
}

.problem-card {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  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: 1rem;
}

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

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

/* Solution Section
   ========================================================================== */

.solution-section {
  padding: var(--space-16) var(--space-12);
}

.solution-section .section-container {
  padding: var(--space-8);
  background: linear-gradient(180deg, var(--green-05) 0%, var(--green-10) 100%);
  border-radius: var(--radius-xl);
}

.solution-card {
  display: flex;
  flex-direction: column;
  background: var(--white-30);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  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 {
  color: var(--gray-100);
  margin-bottom: 0.75rem;
  font-weight: var(--font-semibold);
}

.solution-cta {
  display: flex;
  justify-content: center;
  margin-top: var(--space-8);
}

/* Company Section
   ========================================================================== */

.company-section {
  padding: var(--space-16) var(--space-12) 0;
}

.company-section .section-container {
  padding: var(--space-8);
  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: var(--space-10);
}

.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);
}

.company-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-10);
}

.company-card {
  display: block;
  background: var(--white-30);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  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: 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: 1rem;
  color: var(--blue-100);
}

.company-highlight {
  display: inline-block;
  margin-top: var(--space-4);
  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: var(--space-6) 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: var(--space-4);
}

.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: var(--space-8);
}

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

/* 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: 4rem;
  border: 1px solid var(--gray-08);
}

.feature {
  background: var(--gray-03);
  padding: var(--space-8);
  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: 1.5rem;
  font-size: var(--text-4xl);
}

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

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

/* Platform Section
   ========================================================================== */

.platform-section {
  padding: var(--space-16) var(--space-10);
  background: var(--gradient-section-up);
}

.platform-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  max-width: 1100px;
  margin: 3rem auto 0;
}

.platform-card {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  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: 1.5rem;
}

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

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

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

/* 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: 4rem;
}

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

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

.comparison-table {
  margin-top: 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: 2rem auto 0;
  text-align: center;
  color: var(--gray-50);
  font-size: var(--text-base);
  font-style: italic;
}

/* CTA Section
   ========================================================================== */

.cta-section {
  background: var(--gradient-section-up);
  text-align: center;
  padding: 10rem 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: 1.5rem;
}

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

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

/* AI Section
   ========================================================================== */

.ai-section {
  padding: var(--space-16) var(--space-10);
  background: var(--gradient-section-down);
}

.ai-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-top: 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: var(--space-6);
  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: 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: 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);
}

/* K8s Section
   ========================================================================== */

.k8s-section {
  padding: var(--space-16) var(--space-10);
  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: 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: var(--space-6);
}

.k8s-control {
  text-align: center;
  margin-bottom: 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: 1rem 0;
}

.k8s-workers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-bottom: 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: 0.75rem;
  color: var(--gray-100);
}

.worker-gpus {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  justify-content: center;
  margin-bottom: 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;
}

/* Network Section
   ========================================================================== */

.network-section {
  padding: var(--space-16) var(--space-10);
  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: 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: 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);
}

/* Developer Section
   ========================================================================== */

.dev-section {
  padding: var(--space-16) var(--space-10);
  background: var(--gray-03);
}

.dev-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
  margin-top: 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: var(--space-5);
  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: 1rem;
}

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

.dev-card p {
  color: var(--gray-80);
  font-size: var(--text-sm);
  margin-bottom: 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;
}

/* Trust Section
   ========================================================================== */

.trust-section {
  padding: 6rem 4rem;
  background: var(--white-100);
  text-align: center;
}

.trust-badges {
  display: flex;
  justify-content: center;
  gap: var(--space-6);
  margin-top: 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: 2rem;
  color: var(--gray-50);
  font-size: var(--text-base);
}

.operational-proof {
  margin-top: 4rem;
  padding-top: 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: 2rem;
  text-align: center;
}

.proof-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

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

.proof-icon {
  display: block;
  margin-bottom: 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: 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;
}

/* ICP Section
   ========================================================================== */

.icp-section {
  padding: var(--space-16) var(--space-10);
  background: var(--white-100);
}

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

.icp-card {
  padding: var(--space-6);
  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: 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: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--gray-08);
  color: var(--gray-50);
  font-size: var(--text-base);
  font-style: italic;
}

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

.pricing-section {
  padding: var(--space-16) var(--space-10);
  background: var(--gradient-section-down);
}

.pricing-card {
  max-width: 700px;
  margin: 3rem auto 0;
  background: var(--gray-03);
  border: 2px solid var(--blue-100);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  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);
}

/* Why Section
   ========================================================================== */

.why-section {
  padding: 6rem 4rem;
  background: var(--white-100);
}

.why-grid {
  max-width: 1000px;
  margin: 3rem auto 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}

.why-card {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
}

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

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

/* Objections Section
   ========================================================================== */

.objections-section {
  padding: var(--space-16) var(--space-10);
  background: var(--gray-03);
}

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

.objection-item {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}

.objection-item h4 {
  font-size: var(--text-lg);
  color: var(--gray-100);
  margin-bottom: 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 */

/* ==========================================================================
   Calculator Section
   ========================================================================== */

.calculator-section {
  padding: var(--space-16) var(--space-10);
  background: var(--gradient-section-down);
}

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

.calculator-header {
  text-align: center;
  margin-bottom: 3rem;
}

.calculator-card {
  background: var(--gray-03);
  border: 1px solid var(--gray-08);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  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: var(--space-6);
}

.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: var(--space-8);
  padding-top: var(--space-8);
  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: var(--space-6);
  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: var(--space-6);
}

.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: var(--space-4);
  font-weight: var(--font-medium);
}

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

/* Calculator Responsive */

/* ==========================================================================
   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: var(--space-16) var(--space-10);
  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: 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: 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);
}

/* 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: var(--space-16) var(--space-10);
  background: var(--white-100);
  border-top: 1px solid var(--gray-08);
}

.pricing-cards-header {
  text-align: center;
  margin-bottom: 3rem;
}

.pricing-hero-card {
  max-width: 600px;
  margin: 0 auto 3rem;
  padding: 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: 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: 2rem;
}

.pricing-hero-features {
  display: flex;
  justify-content: center;
  gap: 2rem;
  margin-bottom: 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: 1.5rem;
  font-size: var(--text-sm);
  color: var(--gray-50);
}

.pricing-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 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: 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: 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);
}

/* Usecases Section
   ========================================================================== */

.usecases-section {
  padding: 0 var(--space-12) var(--space-16);
  background: transparent;
}

.usecases-header {
  text-align: center;
  margin-bottom: var(--space-10);
}

/* Usecase Item (zigzag layout) */
.usecase-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  margin-bottom: var(--space-14);
}

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

.usecase-image {
  flex: 1;
}

.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: var(--space-6);
}

/* Comparison columns */
.usecase-comparison {
  display: flex;
  gap: var(--space-6);
  margin-top: var(--space-5);
  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 */

/* Promo Box Section
   ========================================================================== */

.promo-box-section {
  padding: var(--space-16) var(--space-10);
  background: var(--white-100);
  border-top: 1px solid var(--gray-08);
}

.promo-box {
  max-width: 700px;
  margin: 0 auto;
  text-align: center;
  padding: 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: 0.75rem;
}

.promo-title {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  margin-bottom: 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 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: 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);
}

/* Form Section
   ========================================================================== */

.form-section {
  padding: var(--space-16) var(--space-10);
  background: var(--white-100);
}

.form-header {
  text-align: center;
  margin-bottom: var(--space-8);
  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: 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);
}

/* Steps Section
   ========================================================================== */

.steps-section {
  padding: var(--space-10) var(--space-10);
}

.steps-header {
  text-align: center;
  margin-bottom: 2.5rem;
}

.steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  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: 2rem;
}

/* Solution Grid (extended)
   ========================================================================== */

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

.solution-header {
  text-align: center;
  margin-bottom: 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 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 h3 {
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  margin-bottom: 0.5rem;
  text-align: center;
}

.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;
}

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

/* ==========================================================================
   Responsive for New Sections
   ========================================================================== */

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

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

.gpu-catalog-section {
  padding: var(--space-16) var(--space-12);
  background: var(--gray-03);
}

.gpu-catalog-header {
  text-align: center;
  margin-bottom: 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: 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: 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: 0.375rem;
  color: var(--gray-100);
}

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

.gpu-use {
  font-size: var(--text-sm);
  color: var(--gray-50);
  margin-bottom: 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: 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: var(--space-6);
}

.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: var(--space-10);
}

/* Flow Comparison Section
   ========================================================================== */

.flow-comparison-section {
  padding: var(--space-16) var(--space-10);
  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: 4rem;
}

.flow-comparison-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  max-width: 900px;
  margin: 0 auto 3rem;
}

.flow-box {
  padding: 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: 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: 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);
}

/* Logos Bar Section
   ========================================================================== */

.logos-bar-section {
  padding: 3rem var(--space-10);
  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: 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);
}

/* Benefits Grid Section
   ========================================================================== */

.benefits-grid-section {
  padding: var(--space-16) var(--space-10);
  border-top: 1px solid var(--gray-08);
}

.benefits-header {
  text-align: center;
  margin-bottom: 3rem;
}

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

.benefit-card {
  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: 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: 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);
}

/* Eligibility Section
   ========================================================================== */

.eligibility-section {
  padding: var(--space-16) var(--space-10);
  border-top: 1px solid var(--gray-08);
}

.eligibility-content {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 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: 1.5rem;
}

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

.modal-content h3 {
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  margin-bottom: 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: 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: 1.5rem;
}

/* ==========================================================================
   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: var(--space-16) var(--space-12);
  padding-bottom: 8rem;
  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: 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 */

/* ==========================================================================
   Unified Section Padding (≤1300px)
   Applies to all sections except Hero
   ========================================================================== */

/* ==========================================================================
   RESPONSIVE — Wide screens (max-width: 1280px)
   ========================================================================== */

@media (max-width: 1280px) {
  /* Originally: max-width: 1200px */
  .company-grid {
    grid-template-columns: 1fr;
  }

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

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

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

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

  /* 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);
  }

  /* Originally: max-width: 1300px */
  .legal-section,
  .solution-section,
  .company-section,
  .usecases-section,
  .gpu-catalog-section,
  .logos-bar-section,
  .trust-section,
  .form-section,
  .problem-section,
  .features-section,
  .platform-section,
  .code-section,
  .comparison-section,
  .cta-section,
  .ai-section,
  .k8s-section,
  .network-section,
  .dev-section,
  .icp-section,
  .pricing-section,
  .why-section,
  .objections-section,
  .calculator-section,
  .comparison-vs-section,
  .mini-cta-section,
  .pricing-cards-section,
  .promo-box-section,
  .steps-section,
  .flow-comparison-section,
  .benefits-grid-section,
  .eligibility-section {
    padding: var(--space-8) var(--space-6);
  }
}

/* ==========================================================================
   RESPONSIVE — Desktop/Laptop (max-width: 1024px)
   ========================================================================== */

@media (max-width: 1024px) {
  .hero-hud {
    width: 40%;
    opacity: 0.5;
  }

  .hero-hud__nodes,
  .hero-hud__routes,
  .hero-hud__label {
    display: none;
  }

  /* Originally: max-width: 1100px */
  .usecase-item {
    margin-bottom: var(--space-11);
  }

  .hero {
    padding: calc(4rem + 60px) 2rem 4rem;
  }

  .hero-logo {
    left: 2rem;
  }

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

  .code-container {
    grid-template-columns: 1fr;
  }

  .comparison-row {
    grid-template-columns: 2fr 1fr 1fr;
  }

  .comparison-cell:nth-child(4),
  .comparison-cell:nth-child(5) {
    display: none;
  }

  .stats-bar {
    flex-wrap: wrap;
    gap: var(--space-6);
  }

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

  .k8s-container {
    grid-template-columns: 1fr;
  }

  .k8s-workers {
    grid-template-columns: 1fr;
  }

  .network-container {
    grid-template-columns: 1fr;
  }

  .dev-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .why-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .host-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .platform-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Originally: max-width: 900px */
  .hero-ctas {
    flex-direction: column;
    align-items: stretch;
  }

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

  /* 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%
    );
  }

  /* Originally: max-width: 1000px */
  .solution-grid {
    grid-template-columns: 1fr;
    max-width: 100%;
  }

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

  .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);
  }

  /* 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);
  }

  /* Originally: max-width: 900px */
  .benefits-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .legal-section {
    padding: var(--space-16) var(--space-6);
  }

  .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;
  }
}

/* ==========================================================================
   RESPONSIVE — Tablet (max-width: 768px)
   ========================================================================== */

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

  .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-hud {
    display: none;
  }

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

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

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

  .company-section .section-container {
    padding: var(--space-8) 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;
  }

  .proof-grid {
    grid-template-columns: 1fr;
    gap: var(--space-5);
  }

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

  .calculator-section {
    padding: var(--space-10) var(--space-5);
  }

  .calculator-card {
    padding: var(--space-5);
  }

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

  .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;
  }

  .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);
  }

  .pain-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .pricing-cards-grid {
    grid-template-columns: 1fr;
  }

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

  .steps-grid {
    grid-template-columns: repeat(2, 1fr);
  }

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

  .form-row {
    grid-template-columns: 1fr;
  }

  .promo-features {
    flex-direction: column;
    gap: 0.75rem;
  }

  .gpu-catalog-footer {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .flow-comparison-grid {
    grid-template-columns: 1fr;
  }

  .eligibility-content {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }

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

  .legal-layout__left .sovereign-questions {
    min-height: 2.5em;
  }

  .legal-layout__left .sovereign-questions p {
    font-size: var(--text-xl);
  }
}

/* min-width queries for 768px */
@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);
  }
}

/* ==========================================================================
   RESPONSIVE — Mobile (max-width: 640px)
   ========================================================================== */

@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%
    );
  }

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

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

  .network-stats {
    flex-direction: column;
    gap: var(--space-4);
  }

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

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

  .egress-compare {
    flex-direction: column;
  }

  .price {
    font-size: var(--text-display-sm);
  }

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

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

  /* Originally: max-width: 600px */
  .gpu-catalog-grid {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  /* Originally: max-width: 600px */
  .benefits-grid {
    grid-template-columns: 1fr;
  }

  .flow-stats {
    grid-template-columns: 1fr;
  }

  .logos-bar-grid {
    gap: 1.5rem;
  }

  .modal-content {
    padding: 2rem 1.5rem;
    margin: 1rem;
  }
}
