/* ============================================================
   ALL TERRAIN PRO — Sales Funnel Design
   Paleta: Negro + Amarillo CAT + Blanco
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@400;500;600;700;800;900&display=swap');

/* ── Variables ── */
:root {
  --yellow: #6366F1;
  --yellow-dark: #4F46E5;
  --yellow-glow: rgba(99, 102, 241, 0.35);
  --black: #0A0A0A;
  --dark: #111111;
  --dark-2: #1A1A1A;
  --dark-3: #222222;
  --border: rgba(245,192,17,0.15);
  --border-white: rgba(255,255,255,0.08);
  --text: #FFFFFF;
  --text-muted: #999999;
  --red: #FF3B30;
  --green: #22C55E;
  --radius: 12px;
  --shadow-y: 0 0 40px var(--yellow-glow);
  --t: 0.25s cubic-bezier(0.4,0,0.2,1);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',sans-serif;
  background:var(--black);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;outline:none;}

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

/* ── Countdown ── */
.countdown-bar{
  background:var(--yellow);
  color:var(--black);
  padding:0.65rem 1.5rem;
  text-align:center;
  font-size:0.85rem;
  font-weight:800;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0.5rem;
  flex-wrap:wrap;
  letter-spacing:0.03em;
  position:relative;z-index:99;
}
#countdown-timer{display:inline-flex;gap:0.3rem;font-weight:900;}
.c-seg{
  background:var(--black);
  color:var(--yellow);
  padding:0.1rem 0.45rem;
  border-radius:4px;
  font-size:0.95rem;
  min-width:30px;
  text-align:center;
}

/* ── Navbar ── */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 2rem;
  background:rgba(10,10,10,0.9);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:var(--t);
}
.navbar.scrolled{background:rgba(10,10,10,0.98);}
.nav-logo{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.6rem;
  letter-spacing:0.05em;
  color:var(--yellow);
}
.nav-cta{
  background:var(--yellow);
  color:var(--black);
  padding:0.55rem 1.4rem;
  border-radius:6px;
  font-size:0.88rem;
  font-weight:800;
  letter-spacing:0.04em;
  text-transform:uppercase;
  transition:var(--t);
}
.nav-cta:hover{background:var(--yellow-dark);transform:scale(1.04);}

/* ── Hero ── */
.hero{
  min-height:100vh;
  display:flex;
  align-items:center;
  padding:8rem 2rem 5rem;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 70% 50%, rgba(245,192,17,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 50% 80% at 0% 100%, rgba(245,192,17,0.05) 0%, transparent 50%);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:center;
  max-width:1200px;
  margin:0 auto;
  width:100%;
  position:relative;z-index:1;
}

/* Badge */
.hero-badge{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:rgba(245,192,17,0.12);
  border:1px solid rgba(245,192,17,0.4);
  color:var(--yellow);
  padding:0.35rem 0.9rem;
  border-radius:4px;
  font-size:0.78rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.1em;
  margin-bottom:1.25rem;
}

/* Hero title — 3-line hierarchy */
.hero-title{
  display:flex;
  flex-direction:column;
  line-height:0.95;
  margin-bottom:1.25rem;
  gap:0.15rem;
}
.title-line-1{
  font-family:'Inter',sans-serif;
  font-size:clamp(1rem,2vw,1.3rem);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:0.18em;
  color:rgba(255,255,255,0.55);
}
.title-line-2{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(5rem,10vw,9rem);
  line-height:1;
  letter-spacing:-0.01em;
  color:var(--yellow);
  text-shadow:0 0 60px var(--yellow-glow);
}
.title-line-3{
  font-family:'Inter',sans-serif;
  font-size:clamp(1.4rem,2.5vw,2rem);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:#fff;
}
.title-line-3 em{
  font-style:normal;
  color:var(--yellow);
  background:rgba(245,192,17,0.12);
  border:1px solid rgba(245,192,17,0.4);
  padding:0.1em 0.4em;
  border-radius:4px;
  font-size:0.9em;
}

/* Feature tags */
.feature-tags{
  display:flex;flex-wrap:wrap;gap:0.5rem;
  margin-bottom:1rem;
}
.ftag{
  font-size:0.78rem;font-weight:700;
  color:var(--text-muted);
  border:1px solid rgba(255,255,255,0.1);
  padding:0.3rem 0.75rem;
  border-radius:4px;
  text-transform:uppercase;
  letter-spacing:0.04em;
}
/* Hero description */
.hero-desc{
  font-size:0.9rem;
  color:var(--text-muted);
  max-width:460px;
  margin-bottom:1.5rem;
  line-height:1.75;
  display:-webkit-box;
  -webkit-line-clamp:3;
  line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
/* Hero badge (override — keep once) */

.hero-badge{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:rgba(245,192,17,0.08);
  border:1px solid rgba(245,192,17,0.3);
  color:var(--yellow);
  padding:0.4rem 0.9rem;
  border-radius:4px;
  font-size:0.75rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.1em;
  margin-bottom:1.25rem;
}
.dot-live{
  width:8px;height:8px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 8px var(--green);
  animation:pulse-live 1.5s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes pulse-live{
  0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,0.6);}
  50%{box-shadow:0 0 0 6px rgba(34,197,94,0);}
}

