/* ========================================
   VARIABLES - Design Tokens & Color System
   oto Website - Soft Neobrutalist Redesign
   ======================================== */

:root {
  /* Base Colors (Warm Neutrals - matches app) */
  --color-bg:           #F5F3F1;
  --color-surface:      #FEFCF9;
  --color-surface-alt:  #EEE9E3;
  --color-text-primary: #2A2A2A;
  --color-text-secondary: rgba(42,42,42,0.65);
  --color-text-tertiary: rgba(42,42,42,0.4);

  /* Primary Accents (Soft & Muted) */
  --color-blue:         #8CAAC8;  /* Matches app primary */
  --color-blue-light:   #A8BDD4;
  --color-coral:        #D28C82;
  --color-coral-light:  #E4A89F;
  --color-mint:         #9BC4B5;
  --color-lavender:     #B8A8C8;
  --color-peach:        #E8B89A;

  /* Semantic */
  --color-primary:      var(--color-blue);
  --color-secondary:    var(--color-coral);
  --color-success:      var(--color-mint);
  --color-attention:    var(--color-peach);

  /* Borders (Chunky but Soft) */
  --border-width:       2px;
  --border-width-thick: 3px;
  --border-blue:        2px solid rgba(140,170,200,0.4);
  --border-blue-thick:  3px solid rgba(140,170,200,0.5);
  --border-coral:       2px solid rgba(210,140,130,0.4);
  --border-neutral:     2px solid rgba(42,42,42,0.1);

  /* Shadows (Soft Colored Offset) */
  --shadow-blue:        0 4px 0 0 rgba(140,170,200,0.3);
  --shadow-blue-hover:  0 8px 0 0 rgba(140,170,200,0.35);
  --shadow-coral:       0 4px 0 0 rgba(210,140,130,0.3);
  --shadow-coral-hover: 0 8px 0 0 rgba(210,140,130,0.35);
  --shadow-mint:        0 4px 0 0 rgba(155,196,181,0.3);
  --shadow-neutral:     0 4px 0 0 rgba(42,42,42,0.08);
  --shadow-neutral-hover: 0 8px 0 0 rgba(42,42,42,0.12);

  /* Mixed shadow for depth */
  --shadow-mixed-blue:  0 0 0 2px rgba(140,170,200,0.2),
                        0 4px 0 0 rgba(140,170,200,0.25),
                        0 4px 12px 0 rgba(140,170,200,0.1);

  /* Radius (Friendly Native) */
  --radius-sm:          8px;
  --radius-md:          10px;
  --radius-lg:          12px;
  --radius-xl:          14px;
  --radius-2xl:         16px;

  /* Spacing (8px Grid) */
  --space-1:  8px;
  --space-2:  16px;
  --space-3:  24px;
  --space-4:  32px;
  --space-5:  40px;
  --space-6:  48px;
  --space-8:  64px;
  --space-10: 80px;
  --space-12: 96px;
  --space-16: 128px;
  --site-header-height: calc(var(--space-3) * 2 + 32px);

  /* Typography */
  --font-primary: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Helvetica Neue", sans-serif;
  --font-heading: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Helvetica Neue", sans-serif;
  --font-mono:    "SF Mono", Monaco, "Cascadia Code", monospace;

  /* Animations (Smooth Apple-like) */
  --ease-smooth: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-bounce: cubic-bezier(0.34, 1.26, 0.64, 1);
  --duration-fast: 150ms;
  --duration-medium: 300ms;
  --duration-slow: 400ms;
}

@media (prefers-color-scheme: dark) {
  :root {
    /* Warm dark palette */
    --color-bg:           #2A2826;
    --color-surface:      #36322E;
    --color-surface-alt:  #1F1D1B;
    --color-text-primary: #F5F3F0;
    --color-text-secondary: rgba(245,243,240,0.65);
    --color-text-tertiary: rgba(245,243,240,0.4);

    /* Lighter accents for visibility */
    --color-blue:         #A8BDD4;
    --color-blue-light:   #C0D4E8;
    --color-coral:        #E4A89F;
    --color-coral-light:  #F0C4BA;
    --color-mint:         #B5D9CC;
    --color-lavender:     #C8B8D4;
    --color-peach:        #F5CAB0;

    /* Adjusted borders for dark mode */
    --border-blue:        2px solid rgba(168,189,212,0.4);
    --border-blue-thick:  3px solid rgba(168,189,212,0.5);
    --border-neutral:     2px solid rgba(245,243,240,0.15);

    /* Adjusted shadows */
    --shadow-blue:        0 4px 0 0 rgba(168,189,212,0.25);
    --shadow-blue-hover:  0 8px 0 0 rgba(168,189,212,0.3);
    --shadow-mixed-blue:  0 0 0 2px rgba(168,189,212,0.2),
                          0 4px 0 0 rgba(168,189,212,0.25),
                          0 4px 12px 0 rgba(168,189,212,0.1);
  }
}

/* ========================================
   RESET & BASE STYLES
   ======================================== */

* {
  box-sizing: border-box;
}

html {
  font-family: var(--font-primary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-text-primary);
  font-family: var(--font-primary);
  font-size: 17px; /* Matches app */
  line-height: 1.5;
  font-weight: 400;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
  position: relative;
}

a:focus-visible {
  outline: 3px solid rgba(140,170,200,0.5);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ========================================
   TYPOGRAPHY
   ======================================== */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: 1.2;
  margin: 0;
  letter-spacing: -0.01em;
}

h1 {
  font-size: clamp(1.75rem, 4vw, 3rem);
}

h2 {
  font-size: clamp(1.5rem, 3.5vw, 2.25rem);
}

h3 {
  font-size: 1.25rem;
}

.hero__title {
  font-family: var(--font-heading);
  font-size: clamp(2.5rem, 7vw, 5.5rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin: 0 0 var(--space-3);
  color: var(--color-text-primary);
}

.hero__lead {
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.5;
  max-width: 600px;
  margin: 0 auto var(--space-6);
  text-align: center;
  color: var(--color-text-secondary);
}

.section__header h2 {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3.5vw, 2.25rem);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.section__lead {
  font-size: 1.0625rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--color-text-secondary);
}

/* ========================================
   NAVIGATION
   ======================================== */

.skip-link {
  position: absolute;
  left: -999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.skip-link:focus {
  left: 16px;
  top: 16px;
  width: auto;
  height: auto;
  background: var(--color-text-primary);
  color: var(--color-bg);
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  z-index: 1000;
}

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  background: rgba(238,233,227,0.95);
  border-bottom: var(--border-blue);
  z-index: 200;
  box-shadow: 0 2px 0 0 rgba(140,170,200,0.15);
  backdrop-filter: blur(20px) saturate(180%);
}

@media (prefers-color-scheme: dark) {
  .site-header {
    background: rgba(42,40,38,0.95);
  }
}

.nav {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-6);
}

.nav__brand {
  margin-right: auto;
}

.nav__brand .logo-link {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
}

.nav__brand .logo-icon {
  width: auto;
  height: 36px;
  flex-shrink: 0;
}

.nav__brand .logo-text {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-text-primary);
}

.nav__list {
  list-style: none;
  display: flex;
  gap: var(--space-4);
  margin: 0;
  padding: 0;
}

.nav__list a {
  font-size: 0.9375rem;
  font-weight: 500;
  padding: var(--space-1) var(--space-2);
  color: var(--color-text-primary);
  border-radius: var(--radius-sm);
  border: 2px solid transparent;
  transition: all var(--duration-medium) var(--ease-smooth);
}

.nav__list a:hover {
  border-color: rgba(140,170,200,0.3);
  background: rgba(140,170,200,0.1);
  transform: translateY(-1px);
}

.nav__list a.active {
  border-color: var(--color-blue);
  background: rgba(140,170,200,0.15);
  color: var(--color-blue);
}

.nav__cta {
  font-size: 0.9375rem;
  font-weight: 600;
  padding: var(--space-2) var(--space-3);
  background: transparent;
  color: #000;
  border: 1px solid var(--color-text);
  border-radius: var(--radius-md);
  transition: all var(--duration-fast) var(--ease-smooth);
}

.nav__cta:hover {
  background: var(--color-blue);
  color: #fff;
  border-color: var(--color-blue);
  transform: translateY(-1px);
}

.nav__toggle {
  display: none;
  background: none;
  border: var(--border-neutral);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-md);
  font: inherit;
  color: inherit;
  cursor: pointer;
}

