/* ================================================
   CALZADO ARTESANAL LEÓN · XONACATLÁN
   CSS Premium — Diseño desde cero
   ================================================ */

/* --- Variables --- */
:root {
    --marron: #6B3A2A;
    --marron-oscuro: #3E1F13;
    --marron-claro: #A0674F;
    --dorado: #C9A84C;
    --dorado-suave: #F5E6B8;
    --negro: #18120E;
    --blanco: #FFFFFF;
    --crema: #FBF8F3;
    --gris-claro: #F2EFEB;
    --texto: #2C1E14;
    --texto-sec: #6B5E54;
    --texto-muted: #9E9389;
    --verde-wa: #25D366;
    --verde-wa-dark: #128C7E;
    --rojo: #C0392B;
    --exito: #27AE60;
    --error: #E74C3C;
    --info: #2980B9;

    --fuente-titulo: 'Cormorant Garamond', Georgia, serif;
    --fuente-cuerpo: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    --sombra-sm: 0 1px 3px rgba(0,0,0,.06);
    --sombra-md: 0 4px 12px rgba(0,0,0,.08);
    --sombra-lg: 0 12px 32px rgba(0,0,0,.1);
    --sombra-xl: 0 20px 50px rgba(0,0,0,.12);

    --radio-sm: 6px;
    --radio-md: 10px;
    --radio-lg: 16px;
    --radio-xl: 24px;

    --trans: 280ms ease;
    --max-w: 1180px;
}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--fuente-cuerpo);font-size:16px;line-height:1.65;color:var(--texto);background:var(--blanco)}
img{max-width:100%;height:auto;display:block}
a{color:var(--marron);text-decoration:none;transition:color var(--trans)}
a:hover{color:var(--marron-oscuro)}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
h1,h2,h3,h4{font-family:var(--fuente-titulo);font-weight:600;line-height:1.2;color:var(--negro)}
h1{font-size:clamp(2rem,5vw,3.2rem)}
h2{font-size:clamp(1.6rem,4vw,2.4rem)}
h3{font-size:clamp(1.15rem,2.5vw,1.45rem)}
p{margin-bottom:1rem}

/* --- Utilidades --- */
.contenedor{max-width:var(--max-w);margin:0 auto;padding:0 1.25rem}
.sr-only-focusable{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--marron);color:#fff;padding:.75rem 1.5rem;border-radius:var(--radio-md);z-index:9999;transition:top .2s}
.sr-only-focusable:focus{top:1rem}

/* ================================================
   BARRA SUPERIOR
   ================================================ */
.barra-superior{background:var(--negro);color:rgba(255,255,255,.85);font-size:.82rem;padding:.45rem 0}
.barra-superior__inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.barra-superior a{color:rgba(255,255,255,.85);display:inline-flex;align-items:center;gap:.35rem}
.barra-superior a:hover{color:var(--dorado)}
.barra-superior span{display:inline-flex;align-items:center;gap:.35rem}
.sep{opacity:.3;margin:0 .25rem}
.barra-superior__redes{display:flex;gap:.75rem}
.barra-superior__redes a{font-size:1rem;transition:color var(--trans),transform var(--trans)}
.barra-superior__redes a:hover{transform:scale(1.15)}

/* ================================================
   CABECERA / NAV
   ================================================ */
.cabecera{position:sticky;top:0;z-index:1000;background:var(--blanco);box-shadow:var(--sombra-sm);transition:box-shadow .3s}
.cabecera.scrolled{box-shadow:var(--sombra-md)}
.cabecera__inner{display:flex;justify-content:space-between;align-items:center;height:72px}
.cabecera__logo{display:flex;align-items:center;gap:.75rem;color:var(--negro)}
.cabecera__logo:hover{color:var(--negro)}
.cabecera__logo-icono{width:44px;height:44px;background:linear-gradient(135deg,var(--marron),var(--marron-oscuro));border-radius:var(--radio-md);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.15rem}
.cabecera__logo-texto{display:flex;flex-direction:column;line-height:1.15}
.cabecera__logo-texto strong{font-family:var(--fuente-titulo);font-size:1.2rem;font-weight:700}
.cabecera__logo-texto small{font-size:.72rem;color:var(--texto-sec);letter-spacing:.5px;text-transform:uppercase}

