/* ═══════════════════════════════════════════════
   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 — Full redesign with aurora, beams & silhouettes
══════════════════════════════════════════════════ */
.loader {
  position:fixed; inset:0; z-index:9999;
  display:flex; align-items:center; justify-content:center;
  background:#040200;
  overflow:hidden;
  transition:opacity .9s ease, visibility .9s ease;
}
.loader.done { opacity:0; visibility:hidden; pointer-events:none; }

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

/* ── Aurora background blobs ── */
.loader__aurora { position:absolute; inset:0; pointer-events:none; }
.loader__aur { position:absolute; border-radius:50%; }
.loader__aur--1 {
  width:70vmax; height:70vmax; left:-15%; top:-15%;
  background:radial-gradient(circle, rgba(198,169,107,.13) 0%, rgba(168,137,74,.04) 45%, transparent 70%);
  filter:blur(70px); animation:aurDrift1 13s ease-in-out infinite;
}
.loader__aur--2 {
  width:60vmax; height:60vmax; right:-15%; bottom:-15%;
  background:radial-gradient(circle, rgba(168,137,74,.10) 0%, transparent 65%);
  filter:blur(80px); animation:aurDrift2 16s ease-in-out infinite;
}
.loader__aur--3 {
  width:50vmax; height:50vmax; left:50%; top:50%;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(220,200,150,.07) 0%, transparent 60%);
  filter:blur(55px); animation:aurPulse 5.5s ease-in-out infinite;
}
.loader__aur--4 {
  width:30vmax; height:30vmax; right:8%; top:12%;
  background:radial-gradient(circle, rgba(198,169,107,.07) 0%, transparent 60%);
  filter:blur(45px); animation:aurDrift3 10s ease-in-out 1.5s infinite;
}
@keyframes aurDrift1 {
  0%,100% { transform:translate(0,0) scale(1); }
  35%      { transform:translate(6%,9%) scale(1.18); }
  70%      { transform:translate(-5%,4%) scale(.88); }
}
@keyframes aurDrift2 {
  0%,100% { transform:translate(0,0) scale(1); }
  40%      { transform:translate(-7%,-6%) scale(1.22); }
  70%      { transform:translate(5%,-9%) scale(1.06); }
}
@keyframes aurPulse {
  0%,100% { transform:translate(-50%,-50%) scale(1);   opacity:.45; }
  50%      { transform:translate(-50%,-50%) scale(1.8); opacity:1; }
}
@keyframes aurDrift3 {
  0%,100% { transform:translate(0,0); }
  50%      { transform:translate(-9%,14%); }
}

