/* GlamPeptides storefront — design brief §1 palette + typography.
 *
 * Brief reference:
 *   Dropbox/Entities/StableResearch/Brands/GLAMPeptides/WIP/DesignBriefs/Web/GlamPeptides_Website_Brief.pdf
 *
 * Alternating dark/cream section rhythm. Dark = luxury atmosphere.
 * Cream = where dark vial packaging pops. Rose gold is the accent
 * everywhere; Champagne gold is for prices/sale badges.
 */

:root {
  /* Dark zone */
  --glam-matte-black: #0D0D0D;
  --glam-carbon:      #111116;
  --glam-deep-wine:   #4A0E2E;
  --glam-white:       #FFFFFF;
  --glam-warm-gray:   #A3A3A3;

  /* Light zone */
  --glam-warm-cream:    #FBF7F2;
  --glam-soft-blush:    #E8D5CE;
  --glam-deep-espresso: #2C2018;

  /* Accents */
  --glam-rose-gold:      #B76E79;
  --glam-champagne-gold: #D4AF76;

  /* Type scale — brief §1.2 */
  --glam-font-display: "Playfair Display", Georgia, serif;
  --glam-font-body:    "Poppins", -apple-system, BlinkMacSystemFont, sans-serif;
}

* { box-sizing: border-box; }

/* Defer body bg + body text color to Vela cosmetic02's tokens.css
   (warm cream bg, deep-espresso text). Earlier glam.css used to force
   matte-black body bg, but that fights the bought template — every
   Vela section expects a light canvas to read against. We only set the
   shared font + smoothing globally; palette comes from tokens.css. */
html, body {
  margin: 0;
  padding: 0;
  font-family: var(--glam-font-body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body.glam { min-height: 100vh; display: flex; flex-direction: column; }
main { flex: 1; }

/* Home 3-col USP block subheadings — match the Vela footer
 * .velaFooterTitle treatment (Playfair Display 30/400, espresso) so
 * the typography reads consistently across the page. WHY not just
 * inherit Vela h3 default: Vela h3 default is the Sans body font;
 * the operator wants the secondary-display serif here for editorial
 * weight on the 3 trust pillars. */
.glam-home-features__title {
  font-family: var(--glam-font-display);
  font-weight: 400;
  font-size: 30px;
  color: var(--glam-deep-espresso);
  margin: 0 0 12px;
  letter-spacing: 0;
}

/* Footer — brief §2.2 Footer (DARK). RUO + FDA disclaimers are
 * non-negotiable for regulatory compliance; every page carries them. */
.brand-footer {
  background: var(--glam-matte-black);
  color: var(--glam-warm-gray);
  padding: 3rem 2rem 2rem;
  border-top: 1px solid rgba(183, 110, 121, 0.2);
}
.brand-footer__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  text-align: center;
}
.brand-footer__ruo,
.brand-footer__fda {
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0;
  /* RUO line is 67 chars: "All products are for research use only.
     Not for human consumption." With letter-spacing 0.14em, the
     prior 60ch cap forced a 2-line wrap. Bumping to 80ch lets the
     RUO line render as a single line at desktop widths while still
     keeping the FDA line (~50 chars) tightly framed. Mobile still
     wraps naturally because viewport width takes over below ~600px. */
  max-width: 80ch;
}
.brand-footer__ruo { white-space: nowrap; }
@media (max-width: 700px) {
  .brand-footer__ruo { white-space: normal; }
}
.brand-footer__fda { color: rgba(163, 163, 163, 0.7); }
.brand-footer__nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.75rem;
  margin: 0 0 1.5rem;
  padding: 0 0 1.5rem;
  border-bottom: 1px solid rgba(183, 110, 121, 0.12);
  width: 100%;
  max-width: 1100px;
}
.brand-footer__nav a {
  color: var(--glam-warm-gray);
  text-decoration: none;
  font-family: var(--glam-font-body);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  transition: color 0.2s ease;
}
.brand-footer__nav a:hover,
.brand-footer__nav a:focus { color: var(--glam-rose-gold); }

/* Content pages — FAQ, About, Shipping, Legal, Contact. Cream
 * section on dark chrome: brief §1 alternating rhythm. Long-form
 * reading layout with measured column width and generous line
 * height. */