/* Price */
.hero-price-row{
  display:flex;align-items:baseline;gap:0.85rem;
  margin-bottom:1.25rem;flex-wrap:wrap;
}
.price-current{
  font-family:'Bebas Neue',sans-serif;
  font-size:3.2rem;
  color:var(--yellow);
  line-height:1;
}
.price-original{font-size:1.1rem;color:var(--text-muted);text-decoration:line-through;}
.price-badge{
  background:var(--red);
  color:#fff;
  font-size:0.78rem;font-weight:800;
  padding:0.2rem 0.55rem;
  border-radius:4px;
  align-self:center;
  text-transform:uppercase;
  letter-spacing:0.05em;
}

/* Buy button */
.btn-buy{
  display:flex;align-items:center;justify-content:center;gap:0.75rem;
  background:var(--yellow);
  color:var(--black);
  font-size:1rem;font-weight:900;
  padding:1.1rem 2.2rem;
  border-radius:8px;
  text-transform:uppercase;
  letter-spacing:0.06em;
  transition:var(--t);
  box-shadow:0 8px 28px var(--yellow-glow);
  position:relative;overflow:hidden;
}
.btn-buy::before{
  content:'';
  position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);
  transition:0.5s;
}
.btn-buy:hover{background:var(--yellow-dark);transform:translateY(-3px);box-shadow:0 16px 40px var(--yellow-glow);}
.btn-buy:hover::before{left:100%;}
.btn-buy:active{transform:translateY(-1px);}
.btn-buy.loading{pointer-events:none;opacity:0.8;}

.btn-secondary{
  display:flex;align-items:center;justify-content:center;gap:0.5rem;
  background:transparent;
  border:1px solid rgba(255,255,255,0.15);
  color:var(--text-muted);
  font-size:0.88rem;font-weight:600;
  padding:0.9rem 1.8rem;
  border-radius:8px;
  text-transform:uppercase;
  letter-spacing:0.05em;
  transition:var(--t);
}
.btn-secondary:hover{border-color:var(--yellow);color:var(--yellow);}

.hero-actions{display:flex;flex-direction:column;gap:0.85rem;}

/* Trust */
.trust-row{
  display:flex;align-items:center;gap:1.25rem;
  flex-wrap:wrap;margin-top:0.75rem;
}
.trust-item{
  display:flex;align-items:center;gap:0.4rem;
  font-size:0.8rem;color:var(--text-muted);
}
.trust-item svg{color:var(--green);flex-shrink:0;}

/* ── Product Visual ── */
.hero-visual{display:flex;justify-content:center;align-items:center;}
.product-img-wrap{
  position:relative;width:100%;max-width:480px;margin:0 auto;
}
.product-img-wrap::before{
  content:'';
  position:absolute;inset:-1px;
  border-radius:20px;
  background:linear-gradient(135deg,var(--yellow),rgba(245,192,17,0.2));
  opacity:0.4;filter:blur(24px);z-index:-1;
}
/* ── Product Gallery Carousel ── */
.gallery-carousel{
  position:relative;
  border-radius:20px;
  overflow:hidden;
  background:var(--dark-2);
  border:1px solid rgba(245,192,17,0.2);
  aspect-ratio:1;
}
.gallery-main{
  width:100%;height:100%;
  position:relative;overflow:hidden;
}
.gallery-slide{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  opacity:0;
  transition:opacity 0.5s ease, transform 0.5s ease;
  transform:scale(1.03);
}
.gallery-slide.active{
  opacity:1;transform:scale(1);
  position:relative;
  /* keep height stable */
  min-height:100%;
}
.gallery-slide img{
  width:100%;height:100%;
  object-fit:cover;
  border-radius:0;
  display:block;
}
.product-img-placeholder{
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;opacity:0.15;
  width:100%;height:100%;min-height:320px;
}

/* Arrows */
.gallery-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:10;
  background:rgba(10,10,10,0.7);
  border:1px solid rgba(255,255,255,0.12);
  color:var(--text);
  width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:var(--t);
  backdrop-filter:blur(6px);
}
.gallery-arrow:hover{
  background:var(--yellow);color:var(--black);
  border-color:var(--yellow);
}
.gallery-prev{left:10px;}
.gallery-next{right:10px;}

/* Dot indicators */
.gallery-dots{
  position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
  display:flex;gap:6px;z-index:10;
}
.gallery-dot{
  width:7px;height:7px;border-radius:50%;
  background:rgba(255,255,255,0.3);
  cursor:pointer;
  transition:background 0.3s,transform 0.3s;
}
.gallery-dot.active{
  background:var(--yellow);
  transform:scale(1.3);
}

/* Thumbnail strip */
.gallery-thumbs{
  display:flex;gap:8px;
  margin-top:10px;
  overflow-x:auto;
  padding-bottom:4px;
  scrollbar-width:none;
}
.gallery-thumbs::-webkit-scrollbar{display:none;}
.gallery-thumb{
  flex-shrink:0;
  width:60px;height:60px;
  border-radius:8px;
  overflow:hidden;
  border:2px solid transparent;
  cursor:pointer;
  opacity:0.55;
  transition:var(--t);
}
.gallery-thumb img{
  width:100%;height:100%;object-fit:cover;
}
.gallery-thumb.active{
  border-color:var(--yellow);
  opacity:1;
}
.gallery-thumb:hover{opacity:0.85;}



