/* ============================================
   CARRIROAD PAGE STYLES — Kinetic Precision
   Hero, Services, Labs, Map, About, Contact
   ============================================ */

/* ====== HERO ====== */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  padding-top: var(--nav-height);
  background: var(--cr-surface);
}

/* Hero background image — fallback */
.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: url('../assets/hero-truck.jpg');
  background-size: cover;
  background-position: center center;
  /* no mirror — original orientation */
  opacity: 0.9;
  filter: contrast(1.08) saturate(1.05);
}

/* Hero background video — QHD integration */
.hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  z-index: 1; /* Above fallback image, below overlay */
  opacity: 0.9;
  filter: contrast(1.08) saturate(1.05);
}

.hero__video-toggle {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(13, 13, 13, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: var(--cr-white);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s var(--ease-out);
  backdrop-filter: blur(8px);
  margin-left: var(--space-md);
  flex-shrink: 0;
}

.hero__video-toggle:hover {
  background: rgba(13, 13, 13, 0.8);
  border-color: var(--cr-lime);
  color: var(--cr-lime);
  transform: scale(1.05);
}

/* Hero gradient overlay — deep black, cinematic */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 3;
  background: 
    /* Deep black left zone — fades to reveal truck on right */
    linear-gradient(90deg, 
      rgba(0, 0, 0, 0.97) 0%,
      rgba(0, 0, 0, 0.90) 15%,
      rgba(0, 0, 0, 0.65) 32%,
      rgba(0, 0, 0, 0.20) 48%,
      transparent 60%
    ),
    /* Bottom edge fade */
    linear-gradient(0deg,
      rgba(0, 0, 0, 0.55) 0%,
      rgba(0, 0, 0, 0.15) 12%,
      transparent 30%
    ),
    /* Subtle top vignette for navbar */
    linear-gradient(180deg,
      rgba(0, 0, 0, 0.35) 0%,
      transparent 12%
    );
}

.hero__content {
  position: relative;
  z-index: 4;
  max-width: 560px;
}

.hero__tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--cr-lime);
  margin-bottom: var(--space-xl);
  animation: fadeInUp 0.8s var(--ease-out) both;
}

.hero__tag::before {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--cr-lime);
}

.hero__title {
  font-family: var(--font-heading);
  font-size: clamp(2.4rem, 4vw, 3.2rem);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  line-height: 1.15;
  margin-bottom: var(--space-lg);
  animation: fadeInUp 0.8s var(--ease-out) 0.15s both;
}

.hero__subtitle {
  font-size: var(--fs-body-lg);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
  max-width: 420px;
  margin-bottom: var(--space-2xl);
  animation: fadeInUp 0.8s var(--ease-out) 0.3s both;
}

.hero__actions {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  animation: fadeInUp 0.8s var(--ease-out) 0.45s both;
}

/* Hero decorative grid */
.hero__grid-lines {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.03;
  background-image: 
    linear-gradient(rgba(161,251,0,0.3) 1px, transparent 1px),
    linear-gradient(90deg, rgba(161,251,0,0.3) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at 70% 50%, black 20%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at 70% 50%, black 20%, transparent 70%);
}

/* ====== STATS BAR ====== */
.stats-bar {
  background: var(--cr-surface-mid);
  border-top: var(--border-ghost);
  border-bottom: var(--border-ghost);
  padding: var(--space-2xl) 0;
}

.stats-bar__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}

.stats-bar .stat {
  position: relative;
}

.stats-bar .stat:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0;
  top: 20%;
  height: 60%;
  width: 1px;
  background: rgba(65, 74, 52, 0.3);
}

/* ====== SERVICES SECTION ====== */
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}

.service-card {
  background: var(--cr-gradient-card);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl) var(--space-xl);
  position: relative;
  overflow: hidden;
  transition: all var(--duration-slow) var(--ease-out);
  cursor: pointer;
}

.service-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--cr-gradient-neon);
  opacity: 0;
  transition: opacity var(--duration-normal) var(--ease-out);
}

.service-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  width: 150px;
  height: 150px;
  background: radial-gradient(circle, var(--cr-lime-glow) 0%, transparent 70%);
  opacity: 0;
  transition: opacity var(--duration-slow) var(--ease-out);
}

.service-card:hover {
  border-color: rgba(161, 251, 0, 0.15);
  transform: translateY(-6px);
  box-shadow: var(--shadow-neon);
}

.service-card:hover::before { opacity: 1; }
.service-card:hover::after { opacity: 0.5; }

.service-card__icon {
  width: 64px;
  height: 64px;
  background: var(--cr-lime-glow);
  border: 1px solid rgba(161, 251, 0, 0.12);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-xl);
  font-size: 1.8rem;
  transition: all var(--duration-normal) var(--ease-out);
}

.service-card:hover .service-card__icon {
  background: var(--cr-lime-glow-strong);
  border-color: rgba(161, 251, 0, 0.3);
  box-shadow: 0 0 30px var(--cr-neon-pulse);
  transform: scale(1.05);
}

.service-card__title {
  font-family: var(--font-heading);
  font-size: var(--fs-h4);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  margin-bottom: var(--space-sm);
}

.service-card__desc {
  font-size: var(--fs-small);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-md);
}

