/* ============================================
   LÁCTEO INDUSTRIA SOTO — Verde Campo
   Paleta + Tipografía + Componentes globales
   ============================================ */

:root{
  --verde-oscuro:#1F4F3A;
  --verde-pasto:#3D7A5B;
  --crema:#FAF6EC;
  --crema-claro:#FDFAF1;
  --negro:#1A1A1A;
  --gris:#6B6B63;
  --gris-claro:#A8A8A0;
  --dorado:#D4A017;
  --dorado-suave:#E8C04C;
  --sombra:0 10px 30px rgba(31,79,58,.12);
  --sombra-fuerte:0 20px 50px rgba(31,79,58,.18);
  --radio:4px;
  --font-display:'Fraunces',serif;
  --font-body:'Inter',sans-serif;
  --max-w:1200px;
  --gap:2rem;
  --transicion:all .3s ease;
  --ease-out-expo:cubic-bezier(.22,1,.36,1);
  --ease-out-quart:cubic-bezier(.25,1,.5,1);
  --dur-fast:240ms;
  --dur-base:600ms;
  --dur-slow:900ms;
}

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

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:var(--font-body);
  background:var(--crema);
  color:var(--negro);
  line-height:1.7;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

h1,h2,h3,h4,h5{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.2;
  color:var(--verde-oscuro);
  letter-spacing:-.01em;
}
h1{font-size:clamp(2.5rem,5vw,4rem);margin-bottom:1rem}
h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:1rem}
h3{font-size:clamp(1.3rem,2vw,1.7rem);margin-bottom:.8rem}
h4{font-size:1.2rem;margin-bottom:.5rem}
p{margin-bottom:1rem;color:var(--negro)}
a{color:var(--verde-oscuro);transition:var(--transicion)}
a:hover{color:var(--dorado)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}

.container{max-width:var(--max-w);margin:0 auto;padding:0 2rem}

/* ============================================
   HEADER
   ============================================ */
.site-header{
  background:transparent;
  padding:1.2rem 0;
  border-bottom:1px solid transparent;
  position:sticky;
  top:0;
  z-index:100;
  transition:background .35s ease, border-color .35s ease, box-shadow .35s ease, padding .35s ease, backdrop-filter .35s ease;
}
.site-header.scrolled{
  background:rgba(250,246,236,.82);
  backdrop-filter:blur(18px) saturate(1.4);
  -webkit-backdrop-filter:blur(18px) saturate(1.4);
  border-bottom-color:rgba(0,0,0,.08);
  box-shadow:0 8px 28px rgba(0,0,0,.12);
  padding:.7rem 0;
}

/* Pages with dark hero-interno: header at top blends with the dark background */
body:has(.hero-interno) .site-header{background:var(--verde-oscuro)}
body:has(.hero-interno) .site-header.scrolled{background:rgba(250,246,236,.82)}
body:has(.hero-interno) .site-header:not(.scrolled) .logo,
body:has(.hero-interno) .site-header:not(.scrolled) .main-nav a{color:var(--crema)}
body:has(.hero-interno) .site-header:not(.scrolled) .logo-text span{color:var(--dorado-suave)}
body:has(.hero-interno) .site-header:not(.scrolled) .menu-toggle span{background:var(--crema)}
body:has(.hero-interno) .site-header:not(.scrolled) .main-nav a:hover,
body:has(.hero-interno) .site-header:not(.scrolled) .main-nav a.active{color:var(--dorado-suave)}
body:has(.hero-interno) .site-header:not(.scrolled) .main-nav a.cta-nav{background:var(--dorado);color:var(--verde-oscuro)}
body:has(.hero-interno) .site-header:not(.scrolled) .main-nav a.cta-nav:hover{background:var(--crema);color:var(--verde-oscuro)}
.site-header .logo,
.site-header .main-nav a,
.site-header .logo-text span{transition:color .35s ease}
.site-header .menu-toggle span{transition:background .35s ease, transform var(--transicion)}
.site-header .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
}
.logo{
  display:flex;
  align-items:center;
  gap:.8rem;
  text-decoration:none;
  color:var(--verde-oscuro);
}
.logo img,
.logo-img{height:64px;width:auto;display:block}
.logo-text{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.3rem;
  line-height:1.1;
}
.logo-text span{color:var(--dorado);display:block;font-size:.7rem;letter-spacing:2px;text-transform:uppercase;font-family:var(--font-body);font-weight:600;margin-top:.2rem}

