/* =========================================================================
   THE VIBE ADULT SHOP — Design System v2
   Editorial luxury / prestige-skincare. Blush paper, jewel magenta (sparing),
   deep wine, gold hairlines. Fraunces (display) + Hanken Grotesk (body).
   Mobile-first, WCAG-AA. Vanilla JS only for accordion + mobile menu.
   ========================================================================= */

/* ---------- Tokens ---------- */
:root{
  --canvas:#FBF7F4;        /* blush paper */
  --canvas-2:#F4ECE6;      /* warm sand */
  --ink:#2A1A20;           /* near-black plum */
  --ink-soft:#5C4750;      /* muted mauve text */
  --magenta:#C81E6E;       /* jewel accent — money colour, sparing */
  --magenta-dark:#A8155A;  /* hover */
  --wine:#5A1733;          /* deep luxury sections / footer */
  --wine-deep:#43122A;     /* footer base */
  --gold:#C9A77D;          /* hairlines / accents */
  --gold-soft:#E4D3BD;
  --white:#FFFFFF;
  --line:rgba(90,23,51,.14);     /* hairline on light */
  --line-gold:rgba(201,167,125,.55);
  --line-on-dark:rgba(228,211,189,.22);

  --shadow-sm:0 1px 2px rgba(42,26,32,.05), 0 2px 8px rgba(42,26,32,.05);
  --shadow-md:0 6px 24px rgba(42,26,32,.08), 0 2px 6px rgba(42,26,32,.05);
  --shadow-lg:0 18px 50px rgba(42,26,32,.14);

  --radius:14px;
  --radius-sm:10px;
  --radius-pill:999px;

  --font-display:"Fraunces", Georgia, "Times New Roman", serif;
  --font-body:"Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;

  --maxw:1240px;
  --gutter:clamp(18px, 5vw, 56px);
  --section-y:clamp(56px, 8vw, 104px);

  --header-h:74px;
  --util-h:38px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  background:var(--canvas);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
ul{margin:0;padding:0;list-style:none}
:focus-visible{outline:2px solid var(--magenta);outline-offset:3px;border-radius:4px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:430;
  line-height:1.08;
  letter-spacing:-.01em;
  color:var(--ink);
  margin:0 0 .5em;
  font-optical-sizing:auto;
}
h1{font-size:clamp(2.3rem, 5.4vw, 4rem)}
h2{font-size:clamp(1.8rem, 3.6vw, 2.85rem)}
h3{font-size:clamp(1.25rem, 2vw, 1.6rem)}
h4{font-size:1.12rem}
p{margin:0 0 1em}
strong{font-weight:600;color:var(--ink)}
.lead{font-size:clamp(1.06rem,1.6vw,1.28rem);color:var(--ink-soft);line-height:1.6}

.eyebrow{
  font-family:var(--font-body);
  font-size:.74rem;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--magenta);
  margin:0 0 1rem;
  display:inline-block;
}
.eyebrow--gold{color:var(--gold)}
.eyebrow--on-dark{color:var(--gold-soft)}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y)}
.section--canvas2{background:var(--canvas-2)}
.section--wine{background:var(--wine);color:var(--gold-soft)}
.section--wine h1,.section--wine h2,.section--wine h3{color:#FBEFE6}
.section--tight{padding-block:clamp(40px,5vw,64px)}
.center{text-align:center}
.measure{max-width:62ch;margin-inline:auto}
.section-head{max-width:64ch;margin:0 auto clamp(34px,4vw,52px)}
.section-head.center{text-align:center}

/* hairline gold divider */
.rule-gold{height:1px;background:var(--line-gold);border:0;margin:0}
.divider-motif{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--gold);margin:6px 0 30px}
.divider-motif::before,.divider-motif::after{content:"";height:1px;width:min(120px,18vw);background:var(--line-gold)}
.divider-motif span{font-size:1rem;letter-spacing:.3em}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--font-body);font-weight:600;font-size:.98rem;
  letter-spacing:.01em;line-height:1;
  padding:15px 30px;min-height:50px;
  border-radius:var(--radius-pill);
  border:1.5px solid transparent;
  transition:transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease, box-shadow .18s ease;
  text-align:center;cursor:pointer;
}
.btn:active{transform:translateY(1px)}
/* PRIMARY = the money button. Magenta, reserved for ONE action per section. */
.btn--primary{background:var(--magenta);color:#fff;box-shadow:0 8px 20px rgba(200,30,110,.24)}
.btn--primary:hover{background:var(--magenta-dark);box-shadow:0 10px 26px rgba(200,30,110,.32)}
/* SECONDARY = ghost, never magenta */
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff}
.btn--ghost-gold{background:transparent;color:var(--wine);border-color:var(--gold)}
.btn--ghost-gold:hover{background:var(--gold);color:var(--wine)}
/* on dark backgrounds */
.btn--on-dark{background:#fff;color:var(--wine)}
.btn--on-dark:hover{background:var(--gold-soft)}
.btn--ghost-on-dark{background:transparent;color:#FBEFE6;border-color:rgba(228,211,189,.5)}
.btn--ghost-on-dark:hover{background:rgba(228,211,189,.14);border-color:var(--gold)}
.btn--block{display:flex;width:100%}
.btn--sm{padding:11px 20px;min-height:44px;font-size:.9rem}

/* quiet text link with arrow */
.link-arrow{
  display:inline-flex;align-items:center;gap:.4em;
  font-weight:600;font-size:.95rem;color:var(--magenta);
  border-bottom:1px solid transparent;transition:gap .18s, border-color .18s;
}
.link-arrow:hover{gap:.7em;border-color:var(--magenta)}
.link-arrow .chev{width:1em;height:1em}

/* ---------- Icon sizing (hard caps — no giant SVGs) ---------- */
.icon{width:1.25em;height:1.25em;flex:none;display:inline-block;vertical-align:middle}
.icon-sm{width:1em;height:1em;flex:none}
.icon-lg{width:24px;height:24px;flex:none}
.icon-pillar{width:30px;height:30px;flex:none;color:var(--magenta)}

/* =========================================================================
   UTILITY BAR (very top, thin, dark)
   ========================================================================= */
.utilitybar{
  background:var(--wine-deep);color:var(--gold-soft);
  font-size:.78rem;letter-spacing:.02em;
  border-bottom:1px solid var(--line-on-dark);
}
.utilitybar .container{
  min-height:var(--util-h);
  display:flex;align-items:center;justify-content:center;gap:0;
  padding-block:7px;
}
.utilitybar ul{display:flex;align-items:center;flex-wrap:wrap;justify-content:center;gap:8px 0}
/* NB: must NOT be display:flex — flex turns the text around <strong>THEVIBE</strong>
   into separate flex items and collapses the surrounding spaces. Keep normal inline flow. */
.utilitybar li{display:inline-block;white-space:nowrap}
.utilitybar li::after{content:"·";margin:0 14px;color:var(--gold);opacity:.7}
.utilitybar li:last-child::after{display:none}
.utilitybar strong{color:#fff;font-weight:700}
/* mobile: rotating single line */
.utilitybar__rotator{display:none}
@media (max-width:760px){
  .utilitybar ul{display:none}
  .utilitybar__rotator{
    display:block;text-align:center;white-space:nowrap;
    overflow:hidden;text-overflow:ellipsis;max-width:100%;
  }
  .utilitybar__rotator strong{color:#fff}
}

/* =========================================================================
   HEADER (sticky)
   ========================================================================= */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(251,247,244,.92);
  backdrop-filter:saturate(1.1) blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;align-items:center;gap:22px;
  min-height:var(--header-h);
}
.brand{display:flex;align-items:center;flex:none}
.brand-logo{
  height:48px;width:auto;display:block;
  background:transparent;border:0;
}
/* WooCommerce ships ".woocommerce-page img{height:auto}", which outranks .brand-logo on
   shop/product/cart/checkout pages and balloons the logo — scope ours higher so it always wins. */
.site-header .brand-logo,.mobile-nav__head .brand-logo{height:48px !important;width:auto !important}
@media (max-width:560px){.site-header .brand-logo,.mobile-nav__head .brand-logo{height:40px !important}}

/* header product-search (compact input + magnifier submit) */
.header-search{display:flex;align-items:center;gap:6px}
.header-search__input{width:150px;padding:9px 14px;border:1.5px solid var(--line);border-radius:var(--radius-pill);background:var(--white);font-family:var(--font-body);font-size:.9rem;color:var(--ink);outline:none}
.header-search__input:focus{border-color:var(--magenta)}
@media (max-width:980px){.header-search{display:none}}

/* Payment badges — force a tight single wrapping row (were rendering full-width stacked, bloating the footer height) */
.footer-nap ul.payment-icons{display:flex !important;flex-wrap:wrap;gap:6px;margin-top:12px;padding:0;list-style:none}
.footer-nap ul.payment-icons li{display:inline-block !important;width:auto !important;float:none !important;margin:0;font-size:.62rem;font-weight:700;letter-spacing:.04em;padding:5px 9px;border-radius:6px;background:rgba(255,255,255,.08);border:1px solid var(--line-on-dark);color:#fff}

.primary-nav{display:flex;align-items:center;gap:4px;margin-inline:auto}
.primary-nav>li>a{
  display:inline-flex;align-items:center;gap:.4em;
  padding:10px 14px;border-radius:var(--radius-pill);
  font-weight:500;font-size:.96rem;color:var(--ink);
  transition:color .15s, background .15s;
}
.primary-nav>li>a:hover{color:var(--magenta);background:rgba(200,30,110,.06)}
.nav-strong>a{font-weight:600}

.header-actions{display:flex;align-items:center;gap:6px;flex:none}
.icon-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:50%;
  background:transparent;border:0;color:var(--ink);
  transition:background .15s,color .15s;position:relative;
}
.icon-btn:hover{background:var(--canvas-2);color:var(--magenta)}
.icon-btn .icon{width:21px;height:21px}
/* cart dot — magenta, item count, always visible */
.cart-btn .cart-count{
  position:absolute;top:4px;right:3px;
  min-width:18px;height:18px;padding:0 4px;
  background:var(--magenta);color:#fff;
  font-family:var(--font-body);font-size:.66rem;font-weight:700;line-height:18px;
  border-radius:var(--radius-pill);text-align:center;
  box-shadow:0 0 0 2px var(--canvas);
}
.hamburger{display:none}

/* mobile nav drawer */
.mobile-nav{
  position:fixed;inset:0;z-index:80;
  visibility:hidden;opacity:0;transition:opacity .25s, visibility .25s;
}
.mobile-nav[aria-hidden="false"]{visibility:visible;opacity:1}
.mobile-nav__backdrop{position:absolute;inset:0;background:rgba(42,26,32,.5)}
.mobile-nav__panel{
  position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);
  background:var(--canvas);box-shadow:var(--shadow-lg);
  transform:translateX(100%);transition:transform .28s ease;
  display:flex;flex-direction:column;padding:18px 22px;overflow-y:auto;
}
.mobile-nav[aria-hidden="false"] .mobile-nav__panel{transform:translateX(0)}
.mobile-nav__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.mobile-nav__links{display:flex;flex-direction:column;margin-top:6px}
.mobile-nav__links a{
  padding:15px 6px;font-family:var(--font-display);font-size:1.35rem;
  border-bottom:1px solid var(--line);color:var(--ink);
}
.mobile-nav__links a:hover{color:var(--magenta)}
.mobile-nav__promo{
  margin-top:auto;padding:16px;border-radius:var(--radius);
  background:var(--canvas-2);border:1px solid var(--line-gold);
  font-size:.86rem;color:var(--ink-soft);text-align:center;
}
.mobile-nav__promo strong{color:var(--magenta)}

@media (max-width:980px){
  .primary-nav{display:none}
  .hamburger{display:inline-flex}
  .header-actions .search-btn{display:none}
}

/* =========================================================================
   SHOP BAR — persistent category strip under the header (low-friction browse)
   Horizontal, scrolls sideways on small screens; visible on every page.
   ========================================================================= */
.shopbar{background:var(--canvas-2);border-bottom:1px solid var(--line)}
.shopbar__inner{
  display:flex;align-items:center;gap:2px;
  overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;
  padding-block:8px;
}
.shopbar__inner::-webkit-scrollbar{display:none}
.shopbar__lead{
  flex:none;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);padding-right:10px;margin-right:4px;border-right:1px solid var(--line);
}
.shopbar__link{
  flex:none;white-space:nowrap;
  font-size:.86rem;font-weight:600;color:var(--ink-soft);
  padding:8px 14px;border-radius:var(--radius-pill);
  transition:background .15s,color .15s;
}
.shopbar__link:hover{background:rgba(200,30,110,.08);color:var(--magenta)}
.shopbar__link--all{color:var(--magenta)}
.shopbar__link--all:hover{background:rgba(200,30,110,.1)}
@media (max-width:560px){.shopbar__lead{display:none}}

/* =========================================================================
   TRUST STRIP (4 cells) — reusable
   ========================================================================= */
.trust-strip{
  border-top:1px solid var(--line-gold);
  border-bottom:1px solid var(--line-gold);
  background:var(--canvas);
}
.trust-strip__grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
}
.trust-cell{
  display:flex;align-items:center;gap:14px;
  padding:26px clamp(14px,2.4vw,30px);
  border-right:1px solid var(--line);
}
.trust-cell:last-child{border-right:0}
.trust-cell .icon-pillar{color:var(--magenta)}
.trust-cell h2,.trust-cell h3,.trust-cell__heading{font-family:var(--font-body);font-size:.98rem;font-weight:700;margin:0 0 2px;letter-spacing:0}
.trust-cell p{font-size:.84rem;color:var(--ink-soft);margin:0;line-height:1.4}
@media (max-width:880px){
  .trust-strip__grid{grid-template-columns:repeat(2,1fr)}
  .trust-cell:nth-child(2){border-right:0}
  .trust-cell:nth-child(1),.trust-cell:nth-child(2){border-bottom:1px solid var(--line)}
}
@media (max-width:480px){
  .trust-cell{padding:18px 16px;gap:12px}
  .trust-cell h2,.trust-cell h3,.trust-cell__heading{font-size:.92rem}
}

