/* ============================================================
   PACHAMIA — styles.css
   Design: Organic Biophilic + Storytelling
   Mobile-first responsive
   ============================================================ */

/* ── TOKENS ─────────────────────────────────────────────── */
:root {
  --cream:        #F7F1E8;
  --cream-dark:   #EDE4D3;
  --sand:         #D4C5A9;
  --terra:        #B8643A;
  --terra-light:  #CC7A50;
  --coffee:       #7A4E2D;
  --espresso:     #3E2410;
  --sage:         #8A9E7A;
  --smoke:        #C8C0B4;
  --white:        #FDFAF6;

  --ff-display: 'Playfair Display', Georgia, serif;
  --ff-body:    'Jost', sans-serif;
  --ff-hand:    'Caveat', cursive;

  --nav-h:       68px;
  --sp:          clamp(72px, 9vw, 130px);
  --side:        clamp(20px, 5vw, 72px);
  --radius:      3px;
  --tr:          360ms cubic-bezier(0.25,0.46,0.45,0.94);
}

/* ── RESET ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--cream);
  color:var(--espresso);
  font-family:var(--ff-body);
  font-weight:300;
  line-height:1.7;
  overflow-x:hidden;
}
img{display:block;width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font-family:var(--ff-body)}

/* ── NOISE OVERLAY ───────────────────────────────────────── */
body::before{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  opacity:.35;pointer-events:none;z-index:999;
}

/* ── TYPOGRAPHY HELPERS ──────────────────────────────────── */
.label{
  display:block;
  font-size:.62rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:var(--terra);margin-bottom:14px;
}
.label--light{color:var(--terra-light)}

.title{
  font-family:var(--ff-display);
  font-size:clamp(1.9rem,3.2vw,3rem);
  font-weight:400;line-height:1.15;color:var(--espresso);
}
.title em{font-style:italic;color:var(--terra)}
.title--light{color:var(--cream)}
.title--sm{font-size:clamp(1.5rem,2.4vw,2.3rem)}

.divider{width:38px;height:2px;background:var(--terra);margin:22px 0}
.divider--light{background:var(--terra-light)}

/* ── REVEAL ANIMATION ────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}
.reveal-d4{transition-delay:.42s}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--side);
  z-index:900;
  transition:background var(--tr),box-shadow var(--tr);
}
.nav.scrolled{
  background:rgba(247,241,232,.96);
  backdrop-filter:blur(12px);
  box-shadow:0 1px 0 var(--sand);
}
.nav__logo img{height:34px;width:auto}
.nav__links{
  display:none;gap:32px;
}
.nav__links a{
  font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  color:var(--espresso);opacity:.7;transition:opacity var(--tr);
}
.nav__links a:hover{opacity:1}
.nav__right{display:flex;align-items:center;gap:16px}

/* Lang toggle */
.lang-toggle{
  display:flex;align-items:center;
  background:var(--cream-dark);border-radius:18px;padding:3px;
  border:1px solid var(--sand);
}
.lang-btn{
  font-size:.62rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 11px;border-radius:14px;border:none;
  background:transparent;color:var(--coffee);transition:all .22s;
}
.lang-btn.active{background:var(--coffee);color:var(--cream)}

/* CTA nav */
.nav__cta{
  display:none;
  font-size:.63rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  padding:8px 18px;border:1.5px solid var(--coffee);border-radius:18px;
  color:var(--coffee);transition:all var(--tr);
}
.nav__cta:hover{background:var(--coffee);color:var(--cream)}

/* Hamburger */
.nav__burger{
  display:flex;flex-direction:column;gap:5px;padding:4px;
  background:none;border:none;
}
.nav__burger span{display:block;width:22px;height:1.5px;background:var(--espresso);transition:var(--tr)}
.nav__burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile menu */
.mobile-menu{
  display:none;position:fixed;inset:0;
  background:var(--cream);z-index:800;
  flex-direction:column;justify-content:center;align-items:center;gap:28px;
  padding-top:var(--nav-h);
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  font-family:var(--ff-display);font-size:1.6rem;font-weight:400;
  color:var(--espresso);
}

