/* ═══════════════════════════════════════════
   JENGIBRE TEJIDOS — style.css | 2026
   ═══════════════════════════════════════════ */
:root {
  --crema:#F9F7F2; --lana:#F0EBE1; --jengibre:#C17D3C;
  --jengibre-claro:#D4956A; --tierra:#3A2B1F; --tierra-medio:#5C4033;
  --texto:#2C1F16; --texto-suave:#6B5444; --borde:#D4C4A8;
  --musgo:#5C6A47; --musgo-claro:#8A9A72; --blanco:#FFFFFF;
  --wa:#25D366; --ig:#E1306C; --fb:#1877F2;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --radio:2px; --trans:0.35s cubic-bezier(0.25,0.46,0.45,0.94);
  --sombra:0 8px 32px rgba(44,31,22,0.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--sans);background:var(--crema);color:var(--texto);line-height:1.7;font-weight:300;overflow-x:hidden;}
img{display:block;max-width:100%;height:auto;transition:opacity 0.4s ease;}
img[loading="lazy"]{opacity:0;}
img[loading="lazy"].loaded,img:not([loading]){opacity:1;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
strong{font-weight:500;}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.15;}
h1{font-size:clamp(2.4rem,6.5vw,4.8rem);}
h2{font-size:clamp(1.9rem,4vw,3rem);}
h3{font-size:clamp(1.1rem,2vw,1.5rem);}
em{font-style:italic;color:var(--jengibre);}
p{font-size:clamp(0.92rem,1.4vw,1.05rem);}
.etiqueta{display:inline-block;font-size:0.68rem;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--musgo);margin-bottom:0.75rem;}
.etiqueta--claro{color:var(--jengibre-claro);}
.seccion-cab{text-align:center;max-width:600px;margin:0 auto clamp(2.5rem,5vw,4rem);}
.seccion-cab h2{color:var(--tierra);margin-bottom:0.75rem;}
.seccion-cab p{color:var(--texto-suave);}
.contenedor{max-width:1200px;margin:0 auto;padding:0 clamp(1.25rem,5vw,4rem);}

/* BARRA TOP */
.barra-top{background:var(--tierra);color:rgba(240,235,225,0.85);font-size:0.68rem;letter-spacing:0.12em;padding:0.45rem 1rem;border-bottom:1px solid rgba(193,125,60,0.25);}
.barra-top__inner{display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;max-width:1200px;margin:0 auto;align-items:center;}

