/* ============================================================
   ECOPLAGAS DE MÉXICO — Sistema de Diseño Eco Editorial v1
   Verde marca #69b42e × Mangogrotesque + Barlow × Kit Craft v1.1
   ============================================================ */

/* ============================================================
   FUENTES
   ============================================================ */
@font-face {
  font-family: 'Mangogrotesque';
  src: url('../fonts/MangoGrotesque-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  /* Marca Ecoplagas */
  --eco-green:        #69b42e;
  --eco-green-deep:   #4a8a1f;
  --eco-green-soft:   #f0f7e8;
  --gris-marca:       #7e8484;
  --gris-soft:        #e5e8e3;

  /* Neutros editorial */
  --bg:               #FFFFFF;
  --bg-soft:          #FBFBF8;
  --ink:              #0F1614;
  --ink-soft:         #3D4541;
  --ink-muted:        #6B7570;
  --line:             #E8EAE5;

  /* Acentos */
  --accent-amber:     #C5A467;
  --alert:            #B83A3A;

  /* Sombras */
  --shadow-card:      0 1px 3px rgba(15, 22, 20, 0.04), 0 8px 24px rgba(15, 22, 20, 0.06);
  --shadow-hover:     0 4px 12px rgba(105, 180, 46, 0.12), 0 12px 32px rgba(15, 22, 20, 0.08);
  --shadow-cta:       0 4px 14px rgba(105, 180, 46, 0.25);

  /* Easings Kit Craft */
  --ease-out-expo:    cubic-bezier(.22,1,.36,1);
  --ease-out-quart:   cubic-bezier(.25,1,.5,1);

  /* Duraciones */
  --dur-fast:         240ms;
  --dur-base:         600ms;
  --dur-slow:         900ms;

  /* Spacing 8-pt */
  --space-1:  0.5rem;
  --space-2:  1rem;
  --space-3:  1.5rem;
  --space-4:  2rem;
  --space-5:  3rem;
  --space-6:  4rem;
  --space-7:  6rem;
  --space-8:  8rem;
  --space-9:  10rem;

  /* Container */
  --container-max:    1280px;
  --container-pad:    clamp(1.4rem, 4vw, 2.5rem);

  /* Border radius (editorial = casi nada) */
  --radius-sm:        4px;
  --radius-md:        8px;
  --radius-lg:        16px;

  /* Tipografía */
  --font-display:     'Mangogrotesque', Arial, sans-serif;
  --font-body:        'Barlow', system-ui, sans-serif;
}

/* ============================================================
   RAPTOR LIB 00 — A11Y MOTION BASE
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ============================================================
   RESET + BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
*::selection { background: var(--eco-green); color: #FFFFFF; }

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.65;
  color: var(--ink-soft);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  min-height: 100vh;
}

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

a {
  color: var(--eco-green-deep);
  text-decoration: none;
  transition: color var(--dur-fast);
}
a:hover { color: var(--eco-green); }

ul, ol { list-style-position: inside; }

/* RAPTOR LIB 07 — View Transitions */
@view-transition { navigation: auto; }
::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 320ms;
  animation-timing-function: var(--ease-out-quart);
}

/* ============================================================
   TIPOGRAFÍA
   ============================================================ */
h1.fat, .h1-hero {
  font-family: var(--font-display);
  font-size: clamp(3.2rem, 10vw, 8.5rem);
  font-weight: 700;
  line-height: 0.88;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  color: var(--ink);
}
.h1-hero .accent-line { color: var(--eco-green); display: block; }

h1 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 6vw, 5rem);
  font-weight: 700;
  line-height: 0.9;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--ink);
}

h2 {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4.5vw, 3.5rem);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: var(--ink);
}

h3 {
  font-family: var(--font-body);
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--ink);
  letter-spacing: -0.005em;
}

h4 {
  font-family: var(--font-body);
  font-size: 1.05rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--ink);
}

p { margin-bottom: var(--space-2); }
p.lead {
  font-size: clamp(1.15rem, 1.6vw, 1.35rem);
  line-height: 1.55;
  color: var(--ink);
  font-weight: 400;
}

.eyebrow {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--eco-green);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}

.caption {
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--ink-muted);
}

small, .small { font-size: 0.8rem; color: var(--ink-muted); }