.glam-content {
  background: var(--glam-warm-cream);
  color: var(--glam-deep-espresso);
  padding: 5rem 1.5rem 6rem;
}
.glam-content__inner {
  max-width: 720px;
  margin: 0 auto;
}
.glam-content__title {
  font-family: var(--glam-font-display);
  font-size: clamp(2.25rem, 5vw, 3.25rem);
  letter-spacing: -0.01em;
  color: var(--glam-deep-espresso);
  margin: 0 0 2.5rem;
  padding-bottom: 1.25rem;
  border-bottom: 2px solid var(--glam-rose-gold);
}
.glam-content__body {
  font-family: var(--glam-font-body);
  font-size: 1rem;
  line-height: 1.75;
}
.glam-content__body h2 {
  font-family: var(--glam-font-display);
  font-weight: 600;
  font-size: 1.5rem;
  color: var(--glam-deep-wine);
  margin: 2.5rem 0 0.75rem;
}
.glam-content__body h3 {
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 1.05rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--glam-deep-espresso);
  margin: 1.75rem 0 0.5rem;
}
.glam-content__body p { margin: 0 0 1.1rem; }
.glam-content__body ul { margin: 0.25rem 0 1.25rem; padding-left: 1.4rem; }
.glam-content__body li { margin-bottom: 0.45rem; }
.glam-content__body a {
  color: var(--glam-rose-gold);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.glam-content__body a:hover { color: var(--glam-deep-wine); }
.glam-content__body address {
  font-style: normal;
  line-height: 1.7;
  margin-bottom: 1.25rem;
}
.glam-content__lede {
  font-family: var(--glam-font-display);
  font-style: italic;
  font-size: 1.25rem;
  color: var(--glam-rose-gold);
  margin: 0 0 2rem;
}
.glam-content__notice {
  background: rgba(183, 110, 121, 0.08);
  border-left: 3px solid var(--glam-rose-gold);
  padding: 1rem 1.25rem;
  margin: 0 0 2rem;
  font-size: 0.95rem;
  color: var(--glam-deep-espresso);
}

.brand-footer__copy {
  font-size: 0.75rem;
  margin: 0.75rem 0 0;
  color: var(--glam-warm-gray);
}

/* Age gate — brief §2.1. Full-viewport overlay with blurred scrim and
 * centered card. No JS: the form POST handles acknowledgement and the
 * server sets the 30-day cookie. */
.glam-age-gate {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.glam-age-gate__scrim {
  position: absolute;
  inset: 0;
  background: rgba(13, 13, 13, 0.82);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.glam-age-gate__card {
  position: relative;
  background: var(--glam-carbon);
  color: var(--glam-white);
  border: 1px solid rgba(183, 110, 121, 0.35);
  border-radius: 2px;
  padding: 3rem 2.5rem 2.5rem;
  max-width: 460px;
  width: 100%;
  text-align: center;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.6);
}
.glam-age-gate__wordmark {
  font-family: var(--glam-font-display);
  font-size: 1.5rem;
  color: var(--glam-rose-gold);
  margin: 0 0 1.5rem;
}
.glam-age-gate__wordmark sup { font-size: 0.4em; vertical-align: super; }
.glam-age-gate__heading {
  font-family: var(--glam-font-display);
  font-size: 1.75rem;
  font-weight: 600;
  margin: 0 0 1rem;
  letter-spacing: 0.01em;
  /* Vela's `h1, h2, ... { color: var(--vela-text-color-secondary) }`
     applies a near-black color to the heading and wins over the
     parent .glam-age-gate__card's `color: var(--glam-white)` because
     element-typed selectors (h2) are evaluated above inheritance.
     Explicit color here pins the modal heading to white so it reads
     against the Carbon-black card background. */
  color: var(--glam-white);
}
.glam-age-gate__body {
  color: var(--glam-warm-gray);
  font-size: 0.95rem;
  line-height: 1.6;
  margin: 0 0 2rem;
}
.glam-age-gate__actions {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1.75rem;
}
.glam-age-gate__btn {
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  padding: 0.95rem 1.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.glam-age-gate__btn--primary {
  background: var(--glam-rose-gold);
  color: var(--glam-matte-black);
}
.glam-age-gate__btn--primary:hover { background: var(--glam-champagne-gold); }
.glam-age-gate__btn--ghost {
  background: transparent;
  color: var(--glam-warm-gray);
  border-color: rgba(163, 163, 163, 0.4);
}
.glam-age-gate__btn--ghost:hover {
  color: var(--glam-white);
  border-color: var(--glam-white);
}
.glam-age-gate__legal {
  font-size: 0.7rem;
  color: rgba(163, 163, 163, 0.7);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0;
  line-height: 1.6;
}

/* Age-blocked exit page — reuses the hero layout with a dimmer cast. */
.glam-age-blocked__body {
  color: var(--glam-warm-gray);
  font-size: 1rem;
  max-width: 52ch;
  margin: 1.5rem auto 0;
  line-height: 1.7;
}

/* Shop / Collection — brief §2.3. CREAM zone: warm cream background
 * so dark matte-black vial packaging with rose-gold caps pops. */
.glam-shop {
  background: var(--glam-warm-cream);
  color: var(--glam-deep-espresso);
  padding: 4rem 2rem 5rem;
}
.glam-shop__header {
  max-width: 1200px;
  margin: 0 auto 3rem;
  text-align: center;
}
.glam-shop__heading {
  font-family: var(--glam-font-display);
  font-weight: 700;
  font-size: clamp(2.25rem, 5vw, 3.25rem);
  margin: 0 0 0.75rem;
  color: var(--glam-deep-espresso);
}
.glam-shop__subhead {
  color: rgba(44, 32, 24, 0.6);
  font-size: 0.95rem;
  letter-spacing: 0.02em;
  margin: 0;
}
.glam-shop__filters {
  max-width: 1200px;
  margin: 0 auto 3rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
  padding: 1.25rem 0;
  border-top: 1px solid rgba(44, 32, 24, 0.1);
  border-bottom: 1px solid rgba(44, 32, 24, 0.1);
}
.glam-shop__filter {
  font-family: var(--glam-font-body);
  font-weight: 500;
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(44, 32, 24, 0.55);
  text-decoration: none;
  padding: 0.5rem 1rem;
  border: 1px solid transparent;
  transition: color 0.2s ease, border-color 0.2s ease;
}
.glam-shop__filter:hover {
  color: var(--glam-rose-gold);
}
.glam-shop__filter--active {
  color: var(--glam-rose-gold);
  border-color: var(--glam-rose-gold);
}
.glam-shop__grid {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 1200px;
  display: grid;
  gap: 2rem;
  grid-template-columns: repeat(1, minmax(0, 1fr));
}
@media (min-width: 640px) {
  .glam-shop__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 960px) {
  .glam-shop__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.glam-card {
  background: var(--glam-white);
  border: 1px solid rgba(44, 32, 24, 0.08);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.glam-card:hover {
  border-color: var(--glam-rose-gold);
  box-shadow: 0 18px 40px rgba(44, 32, 24, 0.12);
  transform: translateY(-3px);
}
.glam-card__link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.glam-card__image-frame {
  aspect-ratio: 4 / 5;
  background: var(--glam-soft-blush);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.glam-card__image-placeholder {
  font-family: var(--glam-font-display);
  font-size: 1.75rem;
  color: rgba(44, 32, 24, 0.4);
  letter-spacing: 0.02em;
}
.glam-card__body { padding: 1.5rem 1.25rem 1.75rem; }
.glam-card__name {
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 1.25rem;
  margin: 0 0 0.25rem;
  color: var(--glam-deep-espresso);
}
.glam-card__tagline {
  font-family: var(--glam-font-body);
  font-weight: 300;
  font-size: 0.8rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--glam-rose-gold);
  margin: 0 0 0.75rem;
}
.glam-card__descriptor,
.glam-card__dose {
  font-size: 0.85rem;
  color: rgba(44, 32, 24, 0.65);
  margin: 0 0 0.25rem;
  line-height: 1.5;
}
.glam-card__price {
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 1.125rem;
  color: var(--glam-champagne-gold);
  margin: 1rem 0 0;
}
.glam-shop__ruo-note {
  max-width: 640px;
  margin: 3rem auto 0;
  text-align: center;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(44, 32, 24, 0.5);
  line-height: 1.7;
}

/* PDP — brief §2.4. Split layout: cream image frame on the left,
 * dark info card on the right. Below-fold: stacked detail sections
 * (JS-less "tab" alternative). Related-products row at the bottom. */
.glam-pdp { background: var(--glam-warm-cream); }
.glam-pdp__split {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
}
@media (min-width: 960px) {
  .glam-pdp__split { grid-template-columns: 1fr 1fr; }
}
.glam-pdp__image-frame {
  background: var(--glam-soft-blush);
  aspect-ratio: 4 / 5;
  display: flex;
  align-items: center;
  justify-content: center;
}
.glam-pdp__image-placeholder {
  font-family: var(--glam-font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  color: rgba(44, 32, 24, 0.35);
  letter-spacing: 0.02em;
}
.glam-pdp__info {
  background: var(--glam-carbon);
  color: var(--glam-white);
  padding: 3rem 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.glam-pdp__ruo-badge {
  align-self: flex-start;
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--glam-warm-gray);
  border: 1px solid rgba(163, 163, 163, 0.4);
  padding: 0.35rem 0.75rem;
  /* operator (2026-05-05): 'add a bit more space between research use
     only box and the product name on glam pdp'. 1rem → 1.75rem. */
  margin: 0 0 1.75rem;
}
.glam-pdp__name {
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 2.25rem;
  margin: 0;
}
.glam-pdp__tagline {
  font-family: var(--glam-font-body);
  font-weight: 300;
  font-size: 0.85rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--glam-rose-gold);
  margin: 0.25rem 0 0.75rem;
}
.glam-pdp__descriptor {
  color: var(--glam-warm-gray);
  font-size: 0.95rem;
  margin: 0;
  line-height: 1.6;
}
.glam-pdp__dose {
  color: var(--glam-champagne-gold);
  font-family: var(--glam-font-body);
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: 0.05em;
  margin: 0.5rem 0 0;
}
.glam-pdp__price {
  color: var(--glam-champagne-gold);
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 2rem;
  margin: 1rem 0 1.5rem;
}
.glam-pdp__cart-form {
  display: flex;
  gap: 1rem;
  align-items: flex-end;
  flex-wrap: wrap;
}
.glam-pdp__qty-label {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--glam-warm-gray);
}
.glam-pdp__qty-input {
  width: 80px;
  padding: 0.75rem;
  background: #FFFFFF;
  color: var(--glam-matte-black);
  border: 1px solid var(--glam-deep-espresso);
  font-family: var(--glam-font-body);
  font-size: 1rem;
}
.glam-pdp__qty-input:focus {
  outline: 2px solid var(--glam-rose-gold);
  outline-offset: -1px;
}
.glam-pdp__cart-button {
  flex: 1;
  min-width: 180px;
  background: var(--glam-rose-gold);
  color: var(--glam-matte-black);
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  padding: 0.95rem 1.5rem;
  border: none;
  cursor: pointer;
  transition: background 0.2s ease;
}
.glam-pdp__cart-button:hover { background: var(--glam-champagne-gold); }

.glam-pdp__details {
  max-width: 1200px;
  margin: 4rem auto 0;
  padding: 0 2rem;
  color: var(--glam-deep-espresso);
  display: grid;
  gap: 2.5rem;
}
.glam-pdp__detail-heading {
  font-family: var(--glam-font-display);
  font-weight: 600;
  font-size: 1.75rem;
  margin: 0 0 0.75rem;
  color: var(--glam-deep-espresso);
  border-bottom: 1px solid rgba(44, 32, 24, 0.1);
  padding-bottom: 0.75rem;
}
.glam-pdp__detail-body {
  line-height: 1.7;
  max-width: 72ch;
  color: rgba(44, 32, 24, 0.8);
}
.glam-pdp__detail-note {
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(44, 32, 24, 0.5);
  max-width: 72ch;
  line-height: 1.7;
  margin: 1rem 0 0;
}

.glam-pdp__related {
  max-width: 1200px;
  margin: 5rem auto 0;
  padding: 0 2rem 5rem;
}
.glam-pdp__related-heading {
  font-family: var(--glam-font-display);
  font-weight: 600;
  font-size: 1.5rem;
  text-align: center;
  color: var(--glam-deep-espresso);
  margin: 0 0 2rem;
}
.glam-pdp__related-grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

/* Cart — brief §2.9. Defer bg + text color to Vela cart.liquid styling
 * (light canvas, dark text). Earlier we forced carbon bg + white text
 * which produced black-on-black "Your Cart" heading. */
.glam-cart {
  min-height: 70vh;
  padding: 4rem 2rem 5rem;
}
.glam-cart__header {
  max-width: 900px;
  margin: 0 auto 2.5rem;
  text-align: center;
}
.glam-cart__heading {
  font-family: var(--glam-font-display);
  font-weight: 700;
  font-size: clamp(2rem, 4vw, 2.75rem);
  margin: 0;
}
.glam-cart__list {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 900px;
  border-top: 1px solid rgba(163, 163, 163, 0.25);
}
.glam-cart__row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 2rem;
  align-items: center;
  padding: 1.5rem 0;
  border-bottom: 1px solid rgba(163, 163, 163, 0.15);
}
.glam-cart__row-name {
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 1.125rem;
  margin: 0 0 0.25rem;
}
.glam-cart__row-descriptor {
  font-size: 0.85rem;
  color: var(--glam-warm-gray);
  margin: 0;
}
.glam-cart__row-qty {
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--glam-warm-gray);
  margin: 0;
}
.glam-cart__row-price {
  font-family: var(--glam-font-body);
  font-weight: 600;
  color: var(--glam-champagne-gold);
  font-size: 1.125rem;
  margin: 0;
}
.glam-cart__summary {
  max-width: 900px;
  margin: 2.5rem auto 0;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem 2rem;
  align-items: center;
}
.glam-cart__subtotal-label {
  font-size: 0.85rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--glam-warm-gray);
  margin: 0;
}
.glam-cart__subtotal-value {
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 1.5rem;
  color: var(--glam-champagne-gold);
  margin: 0;
  text-align: right;
}
.glam-cart__checkout-btn {
  grid-column: 1 / -1;
  text-align: center;
  background: var(--glam-rose-gold);
  color: var(--glam-matte-black);
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  padding: 1.1rem 1.5rem;
  text-decoration: none;
  transition: background 0.2s ease;
  margin-top: 1.25rem;
}
.glam-cart__checkout-btn:hover { background: var(--glam-champagne-gold); }
.glam-cart__continue-link {
  grid-column: 1 / -1;
  text-align: center;
  color: var(--glam-warm-gray);
  text-decoration: underline;
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.glam-cart__continue-link--primary {
  display: inline-block;
  margin-top: 1.5rem;
  background: var(--glam-rose-gold);
  color: var(--glam-matte-black);
  text-decoration: none;
  padding: 0.95rem 2rem;
  font-weight: 600;
  letter-spacing: 0.15em;
}
.glam-cart__empty {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
  padding: 4rem 2rem;
}
.glam-cart__empty-msg {
  font-family: var(--glam-font-display);
  font-size: 1.5rem;
  color: var(--glam-warm-gray);
  margin: 0;
}

/* Lab Results / Certificates index page — process-on-display layout.
 * Cream zone with restrained typography; the data IS the design.
 * Patterned after industry best practice (Oath Research) but in the
 * Glam palette: deep-espresso text, rose-gold accents, warm-cream
 * background. */
.glam-coas {
  background: var(--glam-warm-cream);
  color: var(--glam-deep-espresso);
  padding: 5rem 1.5rem 6rem;
}
.glam-coas__inner {
  max-width: 1100px;
  margin: 0 auto;
}
.glam-coas__header {
  text-align: center;
  margin-bottom: 3.5rem;
  padding-bottom: 2rem;
  border-bottom: 2px solid var(--glam-rose-gold);
}
.glam-coas__title {
  font-family: var(--glam-font-display);
  font-size: clamp(2.5rem, 6vw, 3.75rem);
  letter-spacing: -0.01em;
  margin: 0 0 1rem;
}
.glam-coas__lede {
  font-family: var(--glam-font-body);
  font-size: 1.05rem;
  line-height: 1.6;
  max-width: 640px;
  margin: 0 auto;
  color: var(--glam-deep-espresso);
}

/* Hero stats row — facts, not marketing. Each stat is a stacked
 * value/label pair, equal weight, no decoration. */
.glam-coas__stats {
  list-style: none;
  padding: 0;
  margin: 0 0 4rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 2rem;
  text-align: center;
}
.glam-coas__stat {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1.5rem 1rem;
  border: 1px solid rgba(183, 110, 121, 0.18);
  background: rgba(255, 255, 255, 0.5);
}
.glam-coas__stat-value {
  font-family: var(--glam-font-display);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--glam-deep-wine);
  line-height: 1;
}
.glam-coas__stat-label {
  font-family: var(--glam-font-body);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--glam-warm-gray);
  color: rgba(44, 32, 24, 0.65);
}
.glam-coas__empty {
  font-family: var(--glam-font-body);
  font-size: 1rem;
  color: var(--glam-warm-gray);
  text-align: center;
  margin: 3rem 0 4rem;
  padding: 3rem 1.5rem;
  border: 1px dashed rgba(183, 110, 121, 0.3);
  background: rgba(255, 255, 255, 0.5);
}
.glam-coas__empty a {
  color: var(--glam-rose-gold);
  text-decoration: underline;
}