@media (max-width: 760px) {
  .nav__toggle {
    display: block;
  }

  .nav__list {
    position: absolute;
    top: 100%;
    right: 0;
    background: var(--color-surface);
    flex-direction: column;
    padding: var(--space-4);
    box-shadow: var(--shadow-mixed-blue);
    border: var(--border-blue);
    border-radius: var(--radius-lg);
    transform: translateY(-8px);
    opacity: 0;
    pointer-events: none;
    transition: all var(--duration-medium) var(--ease-smooth);
  }

  .nav__list[data-open="true"] {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }

  .nav__cta {
    font-size: 0.875rem;
    padding: var(--space-1) var(--space-2);
    margin-right: var(--space-2);
  }
}

/* ========================================
   LAYOUT & SECTIONS
   ======================================== */

main {
  overflow-x: visible;
  padding-top: var(--site-header-height);
}

section[id] {
  scroll-margin-top: calc(var(--site-header-height) + var(--space-2));
}

.section {
  max-width: 100%;
  margin: 0;
  padding: var(--space-12) var(--space-6);
  background: var(--color-bg);
  border-top: 2px solid rgba(42,42,42,0.06);
}

.section--alt {
  background: var(--color-bg);
  border-top: var(--border-blue);
  border-bottom: var(--border-blue);
  position: relative;
}

/* Optional: Soft gradient accent stripe */
.section--alt::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg,
    rgba(140,170,200,0.5),
    rgba(184,168,200,0.5),
    rgba(210,140,130,0.5),
    rgba(155,196,181,0.5)
  );
  opacity: 0.5;
}

.section__header {
  max-width: 1200px;
  margin: 0 auto var(--space-8);
  text-align: center;
}

.section__header h2 {
  position: relative;
  display: inline-block;
  padding-bottom: var(--space-2);
}

/* Optional: Soft underline on headers */
.section__header h2::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--color-coral);
  border-radius: 2px;
  opacity: 0.5;
}

.section__lead {
  font-size: 1.0625rem;
  line-height: 1.5;
  color: var(--color-text-secondary);
  max-width: 640px;
  margin: var(--space-3) auto 0;
}

/* ========================================
   HERO SECTION
   ======================================== */

.hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  max-width: 1400px;
  margin: 0 auto;
  padding: var(--space-12) var(--space-6);
  background: var(--color-bg);
}

@media (min-width: 960px) {
  .hero {
    grid-template-columns: 1.2fr 1fr;
    gap: var(--space-12);
  }
}

.hero.centered {
  text-align: center;
  grid-template-columns: 1fr;
  justify-items: center;
  padding-top: var(--space-12);
  padding-bottom: var(--space-8);
  gap: var(--space-4);
  place-content: start center;
  max-width: min(1100px, 88vw);
  margin: 0 auto;
}

.hero__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: visible;
  position: relative;
  max-width: clamp(560px, 70vw, 780px);
  margin-inline: auto;
}

.hero__title {
  margin: 0 0 var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.hero-line {
  display: block;
  line-height: 1.08;
}

.hero__transformation {
  font-size: 1.2rem;
  font-weight: 500;
  max-width: 36rem;
  margin: var(--space-2) auto var(--space-4);
  color: var(--color-text-primary);
  line-height: 1.5;
}

.hero__actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-bottom: var(--space-4);
  justify-content: center;
}

/* Trust line with soft indicator */
.trust-line {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-size: 0.9375rem;
  color: var(--color-text-secondary);
  margin-top: var(--space-1);
  margin-bottom: var(--space-2);
}

.trust-line::before {
  content: "✓";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  background: var(--color-mint);
  color: white;
  border-radius: 50%;
  font-weight: 700;
  font-size: 0.75rem;
}

/* Hero visual with soft blue border */
.hero__visual {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: auto;
  width: 100%;
  max-width: min(980px, 88vw);
  margin: 0 auto;
}

/* ========================================
   BUTTONS
   ======================================== */

.warm-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding: var(--space-2) var(--space-5);
  border: 2px solid currentColor;
  border-radius: var(--radius-md);
  background: var(--color-bg);
  color: var(--color-text-primary);
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 4px 0 0 currentColor;
  transition: transform var(--duration-fast) var(--ease-smooth),
              box-shadow var(--duration-fast) var(--ease-smooth);
}

.warm-button.primary {
  background: var(--color-blue);
  color: #FFFFFF;
  border-color: var(--color-blue);
  box-shadow: var(--shadow-blue);
}

.warm-button.primary:hover {
  background: var(--color-blue-light);
  border-color: var(--color-blue-light);
  transform: translateY(-2px);
  box-shadow: 0 6px 0 0 rgba(140,170,200,0.35);
}

.warm-button.primary:active {
  transform: translateY(1px);
  box-shadow: 0 3px 0 0 rgba(140,170,200,0.3);
}

.warm-button.secondary {
  background: var(--color-coral);
  color: #FFFFFF;
  border-color: var(--color-coral);
  box-shadow: var(--shadow-coral);
}

.warm-button.secondary:hover {
  background: var(--color-coral-light);
  border-color: var(--color-coral-light);
  transform: translateY(-2px);
  box-shadow: 0 6px 0 0 rgba(210,140,130,0.35);
}

.warm-button.secondary:active {
  transform: translateY(1px);
  box-shadow: 0 3px 0 0 rgba(210,140,130,0.3);
}

.warm-button:focus-visible {
  outline: 3px solid rgba(140,170,200,0.5);
  outline-offset: 2px;
}

.warm-button.large {
  padding: var(--space-3) var(--space-6);
  font-size: 1.125rem;
  box-shadow: 0 6px 0 0 currentColor;
}

.warm-button.large:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 0 0 currentColor;
}

.warm-button.large:active {
  transform: translateY(2px);
  box-shadow: 0 4px 0 0 currentColor;
}

/* App Store badge */
.app-store-badge-link {
  display: inline-block;
  line-height: 0;
  border-radius: var(--radius-lg);
  transition: transform var(--duration-medium) var(--ease-smooth);
}

.app-store-badge-link:hover {
  transform: translateY(-2px);
}

.app-store-badge {
  display: block;
  height: 54px;
  width: auto;
  max-width: 100%;
}

/* ========================================
   CARDS
   ======================================== */

.organic-card,
.feature-card,
.value-card,
.guarantee-card {
  background: var(--color-surface);
  border: var(--border-blue);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-blue);
  transition: transform var(--duration-medium) var(--ease-smooth),
              box-shadow var(--duration-medium) var(--ease-smooth),
              border-color var(--duration-medium) ease;
  position: relative;
  overflow: visible;
}

.organic-card:hover,
.feature-card:hover {
  transform: translateY(-4px);
  border: var(--border-blue-thick);
  box-shadow: var(--shadow-blue-hover);
}

/* Remove old pseudo-elements */
.organic-card::before,
.organic-card::after,
.feature-card::before,
.feature-card::after {
  display: none;
}

/* Feature Cards Layout */
.features-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: repeat(12, 1fr);
}

.feature-card--hero {
  grid-column: span 12;
}

.feature-card--lg {
  grid-column: span 6;
}

.feature-card--md {
  grid-column: span 4;
}

.feature-card--sm {
  grid-column: span 3;
  padding: var(--space-4);
}

@media (max-width: 1100px) {
  .feature-card--md {
    grid-column: span 6;
  }

  .feature-card--sm {
    grid-column: span 4;
  }
}

@media (max-width: 760px) {
  .features-grid {
    grid-template-columns: repeat(6, 1fr);
  }

  .feature-card--hero,
  .feature-card--lg,
  .feature-card--md,
  .feature-card--sm {
    grid-column: span 6;
  }
}

/* Alternate colors for variety (still soft) */
.feature-card:nth-child(6n+1) {
  border-color: rgba(140,170,200,0.4);
  box-shadow: var(--shadow-blue);
}

.feature-card:nth-child(6n+1):hover {
  border-color: rgba(140,170,200,0.5);
  box-shadow: var(--shadow-blue-hover);
}

.feature-card:nth-child(6n+2) {
  border-color: rgba(210,140,130,0.4);
  box-shadow: var(--shadow-coral);
}

.feature-card:nth-child(6n+2):hover {
  border-color: rgba(210,140,130,0.5);
  box-shadow: var(--shadow-coral-hover);
}

.feature-card:nth-child(6n+3) {
  border-color: rgba(155,196,181,0.4);
  box-shadow: var(--shadow-mint);
}

.feature-card:nth-child(6n+3):hover {
  border-color: rgba(155,196,181,0.5);
  box-shadow: 0 8px 0 0 rgba(155,196,181,0.35);
}

