:root{--line:#ece6df;--muted:#6b6b6b;--radius:22px}
*{box-sizing:border-box}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial;background:#faf7f2;color:#111}
a{color:inherit;text-decoration:none}
.topbar{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;gap:18px;justify-content:space-between;padding:14px 22px;background:rgba(250,247,242,.78);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand img{height:64px;width:auto;display:block}
.nav{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.nav a{font-weight:800;font-size:13px;color:#222;opacity:.9}
.wa{font-weight:900;font-size:13px;border:1px solid var(--line);padding:10px 12px;border-radius:999px;background:#fff}
main{padding-top:86px}
.hero{height:92vh;position:relative;overflow:hidden}
.heroVideo{width:100%;height:100%;object-fit:cover;display:block}
.heroCta{position:absolute;right:24px;bottom:24px;background:#111;color:#fff;padding:12px 18px;border-radius:999px;font-weight:900;box-shadow:0 12px 30px rgba(0,0,0,.28)}
.carouselWrap{padding:26px 22px}
.carouselHead h2{margin:0 0 10px;text-align:center;letter-spacing:.18em;font-size:14px;text-transform:uppercase}
.carousel{position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.track{display:flex;gap:14px;padding:0;transition:transform .35s ease}
.slide{flex:0 0 calc((100% - 28px)/3);position:relative}
.slide img{width:100%;height:260px;object-fit:cover;display:block}
.ver-coleccion{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);background:rgba(0,0,0,.72);color:#fff;padding:8px 14px;border-radius:999px;font-weight:900;font-size:13px}
.arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.92);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 25px rgba(0,0,0,.08);z-index:3}
.arrow.left{left:10px}
.arrow.right{right:10px}
.tiendaIntro{padding:34px 22px;text-align:center}
.tiendaIntro h2{margin:0 0 10px;font-size:26px;letter-spacing:.22em;font-weight:950}
.tiendaIntro .sub{margin:0 auto 18px;color:var(--muted);max-width:72ch;line-height:1.55}
.glowCard{margin:0 auto;width:min(860px,92vw);border-radius:22px;padding:16px 18px;position:relative;background:radial-gradient(1200px 400px at 20% 0%, rgba(255,255,255,.85), rgba(255,255,255,.15)),linear-gradient(135deg,#ffffff,#fbf7f3);border:1px solid rgba(236,230,223,.9);box-shadow:0 18px 55px rgba(0,0,0,.09);overflow:hidden}
.glowCard::before{content:"";position:absolute;inset:-2px;background:linear-gradient(90deg, rgba(0,0,0,0), rgba(0,0,0,.10), rgba(0,0,0,0));transform:translateX(-60%);opacity:.25;animation:shine 4.2s ease-in-out infinite}
@keyframes shine{0%{transform:translateX(-60%)}50%{transform:translateX(60%)}100%{transform:translateX(60%)}}
.glowTop{display:flex;align-items:center;justify-content:space-between}
.tag{display:inline-flex;align-items:center;font-weight:950;font-size:12px;letter-spacing:.16em;background:#fff;border:1px solid var(--line);padding:8px 12px;border-radius:999px}
.dot{width:10px;height:10px;border-radius:999px;background:#111;box-shadow:0 0 0 0 rgba(17,17,17,.35);animation:pulse 1.7s ease-in-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(17,17,17,.35)}70%{box-shadow:0 0 0 12px rgba(17,17,17,0)}100%{box-shadow:0 0 0 0 rgba(17,17,17,0)}}
.glowMsg{font-weight:950;margin:14px auto 6px;max-width:70ch}
.glowHint{color:var(--muted);font-size:13px}
.layout{display:grid;grid-template-columns:260px 1fr;gap:22px;padding:10px 22px 34px}
.sidebar{position:sticky;top:96px;height:fit-content;border:1px solid var(--line);border-radius:var(--radius);background:#fff;padding:14px}
.sidebar h4{margin:0 0 10px;font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.sidebar a{display:block;padding:10px 10px;border-radius:14px;font-weight:850;color:#222}
.sidebar a:hover{background:#f6f1ea}
.subLink{padding-left:18px;color:#444;font-weight:800}
.shopSection{margin-bottom:24px}
.shopSection h3{margin:0 0 12px;font-size:18px}
.grid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:14px}
.card{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;transition:transform .18s ease, box-shadow .18s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 18px 45px rgba(0,0,0,.10)}
.media{height:220px;overflow:hidden}
.media img{width:100%;height:100%;object-fit:cover;display:block}
.meta{padding:12px}
.name{font-weight:950;margin-bottom:4px}
.desc{color:var(--muted);font-size:13px;margin-bottom:10px}
.row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.pill{font-size:12px;border:1px solid var(--line);padding:6px 10px;border-radius:999px;background:#fff}
.price{font-weight:950}
.buyRow{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:stretch}
.frag{border:1px solid var(--line);border-radius:14px;padding:10px 12px;background:#fff}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.qbtn{width:34px;height:38px;border:none;background:#fff;font-weight:950;cursor:pointer}
.qval{width:34px;border:none;text-align:center;font-weight:950}
.add{border:none;border-radius:14px;background:#111;color:#fff;font-weight:950;padding:10px 12px;cursor:pointer}
.footer{background:#111;color:#fff;margin-top:20px}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 2fr;gap:22px;padding:34px 22px}
.flogo{height:44px;width:auto;display:block;margin-bottom:10px;filter:brightness(1.05)}
.ftext{color:rgba(255,255,255,.75);line-height:1.5}
.footer h5{margin:0 0 10px;font-size:13px;letter-spacing:.14em;text-transform:uppercase}
.footer p{margin:0 0 8px;color:rgba(255,255,255,.75)}
.news{display:flex;gap:10px;margin-top:10px}
.news input{flex:1;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.25);color:#fff;padding:10px 12px}
.news button{border:none;border-radius:14px;background:#fff;color:#111;padding:10px 12px;font-weight:950;cursor:pointer}
.fbottom{display:flex;justify-content:space-between;gap:12px;padding:16px 22px;border-top:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.75);font-size:13px}
@media (max-width:980px){.layout{grid-template-columns:1fr}.grid{grid-template-columns:repeat(2,1fr)}.fgrid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.nav{display:none}.brand img{height:46px}.grid{grid-template-columns:1fr}.slide{flex:0 0 90%}}
/* Product card hierarchy */
.subline{margin-top:4px;margin-bottom:6px}
.weight{display:inline-flex;align-items:center;font-size:12px;border:1px solid var(--line);padding:6px 10px;border-radius:999px;background:#fff}
.priceBig{font-size:22px;font-weight:1000;letter-spacing:.01em;margin:2px 0 10px}
.fragLabel{display:block;text-align:left;font-size:12px;font-weight:950;letter-spacing:.08em;text-transform:uppercase;color:#333;margin:0 0 6px}
.add{white-space:nowrap}

/* ===== MINI CAROUSEL (PRODUCTOS) ===== */
.media.miniCarousel{position:relative;overflow:hidden}
.media.miniCarousel .miniImg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity .22s ease;
}
.media.miniCarousel .miniImg.active{opacity:1}
.media.miniCarousel .miniNav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:38px;height:38px;border-radius:999px;
  border:1px solid rgba(0,0,0,.12);
  background:rgba(255,255,255,.86);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;user-select:none;
}
.media.miniCarousel .miniNav.prev{left:10px}
.media.miniCarousel .miniNav.next{right:10px}
.media.miniCarousel .miniDots{
  position:absolute;left:0;right:0;bottom:10px;
  display:flex;justify-content:center;gap:6px;
}
.media.miniCarousel .miniDot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(0,0,0,.25);
}
.media.miniCarousel .miniDot.active{background:rgba(0,0,0,.55)}

/* ===== CART UI ===== */
#cartFab{
  position:fixed;right:16px;bottom:16px;z-index:999;
  border:none;background:#111;color:#fff;width:56px;height:56px;
  border-radius:999px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;box-shadow:0 18px 45px rgba(0,0,0,.18);
}
#cartFab:active{transform:scale(.98)}
#cartFab .cartIcon{font-size:20px;line-height:1}
#cartFab .cartCount{
  position:absolute;top:-6px;right:-6px;min-width:22px;height:22px;padding:0 6px;
  border-radius:999px;background:#fff;color:#111;border:1px solid rgba(0,0,0,.12);
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;
}
.cartBackdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(2px);
  z-index:998;opacity:0;pointer-events:none;transition:opacity .22s ease;
}
.cartBackdrop.open{opacity:1;pointer-events:auto}
.cartSheet{
  position:fixed;left:0;right:0;bottom:0;z-index:999;background:#fff;
  border-top-left-radius:18px;border-top-right-radius:18px;
  box-shadow:0 -18px 45px rgba(0,0,0,.18);
  transform:translateY(105%);transition:transform .25s ease;
  max-height:78vh;display:flex;flex-direction:column;
}
.cartSheet.open{transform:translateY(0)}
.cartHeader{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 10px;border-bottom:1px solid rgba(0,0,0,.08);
}
.cartTitle{font-size:16px;font-weight:600}
.cartSubtitle{font-size:12px;opacity:.7;margin-top:2px}
.cartClose{
  border:1px solid rgba(0,0,0,.12);background:#fff;width:38px;height:38px;
  border-radius:999px;cursor:pointer;
}
.cartItems{padding:12px 16px;overflow:auto;flex:1}
.cartItem{
  display:grid;grid-template-columns:64px 1fr auto;gap:10px;
  padding:12px 0;border-bottom:1px solid rgba(0,0,0,.06);align-items:start;
}
.cartItem:last-child{border-bottom:none}
.cartThumb{
  width:64px;height:64px;border-radius:12px;object-fit:cover;
  border:1px solid rgba(0,0,0,.08);background:#faf7f2;
}
.cartItemName{font-size:14px;font-weight:600}
.cartItemMeta{font-size:12px;opacity:.75;margin-top:4px;line-height:1.25}
.cartItemPrice{font-size:13px;font-weight:600;margin-top:6px}
.qtyControls{display:flex;align-items:center;gap:8px}
.qtyBtn{
  width:34px;height:34px;border-radius:10px;border:1px solid rgba(0,0,0,.12);
  background:#fff;cursor:pointer;
}
.qtyVal{min-width:18px;text-align:center;font-weight:600}
.removeBtn{
  margin-top:8px;border:none;background:transparent;cursor:pointer;
  font-size:12px;opacity:.7;text-decoration:underline;
}
.cartFooter{
  padding:12px 16px 16px;border-top:1px solid rgba(0,0,0,.08);background:#fff;
}
.cartTotalRow{display:flex;align-items:center;justify-content:space-between;padding:8px 0 12px;font-size:14px}
.cartPrimary{
  width:100%;border:none;background:#111;color:#fff;padding:12px 14px;border-radius:14px;
  cursor:pointer;font-weight:600;
}
.cartSecondary{
  width:100%;margin-top:10px;border:1px solid rgba(0,0,0,.12);background:#fff;color:#111;
  padding:12px 14px;border-radius:14px;cursor:pointer;font-weight:600;
}
@media (min-width:901px){
  .cartSheet{
    left:auto;width:420px;right:16px;bottom:16px;border-radius:18px;max-height:70vh;
    transform:translateY(0) translateX(110%);
  }
  .cartSheet.open{transform:translateY(0) translateX(0)}
}