/* Product grid — one card per peptide with at least one approved
 * batch. Cards are visually quiet so the data dominates. */
.glam-coas__grid {
  list-style: none;
  padding: 0;
  margin: 0 0 4rem;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
}
.glam-coas__card {
  background: #fff;
  border: 1px solid rgba(44, 32, 24, 0.08);
  padding: 1.75rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: border-color 0.2s ease, transform 0.2s ease;
}
.glam-coas__card:hover {
  border-color: var(--glam-rose-gold);
  transform: translateY(-2px);
}
.glam-coas__card-title {
  font-family: var(--glam-font-display);
  font-weight: 600;
  font-size: 1.5rem;
  margin: 0;
  color: var(--glam-deep-espresso);
}
.glam-coas__card-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem 1rem;
  margin: 0;
  font-family: var(--glam-font-body);
  font-size: 0.85rem;
}
.glam-coas__card-meta div { display: flex; flex-direction: column; gap: 0.15rem; }
.glam-coas__card-meta dt {
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(44, 32, 24, 0.55);
  margin: 0;
}
.glam-coas__card-meta dd {
  font-weight: 500;
  margin: 0;
  color: var(--glam-deep-espresso);
}
.glam-coas__pass { color: #2d8a4e; font-weight: 600; }
.glam-coas__card-cta {
  align-self: flex-start;
  font-family: var(--glam-font-body);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--glam-rose-gold);
  text-decoration: none;
  padding: 0.6rem 0;
  border-top: 1px solid rgba(183, 110, 121, 0.15);
  width: 100%;
  transition: color 0.2s ease;
}
.glam-coas__card-cta:hover { color: var(--glam-deep-wine); }
.glam-coas__note {
  font-family: var(--glam-font-body);
  font-size: 0.85rem;
  line-height: 1.7;
  color: rgba(44, 32, 24, 0.65);
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  padding-top: 2.5rem;
  border-top: 1px solid rgba(44, 32, 24, 0.08);
}

