/* HERO */
.hero{min-height:calc(100vh - 110px);display:flex;align-items:center;justify-content:center;background:#000;color:#fff;position:relative;overflow:hidden;padding:clamp(2rem,5vw,4rem) 0}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 3s ease-in-out;transform:scale(1.05);animation:zoom 8s ease-in-out infinite paused}
.hero-slide.active{opacity:.4;animation-play-state:running}
@keyframes zoom{0%{transform:scale(1.05)}50%{transform:scale(1.15)}100%{transform:scale(1.05)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,rgba(0,0,0,.5) 100%);z-index:1}
.hero-ct{position:relative;z-index:2;text-align:center;max-width:1150px}
.hero-tag{font-size:.85rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--red);margin-bottom:1rem}
.hero h1{font-family:var(--font-d);font-weight:900;font-size:clamp(2.5rem,5.5vw,4.5rem);line-height:1.1;margin-bottom:1.5rem}
.hero h1 em{color:var(--red);font-style:italic}
.hero-sub{font-size:clamp(1rem,1.5vw,1.2rem);line-height:1.8;margin-bottom:2.5rem;color:rgba(255,255,255,.85);text-align:center}
.hero-ctas{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}
.btn{padding:1rem 2rem;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;transition:all .3s;cursor:pointer;display:inline-block}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:#a93226;transform:translateY(-2px)}
.btn-outline{border:2px solid #fff;color:#fff}
.btn-outline:hover{background:#fff;color:#000}

/* PRODUCTS */
.products{padding:clamp(4rem,8vw,8rem) 0;background:#f9f9f9}
.section-title{font-family:var(--font-d);font-weight:900;font-size:clamp(2rem,3.5vw,3rem);margin-bottom:3rem;color:var(--dark)}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2.5rem}
.section-tag{font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:.5rem}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,2.5rem)}