.num-tech {
  font-feature-settings: 'tnum';
  font-variant-numeric: tabular-nums;
}

blockquote {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--eco-green);
  text-transform: none;
  padding-left: var(--space-4);
  border-left: 3px solid var(--eco-green);
  margin: var(--space-6) 0;
}
blockquote cite {
  display: block;
  margin-top: var(--space-2);
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: var(--ink-muted);
  font-style: normal;
}

.teo-quote {
  margin: var(--space-7) auto;
  max-width: 720px;
  text-align: center;
  border: none;
  padding: 0;
}
.teo-quote p::before { content: '\201C'; color: var(--eco-green); margin-right: 0.2em; }
.teo-quote p::after  { content: '\201D'; color: var(--eco-green); margin-left: 0.2em; }

/* ============================================================
   LAYOUT
   ============================================================ */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
}
.container-narrow {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 var(--container-pad);
}

section { padding: var(--space-8) 0; }
.section-lg     { padding: var(--space-9) 0; }
.section-tight  { padding: var(--space-6) 0; }
.section-alt    { background: var(--bg-soft); }

@media (max-width: 768px) {
  section        { padding: var(--space-6) 0; }
  .section-lg    { padding: var(--space-7) 0; }
  .section-tight { padding: var(--space-5) 0; }
}

/* ============================================================
   HEADER TRANSPARENTE — Kit Craft 13
   ============================================================ */
.header-transparent {
  position: absolute;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: transparent;
  padding: 1.25rem 0;
  transition: background var(--dur-fast) var(--ease-out-expo);
}
.header-transparent.scrolled,
.header-transparent.is-open {
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 var(--line);
}
/* Hover solo activa background si el header NO está en modo dark (cuando hay imagen oscura detrás) */
.header-transparent:not(.on-dark):hover {
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 var(--line);
}

/* Header on-dark — sobre hero con imagen oscura: texto blanco, logo invertido */
.header-transparent.on-dark .nav-links a { color: #FFFFFF; }
.header-transparent.on-dark .nav-links a:hover,
.header-transparent.on-dark .nav-links a.active { color: var(--eco-green); }
.header-transparent.on-dark .logo img {
  filter: brightness(0) invert(1);
  transition: filter var(--dur-fast) var(--ease-out-expo);
}
.header-transparent.on-dark .menu-toggle {
  color: #FFFFFF;
  border-color: rgba(255, 255, 255, 0.5);
}

/* Cuando el header on-dark hace scroll, vuelve a colores normales sobre fondo blanco */
.header-transparent.on-dark.scrolled .nav-links a { color: var(--ink); }
.header-transparent.on-dark.scrolled .nav-links a:hover,
.header-transparent.on-dark.scrolled .nav-links a.active { color: var(--eco-green); }
.header-transparent.on-dark.scrolled .logo img { filter: none; }
.header-transparent.on-dark.scrolled .menu-toggle {
  color: var(--ink);
  border-color: var(--ink);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

.logo { display: inline-flex; align-items: center; }
.logo img { height: 60px; width: auto; }

.nav-links {
  display: flex;
  gap: var(--space-4);
  list-style: none;
  align-items: center;
}
.nav-links a {
  color: var(--ink);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  text-decoration: none;
  transition: color var(--dur-fast);
}
.nav-links a:hover,
.nav-links a.active { color: var(--eco-green); }

.btn-cta-header {
  display: inline-block;
  background: var(--eco-green);
  color: #FFFFFF;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9rem;
  padding: 0.65rem 1.2rem;
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: background var(--dur-fast), transform var(--dur-fast);
}
.btn-cta-header:hover {
  background: var(--eco-green-deep);
  color: #FFFFFF;
  transform: translateY(-1px);
}

.menu-toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--ink);
  border-radius: var(--radius-sm);
  padding: 0.5rem 0.75rem;
  cursor: pointer;
  font-size: 1.2rem;
  color: var(--ink);
}

@media (max-width: 900px) {
  .nav-links { display: none; }
  .nav-links.is-open {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(12px);
    padding: var(--space-3) var(--container-pad);
    gap: var(--space-2);
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
  }
  .nav-links.is-open a { padding: 0.5rem 0; }
  .menu-toggle { display: inline-block; }
  .btn-cta-header { padding: 0.55rem 1rem; font-size: 0.85rem; }
}