/* BOTONES */
.btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.85rem 2rem;font-family:var(--sans);font-size:0.82rem;font-weight:400;letter-spacing:0.1em;text-transform:uppercase;border:1px solid transparent;cursor:pointer;transition:var(--trans);white-space:nowrap;border-radius:var(--radio);touch-action:manipulation;}
.btn--primario{background:var(--jengibre);color:var(--blanco);border-color:var(--jengibre);}
.btn--primario:hover{background:var(--tierra);border-color:var(--tierra);transform:translateY(-1px);}
.btn--oscuro{background:var(--tierra);color:var(--lana);border-color:var(--tierra);}
.btn--oscuro:hover{background:var(--tierra-medio);transform:translateY(-1px);}
.btn--wa{background:var(--wa);color:var(--blanco);border-color:var(--wa);}
.btn--wa:hover{background:#1da851;transform:scale(1.04);}
.btn--sm{padding:0.6rem 1.25rem;font-size:0.75rem;}
.btn--claro-outline{background:transparent;color:var(--lana);border-color:rgba(240,235,225,0.4);}
.btn--claro-outline:hover{border-color:var(--lana);background:rgba(240,235,225,0.08);}
.btn--enviar{background:var(--musgo);color:var(--blanco);border:none;width:100%;padding:1rem 2rem;font-size:0.85rem;cursor:pointer;position:relative;transition:background var(--trans),transform 0.25s cubic-bezier(0.34,1.56,0.64,1);border-radius:var(--radio);}
.btn--enviar:hover{background:var(--musgo-claro);transform:scale(1.04);}
.btn--enviar:active{transform:scale(0.98);}
.btn--cargando .btn__texto{opacity:0;}
.btn--cargando .btn__spinner{display:block;}
.btn__spinner{display:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:18px;height:18px;border:2px solid rgba(255,255,255,0.3);border-top-color:white;border-radius:50%;animation:spin 0.7s linear infinite;}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg);}}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;transition:background var(--trans),box-shadow var(--trans);}
.nav--scroll{background:rgba(255,255,255,0.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 2px 24px rgba(44,31,22,0.08);}
.nav__inner{display:flex;align-items:center;justify-content:space-between;padding:0.5rem clamp(1.25rem,5vw,4rem);max-width:1400px;margin:0 auto;}
.nav__logo-wrap{display:flex;align-items:center;}
.nav__logo-texto{font-family:var(--serif);font-size:1.5rem;font-weight:300;color:var(--lana);letter-spacing:0.05em;transition:color var(--trans);}
.nav__logo-texto em{font-style:italic;color:var(--jengibre-claro);}
.nav--scroll .nav__logo-texto{color:var(--tierra);}
.nav__logo-img{height:90px;width:auto;max-width:180px;object-fit:contain;border-radius:6px;transition:transform var(--trans),filter var(--trans);filter:drop-shadow(0 2px 8px rgba(44,31,22,0.2));}
.nav__logo-img:hover{transform:scale(1.04);}
.nav__links{display:flex;gap:2.25rem;align-items:center;}
.nav__link{font-size:0.71rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:rgba(255,255,255,0.97);transition:color var(--trans);position:relative;text-shadow:0 1px 6px rgba(0,0,0,0.55);}
.nav--scroll .nav__link{color:var(--texto-suave);text-shadow:none;}
.nav__link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--jengibre);transition:width 0.3s ease;border-radius:2px;}
.nav__link:hover{color:var(--jengibre);}
.nav__link:hover::after{width:100%;}
.nav--scroll .nav__link:hover{color:var(--jengibre);}
.nav__link--cta{background:var(--jengibre);color:var(--blanco)!important;padding:0.6rem 1.5rem;border-radius:50px;letter-spacing:0.08em;box-shadow:0 4px 14px rgba(193,125,60,0.4);transition:all var(--trans);}
.nav__link--cta::after{display:none;}
.nav__link--cta:hover{background:var(--tierra)!important;transform:translateY(-2px);box-shadow:0 6px 20px rgba(44,31,22,0.3);}
.nav__hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;z-index:201;}
.nav__hamburger span{display:block;width:24px;height:1.5px;background:var(--lana);transition:var(--trans);transform-origin:center;}
.nav--scroll .nav__hamburger span{background:var(--tierra);}
.nav__hamburger--x span:nth-child(1){transform:translateY(6.5px) rotate(45deg);background:var(--tierra)!important;}
.nav__hamburger--x span:nth-child(2){opacity:0;transform:scaleX(0);}
.nav__hamburger--x span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);background:var(--tierra)!important;}
.nav__mobile{position:fixed;inset:0;background:var(--crema);display:flex;align-items:center;justify-content:center;z-index:199;transform:translateY(-100%);transition:transform 0.45s cubic-bezier(0.76,0,0.24,1);}
.nav__mobile--abierto{transform:translateY(0);}
.nav__mobile ul{display:flex;flex-direction:column;align-items:center;gap:2rem;}
.nav__mobile a{font-family:var(--serif);font-size:2rem;font-weight:300;color:var(--tierra);transition:color var(--trans);}
.nav__mobile a:hover{color:var(--jengibre);}

/* HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;padding:0 clamp(1.25rem,7vw,8rem) clamp(4rem,10vh,8rem);
  background-image:url('fotos/foto-inicio.png');
  background-size:cover;background-position:center top;background-attachment:scroll;}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(44,31,22,0.1) 0%,rgba(44,31,22,0.75) 100%);}
.hero__content{position:relative;z-index:2;max-width:700px;}
.hero__badge-top{display:inline-block;background:rgba(193,125,60,0.85);color:var(--blanco);font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;padding:0.35rem 1rem;border-radius:20px;margin-bottom:1.25rem;backdrop-filter:blur(4px);}
.hero__eyebrow{margin-bottom:0;}
.hero__title{color:var(--lana);font-weight:300;margin-bottom:1.5rem;text-shadow:0 2px 30px rgba(0,0,0,0.2);}
.hero__subtitle{color:rgba(240,235,225,0.82);font-size:clamp(1rem,1.8vw,1.15rem);margin-bottom:2.5rem;line-height:1.65;}
.hero__btns{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem;}
.hero__btn-principal{font-size:0.85rem;padding:1rem 1.75rem;}
.hero__trust{display:flex;gap:1.5rem;flex-wrap:wrap;}
.hero__trust span{font-size:0.75rem;color:rgba(240,235,225,0.7);letter-spacing:0.05em;}
.hero__scroll{position:absolute;bottom:2.5rem;right:clamp(1.25rem,5vw,4rem);display:flex;flex-direction:column;align-items:center;gap:0.5rem;z-index:2;}
.hero__scroll span{font-size:0.6rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(240,235,225,0.5);writing-mode:vertical-lr;}
.hero__scroll-linea{width:1px;height:50px;background:linear-gradient(to bottom,rgba(240,235,225,0.5),transparent);animation:pulseLinea 2.2s ease-in-out infinite;}
@keyframes pulseLinea{0%,100%{transform:scaleY(1);opacity:1;}50%{transform:scaleY(0.5);opacity:0.3;}}

/* TRUST STRIP */
.trust-strip{background:var(--tierra);padding:2rem clamp(1.25rem,5vw,4rem);}
.trust-strip__inner{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap;max-width:900px;margin:0 auto;}
.trust-item{text-align:center;}
.trust-item__num{display:block;font-family:var(--serif);font-size:2rem;font-weight:300;color:var(--jengibre-claro);line-height:1;}
.trust-item__txt{display:block;font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(240,235,225,0.6);margin-top:0.2rem;}
.trust-sep{width:1px;height:40px;background:rgba(193,125,60,0.3);}

/* RAÍZ / NOSOTROS */
.raiz{padding:clamp(5rem,12vh,9rem) clamp(1.25rem,5vw,4rem);background:var(--blanco);}
.raiz__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(3rem,7vw,7rem);align-items:center;max-width:1200px;margin:0 auto;}
.raiz__col-imagen{position:relative;}
.raiz__foto{width:100%;aspect-ratio:4/5;object-fit:cover;filter:sepia(8%);border-radius:var(--radio);box-shadow:var(--sombra);}
.raiz__badge{position:absolute;bottom:-1.5rem;right:-1.5rem;background:var(--jengibre);color:var(--blanco);padding:1.5rem;text-align:center;border-radius:var(--radio);box-shadow:var(--sombra);}
.raiz__badge-num{display:block;font-family:var(--serif);font-size:2.2rem;font-weight:300;line-height:1;}
.raiz__badge-txt{display:block;font-size:0.72rem;letter-spacing:0.08em;margin-top:0.3rem;opacity:0.9;}
.raiz__titulo{color:var(--tierra);margin-bottom:1.75rem;}
.raiz__col-texto p{color:var(--texto-suave);margin-bottom:1rem;}
.raiz__frase{font-weight:500;color:var(--jengibre);margin:1.25rem 0 1.5rem;font-size:1.05rem;}
.raiz__diferencial{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1.5rem 0 2rem;}
.raiz__dif-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:0.4rem;padding:1rem;background:var(--crema);border-radius:var(--radio);}
.raiz__dif-icon{font-size:1.5rem;}
.raiz__dif-item strong{font-size:0.82rem;color:var(--tierra);display:block;}
.raiz__dif-item p{font-size:0.75rem;color:var(--texto-suave);margin:0;}