/* Desktop nav links */
@media(min-width:900px){
  .nav__links{display:flex}
  .nav__cta{display:inline-flex}
  .nav__burger{display:none}
}

/* ============================================================
   HERO  (IMG_01 — 16:9 landscape 1600x900)
   ============================================================ */
.hero{
  position:relative;
  min-height:100svh;
  display:grid;
  grid-template-columns:1fr;
  overflow:hidden;
  padding-top:var(--nav-h);
}
.hero__bg{
  position:absolute;inset:0;z-index:0;
}
.hero__bg img{
  width:100%;height:100%;
  object-fit:cover;object-position:center 25%;
  filter:saturate(.92)brightness(.88);
}
.hero__bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,
    rgba(62,36,16,.35) 0%,
    rgba(62,36,16,.55) 100%);
}
.hero__content{
  position:relative;z-index:2;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(40px,8vw,100px) var(--side) clamp(80px,10vw,120px);
  min-height:100svh;
}
.hero__eyebrow{
  display:flex;align-items:center;gap:12px;
  font-size:.62rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  color:var(--sand);margin-bottom:18px;
}
.hero__eyebrow::before{
  content:'';display:block;width:28px;height:1px;background:var(--terra-light);
}
.hero__title{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem,6vw,4.8rem);
  font-weight:400;line-height:1.1;
  color:#fff;margin-bottom:22px;
}
.hero__title em{font-style:italic;color:var(--terra-light)}
.hero__sub{
  font-size:clamp(.88rem,1.2vw,1rem);font-weight:300;
  color:rgba(255,255,255,.85);max-width:420px;
  margin-bottom:38px;line-height:1.8;
}
.hero__ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--espresso);color:var(--cream);
  font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  padding:13px 26px;border-radius:2px;border:none;
  transition:all var(--tr);
}
.btn-primary:hover{background:var(--coffee);transform:translateY(-1px);box-shadow:0 8px 22px rgba(62,36,16,.25)}

.btn-ghost{
  font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.85);
  display:flex;align-items:center;gap:6px;transition:gap var(--tr);
}
.btn-ghost::after{content:'→';font-size:.9rem}
.btn-ghost:hover{gap:12px}

.hero__stats{
  position:absolute;bottom:clamp(28px,4vw,52px);left:var(--side);
  display:flex;gap:clamp(20px,4vw,40px);z-index:2;
}
.hero__stat-num{
  font-family:var(--ff-display);font-size:1.7rem;color:#fff;line-height:1;
}
.hero__stat-label{
  font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.6);margin-top:4px;
}

@media(min-width:768px){
  .hero__bg::after{
    background:linear-gradient(105deg,
      rgba(62,36,16,.7) 0%,
      rgba(62,36,16,.4) 55%,
      transparent 100%);
  }
}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  background:var(--espresso);color:var(--cream);
  padding:13px 0;overflow:hidden;white-space:nowrap;
}
.marquee__track{
  display:inline-flex;
  animation:marquee-scroll 28s linear infinite;
}
.marquee__track:hover{animation-play-state:paused}
.marquee__item{
  font-size:.62rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  padding:0 28px;opacity:.82;
}
.marquee__dot{color:var(--terra);padding:0 6px}
@keyframes marquee-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ============================================================
   MANIFIESTO
   ============================================================ */
.manifiesto{
  padding:var(--sp) var(--side);text-align:center;
  background:var(--cream);position:relative;
}
.manifiesto::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:1px;background:linear-gradient(90deg,transparent,var(--sand),transparent);
}
.manifiesto__quote{
  font-family:var(--ff-display);
  font-size:clamp(1.3rem,2.6vw,2.1rem);
  font-weight:400;font-style:italic;line-height:1.5;
  color:var(--espresso);max-width:760px;margin:0 auto;
  position:relative;
}
.manifiesto__quote::before{
  content:'"';
  font-size:clamp(5rem,12vw,9rem);
  font-family:var(--ff-display);color:var(--sand);
  position:absolute;top:-30px;left:-10px;line-height:1;z-index:0;
  pointer-events:none;
}
.manifiesto__text{position:relative;z-index:1}

