/* ═══════════════════════════════════════
   TATVAAM — Shared Stylesheet
   ═══════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=Jost:wght@300;400;500&display=swap');

:root {
  /* ── Base ── */
  --cream:        #FFF8F0;
  --warm-white:   #FFFDF8;
  /* ── Saffron / Spice (premium warmth) ── */
  --gold:         #D4811A;
  --gold-light:   #F5B96B;
  --gold-dark:    #7A3800;
  /* ── Fennel / Fresh (mouth-freshener identity) ── */
  --fresh:        #2A6B47;
  --fresh-light:  #5BAA7F;
  --fresh-dark:   #0E3D22;
  /* ── Maroon / Festive (Indian heritage) ── */
  --maroon:       #7A1F2E;
  --maroon-light: #A63245;
  --maroon-dark:  #4A0F1A;
  /* ── Neutrals ── */
  --charcoal:     #1C1C1A;
  --charcoal-mid: #2E2E2A;
  --charcoal-light:#4A4A44;
  --border:       #EADCC8;
  --border-dark:  #D4B99A;
  --serif:        'Cormorant Garamond', Georgia, serif;
  --sans:         'Jost', sans-serif;
  --ease-out:     cubic-bezier(0.22, 1, 0.36, 1);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; font-size: 18px; }
body { font-family: var(--sans); background: var(--cream); color: var(--charcoal); font-weight:400; overflow-x:hidden; font-size: 1rem; line-height: 1.65; }
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; }

/* ── ANIMATIONS ── */
@keyframes fadeUp   { from { opacity:0; transform:translateY(32px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn   { from { opacity:0; } to { opacity:1; } }
@keyframes slideRight { from { opacity:0; transform:translateX(-40px); } to { opacity:1; transform:translateX(0); } }
@keyframes marquee  { from { transform:translateX(0); } to { transform:translateX(-50%); } }
@keyframes spin     { to { transform:rotate(360deg); } }
@keyframes shimmer  { 0%,100% { opacity:0.6; } 50% { opacity:1; } }
@keyframes scaleIn  { from { opacity:0; transform:scale(0.92); } to { opacity:1; transform:scale(1); } }
@keyframes borderGrow { from { width:0; } to { width:40px; } }

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-left {
  opacity:0; transform:translateX(-30px);
  transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}
.reveal-left.visible { opacity:1; transform:translateX(0); }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(255,248,240,0.96); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition: transform 0.3s ease;
}
nav.nav-hidden {
  transform: translateY(-100%);
}
nav.scrolled { box-shadow: 0 4px 40px rgba(14,61,34,0.08); }
.nav-inner {
  max-width:1260px; margin:auto; padding:0 2.5rem;
  display:flex; align-items:center; justify-content:space-between; height:76px;
}
.nav-logo { display:flex; align-items:center; }
.nav-logo-img { height:120px; width:auto; mix-blend-mode:multiply; }
.nav-links {
  display:flex; gap:2.5rem; font-size:0.82rem;
  letter-spacing:0.12em; text-transform:uppercase;
}
.nav-links a { color:var(--charcoal-mid); transition:color 0.2s; position:relative; padding-bottom:2px; }
.nav-links a::after {
  content:''; position:absolute; bottom:0; left:0; width:0; height:1px;
  background:var(--fresh); transition:width 0.25s var(--ease-out);
}
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }
.nav-links a:hover, .nav-links a.active { color:var(--fresh); }
.nav-actions { display:flex; align-items:center; gap:1.25rem; }
.cart-btn {
  display:flex; align-items:center; gap:0.5rem;
  background:var(--fresh-dark); color:var(--cream);
  padding:0.55rem 1.3rem; font-size:0.76rem; letter-spacing:0.14em;
  text-transform:uppercase; border:none; cursor:pointer;
  font-family:var(--sans); transition:all 0.2s;
}
.cart-btn:hover { background:var(--fresh); }
.cart-count {
  background:var(--fresh); color:white; border-radius:50%;
  width:18px; height:18px; font-size:0.62rem;
  display:flex; align-items:center; justify-content:center; font-weight:500;
}


/* ── HAMBURGER + MOBILE NAV ── */
.hamburger { display:none; flex-direction:column; justify-content:center; gap:5px; background:none; border:none; cursor:pointer; padding:6px; margin-left:0.5rem; }
.hamburger span { display:block; width:22px; height:1.5px; background:var(--charcoal); transition:all 0.3s var(--ease-out); transform-origin:center; }
.hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }
.mobile-nav { display:none; position:fixed; inset:0; background:var(--cream); z-index:150; flex-direction:column; align-items:center; justify-content:center; }
.mobile-nav.open { display:flex; animation:fadeIn 0.2s ease; }
.mobile-nav-close { position:absolute; top:1.5rem; right:2rem; background:none; border:none; font-size:2rem; cursor:pointer; color:var(--charcoal-light); line-height:1; }
.mobile-nav-logo { height:64px; width:auto; mix-blend-mode:multiply; margin-bottom:2.5rem; }
.mobile-nav a { font-family:var(--serif); font-size:2.8rem; font-weight:300; font-style:italic; color:var(--charcoal); padding:0.5rem 2rem; transition:color 0.2s; }
.mobile-nav a:hover, .mobile-nav a.active { color:var(--fresh); }

/* ── BUTTONS ── */
.btn-primary {
  display:inline-block; background:var(--fresh-dark); color:var(--cream);
  padding:0.9rem 2.5rem; font-size:0.72rem; letter-spacing:0.16em;
  text-transform:uppercase; border:none; cursor:pointer;
  font-family:var(--sans); transition:all 0.25s; position:relative; overflow:hidden;
}
.btn-primary::after {
  content:''; position:absolute; inset:0;
  background:var(--fresh); transform:translateX(-101%);
  transition:transform 0.3s var(--ease-out);
}
.btn-primary:hover::after { transform:translateX(0); }
.btn-primary span { position:relative; z-index:1; }

.btn-outline {
  display:inline-block; border:1px solid var(--fresh-dark); color:var(--fresh-dark);
  padding:0.9rem 2.5rem; font-size:0.72rem; letter-spacing:0.16em;
  text-transform:uppercase; cursor:pointer; font-family:var(--sans);
  transition:all 0.25s; background:transparent;
}
.btn-outline:hover { background:var(--fresh-dark); color:var(--cream); }