/* =========================================================================
   TRUST FOOTER STRIP (above main footer) — calm, factual
   ========================================================================= */
.trust-bar{background:var(--canvas-2);border-top:1px solid var(--line)}
.trust-bar__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding-block:22px;max-width:1040px;margin-inline:auto}
.trust-bar__item{display:flex;align-items:center;gap:12px;justify-content:center;text-align:left}
.trust-bar__item .icon-pillar{width:26px;height:26px;color:var(--wine)}
.trust-bar__item span{font-size:.9rem;font-weight:600;color:var(--ink);line-height:1.3}
@media (max-width:760px){
  .trust-bar__grid{grid-template-columns:repeat(2,1fr);gap:20px 14px}
}

/* =========================================================================
   HERO (homepage / landing)
   ========================================================================= */
.hero{position:relative;overflow:hidden;background:var(--canvas)}
.hero::after{ /* soft blush glow */
  content:"";position:absolute;top:-30%;right:-15%;width:60%;height:140%;
  background:radial-gradient(circle at center, rgba(200,30,110,.07), transparent 62%);
  pointer-events:none;
}
.hero__inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,72px);
  align-items:center;padding-block:clamp(48px,7vw,92px);
}
.hero__copy{max-width:36rem}
.hero h1{margin-bottom:.4em}
.hero__sub{font-size:clamp(1.05rem,1.6vw,1.24rem);color:var(--ink-soft);margin-bottom:1.6em;max-width:34rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:1.8em}
.hero__media{position:relative}
.hero__media img{
  width:100%;border-radius:var(--radius);box-shadow:var(--shadow-lg);
  aspect-ratio:4/5;object-fit:cover;background:var(--canvas-2);
}
.hero__media-frame{position:relative}
.hero__media-frame::before{
  content:"";position:absolute;inset:14px;border:1px solid var(--line-gold);
  border-radius:var(--radius);pointer-events:none;z-index:2;
}
@media (max-width:880px){
  .hero__inner{grid-template-columns:1fr;gap:36px}
  .hero__media{order:-1;max-width:480px;margin-inline:auto}
  .hero__media img{aspect-ratio:16/11}
}