.service-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  color: var(--cr-lime);
  opacity: 0;
  transform: translateY(10px);
  transition: all var(--duration-normal) var(--ease-out);
}

.service-card:hover .service-card__link {
  opacity: 1;
  transform: translateY(0);
}

/* ====== CARRI LABS — Bento Grid ====== */
.labs-section {
  background: var(--cr-surface);
  position: relative;
  overflow: hidden;
}

.labs-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(161, 251, 0, 0.04) 0%, transparent 70%);
  pointer-events: none;
}

.labs-bento {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto auto;
  gap: var(--space-lg);
}

.labs-cell {
  background: var(--cr-gradient-card);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  position: relative;
  overflow: hidden;
  transition: all var(--duration-slow) var(--ease-out);
}

.labs-cell:hover {
  border-color: rgba(161, 251, 0, 0.12);
  transform: translateY(-4px);
}

/* Featured cell: spans 2 columns (Temperature IoT) */
.labs-cell--featured {
  grid-column: span 2;
  background: linear-gradient(145deg, #1E1E1E 0%, #0E1A00 100%);
  border-color: rgba(161, 251, 0, 0.1);
}

.labs-cell--featured:hover {
  box-shadow: 0 0 40px rgba(6, 182, 212, 0.15), var(--shadow-neon);
}

.labs-cell__icon {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-lg);
  font-size: 1.5rem;
  transition: all var(--duration-normal) var(--ease-out);
}

.labs-cell__icon--temp {
  background: rgba(6, 182, 212, 0.15);
  color: #06B6D4;
  border: 1px solid rgba(6, 182, 212, 0.2);
}

.labs-cell__icon--fuel {
  background: rgba(245, 158, 11, 0.15);
  color: #F59E0B;
  border: 1px solid rgba(245, 158, 11, 0.2);
}

.labs-cell__icon--safety {
  background: var(--cr-lime-glow);
  color: var(--cr-lime);
  border: 1px solid rgba(161, 251, 0, 0.15);
}

.labs-cell__icon--hours {
  background: rgba(139, 92, 246, 0.15);
  color: #8B5CF6;
  border: 1px solid rgba(139, 92, 246, 0.2);
}

.labs-cell__icon--analytics {
  background: rgba(59, 130, 246, 0.15);
  color: #3B82F6;
  border: 1px solid rgba(59, 130, 246, 0.2);
}

.labs-cell:hover .labs-cell__icon {
  transform: scale(1.1);
}

.labs-cell__badge {
  display: inline-block;
  font-size: 10px;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-md);
}

.labs-cell__badge--active {
  background: var(--cr-lime-glow);
  color: var(--cr-lime);
}

.labs-cell__badge--dev {
  background: rgba(59, 130, 246, 0.15);
  color: #3B82F6;
}

.labs-cell__badge--soon {
  background: rgba(139, 92, 246, 0.15);
  color: #8B5CF6;
}

.labs-cell__title {
  font-family: var(--font-heading);
  font-size: var(--fs-h4);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  margin-bottom: var(--space-sm);
}

.labs-cell__text {
  font-size: var(--fs-small);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
}

/* Temperature gauge mini-viz */
.temp-gauge {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-lg);
  padding: var(--space-md);
  background: rgba(6, 182, 212, 0.06);
  border-radius: var(--radius-md);
  border: 1px solid rgba(6, 182, 212, 0.1);
}

.temp-gauge__bar {
  flex: 1;
  height: 6px;
  background: var(--cr-surface-high);
  border-radius: var(--radius-full);
  overflow: hidden;
  position: relative;
}

.temp-gauge__fill {
  height: 100%;
  width: 35%;
  background: linear-gradient(90deg, #06B6D4, #22D3EE);
  border-radius: var(--radius-full);
  animation: tempPulse 3s ease-in-out infinite;
}

.temp-gauge__value {
  font-family: var(--font-heading);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: #06B6D4;
  white-space: nowrap;
}

/* ====== CARRI LABS — Premium Teaser ====== */
.labs-teaser {
  position: relative;
  background: linear-gradient(145deg, #1a1a1a 0%, #0E1A00 40%, #131313 100%);
  border: 1px solid rgba(161, 251, 0, 0.12);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  transition: all var(--duration-slow) var(--ease-out);
}

.labs-teaser:hover {
  border-color: rgba(161, 251, 0, 0.25);
  box-shadow: 0 0 60px rgba(161, 251, 0, 0.08), var(--shadow-neon);
}

.labs-teaser__glow {
  position: absolute;
  top: -200px;
  right: -200px;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(161, 251, 0, 0.06) 0%, transparent 60%);
  pointer-events: none;
  transition: opacity 0.5s ease;
}

.labs-teaser:hover .labs-teaser__glow {
  opacity: 1.5;
}

.labs-teaser__content {
  position: relative;
  z-index: 1;
  padding: var(--space-3xl);
}

.labs-teaser__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3xl);
  align-items: center;
}

.labs-teaser__features {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.labs-teaser__feature {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-lg);
  border: 1px solid transparent;
  transition: all 0.3s ease;
}

.labs-teaser__feature:hover {
  background: rgba(161, 251, 0, 0.04);
  border-color: rgba(161, 251, 0, 0.08);
}