.main-nav ul{
  display:flex;
  gap:2rem;
  align-items:center;
  flex-wrap:wrap;
}
.main-nav a{
  color:var(--verde-oscuro);
  text-decoration:none;
  font-weight:500;
  font-size:.95rem;
  position:relative;
  padding:.5rem 0;
  transition:color .25s ease;
}
.main-nav a::after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:2px;
  background:var(--dorado);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .3s ease;
}
.main-nav a:hover,
.main-nav a.active{color:var(--dorado)}
.main-nav a:hover::after,
.main-nav a.active::after{transform:scaleX(1)}
.main-nav a.cta-nav{
  background:var(--verde-oscuro);
  color:var(--crema);
  padding:.7rem 1.4rem;
  border-radius:var(--radio);
}
.main-nav a.cta-nav:hover{background:var(--dorado);color:var(--verde-oscuro)}
.main-nav a.cta-nav::after{display:none}

.menu-toggle{
  display:none;
  background:transparent;
  border:none;
  cursor:pointer;
  padding:.5rem;
  width:44px;
  height:44px;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:5px;
}
.menu-toggle span{
  display:block;
  width:26px;
  height:2.5px;
  background:var(--verde-oscuro);
  transition:var(--transicion);
}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}

/* ============================================
   BOTONES
   ============================================ */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:1rem 2rem;
  font-family:var(--font-body);
  font-weight:600;
  font-size:.95rem;
  text-decoration:none;
  border-radius:var(--radio);
  transition:var(--transicion);
  cursor:pointer;
  border:2px solid transparent;
  letter-spacing:.3px;
  white-space:nowrap;
}
.btn-primary{background:var(--verde-oscuro);color:var(--crema);border-color:var(--verde-oscuro)}
.btn-primary:hover{background:var(--verde-pasto);border-color:var(--verde-pasto);color:var(--crema);transform:translateY(-2px);box-shadow:var(--sombra)}
.btn-accent{background:var(--dorado);color:var(--negro);border-color:var(--dorado);position:relative;overflow:hidden;isolation:isolate;font-weight:600}
.btn-accent::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent 20%,rgba(255,255,255,.35) 50%,transparent 80%);
  transform:translateX(-110%);
  transition:transform .9s var(--ease-out-expo);
  z-index:-1;
  pointer-events:none;
}
.btn-accent:hover::before{transform:translateX(110%)}
.btn-accent:hover{background:var(--verde-oscuro);color:var(--crema);border-color:var(--verde-oscuro);transform:translateY(-2px);box-shadow:var(--sombra)}
.btn-outline{background:transparent;color:var(--verde-oscuro);border-color:var(--verde-oscuro)}
.btn-outline:hover{background:var(--verde-oscuro);color:var(--crema);transform:translateY(-2px)}
.btn-outline-crema{background:transparent;color:var(--crema);border-color:var(--crema)}
.btn-outline-crema:hover{background:var(--crema);color:var(--verde-oscuro)}

/* ============================================
   SECCIONES Y HELPERS
   ============================================ */
section{padding:5rem 0}
.section-title{text-align:center;margin-bottom:3.5rem}
.section-title .eyebrow{
  display:inline-block;
  color:var(--dorado);
  font-family:var(--font-body);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:2px;
  font-size:.8rem;
  margin-bottom:1rem;
}
.section-title h2{margin-bottom:.8rem}
.section-title p{
  color:var(--gris);
  max-width:700px;
  margin:0 auto;
  font-size:1.05rem;
}