.feature-card:nth-child(6n+4) {
  border-color: rgba(184,168,200,0.4);
  box-shadow: 0 4px 0 0 rgba(184,168,200,0.3);
}

.feature-card:nth-child(6n+4):hover {
  border-color: rgba(184,168,200,0.5);
  box-shadow: 0 8px 0 0 rgba(184,168,200,0.35);
}

.feature-card:nth-child(6n+5) {
  border-color: rgba(232,184,154,0.4);
  box-shadow: 0 4px 0 0 rgba(232,184,154,0.3);
}

.feature-card:nth-child(6n+5):hover {
  border-color: rgba(232,184,154,0.5);
  box-shadow: 0 8px 0 0 rgba(232,184,154,0.35);
}

.feature-card:nth-child(6n+6) {
  border-color: rgba(168,189,212,0.4);
  box-shadow: 0 4px 0 0 rgba(168,189,212,0.3);
}

.feature-card:nth-child(6n+6):hover {
  border-color: rgba(168,189,212,0.5);
  box-shadow: 0 8px 0 0 rgba(168,189,212,0.35);
}

/* Feature card structure */
.feature-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.feature-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  font-size: 24px;
  border: 2px solid currentColor;
  box-shadow: 0 3px 0 0 currentColor;
}

/* Soft color palette for icons */
.feature-card:nth-child(6n+1) .feature-card__icon {
  background: var(--color-blue);
  color: white;
  border-color: var(--color-blue);
}

.feature-card:nth-child(6n+2) .feature-card__icon {
  background: var(--color-coral);
  color: white;
  border-color: var(--color-coral);
}

.feature-card:nth-child(6n+3) .feature-card__icon {
  background: var(--color-mint);
  color: white;
  border-color: var(--color-mint);
}

.feature-card:nth-child(6n+4) .feature-card__icon {
  background: var(--color-lavender);
  color: white;
  border-color: var(--color-lavender);
}

.feature-card:nth-child(6n+5) .feature-card__icon {
  background: var(--color-peach);
  color: var(--color-text-primary);
  border-color: var(--color-peach);
}

.feature-card:nth-child(6n+6) .feature-card__icon {
  background: var(--color-blue-light);
  color: white;
  border-color: var(--color-blue-light);
}

.feature-card__icon svg,
.feature-card__icon .ph {
  width: 24px;
  height: 24px;
  font-size: 24px;
  line-height: 1;
  display: inline-block;
}

.feature-card h3 {
  font-size: 1.125rem;
  font-weight: 600;
  margin: 0;
}

.feature-card__desc {
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--color-text-secondary);
  margin: 0;
  margin-top: var(--space-3);
}

/* ========================================
   GUARANTEE CARDS
   ======================================== */

.guarantee-layout {
  display: grid;
  gap: var(--space-8);
  max-width: 1200px;
  margin: 0 auto;
}

.guarantee-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--space-6);
}

.guarantee-card {
  background: var(--color-surface);
  border: var(--border-neutral);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-neutral);
  transition: transform var(--duration-medium) var(--ease-smooth),
              box-shadow var(--duration-medium) var(--ease-smooth),
              border-color var(--duration-medium) ease;
}

.guarantee-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-neutral-hover);
}

.reality-card {
  border-color: rgba(210,140,130,0.4);
  box-shadow: var(--shadow-coral);
}

.reality-card:hover {
  box-shadow: var(--shadow-coral-hover);
  border-color: rgba(210,140,130,0.5);
}

.promise-card {
  border-color: rgba(155,196,181,0.4);
  box-shadow: var(--shadow-mint);
}

.promise-card:hover {
  box-shadow: 0 8px 0 0 rgba(155,196,181,0.35);
  border-color: rgba(155,196,181,0.5);
}

/* Soft colorful icon */
.card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-4);
  border: 2px solid currentColor;
  box-shadow: 0 3px 0 0 currentColor;
}

.reality-card .card-icon {
  background: var(--color-coral);
  color: white;
  border-color: var(--color-coral);
}

.promise-card .card-icon {
  background: var(--color-mint);
  color: white;
  border-color: var(--color-mint);
}

.card-icon i {
  font-size: 28px;
}

.card-header {
  margin: 0 0 var(--space-3);
  font-size: 1.25rem;
  font-weight: 700;
}

.card-body {
  margin: 0;
  font-size: 1rem;
  line-height: 1.5;
  color: var(--color-text-secondary);
}

.guarantee-refund {
  background: var(--color-surface);
  border: var(--border-blue-thick);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-blue);
}

.guarantee-refund h3 {
  margin: 0 0 var(--space-3);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-text-primary);
}

/* Guarantee split for responsive */
.guarantee-split {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  padding: var(--space-4);
}

.guarantee-left,
.guarantee-right {
  padding: var(--space-2);
}

.guarantee-right h3 {
  margin: 0 0 var(--space-2);
  font-size: 1.125rem;
  font-weight: 600;
}

@media (min-width: 860px) {
  .guarantee-split {
    grid-template-columns: 1.05fr 0.95fr;
    align-items: start;
    gap: var(--space-12);
    position: relative;
  }

  .guarantee-split::after {
    content: '';
    position: absolute;
    top: 14px;
    bottom: 14px;
    left: 50%;
    width: 1px;
    background: var(--border-neutral);
    transform: translateX(-0.5px);
  }
}

/* ========================================
   VIDEO WRAPPER
   ======================================== */

.video-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 16 / 10;
  border: var(--border-blue-thick);
  border-radius: var(--radius-2xl);
  background: var(--color-surface);
  box-shadow: var(--shadow-mixed-blue);
  overflow: hidden;
  transition: transform var(--duration-medium) var(--ease-smooth),
              box-shadow var(--duration-medium) var(--ease-smooth),
              border-color var(--duration-medium) ease;
  min-height: clamp(360px, 40vw, 620px);
  max-height: 620px;
}

.video-wrapper:hover {
  transform: translateY(-4px);
  box-shadow: 
    0 0 0 2px rgba(140,170,200,0.25),
    0 8px 0 0 rgba(140,170,200,0.35),
    0 8px 16px 0 rgba(140,170,200,0.15);
  border-color: rgba(184,168,200,0.5);
}

.demo-slideshow {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: var(--color-surface);
}

.demo-slideshow .slide-layer {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 0;
  transition: opacity var(--duration-medium) var(--ease-smooth);
}

.demo-slideshow .slide-layer.visible {
  opacity: 1;
}

.demo-slideshow:not(.ready) {
  display: none;
}

.demo-video {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  opacity: 1;
  transition: opacity var(--duration-slow) var(--ease-smooth);
  background: transparent;
}

.demo-video.loaded {
  opacity: 1;
}

/* Hide Safari's built-in controls */
video.demo-video::-webkit-media-controls,
video.demo-video::-webkit-media-controls-enclosure,
video.demo-video::-webkit-media-controls-overlay-enclosure,
video.demo-video::-webkit-media-controls-panel {
  display: none !important;
}

.video-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}

/* Slideshow controls */
.slideshow-control {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 44px;
  height: 44px;
  border: 2px solid rgba(140,170,200,0.4);
  border-radius: var(--radius-md);
  background: rgba(245,243,240,0.95);
  color: var(--color-blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 3px 0 0 rgba(140,170,200,0.25);
  backdrop-filter: blur(10px);
  transition: transform var(--duration-fast) var(--ease-smooth),
              box-shadow var(--duration-fast) var(--ease-smooth),
              border-color var(--duration-fast) ease;
}

.slideshow-control:hover {
  transform: translateY(calc(-50% - 2px));
  box-shadow: 0 5px 0 0 rgba(140,170,200,0.3);
  border-color: var(--color-blue);
}

.slideshow-control:active {
  transform: translateY(calc(-50% + 1px));
  box-shadow: 0 2px 0 0 rgba(140,170,200,0.25);
}

.slideshow-control.prev {
  left: var(--space-3);
}

.slideshow-control.next {
  right: var(--space-3);
}

@media (prefers-color-scheme: dark) {
  .slideshow-control {
    background: rgba(54,50,46,0.95);
    color: var(--color-blue);
  }
}

@media (max-width: 768px) {
  .slideshow-control {
    width: 38px;
    height: 38px;
    font-size: 16px;
  }

  .video-wrapper {
    min-height: 180px;
    max-height: 360px;
  }
}

/* ========================================
   SCREENSHOT GALLERY
   ======================================== */

.screenshot-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-6);
  max-width: 1200px;
  margin: 0 auto;
}