.labs-teaser__feature-icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  border-radius: var(--radius-md);
  background: var(--cr-lime-glow);
  border: 1px solid rgba(161, 251, 0, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cr-lime);
  transition: all 0.3s ease;
}

.labs-teaser__feature:hover .labs-teaser__feature-icon {
  background: var(--cr-lime-glow-strong);
  border-color: rgba(161, 251, 0, 0.3);
  transform: scale(1.05);
}

.labs-teaser__feature-title {
  font-family: var(--font-heading);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  font-size: var(--fs-body);
  margin-bottom: 2px;
}

.labs-teaser__feature-text {
  font-size: var(--fs-small);
  color: var(--cr-on-surface);
  line-height: 1.5;
}

.labs-teaser__cta-block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-lg);
  padding: var(--space-2xl);
  background: rgba(19, 19, 19, 0.5);
  border: 1px solid rgba(161, 251, 0, 0.06);
  border-radius: var(--radius-xl);
}

.labs-teaser__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--cr-lime);
  background: var(--cr-lime-glow);
  border: 1px solid rgba(161, 251, 0, 0.15);
  padding: 6px 16px;
  border-radius: var(--radius-full);
}

.labs-teaser__title {
  font-family: var(--font-heading);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  line-height: 1.25;
}

.labs-teaser__desc {
  font-size: var(--fs-small);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
  max-width: 380px;
}

@media (max-width: 768px) {
  .labs-teaser__grid {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
  }

  .labs-teaser__content {
    padding: var(--space-xl);
  }

  .labs-teaser__cta-block {
    align-items: center;
    text-align: center;
  }

  .labs-teaser__desc {
    max-width: none;
  }
}

/* ====== CARRI LABS PAGE ====== */
.labs-hero {
  min-height: 45vh;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  padding: calc(var(--nav-height) + var(--space-3xl)) 0 var(--space-3xl);
  background: var(--cr-surface);
}

.labs-hero__bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #131313 0%, #0E1A00 40%, #131313 100%);
}

.labs-hero__bg::after {
  content: '';
  position: absolute;
  top: -50%;
  right: -20%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(161, 251, 0, 0.06) 0%, transparent 60%);
  pointer-events: none;
}

.labs-hero__content {
  position: relative;
  z-index: 1;
  max-width: 700px;
}

.labs-hero__title {
  font-family: var(--font-heading);
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: var(--fw-black);
  color: var(--cr-white);
  line-height: 1.15;
  margin: var(--space-md) 0 var(--space-lg);
}

.labs-hero__subtitle {
  font-size: var(--fs-body-lg);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
  max-width: 560px;
}

/* Hero Cards — Proyectos Estrella */
.labs-heroes {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.labs-hero-card {
  display: flex;
  align-items: center;
  gap: var(--space-xl);
  padding: var(--space-xl) var(--space-2xl);
  border-radius: var(--radius-xl);
  border: 1px solid rgba(255,255,255,0.06);
  background: var(--cr-gradient-card);
  position: relative;
  overflow: hidden;
  transition: all 0.4s var(--ease-out);
  text-decoration: none;
  cursor: pointer;
}

.labs-hero-card:hover {
  transform: translateY(-4px);
}

.labs-hero-card__glow {
  position: absolute;
  top: -100px;
  right: -100px;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  opacity: 0;
  transition: opacity 0.5s ease;
  pointer-events: none;
}

.labs-hero-card:hover .labs-hero-card__glow {
  opacity: 1;
}

.labs-hero-card__icon {
  width: 72px;
  height: 72px;
  min-width: 72px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s ease;
}

.labs-hero-card:hover .labs-hero-card__icon {
  transform: scale(1.1);
}

.labs-hero-card__body {
  flex: 1;
}

.labs-hero-card__badge {
  display: inline-block;
  font-size: 10px;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-sm);
}

.labs-hero-card__body h3 {
  font-family: var(--font-heading);
  font-size: var(--fs-h3);
  font-weight: var(--fw-black);
  color: var(--cr-white);
  margin-bottom: var(--space-xs);
  transition: color 0.3s ease;
  text-transform: uppercase;
  letter-spacing: -0.01em;
}

.labs-hero-card__body p {
  font-size: var(--fs-small);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
  max-width: 600px;
}