/* Per-product COA history — newest-first table view. Same cream
 * surface as /coas, table-driven so every batch is line-comparable. */
.glam-coa-history {
  background: var(--glam-warm-cream);
  color: var(--glam-deep-espresso);
  padding: 5rem 1.5rem 6rem;
}
.glam-coa-history__inner {
  max-width: 960px;
  margin: 0 auto;
}
.glam-coa-history__header {
  margin-bottom: 3rem;
  padding-bottom: 1.75rem;
  border-bottom: 2px solid var(--glam-rose-gold);
}
.glam-coa-history__breadcrumb {
  font-family: var(--glam-font-body);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin: 0 0 1rem;
}
.glam-coa-history__breadcrumb a {
  color: var(--glam-rose-gold);
  text-decoration: none;
}
.glam-coa-history__breadcrumb a:hover { color: var(--glam-deep-wine); }
.glam-coa-history__title {
  font-family: var(--glam-font-display);
  font-size: clamp(2.25rem, 5vw, 3.25rem);
  letter-spacing: -0.01em;
  margin: 0 0 0.5rem;
}
.glam-coa-history__sku {
  font-family: var(--glam-font-body);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(44, 32, 24, 0.55);
  margin: 0;
}
.glam-coa-history__table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--glam-font-body);
  font-size: 0.9rem;
  background: #fff;
  border: 1px solid rgba(44, 32, 24, 0.08);
}
.glam-coa-history__table th {
  text-align: left;
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(44, 32, 24, 0.55);
  padding: 1rem 1.25rem;
  border-bottom: 1px solid rgba(44, 32, 24, 0.08);
  font-weight: 500;
}
.glam-coa-history__table td {
  padding: 1.1rem 1.25rem;
  border-bottom: 1px solid rgba(44, 32, 24, 0.05);
}
.glam-coa-history__table tr:last-child td { border-bottom: none; }
.glam-coa-history__batch-id {
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 0.85rem;
}
.glam-coa-history__pass { color: #2d8a4e; font-weight: 600; }
.glam-coa-history__row-cta {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--glam-rose-gold);
  text-decoration: none;
}
.glam-coa-history__row-cta:hover { color: var(--glam-deep-wine); }
.glam-coa-history__empty {
  font-family: var(--glam-font-body);
  font-size: 1rem;
  color: var(--glam-warm-gray);
  text-align: center;
  margin: 3rem 0;
  padding: 3rem 1.5rem;
  border: 1px dashed rgba(183, 110, 121, 0.3);
  background: rgba(255, 255, 255, 0.5);
}
.glam-coa-history__note {
  font-family: var(--glam-font-body);
  font-size: 0.85rem;
  line-height: 1.7;
  color: rgba(44, 32, 24, 0.65);
  max-width: 720px;
  margin: 3rem auto 0;
  text-align: center;
}

