:root{
  --blue: #0e2e57;
  --gold: #D4AF37;
  --radius-card: 28px;
  --gray-bg: #d9d9d9;    /* fondo de la “capsula” de la imagen */
  --text-soft: #a0a0a0;

  --font: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;

  /* Alturas del header (normal vs scrolled) */
  --header-h: 100px;          /* MÁS GRANDE antes de scrollear */
  --header-h-scrolled: 58px;  /* tamaño al scrollear */

  /* Logo acompaña la altura del header */
  --logo-h-default: 100px;    
  --logo-h-scrolled: 58px;    /* logo scrolleado */

  /* Tipografías / tamaños */
  --menu-size: clamp(1rem, 2vw, 1.3rem);
  --contact-size: 0.9rem;
  --icon-contact: 18px;
  --icon-social: 22px;
  --social-box: 32px;

  --gap-menu: clamp(1.4rem, 3vw, 3rem);
}

*{ box-sizing: border-box; }
html, body{ height:100%; }
body{ margin:0; font-family: var(--font); }

.footer {
  background: var(--blue, #0e2e57);
  color: #fff;
  padding-top: 2.5rem;
}
.footer .container { width: 94%; max-width: 1400px; margin: 0 auto; }

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.2fr;
  gap: 2rem;
}
@media (max-width: 980px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .footer-grid { grid-template-columns: 1fr; }
}

.f-col .f-title {
  font-weight: 700; margin: 0 0 .8rem; font-size: 1.05rem; color: #fff);
}
.f-list { list-style: none; padding: 0; margin: 0; }
.f-list li { margin: .45rem 0; }
.f-list a { color: #fff; text-decoration: none; opacity: .95; }
.f-list a:hover { text-decoration: underline; }

/* Logo del footer: respeta proporción 1500x685 y escala fluido */
.f-col.brand .f-logo img{
  display: block;
  width: clamp(160px, 14vw, 260px); /* ajusta tamaño visual */
  max-width: 100%;
  height: auto;                     /* mantiene proporción */
  aspect-ratio: 1500 / 685;         /* ayuda al layout estable */
  object-fit: contain;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.25));
}

.f-desc { margin-top: .7rem; line-height: 1.5; opacity: .9; }

.f-list.contact .icon { width: 18px; height: 18px; margin-right: .45rem; vertical-align: -4px; opacity: .9; }
.social-row a { display: inline-block; margin-right: .4rem; }
.social-row img { width: 24px; height: 24px; opacity: .95; }
.social-row img:hover { opacity: 1; }

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.12);
  margin-top: 2rem;
  padding: .9rem 0;
  text-align: center;
  color: rgba(255,255,255,.85);
}

/* ======= HERO (portada) ======= */
.hero{
  position: relative;
  min-height: clamp(420px, 70vh, 760px);
  display: flex;
  align-items: center;
  background: url('../img/portada.jpg') center / cover no-repeat;
  background-attachment: scroll; /* 👈 hace que el fondo se quede fijo */
  isolation: isolate;
}

/* Overlay azul para mejorar contraste del texto */
.hero::after{
  content:"";
  position: absolute; inset: 0;
  background:
    radial-gradient(1200px 600px at 20% 50%, rgba(0,0,0,0.18), transparent 60%),
    linear-gradient(0deg, rgba(14,46,87,0.62), rgba(14,46,87,0.62));
  z-index: -1;
}

/* Contenido del hero */
.hero-inner{
  padding: clamp(24px, 4vw, 48px) 0;
}

