/* ============================================================
   ABHAY SHAH PERFUME CREATOR — Design System v4
   Cormorant Garamond + DM Sans · 8px Grid · Light/Dark
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,300;1,9..40,400&display=swap');

/* ── 8px SPACING TOKENS ─────────────────────────────────── */
:root {
  --s1:  8px;  --s2: 16px;  --s3: 24px;  --s4: 32px;
  --s5: 40px;  --s6: 48px;  --s8: 64px;  --s10: 80px;
  --s12: 96px; --s16: 128px;

  /* ── Radius ─── */
  --r-sm: 8px; --r-md: 16px; --r-lg: 24px; --r-xl: 32px; --r-pill: 100px;

  /* ── Font ─── */
  --f-display: 'Cormorant Garamond', Georgia, serif;
  --f-body:    'DM Sans', system-ui, sans-serif;

  /* ── Transition ─── */
  --ease: cubic-bezier(.4, 0, .2, 1);
  --t-fast: .18s; --t-base: .28s; --t-slow: .45s;
}

/* ── LIGHT THEME (Default) ────────────────────────────────── */
:root, [data-theme="light"] {
  --bg:        #FAF8F5;
  --bg-alt:    #F3EDE4;
  --surface:   #FFFFFF;
  --card:      #FFFFFF;
  --card-h:    #FBF7F2;
  --border:    rgba(26,20,10,.09);
  --border-m:  rgba(26,20,10,.16);
  --txt:       #1A1410;
  --txt-soft:  #5C4E3A;
  --muted:     #9C8870;
  --gold:      #A07828;
  --gold-l:    #C49A30;
  --gold-glow: rgba(160,120,40,.18);
  --red:       #B83020;
  --nav-bg:    rgba(250,248,245,.95);
  --shadow-sm: 0 2px 8px rgba(26,20,10,.07);
  --shadow-md: 0 8px 32px rgba(26,20,10,.1);
  --shadow-lg: 0 20px 60px rgba(26,20,10,.13);
  --tag-bg:    rgba(26,20,10,.05);
  --tag-c:     #5C4E3A;
  --overlay:   rgba(26,20,10,.55);
  --hero-bg:   #F5EFE6;
  --strip-bg:  #1A1410;
  --strip-c:   rgba(255,255,255,.75);
}

/* ── DARK THEME ────────────────────────────────────────────── */
[data-theme="dark"] {
  --bg:        #0E0A06;
  --bg-alt:    #141008;
  --surface:   #1A1410;
  --card:      #1E1910;
  --card-h:    #242016;
  --border:    rgba(255,255,255,.08);
  --border-m:  rgba(255,255,255,.15);
  --txt:       #F0EAE0;
  --txt-soft:  #C8B89A;
  --muted:     rgba(240,234,224,.45);
  --gold:      #C9974A;
  --gold-l:    #E8C070;
  --gold-glow: rgba(201,151,74,.2);
  --red:       #E05040;
  --nav-bg:    rgba(14,10,6,.96);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.25);
  --shadow-md: 0 8px 32px rgba(0,0,0,.35);
  --shadow-lg: 0 20px 60px rgba(0,0,0,.5);
  --tag-bg:    rgba(255,255,255,.07);
  --tag-c:     rgba(240,234,224,.55);
  --overlay:   rgba(0,0,0,.65);
  --hero-bg:   #0E0A06;
  --strip-bg:  #0A0806;
  --strip-c:   rgba(255,255,255,.6);
}

/* ── RESET ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family: var(--f-body);
  background: var(--bg);
  color: var(--txt);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: background var(--t-base) var(--ease),
              color var(--t-base) var(--ease);
}
img { max-width:100%; display:block; object-fit:cover; }
a   { text-decoration:none; color:inherit; }
button { font-family:var(--f-body); cursor:pointer; }
ul { list-style:none; }

/* ── LAYOUT ────────────────────────────────────────────────── */
.wrap { max-width:1280px; margin:0 auto; padding:0 var(--s4); }
.page-wrap { min-height:100vh; }

