/* ============================================================
   THE FRAGRANCE WORLD — DESIGN SYSTEM v5.0 (DEFINITIVE)
   "Less is Luxury" — March 2026
   ============================================================

   PHILOSOPHY: The website is the gallery. The bottle is the art.
   PALETTE: White-first surface system (Phlur-inspired)
   ACCENT: One accent only — Warm Amber for stars + savings
   BUTTONS: Inkwell black. Always.
   FONTS: Cormorant Garamond + Outfit (2 fonts only)

   RULES:
   - Never use Cormorant Garamond for numbers/prices — always Outfit
   - Near Black (#111110) is ONLY for hero H1 headlines
   - Inkwell (#1C1C1A) for ALL body text, prices, UI, buttons
   - Cool Silver (#787F86) for UI chrome ONLY — min 18px or bold
   - Warm Amber (#C17F24) ONLY for: star ratings, progress bar fills
   - Amber Resin (#8B6E52) ONLY for: bundle upsell zones
   - Buttons are ALWAYS --ink (black). No coloured CTAs.
   - White-first surface: --bg (white) → --bg2 (off-white) → --card (white)

   ============================================================ */

:root {
  /* ─── SURFACES (white-first system) ─── */
  --bg:          #FFFFFF;    /* White — page background */
  --bg2:         #F7F7F8;    /* Off-white — subtle section panels, product image bg */
  --card:        #FFFFFF;    /* White — cards, product panels, nav, modals */
  --bd:          #E5E5E7;    /* Border — default */
  --bd-dk:       #E5E5E7;    /* Border — emphasized */

  /* ─── TEXT ─── */
  --deep:        #111110;    /* Near Black — hero H1 ONLY */
  --ink:         #1C1C1A;    /* Inkwell — all body text, UI, prices, buttons */
  --charcoal:    #111110;    /* Alias for --deep (legacy compat) */
  --muted:       #787F86;    /* Cool Silver — UI chrome only, min 18px/bold */
  --white:       #FFFFFF;    /* Text on dark backgrounds */

  /* ─── ACCENT: Warm Amber (restricted use) ─── */
  --gold:        #C17F24;    /* Star ratings, progress bar fills ONLY */
  --gold-lt:     rgba(193,127,36,.65);

  /* ─── BUNDLE: Amber Resin (restricted use) ─── */
  --bundle:      #8B6E52;    /* Bundle upsell zones ONLY */
  --bundle-bg:   #F7F0E8;
  --bundle-bd:   rgba(139,110,82,0.22);

  /* ─── LEGACY (kept for compat, not actively used) ─── */
  --cta:         #1C1C1A;    /* Remapped to --ink. No green CTAs. */
  --cta-hover:   #1C1C1A;
  --trust:       #C17F24;    /* Remapped to --gold. No green trust. */
  --trust-bg:    #F0F0F2;    /* Remapped to --bg2. No green surfaces. */

  /* ─── TYPOGRAPHY ─── */
  --fd: "Cormorant Garamond", Georgia, "Times New Roman", serif;  /* Headlines, product names */
  --fb: "Outfit", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", sans-serif; /* Everything else */

  /* ─── SHARED ─── */
  --radius:      0px;
  --t:           0.22s cubic-bezier(0.32,0.72,0,1);

  /* ─── MOTION EASING TOKENS ─── */
  --ease-out: cubic-bezier(0.32,0.72,0,1);
  --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
  --ease-snappy: cubic-bezier(0.32,0.72,0,1);
}

/* Google Fonts:
   <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Outfit:wght@300;400;500;600&display=swap" rel="stylesheet">
*/

/* ─── USAGE RULES ─── */
/*
 * BUTTONS:
 *   - All buttons use --ink (black). No exceptions.
 *   - Hover: background:transparent, color:var(--ink) (outline reveal)
 *   - On dark backgrounds: background:var(--white), color:var(--ink)
 *   - Never use coloured buttons. The product is the colour.
 *
 * STARS & PROGRESS — Warm Amber (#C17F24):
 *   - Review stars (★★★★★)
 *   - Progress bar fills (delivery threshold, bundle step progress)
 *   - WCAG: 4.6:1 on #F5F4F0 — passes AA at all sizes
 *   - Never for buttons, borders, body text, or headings
 *
 * BUNDLE — Amber Resin (#8B6E52):
 *   - Bundle callout boxes, Save badges, loyalty tiers
 *   - Background: --bundle-bg (#F7F0E8)
 *   - Body copy inside bundle box uses --ink, not --bundle
 *
 * SURFACES — White-first system:
 *   - Page sits on --bg (White #FFFFFF)
 *   - Cards on --card (White #FFFFFF)
 *   - Subtle panels use --bg2 (Off-white #F7F7F8)
 *   - Section delineation via 1px borders + generous whitespace
 *
 * SMALL TEXT:
 *   - Never use --muted below 18px regular / 14px bold
 *   - For small secondary text, use --ink with lighter font-weight (300)
 */

/* ============================================================
   SHARED COMPONENTS — nav, footer, promo, mobile drawer
   These render on every page via header.php / footer.php
   ============================================================ */

/* ─── RESET ─── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; text-size-adjust:100%; background:var(--bg); scroll-behavior:smooth; }
body { font-family:var(--fb); color:var(--ink); -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; font-kerning:normal; font-size:16px; line-height:1.6; overflow-x:clip; }

/* ─── FOCUS ─── */
/* Visible focus ring for keyboard users (WCAG 2.1 AA) */
:focus-visible { outline:2px solid var(--ink); outline-offset:3px; transition:outline-offset .15s var(--ease-out); }
:focus-visible:active { outline-offset:1px; }
:focus:not(:focus-visible) { outline:none; }

