
:root{
  /* === Paleta oficial Javier Pereira (brand manual 2026-06-25) === */
  --brown:#502c1d;          /* primario */
  --brown-dark:#2A1B14;
  --warm-gray:#d1cbbd;      /* warm gray del manual */
  --cream:#f9f4e4;          /* cream light oficial */
  --cream-cardboard:#CECABC;
  --teal:#6ad8d3;           /* cyan vibrante */
  --teal-deep:#5bbba3;      /* mint */
  --yellow:#e8e226;
  --pink:#ea5374;
  --orange-red:#e9483f;
  --green:#7aba4c;
  /* === Tokens utilitarios === */
  --bg:#F8F3EA; --paper:#FCFAF5; --ink:#1B1B1B;
  --muted:#7A6E63; --line:rgba(80,44,29,.12);
  /* === Accents por SKU === */
  --sku-sweet:#6ad8d3;      /* SWEET BOOST → teal */
  --sku-tasty:#ea5374;      /* TASTY CHARM → pink */
  --sku-hard:#e9483f;       /* HARD WORK → red */
  --sku-allure:#7aba4c;     /* GOOD ALLURE → green */
  /* === Tipografía oficial (Geared Slab + Axis Extra Bold + Oswald + QuickSand) ===
     Substitutos free: Roboto Slab ≈ Geared Slab, Anton ≈ Axis Extra Bold.
     Reemplazá por las fuentes oficiales (.woff2) cuando estén disponibles. */
  --serif:'Roboto Slab','Cormorant Garamond',Georgia,serif;       /* Geared Slab substitute */
  --sans:'Quicksand','Inter','Helvetica Neue',Arial,sans-serif;   /* Quicksand oficial */
  --display:'Anton','Oswald','Inter',sans-serif;                  /* Axis Extra Bold substitute */
  --accent-sans:'Oswald','Inter',sans-serif;                      /* Oswald oficial */
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.65;font-size:16px;font-weight:400;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--brown);text-decoration:none;transition:color .25s ease}
a:hover{color:var(--pink)}
.container{max-width:1240px;margin:0 auto;padding:0 28px}

/* TYPOGRAPHY */
h1,h2,h3,h4{margin:0 0 0.5em;color:var(--brown);letter-spacing:-.005em}
.display{font-family:var(--display);font-weight:900;text-transform:uppercase;line-height:.95;letter-spacing:.005em}
.serif{font-family:var(--serif);font-weight:500;font-style:italic;letter-spacing:.005em}
h1{font-size:clamp(2.6rem,7vw,5.2rem);font-family:var(--display);font-weight:900;text-transform:uppercase;line-height:.95}
h2{font-size:clamp(1.9rem,4.5vw,3.4rem);font-family:var(--display);font-weight:900;text-transform:uppercase;line-height:1}
h3{font-size:1.25rem;font-family:var(--sans);font-weight:800;text-transform:uppercase;letter-spacing:.05em}
p{margin:0 0 1em}
.eyebrow{font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--teal);font-weight:700;display:inline-block;position:relative;padding-left:30px}
.eyebrow::before{content:"";position:absolute;left:0;top:50%;width:22px;height:1px;background:var(--teal)}
.eyebrow.light{color:var(--cream)}.eyebrow.light::before{background:var(--cream)}
.eyebrow.center{padding-left:0}.eyebrow.center::before{display:none}