/* Color Variants */
.labs-hero-card--cyan { border-color: rgba(6,182,212,0.2); background: linear-gradient(135deg, rgba(6,182,212,0.08), var(--cr-surface-mid)); }
.labs-hero-card--cyan:hover { border-color: rgba(6,182,212,0.5); box-shadow: 0 0 40px rgba(6,182,212,0.15); }
.labs-hero-card--cyan .labs-hero-card__glow { background: radial-gradient(circle, rgba(6,182,212,0.12) 0%, transparent 60%); }
.labs-hero-card--cyan .labs-hero-card__icon { background: rgba(6,182,212,0.15); color: #06B6D4; }
.labs-hero-card--cyan .labs-hero-card__badge { background: rgba(6,182,212,0.15); color: #22D3EE; border: 1px solid rgba(6,182,212,0.3); }
.labs-hero-card--cyan:hover h3 { color: #22D3EE; }

.labs-hero-card--amber { border-color: rgba(245,158,11,0.2); background: linear-gradient(135deg, rgba(245,158,11,0.08), var(--cr-surface-mid)); }
.labs-hero-card--amber:hover { border-color: rgba(245,158,11,0.5); box-shadow: 0 0 40px rgba(245,158,11,0.15); }
.labs-hero-card--amber .labs-hero-card__glow { background: radial-gradient(circle, rgba(245,158,11,0.12) 0%, transparent 60%); }
.labs-hero-card--amber .labs-hero-card__icon { background: rgba(245,158,11,0.15); color: #F59E0B; }
.labs-hero-card--amber .labs-hero-card__badge { background: rgba(245,158,11,0.15); color: #FBBF24; border: 1px solid rgba(245,158,11,0.3); }
.labs-hero-card--amber:hover h3 { color: #FBBF24; }

.labs-hero-card--emerald { border-color: rgba(16,185,129,0.2); background: linear-gradient(135deg, rgba(16,185,129,0.08), var(--cr-surface-mid)); }
.labs-hero-card--emerald:hover { border-color: rgba(16,185,129,0.5); box-shadow: 0 0 40px rgba(16,185,129,0.15); }
.labs-hero-card--emerald .labs-hero-card__glow { background: radial-gradient(circle, rgba(16,185,129,0.12) 0%, transparent 60%); }
.labs-hero-card--emerald .labs-hero-card__icon { background: rgba(16,185,129,0.15); color: #10B981; }
.labs-hero-card--emerald .labs-hero-card__badge { background: rgba(16,185,129,0.15); color: #34D399; border: 1px solid rgba(16,185,129,0.3); }
.labs-hero-card--emerald:hover h3 { color: #34D399; }

.labs-hero-card--pink { border-color: rgba(236,72,153,0.2); background: linear-gradient(135deg, rgba(236,72,153,0.08), var(--cr-surface-mid)); }
.labs-hero-card--pink:hover { border-color: rgba(236,72,153,0.5); box-shadow: 0 0 40px rgba(236,72,153,0.15); }
.labs-hero-card--pink .labs-hero-card__glow { background: radial-gradient(circle, rgba(236,72,153,0.12) 0%, transparent 60%); }
.labs-hero-card--pink .labs-hero-card__icon { background: rgba(236,72,153,0.15); color: #EC4899; }
.labs-hero-card--pink .labs-hero-card__badge { background: rgba(236,72,153,0.15); color: #F472B6; border: 1px solid rgba(236,72,153,0.3); }
.labs-hero-card--pink:hover h3 { color: #F472B6; }

.labs-hero-card--indigo { border-color: rgba(99,102,241,0.2); background: linear-gradient(135deg, rgba(99,102,241,0.08), var(--cr-surface-mid)); }
.labs-hero-card--indigo:hover { border-color: rgba(99,102,241,0.5); box-shadow: 0 0 40px rgba(99,102,241,0.15); }
.labs-hero-card--indigo .labs-hero-card__glow { background: radial-gradient(circle, rgba(99,102,241,0.12) 0%, transparent 60%); }
.labs-hero-card--indigo .labs-hero-card__icon { background: rgba(99,102,241,0.15); color: #6366F1; }
.labs-hero-card--indigo .labs-hero-card__badge { background: rgba(99,102,241,0.15); color: #818CF8; border: 1px solid rgba(99,102,241,0.3); }
.labs-hero-card--indigo:hover h3 { color: #818CF8; }

/* Modules Grid */
.labs-modules-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}

.labs-module-card {
  background: var(--cr-gradient-card);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  transition: all 0.3s var(--ease-out);
}

.labs-module-card:hover {
  border-color: rgba(161, 251, 0, 0.15);
  transform: translateY(-4px);
}

.labs-module-card__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-md);
  border: 1px solid;
  transition: transform 0.3s ease;
}

.labs-module-card:hover .labs-module-card__icon {
  transform: scale(1.1);
}

.labs-module-card h3 {
  font-family: var(--font-heading);
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  margin-bottom: var(--space-sm);
}

.labs-module-card p {
  font-size: var(--fs-small);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
}

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

@media (max-width: 768px) {
  .labs-hero-card { flex-direction: column; text-align: center; padding: var(--space-xl); }
  .labs-hero-card__body h3 { font-size: var(--fs-h4); }
  .labs-modules-grid { grid-template-columns: 1fr; }
}

/* ====== CARRI LABS — Subpage Components ====== */
.labs-back-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  color: var(--cr-on-surface);
  text-decoration: none;
  margin-bottom: var(--space-xl);
  transition: color 0.3s ease;
}
.labs-back-link:hover { color: var(--cr-lime); }

/* Steps / Process */
.labs-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}

.labs-step {
  text-align: center;
  padding: var(--space-lg);
}

.labs-step__number {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: var(--fs-h3);
  font-weight: var(--fw-black);
  margin: 0 auto var(--space-md);
}

.labs-step h4 {
  font-family: var(--font-heading);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  margin-bottom: var(--space-xs);
}

.labs-step p {
  font-size: var(--fs-small);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
}

/* KPI Grid */
.labs-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}

.labs-kpi {
  text-align: center;
  padding: var(--space-xl);
  background: var(--cr-gradient-card);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-xl);
}

.labs-kpi__value {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 3vw, 2.8rem);
  font-weight: var(--fw-black);
  line-height: 1;
  margin-bottom: var(--space-sm);
}

.labs-kpi__label {
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  margin-bottom: var(--space-xs);
}

.labs-kpi p {
  font-size: var(--fs-xs);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
}

/* Data Table */
.labs-table-wrapper {
  overflow-x: auto;
  border-radius: var(--radius-xl);
  border: 1px solid var(--cr-glass-border);
  background: var(--cr-gradient-card);
}

.labs-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-small);
}

.labs-table th {
  padding: var(--space-md) var(--space-lg);
  text-align: left;
  font-size: 10px;
  font-weight: var(--fw-black);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--cr-on-surface);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.labs-table td {
  padding: var(--space-md) var(--space-lg);
  color: var(--cr-on-surface);
  border-bottom: 1px solid rgba(255,255,255,0.03);
}

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

.labs-table__highlight {
  background: rgba(161, 251, 0, 0.04);
}
.labs-table__highlight td { color: var(--cr-white); font-weight: var(--fw-bold); }

/* Inline Badges */
.labs-badge-inline {
  display: inline-block;
  font-size: 9px;
  font-weight: var(--fw-black);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 3px 10px;
  border-radius: var(--radius-full);
}
.labs-badge-inline--blue { background: rgba(59,130,246,0.12); color: #60A5FA; }
.labs-badge-inline--purple { background: rgba(139,92,246,0.12); color: #A78BFA; }
.labs-badge-inline--lime { background: rgba(161,251,0,0.12); color: #A1FB00; }

/* Checklist */
.labs-checklist {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.labs-checklist li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-small);
  color: var(--cr-text-muted);
}

.labs-checklist li::before {
  content: '○';
  color: var(--cr-text-muted);
  font-size: 10px;
}

.labs-checklist__done {
  color: var(--cr-on-surface) !important;
}
.labs-checklist__done::before {
  content: '✓' !important;
  color: var(--cr-lime) !important;
}

.labs-checklist__progress {
  color: var(--cr-on-surface) !important;
}
.labs-checklist__progress::before {
  content: '◐' !important;
  color: #22D3EE !important;
}

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

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

/* ====== MAP SIMULATION SECTION ====== */


.map-section {
  background: var(--cr-surface-dim);
  padding: var(--space-4xl) 0;
  position: relative;
}

.map-container {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  border: 1px solid var(--cr-glass-border);
  box-shadow: var(--shadow-lg);
}

/* ── Map Cinema: Phase overlay system ── */
.map-cinema {
  position: relative;
  height: 550px;
}

.map-cinema__globe {
  position: relative;
  z-index: 2;
  height: 100%;
  transition: opacity 1s ease-in-out;
}

.map-cinema__globe.is-hidden {
  opacity: 0;
  pointer-events: none;
  position: absolute;
  inset: 0;
}

.map-cinema__leaflet {
  position: absolute;
  inset: 0;
  z-index: 1;
  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.map-cinema__leaflet.is-visible {
  opacity: 1;
}

#globe-container {
  width: 100%;
  height: 100%;
}

#simulation-map {
  width: 100%;
  height: 100%;
  background: var(--cr-surface);
}

.map-overlay {
  position: absolute;
  top: var(--space-lg);
  left: var(--space-lg);
  z-index: 500;
  background: var(--cr-glass-bg);
  backdrop-filter: var(--cr-glass-blur);
  -webkit-backdrop-filter: var(--cr-glass-blur);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  min-width: 220px;
}

.map-overlay__title {
  font-family: var(--font-heading);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.map-overlay__live {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  font-weight: var(--fw-semibold);
  color: var(--cr-lime);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.map-overlay__live::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--cr-lime);
  border-radius: 50%;
  animation: glowPulse 2s ease-in-out infinite;
}

.map-overlay__stat {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}

.map-overlay__stat:last-child {
  border-bottom: none;
}

.map-overlay__stat-label {
  font-size: var(--fs-xs);
  color: var(--cr-on-surface);
}

.map-overlay__stat-value {
  font-family: var(--font-heading);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  color: var(--cr-lime);
}

/* Map right-side legend */
.map-legend {
  position: absolute;
  bottom: var(--space-lg);
  right: var(--space-lg);
  z-index: 500;
  background: var(--cr-glass-bg);
  backdrop-filter: var(--cr-glass-blur);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  display: flex;
  gap: var(--space-lg);
}

.map-legend__item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-xs);
  color: var(--cr-on-surface);
}

.map-legend__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

.map-legend__dot--origin { background: #22C55E; }
.map-legend__dot--dest { background: #EF4444; }
.map-legend__dot--active { background: var(--cr-lime); animation: glowPulse 2s infinite; }

/* ====== WHY CARRIROAD ====== */
.why-section {
  background: var(--cr-gradient-section);
}

.why-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3xl);
  align-items: center;
}

.why-image {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--cr-surface-high);
}

.why-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.why-image::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(19,19,19,0.4), transparent);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-xl);
}

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