/* Float badges */
.float-badge{
  position:absolute;
  background:var(--dark-3);
  border:1px solid rgba(245,192,17,0.3);
  border-radius:8px;
  padding:0.55rem 0.9rem;
  font-size:0.8rem;font-weight:700;
  display:flex;align-items:center;gap:0.4rem;
  backdrop-filter:blur(10px);
  box-shadow:0 4px 20px rgba(0,0,0,0.5);
  animation:float 4s ease-in-out infinite;
  z-index:2;
}
.float-badge:nth-child(2){animation-delay:-2s;}
.float-badge-tl{top:-0.75rem;left:-1rem;}
.float-badge-br{bottom:-0.75rem;right:-1rem;}
.float-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

/* ── Variant groups ── */
.variant-groups{display:flex;flex-direction:column;gap:1.25rem;margin:1rem 0;}
.vgroup{display:flex;flex-direction:column;gap:0.6rem;}
.vgroup-header{
  display:flex;align-items:center;gap:0.6rem;flex-wrap:wrap;
}
.vgroup-label{
  font-size:0.72rem;font-weight:800;
  text-transform:uppercase;letter-spacing:0.14em;
  color:var(--text-muted);
}
.vgroup-selected{
  font-size:0.78rem;font-weight:700;
  color:var(--yellow);
}
.size-guide-link{
  margin-left:auto;
  font-size:0.75rem;font-weight:700;
  color:var(--text-muted);
  text-decoration:underline;
  text-underline-offset:3px;
  transition:color 0.2s;
}
.size-guide-link:hover{color:var(--yellow);}

/* Shared selector row */
.variant-selector{
  display:flex;flex-wrap:wrap;gap:0.5rem;
}

/* Color buttons — wider pill */
.color-selector .variant-btn{
  min-width:90px;
  padding:0.45rem 1rem;
  border-radius:6px;
  font-size:0.8rem;font-weight:700;
  letter-spacing:0.04em;
  text-transform:uppercase;
}

/* Size buttons — compact square */
.size-selector .variant-btn{
  min-width:50px;
  padding:0.45rem 0.6rem;
  border-radius:6px;
  font-size:0.85rem;font-weight:700;
  text-align:center;
  letter-spacing:0;
  text-transform:none;
}

/* shared btn base */
.variant-btn{
  background:transparent;
  border:1.5px solid rgba(255,255,255,0.15);
  color:rgba(255,255,255,0.7);
  cursor:pointer;
  transition:var(--t);
}
.variant-btn:hover:not(:disabled){
  border-color:var(--yellow);
  color:var(--yellow);
  background:rgba(245,192,17,0.06);
}
.variant-btn.selected{
  border-color:var(--yellow);
  background:var(--yellow);
  color:var(--black);
}
.variant-btn.unavailable{
  opacity:0.3;cursor:not-allowed;
  text-decoration:line-through;
}
.variant-btn.dimmed{opacity:0.4;}

/* ── Size guide modal ── */
.size-modal{
  position:fixed;inset:0;
  z-index:999;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;opacity:0;
  transition:opacity 0.3s;
}
.size-modal.open{pointer-events:all;opacity:1;}
.size-modal-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,0.8);
  backdrop-filter:blur(4px);
}
.size-modal-content{
  position:relative;z-index:1;
  background:var(--dark-2);
  border:1px solid rgba(245,192,17,0.3);
  border-radius:16px;
  padding:2rem;
  max-width:520px;width:90%;
  max-height:90vh;overflow-y:auto;
  box-shadow:0 24px 80px rgba(0,0,0,0.7);
  transform:translateY(20px);
  transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
}
.size-modal.open .size-modal-content{transform:translateY(0);}
.size-modal-close{
  position:absolute;top:1rem;right:1rem;
  background:rgba(255,255,255,0.08);
  color:var(--text);
  width:32px;height:32px;border-radius:50%;
  font-size:0.9rem;
  display:flex;align-items:center;justify-content:center;
  transition:var(--t);
}
.size-modal-close:hover{background:rgba(245,192,17,0.15);color:var(--yellow);}
.size-modal-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.8rem;letter-spacing:0.04em;
  margin-bottom:1.25rem;
}
.size-modal-img{width:100%;border-radius:8px;}



/* ── Qty ── */
.qty-row{display:flex;align-items:center;gap:0.75rem;margin:1rem 0;}
.qty-label{font-size:0.85rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:0.05em;}
.qty-ctrl{
  display:flex;align-items:center;
  background:var(--dark-3);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:6px;overflow:hidden;
}
.qty-btn{
  background:none;color:var(--text);
  font-size:1.2rem;width:38px;height:38px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:var(--t);
}
.qty-btn:hover{background:rgba(245,192,17,0.1);color:var(--yellow);}
.qty-val{min-width:32px;text-align:center;font-weight:700;font-size:0.95rem;}