/* Smooth focus transitions */
input, select, button { transition:border-color .2s var(--ease-out), background .2s var(--ease-out), color .2s var(--ease-out), transform .15s var(--ease-out); }

/* ─── SKIP LINK ─── */
.skip-link { position:absolute; top:-100px; left:16px; z-index:9999; background:var(--ink); color:var(--white); padding:12px 24px; font-family:var(--fb); font-size:13px; font-weight:500; letter-spacing:0.5px; text-decoration:none; transition:top .2s var(--ease-out); }
.skip-link:focus { top:8px; }

/* ─── GLOBAL BUTTON PRESS FEEDBACK ─── */
.tfw-btn:active, .cd-checkout-btn:active, .cd-viewcart-btn:active, .cd-shop-btn:active,
.cd-acc-btn:active, .md-cta-btn:active, button[type="submit"]:active { transform:scale(0.97); }
.nav-r svg:active, .nav-hamburger:active svg { transform:scale(0.9); }

/* ─── GLOBAL SCROLL REVEAL ─── */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .6s var(--ease-out), transform .6s var(--ease-out); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-group .reveal-child { opacity:0; transform:translateY(16px); transition:opacity .5s var(--ease-out), transform .5s var(--ease-out); }
.reveal-group .reveal-child.visible { opacity:1; transform:translateY(0); }
.reveal-child:nth-child(1){transition-delay:0ms}.reveal-child:nth-child(2){transition-delay:80ms}
.reveal-child:nth-child(3){transition-delay:160ms}.reveal-child:nth-child(4){transition-delay:240ms}
.reveal-child:nth-child(5){transition-delay:320ms}.reveal-child:nth-child(6){transition-delay:400ms}

/* ─── TABULAR FIGURES (prices align vertically) ─── */
.pdp-price, .pso-price, .pso-per, .ct-tfw-price, .ct-other-price,
.gs-card-price, .gs-card-was, .gs-card-save,
.quiz-result-price-tfw, .quiz-bundle-inline__price,
.cd-item-price, .cd-bundle-now, .cd-bundle-was,
.cart-badge { font-variant-numeric:tabular-nums; }

/* ─── UTILS ─── */
.rule { display:block; width:100%; height:3px; background:var(--ink); }
.breadcrumb { display:none !important; }

/* ─── PROMO BAR ─── */
.promo {
  background:var(--charcoal); color:var(--white);
  padding:0 16px; display:flex; align-items:center; justify-content:center;
  font-family:var(--fb); font-size:11px; font-weight:400;
  letter-spacing:1.2px; text-transform:uppercase;
  position:relative; height:36px; overflow:hidden;
}
.promo-msg {
  position:absolute; opacity:0; transform:translateY(8px);
  transition:opacity .4s var(--ease-out), transform .4s var(--ease-out);
  white-space:nowrap; will-change:transform, opacity;
}
.promo-msg.promo-active {
  opacity:1; transform:translateY(0);
}

/* ─── NAV ─── */
.nav {
  background:var(--white); height:56px; padding:0 24px;
  display:flex; align-items:center; justify-content:center;
  border-bottom:none; position:sticky; top:0; z-index:300;
}
.nav-logo { display:flex; align-items:center; position:absolute; left:50%; transform:translate(-50%, 2px); }
.nav-logo img { height:36px; width:auto; max-width:200px; }
.nav-links { display:none; }
.nav-links > a, .nav-links > span {
  font-family:var(--fb); font-size:14px; letter-spacing:1.2px; text-transform:uppercase;
  color:var(--ink); cursor:pointer; transition:color .18s var(--ease-out); padding-bottom:2px; font-weight:500;
  position:relative;
}
.nav-links > a:hover, .nav-links > a.active, .nav-links > span:hover, .nav-links > span.active { color:var(--ink); }
.nav-links > a.active, .nav-links > span.active { border-bottom:1px solid var(--ink); }
.nav-links > a { text-decoration:none; color:inherit; }

/* NAV — underline slide from left */
.nav-links > a::after, .nav-links > span::after {
  content:''; position:absolute; bottom:-2px; left:0;
  width:0; height:1px; background:var(--ink);
  transition:width .2s var(--ease-out);
}
.nav-links > a:hover::after, .nav-links > span:hover::after { width:100%; }
.nav-links > a.active::after, .nav-links > span.active::after { width:100%; }