.why-item {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-lg);
  border-radius: var(--radius-lg);
  border: 1px solid var(--cr-glass-border);
  background: rgba(30, 30, 30, 0.5);
  transition: all var(--duration-normal) var(--ease-out);
}

.why-item:hover {
  background: var(--cr-surface-mid);
  border-color: rgba(161, 251, 0, 0.12);
  transform: translateX(8px);
}

.why-item__icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  background: var(--cr-lime-glow);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cr-lime);
  font-size: 1.2rem;
}

.why-item__title {
  font-family: var(--font-heading);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  margin-bottom: var(--space-xs);
}

.why-item__text {
  font-size: var(--fs-small);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
}

/* ====== CTA BANNER ====== */
.cta-banner {
  padding: var(--space-4xl) 0;
  position: relative;
  overflow: hidden;
}

.cta-banner__inner {
  background: var(--cr-surface-mid);
  border: var(--border-glow);
  border-radius: var(--radius-2xl);
  padding: var(--space-3xl) var(--space-2xl);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.cta-banner__inner::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle at 50% 120%, var(--cr-lime-glow) 0%, transparent 50%);
  pointer-events: none;
}

.cta-banner h2 {
  position: relative;
  margin-bottom: var(--space-md);
}

.cta-banner p {
  position: relative;
  max-width: 500px;
  margin: 0 auto var(--space-xl);
}