.screenshot-card {
  background: var(--color-surface);
  border: var(--border-neutral);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-neutral);
  cursor: pointer;
  transition: transform var(--duration-medium) var(--ease-smooth),
              box-shadow var(--duration-medium) var(--ease-smooth),
              border-color var(--duration-medium) ease;
  padding: 0;
}

.screenshot-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-neutral-hover);
}

/* Vary border colors softly */
.screenshot-card:nth-child(4n+1) {
  border-color: rgba(140,170,200,0.3);
}

.screenshot-card:nth-child(4n+1):hover {
  border-color: rgba(140,170,200,0.5);
  box-shadow: var(--shadow-blue);
}

.screenshot-card:nth-child(4n+2) {
  border-color: rgba(210,140,130,0.3);
}

.screenshot-card:nth-child(4n+2):hover {
  border-color: rgba(210,140,130,0.5);
  box-shadow: var(--shadow-coral);
}

.screenshot-card:nth-child(4n+3) {
  border-color: rgba(155,196,181,0.3);
}

.screenshot-card:nth-child(4n+3):hover {
  border-color: rgba(155,196,181,0.5);
  box-shadow: var(--shadow-mint);
}

.screenshot-card:nth-child(4n+4) {
  border-color: rgba(184,168,200,0.3);
}

.screenshot-card:nth-child(4n+4):hover {
  border-color: rgba(184,168,200,0.5);
  box-shadow: 0 8px 0 0 rgba(184,168,200,0.3);
}

.screenshot-card picture {
  display: block;
  background: var(--color-surface);
  border-bottom: 2px solid rgba(42,42,42,0.06);
}

.screenshot-card img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 5/4;
  object-fit: cover;
  transition: transform var(--duration-medium) var(--ease-smooth);
}

.screenshot-card:hover img {
  transform: scale(1.03);
}

.screenshot-card figcaption {
  padding: var(--space-3);
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  text-align: center;
}

/* ========================================
   PRICING SECTION
   ======================================== */

.pricing-box {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  padding: var(--space-8);
  margin: var(--space-8) auto 0;
  max-width: 1200px;
  background: var(--color-surface-alt);
  border: var(--border-blue-thick);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-mixed-blue);
}

@media (min-width: 960px) {
  .pricing-box {
    grid-template-columns: 1fr 1.5fr 1fr;
    align-items: center;
  }
}

.pricing-benefits {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
  font-size: 1rem;
}

.pricing-benefits li {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) 0;
}

.pricing-benefits li::before {
  content: "✓";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: var(--color-mint);
  color: white;
  border-radius: 50%;
  font-weight: 700;
  font-size: 0.875rem;
  flex-shrink: 0;
  box-shadow: 0 2px 0 0 rgba(155,196,181,0.4);
}

.pricing-card {
  position: relative;
  background: var(--color-surface);
  border: var(--border-coral);
  border-radius: var(--radius-2xl);
  padding: clamp(34px, 6vw, 70px) clamp(28px, 6vw, 74px) clamp(38px, 6vw, 76px);
  text-align: center;
  box-shadow: var(--shadow-coral);
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Soft badge - centered on the card top border */
.pricing-card__badge {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -55%);
  background: var(--color-blue); /* #8CAAC8 soft blue matches app */
  color: #ffffff;
  padding: 8px 24px;
  border: 2px solid var(--color-blue);
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.48px;
  text-transform: uppercase;
  box-shadow: 0 4px 0 0 rgba(140,170,200,0.3); /* Soft colored offset shadow */
  z-index: 5;
  white-space: nowrap;
  transition: transform var(--duration-medium) var(--ease-smooth),
              box-shadow var(--duration-medium) var(--ease-smooth);
}

.pricing-card__badge:hover {
  transform: translate(-50%, calc(-55% - 2px)); /* Gentle lift */
  box-shadow: 0 6px 0 0 rgba(140,170,200,0.35); /* Deeper shadow on hover */
}

/* Soft ribbon - positioned centered below badge */
.pricing-card__ribbon {
  position: absolute;
  top: clamp(38px, 5vw, 52px);
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(145deg, #f6d5c7 0%, #d9a99e 100%); /* Peach/coral gradient */
  color: #3d2522; /* Warm dark for contrast */
  padding: 12px 20px;
  border-radius: 16px; /* Soft rounded corners */
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.65px;
  box-shadow: 0 4px 0 0 rgba(202, 139, 121, 0.35); /* Soft colored offset shadow */
  transition: transform var(--duration-medium) var(--ease-smooth),
              box-shadow var(--duration-medium) var(--ease-smooth);
}

.pricing-card__ribbon:hover {
  transform: translateX(-50%) translateY(-2px); /* Gentle lift */
  box-shadow: 0 6px 0 0 rgba(202, 139, 121, 0.4); /* Deeper shadow on hover */
}

.pricing-card__ribbon::after {
  content: none;
}

.pricing-card__ribbon-title {
  display: block;
  font-size: 0.7rem;
  letter-spacing: 0.55px;
}

.pricing-card__ribbon-subtitle {
  display: block;
  font-size: 0.95rem;
}

@media (max-width: 560px) {
  .pricing-card__ribbon {
    top: 32px;
    padding: 10px 16px;
  }

  .pricing-card__ribbon-subtitle {
    font-size: 0.85rem;
  }
}

.pricing-card__label {
  margin: clamp(30px, 6vw, 54px) 0 12px;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--color-text-secondary);
}

.pricing-card__price {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  margin: 0 0 var(--space-4);
}

.pricing-card__price-original {
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-decoration: line-through;
  text-decoration-thickness: 2px;
  text-decoration-color: var(--color-coral);
}

.pricing-card__price-current {
  font-size: clamp(3.8rem, 9vw, 5.8rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.015em;
  color: var(--color-text-primary);
}

.pricing-card__actions {
  margin: var(--space-4) 0;
}

.pricing-card__cta {
  min-width: 280px;
  font-weight: 600;
}

.pricing-card__cta i.ph {
  font-size: 1.25em;
  line-height: 1;
}

.pricing-card__note {
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  margin: var(--space-3) 0 0;
}

/* Soft savings card */
.savings-card {
  border: var(--border-blue);
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin: var(--space-6) auto 0;
  text-align: center;
  box-shadow: var(--shadow-blue);
  width: min(calc(100% - 30px), max-content);
  position: relative;
  z-index: 3;
}

.savings-card-headline {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-blue);
  margin-bottom: var(--space-2);
}

.savings-card-breakdown {
  font-size: 0.9375rem;
  color: var(--color-text-secondary);
}

.savings-card-highlight {
  color: var(--color-coral);
  font-weight: 700;
}

/* Pricing competitor text */
.pricing-competitor-text {
  max-width: 980px;
  margin: 0 auto var(--space-8);
  text-align: center;
  padding: 0 var(--space-6);
}

.pricing-competitor-text .competitor-title {
  margin: 0;
  font-size: clamp(1.25rem, 2.8vw, 2rem);
  font-weight: 600;
  letter-spacing: -0.01em;
}

.pricing-competitor-text .competitor-sub {
  margin: 6px 0 10px;
}

.pricing-competitor-text .competitor-annual {
  margin: 6px 0 12px;
  display: inline-block;
  padding: 6px 12px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(210,140,130,0.08), rgba(232,184,154,0.04));
  border: 2px solid rgba(210,140,130,0.18);
}

.pricing-competitor-text .annual-price {
  color: var(--color-coral);
  font-weight: 700;
}

.pricing-competitor-text .competitor-points {
  margin: 8px auto 12px;
  max-width: 920px;
  color: var(--color-text-secondary);
}

.pricing-competitor-text .competitor-bottom {
  margin: 0;
  font-weight: 700;
}

/* Competitor summary */
.competitor-summary {
  max-width: 1100px;
  margin: 0 auto var(--space-8);
  padding: var(--space-4);
}

.competitor-summary .pricing-benefits {
  font-size: 1rem;
}

.competitor-summary .pricing-benefits li::before {
  content: "–";
  color: var(--color-text-secondary);
  font-weight: 700;
  background: none;
  border-radius: 0;
  box-shadow: none;
}

/* ========================================
   FAQ SECTION
   ======================================== */

.faq {
  max-width: 900px;
  margin: 0 auto;
  display: grid;
  gap: var(--space-3);
}

.faq-item {
  background: var(--color-surface);
  border: var(--border-neutral);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-neutral);
  transition: transform var(--duration-medium) var(--ease-smooth),
              box-shadow var(--duration-medium) var(--ease-smooth),
              border-color var(--duration-medium) ease;
}