/* rating inline trust line */
.rating-line{display:inline-flex;align-items:center;gap:10px;font-size:.92rem;color:var(--ink-soft)}
.stars{display:inline-flex;gap:1px;color:var(--gold)}
.stars .icon-sm{width:16px;height:16px}
.rating-line strong{color:var(--ink);font-weight:700}

/* =========================================================================
   CATEGORY / "SHOP BY TYPE" TILES  — packshot cards
   The WHOLE product shows on a soft panel (object-fit:contain, never cropped),
   with the label in its own band beneath. Compact + premium, rhymes with the
   product cards. `.tiles-grid--dense` = a tighter 4-up grid for the full
   category index so it doesn't dominate the screen.
   ========================================================================= */
.tiles-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:clamp(14px,1.8vw,22px);
}
.tiles-grid--dense{grid-template-columns:repeat(4,1fr)}
@media (max-width:980px){.tiles-grid--dense{grid-template-columns:repeat(3,1fr)}}
@media (max-width:860px){.tiles-grid,.tiles-grid--dense{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.tiles-grid,.tiles-grid--dense{grid-template-columns:1fr}}

.tile{
  position:relative;display:flex;flex-direction:column;
  border-radius:var(--radius);overflow:hidden;
  background:var(--white);
  border:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--line-gold)}