.seccion-oscura{background:var(--verde-oscuro);color:var(--crema)}
.seccion-oscura h1,.seccion-oscura h2,.seccion-oscura h3,.seccion-oscura h4{color:var(--crema)}
.seccion-oscura .eyebrow{color:var(--dorado-suave)}
.seccion-oscura p{color:rgba(250,246,236,.85)}
.seccion-oscura .section-title p{color:rgba(250,246,236,.85)}
.seccion-oscura .historia p{color:rgba(250,246,236,.85)}
.seccion-oscura .historia p.lead{color:var(--crema);border-left-color:var(--dorado-suave)}
.seccion-oscura a:not(.btn){color:var(--dorado-suave)}
.seccion-oscura a:not(.btn):hover{color:var(--crema)}

.seccion-clara{background:var(--crema-claro)}

/* ============================================
   HERO
   ============================================ */
.hero{
  padding:6rem 0 5rem;
  background:var(--crema);
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.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:.08;
  mix-blend-mode:multiply;
  pointer-events:none;
  z-index:-1;
}
.hero-content{
  max-width:900px;
  margin:0 auto;
  text-align:center;
  position:relative;
  z-index:2;
}
.hero .eyebrow{
  display:inline-block;
  color:var(--dorado);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:2px;
  font-size:.8rem;
  margin-bottom:1.2rem;
}
.hero h1{margin-bottom:1.5rem}
.hero h1 em{font-style:italic;color:var(--verde-pasto)}
.hero .lead{
  font-size:1.2rem;
  color:var(--gris);
  max-width:720px;
  margin:0 auto 2.5rem;
}
.hero-buttons{
  display:flex;
  gap:1rem;
  justify-content:center;
  flex-wrap:wrap;
}

/* ======= RAPTOR LIB 01 — HERO STAGGER ======= */
.hero .eyebrow,
.hero .lead,
.hero-buttons{
  opacity:0;
  transform:translateY(24px);
  animation:heroReveal .9s var(--ease-out-expo) forwards;
}
.hero .eyebrow{animation-delay:.05s}
.hero .lead{animation-delay:.24s}
.hero-buttons{animation-delay:.36s}
@keyframes heroReveal{to{opacity:1;transform:none}}

.hero-interno{
  padding:4rem 0 3rem;
  background:var(--verde-oscuro);
  color:var(--crema);
  text-align:center;
}
.hero-interno h1{color:var(--crema);margin-bottom:.8rem}
.hero-interno .lead{color:rgba(250,246,236,.85);max-width:680px;margin:0 auto}
.hero-interno .breadcrumbs{margin-bottom:1rem;font-size:.85rem;color:var(--dorado-suave)}
.hero-interno .breadcrumbs a{color:var(--dorado-suave)}
.hero-interno .breadcrumbs a:hover{color:var(--crema)}

/* ============================================
   STATS BAR
   ============================================ */
.stats-bar{
  background:var(--verde-oscuro);
  color:var(--crema);
  padding:3rem 0;
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:2rem;
  text-align:center;
}
.stat-item{padding:1rem}
.stat-num{
  font-family:var(--font-display);
  font-size:3.2rem;
  font-weight:700;
  color:var(--dorado-suave);
  line-height:1;
  margin-bottom:.4rem;
  font-variant-numeric:tabular-nums;
}
.stat-label{
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:rgba(250,246,236,.85);
  font-weight:500;
}

/* ============================================
   GRID DE PRODUCTOS
   ============================================ */