/* ── SECTION HEADER ── */
.section-header { text-align:center; margin-bottom:4rem; }
.eyebrow {
  font-size:0.76rem; letter-spacing:0.28em; text-transform:uppercase;
  color:var(--gold-dark); margin-bottom:1rem; display:block; font-weight:500;
}
.section-title {
  font-family:var(--serif); font-size:clamp(2rem,4vw,3.5rem);
  font-weight:300; color:var(--charcoal); line-height:1.1;
}
.section-title em { font-style:italic; color:var(--gold-dark); }
.gold-divider {
  width:0; height:1px;
  background:linear-gradient(90deg, var(--gold), var(--fresh));
  margin:1.5rem auto; animation:borderGrow 0.8s var(--ease-out) forwards;
}

/* ── MARQUEE ── */
.marquee-strip {
  background:var(--fresh-dark); color:var(--cream);
  padding:0.8rem 0; overflow:hidden; white-space:nowrap;
}
.marquee-inner { display:inline-flex; animation:marquee 22s linear infinite; }
.marquee-inner span {
  font-size:0.67rem; letter-spacing:0.22em; text-transform:uppercase;
  padding:0 2.5rem; color:rgba(255,255,255,0.7);
}
.marquee-inner span.dot { color:var(--fresh-light); padding:0; }

/* ── CART DRAWER ── */
.cart-overlay {
  position:fixed; inset:0; background:rgba(28,28,26,0.45);
  z-index:200; opacity:0; pointer-events:none; transition:opacity 0.3s;
}
.cart-overlay.open { opacity:1; pointer-events:all; }
.cart-drawer {
  position:fixed; right:0; top:0; bottom:0; width:420px;
  background:var(--warm-white); z-index:201;
  transform:translateX(100%);
  transition:transform 0.38s var(--ease-out);
  display:flex; flex-direction:column;
}
.cart-drawer.open { transform:translateX(0); }
.cart-head {
  padding:1.5rem 2rem; border-bottom:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center;
}
.cart-head h2 { font-family:var(--serif); font-size:1.6rem; font-weight:400; }
.close-btn { background:none; border:none; font-size:1.6rem; cursor:pointer; color:var(--charcoal-light); line-height:1; }
.cart-items { flex:1; overflow-y:auto; padding:1.5rem 2rem; }
.cart-empty { text-align:center; padding:4rem 0; color:var(--charcoal-light); font-size:0.85rem; }
.cart-item { display:flex; gap:1rem; padding:1rem 0; border-bottom:1px solid var(--border); animation:fadeIn 0.3s; }
.cart-item-img { width:64px; height:64px; background:var(--cream); flex-shrink:0; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.cart-item-img img { width:100%; height:100%; object-fit:cover; }
.cart-item-info { flex:1; }
.cart-item-name { font-family:var(--serif); font-size:1rem; margin-bottom:2px; }
.cart-item-variant { font-size:0.7rem; color:var(--charcoal-light); margin-bottom:6px; }
.cart-item-row { display:flex; align-items:center; justify-content:space-between; }
.cart-item-price { font-family:var(--serif); font-size:1rem; }
.qty-control { display:flex; align-items:center; gap:6px; }
.qty-btn {
  width:26px; height:26px; border:1px solid var(--border);
  background:none; cursor:pointer; display:flex; align-items:center; justify-content:center;
  font-size:0.9rem; transition:all 0.15s;
}
.qty-btn:hover { background:var(--charcoal); color:var(--cream); border-color:var(--charcoal); }
.qty-num { font-size:0.82rem; min-width:20px; text-align:center; }
.remove-item { background:none; border:none; color:var(--charcoal-light); cursor:pointer; font-size:0.72rem; text-decoration:underline; margin-top:4px; }
.cart-foot { padding:1.5rem 2rem; border-top:1px solid var(--border); }
.cart-total-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:1.2rem; }
.cart-total-label { font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--charcoal-light); }
.cart-total-amount { font-family:var(--serif); font-size:1.7rem; }
.checkout-btn {
  width:100%; background:var(--fresh-dark); color:var(--cream); border:none;
  padding:1rem; font-size:0.75rem; letter-spacing:0.16em; text-transform:uppercase;
  cursor:pointer; font-family:var(--sans); transition:background 0.25s;
}
.checkout-btn:hover { background:var(--fresh); }