.faq-item:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-neutral-hover);
  border-color: rgba(140,170,200,0.3);
}

.faq-toggle {
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  padding: var(--space-4);
  font-family: var(--font-primary);
  font-size: 1.0625rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--color-text-primary);
  transition: color var(--duration-medium) ease;
}

.faq-item h3 {
  margin: 0;
  font-size: 16px;
}

.faq-toggle:hover {
  color: var(--color-blue);
}

.faq-toggle::after {
  content: "+";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: rgba(140,170,200,0.15);
  color: var(--color-blue);
  border-radius: 50%;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  border: 2px solid rgba(140,170,200,0.3);
  transition: transform var(--duration-medium) var(--ease-bounce),
              background-color var(--duration-medium) ease,
              border-color var(--duration-medium) ease;
}

.faq-toggle[aria-expanded="true"]::after {
  content: "−";
  transform: rotate(180deg);
  background: var(--color-blue);
  color: white;
  border-color: var(--color-blue);
}

.faq-panel {
  padding: 0 var(--space-4) var(--space-4);
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--color-text-secondary);
  border-top: 2px solid rgba(42,42,42,0.06);
  margin-top: var(--space-2);
}

.faq-panel p {
  margin: var(--space-2) 0 0;
}

.faq-panel[hidden] {
  display: none;
}

/* ========================================
   INPUT FIELDS
   ======================================== */

input[type="text"],
input[type="email"],
textarea,
.language-search-input {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  font-family: var(--font-primary);
  font-size: 1rem;
  background: var(--color-surface);
  border: var(--border-neutral);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  outline: none;
  box-shadow: var(--shadow-neutral);
  transition: border-color var(--duration-medium) ease,
              box-shadow var(--duration-medium) var(--ease-smooth),
              transform var(--duration-medium) var(--ease-smooth);
}

input:focus,
textarea:focus,
.language-search-input:focus {
  border: var(--border-blue-thick);
  transform: translateY(-2px);
  box-shadow: var(--shadow-blue);
  padding: calc(var(--space-2) - 1px) calc(var(--space-3) - 1px);
}

input::placeholder,
textarea::placeholder,
.language-search-input::placeholder {
  color: var(--color-text-tertiary);
}

/* ========================================
   FOOTER
   ======================================== */

.site-footer {
  text-align: center;
  padding: var(--space-6) var(--space-6);
  border-top: var(--border-blue);
  background: var(--color-surface-alt);
  box-shadow: inset 0 2px 0 0 rgba(140,170,200,0.15);
}

.site-footer p {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--color-text-secondary);
  font-weight: 400;
}

/* ========================================
   STICKY BUY BAR
   ======================================== */

.sticky-buy {
  position: fixed;
  left: 0;
  right: 0;
  bottom: -120px;
  display: flex;
  justify-content: center;
  gap: var(--space-3);
  align-items: center;
  background: rgba(245,243,240,0.95);
  backdrop-filter: blur(20px) saturate(180%);
  border-top: var(--border-blue);
  padding: var(--space-3) var(--space-4);
  z-index: 60;
  box-shadow: 0 -2px 0 0 rgba(140,170,200,0.15);
  transition: bottom var(--duration-medium) var(--ease-smooth);
}

@media (prefers-color-scheme: dark) {
  .sticky-buy {
    background: rgba(42,40,38,0.95);
  }
}

.sticky-buy.is-visible {
  bottom: 0;
}

.sticky-buy__price {
  font-weight: 600;
  font-size: 1.125rem;
  color: var(--color-text-primary);
}

.sticky-buy__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-md);
  background: var(--color-blue);
  color: white;
  font-weight: 600;
  font-size: 1rem;
  border: 2px solid var(--color-blue);
  box-shadow: var(--shadow-blue);
  text-decoration: none;
  transition: transform var(--duration-fast) var(--ease-smooth),
              box-shadow var(--duration-fast) var(--ease-smooth),
              background var(--duration-fast) ease;
}

.sticky-buy__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 0 0 rgba(140,170,200,0.35);
  background: var(--color-blue-light);
}

.sticky-buy__cta:active {
  transform: translateY(1px);
  box-shadow: 0 3px 0 0 rgba(140,170,200,0.3);
}

@media (min-width: 860px) {
  .sticky-buy {
    display: none;
  }
}

/* ========================================
   ANIMATION SYSTEM
   ======================================== */

/* Apply smooth transitions globally */
* {
  transition-timing-function: var(--ease-smooth);
}

/* Reduce motion for accessibility */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    transition-delay: 0ms !important;
  }

  :root {
    --ease-smooth: ease;
    --ease-bounce: ease;
  }
}

/* ========================================
   🌟 COMBO DELUXE ANIMATIONS 🌟
   ======================================== */

/* Reveal animations (soft fade up with scale) */
.reveal {
  opacity: 0;
  transform: translateY(32px) scale(0.96);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  transition: opacity var(--duration-slow) var(--ease-smooth),
              transform var(--duration-slow) var(--ease-bounce);
}

/* Enhanced card reveals */
.feature-card.reveal,
.value-card.reveal,
.screenshot-card.reveal,
.guarantee-card.reveal {
  opacity: 0;
  transform: translateY(40px) scale(0.94);
}

.feature-card.reveal.is-visible,
.value-card.reveal.is-visible,
.screenshot-card.reveal.is-visible,
.guarantee-card.reveal.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  transition: opacity 600ms var(--ease-smooth),
              transform 600ms var(--ease-bounce);
}

/* Section headers special animation */
.section__header.header-animate {
  opacity: 0;
  transform: translateY(40px);
}

.section__header.header-visible {
  opacity: 1;
  transform: translateY(0);
  animation: headerSlideIn 0.8s var(--ease-bounce) forwards;
}

