/* ═══════════════════════════════════════════════
   LUNA AURUM JEWELRY — Luxury CSS
   Paleta: #FFFFEF · #F5F1EB · #E8DCD0 · #C6A96B · #1A1A1A
═══════════════════════════════════════════════ */

/* ── Variables ─────────────────────────────── */
:root {
  --white:      #FFFFEF;
  --cream:      #F5F1EB;
  --nude:       #E8DCD0;
  --gold:       #C6A96B;
  --gold-dark:  #A8894A;
  --gold-light: #DCC896;
  --gold-bg:    rgba(198,169,107,.08);
  --black:      #1A1A1A;
  --text:       #2C2C2C;
  --text-muted: #7A7A6A;
  --border:     rgba(198,169,107,.25);
  --shadow:     0 8px 40px rgba(26,26,26,.10);
  --shadow-lg:  0 20px 60px rgba(26,26,26,.18);
  --radius:     8px;
  --radius-lg:  16px;
  --serif:      'Cormorant Garamond', Georgia, serif;
  --sans:       'Montserrat', system-ui, sans-serif;
  --nav-h:      76px;
  --transition: .4s cubic-bezier(.25,.8,.25,1);
}



/* ── Reset ─────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--sans); background:var(--white); color:var(--text); line-height:1.7; overflow-x:hidden; }
img  { display:block; width:100%; height:100%; object-fit:cover; }
a    { text-decoration:none; color:inherit; }
ul   { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }

/* ── Utilities ─────────────────────────────── */
.container { max-width:1260px; margin:0 auto; padding:0 24px; }
.btn-gold {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--gold); color:#fff;
  padding:14px 32px; border-radius:var(--radius);
  font-family:var(--sans); font-size:.8rem; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase;
  transition:var(--transition); border:2px solid var(--gold);
}
.btn-gold:hover { background:var(--gold-dark); border-color:var(--gold-dark); transform:translateY(-2px); }
.btn-gold--full { width:100%; justify-content:center; }
.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; color:#fff;
  padding:14px 32px; border-radius:var(--radius);
  font-family:var(--sans); font-size:.8rem; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase;
  border:2px solid rgba(255,255,255,.5); transition:var(--transition);
}
.btn-outline:hover { border-color:#fff; background:rgba(255,255,255,.1); }
.badge { display:inline-block; font-size:.65rem; font-weight:600; letter-spacing:.08em; padding:3px 10px; border-radius:20px; text-transform:uppercase; }
.badge--gold { background:var(--gold); color:#fff; }
.badge--red  { background:#c0392b;   color:#fff; }

.about__features { display:flex; flex-direction:column; gap:12px; padding:4px 0; }
.about__features li { display:flex; align-items:center; gap:14px; font-size:.88rem; color:var(--text); }
.about__features li i { color:var(--gold); font-size:.95rem; width:18px; text-align:center; flex-shrink:0; }

/* ── Scroll reveal ─────────────────────────── */
.reveal { opacity:0; transform:translateY(36px); transition:opacity .8s ease,transform .8s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── Section header ────────────────────────── */
.section-header { text-align:center; margin-bottom:56px; }
.section-header__sub {
  font-family:var(--sans); font-size:.72rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--gold);
  display:block; margin-bottom:12px;
}
.section-header__title {
  font-family:var(--serif); font-size:clamp(2rem,4vw,3rem); font-weight:400;
  color:var(--black); line-height:1.15;
}
.section-header__title em { font-style:italic; color:var(--gold); }

/* ══════════ LOADER ════════════ */
.loader {
  position:fixed; inset:0; background:var(--black); z-index:9999;
  display:flex; align-items:center; justify-content:center;
  transition:opacity .6s ease, visibility .6s ease;
}

.navbar__logo img{
  width:42px;
  height:42px;
  object-fit:contain;
}

.loader__logo{
  width:90px;
  height:90px;
  object-fit:contain;
  margin-bottom:20px;
  display:flex;
  justify-content:center;
  align-items:center;
}

.loader.done { opacity:0; visibility:hidden; }
.loader__content { text-align:center; }
.loader__logo {
  font-size:3rem; color:var(--gold); animation:loaderPulse 1.5s ease infinite;
  display:block; margin-bottom:12px;
}
@keyframes loaderPulse { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.15);opacity:.7} }
.loader__name {
  font-family:var(--serif); font-size:1.6rem; font-weight:300;
  color:var(--white); letter-spacing:.25em; margin-bottom:28px;
}
.loader__bar { width:180px; height:2px; background:rgba(255,255,255,.15); border-radius:2px; overflow:hidden; }
.loader__fill { width:0; height:100%; background:var(--gold); border-radius:2px; animation:loaderBar 1.8s ease forwards; }
@keyframes loaderBar { to { width:100%; } }

/* ══════════ NAVBAR ════════════ */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:900;
  transition:background var(--transition), box-shadow var(--transition), border-color var(--transition);
  border-bottom:1px solid transparent;
}
.navbar.scrolled {
  background:rgba(245,241,235,.96); backdrop-filter:blur(12px);
  box-shadow:var(--shadow); border-color:var(--border);
}
.navbar__inner {
  max-width:1260px; margin:0 auto; padding:0 24px;
  height:var(--nav-h); display:flex; align-items:center; gap:24px;
}
.navbar__logo {
  display:flex; align-items:center; gap:10px; flex-shrink:0;
  font-family:var(--serif); font-weight:500; letter-spacing:.1em;
  font-size:1.25rem; color:#fff; transition:color var(--transition);
}
.navbar.scrolled .navbar__logo { color:var(--black); }
.navbar__logo-moon { font-size:1.4rem; color:var(--gold); }
.navbar__nav {
  display:flex; gap:32px; margin:0 auto;
}
.navbar__nav a {
  font-size:.73rem; font-weight:500; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.85); position:relative; transition:color var(--transition);
  padding-bottom:4px;
}
.navbar__nav a::after {
  content:''; position:absolute; bottom:0; left:0; width:0; height:1px;
  background:var(--gold); transition:width var(--transition);
}
.navbar__nav a:hover { color:#fff; }
.navbar__nav a:hover::after { width:100%; }
.navbar.scrolled .navbar__nav a { color:var(--text-muted); }
.navbar.scrolled .navbar__nav a:hover { color:var(--gold); }
.navbar__actions { display:flex; align-items:center; gap:4px; }
.navbar__icon {
  width:42px; height:42px; display:flex; align-items:center; justify-content:center;
  border-radius:50%; color:#fff; font-size:.95rem; position:relative;
  transition:background var(--transition), color var(--transition);
}
.navbar__icon:hover { background:rgba(255,255,255,.15); }
.navbar.scrolled .navbar__icon { color:var(--black); }
.navbar.scrolled .navbar__icon:hover { background:var(--nude); }
.navbar__cart-count {
  position:absolute; top:6px; right:6px; width:16px; height:16px;
  background:var(--gold); color:#fff; border-radius:50%;
  font-size:.6rem; font-weight:700; display:flex; align-items:center; justify-content:center;
  line-height:1; transition:transform .2s;
}
.navbar__cart-count.bump { animation:cartBump .3s ease; }
@keyframes cartBump { 0%{transform:scale(1)} 50%{transform:scale(1.4)} 100%{transform:scale(1)} }
.navbar__burger { display:none; flex-direction:column; gap:5px; padding:8px; }
.navbar__burger span { display:block; width:24px; height:2px; background:currentColor; border-radius:2px; transition:var(--transition); }
.navbar.scrolled .navbar__burger { color:var(--black); }
.navbar__burger:not(.scrolled) { color:#fff; }

/* Search bar */
.search-bar {
  background:var(--cream); border-top:1px solid var(--border);
  max-height:0; overflow:hidden; transition:max-height .4s ease;
}
.search-bar.open { max-height:72px; }
.search-bar__inner {
  max-width:600px; margin:0 auto; padding:14px 24px;
  display:flex; align-items:center; gap:12px;
}
.search-bar__inner i { color:var(--gold); }
.search-bar__inner input {
  flex:1; border:none; background:none; font-family:var(--sans);
  font-size:.9rem; color:var(--text); outline:none;
}
#search-close { color:var(--text-muted); font-size:.85rem; }

/* Mobile nav */
.mobile-nav {
  position:fixed; top:0; left:-100%; width:300px; height:100%;
  background:var(--black); z-index:950; padding:32px 28px;
  display:flex; flex-direction:column; gap:24px;
  transition:left .4s cubic-bezier(.25,.8,.25,1);
}
.mobile-nav.open { left:0; }
.mobile-nav__close { color:var(--gold); font-size:1.2rem; align-self:flex-end; }
.mobile-nav__logo { font-family:var(--serif); font-size:1.4rem; color:var(--white); letter-spacing:.1em; }
.mobile-nav__links { display:flex; flex-direction:column; gap:4px; margin-top:8px; }
.mobile-nav__link {
  font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; font-weight:500;
  color:rgba(255,255,255,.7); padding:14px 0; border-bottom:1px solid rgba(255,255,255,.06);
  transition:color var(--transition);
}
.mobile-nav__link:hover { color:var(--gold); }
.mobile-nav__contact { font-size:.8rem; color:var(--gold); margin-top:auto; display:flex; align-items:center; gap:8px; }
.mobile-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:940;
  opacity:0; visibility:hidden; transition:var(--transition);
}
.mobile-overlay.show { opacity:1; visibility:visible; }

/* ══════════ HERO ════════════ */
.hero {
  position:relative; min-height:100dvh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.hero__bg {
  position:absolute; inset:0;
  background-image:url('https://images.unsplash.com/photo-1617038260897-41a1f14a8ca0?w=1920&h=1200&fit=crop&auto=format');
  background-size:cover; background-position:center;
  transform:scale(1.05); transition:transform 8s ease;
}
.hero__bg.loaded { transform:scale(1); }
.hero__overlay {
  position:absolute; inset:0;
  background:linear-gradient(160deg,rgba(26,26,26,.75) 0%,rgba(26,26,26,.55) 50%,rgba(26,26,26,.4) 100%);
}
.hero__particles { position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.particle {
  position:absolute; border-radius:50%; background:var(--gold);
  animation:floatUp linear infinite;
}
@keyframes floatUp {
  0%   { transform:translateY(100vh) translateX(0); opacity:0; }
  5%   { opacity:1; }
  95%  { opacity:.4; }
  100% { transform:translateY(-10vh) translateX(var(--dx,20px)); opacity:0; }
}
.hero__content {
  position:relative; z-index:2; text-align:center;
  padding:0 24px; max-width:720px;
}
.hero__sub {
  font-family:var(--sans); font-size:.72rem; font-weight:600;
  letter-spacing:.25em; text-transform:uppercase; color:var(--gold);
  display:block; margin-bottom:20px;
}
.hero__title {
  font-family:var(--serif); font-size:clamp(3rem,7vw,6rem); font-weight:400;
  color:#fff; line-height:1.05; margin-bottom:20px;
}
.hero__title em { font-style:italic; color:var(--gold); }
.hero__desc { color:rgba(255,255,255,.8); font-size:1rem; margin-bottom:36px; line-height:1.8; }
.hero__btns { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.hero__scroll {
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px; z-index:2;
  color:rgba(255,255,255,.6); font-size:.65rem; letter-spacing:.15em; text-transform:uppercase;
  animation:scrollBob 2s ease infinite;
}
@keyframes scrollBob { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(6px)} }
.hero__scroll-line { width:1px; height:40px; background:linear-gradient(rgba(255,255,255,.6),transparent); }

/* ══════════ MARQUEE ════════════ */
.marquee { background:var(--gold); overflow:hidden; padding:14px 0; }
.marquee__track {
  display:flex; gap:40px; width:max-content;
  animation:marqueeScroll 25s linear infinite;
  white-space:nowrap;
}
.marquee__track span {
  font-family:var(--sans); font-size:.7rem; font-weight:600;
  letter-spacing:.15em; text-transform:uppercase; color:#fff;
  flex-shrink:0;
}
@keyframes marqueeScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ══════════ CATEGORIES ════════════ */
.categories { padding:100px 0; background:var(--white); }
.categories__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.cat-card {
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  aspect-ratio:3/4; cursor:pointer;
  box-shadow:var(--shadow);
  transition:transform var(--transition), box-shadow var(--transition);
}
.cat-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.cat-card__img-wrap { position:absolute; inset:0; }
.cat-card__img-wrap img { transition:transform .7s ease; }
.cat-card:hover .cat-card__img-wrap img { transform:scale(1.07); }
.cat-card::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top,rgba(26,26,26,.85) 0%,rgba(26,26,26,.1) 60%,transparent 100%);
}
.cat-card__body {
  position:absolute; bottom:0; left:0; right:0; z-index:2;
  padding:28px 24px; color:#fff;
}
.cat-card__body h3 { font-family:var(--serif); font-size:1.5rem; font-weight:400; margin-bottom:6px; }
.cat-card__body span { font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); display:flex; align-items:center; gap:8px; }
.cat-card__body span i { transition:transform var(--transition); }
.cat-card:hover .cat-card__body span i { transform:translateX(6px); }