/* ── CHECKOUT MODAL ── */
.modal-overlay {
  position:fixed; inset:0; background:rgba(28,28,26,0.6);
  z-index:300; display:none; align-items:center; justify-content:center;
}
.modal-overlay.open { display:flex; }
.modal {
  background:var(--warm-white); width:90%; max-width:600px;
  max-height:90vh; overflow-y:auto; padding:2.5rem;
  animation:scaleIn 0.3s var(--ease-out);
}
.modal-title { font-family:var(--serif); font-size:2rem; font-weight:300; margin-bottom:0.4rem; }
.modal-sub { font-size:0.78rem; color:var(--charcoal-light); margin-bottom:2rem; }
.form-group { margin-bottom:1.2rem; }
.form-group label { display:block; font-size:0.62rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--charcoal-mid); margin-bottom:0.45rem; }
.form-group input, .form-group textarea, .form-group select {
  width:100%; border:1px solid var(--border); background:white;
  padding:0.75rem 1rem; font-family:var(--sans); font-size:0.85rem;
  color:var(--charcoal); outline:none; transition:border-color 0.2s;
}
.form-group input:focus, .form-group textarea:focus { border-color:var(--charcoal); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.maps-wrapper { position:relative; }
.maps-suggestions {
  position:absolute; top:100%; left:0; right:0; background:white;
  border:1px solid var(--border); border-top:none; z-index:10;
  max-height:200px; overflow-y:auto; box-shadow:0 8px 24px rgba(28,28,26,0.1);
}
.maps-suggestion-item { padding:0.75rem 1rem; cursor:pointer; font-size:0.8rem; border-bottom:1px solid var(--border); transition:background 0.15s; }
.maps-suggestion-item:hover { background:var(--cream); }
.order-summary { background:var(--cream); padding:1.25rem; margin:1.5rem 0; }
.order-summary h4 { font-family:var(--serif); font-size:1rem; margin-bottom:1rem; }
.summary-line { display:flex; justify-content:space-between; font-size:0.8rem; margin-bottom:0.4rem; color:var(--charcoal-mid); }
.summary-total { display:flex; justify-content:space-between; font-family:var(--serif); font-size:1.1rem; margin-top:0.75rem; padding-top:0.75rem; border-top:1px solid var(--border); }
.pay-btn {
  width:100%; background:var(--fresh-dark); color:var(--cream); border:none;
  padding:1rem; font-size:0.78rem; letter-spacing:0.16em; text-transform:uppercase;
  cursor:pointer; font-family:var(--sans); transition:background 0.25s; margin-top:0.5rem;
}
.pay-btn:hover { background:var(--fresh); }
.razorpay-note { font-size:0.68rem; color:var(--charcoal-light); text-align:center; margin-top:0.75rem; }

/* ── TOAST ── */
.toast {
  position:fixed; bottom:2rem; left:50%;
  transform:translateX(-50%) translateY(80px);
  background:var(--charcoal); color:var(--cream);
  padding:0.8rem 1.75rem; font-size:0.78rem; letter-spacing:0.05em;
  z-index:500; transition:transform 0.35s var(--ease-out); white-space:nowrap;
}
.toast.show { transform:translateX(-50%) translateY(0); }

/* ── FOOTER ── */
.site-footer { background:#081A10; color:var(--cream); }
.footer-top { max-width:1260px; margin:auto; padding:2.5rem 2.5rem 3rem; display:grid; grid-template-columns:2.2fr 1fr 1fr 1.2fr; gap:4rem; }
.footer-logo-img { height:100px; width:auto; filter:invert(1); mix-blend-mode:screen; opacity:0.8; margin-bottom:1.25rem; display:block; }
.footer-desc { font-size:0.84rem; color:rgba(250,247,242,0.62); line-height:1.9; }
.footer-col-title { font-size:0.62rem; letter-spacing:0.24em; text-transform:uppercase; color:var(--gold); margin-bottom:1.25rem; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:0.65rem; }
.footer-links a { font-size:0.88rem; color:rgba(250,247,242,0.65); transition:color 0.2s; }
.footer-links a:hover { color:var(--gold-light); }
.footer-contact p { font-size:0.88rem; color:rgba(250,247,242,0.65); line-height:2; }
.footer-contact a { color:var(--gold-light); transition:color 0.2s; text-decoration:underline; text-underline-offset:3px; }
.footer-contact a:hover { color:var(--gold); }
.footer-contact a[href^="tel"] { color:rgba(250,247,242,0.7); text-decoration:none; }
.footer-bottom {
  max-width:1260px; margin:auto; padding:1.5rem 2.5rem;
  border-top:1px solid rgba(250,247,242,0.07);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem;
}
.footer-copy { font-size:0.74rem; color:rgba(250,247,242,0.45); }
.footer-legal { display:flex; gap:2rem; }
.footer-legal a { font-size:0.74rem; color:rgba(250,247,242,0.45); transition:color 0.2s; }
.footer-legal a:hover { color:var(--gold-light); }

/* ── INNER PAGE HERO ── */
.inner-hero {
  margin-top:76px; background:var(--fresh-dark); padding:5rem 2.5rem;
  text-align:center; position:relative; overflow:hidden;
}
.inner-hero::before {
  content:''; position:absolute; top:-100px; left:50%; transform:translateX(-50%);
  width:600px; height:400px; border-radius:50%;
  background:radial-gradient(circle, rgba(42,107,71,0.18) 0%, transparent 70%);
}
.inner-hero .eyebrow { color:var(--gold); }
.inner-hero .page-title {
  font-family:var(--serif); font-size:clamp(2.5rem,5vw,4.5rem);
  font-weight:300; color:var(--cream); line-height:1.1;
}
.inner-hero .page-title em { font-style:italic; color:var(--gold-light); }
.inner-hero .page-sub { font-size:0.85rem; color:rgba(250,247,242,0.55); margin-top:1rem; letter-spacing:0.08em; }
.breadcrumb { font-size:0.68rem; letter-spacing:0.1em; color:rgba(250,247,242,0.35); margin-top:1.5rem; }
.breadcrumb a { color:var(--gold); }
.breadcrumb a:hover { color:var(--gold-light); }

/* ── INNER PAGE BODY ── */
.inner-body { max-width:900px; margin:auto; padding:5rem 2.5rem; }
.inner-body h2 { font-family:var(--serif); font-size:1.8rem; font-weight:400; margin:2.5rem 0 1rem; color:var(--charcoal); }
.inner-body h3 { font-family:var(--serif); font-size:1.25rem; font-weight:400; margin:2rem 0 0.75rem; color:var(--charcoal-mid); }
.inner-body p { font-size:0.88rem; line-height:1.95; color:var(--charcoal-mid); margin-bottom:1.25rem; }
.inner-body ul, .inner-body ol { margin:0.5rem 0 1.25rem 1.5rem; }
.inner-body li { font-size:0.88rem; line-height:1.9; color:var(--charcoal-mid); margin-bottom:0.4rem; }
.inner-body a { color:var(--gold-dark); border-bottom:1px solid var(--gold-light); transition:color 0.2s; }
.inner-body a:hover { color:var(--gold); }
.inner-divider { width:40px; height:1px; background:var(--gold); margin:2rem 0; }

/* ── RESPONSIVE ── */
@media (max-width:900px) {
  .footer-top { grid-template-columns:1fr 1fr; gap:2.5rem; }
}
@media (max-width:768px) {
  /* Hide text links and show hamburger from 768px down (phones + small tablets) */
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .account-btn { display:none; }
}

@media (max-width:640px) {
  /* ── NAV ── */
  .nav-inner { padding:0 1.1rem; height:58px; }
  .nav-logo-img { height: 52px; }   /* fits cleanly inside 58px nav */
  .nav-actions { gap:0.6rem; }
  .cart-btn { padding:0.45rem 0.85rem; font-size:0.66rem; gap:0.35rem; }
  .cart-count { width:16px; height:16px; font-size:0.58rem; }

  /* ── PAGE OFFSETS ── */
  .hero { margin-top:58px; }
  .inner-hero { margin-top:58px; padding:2.75rem 1.5rem 2.5rem; }
  .inner-hero .page-title { font-size:clamp(1.9rem,8vw,2.8rem); }
  .inner-hero .page-sub { font-size:0.8rem; }

  /* ── INNER PAGE BODY ── */
  .inner-body { padding:2.5rem 1.25rem; }

  /* ── SECTION HEADER ── */
  .section-header { margin-bottom:2rem; }
  .section-title { font-size:clamp(1.7rem,6vw,2.4rem); }

  /* ── CART DRAWER ── */
  .cart-drawer { width:100%; }
  .cart-head { padding:1.1rem 1.25rem; }
  .cart-items { padding:0.75rem 1.25rem; }
  .cart-foot { padding:1.1rem 1.25rem; }
  .cart-total-amount { font-size:1.4rem; }

  /* ── CHECKOUT MODAL ── */
  .modal { padding:1.75rem 1.25rem; width:95%; max-height:94vh; border-radius:0; }
  .modal-title { font-size:1.5rem; }
  .modal-sub { font-size:0.74rem; margin-bottom:1.5rem; }
  .form-group input, .form-group textarea, .form-group select { font-size:16px; }

  /* ── AUTH MODAL ── */
  .auth-modal-overlay { align-items: flex-start; padding-top: 3vh; }
  .auth-box { padding:1.75rem 1.25rem; width:96%; max-width:100%; border-radius:0; max-height:88vh; }
  .auth-brand { font-size:1.5rem; }

  /* ── FORM ROW ── */
  .form-row { grid-template-columns:1fr; }

  /* ── FOOTER ── */
  .footer-top { grid-template-columns:1fr; gap:1.75rem; padding:2.5rem 1.25rem 2rem; }
  .footer-bottom { flex-direction:column; align-items:flex-start; padding:1.25rem; gap:0.5rem; }
  .footer-desc { font-size:0.75rem; }
  .footer-logo-img { height:44px; margin-bottom:0.85rem; }
  .footer-col-title { margin-bottom:0.85rem; }

  /* ── TOAST ── */
  .toast { font-size:0.72rem; padding:0.72rem 1.25rem; max-width:92vw; white-space:normal; text-align:center; left:50%; }

  /* ── MOBILE NAV ── */
  .mobile-nav a { font-size:2rem; padding:0.4rem 2rem; }
  .mobile-nav-logo { height:52px; margin-bottom:2rem; }
}

/* ── CUSTOMER AUTH MODAL ── */
.auth-modal-overlay{position:fixed;inset:0;background:rgba(28,28,26,0.6);z-index:400;display:none;align-items:center;justify-content:center;}
.auth-modal-overlay.open{display:flex;}
.auth-box{background:white;width:90%;max-width:440px;padding:2.5rem;position:relative;animation:scaleIn 0.3s var(--ease-out);max-height:90vh;overflow-y:auto;}
.auth-close{position:absolute;top:1rem;right:1.25rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--charcoal-light);line-height:1;}
.auth-brand{font-family:var(--serif);font-size:1.8rem;text-align:center;margin-bottom:0.2rem;color:var(--charcoal);}
.auth-tagline{font-size:0.64rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold-dark);text-align:center;margin-bottom:1.75rem;}
.auth-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.75rem;}
.auth-tab{flex:1;padding:0.65rem;background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--charcoal-light);transition:all 0.2s;border-bottom:2px solid transparent;margin-bottom:-1px;}
.auth-tab.active{color:var(--charcoal);border-bottom-color:var(--charcoal);}
.auth-field{margin-bottom:1rem;}
.auth-field label{display:block;font-size:0.74rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--charcoal-mid);margin-bottom:0.4rem;font-weight:500;}
.auth-field input{width:100%;border:1px solid var(--border);padding:0.8rem 1rem;font-family:var(--sans);font-size:1rem;color:var(--charcoal);outline:none;transition:border-color 0.2s;background:white;}
.auth-field input:focus{border-color:var(--charcoal);}
.auth-row{display:grid;grid-template-columns:1fr 1fr;gap:0.75rem;}
.auth-btn{width:100%;background:var(--charcoal);color:var(--cream);border:none;padding:0.95rem;font-size:0.78rem;letter-spacing:0.16em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:background 0.25s;margin-top:0.5rem;}
.auth-btn:hover{background:var(--gold-dark);}
.auth-error{font-size:0.82rem;color:#A32D2D;margin:0.5rem 0;min-height:1rem;}
.auth-switch{font-size:0.82rem;color:var(--charcoal-light);text-align:center;margin-top:1.25rem;}
.auth-switch a{color:var(--gold-dark);cursor:pointer;text-decoration:underline;}
.auth-forgot-heading{font-family:var(--serif);font-size:1.4rem;font-weight:300;color:var(--charcoal);margin-bottom:0.4rem;}
.auth-forgot-sub{font-size:0.76rem;color:var(--charcoal-light);line-height:1.65;margin-bottom:1.25rem;}

/* ── ACCOUNT BUTTON ── */
.account-btn{display:flex;align-items:center;gap:0.45rem;background:none;border:1px solid var(--border);color:var(--charcoal-mid);padding:0.48rem 1rem;font-size:0.68rem;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:all 0.2s;white-space:nowrap;}
.account-btn:hover{border-color:var(--charcoal);color:var(--charcoal);}
.account-btn.signed-in{border-color:var(--gold);color:var(--gold-dark);}

/* ── WISHLIST BUTTON ON CARD ── */
.wishlist-btn{position:absolute;top:0.65rem;right:0.65rem;width:32px;height:32px;background:white;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;z-index:2;padding:0;}
.wishlist-btn svg{width:15px;height:15px;stroke:var(--charcoal-light);fill:none;transition:all 0.2s;}
.wishlist-btn:hover svg,.wishlist-btn.active svg{stroke:var(--gold-dark);fill:var(--gold-dark);}

/* ── SORT SELECT ── */
.sort-select{border:1px solid var(--border);padding:0.65rem 2rem 0.65rem 0.85rem;font-family:var(--sans);font-size:0.74rem;color:var(--charcoal-mid);background:white url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236B6B65'/%3E%3C/svg%3E") no-repeat right 0.6rem center;-webkit-appearance:none;outline:none;cursor:pointer;height:38px;}
.sort-select:focus{border-color:var(--charcoal);}
.shop-right{display:flex;align-items:center;gap:0.75rem;flex-shrink:0;}

@media(max-width:640px){.auth-row{grid-template-columns:1fr;}.shop-right{width:100%;}.sort-select{flex:1;}.search-wrap{flex:2;}.account-btn{padding:0.45rem 0.75rem;font-size:0.62rem;}}

/* ══ PRODUCT DETAIL MODAL ═══════════════════════════════════════ */
.pdm-overlay{position:fixed;inset:0;background:rgba(14,30,20,0.72);z-index:350;display:none;align-items:center;justify-content:center;padding:1.25rem;}
.pdm-overlay.open{display:flex;}
.pdm{background:var(--warm-white);width:100%;max-width:980px;max-height:90vh;display:grid;grid-template-columns:360px 1fr;position:relative;animation:scaleIn 0.3s var(--ease-out);overflow:hidden;box-shadow:0 32px 80px rgba(14,30,20,0.35);}
.pdm-close{position:absolute;top:0.85rem;right:1rem;background:rgba(255,255,255,0.9);border:1px solid var(--border);font-size:1.4rem;cursor:pointer;color:var(--charcoal-light);z-index:5;width:34px;height:34px;display:flex;align-items:center;justify-content:center;line-height:1;transition:all 0.2s;padding:0;}
.pdm-close:hover{background:var(--charcoal);color:var(--cream);border-color:var(--charcoal);}
.pdm-body{display:contents;}

/* Visual panel */
.pdm-visual{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 2rem;position:relative;overflow:hidden;}
.pdm-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,rgba(255,255,255,0.12) 0%,transparent 60%);pointer-events:none;}
.pdm-vis-inner{text-align:center;position:relative;z-index:1;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.pdm-vis-icon{font-size:5.5rem;line-height:1;margin-bottom:1.5rem;filter:drop-shadow(0 8px 24px rgba(0,0,0,0.3));}
.pdm-vis-name{font-family:var(--serif);font-size:1.4rem;font-weight:300;font-style:italic;color:rgba(255,255,255,0.92);line-height:1.25;margin-bottom:0.5rem;text-align:center;}
.pdm-vis-cat{font-size:0.58rem;letter-spacing:0.28em;text-transform:uppercase;color:rgba(255,255,255,0.55);}
.pdm-vis-trust{position:relative;z-index:1;margin-top:2rem;display:flex;flex-direction:column;gap:0.4rem;align-self:flex-start;width:100%;}
.pdm-vis-trust span{font-size:0.62rem;letter-spacing:0.1em;color:rgba(255,255,255,0.65);display:flex;align-items:center;gap:0.4rem;}
/* When product has a real photo */
.pdm-visual-photo{padding:0!important;align-items:stretch!important;justify-content:flex-end!important;}
.pdm-visual-photo::before{display:none;}
.pdm-vis-trust-photo{position:absolute;bottom:0;left:0;right:0;margin:0!important;padding:1.25rem 1.5rem;background:linear-gradient(0deg,rgba(0,0,0,0.6) 0%,transparent 100%);}
.pdm-vis-trust-photo span{color:rgba(255,255,255,0.85)!important;}

/* Info panel */
.pdm-info{overflow:hidden;display:flex;flex-direction:column;background:var(--warm-white);}
.pdm-info-scroll{overflow-y:auto;padding:2rem 2.25rem;height:100%;max-height:90vh;}
.pdm-info-scroll::-webkit-scrollbar{width:4px;}.pdm-info-scroll::-webkit-scrollbar-thumb{background:var(--border-dark);}
.pdm-badge{display:inline-block;background:var(--maroon);color:white;font-size:0.52rem;letter-spacing:0.14em;text-transform:uppercase;padding:0.28rem 0.75rem;margin-bottom:0.75rem;}
.pdm-name{font-family:var(--serif);font-size:1.75rem;font-weight:300;color:var(--charcoal);line-height:1.18;margin-bottom:0.5rem;}
.pdm-stars{color:var(--gold);font-size:0.85rem;margin-bottom:0.85rem;letter-spacing:0.04em;}
.pdm-rating-text{color:var(--charcoal-light);font-size:0.72rem;font-family:var(--sans);}
.pdm-desc{font-size:0.84rem;color:var(--charcoal-light);line-height:1.9;margin-bottom:1.5rem;border-bottom:1px solid var(--border);padding-bottom:1.5rem;}

/* Sections */
.pdm-section{margin-bottom:1.4rem;}
.pdm-section-title{font-size:0.58rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--charcoal-mid);margin-bottom:0.6rem;font-weight:500;}
.pdm-chips{display:flex;flex-wrap:wrap;gap:0.38rem;}
.pdm-chip{background:var(--cream);border:1px solid var(--border);padding:0.3rem 0.72rem;font-size:0.68rem;color:var(--charcoal-mid);letter-spacing:0.03em;}
.pdm-benefits{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:0.35rem;}
.pdm-benefits li{font-size:0.73rem;color:var(--charcoal-mid);padding:0.18rem 0;display:flex;align-items:center;gap:0.4rem;}
.pdm-benefits li::before{content:'✓';color:var(--fresh);font-size:0.75rem;flex-shrink:0;}
.pdm-variants{display:flex;flex-wrap:wrap;gap:0.38rem;}
.pdm-variant-chip{border:1px solid var(--border);background:white;padding:0.36rem 0.9rem;font-size:0.65rem;letter-spacing:0.08em;cursor:pointer;font-family:var(--sans);color:var(--charcoal-mid);transition:all 0.15s;}
.pdm-variant-chip:hover,.pdm-variant-chip.active{background:var(--fresh-dark);color:var(--cream);border-color:var(--fresh-dark);}