/* VIBE DROPDOWN */
.nav-vibe { position:relative; background:none; border:none; cursor:pointer; font-family:var(--fb); font-size:14px; letter-spacing:1.2px; text-transform:uppercase; font-weight:500; color:var(--ink); padding:0; -webkit-appearance:none; appearance:none; }
button.md-nav-item { width:100%; text-align:left; background:none; border:none; border-bottom:1px solid var(--bd); cursor:pointer; -webkit-appearance:none; appearance:none; }
.nav-vibe-label { display:flex; align-items:center; gap:4px; }
.nav-vibe-label::after { content:"▾"; font-size:11px; color:var(--ink); font-family:var(--fb); }
.vibe-drop {
  position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(-4px);
  background:transparent; padding-top:18px;
  min-width:280px; opacity:0; pointer-events:none; visibility:hidden; transition:opacity .2s var(--ease-out), visibility .2s, transform .2s var(--ease-out);
  z-index:400;
}
.vibe-drop-inner { background:var(--white); border:1px solid var(--bd); border-top:2px solid var(--ink); box-shadow:0 12px 40px rgba(0,0,0,.1); }
.nav-vibe:hover .vibe-drop, .nav-vibe.open .vibe-drop { opacity:1; pointer-events:auto; visibility:visible; transform:translateX(-50%) translateY(0); }
.vibe-drop-head { padding:12px 18px 8px; font-family:var(--fb); font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--ink); font-weight:300; border-bottom:1px solid var(--bd); }
.vibe-drop-item { display:flex; align-items:center; gap:12px; padding:13px 18px; cursor:pointer; border-bottom:1px solid var(--bd); transition:background .12s; text-decoration:none; }
.vibe-drop-item:last-child { border-bottom:none; }
.vibe-drop-item:hover { background:var(--bg2); }
.vdi-icon { width:28px; height:28px; background:var(--ink); display:flex; align-items:center; justify-content:center; font-size:12px; flex:none; }
.vdi-name { font-family:var(--fb); font-size:13px; font-weight:500; color:var(--ink); }
.vdi-notes { font-family:var(--fb); font-size:11px; letter-spacing:1px; text-transform:uppercase; color:var(--ink); font-weight:300; margin-top:1px; }

/* Bundles — no special styling, matches other nav links */
.nav-bundles { }

/* ─── MORE DROPDOWN ─── */
.nav-more { position:relative; background:none; border:none; cursor:pointer; font-family:var(--fb); font-size:14px; letter-spacing:1.2px; text-transform:uppercase; font-weight:500; color:var(--ink); padding:0; -webkit-appearance:none; appearance:none; }
.nav-more-label { display:flex; align-items:center; gap:4px; }
.nav-more-label::after { content:"▾"; font-size:11px; color:var(--ink); font-family:var(--fb); }
.more-drop {
  position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(-4px);
  background:transparent; padding-top:18px;
  min-width:220px; opacity:0; pointer-events:none; visibility:hidden; transition:opacity .2s var(--ease-out), visibility .2s, transform .2s var(--ease-out);
  z-index:400;
}
.more-drop-inner { background:var(--white); border:1px solid var(--bd); border-top:2px solid var(--ink); box-shadow:0 12px 40px rgba(0,0,0,.1); }
.nav-more:hover .more-drop, .nav-more.open .more-drop { opacity:1; pointer-events:auto; visibility:visible; transform:translateX(-50%) translateY(0); }
.more-drop-item,
.more-drop-item:link,
.more-drop-item:visited {
  display:block; padding:13px 18px; font-family:var(--fb); font-size:13px; font-weight:400;
  letter-spacing:.5px; color:var(--ink) !important; text-decoration:none;
  border-bottom:1px solid var(--bd); transition:background .12s;
}
.more-drop-item:last-child { border-bottom:none; }
.more-drop-item:hover { background:var(--bg2); }

/* ─── SPRAY POINTS ICON ─── */
.nav-points-icon {
  background:none; border:none; cursor:pointer; padding:12px; margin:-12px;
  display:none; align-items:center; justify-content:center; min-width:44px; min-height:44px;
}

.nav-r { display:flex; align-items:center; gap:16px; position:absolute; right:24px; }
.nav-r svg { width:17px; height:17px; stroke:var(--ink); fill:none; stroke-width:1.4; cursor:pointer; }
.cart-wrap { position:relative; }
.cart-badge, .tfw-cart-count {
  position:absolute; top:-6px; right:-7px;
  background:var(--ink); color:var(--white);
  font-size:9px; width:15px; height:15px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--fb);
}

/* ─── FIBOSEARCH: disable ALL dark overlay/dimming ─── */
.dgwt-wcas-darkened-overlay,
.dgwt-wcas-overlay-mobile,
.dgwt-wcas-om-bar { display:none !important; opacity:0 !important; visibility:hidden !important; }
body.dgwt-wcas-darkoverl-on,
body.dgwt-wcas-overlay-mobile-on,
body.dgwt-wcas-focused { background:var(--bg) !important; }
body.dgwt-wcas-darkoverl-on::before,
body.dgwt-wcas-darkoverl-on::after,
body.dgwt-wcas-overlay-mobile-on::before,
body.dgwt-wcas-overlay-mobile-on::after { display:none !important; content:none !important; }

/* ─── DESKTOP NAV SEARCH DROPDOWN ─── */
/* Mobile: completely hidden */
@media(max-width:767px){
  .nav-search-drop { display:none !important; }
}
/* Desktop: rendered but visually hidden — prevents FiboSearch re-init scroll */
@media(min-width:768px){
  .nav-search-drop {
    position:fixed; top:56px; left:0; right:0; z-index:299;
    background:var(--white); border-bottom:1px solid var(--bd);
    box-shadow:0 8px 24px rgba(0,0,0,.06);
    opacity:0; visibility:hidden; pointer-events:none;
    transition:opacity .15s ease, visibility .15s ease;
  }
  .nav-search-drop.open { opacity:1; visibility:visible; pointer-events:auto; }
}
.nav-search-drop-inner { max-width:580px; margin:0 auto; padding:14px 24px; }
.nav-search-drop .dgwt-wcas-search-wrapp { max-width:100% !important; }
.nav-search-drop .dgwt-wcas-search-form { border-radius:0 !important; }
.nav-search-drop .dgwt-wcas-search-input { font-family:var(--fb) !important; font-size:16px !important; }
.nav-search-drop .dgwt-wcas-suggestions-wrapp { border-radius:0 !important; }
.nav-search-drop .dgwt-wcas-suggestion { font-family:var(--fb) !important; }
.nav-search-drop .dgwt-wcas-st { font-family:var(--fb) !important; color:var(--ink) !important; }
.nav-search-drop .dgwt-wcas-sp { font-family:var(--fb) !important; color:var(--ink) !important; }
.nav-search-drop-form { display:flex; }
.nav-search-drop-form input[name="s"] { flex:1; padding:12px 20px; border:1px solid var(--bd); font-family:var(--fb); font-size:16px; color:var(--ink); outline:none; }
.nav-search-drop-form input[name="s"]:focus { border-color:var(--ink); }
.nav-search-drop-form button { background:var(--ink); border:none; padding:0 18px; cursor:pointer; display:flex; align-items:center; min-height:44px; }
.nav-search-scrim { display:none; position:fixed; inset:0; z-index:298; background:rgba(0,0,0,.15); }
.nav-search-scrim.open { display:block; }