/* CATÁLOGO */
.productos{padding:clamp(5rem,12vh,9rem) clamp(1.25rem,5vw,4rem);background:var(--crema);}
.productos__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;max-width:1200px;margin:0 auto;}
.productos__subtitulo{font-family:var(--serif);font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:300;color:var(--tierra);margin:0 0 2rem;padding-bottom:0.5rem;border-bottom:1px solid var(--borde);max-width:1200px;}
.productos__subtitulo--separado{margin-top:clamp(3rem,6vw,5rem);}
.tarjeta{background:var(--lana);overflow:hidden;}
.tarjeta__img-wrap{position:relative;overflow:hidden;}
.tarjeta__img-wrap img{width:100%;height:360px;object-fit:cover;transition:transform 0.65s cubic-bezier(0.25,0.46,0.45,0.94);}
.tarjeta:hover .tarjeta__img-wrap img{transform:scale(1.06);}
.tarjeta__badge{position:absolute;top:1rem;left:1rem;background:rgba(58,43,31,0.82);color:var(--jengibre-claro);font-size:0.62rem;letter-spacing:0.15em;text-transform:uppercase;padding:0.3rem 0.75rem;backdrop-filter:blur(4px);}
.tarjeta__cuerpo{padding:1.5rem;}
.tarjeta__cuerpo h3{color:var(--tierra);margin-bottom:0.4rem;}
.tarjeta__cuerpo p{color:var(--texto-suave);font-size:0.88rem;margin-bottom:0.9rem;}
.tarjeta__link{font-size:0.78rem;font-weight:500;letter-spacing:0.08em;color:var(--jengibre);text-transform:uppercase;transition:color var(--trans);}
.tarjeta__link:hover{color:var(--tierra);}
/* Tarjeta CTA especial */
.tarjeta--cta{background:var(--tierra);display:flex;align-items:center;justify-content:center;min-height:300px;}
.tarjeta__cta-contenido{padding:2rem;text-align:center;}
.tarjeta__cta-icono{display:block;font-size:2rem;margin-bottom:1rem;color:var(--jengibre-claro);}
.tarjeta--cta h3{color:var(--lana);margin-bottom:0.75rem;}
.tarjeta--cta p{color:rgba(240,235,225,0.7);font-size:0.9rem;margin-bottom:1.5rem;}

/* PROCESO */
.proceso{background:var(--tierra);padding:clamp(5rem,12vh,9rem) clamp(1.25rem,5vw,4rem);color:var(--lana);}
.proceso__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,7vw,7rem);align-items:center;max-width:1200px;margin:0 auto;}
.proceso__titulo{color:var(--lana);margin-bottom:1rem;}
.proceso__col-texto>p{color:rgba(240,235,225,0.7);margin-bottom:2rem;}
.proceso__pasos{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;}
.proceso__paso{display:flex;gap:1.25rem;align-items:flex-start;}
.proceso__num{font-family:var(--serif);font-size:2.5rem;font-weight:300;color:rgba(193,125,60,0.35);line-height:1;flex-shrink:0;width:3rem;}
.proceso__paso strong{display:block;color:var(--lana);margin-bottom:0.25rem;}
.proceso__paso p{color:rgba(240,235,225,0.6);font-size:0.9rem;}
.proceso__col-fotos{display:grid;grid-template-columns:1.2fr 0.8fr;grid-template-rows:auto auto;gap:3px;}
.proceso__foto-grande{grid-row:span 2;}
.proceso__foto-grande img,.proceso__foto-chica img{width:100%;height:100%;object-fit:cover;min-height:180px;filter:sepia(12%);border-radius:var(--radio);}
.proceso__foto-grande img{min-height:380px;}