/* Purchase row */
.pdm-purchase-row{display:flex;align-items:center;justify-content:space-between;margin:1.25rem 0 1rem;padding:1rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.pdm-qty-wrap{display:flex;align-items:center;gap:0.65rem;border:1px solid var(--border);padding:0.38rem 0.85rem;background:white;}
.pdm-qty-btn{background:none;border:none;cursor:pointer;font-size:1.15rem;color:var(--charcoal);line-height:1;width:22px;height:22px;display:flex;align-items:center;justify-content:center;transition:color 0.15s;}
.pdm-qty-btn:hover{color:var(--fresh);}
.pdm-qty-num{font-family:var(--serif);font-size:1.2rem;min-width:26px;text-align:center;}
.pdm-price{font-family:var(--serif);font-size:2rem;color:var(--charcoal);}

/* CTAs */
.pdm-ctas{display:grid;grid-template-columns:1fr 1fr;gap:0.65rem;margin-bottom:1.1rem;}
.pdm-add-btn{background:var(--fresh-dark);color:var(--cream);border:none;padding:0.9rem 0.75rem;font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:background 0.2s;}
.pdm-add-btn:hover{background:var(--fresh);}
.pdm-buy-btn{background:var(--gold-dark);color:white;border:none;padding:0.9rem 0.75rem;font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:background 0.2s;}
.pdm-buy-btn:hover{background:var(--gold);}

/* Trust */
.pdm-trust-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border);}
.pdm-trust-row span{font-size:0.67rem;color:var(--charcoal-light);letter-spacing:0.04em;}