.productos-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:2rem;
}
.producto-card{
  background:var(--crema-claro);
  border:1px solid rgba(31,79,58,.1);
  border-radius:var(--radio);
  overflow:hidden;
  transition:var(--transicion);
  display:flex;
  flex-direction:column;
}
.producto-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--sombra-fuerte);
  border-color:var(--verde-pasto);
}
.producto-img{
  height:220px;
  background:linear-gradient(135deg,var(--verde-pasto) 0%,var(--verde-oscuro) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--crema);
  font-family:var(--font-display);
  font-size:1.5rem;
  font-weight:600;
  padding:1.5rem;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.producto-img img,
.producto-hero-img img,
.historia-img img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.historia-img{
  position:relative;
  overflow:hidden;
  border-radius:var(--radio);
  min-height:360px;
  margin:2.5rem 0;
  background:linear-gradient(135deg,var(--verde-pasto) 0%,var(--verde-oscuro) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--crema);
  font-family:var(--font-display);
  font-size:1.6rem;
  text-align:center;
  padding:2rem;
  box-shadow:var(--sombra);
}
.producto-img::after{
  content:'';
  position:absolute;
  bottom:1rem;
  left:50%;
  transform:translateX(-50%);
  width:40px;
  height:2px;
  background:var(--dorado);
}
.producto-info{
  padding:1.8rem;
  display:flex;
  flex-direction:column;
  flex:1;
}
.producto-info h3{color:var(--verde-oscuro);margin-bottom:.5rem}
.producto-info p{
  color:var(--gris);
  font-size:.92rem;
  margin-bottom:1.2rem;
  flex:1;
}
.producto-info .producto-link{
  color:var(--dorado);
  text-decoration:none;
  font-weight:600;
  font-size:.9rem;
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  transition:var(--transicion);
  position:relative;
  padding-right:.2rem;
}
.producto-info .producto-link:hover{color:var(--verde-oscuro)}
.producto-info .producto-link:hover svg{transform:translateX(6px)}
.producto-info .producto-link svg{transition:transform .4s var(--ease-out-expo)}
.producto-info .producto-link::after{
  content:'';
  position:absolute;
  left:0;
  bottom:-2px;
  width:100%;
  height:1px;
  background:currentColor;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .45s var(--ease-out-expo);
}
.producto-info .producto-link:hover::after{transform:scaleX(1)}

/* ============================================
   FICHA DE PRODUCTO (páginas internas)
   ============================================ */
.producto-hero{
  padding:4rem 0;
  background:var(--crema);
}
.producto-hero .container{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:center;
}
.producto-hero-img{
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg,var(--verde-pasto) 0%,var(--verde-oscuro) 100%);
  border-radius:var(--radio);
  min-height:400px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--crema);
  font-family:var(--font-display);
  font-size:2.2rem;
  font-weight:600;
  text-align:center;
  padding:2rem;
  box-shadow:var(--sombra);
}
.producto-hero-content .eyebrow{
  color:var(--dorado);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:2px;
  font-size:.8rem;
  margin-bottom:1rem;
  display:block;
}
.producto-hero-content h1{margin-bottom:1rem}
.producto-hero-content .lead{
  font-size:1.15rem;
  color:var(--gris);
  margin-bottom:2rem;
}
.ficha-tecnica{
  background:var(--crema-claro);
  border:1px solid rgba(31,79,58,.1);
  border-radius:var(--radio);
  padding:2rem;
  margin-bottom:2rem;
}
.ficha-tecnica h3{
  font-size:1.1rem;
  color:var(--verde-oscuro);
  margin-bottom:1rem;
  padding-bottom:.8rem;
  border-bottom:1px solid rgba(31,79,58,.1);
}
.ficha-tecnica ul{display:grid;gap:.8rem}
.ficha-tecnica li{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  font-size:.95rem;
  padding:.3rem 0;
}
.ficha-tecnica li strong{
  color:var(--verde-oscuro);
  font-weight:600;
  flex-shrink:0;
}
.ficha-tecnica li span{
  color:var(--gris);
  text-align:right;
}