/* GALERÍA */
.galeria{padding:clamp(5rem,12vh,9rem) clamp(1.25rem,5vw,4rem);background:var(--lana);}
.galeria__grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:260px;gap:3px;max-width:1200px;margin:0 auto;}
.galeria__item--grande{grid-column:span 2;}
.galeria__item{position:relative;overflow:hidden;cursor:pointer;margin:0;}
.galeria__item img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s cubic-bezier(0.25,0.46,0.45,0.94),filter 0.6s ease;filter:saturate(0.9) brightness(0.95);}
.galeria__item:hover img{transform:scale(1.07);filter:saturate(1.1) brightness(1.02);}
figcaption{position:absolute;bottom:0;left:0;right:0;padding:2rem 1.25rem 1.1rem;background:linear-gradient(to top,rgba(44,31,22,0.88),transparent);color:var(--lana);font-family:var(--serif);font-style:italic;font-size:1rem;opacity:0;transform:translateY(8px);transition:opacity 0.4s ease,transform 0.4s ease;}
.galeria__item:hover figcaption{opacity:1;transform:translateY(0);}
.galeria__cta{text-align:center;margin-top:2.5rem;}

/* FAQ */
.faq{padding:clamp(5rem,12vh,9rem) clamp(1.25rem,5vw,4rem);background:var(--crema);}
.faq__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;max-width:1000px;margin:0 auto clamp(2rem,4vw,3rem);background:var(--borde);}
.faq__item{background:var(--blanco);padding:0;}
details.faq__item summary{cursor:pointer;list-style:none;}
details.faq__item summary::-webkit-details-marker{display:none;}
.faq__pregunta{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem;font-family:var(--serif);font-size:1.05rem;color:var(--tierra);font-weight:400;transition:background var(--trans);}
.faq__item:hover .faq__pregunta{background:var(--crema);}
.faq__icono{font-size:1.2rem;color:var(--jengibre);flex-shrink:0;width:1.5rem;text-align:center;font-family:var(--sans);font-weight:300;}
.faq__respuesta{padding:0 1.5rem 1.5rem;border-top:1px solid var(--borde);}
.faq__respuesta p{color:var(--texto-suave);font-size:0.95rem;margin-top:1rem;}
.faq__cta{text-align:center;max-width:1000px;margin:0 auto;}
.faq__cta p{color:var(--texto-suave);margin-bottom:1.25rem;font-family:var(--serif);font-style:italic;font-size:1.1rem;}