.cta-banner .btn {
  position: relative;
}

/* ====== PROCESS GRID ====== */
.process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
  margin-top: var(--space-2xl);
}

.process-step {
  position: relative;
  text-align: center;
  padding: var(--space-2xl) var(--space-lg);
  background: var(--cr-gradient-card);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-xl);
  transition: all 0.3s ease;
}

.process-step:hover {
  border-color: rgba(161, 251, 0, 0.12);
  transform: translateY(-4px);
}

.process-step__number {
  width: 56px;
  height: 56px;
  background: var(--cr-lime-glow);
  border: 1px solid rgba(161, 251, 0, 0.15);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-lg);
  font-family: var(--font-heading);
  font-size: var(--fs-h3);
  font-weight: 700;
  color: var(--cr-lime);
}

.process-step__title {
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--cr-white);
  margin-bottom: var(--space-sm);
}

.process-step__text {
  font-size: var(--fs-small);
  color: var(--cr-on-surface);
  line-height: 1.6;
}

/* ====== FLEET IMAGE BANNER ====== */
.fleet-banner {
  width: 100%;
  height: 300px;
  overflow: hidden;
  position: relative;
}

.fleet-banner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.6);
}

.fleet-banner::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, var(--cr-surface) 0%, transparent 30%, transparent 70%, var(--cr-surface-dim) 100%);
}

/* ====== CONTACT PAGE ====== */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--space-3xl);
  align-items: start;
}

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

.contact-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-lg);
  background: var(--cr-gradient-card);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-lg);
  transition: all var(--duration-normal) var(--ease-out);
}

.contact-item:hover {
  border-color: rgba(161, 251, 0, 0.12);
  transform: translateX(4px);
}

.contact-item__icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  background: var(--cr-lime-glow);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cr-lime);
}

.contact-item__label {
  font-size: var(--fs-xs);
  color: var(--cr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 2px;
}

.contact-item__value {
  color: var(--cr-white);
  font-weight: var(--fw-medium);
}

/* Contact Form — editorial "no box" inputs (bottom border only) */
.contact-form {
  background: var(--cr-gradient-card);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
}

.form-group {
  margin-bottom: var(--space-lg);
}

.form-label {
  display: block;
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--cr-on-surface);
  margin-bottom: var(--space-sm);
}

.form-input,
.form-textarea {
  width: 100%;
  padding: 14px 18px;
  background: var(--cr-surface);
  border: none;
  border-bottom: 2px solid var(--cr-outline);
  border-radius: var(--radius-sm);
  color: var(--cr-white);
  font-size: var(--fs-body);
  transition: all var(--duration-normal) var(--ease-out);
}

.form-input:focus,
.form-textarea:focus {
  border-bottom-color: var(--cr-lime);
  box-shadow: 0 2px 0 0 rgba(161, 251, 0, 0.3);
}

.form-textarea {
  min-height: 140px;
  resize: vertical;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}

/* ====== ABOUT PAGE ====== */
.about-hero {
  padding: calc(var(--nav-height) + var(--space-4xl)) 0 var(--space-3xl);
  background: var(--cr-gradient-hero);
  position: relative;
  overflow: hidden;
}

.about-hero__content {
  max-width: 700px;
  position: relative;
  z-index: 2;
}

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

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

/* ====== PAGE HERO (Subpages) ====== */
.page-hero {
  padding: calc(var(--nav-height) + var(--space-4xl)) 0 var(--space-3xl);
  background: var(--cr-gradient-hero);
  position: relative;
  overflow: hidden;
  text-align: center;
}

.page-hero h1 {
  margin-bottom: var(--space-md);
}

.page-hero p {
  max-width: 600px;
  margin: 0 auto;
}

/* ====== COLD CHAIN DEDICATED SECTION ====== */
.cold-chain-section {
  background: linear-gradient(180deg, var(--cr-surface) 0%, #0A1520 100%);
  position: relative;
}

.cold-chain-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3xl);
  align-items: center;
}

.cold-chain-visual {
  background: rgba(6, 182, 212, 0.04);
  border: 1px solid rgba(6, 182, 212, 0.1);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  position: relative;
}

.cold-chain-ranges {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}

.cold-range {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md);
  background: rgba(6, 182, 212, 0.06);
  border-radius: var(--radius-md);
  border: 1px solid rgba(6, 182, 212, 0.08);
}