@keyframes headerSlideIn {
  0% {
    opacity: 0;
    transform: translateY(40px);
  }
  60% {
    transform: translateY(-5px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Section header underline animation */
.section__header.header-visible h2::after {
  animation: underlineGrow 0.6s ease-out 0.3s forwards;
  transform-origin: left;
  transform: scaleX(0);
}

@keyframes underlineGrow {
  to {
    transform: scaleX(1);
  }
}

/* Button/CTA scale bounce animation */
.warm-button.button-animate,
.app-store-badge-link.button-animate {
  opacity: 0;
  transform: scale(0.9);
}

.warm-button.button-visible,
.app-store-badge-link.button-visible {
  opacity: 1;
  transform: scale(1);
  animation: buttonBounceIn 0.5s var(--ease-bounce) forwards;
}

@keyframes buttonBounceIn {
  0% {
    opacity: 0;
    transform: scale(0.9);
  }
  50% {
    transform: scale(1.05);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

/* Parallax smooth transitions */
.hero__content,
.hero__visual {
  will-change: transform;
  transition: transform 0.1s ease-out;
}

/* Scroll progress bar pulse */
.scroll-progress {
  box-shadow: 0 0 12px rgba(140,170,200,0.4);
}

/* Smooth body background transitions */
body {
  transition: background-color 0.6s var(--ease-smooth);
}

/* Add floating animation to hero elements */
@keyframes float {
  0%, 100% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-10px);
  }
}

.hero__visual:hover {
  animation: float 3s ease-in-out infinite;
}

/* Add subtle pulse to trust line checkmark */
.trust-line::before {
  animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(155,196,181,0.4);
  }
  50% {
    transform: scale(1.05);
    box-shadow: 0 0 0 4px rgba(155,196,181,0);
  }
}

/* Enhanced pricing card entrance */
.pricing-card {
  animation: priceCardFloat 0.8s ease-out;
}

@keyframes priceCardFloat {
  0% {
    opacity: 0;
    transform: translateY(60px) scale(0.95);
  }
  60% {
    transform: translateY(-8px) scale(1.02);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* FAQ item hover with lift */
.faq-item {
  will-change: transform, box-shadow;
}

/* Screenshot cards get extra spring */
.screenshot-card {
  will-change: transform;
  transition: transform 400ms var(--ease-bounce),
              box-shadow 400ms var(--ease-smooth),
              border-color 400ms ease;
}

/* Feature card icons get micro-interactions */
.feature-card__icon {
  will-change: transform;
  transition: transform 300ms var(--ease-bounce);
}

.feature-card:hover .feature-card__icon {
  transform: scale(1.1) rotate(5deg);
}

/* Video wrapper gets enhanced hover */
.video-wrapper {
  will-change: transform, box-shadow;
}

/* Add entrance animation for pricing benefits */
.pricing-benefits li {
  opacity: 0;
  transform: translateX(-20px);
  animation: slideInFromLeft 0.4s ease-out forwards;
}

.pricing-benefits li:nth-child(1) { animation-delay: 0.1s; }
.pricing-benefits li:nth-child(2) { animation-delay: 0.2s; }
.pricing-benefits li:nth-child(3) { animation-delay: 0.3s; }
.pricing-benefits li:nth-child(4) { animation-delay: 0.4s; }
.pricing-benefits li:nth-child(5) { animation-delay: 0.5s; }
.pricing-benefits li:nth-child(6) { animation-delay: 0.6s; }

@keyframes slideInFromLeft {
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Add shimmer effect to badges - only overflow needed */
.pricing-card__badge,
.pricing-card__ribbon {
  overflow: hidden; /* For shimmer effect, no position: relative needed */
}

.pricing-card__badge::before,
.pricing-card__ribbon::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, 
    transparent, 
    rgba(255,255,255,0.3), 
    transparent
  );
  animation: shimmer 3s ease-in-out infinite;
}

@keyframes shimmer {
  0% {
    left: -100%;
  }
  50%, 100% {
    left: 100%;
  }
}

/* Guarantee cards get staggered entrance */
.guarantee-card:nth-child(1) {
  animation-delay: 0.1s;
}

.guarantee-card:nth-child(2) {
  animation-delay: 0.2s;
}

/* Add glow effect on hover for CTAs */
.warm-button.primary:hover {
  box-shadow: 0 6px 0 0 rgba(140,170,200,0.35),
              0 0 20px rgba(140,170,200,0.3);
}

.warm-button.secondary:hover {
  box-shadow: 0 6px 0 0 rgba(210,140,130,0.35),
              0 0 20px rgba(210,140,130,0.3);
}

/* ========================================
   UTILITY CLASSES
   ======================================== */

.hidden {
  display: none !important;
}

.muted {
  opacity: 0.6;
}

.micro {
  font-size: 11px;
  letter-spacing: 1.2px;
}

/* ========================================
   ADDITIONAL COMPONENTS
   ======================================== */

/* Value cards */
.value-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
}

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

.value-card h3 {
  margin: 0 0 var(--space-2);
}

.value-card p {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--color-text-secondary);
}

/* Checklist */
.checklist {
  list-style: none;
  margin: var(--space-4) 0 0;
  padding: 0;
  display: grid;
  gap: var(--space-2);
}

.checklist li {
  padding-left: var(--space-4);
  position: relative;
  font-size: 0.9375rem;
}

.checklist li::before {
  content: "";
  width: 14px;
  height: 14px;
  left: 0;
  top: 4px;
  position: absolute;
  border-radius: 4px;
  background: var(--color-mint);
  opacity: 0.9;
}

/* Statement card */
.statement-card {
  max-width: min(50rem, 90%);
  margin: var(--space-8) auto 0;
  padding: var(--space-5) clamp(1.5rem, 4vw, 3rem);
  border-radius: var(--radius-2xl);
  background: var(--color-surface);
  border: var(--border-blue);
  box-shadow: var(--shadow-blue);
  text-align: center;
}

.statement-card .statement {
  margin-bottom: var(--space-2);
}

.statement-card--bottleneck {
  margin-top: clamp(1.5rem, 5vw, 2.5rem);
  max-width: min(44rem, 92%);
}

.statement {
  font-size: 1.75rem;
  font-weight: 500;
  line-height: 1.2;
  margin: 0;
}

/* Before/After example */
.ba {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-4);
}

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

.ba__label {
  font-size: 12px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--color-text-secondary);
}

.ba__label--good {
  color: var(--color-mint);
  font-weight: 600;
}

.ba__box {
  border: var(--border-neutral);
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface);
  box-shadow: var(--shadow-neutral);
}

.ba__text {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.5;
}

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

/* Bottleneck grid */
.bottleneck-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: clamp(1.5rem, 4vw, 2.5rem);
  align-items: start;
  margin-top: var(--space-8);
}

.bottleneck-grid > .feature-card {
  grid-column: span 12;
  background: var(--color-surface);
  border: var(--border-blue);
  box-shadow: var(--shadow-blue);
  padding: clamp(1.75rem, 3vw, 2.5rem);
  border-radius: var(--radius-2xl);
  gap: clamp(0.75rem, 2vw, 1.5rem);
}

.bottleneck-grid > .feature-card:nth-of-type(-n+2) {
  grid-column: span 12;
}

@media (min-width: 900px) {
  .bottleneck-grid > .feature-card:nth-of-type(-n+2) {
    grid-column: span 6;
  }
}

.bottleneck-grid .feature-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.bottleneck-grid .feature-card__desc {
  margin: 0;
  color: var(--color-text-secondary);
  min-height: clamp(0rem, 2vw, 2.4rem);
}

.bottleneck-grid ul {
  margin: clamp(0.25rem, 1.5vw, 0.75rem) 0 0;
  padding-left: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.bottleneck-grid li {
  color: var(--color-text-secondary);
}

.bottleneck-grid .feature-card__icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.06);
}

.bottleneck-grid .feature-card__icon i {
  font-size: 22px;
}

.bottleneck-grid .feature-card:nth-of-type(1) .feature-card__icon {
  color: #f0875d;
  background: rgba(240, 135, 93, 0.12);
}

.bottleneck-grid .feature-card:nth-of-type(2) .feature-card__icon {
  color: #6b7bff;
  background: rgba(107, 123, 255, 0.12);
}

/* Design grid */
.design-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
}

.design-point {
  padding: var(--space-5);
}

.design-point h3 {
  margin: 0 0 var(--space-2);
}

.design-point p {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--color-text-secondary);
}

/* Support grid */
.support-grid {
  display: grid;
  gap: var(--space-8);
  grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr));
  align-items: stretch;
  max-width: 70rem;
  margin: 0 auto;
}

.support-card {
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  height: 100%;
}

.support-card h2,
.support-card h3 {
  margin: 0;
}

.support-card ul,
.support-card ol {
  margin: 0;
  padding-left: 1.25rem;
  line-height: 1.5;
}

.support-card p:last-child {
  margin-bottom: 0;
}

.contact-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact-list li {
  list-style: disc;
}

.support-section .section__header {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.support-section .section__lead {
  margin-left: auto;
  margin-right: auto;
  max-width: 34rem;
}

.support-section h1 {
  font-size: clamp(2rem, 5vw, 3.25rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin-bottom: var(--space-3);
}

/* Split visual */
.split__visual {
  padding: var(--space-8);
  min-height: 16rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.privacy-callout {
  max-width: 22rem;
  text-align: center;
}

.privacy-callout .micro {
  font-size: 0.8125rem;
  letter-spacing: 0.1em;
  margin: 0 0 var(--space-2);
  color: var(--color-blue);
  font-weight: 600;
}

/* Section split */
.section__split {
  display: grid;
  gap: var(--space-12);
  grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr));
  align-items: center;
}

/* Additional features */
.additional-features {
  margin: var(--space-12) 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: var(--space-2);
  font-size: 0.9375rem;
}

.additional-features li {
  padding-left: var(--space-4);
  position: relative;
}

.additional-features li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  width: 10px;
  height: 10px;
  border-radius: 3px;
  background: var(--color-blue);
  opacity: 0.85;
}

/* Trust & Proof block */
.trust-proof {
  max-width: 760px;
  margin: var(--space-3) auto 0;
  padding: var(--space-3);
  display: grid;
  gap: var(--space-2);
}

.trust-row {
  display: grid;
  grid-template-columns: 120px 1fr;
  align-items: baseline;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  border-bottom: 1px solid rgba(42,42,42,0.06);
}

.trust-row:last-child {
  border-bottom: 0;
}

.trust-copy {
  margin: 0;
}

/* Roadmap */
.roadmap-grid {
  display: grid;
  gap: var(--space-8);
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  margin-top: var(--space-4);
}

.roadmap-item {
  padding: var(--space-5);
}

