:root{
  --honey:#D4860A;
  --honey-l:#F0A830;
  --honey-d:#9A6300;
  --gold:#E8B54A;
  --green:#5A7247;
  --green-d:#3F5232;
  --cream:#FBF4E4;
  --cream2:#F5EDD4;
  --dark:#231505;
  --dark2:#332006;
  --dark3:#150D02;
  --mu:rgba(35,21,5,0.55);
  --white:#FFFDF7;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--dark);overflow-x:hidden;}
img{display:block;max-width:100%;}
body.locked{overflow:hidden;}

/* ===== SCROLL ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.9s cubic-bezier(.16,1,.3,1),transform 0.9s cubic-bezier(.16,1,.3,1);}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-left{opacity:0;transform:translateX(-50px);transition:opacity 0.9s cubic-bezier(.16,1,.3,1),transform 0.9s cubic-bezier(.16,1,.3,1);}
.reveal-left.visible{opacity:1;transform:translateX(0);}
.reveal-right{opacity:0;transform:translateX(50px);transition:opacity 0.9s cubic-bezier(.16,1,.3,1),transform 0.9s cubic-bezier(.16,1,.3,1);}
.reveal-right.visible{opacity:1;transform:translateX(0);}
.reveal-scale{opacity:0;transform:scale(0.85);transition:opacity 0.8s cubic-bezier(.16,1,.3,1),transform 0.8s cubic-bezier(.16,1,.3,1);}
.reveal-scale.visible{opacity:1;transform:scale(1);}
.stagger-1{transition-delay:0.05s;}
.stagger-2{transition-delay:0.15s;}
.stagger-3{transition-delay:0.25s;}
.stagger-4{transition-delay:0.35s;}
.stagger-5{transition-delay:0.45s;}
.stagger-6{transition-delay:0.55s;}
.draw-line{stroke-dasharray:1000;stroke-dashoffset:1000;transition:stroke-dashoffset 1.8s ease-out;}
.draw-line.visible{stroke-dashoffset:0;}
@keyframes beeFloat{0%,100%{transform:translate(0,0) rotate(0deg);}25%{transform:translate(8px,-12px) rotate(5deg);}50%{transform:translate(-4px,-20px) rotate(-3deg);}75%{transform:translate(-10px,-8px) rotate(4deg);}}

/* ===== NAV ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:12px 48px;display:flex;align-items:center;justify-content:space-between;background:rgba(21,13,2,0.92);backdrop-filter:blur(10px);transition:transform 0.4s ease;border-bottom:1px solid rgba(212,134,10,0.12);}
nav.nav-hidden{transform:translateY(-100%);}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;}
.nav-logo img{width:52px;height:52px;object-fit:contain;}
.nav-logo-text{display:flex;flex-direction:column;}
.nav-logo-main{font-family:'Playfair Display',serif;font-size:19px;font-weight:700;color:var(--cream);letter-spacing:1px;line-height:1.1;}
.nav-logo-sub{font-size:8px;font-weight:500;letter-spacing:0.32em;text-transform:uppercase;color:var(--honey-l);margin-top:2px;}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center;}
.nav-links a{font-size:11px;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:rgba(251,244,228,0.65);text-decoration:none;transition:color 0.3s;}
.nav-links a:hover{color:var(--honey-l);}
.nav-cta{background:var(--honey);color:var(--dark);font-size:11px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;padding:11px 24px;border:none;cursor:pointer;text-decoration:none;transition:background 0.3s;border-radius:3px;}
.nav-cta:hover{background:var(--honey-l);}
.progress-bar{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--honey),var(--honey-l));z-index:101;width:0%;transition:width 0.1s;}

/* ===== HERO SADO STYLE ===== */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:100px 24px 60px;background:#1a1003;}
.hero-bg-photo{position:absolute;inset:0;background:url('../images/hero-bg.jpg') center center/cover no-repeat;filter:brightness(0.78) saturate(0.95);}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,6,0,0.45) 0%,rgba(15,9,1,0.35) 40%,rgba(10,6,0,0.72) 85%,rgba(10,6,0,0.92) 100%);}
.honey-glow{position:absolute;width:60vw;height:60vw;max-width:800px;max-height:800px;border-radius:50%;background:radial-gradient(circle,rgba(240,168,48,0.12) 0%,transparent 65%);top:50%;left:50%;transform:translate(-50%,-50%);animation:glowPulse 6s ease-in-out infinite;pointer-events:none;}
@keyframes glowPulse{0%,100%{opacity:0.7;transform:translate(-50%,-50%) scale(1);}50%{opacity:1;transform:translate(-50%,-50%) scale(1.08);}}

/* Honey drips */
.honey-drip{position:absolute;top:0;width:7px;border-radius:0 0 8px 8px;background:linear-gradient(to bottom,rgba(212,134,10,0.0),rgba(232,181,74,0.55) 30%,rgba(240,168,48,0.85));filter:drop-shadow(0 2px 6px rgba(240,168,48,0.35));animation:dripFall 9s ease-in infinite;pointer-events:none;}
.honey-drip::after{content:'';position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);width:14px;height:14px;border-radius:50%;background:rgba(240,168,48,0.85);}
.honey-drip.d1{left:12%;height:90px;animation-delay:0s;}
.honey-drip.d2{left:34%;height:140px;animation-delay:2.5s;}
.honey-drip.d3{left:62%;height:110px;animation-delay:5s;}
.honey-drip.d4{left:85%;height:80px;animation-delay:7s;}
@keyframes dripFall{0%{transform:translateY(-110%);opacity:0;}12%{opacity:1;}55%{transform:translateY(35vh);opacity:1;}75%{opacity:0;}100%{transform:translateY(45vh);opacity:0;}}

.hero-bee{position:absolute;font-size:26px;opacity:0.5;pointer-events:none;filter:drop-shadow(0 2px 6px rgba(0,0,0,0.4));}
.hero-bee.b1{top:22%;right:16%;animation:beeFloat 7s ease-in-out infinite;}
.hero-bee.b2{top:64%;right:26%;font-size:18px;animation:beeFloat 5s ease-in-out infinite reverse;animation-delay:1s;}
.hero-bee.b3{top:32%;left:12%;font-size:21px;animation:beeFloat 8s ease-in-out infinite;animation-delay:2s;}
.hero-bee.b4{top:72%;left:20%;font-size:16px;animation:beeFloat 6s ease-in-out infinite;animation-delay:3.5s;}