/* ─── HAMBURGER MENU ─── */
.nav-hamburger {
  display:block; background:none; border:none; cursor:pointer; padding:12px;
  position:absolute; left:24px; z-index:310;
}
.nav-hamburger svg { width:22px; height:22px; stroke:var(--ink); fill:none; stroke-width:1.6; }

/* ─── MOBILE DRAWER ─── */
.mobile-drawer {
  position:fixed; inset:0; z-index:500; opacity:0; pointer-events:none; transition:opacity .28s var(--ease-out);
}
.mobile-drawer.open { opacity:1; pointer-events:auto; }
.mobile-drawer-overlay { position:absolute; inset:0; background:rgba(10,10,8,.6); backdrop-filter:blur(4px); }
.mobile-drawer-panel {
  position:absolute; top:0; left:0; bottom:0; width:85%; max-width:340px;
  background:var(--white); transform:translateX(-100%); transition:transform .35s var(--ease-out); will-change:transform;
  overflow-y:auto; display:flex; flex-direction:column;
}
.mobile-drawer.open .mobile-drawer-panel { transform:translateX(0); }
.md-header { padding:20px 24px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--bd); }
.md-logo { display:flex; align-items:center; justify-content:center; text-decoration:none; flex:1; outline:none; }
/* Remove focus outlines for touch/programmatic focus in drawer — keep for keyboard */
.mobile-drawer-panel *:focus:not(:focus-visible) { outline:none !important; box-shadow:none !important; }
.md-logo img { height:40px; width:auto; max-width:160px; object-fit:contain; }
.md-close { background:none; border:none; cursor:pointer; font-size:18px; color:var(--ink); width:44px; height:44px; display:flex; align-items:center; justify-content:center; }
.md-close:hover { color:var(--ink); }
/* Bundle CTA in drawer */
.md-cta { padding:16px 24px; }
.md-cta-btn,
.md-cta-btn:link,
.md-cta-btn:visited { display:block; width:100%; padding:16px; background:var(--ink); color:var(--white) !important; font-family:var(--fb); font-size:12px; font-weight:400; letter-spacing:.06em; text-transform:uppercase; text-align:center; text-decoration:none; border:none; }
.md-search { padding:16px 24px; }
.md-search input {
  width:100%; padding:12px 16px; border:1px solid var(--bd); background:var(--bg);
  font-family:var(--fb); font-size:16px; color:var(--ink); outline:none;
}
.md-search input::placeholder { color:var(--ink); font-weight:300; }
.md-search input:focus { border-color:var(--ink); outline:none; }
.md-search .dgwt-wcas-search-input,
.md-search .dgwt-wcas-search-input:focus,
.md-search .dgwt-wcas-search-input:active { border:none !important; outline:none !important; box-shadow:none !important; }
.md-search .dgwt-wcas-search-form,
.md-search .dgwt-wcas-search-form:focus-within { border:none !important; outline:none !important; box-shadow:none !important; transition:none !important; background:var(--white) !important; }
.md-search .dgwt-wcas-sf-wrapp,
.md-search .dgwt-wcas-sf-wrapp:focus-within { outline:none !important; box-shadow:none !important; border:none !important; transition:none !important; }
.md-search .dgwt-wcas-search-wrapp,
.md-search .dgwt-wcas-search-wrapp:focus-within { outline:none !important; box-shadow:none !important; border:none !important; transition:none !important; }
/* Prevent iOS auto-zoom on all search inputs — must be ≥16px */
.dgwt-wcas-search-input { font-size:16px !important; }
.md-nav { padding:8px 0; }
.md-nav-item,
.md-nav-item:link,
.md-nav-item:visited,
.md-nav-item:active {
  display:block; padding:16px 24px; font-family:var(--fb); font-size:14px; font-weight:500;
  letter-spacing:1px; text-transform:uppercase; color:var(--ink) !important; text-decoration:none;
  border-bottom:1px solid var(--bd); transition:background .12s;
}
.md-nav-item:hover { background:var(--bg2); }
.md-nav-item.active { background:var(--bg2); border-left:3px solid var(--ink); }
.md-nav-bundles { font-weight:500; }
/* Vibe accordion */
.md-nav-item[data-toggle] { display:flex; align-items:center; justify-content:space-between; cursor:pointer; }
.md-nav-item[data-toggle] .md-chevron { width:12px; height:12px; stroke:var(--ink); fill:none; stroke-width:2; transition:transform .25s var(--ease-out); }
.md-nav-item[data-toggle].open .md-chevron { transform:rotate(180deg); }
.md-sub-items { padding:0; display:flex; flex-direction:column; gap:0; max-height:0; overflow:hidden; transition:max-height .35s var(--ease-out); }
.md-sub-items.open { max-height:500px; }
.md-sub-item,
.md-sub-item:link,
.md-sub-item:visited,
.md-sub-item:active {
  display:flex; align-items:center; gap:12px; padding:14px 24px 14px 40px;
  font-family:var(--fb); font-size:13px; font-weight:400; color:var(--ink) !important; text-decoration:none;
  border-bottom:1px solid var(--bd); transition:background .12s;
}
.md-sub-item:hover { background:var(--bg2); }
.md-sub-icon { font-size:18px; flex:none; width:28px; text-align:center; }
.md-sub-notes { font-family:var(--fb); font-size:11px; letter-spacing:1px; text-transform:uppercase; color:var(--ink); font-weight:300; display:block; margin-top:2px; }
/* ─── MOBILE SECONDARY NAV ─── */
.md-secondary { padding:16px 0; border-top:1px solid var(--bd); }
.md-sec-item,
.md-sec-item:link,
.md-sec-item:visited,
.md-sec-item:active {
  display:flex; align-items:center; gap:12px; padding:13px 24px;
  font-family:var(--fb); font-size:13px; font-weight:400; letter-spacing:.5px;
  color:var(--ink) !important; text-decoration:none; transition:background .12s;
}
.md-sec-item:hover { background:var(--bg2); }
.md-sec-icon { width:18px; height:18px; flex:none; stroke:var(--ink); fill:none; stroke-width:1.4; }