.pc{cursor:pointer;opacity:0;transform:translateY(50px);animation:reveal .8s cubic-bezier(.16,1,.3,1) forwards}
@keyframes reveal{to{opacity:1;transform:translateY(0)}}
.pc-img{position:relative;aspect-ratio:1;border-radius:1rem;overflow:hidden;margin-bottom:1.1rem;box-shadow:0 4px 20px rgba(44,24,16,.08);background:#fff}
.pc-img-in{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transition:transform .6s cubic-bezier(.16,1,.3,1),opacity .4s ease;background-size:contain;background-repeat:no-repeat;background-position:center;opacity:1;touch-action:pan-y;user-select:none;-webkit-user-select:none;cursor:grab}
.pc-img-in:active{cursor:grabbing}
.pc-img-in.is-switching{opacity:0}
.pc:hover .pc-img-in{transform:scale(1.05)}
.pc-seal{position:absolute;bottom:.7rem;width:72px;height:auto;z-index:3;pointer-events:none;filter:drop-shadow(0 3px 10px rgba(0,0,0,.28))}
.pc-seal-left{left:.7rem}
.pc-seal-green{left:.7rem;bottom:4.8rem;top:auto;transform:scale(.72);transform-origin:center bottom}
.pc-badge{position:absolute;top:.6rem;left:.6rem;z-index:2;display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:999px;background:rgba(15,15,15,.72);backdrop-filter:blur(6px);color:#fff;font-size:.46rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;box-shadow:0 2px 8px rgba(15,15,15,.15)}
.pc-badge::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--red);box-shadow:0 0 0 2px rgba(244,30,13,.18)}
.pc-dots{position:absolute;left:50%;bottom:.85rem;transform:translateX(-50%);display:flex;align-items:center;gap:.35rem;z-index:2;pointer-events:none;padding:.28rem .45rem;border-radius:999px;background:rgba(255,255,255,.7);backdrop-filter:blur(6px);box-shadow:0 4px 14px rgba(15,15,15,.08)}
.pc-dot{width:6px;height:6px;border-radius:999px;background:rgba(15,15,15,.18);transition:all .25s ease}
.pc-dot.active{width:18px;background:var(--red)}
.pc-add{position:absolute;bottom:.9rem;right:.9rem;width:42px;height:42px;border-radius:50%;background:#f5f0ea;border:none;display:flex;align-items:center;justify-content:center;z-index:2;opacity:0;transform:translateY(8px);transition:all .4s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 16px rgba(44,24,16,.15);cursor:pointer}
.pc-add svg{width:18px;height:18px;stroke:var(--dark);fill:none;stroke-width:2}
.pc:hover .pc-add{opacity:1;transform:translateY(0)}
.pc-brand{font-size:.58rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:.25rem}
.pc-name{font-family:var(--font-d);font-weight:700;font-size:1rem;color:var(--dark);margin-bottom:.4rem;line-height:1.3}
.pc-stars{display:flex;align-items:center;gap:.2rem;margin-bottom:.4rem}
.pc-stars svg{width:13px;height:13px;fill:var(--gold)}
.pc-stars span{font-size:.65rem;font-weight:600;color:var(--gray);margin-left:.25rem}
.pc-price{display:flex;align-items:center;gap:.5rem}
.price{font-weight:700;font-size:1rem;color:var(--dark)}
.pc[data-d="1"]{animation-delay:.1s}
.pc[data-d="2"]{animation-delay:.2s}
.pc[data-d="3"]{animation-delay:.3s}
.pc[data-d="4"]{animation-delay:.4s}
@media(max-width:768px){
  .product-grid{display:block!important;position:relative;overflow:hidden}
  .product-grid .pc{display:none;width:100%!important;max-width:360px;margin:0 auto}
  .product-grid .pc.carousel-active{display:block}
  .pc-seal{width:60px;bottom:.55rem}
  .pc-seal-left{left:.55rem}
  .pc-seal-green{left:.55rem;bottom:3.9rem}
  .carousel-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}
  .carousel-dot{width:8px;height:8px;border-radius:50%;background:#ddd;border:none;padding:0;cursor:pointer;transition:background .3s}
  .carousel-dot.active{background:var(--red)}
}
@media(min-width:769px){.carousel-dots{display:none}}
@media(max-width:480px){.pc-seal{width:54px}}
@media(hover:none){.pc-add{opacity:1;transform:translateY(0)}}

/* BANNER */
.banner{
  padding:clamp(6rem,14vw,14rem) 0;
  background:#0a0a0a;
  color:#fff;
  text-align:center;
  position:relative;
  overflow:hidden
}
.banner::before{
  content:'';
  position:absolute;
  inset:-8%;
  background-image:url('/assets/images/banners/home-hero/home-hero-01.webp');
  background-size:cover;
  background-position:center;
  transform:scale(1.08);
  opacity:.18;
  z-index:0;
  will-change:transform;
  animation:bannerZoom 18s ease-in-out infinite alternate;
}
.banner::after{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 50% 35%, rgba(255,255,255,.08) 0%, rgba(255,255,255,0) 40%),
    linear-gradient(180deg, rgba(0,0,0,.1) 0%, rgba(0,0,0,.55) 100%);
  z-index:0;
}
.banner .container{position:relative;z-index:1}
.banner-pre{font-size:.6rem;font-weight:700;letter-spacing:.4em;text-transform:uppercase;color:var(--red);margin-bottom:2rem}
.banner h2{font-family:var(--font-d);font-weight:900;font-size:clamp(2.5rem,6vw,4.5rem);line-height:.95;margin-bottom:2rem}
.banner h2 em{color:var(--red);font-style:italic}
.banner-sub{font-size:.95rem;line-height:1.8;color:rgba(255,255,255,.7);max-width:560px;margin:0 auto 2.5rem}

@keyframes bannerZoom{
  0%{transform:scale(1.06)}
  100%{transform:scale(1.18)}
}