/* PDP detail-section CTA — quietly accents the COA-history link
 * without competing with the Add-to-Cart button. */
.glam-pdp__detail-cta-row {
  margin: 1rem 0 0;
}
.glam-pdp__detail-cta {
  font-family: var(--glam-font-body);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--glam-rose-gold);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  transition: color 0.2s ease;
}
.glam-pdp__detail-cta:hover { color: var(--glam-champagne-gold); }

/* ----- Vela cosmetic02 chrome adaptation overrides ------------------
 * The Vela theme's vela-site.css hardcodes `background-color: white`
 * on #velaFooter, ignoring our --vela-footer-bgcolor token. Brief §2.2
 * specifies a DARK footer; the chrome footer is meant to be the brand
 * dark register before the compliance footer beneath it. Force the
 * dark-on-dark intent here, with !important to win Vela's specificity.
 */
#velaFooter {
  background-color: var(--vela-footer-bgcolor) !important;
  color: var(--vela-footer-textcolor) !important;
}
.velaFooterTitle {
  color: var(--vela-footer-titlecolor) !important;
}
.velaFooterMenu .velaFooterList a,
.velaFooterMenu a,
.vela-contactinfo a {
  color: var(--vela-footer-link) !important;
}
.velaFooterMenu .velaFooterList a:hover,
.velaFooterMenu a:hover,
.vela-contactinfo a:hover {
  color: var(--vela-footer-link-hover) !important;
}
.velaCopyRight {
  color: var(--vela-footer-textcolor) !important;
}