.md-footer { padding:24px; border-top:1px solid var(--bd); }
.md-footer-links { display:flex; flex-direction:column; gap:8px; }
.md-footer-links a,
.md-footer-links a:link,
.md-footer-links a:visited {
  font-family:var(--fb); font-size:11px; letter-spacing:1px; text-transform:uppercase;
  color:var(--ink); font-weight:300; text-decoration:none;
}

/* ─── FOOTER ─── */
.footer { background:var(--charcoal); border-top:3px solid var(--ink); }
/* Kill ALL default link colours inside footer */
.footer a, .footer a:link, .footer a:visited, .footer a:active { color:rgba(255,255,255,.75) !important; text-decoration:none; }
.footer a { transition:color .2s var(--ease-out) !important; }
.footer a:hover { color:var(--white) !important; }
/* Mobile-first: 2-col grid, tight padding */
.footer-top { padding:40px 20px; display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.ft-brand { font-family:var(--fb); font-size:17px; font-weight:500; letter-spacing:.5px; color:var(--white); margin-bottom:10px; }
.ft-tag { font-family:var(--fb); font-size:12px; font-weight:300; color:rgba(255,255,255,.65); line-height:1.6; max-width:240px; }
.ft-col-t { font-family:var(--fb); font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.70); margin-bottom:14px; }
.ft-links { display:flex; flex-direction:column; gap:9px; }
.ft-links a { font-family:var(--fb); font-size:12px; font-weight:300; }
/* Footer email capture — mobile-first: stacked, centered */
.footer-email { padding:24px; border-top:1px solid rgba(255,255,255,.08); }
.footer-email-inner { display:flex; flex-direction:column; align-items:center; text-align:center; gap:16px; max-width:900px; margin:0 auto; }
.footer-email-text { display:flex; flex-direction:column; gap:4px; align-items:center; }
.footer-email-title { font-family:var(--fb); font-size:14px; font-weight:500; color:var(--white); letter-spacing:.3px; }
.footer-email-sub { font-family:var(--fb); font-size:12px; font-weight:300; color:rgba(255,255,255,.6); }
.footer-email-form { display:flex; gap:0; width:100%; }
.footer-email-input { font-family:var(--fb); font-size:13px; color:var(--white); background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-right:none; padding:12px 16px; flex:1; min-width:0; }
.footer-email-input::placeholder { color:rgba(255,255,255,.4); }
.footer-email-input:focus { outline:none; border-color:rgba(255,255,255,.4); }
.footer-email-btn { font-family:var(--fb); font-size:12px; font-weight:500; letter-spacing:.08em; text-transform:uppercase; color:var(--ink); background:var(--white); border:1px solid var(--white); padding:12px 24px; cursor:pointer; transition:all .2s; white-space:nowrap; }
.footer-email-btn:hover { background:var(--bg2); }

/* Footer Trustpilot — mobile-first */
.footer-trustpilot { display:flex; align-items:center; justify-content:center; gap:8px; padding:12px 24px; border-top:1px solid rgba(255,255,255,.08); }
.footer-tp-stars { font-size:14px; color:var(--gold); letter-spacing:2px; }
.footer-tp-text { font-family:var(--fb); font-size:12px; font-weight:300; color:rgba(255,255,255,.6); }
.footer-tp-text strong { font-weight:500; color:var(--white); }