/* media panel — full product visible, never decapitated */
.tile__img{
  position:static;width:100%;aspect-ratio:4/3;
  object-fit:contain;background:var(--canvas-2);
  padding:clamp(14px,2vw,20px);
  transition:transform .5s ease;
}
.tile:hover .tile__img{transform:scale(1.04)}
.tile__scrim{display:none} /* no overlay needed — label sits below the image */
.tile__body{
  position:static;color:var(--ink);
  display:flex;flex-direction:column;
  padding:15px clamp(14px,1.5vw,18px) 17px;
}
.tile__count{
  font-family:var(--font-body);font-size:.68rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--magenta);
  display:block;margin-bottom:5px;
}
.tile__name{
  font-family:var(--font-display);font-weight:430;
  font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--ink);margin:0 0 8px;line-height:1.15;
}
.tile__browse{
  display:inline-flex;align-items:center;gap:.4em;margin-top:auto;
  font-size:.82rem;font-weight:600;color:var(--magenta);opacity:.95;
  transition:gap .18s,opacity .18s;
}
.tile:hover .tile__browse{gap:.7em;opacity:1}
.tile__browse .chev{width:1em;height:1em}

/* cream variant (no image) — elegant gold-hairline CTA card. Motif sits ABOVE
   the text in normal flow (never overlapping it); the whole group is centred. */