/* Proceso de elaboración */
.proceso{padding:5rem 0;background:var(--crema-claro)}
.proceso-pasos{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1.5rem;
  max-width:1100px;
  margin:0 auto;
}
.paso-card{
  background:var(--crema);
  border:1px solid rgba(31,79,58,.1);
  border-radius:var(--radio);
  padding:2rem 1.8rem;
  text-align:center;
  transition:var(--transicion);
  position:relative;
}
.paso-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--sombra);
  border-color:var(--dorado);
}
.paso-num{
  font-family:var(--font-display);
  font-size:3rem;
  font-weight:700;
  color:var(--dorado);
  line-height:1;
  margin-bottom:.8rem;
}
.paso-card h4{
  color:var(--verde-oscuro);
  margin-bottom:.5rem;
  font-size:1.1rem;
}
.paso-card p{
  font-size:.88rem;
  color:var(--gris);
  margin:0;
}

/* ============================================
   CARDS GENÉRICAS (diferenciadores, valores)
   ============================================ */
.cards-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:2rem;
}
.feature-card{
  background:var(--crema-claro);
  border:1px solid rgba(31,79,58,.1);
  border-radius:var(--radio);
  padding:2.5rem 2rem;
  text-align:center;
  transition:var(--transicion);
}
.feature-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--sombra);
  border-color:var(--verde-pasto);
}
.feature-icon{
  width:72px;
  height:72px;
  color:var(--verde-oscuro);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 1.5rem;
}
.feature-icon svg{width:100%;height:100%;stroke-width:1.3}
.feature-card h3{margin-bottom:.8rem;font-size:1.25rem}
.feature-card p{color:var(--gris);margin:0;font-size:.95rem}

/* ============================================
   HISTORIA / NOSOTROS
   ============================================ */
.historia{max-width:820px;margin:0 auto}
.historia p{
  font-size:1.08rem;
  margin-bottom:1.5rem;
  line-height:1.85;
  color:var(--negro);
}
.historia p.lead{
  font-size:1.45rem;
  color:var(--verde-oscuro);
  font-family:var(--font-display);
  font-weight:500;
  font-style:italic;
  padding:1.8rem 2rem 1.8rem 3rem;
  border-left:3px solid var(--dorado);
  position:relative;
  margin:2.5rem 0;
}
.historia p.lead::before{
  content:'\201C';
  position:absolute;
  left:.6rem;
  top:-.4rem;
  font-family:var(--font-display);
  font-size:5rem;
  line-height:1;
  color:var(--dorado-suave);
  opacity:.35;
  pointer-events:none;
}
.historia p:not(.lead):first-of-type::first-letter{
  font-family:var(--font-display);
  font-weight:700;
  font-size:4.2rem;
  float:left;
  line-height:.9;
  padding:.3rem .6rem 0 0;
  color:var(--dorado-suave);
}

/* ============================================
   COBERTURA
   ============================================ */
.cobertura-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:2rem;
}
.cobertura-card{
  background:var(--crema-claro);
  border:1px solid rgba(31,79,58,.1);
  border-radius:var(--radio);
  padding:2.5rem 2rem;
  text-align:center;
  transition:var(--transicion);
}
.cobertura-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--sombra);
  border-color:var(--dorado);
}
.cobertura-card .estado-num{
  font-family:var(--font-display);
  font-size:4rem;
  font-weight:700;
  color:var(--dorado);
  line-height:1;
  margin-bottom:.5rem;
}
.cobertura-card h3{color:var(--verde-oscuro);margin-bottom:.8rem}
.cobertura-card p{color:var(--gris);margin:0;font-size:.95rem}

/* ============================================
   CONTACTO
   ============================================ */
.contacto-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:start;
}
.contacto-info{
  background:var(--verde-oscuro);
  color:var(--crema);
  padding:3rem 2.5rem;
  border-radius:var(--radio);
}
.contacto-info h3{color:var(--crema);margin-bottom:1.5rem}
.contacto-info .info-block{
  padding:1.5rem 0;
  border-bottom:1px solid rgba(250,246,236,.15);
}
.contacto-info .info-block:last-child{border-bottom:none}
.contacto-info .info-label{
  color:var(--dorado-suave);
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:2px;
  font-weight:600;
  margin-bottom:.5rem;
  display:block;
}
.contacto-info .info-value{
  color:var(--crema);
  font-size:1.1rem;
  font-weight:500;
  text-decoration:none;
  display:block;
}
.contacto-info .info-value:hover{color:var(--dorado-suave)}
.contacto-info p{color:rgba(250,246,236,.85);margin:0}