/* Mobile-first: tight padding */
.footer-bot { padding:20px; border-top:1px solid rgba(255,255,255,.08); display:flex; flex-direction:column; align-items:center; gap:12px; text-align:center; }
.footer-copy { font-family:var(--fb); font-size:11px; letter-spacing:1.2px; text-transform:uppercase; color:rgba(255,255,255,.55); }
.footer-legal { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.footer-legal a,
.footer-legal a:link,
.footer-legal a:visited { font-family:var(--fb); font-size:11px; color:rgba(255,255,255,.6) !important; text-decoration:none; font-weight:300; }
.footer-legal a:hover { color:var(--white) !important; text-decoration:underline; text-underline-offset:3px; }
.footer-badges { display:flex; gap:10px; }
.footer-badge { font-family:var(--fb); font-size:11px; letter-spacing:1.2px; text-transform:uppercase; color:rgba(255,255,255,.55); border:1px solid rgba(255,255,255,.12); padding:3px 9px; }
.footer-payments { display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-top:8px; }
.footer-pay-badge { font-family:var(--fb); font-size:11px; letter-spacing:1px; text-transform:uppercase; color:rgba(255,255,255,.55); border:1px solid rgba(255,255,255,.1); padding:4px 10px; }

/* ─── CART DRAWER ─── */
#cartScrim { position:fixed; inset:0; z-index:449; background:rgba(28,28,26,0.4); opacity:0; pointer-events:none; transition:opacity 280ms var(--ease-out); backdrop-filter:blur(2px); -webkit-backdrop-filter:blur(2px); }
#cartScrim.open { opacity:1; pointer-events:auto; }
#cartDrawer { position:fixed; top:0; right:0; bottom:0; width:100%; max-width:400px; z-index:450; background:var(--white); transform:translateX(100%); transition:transform 380ms var(--ease-out); display:flex; flex-direction:column; box-shadow:-8px 0 32px rgba(0,0,0,.1); will-change:transform; }
#cartDrawer.open { transform:translateX(0); }
.cd-header { display:flex; align-items:center; justify-content:space-between; padding:20px 24px; border-bottom:1px solid var(--bd); flex-shrink:0; }
.cd-title { font-family:var(--fb); font-size:14px; font-weight:500; letter-spacing:1px; text-transform:uppercase; color:var(--ink); }
.cd-count { font-weight:300; font-size:12px; color:var(--ink); }
.cd-close { background:none; border:none; font-size:24px; cursor:pointer; color:var(--ink); padding:0; line-height:1; width:44px; height:44px; display:flex; align-items:center; justify-content:center; }
.cd-body { flex:1; overflow-y:auto; padding:0; }
.cd-empty { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:60px 24px; text-align:center; }
.cd-empty p { font-family:var(--fb); font-size:14px; color:var(--ink); font-weight:300; margin-bottom:20px; }
.cd-shop-btn { font-family:var(--fb); font-size:12px; font-weight:400; letter-spacing:.06em; text-transform:uppercase; color:var(--ink); border:1px solid var(--ink); padding:12px 28px; text-decoration:none; transition:all .2s; }
.cd-shop-btn:hover { background:var(--ink); color:var(--white); }
.cd-items { display:flex; flex-direction:column; }
.cd-item { display:flex; gap:16px; padding:20px 24px; border-bottom:1px solid var(--bd); }
.cd-item-img { width:72px; height:90px; flex-shrink:0; background:var(--bg); }
.cd-item-img img { width:100%; height:100%; object-fit:cover; }
.cd-item-info { flex:1; min-width:0; display:flex; flex-direction:column; }
.cd-item-name { font-family:var(--fb); font-size:13px; font-weight:500; text-transform:uppercase; color:var(--ink); margin-bottom:2px; letter-spacing:.02em; }
.cd-item-attr { font-family:var(--fb); font-size:11px; color:var(--ink); font-weight:300; margin-bottom:8px; }
.cd-item-bottom { display:flex; align-items:center; justify-content:space-between; margin-top:auto; }
.cd-item-price { font-family:var(--fb); font-size:14px; font-weight:400; color:var(--ink); }
.cd-qty { display:flex; align-items:center; border:1px solid var(--bd); }
.cd-qty button { background:none; border:none; width:44px; height:44px; font-size:16px; cursor:pointer; color:var(--ink); display:flex; align-items:center; justify-content:center; transition:background .15s; }
.cd-qty button:hover { background:var(--bg); }
.cd-qty-val { font-family:var(--fb); font-size:13px; font-weight:400; width:32px; text-align:center; color:var(--ink); }
.cd-item-remove { background:none; border:none; font-family:var(--fb); font-size:11px; letter-spacing:.5px; text-transform:uppercase; color:var(--ink); cursor:pointer; padding:4px 0; font-weight:300; transition:color .15s; }
.cd-item-remove:hover { font-weight:400; }
.cd-footer { flex-shrink:0; padding:20px 24px; padding-bottom:max(20px, env(safe-area-inset-bottom)); border-top:1px solid var(--bd); }
.cd-subtotal { display:flex; justify-content:space-between; font-family:var(--fb); font-size:14px; font-weight:500; color:var(--ink); margin-bottom:6px; }
.cd-shipping-note { font-family:var(--fb); font-size:11px; color:var(--ink); font-weight:300; margin-bottom:16px; }
.cd-checkout-btn { display:block; width:100%; padding:16px; background:var(--ink); color:var(--white); font-family:var(--fb); font-size:13px; font-weight:400; letter-spacing:.06em; text-transform:uppercase; text-align:center; text-decoration:none; border:none; cursor:pointer; transition:opacity .2s; margin-bottom:8px; }
.cd-checkout-btn:hover { background:transparent; color:var(--ink); border:1px solid var(--ink); }
.cd-viewcart-btn { display:block; width:100%; padding:12px; background:transparent; color:var(--ink); font-family:var(--fb); font-size:12px; font-weight:400; letter-spacing:.06em; text-transform:uppercase; text-align:center; text-decoration:none; border:1px solid var(--bd); transition:border-color .2s; }
.cd-viewcart-btn:hover { border-color:var(--ink); }
/* Bundle group in cart drawer */
.cd-bundle-group { border:1px solid var(--bd); margin:12px; background:var(--bg); }
.cd-bundle-header { display:flex; flex-direction:column; padding:14px 16px 4px; gap:2px; }
.cd-bundle-label { font-family:var(--fb); font-size:13px; font-weight:600; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink); }
.cd-bundle-meta { font-family:var(--fb); font-size:11px; font-weight:400; color:var(--ink); }
.cd-bundle-pricing { display:flex; align-items:baseline; gap:8px; padding:0 16px 12px; border-bottom:1px solid var(--bd); }
.cd-bundle-was { font-family:var(--fb); font-size:12px; font-weight:300; color:var(--ink); text-decoration:line-through; }
.cd-bundle-now { font-family:var(--fb); font-size:18px; font-weight:600; color:var(--ink); letter-spacing:-0.02em; }
.cd-bundle-save { font-family:var(--fb); font-size:10px; font-weight:500; color:#8B6E52; letter-spacing:0.04em; text-transform:uppercase; }
.cd-bundle-total { font-family:var(--fb); font-size:14px; font-weight:500; color:var(--ink); letter-spacing:0; text-transform:none; }
.cd-bundle-item { padding:12px 16px; }
.cd-bundle-item .cd-item-img { width:48px; height:60px; }
.cd-bundle-item .cd-item-name { font-size:12px; }
.cd-price-was { text-decoration:line-through; font-weight:300; font-size:12px; color:var(--ink); margin-right:4px; }

/* Shipping progress bar */
.cd-shipping-bar{height:4px;background:var(--bd);margin-bottom:8px;border-radius:0;overflow:hidden}
.cd-shipping-bar-fill{height:100%;background:var(--ink);border-radius:0;transition:width .5s var(--ease-out);width:0}
.cd-shipping-bar-fill.complete{background:var(--gold)}
.cd-shipping-msg{font-family:var(--fb);font-size:11px;color:var(--ink);font-weight:400;margin-bottom:12px;text-align:center}
.cd-shipping-msg strong{font-weight:500}
.cd-shipping-msg .cd-ship-icon{margin-right:4px}
/* Dynamic upsell */
.cd-upsell-dynamic{margin-bottom:12px}
.cd-upsell-dynamic:empty{display:none;margin:0}
.cd-upsell-nudge{background:var(--ink);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.cd-upsell-nudge-text{font-family:var(--fb);font-size:12px;color:var(--white);font-weight:300}
.cd-upsell-nudge-text strong{font-weight:500;color:var(--gold)}
.cd-upsell-nudge-link,.cd-upsell-nudge-link:link,.cd-upsell-nudge-link:visited{font-family:var(--fb);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--white);text-decoration:none;white-space:nowrap;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:1px}
.cd-upsell-nudge-link:hover{border-color:var(--white)}
/* Accessory quick-add in cart */
.cd-upsell-acc{padding:12px 16px;background:var(--bg);border:1px solid var(--bd);margin-bottom:12px}
.cd-upsell-acc-label{display:block;font-family:var(--fb);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--ink);margin-bottom:8px;font-weight:400}
.cd-upsell-acc-btns{display:flex;gap:8px}
.cd-acc-btn{flex:1;padding:10px 12px;background:var(--white);border:1px solid var(--bd);font-family:var(--fb);font-size:12px;font-weight:400;color:var(--ink);cursor:pointer;transition:border-color .15s;text-align:center}
.cd-acc-btn:hover{border-color:var(--ink)}