/* ============================================================
   HISTORIA  (IMG_02 — 3:4 portrait 900x1200)
   ============================================================ */
.historia{
  display:grid;
  grid-template-columns:1fr;
}
.historia__image{
  position:relative;
  aspect-ratio:3/4;
  overflow:hidden;
  max-height:600px;
}
.historia__image img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  filter:saturate(.88)brightness(.94);
  transition:transform .8s ease;
}
.historia:hover .historia__image img{transform:scale(1.03)}
.historia__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 65%,var(--cream) 100%);
}
.historia__content{
  background:var(--cream);
  padding:clamp(48px,7vw,90px) var(--side);
}
.historia__body{
  font-size:.93rem;color:var(--coffee);line-height:1.85;margin-bottom:14px;
}
.historia__badge{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:28px;padding:11px 18px;
  background:var(--cream-dark);border:1px solid var(--sand);border-radius:2px;
}
.historia__badge-icon{width:18px;height:18px;color:var(--terra)}
.historia__badge-text{
  font-size:.67rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--espresso);
}
@media(min-width:860px){
  .historia{grid-template-columns:1fr 1fr;min-height:580px}
  .historia__image{aspect-ratio:unset;max-height:unset}
  .historia__overlay{
    background:linear-gradient(to right,transparent 70%,var(--cream) 100%);
  }
  .historia__content{
    display:flex;flex-direction:column;justify-content:center;
  }
}

/* ============================================================
   PROCESO dark section
   ============================================================ */
.proceso{
  background:var(--espresso);
  padding:var(--sp) var(--side);position:relative;overflow:hidden;
}
.proceso::before{
  content:'"';
  font-family:var(--ff-display);font-size:40vw;font-weight:700;
  color:rgba(255,255,255,.02);
  position:absolute;top:-5vw;right:-3vw;line-height:1;pointer-events:none;
}
.proceso__header{
  display:grid;grid-template-columns:1fr;gap:28px;margin-bottom:52px;
}
.proceso__intro{
  font-size:.93rem;color:var(--smoke);line-height:1.85;
}
.proceso__steps{
  display:grid;grid-template-columns:1fr 1fr;gap:2px;
}
.proceso__step{
  background:rgba(255,255,255,.04);
  padding:28px 20px;
  border-top:1px solid rgba(255,255,255,.08);
  transition:background var(--tr);
}
.proceso__step:hover{background:rgba(255,255,255,.07)}
.proceso__num{
  font-family:var(--ff-display);font-size:2.6rem;font-weight:400;
  color:rgba(255,255,255,.07);line-height:1;margin-bottom:18px;
}
.proceso__step-title{
  font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--cream);margin-bottom:10px;
}
.proceso__step-body{font-size:.8rem;color:var(--smoke);line-height:1.7}
@media(min-width:640px){
  .proceso__steps{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:960px){
  .proceso__header{grid-template-columns:1fr 1fr;gap:60px}
  .proceso__steps{grid-template-columns:repeat(5,1fr)}
}

/* ============================================================
   PROCESO VISUAL  (IMG_03 — 2:3 portrait 666x1000)
   ============================================================ */
.proceso-visual{
  display:grid;grid-template-columns:1fr;
}
.proceso-visual__content{
  background:var(--cream-dark);
  padding:clamp(52px,7vw,90px) var(--side);
  order:2;
}
.proceso-visual__image{
  overflow:hidden;
  aspect-ratio:2/3;max-height:560px;
  order:1;
}
.proceso-visual__image img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  filter:saturate(.9);
  transition:transform .8s ease;
}
.proceso-visual:hover .proceso-visual__image img{transform:scale(1.03)}
.pv-quote{
  font-family:var(--ff-hand);
  font-size:clamp(1.25rem,1.7vw,1.55rem);
  color:var(--terra);line-height:1.4;margin-bottom:22px;
}
.pv-body{font-size:.93rem;color:var(--coffee);line-height:1.85;margin-bottom:12px}
@media(min-width:860px){
  .proceso-visual{grid-template-columns:1fr 1fr;min-height:560px}
  .proceso-visual__content{order:1;display:flex;flex-direction:column;justify-content:center}
  .proceso-visual__image{aspect-ratio:unset;max-height:unset;order:2}
}