.tile--cream{background:var(--canvas);border:1px solid var(--line-gold);min-height:clamp(190px,20vw,240px);justify-content:center;padding:26px}
.tile--cream .tile__scrim{display:none}
.tile--cream .tile__motif{position:static;color:var(--gold);margin-bottom:14px;line-height:0}
.tile--cream .tile__motif .icon{width:32px;height:32px}
.tile--cream .tile__body{position:static;flex:0 0 auto;padding:0}
.tile--cream .tile__count{color:var(--magenta)}
.tile--cream .tile__name{color:var(--ink)}
.tile--cream .tile__browse{color:var(--magenta);opacity:1;margin-top:12px}

/* =========================================================================
   PRODUCT CARD  (FIX #3 — price + button on ONE tidy aligned baseline row)
   Fixed footer row via flex column + margin-top:auto.
   ========================================================================= */
.product-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(16px,2vw,26px);
}
@media (max-width:1000px){.product-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:720px){.product-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:420px){.product-grid{grid-template-columns:1fr}}

.product-card{
  display:flex;flex-direction:column;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  height:100%;
}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--line-gold)}
.product-card__media{
  position:relative;display:block;
  aspect-ratio:1/1;background:var(--canvas-2);
  padding:14px;
}
.product-card__media img{
  width:100%;height:100%;object-fit:contain;
  transition:transform .4s ease;
}
.product-card:hover .product-card__media img{transform:scale(1.04)}
.product-card__badge{
  position:absolute;top:12px;left:12px;z-index:2;
  font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 10px;border-radius:var(--radius-pill);
  background:var(--wine);color:#fff;
}
.product-card__badge--soft{background:var(--canvas);color:var(--ink-soft);border:1px solid var(--line)}

.product-card__body{
  display:flex;flex-direction:column;flex:1 1 auto;
  padding:16px 16px 18px;
}
.product-card__cat{
  font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--magenta);margin:0 0 6px;
}
.product-card__name{
  font-family:var(--font-display);font-weight:430;font-size:1.06rem;line-height:1.25;
  color:var(--ink);margin:0 0 10px;
  /* clamp to 2 lines */
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;min-height:2.5em;
}
.product-card__name a:hover{color:var(--magenta)}
.product-card__price-wrap{margin-top:auto} /* push footer to baseline */
.product-card__price{
  font-family:var(--font-body);font-weight:700;font-size:1.12rem;color:var(--ink);
  display:flex;align-items:baseline;gap:8px;margin:0;
}
.product-card__finance{
  font-size:.74rem;color:var(--ink-soft);margin:4px 0 14px;line-height:1.35;
}
/* the aligned action row */
.product-card__action{display:flex;align-items:center}
.product-card__action .btn{width:100%}
.product-card__reassure{
  display:flex;align-items:center;gap:6px;justify-content:center;
  margin-top:10px;font-size:.72rem;color:var(--ink-soft);
}
.product-card__reassure .icon-sm{width:13px;height:13px;color:var(--gold)}

/* =========================================================================
   BRAND WALL
   ========================================================================= */
.brand-wall{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:clamp(22px,5vw,64px);
}
.brand-wall__item{
  font-family:var(--font-display);font-weight:430;font-size:clamp(1.25rem,2.4vw,1.85rem);
  color:var(--ink-soft);letter-spacing:.02em;opacity:.78;
  transition:opacity .2s, color .2s;
}
.brand-wall__item:hover{opacity:1;color:var(--wine)}

/* =========================================================================
   EDUCATION / VISIT-US / OFFER bands
   ========================================================================= */
.band-split{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,68px);align-items:center;
}
@media (max-width:840px){.band-split{grid-template-columns:1fr;gap:32px}}
.band-split__media img{
  width:100%;border-radius:var(--radius);box-shadow:var(--shadow-md);
  aspect-ratio:4/3;object-fit:cover;background:var(--canvas-2);
}
.band-split--reverse .band-split__media{order:2}
@media (max-width:840px){.band-split--reverse .band-split__media{order:0}}
/* product shots in an editorial band: contain on a soft panel so the WHOLE
   product reads (never a cropped/"blown-up" close-up). */
.band-split__media img{object-fit:contain;padding:clamp(16px,3vw,34px)}
/* "Visit us" map — a real, recognisable location instead of a stray product */
.band-split__media--map{position:relative}
.band-split__media--map iframe{
  display:block;width:100%;aspect-ratio:4/3;border:0;
  border-radius:var(--radius);box-shadow:var(--shadow-md);
}

.feature-list{display:grid;gap:14px;margin:22px 0 26px}
.feature-list li{display:flex;align-items:flex-start;gap:12px;font-size:.98rem;color:var(--ink-soft)}
.feature-list .icon{width:20px;height:20px;color:var(--magenta);margin-top:2px}