@media (max-width: 480px) {
  .logo img { height: 48px; }
  .btn-cta-header { font-size: 0.8rem; padding: 0.5rem 0.85rem; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  padding: clamp(6.5rem, 11vh, 8rem) 0 var(--space-5);
  position: relative;
  overflow: hidden;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
}
@media (max-width: 900px) {
  .hero-grid { grid-template-columns: 1fr; gap: var(--space-5); }
}

.hero-text { display: flex; flex-direction: column; }
.hero-sub { margin-top: var(--space-3); max-width: 56ch; }

/* Hero con imagen de fondo (home) — estilo Metropolitan, texto blanco sobre overlay oscuro */
.hero-with-bg {
  min-height: clamp(620px, 92vh, 880px);
  display: flex;
  align-items: flex-end;
  padding-top: clamp(7rem, 12vh, 9rem);
  padding-bottom: clamp(2.5rem, 5vh, 4rem);
  color: #FFFFFF;
}
.hero-with-bg .hero-bg {
  position: absolute;
  inset: 0;
  background-image: url('/img/hero-prueba-exoplagas.webp');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
  will-change: transform;
}
/* Overlay oscuro semi-transparente — Metropolitan style */
.hero-with-bg .hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg,
      rgba(0, 0, 0, 0.55) 0%,
      rgba(0, 0, 0, 0.40) 40%,
      rgba(0, 0, 0, 0.55) 80%,
      rgba(0, 0, 0, 0.70) 100%);
  z-index: 1;
}
.hero-with-bg .hero-content {
  position: relative;
  z-index: 2;
  width: 100%;
}
.hero-with-bg .hero-text {
  max-width: 62%;
}
.hero-with-bg::before { display: none; } /* Quitamos el noise CSS — la imagen ya da el efecto */

/* Texto blanco sobre overlay oscuro */
.hero-with-bg h1.fat,
.hero-with-bg .h1-hero { color: #FFFFFF; }
.hero-with-bg h1.fat .accent-line {
  color: var(--eco-green);
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.35);
}
.hero-with-bg .hero-sub { color: rgba(255, 255, 255, 0.95); }
.hero-with-bg .hero-sub strong { color: #FFFFFF; font-weight: 600; }
.hero-with-bg .eyebrow {
  color: #FFFFFF;
  opacity: 0.85;
}
.hero-with-bg .eyebrow span:first-child::before {
  background: var(--eco-green);
}

/* Trust strip blanco */
.hero-with-bg .trust-strip {
  color: rgba(255, 255, 255, 0.85);
  border-top-color: rgba(255, 255, 255, 0.20);
}
.hero-with-bg .trust-strip strong { color: #FFFFFF; font-weight: 600; }

/* Botón secundario invertido (outline blanco) */
.hero-with-bg .btn-secondary {
  background: transparent;
  border-color: #FFFFFF;
  color: #FFFFFF;
}
.hero-with-bg .btn-secondary:hover {
  background: #FFFFFF;
  color: var(--ink);
}

@media (max-width: 900px) {
  .hero-with-bg .hero-text { max-width: 100%; }
  .hero-with-bg .hero-overlay {
    background:
      linear-gradient(180deg,
        rgba(0, 0, 0, 0.55) 0%,
        rgba(0, 0, 0, 0.45) 50%,
        rgba(0, 0, 0, 0.65) 100%);
  }
  .hero-with-bg .hero-bg {
    background-position: center 60%;
  }
}

@media (max-width: 640px) {
  .hero-with-bg { min-height: clamp(560px, 88vh, 720px); }
}

.star-badge {
  display: inline-block;
  background: var(--eco-green);
  color: #FFFFFF;
  padding: 0.35rem 0.8rem;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  font-weight: 700;
  text-transform: uppercase;
}

.hero-ctas {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-4);
  flex-wrap: wrap;
}

@media (max-width: 640px) {
  .hero-ctas { flex-direction: column; align-items: stretch; }
  .hero-ctas .btn-primary,
  .hero-ctas .btn-secondary { width: 100%; text-align: center; }
}

.hero-aside { display: flex; align-items: stretch; }

/* RAPTOR LIB 11 — Noise sutil sobre hero */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.12  0 0 0 0 0.31  0 0 0 0 0.22  0 0 0 0.45 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: .05;
  mix-blend-mode: multiply;
  pointer-events: none;
  z-index: -1;
}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid var(--line);
  font-size: 0.85rem;
  color: var(--ink-muted);
  align-items: center;
}
.trust-strip strong { color: var(--ink); font-weight: 600; }
.trust-strip > span {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

@media (max-width: 640px) {
  .trust-strip { gap: var(--space-2); font-size: 0.78rem; }
}

/* ============================================================
   BOTONES
   ============================================================ */

/* Primario verde con shimmer (Kit Craft 04) */
.btn-primary {
  display: inline-block;
  background: var(--eco-green);
  color: #FFFFFF;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: 0.02em;
  padding: 1.1rem 2rem;
  text-decoration: none;
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-cta);
  transition: background var(--dur-fast), transform var(--dur-fast), box-shadow var(--dur-fast);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border: 0;
  cursor: pointer;
  text-align: center;
}
.btn-primary:hover {
  background: var(--eco-green-deep);
  color: #FFFFFF;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(105, 180, 46, 0.32);
}
.btn-primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 20%, rgba(255,255,255,.25) 50%, transparent 80%);
  transform: translateX(-110%);
  transition: transform .9s var(--ease-out-expo);
  z-index: -1;
  pointer-events: none;
}
.btn-primary:hover::before { transform: translateX(110%); }