/* ============================================================
   DIFERENCIADORES
   ============================================================ */
.diferenciadores{padding:var(--sp) var(--side);background:var(--cream)}
.diferenciadores__header{
  display:grid;grid-template-columns:1fr;gap:28px;margin-bottom:52px;
}
.dif-desc{font-size:.93rem;color:var(--coffee);line-height:1.85}
.dif-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:2px;
}
.dif-card{
  background:var(--cream-dark);padding:30px 22px;
  border-top:2px solid transparent;
  transition:border-color var(--tr),transform var(--tr),box-shadow var(--tr);
}
.dif-card:hover{
  border-top-color:var(--terra);
  transform:translateY(-4px);
  box-shadow:0 14px 36px rgba(62,36,16,.08);
}
.dif-icon{width:32px;height:32px;margin-bottom:16px;color:var(--terra)}
.dif-icon svg{width:100%;height:100%}
.dif-title{
  font-family:var(--ff-display);font-size:.95rem;font-weight:500;
  color:var(--espresso);margin-bottom:10px;
}
.dif-body{font-size:.8rem;color:var(--coffee);line-height:1.7}

/* Compare table */
.compare-wrap{margin-top:56px;overflow-x:auto}
.compare-table{border-collapse:collapse;width:100%;min-width:480px}
.compare-table th{
  font-size:.63rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  padding:14px 20px;text-align:left;
  background:var(--espresso);color:var(--cream);
}
.compare-table th:first-child{background:transparent;color:var(--espresso)}
.compare-table th:nth-child(2){background:var(--terra)}
.compare-table td{
  padding:12px 20px;font-size:.8rem;
  border-bottom:1px solid var(--sand);color:var(--coffee);
}
.compare-table td:first-child{font-weight:500;color:var(--espresso)}
.compare-table td.yes{color:var(--sage);font-weight:500}
.compare-table td.no{color:#aaa}

@media(min-width:640px){.dif-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:960px){
  .diferenciadores__header{grid-template-columns:1fr 1fr;gap:60px}
}

/* ============================================================
   COLECCIONES
   ============================================================ */
.colecciones{
  padding:var(--sp) var(--side);
  background:var(--cream-dark);
}
.col-header{text-align:center;margin-bottom:40px}
.col-header .title{margin-bottom:14px}
.col-desc{font-size:.88rem;color:var(--coffee);max-width:520px;margin:0 auto 8px}
.col-note{font-size:.77rem;color:var(--coffee);opacity:.7}

/* Tabs */
.tabs-wrap{text-align:center;margin-bottom:36px}
.tabs{
  display:inline-flex;background:var(--sand);border-radius:2px;
  padding:2px;gap:2px;
}
.tab-btn{
  font-size:.67rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  padding:11px 26px;border:none;background:transparent;
  color:var(--coffee);transition:all .2s;border-radius:1px;
}
.tab-btn.active{background:var(--espresso);color:var(--cream)}

/* Product grid */
.products-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.products-grid.hidden{display:none}
@media(min-width:640px){.products-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:960px){.products-grid{grid-template-columns:repeat(4,1fr);gap:18px}}

.product-card{
  background:var(--cream);border-radius:var(--radius);overflow:hidden;
  transition:transform var(--tr),box-shadow var(--tr);
}
.product-card:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 44px rgba(62,36,16,.12);
}
.product-card__img{
  position:relative;
  aspect-ratio:1/1;
  overflow:hidden;background:var(--cream-dark);
}
.product-card__img img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .6s ease;
}
.product-card:hover .product-card__img img{transform:scale(1.06)}
.product-card__badge{
  position:absolute;top:10px;right:10px;
  background:var(--espresso);color:var(--cream);
  font-size:.55rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  padding:4px 9px;border-radius:1px;
}
.product-card__info{padding:16px 16px 18px}
.product-card__name{
  font-family:var(--ff-display);font-size:.92rem;font-weight:500;
  color:var(--espresso);margin-bottom:3px;
}
.product-card__sub{font-size:.72rem;color:var(--coffee);opacity:.7;margin-bottom:12px}
.product-card__footer{display:flex;align-items:center;justify-content:space-between}
.product-card__price{
  font-family:var(--ff-display);font-size:1.05rem;color:var(--espresso);
}
.product-card__price span{
  font-family:var(--ff-body);font-size:.6rem;color:var(--coffee);
  opacity:.6;display:block;line-height:1;
}
.btn-buy{
  font-size:.58rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  padding:7px 14px;background:var(--terra);color:var(--cream);
  border:none;border-radius:1px;transition:background var(--tr);
}
.btn-buy:hover{background:var(--espresso)}