/* ── Diagonal light beams ── */
.loader__beams { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.loader__beam {
  position:absolute; top:-30%; bottom:-30%; width:1px;
  background:linear-gradient(180deg,
    transparent 0%, transparent 15%,
    rgba(220,200,150,.22) 50%,
    transparent 85%, transparent 100%);
  transform:rotate(-28deg) scaleY(0); transform-origin:50% 0;
  opacity:0;
}
.loader__beam--1 { left:14%; animation:beamAppear  9s ease-in-out  .3s infinite; }
.loader__beam--2 { left:36%; width:2px; animation:beamAppear 11s ease-in-out 3.2s infinite; }
.loader__beam--3 { left:62%; animation:beamAppear  8s ease-in-out  6s infinite; }
.loader__beam--4 { left:83%; animation:beamAppear 13s ease-in-out  1s infinite; }
@keyframes beamAppear {
  0%,100% { opacity:0; transform:rotate(-28deg) scaleY(0); }
  12%,88% { opacity:1; transform:rotate(-28deg) scaleY(1); }
}

/* ── Drifting jewelry silhouettes ── */
.loader__silhouettes { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.loader__sil { position:absolute; color:#DCC896; opacity:0; will-change:transform,opacity; }

.loader__sil--1 { width:130px; bottom:18%; left:-170px;  animation:silL1 20s linear  1s infinite; }
.loader__sil--2 { width:80px;  top:10%;    right:-110px; animation:silR1 26s linear  5s infinite; }
.loader__sil--3 { font-size:88px; bottom:4%; left:-120px; letter-spacing:0; animation:silL2 30s linear 12s infinite; }
.loader__sil--4 { width:65px;  top:42%;   left:-90px;   animation:silL3 22s linear  3s infinite; }
.loader__sil--5 { font-size:55px; top:68%; right:-80px; letter-spacing:0; animation:silR2 18s linear  8s infinite; }
.loader__sil--6 { width:105px; top:22%;   left:-145px;  animation:silL4 35s linear 16s infinite; }

@keyframes silL1 {
  0%   { opacity:0; transform:translate(0,0)       rotate(0deg)   scale(.85); }
  7%   { opacity:.055; }  90% { opacity:.055; }
  100% { opacity:0; transform:translate(120vw,-32vh) rotate(20deg)  scale(1.2); }
}
@keyframes silL2 {
  0%   { opacity:0; transform:translate(0,0)       rotate(0deg); }
  6%   { opacity:.04; }   92% { opacity:.04; }
  100% { opacity:0; transform:translate(120vw,-18vh) rotate(-8deg); }
}
@keyframes silL3 {
  0%   { opacity:0; transform:translate(0,0)       rotate(12deg)  scale(1); }
  8%   { opacity:.065; }  90% { opacity:.065; }
  100% { opacity:0; transform:translate(120vw, 28vh) rotate(35deg)  scale(1.15); }
}
@keyframes silL4 {
  0%   { opacity:0; transform:translate(0,0)       rotate(-6deg)  scale(.9); }
  6%   { opacity:.04; }   92% { opacity:.04; }
  100% { opacity:0; transform:translate(120vw, 42vh) rotate(18deg)  scale(1.3); }
}
@keyframes silR1 {
  0%   { opacity:0; transform:translate(0,0)       rotate(0deg)   scale(1); }
  7%   { opacity:.06; }   90% { opacity:.06; }
  100% { opacity:0; transform:translate(-120vw, 38vh) rotate(-25deg) scale(1.1); }
}
@keyframes silR2 {
  0%   { opacity:0; transform:translate(0,0)       rotate(5deg); }
  8%   { opacity:.05; }   90% { opacity:.05; }
  100% { opacity:0; transform:translate(-120vw,-30vh) rotate(-18deg); }
}

/* ── Central glow ── */
.loader__glow {
  position:absolute; width:520px; height:520px; border-radius:50%;
  background:radial-gradient(circle, rgba(198,169,107,.15) 0%, rgba(168,137,74,.06) 40%, transparent 68%);
  animation:loaderGlowPulse 3.2s ease-in-out infinite; pointer-events:none;
}
@keyframes loaderGlowPulse {
  0%,100% { transform:scale(1);   opacity:.55; }
  50%      { transform:scale(1.5); opacity:1; }
}

/* ── Concentric spinning rings (3 total) ── */
.loader__ring {
  position:absolute; width:200px; height:200px; border-radius:50%;
  border:1px solid rgba(198,169,107,.14);
  animation:loaderRingSpin 12s linear infinite; pointer-events:none;
}
.loader__ring::before {
  content:''; position:absolute; inset:-13px; border-radius:50%;
  border:2px solid transparent;
  border-top-color:#C6A96B;
  border-right-color:rgba(198,169,107,.28);
  animation:loaderRingSpin 2.5s linear infinite;
  box-shadow:0 0 14px rgba(198,169,107,.22), 0 0 30px rgba(198,169,107,.08);
}
.loader__ring::after {
  content:''; position:absolute; inset:-26px; border-radius:50%;
  border:1px solid transparent;
  border-bottom-color:rgba(220,200,150,.22);
  border-left-color:rgba(198,169,107,.1);
  animation:loaderRingSpin 5s linear infinite reverse;
}
.loader__ring--2 {
  width:290px; height:290px;
  border-color:rgba(198,169,107,.07);
  animation-duration:20s; animation-direction:reverse;
}
.loader__ring--2::before {
  animation-duration:4.2s;
  border-top-color:transparent;
  border-right-color:transparent;
  border-bottom-color:rgba(168,137,74,.35);
  border-left-color:rgba(198,169,107,.15);
  inset:-14px;
}
.loader__ring--2::after {
  animation-duration:9s;
  border-bottom-color:transparent;
  border-left-color:rgba(220,200,150,.14);
}
.loader__ring--3 {
  width:380px; height:380px;
  border-color:rgba(198,169,107,.04);
  animation-duration:28s;
}
.loader__ring--3::before {
  animation-duration:7s;
  border-top-color:rgba(198,169,107,.18);
  border-right-color:transparent;
  inset:-15px;
}
.loader__ring--3::after { display:none; }
@keyframes loaderRingSpin { to { transform:rotate(360deg); } }

/* ── Orbiting gem symbols ── */
.loader__orbit {
  position:absolute; width:210px; height:210px;
  animation:loaderRingSpin 9s linear infinite; pointer-events:none;
}
.loader__orb {
  position:absolute; font-size:.75rem; letter-spacing:0;
  color:#DCC896; opacity:.85;
  text-shadow:0 0 10px rgba(220,200,150,.9), 0 0 20px rgba(198,169,107,.5);
}
.loader__orb--1 { top:-7px;   left:50%;  transform:translateX(-50%);
  animation:orbPulse 2.4s ease-in-out infinite; }
.loader__orb--2 { top:50%;    right:-9px; transform:translateY(-50%);
  animation:orbPulse 2.4s ease-in-out .6s infinite; }
.loader__orb--3 { bottom:-7px;left:50%;  transform:translateX(-50%);
  animation:orbPulse 2.4s ease-in-out 1.2s infinite; }
.loader__orb--4 { top:50%;    left:-9px;  transform:translateY(-50%);
  animation:orbPulse 2.4s ease-in-out 1.8s infinite; }
@keyframes orbPulse {
  0%,100% { opacity:.4; transform:translateX(-50%) scale(.8); }
  50%      { opacity:1;  transform:translateX(-50%) scale(1.6); }
}

/* ── Gold floating particles ── */
.loader__particles { position:absolute; inset:0; pointer-events:none; }
.loader__particles span {
  position:absolute; border-radius:50%; background:#C6A96B;
  animation:loaderFloat linear infinite; opacity:0;
}
.loader__particles span:nth-child(1)  { width:2px; height:2px; left:8%;  top:25%; animation-duration:4.5s; animation-delay:0s;   }
.loader__particles span:nth-child(2)  { width:3px; height:3px; left:22%; top:65%; animation-duration:5.2s; animation-delay:.7s;  }
.loader__particles span:nth-child(3)  { width:2px; height:2px; left:38%; top:12%; animation-duration:3.8s; animation-delay:.3s;  }
.loader__particles span:nth-child(4)  { width:4px; height:4px; left:55%; top:72%; animation-duration:4.8s; animation-delay:1.1s; }
.loader__particles span:nth-child(5)  { width:2px; height:2px; left:70%; top:28%; animation-duration:3.5s; animation-delay:.5s;  }
.loader__particles span:nth-child(6)  { width:3px; height:3px; left:82%; top:58%; animation-duration:4.2s; animation-delay:1.4s; }
.loader__particles span:nth-child(7)  { width:2px; height:2px; left:14%; top:82%; animation-duration:3.2s; animation-delay:.2s;  }
.loader__particles span:nth-child(8)  { width:4px; height:4px; left:88%; top:18%; animation-duration:5.5s; animation-delay:.9s;  }
.loader__particles span:nth-child(9)  { width:2px; height:2px; left:48%; top:88%; animation-duration:4.1s; animation-delay:.6s;  }
.loader__particles span:nth-child(10) { width:3px; height:3px; left:65%; top:10%; animation-duration:3.9s; animation-delay:1.2s; }
.loader__particles span:nth-child(11) { width:3px; height:3px; left:30%; top:40%; animation-duration:4.4s; animation-delay:.4s;  }
.loader__particles span:nth-child(12) { width:2px; height:2px; left:60%; top:50%; animation-duration:3.6s; animation-delay:1.0s; }
.loader__particles span:nth-child(13) { width:4px; height:4px; left:75%; top:35%; animation-duration:5.0s; animation-delay:.2s;  }
.loader__particles span:nth-child(14) { width:2px; height:2px; left:42%; top:70%; animation-duration:4.3s; animation-delay:.8s;  }
.loader__particles span:nth-child(15) { width:3px; height:3px; left:18%; top:48%; animation-duration:3.7s; animation-delay:1.6s; }
.loader__particles span:nth-child(16) { width:2px; height:2px; left:92%; top:62%; animation-duration:4.9s; animation-delay:.5s;  }
@keyframes loaderFloat {
  0%   { transform:translateY(0)      scale(0);   opacity:0; }
  12%  { opacity:1; }
  88%  { opacity:.55; }
  100% { transform:translateY(-170px) scale(1.6); opacity:0; }
}

/* ── Logo wrap with corona glow ── */
.loader__logo-wrap {
  position:relative; margin-bottom:26px;
  display:inline-flex; align-items:center; justify-content:center;
}
.loader__logo-glow {
  position:absolute; inset:-28px; border-radius:50%; z-index:-1;
  background:radial-gradient(circle, rgba(198,169,107,.45) 0%, rgba(168,137,74,.15) 35%, transparent 70%);
  animation:loaderGlowPulse 2.2s ease-in-out infinite;
}
.loader__logo {
  width:78px; height:78px; object-fit:contain; display:block;
  filter:drop-shadow(0 0 24px rgba(198,169,107,.65));
  animation:loaderLogoPulse 2.5s ease-in-out infinite;
}
@keyframes loaderLogoPulse {
  0%,100% { filter:drop-shadow(0 0 18px rgba(198,169,107,.5)); }
  50%      { filter:drop-shadow(0 0 44px rgba(220,200,150,.95)) drop-shadow(0 0 90px rgba(198,169,107,.35)); }
}

/* ── Brand text & loading bar ── */
.loader__content {
  position:relative; z-index:10;
  display:flex; flex-direction:column; align-items:center; text-align:center;
}
.loader__brand {
  font-family:'Cormorant Garamond', Georgia, serif;
  font-size:2.1rem; font-weight:300; color:#DCC896;
  letter-spacing:.42em; text-transform:uppercase; margin-bottom:10px;
  animation:loaderFadeUp .9s ease .15s both;
}
.loader__brand-gem { font-size:.9rem; opacity:.5; letter-spacing:0; }
.loader__sub {
  font-family:'Montserrat', sans-serif;
  font-size:.58rem; font-weight:500; letter-spacing:.35em;
  text-transform:uppercase; color:rgba(198,169,107,.55); margin-bottom:42px;
  animation:loaderFadeUp .9s ease .35s both;
}
@keyframes loaderFadeUp {
  from { opacity:0; transform:translateY(14px); }
  to   { opacity:1; transform:translateY(0); }
}
.loader__bar {
  width:190px; height:1.5px;
  background:rgba(198,169,107,.1); border-radius:4px; overflow:hidden;
  animation:loaderFadeUp .9s ease .5s both;
}
.loader__fill {
  width:0; height:100%; border-radius:4px;
  background:linear-gradient(90deg, #A8894A 0%, #DCC896 35%, #fff8e0 50%, #DCC896 65%, #C6A96B 100%);
  box-shadow:0 0 16px rgba(198,169,107,.85), 0 0 32px rgba(198,169,107,.4);
  animation:loaderBar 2.2s cubic-bezier(.4,0,.2,1) .45s 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; }

/* ══════════ ORDERS DRAWER ════════════ */
.orders-drawer { position:fixed; inset:0; z-index:800; pointer-events:none; }
.orders-drawer.open { pointer-events:all; }
.orders-drawer__overlay { position:absolute; inset:0; background:rgba(26,26,26,.55); opacity:0; transition:opacity var(--transition); }
.orders-drawer.open .orders-drawer__overlay { opacity:1; }
.orders-drawer__panel {
  position:absolute; top:0; right:0; width:min(440px,100vw); height:100%;
  background:var(--white); box-shadow:var(--shadow-lg);
  display:flex; flex-direction:column;
  transform:translateX(100%); transition:transform var(--transition);
}
.orders-drawer.open .orders-drawer__panel { transform:translateX(0); }
.orders-drawer__header {
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 24px; border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.orders-drawer__header h3 { font-family:var(--serif); font-size:1.2rem; font-weight:500; }
.orders-drawer__header button { color:var(--text-muted); font-size:1rem; transition:color var(--transition); }
.orders-drawer__header button:hover { color:var(--black); }
.orders-drawer__body { flex:1; overflow-y:auto; padding:16px; }
.orders-drawer__footer { padding:20px 24px; border-top:1px solid var(--border); flex-shrink:0; }
.orders-drawer__loading { text-align:center; padding:40px 0; color:var(--text-muted); font-size:.88rem; }
.orders-drawer__empty { text-align:center; padding:48px 16px; color:var(--text-muted); }
.orders-drawer__empty i { font-size:2.5rem; color:var(--nude); margin-bottom:12px; display:block; }
.orders-drawer__empty p { font-size:.88rem; margin-bottom:20px; }

/* order card inside drawer */
.od-card { border:1px solid var(--border); border-radius:var(--radius); margin-bottom:14px; overflow:hidden; }
.od-card__head {
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px; background:var(--cream); gap:8px; flex-wrap:wrap;
}
.od-card__num { font-family:var(--serif); font-weight:600; font-size:.95rem; }
.od-card__date { font-size:.72rem; color:var(--text-muted); margin-left:6px; }
.od-badge {
  font-size:.65rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  padding:3px 8px; border-radius:20px;
}
.od-badge--paid   { background:#27ae6020; color:#27ae60; border:1px solid #27ae6040; }
.od-badge--pend   { background:#f39c1220; color:#f39c12; border:1px solid #f39c1240; }
.od-badge--failed { background:#c0392b20; color:#c0392b; border:1px solid #c0392b40; }
.od-badge--ship   { background:var(--nude); color:var(--text-muted); border:1px solid var(--border); }
.od-card__items { padding:10px 14px; display:flex; flex-direction:column; gap:8px; }
.od-item { display:flex; align-items:center; gap:10px; }
.od-item__img {
  width:44px; height:44px; border-radius:6px; overflow:hidden; flex-shrink:0;
  background:var(--nude); display:flex; align-items:center; justify-content:center; color:var(--text-muted);
}
.od-item__img img { width:100%; height:100%; object-fit:cover; }
.od-item__name { flex:1; font-size:.8rem; font-weight:500; line-height:1.3; }
.od-item__qty { font-size:.75rem; color:var(--text-muted); }
.od-item__price { font-size:.82rem; font-weight:600; color:var(--gold); white-space:nowrap; }
.od-card__foot {
  padding:10px 14px; border-top:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:6px;
}
.od-card__addr { font-size:.72rem; color:var(--text-muted); }
.od-card__total { font-family:var(--serif); font-size:1rem; font-weight:600; color:var(--gold); }

/* profile menu badge */
.profile-menu__badge {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:18px; height:18px; padding:0 5px;
  background:var(--gold); color:#fff; border-radius:10px;
  font-size:.65rem; font-weight:700; margin-left:auto;
}

/* post-checkout success banner */
.order-success-banner {
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%);
  z-index:900; width:min(640px,calc(100vw - 32px));
  background:var(--black); color:#fff; border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); animation:bannerSlideUp .4s ease;
}
.order-success-banner__inner {
  display:flex; align-items:center; gap:14px; padding:16px 20px; flex-wrap:wrap;
}
.order-success-banner i.fa-check-circle { font-size:1.6rem; color:#27ae60; flex-shrink:0; }
.order-success-banner div { flex:1; min-width:0; }
.order-success-banner strong { display:block; font-size:.9rem; }
.order-success-banner span  { font-size:.78rem; color:rgba(255,255,255,.7); }
@keyframes bannerSlideUp {
  from { transform:translateX(-50%) translateY(20px); opacity:0; }
  to   { transform:translateX(-50%) translateY(0);    opacity:1; }
}

/* ══════════ 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:60px; }
  .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; }
  /* Navbar compacta en móvil */
  .navbar__inner { padding:0 10px; gap:6px; }
  .navbar__logo  { gap:7px; }
  .navbar__logo img { width:34px; height:34px; }
  .navbar__logo-text { font-size:1.05rem; letter-spacing:.06em; }
  .navbar__actions { gap:0; }
  .navbar__icon { width:38px; height:38px; font-size:.88rem; }
}
@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; }
  /* Logo más a la izquierda, texto más pequeño */
  .navbar__inner { padding:0 8px; gap:4px; }
  .navbar__logo img { width:30px; height:30px; }
  .navbar__logo-text { font-size:.95rem; }
  .navbar__burger { padding:6px; }
  .navbar__icon { width:36px; height:36px; }
}
@media (max-width:380px) {
  /* En teléfonos muy pequeños ocultamos el texto del logo */
  .navbar__logo-text { display:none; }
  .navbar__inner { padding:0 6px; gap:2px; }
}

/* ══════════════════════════════════════════════════
   AUTH BUTTONS EN NAVBAR
══════════════════════════════════════════════════ */
.navbar__auth-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 14px; border-radius:var(--radius);
  font-family:var(--sans); font-size:.7rem; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  transition:var(--transition); cursor:pointer; border:none;
  white-space:nowrap;
}
.navbar__auth-btn--ghost {
  background:transparent; color:rgba(255,255,255,.85);
  border:1.5px solid rgba(255,255,255,.35);
}
.navbar__auth-btn--ghost:hover { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.6); color:#fff; }
.navbar.scrolled .navbar__auth-btn--ghost { color:var(--text); border-color:var(--border); }
.navbar.scrolled .navbar__auth-btn--ghost:hover { background:var(--nude); }
.navbar__auth-btn--gold { background:var(--gold); color:#fff; border:1.5px solid var(--gold); }
.navbar__auth-btn--gold:hover { background:var(--gold-dark); border-color:var(--gold-dark); }
.navbar__auth-label { display:none; }
@media(min-width:480px) { .navbar__auth-label { display:inline; } }

/* Mostrar botones desktop / ícono móvil */
.navbar__auth-mobile { display:none !important; }
@media(max-width:600px) {
  .navbar__auth-desktop { display:none !important; }
  .navbar__auth-mobile  { display:flex !important; }
}

/* ── Auth links en menú móvil ── */
.mobile-nav__auth-links {
  display:flex; flex-direction:column; gap:10px;
  padding:18px 24px; border-top:1px solid rgba(255,255,255,.12);
}
.mobile-nav__auth-link {
  display:flex; align-items:center; gap:10px;
  padding:12px 18px; border-radius:var(--radius);
  font-family:var(--sans); font-size:.78rem; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase; cursor:pointer;
  border:none; text-decoration:none; transition:var(--transition);
}
.mobile-nav__auth-link--ghost {
  background:rgba(255,255,255,.1); color:rgba(255,255,255,.9);
  border:1.5px solid rgba(255,255,255,.25);
}
.mobile-nav__auth-link--ghost:hover { background:rgba(255,255,255,.2); }
.mobile-nav__auth-link--gold { background:var(--gold); color:#fff; border:1.5px solid var(--gold); }
.mobile-nav__auth-link--gold:hover { background:var(--gold-dark); }

/* ── Perfil en navbar ── */
.navbar__profile-wrap { position:relative; }
.navbar__profile-btn {
  width:38px; height:38px; border-radius:50%;
  border:2px solid var(--gold); cursor:pointer;
  overflow:hidden; display:flex; align-items:center; justify-content:center;
  background:var(--gold); transition:var(--transition);
}
.navbar__profile-btn:hover { transform:scale(1.08); box-shadow:0 0 0 3px rgba(198,169,107,.3); }
.navbar__profile-avatar { width:100%; height:100%; object-fit:cover; }
.navbar__profile-initial { color:#fff; font-family:var(--serif); font-size:1.1rem; font-weight:500; }
.navbar__profile-menu {
  position:absolute; top:calc(100% + 12px); right:0;
  background:#fff; border-radius:var(--radius-lg); width:220px;
  box-shadow:0 12px 48px rgba(0,0,0,.15); border:1px solid var(--border);
  opacity:0; visibility:hidden; transform:translateY(-8px);
  transition:all .25s ease; z-index:200;
}
.navbar__profile-menu.open { opacity:1; visibility:visible; transform:translateY(0); }
.profile-menu__header {
  padding:16px 18px 12px; border-bottom:1px solid var(--border);
}
.profile-menu__header strong { display:block; font-size:.85rem; color:var(--black); margin-bottom:2px; }
.profile-menu__header span { font-size:.72rem; color:var(--text-muted); }
.profile-menu__item {
  display:flex; align-items:center; gap:10px;
  padding:11px 18px; font-size:.78rem; color:var(--text);
  transition:background .2s; cursor:pointer; width:100%;
  text-align:left; border:none; background:none; font-family:var(--sans);
}
.profile-menu__item:hover { background:var(--cream); color:var(--gold); }
.profile-menu__item i { width:14px; color:var(--gold); }
.profile-menu__logout { color:#c0392b !important; }
.profile-menu__logout:hover { background:#fdf0f0 !important; }
.profile-menu__logout i { color:#c0392b !important; }

/* ── Testimonials CTA ── */
.testimonials__cta { text-align:center; margin-top:36px; }

/* ══════════════════════════════════════════════════
   AUTH MODAL
══════════════════════════════════════════════════ */
.auth-modal {
  position:fixed; inset:0; z-index:1100;
  display:flex; align-items:center; justify-content:center;
  pointer-events:none; visibility:hidden;
}
.auth-modal.open { pointer-events:all; visibility:visible; }
.auth-modal__overlay {
  position:absolute; inset:0; background:rgba(26,26,26,.65);
  backdrop-filter:blur(4px);
  opacity:0; transition:opacity .3s;
}
.auth-modal.open .auth-modal__overlay { opacity:1; }
.auth-modal__box {
  position:relative; background:#fff; border-radius:var(--radius-lg);
  width:min(460px,95vw); max-height:90vh; overflow-y:auto;
  padding:36px 32px; z-index:2;
  transform:scale(.94) translateY(16px); opacity:0;
  transition:transform .35s cubic-bezier(.25,.8,.25,1), opacity .35s;
  box-shadow:0 24px 80px rgba(0,0,0,.22);
}
.auth-modal.open .auth-modal__box { transform:scale(1) translateY(0); opacity:1; }
.auth-modal__close {
  position:absolute; top:16px; right:16px;
  width:34px; height:34px; border-radius:50%; background:var(--nude);
  display:flex; align-items:center; justify-content:center;
  font-size:.8rem; color:var(--text-muted); transition:var(--transition);
}
.auth-modal__close:hover { background:var(--gold); color:#fff; }
.auth-modal__title {
  font-family:var(--serif); font-size:1.6rem; font-weight:400;
  color:var(--black); margin-bottom:6px;
}
.auth-modal__sub { font-size:.82rem; color:var(--text-muted); margin-bottom:24px; }

/* ── Tabs ── */
.auth-tabs {
  display:flex; gap:4px; background:var(--cream);
  border-radius:var(--radius); padding:4px; margin-bottom:28px;
}
.auth-tab {
  flex:1; padding:9px; border-radius:6px; font-size:.72rem;
  font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  transition:var(--transition); cursor:pointer;
  color:var(--text-muted); border:none; background:none; font-family:var(--sans);
}
.auth-tab.active { background:#fff; color:var(--gold); box-shadow:0 2px 8px rgba(0,0,0,.08); }

/* ── Panel ── */
.auth-panel { display:none; }
.auth-panel.active { display:block; }

/* ── Google button ── */
.auth-google-btn {
  width:100%; padding:12px 16px; border:1.5px solid var(--nude);
  border-radius:var(--radius); display:flex; align-items:center;
  justify-content:center; gap:10px; font-size:.82rem; font-weight:500;
  color:var(--text); cursor:pointer; background:#fff;
  transition:var(--transition); font-family:var(--sans);
}
.auth-google-btn:hover { border-color:var(--gold); background:var(--cream); }

/* ── Divider ── */
.auth-divider {
  display:flex; align-items:center; gap:12px;
  margin:18px 0; color:var(--text-muted); font-size:.72rem;
}
.auth-divider::before,.auth-divider::after { content:''; flex:1; height:1px; background:var(--nude); }

/* ── Form fields ── */
.auth-form-group { margin-bottom:16px; }
.auth-form-group label {
  display:block; font-size:.7rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--text-muted); margin-bottom:7px;
}
.auth-form-group input,.auth-form-group textarea,.auth-form-group select {
  width:100%; padding:11px 14px; border:1.5px solid var(--nude);
  border-radius:var(--radius); font-size:.88rem; color:var(--text);
  background:#fff; outline:none; transition:border-color .3s; font-family:var(--sans);
}
.auth-form-group input:focus,.auth-form-group textarea:focus,.auth-form-group select:focus { border-color:var(--gold); }
.auth-form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:400px) { .auth-form-row { grid-template-columns:1fr; } }

/* ── Auth Button ── */
.auth-btn {
  width:100%; padding:13px; background:var(--gold); color:#fff;
  border:none; border-radius:var(--radius); font-size:.78rem;
  font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  cursor:pointer; transition:background .3s; font-family:var(--sans);
  display:flex; align-items:center; justify-content:center; gap:8px;
  margin-top:8px;
}
.auth-btn:hover { background:var(--gold-dark); }
.auth-btn:disabled { opacity:.6; cursor:not-allowed; }

/* ── Switch text ── */
.auth-switch { text-align:center; font-size:.78rem; color:var(--text-muted); margin-top:16px; }
.auth-link { color:var(--gold); font-weight:600; cursor:pointer; border:none; background:none; font-family:inherit; }
.auth-link:hover { text-decoration:underline; }

/* ── Error / Success ── */
.auth-error {
  background:#fdf0f0; border:1px solid #f5c6cb; color:#721c24;
  padding:10px 14px; border-radius:var(--radius); font-size:.8rem; margin-bottom:14px;
}
.auth-success {
  background:#f0fdf4; border:1px solid #86efac; color:#166534;
  padding:10px 14px; border-radius:var(--radius); font-size:.8rem; margin-bottom:14px;
}

/* ── Star Rating ── */
.star-rating { display:flex; flex-direction:row-reverse; gap:4px; justify-content:flex-end; }
.star-rating input { display:none; }
.star-rating label { font-size:1.4rem; color:var(--nude); cursor:pointer; transition:color .2s; }
.star-rating input:checked ~ label,
.star-rating label:hover,
.star-rating label:hover ~ label { color:var(--gold); }

/* ══════════════════════════════════════════════════
   CHECKOUT PAGE
══════════════════════════════════════════════════ */
body.checkout-page { background:var(--cream); }

.checkout-nav {
  background:#fff; border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:100; box-shadow:var(--shadow);
}
.checkout-nav__inner {
  max-width:1200px; margin:0 auto; padding:0 24px;
  height:66px; display:flex; align-items:center; justify-content:space-between; gap:20px;
}
.checkout-nav__logo {
  display:flex; align-items:center; gap:8px;
  font-family:var(--serif); font-size:1.1rem; color:var(--black); font-weight:500;
}
.checkout-nav__logo img { width:32px; height:32px; object-fit:contain; }
.checkout-nav__steps {
  display:flex; align-items:center; gap:8px;
  font-size:.7rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--text-muted);
}
.checkout-nav__steps .step { display:flex; align-items:center; gap:6px; transition:color .3s; }
.checkout-nav__steps .step.active { color:var(--gold); font-weight:600; }
.checkout-nav__steps .step-arrow { color:var(--nude); font-size:.6rem; }
.checkout-nav__back { font-size:.75rem; color:var(--text-muted); transition:color .3s; display:flex; align-items:center; gap:6px; }
.checkout-nav__back:hover { color:var(--gold); }
@media(max-width:600px) { .checkout-nav__steps { display:none; } }

.checkout-main { max-width:1200px; margin:0 auto; padding:36px 24px 80px; }

.checkout-grid {
  display:grid; grid-template-columns:1fr 420px; gap:32px; align-items:start;
}
@media(max-width:900px) {
  .checkout-grid { grid-template-columns:1fr; }
  .checkout-summary-col { order:-1; }
}

.checkout-card {
  background:#fff; border-radius:var(--radius-lg);
  padding:32px; box-shadow:var(--shadow); margin-bottom:20px;
}
.checkout-card__title {
  font-family:var(--serif); font-size:1.4rem; font-weight:400;
  color:var(--black); margin-bottom:24px; display:flex; align-items:center; gap:12px;
}
.step-num {
  width:30px; height:30px; border-radius:50%; background:var(--gold); color:#fff;
  font-family:var(--sans); font-size:.8rem; font-weight:700;
  display:inline-flex; align-items:center; justify-content:center; flex-shrink:0;
}

/* ── Form fields en checkout ── */
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media(max-width:520px) { .form-row { grid-template-columns:1fr; } }
.form-field { margin-bottom:18px; }
.form-field label {
  display:block; font-size:.7rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--text-muted); margin-bottom:7px;
}
.form-field input,.form-field select,.form-field textarea {
  width:100%; padding:12px 14px; border:1.5px solid var(--nude);
  border-radius:var(--radius); font-size:.88rem; color:var(--text);
  background:#fff; outline:none; transition:border-color .3s; font-family:var(--sans);
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus { border-color:var(--gold); }
.form-field textarea { resize:vertical; min-height:70px; }
.input-disabled { background:var(--cream) !important; color:var(--text-muted) !important; cursor:not-allowed; }
.input-error { border-color:#c0392b !important; }

/* ── Teléfono con prefijo ── */
.phone-input { display:flex; gap:0; border:1.5px solid var(--nude); border-radius:var(--radius); overflow:hidden; transition:border-color .3s; }
.phone-input:focus-within { border-color:var(--gold); }
.phone-prefix-select {
  border:none !important; border-right:1px solid var(--nude) !important;
  border-radius:0 !important; background:var(--cream); min-width:0; flex:0 0 auto;
  max-width:200px; font-size:.78rem;
}
.phone-input input {
  border:none !important; border-radius:0 !important; flex:1;
}

/* ── Botones checkout ── */
.btn-checkout-continue {
  width:100%; padding:15px; background:var(--gold); color:#fff;
  border:none; border-radius:var(--radius); font-size:.8rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; cursor:pointer;
  transition:background .3s; display:flex; align-items:center;
  justify-content:center; gap:10px; font-family:var(--sans); margin-top:8px;
}
.btn-checkout-continue:hover { background:var(--gold-dark); }
.btn-checkout-back {
  padding:13px 24px; background:var(--nude); color:var(--text);
  border:none; border-radius:var(--radius); font-size:.78rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; cursor:pointer; transition:background .3s; font-family:var(--sans);
}
.btn-checkout-back:hover { background:var(--border); }
.btn-checkout-pay {
  flex:1; padding:15px; background:var(--black); color:#fff;
  border:none; border-radius:var(--radius); font-size:.82rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; cursor:pointer; transition:background .3s;
  display:flex; align-items:center; justify-content:center; gap:8px; font-family:var(--sans);
}
.btn-checkout-pay:hover { background:#333; }
.btn-checkout-pay:disabled { opacity:.6; cursor:not-allowed; }

/* ── Stripe Element ── */
.stripe-card-element {
  padding:14px 16px; border:1.5px solid var(--nude);
  border-radius:var(--radius); background:#fff; min-height:46px;
  transition:border-color .3s;
}
.stripe-card-element:focus-within { border-color:var(--gold); }
.stripe-error { color:#c0392b; font-size:.78rem; margin-top:6px; min-height:18px; }
.checkout-error {
  background:#fdf0f0; border:1px solid #f5c6cb; color:#721c24;
  padding:12px 16px; border-radius:var(--radius); font-size:.82rem; margin-bottom:16px;
}
.payment-security {
  background:var(--cream); border-radius:var(--radius); padding:12px 16px;
  font-size:.78rem; color:var(--text-muted); display:flex; align-items:center; gap:8px;
  margin-top:16px;
}
.payment-security i { color:var(--gold); }
.payment-mini-summary { padding:16px; background:var(--cream); border-radius:var(--radius); margin-bottom:20px; font-size:.85rem; line-height:1.8; color:var(--text-muted); }
.payment-mini-summary strong { color:var(--black); }
.payment-mini-total { display:flex; justify-content:space-between; padding-top:8px; margin-top:8px; border-top:1px solid var(--border); font-weight:600; }

/* ── Summary column ── */
.checkout-summary { border-top:3px solid var(--gold); }
.sticky-summary { position:sticky; top:90px; }
.checkout-summary__title { font-family:var(--serif); font-size:1.2rem; font-weight:400; margin-bottom:20px; }
.summary-item { display:flex; align-items:center; gap:12px; padding:10px 0; border-bottom:1px solid var(--nude); }
.summary-item__img { position:relative; width:60px; height:60px; border-radius:8px; overflow:hidden; flex-shrink:0; background:var(--nude); }
.summary-item__img img { width:100%; height:100%; object-fit:cover; }
.summary-item__qty {
  position:absolute; top:-6px; right:-6px; width:20px; height:20px;
  background:var(--gold); color:#fff; border-radius:50%;
  font-size:.6rem; font-weight:700; display:flex; align-items:center; justify-content:center;
}
.summary-item__info { flex:1; min-width:0; }
.summary-item__name { display:block; font-size:.82rem; font-weight:600; color:var(--black); line-height:1.3; margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.summary-item__price { font-size:.78rem; color:var(--text-muted); }
.summary-totals { padding-top:16px; }
.summary-row { display:flex; justify-content:space-between; font-size:.85rem; padding:5px 0; color:var(--text-muted); }
.summary-total-row { font-size:1rem; color:var(--black); padding-top:10px; border-top:1.5px solid var(--border); margin-top:6px; }
.summary-badges {
  display:flex; flex-direction:column; gap:6px; margin-top:20px;
  padding-top:16px; border-top:1px solid var(--nude);
}
.summary-badges span { font-size:.72rem; color:var(--text-muted); display:flex; align-items:center; gap:6px; }
.summary-badges span i { color:var(--gold); width:14px; }

/* ── Success screen ── */
.checkout-success { text-align:center; padding:48px 32px; }
.success-icon { font-size:4rem; color:#27ae60; margin-bottom:20px; }
.checkout-success h2 { font-family:var(--serif); font-size:1.8rem; font-weight:400; margin-bottom:14px; }
.checkout-success p { color:var(--text-muted); line-height:1.7; }

/* ══════════════════════════════════════════════════
   PROFILE PAGE
══════════════════════════════════════════════════ */
body.profile-page { background:var(--cream); }
.profile-main { max-width:1100px; margin:0 auto; padding:36px 24px 80px; }

.profile-grid { display:grid; grid-template-columns:260px 1fr; gap:28px; align-items:start; }
@media(max-width:768px) {
  .profile-grid { grid-template-columns:1fr; }
}

/* ── Sidebar ── */
.profile-sidebar {
  background:#fff; border-radius:var(--radius-lg); padding:28px;
  box-shadow:var(--shadow); position:sticky; top:24px;
}
.profile-avatar-wrap { text-align:center; padding-bottom:24px; border-bottom:1px solid var(--border); margin-bottom:20px; }
.profile-avatar-img { width:80px; height:80px; border-radius:50%; object-fit:cover; margin:0 auto 12px; border:3px solid var(--gold); }
.profile-avatar-big {
  width:80px; height:80px; border-radius:50%; background:var(--gold); color:#fff;
  font-family:var(--serif); font-size:2.5rem; display:flex; align-items:center;
  justify-content:center; margin:0 auto 12px; border:3px solid var(--gold);
}
.profile-name { font-family:var(--serif); font-size:1.15rem; font-weight:500; color:var(--black); margin-bottom:4px; }
.profile-email { font-size:.75rem; color:var(--text-muted); }
.profile-nav { display:flex; flex-direction:column; gap:2px; }
.profile-nav__link {
  display:flex; align-items:center; gap:10px; padding:11px 14px;
  border-radius:var(--radius); font-size:.78rem; font-weight:500;
  color:var(--text-muted); transition:var(--transition); cursor:pointer;
}
.profile-nav__link i { width:16px; text-align:center; color:var(--gold); }
.profile-nav__link:hover,.profile-nav__link.active { background:var(--gold-bg); color:var(--gold); }
.profile-nav__badge {
  margin-left:auto; background:var(--gold); color:#fff;
  border-radius:12px; padding:1px 8px; font-size:.6rem; font-weight:700;
}
.profile-logout-btn {
  width:100%; padding:11px; margin-top:20px; border:1.5px solid #f5c6cb;
  border-radius:var(--radius); color:#c0392b; font-size:.75rem; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase; cursor:pointer; background:none;
  transition:var(--transition); display:flex; align-items:center; justify-content:center; gap:8px; font-family:var(--sans);
}
.profile-logout-btn:hover { background:#fdf0f0; }

/* ── Sections ── */
.profile-section { display:none; }
.profile-section.active { display:block; }
.profile-section__title {
  font-family:var(--serif); font-size:1.4rem; font-weight:400;
  color:var(--black); margin-bottom:24px; padding-bottom:16px;
  border-bottom:1px solid var(--border);
}
.profile-form { background:#fff; border-radius:var(--radius-lg); padding:28px; box-shadow:var(--shadow); }

/* ── Pedidos ── */
.orders-list { display:flex; flex-direction:column; gap:16px; }
.order-card { background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow); overflow:hidden; }
.order-card__header {
  display:flex; justify-content:space-between; align-items:center;
  padding:16px 20px; border-bottom:1px solid var(--border); background:var(--cream);
  flex-wrap:wrap; gap:10px;
}
.order-card__num { font-weight:700; font-size:.85rem; color:var(--black); margin-right:8px; }
.order-card__date { font-size:.75rem; color:var(--text-muted); }
.order-badge {
  display:inline-block; padding:3px 10px; border-radius:20px;
  font-size:.65rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
}
.order-card__items { padding:12px 20px; }
.order-item { display:flex; align-items:center; gap:12px; padding:8px 0; }
.order-item__img {
  width:48px; height:48px; border-radius:8px; overflow:hidden; flex-shrink:0;
  background:var(--nude); display:flex; align-items:center; justify-content:center;
}
.order-item__img--placeholder { color:var(--gold); font-size:1.2rem; }
.order-item__img img { width:100%; height:100%; object-fit:cover; }
.order-item__info { flex:1; min-width:0; display:flex; align-items:center; gap:8px; }
.order-item__name { font-size:.82rem; font-weight:500; color:var(--black); flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.order-item__qty { font-size:.72rem; color:var(--text-muted); white-space:nowrap; }
.order-item__price { font-size:.82rem; font-weight:600; color:var(--text); white-space:nowrap; }
.order-card__footer {
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 20px; border-top:1px solid var(--border);
  font-size:.78rem; color:var(--text-muted); flex-wrap:wrap; gap:8px;
}

/* ── Perfil empty state ── */
.profile-empty {
  background:#fff; border-radius:var(--radius-lg); padding:60px 32px;
  text-align:center; box-shadow:var(--shadow); color:var(--text-muted);
}
.profile-empty i { font-size:2.5rem; color:var(--nude); margin-bottom:16px; display:block; }
.profile-empty p { font-size:.88rem; margin-bottom:4px; }

/* ── Cart summary en perfil ── */
.cart-summary-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 0; border-top:1.5px solid var(--border); margin-top:8px;
  font-size:.9rem;
}

/* ══════════════════════════════════════════════════
   ENHANCED ANIMATIONS & POLISH — v2
══════════════════════════════════════════════════ */

/* ── Custom scrollbar ── */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--nude); border-radius:3px; transition:background .2s; }
::-webkit-scrollbar-thumb:hover { background:var(--gold); }

/* ── Reveal with direction support (overrides base) ── */
.reveal {
  opacity:0;
  transform:translateX(var(--rx,0)) translateY(var(--ry,36px)) scale(var(--rs,1));
  transition:opacity .8s ease, transform .8s ease;
}
.reveal.visible { opacity:1; transform:translateX(0) translateY(0) scale(1); }
.reveal.from-left  { --rx:-60px; --ry:0; }
.reveal.from-right { --rx: 60px; --ry:0; }
.reveal.from-scale { --rs:.88;   --ry:0; }

/* ── Stagger delays ── */
.stagger-1 { transition-delay:.07s; }
.stagger-2 { transition-delay:.15s; }
.stagger-3 { transition-delay:.23s; }
.stagger-4 { transition-delay:.31s; }
.stagger-5 { transition-delay:.39s; }
.stagger-6 { transition-delay:.47s; }

/* ── Scroll-to-top button ── */
.scroll-top-btn {
  position:fixed; bottom:96px; right:26px; z-index:700;
  width:46px; height:46px; border-radius:50%;
  background:var(--black); color:var(--gold); font-size:.82rem;
  border:2px solid rgba(198,169,107,.35);
  box-shadow:0 8px 24px rgba(26,26,26,.28);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transform:translateY(18px) scale(.8);
  transition:opacity .35s ease, transform .35s ease, background .25s, color .25s, border-color .25s;
  pointer-events:none;
}
.scroll-top-btn.visible {
  opacity:1; transform:translateY(0) scale(1);
  pointer-events:all;
  animation:sttBounce .55s cubic-bezier(.34,1.56,.64,1) both;
}
.scroll-top-btn:hover { background:var(--gold); color:#fff; border-color:var(--gold); transform:translateY(-3px) scale(1.1); }
@keyframes sttBounce {
  0%  { transform:translateY(18px) scale(.8); }
  65% { transform:translateY(-5px) scale(1.12); }
  100%{ transform:translateY(0)    scale(1); }
}

/* ── WhatsApp bounce entrance ── */
@keyframes waBounceIn {
  0%  { transform:scale(0);    opacity:0; }
  60% { transform:scale(1.18); opacity:1; }
  100%{ transform:scale(1);    opacity:1; }
}
.wa-float {
  animation:waBounceIn .65s cubic-bezier(.34,1.56,.64,1) 1.4s both,
            waPulse 2.8s ease 2.1s infinite;
}

/* ── Product card shimmer on hover ── */
.product-card__img-wrap::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(105deg, transparent 35%, rgba(255,255,255,.25) 50%, transparent 65%);
  transform:translateX(-120%);
  pointer-events:none; z-index:4; transition:none;
}
.product-card:hover .product-card__img-wrap::after {
  animation:cardShimmer .55s ease forwards;
}
@keyframes cardShimmer {
  to { transform:translateX(160%); }
}

/* ── Product card lift ── */
.product-card { will-change:transform; }
.product-card:hover {
  transform:translateY(-9px) scale(1.015);
  box-shadow:0 30px 72px rgba(26,26,26,.17);
}

/* ── Category card enhanced hover ── */
.cat-card {
  transition:transform .4s cubic-bezier(.25,.8,.25,1), box-shadow .4s;
}
.cat-card:hover {
  transform:translateY(-6px) scale(1.03);
  box-shadow:0 20px 52px rgba(26,26,26,.14);
}

/* ── Fly-to-cart clone ── */
.fly-clone {
  position:fixed; z-index:9999; pointer-events:none;
  border-radius:12px; overflow:hidden;
  transition:left .65s cubic-bezier(.6,.05,.01,.9),
              top  .65s cubic-bezier(.6,.05,.01,.9),
              width .65s cubic-bezier(.6,.05,.01,.9),
              height .65s cubic-bezier(.6,.05,.01,.9),
              border-radius .65s ease,
              opacity .65s ease;
}

/* ── Filter re-entrance animation ── */
@keyframes cardReveal {
  from { opacity:0; transform:scale(.94) translateY(8px); }
  to   { opacity:1; transform:scale(1)   translateY(0); }
}

/* ── Section sub-header decoration ── */
.section-header__sub {
  position:relative;
}

/* ── Drawer scrollbars ── */
.cart-drawer__body::-webkit-scrollbar,
.orders-drawer__body::-webkit-scrollbar { width:4px; }
.cart-drawer__body::-webkit-scrollbar-thumb,
.orders-drawer__body::-webkit-scrollbar-thumb { background:var(--nude); border-radius:2px; }

/* ══════════ MOBILE IMPROVEMENTS ══════════ */
@media (max-width:768px) {
  /* Horizontally scrollable filter strip */
  .products__filters {
    overflow-x:auto; padding-bottom:4px;
    -webkit-overflow-scrolling:touch;
    flex-wrap:nowrap; gap:8px; scroll-snap-type:x mandatory;
  }
  .products__filters::-webkit-scrollbar { display:none; }
  .filter-btn { white-space:nowrap; scroll-snap-align:start; flex-shrink:0; }

  /* 2-column product grid, tighter */
  .products__grid { grid-template-columns:repeat(2,1fr); gap:14px; }
  .product-card__body { padding:12px 14px; }
  .product-card__name { font-size:.92rem; }

  /* Drawers full-width */
  .cart-drawer__panel   { width:100vw; max-width:100vw; }
  .orders-drawer__panel { width:100vw; }

  /* Floating buttons smaller/repositioned */
  .scroll-top-btn { bottom:82px; right:14px; width:42px; height:42px; font-size:.75rem; }
  .wa-float { bottom:22px; right:14px; width:50px; height:50px; font-size:1.4rem; }
  .wa-float__tooltip { display:none; }
}

@media (max-width:480px) {
  /* Hero */
  .hero__title    { font-size:clamp(2.2rem,10vw,3rem); }
  .hero__subtitle { font-size:.7rem; letter-spacing:.16em; }
  .hero__cta-sub  { display:none; }
  .hero__btns     { gap:10px; }
  .btn-gold, .btn-outline { padding:12px 22px; font-size:.74rem; }

  /* Section headings */
  .section-header { margin-bottom:28px; }
  .section-header__title { font-size:clamp(1.55rem,7vw,2.1rem); }
  .section-header__sub   { font-size:.65rem; }

  /* Product grid compact */
  .products__grid  { gap:10px; }
  .product-card__body { padding:10px 12px; }
  .product-card__name { font-size:.85rem; line-height:1.22; }
  .product-card__price { font-size:.8rem; }
  .product-card__add   { font-size:.64rem; padding:10px; letter-spacing:.06em; }
  .product-card__quick { font-size:.7rem; padding:8px; }

  /* Category cards */
  .categories__grid { gap:8px; }
  .cat-card__name   { font-size:.9rem; }

  /* About */
  .about { padding:56px 0; }
  .about__stats   { flex-wrap:wrap; gap:14px; }
  .about__stat-num{ font-size:1.75rem; }

  /* Promises 2-col on mobile */
  .promises { padding:56px 0; }
  .promises__grid { grid-template-columns:1fr 1fr; gap:20px; }
  .promise-item i { font-size:1.6rem; margin-bottom:10px; }
  .promise-item h4{ font-size:1rem; }
  .promise-item p { font-size:.74rem; }

  /* Offers */
  .offers-banner { padding:56px 0; }
  .offers-grid   { grid-template-columns:1fr 1fr; gap:10px; }
  .offers-banner__inner { gap:32px; }

  /* Gallery */
  .gallery-cta__text { padding:48px 24px; }

  /* Footer */
  .footer { padding:44px 0 0; }
  .footer__logo { font-size:1.18rem; }
  .footer__col h4 { font-size:.92rem; margin-bottom:14px; }

  /* Auth modal */
  .auth-modal__box { padding:26px 18px; }
  .auth-modal__title { font-size:1.35rem; }

  /* Checkout */
  .checkout-card { padding:20px 16px; }
  .checkout-nav__back { display:none; }
  .checkout-main { padding:20px 14px 60px; }
}

@media (max-width:360px) {
  /* Single column on very small phones */
  .products__grid { grid-template-columns:1fr; }
  .product-card__img-wrap { aspect-ratio:4/3; }
  .promises__grid { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════════════════
   LOGO IMAGES — footer & mobile nav
══════════════════════════════════════════════════ */
.footer__logo {
  display:flex; align-items:center; gap:10px;
  font-family:var(--serif); font-size:1.5rem; color:#fff; letter-spacing:.1em; margin-bottom:16px;
}
.footer__logo-img {
  width:28px; height:28px; object-fit:contain;
  filter:brightness(0) invert(1);
  flex-shrink:0;
}
.mobile-nav__logo {
  display:flex; align-items:center; gap:10px;
}
.mobile-nav__logo-img {
  width:26px; height:26px; object-fit:contain;
  filter:brightness(0) invert(1);
  flex-shrink:0;
}

/* ══════════════════════════════════════════════════
   ENHANCED ENTRANCE ANIMATIONS
   Cards fly in from far outside — no diagonal issues
══════════════════════════════════════════════════ */
.reveal {
  opacity:0;
  transform:translateX(var(--rx,0)) translateY(var(--ry,40px)) scale(var(--rs,1));
  transition:opacity .75s cubic-bezier(.25,.8,.25,1), transform .75s cubic-bezier(.25,.8,.25,1);
}
.reveal.visible { opacity:1; transform:translateX(0) translateY(0) scale(1); }
.reveal.from-left  { --rx:-160px; --ry:0; }
.reveal.from-right { --rx: 160px; --ry:0; }
.reveal.from-scale { --rs:.85;    --ry:0; }

/* On mobile: disable horizontal slides to avoid overflow */
@media (max-width:640px) {
  .reveal.from-left,
  .reveal.from-right { --rx:0; --ry:40px; }
}


/* ══════════════════════════════════════════════════
   PRODUCT CARD SPARKLE EFFECT
══════════════════════════════════════════════════ */

/* Radiant glow ring on hover */
.product-card:hover {
  box-shadow:0 30px 72px rgba(26,26,26,.18),
             0 0 0 2px rgba(198,169,107,.28),
             0 0 0 5px rgba(198,169,107,.10),
             0 0 52px rgba(198,169,107,.15);
}

/* DOM sparkle elements (created by JS) */
.pcard-sparkle {
  position:absolute;
  pointer-events:none;
  z-index:9990;
  user-select:none;
  line-height:1;
  animation:sparklePop .85s ease forwards;
  text-shadow:0 0 6px currentColor;
}
@keyframes sparklePop {
  0%   { transform:scale(0)   rotate(0deg)  translateY(0);     opacity:0; }
  30%  { transform:scale(1.5) rotate(20deg) translateY(-6px);  opacity:1; }
  100% { transform:scale(0)   rotate(75deg) translateY(-22px); opacity:0; }
}

/* ══════════════════════════════════════════════════
   AYUDA PAGE
══════════════════════════════════════════════════ */
.ayuda-page { background:var(--white); }

/* ── Help Navbar ── */
.help-nav {
  background:#fff; border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:100; box-shadow:var(--shadow);
}
.help-nav__inner {
  max-width:1200px; margin:0 auto; padding:0 24px;
  height:70px; display:flex; align-items:center; gap:24px;
}
.help-nav__logo {
  display:flex; align-items:center; gap:10px;
  font-family:var(--serif); font-size:1.15rem; color:var(--black);
  font-weight:500; letter-spacing:.08em; text-transform:uppercase;
  flex-shrink:0;
}
.help-nav__logo img { width:36px; height:36px; object-fit:contain; }
.help-nav__links {
  display:flex; gap:6px; flex:1; justify-content:center; flex-wrap:wrap;
}
.help-nav__links a {
  padding:7px 16px; border-radius:40px; font-size:.7rem; font-weight:600;
  letter-spacing:.09em; text-transform:uppercase; color:var(--text-muted);
  transition:var(--transition); border:1px solid transparent;
}
.help-nav__links a:hover { background:var(--gold-bg); color:var(--gold); border-color:var(--border); }
.help-nav__back {
  display:flex; align-items:center; gap:6px;
  padding:9px 18px; border-radius:var(--radius);
  background:var(--gold); color:#fff;
  font-size:.7rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  transition:background .25s; flex-shrink:0;
}
.help-nav__back:hover { background:var(--gold-dark); }
@media(max-width:768px) {
  .help-nav__links { display:none; }
  .help-nav__inner { justify-content:space-between; }
}

/* ── Help Hero ── */
.help-hero {
  background:linear-gradient(145deg, #0a0700 0%, #1a1100 40%, #231800 70%, #1a1100 100%);
  padding:90px 24px 80px;
  text-align:center; position:relative; overflow:hidden;
}
.help-hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(198,169,107,.18) 0%, transparent 70%);
  pointer-events:none;
}
.help-hero__content { position:relative; z-index:1; max-width:700px; margin:0 auto; }
.help-hero__sub {
  font-size:.68rem; font-weight:600; letter-spacing:.28em; text-transform:uppercase;
  color:var(--gold); display:block; margin-bottom:16px;
}
.help-hero__title {
  font-family:var(--serif); font-size:clamp(2.4rem,6vw,3.6rem); font-weight:300;
  color:#fff; line-height:1.15; margin-bottom:18px;
}
.help-hero__title em { color:var(--gold-light); font-style:italic; }
.help-hero__desc {
  font-size:.88rem; color:rgba(255,255,255,.6); margin-bottom:36px; line-height:1.8;
}
.help-hero__links { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.help-hero__pill {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 20px; border-radius:40px;
  border:1.5px solid rgba(198,169,107,.35);
  color:rgba(255,255,255,.8); font-size:.72rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase;
  transition:var(--transition);
}
.help-hero__pill:hover { background:var(--gold); border-color:var(--gold); color:#fff; }
.help-hero__pill i { color:var(--gold); }
.help-hero__pill:hover i { color:#fff; }

/* ── Help Sections ── */
.help-section { padding:80px 0; }
.help-section--alt { background:var(--cream); }
.help-section__header {
  display:flex; align-items:flex-start; gap:20px; margin-bottom:48px;
}
.help-section__icon {
  font-size:2rem; color:var(--gold); flex-shrink:0; margin-top:4px;
}
.help-section__tag {
  font-size:.65rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase;
  color:var(--gold); display:block; margin-bottom:6px;
}
.help-section__title {
  font-family:var(--serif); font-size:clamp(1.8rem,4vw,2.4rem);
  font-weight:400; color:var(--black); line-height:1.2;
}
.help-intro {
  font-size:.9rem; color:var(--text-muted); line-height:1.9;
  max-width:680px; margin-bottom:40px;
}

/* ── Steps ── */
.help-steps { display:flex; flex-direction:column; gap:0; }
.help-step {
  display:flex; gap:24px; align-items:flex-start;
  padding:28px 0; border-bottom:1px solid var(--border);
}
.help-step:last-child { border-bottom:none; }
.help-step__num {
  font-family:var(--serif); font-size:2.4rem; font-weight:300;
  color:var(--gold); line-height:1; flex-shrink:0; width:52px; text-align:center;
}
.help-step__content h3 {
  font-family:var(--serif); font-size:1.15rem; font-weight:500;
  color:var(--black); margin-bottom:8px;
}
.help-step__content p { font-size:.86rem; color:var(--text-muted); line-height:1.8; }
.help-steps--small .help-step__num { font-size:1.8rem; width:40px; }
.help-steps--small .help-step { padding:20px 0; }

/* ── Info cards grid ── */
.help-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(240px,1fr)); gap:24px;
}
.help-grid--3 { grid-template-columns:repeat(auto-fill, minmax(200px,1fr)); }
.help-card {
  background:#fff; border-radius:var(--radius-lg); padding:28px 24px;
  box-shadow:var(--shadow); border:1px solid var(--border);
  transition:transform var(--transition), box-shadow var(--transition);
}
.help-section--alt .help-card { background:#fff; }
.help-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.help-card > i {
  font-size:1.8rem; color:var(--gold); margin-bottom:16px; display:block;
}
.help-card h3 {
  font-family:var(--serif); font-size:1.05rem; font-weight:500;
  color:var(--black); margin-bottom:10px;
}
.help-card p { font-size:.82rem; color:var(--text-muted); line-height:1.8; }

/* ── CTA info box ── */
.help-cta-box {
  display:flex; align-items:flex-start; gap:14px;
  background:var(--gold-bg); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:18px 22px; margin-top:36px;
}
.help-cta-box > i { color:var(--gold); font-size:1.1rem; flex-shrink:0; margin-top:2px; }
.help-cta-box p { font-size:.83rem; color:var(--text); line-height:1.7; }
.help-cta-box a { color:var(--gold); font-weight:600; }
.help-cta-box a:hover { text-decoration:underline; }

/* ── Returns layout ── */
.help-returns { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
@media(max-width:768px) { .help-returns { grid-template-columns:1fr; } }
.help-returns__main { display:flex; flex-direction:column; gap:24px; }
.help-badge {
  display:flex; align-items:baseline; gap:10px;
  background:var(--gold); color:#fff; border-radius:var(--radius-lg);
  padding:20px 28px; width:fit-content;
}
.help-badge__num {
  font-family:var(--serif); font-size:3.5rem; font-weight:300; line-height:1;
}
.help-badge__txt { font-size:.78rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; }
.help-list { list-style:none; display:flex; flex-direction:column; gap:10px; }
.help-list li { display:flex; align-items:flex-start; gap:10px; font-size:.86rem; color:var(--text); }
.help-list li i { color:var(--gold); font-size:.8rem; margin-top:3px; flex-shrink:0; }
.help-returns__text { display:flex; flex-direction:column; gap:16px; }
.help-returns__text > p { font-size:.88rem; color:var(--text-muted); line-height:1.8; }

/* ── Help Footer ── */
.help-footer { background:var(--black); color:rgba(255,255,255,.7); padding:40px 0; }
.help-footer__inner {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:20px; padding-bottom:24px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.help-footer__logo {
  display:flex; align-items:center; gap:10px;
  font-family:var(--serif); font-size:1.2rem; color:#fff; letter-spacing:.1em;
}
.help-footer__logo img { width:30px; height:30px; object-fit:contain; filter:brightness(0) invert(1); }
.help-footer__links { display:flex; gap:20px; flex-wrap:wrap; }
.help-footer__links a {
  display:flex; align-items:center; gap:7px;
  font-size:.75rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  color:rgba(255,255,255,.6); transition:color .25s;
}
.help-footer__links a:hover { color:var(--gold); }
.help-footer__copy {
  text-align:center; font-size:.72rem; color:rgba(255,255,255,.35);
  padding-top:18px;
}

/* ── Responsive help page ── */
@media(max-width:640px) {
  .help-hero  { padding:60px 20px 50px; }
  .help-section { padding:56px 0; }
  .help-section__header { flex-direction:column; gap:12px; }
  .help-step { flex-direction:column; gap:10px; }
  .help-step__num { font-size:1.8rem; width:auto; }
  .help-grid { grid-template-columns:1fr; }
  .help-grid--3 { grid-template-columns:1fr 1fr; }
}
@media(max-width:400px) {
  .help-grid--3 { grid-template-columns:1fr; }
  .help-badge__num { font-size:2.8rem; }
}