/* Ensure feature-text section + product cards have readable contrast.
 * Vela defaults are dark text on white, our cream body bg keeps that
 * readable, but explicit defensive rule for the headings. */
.velaFeatureText,
.velaListProductList {
  color: var(--vela-text-color-primary);
}
/* "The Collection" featured-products heading + lede inherit the same
 * Playfair-display treatment as the 3-col USP block subheadings. */
.velaFeatureBlockTitle h3,
.velaListHeading,
.velaListLede {
  color: var(--vela-text-color-secondary);
}
.velaListHeading {
  font-family: var(--glam-font-display);
  font-weight: 400;
  font-size: clamp(32px, 4vw, 44px);
  letter-spacing: 0;
  margin: 0 0 8px;
}
.velaListLede {
  font-family: var(--glam-font-body);
  font-size: 16px;
  color: var(--glam-deep-espresso);
  opacity: 0.78;
  max-width: 640px;
  margin: 0 auto 32px;
}

/* Hero → 3-col → featured-products section rhythm. Operator
 * (2026-05-04): 'decrease the space between the 3 col and The
 * Collection on the front page of glam'. Reduced bottom-of-3-col
 * + top-of-collection so the two sections sit closer together. */
.velaFeatureText.glam-home-features {
  padding: 80px 0 24px;
}
.velaProductList.glam-home-featured {
  padding: 8px 0 80px;
}

/* Vela's stock .proList has overflow:hidden (clearfix-era pattern),
 * which on the operator's report (2026-05-04 wd2) was clipping the
 * rose-gold hover glow off the LEFT and RIGHT of every card so the
 * shadow read like a half-glow. We don't need that clearfix because
 * the inner .rowFlex is flexbox. Open the row so box-shadow can
 * render outside the row bounds. Container padding still keeps
 * cards from kissing the viewport edge. */
.glam .proList,
.glam .collBoxProducts {
  overflow: visible;
}
.glam .velaProductList.glam-home-featured .container,
.glam .collection-container {
  /* small horizontal cushion so the glow has room to render at
   * the leftmost / rightmost cards without being cut by .container's
   * boundary; .container's max-width still centers the grid. */
  padding-left: 32px;
  padding-right: 32px;
}