/* MARQUEE */
.marquee{background:var(--brown);color:var(--cream);overflow:hidden;border-bottom:1px solid var(--brown-dark);font-family:var(--display);font-size:1.1rem;letter-spacing:.18em;text-transform:uppercase}
.marquee-track{display:inline-flex;gap:60px;padding:14px 0;animation:scroll 24s linear infinite;white-space:nowrap}
.marquee-track span{display:inline-flex;align-items:center;gap:60px}
.marquee-track::after{content:"";display:inline-block;width:14px;height:14px;background:var(--pink);border-radius:50%;margin-left:30px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* HEADER */
.site-header{position:sticky;top:0;z-index:50;background:rgba(252,250,245,.94);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:padding .3s ease}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;gap:20px}
.logo{display:flex;align-items:center;gap:10px}
.logo img{height:52px;width:auto}
.site-nav{display:flex;gap:26px;flex-wrap:wrap}
.site-nav a{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.13em;color:var(--brown);position:relative;padding:6px 0}
.site-nav a::after{content:"";position:absolute;left:50%;bottom:0;width:0;height:1.5px;background:var(--pink);transition:.25s ease;transform:translateX(-50%)}
.site-nav a:hover::after,.site-nav a.active::after{width:100%}
.site-actions{display:flex;align-items:center;gap:14px}
.lang{display:flex;gap:4px;font-size:.72rem;font-weight:700;letter-spacing:.15em}
.lang a{padding:5px 9px;border:1px solid var(--line);border-radius:2px;color:var(--brown)}
.lang a.active{background:var(--brown);color:#fff;border-color:var(--brown)}
.cart-btn{display:flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.13em}
.cart-btn svg{width:18px;height:18px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--brown);color:var(--cream);padding:16px 32px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:.8rem;font-family:var(--sans);border:0;cursor:pointer;transition:.3s cubic-bezier(.16,.84,.44,1);text-decoration:none;border-radius:2px;position:relative;overflow:hidden}
.btn::after{content:"";position:absolute;inset:0;background:var(--pink);transform:translateX(-101%);transition:.35s cubic-bezier(.16,.84,.44,1);z-index:0}
.btn>*{position:relative;z-index:1}
.btn span,.btn svg{position:relative;z-index:1}
.btn:hover{color:#fff}
.btn:hover::after{transform:translateX(0)}
.btn.ghost{background:transparent;color:#fff;border:1.5px solid #fff}
.btn.ghost::after{background:#fff}
.btn.ghost:hover{color:var(--brown)}
.btn.light{background:#fff;color:var(--brown)}
.btn.light::after{background:var(--brown)}
.btn.light:hover{color:#fff}

/* ============= HERO (cinematic) ============= */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:#1a0e08;color:#fff;isolation:isolate}
.hero-bg{position:absolute;inset:-5%;background-size:cover;background-position:center;animation:kenburns 22s ease-in-out infinite alternate;z-index:0}
.hero-bg::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 40%,rgba(73,47,35,.45) 0%,rgba(26,14,8,.92) 100%)}
@keyframes kenburns{
  0%{transform:scale(1.04) translate(-1%,-1%)}
  50%{transform:scale(1.12) translate(2%,1%)}
  100%{transform:scale(1.06) translate(-2%,2%)}
}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(26,14,8,.35) 0%,rgba(26,14,8,.65) 60%,rgba(26,14,8,.78) 100%);z-index:1}
.steam{position:absolute;left:50%;bottom:0;width:200px;height:100%;transform:translateX(-50%);z-index:2;opacity:.15;pointer-events:none}
.steam path{animation:steam 9s ease-in-out infinite}
.steam path:nth-child(2){animation-delay:-3s}
.steam path:nth-child(3){animation-delay:-6s}
@keyframes steam{
  0%{transform:translateY(20%) scale(1);opacity:0}
  30%{opacity:.7}
  100%{transform:translateY(-30%) scale(1.4);opacity:0}
}
.hero-content{position:relative;z-index:3;width:100%;padding:90px 28px 70px;text-align:center}
.hero h1{color:#fff;font-size:clamp(2.8rem,8vw,6.2rem);max-width:1100px;margin:0 auto;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero h1 .accent{color:var(--cream);font-family:var(--serif);font-style:italic;font-weight:500;text-transform:none;display:block;font-size:clamp(1.5rem,3vw,2.4rem);margin-top:8px;letter-spacing:0;text-shadow:0 1px 14px rgba(0,0,0,.5)}
.hero .lead{color:rgba(255,255,255,.85);max-width:580px;margin:28px auto 38px;font-size:1.04rem;line-height:1.7;text-shadow:0 1px 12px rgba(0,0,0,.4)}
.hero .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:32px}
.hero-scroll{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;z-index:3;animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}
.hero-side{position:absolute;top:50%;right:30px;transform:translateY(-50%) rotate(90deg);transform-origin:right center;font-size:.68rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.45);z-index:3}
.hero-stats{position:absolute;left:0;right:0;bottom:0;display:grid;grid-template-columns:repeat(3,1fr);background:rgba(26,14,8,.55);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.08);z-index:3}
.hero-stats .stat{padding:18px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.hero-stats .stat:last-child{border-right:0}
.hero-stats .num{font-family:var(--display);font-size:1.6rem;color:#fff;letter-spacing:.04em}
.hero-stats .lbl{font-size:.66rem;letter-spacing:.22em;color:rgba(255,255,255,.6);text-transform:uppercase;margin-top:4px}

/* SECTION RHYTHM */
section{padding:120px 0;position:relative}
.section-head{text-align:center;max-width:760px;margin:0 auto 64px}
.section-head .eyebrow{margin-bottom:18px;padding-left:0}
.section-head .eyebrow::before{display:none}
.section-head h2{margin-bottom:18px}
.section-head .desc{color:var(--muted);font-size:1.04rem;line-height:1.7}

/* PRODUCT GRID */
.products{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:30px}
.product-card{background:#fff;border:1px solid var(--line);padding:0;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:.4s cubic-bezier(.16,.84,.44,1);text-decoration:none}
.product-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px -20px rgba(73,47,35,.3)}
.product-card .img-wrap{position:relative;aspect-ratio:4/5;overflow:hidden;background:#F1EAD9}
.product-card .img-wrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.5s ease}
.product-card .img-wrap .alt-img{opacity:0}
.product-card:hover .img-wrap .main-img{opacity:0}
.product-card:hover .img-wrap .alt-img{opacity:1}
.product-card .badge{position:absolute;top:14px;left:14px;background:var(--brown);color:var(--cream);font-size:.62rem;font-weight:700;letter-spacing:.18em;padding:6px 10px;text-transform:uppercase;z-index:2}
.product-card .body{padding:24px 22px;display:flex;flex-direction:column;flex-grow:1;text-align:center;color:var(--ink)}
.product-card .name{font-family:var(--display);font-weight:900;font-size:2.1rem;text-transform:uppercase;line-height:.9;margin:0 0 8px;color:var(--brown);letter-spacing:.005em}
.product-card .name .accent{display:inline}
.product-card .format{font-size:.66rem;letter-spacing:.25em;color:var(--teal);text-transform:uppercase;margin-bottom:14px;font-weight:700}
.product-card .desc{color:var(--muted);font-size:.92rem;margin:8px 0 18px;flex-grow:1;line-height:1.6}
.product-card .row{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--line);margin-top:auto}
.product-card .price{font-weight:800;font-size:1rem;color:var(--brown)}
.product-card .row span{font-size:.72rem;letter-spacing:.18em;font-weight:700;text-transform:uppercase;color:var(--pink)}

/* SECTION: products with bg */
.section-products{background:var(--paper);position:relative;overflow:hidden}
.section-products::before{content:"";position:absolute;top:60px;left:-100px;width:220px;height:220px;background:radial-gradient(circle,rgba(234,83,116,.08) 0%,transparent 70%);border-radius:50%}
.section-products::after{content:"";position:absolute;bottom:60px;right:-100px;width:280px;height:280px;background:radial-gradient(circle,rgba(45,104,102,.06) 0%,transparent 70%);border-radius:50%}

/* STORY SECTION (parallax) */
.story{position:relative;color:#fff;padding:160px 0;overflow:hidden;background:#1a0e08;isolation:isolate}
.story::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(26,14,8,.55),rgba(26,14,8,.78));background-size:cover;background-position:center;background-attachment:fixed;z-index:-1}
.story-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-attachment:fixed;z-index:-2;opacity:.85}
.story h2{color:#fff;font-size:clamp(2rem,4.5vw,3.6rem);max-width:1000px;margin:0 auto 28px;letter-spacing:0}
.story h2 .accent{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--cream);text-transform:none;font-size:.85em}
.story p{color:rgba(255,255,255,.86);max-width:620px;margin:0 auto 36px;font-size:1.08rem;font-family:var(--serif);font-style:italic}
.story .container{text-align:center;position:relative;z-index:1}

/* VALUE PROPS */
.values{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:36px;margin-top:60px}
.value{text-align:center;padding:20px 14px}
.value .icon{width:54px;height:54px;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;color:var(--pink)}
.value .icon svg{width:100%;height:100%;stroke-width:1.4}
.value h4{font-family:var(--display);font-size:1rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brown);margin-bottom:10px}
.value p{color:var(--muted);font-size:.92rem;line-height:1.6}

/* REVIEWS */
.reviews{padding:120px 0;background:var(--paper);position:relative}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:26px;margin-top:50px}
.review{background:#fff;padding:34px 30px;position:relative;border:1px solid var(--line);transition:.3s ease}
.review:hover{transform:translateY(-4px);box-shadow:0 18px 40px -16px rgba(73,47,35,.18)}
.review::before{content:"\201C";position:absolute;top:-12px;left:24px;font-family:var(--serif);font-size:6rem;color:var(--pink);line-height:1;font-weight:700}
.review .stars{color:var(--pink);font-size:1rem;letter-spacing:2px;margin-bottom:16px;margin-top:24px}
.review .quote{font-family:var(--serif);font-style:italic;color:var(--ink);margin-bottom:24px;line-height:1.7;font-size:1.02rem}
.review .author{font-weight:800;text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--brown)}
.review .author small{display:block;color:var(--teal);margin-top:6px;font-size:.66rem;letter-spacing:.2em;font-weight:600}