.roadmap-item h3 {
  margin: 0 0 var(--space-2);
  font-size: 1.25rem;
  letter-spacing: -0.3px;
  font-weight: 500;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.roadmap-item p {
  margin: 0;
  font-size: 15px;
}

.tag {
  display: inline-block;
  font-size: 11px;
  letter-spacing: 0.8px;
  padding: 4px 8px 5px;
  border-radius: var(--radius-lg);
  background: var(--color-surface-alt);
  font-weight: 500;
}

.tag.upcoming {
  background: rgba(140,170,200,0.15);
  color: #3a5064;
}

.tag.building {
  background: rgba(210,140,130,0.25);
  color: #5a4835;
}

.tag.ongoing {
  background: rgba(140,170,200,0.22);
  color: #344454;
}

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

/* Language List */
.language-list-toggle { 
  background: rgba(140,170,200,0.08);
  border: var(--border-neutral);
  border-radius: var(--radius-sm);
  padding: var(--space-1) var(--space-2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  margin-top: var(--space-2);
  margin-bottom: var(--space-3);
  transition: all var(--duration-medium) ease;
  color: var(--color-blue);
  display: inline-block;
}

.language-list-toggle:hover {
  background: rgba(140,170,200,0.15);
  border-color: rgba(140,170,200,0.3);
}

.language-list-container {
  margin-top: var(--space-2);
  padding: var(--space-2);
  background: rgba(42,42,42,0.03);
  border: var(--border-neutral);
  border-radius: var(--radius-lg);
}

@media (prefers-color-scheme: dark) {
  .language-list-container {
    background: rgba(255,255,255,0.02);
  }
}

.language-search {
  margin-bottom: var(--space-2);
}

.language-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px 12px;
  max-height: 400px;
  overflow-y: auto;
  padding-right: 8px;
}

.language-grid::-webkit-scrollbar {
  width: 6px;
}

.language-grid::-webkit-scrollbar-track {
  background: rgba(0,0,0,0.05);
  border-radius: 3px;
}

.language-grid::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,0.2);
  border-radius: 3px;
}

@media (prefers-color-scheme: dark) {
  .language-grid::-webkit-scrollbar-track {
    background: rgba(255,255,255,0.05);
  }

  .language-grid::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,0.2);
  }
}

.language-item {
  padding: 6px 8px;
  font-size: 13px;
  line-height: 1.4;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  transition: all var(--duration-fast) ease;
  cursor: default;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.language-item:hover {
  background: rgba(140,170,200,0.08);
  border-color: rgba(140,170,200,0.2);
}

.language-item.hidden {
  display: none !important;
}

@media (max-width: 768px) {
  .language-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 480px) {
  .language-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
  }

  .language-item {
    padding: 6px 8px;
    font-size: 12px;
  }
}

/* Language feature link */
.language-feature-link {
  display: inline-block;
  margin-top: var(--space-2);
  font-size: 13px;
  font-weight: 500;
  color: var(--color-blue);
  text-decoration: none;
  transition: all var(--duration-medium) ease;
}

.language-feature-link:hover {
  color: var(--color-blue-light);
  transform: translateX(2px);
}

/* Badge stack */
.badge-stack {
  display: inline-flex;
  flex-direction: column;
  gap: 6px;
  margin-left: auto;
}

/* Neural engine badge */
.neural-engine-badge,
.metal-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 600;
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  line-height: 1;
}

.neural-engine-badge {
  background: linear-gradient(135deg, var(--color-blue), var(--color-lavender));
  color: white;
}

.metal-badge {
  background: linear-gradient(135deg, #6B7280, #111827);
  color: white;
}

/* Gallery note */
.gallery-note {
  text-align: center;
  margin-top: var(--space-8);
}

/* Steps list */
.steps-list {
  list-style: decimal;
  margin: 0;
  padding-left: var(--space-4);
  display: grid;
  gap: var(--space-2);
  font-size: 0.9375rem;
}

.steps-list li {
  line-height: 1.5;
}

/* About Section (Why, Support, Privacy combined) */
.about-subsection {
  margin-bottom: var(--space-12);
  scroll-margin-top: calc(var(--site-header-height) + var(--space-4));
}

.about-subsection:last-child {
  margin-bottom: 0;
}

.about-subsection__title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-2);
  color: var(--color-text-primary);
}

.about-subsection__lead {
  font-size: 1.125rem;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-4);
}

/* Compact support grid for about section */
.support-grid--compact {
  gap: var(--space-4);
  max-width: 60rem;
}

.support-grid--compact .support-card {
  padding: var(--space-4);
  gap: var(--space-2);
}

.support-grid--compact .support-card h4 {
  font-size: 1.125rem;
  margin: 0 0 var(--space-1);
}

.support-grid--compact .support-card ul {
  font-size: 0.9375rem;
}

/* Privacy highlights for about section */
.privacy-highlights {
  display: grid;
  gap: var(--space-3);
  margin: var(--space-4) 0;
}

.privacy-highlight {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3);
  background: var(--color-surface-alt);
  border-radius: var(--radius-md);
  border: var(--border-neutral);
}

.privacy-highlight i {
  font-size: 1.5rem;
  color: var(--color-blue);
  flex-shrink: 0;
  margin-top: 2px;
}

.privacy-highlight div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.privacy-highlight strong {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-text-primary);
}

.privacy-highlight span {
  font-size: 0.875rem;
  color: var(--color-text-secondary);
}

@media (min-width: 640px) {
  .privacy-highlights {
    grid-template-columns: repeat(3, 1fr);
  }
  
  .privacy-highlight {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }
  
  .privacy-highlight div {
    align-items: center;
  }
}

/* Why body */
.why-body {
  padding: var(--space-6);
  line-height: 1.55;
  font-size: 17px;
}

.why-body strong {
  font-weight: 650;
  font-size: 19px;
}

/* About page - Values grid */
.values-grid {
  display: grid;
  gap: var(--space-4);
  max-width: 64rem;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .values-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.value-card {
  padding: var(--space-5);
  text-align: center;
}

.value-icon {
  width: 3rem;
  height: 3rem;
  margin: 0 auto var(--space-3);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-surface-alt);
  border-radius: var(--radius-md);
}

.value-icon i {
  font-size: 1.5rem;
  color: var(--color-blue);
}

.value-card h3 {
  font-size: 1.125rem;
  font-weight: 600;
  margin: 0 0 var(--space-2);
}

.value-card p {
  font-size: 0.9375rem;
  color: var(--color-text-secondary);
  margin: 0;
  line-height: 1.5;
}

/* About page - Links grid */
.links-grid {
  display: grid;
  gap: var(--space-4);
  max-width: 48rem;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .links-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.link-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  text-decoration: none;
  color: inherit;
  transition: transform var(--duration-medium) var(--ease-smooth),
              box-shadow var(--duration-medium) var(--ease-smooth);
}

.link-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-blue-hover);
}

.link-card i {
  font-size: 1.5rem;
  color: var(--color-blue);
  flex-shrink: 0;
  margin-top: 2px;
}

.link-card h3 {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 4px;
}

.link-card p {
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  margin: 0;
}

.why-body .frustrations {
  list-style: none;
  margin: var(--space-3) 0;
  padding: 0;
  display: grid;
  gap: var(--space-1);
}

.why-body .frustrations li {
  padding-left: var(--space-4);
  position: relative;
  font-size: 0.9375rem;
}

.why-body .frustrations li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-blue);
}

/* CTA */
.cta {
  text-align: center;
}

.cta__inner {
  padding: 4rem var(--space-8) 4.5rem;
  max-width: 48rem;
  margin: 0 auto;
  background: linear-gradient(145deg, var(--color-bg) 0%, var(--color-surface-alt) 100%);
}

.cta__inner h1,
.cta__inner h2,
.cta__inner h3,
.cta__inner h4,
.cta__inner h5,
.cta__inner h6 {
  font-family: var(--font-heading);
}

.cta__inner p {
  font-size: 1.0625rem;
}

/* Policy content */
.policy-content {
  padding: var(--space-12) var(--space-8);
  max-width: 48rem;
  margin: 0 auto;
  line-height: 1.7;
}

.policy-content hr {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-blue), transparent);
  margin: var(--space-8) 0 var(--space-4);
}

.policy-content strong {
  color: var(--color-text-primary);
  font-weight: 600;
}

/* Policy Accordion */
.policy-accordion {
  margin: var(--space-4) 0;
}

.policy-item {
  border-bottom: 1px solid rgba(42,42,42,0.06);
}

.policy-item:last-child {
  border-bottom: none;
}

.policy-item h2,
.policy-item h3 {
  margin: 0;
}

.policy-toggle {
  width: 100%;
  padding: var(--space-4) 0;
  background: transparent;
  border: none;
  color: var(--color-text-primary);
  font-size: 1.25rem;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  position: relative;
  transition: color var(--duration-medium) ease;
  font-family: inherit;
}

.policy-toggle:hover {
  color: var(--color-blue);
}

.policy-toggle::after {
  content: "▼";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  transition: transform var(--duration-medium) ease, color var(--duration-medium) ease;
}