/* CONTACTO */
.contacto{padding:clamp(5rem,12vh,9rem) clamp(1.25rem,5vw,4rem);background:var(--tierra);color:var(--lana);}
.contacto__inner{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(3rem,7vw,7rem);max-width:1100px;margin:0 auto;align-items:start;}
.contacto__titulo{color:var(--lana);margin-bottom:1rem;}
.contacto__info>p{color:rgba(240,235,225,0.7);margin-bottom:2rem;}
.contacto__datos{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem;}
.contacto__datos li{display:flex;flex-direction:column;gap:0.2rem;}
.contacto__dato-label{font-size:0.62rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--jengibre-claro);font-weight:500;}
.contacto__datos a{color:rgba(240,235,225,0.85);font-size:0.95rem;transition:color var(--trans);}
.contacto__datos a:hover{color:var(--jengibre-claro);}
.contacto__datos span{color:rgba(240,235,225,0.6);font-size:0.9rem;}
.contacto__mapa{margin-bottom:1.5rem;overflow:hidden;border-radius:var(--radio);}
.contacto__redes{display:flex;gap:0.75rem;align-items:center;}
.red-social{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--trans);border:1px solid rgba(240,235,225,0.2);}
.red-social svg{width:20px;height:20px;}
.red-social--wa{color:var(--wa);}
.red-social--wa:hover{background:var(--wa);color:white;border-color:var(--wa);}
.red-social--ig{color:var(--ig);}
.red-social--ig:hover{background:var(--ig);color:white;border-color:var(--ig);}
.red-social--fb{color:var(--fb);}
.red-social--fb:hover{background:var(--fb);color:white;border-color:var(--fb);}
/* Formulario */
.contacto__form{display:flex;flex-direction:column;gap:1.25rem;}
.campo{display:flex;flex-direction:column;gap:0.35rem;}
.campo__label{font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--jengibre-claro);font-weight:500;}
.campo__input,.campo__select,.campo__textarea{width:100%;background:rgba(240,235,225,0.08);border:1px solid rgba(240,235,225,0.2);color:var(--lana);padding:0.9rem 1rem;font-family:var(--sans);font-size:1rem;font-weight:300;outline:none;transition:border-color var(--trans),background var(--trans);border-radius:var(--radio);appearance:none;}
.campo__input::placeholder,.campo__textarea::placeholder{color:rgba(240,235,225,0.3);}
.campo__input:focus,.campo__select:focus,.campo__textarea:focus{border-color:var(--jengibre);background:rgba(240,235,225,0.12);}
.campo__input--error{border-color:#e07070!important;}
.campo__select-wrap{position:relative;}
.campo__flecha{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:rgba(240,235,225,0.4);pointer-events:none;font-size:0.8rem;}
.campo__select option{background:var(--tierra-medio);color:var(--lana);}
.campo__textarea{resize:vertical;min-height:110px;}
.campo__error{font-size:0.75rem;color:#e07070;min-height:1rem;display:block;}
.form__exito{text-align:center;padding:1rem;background:rgba(92,106,71,0.25);border:1px solid var(--musgo);color:var(--musgo-claro);font-size:0.9rem;border-radius:var(--radio);}

/* FOOTER */
.footer{background:#2A1D12;color:rgba(240,235,225,0.55);padding:3rem clamp(1.25rem,5vw,4rem) 0;}
.footer__inner{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:2rem;max-width:1200px;margin:0 auto;padding-bottom:2.5rem;border-bottom:1px solid rgba(240,235,225,0.1);}
.footer__logo-img{height:56px;width:auto;object-fit:contain;border-radius:4px;margin-bottom:0.5rem;}
.footer__tagline{font-size:0.7rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--jengibre-claro);}
.footer__nav{display:flex;flex-wrap:wrap;gap:1rem 2rem;}
.footer__nav a{font-size:0.78rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(240,235,225,0.5);transition:color var(--trans);}
.footer__nav a:hover{color:var(--jengibre-claro);}
.footer__redes{display:flex;gap:0.75rem;align-items:center;}
.footer__red{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:var(--trans);border:1px solid rgba(240,235,225,0.15);}
.footer__red svg{width:18px;height:18px;}
.footer__red--wa{color:var(--wa);}
.footer__red--wa:hover{background:var(--wa);color:white;}
.footer__red--ig{color:var(--ig);}
.footer__red--ig:hover{background:var(--ig);color:white;}
.footer__red--fb{color:var(--fb);}
.footer__red--fb:hover{background:var(--fb);color:white;}
.footer__legal{text-align:center;padding:1.25rem;font-size:0.75rem;color:rgba(240,235,225,0.3);}
.footer__legal a{color:rgba(240,235,225,0.5);transition:color var(--trans);}
.footer__legal a:hover{color:var(--jengibre-claro);}

/* WHATSAPP FLOTANTE */
.wa-flotante{position:fixed;bottom:1.75rem;right:1.75rem;z-index:300;display:flex;align-items:center;gap:0.6rem;background:var(--wa);color:white;padding:0.85rem 1.25rem;border-radius:50px;box-shadow:0 4px 20px rgba(37,211,102,0.4);font-size:0.82rem;font-weight:500;letter-spacing:0.04em;transition:transform var(--trans),box-shadow var(--trans);animation:waPulse 8s ease-in-out 3s infinite;}
.wa-flotante:hover{transform:scale(1.06) translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,0.5);animation:none;}
@keyframes waPulse{0%,90%,100%{transform:scale(1);}93%{transform:scale(1.08);}96%{transform:scale(1);}98%{transform:scale(1.05);}}

/* ANIMACIONES */
.anim{opacity:0;transform:translateY(24px);transition:opacity 0.65s ease var(--delay,0s),transform 0.65s ease var(--delay,0s);}
.anim.visible{opacity:1;transform:translateY(0);}
:focus-visible{outline:2px solid var(--jengibre);outline-offset:3px;}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms!important;transition-duration:0.01ms!important;}.anim{opacity:1;transform:none;}}