/* SUBSCRIPTION */
.subscription{padding:130px 0;background:var(--cream);position:relative;overflow:hidden}
.subscription::before{content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(73,47,35,.12) 0%,transparent 65%);border-radius:50%}
.sub-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative}
.sub-grid img{max-width:380px;justify-self:center;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.sub-grid .text h2{margin-bottom:24px}
.sub-grid .text p{color:var(--ink);font-size:1.05rem;line-height:1.7;margin-bottom:34px}
@media(max-width:880px){.sub-grid{grid-template-columns:1fr;gap:40px;text-align:center}.sub-grid img{order:-1;max-width:240px}}

/* INSTAGRAM / LIFESTYLE GRID */
.lifestyle{padding:120px 0;background:#fff}
.lifestyle-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(2,200px);gap:6px;margin-top:46px}
.lifestyle-grid .item{position:relative;overflow:hidden;background:#F1EAD9}
.lifestyle-grid .item img{width:100%;height:100%;object-fit:cover;transition:.6s cubic-bezier(.16,.84,.44,1)}
.lifestyle-grid .item:hover img{transform:scale(1.06)}
.lifestyle-grid .item:nth-child(1){grid-column:span 2;grid-row:span 2}
.lifestyle-grid .item:nth-child(4){grid-column:span 2}
@media(max-width:760px){.lifestyle-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(4,180px)}.lifestyle-grid .item:nth-child(1){grid-column:span 2;grid-row:span 1}.lifestyle-grid .item:nth-child(4){grid-column:span 2}}

/* INNER HERO (with image bg) */
.hero-inner{position:relative;min-height:55vh;display:flex;align-items:center;justify-content:center;color:#fff;text-align:center;overflow:hidden;background:#1a0e08;padding:140px 28px 80px}
.hero-inner .bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:kenburns 22s ease-in-out infinite alternate}
.hero-inner .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,14,8,.5) 0%,rgba(26,14,8,.75) 100%)}
.hero-inner .inner{position:relative;z-index:2;max-width:880px}
.hero-inner h1{color:#fff}
.hero-inner h1 .light{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--cream);text-transform:none;display:block;font-size:.55em;margin-top:10px;letter-spacing:0}
.hero-inner .lead{color:rgba(255,255,255,.88);font-size:1.08rem;margin-top:24px;max-width:680px;margin-left:auto;margin-right:auto;font-family:var(--serif);font-style:italic;line-height:1.7}

/* TWO COLUMN ALTERNATING (about/innovation) */
.split{padding:120px 0}
.split + .split{padding-top:0}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.split-grid.flip .text{order:2}
.split-grid.flip .visual{order:1}
.split-grid .visual{position:relative}
.split-grid .visual img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:2px}
.split-grid .visual .stamp{position:absolute;bottom:-30px;right:-30px;width:140px;height:140px;background:var(--cream);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-direction:column;font-family:var(--display);text-transform:uppercase;color:var(--brown);text-align:center;line-height:1.1;font-size:.74rem;letter-spacing:.1em;padding:18px;box-shadow:0 12px 36px rgba(73,47,35,.18);transform:rotate(-10deg)}
.split-grid .visual .stamp span{display:block;font-size:1.6rem;margin-bottom:4px;color:var(--pink)}
.split-grid .text h2{margin-bottom:24px}
.split-grid .text .eyebrow{margin-bottom:18px;padding-left:0}
.split-grid .text .eyebrow::before{display:none}
.split-grid .text p{color:var(--ink);font-size:1.05rem;line-height:1.75;margin-bottom:18px}
.split-grid .text p.lead-text{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--brown);margin-bottom:24px}
@media(max-width:860px){.split-grid{grid-template-columns:1fr;gap:40px}.split-grid.flip .text{order:1}.split-grid.flip .visual{order:2}}

