:root{
  --bg:#F7F3EF;--bg-alt:#3B2E22;--wood:#3B2E22;--text:#2B2B2B;--text2:#2B2B2B;--head:#F7F4F0;
  --accent:#C9A86A;--brown-gradient:linear-gradient(120deg,#FAF7F3 0%,#3B2E22 100%);
  --ui1:#EAE7E2;--ui2:#CFCAC2;--radius:16px;--shadow:0 10px 30px rgba(0,0,0,.30);
  --fontHead:'Poppins',sans-serif;--fontBody:'Manrope',sans-serif;
}
*{box-sizing:border-box}
html,body{
  margin:0;
  padding:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--fontBody);
  scroll-behavior:smooth;
  max-width:100%;
  overflow-x:hidden;   /* bloquea el desplazamiento lateral en móvil */
}

img{max-width:100%;display:block}
.container{width:min(1120px,92%);margin-inline:auto}

/* Secciones */
.section{padding:64px 0;background:var(--bg);color:var(--text);}
.section-alt{padding:64px 0;background:var(--brown-gradient);color:var(--head);}
.section-title{font-family:var(--fontHead);font-size:clamp(26px,3vw,34px);margin:0 0 8px;position:relative;}
.section-title::after{content:"";position:absolute;left:0;bottom:-6px;width:72px;height:3px;border-radius:999px;background:var(--accent);}
.section .section-title{color:#2B2B2B !important;}
.section-alt .section-title{color:#2B2B2B !important;}
#contacto,#contacto a,.contact-line,.contact-line a{color:#2B2B2B !important;}
.section-lead{margin:18px 0 24px;color:#4a4a4a;max-width:720px;}
.section-alt .section-lead{color:var(--text2);}

/* Header */
.site-header{position:sticky;top:0;background:var(--wood);border-bottom:none;z-index:10;backdrop-filter:none;transition:background .25s ease,backdrop-filter .25s ease;}
.site-header.is-scrolled{background:rgba(59,46,34,.92);backdrop-filter:saturate(140%) blur(8px);}
.header-beige{background:transparent;padding:10px 14px;border-radius:var(--radius);}
.header-inner{display:flex;gap:16px;align-items:center;justify-content:space-between;padding:10px 0;}
.logo{font-family:var(--fontHead);letter-spacing:.5px;font-weight:700;color:var(--head);text-decoration:none;}
.logo span{color:#000;}
.nav{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.nav a{color:var(--head);text-decoration:none;padding:8px 10px;border-radius:10px;transition:.25s;}
.nav a:hover{background:rgba(255,255,255,.10);}
.social{opacity:.95;}

/* Mega menú */
.mega-nav{display:flex;align-items:center;gap:16px;width:100%;}
.mega-nav .menu{display:flex;gap:18px;list-style:none;margin:0;padding:0;align-items:center;}
.mega-nav .menu a,.mega-nav .menu .menu-btn{color:#fff;text-decoration:none;font-weight:600;background:transparent;border:none;cursor:pointer;padding:8px 10px;border-radius:8px;font-size:inherit;}
.mega-nav .menu a:hover,.mega-nav .menu .menu-btn:hover{background:rgba(0,0,0,.12);}
.has-submenu{position:relative;}
.submenu{
  position:absolute;
  left:0;
  top:110%;
  min-width:520px;
  padding:14px;
  border-radius:12px;
  background:#fff;
  color:#1f1f1f;
  border:1px solid var(--ui1);
  box-shadow:var(--shadow);
  z-index:2000;
  display:flex;
  gap:24px;

  /* oculto por defecto pero sin saltos */
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(6px);
  transition:opacity .18s ease,transform .18s ease,visibility 0s linear .18s;
}
.has-submenu:hover .submenu,
.has-submenu:focus-within .submenu{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0);
  transition:opacity .18s ease,transform .18s ease,visibility 0s;
}
.submenu a{color:#1f1f1f !important;padding:6px 8px;border-radius:8px;display:block;white-space:nowrap;}
.submenu a:hover{background:var(--ui1);}
.submenu-col{display:flex;flex-direction:column;gap:4px;}

/* Hero */
.hero{position:relative;padding:82px 0 76px;background:var(--brown-gradient);}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center;}
@media(max-width:900px){.hero-inner{grid-template-columns:1fr;}}
.hero-pill-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px;}
.pill{font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:999px;background:#fff;border:1px solid rgba(0,0,0,.04);}
.pill-outline{background:rgba(255,255,255,.4);border:1px solid rgba(0,0,0,.08);}
.hero-copy h1{font-family:var(--fontHead);color:#2B2B2B;font-size:clamp(28px,4vw,44px);margin:0 0 8px;}
.sub{margin:0 0 16px;color:#555;}
.cta-row{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap;}
.tagline{background:#fff;border:1px solid var(--ui1);border-radius:var(--radius);padding:14px 16px;line-height:1.3;box-shadow:var(--shadow);white-space:pre-wrap;}

/* Botones */
.btn{padding:12px 24px;border-radius:var(--radius);background:var(--accent);color:#2B2B2B;font-weight:600;border:none;cursor:pointer;box-shadow:var(--shadow);transition:.2s;text-decoration:none;display:inline-flex;justify-content:center;align-items:center;gap:6px;}
.btn:hover{background:#B99868;}
.btn-outline{background:transparent;color:#2B2B2B;border:1px solid #2B2B2B;box-shadow:none;}
.btn-wa{background:#1F1F1F;color:#fff;}
.btn.full{width:100%;}

/* Imagen hero */
.hero-media{min-height:350px;max-height:400px;border-radius:var(--radius);background:linear-gradient(180deg,rgba(0,0,0,.10),rgba(0,0,0,.10)),url('assets/img/hero.webp') center/cover no-repeat;box-shadow:var(--shadow);transition:transform .5s ease,box-shadow .5s ease;}
.hero-media:hover{transform:scale(1.02);box-shadow:0 12px 35px rgba(0,0,0,.15);}

/* Productos / filtros */
.section-head{display:flex;flex-direction:column;align-items:flex-start;}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin:16px 0 24px;}
.chip{padding:8px 12px;border-radius:99px;border:1px solid var(--ui2);background:#fff;cursor:pointer;color:#2B2B2B;font-size:13px;}
.chip.active,.chip:hover{border-color:#2B2B2B;color:#2B2B2B;}

/* Cards */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media(max-width:900px){.grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){.grid{grid-template-columns:1fr;}}
.card{background:#fff;border:1px solid var(--ui1);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;color:#2B2B2B;}
.card-img{background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.08)),url('assets/img/placeholder.webp') center/cover no-repeat;aspect-ratio:4/3;}
.card-body{padding:16px;display:flex;flex-direction:column;gap:8px;}
.card-body h3{margin:0 0 4px;font-family:var(--fontHead);color:#2B2B2B;}
.card-body p{font-size:14px;line-height:1.4;}
.badge{display:inline-block;margin-left:6px;background:var(--ui1);border:1px solid var(--ui2);border-radius:8px;padding:2px 8px;font-size:11px;}

/* Beneficios / FAQ */
.benefits{display:flex;gap:12px;flex-wrap:wrap;padding:0;margin:12px 0 0;}
.benefits li{list-style:none;background:#fff;border:1px solid var(--ui1);border-radius:12px;padding:10px 12px;color:#2B2B2B;}
.list{padding-left:18px;}
.faq{margin:10px 0;border:1px solid var(--ui1);border-radius:10px;background:#fff;padding:10px 12px;color:#2B2B2B;}

/* Pagos */
.payments{display:flex;flex-wrap:wrap;gap:10px;padding:0;margin:16px 0 0;list-style:none;}
.payment-chip{background:#fff;border:1px solid var(--ui2);border-radius:999px;padding:10px 14px;box-shadow:var(--shadow);font-weight:600;color:#2B2B2B;}

/* Contacto */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
@media(max-width:800px){.contact-grid{grid-template-columns:1fr;}}
.contact-line{margin:8px 0;}

/* Footer */
.site-footer{border-top:1px solid var(--ui1);padding:16px 0;background:#fff;color:#2B2B2B;}
.footer-inner{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap;}
.foot-nav a{margin-left:12px;color:#444;text-decoration:none;}
.foot-nav a:hover{text-decoration:underline;}
#sucursales h3{font-family:var(--fontHead);color:#2B2B2B;margin:0 0 8px;font-size:20px;}

/* NOSOTROS / MVV */
.section-nosotros{background:var(--bg);}
.nosotros-lead{max-width:880px;margin:0 auto 40px;text-align:center;color:#4a4a4a;line-height:1.6;}
.mv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;align-items:flex-start;}
.mv-item{background:#fff;border-radius:var(--radius);border:1px solid var(--ui1);box-shadow:var(--shadow);padding:26px 22px 24px;color:var(--text2);text-align:center;}
.mv-item h3{font-family:var(--fontHead);font-size:26px;margin:16px 0 10px;color:#2B2B2B;}
.mv-divider{width:90px;height:3px;background:var(--accent);margin:0 auto 18px;border-radius:10px;}
.mv-icon{width:140px;height:140px;margin:0 auto;border-radius:50%;background:#fff;border:3px solid var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 22px rgba(0,0,0,.15);}
.mv-icon img{width:70%;height:70%;object-fit:contain;}
.mv-values-list{margin:0;padding-left:20px;text-align:left;line-height:1.6;}
.mv-values-list li+li{margin-top:6px;}
@media (max-width:900px){.mv-grid{grid-template-columns:1fr;}.mv-item{padding:24px 18px;}}

/* Galería dentro de card */
.card-gallery{display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x mandatory;border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;}
.card-gallery img{flex:0 0 auto;width:100%;max-width:260px;border-radius:var(--radius);scroll-snap-align:start;}

/* Quitar la línea blanca en productos con solo 1 imagen */
.card-gallery:has(img:only-child){display:block;overflow:hidden;}
.card-gallery:has(img:only-child) img{width:100%;max-width:100%;display:block;}

@media (max-width:650px){

  /* HEADER en columna para que entre todo */
  .header-inner{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
    padding:8px 0 10px;
  }

  .mega-nav{
    flex-direction:column;
    align-items:flex-start;
    width:100%;
    gap:8px;
  }

  .mega-nav .menu{
    display:flex;
    flex-wrap:wrap;      /* que pueda bajar a varias filas */
    column-gap:12px;
    row-gap:4px;
    padding:0;
  }

  .mega-nav .menu a,
  .mega-nav .menu .menu-btn{
    font-size:13px;
    padding:6px 4px;
  }

  /* Submenú: sin ancho fijo y sin desbordar */
  .submenu{
    position:static;     /* se ubica debajo del botón */
    min-width:0;
    width:100%;
    margin-top:4px;
    box-shadow:none;
    padding:10px 0 0;
    transform:none;
    opacity:1;
    visibility:visible;
    pointer-events:auto;
  }

  .submenu-col{
    gap:6px;
  }
}