/* Related */
.pdm-related{display:grid;grid-template-columns:repeat(3,1fr);gap:0.65rem;}
.pdm-related-card{cursor:pointer;border:1px solid var(--border);background:white;transition:transform 0.2s,box-shadow 0.2s;overflow:hidden;}
.pdm-related-card:hover{transform:translateY(-3px);box-shadow:0 8px 22px rgba(14,61,34,0.1);}
.pdm-related-img{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:1.8rem;}
.pdm-related-name{font-family:var(--serif);font-size:0.78rem;padding:0.45rem 0.6rem 0.15rem;color:var(--charcoal);line-height:1.3;}
.pdm-related-price{font-size:0.64rem;color:var(--charcoal-light);padding:0 0.6rem 0.55rem;}
/* ── PDM Reviews ── */
.pdm-reviews-list{display:flex;flex-direction:column;gap:1rem;margin-top:0.5rem;}
.pdm-review-item{background:var(--cream);padding:0.9rem 1rem;border-left:3px solid var(--fresh-light);}
.pdm-review-top{display:flex;align-items:center;gap:0.6rem;margin-bottom:0.35rem;flex-wrap:wrap;}
.pdm-review-stars{color:var(--gold);font-size:0.78rem;letter-spacing:0.04em;flex-shrink:0;}
.pdm-review-name{font-size:0.72rem;font-weight:500;color:var(--charcoal);}
.pdm-review-loc{font-weight:300;color:var(--charcoal-light);}
.pdm-review-text{font-size:0.76rem;color:var(--charcoal-mid);line-height:1.7;margin:0;}