/* ── TYPOGRAPHY SCALE ──────────────────────────────────────── */
.display-1 { font-family:var(--f-display); font-size:clamp(56px,7vw,96px); font-weight:300; line-height:1.02; letter-spacing:-.5px; }
.display-2 { font-family:var(--f-display); font-size:clamp(40px,5vw,68px); font-weight:400; line-height:1.06; letter-spacing:-.3px; }
.heading-1 { font-family:var(--f-display); font-size:clamp(30px,4vw,48px); font-weight:500; line-height:1.12; }
.heading-2 { font-family:var(--f-display); font-size:clamp(22px,3vw,36px); font-weight:500; line-height:1.18; }
.heading-3 { font-family:var(--f-display); font-size:clamp(18px,2.5vw,24px); font-weight:500; line-height:1.25; }
.body-lg    { font-size:17px; line-height:1.75; }
.body-md    { font-size:15px; line-height:1.7; }
.body-sm    { font-size:13px; line-height:1.65; }
.label      { font-size:11px; letter-spacing:3px; text-transform:uppercase; font-weight:600; }
.italic     { font-style:italic; }
.em-gold    { color:var(--gold); font-style:italic; }
.muted      { color:var(--muted); }
.txt-soft   { color:var(--txt-soft); }

/* ── EYEBROW ─────────────────────────────────────────────── */
.eyebrow {
  display:inline-flex; align-items:center; gap:var(--s1);
  font-size:11px; letter-spacing:3px; text-transform:uppercase;
  font-weight:600; color:var(--gold); margin-bottom:var(--s2);
}
.eyebrow::before { content:''; display:block; width:28px; height:1.5px; background:var(--gold); }

/* ── SECTION HEADING ────────────────────────────────────────── */
.section-h {
  font-family:var(--f-display);
  font-size:clamp(28px,4vw,48px);
  font-weight:400; line-height:1.1; color:var(--txt);
}
.section-h em { font-style:italic; color:var(--gold); }
.section-sub { font-size:15px; color:var(--muted); margin-top:var(--s2); line-height:1.75; max-width:560px; }

/* ── DIVIDER ─────────────────────────────────────────────── */
.divider { width:48px; height:2px; background:linear-gradient(90deg,var(--gold),transparent); margin:var(--s3) 0; }

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:var(--s1);
  padding:14px var(--s4); border-radius:var(--r-pill);
  font-family:var(--f-body); font-size:13px; font-weight:600;
  letter-spacing:.5px; transition:all var(--t-base) var(--ease); border:none;
  cursor:pointer; white-space:nowrap;
}
.btn-primary {
  background:var(--txt); color:var(--bg);
  box-shadow: var(--shadow-sm);
}
.btn-primary:hover { background:var(--gold); color:#fff; transform:translateY(-1px); box-shadow:0 6px 24px var(--gold-glow); }
.btn-gold {
  background:linear-gradient(135deg, var(--gold), var(--gold-l));
  color:#fff; box-shadow:0 4px 18px var(--gold-glow);
}
.btn-gold:hover { transform:translateY(-2px); box-shadow:0 8px 28px var(--gold-glow); filter:brightness(1.06); }
.btn-ghost {
  background:transparent; color:var(--txt);
  border:1.5px solid var(--border-m);
}
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); }
.btn-icon {
  background:transparent; color:var(--txt);
  border:1.5px solid var(--border-m);
  width:44px; height:44px; padding:0; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
}
.btn-icon:hover { border-color:var(--gold); color:var(--gold); }
.btn-sm { padding:10px var(--s3); font-size:12px; }
.btn-lg { padding:18px var(--s6); font-size:15px; }