/* Shop + featured product card chrome. WHY: in the bare Vela default
 * each card was just stacked text on the page background, so the eye
 * read the price as belonging to the next row. Now each card is its
 * own translucent tile with a soft blush border, letting the price
 * sit clearly inside its own card with a thin top divider.
 *
 * Hover lift: the bare Vela default had no hover treatment after we
 * stripped the jQuery hover-overlay JS during chrome ingestion.
 * Restore visual feedback via a CSS-only translateY + shadow pop. */
.glam .velaProBlock {
  margin-bottom: 48px;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(232, 213, 206, 0.55);
  border-radius: 4px;
  padding: 0 0 16px;
  box-shadow: 0 2px 16px rgba(13, 13, 13, 0.04);
  transition: transform 0.25s ease, box-shadow 0.25s ease,
              border-color 0.25s ease;
}
/* Hover state — operator (2026-05-04): 'can you make the glow around
 * the mouseover or selected product rosegold? more glow shadow'.
 * Two-layer rose-gold glow: outer soft halo + inner crisp ring. */
.glam .velaProBlock:hover,
.glam .velaProBlock:focus-within {
  transform: translateY(-3px);
  border-color: rgba(183, 110, 121, 0.85);
  box-shadow:
    0 0 0 1px rgba(183, 110, 121, 0.35),
    0 16px 48px rgba(183, 110, 121, 0.32),
    0 4px 18px rgba(183, 110, 121, 0.22);
}
.glam .velaProBlock .proPrice {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(232, 213, 206, 0.42);
}
/* Price stays in the brand rose-gold (champagne register, not the
 * generic espresso body color) so it reads as the deliberate price
 * accent — same color as on the PDP. */
.glam .velaProBlock .priceProduct,
.glam .velaProBlock .priceSale {
  font-family: var(--glam-font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--glam-rose-gold);
  letter-spacing: 0.02em;
}


/* =============================================================================
   GlamPeptides — Safety Data Sheet pages
   =============================================================================
   Per-chemistry SDS library at /glam/sds (index) and /glam/sds/:key (show).
   Champagne palette: Playfair Display serif headings, espresso revision
   stamp on warm-cream canvas. Mirrors the COA library's typographic
   register but with a more documentary feel — labs and ops read these,
   not customers shopping the shop grid.
   ============================================================================= */
.glam .glam-sds-page {
  max-width: 1100px;
  margin: 0 auto;
  padding: 60px 24px 80px;
}
.glam .glam-sds-page h1,
.glam .glam-sds-page h2,
.glam .glam-sds-page h3 {
  font-family: var(--glam-font-display);
  color: var(--glam-deep-espresso);
  letter-spacing: 0.01em;
}
.glam .glam-sds__card {
  background: var(--glam-warm-cream);
  border: 1px solid rgba(232, 213, 206, 0.6);
  border-radius: 6px;
  padding: 28px 24px;
  transition: box-shadow 0.18s ease, transform 0.18s ease;
}
.glam .glam-sds__card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(183, 110, 121, 0.18);
}
.glam .glam-sds__card-meta {
  margin: 16px 0 24px;
  font-size: 13px;
  color: var(--glam-deep-espresso);
  font-family: var(--glam-font-body);
}
.glam .glam-sds__card-meta dt {
  display: inline-block;
  margin-right: 6px;
  color: var(--glam-warm-gray);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 11px;
}
.glam .glam-sds__card-meta dd {
  display: inline-block;
  margin: 0 0 4px 0;
  color: var(--glam-deep-espresso);
}
.glam .glam-sds-detail__crumb {
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--glam-warm-gray);
  margin-bottom: 12px;
}
.glam .glam-sds-detail__crumb a {
  color: var(--glam-rose-gold);
  text-decoration: none;
}
.glam .glam-sds-detail__meta {
  font-family: var(--glam-font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--glam-deep-espresso);
  border-top: 1px solid var(--glam-rose-gold);
  border-bottom: 1px solid var(--glam-rose-gold);
  padding: 8px 0;
  display: inline-block;
  letter-spacing: 0.04em;
}
.glam .glam-sds-detail__body section {
  margin: 28px 0;
  padding: 20px 24px;
  background: rgba(251, 247, 242, 0.6);
  border-left: 3px solid var(--glam-champagne-gold);
}
.glam .glam-sds-detail__body section h3 {
  margin-top: 0;
  margin-bottom: 12px;
  font-size: 18px;
  color: var(--glam-deep-espresso);
}
.glam .glam-sds-detail__body p {
  font-size: 14px;
  line-height: 1.7;
  color: var(--glam-deep-espresso);
}
.glam .glam-sds-detail__note,
.glam .glam-sds__note,
.glam .glam-sds__empty {
  font-size: 12px;
  color: var(--glam-warm-gray);
  letter-spacing: 0.04em;
}

/* Trademark superscript on protectable brand-name product titles.
   See app/helpers/brand_trademark_helper.rb for the rationale. The
   superscript inherits the parent color but sits at the top of the
   line — slightly muted so the wordmark still leads visually. */