.contacto-mapa{
  border-radius:var(--radio);
  overflow:hidden;
  box-shadow:var(--sombra);
  min-height:500px;
  background:var(--crema-claro);
}
.contacto-mapa iframe{
  width:100%;
  height:100%;
  min-height:500px;
  border:0;
  display:block;
}

/* ============================================
   CTA FINAL
   ============================================ */
.cta-final{
  background:var(--verde-oscuro);
  color:var(--crema);
  padding:5rem 0;
  text-align:center;
  position:relative;
  isolation:isolate;
}
.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 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:.12;
  mix-blend-mode:overlay;
  pointer-events:none;
  z-index:-1;
}
.cta-final h2{color:var(--crema);margin-bottom:1rem}
.cta-final p{
  color:rgba(250,246,236,.85);
  max-width:640px;
  margin:0 auto 2.5rem;
  font-size:1.1rem;
}
.cta-final .hero-buttons{justify-content:center}
.hero-buttons .btn,
.cta-final .btn{transition:transform .35s var(--ease-out-expo)}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{
  background:var(--negro);
  color:rgba(250,246,236,.8);
  padding:4rem 0 0;
  border-top:4px solid var(--dorado);
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:2.5rem;
  margin-bottom:3rem;
}
.footer-col h4{
  color:var(--dorado);
  font-family:var(--font-display);
  font-size:1.2rem;
  margin-bottom:1.2rem;
}
.footer-col p,.footer-col a{
  color:rgba(250,246,236,.75);
  font-size:.9rem;
  line-height:1.8;
  text-decoration:none;
  display:block;
}
.footer-col a:hover{color:var(--dorado)}
.footer-col .logo-text{color:var(--crema);font-size:1.4rem;margin-bottom:1rem}
.footer-col .logo-text span{color:var(--dorado)}
.footer-col .logo-img{height:72px;width:auto;display:block;margin-bottom:1rem}
.footer-bottom{
  border-top:1px solid rgba(250,246,236,.1);
  padding:1.8rem 0;
  text-align:center;
  font-size:.85rem;
  color:rgba(250,246,236,.5);
}
.footer-bottom a{color:rgba(250,246,236,.5);text-decoration:none}
.footer-bottom a:hover{color:var(--dorado)}

/* ============================================
   BOTONES FLOTANTES
   ============================================ */