/* ── PILLS / BADGES ─────────────────────────────────────── */
.pill {
  display:inline-flex; align-items:center;
  padding:3px 12px; border-radius:var(--r-pill);
  font-size:10px; font-weight:700; letter-spacing:.8px; text-transform:uppercase;
}
.pill-gold   { background:rgba(160,120,40,.12); color:var(--gold); border:1px solid rgba(160,120,40,.25); }
.pill-rose   { background:rgba(196,115,106,.12); color:#B86055; border:1px solid rgba(196,115,106,.25); }
.pill-green  { background:rgba(52,183,120,.1); color:#34b778; border:1px solid rgba(52,183,120,.25); }
.pill-dark   { background:var(--tag-bg); color:var(--tag-c); border:1px solid var(--border); }
.pill-new    { background:rgba(52,183,120,.1); color:#34b778; border:1px solid rgba(52,183,120,.3); }

/* ── NAV ──────────────────────────────────────────────────── */
.site-nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  transition: background var(--t-base) var(--ease),
              box-shadow var(--t-base) var(--ease),
              backdrop-filter var(--t-base) var(--ease);
}
.site-nav.scrolled {
  background: var(--nav-bg);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  box-shadow: 0 1px 0 var(--border);
}
.nav-strip {
  background: var(--strip-bg);
  text-align:center; padding:9px var(--s4);
  font-size:11px; letter-spacing:2.5px;
  color:var(--strip-c); font-weight:500;
  overflow:hidden;
}
.nav-strip-inner {
  display:inline-flex; gap:0; animation:stripMarch 30s linear infinite; white-space:nowrap;
}
.nav-strip-item { padding:0 var(--s6); display:inline-flex; align-items:center; gap:var(--s3); }
@keyframes stripMarch { to { transform:translateX(-50%); } }

.nav-main {
  display:flex; align-items:center; justify-content:space-between;
  padding:var(--s2) var(--s4); max-width:1280px; margin:0 auto;
  gap:var(--s4);
}
.nav-logo {
  font-family:var(--f-display);
  font-size:22px; font-weight:500; color:var(--txt);
  display:flex; align-items:center; gap:var(--s2);
  letter-spacing:-.2px; flex-shrink:0;
}
.nav-logo-img {
  height:36px; width:36px; object-fit:contain; border-radius:var(--r-sm);
  background: var(--card); border:1px solid var(--border);
}
.nav-links {
  display:flex; gap:var(--s5); align-items:center;
}
.nav-links a {
  font-size:13px; font-weight:500; color:var(--muted);
  transition:color var(--t-fast) var(--ease); letter-spacing:.2px;
  position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0; height:1.5px;
  background:var(--gold); transform:scaleX(0); transition:transform var(--t-base) var(--ease);
  transform-origin:left;
}
.nav-links a:hover { color:var(--txt); }
.nav-links a:hover::after, .nav-links a.active::after { transform:scaleX(1); }
.nav-links a.active { color:var(--txt); }

.nav-actions { display:flex; gap:var(--s1); align-items:center; flex-shrink:0; }
.nav-cart-btn {
  display:flex; align-items:center; gap:6px;
  background:var(--card); border:1.5px solid var(--border);
  color:var(--txt); padding:9px 18px; border-radius:var(--r-pill);
  font-size:13px; font-weight:600; transition:all var(--t-fast) var(--ease);
  position:relative;
}
.nav-cart-btn:hover { border-color:var(--gold); }
.cart-badge {
  position:absolute; top:-7px; right:-7px;
  width:19px; height:19px; border-radius:50%;
  background:var(--gold); color:#fff;
  font-size:10px; font-weight:700;
  display:none; align-items:center; justify-content:center;
  font-family:var(--f-body);
}

/* Theme toggle */
.theme-toggle {
  width:40px; height:40px; border-radius:50%;
  background:var(--card); border:1.5px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:17px; cursor:pointer;
  transition:all var(--t-fast) var(--ease);
  flex-shrink:0;
}
.theme-toggle:hover { border-color:var(--gold); transform:rotate(20deg); }

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; padding:var(--s1); cursor:pointer;
}
.hamburger span { width:22px; height:1.5px; background:var(--txt); border-radius:2px; transition:all var(--t-base) var(--ease); }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(4.5px, 4.5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(4.5px, -4.5px); }

/* Mobile nav overlay */
.mobile-nav {
  display:none; position:fixed; inset:0; z-index:850;
  background:var(--bg); flex-direction:column;
  padding:80px var(--s4) var(--s4);
  gap:0; overflow-y:auto;
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
  padding:var(--s3) 0; font-size:20px;
  font-family:var(--f-display); font-weight:400;
  color:var(--txt); border-bottom:1px solid var(--border);
  transition:color var(--t-fast) var(--ease);
}
.mobile-nav a:hover { color:var(--gold); padding-left:var(--s2); }
.mob-close {
  position:absolute; top:var(--s3); right:var(--s3);
  background:var(--card); border:1px solid var(--border);
  color:var(--txt); width:44px; height:44px; border-radius:50%;
  font-size:18px;
}

/* ── PRODUCT CARDS ───────────────────────────────────────── */
.pcard {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden; cursor:pointer;
  transition:all var(--t-base) var(--ease);
}
.pcard:hover {
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  border-color:var(--border-m);
}
.pcard-img {
  height:240px; position:relative;
  overflow:hidden; display:flex;
  align-items:center; justify-content:center;
}
.pcard-img img {
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  transition:transform var(--t-slow) var(--ease);
  z-index:1; loading:lazy;
}
.pcard:hover .pcard-img img { transform:scale(1.06); }
.pcard-img-emoji { font-size:56px; position:relative; z-index:2; }
.pcard-badge { position:absolute; top:var(--s2); left:var(--s2); z-index:3; }
.pcard-wish {
  position:absolute; top:var(--s2); right:var(--s2); z-index:3;
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.85); border:1px solid rgba(0,0,0,.08);
  backdrop-filter:blur(8px); display:flex; align-items:center;
  justify-content:center; font-size:14px; transition:all var(--t-fast) var(--ease);
}
[data-theme="dark"] .pcard-wish { background:rgba(0,0,0,.5); border:1px solid rgba(255,255,255,.1); }
.pcard-wish:hover { transform:scale(1.12); }
.pcard-body { padding:var(--s3); }
.pcard-gender {
  font-size:10px; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--gold); font-weight:600; margin-bottom:4px;
}
.pcard-name {
  font-family:var(--f-display); font-size:20px;
  color:var(--txt); font-weight:500; margin-bottom:3px;
  line-height:1.2;
}
.pcard-tag { font-size:12px; color:var(--muted); font-style:italic; margin-bottom:var(--s2); line-height:1.4; }
.pcard-mood { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:var(--s2); }
.pcard-mood span {
  font-size:10px; padding:3px 10px; border-radius:var(--r-pill);
  background:var(--tag-bg); color:var(--tag-c);
  border:1px solid var(--border); font-weight:500;
}
.pcard-sizes { display:flex; gap:6px; margin-bottom:var(--s2); }
.size-chip {
  flex:1; padding:9px 4px; border-radius:var(--r-sm);
  border:1.5px solid var(--border); font-size:11px;
  font-weight:600; cursor:pointer; transition:all var(--t-fast) var(--ease);
  background:transparent; color:var(--muted);
  font-family:var(--f-body); text-align:center; line-height:1.3;
}
.size-chip:hover { border-color:var(--gold-l); color:var(--gold); }
.size-chip.active { border-color:var(--gold); color:var(--gold); background:var(--gold-glow); }
.pcard-bottom { display:flex; align-items:center; justify-content:space-between; }
.pcard-price { font-family:var(--f-display); font-size:22px; font-weight:600; color:var(--txt); }
.add-bag {
  padding:10px var(--s3); background:var(--txt); color:var(--bg);
  border:none; border-radius:var(--r-pill); font-size:12px; font-weight:600;
  font-family:var(--f-body); transition:all var(--t-fast) var(--ease);
  letter-spacing:.3px;
}
.add-bag:hover { background:var(--gold); color:#fff; transform:scale(1.03); }

/* ── FOOTER ──────────────────────────────────────────────── */
footer {
  background:var(--bg-alt);
  border-top:1px solid var(--border);
}
.footer-inner { max-width:1280px; margin:0 auto; padding:var(--s10) var(--s4) var(--s4); }
.footer-grid { display:grid; grid-template-columns:2.2fr 1fr 1fr 1fr; gap:var(--s10); margin-bottom:var(--s8); }
.footer-logo {
  font-family:var(--f-display);
  font-size:24px; font-weight:400; color:var(--txt);
  display:flex; align-items:center; gap:var(--s2); margin-bottom:var(--s3);
}
.footer-logo img { height:36px; width:36px; object-fit:contain; border-radius:var(--r-sm); }
.footer-desc { font-size:14px; color:var(--muted); line-height:1.75; margin-bottom:var(--s3); max-width:280px; }
.footer-contact p { font-size:13px; color:var(--muted); margin-bottom:var(--s1); }
.footer-contact a:hover { color:var(--gold); }
.footer-col h4 { font-family:var(--f-display); font-size:15px; color:var(--txt); margin-bottom:var(--s3); font-weight:500; }
.footer-col a { display:block; font-size:13px; color:var(--muted); margin-bottom:var(--s2); transition:color var(--t-fast); }
.footer-col a:hover { color:var(--gold); }
.footer-socials { display:flex; gap:var(--s1); margin-top:var(--s3); }
.soc-btn {
  width:38px; height:38px; border-radius:50%;
  background:var(--card); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; transition:all var(--t-fast) var(--ease);
}
.soc-btn:hover { border-color:var(--gold); transform:translateY(-2px); }
.footer-bottom {
  border-top:1px solid var(--border);
  padding-top:var(--s3); display:flex;
  justify-content:space-between; align-items:center; flex-wrap:wrap; gap:var(--s2);
}
.footer-bottom span { font-size:12px; color:var(--muted); }
.pay-chips { display:flex; gap:var(--s1); }
.pay-chip {
  padding:4px 10px; border:1px solid var(--border);
  border-radius:var(--r-sm); font-size:10px; font-weight:700;
  color:var(--muted); background:var(--card); letter-spacing:.5px;
}

/* ── REVEAL ANIMATION ─────────────────────────────────────── */
.reveal {
  opacity:0; transform:translateY(28px);
  transition:opacity .65s var(--ease), transform .65s var(--ease);
}
.reveal.in { opacity:1; transform:translateY(0); }
.reveal-left  { opacity:0; transform:translateX(-28px); transition:opacity .65s var(--ease),transform .65s var(--ease); }
.reveal-left.in { opacity:1; transform:translateX(0); }
.reveal-right { opacity:0; transform:translateX(28px); transition:opacity .65s var(--ease),transform .65s var(--ease); }
.reveal-right.in { opacity:1; transform:translateX(0); }
.delay-1 { transition-delay:.1s; }
.delay-2 { transition-delay:.2s; }
.delay-3 { transition-delay:.3s; }
.delay-4 { transition-delay:.4s; }

/* ── GLASS CARD ───────────────────────────────────────────── */
.glass {
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-lg);
}
[data-theme="light"] .glass {
  background:rgba(255,255,255,.7);
  border:1px solid rgba(0,0,0,.08);
}