/* ══════════ FEATURED / SWIPER ════════════ */
.featured { padding:100px 0; background:var(--cream); }
.featured-swiper { padding-bottom:48px !important; }
.featured-swiper .swiper-slide { width:280px; }
.featured-prev,.featured-next {
  color:var(--gold) !important;
}
.featured-prev::after,.featured-next::after { font-size:1.1rem !important; }
.swiper-pagination-bullet-active { background:var(--gold) !important; }

/* ══════════ PRODUCTS ════════════ */
.products { padding:100px 0; }
.products__filters { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-bottom:48px; }
.filter-btn {
  padding:9px 22px; border-radius:40px;
  font-family:var(--sans); font-size:.72rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
  border:1.5px solid var(--nude); color:var(--text-muted);
  transition:var(--transition);
}
.filter-btn:hover, .filter-btn.active {
  background:var(--gold); border-color:var(--gold); color:#fff;
}
.products__grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:28px;
}
.product-card {
  background:#fff; border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow); transition:transform var(--transition), box-shadow var(--transition);
  cursor:pointer;
}
.product-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.product-card__img-wrap {
  position:relative; aspect-ratio:1; overflow:hidden;
  background:var(--nude);
}
.product-card__img-wrap img { transition:transform .7s ease; }
.product-card:hover .product-card__img-wrap img { transform:scale(1.08); }
.product-card__badges { position:absolute; top:12px; left:12px; display:flex; flex-direction:column; gap:6px; z-index:2; }
.product-card__actions {
  position:absolute; bottom:0; left:0; right:0; z-index:3;
  display:flex; flex-direction:column; gap:0;
  transform:translateY(100%); transition:transform var(--transition);
}
.product-card:hover .product-card__actions { transform:translateY(0); }
.product-card__quick {
  background:rgba(26,26,26,.75); color:#fff;
  padding:10px; font-size:.8rem; text-align:center;
  display:flex; align-items:center; justify-content:center;
}
.product-card__add {
  background:var(--gold); color:#fff;
  padding:13px; font-size:.72rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
  display:flex; align-items:center; justify-content:center; gap:8px;
  transition:background var(--transition);
}
.product-card__add:hover { background:var(--gold-dark); }
.product-card__body { padding:18px 20px; }
.product-card__cat { font-size:.65rem; letter-spacing:.15em; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.product-card__name { font-family:var(--serif); font-size:1.1rem; font-weight:500; color:var(--black); margin-bottom:10px; line-height:1.3; }
.product-card__price-wrap { display:flex; gap:10px; align-items:baseline; flex-wrap:wrap; }
.product-card__price { font-size:.9rem; font-weight:600; color:var(--text); }
.product-card__price--old { text-decoration:line-through; color:var(--text-muted); font-weight:400; font-size:.82rem; }
.product-card__price--sale { color:#c0392b; }

/* Product card hidden */
.product-card.hidden { display:none; }

/* ══════════ OFFERS BANNER ════════════ */
.offers-banner { position:relative; padding:100px 0; overflow:hidden; }
.offers-banner__bg {
  position:absolute; inset:0;
  background:linear-gradient(135deg,#1A1A1A 0%,#2a2010 100%);
}
.offers-banner__inner { position:relative; z-index:2; display:grid; grid-template-columns:1fr 2fr; gap:60px; align-items:start; }
.offers-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.offers-banner .product-card { background:#fff; }

/* ══════════ ABOUT ════════════ */
.about { padding:100px 0; background:var(--cream); }
.about__inner { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about__img-wrap { position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:3/4; }
.about__img-badge {
  position:absolute; bottom:28px; right:-20px;
  background:var(--gold); color:#fff; border-radius:var(--radius);
  padding:16px 20px; text-align:center; box-shadow:var(--shadow-lg);
}
.about__img-badge-num { display:block; font-family:var(--serif); font-size:2.5rem; line-height:1; font-weight:500; }
.about__img-badge-num small { font-size:1rem; }
.about__img-badge-txt { font-size:.65rem; letter-spacing:.15em; text-transform:uppercase; }
.about__content { display:flex; flex-direction:column; gap:20px; }
.about__content p { color:var(--text-muted); line-height:1.9; }
.about__stats { display:flex; gap:32px; padding:28px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin:8px 0; }
.about__stat { text-align:center; }
.about__stat-num { display:block; font-family:var(--serif); font-size:2.2rem; font-weight:500; color:var(--gold); }
.about__stat-label { font-size:.65rem; letter-spacing:.1em; text-transform:uppercase; color:var(--text-muted); }

/* ══════════ PROMISES ════════════ */
.promises { padding:80px 0; background:var(--black); }
.promises__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:40px; }
.promise-item { text-align:center; color:#fff; }
.promise-item i { font-size:2rem; color:var(--gold); margin-bottom:16px; display:block; }
.promise-item h4 { font-family:var(--serif); font-size:1.15rem; font-weight:400; margin-bottom:10px; }
.promise-item p { font-size:.8rem; color:rgba(255,255,255,.6); line-height:1.7; }

/* ══════════ TESTIMONIALS ════════════ */
.testimonials { padding:100px 0; background:var(--white); }
.testimonials-swiper { padding-bottom:48px !important; }
.testimonial-card {
  background:var(--cream); border-radius:var(--radius-lg);
  padding:36px; border:1px solid var(--border);
}
.testimonial-card__stars { color:var(--gold); font-size:.85rem; margin-bottom:16px; display:flex; gap:4px; }
.testimonial-card__text { font-family:var(--serif); font-size:1.1rem; font-style:italic; color:var(--text); line-height:1.8; margin-bottom:24px; }
.testimonial-card__author { display:flex; align-items:center; gap:14px; }
.testimonial-card__avatar {
  width:44px; height:44px; border-radius:50%; background:var(--gold);
  color:#fff; font-family:var(--serif); font-size:1.3rem;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.testimonial-card__author strong { display:block; font-size:.88rem; font-weight:600; }
.testimonial-card__author span { font-size:.75rem; color:var(--text-muted); }

/* ══════════ GALLERY CTA ════════════ */
.gallery-cta { display:grid; grid-template-columns:1fr 1fr; }
.gallery-cta__grid { display:grid; grid-template-columns:repeat(3,1fr); }
.gallery-cta__item { position:relative; aspect-ratio:1; overflow:hidden; }
.gallery-cta__item img { transition:transform .7s ease; }
.gallery-cta__item:hover img { transform:scale(1.1); }
.gallery-cta__overlay {
  position:absolute; inset:0; background:rgba(198,169,107,.5);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity var(--transition); color:#fff; font-size:1.5rem;
}
.gallery-cta__item:hover .gallery-cta__overlay { opacity:1; }
.gallery-cta__text {
  background:var(--nude); display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:20px; padding:60px 48px; text-align:center;
}

/* ══════════ FOOTER ════════════ */
.footer { background:var(--black); color:rgba(255,255,255,.7); padding:80px 0 0; }
.footer__inner { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:48px; padding-bottom:60px; }
.footer__logo { font-family:var(--serif); font-size:1.5rem; color:#fff; letter-spacing:.1em; margin-bottom:16px; }
.footer__brand p { font-size:.82rem; line-height:1.8; }
.footer__socials { display:flex; gap:12px; margin-top:24px; }
.footer__socials a {
  width:38px; height:38px; border-radius:50%;
  border:1px solid rgba(255,255,255,.2); color:rgba(255,255,255,.7);
  display:flex; align-items:center; justify-content:center; font-size:.85rem;
  transition:var(--transition);
}
.footer__socials a:hover { background:var(--gold); border-color:var(--gold); color:#fff; }
.footer__col h4 { font-family:var(--serif); font-size:1rem; font-weight:500; color:#fff; margin-bottom:20px; }
.footer__col ul { display:flex; flex-direction:column; gap:10px; }
.footer__col ul li a { font-size:.78rem; transition:color var(--transition); }
.footer__col ul li a:hover { color:var(--gold); }
.footer__contact { display:flex; flex-direction:column; gap:12px; }
.footer__contact li { display:flex; align-items:flex-start; gap:10px; font-size:.78rem; }
.footer__contact li i { color:var(--gold); margin-top:3px; flex-shrink:0; }
.footer__contact li a:hover { color:var(--gold); }
.footer__bottom {
  border-top:1px solid rgba(255,255,255,.08); padding:22px 0;
  display:flex; justify-content:space-between; align-items:center;
  font-size:.72rem; max-width:1260px; margin:0 auto; padding-left:24px; padding-right:24px;
}

/* ══════════ CART DRAWER ════════════ */
.cart-drawer { position:fixed; inset:0; z-index:800; pointer-events:none; }
.cart-drawer.open { pointer-events:all; }
.cart-drawer__overlay { position:absolute; inset:0; background:rgba(26,26,26,.55); opacity:0; transition:opacity var(--transition); }
.cart-drawer.open .cart-drawer__overlay { opacity:1; }
.cart-drawer__panel {
  position:absolute; top:0; right:0; bottom:0; width:min(400px,100vw);
  background:#fff; display:flex; flex-direction:column;
  transform:translateX(100%); transition:transform var(--transition);
  box-shadow:-20px 0 60px rgba(0,0,0,.15);
}
.cart-drawer.open .cart-drawer__panel { transform:translateX(0); }
.cart-drawer__header {
  padding:24px 28px; border-bottom:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center;
}
.cart-drawer__header h3 { font-family:var(--serif); font-size:1.2rem; font-weight:500; }
.cart-drawer__header button { color:var(--text-muted); font-size:1rem; transition:color var(--transition); }
.cart-drawer__header button:hover { color:var(--black); }
.cart-drawer__body { flex:1; overflow-y:auto; padding:16px; }
.cart-empty {
  text-align:center; padding:60px 20px; color:var(--text-muted);
}
.cart-empty i { font-size:3rem; color:var(--nude); margin-bottom:16px; display:block; }
.cart-empty p { font-size:.85rem; }
.cart-item { display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--border); }
.cart-item__img { width:72px; height:72px; border-radius:var(--radius); overflow:hidden; flex-shrink:0; background:var(--nude); }
.cart-item__info { flex:1; min-width:0; }
.cart-item__name { font-size:.85rem; font-weight:600; color:var(--black); line-height:1.3; margin-bottom:6px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cart-item__price { font-size:.8rem; color:var(--gold); font-weight:600; margin-bottom:10px; }
.cart-item__controls { display:flex; align-items:center; gap:10px; }
.cart-item__controls button { width:26px; height:26px; border-radius:50%; border:1px solid var(--border); font-size:.8rem; display:flex; align-items:center; justify-content:center; transition:var(--transition); }
.cart-item__controls button:hover { background:var(--gold); border-color:var(--gold); color:#fff; }
.cart-item__controls span { font-size:.85rem; font-weight:600; min-width:20px; text-align:center; }
.cart-item__remove { margin-left:auto; color:var(--text-muted); font-size:.8rem; padding:4px; transition:color var(--transition); }
.cart-item__remove:hover { color:#c0392b; }
.cart-drawer__footer { padding:20px 24px; border-top:1px solid var(--border); }
.cart-drawer__total { display:flex; justify-content:space-between; font-size:1rem; margin-bottom:14px; }
.cart-drawer__total strong { font-family:var(--serif); font-size:1.2rem; color:var(--gold); }
.cart-drawer__note { font-size:.72rem; color:var(--text-muted); text-align:center; margin-bottom:16px; display:flex; align-items:center; justify-content:center; gap:6px; }

/* ══════════ PRODUCT MODAL ════════════ */
.product-modal { position:fixed; inset:0; z-index:800; display:flex; align-items:center; justify-content:center; pointer-events:none; }
.product-modal.open { pointer-events:all; }
.product-modal__overlay { position:absolute; inset:0; background:rgba(26,26,26,.7); opacity:0; transition:opacity var(--transition); }
.product-modal.open .product-modal__overlay { opacity:1; }
.product-modal__box {
  position:relative; background:#fff; border-radius:var(--radius-lg);
  width:min(860px,95vw); max-height:90vh; overflow-y:auto;
  transform:scale(.92) translateY(20px); opacity:0; transition:var(--transition);
  box-shadow:var(--shadow-lg);
}
.product-modal.open .product-modal__box { transform:scale(1) translateY(0); opacity:1; }
.product-modal__close {
  position:absolute; top:16px; right:16px; z-index:5;
  width:36px; height:36px; border-radius:50%; background:rgba(26,26,26,.08);
  display:flex; align-items:center; justify-content:center; font-size:.85rem;
  transition:background var(--transition);
}
.product-modal__close:hover { background:rgba(26,26,26,.18); }
.product-modal__inner { display:grid; grid-template-columns:1fr 1fr; }
.pm-img { aspect-ratio:1; overflow:hidden; border-radius:var(--radius-lg) 0 0 var(--radius-lg); }
.pm-body { padding:48px 40px; display:flex; flex-direction:column; gap:16px; }
.pm-cat { font-size:.65rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); }
.pm-name { font-family:var(--serif); font-size:1.8rem; font-weight:400; color:var(--black); line-height:1.2; }
.pm-prices { display:flex; gap:12px; align-items:baseline; }
.pm-price { font-size:1.3rem; font-weight:600; color:var(--gold); }
.pm-price-old { font-size:1rem; text-decoration:line-through; color:var(--text-muted); }
.pm-desc { font-size:.88rem; color:var(--text-muted); line-height:1.9; }
.pm-add { margin-top:auto; display:flex; flex-direction:column; gap:10px; }

/* ══════════ WHATSAPP FLOAT ════════════ */
.wa-float {
  position:fixed; bottom:28px; right:28px; z-index:700;
  width:58px; height:58px; border-radius:50%;
  background:#25D366; color:#fff; font-size:1.6rem;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 30px rgba(37,211,102,.45);
  animation:waPulse 2.5s ease infinite;
  transition:transform var(--transition);
}
.wa-float:hover { transform:scale(1.1); }
@keyframes waPulse { 0%,100%{box-shadow:0 8px 30px rgba(37,211,102,.45)} 50%{box-shadow:0 8px 50px rgba(37,211,102,.7)} }
.wa-float__tooltip {
  position:absolute; right:68px;
  background:var(--black); color:#fff; border-radius:var(--radius);
  font-size:.72rem; font-weight:600; padding:6px 14px; white-space:nowrap;
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.wa-float__tooltip::after {
  content:''; position:absolute; left:100%; top:50%;
  transform:translateY(-50%); border:6px solid transparent;
  border-left-color:var(--black);
}
.wa-float:hover .wa-float__tooltip { opacity:1; }

/* ══════════ TOAST ════════════ */
.toast-container { position:fixed; bottom:100px; right:24px; z-index:1000; display:flex; flex-direction:column; gap:10px; }
.toast {
  background:var(--black); color:#fff; padding:14px 20px; border-radius:var(--radius);
  font-size:.8rem; display:flex; align-items:center; gap:10px;
  border-left:3px solid var(--gold); box-shadow:var(--shadow-lg);
  transform:translateX(120%); animation:toastIn .4s ease forwards;
  max-width:300px;
}
.toast.error { border-color:#c0392b; }
.toast.success { border-color:#27ae60; }
@keyframes toastIn { to { transform:translateX(0); } }

/* ══════════ RESPONSIVE ════════════ */
@media (max-width:1024px) {
  .categories__grid { grid-template-columns:repeat(2,1fr); }
  .promises__grid   { grid-template-columns:repeat(2,1fr); }
  .footer__inner    { grid-template-columns:1fr 1fr; gap:36px; }
  .about__inner     { grid-template-columns:1fr; gap:48px; }
  .about__img-wrap  { max-width:480px; margin:0 auto; }
  .gallery-cta      { grid-template-columns:1fr; }
  .gallery-cta__text { padding:60px; }
  .offers-banner__inner { grid-template-columns:1fr; }
  .offers-grid { grid-template-columns:repeat(4,1fr); }
  .navbar__nav { display:none; }
  .navbar__burger { display:flex; }
}
@media (max-width:768px) {
  :root { --nav-h:64px; }
  .categories__grid { grid-template-columns:repeat(2,1fr); gap:14px; }
  .featured-swiper .swiper-slide { width:240px; }
  .products__grid { grid-template-columns:repeat(2,1fr); gap:16px; }
  .offers-grid { grid-template-columns:repeat(2,1fr); }
  .footer__inner { grid-template-columns:1fr; }
  .product-modal__inner { grid-template-columns:1fr; }
  .pm-img { border-radius:var(--radius-lg) var(--radius-lg) 0 0; }
  .gallery-cta__grid { grid-template-columns:repeat(3,1fr); }
  .about__stats { gap:20px; }
  .footer__bottom { flex-direction:column; gap:8px; text-align:center; }
}
@media (max-width:480px) {
  .hero__title { font-size:2.8rem; }
  .hero__btns { flex-direction:column; align-items:center; }
  .categories__grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .products__grid { grid-template-columns:1fr 1fr; gap:12px; }
  .product-card__body { padding:14px; }
  .product-card__name { font-size:1rem; }
  .promises__grid { grid-template-columns:1fr; }
}