.botones-flotantes{
  position:fixed;
  bottom:20px;
  right:20px;
  display:flex;
  flex-direction:column;
  gap:12px;
  z-index:99;
}
.btn-flotante{
  width:56px;
  height:56px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  text-decoration:none;
  box-shadow:0 6px 20px rgba(0,0,0,.25);
  transition:var(--transicion);
}
.btn-flotante:hover{transform:scale(1.08)}
.btn-wa{background:#25D366}
.btn-call{background:var(--verde-oscuro)}
.btn-flotante svg{width:26px;height:26px;fill:#fff}

/* Modal de confirmación llamada */
.modal-llamada{
  display:flex;
  visibility:hidden;
  opacity:0;
  pointer-events:none;
  position:fixed;
  inset:0;
  background:rgba(26,26,26,.75);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  z-index:200;
  align-items:center;
  justify-content:center;
  padding:1rem;
  transition:opacity .35s var(--ease-out-expo), visibility 0s .35s;
}
.modal-llamada.activo{
  visibility:visible;
  opacity:1;
  pointer-events:auto;
  transition:opacity .35s var(--ease-out-expo), visibility 0s;
}
.modal-content{
  background:var(--crema);
  padding:2.5rem 2rem;
  border-radius:var(--radio);
  max-width:420px;
  text-align:center;
  box-shadow:var(--sombra-fuerte);
  transform:scale(.92) translateY(20px);
  transition:transform .45s var(--ease-out-expo);
}
.modal-llamada.activo .modal-content{transform:scale(1) translateY(0)}
.modal-content h3{color:var(--verde-oscuro);margin-bottom:.8rem}
.modal-content p{color:var(--gris);margin-bottom:1.8rem}
.modal-content .modal-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ============================================
   PÁGINAS LEGALES
   ============================================ */
.legal-content{
  max-width:820px;
  margin:0 auto;
  padding:2rem 0;
}
.legal-content h2{
  margin-top:2.5rem;
  margin-bottom:1rem;
  font-size:1.6rem;
}
.legal-content h2:first-child{margin-top:0}
.legal-content p{
  color:var(--negro);
  line-height:1.8;
  margin-bottom:1rem;
}
.legal-content ul{
  margin:1rem 0 1.5rem 2rem;
  list-style:disc;
}
.legal-content li{margin-bottom:.5rem;color:var(--negro)}
.legal-content strong{color:var(--verde-oscuro)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width:900px){
  .producto-hero .container{grid-template-columns:1fr}
  .contacto-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
}
@media (max-width:768px){
  section{padding:4rem 0}
  .hero{padding:4rem 0 3rem}
  .menu-toggle{display:flex}
  .main-nav{
    position:fixed;
    top:0;
    right:-100%;
    width:85%;
    max-width:340px;
    height:100vh;
    background:var(--crema);
    padding:6rem 2rem 2rem;
    transition:right .4s ease;
    box-shadow:-10px 0 30px rgba(0,0,0,.15);
    z-index:99;
    overflow-y:auto;
  }
  .main-nav.activo{right:0}
  .main-nav ul{flex-direction:column;gap:0;align-items:stretch}
  .main-nav li{
    border-bottom:1px solid rgba(31,79,58,.08);
    opacity:0;
    transform:translateX(20px);
    transition:opacity .5s var(--ease-out-expo), transform .5s var(--ease-out-expo);
  }
  .main-nav.activo li{opacity:1;transform:none}
  .main-nav.activo li:nth-child(1){transition-delay:.15s}
  .main-nav.activo li:nth-child(2){transition-delay:.22s}
  .main-nav.activo li:nth-child(3){transition-delay:.29s}
  .main-nav.activo li:nth-child(4){transition-delay:.36s}
  .main-nav.activo li:nth-child(5){transition-delay:.43s}
  .main-nav a{padding:1.1rem 0;display:block;font-size:1.05rem}
  .main-nav a.cta-nav{margin-top:1rem;text-align:center}
  .hero-buttons{flex-direction:column;align-items:stretch}
  .btn{width:100%;justify-content:center}
  .footer-grid{grid-template-columns:1fr;gap:2rem;text-align:center}
  .contacto-info{padding:2rem 1.5rem}
}
@media (max-width:480px){
  .container{padding:0 1.5rem}
  h1{font-size:2.2rem}
  h2{font-size:1.8rem}
  .stat-num{font-size:2.5rem}
  .cobertura-card .estado-num{font-size:3rem}
}

/* ============================================
   UTILIDADES
   ============================================ */
.text-center{text-align:center}
.mt-2{margin-top:2rem}
.mt-3{margin-top:3rem}
.mb-2{margin-bottom:2rem}
.visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* Skip link para accesibilidad */
.skip-link{
  position:absolute;
  top:0;
  left:0;
  transform:translateY(-120%);
  background:var(--dorado);
  color:var(--verde-oscuro);
  padding:.8rem 1.5rem;
  text-decoration:none;
  font-weight:600;
  z-index:999;
  transition:transform .2s ease;
}
.skip-link:focus{transform:translateY(0)}

/* Focus visible para accesibilidad */
a:focus-visible,button:focus-visible{
  outline:3px solid var(--dorado);
  outline-offset:3px;
  border-radius:2px;
}

/* ============================================
   RAPTOR LIB 01 — REVEAL 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}
.producto-card[data-reveal]:nth-child(2){--reveal-delay:80}
.producto-card[data-reveal]:nth-child(3){--reveal-delay:160}
.producto-card[data-reveal]:nth-child(4){--reveal-delay:240}
.producto-card[data-reveal]:nth-child(5){--reveal-delay:320}
.producto-card[data-reveal]:nth-child(6){--reveal-delay:400}
.producto-card[data-reveal]:nth-child(7){--reveal-delay:480}
.feature-card[data-reveal]:nth-child(2){--reveal-delay:80}
.feature-card[data-reveal]:nth-child(3){--reveal-delay:160}
.feature-card[data-reveal]:nth-child(4){--reveal-delay:240}
.paso-card[data-reveal]:nth-child(2){--reveal-delay:60}
.paso-card[data-reveal]:nth-child(3){--reveal-delay:120}
.paso-card[data-reveal]:nth-child(4){--reveal-delay:180}
.paso-card[data-reveal]:nth-child(5){--reveal-delay:240}
.paso-card[data-reveal]:nth-child(6){--reveal-delay:300}
@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 — ANIMATED ICONS ======= */
.feature-icon svg{overflow:visible;width:100%;height:100%;stroke-width:1.3}
@keyframes iconFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-3px)}
}
@keyframes iconPulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.1)}
}
@keyframes iconRock{
  0%,100%{transform:rotate(0)}
  25%{transform:rotate(5deg)}
  75%{transform:rotate(-5deg)}
}
@keyframes iconSteam{
  0%{opacity:0;transform:translateY(0)}
  20%{opacity:.7}
  100%{opacity:0;transform:translateY(-6px)}
}
.icon-anim-float{animation:iconFloat 3s ease-in-out infinite}
.icon-anim-pulse{animation:iconPulse 2.8s ease-in-out infinite}
.icon-anim-rock{animation:iconRock 4s ease-in-out infinite}
.icon-steam{opacity:0}
.icon-steam-1{animation:iconSteam 2s ease-out infinite}
.icon-steam-2{animation:iconSteam 2s ease-out .7s infinite}
.icon-steam-3{animation:iconSteam 2s ease-out 1.4s infinite}