/* Secundario outline */
.btn-secondary {
  display: inline-block;
  background: transparent;
  color: var(--ink);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 1rem;
  padding: 1.05rem 2rem;
  border: 1px solid var(--ink);
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: all var(--dur-fast);
  text-align: center;
}
.btn-secondary:hover {
  background: var(--ink);
  color: #FFFFFF;
}

/* Link arrow editorial */
.cta-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--eco-green);
  text-decoration: none;
  border-bottom: 1px solid var(--eco-green);
  padding-bottom: 0.15rem;
  transition: gap var(--dur-fast);
}
.cta-arrow .arr {
  display: inline-block;
  transition: transform var(--dur-fast);
}
.cta-arrow:hover { color: var(--eco-green-deep); }
.cta-arrow:hover .arr { transform: translateX(4px); }

/* ============================================================
   CARDS (servicios, plagas, posts)
   ============================================================ */
.service-card {
  background: #FFFFFF;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  transition: border-color var(--dur-base) var(--ease-out-expo),
              box-shadow var(--dur-base) var(--ease-out-expo),
              transform var(--dur-base) var(--ease-out-expo);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.service-card:hover {
  border-color: var(--eco-green);
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}
.service-card .icon-wrap {
  width: 64px;
  height: 64px;
  margin-bottom: var(--space-2);
  color: var(--eco-green);
}
.service-card .cta-arrow { margin-top: auto; padding-top: var(--space-2); }

/* Badge "Servicio Estrella" solo en termitas */
.service-card.is-star {
  border-top: 3px solid var(--eco-green);
}
.service-card.is-star::before {
  content: '★ SERVICIO ESTRELLA';
  position: absolute;
  top: -10px;
  left: var(--space-3);
  background: var(--eco-green);
  color: #FFFFFF;
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  font-weight: 700;
  padding: 0.25rem 0.7rem;
  border-radius: 2px;
}

/* Grid de servicios */
.services-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-3);
}

/* Grid editorial con romanos */
.services-grid h2 { margin-bottom: var(--space-7); max-width: 18ch; }
.service-row {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--space-5);
  padding: var(--space-5) 0;
  border-top: 1px solid var(--line);
  align-items: start;
}
.services-grid .service-row:last-child { border-bottom: 1px solid var(--line); }
.service-roman span {
  font-family: var(--font-display);
  font-size: clamp(4rem, 10vw, 8rem);
  font-weight: 700;
  line-height: 0.85;
  color: var(--eco-green);
  letter-spacing: -0.02em;
}
.service-body .badge-star {
  display: inline-block;
  background: var(--eco-green);
  color: #FFFFFF;
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  font-weight: 700;
  padding: 0.25rem 0.7rem;
  text-transform: uppercase;
  margin-bottom: var(--space-2);
  border-radius: 2px;
}
.service-body h3 { margin-bottom: var(--space-2); }
.service-body p { margin-bottom: var(--space-3); max-width: 60ch; }