.cold-range__temp {
  font-family: var(--font-heading);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: #06B6D4;
  min-width: 80px;
}

.cold-range__label {
  font-size: var(--fs-small);
  color: var(--cr-white);
  font-weight: var(--fw-medium);
}

.cold-range__desc {
  font-size: var(--fs-xs);
  color: var(--cr-on-surface);
}

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

  .why-grid,
  .cold-chain-grid {
    gap: var(--space-2xl);
  }

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

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

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

  .labs-cell--featured {
    grid-column: span 2;
  }

  #simulation-map {
    height: 400px;
  }
}

@media (max-width: 768px) {
  /* Kill decorative elements that cause horizontal overflow on real mobile */
  .labs-teaser__glow,
  .labs-hero__bg::after,
  .hero__orb,
  .hero__grid-lines {
    display: none !important;
  }

  .labs-section::before {
    display: none;
  }

  /* Ensure all sections clip their content on mobile */
  .section,
  .labs-section,
  .why-section,
  .cta-banner,
  .stats-bar {
    overflow: hidden;
  }

  .hero {
    min-height: auto;
    padding: calc(var(--nav-height) + var(--space-3xl)) 0 var(--space-3xl);
  }

  .hero__title {
    font-size: clamp(2rem, 8vw, 3rem);
  }

  .hero__actions {
    flex-direction: column;
    align-items: flex-start;
  }

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

  .stats-bar .stat:not(:last-child)::after {
    display: none;
  }

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

  .labs-cell--featured {
    grid-column: span 1;
  }

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

  .why-image {
    order: -1;
  }

  .values-grid,
  .advantages-grid {
    grid-template-columns: 1fr;
  }

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

  .cta-banner__inner {
    padding: var(--space-2xl) var(--space-lg);
  }

  /* Process grid — collapse to 2 columns on mobile */
  .process-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Prevent reveal animations from causing horizontal overflow on mobile */
  .reveal-left, .reveal-right {
    opacity: 0;
    transform: translateY(30px) !important;
  }
  .reveal-left.visible, .reveal-right.visible {
    opacity: 1;
    transform: translateY(0) !important;
  }

  /* Clip the contact map wrapper to prevent Leaflet tile overflow */
  .contact-map-wrapper,
  [id="contactMapWrapper"] {
    overflow: hidden;
    max-width: 100%;
  }

  #simulation-map {
    height: 350px;
  }

  .map-overlay {
    position: relative;
    top: auto;
    left: auto;
    border-radius: 0;
    border-radius: 0 0 var(--radius-xl) var(--radius-xl);
    min-width: auto;
  }

  .map-legend {
    position: relative;
    bottom: auto;
    right: auto;
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    justify-content: center;
  }
}

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

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

/* ====== NETWORK / ALIADOS ====== */
.network-section {
  padding: var(--space-4xl) 0;
  background: var(--cr-bg);
  border-top: 1px solid var(--cr-glass-border);
}

/* Collapsed Card — Initial State */
.network-collapsed {
  background: var(--cr-surface-high);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-2xl);
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  transition: all 0.4s ease;
  margin-top: var(--space-2xl);
  user-select: none;
}

.network-collapsed:hover {
  border-color: rgba(161, 251, 0, 0.25);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.network-collapsed__left {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
}

.network-collapsed__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  background: rgba(161, 251, 0, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.network-collapsed__text h3 {
  font-family: var(--font-heading);
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  margin-bottom: 2px;
}

.network-collapsed__text span {
  font-size: var(--fs-xs);
  color: var(--cr-text-muted);
}

.network-collapsed__hint {
  font-size: var(--fs-xs);
  color: var(--cr-text-muted);
  display: flex;
  align-items: center;
  gap: 6px;
  opacity: 0.6;
  transition: opacity 0.3s;
}

.network-collapsed:hover .network-collapsed__hint {
  opacity: 1;
  color: var(--cr-lime);
}

.network-collapsed__badge {
  font-family: var(--font-heading);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--cr-lime);
  padding: 6px 14px;
  background: rgba(161, 251, 0, 0.08);
  border: 1px solid rgba(161, 251, 0, 0.15);
  border-radius: 20px;
  white-space: nowrap;
}

/* Carousel — Expanded State */
.network-carousel {
  margin-top: var(--space-xl);
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 0.6s cubic-bezier(0.4,0,0.2,1), opacity 0.4s ease;
}

.network-section.is-expanded .network-carousel {
  max-height: 400px;
  opacity: 1;
}

.network-section.is-expanded .network-collapsed__hint svg {
  transform: rotate(180deg);
}

.network-track {
  display: flex;
  gap: var(--space-lg);
  animation: networkScroll 18s linear infinite;
  width: max-content;
}

.network-section.is-expanded:hover .network-track,
.network-track:hover {
  animation-play-state: paused;
}

@keyframes networkScroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.network-card {
  background: var(--cr-surface-high);
  border: 1px solid var(--cr-glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-2xl);
  text-align: center;
  transition: all 0.3s ease;
  min-width: 220px;
  flex-shrink: 0;
}

.network-card:hover {
  border-color: rgba(161, 251, 0, 0.2);
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
}

.network-card__icon {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-md);
  background: rgba(161, 251, 0, 0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-md);
  transition: all 0.3s ease;
}