/* IMPACT PILLARS */
.pillars{padding:120px 0;background:var(--paper)}
.pillar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;margin-top:60px}
.pillar{background:#fff;padding:42px 36px;border-top:3px solid var(--pink);border-radius:2px;transition:.3s ease;position:relative}
.pillar:nth-child(2){border-top-color:var(--teal)}
.pillar:nth-child(3){border-top-color:var(--green)}
.pillar:nth-child(4){border-top-color:var(--brown)}
.pillar:hover{transform:translateY(-6px);box-shadow:0 24px 50px -16px rgba(73,47,35,.18)}
.pillar h3{font-family:var(--display);font-size:1.15rem;line-height:1.2;letter-spacing:.06em;margin-bottom:18px;color:var(--brown)}
.pillar p{color:var(--muted);font-size:.96rem;line-height:1.7;margin:0}
.pillar .num{position:absolute;top:24px;right:28px;font-family:var(--display);font-size:2.6rem;color:var(--cream);line-height:1;opacity:.7}

/* PRODUCT DETAIL */
.product-detail{padding:80px 0 100px}
.pd-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:flex-start}
.pd-gallery{position:sticky;top:90px}
.pd-gallery .main{background:#fff;border:1px solid var(--line);aspect-ratio:1/1;overflow:hidden}
.pd-gallery .main img{width:100%;height:100%;object-fit:cover}
.pd-gallery .thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}
.pd-gallery .thumbs .t{background:#fff;border:1px solid var(--line);aspect-ratio:1/1;overflow:hidden;cursor:pointer;transition:.25s ease}
.pd-gallery .thumbs .t:hover{border-color:var(--pink)}
.pd-gallery .thumbs .t img{width:100%;height:100%;object-fit:cover}
.pd-info .breadcrumb{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin-bottom:20px}
.pd-info h1{font-family:var(--display);font-size:clamp(3rem,6vw,5rem);line-height:.9;margin-bottom:14px;letter-spacing:.005em}
.pd-info .desc{font-family:var(--serif);font-style:italic;font-size:1.18rem;color:var(--brown);margin-bottom:24px;line-height:1.5}
.pd-info .price{font-size:1.8rem;font-weight:800;color:var(--brown);margin:24px 0;padding-bottom:24px;border-bottom:1px solid var(--line)}
.pd-info .options{margin:24px 0}
.pd-info .options label{display:block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--brown);margin-bottom:10px}
.pd-info .opts{display:flex;gap:8px;flex-wrap:wrap}
.pd-info .opts .opt{background:#fff;border:1.5px solid var(--line);padding:10px 18px;cursor:pointer;font-size:.84rem;font-weight:600;letter-spacing:.05em;transition:.2s ease}
.pd-info .opts .opt:hover,.pd-info .opts .opt.sel{border-color:var(--brown);background:var(--brown);color:#fff}
.pd-info .add-cart{margin-top:30px;width:100%;justify-content:center;padding:20px 32px;font-size:.88rem}
.pd-specs{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:34px;border:1px solid var(--line)}
.pd-specs .s{padding:18px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center}
.pd-specs .s:nth-child(2n){border-right:0}
.pd-specs .s:nth-last-child(-n+2){border-bottom:0}
.pd-specs .lbl{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--teal);font-weight:700;margin-bottom:6px}
.pd-specs .val{font-family:var(--display);font-size:1.1rem;text-transform:uppercase;color:var(--brown);letter-spacing:.04em}
.pd-tabs{margin-top:80px;border-top:1px solid var(--line);padding-top:60px}
.pd-tabs .tab-headers{display:flex;gap:32px;border-bottom:1px solid var(--line);margin-bottom:32px}
.pd-tabs .tab-headers a{padding:14px 0;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px}
.pd-tabs .tab-headers a.active{color:var(--brown);border-bottom-color:var(--pink)}
.pd-tabs h3{font-family:var(--display);font-size:1.4rem;margin-bottom:18px}
.pd-tabs p{color:var(--ink);font-size:1.02rem;line-height:1.8;margin-bottom:16px}
@media(max-width:860px){.pd-grid{grid-template-columns:1fr;gap:30px}.pd-gallery{position:static}}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:36px;margin-top:60px}
.blog-card{background:#fff;border:1px solid var(--line);overflow:hidden;transition:.3s ease;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -16px rgba(73,47,35,.15)}
.blog-card .img-wrap{aspect-ratio:16/10;overflow:hidden;background:var(--cream)}
.blog-card .img-wrap img{width:100%;height:100%;object-fit:cover;transition:.5s ease}
.blog-card:hover img{transform:scale(1.06)}
.blog-card .body{padding:28px 26px;flex-grow:1;display:flex;flex-direction:column}
.blog-card .meta{font-size:.7rem;color:var(--teal);letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;font-weight:700}
.blog-card h3{font-family:var(--display);font-size:1.15rem;line-height:1.25;text-transform:uppercase;color:var(--brown);margin-bottom:12px;letter-spacing:.02em}
.blog-card .excerpt{color:var(--muted);font-size:.92rem;line-height:1.65;margin-bottom:18px;flex-grow:1}
.blog-card .read{font-weight:800;color:var(--pink);text-transform:uppercase;font-size:.74rem;letter-spacing:.18em;margin-top:auto}

/* POST CONTENT */
.post-content{max-width:780px;margin:0 auto;padding:80px 28px 100px}
.post-content h1{margin-bottom:20px;text-transform:none;letter-spacing:-.01em;font-family:var(--display);font-size:clamp(2rem,5vw,3.4rem)}
.post-content .date{display:block;text-align:center;color:var(--teal);letter-spacing:.22em;text-transform:uppercase;font-size:.74rem;margin-bottom:50px;font-weight:700}
.post-content p{font-family:var(--serif);font-size:1.18rem;line-height:1.8;margin-bottom:1.2em;color:var(--ink)}
.post-content h2,.post-content h3{font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;margin-top:1.8em;color:var(--brown)}
.post-content h2{font-size:1.6rem}.post-content h3{font-size:1.2rem}

/* FAQ ACCORDION */
.faqs{max-width:780px;margin:60px auto 0}
.faq{background:#fff;border:1px solid var(--line);margin-bottom:12px;border-radius:2px;overflow:hidden}
.faq summary{padding:24px 28px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;font-weight:700;color:var(--brown);font-size:1rem;letter-spacing:.01em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--pink);transition:.25s ease;font-weight:300}
.faq[open] summary::after{transform:rotate(45deg)}
.faq .a{padding:0 28px 26px;color:var(--ink);line-height:1.75;border-top:1px solid var(--line);padding-top:18px}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;padding:90px 0}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}
.contact-info p{margin-bottom:24px}
.contact-info .label{display:block;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--teal);font-weight:700;margin-bottom:6px}
.contact-info .val{font-size:1.05rem;color:var(--ink)}
.contact-info img{margin-top:30px;border-radius:2px;width:100%;aspect-ratio:4/5;object-fit:cover}
.form-card{background:#fff;border:1px solid var(--line);padding:42px 38px}
.form-card h3{font-family:var(--display);font-size:1.6rem;letter-spacing:.05em;margin-bottom:6px}
.form-card .sub{color:var(--muted);font-family:var(--serif);font-style:italic;margin-bottom:30px;font-size:1.04rem}
.form-card .field{margin-bottom:18px}
.form-card label{display:block;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--brown);margin-bottom:8px}
.form-card input,.form-card textarea{width:100%;padding:14px 16px;border:1px solid var(--line);background:var(--paper);font-family:inherit;font-size:.96rem;color:var(--ink);border-radius:2px;transition:.2s ease}
.form-card input:focus,.form-card textarea:focus{outline:none;border-color:var(--brown);background:#fff}
.form-card textarea{min-height:120px;resize:vertical}
.form-card .btn{width:100%;justify-content:center;margin-top:8px}

/* PROSE */
.prose{max-width:780px;margin:0 auto;padding:60px 28px 90px}
.prose h1{margin-bottom:32px;text-align:center;font-size:clamp(2rem,5vw,3rem)}
.prose p,.prose li{font-size:1.04rem;line-height:1.8;margin-bottom:1em}
.prose h2,.prose h3{margin-top:1.6em;margin-bottom:0.6em;font-family:var(--display);text-transform:uppercase;letter-spacing:.04em}
.prose ul{padding-left:22px}

/* FOOTER */
.site-footer{background:var(--brown);color:var(--cream);padding:90px 0 30px;margin-top:0;position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--pink),transparent)}
.footer-newsletter{background:var(--brown-dark);padding:60px 0;text-align:center;margin-bottom:80px}
.footer-newsletter h3{color:#fff;font-family:var(--display);font-size:1.8rem;letter-spacing:.06em;margin-bottom:10px}
.footer-newsletter p{color:rgba(206,202,188,.75);margin-bottom:26px;font-family:var(--serif);font-style:italic;font-size:1.08rem}
.footer-newsletter form{display:flex;max-width:480px;margin:0 auto;gap:0;border:1px solid rgba(255,255,255,.18)}
.footer-newsletter input{flex:1;background:transparent;border:0;padding:18px 22px;color:#fff;font-family:inherit;font-size:.96rem;outline:none}
.footer-newsletter input::placeholder{color:rgba(206,202,188,.5)}
.footer-newsletter button{background:#fff;color:var(--brown);border:0;padding:0 28px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:.78rem;cursor:pointer;transition:.25s ease}
.footer-newsletter button:hover{background:var(--pink);color:#fff}
.foot-cols{display:grid;grid-template-columns:1.4fr repeat(3,1fr) 1fr;gap:50px;margin-bottom:60px}
.foot-cols .brand img{height:60px;margin-bottom:18px;filter:brightness(0) invert(1) opacity(0.95)}
.foot-cols .brand p{color:rgba(206,202,188,.7);font-size:.92rem;line-height:1.7;font-family:var(--serif);font-style:italic}
.foot-cols h4{color:#fff;font-family:var(--display);font-size:.84rem;letter-spacing:.18em;margin-bottom:20px;text-transform:uppercase}
.foot-cols ul{list-style:none;padding:0;margin:0}
.foot-cols li{margin:0 0 12px;font-size:.9rem}
.foot-cols a{color:rgba(206,202,188,.85);transition:.2s ease}
.foot-cols a:hover{color:#fff;padding-left:6px}
.social{display:flex;gap:12px;margin-top:10px}
.social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid rgba(255,255,255,.18);border-radius:50%;color:#fff;transition:.25s ease}
.social a:hover{background:var(--pink);border-color:var(--pink);color:#fff;transform:translateY(-2px)}
.social svg{width:14px;height:14px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;font-size:.78rem;color:rgba(206,202,188,.6);letter-spacing:.16em;text-transform:uppercase}
@media(max-width:1020px){.foot-cols{grid-template-columns:repeat(2,1fr);gap:40px}.foot-cols .brand{grid-column:span 2}}

/* ANIMATIONS — fade-in on scroll */
.fade{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.16,.84,.44,1),transform .9s cubic-bezier(.16,.84,.44,1)}
.fade.in{opacity:1;transform:translateY(0)}
.fade-d1{transition-delay:.08s}.fade-d2{transition-delay:.16s}.fade-d3{transition-delay:.24s}.fade-d4{transition-delay:.32s}

/* MOBILE */
@media(max-width:880px){
  .site-header .container{flex-wrap:wrap;gap:12px;padding:12px 18px}
  .site-nav{order:3;width:100%;justify-content:flex-start;gap:14px;font-size:.7rem;overflow-x:auto;padding-bottom:6px}
  .site-nav a{white-space:nowrap}
  section{padding:80px 0}
  .hero{min-height:88vh}
  .hero-content{padding:60px 24px 90px}
  .hero-stats{display:none}
  .container{padding:0 20px}
  .review::before{font-size:4rem}
}

/* ============ HERO WITH VIDEO ============ */
.hero-video{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#0a0604;color:#fff;isolation:isolate}
.hero-video-el{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-video .hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,6,4,.35) 0%,rgba(10,6,4,.55) 45%,rgba(10,6,4,.78) 100%);z-index:1}
.hero-video .hero-content{position:relative;z-index:2;text-align:center;padding:120px 28px 100px;max-width:1200px;width:100%}
.hero-eyebrow{font-size:.84rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.92);font-weight:600;margin:0 0 28px;display:inline-block;padding:8px 22px;border-top:1px solid rgba(255,255,255,.35);border-bottom:1px solid rgba(255,255,255,.35)}
.hero-title{font-family:var(--display);font-weight:900;text-transform:uppercase;line-height:.92;letter-spacing:.005em;color:#fff;margin:0;text-shadow:0 2px 40px rgba(0,0,0,.4)}
.hero-title .line-1{display:block;font-size:clamp(2.4rem,7vw,5.6rem);font-family:var(--serif);font-style:italic;font-weight:500;text-transform:none;letter-spacing:0;color:var(--cream);margin-bottom:14px;font-size:clamp(1.8rem,4vw,3rem)}
.hero-title .line-2{display:block;font-size:clamp(3.2rem,10vw,8rem);line-height:.9}
.hero-title .line-3{display:block;font-size:clamp(2.4rem,7vw,5.6rem);line-height:1;margin-top:14px;color:var(--cream);font-family:var(--serif);font-style:italic;font-weight:500;text-transform:none;letter-spacing:0}
.hero-actions{margin-top:50px;display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.btn-big{padding:22px 50px;font-size:.92rem;letter-spacing:.18em;border-radius:0}

/* ============ MANIFESTO SECTION ============ */
.manifesto{padding:140px 0;background:var(--paper);position:relative;overflow:hidden}
.manifesto::before{content:"";position:absolute;top:80px;left:-100px;width:280px;height:280px;background:radial-gradient(circle,rgba(45,104,102,.08) 0%,transparent 65%);border-radius:50%}
.manifesto-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:90px;align-items:center;position:relative}
.manifesto-title{font-family:var(--display);font-size:clamp(2.4rem,5vw,4.4rem);line-height:.98;text-transform:uppercase;color:var(--brown);margin:18px 0 28px;letter-spacing:.005em}
.manifesto-title em{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--pink);text-transform:none;letter-spacing:0;font-size:1.05em;display:inline-block;padding:0 .1em}
.manifesto-body{font-size:1.08rem;line-height:1.75;color:var(--ink);margin-bottom:36px;max-width:540px}
.link-arrow{display:inline-flex;align-items:center;gap:14px;color:var(--brown);font-weight:800;text-transform:uppercase;letter-spacing:.14em;font-size:.9rem;padding:14px 0;border-bottom:2px solid var(--brown);transition:.3s ease}
.link-arrow svg{transition:transform .3s ease}
.link-arrow:hover{color:var(--pink);border-bottom-color:var(--pink)}
.link-arrow:hover svg{transform:translateX(6px)}
.manifesto-visual{position:relative}
.manifesto-visual img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:2px;box-shadow:0 30px 80px -20px rgba(73,47,35,.35)}
.manifesto-stamp{position:absolute;top:-26px;right:-26px;width:148px;height:148px;background:var(--pink);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;box-shadow:0 14px 36px rgba(234,83,116,.4);transform:rotate(-8deg);transition:.4s cubic-bezier(.16,.84,.44,1)}
.manifesto-visual:hover .manifesto-stamp{transform:rotate(0)}
.manifesto-stamp .stamp-num{font-family:var(--display);font-size:2.4rem;line-height:1;letter-spacing:.005em}
.manifesto-stamp .stamp-lbl{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;margin-top:6px}
@media(max-width:880px){
  .manifesto{padding:90px 0}
  .manifesto-grid{grid-template-columns:1fr;gap:50px}
  .manifesto-visual{order:-1;max-width:420px;margin:0 auto}
  .manifesto-stamp{width:120px;height:120px;top:-18px;right:-18px}
  .manifesto-stamp .stamp-num{font-size:1.8rem}
}

/* Hide old hero-stats on video hero */
.hero-video .hero-stats{display:none}

/* ============ V3 PATCH — bigger logo, hero hierarchy, tighter spacing ============ */
/* LOGO bigger everywhere */
.logo img{height:72px}
.site-header .container{padding:18px 28px}
.foot-cols .brand img{height:80px}

/* HERO new hierarchy: line-1 = GIANT From the heart of Colombia */
.hero-title .line-1{
  display:block;
  font-family:var(--display);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.005em;
  font-style:normal;
  color:#fff;
  font-size:clamp(3rem,9vw,7.5rem) !important;
  line-height:.92;
  margin-bottom:18px;
  margin-top:0;
}
.hero-title .line-2{
  display:block;
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  text-transform:none;
  letter-spacing:0;
  color:var(--cream);
  font-size:clamp(1.6rem,3.4vw,2.8rem);
  line-height:1.15;
  margin-bottom:6px;
}
.hero-title .line-3{
  display:block;
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  text-transform:none;
  letter-spacing:0;
  color:var(--cream);
  font-size:clamp(1.4rem,3vw,2.4rem);
  line-height:1.15;
  margin-top:0;
}
.hero-eyebrow{margin-bottom:36px}

/* TIGHTER SPACING */
section{padding:80px 0 !important}
.manifesto{padding:90px 0 !important}
.story{padding:110px 0 !important}
.section-head{margin-bottom:48px}
.subscription{padding:90px 0 !important}
.reviews{padding:90px 0 !important}
.lifestyle{padding:90px 0 !important}
.section-products{padding:90px 0 !important}

@media(max-width:880px){
  section{padding:60px 0 !important}
  .manifesto, .reviews, .lifestyle, .subscription, .section-products, .story{padding:60px 0 !important}
  .logo img{height:60px}
  .foot-cols .brand img{height:70px}
}

/* ============ V4 — wordmark grande + subtítulo hero ============ */
/* Big arched wordmark at top of hero */
.hero-wordmark{
  display:block;
  margin:0 auto 36px;
  width:auto;
  max-width:540px;
  height:auto;
  filter:brightness(0) invert(1) drop-shadow(0 2px 30px rgba(0,0,0,.5));
  opacity:.98;
}
@media(max-width:880px){
  .hero-wordmark{max-width:340px;margin-bottom:24px}
}

/* Subtitle below the CTA button */
.hero-subtitle{
  margin:30px auto 0;
  max-width:680px;
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.05rem,2vw,1.35rem);
  color:var(--cream);
  line-height:1.5;
  text-align:center;
  text-shadow:0 1px 14px rgba(0,0,0,.4);
}
.hero-subtitle a{
  color:#fff;
  font-family:var(--sans);
  font-style:normal;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.82rem;
  padding:6px 0;
  margin-left:14px;
  border-bottom:1.5px solid rgba(255,255,255,.6);
  transition:.25s ease;
}
.hero-subtitle a:hover{
  color:var(--pink);
  border-bottom-color:var(--pink);
}

/* Tighter hero content padding when wordmark is shown */
.hero-video .hero-content{padding-top:90px;padding-bottom:90px}
@media(max-width:880px){
  .hero-video .hero-content{padding-top:60px;padding-bottom:60px}
  .hero-subtitle{font-size:1rem;margin-top:24px}
  .hero-subtitle a{display:inline-block;margin-top:10px;margin-left:0}
}

/* ============ V5 — wordmark banner arriba + story con imagen visible ============ */
/* Brand banner (arriba del video) */
.brand-banner{
  background:var(--paper);
  padding:38px 28px;
  text-align:center;
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
}
.brand-wordmark{
  max-width:520px;
  width:80%;
  height:auto;
  filter:none;
  opacity:1;
}
@media(max-width:880px){
  .brand-banner{padding:24px 20px}
  .brand-wordmark{max-width:280px}
}

/* Hide the old hero-wordmark style — wordmark is no longer inside hero */
.hero-wordmark{display:none}

/* STORY section with REAL background image */
.story-img{
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
  position:relative;
  z-index:0;
}
.story-img .story-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(26,14,8,.35) 0%,rgba(26,14,8,.6) 100%);
}
.story-img .container{position:relative;z-index:2}
/* Override the old ::before that was hiding the image */
.story::before{display:none !important}
.story-bg{display:none}