/* NAP card */
.nap-card{
  background:var(--canvas);border:1px solid var(--line-gold);border-radius:var(--radius);
  padding:clamp(22px,3vw,34px);box-shadow:var(--shadow-sm);
}
.nap-card dl{margin:0;display:grid;gap:14px}
.nap-card dt{font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--magenta);margin-bottom:2px}
.nap-card dd{margin:0;font-size:1.02rem;color:var(--ink)}
.nap-card .hours-open{color:var(--wine);font-weight:700}

/* offer band */
.offer-band{background:var(--wine);color:#FBEFE6;text-align:center}
.offer-band .container{padding-block:clamp(46px,6vw,72px)}
.offer-band h2{color:#fff}
.offer-band .promo-code{
  display:inline-block;font-family:var(--font-body);font-weight:800;
  letter-spacing:.16em;color:#fff;background:rgba(255,255,255,.1);
  border:1px solid var(--line-on-dark);border-radius:var(--radius-sm);
  padding:6px 16px;margin:0 2px;
}
.offer-band p{color:var(--gold-soft);max-width:46ch;margin-inline:auto;margin-bottom:1.6em}

/* =========================================================================
   REVIEWS BAND (aggregate only + marked placeholders — NO fake quotes)
   ========================================================================= */
.reviews-band{text-align:center}
/* eyebrow must sit on its own line ABOVE the rating (was inline-block, so it rendered
   side-by-side with the inline-flex aggregate). Force block + center the aggregate. */
.reviews-band .eyebrow{display:block}
.reviews-aggregate{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  margin:0 auto 38px;
}
.reviews-aggregate .stars .icon{width:26px;height:26px}
.reviews-aggregate .score{font-family:var(--font-display);font-size:2.4rem;line-height:1}
.reviews-aggregate .count{font-size:.92rem;color:var(--ink-soft)}
.review-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;text-align:left}
@media (max-width:760px){.review-cards{grid-template-columns:1fr;max-width:480px;margin-inline:auto}}
.review-card{
  background:var(--canvas);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-sm);
}
.review-card .stars{margin-bottom:12px}
.review-card .stars .icon-sm{width:16px;height:16px}
.review-card__placeholder{font-style:italic;color:var(--ink-soft);font-size:.95rem;margin-bottom:14px}
.review-card__attr{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--gold)}

/* =========================================================================
   DISCRETION REASSURANCE
   ========================================================================= */
.discretion{background:var(--canvas-2)}
.discretion__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,3vw,40px)}
@media (max-width:760px){.discretion__grid{grid-template-columns:1fr;gap:26px}}
.discretion__item .icon-pillar{color:var(--wine);margin-bottom:14px}
.discretion__item h3{font-family:var(--font-display);font-size:1.2rem;margin-bottom:8px}
.discretion__item p{font-size:.92rem;color:var(--ink-soft);margin:0}

/* =========================================================================
   NEWSLETTER
   ========================================================================= */
.newsletter{text-align:center}
.newsletter__form{
  display:flex;gap:10px;max-width:480px;margin:24px auto 12px;flex-wrap:wrap;
}
.newsletter__form input{
  flex:1 1 220px;min-width:0;
  padding:14px 18px;border-radius:var(--radius-pill);
  border:1.5px solid var(--line);background:var(--white);
  font-family:var(--font-body);font-size:1rem;color:var(--ink);
}
.newsletter__form input:focus{outline:none;border-color:var(--magenta)}
.newsletter__fine{font-size:.78rem;color:var(--ink-soft);margin:0}

/* =========================================================================
   BREADCRUMBS (for inner pages)
   ========================================================================= */