.hero-center{position:relative;z-index:2;text-align:center;max-width:1100px;width:100%;}
.hero-logo{width:130px;height:130px;object-fit:contain;margin:0 auto 28px;filter:drop-shadow(0 8px 30px rgba(240,168,48,0.35));animation:logoFloat 5s ease-in-out infinite;}
@keyframes logoFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}
.hero-topline{display:flex;align-items:center;justify-content:center;gap:18px;margin-bottom:18px;}
.hero-topline .line{flex:1;max-width:240px;height:1px;background:linear-gradient(90deg,transparent,rgba(251,244,228,0.55));position:relative;}
.hero-topline .line.right{background:linear-gradient(90deg,rgba(251,244,228,0.55),transparent);}
.hero-topline .line::before{content:'';position:absolute;top:50%;width:7px;height:7px;border-radius:50%;background:var(--honey-l);transform:translateY(-50%);}
.hero-topline .line.left::before{left:0;}
.hero-topline .line.right::before{right:0;}
.hero-topline span{font-size:12px;font-weight:600;letter-spacing:0.45em;text-transform:uppercase;color:var(--cream);white-space:nowrap;}
.hero-title{font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(56px,11.5vw,150px);line-height:0.95;color:var(--cream);letter-spacing:0.06em;text-shadow:0 6px 40px rgba(0,0,0,0.45);}
.hero-title .gold{color:var(--honey-l);}
.hero-sub{margin-top:22px;font-size:14px;color:rgba(251,244,228,0.6);font-weight:300;letter-spacing:0.06em;max-width:540px;margin-left:auto;margin-right:auto;line-height:1.9;}
.hero-btns{display:flex;gap:14px;justify-content:center;margin-top:34px;flex-wrap:wrap;}
.btn-primary{background:var(--honey);color:var(--dark);font-size:12px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;padding:15px 36px;text-decoration:none;transition:all 0.3s;display:inline-block;position:relative;overflow:hidden;border:none;cursor:pointer;border-radius:3px;}
.btn-primary::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:rgba(255,255,255,0.25);transition:left 0.4s;}
.btn-primary:hover::before{left:100%;}
.btn-primary:hover{background:var(--honey-l);transform:translateY(-2px);box-shadow:0 8px 24px rgba(212,134,10,0.35);}
.btn-ghost{color:rgba(251,244,228,0.7);font-size:12px;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;text-decoration:none;display:inline-flex;align-items:center;gap:8px;padding:15px 10px;transition:all 0.3s;}
.btn-ghost:hover{color:var(--honey-l);gap:14px;}
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2;}
.hero-scroll span{font-size:9px;letter-spacing:0.3em;text-transform:uppercase;color:rgba(251,244,228,0.3);}
.hero-scroll::after{content:'';width:1px;height:44px;background:linear-gradient(to bottom,rgba(240,168,48,0.6),transparent);animation:scrollAnim 2s ease-in-out infinite;}
@keyframes scrollAnim{0%,100%{opacity:0.3;}50%{opacity:1;}}

/* ===== SECTION COMMON ===== */
.sec-tag{font-size:10px;font-weight:700;letter-spacing:0.4em;text-transform:uppercase;color:var(--honey);display:block;margin-bottom:16px;}
.sec-title{font-family:'Playfair Display',serif;font-size:clamp(30px,4vw,48px);font-weight:900;line-height:1.15;margin-bottom:20px;}
.sec-title em{font-style:italic;color:var(--honey);}
.sec-text{font-size:14.5px;color:var(--mu);line-height:1.95;font-weight:300;margin-bottom:16px;}

/* ===== TIENDA ===== */
#productos{padding:100px 48px;background:var(--dark);position:relative;}
.productos-head{text-align:center;margin-bottom:56px;}
.productos-head .sec-title{color:var(--cream);}
.productos-head .sec-title em{color:var(--honey-l);}
.productos-head .sec-tag{color:var(--honey-l);}
.productos-head p{font-size:14px;color:rgba(251,244,228,0.4);font-weight:300;margin-top:10px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.7;}