/* NOSOTROS HOME */
.nos-home{padding:clamp(4rem,8vw,8rem) 0;background:#fff}
.nos-home-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,6vw,7rem);align-items:center}
.nos-home-img{aspect-ratio:5/4;border-radius:12px;overflow:hidden;background:#f0f0f0}
.nos-home-txt h2{font-family:var(--font-d);font-weight:900;font-size:clamp(2rem,3.5vw,3rem);line-height:1.1;color:var(--dark);margin-bottom:1.25rem}
.nos-home-txt h2 em{color:var(--red);font-style:italic}
.nos-home-txt p{font-size:.95rem;line-height:1.8;color:var(--gray);margin-bottom:1.25rem}
.pillars{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;margin:1.75rem 0}
.pillar{padding:1rem;border-radius:.75rem;background:#f9f9f9;border:1px solid #e8e8e8}
.pillar h5{font-weight:700;font-size:.85rem;color:var(--dark);margin-bottom:.25rem}
.pillar p{font-size:.8rem;color:var(--gray);line-height:1.5;margin:0}
@media(max-width:768px){
  .nos-home-grid{grid-template-columns:1fr}
  .pillars{grid-template-columns:1fr}
}

/* ORIGEN */
.origen{padding:clamp(4rem,8vw,8rem) 0;background:#f9f9f9}
.origen-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,6vw,7rem);align-items:center}
.origen-txt h2,.origen-grid h2{font-family:var(--font-d);font-weight:900;font-size:clamp(2rem,3.5vw,3rem);line-height:1.15;color:var(--dark);margin-bottom:1.5rem;margin-top:2rem}
.origen-txt h2 br{display:none}
.origen-txt p{font-size:.95rem;line-height:1.8;color:var(--gray);margin-bottom:1.25rem;text-align:justify}
.origen-grid > div > p{text-align:justify;margin-bottom:1.25rem}
.origen-stats{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin:2rem 0}
.origen-stat span{display:block}
.origen-stat span:first-child{font-family:var(--font-d);font-weight:900;font-size:1.8rem;color:var(--red)}
.origen-stat span:last-child{font-size:.85rem;color:var(--gray);margin-top:.25rem}
.origen-img{aspect-ratio:1;border-radius:12px;overflow:hidden;background:#e8e8e8}
.origen-bullets{list-style:none;margin:1.25rem 0 0;display:flex;flex-direction:column;gap:1rem}
.origen-bullets li{font-size:.93rem;line-height:1.75;color:var(--gray);padding-left:1.1rem;border-left:2px solid var(--red)}
@media(max-width:768px){
  .origen-grid{grid-template-columns:1fr}
  .origen-stats{grid-template-columns:1fr}
}

/* REVIEWS */
.reviews{padding:clamp(4rem,8vw,8rem) 0;background:#fff}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-top:3rem}
.review-card{padding:2rem;border-radius:8px;background:#f9f9f9;border:1px solid #e8e8e8}
.review-stars{display:flex;gap:.25rem;margin-bottom:1rem}
.review-stars svg{width:16px;height:16px;fill:var(--red)}
.review-text{font-size:.95rem;line-height:1.8;color:var(--gray);margin-bottom:1.5rem;font-style:italic}
.review-author{display:flex;gap:.75rem;align-items:center}
.review-avatar{width:40px;height:40px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}
.review-author-info span{display:block;font-size:.85rem}
.review-author-info span:first-child{font-weight:600;color:var(--dark)}
.review-author-info span:last-child{color:var(--gray);font-size:.8rem}

/* INFO */
.info{padding:clamp(4rem,8vw,8rem) 0;background:#f9f9f9}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:3rem}
.info-card{text-align:center;padding:2rem}
.info-icon{width:60px;height:60px;background:rgba(244,30,13,.08);border-radius:8px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}
.info-icon svg{width:28px;height:28px;stroke:var(--red);fill:none}
.info-card h4{font-weight:700;margin-bottom:.5rem;font-size:1rem}
.info-card p{font-size:.9rem;color:var(--gray);line-height:1.6}

/* NEWSLETTER */
.newsletter{padding:clamp(4rem,8vw,8rem) 0;background:#0a0a0a;color:#fff;text-align:center}
.newsletter h2{font-family:var(--font-d);font-weight:900;font-size:clamp(2rem,3vw,2.8rem);margin-bottom:1rem}
.newsletter p{font-size:.95rem;color:rgba(255,255,255,.7);margin-bottom:2rem;max-width:500px;margin-left:auto;margin-right:auto}
.news-form{display:flex;gap:1rem;max-width:500px;margin:0 auto}
.news-input{flex:1;padding:.75rem 1rem;border-radius:4px;border:none;font-size:.9rem}
.news-btn{padding:.75rem 2rem;background:var(--red);color:#fff;border-radius:4px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;transition:all .3s}
.news-btn:hover{background:#a93226}
@media(max-width:600px){
  .news-form{flex-direction:column}
  .news-input,.news-btn{width:100%}
}

/* FOOTER */
footer{background:#0a0a0a;color:#fff;padding:3rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}
.footer-col h4{font-weight:700;margin-bottom:1rem;color:var(--red)}
.footer-col ul{list-style:none}
.footer-col a{font-size:.9rem;color:rgba(255,255,255,.6);transition:color .3s;display:block;margin-bottom:.5rem}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:2rem;text-align:center;font-size:.85rem;color:rgba(255,255,255,.4)}

/* MOBILE NAV */
.mob-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;opacity:0;pointer-events:none;transition:opacity .3s}
.mob-overlay.open{opacity:1;pointer-events:auto}
.mob-nav{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:85vw;background:#fff;z-index:2001;transform:translateX(-100%);transition:transform .3s;padding:2rem;display:flex;flex-direction:column}
.mob-nav.open{transform:translateX(0)}
.mob-close{position:absolute;top:1.5rem;right:1.5rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center}
.mob-close svg{width:24px;height:24px;stroke:var(--dark);fill:none}
.mob-nav ul{list-style:none;display:flex;flex-direction:column;gap:1rem;margin-top:2rem}
.mob-nav a{font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.85rem;color:var(--dark)}
.mob-nav a:hover{color:var(--red)}

@media(max-width:768px){
  .product-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
  .reviews-grid{grid-template-columns:1fr}
  .info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
}