/* ── Section shared ── */
section{position:relative;z-index:1;}
.section-inner{max-width:1200px;margin:0 auto;padding:0 2rem;}
.section-label{
  display:inline-block;
  color:var(--yellow);
  font-size:0.78rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.12em;
  margin-bottom:0.75rem;
}
.section-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2rem,4vw,3.5rem);
  line-height:1.1;
  text-transform:uppercase;
  letter-spacing:0.02em;
  margin-bottom:1rem;
}
.section-sub{color:var(--text-muted);font-size:0.95rem;max-width:540px;margin:0 auto;line-height:1.75;}

/* ── Divider ── */
.divider{
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(245,192,17,0.3),transparent);
  margin:0;
}

/* ── Benefits ── */
.benefits{padding:5rem 0;}
.benefits-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1.25rem;
  margin-top:3rem;
}
.benefit-card{
  background:var(--dark-2);
  border:1px solid var(--border-white);
  border-radius:var(--radius);
  padding:1.75rem 1.5rem;
  transition:var(--t);
  position:relative;overflow:hidden;
}
.benefit-card::after{
  content:'';
  position:absolute;bottom:0;left:0;right:0;
  height:2px;
  background:var(--yellow);
  transform:scaleX(0);
  transition:var(--t);
  transform-origin:left;
}
.benefit-card:hover{border-color:rgba(245,192,17,0.3);transform:translateY(-4px);}
.benefit-card:hover::after{transform:scaleX(1);}
.benefit-icon{font-size:2rem;margin-bottom:1rem;display:block;}
.benefit-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.3rem;font-weight:400;
  letter-spacing:0.04em;
  margin-bottom:0.5rem;
  text-transform:uppercase;
}
.benefit-desc{color:var(--text-muted);font-size:0.88rem;line-height:1.7;}

/* ── Info Accordions (Qué incluye / Calidad / Envío) ── */
.info-accordions{padding:3rem 0;}
.info-acc-item{
  border-bottom:1px solid var(--border-white);
  overflow:hidden;
}
.info-acc-item:first-child{border-top:1px solid var(--border-white);}
.info-acc-q{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 0;
  background:transparent;color:var(--text);
  font-size:0.88rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.08em;
  text-align:left;gap:1rem;
  cursor:pointer;
}
.info-acc-q svg{
  flex-shrink:0;color:var(--yellow);
  transition:transform 0.3s ease;
}
.info-acc-item.open .info-acc-q svg{transform:rotate(180deg);}
.info-acc-body{
  max-height:0;overflow:hidden;
  transition:max-height 0.4s ease,padding 0.3s;
  color:var(--text-muted);font-size:0.9rem;line-height:1.8;
  padding:0;
}
.info-acc-item.open .info-acc-body{max-height:300px;padding-bottom:1.25rem;}
.include-list,.shipping-list{
  list-style:none;display:flex;flex-direction:column;gap:0.6rem;
}
.include-list li,.shipping-list li{
  padding:0.5rem 0.75rem;
  border-left:3px solid var(--yellow);
  background:rgba(245,192,17,0.04);
  border-radius:0 4px 4px 0;
  font-size:0.92rem;
}

/* ── Urgency Section ── */
.urgency-section{
  padding:5rem 2rem;
  background:linear-gradient(180deg,var(--dark) 0%,var(--dark-2) 100%);
  text-align:center;
  position:relative;overflow:hidden;
}
.urgency-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(245,192,17,0.06) 0%,transparent 65%);
  pointer-events:none;
}
.urgency-inner{
  max-width:680px;margin:0 auto;position:relative;z-index:1;
}
.urgency-badge{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:rgba(239,68,68,0.1);
  border:1px solid rgba(239,68,68,0.4);
  color:#f87171;
  padding:0.35rem 1rem;
  border-radius:4px;
  font-size:0.72rem;font-weight:800;
  text-transform:uppercase;letter-spacing:0.12em;
  margin-bottom:1.25rem;
}
.urgency-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(3rem,7vw,5.5rem);
  line-height:1.05;
  letter-spacing:0.02em;
  margin-bottom:0.75rem;
  text-transform:uppercase;
}
.urgency-title em{
  font-style:normal;
  color:var(--yellow);
  text-shadow:0 0 40px var(--yellow-glow);
}
.urgency-sub{
  color:var(--text-muted);font-size:1rem;line-height:1.7;
  margin-bottom:2rem;
}
.urgency-divider{
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(245,192,17,0.3),transparent);
  margin:2rem auto;max-width:400px;
}
.urgency-cta-text{
  font-family:'Inter',sans-serif;
  font-size:clamp(1.3rem,3vw,1.8rem);
  font-weight:900;text-transform:uppercase;
  letter-spacing:0.04em;margin-bottom:0.6rem;
}
.urgency-cta-sub{
  color:var(--text-muted);font-size:0.9rem;line-height:1.7;margin-bottom:2rem;
}
.btn-urgency{
  display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;
  background:var(--yellow);color:var(--black);
  font-size:1rem;font-weight:900;
  padding:1.1rem 2.5rem;border-radius:8px;
  text-transform:uppercase;letter-spacing:0.06em;
  transition:var(--t);
  box-shadow:0 8px 30px var(--yellow-glow);
}
.btn-urgency:hover{background:var(--yellow-dark);transform:translateY(-3px);box-shadow:0 16px 40px var(--yellow-glow);}