/* ─── MOBILE TOUCH FEEDBACK (base, always available) ─── */
.nav-hamburger:active { transform:scale(0.92); }
.cd-close:active, .md-close:active { transform:scale(0.9); }
.cd-checkout-btn:active, .cd-viewcart-btn:active { transform:scale(0.98); }

/* ─── RESPONSIVE — DESKTOP (769px+) ─── */
@media(min-width:769px){
  .promo { padding:0 48px; height:42px; font-size:13px; letter-spacing:1.5px; }
  .nav { padding:0 48px; height:60px; justify-content:space-between; }
  .nav-logo { position:static; transform:none; }
  .nav-logo img { height:44px; max-width:none; }
  .nav-r { position:static; }
  .nav-links { display:flex; gap:20px; align-items:center; }
  .nav-hamburger { display:none; }
  .nav-points-icon { display:flex; }
  .footer-top { grid-template-columns:2fr 1fr 1fr 1fr; padding:60px 48px; gap:48px; }
  .ft-brand { font-size:16px; }
  .footer-bot { padding:24px 48px 32px; }
  .footer-legal { gap:16px; }
  .footer-email { padding:32px 48px; }
  .footer-email-inner { flex-direction:row; text-align:left; align-items:center; justify-content:space-between; }
  .footer-email-text { align-items:flex-start; }
  .footer-email-form { width:auto; }
  .footer-email-input { min-width:220px; }
  .footer-trustpilot { padding:16px 48px; }
}

/* ─── DESKTOP TYPOGRAPHY (1024px+) ─── */
@media(min-width:1024px){
  body { font-size:18px; }
}

/* ============================================================
   SOCIAL PROOF WALL — Full wall (Homepage, Inspired-By, Bundle)
   ============================================================ */
.social-wall {
  background: var(--ink);
  padding: 56px 0 0;
  position: relative;
  overflow: hidden;
}
.social-wall::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 20% 50%, rgba(255,255,255,0.04) 1px, transparent 1px),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,0.03) 1px, transparent 1px),
    radial-gradient(circle at 40% 80%, rgba(255,255,255,0.035) 1px, transparent 1px),
    radial-gradient(circle at 60% 30%, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 2px 2px, 4px 4px, 3px 3px, 5px 5px;
  pointer-events: none;
}
.social-wall > * { position: relative; z-index: 1; }
.sw-header {
  text-align: center;
  padding: 0 20px 40px;
}
.sw-eyebrow {
  font-family: var(--fb);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}