.policy-toggle[aria-expanded="true"]::after {
  transform: translateY(-50%) rotate(180deg);
  color: var(--color-blue);
}

.policy-panel {
  padding: 0 0 var(--space-4) 0;
  overflow: hidden;
  transition: all var(--duration-medium) ease;
}

.policy-panel[hidden] {
  display: none;
}

.policy-panel p {
  margin-bottom: var(--space-3);
  color: var(--color-text-primary);
  font-size: 1rem;
}

.policy-panel ul {
  margin: var(--space-3) 0;
  padding-left: 0;
  list-style: none;
}

.policy-panel li {
  position: relative;
  padding: var(--space-1) 0 var(--space-1) var(--space-4);
  margin-bottom: var(--space-1);
  color: var(--color-text-primary);
  background: rgba(140,170,200,0.05);
  border-radius: var(--radius-md);
  transition: background-color var(--duration-medium) ease;
}

.policy-panel li:hover {
  background: rgba(140,170,200,0.08);
}

.policy-panel li::before {
  content: "✓";
  position: absolute;
  left: var(--space-2);
  top: var(--space-1);
  color: var(--color-blue);
  font-weight: 600;
  font-size: 0.9rem;
}

/* ESL Section Styles */
.esl-content {
  padding: var(--space-6);
  max-width: 1000px;
  margin: var(--space-3) auto;
}

.esl-features {
  display: flex;
  gap: var(--space-3);
  margin: var(--space-6) 0;
  flex-wrap: wrap;
}

.esl-features .feature-card {
  flex: 1;
  min-width: 280px;
  padding: var(--space-3);
}

.esl-features .feature-card h3 {
  font-size: 1rem;
}

.esl-features .feature-card__desc {
  font-size: 0.875rem;
}

.language-examples {
  margin: var(--space-6) 0 var(--space-3);
}

.language-examples h3 {
  margin-bottom: var(--space-3);
  color: var(--color-text-primary);
}

.examples-grid {
  display: flex;
  gap: var(--space-6);
  flex-wrap: wrap;
}

.example-card {
  flex: 1;
  min-width: 280px;
  padding: var(--space-3);
  background: var(--color-surface);
  border-radius: var(--radius-2xl);
  border: var(--border-blue);
  box-shadow: var(--shadow-blue);
}

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

.language-badge {
  display: inline-block;
  padding: 0.25rem 0.625rem;
  background: var(--color-blue);
  color: white;
  border-radius: var(--radius-2xl);
  font-weight: 600;
  font-size: 0.8125rem;
}

.example-content {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.spoken-text,
.english-text {
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg);
  border-radius: var(--radius-lg);
}

.spoken-text p,
.english-text p {
  margin: 0;
}

.spoken-text p:first-child,
.english-text p:first-child {
  margin-bottom: 0.25rem;
}

.arrow-down {
  text-align: center;
  font-size: 1rem;
  color: var(--color-blue);
  opacity: 0.6;
  line-height: 1;
  margin: 0;
}

/* Dark mode adjustments for ESL */
@media (prefers-color-scheme: dark) {
  .example-card {
    background: var(--color-surface);
  }
  
  .spoken-text,
  .english-text {
    background: var(--color-bg);
  }
  
  .language-badge {
    background: var(--color-blue);
    color: white;
  }
}

/* Lazy image loading */
.lazy-image {
  opacity: 0;
  transition: opacity var(--duration-slow) ease-out;
  contain: layout style paint;
  will-change: opacity;
}

.lazy-image.loaded,
.lazy-image.is-loaded {
  opacity: 1;
}

/* Lightbox for enhanced viewing */
.lightbox {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0,0,0,0.9);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--duration-medium) ease-out, visibility var(--duration-medium) ease-out;
}

.lightbox.active {
  opacity: 1;
  visibility: visible;
}

.lightbox-content {
  max-width: 90vw;
  max-height: 90vh;
  transform: scale(0.8);
  transition: transform var(--duration-medium) var(--ease-bounce);
}

.lightbox.active .lightbox-content {
  transform: scale(1);
}

/* ========================================
   RESPONSIVE ADJUSTMENTS
   ======================================== */

@media (max-width: 768px) {
  .section {
    padding: var(--space-8) var(--space-4);
  }

  .hero {
    padding: var(--space-8) var(--space-4);
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }

  .hero__visual {
    max-width: 100%;
  }

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

  .screenshot-card:hover {
    transform: none;
  }
}

@media (max-width: 480px) {
  .section {
    padding: var(--space-6) var(--space-3);
  }

  .hero {
    padding: var(--space-6) var(--space-3);
    gap: var(--space-3);
  }
}

/* Smooth scroll enhancements */
@media (prefers-reduced-motion: no-preference) {
  main {
    scroll-behavior: smooth;
  }

  .section {
    scroll-margin-top: calc(var(--site-header-height) + var(--space-2));
  }
}

/* ==========================================================================
   AEO ENHANCEMENTS - Comparison Table & Use Cases
   ========================================================================== */

/* Comparison Table Styles */
.comparison-table-wrapper {
  overflow-x: auto;
  margin: var(--space-4) 0;
  border-radius: var(--radius-2xl);
  background: var(--color-surface-alt);
  padding: var(--space-1);
  border: var(--border-neutral);
}

.comparison-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.comparison-table thead {
  background: var(--color-blue);
  color: var(--color-surface);
}

.comparison-table th {
  padding: var(--space-2) var(--space-1);
  text-align: left;
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.comparison-table th:first-child {
  width: 25%;
}

.comparison-table th:not(:first-child) {
  text-align: center;
  width: 18.75%;
}

.comparison-table tbody tr {
  border-bottom: 1px solid var(--color-surface-alt);
  transition: background-color var(--duration-fast) var(--ease-smooth);
}

.comparison-table tbody tr:hover {
  background: var(--color-surface-alt);
}

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

.comparison-table td {
  padding: var(--space-2) var(--space-1);
  vertical-align: top;
}

.comparison-table td:first-child {
  font-weight: 500;
  color: var(--color-text-primary);
}

.comparison-table td:not(:first-child) {
  text-align: center;
  color: var(--color-text-secondary);
}

/* Highlight oto column */
.comparison-table th:nth-child(2),
.comparison-table td:nth-child(2) {
  background: rgba(140, 170, 200, 0.08);
  font-weight: 600;
  color: var(--color-text-primary);
}

/* Dark mode adjustments */
@media (prefers-color-scheme: dark) {
  .comparison-table-wrapper {
    background: var(--color-surface-alt);
  }

  .comparison-table thead {
    background: var(--color-blue);
    color: var(--color-surface-alt);
  }

  .comparison-table th:nth-child(2),
  .comparison-table td:nth-child(2) {
    background: rgba(168, 189, 212, 0.12);
  }
}

/* Mobile responsive */
@media (max-width: 768px) {
  .comparison-table {
    font-size: 0.75rem;
  }

  .comparison-table th,
  .comparison-table td {
    padding: var(--space-1) 4px;
  }

  .comparison-table th {
    font-size: 0.7rem;
  }
}

/* Use Cases Grid Styles */
.use-cases-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-6);
}

.use-case-card {
  padding: var(--space-5);
  background: var(--color-surface);
  border: var(--border-neutral);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-neutral);
  transition: transform var(--duration-medium) var(--ease-smooth),
              box-shadow var(--duration-medium) var(--ease-smooth);
}

.use-case-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-neutral-hover);
}

.use-case-icon {
  font-size: 2.5rem;
  margin-bottom: var(--space-2);
  line-height: 1;
}

.use-case-card h4 {
  margin: var(--space-2) 0;
  font-size: 1.25rem;
  color: var(--color-blue);
  font-weight: 600;
}

.use-case-challenge {
  margin: var(--space-2) 0;
  padding: var(--space-2);
  background: rgba(210, 140, 130, 0.08);
  border-left: 3px solid var(--color-coral);
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
}

.use-case-solution {
  margin: var(--space-2) 0;
  padding: var(--space-2);
  background: rgba(140, 170, 200, 0.08);
  border-left: 3px solid var(--color-blue);
  border-radius: var(--radius-sm);
}

.use-case-results {
  margin-top: var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-surface-alt);
  font-size: 0.85rem;
  color: var(--color-text-secondary);
}

/* Tablet: 2 columns */
@media (max-width: 1024px) {
  .use-cases-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Mobile: 1 column */
@media (max-width: 768px) {
  .use-cases-grid {
    grid-template-columns: 1fr;
  }

  .use-case-card {
    padding: var(--space-4);
  }
}