/* ── Photo Testimonials ── */
.testi-section{padding:5rem 0;background:var(--dark);}
.testi-photo-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  align-items:start;
}
.testi-photo-card{
  background:var(--dark-2);
  border:1px solid var(--border-white);
  border-radius:var(--radius);
  overflow:hidden;
  transition:var(--t);
}
.testi-photo-card:hover{transform:translateY(-4px);border-color:rgba(245,192,17,0.3);}
.testi-photo-card.featured{
  border-color:rgba(245,192,17,0.35);
  transform:scale(1.03);
}
.testi-photo-card.featured:hover{transform:scale(1.03) translateY(-4px);}
.testi-photo-wrap{
  aspect-ratio:4/3;overflow:hidden;
  position:relative;
}
.testi-photo-wrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.5s ease;
}
.testi-photo-card:hover .testi-photo-wrap img{transform:scale(1.05);}
.testi-photo-body{padding:1.25rem;}
.testi-photo-text{
  font-size:0.88rem;line-height:1.65;
  color:var(--text-muted);margin-bottom:0.75rem;
}
.testi-photo-text strong{color:var(--text);}
.testi-stars{color:var(--yellow);font-size:1rem;letter-spacing:2px;margin-bottom:0.4rem;}
.testi-author-name{font-size:0.8rem;font-weight:700;color:var(--text-muted);}

/* ── Satisfaction Stats ── */
.stats-section{
  background:linear-gradient(135deg,#1a1200 0%,#0A0A0A 60%);
  padding:4rem 2rem;
  border-top:1px solid var(--border-white);
  border-bottom:1px solid var(--border-white);
}
.stats-inner{
  max-width:900px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:3rem;align-items:center;
}
.stats-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.5rem,5vw,4rem);
  line-height:1.05;
  text-transform:uppercase;
  letter-spacing:0.02em;
  color:var(--yellow);
  margin-bottom:1rem;
}
.stats-desc{
  font-size:0.88rem;color:var(--text-muted);line-height:1.7;
}
.stats-right{
  display:flex;flex-direction:column;gap:0;
}
.stat-row{
  display:flex;align-items:center;gap:1.25rem;
  padding:1rem 0;
}
.stat-ring{
  position:relative;width:60px;height:60px;flex-shrink:0;
}
.stat-ring svg{width:60px;height:60px;}
.stat-pct{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-family:'Bebas Neue',sans-serif;
  font-size:1rem;color:var(--text);
}
.stat-label{
  font-size:0.9rem;font-weight:600;color:var(--text);
}
.stat-divider{
  height:1px;background:var(--border-white);
}
.stats-footnote{
  font-size:0.72rem;color:var(--text-muted);
  margin-top:1rem;line-height:1.5;
  font-style:italic;
}

@media(max-width:768px){
  .testi-photo-grid{grid-template-columns:1fr;}
  .testi-photo-card.featured{transform:none;}
  .stats-inner{grid-template-columns:1fr;text-align:center;}
  .stat-row{justify-content:center;}
}



/* ── FAQ ── */
.faq{padding:5rem 0;}
.faq-list{max-width:720px;margin:3rem auto 0;display:flex;flex-direction:column;gap:0.75rem;}
.faq-item{
  background:var(--dark-2);
  border:1px solid var(--border-white);
  border-radius:var(--radius);
  overflow:hidden;
  transition:border-color 0.2s;
}
.faq-item.open{border-color:rgba(245,192,17,0.4);}
.faq-q{
  width:100%;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 1.5rem;
  background:transparent;color:var(--text);
  font-size:0.93rem;font-weight:600;
  text-align:left;gap:1rem;
}
.faq-q svg{flex-shrink:0;transition:transform 0.3s;color:var(--yellow);}
.faq-item.open .faq-q svg{transform:rotate(45deg);}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height 0.4s ease,padding 0.3s;
  color:var(--text-muted);font-size:0.9rem;line-height:1.75;
  padding:0 1.5rem;
}
.faq-item.open .faq-a{max-height:200px;padding:0 1.5rem 1.25rem;}

/* ── Final CTA ── */
.final-cta{
  padding:7rem 0;
  text-align:center;
  background:linear-gradient(180deg,var(--black) 0%,var(--dark) 50%,var(--black) 100%);
  position:relative;overflow:hidden;
}
.final-cta::before{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 50% at 50% 100%,rgba(245,192,17,0.1) 0%,transparent 60%);
  pointer-events:none;
}
.final-cta .section-title{max-width:700px;margin:0 auto 1rem;}
.cta-actions{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;margin-top:2.5rem;}
.cta-actions .btn-buy{min-width:320px;font-size:1.05rem;padding:1.25rem 2.5rem;}

.guarantee{
  display:flex;align-items:center;justify-content:center;
  gap:0.75rem;margin-top:2rem;color:var(--text-muted);font-size:0.85rem;
}
.guarantee svg{color:var(--green);}