.breadcrumbs{font-size:.82rem;color:var(--ink-soft);padding-block:16px}
.breadcrumbs ol{display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.breadcrumbs li{display:flex;align-items:center;gap:8px}
.breadcrumbs li::after{content:"/";color:var(--gold)}
.breadcrumbs li:last-child::after{display:none}
.breadcrumbs a:hover{color:var(--magenta)}
.breadcrumbs [aria-current="page"]{color:var(--ink);font-weight:600}

/* =========================================================================
   FAQ ACCORDION  (FIX #2 — clean, small chevron <=1em, never a giant arrow)
   ========================================================================= */
.accordion{max-width:760px;margin-inline:auto;border-top:1px solid var(--line)}
.accordion__item{border-bottom:1px solid var(--line)}
.accordion__trigger{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;
  background:none;border:0;padding:22px 4px;text-align:left;
  font-family:var(--font-display);font-size:1.12rem;font-weight:430;color:var(--ink);
  cursor:pointer;line-height:1.3;
}
.accordion__trigger:hover{color:var(--magenta)}
/* the chevron — HARD-CAPPED to 1em so it can never render giant */
.accordion__chev{
  width:1em;height:1em;min-width:1em;flex:none;
  color:var(--gold);transition:transform .25s ease;
}
.accordion__trigger[aria-expanded="true"] .accordion__chev{transform:rotate(180deg)}
.accordion__trigger[aria-expanded="true"]{color:var(--magenta)}
.accordion__panel{
  overflow:hidden;max-height:0;transition:max-height .3s ease;
}
.accordion__panel-inner{padding:0 4px 24px;color:var(--ink-soft);font-size:.98rem;line-height:1.6}
.accordion__panel-inner p:last-child{margin-bottom:0}
.accordion__panel[hidden]{display:none}

/* =========================================================================
   FOOTER (rich wine)
   ========================================================================= */
.site-footer{background:var(--wine-deep);color:var(--gold-soft)}
/* tighter, less sprawling footer — narrower content column + reduced padding */
.footer-main{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:clamp(22px,3vw,40px);
  padding-block:clamp(34px,4vw,52px);
  max-width:1040px;margin-inline:auto;
}
@media (max-width:900px){.footer-main{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:540px){.footer-main{grid-template-columns:1fr;gap:32px}}
/* show the real full-colour logo (same as header). Do NOT flatten it to a white
   silhouette with brightness(0) invert(1) — that's why footer != header logo. */
.footer-brand .brand-logo{height:44px;margin-bottom:18px}
.footer-brand p{font-size:.9rem;color:var(--gold-soft);max-width:32ch;line-height:1.6}
.footer-brand .footer-local{color:var(--gold);font-weight:600;margin-top:10px}
.footer-col h4{
  font-family:var(--font-body);font-size:.78rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:#fff;margin:0 0 18px;
}
.footer-col ul{display:grid;gap:11px}
.footer-col a{font-size:.92rem;color:var(--gold-soft);transition:color .15s,padding .15s}
.footer-col a:hover{color:#fff;padding-left:3px}
.footer-nap address{font-style:normal;font-size:.92rem;line-height:1.7;color:var(--gold-soft)}
.footer-nap a{color:#fff;font-weight:600}
.footer-nap .hours{color:var(--gold);margin-top:8px;font-weight:600}

.footer-news input{
  width:100%;padding:13px 16px;border-radius:var(--radius-pill);
  border:1px solid var(--line-on-dark);background:rgba(255,255,255,.06);
  color:#fff;font-family:var(--font-body);font-size:.95rem;margin-bottom:10px;
}
.footer-news input::placeholder{color:rgba(228,211,189,.6)}
.footer-news input:focus{outline:none;border-color:var(--gold)}

.payment-icons{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.payment-icons li{
  font-size:.66rem;font-weight:700;letter-spacing:.04em;
  padding:6px 10px;border-radius:6px;
  background:rgba(255,255,255,.08);border:1px solid var(--line-on-dark);color:#fff;
}

.footer-bottom{
  border-top:1px solid var(--line-on-dark);
}
.footer-bottom .container{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;
  padding-block:16px;font-size:.84rem;color:var(--gold-soft);
}
.footer-bottom a{color:#fff;font-weight:600;border-bottom:1px solid var(--gold)}
.footer-bottom a:hover{color:var(--gold)}
.footer-age{display:inline-flex;align-items:center;gap:8px}
.footer-age .badge18{
  font-weight:800;font-size:.72rem;padding:3px 8px;border-radius:6px;
  background:var(--magenta);color:#fff;letter-spacing:.04em;
}

/* =========================================================================
   WOOCOMMERCE SINGLE PRODUCT — styling only (cart/checkout untouched).
   The theme strips Woo's default full-width wrapper for editorial archives, so
   functions.php re-wraps single products in .container. This lays the gallery
   + buy box side-by-side, caps the image size (no more giant "zoomed-in"
   product), and makes the price + Add-to-cart the clear, visible CTA.
   ========================================================================= */
.single-product-wrap{padding-block:clamp(20px,3vw,44px)}
.single-product-wrap .tv-breadcrumb,
.single-product-wrap .woocommerce-breadcrumb{font-size:.82rem;color:var(--ink-soft);margin-bottom:18px}
.single-product div.product{
  display:flex;flex-wrap:wrap;gap:clamp(26px,4vw,56px);align-items:flex-start;
}
.single-product div.product>.woocommerce-product-gallery{
  width:auto;flex:1 1 380px;max-width:48%;margin:0;float:none !important;
}
.single-product div.product>.summary,
.single-product div.product>.entry-summary{
  width:auto;flex:1 1 380px;max-width:48%;margin:0;float:none !important;
}
.single-product div.product>.woocommerce-tabs,
.single-product div.product>.related,
.single-product div.product>.upsells{flex:1 1 100%;width:100%;margin-top:clamp(28px,4vw,48px)}
.single-product .woocommerce-product-gallery{position:relative}
.single-product .woocommerce-product-gallery__wrapper img{
  border-radius:var(--radius);background:var(--canvas-2);
}
.single-product .summary .product_title{margin:.1em 0 .35em}
.single-product .summary .price{
  color:var(--magenta);font-family:var(--font-body);font-weight:700;font-size:1.7rem;margin:0 0 .2em;
}
.single-product .summary .price del{color:var(--ink-soft);font-weight:400;font-size:1.1rem;opacity:.7}
.single-product .summary .stock{font-weight:600}
.single-product .summary .stock.out-of-stock{color:var(--magenta)}
.single-product .summary .woocommerce-product-details__short-description{color:var(--ink-soft)}
/* quantity + add-to-cart row */
.single-product .summary form.cart{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin:1.2em 0}
.single-product .summary form.cart .quantity .qty{
  width:72px;padding:13px 10px;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  background:var(--white);font-family:var(--font-body);font-size:1rem;text-align:center;
}
.single-product .summary .single_add_to_cart_button{
  flex:1 1 auto;min-height:52px;padding:15px 30px;
  background:var(--magenta);color:#fff;border:0;border-radius:var(--radius-pill);
  font-family:var(--font-body);font-weight:600;font-size:1rem;letter-spacing:.01em;cursor:pointer;
  box-shadow:0 8px 20px rgba(200,30,110,.24);transition:background .18s,box-shadow .18s;
}
.single-product .summary .single_add_to_cart_button:hover{background:var(--magenta-dark)}
.single-product .summary .product_meta{font-size:.84rem;color:var(--ink-soft);margin-top:1.2em}
@media (max-width:880px){
  .single-product div.product>.woocommerce-product-gallery,
  .single-product div.product>.summary,
  .single-product div.product>.entry-summary{max-width:100%;flex-basis:100%}
}

/* =========================================================================
   STICKY MOBILE ADD-TO-BAG BAR (for PDP — provided in vocab for page builders)
   ========================================================================= */
.sticky-bag{
  position:fixed;left:0;right:0;bottom:0;z-index:70;
  display:none;align-items:center;gap:14px;
  padding:12px var(--gutter);
  background:rgba(251,247,244,.97);backdrop-filter:blur(8px);
  border-top:1px solid var(--line-gold);box-shadow:0 -6px 20px rgba(42,26,32,.08);
}
.sticky-bag__price{font-weight:700;font-size:1.05rem;white-space:nowrap}
.sticky-bag .btn{flex:1}
@media (max-width:760px){.sticky-bag{display:flex}}

/* =========================================================================
   UTILITIES
   ========================================================================= */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.skip-link{
  position:absolute;left:12px;top:-50px;z-index:200;
  background:var(--magenta);color:#fff;padding:10px 16px;border-radius:8px;
  transition:top .2s;font-weight:600;
}
.skip-link:focus{top:12px}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.text-soft{color:var(--ink-soft)}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
}
/* real Google review quote text (agents renamed placeholder->quote) — restore styling */
.review-card__quote{font-family:var(--font-display);font-style:italic;font-size:1.06rem;line-height:1.5;color:var(--ink);margin:0 0 14px}
.review-card blockquote,blockquote.review-card__quote{margin:0 0 14px;padding:0;border:0;quotes:none}

/* =========================================================================
   AGE GATE (18+) — fullscreen overlay shown on entry (JS-remembered 30 min).
   Shown by default; hidden once .tv-age-ok is set on <html>.
   ========================================================================= */
.age-gate{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;padding:24px;
  background:linear-gradient(160deg,var(--wine-deep),var(--wine));
}
.tv-age-ok .age-gate{display:none !important}
.age-gate__card{
  background:var(--canvas);border:1px solid var(--line-gold);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);max-width:440px;width:100%;
  padding:clamp(28px,5vw,44px);text-align:center;
}
.age-gate__logo{height:46px;width:auto;margin:0 auto 18px;display:block}
.age-gate__badge{
  display:inline-block;font-family:var(--font-body);font-weight:800;font-size:.72rem;
  letter-spacing:.14em;text-transform:uppercase;color:#fff;background:var(--magenta);
  padding:5px 12px;border-radius:var(--radius-pill);margin:0 0 14px;
}
.age-gate h2{font-size:clamp(1.5rem,3vw,2rem);margin:0 0 .4em}
.age-gate p{color:var(--ink-soft);font-size:1rem;margin:0 0 1.3em}
.age-gate__actions{display:flex;flex-direction:column;gap:12px;margin:0 0 16px}
.age-gate__fine{font-size:.78rem;color:var(--ink-soft);margin:0}
@media (max-width:480px){.age-gate__card{padding:26px 20px}}