@media (max-width: 768px) {
  .service-row { grid-template-columns: 1fr; gap: var(--space-2); }
  .service-roman span { font-size: clamp(3rem, 14vw, 4.5rem); }
}

/* ============================================================
   FAQ ACORDEÓN
   ============================================================ */
.faq { padding-top: var(--space-5); }
.faq h2 { margin-bottom: var(--space-5); }
.faq-list { max-width: 880px; margin: 0 auto; }
.faq-item {
  border-bottom: 1px solid var(--line);
  padding: var(--space-3) 0;
}
.faq-item summary {
  cursor: pointer;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--ink);
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-1) 0;
  transition: color var(--dur-fast);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '+';
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--eco-green);
  transition: transform var(--dur-fast);
  flex-shrink: 0;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item[open] summary { color: var(--eco-green); }
.faq-item > div,
.faq-item > p { padding-top: var(--space-2); }
.faq-item p { color: var(--ink-soft); line-height: 1.7; margin-bottom: 0; }

/* ============================================================
   MARQUEE — Kit Craft 09
   ============================================================ */
.marquee-section {
  padding: var(--space-5) 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--bg-soft);
  overflow: hidden;
}
.marquee { overflow: hidden; width: 100%; }
.marquee-track {
  display: flex;
  gap: 3rem;
  width: max-content;
  animation: marqueeScroll 40s linear infinite;
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  text-transform: uppercase;
  letter-spacing: -0.005em;
  color: var(--ink);
  white-space: nowrap;
  align-items: center;
}
.marquee-track span:nth-child(odd):not(.dot) { color: var(--ink); }
.marquee-track .dot {
  color: var(--eco-green);
  font-size: 0.6em;
}
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes marqueeScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation: none; flex-wrap: wrap; justify-content: center; }
}

/* ============================================================
   PLACEHOLDERS DE FOTO
   ============================================================ */
.photo-placeholder {
  background: linear-gradient(135deg, var(--eco-green-soft) 0%, var(--gris-soft) 100%);
  border: 2px dashed var(--eco-green);
  border-radius: var(--radius-md);
  aspect-ratio: 16/9;
  display: grid;
  place-items: center;
  text-align: center;
  padding: var(--space-3);
  width: 100%;
  position: relative;
}
.photo-placeholder.aspect-4-5 { aspect-ratio: 4/5; }
.photo-placeholder.aspect-1-1 { aspect-ratio: 1/1; }
.placeholder-label { max-width: 320px; }
.placeholder-label strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: var(--eco-green-deep);
  letter-spacing: 0.1em;
}
.placeholder-label span {
  display: block;
  margin: var(--space-2) 0 var(--space-1);
  color: var(--ink);
  font-weight: 500;
  line-height: 1.4;
}
.placeholder-label small {
  color: var(--ink-muted);
  font-size: 0.75rem;
  display: block;
}

/* ============================================================
   STATS / NÚMEROS DESTACADOS
   ============================================================ */
.stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-4);
  margin: var(--space-6) 0;
}
.stat {
  text-align: center;
  padding: var(--space-3);
  border-top: 2px solid var(--eco-green);
}
.stat .stat-num {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 700;
  line-height: 1;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.stat .stat-label {
  display: block;
  margin-top: var(--space-2);
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-weight: 600;
}

/* ============================================================
   FOOTER
   ============================================================ */
footer {
  background: var(--ink);
  color: rgba(255,255,255,0.85);
  padding: var(--space-7) 0 var(--space-5);
}
footer h4 { color: #FFFFFF; margin-bottom: var(--space-3); font-size: 0.85rem; letter-spacing: 0.15em; text-transform: uppercase; }
footer a {
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  transition: color var(--dur-fast);
  display: inline-block;
  padding: 0.2rem 0;
}
footer a:hover { color: var(--eco-green); }
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--space-5);
}
.footer-brand-block h3 {
  font-family: var(--font-display);
  color: #FFFFFF;
  font-size: 1.4rem;
  text-transform: uppercase;
  margin-bottom: var(--space-2);
}
.footer-brand-block p {
  color: rgba(255,255,255,0.6);
  font-size: 0.9rem;
  line-height: 1.6;
  max-width: 36ch;
}
.footer-list { list-style: none; padding: 0; }
.footer-list li a { font-size: 0.9rem; }
.footer-social {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-3);
}
.footer-social a {
  font-size: 0.85rem;
  padding: 0.4rem 0.8rem;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-sm);
}
.footer-social a:hover {
  border-color: var(--eco-green);
  color: var(--eco-green);
}