/* ── Sticky bar ── */
.sticky-bar{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--yellow);
  z-index:200;
  padding:0.85rem 2rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  transform:translateY(100%);
  transition:transform 0.4s cubic-bezier(0.4,0,0.2,1);
}
.sticky-bar.visible{transform:translateY(0);}
.sticky-info{display:flex;align-items:baseline;gap:0.75rem;}
.sticky-title{font-weight:800;font-size:0.9rem;color:var(--black);text-transform:uppercase;}
.sticky-price{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.6rem;
  color:var(--black);
  line-height:1;
}
.sticky-bar .btn-buy{
  background:var(--black);
  color:var(--yellow);
  padding:0.8rem 1.75rem;
  font-size:0.9rem;
  box-shadow:none;
}
.sticky-bar .btn-buy:hover{background:var(--dark-3);}

/* ── Footer ── */
footer{
  background:var(--dark);
  border-top:1px solid var(--border-white);
  padding:2rem;
  text-align:center;
  color:var(--text-muted);
  font-size:0.8rem;
  padding-bottom:5rem;
}

/* ── Spinner ── */
@keyframes spin{to{transform:rotate(360deg);}}
.spinner{
  width:20px;height:20px;
  border:2.5px solid rgba(0,0,0,0.3);
  border-top-color:var(--black);
  border-radius:50%;
  animation:spin 0.8s linear infinite;
  flex-shrink:0;
}

/* ── Skeleton ── */
.skeleton{
  background:linear-gradient(90deg,var(--dark-2) 25%,var(--dark-3) 50%,var(--dark-2) 75%);
  background-size:200% 100%;
  animation:skeleton 1.5s infinite;
  border-radius:6px;
  color:transparent !important;
}
@keyframes skeleton{0%{background-position:200% 0;}100%{background-position:-200% 0;}}