/* TABLET */
@media(max-width:1024px){
  .nav__links{display:none;}.nav__hamburger{display:flex;}
  .raiz__grid{grid-template-columns:1fr;gap:3rem;}.raiz__badge{right:0;}
  .raiz__diferencial{grid-template-columns:1fr;}
  .productos__grid{grid-template-columns:repeat(2,1fr);}
  .proceso__grid{grid-template-columns:1fr;gap:3rem;}
  .proceso__col-fotos{grid-template-columns:1fr 1fr;}.proceso__foto-grande{grid-row:span 1;}.proceso__foto-grande img{min-height:280px;}
  .galeria__grid{grid-template-columns:repeat(2,1fr);}.galeria__item--grande{grid-column:span 1;}
  .faq__grid{grid-template-columns:1fr;}
  .contacto__inner{grid-template-columns:1fr;gap:3rem;}
}

/* MOBILE */
@media(max-width:768px){
  .barra-top__inner{gap:0.75rem;font-size:0.65rem;}
  .nav__inner{padding:0.5rem 1.25rem;}
  .nav__logo-img{height:75px;}
  .hero{padding:5rem 1.25rem 3.5rem;align-items:flex-end;}
  .hero__scroll{display:none;}.hero__btns{flex-direction:column;gap:0.75rem;}
  .hero__btns .btn{justify-content:center;}.hero__trust{gap:1rem;}
  .trust-strip__inner{gap:1rem;}.trust-sep{display:none;}
  .raiz{padding:4rem 1.25rem;}
  .raiz__badge{position:static;margin-top:1rem;display:inline-flex;gap:1rem;align-items:center;}.raiz__badge-num{font-size:1.8rem;}
  .productos{padding:4rem 1.25rem;}
  .productos__grid{grid-template-columns:1fr;gap:2px;}.tarjeta__img-wrap img{height:300px;}
  .proceso{padding:4rem 1.25rem;}
  .proceso__col-fotos{grid-template-columns:1fr;}.proceso__foto-grande img,.proceso__foto-chica img{min-height:240px;}
  .galeria{padding:4rem 1.25rem;}
  .galeria__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px;gap:2px;}
  figcaption{opacity:1;transform:translateY(0);}
  .faq{padding:4rem 1.25rem;}
  .faq__pregunta{font-size:0.95rem;padding:1.25rem;}
  .contacto{padding:4rem 1.25rem;}
  .footer__inner{flex-direction:column;gap:1.5rem;}.footer__nav{gap:0.75rem 1.5rem;}
  .wa-flotante span{display:none;}.wa-flotante{padding:1rem;border-radius:50%;}
}
/* VIDEO PROCESO */
.proceso__video{margin:1.5rem 0 1.75rem;border-radius:var(--radio);overflow:hidden;position:relative;padding-bottom:56.25%;height:0;box-shadow:var(--sombra);}
.proceso__video iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;}

@media(max-width:480px){
  .galeria__grid{grid-template-columns:1fr;grid-auto-rows:220px;}.galeria__item--grande{grid-column:span 1;}
  .productos__grid{grid-template-columns:1fr;}
  .hero__trust{flex-direction:column;gap:0.5rem;}
}

/* ═══════════════════════════════════════════
   CARRUSEL BEBÉS
   ═══════════════════════════════════════════ */