.productos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:760px;margin:0 auto;}
.prod,.prod-card{background:linear-gradient(170deg,#2b1c08,#1c1204);border:1px solid rgba(212,134,10,0.18);border-radius:18px;position:relative;overflow:hidden;transition:all 0.4s;display:flex;flex-direction:column;}
.prod:hover,.prod-card:hover{transform:translateY(-8px);border-color:rgba(240,168,48,0.45);box-shadow:0 24px 50px rgba(0,0,0,0.45);}
.prod.hidden-prod,.prod-card.hidden-product{display:none;}
.prod-img-wrap{width:100%;aspect-ratio:4/5;overflow:hidden;background:linear-gradient(160deg,#f5e3c0,#e8cfa0);position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.prod-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.4s cubic-bezier(.2,.8,.3,1);}
.prod:hover .prod-img,.prod-card:hover .prod-img{transform:scale(1.06);}
.prod-img-wrap::after{content:'Ver producto';position:absolute;bottom:8px;left:50%;transform:translateX(-50%) translateY(8px);background:rgba(21,13,2,0.85);color:var(--honey-l);font-size:9px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;padding:6px 14px;border-radius:100px;opacity:0;transition:all 0.35s;pointer-events:none;}
.prod:hover .prod-img-wrap::after,.prod-card:hover .prod-img-wrap::after{opacity:1;transform:translateX(-50%) translateY(0);}
.prod-body{padding:13px 15px;display:flex;flex-direction:column;flex:1;}
.prod-name{font-family:'Playfair Display',serif;font-size:14.5px;font-weight:700;color:var(--cream);margin-bottom:3px;line-height:1.25;cursor:pointer;transition:color 0.3s;}
.prod-name:hover{color:var(--honey-l);}
.prod-desc{font-size:11px;color:rgba(251,244,228,0.45);line-height:1.5;font-weight:300;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.prod-badge{position:absolute;top:14px;right:14px;font-size:9px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;background:var(--honey);color:var(--dark);padding:5px 12px;z-index:4;border-radius:100px;box-shadow:0 4px 12px rgba(0,0,0,0.3);}
.prod-variants,.prod-variant-row{margin-top:auto;}
.variant-select,.prod-select{width:100%;background:rgba(255,255,255,0.05);border:1px solid rgba(212,134,10,0.3);color:var(--cream);padding:7px 9px;font-family:'DM Sans',sans-serif;font-size:11px;border-radius:6px;margin-bottom:8px;cursor:pointer;outline:none;}
.variant-select option,.prod-select option{background:var(--dark2);color:var(--cream);}
.prod-bottom,.prod-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.prod-price{font-family:'Playfair Display',serif;font-size:17px;font-weight:900;color:var(--honey-l);}
.add-cart-btn,.prod-btn{background:var(--honey);color:var(--dark);border:none;padding:7px 14px;font-size:10px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;cursor:pointer;border-radius:100px;transition:all 0.25s;display:flex;align-items:center;gap:6px;}
.add-cart-btn:hover,.prod-btn:hover{background:var(--honey-l);transform:translateY(-1px);box-shadow:0 6px 16px rgba(212,134,10,0.35);}
.add-cart-btn.added{background:var(--green);color:var(--white);}

.ver-mas-wrap{text-align:center;margin-top:44px;}
.ver-mas-btn{background:transparent;border:1.5px solid var(--honey);color:var(--honey-l);padding:14px 44px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;cursor:pointer;border-radius:100px;transition:all 0.3s;}
.ver-mas-btn:hover{background:var(--honey);color:var(--dark);}

/* ===== PRODUCT FULL PAGE ===== */
.pd-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start;background:var(--white);border-radius:18px;overflow:hidden;box-shadow:0 20px 60px rgba(35,21,5,0.1);max-width:980px;margin:0 auto;}
.pd-img-side{background:linear-gradient(160deg,#f8ecd2,#eed9ae);display:flex;align-items:center;justify-content:center;padding:28px;min-height:320px;}
.pd-img-side img{max-width:100%;max-height:320px;object-fit:contain;border-radius:10px;}
.pd-info-side{padding:32px 36px 32px 0;display:flex;flex-direction:column;}
.pd-brand{font-size:10px;font-weight:700;letter-spacing:0.35em;text-transform:uppercase;color:var(--honey);margin-bottom:10px;}
.pd-name{font-family:'Playfair Display',serif;font-size:24px;font-weight:900;color:var(--dark);line-height:1.2;margin-bottom:8px;}
.pd-desc{font-size:13px;color:var(--mu);line-height:1.7;font-weight:300;margin-bottom:14px;}
.pd-price{font-family:'Playfair Display',serif;font-size:30px;font-weight:900;color:var(--honey-d);margin-bottom:14px;}
.pd-label{font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--mu);margin-bottom:8px;display:block;}
.pd-variant{width:100%;border:1.5px solid rgba(212,134,10,0.35);border-radius:8px;padding:10px 14px;font-family:'DM Sans',sans-serif;font-size:13px;background:var(--cream);color:var(--dark);cursor:pointer;outline:none;margin-bottom:14px;}
.pd-qty-row{display:flex;align-items:center;gap:16px;margin-bottom:16px;}
.pd-qty{display:flex;align-items:center;border:1.5px solid rgba(212,134,10,0.35);border-radius:8px;overflow:hidden;}
.pd-qty button{width:42px;height:44px;background:var(--cream);border:none;font-size:18px;cursor:pointer;color:var(--honey-d);font-weight:700;transition:background 0.2s;}
.pd-qty button:hover{background:var(--cream2);}
.pd-qty span{width:52px;text-align:center;font-size:16px;font-weight:700;}
.pd-add{flex:1;background:var(--honey);color:var(--dark);border:none;padding:14px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer;border-radius:8px;transition:all 0.25s;}
.pd-add:hover{background:var(--honey-l);box-shadow:0 8px 20px rgba(212,134,10,0.3);}
.pd-note{font-size:11.5px;color:var(--mu);display:flex;align-items:center;gap:8px;}

/* Related products row */
.related-section{margin-top:32px;max-width:980px;margin-left:auto;margin-right:auto;}
.related-title{font-family:'Playfair Display',serif;font-size:19px;font-weight:900;margin-bottom:14px;}
.related-row-wrap{position:relative;}
.related-row{display:flex;gap:18px;overflow-x:auto;scroll-behavior:smooth;padding-bottom:8px;scrollbar-width:none;}
.related-row::-webkit-scrollbar{display:none;}
.related-card{flex:0 0 140px;background:linear-gradient(170deg,#2b1c08,#1c1204);border:1px solid rgba(212,134,10,0.18);border-radius:12px;overflow:hidden;cursor:pointer;transition:all 0.3s;}
.related-card:hover{transform:translateY(-4px);border-color:rgba(240,168,48,0.4);}
.related-card img{width:100%;height:100px;object-fit:contain;background:linear-gradient(160deg,#f8ecd2,#eed9ae);display:block;}
.related-card .rc-body{padding:9px;}
.related-card .rc-name{font-family:'Playfair Display',serif;font-size:11.5px;font-weight:700;color:var(--cream);line-height:1.3;margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.related-card .rc-price{font-size:12.5px;font-weight:900;color:var(--honey-l);font-family:'Playfair Display',serif;}
.related-btn{position:absolute;top:40px;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:var(--white);border:1px solid rgba(212,134,10,0.2);cursor:pointer;font-size:16px;color:var(--dark);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(35,21,5,0.12);z-index:2;transition:all 0.25s;}
.related-btn:hover{background:var(--honey);color:var(--white);}
.related-btn.prev{left:-22px;}
.related-btn.next{right:-22px;}

/* ===== GALERIA CARRUSEL ===== */
#galeria{padding:100px 48px;background:var(--cream);}
.galeria-head{text-align:center;margin-bottom:48px;}
.carousel{max-width:680px;margin:0 auto;position:relative;}
.carousel-frame{position:relative;border-radius:16px;overflow:hidden;box-shadow:0 24px 60px rgba(35,21,5,0.2);background:var(--dark3);min-height:380px;display:flex;align-items:center;justify-content:center;}
.carousel-slide{position:absolute;inset:0;opacity:0;transition:opacity 0.7s ease;display:flex;align-items:center;justify-content:center;background:var(--dark3);}
.carousel-slide.active{opacity:1;}
.carousel-slide img{max-width:100%;max-height:480px;width:auto;height:auto;object-fit:contain;}
.carousel-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(21,13,2,0.85),transparent);padding:36px 32px 24px;}
.carousel-caption h4{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--cream);}
.carousel-caption p{font-size:12px;color:rgba(251,244,228,0.6);margin-top:4px;font-weight:300;}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:rgba(251,244,228,0.92);border:none;cursor:pointer;font-size:18px;color:var(--dark);display:flex;align-items:center;justify-content:center;transition:all 0.3s;z-index:3;box-shadow:0 8px 24px rgba(0,0,0,0.25);}
.carousel-btn:hover{background:var(--honey);color:var(--white);transform:translateY(-50%) scale(1.08);}
.carousel-btn.prev{left:-26px;}
.carousel-btn.next{right:-26px;}
.carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:22px;}
.carousel-dot{width:8px;height:8px;border-radius:100px;background:rgba(212,134,10,0.25);border:none;cursor:pointer;transition:all 0.3s;padding:0;}
.carousel-dot.active{width:28px;background:var(--honey);}

/* ===== PROCESO ===== */
#proceso{padding:100px 48px;background:var(--cream2);position:relative;}
.proceso-head{text-align:center;margin-bottom:60px;}
.proceso-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:1100px;margin:0 auto;position:relative;}
.proceso-line-svg{position:absolute;top:80px;left:12.5%;right:12.5%;height:2px;width:75%;}
.step{padding:0 20px;text-align:center;position:relative;}
.step-circle{width:160px;height:160px;border-radius:50%;border:4px solid rgba(212,134,10,0.35);overflow:hidden;margin:0 auto 24px;position:relative;z-index:1;transition:all 0.4s;box-shadow:0 12px 32px rgba(35,21,5,0.2);}
.step-circle img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s;}
.step:hover .step-circle img{transform:scale(1.15);}
.step.visible .step-circle{border-color:var(--honey);}
.step-num{position:absolute;top:-6px;right:calc(50% - 90px);width:32px;height:32px;background:var(--honey);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--white);transform:scale(0);transition:transform 0.4s cubic-bezier(.34,1.56,.64,1) 0.3s;z-index:2;border:2px solid var(--cream2);}
.step.visible .step-num{transform:scale(1);}
.step-name{font-size:14px;font-weight:700;color:var(--dark);margin-bottom:8px;}
.step-desc{font-size:12px;color:var(--mu);line-height:1.6;font-weight:300;}

/* ===== HISTORIA ===== */
#historia{padding:100px 48px;background:var(--cream);position:relative;}
.historia-inner{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:1.1fr 0.9fr;gap:80px;align-items:start;}
.historia-quote{border-left:3px solid var(--honey);padding-left:20px;margin:28px 0;position:relative;}
.historia-quote::before{content:'"';position:absolute;top:-30px;left:8px;font-family:'Playfair Display',serif;font-size:80px;color:rgba(212,134,10,0.12);font-weight:900;}
.historia-quote p{font-family:'Playfair Display',serif;font-size:17px;font-style:italic;color:var(--dark2);line-height:1.65;position:relative;z-index:1;}
.timeline{margin-top:32px;position:relative;padding-left:32px;}
.timeline-line{position:absolute;left:5px;top:8px;bottom:8px;width:2px;background:rgba(212,134,10,0.15);}
.timeline-line-fill{position:absolute;left:5px;top:8px;width:2px;background:var(--honey);height:0;transition:height 1.6s cubic-bezier(.16,1,.3,1);}
.timeline-line-fill.visible{height:100%;}
.tl-item{position:relative;margin-bottom:32px;}
.tl-item:last-child{margin-bottom:0;}
.tl-dot{position:absolute;left:-32px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--honey);border:3px solid var(--cream);box-shadow:0 0 0 1px rgba(212,134,10,0.3);transform:scale(0);transition:transform 0.4s cubic-bezier(.34,1.56,.64,1) 0.3s;}
.tl-dot.visible{transform:scale(1);}
.tl-year{font-family:'Playfair Display',serif;font-weight:900;font-size:24px;color:var(--honey-d);line-height:1;margin-bottom:6px;}
.tl-text{font-size:13.5px;color:var(--mu);line-height:1.7;font-weight:300;}
.tl-text strong{color:var(--dark2);font-weight:700;}
.historia-right{position:sticky;top:100px;}
.photo-stack{position:relative;height:520px;}
.ph-card{position:absolute;border:6px solid var(--white);box-shadow:0 20px 50px rgba(35,21,5,0.25);overflow:hidden;border-radius:4px;}
.ph-card img{width:100%;height:100%;object-fit:cover;display:block;}
.ph-1{width:78%;height:340px;top:0;left:0;z-index:2;transform:rotate(-2deg);}
.ph-2{width:55%;height:220px;bottom:0;right:0;z-index:3;transform:rotate(3deg);}
.hex-decoration{position:absolute;width:100px;height:100px;opacity:0.15;z-index:1;}
.hex-decoration.top-right{top:-20px;right:10%;}
.hex-decoration.bottom-left{bottom:40px;left:-20px;}
.historia-badge{position:absolute;bottom:30px;left:-20px;background:var(--honey);color:var(--white);padding:16px 24px;z-index:4;box-shadow:0 12px 30px rgba(212,134,10,0.35);border-radius:6px;}
.hb-num{font-family:'Playfair Display',serif;font-size:34px;font-weight:900;line-height:1;}
.hb-label{font-size:10px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;opacity:0.85;margin-top:2px;}

/* ===== MISION VISION ===== */
#mision{padding:90px 48px;background:var(--green-d);position:relative;overflow:hidden;}
.mv-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:40px;position:relative;z-index:1;}
.mv-card{background:rgba(255,255,255,0.04);border:1px solid rgba(212,134,10,0.2);padding:36px;transition:all 0.4s;position:relative;overflow:hidden;border-radius:14px;}
.mv-card::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--honey);transition:width 0.6s ease;}
.mv-card.visible::before{width:100%;}
.mv-card:hover{background:rgba(255,255,255,0.07);transform:translateY(-4px);}
.mv-icon{font-size:32px;margin-bottom:16px;display:block;}
.mv-title{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;color:var(--cream);margin-bottom:14px;}
.mv-text{font-size:13.5px;color:rgba(251,244,228,0.6);line-height:1.85;font-weight:300;}