@media(max-width:880px){
  .story-img{background-attachment:scroll}
}

/* ============ V6 — brand-banner with BADGE logo (round, taller) ============ */
.brand-banner{padding:32px 28px}
.brand-wordmark{max-width:200px;width:auto;height:auto}
@media(max-width:880px){
  .brand-banner{padding:22px 20px}
  .brand-wordmark{max-width:140px}
}

/* ============ V7 — wordmark in header (esquina izq), no brand-banner ============ */
.brand-banner{display:none}
/* Header logo is now the arched wordmark — landscape orientation */
.logo img{height:auto;width:auto;max-height:56px;max-width:200px;object-fit:contain}
@media(max-width:880px){
  .logo img{max-height:44px;max-width:150px}
}

/* ============ V8 — bigger lead in inner heroes (our coffees etc) ============ */
.hero-inner .lead{
  font-size:clamp(1.4rem,2.6vw,2.2rem) !important;
  line-height:1.4;
  max-width:880px;
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  color:rgba(255,255,255,.94);
}
@media(max-width:880px){
  .hero-inner .lead{font-size:1.2rem !important}
}

/* ============ V9 — product gallery con thumbs clicables + subscription ============ */
.pd-back{padding-top:24px;margin-bottom:14px;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase}
.pd-back a{color:var(--brown);font-weight:600}
.pd-back a:hover{color:var(--pink)}