/* Animación de fade + slide-up */
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(28px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hero-title {
  font-family: 'Oswald', sans-serif;
  color: #fff;
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: .5px;
  max-width: min(980px, 92%);
  font-size: clamp(1.8rem, 3.2vw + 1rem, 3.2rem);
  text-wrap: balance;
  text-shadow: 0 2px 12px rgba(0,0,0,.35);

  /* Animación */
  opacity: 0; /* estado inicial */
  animation: fadeUp .9s ease-out forwards;
  animation-delay: .3s; /* empieza un poquito después */
}


/* Ajustes responsivos */
@media (max-width: 900px){
  .hero{ min-height: 62vh; }
  .hero-title{ max-width: 46ch; }
}
@media (max-width: 640px){
  .hero{ min-height: 56vh; }
  .hero-title{ max-width: 34ch; }
}

/* ======= BANDA DE PRESENTACIÓN ======= */
.intro-band{
  position: relative;
  background: #0e2e57; /* azul corporativo */
  color:#fff;
  margin-top: -34px;
  padding: clamp(16px, 2.5vw, 24px) 0;
  box-shadow: 0 -10px 22px rgba(0,0,0,.18), 0 8px 22px rgba(0,0,0,.18);
  z-index: 1;
}

/* Layout interno */
.intro-wrap{
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: clamp(14px, 2vw, 28px);
  row-gap: 12px;
}

/* Logo (ajuste fluido) */
.intro-logo img{
  display:block;
  width: clamp(50px, 5.5vw, 78px);
  height: auto;
  object-fit: contain;
  filter: brightness(0) invert(1); /* vuelve blanco el logo */
  image-rendering: -webkit-optimize-contrast;
}

/* Texto */
.intro-text{
  margin: 0;
  font-family: 'Nunito Sans', sans-serif; /* o 'Oswald' si quieres más corporativo */
  font-weight: 300;
  font-size: clamp(.9rem, .95vw + .55rem, 1.1rem); /* 👈 más pequeño */
  line-height: 1.45; /* un poco más compacto */
  letter-spacing: .15px;
  color: rgba(255,255,255,.95);
}

/* Responsive */
@media (max-width: 900px){
  .intro-wrap{
    grid-template-columns: 1fr;
    text-align: left;
  }
  .intro-logo{ order: -1; }
  .intro-logo img{ width: clamp(58px, 11vw, 90px); }
}

/* Contenedor que fuerza el snap por pantalla */
.cat-snap{
  scroll-snap-type: y mandatory;     /* encaje obligatorio */
  scroll-behavior: smooth;           /* desplazamiento suave */
}

/* Cada slide ocupa toda la pantalla y “encaja” */
.fullcat{
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  background-attachment: fixed;      /* parallax en desktop */
  isolation: isolate;

  scroll-snap-align: start;          /* el inicio de cada slide es el punto de encaje */
  scroll-snap-stop: always;          /* detente siempre en cada slide */
  scroll-margin-top: var(--header-h);/* compensa el header fijo */
}

/* Overlay azul para legibilidad */
.fullcat::after{
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(1100px 520px at 22% 55%, rgba(0,0,0,.18), transparent 60%),
    linear-gradient(0deg, rgba(14,46,87,.62), rgba(14,46,87,.62));
  z-index: -1;
}

.fullcat-inner{ padding: clamp(24px, 4vw, 56px) 0; }

.fullcat-title{
  font-family: 'Oswald', sans-serif;
  color:#fff; font-weight:400;
  line-height:1.12; letter-spacing:.6px;
  max-width:24ch;
  font-size: clamp(1.6rem, 3.1vw + 1rem, 3.4rem);
  text-shadow: 0 2px 12px rgba(0,0,0,.35);
  margin: 0 0 1.2rem;
}

.fullcat-btn{
  display:inline-block;
  padding:.7rem 1.6rem;
  border:2px solid #fff; border-radius:999px;
  color:#fff; text-decoration:none; font-weight:600; letter-spacing:.5px;
  box-shadow:0 3px 18px rgba(0,0,0,.25);
  transition: transform .2s ease, background-color .2s ease, color .2s ease, box-shadow .2s ease;
}
.fullcat-btn:hover{ background:#fff; color:#0e2e57; transform: translateY(-2px); box-shadow:0 6px 22px rgba(0,0,0,.28); }

/* Fallback móvil: muchos navegadores no soportan fixed */
@media (max-width: 900px){
  .fullcat{ background-attachment: scroll; }
}

/* —— Composición para la portada y bloques Misión/Visión ——————————— */
.fullcat--hero .fullcat-inner{
  max-width: 1100px;
}
.grid-2{
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  align-items: center;
  gap: clamp(16px, 4vw, 48px);
}
@media (max-width: 980px){
  .grid-2{ grid-template-columns: 1fr; }
}

/* bloque de marca grande (izquierda del hero) */
.brand-block{ color:#fff; }
.brand-logo{
  width: clamp(160px, 28vw, 360px);
  display:block;
  filter: drop-shadow(0 4px 14px rgba(0,0,0,.35));
  margin-bottom: clamp(10px, 2vw, 18px);
}
.brand-name{
  margin: 0;
  font-weight: 700;
  line-height: 1;
  font-size: clamp(2.2rem, 6vw, 4.2rem);
  letter-spacing: .02em;
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
}
.brand-sub{
  margin:.2rem 0 0;
  font-weight: 600;
  font-size: clamp(1rem, 2.4vw, 1.4rem);
  opacity:.95;
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
}

/* textos de los paneles */
.lead{
  margin: 0;
  color:#fff;
  font-size: clamp(1.05rem, 2.2vw, 1.35rem);
  line-height: 1.55;
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
}
.fullcat-eyebrow{
  margin: 0 0 .6rem;
  color:#fff;
  font-weight: 800;
  letter-spacing: .06em;
  font-size: clamp(1.6rem, 5vw, 3.2rem);
  text-transform: uppercase;
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
}

/* opcional: marca de agua fija (si quieres mantener logos.png arriba a la izq.) */
.fullcat .fullcat-mark{
  position:absolute;
  top: clamp(14px, calc(var(--current-header-h, var(--header-h)) * 0.25), 60px);
  left: clamp(12px, 5vw, 52px);
  width: clamp(56px, 11vw, 120px);
  opacity:.85;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.25));
  pointer-events: none;
  user-select: none;
}

/* Caja de texto para Misión/Visión (no toca el HERO) */
.fullcat:not(.fullcat--hero){ --text-w: 50ch; }     /* ancho cómodo */
@media (max-width: 980px){ .fullcat:not(.fullcat--hero){ --text-w: 42ch; } }

/* Misión a la IZQUIERDA: la caja (título + párrafo) se ancla a la izq. */
.fullcat[data-align="left"]:not(.fullcat--hero) .fullcat-inner{
  max-width: var(--text-w);
  margin-left: clamp(36px, 7vw, 120px);
  margin-right: auto;
  text-align: left;
}

/* Visión a la DERECHA: la caja se ancla a la der. */
.fullcat[data-align="right"]:not(.fullcat--hero) .fullcat-inner{
  max-width: var(--text-w);
  margin-right: clamp(36px, 7vw, 120px);
  margin-left: auto;
  text-align: right;
}

/* Título centrado dentro de la misma caja del texto (como en tu ejemplo) */
.fullcat:not(.fullcat--hero) .fullcat-eyebrow{
  display: block;          /* ocupa el ancho de la caja (.fullcat-inner) */
  text-align: center;      /* centrado dentro de esa caja */
  margin-bottom: .8rem;
}

/* ===================== */
/* CATALOGO (igual que ya tenías) */
.catalogo{ padding: clamp(20px, 4vw, 40px) 0 64px; }
.catalogo .container{ width:94%; max-width:1300px; margin:0 auto; }

/* Título principal (se reutiliza también en producto.php) */
.cat-title{
  margin: 8px 0 28px;
  font-family: 'Nunito Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  font-weight: 800;
  font-size: clamp(28px, 4vw, 44px);
  letter-spacing: .5px;
  text-align: center;
  text-transform: uppercase;
  color: #222;
}

/* Migas opcionales arriba */
.breadcrumb{ display:flex; align-items:center; gap:.5rem; color:#666; font-size:.95rem; margin-bottom: 8px; }
.breadcrumb a{ color:#666; text-decoration:none; }
.breadcrumb a:hover{ color:var(--blue); }

/* Filtros (si los usas) */
.catalog-header{ display:grid; gap:12px; margin: 0 0 18px; }
.catalog-filters{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.catalog-filters input, .catalog-filters select, .catalog-filters button{
  font: inherit; padding:10px 12px; border:1px solid #ddd; border-radius:10px; background:#fff;
}
.catalog-filters button{ background:var(--blue); color:#fff; border-color:var(--blue); cursor:pointer; }
.catalog-filters button:hover{ filter: brightness(0.95); }

/* Grid de productos – 3 columnas desktop */
.product-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(18px, 3vw, 32px);
}
@media (max-width: 1090px){
  .product-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px){
  .product-grid{ grid-template-columns: 1fr; }
}

/* Tarjeta (todo el card es link) */
.product-card{ list-style:none; }
.product-link{ display:block; text-decoration:none; color:inherit; }

.product-media {
  border-radius: var(--radius-card);
  aspect-ratio: 4 / 3;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding: 0;       /* sin padding extra */
  background: none; /* sin fondo */
}

.product-media img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* la imagen llena el área */
  display:block;
}


/* Texto debajo, centrado */
.product-body{ text-align:center; padding: 10px 6px 6px; }
.product-cat{
  display:block;
  font-size: .95rem;
  color: var(--text-soft);
  margin-bottom: 6px;
}
.product-title{
  font-weight: 800;
  font-size: clamp(1rem, 1.6vw, 1.15rem);
  line-height: 1.25;
  color:#111;
}

/* Hover sutil */
.product-link:hover .product-media{
  box-shadow: 0 6px 22px rgba(0,0,0,.08);
  transform: translateY(-1px);
  transition: all .18s ease;
}

/* Estado vacío */
.empty-state{ text-align:center; color:#666; padding:40px 0; }

/* Paginación */
.pagination{
  margin-top: 18px; display:flex; align-items:center; justify-content:center; gap: 12px;
}
.page-link{
  text-decoration:none; color:#fff; background:var(--blue);
  padding:8px 12px; border-radius:10px; border:1px solid var(--blue);
}
.page-link:hover{ filter: brightness(.95); }
.page-info{ color:#333; }

/* ===================== */
/* PRODUCTO (detalle) */
.product-hero{ 
  padding: clamp(20px, 4vw, 44px) 0 64px; 
}
.product-hero .container{ 
  width:94%; 
  max-width: 1240px; 
  margin:0 auto; 
}

/* OJO: el título usa la misma clase .cat-title de arriba, no se redefine aquí */

/* Dos columnas */
.prod-grid{
  display:grid;
  grid-template-columns: minmax(280px, 560px) 1fr;
  gap: clamp(22px, 4vw, 48px);
  align-items: start;
}
@media (max-width: 980px){
  .prod-grid{ grid-template-columns: 1fr; }
}

/* Cápsula gris para la imagen */
.prod-media .prod-media-inner {
  border-radius: var(--radius-card);
  aspect-ratio: 4 / 3;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding: 0; /* sin padding extra */
  background: none; /* sin fondo */
}

.prod-media img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* la imagen llena el espacio */
  display:block;
}


/* Info derecha */
.prod-info{ padding-top: clamp(0px, 1vw, 8px); }
.prod-title{
  margin: 0 0 6px 0;
  font-weight: 700;                  /* más elegante */
  font-size: clamp(24px, 5vw, 44px); /* menos exagerado */
  line-height: 1.15;
  color: #111;
}
.prod-subcat{
  color:#a0a0a0;
  font-size: 1.05rem;
  margin-bottom: 10px;
}
.prod-desc{
  color:#333;
  line-height: 1.55;
  font-size: 1rem;
  margin: 10px 0 12px 0;
  max-width: 64ch;
}

/* Lista de características con “radio” */
.prod-features{
  list-style: none; padding: 0; margin: 12px 0 20px 0;
  display: grid; gap: 10px;
}
.prod-features li{
  display:flex; align-items:center; gap:10px;
  color:#333; font-size: 1rem;
}
.prod-features .dot{
  width: 16px; height: 16px; border-radius: 50%;
  border: 2px solid #222;
  display:inline-block; flex: 0 0 16px;
  position: relative;
}
.prod-features .dot::after{
  content:''; position:absolute; inset:3px;
  border-radius:50%; background:#222; opacity:.1;
}

/* Botón WhatsApp (más fino y texto más delgado) */
.cta-wa{
  margin-top: 18px;
  display:inline-flex; align-items:center; gap:10px;
  text-decoration:none;
  font-weight: 500;                  /* más delgado */
  color:#111;
  border:1px solid #222;             /* fino */
  border-radius: 40px;
  padding: 8px 16px;                 /* compacto */
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.cta-wa:hover{ background:#f7f7f7; }

/* Icono WhatsApp como imagen */
.cta-wa img{
  width: 22px; height: 22px;         /* un toque más pequeño */
  display:block;
}

.catalogo {
  padding: 4rem 0;
  background: #f9f9f9; /* fondo claro */
  text-align: center;
}

.cat-title {
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--blue, #0e2e57);
  margin-bottom: .5rem;
}

.catalogo p {
  font-size: 1.1rem;
  color: #666;
  margin-bottom: 2rem;
}

.cat-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}

.cat-pill {
  display: inline-block;
  padding: .8rem 1.6rem;
  border-radius: 50px;
  background: var(--blue, #0e2e57);
  color: #fff;
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  transition: all 0.3s ease;
  box-shadow: 0 4px 8px rgba(0,0,0,.08);
}

.cat-pill:hover {
  background: var(--gold, #D4AF37);
  color: #0e2e57;
  transform: translateY(-3px);
  box-shadow: 0 6px 12px rgba(0,0,0,.12);
}

.map-wrap{ width:94%; max-width:920px; margin:24px auto 0; font-family:"Nunito Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif; }
.map-card{ background:#fff; border-radius:14px; box-shadow:0 10px 30px rgba(0,0,0,.06); overflow:hidden; }
.map-head{ padding:18px 20px 0; }
.map-head h2{ margin:0; color:#0e2e57; }
.map-head p{ margin:6px 0 12px; color:#374151; }

.map-frame{
  position:relative;
  width:100%;
  /* relación 16:9 con fallback */
  aspect-ratio:16/9;
  background:#eef2f7;
  overflow:hidden;
}
.map-frame iframe{
  position:absolute; inset:0;
  width:100%; height:100%;
  border:0;
  filter:saturate(1.05) contrast(1.02);
}

.map-actions{
  display:flex; justify-content:flex-end; gap:10px;
  padding:12px 16px 16px;
  border-top:1px solid #eef2f7;
}
.btn{
  background:#0e2e57; color:#fff; border:none;
  padding:10px 14px; border-radius:12px; cursor:pointer; font-weight:700; text-decoration:none; display:inline-block;
}
.btn:hover{ filter:brightness(1.06); }
.btn-outline{
  background:#fff; color:#0e2e57; border:1px solid #0e2e57;
}
.btn-outline:hover{ background:#0e2e57; color:#fff; }

body.menu-open::before{
  content:''; position:fixed; inset:0;
  background: rgba(0,0,0,.35);
  z-index: 2090;             /* detrás del panel */
  pointer-events: auto;
}
.mobile-panel{
  z-index: 2100;             /* sobre el backdrop */
  pointer-events: auto;
}