/* ===== FOOTER PRO ===== */
footer{background:var(--dark3);}
.foot-sub{display:flex;align-items:center;justify-content:space-between;gap:28px;padding:36px 48px;border-bottom:1px solid rgba(251,244,228,0.07);flex-wrap:wrap;max-width:1280px;margin:0 auto;}
.foot-sub-text h4{font-size:16px;font-weight:700;color:var(--cream);margin-bottom:5px;}
.foot-sub-text p{font-size:12px;color:rgba(251,244,228,0.4);font-weight:300;}
.foot-sub-form{display:flex;max-width:440px;width:100%;}
.foot-sub-form input{flex:1;background:rgba(255,255,255,0.06);border:1px solid rgba(251,244,228,0.12);border-right:none;color:var(--cream);padding:13px 16px;font-family:'DM Sans',sans-serif;font-size:13px;outline:none;border-radius:6px 0 0 6px;}
.foot-sub-form input::placeholder{color:rgba(251,244,228,0.3);}
.foot-sub-form button{background:var(--honey);color:var(--dark);border:none;padding:13px 24px;font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer;border-radius:0 6px 6px 0;transition:background 0.3s;}
.foot-sub-form button:hover{background:var(--honey-l);}
.foot-cols{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.2fr;gap:44px;padding:52px 48px;max-width:1280px;margin:0 auto;}
.foot-col h5{font-size:12px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--cream);margin-bottom:20px;}
.foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.foot-brand img{width:58px;height:58px;object-fit:contain;}
.foot-brand-name{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--cream);}
.foot-brand-name span{color:var(--honey-l);}
.foot-col p,.foot-col a{font-size:12.5px;color:rgba(251,244,228,0.45);font-weight:300;line-height:1.9;text-decoration:none;display:block;transition:color 0.3s;}
.foot-col a:hover{color:var(--honey-l);}
.foot-item{display:flex;gap:10px;align-items:flex-start;margin-bottom:12px;}
.foot-item span:first-child{font-size:14px;flex-shrink:0;margin-top:1px;}
.foot-social{display:flex;gap:10px;margin-top:18px;}
.foot-social a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(251,244,228,0.15);display:flex;align-items:center;justify-content:center;font-size:15px;transition:all 0.3s;}
.foot-social a:hover{background:var(--honey);border-color:var(--honey);}
.foot-pay{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;}
.foot-pay span{display:inline-flex;width:54px;height:36px;border-radius:6px;overflow:hidden;background:#fff;align-items:center;justify-content:center;}
.foot-pay span svg,.foot-pay span img{width:100%;height:100%;object-fit:contain;}
.foot-secure{display:flex;align-items:center;gap:10px;font-size:12.5px;color:rgba(251,244,228,0.55);}
.foot-secure span:first-child{font-size:18px;}
.foot-bottom{border-top:1px solid rgba(251,244,228,0.07);padding:22px 48px;text-align:center;font-size:11px;color:rgba(251,244,228,0.25);}

/* ===== CART DRAWER ===== */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:255;opacity:0;visibility:hidden;transition:opacity 0.35s;backdrop-filter:blur(2px);}
.cart-overlay.open{opacity:1;visibility:visible;}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:400px;max-width:94vw;background:#ffffff;z-index:256;transform:translateX(100%);transition:transform 0.4s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;}
.cart-drawer.open{transform:translateX(0);}
.cart-header{padding:20px 24px;background:#111111;display:flex;align-items:center;justify-content:space-between;}
.cart-title{font-family:'DM Sans',sans-serif;font-size:18px;font-weight:900;color:#ffffff;letter-spacing:0.02em;}
.cart-count-label{font-size:11px;color:rgba(255,255,255,0.45);margin-top:2px;display:block;font-weight:400;}
.cart-close{background:none;border:none;color:#ffffff;width:34px;height:34px;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:opacity 0.2s;}
.cart-close:hover{opacity:0.6;}
.cart-items{flex:1;overflow-y:auto;padding:8px 24px;}
.cart-empty{text-align:center;padding:60px 20px;color:rgba(0,0,0,0.45);}
.cart-empty span{font-size:48px;display:block;margin-bottom:16px;opacity:0.35;}
.cart-item{display:flex;gap:14px;padding:20px 0;border-bottom:1px solid rgba(0,0,0,0.08);}
.ci-img{width:58px;height:58px;border-radius:4px;object-fit:cover;flex-shrink:0;background:#f5f5f5;}
.ci-mid{flex:1;min-width:0;}
.ci-name{font-size:13px;font-weight:700;color:#111;line-height:1.35;text-transform:uppercase;letter-spacing:0.01em;}
.ci-variant{font-size:11px;color:rgba(0,0,0,0.5);margin-top:3px;}
.ci-price{font-size:14px;font-weight:700;color:#111;margin-top:10px;}
.ci-right{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;flex-shrink:0;}
.ci-remove{background:none;border:none;color:rgba(0,0,0,0.45);cursor:pointer;font-size:17px;padding:2px;transition:color 0.2s;line-height:1;}
.ci-remove:hover{color:#cc3333;}
.ci-qty{display:flex;align-items:center;gap:0;}
.qty-btn{width:28px;height:28px;border:none;background:#111111;color:#fff;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;font-weight:700;border-radius:3px;transition:background 0.2s;}
.qty-btn:hover{background:#333;}
.qty-num{font-size:14px;font-weight:700;min-width:42px;text-align:center;color:#111;}
.cart-footer{padding:20px 24px 22px;background:#f4f4f4;border-top:1px solid rgba(0,0,0,0.07);}
.cf-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:14.5px;color:#111;}
.cf-row .lbl{font-weight:500;}
.cf-row .val{font-weight:500;}
.cf-row.total{padding-top:8px;}
.cf-row.total .lbl,.cf-row.total .val{font-weight:900;font-size:15.5px;}
.cf-entrega-note{font-size:11px;color:rgba(0,0,0,0.45);}
.checkout-btns{display:flex;flex-direction:column;gap:10px;margin-top:16px;}
.checkout-btn{padding:16px;border:none;border-radius:2px;font-size:13px;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;transition:all 0.3s;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;font-family:'DM Sans',sans-serif;}
.checkout-pay{background:#111111;color:#ffffff;}
.checkout-pay:hover{background:#2a2a2a;}
.checkout-wa{background:#25D366;color:white;}
.checkout-wa:hover{background:#20bd5a;}

/* ===== FLOW PAGES (cart/checkout/payment/done) ===== */
.flow-page{position:fixed;inset:0;background:var(--cream);z-index:250;display:none;overflow-y:auto;}
.flow-page.open{display:block;}
.flow-head{position:sticky;top:0;background:rgba(251,244,228,0.96);backdrop-filter:blur(8px);z-index:5;padding:18px 48px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(212,134,10,0.15);}
.flow-back{background:none;border:none;font-size:13px;font-weight:600;color:var(--honey-d);cursor:pointer;display:flex;align-items:center;gap:8px;font-family:'DM Sans',sans-serif;}
.flow-back:hover{text-decoration:underline;}
.breadcrumb{display:flex;align-items:center;gap:14px;font-size:14px;font-weight:600;}
.breadcrumb .bc{color:rgba(35,21,5,0.3);}
.breadcrumb .bc.active{color:var(--honey-d);}
.breadcrumb .bc.done{color:var(--green);}
.breadcrumb .sep{color:rgba(35,21,5,0.25);font-size:12px;}
.flow-body{max-width:1180px;margin:0 auto;padding:32px 48px 60px;}

/* Cart page table */
.cartpage-grid{display:grid;grid-template-columns:1.8fr 1fr;gap:40px;align-items:start;}
.cart-table{width:100%;border-collapse:collapse;}
.cart-table th{font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--mu);text-align:left;padding:0 12px 14px;border-bottom:2px solid rgba(212,134,10,0.2);}
.cart-table td{padding:18px 12px;border-bottom:1px solid rgba(212,134,10,0.12);vertical-align:middle;font-size:14px;}
.ct-prod{display:flex;align-items:center;gap:14px;}
.ct-x{width:26px;height:26px;border-radius:50%;border:1px solid rgba(35,21,5,0.18);background:var(--white);color:rgba(35,21,5,0.5);cursor:pointer;font-size:12px;flex-shrink:0;transition:all 0.2s;}
.ct-x:hover{border-color:#cc3333;color:#cc3333;}
.ct-img{width:62px;height:62px;border-radius:8px;object-fit:cover;flex-shrink:0;}
.ct-name{font-weight:700;color:var(--dark);font-size:13.5px;}
.ct-var{font-size:11.5px;color:var(--mu);margin-top:2px;}
.ct-price{color:var(--mu);}
.ct-qty{display:inline-flex;align-items:center;border:1px solid rgba(212,134,10,0.3);border-radius:6px;overflow:hidden;}
.ct-qty button{width:32px;height:36px;background:var(--white);border:none;cursor:pointer;font-size:15px;color:var(--honey-d);font-weight:700;}
.ct-qty button:hover{background:var(--cream2);}
.ct-qty span{width:40px;text-align:center;font-weight:700;font-size:14px;}
.ct-sub{font-weight:900;color:var(--dark);font-family:'Playfair Display',serif;font-size:16px;}
.totals-box{background:var(--white);border:1px solid rgba(212,134,10,0.18);border-radius:14px;padding:28px;position:sticky;top:90px;}
.totals-box h3{font-size:13px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--dark);margin-bottom:20px;}
.tb-row{display:flex;justify-content:space-between;padding:10px 0;font-size:14px;border-bottom:1px solid rgba(212,134,10,0.1);}
.tb-row .lbl{font-weight:600;color:var(--dark);}
.tb-row .val{color:#111;font-weight:600;}
.tb-note{font-size:11.5px;color:var(--mu);padding:10px 0;border-bottom:1px solid rgba(212,134,10,0.1);font-weight:300;line-height:1.6;}
.tb-total{display:flex;justify-content:space-between;align-items:center;padding:14px 0 4px;font-size:14.5px;}
.tb-total .lbl{font-size:15.5px;font-weight:900;color:#111;}
.tb-total .val{font-family:'DM Sans',sans-serif;font-size:22px;font-weight:900;color:#111;}
.tb-cta{width:100%;margin-top:18px;background:var(--dark);color:var(--cream);border:none;padding:16px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;cursor:pointer;border-radius:8px;transition:all 0.3s;display:flex;align-items:center;justify-content:center;gap:8px;}
.tb-cta:hover{background:var(--honey);color:var(--dark);}
.cartpage-empty{text-align:center;padding:80px 20px;color:var(--mu);}
.cartpage-empty span{font-size:60px;display:block;margin-bottom:18px;opacity:0.35;}

/* Checkout */
.checkout-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:44px;align-items:start;}
.co-form h2{font-family:'Playfair Display',serif;font-size:26px;font-weight:900;margin-bottom:6px;}
.co-ship-note{font-size:12.5px;color:var(--mu);margin-bottom:26px;font-weight:300;}
.co-field{margin-bottom:16px;}
.co-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.co-field label{font-size:12px;font-weight:600;color:var(--dark);display:block;margin-bottom:6px;}
.co-field label .req{color:#cc3333;}
.co-field input,.co-field select,.co-field textarea{width:100%;border:1px solid rgba(35,21,5,0.18);border-radius:6px;padding:12px 14px;font-family:'DM Sans',sans-serif;font-size:13.5px;background:var(--white);color:var(--dark);outline:none;transition:border-color 0.3s;}
.co-field input:focus,.co-field select:focus,.co-field textarea:focus{border-color:var(--honey);}
.co-field input.error,.co-field select.error{border-color:#cc3333;background:#fff5f5;}
.field-error{display:none;color:#cc3333;font-size:11.5px;font-weight:600;margin-top:5px;}
.field-error.show{display:block;}
.order-box{background:var(--white);border:1px solid rgba(212,134,10,0.18);border-radius:14px;padding:28px;position:sticky;top:90px;}
.order-box h3{font-size:13px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:18px;}
.ob-head{font-size:11px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--mu);padding-bottom:10px;border-bottom:2px solid rgba(212,134,10,0.2);margin-bottom:8px;}
.ob-item{display:flex;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid rgba(0,0,0,0.08);font-size:13px;}
.ob-item .n{font-weight:700;color:#111;font-size:13px;text-transform:uppercase;letter-spacing:0.01em;}
.ob-item .v{font-size:11.5px;color:var(--mu);margin-top:2px;}
.ob-item .p{font-weight:700;color:#111;white-space:nowrap;font-family:'DM Sans',sans-serif;}
.ob-pay-note{margin:16px 0;padding:14px;background:var(--cream2);border-radius:8px;}
.ob-pay-logos{display:flex;gap:6px;margin-bottom:8px;}
.ob-pay-logos span{width:44px;height:30px;border-radius:5px;overflow:hidden;background:#fff;display:inline-flex;}
.ob-pay-note p{font-size:11.5px;color:var(--mu);line-height:1.6;}
.ob-privacy{font-size:11px;color:var(--mu);line-height:1.7;margin-bottom:16px;font-weight:300;}

/* Payment method page */
.pm-wrap{max-width:880px;margin:0 auto;}
.pm-wrap h2{font-family:'Playfair Display',serif;font-size:28px;font-weight:900;text-align:center;margin-bottom:8px;}
.pm-wrap .pm-sub{text-align:center;font-size:13px;color:var(--mu);margin-bottom:30px;}
.pm-total{text-align:center;margin-bottom:30px;}
.pm-total .lbl{font-size:11px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--mu);}
.pm-total .amt{font-family:'Playfair Display',serif;font-size:46px;font-weight:900;color:var(--honey-d);}

.pay-options-simple{max-width:420px;margin:0 auto 24px;display:flex;flex-direction:column;gap:12px;}
.pay-opt{border:2px solid rgba(212,134,10,0.18);border-radius:12px;padding:16px 18px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:all 0.25s;background:var(--white);}
.pay-opt:hover,.pay-opt.selected{border-color:var(--honey);background:rgba(212,134,10,0.05);}
.pay-opt.selected{box-shadow:0 6px 20px rgba(212,134,10,0.18);}
.pay-opt-icon{width:56px;height:38px;border-radius:7px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid rgba(0,0,0,0.06);}
.pay-opt-icon img{width:100%;height:100%;object-fit:cover;}
.pay-opt-name{font-size:14.5px;font-weight:700;color:var(--dark);}
.pay-opt-desc{font-size:11.5px;color:var(--mu);}
.pay-check{margin-left:auto;width:22px;height:22px;border-radius:50%;border:2px solid rgba(35,21,5,0.2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;color:transparent;transition:all 0.25s;}
.pay-opt.selected .pay-check{background:var(--honey);border-color:var(--honey);color:var(--white);}

.qr-display{text-align:center;padding:24px;background:var(--white);border:1px solid rgba(212,134,10,0.2);border-radius:14px;}
.qr-box{width:140px;height:140px;background:var(--cream);border:2px dashed var(--honey);border-radius:10px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:48px;}
.qr-amount{font-family:'Playfair Display',serif;font-size:28px;font-weight:900;color:var(--honey-d);}
.qr-note{font-size:11.5px;color:var(--mu);margin-top:8px;line-height:1.6;}
.pm-confirm{width:100%;background:var(--dark);color:var(--cream);border:none;padding:17px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;cursor:pointer;border-radius:8px;transition:all 0.3s;}
.pm-confirm:hover{background:var(--honey);color:var(--dark);}

/* Completed */
.done-wrap{max-width:520px;margin:40px auto;text-align:center;background:var(--white);border-radius:18px;padding:54px 40px;border:1px solid rgba(212,134,10,0.18);box-shadow:0 24px 60px rgba(35,21,5,0.12);}
.done-check{width:88px;height:88px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:42px;margin:0 auto 24px;animation:popIn 0.5s cubic-bezier(.34,1.56,.64,1);}
@keyframes popIn{from{transform:scale(0);}to{transform:scale(1);}}
.done-wrap h2{font-family:'Playfair Display',serif;font-size:28px;font-weight:900;margin-bottom:12px;}
.done-wrap p{font-size:13.5px;color:var(--mu);line-height:1.8;margin-bottom:26px;}
.done-wrap .btn-primary{width:100%;}

/* ===== FLOATING CART ===== */
.cart-fab{position:fixed;bottom:28px;right:28px;z-index:260;background:var(--honey);color:var(--dark);width:62px;height:62px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 10px 30px rgba(212,134,10,0.4);transition:all 0.3s cubic-bezier(.34,1.56,.64,1);transform:scale(0);}
.cart-fab.show{transform:scale(1);}
.cart-fab:hover{background:var(--honey-l);transform:scale(1.08);}
.cart-fab .fab-badge{position:absolute;top:-4px;right:-4px;background:var(--green-d);color:var(--white);font-size:12px;font-weight:900;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--cream);}
.cart-fab.bump{animation:fabBump 0.4s cubic-bezier(.34,1.56,.64,1);}
@keyframes fabBump{0%{transform:scale(1);}40%{transform:scale(1.25);}100%{transform:scale(1);}}
.cart-preview{position:fixed;bottom:100px;right:28px;z-index:259;background:var(--white);border-radius:12px;box-shadow:0 16px 40px rgba(35,21,5,0.18);padding:14px;width:280px;max-width:calc(100vw - 56px);opacity:0;visibility:hidden;transform:translateY(10px) scale(0.96);transition:all 0.3s cubic-bezier(.34,1.56,.64,1);}
.cart-preview.show{opacity:1;visibility:visible;transform:translateY(0) scale(1);}
.cp-item{display:flex;gap:10px;align-items:center;padding:6px 0;}
.cp-item img{width:36px;height:36px;border-radius:6px;object-fit:cover;flex-shrink:0;}
.cp-name{font-size:11.5px;font-weight:700;color:var(--dark);line-height:1.3;}
.cp-variant{font-size:10px;color:var(--mu);}
.cp-price{font-size:12px;font-weight:900;color:var(--honey-d);margin-left:auto;font-family:'Playfair Display',serif;}
.cp-more{font-size:10.5px;color:var(--mu);text-align:center;padding-top:6px;font-style:italic;}

/* Toast */
.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--dark);color:var(--cream);padding:14px 28px;border-radius:100px;font-size:13px;font-weight:600;z-index:400;display:flex;align-items:center;gap:10px;transition:transform 0.4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 12px 30px rgba(0,0,0,0.25);}
.toast.show{transform:translateX(-50%) translateY(0);}
.toast span:first-child{color:var(--honey-l);font-size:16px;}

/* ===== RESPONSIVE ===== */
@media(max-width:960px){
  nav{padding:10px 20px;}
  .nav-links{display:none;}
  .hero{padding:90px 18px 50px;}
  .hero-logo{width:96px;height:96px;}
  .hero-topline .line{max-width:60px;}
  .hero-topline span{font-size:9px;letter-spacing:0.3em;}
  #productos,#galeria,#proceso,#historia,#mision{padding:60px 20px;}
  .productos-grid{grid-template-columns:1fr;gap:24px;}
  .pd-grid{grid-template-columns:1fr;gap:0;}
  .pd-img-side{min-height:260px;padding:20px;border-radius:18px 18px 0 0;}
  .pd-info-side{padding:24px 22px;}
  .related-btn{display:none;}
  .related-card{flex:0 0 150px;}
  .carousel-btn.prev{left:8px;}
  .carousel-btn.next{right:8px;}
  .proceso-steps{grid-template-columns:1fr 1fr;gap:36px;}
  .proceso-line-svg{display:none;}
  .historia-inner{grid-template-columns:1fr;gap:40px;}
  .historia-right{position:static;}
  .photo-stack{height:380px;}
  .mv-inner{grid-template-columns:1fr;gap:24px;}
  .foot-sub{padding:28px 20px;flex-direction:column;align-items:flex-start;}
  .foot-cols{grid-template-columns:1fr;gap:34px;padding:40px 20px;}
  .foot-bottom{padding:18px 20px;}
  .flow-head{padding:14px 18px;flex-wrap:wrap;gap:8px;}
  .breadcrumb{font-size:12px;gap:8px;}
  .flow-body{padding:28px 18px 70px;}
  .cartpage-grid{grid-template-columns:1fr;gap:28px;}
  .totals-box,.order-box{position:static;}
  .checkout-grid{grid-template-columns:1fr;gap:30px;}
  .co-row{grid-template-columns:1fr;}
  .cart-table th:nth-child(2),.cart-table td:nth-child(2){display:none;}
  .cart-fab{bottom:20px;right:20px;width:56px;height:56px;font-size:22px;}
  .cart-preview{bottom:86px;right:16px;}
  .cart-drawer{width:100%;max-width:100%;}
}
@media(max-width:500px){
  .hero-title{letter-spacing:0.03em;}
}

/* ===== AI ASSISTANT CHAT ===== */
.chat-fab{position:fixed;bottom:28px;right:100px;z-index:260;background:var(--dark);color:var(--cream);width:58px;height:58px;border-radius:50%;border:2px solid var(--honey);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 10px 28px rgba(0,0,0,0.3);transition:all 0.3s cubic-bezier(.34,1.56,.64,1);}
.chat-fab:hover{background:var(--honey);color:var(--dark);transform:scale(1.08);}
.chat-window{position:fixed;bottom:96px;right:28px;z-index:261;width:360px;max-width:calc(100vw - 32px);height:480px;max-height:70vh;background:var(--white);border-radius:16px;box-shadow:0 24px 60px rgba(35,21,5,0.3);display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transform:translateY(20px) scale(0.96);transition:all 0.3s cubic-bezier(.34,1.56,.64,1);}
.chat-window.open{opacity:1;visibility:visible;transform:translateY(0) scale(1);}
.chat-header{background:var(--dark);padding:14px 16px;display:flex;align-items:center;justify-content:space-between;}
.chat-header-info{display:flex;align-items:center;gap:10px;}
.chat-header-info img{width:36px;height:36px;object-fit:contain;}
.chat-title{font-size:13.5px;font-weight:700;color:var(--cream);}
.chat-status{font-size:10.5px;color:rgba(251,244,228,0.5);display:flex;align-items:center;gap:5px;}
.chat-status .dot{width:7px;height:7px;border-radius:50%;background:#4ADE80;display:inline-block;}
.chat-close{background:none;border:none;color:var(--cream);font-size:16px;cursor:pointer;width:28px;height:28px;}
.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:var(--cream2);}
.chat-msg{max-width:80%;padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.6;}
.chat-msg.bot{background:var(--white);color:var(--dark);align-self:flex-start;border-bottom-left-radius:4px;box-shadow:0 2px 8px rgba(35,21,5,0.06);}
.chat-action-btn{align-self:flex-start;background:var(--honey);color:var(--white);border:none;padding:9px 16px;border-radius:100px;font-size:12px;font-weight:700;cursor:pointer;transition:background 0.2s;}
.chat-action-btn:hover{background:var(--honey-l);}
.chat-msg.user{background:var(--honey);color:var(--dark);align-self:flex-end;border-bottom-right-radius:4px;font-weight:600;}
.chat-quick{display:flex;gap:8px;padding:0 16px 12px;flex-wrap:wrap;background:var(--cream2);}
.chat-quick button{background:var(--white);border:1px solid rgba(212,134,10,0.25);color:var(--honey-d);font-size:11.5px;font-weight:600;padding:7px 14px;border-radius:100px;cursor:pointer;transition:all 0.2s;}
.chat-quick button:hover{background:var(--honey);color:var(--white);border-color:var(--honey);}
.chat-input-row{display:flex;border-top:1px solid rgba(212,134,10,0.15);background:var(--white);padding:10px;gap:8px;}
.chat-input-row input{flex:1;border:1px solid rgba(212,134,10,0.2);border-radius:100px;padding:10px 16px;font-family:'DM Sans',sans-serif;font-size:13px;outline:none;}
.chat-input-row input:focus{border-color:var(--honey);}
.chat-input-row button{background:var(--honey);color:var(--dark);border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:15px;flex-shrink:0;transition:background 0.2s;}
.chat-input-row button:hover{background:var(--honey-l);}

@media(max-width:600px){
  .chat-fab{right:84px;bottom:20px;width:52px;height:52px;font-size:21px;}
  .chat-window{right:8px;bottom:80px;width:calc(100vw - 16px);height:65vh;}
}

/* ===== SHIPPING OPTIONS ===== */
.shipping-opts-label{font-size:13px;font-weight:700;color:#1a1003;margin:14px 0 8px;letter-spacing:0.03em;}
.shipping-opts{display:flex;gap:10px;margin-bottom:4px;}
.ship-opt{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:14px 10px;border:2px solid rgba(212,134,10,0.4);border-radius:12px;cursor:pointer;transition:all 0.2s;background:#fff;text-align:center;}
.ship-opt:hover{border-color:var(--honey);background:#fdf6e8;transform:translateY(-1px);}
.ship-opt.selected{border-color:var(--honey);background:#fdf0d0;box-shadow:0 0 0 1px var(--honey);}
.ship-name{font-size:14px;font-weight:800;color:#1a1003;letter-spacing:0.02em;}
.ship-price{font-size:18px;font-weight:900;color:#b36a00;}
.ship-tag{font-size:10px;color:#7a5a20;font-weight:500;}
.free-shipping-badge{background:linear-gradient(135deg,#2d6a2d,#3d8a3d);color:#fff;padding:12px 16px;border-radius:10px;text-align:center;font-weight:700;font-size:14px;margin:12px 0;}

/* ===== QR REAL ===== */
.qr-real-img{width:200px;height:200px;object-fit:cover;border-radius:16px;border:4px solid #fff;box-shadow:0 8px 30px rgba(0,0,0,0.25);margin:0 auto 12px;display:block;}
.qr-owner{font-size:13px;font-weight:700;color:var(--cream);text-align:center;margin-bottom:6px;}

/* ===== VOUCHER UPLOAD ===== */
.voucher-section{margin:20px 0 10px;}
.voucher-label{display:block;font-size:14px;font-weight:700;color:var(--cream);margin-bottom:10px;}
.voucher-drop{border:2px dashed rgba(212,134,10,0.5);border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all 0.2s;background:rgba(212,134,10,0.05);}
.voucher-drop:hover{border-color:var(--honey);background:rgba(212,134,10,0.1);}
.voucher-drop span{color:rgba(251,244,228,0.7);font-size:13px;}
.voucher-icon{font-size:28px;display:block;margin-bottom:8px;}
#voucherPreview img{max-width:100%;max-height:160px;border-radius:8px;margin-top:8px;object-fit:contain;}

/* ===== FOOTER MINI MAP ===== */
.foot-mini-map{position:relative;margin-top:10px;border-radius:10px;overflow:hidden;cursor:pointer;}
.foot-mini-map iframe{display:block;pointer-events:none;}
.foot-map-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(10,6,0,0.35);color:#fff;font-size:13px;font-weight:700;letter-spacing:0.03em;opacity:0;transition:opacity 0.2s;}
.foot-map-link:hover .foot-map-overlay{opacity:1;}
.foot-map-link{text-decoration:none;}

/* ===== PAYMENT REDESIGN ===== */
.pay-methods-row{display:flex;gap:14px;margin:20px 0;}
.pay-method-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 12px;border:2.5px solid rgba(255,255,255,0.12);border-radius:16px;cursor:pointer;transition:all 0.25s;background:rgba(255,255,255,0.04);position:relative;}
.pay-method-card:hover{border-color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.08);transform:translateY(-2px);}
.pay-method-card.selected{border-color:var(--honey);background:rgba(212,134,10,0.12);box-shadow:0 0 0 1px var(--honey);}
.pay-method-logo{width:60px;height:60px;object-fit:contain;border-radius:14px;}
.pay-method-name{font-size:15px;font-weight:800;color:var(--cream);letter-spacing:0.02em;}
.pay-method-check{position:absolute;top:10px;right:10px;width:22px;height:22px;border-radius:50%;background:var(--honey);color:var(--dark);font-size:12px;font-weight:900;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 0.2s;}
.pay-method-card.selected .pay-method-check{opacity:1;}
.qr-scan-title{font-size:13px;font-weight:600;color:rgba(251,244,228,0.6);margin-bottom:10px;text-align:center;}
.qr-scan-title span{color:var(--honey-l);font-weight:800;}

/* ===== VOUCHER REDESIGN ===== */
.voucher-section{margin:16px 0 10px;background:rgba(255,255,255,0.04);border:2px dashed rgba(212,134,10,0.4);border-radius:14px;overflow:hidden;}
.voucher-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(212,134,10,0.15);}
.voucher-icon-title{font-size:24px;}
.voucher-title{font-size:14px;font-weight:700;color:var(--cream);}
.voucher-subtitle{font-size:11px;color:rgba(251,244,228,0.45);margin-top:2px;}
.voucher-drop{padding:20px;text-align:center;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;transition:background 0.2s;}
.voucher-drop:hover{background:rgba(212,134,10,0.08);}
.voucher-drop span:last-child{font-size:13px;color:rgba(251,244,228,0.55);}
#voucherPreview img{max-width:100%;max-height:160px;border-radius:8px;object-fit:contain;}

/* ===== FREE SHIPPING BANNER IN CART ===== */
.cart-free-ship{margin-bottom:10px;}
.cart-free-ship:empty{display:none;}
.free-ship-bar{background:linear-gradient(135deg,#1a4d1a,#2d7a2d);border-radius:8px;padding:10px 12px;font-size:12px;font-weight:700;color:#fff;text-align:center;}
.free-ship-progress{margin-top:6px;background:rgba(255,255,255,0.2);border-radius:100px;height:5px;overflow:hidden;}
.free-ship-fill{height:100%;background:#5dcc5d;border-radius:100px;transition:width 0.4s;}

/* ===== FREE SHIPPING TIENDA BANNER ===== */
.free-shipping-tienda{background:linear-gradient(135deg,rgba(45,122,45,0.15),rgba(45,122,45,0.08));border:1px solid rgba(93,204,93,0.3);border-radius:10px;padding:10px 16px;text-align:center;font-size:13px;font-weight:700;color:#7ddd7d;margin-bottom:20px;}

/* ===== PAYMENT UNIFIED YAPE/PLIN ===== */
.pm-pay-block{background:var(--white);border-radius:18px;padding:28px 20px;text-align:center;margin:18px 0;box-shadow:0 4px 24px rgba(35,21,5,0.08);}
.pm-pay-title{font-size:12px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:rgba(80,55,20,0.5);margin-bottom:16px;}
.pm-logos-row{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:6px;}
.pm-app-logo{width:64px;height:64px;object-fit:contain;border-radius:16px;box-shadow:0 4px 14px rgba(0,0,0,0.12);}
.pm-logos-divider{font-size:14px;font-weight:700;color:rgba(80,55,20,0.35);}
.pm-logos-names{font-size:13px;font-weight:700;color:rgba(80,55,20,0.6);margin-bottom:18px;letter-spacing:0.05em;}
.pm-qr-img{width:190px;height:190px;object-fit:cover;border-radius:16px;border:4px solid #f0e8d8;box-shadow:0 8px 28px rgba(0,0,0,0.12);display:block;margin:0 auto 12px;}
.pm-qr-amount{font-family:'Playfair Display',serif;font-size:32px;font-weight:900;color:#3a2200;margin-bottom:4px;}
.pm-qr-name{font-size:13px;font-weight:700;color:rgba(58,34,0,0.65);margin-bottom:8px;}
.pm-qr-note{font-size:12px;color:rgba(58,34,0,0.45);line-height:1.5;max-width:280px;margin:0 auto;}

/* ===== STORE TABS ===== */
.store-tabs{display:flex;gap:10px;justify-content:center;margin-top:24px;flex-wrap:wrap;}
.store-tab{padding:12px 28px;border:2px solid rgba(212,134,10,0.35);border-radius:100px;background:transparent;color:rgba(251,244,228,0.6);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all 0.25s;letter-spacing:0.03em;}
.store-tab:hover{border-color:var(--honey);color:var(--cream);background:rgba(212,134,10,0.1);}
.store-tab.active{background:var(--honey);border-color:var(--honey);color:var(--dark);box-shadow:0 4px 18px rgba(212,134,10,0.35);}

/* ===== PROCESO QUOTE ===== */
.proceso-quote{font-size:14px;font-style:italic;color:rgba(251,244,228,0.55);max-width:560px;margin:0 auto 32px;text-align:center;line-height:1.6;padding:0 16px;}

/* ===== LIGHTBOX ===== */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s;}
.lightbox.open{opacity:1;pointer-events:all;}
.lightbox-img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,0.5);}
.lightbox-close{position:absolute;top:20px;right:24px;background:rgba(255,255,255,0.15);border:none;color:#fff;font-size:22px;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 0.2s;}
.lightbox-close:hover{background:rgba(255,255,255,0.3);}

/* ===== RELATED CARDS UNIFORM ===== */
.rc-card{min-width:150px;max-width:150px;cursor:pointer;transition:transform 0.2s;flex-shrink:0;}
.rc-card:hover{transform:translateY(-4px);}
.rc-img-wrap{width:150px;height:170px;overflow:hidden;border-radius:10px;background:#f5e8d0;margin-bottom:6px;}
.rc-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s;}
.rc-card:hover .rc-img-wrap img{transform:scale(1.05);}
.rc-name{font-size:12px;font-weight:600;color:var(--dark);line-height:1.3;margin-bottom:3px;}
.rc-price{font-size:13px;font-weight:800;color:#b36a00;}

/* ===== VER TODOS BUTTON ===== */
.related-ver-todos{display:block;margin:14px auto 0;background:transparent;border:2px solid rgba(212,134,10,0.4);color:#b36a00;font-size:13px;font-weight:700;padding:9px 22px;border-radius:100px;cursor:pointer;transition:all 0.2s;letter-spacing:0.03em;}
.related-ver-todos:hover{background:var(--honey);border-color:var(--honey);color:var(--dark);}

/* ===== PRODUCT VARIANT THUMBNAILS ===== */
.pd-thumbnails{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap;justify-content:center;}
.pd-thumb{width:62px;height:72px;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all 0.2s;opacity:0.65;flex-shrink:0;}
.pd-thumb:hover{opacity:1;border-color:var(--honey);transform:translateY(-2px);}
.pd-thumb.active{opacity:1;border-color:var(--honey);box-shadow:0 4px 12px rgba(212,134,10,0.35);}
.pd-thumb img{width:100%;height:100%;object-fit:cover;}

/* ===== HAMBURGER MENU ===== */
.nav-right{display:flex;align-items:center;gap:12px;}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;z-index:301;}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--cream);border-radius:2px;transition:all 0.3s;}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.nav-mobile-menu{display:none;position:fixed;top:62px;left:0;right:0;background:var(--dark);z-index:299;flex-direction:column;padding:12px 0 20px;box-shadow:0 8px 32px rgba(0,0,0,0.4);border-bottom:2px solid rgba(212,134,10,0.2);}
.nav-mobile-menu.open{display:flex;}
.nav-mobile-menu a{padding:14px 28px;font-size:15px;font-weight:600;color:var(--cream);text-decoration:none;letter-spacing:0.05em;border-bottom:1px solid rgba(255,255,255,0.05);transition:background 0.2s;}
.nav-mobile-menu a:hover{background:rgba(212,134,10,0.1);color:var(--honey-l);}
.nav-mobile-cta{background:var(--honey)!important;color:var(--dark)!important;margin:12px 20px 0;border-radius:10px;text-align:center;font-weight:700!important;border-bottom:none!important;}

@media(max-width:960px){
  .nav-hamburger{display:flex;}
  .nav-links{display:none!important;}
  .nav-cta{display:none;}
  .proceso-steps{grid-template-columns:1fr;gap:28px;}
  .step-circle{width:140px;height:140px;}
}

/* ===== MOBILE FIXES ===== */
@media(max-width:960px){
  /* Historia foto stack */
  .photo-stack{height:auto;min-height:320px;}
  .ph-card{position:relative!important;top:auto!important;right:auto!important;bottom:auto!important;left:auto!important;transform:none!important;width:100%!important;max-width:320px;margin:0 auto 16px;}
  .ph-1,.ph-2{position:relative!important;transform:none!important;top:auto!important;right:auto!important;}
  .historia-badge{position:relative;margin:12px auto 0;display:block;text-align:center;}
  .hex-decoration{display:none;}

  /* Proceso steps texto completo */
  .step-name{font-size:15px;}
  .step-desc{font-size:12px;}

  /* Nav CTA visible en móvil solo en menú */
  nav{overflow:visible;}
}

@media(max-width:480px){
  .historia-right{overflow:visible;}
  .photo-stack{display:flex;flex-direction:column;align-items:center;height:auto;}
}
