/* ==========================================================================
   Desi By Nature - Design System (premium overhaul)
   Spec 01. Loaded AFTER style.css so it re-skins the whole site to the
   navy / gold / cream palette with Cormorant + Inter, and adds the shared
   premium components used by the rebuilt pages.
   Accent gold is used sparingly (roughly 10 percent of any view).
   ========================================================================== */

:root {
  /* ---- New brand palette (deep forest green ground + gold accent) ---- */
  --color-navy:        #1E382D;   /* primary dark ground: header, footer, dark bands */
  --color-navy-deep:   #16291F;   /* darker green for the top strip + gradients */
  --color-gold:        #C9A227;
  --color-gold-deep:   #B8860B;
  --color-gold-dark:   #8A6A12;   /* legible gold for price + accents */
  --color-cream:       #F6F2E7;
  --color-white-warm:  #FBF9F3;
  --color-green:       #2E6F4C;   /* mid green for links + secondary accents */
  --color-terracotta:  #B5532A;
  --color-text:        #1E382D;
  --color-text-muted:  #5C6A62;
  --color-text-on-dark:#F2EEDF;
  --color-success:     #2F7A4F;
  --color-error:       #B23A3A;
  --color-border:      #E3DDCD;

  /* ---- Spacing + radius (spec) ---- */
  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-6:1.5rem; --space-8:2rem; --space-12:3rem; --space-16:4rem; --space-24:6rem;
  --radius-sm:6px; --radius-md:10px; --radius-lg:16px;
  --container-max:1200px;

  /* ---- Remap legacy tokens so un-rebuilt pages adopt the new palette ---- */
  --c-ink:       var(--color-navy);
  --c-text:      var(--color-text);
  --c-text-2:    var(--color-text-muted);
  --c-muted:     var(--color-text-muted);
  --c-parchment: var(--color-white-warm);
  --c-cream:     var(--color-cream);
  --c-bone:      var(--color-white-warm);

  --c-navy:      var(--color-navy);
  --c-navy-2:    var(--color-navy-deep);
  --c-navy-3:    #2C5240;   /* lighter forest green (footer tagline band) */

  --c-orange:    var(--color-gold);
  --c-orange-2:  var(--color-gold-deep);
  --c-yellow:    var(--color-gold);
  --c-yellow-2:  var(--color-gold-deep);
  --c-buy:       var(--color-gold-deep);
  --c-buy-2:     var(--color-gold-dark);

  --c-link:      var(--color-green);
  --c-link-2:    var(--color-gold-deep);

  --c-price:     var(--color-gold-dark);
  --c-star:      var(--color-gold);
  --c-success:   var(--color-success);

  --c-maroon:    var(--color-gold-deep);
  --c-claret:    var(--color-navy-deep);
  --c-gold:      var(--color-gold);
  --c-gold-lt:   #E3C766;
  --c-ghee:      var(--color-gold);

  --c-border:    var(--color-border);
  --c-border-2:  #EFE9DC;

  --c-cta:        var(--color-gold);
  --c-cta-text:   var(--color-navy);
  --c-badge-bg:   #FBF4DD;
  --c-badge-text: var(--color-gold-deep);
  --c-warn:       var(--color-terracotta);
  --green:        var(--color-success);

  /* one-off legacy aliases used by cart / contact / shop */
  --line:   var(--color-border);
  --cream:  var(--color-cream);
  --muted:  var(--color-text-muted);
  --ink:    var(--color-navy);
  --ink-2:  var(--color-text-muted);
  --bg:     var(--color-white-warm);
  --maroon: var(--color-gold-deep);
  --accent: var(--color-gold);
  --accent2:var(--color-gold-deep);
  --side:   var(--color-cream);

  --font-display: "Fraunces", "Cormorant Garamond", Georgia, serif;
  --font-body:    "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-serif:   var(--font-display);
  --font-sans:    var(--font-body);

  --shadow-sm: 0 1px 2px rgba(22,41,31,.07);
  --shadow-md: 0 6px 20px rgba(22,41,31,.10);
  --shadow-lg: 0 18px 50px rgba(22,41,31,.18);
}

/* ==========================================================================
   Base
   ========================================================================== */
body {
  background-color: var(--color-white-warm);
  color: var(--color-text);
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0;
}
h1, h2, h3, h4, h5, blockquote {
  font-family: var(--font-display);
  color: var(--color-navy);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -.01em;
}
h1 { font-size: clamp(2rem, 4.5vw, 2.9rem); }
h2 { font-size: clamp(1.6rem, 3.4vw, 2.4rem); }
h3 { font-size: 1.35rem; font-weight: 600; }
h4 { font-size: 1.08rem; font-weight: 600; }
a { color: inherit; }

::selection { background: var(--color-gold); color: var(--color-navy); }

/* Keyboard focus is always visible (accessibility baseline) */
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible, summary:focus-visible {
  outline: 2px solid var(--color-gold-deep);
  outline-offset: 2px;
  border-radius: 3px;
}