.nav-principal__lista{display:flex;align-items:center;gap:1.75rem}
.nav-principal__lista a{color:var(--texto);font-weight:500;font-size:.92rem;position:relative;padding:.35rem 0}
.nav-principal__lista a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--marron);transition:width .25s}
.nav-principal__lista a:hover::after,.nav-principal__lista a.activo::after{width:100%}
.nav-btn-wa{background:var(--verde-wa) !important;color:#fff !important;padding:.5rem 1.1rem !important;border-radius:var(--radio-md) !important;font-weight:600 !important;display:inline-flex;align-items:center;gap:.4rem}
.nav-btn-wa::after{display:none !important}
.nav-btn-wa:hover{background:var(--verde-wa-dark) !important;color:#fff !important}

/* Burger */
.cabecera__burger{display:none;flex-direction:column;gap:5px;padding:.5rem;width:40px}
.cabecera__burger span{display:block;width:100%;height:3px;background:var(--negro);border-radius:2px;transition:all .25s}

/* ================================================
   BOTONES
   ================================================ */
.boton{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.5rem;font-weight:500;font-size:.95rem;border-radius:var(--radio-md);transition:all var(--trans);text-decoration:none;border:2px solid transparent}
.boton--primario{background:var(--marron);color:#fff;border-color:var(--marron);box-shadow:0 4px 14px rgba(107,58,42,.25)}
.boton--primario:hover{background:var(--marron-oscuro);border-color:var(--marron-oscuro);color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(107,58,42,.35)}
.boton--wa{background:var(--verde-wa);color:#fff;border-color:var(--verde-wa)}
.boton--wa:hover{background:var(--verde-wa-dark);border-color:var(--verde-wa-dark);color:#fff;transform:translateY(-2px)}
.boton--outline{background:transparent;color:var(--marron);border-color:var(--marron)}
.boton--outline:hover{background:var(--marron);color:#fff}
.boton--light{background:#fff;color:var(--marron);border-color:#fff}
.boton--light:hover{background:var(--crema);color:var(--marron-oscuro)}
.boton--outline-light{background:transparent;color:#fff;border-color:#fff}
.boton--outline-light:hover{background:#fff;color:var(--marron)}
.boton--lg{padding:.9rem 2rem;font-size:1.05rem}
.boton--sm{padding:.4rem .9rem;font-size:.82rem}
.boton--block{width:100%}

/* ================================================
   HERO
   ================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(24,18,14,.82) 0%,rgba(62,31,19,.65) 60%,rgba(107,58,42,.45) 100%)}
.hero__contenido{position:relative;z-index:2;color:#fff;max-width:720px;padding:7rem 0 4rem}
.hero__badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--dorado);color:var(--negro);padding:.4rem 1.1rem;border-radius:50px;font-size:.8rem;font-weight:600;margin-bottom:1.5rem}
.hero h1{color:#fff;margin-bottom:1rem}
.hero h1 em{font-style:normal;color:var(--dorado-suave)}
.hero>div>p{font-size:1.12rem;opacity:.9;margin-bottom:2rem;max-width:580px;line-height:1.7}
.hero__acciones{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.5rem}
.hero__sellos{display:flex;flex-wrap:wrap;gap:1.5rem}
.hero__sello{display:flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:500;opacity:.85}
.hero__sello i{color:var(--dorado);font-size:1.1rem}

/* ================================================
   SECCIONES
   ================================================ */
.seccion{padding:5rem 0}
.seccion--crema{background:var(--crema)}
.seccion__cabecera{text-align:center;max-width:620px;margin:0 auto 3rem}
.seccion__cabecera--claro .seccion__titulo{color:#fff}
.seccion__etiqueta{display:inline-block;color:var(--marron);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;margin-bottom:.5rem}
.seccion__etiqueta--dorado{color:var(--dorado)}
.seccion__titulo{margin-bottom:.75rem}
.seccion__desc{color:var(--texto-sec);font-size:1.05rem}
.seccion__pie{text-align:center;margin-top:3rem}

/* ================================================
   BENEFICIOS
   ================================================ */
.beneficios{background:var(--blanco);padding:4rem 0}
.beneficios__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.beneficio{text-align:center;padding:2rem 1.25rem;border-radius:var(--radio-lg);transition:all .3s}
.beneficio:hover{background:var(--crema);transform:translateY(-6px);box-shadow:var(--sombra-md)}
.beneficio__icono{width:64px;height:64px;background:linear-gradient(135deg,var(--marron),var(--marron-oscuro));border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;color:#fff;font-size:1.4rem}
.beneficio h3{margin-bottom:.5rem}
.beneficio p{color:var(--texto-sec);font-size:.9rem;margin:0}

/* ================================================
   TARJETAS DE PRODUCTO
   ================================================ */
.productos__grid,.catalogo__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.5rem}
.tarjeta-prod{background:var(--blanco);border-radius:var(--radio-lg);overflow:hidden;box-shadow:var(--sombra-md);transition:all .3s}
.tarjeta-prod:hover{transform:translateY(-8px);box-shadow:var(--sombra-xl)}
.tarjeta-prod[hidden]{display:none}
.tarjeta-prod__img{position:relative;height:230px;overflow:hidden}
.tarjeta-prod__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.tarjeta-prod:hover .tarjeta-prod__img img{transform:scale(1.06)}
.tarjeta-prod__badge{position:absolute;top:.75rem;left:.75rem;background:var(--marron);color:#fff;padding:.25rem .85rem;border-radius:50px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.tarjeta-prod__badge--nuevo{background:var(--exito)}
.tarjeta-prod__info{padding:1.25rem}
.tarjeta-prod__info h3{margin-bottom:.35rem}
.tarjeta-prod__info p{color:var(--texto-sec);font-size:.88rem}
.tarjeta-prod__meta-cat{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.tarjeta-prod__cat{font-size:.7rem;color:var(--marron);font-weight:700;text-transform:uppercase;letter-spacing:1px}
.tarjeta-prod__color{font-size:.75rem;color:var(--texto-muted);display:flex;align-items:center;gap:4px}
.tarjeta-prod__meta{display:flex;justify-content:space-between;align-items:center;padding-top:.85rem;border-top:1px solid var(--gris-claro);margin-top:.75rem}
.tarjeta-prod__precio{font-family:var(--fuente-titulo);font-size:1.35rem;font-weight:700;color:var(--marron)}
.tarjeta-prod__precio small{font-size:.7rem;font-weight:400;color:var(--texto-muted)}

/* ================================================
   PASOS (CÓMO COMPRAR)
   ================================================ */
.pasos{display:flex;align-items:flex-start;justify-content:center;gap:1rem;flex-wrap:wrap}
.paso{text-align:center;flex:1;min-width:200px;max-width:280px}
.paso__numero{width:42px;height:42px;background:var(--marron);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fuente-titulo);font-size:1.1rem;font-weight:700;margin:0 auto .75rem}
.paso__icono{width:72px;height:72px;background:var(--crema);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem;color:var(--marron);font-size:1.6rem}
.paso h3{margin-bottom:.35rem}
.paso p{color:var(--texto-sec);font-size:.88rem;margin:0}
.paso__flecha{display:flex;align-items:center;color:var(--marron-claro);font-size:1.4rem;padding-top:3rem}

/* ================================================
   GALERÍA DE PIEL
   ================================================ */
.galeria-piel{overflow:hidden}
.galeria-piel__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.galeria-piel__item{overflow:hidden;height:320px}
.galeria-piel__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.galeria-piel__item:hover img{transform:scale(1.08)}
.galeria-piel__texto{background:var(--negro);color:#fff;padding:3rem 0;text-align:center}
.galeria-piel__texto h2{color:#fff;margin-bottom:.75rem}
.galeria-piel__texto p{max-width:700px;margin:0 auto;color:rgba(255,255,255,.8);font-size:1.05rem}

/* ================================================
   TESTIMONIOS
   ================================================ */
.testimonios{background:var(--negro);padding:5rem 0;color:#fff}
.testimonios__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.testimonio{background:rgba(255,255,255,.05);padding:1.75rem;border-radius:var(--radio-lg);border:1px solid rgba(255,255,255,.08);transition:transform .3s}
.testimonio:hover{transform:translateY(-5px)}
.testimonio__estrellas{color:var(--dorado);margin-bottom:.75rem;font-size:.9rem;display:flex;gap:2px}
.testimonio blockquote{font-style:italic;font-size:1.02rem;line-height:1.65;margin-bottom:1.25rem;color:rgba(255,255,255,.9)}
.testimonio__autor{display:flex;align-items:center;gap:.75rem}
.testimonio__avatar{width:42px;height:42px;background:var(--marron);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem}
.testimonio__autor cite{display:block;font-weight:600;font-style:normal;font-size:.9rem}
.testimonio__autor span{display:block;font-size:.78rem;opacity:.6}

/* ================================================
   MAPA SECCIÓN
   ================================================ */
.mapa-seccion{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.mapa-seccion__info .seccion__titulo{text-align:left}
.mapa-seccion__info p{color:var(--texto-sec);margin-bottom:1.5rem}
.mapa-seccion__lista{list-style:none;margin-bottom:2rem}
.mapa-seccion__lista li{display:flex;align-items:center;gap:.6rem;margin-bottom:.7rem;font-size:.95rem}
.mapa-seccion__lista i{color:var(--exito);font-size:1rem}
.mapa-seccion__mapa{border-radius:var(--radio-lg);overflow:hidden;box-shadow:var(--sombra-lg)}
.mapa-seccion__mapa iframe{display:block;width:100%;min-height:400px}

/* ================================================
   CTA FINAL
   ================================================ */
.cta-final{position:relative;padding:6rem 0;text-align:center;overflow:hidden}
.cta-final__bg{position:absolute;inset:0;background-size:cover;background-position:center}
.cta-final__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(107,58,42,.92),rgba(62,31,19,.95))}
.cta-final__contenido{position:relative;z-index:2;color:#fff}
.cta-final__contenido h2{color:#fff;margin-bottom:.75rem}
.cta-final__contenido p{max-width:550px;margin:0 auto 2rem;opacity:.9;font-size:1.1rem}
.cta-final__acciones{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}

/* ================================================
   PAGE HEADERS
   ================================================ */
.pag-cabecera{background:linear-gradient(135deg,var(--crema) 0%,var(--gris-claro) 100%);padding:7.5rem 0 3rem;text-align:center}
.pag-cabecera h1{margin-bottom:.5rem}
.pag-cabecera p{color:var(--texto-sec);font-size:1.05rem;max-width:600px;margin:0 auto}
.pag-cabecera--oscura{background:linear-gradient(135deg,var(--marron) 0%,var(--marron-oscuro) 100%)}
.pag-cabecera--oscura h1,.pag-cabecera--oscura p{color:#fff}
.pag-cabecera--verde{background:linear-gradient(135deg,var(--verde-wa) 0%,var(--verde-wa-dark) 100%)}
.pag-cabecera--verde h1,.pag-cabecera--verde p{color:#fff}

/* ================================================
   CATÁLOGO FILTROS
   ================================================ */
.catalogo-seccion{padding:2.5rem 0 5rem}
.catalogo__filtros{display:flex;justify-content:center;gap:.65rem;margin-bottom:2.5rem;flex-wrap:wrap}
.filtro{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.3rem;background:var(--crema);border:2px solid transparent;border-radius:50px;font-size:.88rem;font-weight:500;color:var(--texto-sec);transition:all .2s}
.filtro:hover,.filtro.activo{background:var(--marron);color:#fff;border-color:var(--marron)}
.catalogo__vacio{text-align:center;padding:3rem;color:var(--texto-muted);font-size:1.1rem}
.catalogo__vacio i{display:block;font-size:2.5rem;margin-bottom:.75rem}

/* ================================================
   INFO COMPRA
   ================================================ */
.info-compra{padding:4.5rem 0}
.info-compra__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2rem}
.info-compra__item{text-align:center;padding:1.75rem 1rem;background:var(--blanco);border-radius:var(--radio-lg);box-shadow:var(--sombra-sm)}
.info-compra__item i{font-size:2rem;color:var(--marron);margin-bottom:.75rem}
.info-compra__item h3{margin-bottom:.35rem}
.info-compra__item p{color:var(--texto-sec);font-size:.86rem;margin:0}

/* ================================================
   NOSOTROS
   ================================================ */
.sobre__grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.sobre__texto .seccion__titulo{text-align:left}
.sobre__texto p{color:var(--texto-sec)}
.sobre__imagen{border-radius:var(--radio-lg);overflow:hidden;box-shadow:var(--sombra-lg)}
.sobre__imagen img{width:100%;height:auto;object-fit:cover}
.sobre__cifras{display:flex;gap:2.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--gris-claro)}
.cifra{text-align:center}
.cifra__num{display:block;font-family:var(--fuente-titulo);font-size:2.2rem;font-weight:700;color:var(--marron);line-height:1.1}
.cifra__texto{font-size:.82rem;color:var(--texto-sec)}

/* Valores */
.valores__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.valor{background:var(--blanco);padding:2rem 1.25rem;border-radius:var(--radio-lg);text-align:center;box-shadow:var(--sombra-sm);transition:all .3s}
.valor:hover{transform:translateY(-6px);box-shadow:var(--sombra-md)}
.valor__icono{width:64px;height:64px;background:linear-gradient(135deg,var(--marron),var(--marron-oscuro));border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;color:#fff;font-size:1.4rem}
.valor h3{margin-bottom:.5rem}
.valor p{color:var(--texto-sec);font-size:.88rem;margin:0}

/* Proceso */
.proceso__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.proceso__paso{text-align:center;position:relative}
.proceso__num{font-family:var(--fuente-titulo);font-size:3rem;font-weight:700;color:var(--marron);opacity:.2;line-height:1}
.proceso__icono{width:72px;height:72px;background:var(--crema);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:.5rem auto .75rem;color:var(--marron);font-size:1.5rem}
.proceso__paso h3{margin-bottom:.35rem}
.proceso__paso p{color:var(--texto-sec);font-size:.88rem;margin:0}

/* ================================================
   CONTACTO
   ================================================ */
.contacto__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:3rem}
.contacto__info h2,.contacto__form-panel h2{margin-bottom:1rem}
.contacto__info>p{color:var(--texto-sec);margin-bottom:1.5rem}
.contacto__medios{list-style:none;margin-bottom:2rem}
.contacto__medios li{display:flex;align-items:flex-start;gap:.85rem;margin-bottom:1.1rem;padding:1rem;background:var(--crema);border-radius:var(--radio-md)}
.contacto__icono{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;flex-shrink:0}
.contacto__icono--wa{background:var(--verde-wa)}
.contacto__icono--tel{background:var(--marron)}
.contacto__icono--email{background:var(--info)}
.contacto__icono--ubi{background:var(--rojo)}
.contacto__label{font-size:.7rem;color:var(--texto-muted);text-transform:uppercase;letter-spacing:.5px}
.contacto__dato{font-weight:600;color:var(--texto);font-size:1.05rem;display:block}
.contacto__medios small{font-size:.82rem;color:var(--texto-sec)}
.contacto__redes-box h3{margin-bottom:.75rem}
.contacto__redes{display:flex;gap:.65rem}
.redes-link{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.05rem;transition:transform .2s}
.redes-link:hover{transform:scale(1.12);color:#fff}
.redes-link--fb{background:#1877F2}
.redes-link--ig{background:linear-gradient(45deg,#f09433,#dc2743,#bc1888)}
.redes-link--wa{background:var(--verde-wa)}

/* Form panel */
.contacto__form-panel{background:var(--crema);padding:2rem;border-radius:var(--radio-lg)}
.alerta{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-radius:var(--radio-md);margin-bottom:1.25rem}
.alerta i{font-size:1.2rem;flex-shrink:0;margin-top:2px}
.alerta--ok{background:#d4edda;color:#155724}
.alerta--ok i{color:var(--exito)}
.alerta--error{background:#f8d7da;color:#721c24}
.alerta--error i{color:var(--error)}
.alerta p{margin:0}
.form-contacto{display:flex;flex-direction:column;gap:1rem}
.form-fila{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-grupo{display:flex;flex-direction:column;gap:.3rem}
.form-grupo label{font-size:.88rem;font-weight:500}
.req{color:var(--error)}
.form-grupo input,.form-grupo select,.form-grupo textarea{padding:.6rem .85rem;border:1px solid #d9d3cc;border-radius:var(--radio-md);font-family:inherit;font-size:.95rem;transition:border-color .2s;background:var(--blanco)}
.form-grupo input:focus,.form-grupo select:focus,.form-grupo textarea:focus{outline:none;border-color:var(--marron)}
.form-grupo input.error,.form-grupo textarea.error{border-color:var(--error)}
.form-legal{font-size:.82rem;color:var(--texto-muted)}
.form-legal a{text-decoration:underline}
.contacto__wa-cta{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #d9d3cc;text-align:center}
.contacto__wa-cta p{color:var(--texto-sec);margin-bottom:.75rem}

/* Mapa contacto */
.mapa-contacto__grid{display:grid;grid-template-columns:1fr 2fr;gap:2.5rem}
.mapa-contacto__horarios{background:var(--blanco);padding:1.75rem;border-radius:var(--radio-lg);box-shadow:var(--sombra-sm)}
.mapa-contacto__horarios h2{font-size:1.3rem;margin-bottom:1rem}
.horarios li{display:flex;justify-content:space-between;padding:.55rem 0;border-bottom:1px solid var(--gris-claro)}
.horarios .cerrado span:last-child{color:var(--error)}
.horarios__nota{display:flex;gap:.5rem;padding:.85rem;background:var(--crema);border-radius:var(--radio-sm);margin-top:1rem;font-size:.85rem}
.horarios__nota i{color:var(--info);flex-shrink:0;margin-top:2px}
.horarios__nota p{margin:0}
.mapa-contacto__mapa{background:var(--blanco);padding:1.75rem;border-radius:var(--radio-lg);box-shadow:var(--sombra-sm)}
.mapa-contacto__mapa h2{font-size:1.3rem;margin-bottom:1rem}
.mapa-wrap{border-radius:var(--radio-md);overflow:hidden}

/* ================================================
   PÁGINAS LEGALES
   ================================================ */
.legal__contenido{max-width:780px;margin:0 auto}
.legal__intro{background:var(--crema);padding:1.5rem;border-radius:var(--radio-lg);margin-bottom:2.5rem}
.legal__intro p:last-child{margin:0}
.legal article{margin-bottom:2.5rem}
.legal article h2{color:var(--marron);font-size:1.45rem;padding-bottom:.5rem;border-bottom:2px solid var(--gris-claro);margin-bottom:1rem}
.legal article h3{font-size:1.15rem;margin-top:1.5rem;margin-bottom:.5rem}
.legal article ul,.legal article ol{margin-left:1.5rem;margin-bottom:1rem}
.legal article ul{list-style:disc}
.legal article ol{list-style:decimal}
.legal article li{margin-bottom:.4rem;line-height:1.6}
.legal__contacto-box{background:var(--crema);padding:1.25rem;border-radius:var(--radio-md);margin-top:1rem}
.legal__contacto-box p{margin-bottom:.4rem;display:flex;align-items:center;gap:.5rem}
.legal__contacto-box i{color:var(--marron);width:18px}
.tabla-cookies{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.88rem}
.tabla-cookies th,.tabla-cookies td{padding:.55rem .75rem;text-align:left;border-bottom:1px solid var(--gris-claro)}
.tabla-cookies th{background:var(--crema);font-weight:600}

/* ================================================
   404
   ================================================ */
.error-404{padding:10rem 0 6rem;text-align:center}
.error-404__codigo{font-family:var(--fuente-titulo);font-size:8rem;font-weight:700;color:var(--marron);opacity:.15;line-height:1}
.error-404 h1{margin-bottom:.75rem}
.error-404 p{color:var(--texto-sec);max-width:500px;margin:0 auto 2rem}
.error-404__acciones{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}

/* ================================================
   FOOTER
   ================================================ */
.pie{background:var(--negro);color:rgba(255,255,255,.8)}
.pie__principal{padding:4.5rem 0 2.5rem}
.pie__grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.2fr;gap:2.5rem}
.pie__logo{display:flex;align-items:center;gap:.65rem;margin-bottom:1rem}
.pie__logo-icono{width:40px;height:40px;background:var(--marron);border-radius:var(--radio-md);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem}
.pie__logo-texto{display:flex;flex-direction:column;line-height:1.15}
.pie__logo-texto strong{font-family:var(--fuente-titulo);font-size:1.1rem;color:#fff}
.pie__logo-texto small{font-size:.68rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.5px}
.pie__col p{font-size:.88rem;line-height:1.6;margin-bottom:1rem}
.pie__col h4{color:#fff;font-size:1.05rem;margin-bottom:1rem}
.pie__col ul li{margin-bottom:.45rem}
.pie__col ul a{color:rgba(255,255,255,.65);font-size:.88rem}
.pie__col ul a:hover{color:var(--dorado)}
.pie__redes{display:flex;gap:.6rem;margin-top:.75rem}
.pie__redes a{width:36px;height:36px;background:rgba(255,255,255,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;transition:all .2s}
.pie__redes a:hover{background:var(--marron);color:#fff}
.pie__contacto-lista li{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.5rem;font-size:.85rem;color:rgba(255,255,255,.65)}
.pie__contacto-lista i{color:var(--marron-claro);margin-top:3px;width:16px;flex-shrink:0}
.pie__contacto-lista a{color:rgba(255,255,255,.65)}
.pie__contacto-lista a:hover{color:var(--dorado)}
.pie__bottom{border-top:1px solid rgba(255,255,255,.08);padding:1.25rem 0}
.pie__bottom-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.pie__bottom p{font-size:.8rem;color:rgba(255,255,255,.4);margin:0}

/* ================================================
   WHATSAPP FLOTANTE
   ================================================ */
.wa-flotante{position:fixed;bottom:1.75rem;right:1.5rem;width:58px;height:58px;background:var(--verde-wa);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.7rem;box-shadow:0 4px 16px rgba(37,211,102,.35);z-index:99;transition:all .25s}
.wa-flotante:hover{background:var(--verde-wa-dark);transform:scale(1.1);color:#fff}

/* ================================================
   RESPONSIVE
   ================================================ */
@media(max-width:1024px){
    .beneficios__grid,.valores__grid,.proceso__grid,.info-compra__grid{grid-template-columns:repeat(2,1fr)}
    .pie__grid{grid-template-columns:1fr 1fr}
    .sobre__grid,.mapa-seccion,.contacto__grid,.mapa-contacto__grid{grid-template-columns:1fr}
    .sobre__imagen{order:-1}
}
@media(max-width:768px){
    .cabecera__burger{display:flex}
    .nav-principal{position:absolute;top:100%;left:0;right:0;background:var(--blanco);box-shadow:var(--sombra-lg);display:none;padding:1rem}
    .nav-principal.abierto{display:block}
    .nav-principal__lista{flex-direction:column;gap:.25rem}
    .nav-principal__lista li{width:100%}
    .nav-principal__lista a{display:block;padding:.65rem 1rem;border-radius:var(--radio-sm)}
    .nav-principal__lista a:hover{background:var(--crema)}
    .nav-principal__lista a::after{display:none}
    .nav-btn-wa{text-align:center;justify-content:center;margin-top:.5rem}
    .barra-superior__contacto{display:none}
    .barra-superior__inner{justify-content:center}
    .hero__contenido{padding:6rem 0 3rem}
    .beneficios__grid,.valores__grid,.proceso__grid,.info-compra__grid,.testimonios__grid{grid-template-columns:1fr}
    .galeria-piel__grid{grid-template-columns:1fr}
    .galeria-piel__item{height:220px}
    .pasos{flex-direction:column;align-items:center}
    .paso__flecha{transform:rotate(90deg)}
    .pie__grid{grid-template-columns:1fr;text-align:center}
    .pie__redes{justify-content:center}
    .pie__bottom-inner{flex-direction:column;text-align:center}
    .form-fila{grid-template-columns:1fr}
    .catalogo__filtros{flex-direction:column;align-items:center}
    .mapa-contacto__grid{grid-template-columns:1fr}
    .sobre__cifras{flex-direction:column;align-items:center;gap:1.5rem}
}
@media(max-width:480px){
    .cabecera__logo-texto{display:none}
    .hero__sellos{flex-direction:column;gap:.65rem}
    .wa-flotante{width:50px;height:50px;font-size:1.4rem;bottom:1.25rem;right:1rem}
}

/* Reducción de movimiento */
@media(prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* Focus visible */
:focus-visible{outline:2px solid var(--marron);outline-offset:2px}