/* ======= RAPTOR LIB 05 — CARDS TILT ======= */
.productos-grid{perspective:1200px}
.producto-card{
  transform-style:preserve-3d;
  will-change:transform;
}

/* ======= RAPTOR LIB 09 — MARQUEE ======= */
.marquee-section{
  padding:2.5rem 0;
  background:var(--verde-oscuro);
  color:var(--crema);
  overflow:hidden;
  border-top:1px solid rgba(212,160,23,.25);
  border-bottom:1px solid rgba(212,160,23,.25);
}
.marquee{overflow:hidden;width:100%}
.marquee-track{
  display:flex;
  gap:3rem;
  width:max-content;
  animation:marqueeScroll 38s linear infinite;
  font-family:var(--font-display);
  font-size:1.6rem;
  font-style:italic;
  color:var(--dorado-suave);
  white-space:nowrap;
}
.marquee-track span:nth-child(even){color:var(--crema);opacity:.4;font-style:normal}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marqueeScroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ======= RAPTOR LIB 06 — PARALLAX HISTORIA ======= */
@supports (animation-timeline: view()){
  .historia-img{
    animation:historiaParallax linear;
    animation-timeline:view();
    animation-range:entry 0% exit 100%;
  }
}
@keyframes historiaParallax{
  from{transform:translateY(40px) scale(1.05)}
  to{transform:translateY(-40px) scale(1.05)}
}

/* ======= RAPTOR LIB 05b — IMAGE REVEAL ======= */
.producto-card[data-reveal] .producto-img img{
  clip-path:polygon(0 0, 100% 0, 100% 0%, 0 0%);
  transition:clip-path 1.2s var(--ease-out-expo);
  transition-delay:calc(var(--reveal-delay,0) * 1ms + 200ms);
}
.producto-card[data-reveal].is-in .producto-img img{
  clip-path:polygon(0 0, 100% 0, 100% 100%, 0 100%);
}

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