/* ── WRITE A REVIEW FORM (inside product modal) ── */
.pdm-write-review{margin-top:1.25rem;border-top:1px solid var(--border);padding-top:1.25rem;}
.pdm-write-review-toggle{display:flex;align-items:center;gap:0.5rem;background:none;border:1px solid var(--border);padding:0.55rem 1rem;font-size:0.73rem;font-family:var(--sans);color:var(--charcoal);cursor:pointer;border-radius:4px;transition:all .15s;letter-spacing:0.04em;}
.pdm-write-review-toggle:hover{background:var(--charcoal);color:var(--cream);border-color:var(--charcoal);}
.pdm-review-form{margin-top:1rem;background:var(--cream);border:1px solid var(--border);padding:1.1rem 1.1rem 0.9rem;border-radius:4px;display:none;}
.pdm-review-form.open{display:block;}
/* Star selector */
.pdm-star-row{display:flex;align-items:center;gap:0.4rem;margin-bottom:0.85rem;}
.pdm-star-label{font-size:0.63rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--charcoal-mid);margin-right:0.25rem;}
.pdm-star-selector{display:flex;flex-direction:row-reverse;gap:2px;}
.pdm-star-selector input{display:none;}
.pdm-star-selector label{font-size:1.5rem;color:#ddd;cursor:pointer;transition:color .1s;line-height:1;}
.pdm-star-selector label:hover,.pdm-star-selector label:hover~label,.pdm-star-selector input:checked~label{color:var(--gold);}
.pdm-review-inputs{display:flex;flex-direction:column;gap:0.65rem;}
.pdm-review-inputs input,.pdm-review-inputs textarea{border:1px solid var(--border);padding:0.6rem 0.75rem;font-size:0.8rem;font-family:var(--sans);color:var(--charcoal);background:white;border-radius:3px;width:100%;box-sizing:border-box;outline:none;transition:border .15s;}
.pdm-review-inputs input:focus,.pdm-review-inputs textarea:focus{border-color:var(--fresh);}
.pdm-review-inputs textarea{resize:vertical;min-height:70px;}
.pdm-review-submit-row{display:flex;align-items:center;gap:0.75rem;margin-top:0.85rem;flex-wrap:wrap;}
.pdm-review-submit-btn{background:var(--fresh);color:white;border:none;padding:0.6rem 1.4rem;font-size:0.73rem;font-family:var(--sans);letter-spacing:0.08em;text-transform:uppercase;cursor:pointer;border-radius:3px;transition:background .15s;}
.pdm-review-submit-btn:hover{background:var(--fresh-dark);}
.pdm-review-submit-btn:disabled{opacity:.55;cursor:not-allowed;}
.pdm-review-msg{font-size:0.75rem;color:var(--fresh);font-weight:500;}
.pdm-review-login-cta{font-size:0.78rem;color:var(--charcoal-mid);padding:0.75rem 0;}
.pdm-review-login-cta a{color:var(--fresh);text-decoration:none;font-weight:500;}
.pdm-review-login-cta a:hover{text-decoration:underline;}

/* ── CLIENTS / TRUSTED BY SECTION ── */
.clients-wrap{background:var(--warm-white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:5rem 0 4.5rem;}
.clients-inner{max-width:1260px;margin:auto;padding:0 2.5rem;}
.clients-header{text-align:center;margin-bottom:3.5rem;}
.clients-eyebrow{font-size:0.6rem;letter-spacing:0.35em;text-transform:uppercase;color:var(--charcoal-light);display:block;margin-bottom:0.8rem;}
.clients-title{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:300;color:var(--charcoal);line-height:1.2;}
.clients-title em{font-style:italic;color:var(--fresh);}
/* Marquee track */
.clients-track-wrap{overflow:hidden;position:relative;mask-image:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%);}
.clients-track{display:flex;gap:2rem;width:max-content;animation:clientsScroll 32s linear infinite;align-items:center;}
.clients-track:hover{animation-play-state:paused;}
@keyframes clientsScroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
/* Logo cards — bigger */
.client-logo-card{flex-shrink:0;width:180px;height:96px;background:white;border:1px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;padding:1rem 1.25rem;transition:box-shadow .2s,transform .2s;cursor:default;}
.client-logo-card:hover{box-shadow:0 6px 24px rgba(0,0,0,0.09);transform:translateY(-3px);}
.client-logo-card img{max-width:100%;max-height:100%;object-fit:contain;filter:grayscale(100%);opacity:0.6;transition:filter .2s,opacity .2s;}
.client-logo-card:hover img{filter:grayscale(0%);opacity:1;}
.client-logo-card .cl-placeholder{font-family:var(--serif);font-size:0.82rem;color:var(--charcoal-light);text-align:center;font-style:italic;line-height:1.4;}
/* Mobile */
@media(max-width:900px){
  .clients-wrap{padding:3.5rem 0 3rem;}
  .clients-inner{padding:0 1.5rem;}
  .clients-header{margin-bottom:2.5rem;}
}
@media(max-width:640px){
  .clients-wrap{padding:3rem 0 2.5rem;}
  .clients-inner{padding:0 1rem;}
  .clients-header{margin-bottom:2rem;}
  .clients-title{font-size:clamp(1.4rem,6vw,1.9rem);}
  .client-logo-card{width:130px;height:72px;padding:0.7rem 0.9rem;border-radius:8px;}
  .clients-track{gap:1.25rem;}
  .clients-track-wrap{mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%);}
  /* On mobile there's no hover — show logos clearly without greyscale */
  .client-logo-card img{filter:grayscale(30%);opacity:0.85;}
}

/* Mobile */
@media(max-width:740px){
  .pdm-overlay{padding:0;align-items:flex-end;}
  .pdm{grid-template-columns:1fr;max-height:92vh;border-radius:0;box-shadow:none;animation:fadeUp 0.35s var(--ease-out);}
  .pdm-visual{min-height:180px;padding:1.75rem;}
  .pdm-vis-icon{font-size:3.5rem;}
  .pdm-vis-name{font-size:1.1rem;}
  .pdm-vis-trust{display:none;}
  .pdm-info-scroll{padding:1.25rem 1.25rem 2rem;}
  .pdm-name{font-size:1.4rem;}
  .pdm-benefits{grid-template-columns:1fr;}
  .pdm-ctas{grid-template-columns:1fr;}
  .pdm-price{font-size:1.6rem;}
  .pdm-close{top:0.6rem;right:0.75rem;}
  .pdm-trust-row{gap:0.75rem;}
  .pdm-related{grid-template-columns:repeat(3,1fr);gap:0.45rem;}
  .pdm-related-name{font-size:0.68rem;padding:0.35rem 0.4rem 0.1rem;}
  .pdm-related-price{font-size:0.58rem;padding:0 0.4rem 0.4rem;}
}