.pd-gallery{position:sticky;top:90px}
.pd-main{background:#fff;border:1px solid var(--line);aspect-ratio:1/1;overflow:hidden;margin-bottom:14px}
.pd-main img{width:100%;height:100%;object-fit:cover;transition:opacity .4s ease}
.pd-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.pd-thumbs .t{background:#fff;border:2px solid var(--line);aspect-ratio:1/1;overflow:hidden;cursor:pointer;transition:.2s ease}
.pd-thumbs .t:hover{border-color:var(--brown)}
.pd-thumbs .t.sel{border-color:var(--pink)}
.pd-thumbs .t img{width:100%;height:100%;object-fit:cover}

.pd-subscription{display:flex;align-items:center;gap:18px;background:var(--cream);padding:18px 22px;margin-top:18px;border-left:3px solid var(--pink)}
.pd-subscription .sub-icon{font-size:1.8rem}
.pd-subscription .sub-text{display:flex;flex-direction:column;gap:2px}
.pd-subscription .sub-text strong{font-family:var(--display);font-size:.96rem;letter-spacing:.1em;color:var(--brown);text-transform:uppercase}
.pd-subscription .sub-text span{font-size:.86rem;color:var(--ink)}

@media(max-width:860px){
  .pd-gallery{position:static}
  .pd-thumbs{grid-template-columns:repeat(4,1fr)}
}

/* ============ V10 — footer badge más grande ============ */
.foot-cols .brand img{height:130px !important;max-height:130px}
@media(max-width:880px){
  .foot-cols .brand img{height:100px !important}
}

/* ============ V11 — "Cómo se disfruta" section en producto ============ */
.pd-lifestyle{padding:90px 0;background:var(--cream);position:relative;overflow:hidden}
.pd-lifestyle::before{content:"";position:absolute;top:-100px;right:-100px;width:280px;height:280px;background:radial-gradient(circle,rgba(73,47,35,.1) 0%,transparent 65%);border-radius:50%}
.lifestyle-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;position:relative;z-index:1}
.lifestyle-img img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:2px;box-shadow:0 24px 60px -20px rgba(73,47,35,.35)}
.lifestyle-text h2{font-size:clamp(2.2rem,4.5vw,3.6rem);margin-bottom:24px}
.lifestyle-text .eyebrow{margin-bottom:16px;padding-left:0}
.lifestyle-text .eyebrow::before{display:none}
.lifestyle-text .big{font-family:var(--serif);font-style:italic;font-size:clamp(1.1rem,1.8vw,1.35rem);line-height:1.7;color:var(--ink)}
@media(max-width:860px){
  .pd-lifestyle{padding:60px 0}
  .lifestyle-grid-2col{grid-template-columns:1fr;gap:30px}
}