.brand-tm {
  font-size: 0.45em;
  vertical-align: super;
  line-height: 0;
  letter-spacing: 0;
  margin-left: 0.1em;
  opacity: 0.75;
  font-weight: 500;
}

/* Layout container for the .vela-page page-content body. Operator
   follow-up 2026-05-07: "content below hero is still kinda janky".
   The .container -> .pageContainer -> .pageContent chain ships with
   no max-width, so body copy ran edge-to-edge on desktop. Pin to a
   readable measure + center, give the body a warm-cream backdrop so
   the section reads as a distinct block (mirrors .glam-content__inner
   treatment on FAQ/Legal/Shipping pages that use the __body wrapper). */
.glam-content .pageContainer {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 1.5rem 4rem;
}
.glam-content .pageContent {
  background: var(--glam-warm-cream);
  padding: 2.5rem 0 0.5rem;
}
.glam-content .velaBannerText {
  background: var(--glam-warm-cream);
  padding: 4rem 1.5rem 1rem;
  text-align: center;
}
.glam-content .velaBannerTextInner {
  max-width: 760px;
  margin: 0 auto;
}

/* Vela page-content (.vela-page .rte) typography for the ABOUT and
   other pillar-0 content pages. Operator-reported 2026-05-07: "the
   about page of glam is shitty, different font sizes, weird".
   Without these the .rte block uses Vela's default Poppins for h2/h3,
   which fights the H1's Playfair display chain. Mirrors the
   `.glam-content__body h2/h3` styling already shipped for content
   pages that DO use the __body wrapper (FAQ / Legal / Shipping). */
.glam-content .rte h2,
.glam-content .pageContent h2 {
  font-family: var(--glam-font-display);
  font-weight: 600;
  font-size: 1.65rem;
  color: var(--glam-deep-wine);
  margin: 2.5rem 0 0.75rem;
  letter-spacing: -0.005em;
}
.glam-content .rte h3,
.glam-content .pageContent h3 {
  font-family: var(--glam-font-body);
  font-weight: 600;
  font-size: 1.05rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--glam-deep-espresso);
  margin: 1.75rem 0 0.5rem;
}
.glam-content .rte p {
  font-family: var(--glam-font-body);
  font-size: 1rem;
  line-height: 1.75;
  color: var(--glam-deep-espresso);
  margin: 0 0 1.1rem;
}
/* Hero subtitle (.velaHomeSubtitle on About) — should read as a
   tagline beneath the Playfair H1, not a generic Poppins H3.
   Smaller, italic Playfair, rose-gold. */
.glam-content .velaHomeSubtitle {
  font-family: var(--glam-font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.25rem;
  color: var(--glam-rose-gold);
  letter-spacing: 0.005em;
  margin: 0.5rem 0 0;
}

/* PDP gallery — base styles in shared/pdp_gallery.css; this block
   pins the active-thumb accent + hover tint to the glam palette via
   the --pdp-gallery-accent custom property the shared rule reads. */
body.glam {
  --pdp-gallery-accent: var(--glam-rose-gold);
}
body.glam .pdp-gallery__thumb {
  background: var(--glam-warm-cream);
}

/* Newsletter section — warm cream surface, rose-gold accents. */
body.glam .brand-newsletter-section {
  background: var(--glam-warm-cream);
  border-top: 1px solid var(--glam-soft-blush);
  padding: 80px 24px;
}
body.glam .brand-newsletter-section__inner {
  max-width: 720px;
  margin: 0 auto;
  text-align: left;
}
body.glam .brand-newsletter-section__heading {
  margin: 0 0 12px;
  font-family: var(--glam-font-display);
  font-weight: 400;
  font-size: clamp(28px, 4vw, 40px);
  color: var(--glam-deep-espresso);
}
body.glam .brand-newsletter-section__body {
  margin: 0 0 24px;
  font-family: var(--glam-font-body);
  font-size: 15px;
  line-height: 1.65;
  color: var(--glam-warm-gray);
}
body.glam .brand-newsletter-section .field__input {
  background: #FFFFFF;
  border: 1px solid var(--glam-soft-blush);
  color: var(--glam-deep-espresso);
  padding: 14px 16px;
  width: 100%;
  font-family: var(--glam-font-body);
  font-size: 15px;
  border-radius: 0;
}
body.glam .brand-newsletter-section .newsletter-form__button {
  background: var(--glam-rose-gold);
  color: #FFFFFF;
  border: 0;
  border-radius: 0;
  margin-top: 12px;
  padding: 14px 22px;
  font-family: var(--glam-font-body);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
}
body.glam .brand-newsletter-section .newsletter-form__message--success {
  color: #2C6E5C;
  margin-top: 0;
  margin-bottom: 24px;
  font-family: var(--glam-font-body);
  font-size: 14px;
}
body.glam .brand-newsletter-section .newsletter-form__message--error {
  color: #B5443A;
  margin-top: 0;
  margin-bottom: 24px;
  font-family: var(--glam-font-body);
  font-size: 14px;
}