.network-card:hover .network-card__icon {
  background: rgba(161, 251, 0, 0.12);
  transform: scale(1.1);
}

.network-card__name {
  font-family: var(--font-heading);
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  margin-bottom: var(--space-xs);
}

.network-card__desc {
  font-size: var(--fs-xs);
  color: var(--cr-text-muted);
  line-height: var(--lh-relaxed);
}

@media (max-width: 768px) {
  .network-collapsed {
    flex-direction: column;
    text-align: center;
    gap: var(--space-md);
  }
  .network-collapsed__left {
    flex-direction: column;
  }
  .network-card {
    min-width: 180px;
    padding: var(--space-lg);
  }
}

@media (max-width: 480px) {
  .network-card {
    min-width: 160px;
  }
}

/* ====== LEGAL PAGES ====== */
.legal-page {
  padding: calc(var(--nav-height) + var(--space-3xl)) 0 var(--space-4xl);
  background: var(--cr-surface);
  min-height: 100vh;
}

.legal-page__header {
  text-align: center;
  margin-bottom: var(--space-3xl);
  padding-bottom: var(--space-2xl);
  border-bottom: var(--border-ghost);
}

.legal-page__tag {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--cr-lime);
  background: var(--cr-lime-glow);
  border: 1px solid rgba(161, 251, 0, 0.15);
  padding: 6px 18px;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-lg);
}

.legal-page__title {
  font-family: var(--font-heading);
  font-size: var(--fs-h1);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  margin-bottom: var(--space-md);
}

.legal-page__updated {
  font-size: var(--fs-small);
  color: var(--cr-text-muted);
}

.legal-content {
  max-width: 820px;
  margin: 0 auto;
}

.legal-content h2 {
  font-family: var(--font-heading);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--cr-white);
  margin: var(--space-2xl) 0 var(--space-md);
  padding-top: var(--space-xl);
  border-top: var(--border-ghost);
}

.legal-content h2:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

.legal-content p {
  font-size: var(--fs-body);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-md);
}

.legal-content ul {
  list-style: none;
  padding: 0;
  margin-bottom: var(--space-md);
}

.legal-content ul li {
  position: relative;
  padding-left: var(--space-lg);
  font-size: var(--fs-body);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-sm);
}

.legal-content ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 10px;
  width: 6px;
  height: 6px;
  background: var(--cr-lime);
  border-radius: 50%;
}

.legal-content ol {
  padding-left: var(--space-lg);
  margin-bottom: var(--space-md);
}

.legal-content ol li {
  font-size: var(--fs-body);
  color: var(--cr-on-surface);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-sm);
}

.legal-content strong {
  color: var(--cr-white);
  font-weight: var(--fw-semibold);
}

.legal-content a {
  color: var(--cr-lime);
  transition: opacity var(--duration-fast) var(--ease-out);
}

.legal-content a:hover {
  opacity: 0.8;
}

.legal-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-2xl);
  padding: var(--space-lg);
  background: var(--cr-surface-mid);
  border-radius: var(--radius-lg);
  border: 1px solid var(--cr-glass-border);
}

.legal-nav a {
  font-size: var(--fs-small);
  color: var(--cr-on-surface);
  padding: 6px 16px;
  border-radius: var(--radius-full);
  transition: all var(--duration-fast) var(--ease-out);
  text-decoration: none;
  border: 1px solid transparent;
}

.legal-nav a:hover,
.legal-nav a.active {
  color: var(--cr-lime);
  background: var(--cr-lime-glow);
  border-color: rgba(161, 251, 0, 0.15);
}

/* ====== MODO ALTO CONTRASTE — WCAG AA ====== */
/* Activado via toggle: html[data-contrast="high"]    */
/* Mantiene identidad de marca pero ajusta contraste  */
/* para cumplir requisito 4.5:1 en TODOS los textos   */

html[data-contrast="high"] .legal-content p,
html[data-contrast="high"] .legal-content ul li,
html[data-contrast="high"] .legal-content ol li {
  color: #D0D0D0;
}

html[data-contrast="high"] .section-header p,
html[data-contrast="high"] .hero__subtitle,
html[data-contrast="high"] .service-card__desc,
html[data-contrast="high"] .network-card__desc,
html[data-contrast="high"] .testimonial-card__text {
  color: #C8C8C8;
}

html[data-contrast="high"] .map-overlay__stat-label,
html[data-contrast="high"] .footer__desc,
html[data-contrast="high"] .footer__link {
  color: #BFBFBF;
}

/* Accessibility Toggle Button */
.a11y-toggle {
  position: fixed;
  bottom: 80px;
  left: 20px;
  z-index: 998;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--cr-surface-high);
  border: 1px solid var(--cr-glass-border);
  color: var(--cr-on-surface);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  opacity: 0.6;
}

.a11y-toggle:hover {
  opacity: 1;
  border-color: rgba(161, 251, 0, 0.3);
  transform: scale(1.1);
}

.a11y-toggle--active {
  opacity: 1;
  background: var(--cr-lime);
  color: var(--cr-on-primary);
  border-color: var(--cr-lime);
}

.a11y-toggle svg {
  width: 18px;
  height: 18px;
}