/* ── FORM ELEMENTS ────────────────────────────────────────── */
.field {
  width:100%; padding:14px var(--s3);
  border:1.5px solid var(--border-m);
  border-radius:var(--r-md);
  background:var(--surface); color:var(--txt);
  font-family:var(--f-body); font-size:14px;
  outline:none; transition:border-color var(--t-fast) var(--ease);
}
.field::placeholder { color:var(--muted); }
.field:focus { border-color:var(--gold); }

/* ── CART DRAWER ──────────────────────────────────────────── */
#_cartDrawer { background:var(--surface); border-left:1px solid var(--border); }

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width:1024px) {
  .footer-grid { grid-template-columns:1fr 1fr; gap:var(--s8); }
}
@media (max-width:900px) {
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .wrap { padding:0 var(--s3); }
}
@media (max-width:640px) {
  .wrap { padding:0 var(--s2); }
  .footer-grid { grid-template-columns:1fr; gap:var(--s5); }
  .footer-bottom { flex-direction:column; align-items:flex-start; gap:var(--s2); }
}

/* Hide emoji when real product image is present */
.pcard-img img { display:block; z-index:2; }
.pcard-img img ~ span,
.pcard-img img ~ .pcard-img-emoji { display:none !important; }

/* Light mode text visibility fixes */
[data-theme="light"] .pcard-name { color:#1A1410 !important; }
[data-theme="light"] .pcard-tag { color:#7A6A56 !important; }
[data-theme="light"] .pcard-gender { color:#8B6414 !important; }
[data-theme="light"] .pcard-price { color:#8B6414 !important; }
[data-theme="light"] .pcard-mood span { color:#4A3C2A !important; background:rgba(26,20,10,.06) !important; }
[data-theme="light"] .size-chip { color:#7A6A56 !important; }
[data-theme="light"] .size-chip.active { color:#8B6414 !important; border-color:#8B6414 !important; }
[data-theme="light"] .add-bag { background:#1A1410 !important; color:#FAF8F5 !important; }
[data-theme="light"] .benefit-title { color:#1A1410 !important; }
[data-theme="light"] .benefit-desc { color:#7A6A56 !important; }
[data-theme="light"] .section-h { color:#1A1410 !important; }
[data-theme="light"] .section-sub { color:#7A6A56 !important; }
[data-theme="light"] .pillar-title { color:#1A1410 !important; }
[data-theme="light"] .pillar-sub { color:#7A6A56 !important; }
[data-theme="light"] .size-num { color:#8B6414 !important; }
[data-theme="light"] .size-price-v4 { color:#1A1410 !important; }
[data-theme="light"] .size-unit { color:#7A6A56 !important; }
[data-theme="light"] .size-desc-v4 { color:#7A6A56 !important; }
[data-theme="light"] .tc-text { color:#4A3C2A !important; }
[data-theme="light"] .tc-name { color:#1A1410 !important; }
[data-theme="light"] .ftab { color:#7A6A56 !important; }
[data-theme="light"] .ftab.on { background:#1A1410 !important; color:#FAF8F5 !important; }
[data-theme="light"] .btn-primary { background:#1A1410 !important; color:#FAF8F5 !important; }
[data-theme="light"] .btn-ghost { color:#1A1410 !important; border-color:rgba(26,20,10,.25) !important; }
[data-theme="light"] .nav-links a { color:#7A6A56 !important; }
[data-theme="light"] .nav-links a:hover { color:#1A1410 !important; }
[data-theme="light"] .footer-col h4 { color:#1A1410 !important; }
[data-theme="light"] .footer-desc { color:#7A6A56 !important; }
[data-theme="light"] .eyebrow { color:#8B6414 !important; }
[data-theme="light"] .story-quote { color:#4A3C2A !important; }
[data-theme="light"] .hero-trust-item strong { color:#1A1410 !important; }

/* Gifting page light mode fixes */
[data-theme="light"] .sh h1 { color:#1A1410 !important; }
[data-theme="light"] .svc-card-top h3 { color:#1A1410 !important; }
[data-theme="light"] .svc-card-top p { color:#7A6A56 !important; }
[data-theme="light"] .svc-card-list li { color:#4A3C2A !important; }
[data-theme="light"] .svc-card { background:#FFFFFF; border-color:rgba(26,20,10,.1); }
[data-theme="light"] .enq-card h3 { color:#1A1410 !important; }
[data-theme="light"] .enq-card .sub { color:#7A6A56 !important; }
[data-theme="light"] .fg label { color:#4A3C2A !important; }
[data-theme="light"] .fi { background:#F8F4EE !important; color:#1A1410 !important; border-color:rgba(26,20,10,.15) !important; }
[data-theme="light"] .fi::placeholder { color:#9C8870 !important; }
[data-theme="light"] .fi:focus { border-color:#8B6414 !important; }
[data-theme="light"] .enq-sec { background:#F0E9DE; }
[data-theme="light"] .enq-card { background:#FFFFFF; }


/* Gifting hero title stays white in both modes */
.sh h1 { color:#fff !important; }
.sh h1 em { color:var(--gold) !important; }

/* Newsletter section light mode */
[data-theme="light"] .cta-section .section-h { color:#FAF8F5 !important; }
[data-theme="light"] .cta-section .section-h em { color:var(--gold-l) !important; }
[data-theme="light"] .cta-section p { color:rgba(250,248,245,.7) !important; }

/* Newsletter section dark mode */
[data-theme="dark"] .cta-section .section-h { color:#FAF8F5 !important; }
[data-theme="dark"] .cta-section .section-h em { color:#E8C070 !important; }
[data-theme="dark"] .cta-section p { color:rgba(250,248,245,.6) !important; }

/* Gifting page - keep hero title white in light mode */
[data-theme="light"] .sh h1 { color:#fff !important; }

/* Wishlist button */
.nav-wish-btn {
  width:40px; height:40px; border-radius:50%;
  background:var(--card); border:1.5px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:18px; cursor:pointer; position:relative;
  transition:all .2s; color:var(--txt);
}
.nav-wish-btn:hover { border-color:var(--gold); color:var(--gold); }
.wish-badge {
  position:absolute; top:-6px; right:-6px;
  width:18px; height:18px; border-radius:50%;
  background:var(--gold); color:#fff;
  font-size:10px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
}

/* Wishlist drawer */
#_wishDrawer {
  position:fixed; top:0; right:0; bottom:0; width:420px;
  max-width:100%; background:var(--surface);
  z-index:8001; transform:translateX(100%);
  transition:.38s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column;
  border-left:1px solid var(--border);
  font-family:var(--f-body);
}

/* Mobile sticky Add to Bag */
.sticky-atb {
  display:none;
  position:fixed; bottom:0; left:0; right:0; z-index:700;
  background:var(--surface); border-top:1px solid var(--border);
  padding:12px 16px; gap:12px; align-items:center;
  box-shadow:0 -4px 20px var(--shadow);
}
.sticky-atb-name {
  flex:1; font-family:var(--f-display);
  font-size:16px; color:var(--txt);
}
.sticky-atb-price {
  font-size:15px; font-weight:700; color:var(--gold);
}
.sticky-atb-btn {
  padding:12px 24px; background:var(--txt); color:var(--bg);
  border:none; border-radius:40px; font-size:13px;
  font-weight:700; cursor:pointer; font-family:var(--f-body);
  white-space:nowrap;
}
.sticky-atb-btn:hover { background:var(--gold); color:#fff; }
@media(min-width:768px) { .sticky-atb { display:none !important; } }
@media(max-width:767px) { .sticky-atb.visible { display:flex; } }

/* Mobile nav - hide Bag text, keep icon only */
@media(max-width:767px) {
  .nav-cart-btn span:not(.cart-badge) { display:none; }
  .nav-cart-btn svg { display:block; }
}

/* Hide Bag text on mobile */
@media(max-width:767px) { .bag-txt { display:none; } }

/* Exit intent popup */
#exitPopup {
  display:none; position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,.6); backdrop-filter:blur(6px);
  align-items:center; justify-content:center; padding:16px;
}
#exitPopup.show { display:flex; }
.exit-box {
  background:var(--surface); border:1px solid var(--border);
  border-radius:24px; max-width:420px; width:100%;
  padding:40px 32px; text-align:center; position:relative;
  box-shadow:0 24px 80px rgba(0,0,0,.4);
}
.exit-close {
  position:absolute; top:16px; right:16px;
  background:var(--card); border:1px solid var(--border);
  color:var(--muted); width:32px; height:32px;
  border-radius:50%; font-size:16px; cursor:pointer;
}
.exit-emoji { font-size:48px; margin-bottom:16px; }
.exit-title {
  font-family:var(--f-display); font-size:28px;
  color:var(--txt); margin-bottom:8px; line-height:1.2;
}
.exit-title em { color:var(--gold); font-style:italic; }
.exit-sub { font-size:14px; color:var(--muted); margin-bottom:24px; line-height:1.6; }
.exit-offer {
  background:var(--gold-glow); border:1.5px dashed var(--gold);
  border-radius:12px; padding:16px; margin-bottom:24px;
}
.exit-offer-code {
  font-family:var(--f-display); font-size:28px;
  font-weight:600; color:var(--gold); letter-spacing:3px;
}
.exit-offer-desc { font-size:12px; color:var(--muted); margin-top:4px; }
.exit-btns { display:flex; flex-direction:column; gap:10px; }