/* ============ HERO POSTER 4-UP (carga antes del video) ============ */
.hero-poster-4up{position:absolute;inset:0;z-index:0;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:1fr;background:linear-gradient(180deg,#2a1810 0%,#1a0e08 100%);opacity:1;transition:opacity .8s ease}
.hero-poster-4up .hpc{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:6%;background:transparent}
.hero-poster-4up .hpc::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center, rgba(255,255,255,.06) 0%, transparent 70%)}
.hero-poster-4up .hpc img{position:relative;max-width:88%;max-height:88%;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 20px 40px rgba(0,0,0,.45))}
.hero-video-el{opacity:0;transition:opacity 1s ease;z-index:1}
.hero-video.video-playing .hero-video-el{opacity:1}
.hero-video.video-playing .hero-poster-4up{opacity:0;pointer-events:none}
@media (max-width:720px){
  .hero-poster-4up{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}
}

/* ============ PRODUCT GALLERY (4 ángulos + selector tamaño) ============ */
.pd-gallery .pd-main img{display:block;width:100%;height:auto;background:#fbead6;border-radius:8px;aspect-ratio:1/1;object-fit:contain;padding:6%}
.pd-gallery .pd-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}
.pd-gallery .pd-thumbs .t{cursor:pointer;border:2px solid transparent;background:#fbead6;padding:0;border-radius:6px;overflow:hidden;display:block;width:100%;aspect-ratio:1/1}
.pd-gallery .pd-thumbs .t img{display:block;width:100%;height:100%;object-fit:contain;padding:8%;background:transparent}
.pd-gallery .pd-thumbs .t.sel{border-color:var(--brown,#4b2c20)}
.pd-gallery .pd-thumbs .t:hover{border-color:rgba(75,44,32,.5)}

.options .opts{display:flex;gap:8px;flex-wrap:wrap}
.options .opts[data-role="size"] .opt{position:relative;cursor:pointer;padding:14px 22px;border:1.5px solid #4b2c20;border-radius:0;text-align:center;min-width:80px;transition:.2s ease;line-height:1.1}
.options .opts[data-role="size"] .opt.sel{background:#4b2c20;color:#fbead6}
.options .opts[data-role="size"] .opt[data-available="false"]{opacity:.45;cursor:not-allowed;background:repeating-linear-gradient(45deg,transparent 0,transparent 6px,rgba(75,44,32,.06) 6px,rgba(75,44,32,.06) 12px)}
.options .opts[data-role="size"] .opt[data-available="false"]:hover{background:repeating-linear-gradient(45deg,transparent 0,transparent 6px,rgba(75,44,32,.06) 6px,rgba(75,44,32,.06) 12px)}
.options .opts[data-role="size"] .opt .badge-soon{display:block;font-size:.55rem;letter-spacing:.18em;margin-top:3px;font-weight:700;color:inherit;opacity:.8}

/* ============ ADD TO CART · V2 (más prominente, con icono) ============ */
.pd-info .add-cart{
  margin-top:36px;width:100%;justify-content:center;align-items:center;gap:14px;
  padding:24px 32px;font-size:.92rem;letter-spacing:.22em;font-weight:900;
  background:linear-gradient(135deg,#4b2c20 0%,#3a2418 100%);
  color:#fbead6;border:0;border-radius:0;
  box-shadow:0 18px 40px -16px rgba(75,44,32,.5),0 4px 10px -4px rgba(75,44,32,.3);
  position:relative;overflow:hidden;cursor:pointer;
  transition:transform .35s cubic-bezier(.16,.84,.44,1), box-shadow .35s ease, color .25s ease;
}
.pd-info .add-cart::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,#EA5374 0%,#c83f5e 100%);
  transform:translateX(-101%);transition:.45s cubic-bezier(.16,.84,.44,1);z-index:0;
}
.pd-info .add-cart > *{position:relative;z-index:1}
.pd-info .add-cart:hover{
  transform:translateY(-3px);
  box-shadow:0 28px 60px -16px rgba(234,83,116,.5),0 8px 16px -6px rgba(234,83,116,.35);
  color:#fff;
}
.pd-info .add-cart:hover::after{transform:translateX(0)}
.pd-info .add-cart:active{transform:translateY(-1px)}
.pd-info .add-cart .cart-ico{display:inline-flex;width:22px;height:22px}
.pd-info .add-cart .cart-ico svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pd-info .add-cart .arrow{display:inline-flex;transition:transform .35s cubic-bezier(.16,.84,.44,1)}
.pd-info .add-cart:hover .arrow{transform:translateX(6px)}
.pd-info .add-cart .price-suffix{opacity:.7;font-weight:600;letter-spacing:.1em;margin-left:6px}

/* ============ SIZE SELECTOR V2 (didáctico con precios + badges) ============ */
.options .opts[data-role="size"]{gap:10px}
.options .opts[data-role="size"] .opt{
  padding:18px 18px 14px;min-width:110px;display:flex;flex-direction:column;align-items:center;gap:4px;
  position:relative;border:1.5px solid #d4c4ab;background:#fdf6e8;color:#492f23;
  transition:.25s cubic-bezier(.16,.84,.44,1);text-align:center;
}
.options .opts[data-role="size"] .opt:hover{border-color:#4b2c20;transform:translateY(-2px);box-shadow:0 10px 22px -10px rgba(75,44,32,.3)}
.options .opts[data-role="size"] .opt.sel{background:#4b2c20;color:#fbead6;border-color:#4b2c20}
.options .opts[data-role="size"] .opt .sz-name{font-family:var(--display,'Anton','Oswald',sans-serif);font-size:1.25rem;letter-spacing:.04em;font-weight:700;line-height:1}
.options .opts[data-role="size"] .opt .sz-sub{font-size:.7rem;letter-spacing:.06em;opacity:.78;margin-top:2px;font-weight:500;text-transform:none}
.options .opts[data-role="size"] .opt .sz-pop,
.options .opts[data-role="size"] .opt .sz-best{
  position:absolute;top:-9px;left:50%;transform:translateX(-50%);
  background:#EA5374;color:#fff;font-size:.55rem;letter-spacing:.18em;font-weight:800;
  padding:3px 10px;border-radius:999px;white-space:nowrap;box-shadow:0 4px 10px -3px rgba(234,83,116,.5);
}
.options .opts[data-role="size"] .opt .sz-best{background:#2d6866}
.options .opts[data-role="size"] .opt.sel .sz-sub{opacity:.85}

/* ============ MARQUEE V2 (más editorial, ornamentado) ============ */
.marquee{
  background:linear-gradient(180deg,#3a2418 0%,#2a1810 100%);color:#fbead6;
  overflow:hidden;border:none;position:relative;
  font-family:'Cormorant Garamond','Fraunces',serif;font-size:1.05rem;
  letter-spacing:.04em;text-transform:none;font-weight:500;
  border-bottom:1px solid rgba(251,234,214,.12);
  padding:0;
}
.marquee::before,.marquee::after{
  content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(to right,#2a1810 10%,transparent)}
.marquee::after{right:0;background:linear-gradient(to left,#2a1810 10%,transparent)}
.marquee-track{display:inline-flex;gap:0;padding:13px 0;animation:scroll 60s linear infinite;white-space:nowrap;will-change:transform}
.marquee-track::after{display:none}
.marquee-track span{display:inline-flex;align-items:center;gap:0;white-space:nowrap}
.marquee-track .mq-item{display:inline-flex;align-items:center;gap:14px;padding:0 32px}
.marquee-track .mq-item em{font-style:italic;color:#f4d6a3;font-weight:500;font-size:1.1em}
.marquee-track .mq-item strong{font-family:'Inter',sans-serif;font-weight:700;font-size:.78em;letter-spacing:.24em;text-transform:uppercase;color:#fbead6}
.marquee-track .mq-sep{
  display:inline-flex;align-items:center;justify-content:center;width:32px;flex-shrink:0;
  color:#c89f6a;opacity:.55;font-family:serif;
}
.marquee-track .mq-sep svg{width:16px;height:16px;fill:currentColor}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (max-width:720px){.marquee{font-size:.92rem}.marquee-track{animation-duration:45s}.marquee-track .mq-item{padding:0 22px;gap:10px}}

/* ============ STORY · PEOPLE responsive (4 breakpoints + JPG fallback) ============ */
.story-img.story-people{
  background-image:url("img/people-coffee-savor-1600.jpg"); /* fallback */
  background-position:center 38%;
  min-height:62vh;
}
@supports (background-image: image-set(url("x") 1x)){
  .story-img.story-people{
    background-image:image-set(
      url("img/people-coffee-savor-1600.webp") 1x,
      url("img/people-coffee-savor-2400.webp") 2x
    );
  }
}
.story-img.story-people .story-overlay{
  background:linear-gradient(180deg,rgba(26,14,8,.25) 0%,rgba(26,14,8,.55) 60%,rgba(26,14,8,.75) 100%);
}
/* mobile */
@media (max-width:720px){
  .story-img.story-people{
    background-image:url("img/people-coffee-savor-960.webp");
    background-attachment:scroll;
    background-position:center center;
    min-height:54vh;
  }
  @supports (background-image: image-set(url("x") 1x)){
    .story-img.story-people{
      background-image:image-set(
        url("img/people-coffee-savor-480.webp") 1x,
        url("img/people-coffee-savor-960.webp") 2x
      );
    }
  }
  .story-img.story-people .container h2{font-size:clamp(1.6rem,7vw,2.4rem);line-height:1.05}
  .story-img.story-people .container p{font-size:.98rem}
}
/* tablet */
@media (min-width:721px) and (max-width:1280px){
  .story-img.story-people{
    background-image:url("img/people-coffee-savor-1600.jpg");
  }
  @supports (background-image: image-set(url("x") 1x)){
    .story-img.story-people{
      background-image:image-set(
        url("img/people-coffee-savor-960.webp") 1x,
        url("img/people-coffee-savor-1600.webp") 2x
      );
    }
  }
}
/* ES path fix (la página /es/index.html resuelve URLs desde /es/) — usar absolute paths para ES */

/* ============ MOBILE FIX V2 — header / hero / marquee respiran en celular ============ */
@media (max-width:720px){
  /* Marquee: más compacto pero legible */
  .marquee{font-size:.78rem}
  .marquee-track{padding:9px 0}
  .marquee-track .mq-item{padding:0 18px;gap:8px}
  .marquee-track .mq-sep{width:24px}
  .marquee-track .mq-sep svg{width:12px;height:12px}
  .marquee::before,.marquee::after{width:32px}

  /* Header: padding adecuado, logo más chico, separación entre logo y cart */
  .site-header .container{padding:12px 16px;gap:10px}
  .logo img{height:46px !important}
  .foot-cols .brand img{height:60px}
  .site-actions{gap:10px}
  .site-nav{font-size:.66rem;gap:18px;padding-bottom:8px;margin-top:4px}

  /* Hero video: padding superior mayor para no chocar con sticky header */
  .hero-video{min-height:auto;padding:0}
  .hero-video .hero-content{padding:70px 20px 80px}
  .hero-eyebrow{font-size:.66rem;letter-spacing:.28em;padding:6px 14px;margin-bottom:22px}

  /* Hero title: tres líneas respiran, no colapsan */
  .hero-title{line-height:1.08}
  .hero-title .line-1{font-size:1.6rem !important;margin-bottom:10px !important;line-height:1.15 !important}
  .hero-title .line-2{font-size:2.5rem !important;line-height:.98 !important}
  .hero-title .line-3{font-size:1.4rem !important;margin-top:10px !important;line-height:1.2 !important}

  .hero-actions{margin-top:30px}
  .btn-big{padding:18px 36px;font-size:.78rem;letter-spacing:.16em}
  .hero-subtitle{font-size:.86rem;padding:0 8px;margin-top:20px}
  .hero-scroll{display:none}
}

/* Pantallas muy chicas (iPhone SE / Android compacto) */
@media (max-width:380px){
  .hero-title .line-1{font-size:1.4rem !important}
  .hero-title .line-2{font-size:2.1rem !important}
  .hero-title .line-3{font-size:1.25rem !important}
  .hero-eyebrow{font-size:.6rem;letter-spacing:.22em}
  .marquee{font-size:.72rem}
  .marquee-track .mq-item{padding:0 14px;gap:6px}
}

/* ============ TYPE SELECTOR (GRANO / MOLIDO) — coincide visualmente con size selector ============ */
.options .opts[data-role="type"]{display:flex;gap:10px;flex-wrap:wrap}
.options .opts[data-role="type"] .opt{
  padding:18px 22px 14px;min-width:140px;display:flex;flex-direction:column;align-items:center;gap:4px;
  position:relative;border:1.5px solid #d4c4ab;background:#fdf6e8;color:#502c1d;
  transition:.25s cubic-bezier(.16,.84,.44,1);text-align:center;cursor:pointer;
}
.options .opts[data-role="type"] .opt:hover{border-color:#502c1d;transform:translateY(-2px);box-shadow:0 10px 22px -10px rgba(80,44,29,.3)}
.options .opts[data-role="type"] .opt.sel{background:#502c1d;color:#fbead6;border-color:#502c1d}
.options .opts[data-role="type"] .opt .sz-name{font-family:var(--display);font-size:1rem;letter-spacing:.04em;font-weight:700;line-height:1}
.options .opts[data-role="type"] .opt .sz-sub{font-size:.68rem;letter-spacing:.05em;opacity:.78;margin-top:2px;font-weight:500;text-transform:none}