.sw-title {
  font-family: var(--fd);
  font-size: clamp(26px, 4vw, 34px);
  font-weight: 300;
  font-style: italic;
  color: var(--white);
  margin-bottom: 28px;
}
.sw-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  max-width: 720px;
  margin: 0 auto;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 28px;
}
.sw-stat-block {
  text-align: center;
  padding: 0 12px;
  position: relative;
}
.sw-stat-block::after {
  content: '';
  position: absolute;
  right: 0;
  top: 10%;
  height: 80%;
  width: 1px;
  background: rgba(255,255,255,0.08);
}
.sw-stat-block:last-child::after { display: none; }
.sw-stat-big {
  font-family: var(--fb);
  font-size: clamp(32px, 5vw, 48px);
  font-weight: 600;
  color: var(--white);
  letter-spacing: -0.03em;
  line-height: 1;
  display: block;
  margin-bottom: 6px;
}
.sw-stat-label {
  font-family: var(--fb);
  font-size: 11px;
  font-weight: 300;
  color: #AAA;
  line-height: 1.4;
  display: block;
  max-width: 180px;
  margin: 0 auto;
}
.sw-grid {
  display: flex;
  overflow-x: auto;
  gap: 3px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.sw-grid::-webkit-scrollbar { display: none; }
.sw-cell {
  flex: 0 0 44vw;
  aspect-ratio: 1/1;
  overflow: hidden;
  scroll-snap-align: start;
}
.sw-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.sw-tall { aspect-ratio: 1/1; }
.sw-footer {
  font-family: var(--fb);
  font-size: 10px;
  font-weight: 300;
  color: #888;
  text-align: center;
  padding: 14px 20px;
  background: var(--ink);
}
@media(min-width:768px) {
  .social-wall { padding: 80px 0 0; }
  .sw-header { padding: 0 48px 48px; }
  .sw-stat-block { padding: 0 16px; }
  .sw-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 4px;
    overflow: visible;
  }
  .sw-cell { flex: none; aspect-ratio: 1/1; }
  .sw-tall { grid-row: span 2; aspect-ratio: auto; }
  .sw-footer { padding: 20px 48px; }
}
@media (hover: hover) and (pointer: fine) {
  .sw-cell img {
    transition: transform 0.4s cubic-bezier(0,0,0.2,1);
  }
  .sw-cell:hover img {
    transform: scale(1.05);
  }
}

/* ============================================================
   COMPACT UGC STRIP — Reusable across PDP, Discovery, Shop, Comparison
   ============================================================ */
.ugc-strip {
  padding: 48px 0;
  overflow: hidden;
}
.ugc-strip-label {
  font-family: var(--fb);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink);
  text-align: center;
  margin-bottom: 20px;
  padding: 0 20px;
}
.ugc-strip-scroll {
  display: flex;
  gap: 4px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 0 20px;
}
.ugc-strip-scroll::-webkit-scrollbar { display: none; }
.ugc-strip-cell {
  flex: 0 0 140px;
  aspect-ratio: 1/1;
  overflow: hidden;
  scroll-snap-align: start;
}
.ugc-strip-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ugc-strip-line {
  font-family: var(--fb);
  font-size: 12px;
  font-weight: 300;
  color: var(--ink);
  text-align: center;
  margin-top: 16px;
  padding: 0 20px;
}
.ugc-strip-line strong {
  font-weight: 500;
}
@media(min-width:768px) {
  .ugc-strip { padding: 56px 0; }
  .ugc-strip-scroll {
    justify-content: center;
    gap: 6px;
    padding: 0 48px;
    overflow: visible;
  }
  .ugc-strip-cell {
    flex: 0 0 160px;
  }
  .ugc-strip-label { font-size: 11px; }
}
@media (hover: hover) and (pointer: fine) {
  .ugc-strip-cell img {
    transition: transform 0.35s cubic-bezier(0,0,0.2,1);
  }
  .ugc-strip-cell:hover img {
    transform: scale(1.06);
  }
}

/* ─── FRAGRANCE FAMILY BADGE (global — all product cards) ─── */
.pc-fam { position:absolute; bottom:12px; left:12px; font-family:var(--fb); font-size:9px; font-weight:500; letter-spacing:0.08em; text-transform:uppercase; padding:4px 10px; z-index:3; background:var(--white); color:var(--ink); border:1px solid var(--bd); }
.pc-fam--floral { background:#F9F0F4; color:#8C3B5E; border-color:#E8C8D6; }
.pc-fam--gourmand { background:#FDF5EE; color:#8B5E3C; border-color:#E5CDAE; }
.pc-fam--oriental-spicy, .pc-fam--oriental { background:#F7F0EA; color:#7A4B2A; border-color:#D9C0A5; }
.pc-fam--fresh-citrus, .pc-fam--fresh { background:#EFF6F2; color:#3B6B4F; border-color:#B5D4C1; }
.pc-fam--woody-oud, .pc-fam--woody { background:#F3F0EB; color:#5C4A35; border-color:#C9B99A; }
.pc-fam--chypre-green { background:#F1F4EE; color:#4A5E3B; border-color:#B8C9A5; }
.pc-fam--amber { background:#F8F2E8; color:#7A5C2B; border-color:#D4BC8A; }

/* ─── REDUCED MOTION ─── */
@media(prefers-reduced-motion:reduce){
  *, *::before, *::after { animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; }
  .reveal, .reveal-child { opacity:1 !important; transform:none !important; transition:none !important; }
}