/* ── PROMO BANNER ── */
.promo-banner{background:var(--gold-dark);color:var(--cream);text-align:center;padding:3.5rem 2.5rem;position:relative;overflow:hidden;}
.promo-banner::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(212,129,26,0.2) 0%,transparent 65%);pointer-events:none;}
.promo-banner-inner{position:relative;z-index:1;max-width:680px;margin:auto;}
.promo-title{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,3rem);font-weight:300;margin:0.75rem 0;}
.promo-title em{font-style:italic;color:var(--gold-light);}
.promo-sub{font-size:0.82rem;color:rgba(250,247,242,0.6);margin-bottom:2rem;letter-spacing:0.04em;}
@media(max-width:640px){.promo-banner{padding:2.5rem 1.25rem;}.promo-sub{font-size:0.78rem;}}

/* ── REFERRAL — CHECKOUT FIELD ── */
.ref-code-row{border:1px solid var(--border);margin:0.75rem 0;}
.ref-code-header{display:flex;justify-content:space-between;align-items:center;padding:0.7rem 1rem;cursor:pointer;user-select:none;font-size:0.78rem;color:var(--charcoal-mid);transition:background 0.15s;}
.ref-code-header:hover{background:var(--cream);}
.ref-code-body{padding:0.75rem 1rem;border-top:1px solid var(--border);}
.ref-code-input-row{display:flex;}
.ref-code-input-row input{flex:1;border:1px solid var(--border);border-right:none;padding:0.65rem 1rem;font-family:var(--sans);font-size:0.82rem;outline:none;color:var(--charcoal);background:white;}
.ref-code-input-row input:focus{border-color:var(--charcoal);}
.ref-apply-btn{background:var(--charcoal);color:var(--cream);border:none;padding:0.65rem 1.25rem;font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);white-space:nowrap;transition:background 0.2s;}
.ref-apply-btn:hover{background:var(--gold-dark);}
.ref-apply-btn:disabled{background:var(--charcoal-light);cursor:default;}