/* ============================================================
   SENSORIAL  (IMG_04 — 3:4 portrait 900x1200)
   ============================================================ */
.sensorial{display:grid;grid-template-columns:1fr}
.sensorial__content{
  background:var(--espresso);
  padding:clamp(52px,7vw,90px) var(--side);
  order:2;
}
.sensorial__body{font-size:.93rem;color:var(--smoke);line-height:1.85;margin-bottom:12px}
.sensorial__hand{
  font-family:var(--ff-hand);
  font-size:clamp(1.3rem,1.7vw,1.6rem);
  color:var(--sand);line-height:1.4;margin-top:28px;
}
.sensorial__image{
  overflow:hidden;
  aspect-ratio:3/4;max-height:600px;
  order:1;
}
.sensorial__image img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform .8s ease;
}
.sensorial:hover .sensorial__image img{transform:scale(1.03)}
@media(min-width:860px){
  .sensorial{grid-template-columns:1fr 1fr;min-height:600px}
  .sensorial__content{order:1;display:flex;flex-direction:column;justify-content:center}
  .sensorial__image{aspect-ratio:unset;max-height:unset;order:2}
}

/* ============================================================
   USOS
   ============================================================ */
.usos{padding:var(--sp) var(--side);background:var(--cream)}
.usos__header{text-align:center;margin-bottom:48px}
.usos-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:2px;
}
@media(min-width:640px){.usos-grid{grid-template-columns:repeat(4,1fr)}}
.uso-card{
  background:var(--cream-dark);padding:32px 22px;text-align:center;
  border-bottom:2px solid transparent;
  transition:all var(--tr);
}
.uso-card:hover{
  background:var(--terra);border-bottom-color:var(--espresso);
}
.uso-card:hover .uso-title,
.uso-card:hover .uso-body{color:var(--cream)}
.uso-icon{width:42px;height:42px;margin:0 auto 16px}
.uso-icon svg{width:100%;height:100%}
.uso-title{
  font-family:var(--ff-display);font-size:.95rem;font-weight:500;
  color:var(--espresso);margin-bottom:10px;transition:color var(--tr);
}
.uso-body{font-size:.8rem;color:var(--coffee);line-height:1.7;transition:color var(--tr)}

/* ============================================================
   CTA AMAZON
   ============================================================ */
.cta-amazon{
  background:var(--coffee);
  padding:var(--sp) var(--side);text-align:center;
  position:relative;overflow:hidden;
}
.cta-amazon::before{
  content:'PACHAMIA';
  font-family:var(--ff-display);font-size:22vw;font-weight:700;
  color:rgba(255,255,255,.03);
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  white-space:nowrap;pointer-events:none;letter-spacing:-.02em;
}
.cta-amazon .title{margin-bottom:14px}
.cta-subtitle{
  font-size:.93rem;color:var(--sand);max-width:460px;margin:0 auto 38px;
}
.cta-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-amazon-mx{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--terra);color:var(--cream);
  font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  padding:15px 30px;border-radius:2px;
  transition:all var(--tr);
}
.btn-amazon-mx:hover{
  background:var(--terra-light);transform:translateY(-2px);
  box-shadow:0 10px 28px rgba(184,100,58,.35);
}
.btn-amazon-us{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--cream);
  font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  padding:15px 30px;
  border:1.5px solid rgba(255,255,255,.3);border-radius:2px;
  transition:all var(--tr);
}
.btn-amazon-us:hover{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.6);
  transform:translateY(-2px);
}

/* ============================================================
   TESTIMONIOS
   ============================================================ */