.footer-bottom {
  margin-top: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255,255,255,0.1);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.82rem;
  color: rgba(255,255,255,0.5);
  flex-wrap: wrap;
  gap: var(--space-2);
}

@media (max-width: 900px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .footer-grid { grid-template-columns: 1fr; gap: var(--space-4); }
  .footer-bottom { flex-direction: column; text-align: center; }
}

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb {
  font-size: 0.82rem;
  color: var(--ink-muted);
  margin-bottom: var(--space-3);
  letter-spacing: 0.03em;
}
.breadcrumb a { color: var(--ink-muted); text-decoration: none; }
.breadcrumb a:hover { color: var(--eco-green); }
.breadcrumb .sep { margin: 0 0.5em; opacity: 0.5; }

/* ============================================================
   GOOGLE MAPS IFRAME
   ============================================================ */
.gmaps-wrap {
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  margin-top: var(--space-3);
}
.gmaps-iframe {
  display: block;
  width: 100%;
  height: 450px;
  border: 0;
}
@media (max-width: 768px) { .gmaps-iframe { height: 380px; } }
@media (max-width: 640px) { .gmaps-iframe { height: 320px; } }
@media (max-width: 480px) { .gmaps-iframe { height: 280px; } }

/* ============================================================
   NAP BLOCK
   ============================================================ */
.nap-block {
  background: var(--bg-soft);
  border-left: 3px solid var(--eco-green);
  padding: var(--space-3) var(--space-4);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.nap-block dt {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  color: var(--ink-muted);
  text-transform: uppercase;
  margin-top: var(--space-2);
}
.nap-block dt:first-child { margin-top: 0; }
.nap-block dd {
  font-family: var(--font-body);
  color: var(--ink);
  font-size: 1rem;
  margin: 0.25rem 0 0;
  font-weight: 500;
}
.nap-block a { color: var(--ink); font-weight: 500; }
.nap-block a:hover { color: var(--eco-green); }

/* ============================================================
   RAPTOR LIB 01 — REVEALS ON SCROLL
   ============================================================ */
[data-reveal] {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity .9s var(--ease-out-expo),
              transform .9s var(--ease-out-expo);
  transition-delay: calc(var(--reveal-delay, 0) * 1ms);
  will-change: opacity, transform;
}
[data-reveal].is-in {
  opacity: 1;
  transform: none;
}
@supports (animation-timeline: view()) {
  [data-reveal]:not(.is-in) {
    animation: revealIn linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 60%;
    transition: none;
  }
}
@keyframes revealIn {
  from { opacity: 0; transform: translateY(32px); }
  to   { opacity: 1; transform: none; }
}

/* ============================================================
   RAPTOR LIB 03 — ICONOS SVG CON ANIMACIÓN CONTEXTUAL
   Cada icono lleva animación propia que representa su función.
   ============================================================ */

/* Lupa "auditoría sin costo" → zoom cíclico */
.icon-lupa { width: 64px; height: 64px; }
.icon-lupa .lente {
  transform-origin: center;
  animation: lupaZoom 3.6s ease-in-out infinite;
}
@keyframes lupaZoom {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.15); }
}

/* Documento Carta Garantía → líneas que se autorrellenan */
.icon-doc { width: 64px; height: 64px; }
.icon-doc .linea {
  stroke-dasharray: 60;
  stroke-dashoffset: 60;
  animation: docRellenar 2.4s ease-out infinite;
}
.icon-doc .linea:nth-of-type(2) { animation-delay: .25s; }
.icon-doc .linea:nth-of-type(3) { animation-delay: .50s; }
.icon-doc .linea:nth-of-type(4) { animation-delay: .75s; }
@keyframes docRellenar {
  0%        { stroke-dashoffset: 60; }
  60%, 100% { stroke-dashoffset: 0; }
}