.carrusel{position:relative;overflow:hidden;max-width:1200px;margin:0 auto;padding:0 0 3.5rem;}
.carrusel__track{display:flex;transition:transform 0.5s cubic-bezier(0.25,0.46,0.45,0.94);cursor:grab;user-select:none;}
.carrusel__track:active{cursor:grabbing;}
.carrusel__slide{flex:0 0 calc(100% / 3);padding:0 1px;}
@media(max-width:1024px){.carrusel__slide{flex:0 0 50%;}}
@media(max-width:640px){.carrusel__slide{flex:0 0 100%;}}

/* Botones prev/next */
.carrusel__btn{position:absolute;top:45%;transform:translateY(-50%);z-index:10;width:48px;height:48px;border-radius:50%;background:var(--blanco);border:1px solid var(--borde);color:var(--tierra);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(44,31,22,0.12);transition:all var(--trans);}
.carrusel__btn:hover{background:var(--jengibre);color:var(--blanco);border-color:var(--jengibre);transform:translateY(-50%) scale(1.08);}
.carrusel__btn--prev{left:-24px;}
.carrusel__btn--next{right:-24px;}
@media(max-width:768px){.carrusel__btn--prev{left:4px;}.carrusel__btn--next{right:4px;}}

/* Puntos indicadores */
.carrusel__dots{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;gap:0.5rem;padding:1rem 0;}
.carrusel__dot{width:8px;height:8px;border-radius:50%;background:var(--borde);border:none;cursor:pointer;transition:all var(--trans);padding:0;}
.carrusel__dot--activo{background:var(--jengibre);transform:scale(1.3);width:24px;border-radius:4px;}

/* ═══════════════════════════════════════════
   OPTIMIZACIONES PREMIUM
   ═══════════════════════════════════════════ */

/* Tarjetas — hover más elegante */
.tarjeta{background:var(--lana);overflow:hidden;transition:transform 0.4s cubic-bezier(0.25,0.46,0.45,0.94),box-shadow 0.4s ease;}
.tarjeta:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(44,31,22,0.14);}

/* Badge "Nuevo" especial */
.tarjeta__badge{background:rgba(58,43,31,0.82);color:var(--jengibre-claro);font-size:0.62rem;letter-spacing:0.15em;text-transform:uppercase;padding:0.3rem 0.75rem;backdrop-filter:blur(4px);transition:background var(--trans);}
.tarjeta:hover .tarjeta__badge{background:var(--jengibre);}

/* Scroll suave global mejorado */
html{scroll-padding-top:120px;}

/* Selección de texto con color de marca */
::selection{background:rgba(193,125,60,0.25);color:var(--tierra);}

/* Imágenes — transición más suave */
.tarjeta__img-wrap img{transition:transform 0.75s cubic-bezier(0.25,0.46,0.45,0.94),opacity 0.4s ease;}

/* Hero title — mejor legibilidad */
.hero__title{text-shadow:0 2px 40px rgba(0,0,0,0.25);}
.hero__subtitle{text-shadow:0 1px 12px rgba(0,0,0,0.2);}

/* Sección catálogo — padding carrusel en mobile */
@media(max-width:768px){
  .carrusel{padding:0 0 3rem;}
  .carrusel__btn--prev{left:8px;}
  .carrusel__btn--next{right:8px;}
}

/* Botón flotante WA — shadow más dramático */
.wa-flotante{box-shadow:0 6px 24px rgba(37,211,102,0.45);}

/* Footer logo */
.footer__logo-img{height:64px;width:auto;object-fit:contain;border-radius:4px;opacity:0.9;}

/* Proceso video — responsive mejorado */
@media(max-width:768px){
  .proceso__video{margin:1rem 0 1.25rem;}
}

/* Galería caption siempre visible en mobile */
@media(max-width:640px){
  figcaption{opacity:1;transform:translateY(0);font-size:0.85rem;}
}