.testimonios{padding:var(--sp) var(--side);background:var(--cream-dark)}
.testi-header{text-align:center;margin-bottom:48px}
.testi-grid{
  display:grid;grid-template-columns:1fr;gap:18px;
  max-width:480px;margin:0 auto;
}
@media(min-width:860px){
  .testi-grid{grid-template-columns:repeat(3,1fr);max-width:unset}
}
.testi-card{
  background:var(--cream);padding:28px 24px;border-radius:var(--radius);
}
.testi-stars{display:flex;gap:3px;margin-bottom:16px}
.testi-star{width:13px;height:13px;color:var(--terra)}
.testi-quote{
  font-family:var(--ff-display);font-size:.95rem;font-style:italic;
  color:var(--espresso);line-height:1.6;margin-bottom:18px;
}
.testi-author{
  font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--coffee);
}
.testi-source{font-size:.62rem;color:var(--sand);margin-top:2px}

/* ============================================================
   CONTACTO
   ============================================================ */
.contacto{
  padding:clamp(52px,7vw,90px) var(--side);background:var(--cream);
  display:grid;grid-template-columns:1fr;gap:44px;
  border-top:1px solid var(--sand);
}
@media(min-width:768px){
  .contacto{grid-template-columns:1fr 1fr;gap:72px;align-items:center}
}
.contacto__body{font-size:.9rem;color:var(--coffee);line-height:1.85;margin-bottom:22px}
.contacto__email{
  font-family:var(--ff-display);font-size:1.05rem;
  color:var(--terra);font-style:italic;
}
.aviso-text{font-size:.7rem;color:var(--coffee);line-height:1.75;opacity:.75}
.aviso-link{color:var(--terra);text-decoration:underline;text-underline-offset:3px}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--espresso);color:var(--smoke);
  padding:42px var(--side);
  display:grid;grid-template-columns:1fr;gap:24px;
  text-align:center;
}
@media(min-width:768px){
  .footer{
    grid-template-columns:1fr auto 1fr;
    align-items:center;text-align:unset;
  }
}
.footer__logo img{
  height:26px;width:auto;
  filter:brightness(2.5)saturate(.2);opacity:.55;
  margin:0 auto;
}
@media(min-width:768px){.footer__logo img{margin:0}}
.footer__links{
  display:flex;gap:24px;justify-content:center;flex-wrap:wrap;
}
.footer__links a{
  font-size:.62rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  color:var(--smoke);opacity:.5;transition:opacity var(--tr);
}
.footer__links a:hover{opacity:1}
.footer__copy{
  font-size:.62rem;color:var(--smoke);opacity:.4;
}
@media(min-width:768px){.footer__copy{text-align:right}}

/* ============================================================
   PRIVACY MODAL
   ============================================================ */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(62,36,16,.65);z-index:9000;
  align-items:center;justify-content:center;padding:20px;
  overflow-y:auto;
}
.modal-overlay.open{display:flex}
.modal-box{
  background:var(--cream);max-width:640px;width:100%;
  max-height:90vh;overflow-y:auto;
  padding:clamp(28px,5vw,48px);position:relative;
  border-radius:var(--radius);
  margin:auto;
}
.modal-close{
  position:absolute;top:16px;right:16px;
  background:none;border:none;font-size:1.3rem;
  color:var(--coffee);line-height:1;
}
.modal-title{
  font-family:var(--ff-display);font-size:1.35rem;
  color:var(--espresso);margin-bottom:18px;
}
.modal-body{font-size:.8rem;color:var(--coffee);line-height:1.8}
.modal-body h4{
  font-family:var(--ff-display);font-size:.88rem;
  color:var(--espresso);margin:18px 0 7px;
}

/* ============================================================
   UTILITIES / RESPONSIVE
   ============================================================ */
@media(max-width:599px){
  .products-grid{gap:10px}
  .usos-grid{grid-template-columns:1fr}
  .dif-grid{grid-template-columns:1fr}
  .proceso__steps{grid-template-columns:1fr}
  .cta-buttons{flex-direction:column;align-items:center}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    transition-duration:.01ms!important;
  }
}