/* ── Toast ── */
.toast{
  position:fixed;bottom:5rem;left:50%;
  transform:translateX(-50%) translateY(20px);
  background:var(--dark-3);
  border:1px solid var(--border-white);
  border-radius:10px;
  padding:0.85rem 1.5rem;
  display:flex;align-items:center;gap:0.75rem;
  font-size:0.9rem;font-weight:600;
  z-index:9999;opacity:0;pointer-events:none;
  transition:opacity 0.3s,transform 0.3s;
  white-space:nowrap;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast.error{border-color:rgba(255,59,48,0.4);color:#ff6b6b;}
.toast.success{border-color:rgba(34,197,94,0.4);color:var(--green);}

/* ── Responsive ── */
@media(max-width:768px){
  .hero-grid{grid-template-columns:1fr;gap:2rem;}
  .hero-visual{order:-1;}
  .product-img-wrap{max-width:300px;}
  .float-badge{display:none;}
  .hero{padding:7rem 1.25rem 4rem;}
  .benefits,.testimonials,.faq,.final-cta{padding:3.5rem 0;}
  .sticky-bar{flex-direction:column;text-align:center;}
  .cta-actions{flex-direction:column;}
  .cta-actions .btn-buy{width:100%;max-width:360px;}
  .navbar{padding:1rem 1.25rem;}
  .social-proof{bottom:5rem;left:1rem;right:1rem;max-width:none;}
}
@media(max-width:480px){
  .title-line-2{font-size:4rem;}
  .price-current{font-size:2.5rem;}
}

/* ═══════════════════════════════════════════════════════
   URGENCY ELEMENTS
   ═══════════════════════════════════════════════════════ */

/* Social proof notification (bottom-left popup) */
.social-proof{
  position:fixed;
  bottom:5rem;left:1.5rem;
  z-index:9998;
  background:var(--dark-2);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:12px;
  padding:0.85rem 1.1rem;
  display:flex;align-items:center;gap:0.75rem;
  box-shadow:0 8px 32px rgba(0,0,0,0.6);
  max-width:300px;
  opacity:0;
  transform:translateY(20px) translateX(-8px);
  transition:opacity 0.4s,transform 0.4s;
  pointer-events:none;
}
.social-proof.show{
  opacity:1;
  transform:translateY(0) translateX(0);
  pointer-events:all;
}
.sp-icon{
  font-size:1.6rem;flex-shrink:0;
  background:rgba(245,192,17,0.1);
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.sp-text{
  display:flex;flex-direction:column;gap:0.15rem;
  font-size:0.8rem;line-height:1.4;
  flex:1;
}
.sp-text strong{color:var(--text);font-size:0.85rem;}
.sp-text span{color:var(--text-muted);}
.sp-time{
  font-size:0.7rem;color:var(--text-muted);
  flex-shrink:0;align-self:flex-start;
  white-space:nowrap;
}

/* Stock bar */
.urgency-signals{
  background:rgba(255,59,48,0.05);
  border:1px solid rgba(255,59,48,0.2);
  border-radius:10px;
  padding:0.9rem 1rem;
  margin-bottom:1rem;
  display:flex;flex-direction:column;gap:0.7rem;
}
.stock-bar-wrap{display:flex;flex-direction:column;gap:0.4rem;}
.stock-bar-header{
  display:flex;align-items:center;justify-content:space-between;
  font-size:0.82rem;
}
.stock-label{color:var(--text);}
.stock-label strong{color:#ff6b6b;}
.stock-pct{color:var(--text-muted);font-size:0.75rem;}
.stock-bar-track{
  height:7px;
  background:rgba(255,255,255,0.08);
  border-radius:99px;
  overflow:hidden;
}
.stock-bar-fill{
  height:100%;
  background:linear-gradient(90deg,#ff4444,#ff8800);
  border-radius:99px;
  transition:width 1s ease;
  position:relative;
}
.stock-bar-fill::after{
  content:'';
  position:absolute;top:0;right:0;
  height:100%;width:20px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.4));
  animation:shimmer-bar 1.5s ease-in-out infinite;
}
@keyframes shimmer-bar{
  0%,100%{opacity:0.6;}50%{opacity:1;}
}

/* Live viewers */
.viewers-row{
  display:flex;align-items:center;gap:0.5rem;
  font-size:0.8rem;color:var(--text-muted);
}
.viewers-row strong{color:var(--text);}
.viewer-dot{
  width:8px;height:8px;border-radius:50%;
  background:#22C55E;
  box-shadow:0 0 6px #22C55E;
  flex-shrink:0;
  animation:pulse-live 1.5s ease-in-out infinite;
}

/* Urgency note under buy button */
.btn-urgency-note{
  display:flex;align-items:center;justify-content:center;gap:0.4rem;
  font-size:0.78rem;font-weight:700;
  color:var(--yellow);
  letter-spacing:0.03em;
  margin-top:-0.3rem;
  margin-bottom:0.5rem;
}
.btn-urgency-note svg{color:var(--yellow);flex-shrink:0;}

/* ── Floating WhatsApp Button ── */
.wa-float{
  position:fixed;
  bottom:1.5rem;right:1.5rem;
  width:55px;height:55px;
  background:#25D366;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 24px rgba(37,211,102,0.4);
  z-index:9999;
  transition:transform 0.3s cubic-bezier(0.175,0.885,0.32,1.275),box-shadow 0.3s;
}
.wa-float:hover{
  transform:scale(1.15) rotate(-5deg);
  box-shadow:0 12px 32px rgba(37,211,102,0.6);
}
.wa-float svg {
  color: white;
}
.wa-tooltip{
  position:absolute;
  right:100%;margin-right:1.2rem;
  background:#fff;color:#111;
  padding:0.4rem 0.8rem;
  border-radius:8px;
  font-size:0.75rem;font-weight:700;
  white-space:nowrap;
  box-shadow:0 4px 12px rgba(0,0,0,0.15);
  opacity:0;pointer-events:none;
  transform:translateX(10px);
  transition:all 0.3s ease;
}
.wa-tooltip::after{
  content:'';position:absolute;
  right:-5px;top:50%;transform:translateY(-50%);
  border-left:6px solid #fff;border-top:6px solid transparent;border-bottom:6px solid transparent;
}
.wa-float:hover .wa-tooltip{
  opacity:1;transform:translateX(0);
}

/* ── Checkout Modal ── */
.checkout-modal {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.8);
  backdrop-filter: blur(5px);
  z-index: 10000;
  display: flex; justify-content: center; align-items: flex-start;
  overflow-y: auto;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s ease;
  padding: 1rem;
}
.checkout-modal.active {
  opacity: 1; pointer-events: auto;
}
.checkout-modal-content {
  background: #0F0F0F; /* Dark background */
  width: 100%; max-width: 450px;
  border-radius: 12px;
  position: relative;
  border: 1px solid rgba(255,255,255,0.1);
  transform: translateY(20px);
  transition: transform 0.3s ease;
  margin: 1rem auto;
  padding: 1.25rem;
  color: #FFFFFF;
  font-family: 'Inter', sans-serif;
  box-shadow: 0 10px 40px rgba(0,0,0,0.5);
}
.checkout-modal.active .checkout-modal-content {
  transform: translateY(0);
}
.close-modal-btn {
  position: absolute; top: 12px; right: 12px;
  background: rgba(255,255,255,0.05); border: none; font-size: 1.2rem;
  cursor: pointer; color: #AAA; line-height: 1;
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.close-modal-btn:hover { background: rgba(255,255,255,0.1); color: #FFF; }
.modal-header { text-align: center; margin-bottom: 0.8rem; }
.modal-header h3 {
  font-size: 1rem; color: var(--yellow); text-transform: uppercase; letter-spacing: 0.05em;
  margin-top: 0.8rem; margin-bottom: 0.4rem; font-weight: 900;
}
.modal-header p { font-size: 0.8rem; color: #999; line-height: 1.4; margin:0;}
.modal-urgency {
  background: rgba(245, 192, 17, 0.1); border: 1px dashed var(--yellow); color: var(--yellow);
  text-align: center; padding: 0.6rem; border-radius: 6px;
  font-size: 0.82rem; margin-bottom: 1.25rem; font-weight: 600;
}
.modal-packages { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1rem; }
.pkg-option {
  display: flex; align-items: center; gap: 0.75rem;
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.1); border-radius: 8px;
  padding: 0.75rem; cursor: pointer; transition: all 0.2s;
}
.pkg-option.active { border-color: var(--yellow); background: rgba(245, 192, 17, 0.05); box-shadow: 0 4px 15px rgba(245,192,17,0.1); }
.pkg-option input[type="radio"] { display: none; }
.pkg-img img { width: 50px; height: 50px; object-fit: cover; border-radius: 4px; border: 1px solid #eee; background:#111; }
.pkg-info { flex: 1; font-size: 0.8rem; line-height: 1.2; }
.pkg-title { font-weight: 800; margin-bottom: 0.2rem; }
.badge-red { background: red; color: #fff; padding: 0.1rem 0.3rem; border-radius: 3px; font-size: 0.65rem; }
.badge-yellow { background: #F59E0B; color: #fff; padding: 0.1rem 0.3rem; border-radius: 3px; font-size: 0.65rem; }
.badge-green { background: #16A34A; color: #fff; padding: 0.1rem 0.3rem; border-radius: 3px; font-size: 0.65rem; }
.pkg-variant-info { font-size: 0.75rem; color: #AAAAAA; font-weight: 600; }
.pkg-price-col { text-align: right; line-height: 1.2; }
.pkg-price-old { font-size: 0.7rem; color: #666; text-decoration: line-through; }
.pkg-price-final { font-size: 0.95rem; font-weight: 900; color: var(--yellow); }

.modal-summary { background: rgba(255,255,255,0.03); padding: 1rem; border-radius: 8px; margin-bottom: 1.25rem; font-size: 0.85rem; border: 1px solid rgba(255,255,255,0.05);}
.sum-line { display: flex; justify-content: space-between; margin-bottom: 0.4rem; color: #CCC; }
.sum-line.sum-total { border-top: 1px solid rgba(255,255,255,0.1); padding-top: 0.6rem; margin-top: 0.6rem; font-size: 1rem; font-weight: 900; color: #FFF; }

.modal-shipping-method {
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.1); border-radius: 8px; padding: 0.75rem;
  display: flex; justify-content: space-between; align-items: center; font-size: 0.85rem; margin-bottom: 1.25rem;
}
.shipping-radio { display: flex; align-items: center; gap: 0.5rem; color: #DDD; }

.checkout-form h4 { font-size: 0.95rem; text-align: center; margin-bottom: 1rem; color: var(--yellow); text-transform: uppercase; letter-spacing: 0.05em;}
.checkout-form .input-group, .checkout-form .input-row { margin-bottom: 0.75rem; position: relative; }
.checkout-form .input-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
.checkout-form input, .checkout-form select {
  width: 100%; border: 1px solid rgba(255,255,255,0.1); border-radius: 6px; padding: 0.75rem; font-size: 0.9rem;
  background: rgba(0,0,0,0.2); color: #FFF; transition: all 0.2s; font-family: inherit;
}
.checkout-form .input-group input { padding-left: 2.25rem; }
.checkout-form .input-group .icon { position: absolute; left: 0.8rem; top: 50%; transform: translateY(-50%); font-size: 0.85rem; color: #666; pointer-events: none;}
.checkout-form input:focus, .checkout-form select:focus { outline: none; border-color: var(--yellow); background: rgba(0,0,0,0.3); }

.priority-shipping { background: var(--yellow); padding: 0.75rem; border-radius: 6px; margin: 1.25rem 0; font-size: 0.85rem; color: var(--black); text-align: center; font-weight: 800; box-shadow: 0 4px 15px var(--yellow-glow);}

.modal-buttons { display: flex; flex-direction: column; gap: 0.6rem; }
.btn-cod {
  background: #059669; color: #fff; border: none; padding: 0.8rem; border-radius: 6px;
  font-size: 1rem; font-weight: 800; display: flex; align-items: center; justify-content: center; gap: 0.5rem;
  cursor: pointer; transition: background 0.2s;
}
.btn-cod:hover { background: #047857; }
.btn-cc {
  background: #F59E0B; color: #fff; border: none; padding: 0.8rem; border-radius: 6px;
  font-size: 1rem; font-weight: 800; display: flex; align-items: center; justify-content: center; gap: 0.5rem;
  cursor: pointer; transition: background 0.2s;
}
.btn-cc:hover { background: #D97706; }

.form-error-msg { background: rgba(239, 68, 68, 0.1); color: #F87171; font-size: 0.8rem; padding: 0.75rem; border-radius: 6px; border: 1px solid rgba(239, 68, 68, 0.2); margin-bottom: 1rem; text-align: center; font-weight: 600; }

/* ── Gallery Thumbnails ── */
.gallery-thumbs {
  display: flex;
  gap: 0.6rem;
  padding: 0.5rem 0;
  overflow-x: auto;
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none;  /* IE and Edge */
  margin-top: 0.8rem;
}
.gallery-thumbs::-webkit-scrollbar { display: none; } /* Chrome/Safari */

.gallery-thumb {
  flex: 0 0 65px;
  height: 65px;
  border-radius: 8px;
  border: 2px solid transparent;
  overflow: hidden;
  cursor: pointer;
  background: var(--dark-2);
  transition: all 0.2s;
}
.gallery-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.6;
  transition: opacity 0.2s;
}
.gallery-thumb.active { border-color: var(--yellow); box-shadow: 0 0 10px var(--yellow-glow); }
.gallery-thumb.active img { opacity: 1; }
.gallery-thumb:hover img { opacity: 1; }