/* Escudo REPSE → pulse hacia afuera */
.icon-escudo { width: 64px; height: 64px; }
.icon-escudo .anilla {
  transform-origin: center;
  animation: escudoPulse 2.8s ease-out infinite;
}
@keyframes escudoPulse {
  0%   { transform: scale(1); opacity: 1; }
  100% { transform: scale(1.6); opacity: 0; }
}

/* Estrella reseñas → rotación suave */
.icon-estrella { width: 64px; height: 64px; }
.icon-estrella svg, .icon-estrella .estrella {
  transform-origin: center;
  animation: estrellaRota 8s linear infinite;
}
@keyframes estrellaRota {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* Gota Sanitización → cae y se forma */
.icon-gota { width: 64px; height: 64px; }
.icon-gota .gota {
  transform-origin: center;
  animation: gotaCae 3s ease-in-out infinite;
}
@keyframes gotaCae {
  0%, 100% { transform: translateY(-4px) scale(0.9); }
  50%      { transform: translateY(2px) scale(1); }
}

/* Check Auditoría → se dibuja */
.icon-check { width: 64px; height: 64px; }
.icon-check .check-path {
  stroke-dasharray: 30;
  stroke-dashoffset: 30;
  animation: checkDraw 2.2s ease-out infinite;
}
@keyframes checkDraw {
  0%         { stroke-dashoffset: 30; }
  50%, 100%  { stroke-dashoffset: 0; }
}

/* Engranaje MIP → gira */
.icon-engranaje { width: 64px; height: 64px; }
.icon-engranaje .gear {
  transform-origin: center;
  animation: gearGira 8s linear infinite;
}
@keyframes gearGira {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* Sobre Carta Garantía → solapa se abre */
.icon-sobre { width: 64px; height: 64px; }
.icon-sobre .solapa {
  transform-origin: top center;
  animation: sobreAbre 3.5s ease-in-out infinite;
}
@keyframes sobreAbre {
  0%, 100% { transform: rotateX(0); }
  50%      { transform: rotateX(170deg); }
}

/* Termita avanzando por madera → translate cíclico */
.icon-termita { width: 64px; height: 64px; }
.icon-termita .insecto {
  animation: termitaAvanza 4s linear infinite;
}
@keyframes termitaAvanza {
  0%   { transform: translateX(-40%); opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { transform: translateX(40%); opacity: 0; }
}

/* Reduce motion para todos los iconos */
@media (prefers-reduced-motion: reduce) {
  .icon-lupa .lente,
  .icon-doc .linea,
  .icon-escudo .anilla,
  .icon-estrella svg,
  .icon-estrella .estrella,
  .icon-gota .gota,
  .icon-check .check-path,
  .icon-engranaje .gear,
  .icon-sobre .solapa,
  .icon-termita .insecto {
    animation: none;
    stroke-dashoffset: 0;
    opacity: 1;
    transform: none;
  }
}

/* ============================================================
   STAGES (3 etapas termitas, MIP 6 etapas)
   ============================================================ */
.stage {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--space-4);
  padding: var(--space-5) 0;
  border-top: 1px solid var(--line);
  align-items: start;
}
.stage:last-child { border-bottom: 1px solid var(--line); }
.stage-num em {
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 700;
  font-style: normal;
  color: var(--eco-green);
  line-height: 0.85;
}
.stage-body h3 { margin-bottom: var(--space-2); }
.stage-body p { max-width: 64ch; margin-bottom: var(--space-2); }

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

/* ============================================================
   SECTORES B2B CHIPS
   ============================================================ */
.sectors-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-2);
  margin-top: var(--space-4);
}
.sector-chip {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--ink);
  text-align: center;
  transition: all var(--dur-fast);
}
.sector-chip:hover {
  border-color: var(--eco-green);
  background: var(--eco-green-soft);
  color: var(--eco-green-deep);
  transform: translateY(-2px);
}

/* ============================================================
   RESEÑAS CARDS
   ============================================================ */
.reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-5);
}
.review-card {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.review-stars {
  color: var(--eco-green);
  font-size: 0.95rem;
  letter-spacing: 0.1em;
}
.review-card blockquote {
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.55;
  color: var(--ink-soft);
  border: none;
  padding: 0;
  margin: 0;
  text-transform: none;
  letter-spacing: 0;
}
.review-card cite {
  font-size: 0.82rem;
  color: var(--ink-muted);
  font-style: normal;
  font-weight: 500;
}
.review-card cite strong { color: var(--ink); display: block; font-weight: 600; }

/* ============================================================
   CTA FINAL FULL-BLEED
   ============================================================ */
.cta-final {
  background: var(--eco-green);
  color: #FFFFFF;
  padding: var(--space-8) 0;
  position: relative;
  overflow: hidden;
}
.cta-final h2 { color: #FFFFFF; max-width: 18ch; }
.cta-final p { color: rgba(255,255,255,0.92); max-width: 60ch; margin-top: var(--space-3); }
.cta-final .hero-ctas { margin-top: var(--space-4); }
.cta-final .btn-primary {
  background: #FFFFFF;
  color: var(--eco-green-deep);
}
.cta-final .btn-primary:hover { background: var(--ink); color: #FFFFFF; }
.cta-final .btn-secondary {
  border-color: #FFFFFF;
  color: #FFFFFF;
}
.cta-final .btn-secondary:hover { background: #FFFFFF; color: var(--eco-green-deep); }

/* Noise sutil sobre CTA final */
.cta-final::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: .08;
  mix-blend-mode: overlay;
  pointer-events: none;
  z-index: 0;
}
.cta-final > * { position: relative; z-index: 1; }

/* ============================================================
   UTILIDADES
   ============================================================ */
.text-center { text-align: center; }
.mt-4 { margin-top: var(--space-4); }
.mt-5 { margin-top: var(--space-5); }
.mt-6 { margin-top: var(--space-6); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-5 { margin-bottom: var(--space-5); }
.mb-6 { margin-bottom: var(--space-6); }
.max-prose { max-width: 70ch; margin-left: auto; margin-right: auto; }

/* Lista en columna sin viñeta */
.list-clean { list-style: none; padding: 0; }
.list-clean li { padding: 0.4rem 0; }

/* Lista con check verde */
.list-check { list-style: none; padding: 0; }
.list-check li {
  padding: 0.5rem 0 0.5rem 1.8rem;
  position: relative;
  line-height: 1.55;
}
.list-check li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 0.5rem;
  color: var(--eco-green);
  font-weight: 700;
}

/* ============================================================
   ARTÍCULO BLOG (prose)
   ============================================================ */
article.post {
  max-width: 720px;
  margin: 0 auto;
}
article.post h2 { margin-top: var(--space-6); margin-bottom: var(--space-3); font-size: clamp(1.5rem, 3vw, 2.2rem); }
article.post h3 { margin-top: var(--space-4); margin-bottom: var(--space-2); }
article.post p { font-size: 1.05rem; line-height: 1.75; margin-bottom: var(--space-3); }
article.post ul, article.post ol { margin: 0 0 var(--space-3) 1.4rem; }
article.post ul li, article.post ol li { padding: 0.3rem 0; line-height: 1.7; }
article.post .lead { margin-bottom: var(--space-4); color: var(--ink); }
article.post blockquote { margin: var(--space-5) 0; font-size: clamp(1.2rem, 2.2vw, 1.6rem); line-height: 1.4; }

/* ============================================================
   FORMULARIO
   ============================================================ */
form .form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
form .form-grid .full { grid-column: 1/-1; }
form label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 0.4rem;
}
form input, form select, form textarea {
  width: 100%;
  padding: 0.85rem 1rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--ink);
  background: #FFFFFF;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
form input:focus, form select:focus, form textarea:focus {
  outline: none;
  border-color: var(--eco-green);
  box-shadow: 0 0 0 3px var(--eco-green-soft);
}
form textarea { min-height: 140px; resize: vertical; }
form .form-actions { margin-top: var(--space-3); }
form .form-actions .btn-primary { width: 100%; }

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

/* ============================================================
   PROPOSAL BADGE / FLOATING (solo páginas privadas, opcional)
   ============================================================ */
.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--eco-green);
  color: #FFFFFF;
  padding: 0.5rem 1rem;
  z-index: 9999;
}
.skip-link:focus { top: 0; }

/* ============================================================
   FIN
   ============================================================ */