/* Shared eyebrow / section-label in gold caps.
   Uses the darker gold so small caps text passes 4.5:1 on cream/white. On dark
   green bands the eyebrow is overridden to bright gold inline. */
.label, .eyebrow, .dn-eyebrow {
  font-family: var(--font-body);
  font-size: .72rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-gold-dark);
}
.dn-section--navy .dn-eyebrow, .dn-section--navy .label { color: var(--color-gold); }
.dn-eyebrow { display: inline-block; margin-bottom: var(--space-3); }

.dn-section { padding: var(--space-16) 0; }
.dn-section--cream { background: var(--color-cream); }
.dn-section--navy  { background: var(--color-navy); color: var(--color-text-on-dark); }
.dn-section--navy h1, .dn-section--navy h2, .dn-section--navy h3, .dn-section--navy h4 { color: #fff; }
@media (max-width: 768px) { .dn-section { padding: var(--space-12) 0; } }

.dn-section-head { max-width: 640px; margin: 0 auto var(--space-12); text-align: center; }
.dn-section-head p { color: var(--color-text-muted); margin: var(--space-2) 0 0; }
.dn-section-head.left { margin-left: 0; text-align: left; }

/* ==========================================================================
   Buttons (re-skin shared atoms)
   ========================================================================== */
.btn {
  font-family: var(--font-body); font-weight: 600; letter-spacing: .01em;
  border-radius: var(--radius-md); min-height: 48px;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 0 26px; transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
}
.btn-primary {
  background: var(--color-gold-deep); color: #fff; border: 1px solid var(--color-gold-deep);
}
.btn-primary:hover { background: var(--color-gold-dark); transform: translateY(-1px); box-shadow: var(--shadow-md); color:#fff; }
.btn-ghost, .btn-secondary {
  background: transparent; color: var(--color-navy);
  border: 1px solid var(--color-gold-deep);
}
.btn-ghost:hover, .btn-secondary:hover { background: var(--color-cream); transform: translateY(-1px); }
.btn-block { width: 100%; }
.btn-wa {
  background: #fff; color: var(--color-navy); border: 1px solid var(--color-border);
}
.btn-wa:hover { background: var(--color-cream); }
.nav-cta {
  background: var(--color-gold-deep); color: #fff !important; border-radius: var(--radius-md);
  font-weight: 600; letter-spacing: .01em;
}
.nav-cta:hover { background: var(--color-gold-dark); }

/* ==========================================================================
   Announcement / trust bar  (navy strip, gold text)
   ========================================================================== */
.announcement-bar {
  background: var(--color-navy-deep);
  color: var(--color-gold);
  border-bottom: 1px solid rgba(201,162,39,.25);
}
.announcement-bar .ticker-item {
  color: #FFFFFF;
  font-family: var(--font-body);
  font-size: .8rem; letter-spacing: .04em; font-weight: 500;
}
.announcement-bar .orn {
  color: var(--color-gold);
  margin: 0 1.4rem; font-size: .7rem;
}

/* ==========================================================================
   Header  (warm, sticky, condenses on scroll)
   ========================================================================== */
.site-header {
  background: var(--color-navy-deep);
  border-bottom: 1px solid rgba(255,255,255,.08);
  z-index: 200;
  transition: box-shadow .2s ease;
}
.site-header.condensed { box-shadow: 0 4px 18px rgba(0,0,0,.22); }
.site-header .brand-mark { border-color: var(--color-gold); color: var(--color-gold); background: transparent; }
.site-header .brand-text strong { color: #fff; }
.site-header .brand-text em { color: var(--color-gold); }
.site-header .primary > a, .site-header .dropdown > a { color: rgba(247,243,233,.92); font-family: var(--font-body); font-weight: 500; }
.site-header .primary > a:hover, .site-header .dropdown > a:hover { color: #fff; border-color: var(--color-gold); }
.site-header .dropdown .menu { background: #fff; border: 1px solid var(--color-border); box-shadow: var(--shadow-lg); }
.site-header .dropdown .menu a { color: var(--color-navy); }
.site-header .dropdown .menu a:hover { background: var(--color-cream); color: var(--color-gold-deep); }
.site-header .ico { color: #fff; }
.site-header .ico:hover { border-color: var(--color-gold); color: var(--color-gold); }
.site-header .cart-ico .badge { background: var(--color-gold); color: var(--color-navy); }
/* mobile drawer extras */
.nav-mobile-extra { display: none; }
body.nav-open .nav-mobile-extra { display: block; margin-top: var(--space-3); padding-top: var(--space-4); border-top: 1px solid rgba(255,255,255,.12); }
.nav-mobile-extra .wa-chat { display: inline-flex; align-items: center; gap: 8px; background: #25D366; color: #fff; font-weight: 600; padding: 11px 18px; border-radius: var(--radius-md); width: 100%; justify-content: center; }
.nav-mobile-extra .trustline { color: var(--color-gold); font-size: .78rem; letter-spacing: .04em; margin-top: var(--space-4); text-align: center; }
@media (min-width: 1100px) { .nav-mobile-extra { display: none !important; } }
/* desktop quick links (Track Order, WhatsApp) */
.nav-quick { display: none; align-items: center; gap: 6px; color: rgba(247,243,233,.9); font-family: var(--font-body); font-size: .8rem; font-weight: 500; white-space: nowrap; padding: 0 6px; }
.nav-quick:hover { color: var(--color-gold); }
.nav-quick-wa svg { color: #25D366; }
@media (min-width: 1100px) { .nav-quick { display: inline-flex; } }
/* mobile search field inside the drawer */
.nav-mobile-search { display: none; }
body.nav-open .nav-mobile-search { display: flex; width: 100%; margin-bottom: var(--space-3); }
.nav-mobile-search input { flex: 1; background: rgba(255,255,255,.95); border: 0; border-radius: var(--radius-md) 0 0 var(--radius-md); padding: 11px 14px; color: var(--color-navy); font-size: .9rem; }
.nav-mobile-search button { background: var(--color-gold-deep); color: #fff; border-radius: 0 var(--radius-md) var(--radius-md) 0; padding: 0 16px; display: grid; place-items: center; }
@media (min-width: 1100px) { .nav-mobile-search { display: none !important; } }

/* ==========================================================================
   Floating WhatsApp button  (site-wide)
   ========================================================================== */
.wa-float {
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  width: 56px; height: 56px; border-radius: 50%;
  background: #25D366; box-shadow: 0 8px 24px rgba(37,211,102,.4);
  display: flex; align-items: center; justify-content: center;
  z-index: 600; transition: transform .15s ease;
}
.wa-float:hover { transform: scale(1.06); }
/* keep it clear of the mobile bottom-nav + sticky ATC */
@media (max-width: 768px) { .wa-float { bottom: calc(64px + env(safe-area-inset-bottom)); width: 52px; height: 52px; } }
body.has-msa .wa-float { bottom: calc(132px + env(safe-area-inset-bottom)); }

/* ==========================================================================
   Trust-badge row  (shared component)
   ========================================================================== */
.dn-trustbar {
  display: flex; flex-wrap: wrap; gap: var(--space-3);
  list-style: none; padding: 0; margin: 0;
}
.dn-trustbar li {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-body); font-size: .78rem; font-weight: 500;
  color: var(--color-navy);
  background: var(--color-cream); border: 1px solid var(--color-border);
  border-radius: 999px; padding: 7px 14px;
}
.dn-trustbar li::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%;
  background: var(--color-gold-deep); flex: none;
}
.dn-trustbar.on-dark li { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.16); color: var(--color-text-on-dark); }

/* ==========================================================================
   Star rating  (shared component)
   ========================================================================== */
.dn-stars { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body); }
.dn-stars .s { color: var(--color-gold); letter-spacing: 1px; font-size: .95rem; }
.dn-stars .s .empty { color: #D8D2C2; }
.dn-stars .count { color: var(--color-text-muted); font-size: .82rem; }
.dn-stars .new-tag {
  font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 600;
  color: var(--color-green); background: rgba(47,93,67,.08);
  border: 1px solid rgba(47,93,67,.2); border-radius: 999px; padding: 3px 9px;
}

/* ==========================================================================
   Product card  (re-skin shared .card)
   ========================================================================== */
.card {
  background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm); transition: box-shadow .2s ease, transform .2s ease;
}
.card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.card .img { background: var(--color-white-warm); border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
.card .img img { mix-blend-mode: multiply; }
.card .cat { color: var(--color-text-muted); font-family: var(--font-body); letter-spacing: .08em; }
.card .title { font-family: var(--font-display); color: var(--color-navy); font-weight: 600; }
.card .price-now { color: var(--color-navy); font-weight: 700; }
.card .price-was { color: var(--color-text-muted); }
.card .tag { font-family: var(--font-body); font-weight: 600; letter-spacing: .04em; border-radius: 6px; }
.card .tag.bestseller, .card .tag.limited { background: var(--color-navy); color: var(--color-gold); }
.card .tag.sale { background: var(--color-terracotta); color: #fff; }
.card .tag.newtag { background: var(--color-green); color: #fff; }
.card .card-add {
  background: var(--color-gold-deep); color: #fff; font-family: var(--font-body); font-weight: 600;
  border-radius: var(--radius-md);
}
.card .card-add:hover { background: var(--color-gold-dark); }
.card .card-add.in-cart { background: var(--color-navy); }
.card .wish-btn { background: rgba(255,255,255,.9); border: 1px solid var(--color-border); }
.card .wish-btn svg { fill: none; stroke: var(--color-navy); stroke-width: 1.8; }
.card .wish-btn.on svg { fill: var(--color-terracotta); stroke: var(--color-terracotta); }

/* ==========================================================================
   HOMEPAGE
   ========================================================================== */
/* Hero */
.dn-hero { background: var(--color-white-warm); padding: var(--space-24) 0; }
.dn-hero .wrap { display: grid; grid-template-columns: 1.02fr .98fr; gap: var(--space-16); align-items: center; }
.dn-hero h1 { font-size: clamp(2.6rem, 6.2vw, 4.4rem); line-height: 1.04; margin: 0 0 var(--space-4); }
.dn-hero h1 em { color: var(--color-gold-deep); font-style: italic; }
.dn-hero .lead { font-size: 1.12rem; color: var(--color-text-muted); margin: 0 0 var(--space-6); max-width: 34em; }
.dn-hero-stats { display: flex; gap: var(--space-8); margin: var(--space-6) 0; flex-wrap: wrap; }
.dn-hero-stats .st b { display: block; font-family: var(--font-display); font-size: 1.4rem; color: var(--color-navy); font-weight: 600; }
.dn-hero-stats .st span { font-size: .8rem; color: var(--color-text-muted); }
.dn-hero-cta { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-bottom: var(--space-4); }
.dn-hero-reassure { font-size: .85rem; color: var(--color-text-muted); display: flex; align-items: center; gap: 8px; }
.dn-hero-reassure::before { content:""; width: 8px; height: 8px; border-radius:50%; background: var(--color-success); display:inline-block; }
.dn-hero-art { position: relative; background: var(--color-cream); border-radius: var(--radius-lg); padding: var(--space-8); display: flex; align-items: center; justify-content: center; min-height: 540px; }
.dn-hero-art img { max-height: 520px; width: auto; mix-blend-mode: multiply; }
.dn-hero-pills { position: absolute; top: var(--space-6); left: var(--space-6); display: flex; flex-direction: column; gap: 8px; }
.dn-hero-pills span { background: #fff; border: 1px solid var(--color-border); color: var(--color-navy); font-size: .74rem; font-weight: 600; padding: 6px 12px; border-radius: 999px; box-shadow: var(--shadow-sm); }
@media (max-width: 768px) {
  .dn-hero .wrap { grid-template-columns: 1fr; gap: var(--space-8); }
  .dn-hero-art { order: 2; min-height: 300px; }
}

/* Why strip (4-point curator) */
.dn-why { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); }
.dn-why .item { padding: var(--space-6); background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.dn-why .item .ic { width: 40px; height: 40px; color: var(--color-gold-deep); margin-bottom: var(--space-3); }
.dn-why .item h4 { margin: 0 0 var(--space-2); }
.dn-why .item p { margin: 0; color: var(--color-text-muted); font-size: .9rem; }
@media (max-width: 900px) { .dn-why { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .dn-why { grid-template-columns: 1fr; } }

/* Generic two-column band (proof / sourcing) */
.dn-band .wrap { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-12); align-items: center; }
.dn-band.reverse .wrap > :first-child { order: 2; }
.dn-band h2 { margin: 0 0 var(--space-4); }
.dn-band p { color: var(--color-text-muted); }
.dn-section--navy.dn-band p { color: rgba(247,243,233,.82); }
@media (max-width: 768px) { .dn-band .wrap { grid-template-columns: 1fr; gap: var(--space-8); } .dn-band.reverse .wrap > :first-child { order: 0; } }

/* Lab-report card + proof params */
.dn-labcard { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.dn-labcard .thumb { aspect-ratio: 4/3; background: var(--color-cream); display: flex; align-items: center; justify-content: center; color: var(--color-text-muted); font-size: .85rem; text-align: center; padding: var(--space-6); border-bottom: 1px solid var(--color-border); }
.dn-labcard .thumb img { width: 100%; height: 100%; object-fit: cover; }
.dn-labcard .meta { padding: var(--space-4) var(--space-6); }
.dn-labcard .meta b { display: block; color: var(--color-navy); font-family: var(--font-body); }
.dn-labcard .meta span { color: var(--color-text-muted); font-size: .82rem; }
.dn-params { list-style: none; margin: var(--space-6) 0 0; padding: 0; display: grid; gap: 1px; background: var(--color-border); border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; }
.dn-params li { background: #fff; padding: var(--space-3) var(--space-4); display: flex; justify-content: space-between; gap: var(--space-4); font-size: .9rem; }
.dn-params li b { color: var(--color-navy); font-family: var(--font-body); font-weight: 600; }
.dn-params li .v { color: var(--color-gold-dark); font-weight: 600; white-space: nowrap; }
.dn-section--navy .dn-params li .v { color: var(--color-gold); }
.dn-section--navy .dn-params { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.16); }
.dn-section--navy .dn-params li { background: var(--color-navy-deep); }
.dn-section--navy .dn-params li b { color: #fff; }

/* Certification wall */
.dn-certwall { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--space-4); }
.dn-cert { text-align: center; padding: var(--space-6) var(--space-3); background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.dn-cert .ic { width: 38px; height: 38px; color: var(--color-gold-deep); margin: 0 auto var(--space-2); }
.dn-cert b { display: block; font-family: var(--font-body); font-size: .82rem; color: var(--color-navy); }
@media (max-width: 900px) { .dn-certwall { grid-template-columns: repeat(2, 1fr); } }

/* Offers / retention teaser */
.dn-offers { background: var(--color-navy); color: var(--color-text-on-dark); border-radius: var(--radius-lg); padding: var(--space-12); text-align: center; }
.dn-offers h2 { color: #fff; margin: 0 0 var(--space-3); }
.dn-offers p { color: rgba(247,243,233,.82); max-width: 40em; margin: 0 auto var(--space-6); }

/* Reviews band */
.dn-reviewgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
@media (max-width: 900px) { .dn-reviewgrid { grid-template-columns: 1fr; } }
.dn-review { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-6); }
.dn-review .dn-stars { margin-bottom: var(--space-3); }
.dn-review p { color: var(--color-text); margin: 0 0 var(--space-4); }
.dn-review .who b { font-family: var(--font-body); color: var(--color-navy); font-size: .9rem; }
.dn-review .who span { color: var(--color-text-muted); font-size: .8rem; }
.dn-review .vbadge { display:inline-flex; align-items:center; gap:5px; color: var(--color-success); font-size:.74rem; font-weight:600; }
.dn-empty-reviews { text-align: center; padding: var(--space-12); background: #fff; border: 1px dashed var(--color-border); border-radius: var(--radius-lg); color: var(--color-text-muted); }
.dn-photowall { display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; }
.dn-photowall img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: var(--radius-md); border: 1px solid var(--color-border); }
@media (max-width: 900px) { .dn-photowall { grid-template-columns: repeat(3, 1fr); } }
.dn-sorttabs { display: flex; flex-wrap: wrap; gap: 8px; margin: 0 0 var(--space-6); }
.dn-sorttabs a { font-size: .82rem; font-weight: 500; padding: 7px 14px; border-radius: 999px; border: 1px solid var(--color-border); color: var(--color-navy); background: #fff; }
.dn-sorttabs a:hover { border-color: var(--color-gold-deep); }
.dn-sorttabs a.on { background: var(--color-navy); color: var(--color-gold); border-color: var(--color-navy); }

/* Pull-quote band (honest representative note) */
.dn-quoteband { background: var(--color-navy); color: var(--color-text-on-dark); text-align: center; }
.dn-quoteband blockquote { font-family: var(--font-display); font-size: clamp(1.4rem, 3.4vw, 2.2rem); color: #fff; max-width: 18em; margin: 0 auto; font-weight: 500; }
.dn-quoteband .note { color: var(--color-gold); font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; margin-top: var(--space-4); }

/* ==========================================================================
   Generic page hero + prose (sourcing / proof / reviews / concern / contact)
   ========================================================================== */
.dn-page-hero { background: var(--color-cream); padding: var(--space-16) 0; text-align: center; }
.dn-page-hero h1 { font-size: clamp(2rem, 5vw, 3rem); margin: var(--space-2) 0; }
.dn-page-hero p { color: var(--color-text-muted); max-width: 40em; margin: 0 auto; font-size: 1.05rem; }
.dn-prose { max-width: 720px; margin: 0 auto; }
.dn-prose h2 { margin: var(--space-12) 0 var(--space-3); }
.dn-prose p { color: var(--color-text); margin: 0 0 var(--space-4); }
.dn-prose ul { color: var(--color-text); padding-left: 1.1em; }
.dn-prose li { margin-bottom: var(--space-2); }
.dn-pullquote { font-family: var(--font-display); font-size: 1.5rem; color: var(--color-navy); border-left: 3px solid var(--color-gold); padding: var(--space-2) 0 var(--space-2) var(--space-6); margin: var(--space-8) 0; font-style: italic; }

/* Steps (sourcing / how we verify) */
.dn-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); counter-reset: step; }
.dn-steps .step { padding: var(--space-6); background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.dn-steps .step::before { counter-increment: step; content: counter(step); font-family: var(--font-display); font-size: 1.6rem; color: var(--color-gold-deep); font-weight: 700; display: block; margin-bottom: var(--space-2); }
.dn-steps .step h4 { margin: 0 0 var(--space-2); }
.dn-steps .step p { margin: 0; color: var(--color-text-muted); font-size: .9rem; }
@media (max-width: 900px) { .dn-steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .dn-steps { grid-template-columns: 1fr; } }

/* Lab report grid */
.dn-labgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
@media (max-width: 900px) { .dn-labgrid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .dn-labgrid { grid-template-columns: 1fr; } }

/* Verify-us callout */
.dn-callout { background: var(--color-cream); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-8); }
.dn-callout h3 { margin-top: 0; }

/* ==========================================================================
   PDP polish
   ========================================================================== */
.pdp .subtitle { color: var(--color-text-muted); }
.pdp .cat-pill { background: var(--color-navy); color: var(--color-gold); font-family: var(--font-body); letter-spacing: .1em; border-radius: 6px; }
.pdp .pricing .price-now { color: var(--color-navy); font-weight: 700; }
.pdp .pricing .price-was { color: var(--color-text-muted); }
.pdp .pricing .price-pill { background: var(--color-terracotta); color: #fff; border-radius: 999px; font-weight: 600; }
.pdp .var { border: 1px solid var(--color-border); border-radius: var(--radius-md); background: #fff; transition: border-color .15s ease, box-shadow .15s ease; }
.pdp .var:hover { border-color: var(--color-gold-deep); }
.pdp .var.on { border-color: var(--color-gold-deep); box-shadow: 0 0 0 1px var(--color-gold-deep) inset; background: var(--color-cream); }
.pdp .var b { color: var(--color-navy); }
.pdp .var .perml { display: block; font-size: .68rem; color: var(--color-text-muted); margin-top: 2px; font-weight: 500; }
.pdp .trust-list { list-style: none; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 8px 18px; }
.pdp .trust-list li { display: flex; align-items: center; gap: 8px; font-size: .86rem; color: var(--color-navy); }
.pdp .trust-list li::before { content: ""; width: 16px; height: 16px; flex: none; background: var(--color-gold-deep); -webkit-mask: var(--tick) center/contain no-repeat; mask: var(--tick) center/contain no-repeat; }
.pdp .delivery-line { display: flex; align-items: center; gap: 8px; font-size: .88rem; color: var(--color-navy); background: var(--color-cream); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 10px 14px; margin: var(--space-3) 0; }
.pdp .delivery-line b { color: var(--color-gold-deep); }
.pdp .proof-link { display: inline-flex; align-items: center; gap: 8px; color: var(--color-green); font-weight: 600; font-size: .9rem; border-bottom: 1px solid var(--color-gold); padding-bottom: 2px; }
:root { --tick: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E"); }
.pdp .sub-save { border: 1px solid var(--color-border); border-radius: var(--radius-md); }
.pdp .sub-save .save-pill { background: var(--color-green); color: #fff; }
.pdp .sub-save .saving { color: var(--color-success); }
.pdp .batch-line { color: var(--color-text-muted); }

.review-photos { display: flex; gap: 8px; flex-wrap: wrap; margin: 10px 0; }
.review-photos img { width: 72px; height: 72px; object-fit: cover; border-radius: var(--radius-sm); border: 1px solid var(--color-border); }
.pdp .review-summary .big { color: var(--color-navy); font-family: var(--font-display); }
.pdp .review-bars .bar i { background: var(--color-gold); }
.pdp .review-item .verified { color: var(--color-success); font-weight: 600; }

/* PDP bundle (frequently bought together) */
.dn-bundle { border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-6); background: var(--color-cream); margin-top: var(--space-6); }
.dn-bundle h3 { margin: 0 0 var(--space-2); }
.dn-bundle p { color: var(--color-text-muted); font-size: .9rem; margin: 0 0 var(--space-4); }

/* Mobile sticky ATC + bottom nav skins */
.m-sticky-atc { background: #fff; border-top: 1px solid var(--color-border); box-shadow: 0 -6px 20px rgba(22,41,31,.12); }
.m-sticky-atc .msa-add { background: var(--color-gold-deep); color: #fff; border-radius: var(--radius-md); font-weight: 600; }
.m-sticky-atc .msa-price strong { color: var(--color-navy); }
.m-bottom-nav { background: #fff; border-top: 1px solid var(--color-border); }
.m-bottom-nav a { color: var(--color-text-muted); }
.m-bottom-nav a.on { color: var(--color-gold-deep); }
.m-bottom-nav .bn-badge { background: var(--color-gold-deep); color: #fff; }

/* ==========================================================================
   Free-shipping progress bar (cart)
   ========================================================================== */
.dn-freeship { background: var(--color-cream); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 14px 18px; margin: 0 0 var(--space-6); }
.dn-freeship .msg { font-size: .9rem; color: var(--color-navy); margin: 0 0 8px; display: flex; align-items: center; gap: 8px; }
.dn-freeship .msg b { color: var(--color-gold-deep); }
.dn-freeship .track { height: 8px; background: #fff; border: 1px solid var(--color-border); border-radius: 999px; overflow: hidden; }
.dn-freeship .fill { height: 100%; background: linear-gradient(90deg, var(--color-gold), var(--color-gold-deep)); border-radius: 999px; transition: width .4s ease; }
.dn-freeship.unlocked .msg b { color: var(--color-success); }
.dn-freeship.unlocked .fill { background: var(--color-success); }

/* ==========================================================================
   Slide-in cart drawer
   ========================================================================== */
body.cd-lock { overflow: hidden; }
.cart-drawer-overlay { position: fixed; inset: 0; background: rgba(22,41,31,.5); z-index: 700; }
.cart-drawer {
  position: fixed; top: 0; right: 0; height: 100%; width: min(420px, 92vw);
  background: var(--color-white-warm); z-index: 710; display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform .28s ease; box-shadow: var(--shadow-lg);
}
.cart-drawer.open { transform: translateX(0); }
.cart-drawer .cd-head { display: flex; align-items: center; justify-content: space-between; padding: var(--space-6); border-bottom: 1px solid var(--color-border); }
.cart-drawer .cd-head h3 { margin: 0; }
.cart-drawer .cd-close { font-size: 1.6rem; line-height: 1; color: var(--color-navy); width: 36px; height: 36px; }
.cart-drawer .cd-freeship { margin: var(--space-4) var(--space-6) 0; }
.cart-drawer .cd-items { flex: 1; overflow-y: auto; padding: var(--space-4) var(--space-6); }
.cart-drawer .cd-item { display: grid; grid-template-columns: 64px 1fr auto; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--color-border); align-items: start; }
.cart-drawer .cd-thumb { width: 64px; height: 64px; background: var(--color-cream); border: 1px solid var(--color-border); border-radius: var(--radius-sm); overflow: hidden; display: block; }
.cart-drawer .cd-thumb img { width: 100%; height: 100%; object-fit: contain; padding: 6px; }
.cart-drawer .cd-name { font-family: var(--font-display); font-weight: 600; color: var(--color-navy); font-size: .95rem; display: block; }
.cart-drawer .cd-price { color: var(--color-text-muted); font-size: .82rem; margin: 2px 0 8px; }
.cart-drawer .cd-qty { display: flex; align-items: center; gap: 6px; }
.cart-drawer .cd-qty button { width: 26px; height: 26px; border: 1px solid var(--color-border); border-radius: var(--radius-sm); color: var(--color-navy); font-weight: 600; display: grid; place-items: center; }
.cart-drawer .cd-qty button:hover { border-color: var(--color-gold-deep); }
.cart-drawer .cd-qty span { min-width: 22px; text-align: center; font-weight: 600; }
.cart-drawer .cd-qty .cd-rm { width: auto; padding: 0 8px; border: 0; color: var(--color-text-muted); font-weight: 400; font-size: .8rem; margin-left: 6px; }
.cart-drawer .cd-qty .cd-rm:hover { color: var(--color-error); }
.cart-drawer .cd-line { font-weight: 700; color: var(--color-navy); }
.cart-drawer .cd-empty { padding: var(--space-12) var(--space-6); text-align: center; color: var(--color-text-muted); }
.cart-drawer .cd-foot { padding: var(--space-6); border-top: 1px solid var(--color-border); background: #fff; }
.cart-drawer .cd-subtotal { display: flex; justify-content: space-between; font-size: 1.05rem; margin-bottom: 6px; }
.cart-drawer .cd-subtotal b { color: var(--color-navy); }
.cart-drawer .cd-note { color: var(--color-text-muted); font-size: .78rem; margin: 0 0 var(--space-4); }

/* ==========================================================================
   Footer  (navy, cream text, honest)
   ========================================================================== */
.site-footer { background: var(--color-navy); color: var(--color-text-on-dark); }
.site-footer .foot-tagline { color: var(--color-gold); font-family: var(--font-display); border-bottom: 1px solid rgba(255,255,255,.08); }
.site-footer .foot-trust-pills span {
  color: var(--color-text-on-dark); background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14); border-radius: 999px;
}
.site-footer h4 { color: #fff; font-family: var(--font-body); font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; }
.site-footer a { color: rgba(247,243,233,.78); }
.site-footer a:hover { color: var(--color-gold); }
.site-footer .brand-mark { background: var(--color-gold); color: var(--color-navy); }
.site-footer .brand-text strong { color: #fff; }
.site-footer .brand-text em { color: rgba(247,243,233,.6); }
.site-footer .payments span { background: rgba(255,255,255,.9); color: var(--color-navy); border-radius: 4px; font-weight: 700; font-size: .7rem; }
.site-footer .foot-meta { color: rgba(247,243,233,.7); }
.site-footer .foot-meta b { color: #fff; }
.site-footer .foot-copy { color: rgba(247,243,233,.55); }
.site-footer .news input { background: rgba(255,255,255,.95); border: 0; border-radius: var(--radius-md) 0 0 var(--radius-md); color: var(--color-navy); }
.site-footer .news button { background: var(--color-gold-deep); color: #fff; border-radius: 0 var(--radius-md) var(--radius-md) 0; font-weight: 600; }
.site-footer .foot-contact a { color: var(--color-gold); }
.site-footer .foot-social { display: flex; gap: 12px; margin-top: 14px; }
.site-footer .foot-social a { display: grid; place-items: center; width: 38px; height: 38px; border: 1px solid rgba(255,255,255,.18); border-radius: 50%; color: rgba(247,243,233,.85); }
.site-footer .foot-social a:hover { color: var(--color-navy); background: var(--color-gold); border-color: var(--color-gold); }

/* ==========================================================================
   Shop-by-concern chips
   ========================================================================== */
.dn-chips { display: flex; flex-wrap: wrap; gap: var(--space-2); justify-content: center; margin-top: var(--space-6); }
.dn-chips a { font-size: .82rem; font-weight: 500; padding: 8px 16px; border-radius: 999px; border: 1px solid var(--color-border); color: var(--color-navy); background: #fff; }
.dn-chips a:hover, .dn-chips a.on { background: var(--color-navy); color: var(--color-gold); border-color: var(--color-navy); }

/* concern cards */
.dn-concern-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
@media (max-width: 900px) { .dn-concern-grid { grid-template-columns: 1fr; } }
.dn-concern { display: block; background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-8); transition: box-shadow .2s ease, transform .2s ease; }
.dn-concern:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.dn-concern .ic { width: 40px; height: 40px; color: var(--color-gold-deep); margin-bottom: var(--space-3); }
.dn-concern h3 { margin: 0 0 var(--space-2); }
.dn-concern p { color: var(--color-text-muted); font-size: .9rem; margin: 0; }

/* ==========================================================================
   Premium polish (forest-green refresh)
   ========================================================================== */
:root { --doc-ic: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M6 2h7l5 5v15a1 1 0 0 1-1 1H6a1 1 0 0 1-1-1V3a1 1 0 0 1 1-1zm7 1.5V7h3.5L13 3.5zM8 12h8v1.4H8zm0 3h8v1.4H8zm0 3h5v1.4H8z'/%3E%3C/svg%3E"); }

/* Hero art: flat warm cream so the white-background product blends via multiply,
   plus an inset gold hairline ring for a premium framed look. */
.dn-hero-art {
  background: var(--color-cream);
  border: 1px solid var(--color-border);
}
.dn-hero-art::after {
  content: ""; position: absolute; inset: 16px; border: 1px solid rgba(201,162,39,.3);
  border-radius: var(--radius-md); pointer-events: none;
}

/* Gold accent rules flanking centered section eyebrows */
.dn-section-head:not(.left) .dn-eyebrow::before,
.dn-section-head:not(.left) .dn-eyebrow::after {
  content: ""; display: inline-block; width: 26px; height: 1px;
  background: var(--color-gold); vertical-align: middle; margin: 0 12px; opacity: .85;
}

/* Nicer empty lab-report card */
.dn-labcard .thumb span { display: flex; flex-direction: column; align-items: center; gap: 12px; line-height: 1.5; }
.dn-labcard .thumb span::before {
  content: ""; width: 42px; height: 42px; background: var(--color-gold-deep);
  -webkit-mask: var(--doc-ic) center/contain no-repeat; mask: var(--doc-ic) center/contain no-repeat;
}

/* Cards lift a touch more, with a gold top accent on hover */
.card { position: relative; overflow: hidden; }
.card::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--color-gold); transform: scaleX(0); transform-origin: left; transition: transform .25s ease; z-index: 2;
}
.card:hover::before { transform: scaleX(1); }
.card:hover { transform: translateY(-3px); }

/* Dark bands get a subtle gold hairline at the top for depth */
.dn-quoteband, .dn-offers { border-top: 2px solid var(--color-gold-deep); }
.dn-offers { border: 1px solid rgba(201,162,39,.35); border-top: 2px solid var(--color-gold-deep); }

/* Buy panel price gets more presence */
.pdp .pricing .price-now { font-size: 1.9rem; }

/* ==========================================================================
   Lazy-load shimmer placeholder + fade-in
   JS adds .dbn-fade to images still loading and inserts a .dbn-ph shimmer behind
   them; on load it removes the shimmer and adds .dbn-loaded to fade the image in.
   Without JS, images render normally (no class is added).
   ========================================================================== */
@keyframes dbn-shimmer {
  0%   { background-position: -460px 0; }
  100% { background-position:  460px 0; }
}
.dbn-ph {
  position: absolute; inset: 0; z-index: 0; border-radius: inherit; display: block;
  background: linear-gradient(90deg, #ece5d4 0%, #f7f3e9 18%, #ece5d4 38%);
  background-size: 800px 100%;
  animation: dbn-shimmer 1.25s ease-in-out infinite;
}
.dbn-ph::after {
  content: ""; position: absolute; top: 50%; left: 50%; width: 30px; height: 30px;
  margin: -15px 0 0 -15px; border-radius: 50%;
  border: 2px solid rgba(138,106,18,.25); border-top-color: var(--color-gold-deep);
  animation: dbn-spin .7s linear infinite;
}
@keyframes dbn-spin { to { transform: rotate(360deg); } }
img.dbn-fade { opacity: 0; transition: opacity .5s ease; position: relative; z-index: 1; }
img.dbn-fade.dbn-loaded { opacity: 1; }
@media (prefers-reduced-motion: reduce) {
  .dbn-ph, .dbn-ph::after { animation: none; }
  img.dbn-fade { transition: none; }
}

/* utility */
.dn-center { text-align: center; }
.dn-mt-12 { margin-top: var(--space-12); }
.dn-narrow { max-width: 820px; margin-left: auto; margin-right: auto; }