/* ── REFERRAL — ACCOUNT PAGE ── */
.refer-hero{text-align:center;padding:2rem 0 1.5rem;}
.refer-icon{font-size:3rem;margin-bottom:0.75rem;}
.refer-title{font-family:var(--serif);font-size:2rem;font-weight:300;margin-bottom:0.5rem;}
.refer-sub{font-size:0.84rem;color:var(--charcoal-light);line-height:1.75;max-width:480px;margin:0 auto;}
.refer-code-box{background:var(--cream);border:1px solid var(--border);padding:1.75rem 2rem;margin:1.75rem 0;}
.refer-code-display{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:0.3rem;flex-wrap:wrap;}
.copy-btn{background:var(--charcoal);color:var(--cream);border:none;padding:0.6rem 1.5rem;font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:background 0.2s;}
.copy-btn:hover{background:var(--gold-dark);}
.refer-share{margin-bottom:1.75rem;}
.share-btn{background:none;border:1px solid var(--border);color:var(--charcoal-mid);padding:0.6rem 1.5rem;font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:all 0.2s;}
.share-btn:hover{border-color:var(--charcoal);color:var(--charcoal);}
.share-btn.wa{background:#25D366;border-color:#25D366;color:white;}
.share-btn.wa:hover{background:#1FAD55;border-color:#1FAD55;}
.refer-stats{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.75rem;}
.refer-stat{background:var(--warm-white);border:1px solid var(--border);padding:1.5rem;text-align:center;}
.refer-stat-num{font-family:var(--serif);font-size:2.5rem;color:var(--gold-dark);line-height:1;margin-bottom:0.35rem;}
.refer-stat-label{font-size:0.65rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--charcoal-light);}
.refer-how{border-top:1px solid var(--border);padding-top:1.5rem;}
.refer-how-title{font-family:var(--serif);font-size:1.1rem;margin-bottom:1rem;color:var(--charcoal);}
.refer-step{display:flex;align-items:flex-start;gap:1rem;padding:0.75rem 0;border-bottom:1px solid var(--border);font-size:0.84rem;color:var(--charcoal-mid);}
.refer-step:last-child{border-bottom:none;}
.refer-step-num{width:28px;height:28px;background:var(--gold);color:var(--charcoal);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.72rem;font-weight:500;flex-shrink:0;}
@media(max-width:640px){.refer-stats{grid-template-columns:1fr;}.refer-code-display{flex-direction:column;align-items:flex-start;}.copy-btn{width:100%;text-align:center;}}

/* ══ PRODUCT CARD — shared across shop, home, account ═══════════ */
.product-card{background:var(--warm-white);border:1px solid var(--border);transition:transform 0.3s var(--ease-out),box-shadow 0.3s;opacity:0;animation:fadeUp 0.5s ease-out forwards;}
.product-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px rgba(28,28,26,0.09);}
.product-img{width:100%;aspect-ratio:1;background:var(--cream);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;}
.product-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s var(--ease-out),opacity 0.18s ease;}
.product-card:hover .product-img img{transform:scale(1.05);}
.img-dots{position:absolute;bottom:0.6rem;left:50%;transform:translateX(-50%);display:flex;gap:5px;z-index:2;opacity:0;transition:opacity 0.2s;}
.product-card:hover .img-dots{opacity:1;}
.img-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.5);transition:background 0.2s,transform 0.2s;}
.img-dot.active{background:white;transform:scale(1.3);}
.product-badge{position:absolute;top:0.75rem;left:0.75rem;background:var(--gold);color:var(--charcoal);font-size:0.55rem;letter-spacing:0.12em;text-transform:uppercase;padding:0.25rem 0.65rem;}
.cat-label{position:absolute;bottom:0.75rem;left:0.75rem;background:rgba(28,28,26,0.7);color:var(--cream);font-size:0.52rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.2rem 0.5rem;max-width:calc(100% - 1.5rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.wishlist-btn{position:absolute;top:0.75rem;right:0.75rem;width:32px;height:32px;background:white;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.2s;z-index:2;border-radius:0;}
.wishlist-btn:hover{border-color:var(--maroon);background:var(--maroon);}
.wishlist-btn svg{width:14px;height:14px;color:var(--charcoal-light);transition:color 0.2s;}
.wishlist-btn:hover svg{color:white;}
.wishlist-btn.active svg{fill:var(--maroon);color:var(--maroon);}
.wishlist-btn.active:hover svg{fill:white;color:white;}
.product-info{padding:1.25rem 1.5rem 1.5rem;}
.product-rating{display:flex;align-items:center;gap:0.4rem;margin-bottom:0.4rem;}
.product-stars{color:var(--gold);font-size:0.72rem;letter-spacing:0.05em;}
.product-rating-count{font-size:0.68rem;color:var(--charcoal-light);}
.product-name{font-family:var(--serif);font-size:1.12rem;font-weight:400;color:var(--charcoal);margin-bottom:0.35rem;line-height:1.25;}
.product-desc{font-size:0.73rem;color:var(--charcoal-light);line-height:1.65;margin-bottom:0.9rem;}
.product-variants{display:flex;flex-wrap:wrap;gap:0.35rem;margin-bottom:0.9rem;}
.variant-chip{font-size:0.58rem;letter-spacing:0.08em;border:1px solid var(--border);padding:0.24rem 0.58rem;cursor:pointer;transition:all 0.15s;background:white;color:var(--charcoal-mid);font-family:var(--sans);}
.variant-chip:hover,.variant-chip.active{border-color:var(--fresh-dark);background:var(--fresh-dark);color:var(--cream);}
.product-footer{display:flex;align-items:center;justify-content:space-between;gap:0.5rem;}
.product-price{font-family:var(--serif);font-size:1.3rem;color:var(--charcoal);}
.add-to-cart{background:var(--fresh-dark);color:var(--cream);border:none;padding:0.6rem 1.2rem;font-size:0.66rem;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;font-family:var(--sans);transition:background 0.2s;white-space:nowrap;}
.add-to-cart:hover{background:var(--fresh);}
/* Responsive product cards */
@media(max-width:640px){
  .product-info{padding:0.75rem 0.85rem 0.85rem;}
  .product-name{font-size:0.9rem;line-height:1.25;margin-bottom:0.3rem;}
  .product-desc{display:none;}
  .product-variants{gap:0.25rem;margin-bottom:0.6rem;}
  .variant-chip{font-size:0.55rem;padding:0.2rem 0.45rem;}
  .product-price{font-size:1.1rem;}
  .product-footer{flex-direction:column;align-items:stretch;gap:0.5rem;}
  .add-to-cart{width:100%;text-align:center;font-size:0.62rem;padding:0.65rem;}
  .product-badge{font-size:0.48rem;padding:0.2rem 0.45rem;top:0.5rem;left:0.5rem;}
  .cat-label{display:none;}
  .wishlist-btn{top:0.5rem;right:0.5rem;width:28px;height:28px;}
  .wishlist-btn svg{width:12px;height:12px;}
}

/* ══ PRODUCT IMAGE ART PLACEHOLDER ══════════════════════════════ */
/* Used on every product card when no real photo is available */
.product-img-art{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;transition:transform 0.5s var(--ease-out);}
.product-card:hover .product-img-art,.product-card:hover .product-img-art{transform:scale(1.04);}
.product-img-pattern{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,0.14) 1.5px,transparent 1.5px);background-size:18px 18px;background-position:center;}
.product-img-artlabel{font-family:var(--serif);font-size:0.9rem;font-weight:300;font-style:italic;color:rgba(255,255,255,0.88);text-align:center;padding:0 1.25rem;line-height:1.5;position:relative;z-index:1;text-shadow:0 2px 12px rgba(0,0,0,0.3);letter-spacing:0.02em;}
.product-img-artcat{font-size:0.52rem;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-top:0.4rem;position:relative;z-index:1;}
/* PDM visual art (no emoji) */
.pdm-vis-art{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2.5rem;}
.pdm-vis-art-title{font-family:var(--serif);font-size:2rem;font-weight:300;font-style:italic;color:rgba(255,255,255,0.92);line-height:1.2;text-shadow:0 2px 20px rgba(0,0,0,0.25);margin-bottom:0.6rem;}
.pdm-vis-art-cat{font-size:0.58rem;letter-spacing:0.3em;text-transform:uppercase;color:rgba(255,255,255,0.55);}
.pdm-vis-art-pattern{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,0.1) 1.5px,transparent 1.5px);background-size:22px 22px;background-position:center;pointer-events:none;}
.pdm-vis-line{width:40px;height:1px;background:rgba(255,255,255,0.35);margin:1rem auto;}
/* Hero ingredient chips — no emoji */
.hv-chip-clean{position:absolute;background:white;border:1px solid var(--border-dark);padding:0.42rem 1rem;font-size:0.6rem;letter-spacing:0.14em;text-transform:uppercase;box-shadow:0 4px 14px rgba(0,0,0,0.07);white-space:nowrap;color:var(--charcoal-mid);}
/* Hero center — clean art */
.hv-center-art{position:absolute;inset:96px;border-radius:50%;background:linear-gradient(145deg,var(--fresh-dark),#0A2E18);display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;padding:1.5rem;box-shadow:0 0 40px rgba(42,107,71,0.3),inset 0 0 30px rgba(0,0,0,0.1);}
.hv-center-brand{font-family:var(--serif);font-size:1.5rem;font-weight:300;font-style:italic;color:var(--cream);letter-spacing:0.06em;margin-bottom:0.25rem;}
.hv-center-tag{font-size:0.48rem;letter-spacing:0.3em;text-transform:uppercase;color:rgba(250,247,242,0.5);}
@media(max-width:640px){.pdm-vis-art-title{font-size:1.3rem;}.product-img-artlabel{font-size:0.8rem;}}

/* ══ WHATSAPP FLOAT BUTTON (shared across all pages) ════════════ */
.wa-float{position:fixed;bottom:1.75rem;right:1.75rem;z-index:200;}
.wa-float>a,.wa-float[href]{display:flex;align-items:center;justify-content:center;width:54px;height:54px;background:#25D366;border-radius:50%;box-shadow:0 4px 22px rgba(37,211,102,0.45);transition:transform 0.25s,box-shadow 0.25s;color:white;}
a.wa-float{display:flex;align-items:center;justify-content:center;width:54px;height:54px;background:#25D366;border-radius:50%;box-shadow:0 4px 22px rgba(37,211,102,0.45);transition:transform 0.25s,box-shadow 0.25s;color:white;}
.wa-float>a:hover,.wa-float[href]:hover,a.wa-float:hover{transform:scale(1.1);box-shadow:0 8px 30px rgba(37,211,102,0.55);}
.wa-float svg{width:26px;height:26px;fill:white;flex-shrink:0;}
@media(max-width:640px){
  .wa-float{bottom:1.25rem;right:1.25rem;}
  .wa-float>a,.wa-float[href],a.wa-float{width:48px;height:48px;}
  .wa-float svg{width:22px;height:22px;}
}
