/* ============================================================
   DESIGN TOKENS — from /Users/biancabienaime/projects/alinenasseh/design/01-design-system.md
   ============================================================ */
:root {
  /* Colors — v2 wave palette (white + turquoise + black) per Alexander 2026-06-08 */
  --color-bg-cream: #FFFFFF;
  --color-bg-paper: #FFFFFF;
  --color-bg-tint: #F5F1EB;
  --color-ink-deep: #1F1B1A;
  --color-ink-warm: #2A2520;
  --color-ink-mute: #7A6B5C;
  --color-wave-50: #EAF7F4;
  --color-wave-100: #CFEDE7;
  --color-wave-300: #A4DCD2;
  --color-wave-500: #7FCFC4;
  --color-wave-700: #4FA39A;
  --color-accent: #1F1B1A;
  --color-accent-hover: #3D2E22;
  --color-accent-soft: #EAF7F4;
  --color-success: #4A6B3A;
  --color-warning: #B67A2A;
  --color-error: #8B2A1F;

  /* Type */
  --font-display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-serif: 'Fraunces', Georgia, serif;
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;

  /* Spacing */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;
  --space-24: 96px;
  --space-32: 128px;

  /* Radii */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 20px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(31, 22, 17, 0.04);
  --shadow-sm: 0 2px 8px rgba(31, 22, 17, 0.06);
  --shadow-md: 0 8px 24px rgba(31, 27, 26, 0.08);
  --shadow-wave-glow: 0 8px 32px rgba(127, 207, 196, 0.32);

  /* Motion */
  --motion-fast: 120ms ease-out;
  --motion-base: 200ms ease-out;
  --motion-slow: 400ms ease-in-out;
  --motion-reveal: 600ms cubic-bezier(0.16, 1, 0.3, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-ink-deep);
  background: var(--color-bg-cream);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.eyebrow {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-wave-500);
  margin-bottom: var(--space-4);
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--color-ink-warm);
  text-wrap: balance;
}

h1 { font-size: clamp(40px, 5.5vw, 72px); line-height: 1.05; letter-spacing: -0.03em; }
h2 { font-size: clamp(28px, 3.5vw, 44px); line-height: 1.15; letter-spacing: -0.02em; margin-bottom: var(--space-6); }
h3 { font-size: clamp(20px, 2.2vw, 28px); line-height: 1.25; letter-spacing: -0.01em; }
h4 { font-size: 18px; line-height: 1.35; }

p { color: var(--color-ink-warm); }
.lede { font-size: 18px; line-height: 1.6; color: var(--color-ink-mute); max-width: 56ch; }

/* ============================================================
   LAYOUT
   ============================================================ */
.container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

@media (min-width: 768px) {
  .container { padding: 0 var(--space-10); }
}

section { padding: var(--space-16) 0; }
@media (min-width: 768px) {
  section { padding: var(--space-20) 0; }
}

.section-intro {
  max-width: 720px;
  margin-bottom: var(--space-12);
}
.section-intro.center { text-align: center; margin-left: auto; margin-right: auto; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 14px 28px;
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.02em;
  transition: all var(--motion-base);
  white-space: nowrap;
}

.btn-primary {
  background: var(--color-accent);
  color: var(--color-bg-cream);
}
.btn-primary:hover { background: var(--color-accent-hover); box-shadow: var(--shadow-wave-glow); transform: translateY(-1px); }
.btn-primary:focus-visible { outline: 2px solid var(--color-wave-500); outline-offset: 3px; }

.btn-secondary {
  background: transparent;
  color: var(--color-ink-warm);
  border: 1.5px solid var(--color-wave-300);
}
.btn-secondary:hover { background: var(--color-wave-50); border-color: var(--color-wave-500); }
.btn-secondary:focus-visible { outline: 2px solid var(--color-wave-500); outline-offset: 3px; }

.btn-link {
  color: var(--color-wave-500);
  font-weight: 500;
  border-bottom: 1px solid transparent;
  transition: border-color var(--motion-base);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}
.btn-link:hover { border-bottom-color: var(--color-wave-500); }
.btn-link::after { content: '→'; transition: transform var(--motion-base); }
.btn-link:hover::after { transform: translateX(4px); }

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.announcement {
  background: var(--color-ink-deep);
  color: var(--color-bg-cream);
  text-align: center;
  font-size: 13px;
  padding: var(--space-3) var(--space-4);
  letter-spacing: 0.01em;
}

/* ============================================================
   NAV
   ============================================================ */
.nav-wrap {
  background: var(--color-bg-cream);
  border-bottom: 1px solid var(--color-wave-100);
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(8px);
  background: rgba(255, 255, 255, 0.92);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) 0;
}

.logo {
  font-family: var(--font-display);
  font-size: 22px;
  font-style: italic;
  color: var(--color-ink-warm);
  letter-spacing: -0.01em;
}

.nav-links {
  display: none;
  gap: var(--space-8);
  list-style: none;
}
@media (min-width: 1024px) {
  .nav-links { display: flex; }
}

.nav-links a {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-ink-warm);
  transition: color var(--motion-base);
  position: relative;
}
.nav-links a:hover { color: var(--color-wave-500); }
.nav-links a.has-menu::after { content: ' ▾'; font-size: 10px; opacity: 0.6; }

.nav-icons {
  display: flex;
  align-items: center;
  gap: var(--space-5);
}
.nav-icon {
  width: 22px;
  height: 22px;
  color: var(--color-ink-warm);
  cursor: pointer;
  transition: color var(--motion-base);
  position: relative;
}
.nav-icon:hover { color: var(--color-wave-500); }
.cart-count {
  position: absolute;
  top: -4px;
  right: -6px;
  background: var(--color-ink-deep);
  color: #FFFFFF;
  font-size: 10px;
  font-weight: 600;
  width: 16px;
  height: 16px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
}

.mobile-toggle {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 4px;
}
@media (min-width: 1024px) {
  .mobile-toggle { display: none; }
}
.mobile-toggle span {
  width: 22px;
  height: 1.5px;
  background: var(--color-ink-warm);
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  padding: var(--space-16) 0 var(--space-20);
  background: var(--color-bg-cream);
}

.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  align-items: center;
}
@media (min-width: 1024px) {
  .hero-grid { grid-template-columns: 1.1fr 1fr; gap: var(--space-16); }
}

.hero-text { max-width: 560px; }
.hero-text h1 { margin-bottom: var(--space-6); }
.hero-text .lede { margin-bottom: var(--space-8); }
.hero-ctas { display: flex; gap: var(--space-4); flex-wrap: wrap; }

.hero-bonbons {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  position: relative;
}

.bonbon-tile {
  aspect-ratio: 1;
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform var(--motion-slow), box-shadow var(--motion-slow);
  animation: reveal 800ms var(--motion-reveal) both;
}
.bonbon-tile:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.bonbon-tile:nth-child(1) { animation-delay: 0ms; }
.bonbon-tile:nth-child(2) { animation-delay: 100ms; }
.bonbon-tile:nth-child(3) { animation-delay: 200ms; }
.bonbon-tile:nth-child(4) { animation-delay: 300ms; }

.bonbon-tile-label {
  position: absolute;
  bottom: var(--space-4);
  left: var(--space-4);
  background: rgba(250, 247, 242, 0.95);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 500;
  color: var(--color-ink-warm);
}

/* Bonbon "visuals" — placeholder gradients. Real product photos replace these. */
.bonbon-hero-photo {
  grid-column: 1 / -1;
  background: var(--color-bg-tint);
  position: relative;
  overflow: hidden;
  aspect-ratio: 1 / 1;
}
.bonbon-hero-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.bonbon-hero-photo .bonbon-tile-label {
  position: absolute;
  left: var(--space-4);
  bottom: var(--space-4);
  background: rgba(255, 255, 255, 0.92);
  color: var(--color-ink-deep);
  padding: 8px 14px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 500;
  backdrop-filter: blur(4px);
}

/* Collection card photo (replaces radial gradient with a real product shot).
   Photo sits above the ::before gradient, text sits above the photo.
   The .collection-card > * rule below bumps the photo to z-index 1 and
   position: relative — we override both here so the photo fills the card
   and stays below text. */
.collection-card > .collection-photo {
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
}
/* Subtle dark wash at the bottom so text on the photo stays readable.
   Applied to all 4 collection cards so SVG/JPG photos show clearly. */
.collection-bonbons,
.collection-truffles,
.collection-bars,
.collection-seasonal {
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 40%, rgba(0,0,0,0.75) 70%, rgba(0,0,0,0.92) 100%);
}

/* ============================================================
   ANNOUNCEMENT BAR (refactored for partial)
   ============================================================ */
.announcement {
  background: var(--color-ink-deep);
  color: var(--color-bg-cream);
  text-align: center;
  font-size: 13px;
  padding: var(--space-3) var(--space-4);
  letter-spacing: 0.01em;
}
.announcement-sep { margin: 0 var(--space-3); opacity: 0.5; }
.announcement-link {
  color: var(--color-wave-300);
  border-bottom: 1px solid transparent;
  transition: border-color var(--motion-base);
}
.announcement-link:hover { border-bottom-color: var(--color-wave-300); }

/* ============================================================
   LOGO (refactored for partial)
   ============================================================ */
.logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-size: 22px;
  font-style: italic;
  color: var(--color-ink-warm);
  letter-spacing: -0.01em;
}
.logo-mark { display: inline-flex; align-items: center; }
.logo-wordmark { line-height: 1; }

/* ============================================================
   NAV (refactored for partial — links are <a>, not <button>)
   ============================================================ */
.nav-wrap {
  background: var(--color-bg-cream);
  border-bottom: 1px solid var(--color-wave-100);
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(8px);
  background: rgba(255, 255, 255, 0.92);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) 0;
}

.nav-links {
  display: none;
  gap: var(--space-8);
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (min-width: 1024px) {
  .nav-links { display: flex; }
}

.nav-links a {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-ink-warm);
  transition: color var(--motion-base);
  position: relative;
  text-decoration: none;
  display: inline-block;
  padding: 4px 0;
}
.nav-links a:hover { color: var(--color-wave-700); }
.nav-links a.is-active {
  color: var(--color-ink-deep);
  font-weight: 600;
}
.nav-links a.is-active::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 2px;
  background: var(--color-wave-500);
}

.nav-icons {
  display: flex;
  align-items: center;
  gap: var(--space-5);
}
.nav-icon {
  width: 22px;
  height: 22px;
  color: var(--color-ink-warm);
  cursor: pointer;
  transition: color var(--motion-base);
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}
.nav-icon:hover { color: var(--color-wave-700); }
.nav-icon svg { width: 100%; height: 100%; }
.cart-count {
  position: absolute;
  top: -4px;
  right: -6px;
  background: var(--color-ink-deep);
  color: #FFFFFF;
  font-size: 10px;
  font-weight: 600;
  width: 16px;
  height: 16px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
}

.mobile-toggle {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 4px;
  background: none;
  border: none;
  cursor: pointer;
}
@media (min-width: 1024px) {
  .mobile-toggle { display: none; }
}
.mobile-toggle span {
  width: 22px;
  height: 1.5px;
  background: var(--color-ink-warm);
  display: block;
}

/* ============================================================
   ACCESSIBILITY UTILITIES
   ============================================================ */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============================================================
   FOOTER (refactored for partial)
   ============================================================ */
footer {
  background: var(--color-ink-deep);
  color: var(--color-bg-cream);
  padding: var(--space-20) 0 var(--space-8);
  margin-top: var(--space-24);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  margin-bottom: var(--space-12);
}
@media (min-width: 768px) {
  .footer-grid { grid-template-columns: 2fr 1fr 1fr 2fr; }
}
.footer-col h4 {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-wave-300);
  margin-bottom: var(--space-4);
}
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: var(--space-2); }
.footer-col a {
  color: var(--color-wave-100);
  font-size: 14px;
  text-decoration: none;
  transition: color var(--motion-base);
}
.footer-col a:hover { color: var(--color-bg-cream); }
.footer-logo {
  font-family: var(--font-display);
  font-size: 28px;
  font-style: italic;
  margin-bottom: var(--space-3);
  color: var(--color-bg-cream);
}
.footer-tag {
  color: var(--color-wave-100);
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: var(--space-4);
  max-width: 36ch;
}
.footer-address {
  color: var(--color-wave-100);
  font-size: 13px;
  line-height: 1.7;
  font-style: normal;
  margin-bottom: var(--space-4);
}
.footer-address a { color: var(--color-wave-300); }
.footer-social {
  display: flex;
  gap: var(--space-3);
}
.footer-social a {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-wave-100);
  transition: background var(--motion-base), color var(--motion-base);
}
.footer-social a:hover {
  background: var(--color-wave-500);
  color: var(--color-ink-deep);
}
.footer-newsletter p {
  color: var(--color-wave-100);
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: var(--space-3);
}
.footer-form {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.footer-form input {
  flex: 1;
  padding: 10px 14px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.05);
  color: var(--color-bg-cream);
  font-size: 14px;
  font-family: var(--font-sans);
}
.footer-form input::placeholder { color: var(--color-wave-100); opacity: 0.6; }
.footer-form input:focus {
  outline: 2px solid var(--color-wave-500);
  outline-offset: 2px;
}
.footer-trust {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: var(--space-4);
}
.trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}
.trust-rating {
  color: #F5DC78;
  font-size: 14px;
  letter-spacing: 0.05em;
}
.trust-text {
  color: var(--color-wave-100);
  font-size: 12px;
  line-height: 1.4;
}
.trust-text em {
  color: var(--color-bg-cream);
  font-style: italic;
  font-weight: 500;
}
.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: var(--space-6);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  font-size: 12px;
  color: var(--color-wave-100);
}
.footer-legal {
  list-style: none;
  display: flex;
  gap: var(--space-4);
  padding: 0;
  margin: 0;
}

@keyframes reveal {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .bonbon-tile { animation: none; }
  .hero-bonbons .bonbon-tile:hover { transform: none; }
}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust {
  background: var(--color-bg-paper);
  border-top: 1px solid var(--color-wave-100);
  border-bottom: 1px solid var(--color-wave-100);
  padding: var(--space-10) 0;
}

.trust-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}
@media (min-width: 768px) {
  .trust-grid { grid-template-columns: repeat(4, 1fr); gap: var(--space-8); }
}

.trust-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-2);
}
.trust-icon {
  width: 36px;
  height: 36px;
  color: var(--color-wave-500);
  margin-bottom: var(--space-2);
}
.trust-item h4 { font-family: var(--font-sans); font-size: 15px; font-weight: 600; color: var(--color-ink-warm); }
.trust-item p { font-size: 13px; color: var(--color-ink-mute); line-height: 1.4; }

/* ============================================================
   COLLECTIONS GRID
   ============================================================ */
.collections { background: var(--color-bg-cream); }

.collections-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
@media (min-width: 768px) {
  .collections-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .collections-grid { grid-template-columns: repeat(4, 1fr); }
}

.collection-card {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  min-height: 420px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-6);
  color: var(--color-bg-cream);
  background: var(--color-ink-deep);
  box-shadow: var(--shadow-sm);
  transition: transform var(--motion-slow), box-shadow var(--motion-slow);
  cursor: pointer;
}
.collection-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.collection-card > .collection-photo {
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
}
/* Dark wash on the photo so text on top is always readable.
   Pseudos render after the bg image, so they sit on top. */
.collection-card > .collection-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 35%, rgba(0,0,0,0.7) 70%, rgba(0,0,0,0.92) 100%);
  pointer-events: none;
}
/* Hide the original ::before gradient — the card now has its own dark bg
   and the .collection-photo covers the whole card. */
.collection-card::before { display: none; }

.collection-card > * { position: relative; z-index: 1; }
/* Keep the photo and its dark wash below the text content. */
.collection-card > .collection-photo { z-index: 0; }
.collection-card .eyebrow { color: var(--color-wave-100); }
.collection-card h3 { color: var(--color-bg-cream); font-size: 24px; margin-bottom: var(--space-2); }
.collection-card p { color: var(--color-wave-100); font-size: 14px; margin-bottom: var(--space-4); }
.collection-card .btn-link { color: var(--color-bg-cream); border-bottom-color: var(--color-wave-300); }
.collection-card .btn-link:hover { border-bottom-color: var(--color-bg-cream); }

/* ============================================================
   ALINE STORY (zigzag split)
   ============================================================ */
.story {
  background: var(--color-bg-paper);
}

.story-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  align-items: center;
}
@media (min-width: 1024px) {
  .story-grid { grid-template-columns: 1fr 1fr; gap: var(--space-16); }
}

.story-image {
  aspect-ratio: 4/5;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, #1F1B1A 0%, #4FA39A 100%);
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-md);
}
.story-image::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 60%, rgba(255,255,255,0.15) 0%, transparent 60%);
}

.story-text h2 { font-size: clamp(32px, 4vw, 48px); }
.story-text p { font-size: 17px; line-height: 1.7; margin-bottom: var(--space-5); color: var(--color-ink-warm); }
.story-text p + p { color: var(--color-ink-mute); }

/* ============================================================
   BUILD A BOX
   ============================================================ */
.build {
  background: var(--color-wave-700);
  color: var(--color-bg-cream);
  position: relative;
  overflow: hidden;
}
.build::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 60%;
  height: 100%;
  background: radial-gradient(circle at 70% 50%, rgba(184, 142, 107, 0.15) 0%, transparent 60%);
  pointer-events: none;
}

.build .container { position: relative; z-index: 1; }
.build .eyebrow { color: var(--color-wave-300); }
.build h2 { color: var(--color-bg-cream); }
.build p { color: var(--color-wave-100); max-width: 56ch; }

.build-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
}
@media (min-width: 1024px) {
  .build-grid { grid-template-columns: 1fr 1.2fr; gap: var(--space-16); }
}

.box-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 768px) {
  .box-cards { grid-template-columns: repeat(3, 1fr); }
}

.box-card {
  background: rgba(250, 247, 242, 0.06);
  border: 1px solid rgba(184, 142, 107, 0.25);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: all var(--motion-base);
  cursor: pointer;
}
.box-card:hover { background: rgba(250, 247, 242, 0.1); border-color: var(--color-wave-300); transform: translateY(-2px); }
.box-card h4 { font-family: var(--font-display); font-size: 22px; color: var(--color-bg-cream); margin-bottom: var(--space-2); }
.box-card .pieces { font-size: 13px; color: var(--color-wave-100); margin-bottom: var(--space-3); letter-spacing: 0.04em; }
.box-card .price { font-family: var(--font-display); font-size: 20px; color: var(--color-wave-300); }

/* ============================================================
   BEST SELLERS
   ============================================================ */
.best-sellers { background: var(--color-bg-cream); }

.products-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
@media (min-width: 768px) {
  .products-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .products-grid { grid-template-columns: repeat(4, 1fr); }
}

.product-card {
  background: var(--color-bg-paper);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
  transition: all var(--motion-base);
  cursor: pointer;
}
.product-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }

.product-image {
  aspect-ratio: 1;
  position: relative;
  overflow: hidden;
}
.product-image-1 { background: radial-gradient(circle at 50% 50%, #CFEDE7 0%, #7FCFC4 100%); }
.product-image-2 { background: radial-gradient(circle at 50% 50%, #EAF7F4 0%, #A4DCD2 100%); }
.product-image-3 { background: radial-gradient(circle at 50% 50%, #FFFFFF 0%, #CFEDE7 100%); }
.product-image-4 { background: radial-gradient(circle at 50% 50%, #EAF7F4 0%, #4FA39A 100%); }

/* When a product card has an <img>, hide the gradient fallback (image covers it). */
.product-image img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}
.product-image .product-badge { z-index: 1; }

.product-badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  background: var(--color-bg-cream);
  color: var(--color-ink-warm);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-full);
}

.product-info { padding: var(--space-5); }
.product-info h3 { font-family: var(--font-serif); font-size: 17px; margin-bottom: var(--space-1); }
.product-info .tagline { font-size: 13px; color: var(--color-ink-mute); font-style: italic; margin-bottom: var(--space-3); }
.product-info .price-row { display: flex; align-items: center; justify-content: space-between; }
.product-info .price { font-size: 16px; font-weight: 500; color: var(--color-ink-warm); }

.quick-add {
  background: var(--color-wave-500);
  color: var(--color-bg-cream);
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  transition: all var(--motion-base);
}
.quick-add:hover { background: var(--color-wave-700); transform: scale(1.08); }

.section-footer {
  text-align: center;
  margin-top: var(--space-12);
}

/* ============================================================
   CORPORATE + EVENTS (zigzag splits, alternating)
   ============================================================ */
.split {
  padding: var(--space-20) 0;
}
.split.alt { background: var(--color-bg-paper); }

.split-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  align-items: center;
}
@media (min-width: 1024px) {
  .split-grid { grid-template-columns: 1fr 1fr; gap: var(--space-16); }
  .split.reverse .split-grid > div:first-child { order: 2; }
}

.split-image {
  aspect-ratio: 5/4;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}
.split-corporate .split-image { background: url('../assets/illustrations/corporate-gift-box.svg') center/cover no-repeat, #1F1B1A; position: relative; }
.split-corporate .split-image::after {
  content: '';
  position: absolute;
  inset: 12%;
  border: 1px solid var(--color-wave-300);
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(127,207,196,0.2) 0%, rgba(79,163,154,0.4) 100%);
}
.split-events .split-image { background: url('../assets/illustrations/events-wedding-favours.svg') center/cover no-repeat, linear-gradient(135deg, #A4DCD2 0%, #1F1B1A 100%); }
.split-events .split-image::after {
  content: '';
  position: absolute;
  inset: 8%;
  border-radius: var(--radius-md);
  background: linear-gradient(45deg, transparent 30%, rgba(255,255,255,0.15) 50%, transparent 70%);
}

.split-text .value-props {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  margin: var(--space-6) 0 var(--space-8);
}
@media (min-width: 640px) {
  .split-text .value-props { grid-template-columns: repeat(3, 1fr); }
}
.value-prop {
  padding: var(--space-3) 0;
}
.value-prop h4 { font-family: var(--font-sans); font-size: 14px; font-weight: 600; color: var(--color-ink-warm); margin-bottom: 4px; }
.value-prop p { font-size: 13px; color: var(--color-ink-mute); line-height: 1.4; }

.split-ctas { display: flex; gap: var(--space-4); flex-wrap: wrap; }

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews { background: var(--color-bg-cream); }

.reviews-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
@media (min-width: 768px) {
  .reviews-grid { grid-template-columns: repeat(3, 1fr); }
}

.review-card {
  background: var(--color-bg-paper);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  box-shadow: var(--shadow-xs);
  position: relative;
}
.review-quote {
  font-family: var(--font-serif);
  font-size: 17px;
  line-height: 1.6;
  color: var(--color-ink-warm);
  font-style: italic;
  margin-bottom: var(--space-5);
  quotes: '"' '"';
}
.review-quote::before { content: open-quote; font-size: 1.4em; color: var(--color-wave-300); line-height: 0; vertical-align: -0.2em; margin-right: 4px; }
.review-quote::after { content: close-quote; font-size: 1.4em; color: var(--color-wave-300); line-height: 0; vertical-align: -0.2em; margin-left: 4px; }
.review-author { font-size: 14px; font-weight: 500; color: var(--color-ink-warm); }

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter {
  background: var(--color-wave-700);
  color: var(--color-bg-cream);
  padding: var(--space-20) 0;
}
.newsletter .container { text-align: center; max-width: 640px; }
.newsletter h2 { color: var(--color-bg-cream); font-size: clamp(28px, 3.5vw, 40px); }
.newsletter p { color: var(--color-wave-100); margin-bottom: var(--space-8); }
.newsletter-form {
  display: flex;
  gap: var(--space-3);
  max-width: 480px;
  margin: 0 auto var(--space-4);
  flex-direction: column;
}
@media (min-width: 640px) {
  .newsletter-form { flex-direction: row; }
}

.newsletter-form input {
  flex: 1;
  padding: 14px 18px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(184, 142, 107, 0.4);
  background: rgba(250, 247, 242, 0.08);
  color: var(--color-bg-cream);
  font-family: var(--font-sans);
  font-size: 15px;
  transition: all var(--motion-base);
}
.newsletter-form input::placeholder { color: var(--color-wave-100); }
.newsletter-form input:focus { outline: none; border-color: var(--color-wave-300); background: rgba(250, 247, 242, 0.12); }

.newsletter .micro { font-size: 12px; color: var(--color-wave-100); }
.newsletter .social-proof { font-size: 13px; color: var(--color-wave-300); margin-top: var(--space-4); }

/* ============================================================
   FOOTER
   ============================================================ */
footer {
  background: var(--color-ink-deep);
  color: var(--color-wave-100);
  padding: var(--space-16) 0 var(--space-8);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  margin-bottom: var(--space-12);
}
@media (min-width: 768px) {
  .footer-grid { grid-template-columns: 1.5fr 1fr 1fr 1.5fr; gap: var(--space-8); }
}

.footer-col h4 {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-bg-cream);
  margin-bottom: var(--space-4);
}

.footer-brand .logo { color: var(--color-bg-cream); font-size: 24px; margin-bottom: var(--space-3); }
.footer-brand p { font-size: 14px; line-height: 1.6; color: var(--color-wave-100); margin-bottom: var(--space-4); }
.footer-contact { font-size: 13px; line-height: 1.7; color: var(--color-wave-100); }
.footer-contact a { color: var(--color-wave-300); transition: color var(--motion-base); }
.footer-contact a:hover { color: var(--color-bg-cream); }

.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: var(--space-2); }
.footer-col a {
  font-size: 14px;
  color: var(--color-wave-100);
  transition: color var(--motion-base);
}
.footer-col a:hover { color: var(--color-bg-cream); }

.social-row { display: flex; gap: var(--space-3); margin-top: var(--space-4); }
.social-icon {
  width: 36px;
  height: 36px;
  border: 1px solid var(--color-wave-500);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-wave-100);
  transition: all var(--motion-base);
}
.social-icon:hover { background: var(--color-wave-500); color: var(--color-bg-cream); }

.footer-bottom {
  border-top: 1px solid var(--color-wave-700);
  padding-top: var(--space-6);
  text-align: center;
  font-size: 12px;
  color: var(--color-wave-300);
}

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb {
  padding: var(--space-4) 0;
  font-size: 13px;
  color: var(--color-ink-mute);
  border-bottom: 1px solid var(--color-wave-100);
}
.breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  list-style: none;
  padding: 0;
  margin: 0;
}
.breadcrumb li:not(:last-child)::after {
  content: ' / ';
  margin-left: var(--space-2);
  color: var(--color-ink-mute);
}
.breadcrumb a { color: var(--color-ink-warm); }
.breadcrumb a:hover { color: var(--color-wave-700); }
.breadcrumb li[aria-current="page"] { color: var(--color-ink-deep); font-weight: 500; }

/* ============================================================
   SHOP HERO
   ============================================================ */
.shop-hero {
  padding: var(--space-12) 0 var(--space-8);
  text-align: center;
}
.shop-hero h1 {
  font-size: clamp(40px, 5.5vw, 64px);
  margin-bottom: var(--space-4);
}
.shop-hero .lede {
  max-width: 56ch;
  margin: 0 auto;
}

/* ============================================================
   SHOP LAYOUT
   ============================================================ */
.shop-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  padding: var(--space-8) 0 var(--space-20);
}
@media (min-width: 1024px) {
  .shop-layout { grid-template-columns: 240px 1fr; gap: var(--space-12); }
}

/* FILTER RAIL */
.filter-rail-title {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-ink-deep);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-wave-100);
}
.filter-form { display: flex; flex-direction: column; gap: var(--space-6); }
.filter-group { border: none; padding: 0; margin: 0; }
.filter-group legend {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-ink-warm);
  margin-bottom: var(--space-3);
}
.filter-check {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 6px 0;
  cursor: pointer;
  font-size: 14px;
  color: var(--color-ink-warm);
}
.filter-check input { width: 16px; height: 16px; accent-color: var(--color-wave-700); cursor: pointer; }
.filter-check:hover { color: var(--color-ink-deep); }
.filter-count {
  margin-left: auto;
  font-size: 12px;
  color: var(--color-ink-mute);
  font-variant-numeric: tabular-nums;
}
.reset-filters {
  width: 100%;
  background: var(--color-ink-deep);
  color: var(--color-bg-cream);
  padding: 10px;
  border-radius: var(--radius-md);
  font-size: 14px;
  font-weight: 500;
  margin-top: var(--space-2);
  cursor: pointer;
}
.reset-filters:hover { background: var(--color-wave-700); }
.btn-ghost { background: transparent; color: var(--color-ink-warm); }
.btn-ghost:hover { background: var(--color-wave-50); }
.btn-sm { padding: 8px 16px; font-size: 13px; }

/* SHOP TOOLBAR + SORT */
.shop-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: var(--space-4);
  margin-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-wave-100);
}
.result-count { font-size: 14px; color: var(--color-ink-mute); }
.result-count strong { color: var(--color-ink-deep); }
.sort-by {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 14px;
  color: var(--color-ink-mute);
}
.sort-by select {
  padding: 6px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-wave-100);
  background: var(--color-bg-cream);
  color: var(--color-ink-deep);
  font-size: 14px;
  font-family: var(--font-sans);
  cursor: pointer;
}
.sort-by select:focus {
  outline: 2px solid var(--color-wave-500);
  outline-offset: 2px;
}

/* PRODUCT GRID */
.products-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
@media (min-width: 640px) {
  .products-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .products-grid { grid-template-columns: repeat(3, 1fr); }
}

.product-card {
  display: flex;
  flex-direction: column;
  background: var(--color-bg-cream);
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--color-wave-100);
  transition: transform var(--motion-base), box-shadow var(--motion-base), border-color var(--motion-base);
  text-decoration: none;
  color: inherit;
}
.product-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-wave-300);
}
.product-image {
  aspect-ratio: 1;
  position: relative;
  overflow: hidden;
  background: var(--color-bg-tint);
}
.product-image img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--motion-slow);
}
.product-card:hover .product-image img {
  transform: scale(1.04);
}
.product-badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  background: var(--color-ink-deep);
  color: var(--color-bg-cream);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  z-index: 1;
}
.product-info { padding: var(--space-4); flex: 1; display: flex; flex-direction: column; }
.product-info h3 {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 500;
  color: var(--color-ink-deep);
  margin-bottom: 4px;
  line-height: 1.2;
}
.product-info .tagline {
  font-size: 13px;
  color: var(--color-ink-mute);
  line-height: 1.4;
  flex: 1;
  margin-bottom: var(--space-3);
}
.price-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--color-wave-100);
  padding-top: var(--space-3);
}
.price { font-size: 14px; font-weight: 600; color: var(--color-ink-deep); }
.quick-add {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--color-ink-deep);
  color: var(--color-bg-cream);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 400;
  line-height: 1;
  cursor: pointer;
  border: none;
  transition: background var(--motion-base);
}
.quick-add:hover { background: var(--color-wave-700); }

/* PAGINATION */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-12);
  padding: var(--space-6) 0;
}
.page-link, .page-next {
  min-width: 40px;
  height: 40px;
  padding: 0 var(--space-3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-ink-warm);
  border: 1px solid var(--color-wave-100);
  border-radius: var(--radius-md);
  text-decoration: none;
  background: var(--color-bg-cream);
  cursor: pointer;
  transition: all var(--motion-base);
}
.page-link:hover, .page-next:hover {
  border-color: var(--color-wave-500);
  color: var(--color-ink-deep);
}
.page-link.is-current {
  background: var(--color-ink-deep);
  color: var(--color-bg-cream);
  border-color: var(--color-ink-deep);
}
.page-next { padding: 0 var(--space-4); }

/* CROSS-SELL */
.cross-sell {
  padding: var(--space-20) 0;
  background: var(--color-bg-tint);
}
.cross-sell-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  align-items: center;
}
@media (min-width: 768px) {
  .cross-sell-card { grid-template-columns: 2fr 1fr; gap: var(--space-12); }
}
.cross-sell-text h2 { margin-bottom: var(--space-4); font-size: clamp(28px, 4vw, 40px); }
.cross-sell-text p { color: var(--color-ink-warm); margin-bottom: var(--space-6); max-width: 50ch; }
.cross-sell-photo img { width: 100%; height: auto; max-width: 280px; margin: 0 auto; display: block; }


/* ============================================================
   PDP — Product Detail Page
   ============================================================ */
.pdp {
  padding: var(--space-8) 0 var(--space-20);
}
.pdp-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  margin-bottom: var(--space-16);
}
@media (min-width: 1024px) {
  .pdp-grid { grid-template-columns: 1.1fr 1fr; gap: var(--space-12); }
}

/* Gallery */
.pdp-gallery { position: sticky; top: 100px; align-self: start; }
.pdp-gallery-main {
  aspect-ratio: 1;
  background: var(--color-bg-tint);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-4);
}
.pdp-gallery-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pdp-thumbs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-2);
  list-style: none;
  padding: 0;
  margin: 0;
}
.pdp-thumb {
  width: 100%;
  aspect-ratio: 1;
  border: 2px solid transparent;
  border-radius: var(--radius-md);
  background: var(--color-bg-tint);
  cursor: pointer;
  padding: 0;
  overflow: hidden;
  transition: border-color var(--motion-base);
}
.pdp-thumb.is-active { border-color: var(--color-ink-deep); }
.pdp-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Buybox */
.pdp-buybox .eyebrow { margin-bottom: var(--space-3); }
.pdp-buybox h1 { font-size: clamp(32px, 4vw, 48px); margin-bottom: var(--space-3); }
.pdp-rating {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.pdp-rating .stars { color: #F5DC78; font-size: 16px; letter-spacing: 0.1em; }
.pdp-rating .rating-text { color: var(--color-ink-mute); font-size: 13px; }
.pdp-lede {
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-ink-warm);
  margin-bottom: var(--space-6);
  max-width: 56ch;
}
.pdp-price {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-wave-100);
}
.pdp-price .price-current {
  font-family: var(--font-display);
  font-size: 40px;
  font-weight: 500;
  color: var(--color-ink-deep);
}
.pdp-price .price-meta { font-size: 14px; color: var(--color-ink-mute); }

.pdp-variants { border: none; padding: 0; margin: 0 0 var(--space-4); }
.pdp-variants legend {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-ink-warm);
  margin-bottom: var(--space-3);
}
.pdp-variant {
  display: flex;
  align-items: center;
  padding: var(--space-3) var(--space-4);
  border: 2px solid var(--color-wave-100);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  cursor: pointer;
  transition: border-color var(--motion-base);
}
.pdp-variant input { margin-right: var(--space-3); accent-color: var(--color-ink-deep); }
.pdp-variant span { font-size: 14px; color: var(--color-ink-warm); }
.pdp-variant em { color: var(--color-ink-mute); font-style: normal; margin-left: 4px; }
.pdp-variant:has(input:checked) { border-color: var(--color-ink-deep); background: var(--color-bg-tint); }
.pdp-variant:hover { border-color: var(--color-wave-300); }

.pdp-giftwrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) 0;
  margin-bottom: var(--space-6);
  font-size: 14px;
  color: var(--color-ink-warm);
  border-top: 1px solid var(--color-wave-100);
  border-bottom: 1px solid var(--color-wave-100);
  cursor: pointer;
}
.pdp-giftwrap input { accent-color: var(--color-ink-deep); }
.pdp-giftwrap em { color: var(--color-ink-mute); font-style: normal; }

.pdp-cart {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}
.btn-lg { padding: 18px 32px; font-size: 16px; flex: 1; }
.pdp-qty {
  display: flex;
  align-items: center;
  border: 1px solid var(--color-wave-300);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.pdp-qty button {
  width: 40px;
  height: 100%;
  background: transparent;
  border: none;
  font-size: 18px;
  color: var(--color-ink-warm);
  cursor: pointer;
}
.pdp-qty button:hover { background: var(--color-wave-50); }
.pdp-qty input {
  width: 50px;
  height: 100%;
  border: none;
  text-align: center;
  font-size: 15px;
  font-family: var(--font-sans);
  color: var(--color-ink-deep);
  background: transparent;
  -moz-appearance: textfield;
}
.pdp-qty input::-webkit-outer-spin-button,
.pdp-qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.pdp-trust {
  list-style: none;
  padding: var(--space-4) 0 0;
  margin: 0;
  font-size: 13px;
  color: var(--color-ink-mute);
  line-height: 1.6;
}
.pdp-trust li { padding: 6px 0; border-bottom: 1px dashed var(--color-wave-100); }
.pdp-trust li:last-child { border-bottom: none; }
.pdp-trust strong { color: var(--color-ink-deep); font-weight: 600; }

/* Tabs */
.pdp-tabs { margin-bottom: var(--space-20); }
.pdp-tabs-list {
  display: flex;
  gap: var(--space-6);
  border-bottom: 1px solid var(--color-wave-100);
  margin-bottom: var(--space-8);
  overflow-x: auto;
  scrollbar-width: none;
}
.pdp-tabs-list::-webkit-scrollbar { display: none; }
.pdp-tab {
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  padding: var(--space-3) 0;
  margin-bottom: -1px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--color-ink-mute);
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--motion-base);
}
.pdp-tab:hover { color: var(--color-ink-warm); }
.pdp-tab.is-active { color: var(--color-ink-deep); border-bottom-color: var(--color-ink-deep); }
.tab-count { color: var(--color-ink-mute); font-size: 12px; }
.pdp-tab.is-active .tab-count { color: var(--color-ink-deep); }

.pdp-panel { max-width: 72ch; }
.pdp-panel[hidden] { display: none; }
.pdp-panel h2 {
  font-family: var(--font-display);
  font-size: 28px;
  margin-bottom: var(--space-4);
}
.pdp-panel p { margin-bottom: var(--space-4); line-height: 1.7; color: var(--color-ink-warm); }
.pdp-avg { color: var(--color-ink-mute); font-family: var(--font-sans); font-size: 14px; font-weight: 400; }

/* Reviews */
.review-summary {
  background: var(--color-bg-tint);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin-bottom: var(--space-8);
}
.review-bars { display: grid; gap: 6px; max-width: 400px; }
.review-bar {
  display: grid;
  grid-template-columns: 30px 1fr 30px;
  gap: var(--space-3);
  align-items: center;
  font-size: 13px;
  color: var(--color-ink-warm);
}
.review-bar .bar { background: var(--color-wave-100); border-radius: 4px; height: 8px; overflow: hidden; }
.review-bar .bar-fill { background: var(--color-wave-500); height: 100%; }
.review-bar span:last-child { text-align: right; color: var(--color-ink-mute); font-variant-numeric: tabular-nums; }

.review-list { list-style: none; padding: 0; margin: 0; }
.review {
  padding: var(--space-6) 0;
  border-bottom: 1px solid var(--color-wave-100);
}
.review:last-child { border-bottom: none; }
.review-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
  font-size: 13px;
  color: var(--color-ink-mute);
}
.review-stars { color: #F5DC78; }
.review-author { font-weight: 600; color: var(--color-ink-deep); }
.review h3 {
  font-family: var(--font-display);
  font-size: 20px;
  margin-bottom: var(--space-2);
  color: var(--color-ink-deep);
}
.review p { color: var(--color-ink-warm); line-height: 1.6; }
.pdp-see-all { margin-top: var(--space-6); text-align: center; }
.pdp-see-all a { color: var(--color-ink-warm); font-weight: 500; border-bottom: 1px solid var(--color-wave-300); }
.pdp-see-all a:hover { color: var(--color-ink-deep); border-bottom-color: var(--color-ink-deep); }

/* Related products */
.related {
  padding-top: var(--space-12);
  border-top: 1px solid var(--color-wave-100);
}
.related h2 { margin-bottom: var(--space-8); }


/* ============================================================
   BUILD-A-BOX
   ============================================================ */
.bab-hero {
  padding: var(--space-12) 0 var(--space-8);
  text-align: center;
}
.bab-hero h1 { font-size: clamp(36px, 5vw, 56px); margin-bottom: var(--space-4); }
.bab-hero .lede { max-width: 60ch; margin: 0 auto; }
.bab-hero-ctas { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; margin-bottom: var(--space-6); }
.bab-hero-trust {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
  align-items: center;
  font-size: 14px;
  color: var(--color-ink-mute);
  flex-wrap: wrap;
}
.bab-hero-trust span:first-child { color: #F5DC78; font-size: 16px; letter-spacing: 0.05em; }

.bab-steps {
  display: flex;
  justify-content: center;
  gap: 0;
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-10);
  flex-wrap: wrap;
}
.bab-step {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 10px 20px;
  font-size: 13px;
  color: var(--color-ink-mute);
  font-weight: 500;
}
.bab-step + .bab-step::before {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--color-wave-100);
  margin-right: var(--space-3);
}
.bab-step .step-num {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-wave-100);
  color: var(--color-ink-warm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
}
.bab-step.is-current .step-num { background: var(--color-ink-deep); color: var(--color-bg-cream); }
.bab-step.is-current { color: var(--color-ink-deep); font-weight: 600; }

.bab-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  padding-bottom: var(--space-20);
}
@media (min-width: 1024px) {
  .bab-grid { grid-template-columns: 1fr 360px; gap: var(--space-12); }
}

.bab-section-title {
  font-family: var(--font-display);
  font-size: 28px;
  margin: var(--space-10) 0 var(--space-4);
}
.bab-section-title:first-of-type { margin-top: 0; }

.bab-sizes {
  border: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
}
@media (min-width: 640px) {
  .bab-sizes { grid-template-columns: repeat(4, 1fr); }
}
.bab-size {
  position: relative;
  border: 2px solid var(--color-wave-100);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-3);
  text-align: center;
  cursor: pointer;
  transition: border-color var(--motion-base);
  background: var(--color-bg-cream);
}
.bab-size input { position: absolute; opacity: 0; pointer-events: none; }
.bab-size:hover { border-color: var(--color-wave-300); }
.bab-size:has(input:checked),
.bab-size.is-selected { border-color: var(--color-ink-deep); background: var(--color-bg-tint); }
.bab-size-name { display: block; font-family: var(--font-display); font-size: 20px; color: var(--color-ink-deep); margin-bottom: 4px; }
.bab-size-pcs { display: block; font-size: 12px; color: var(--color-ink-mute); margin-bottom: var(--space-2); }
.bab-size-price { display: block; font-family: var(--font-display); font-size: 28px; color: var(--color-ink-deep); font-weight: 500; }
.bab-size-meta { display: block; font-size: 11px; color: var(--color-ink-mute); }
.bab-size-badge {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-ink-deep);
  color: var(--color-bg-cream);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

.bab-help { color: var(--color-ink-warm); margin-bottom: var(--space-4); }
.bab-help strong { color: var(--color-ink-deep); }
.bab-count { font-weight: 600; color: var(--color-ink-deep); }

.bab-filter {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
  align-items: center;
}
.bab-search input {
  flex: 1;
  min-width: 200px;
  padding: 10px 16px;
  border: 1px solid var(--color-wave-100);
  border-radius: var(--radius-md);
  font-size: 14px;
  font-family: var(--font-sans);
  background: var(--color-bg-cream);
}
.bab-search input:focus { outline: 2px solid var(--color-wave-500); outline-offset: 2px; }

.bab-chip-row { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.bab-chip {
  padding: 6px 14px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-wave-100);
  background: var(--color-bg-cream);
  font-size: 13px;
  color: var(--color-ink-warm);
  cursor: pointer;
  transition: all var(--motion-base);
}
.bab-chip:hover { border-color: var(--color-wave-300); }
.bab-chip.is-active { background: var(--color-ink-deep); color: var(--color-bg-cream); border-color: var(--color-ink-deep); }

.bab-grid-flavours {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  list-style: none;
  padding: 0;
  margin: 0;
}
@media (min-width: 640px) {
  .bab-grid-flavours { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1024px) {
  .bab-grid-flavours { grid-template-columns: repeat(3, 1fr); }
}
.bab-flavour {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-3);
  background: var(--color-bg-cream);
  border: 1px solid var(--color-wave-100);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--motion-base);
  text-align: center;
  width: 100%;
}
.bab-flavour:hover { border-color: var(--color-wave-500); transform: translateY(-1px); }
.bab-flavour.is-selected { border-color: var(--color-ink-deep); background: var(--color-bg-tint); }
.bab-flavour-img { width: 100%; aspect-ratio: 1; margin-bottom: var(--space-2); }
.bab-flavour-img img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius-sm); }
.bab-flavour-name { font-size: 13px; font-weight: 600; color: var(--color-ink-deep); margin-bottom: 2px; }
.bab-flavour-meta { font-size: 11px; color: var(--color-ink-mute); }
.bab-flavour-add {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--color-ink-deep);
  color: var(--color-bg-cream);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  opacity: 0;
  transition: opacity var(--motion-base);
}
.bab-flavour:hover .bab-flavour-add,
.bab-flavour.is-selected .bab-flavour-add { opacity: 1; }

/* Summary panel */
.bab-summary {
  position: sticky;
  top: 100px;
  align-self: start;
  background: var(--color-bg-tint);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.bab-summary h2 { font-size: 20px; margin-bottom: var(--space-4); }
.bab-summary-row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  font-size: 14px;
}
.bab-summary-label { color: var(--color-ink-mute); }
.bab-summary-value { color: var(--color-ink-deep); font-weight: 500; }
.bab-summary-progress { height: 4px; background: var(--color-wave-100); border-radius: 2px; margin: var(--space-3) 0; overflow: hidden; }
.bab-summary-progress-bar { height: 100%; background: var(--color-wave-500); transition: width var(--motion-base); }
.bab-summary-flavours {
  max-height: 200px;
  overflow-y: auto;
  background: var(--color-bg-cream);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  margin-bottom: var(--space-4);
  font-size: 13px;
}
.bab-empty { color: var(--color-ink-mute); font-style: italic; text-align: center; margin: 0; }
.bab-summary-flavours ul { list-style: none; padding: 0; margin: 0; }
.bab-summary-flavours li { padding: 4px 0; display: flex; justify-content: space-between; align-items: center; }
.bab-summary-totals {
  border-top: 1px solid var(--color-wave-100);
  padding-top: var(--space-3);
  margin-bottom: var(--space-4);
  font-size: 16px;
}
.bab-summary-price { font-size: 24px; font-family: var(--font-display); }
.bab-cta { width: 100%; }
.bab-cta:disabled { opacity: 0.5; cursor: not-allowed; }
.bab-addons { margin-top: var(--space-4); font-size: 13px; }
.bab-addons summary { cursor: pointer; color: var(--color-ink-warm); font-weight: 500; padding: var(--space-2) 0; }
.bab-addons summary em { color: var(--color-wave-700); font-style: normal; font-weight: 600; }
.bab-addon { display: block; padding: var(--space-2) 0; color: var(--color-ink-warm); }
.bab-addon input { margin-right: var(--space-2); accent-color: var(--color-ink-deep); }
.bab-addon textarea {
  width: 100%;
  margin-top: var(--space-2);
  padding: var(--space-2);
  border: 1px solid var(--color-wave-100);
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: 13px;
  resize: vertical;
}
.bab-addon small { display: block; color: var(--color-ink-mute); font-size: 11px; margin-top: 4px; }


/* ============================================================
   CORPORATE GIFTS
   ============================================================ */
.corp-hero {
  padding: var(--space-12) 0 var(--space-8);
  text-align: center;
}
.corp-hero h1 { font-size: clamp(36px, 5vw, 60px); margin-bottom: var(--space-4); }
.corp-hero .lede { max-width: 60ch; margin: 0 auto var(--space-8); }
.corp-hero-ctas { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; }

.trust-strip {
  padding: var(--space-8) 0;
  background: var(--color-bg-tint);
}
.trust-strip-label {
  text-align: center;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-ink-mute);
  margin-bottom: var(--space-4);
}
.trust-strip-logos {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-10);
  list-style: none;
  padding: 0;
  margin: 0;
}
.trust-strip-logos li {
  font-family: var(--font-display);
  font-size: 22px;
  font-style: italic;
  color: var(--color-ink-warm);
  opacity: 0.6;
}

.how-it-works { padding: var(--space-20) 0; }
.how-it-works h2 { text-align: center; margin-bottom: var(--space-10); }
.how-steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: step;
}
@media (min-width: 768px) {
  .how-steps { grid-template-columns: repeat(4, 1fr); }
}
.how-steps li {
  text-align: center;
  padding: 0 var(--space-3);
}
.how-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--color-wave-100);
  color: var(--color-ink-deep);
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 500;
  margin-bottom: var(--space-3);
}
.how-steps h3 { font-size: 18px; margin-bottom: var(--space-2); }
.how-steps p { color: var(--color-ink-mute); font-size: 14px; line-height: 1.5; }

.volume { padding: var(--space-20) 0; background: var(--color-bg-tint); }
.volume h2 { text-align: center; margin-bottom: var(--space-4); }
.volume-lede { text-align: center; color: var(--color-ink-mute); margin-bottom: var(--space-8); }
.volume-table { width: 100%; max-width: 900px; margin: 0 auto var(--space-6); border-collapse: collapse; background: var(--color-bg-cream); border-radius: var(--radius-lg); overflow: hidden; }
.volume-table th,
.volume-table td { padding: var(--space-3) var(--space-4); text-align: center; font-size: 14px; }
.volume-table th { background: var(--color-ink-deep); color: var(--color-bg-cream); font-weight: 500; font-size: 13px; letter-spacing: 0.05em; }
.volume-table td { border-bottom: 1px solid var(--color-wave-100); }
.volume-table tr:last-child td { border-bottom: none; }
.volume-table td:first-child { text-align: left; font-weight: 600; color: var(--color-ink-deep); }
.volume-custom { color: var(--color-wave-700); font-style: italic; }
.volume-foot { text-align: center; color: var(--color-ink-mute); font-size: 13px; max-width: 70ch; margin: 0 auto; line-height: 1.6; }

.featured-in { padding: var(--space-12) 0; text-align: center; }
.featured-in-label {
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-ink-mute);
  margin-bottom: var(--space-4);
}
.featured-in-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-2); align-items: center; }
.featured-in-list li { color: var(--color-ink-warm); font-size: 15px; }
.featured-in-list em { color: var(--color-ink-deep); font-weight: 600; font-style: italic; margin-right: var(--space-2); }

.inquiry { padding: var(--space-20) 0; background: var(--color-bg-tint); }
.inquiry-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-10); }
@media (min-width: 1024px) {
  .inquiry-grid { grid-template-columns: 1fr 1.4fr; gap: var(--space-16); }
}
.inquiry-text h2 { margin-bottom: var(--space-4); }
.inquiry-text p { color: var(--color-ink-warm); margin-bottom: var(--space-6); line-height: 1.6; }
.inquiry-checklist { list-style: none; padding: 0; margin: 0; }
.inquiry-checklist li { padding: var(--space-2) 0; color: var(--color-ink-warm); }
.inquiry-form {
  background: var(--color-bg-cream);
  padding: var(--space-8);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-wave-100);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.inquiry-form h2 { margin-bottom: var(--space-2); }
.inquiry-form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; font-weight: 500; color: var(--color-ink-deep); }
.inquiry-form label > input,
.inquiry-form label > select,
.inquiry-form label > textarea {
  padding: 10px 14px;
  border: 1px solid var(--color-wave-100);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--color-ink-deep);
  background: var(--color-bg-paper);
  font-weight: 400;
}
.inquiry-form input:focus,
.inquiry-form select:focus,
.inquiry-form textarea:focus { outline: 2px solid var(--color-wave-500); outline-offset: 2px; }
.inquiry-form textarea { resize: vertical; min-height: 100px; }
.form-row { display: grid; grid-template-columns: 1fr; gap: var(--space-4); }
@media (min-width: 640px) { .form-row { grid-template-columns: 1fr 1fr; } }
.form-checkbox-row { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: 6px; }
.form-check { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; cursor: pointer; font-weight: 400; }
.form-check input { accent-color: var(--color-ink-deep); }
.form-fineprint { font-size: 11px; color: var(--color-ink-mute); text-align: center; margin-top: var(--space-2); }
.form-fineprint a { color: var(--color-ink-warm); }

.corp-faq { padding: var(--space-20) 0; max-width: 720px; margin: 0 auto; padding-left: var(--space-6); padding-right: var(--space-6); }
.corp-faq h2 { text-align: center; margin-bottom: var(--space-8); }
.faq-item {
  border-bottom: 1px solid var(--color-wave-100);
  padding: var(--space-4) 0;
}
.faq-item summary {
  cursor: pointer;
  font-family: var(--font-display);
  font-size: 20px;
  color: var(--color-ink-deep);
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.faq-item summary::after { content: '+'; font-size: 28px; color: var(--color-wave-700); transition: transform var(--motion-base); }
.faq-item[open] summary::after { content: '−'; }
.faq-item p { color: var(--color-ink-warm); line-height: 1.6; margin: var(--space-3) 0 0; padding-right: var(--space-8); }

/* EVENTS — reuses corp-hero / how-it-works / inquiry / corp-faq */
.events-hero { padding: var(--space-12) 0 var(--space-8); text-align: center; }
.events-hero h1 { font-size: clamp(36px, 5vw, 56px); margin-bottom: var(--space-4); }
.events-hero .lede { max-width: 60ch; margin: 0 auto var(--space-8); }
.events-hero-ctas { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; margin-bottom: var(--space-6); }
.events-hero-trust {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
  align-items: center;
  font-size: 14px;
  color: var(--color-ink-mute);
  flex-wrap: wrap;
}
.events-hero-trust span:first-child { color: #F5DC78; font-size: 16px; letter-spacing: 0.05em; }
.events-hero-trust em { color: var(--color-ink-deep); font-style: italic; font-weight: 600; }

.events-gallery { padding: var(--space-20) 0; }
.events-gallery h2 { text-align: center; margin-bottom: var(--space-3); }
.events-gallery-lede { text-align: center; color: var(--color-ink-mute); margin-bottom: var(--space-10); max-width: 60ch; margin-left: auto; margin-right: auto; }
.events-gallery-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  list-style: none;
  padding: 0;
  margin: 0;
}
@media (min-width: 768px) { .events-gallery-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .events-gallery-grid { grid-template-columns: repeat(3, 1fr); } }
.events-gallery-grid li { background: var(--color-bg-tint); border-radius: var(--radius-lg); overflow: hidden; }
.events-gallery-grid img { width: 100%; aspect-ratio: 3/2; object-fit: cover; display: block; background: var(--color-bg-cream); }
.events-gallery-cap {
  padding: var(--space-3) var(--space-4);
  font-size: 13px;
  color: var(--color-ink-warm);
  font-style: italic;
  text-align: center;
}

/* CONTACT */
.contact-hero { padding: var(--space-12) 0 var(--space-8); text-align: center; }
.contact-hero h1 { font-size: clamp(36px, 5vw, 56px); margin-bottom: var(--space-4); }
.contact-hero .lede { max-width: 56ch; margin: 0 auto; }

.contact { padding: var(--space-12) 0 var(--space-20); }
.contact-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-10); }
@media (min-width: 1024px) { .contact-grid { grid-template-columns: 1fr 1.4fr; gap: var(--space-16); } }
.contact-info h2 { font-size: 13px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-ink-deep); margin: var(--space-6) 0 var(--space-3); }
.contact-info h2:first-of-type { margin-top: 0; }
.contact-address { font-style: normal; color: var(--color-ink-warm); line-height: 1.6; }
.contact-link { color: var(--color-ink-deep); font-weight: 500; border-bottom: 1px solid var(--color-wave-300); }
.contact-link:hover { border-bottom-color: var(--color-ink-deep); }
.contact-meta { color: var(--color-ink-mute); font-size: 13px; margin-top: 4px; }
.contact-hours { list-style: none; padding: 0; margin: 0; }
.contact-hours li { display: flex; justify-content: space-between; padding: 6px 0; border-bottom: 1px dashed var(--color-wave-100); font-size: 14px; color: var(--color-ink-warm); }
.contact-hours li:last-child { border-bottom: none; }
.contact-hours span:last-child { color: var(--color-ink-deep); font-weight: 500; }

.contact-form {
  background: var(--color-bg-cream);
  padding: var(--space-8);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-wave-100);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.contact-form h2 { margin-bottom: var(--space-2); }
.contact-form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; font-weight: 500; color: var(--color-ink-deep); }
.contact-form input,
.contact-form select,
.contact-form textarea {
  padding: 10px 14px;
  border: 1px solid var(--color-wave-100);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--color-ink-deep);
  background: var(--color-bg-paper);
  font-weight: 400;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus { outline: 2px solid var(--color-wave-500); outline-offset: 2px; }
.contact-form textarea { resize: vertical; min-height: 140px; }

.contact-map { padding: var(--space-12) 0 var(--space-20); }
.contact-map h2 { text-align: center; margin-bottom: var(--space-3); }
.contact-map-lede { text-align: center; color: var(--color-ink-mute); margin-bottom: var(--space-8); max-width: 60ch; margin-left: auto; margin-right: auto; }
.contact-map-embed { max-width: 720px; margin: 0 auto; border-radius: var(--radius-lg); overflow: hidden; }
.map-placeholder {
  background: var(--color-bg-tint);
  padding: var(--space-12) var(--space-6);
  text-align: center;
  border: 1px solid var(--color-wave-100);
}
.map-pin { color: var(--color-ink-deep); margin-bottom: var(--space-3); }
.map-address { font-weight: 600; color: var(--color-ink-deep); margin-bottom: var(--space-2); }
.map-meta a { color: var(--color-wave-700); font-weight: 500; }
.map-meta a:hover { color: var(--color-ink-deep); }

/* CART */
.cart-hero { padding: var(--space-8) 0 var(--space-4); }
.cart-hero h1 { font-size: clamp(28px, 3.5vw, 40px); }

.cart { padding-bottom: var(--space-20); }
.cart-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-10); }
@media (min-width: 1024px) { .cart-grid { grid-template-columns: 1fr 360px; gap: var(--space-12); } }

.cart-items { list-style: none; padding: 0; margin: 0 0 var(--space-6); }
.cart-line {
  display: grid;
  grid-template-columns: 96px 1fr auto auto;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-5) 0;
  border-bottom: 1px solid var(--color-wave-100);
}
.cart-line-img { width: 96px; height: 96px; background: var(--color-bg-tint); border-radius: var(--radius-md); overflow: hidden; }
.cart-line-img img { width: 100%; height: 100%; object-fit: cover; }
.cart-line-info h2 { font-family: var(--font-display); font-size: 20px; margin-bottom: 4px; }
.cart-line-info a { color: var(--color-ink-deep); }
.cart-line-meta { font-size: 13px; color: var(--color-ink-mute); margin-bottom: 4px; }
.cart-line-extra { font-size: 13px; color: var(--color-wave-700); margin-bottom: var(--space-2); }
.cart-line-remove { background: none; border: none; color: var(--color-ink-mute); font-size: 12px; cursor: pointer; padding: 0; text-decoration: underline; }
.cart-line-remove:hover { color: var(--color-error); }
.cart-line-price { font-size: 18px; font-weight: 600; color: var(--color-ink-deep); white-space: nowrap; }
@media (max-width: 640px) {
  .cart-line { grid-template-columns: 80px 1fr; grid-template-rows: auto auto; }
  .cart-line-qty, .cart-line-price { grid-column: 2; justify-self: start; }
  .cart-line-price { grid-column: 2 / -1; justify-self: end; }
}

.cart-actions { display: flex; justify-content: space-between; padding: var(--space-4) 0; }

.cart-upsell { background: var(--color-bg-tint); border-radius: var(--radius-lg); padding: var(--space-6); margin-top: var(--space-6); }
.cart-upsell-qualified { background: var(--color-wave-50); border: 1px solid var(--color-wave-300); }
.cart-upsell p { font-size: 14px; color: var(--color-ink-warm); margin-bottom: var(--space-2); }
.cart-upsell-qualified p:first-child { color: var(--color-ink-deep); }
.cart-upsell strong { color: var(--color-ink-deep); }
.cart-upsell-bar { height: 8px; background: var(--color-wave-100); border-radius: 4px; overflow: hidden; margin: var(--space-3) 0; }
.cart-upsell-bar-fill { height: 100%; background: var(--color-wave-500); transition: width var(--motion-base); }
.cart-upsell-hint { color: var(--color-ink-mute); font-size: 13px; margin-top: var(--space-2); }

.cart-summary {
  position: sticky;
  top: 100px;
  align-self: start;
  background: var(--color-bg-tint);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}
.cart-summary h2 { font-size: 20px; margin-bottom: var(--space-4); }
.cart-summary-row { display: flex; justify-content: space-between; padding: 6px 0; font-size: 14px; }
.cart-summary-row span:first-child { color: var(--color-ink-mute); }
.cart-summary-row span:last-child { color: var(--color-ink-deep); font-weight: 500; }
.cart-summary-meta { color: var(--color-ink-mute) !important; font-weight: 400 !important; font-style: italic; font-size: 13px !important; }
.cart-promo { display: flex; gap: var(--space-2); margin: var(--space-3) 0; padding: var(--space-3) 0; border-top: 1px dashed var(--color-wave-100); border-bottom: 1px dashed var(--color-wave-100); }
.cart-promo label { flex: 1; }
.cart-promo input { width: 100%; padding: 8px 10px; border: 1px solid var(--color-wave-100); border-radius: var(--radius-sm); font-size: 13px; font-family: var(--font-sans); }
.cart-summary-total { border-top: 1px solid var(--color-wave-100); padding-top: var(--space-3); margin-top: var(--space-2); font-size: 16px; }
.cart-summary-total span:last-child { font-family: var(--font-display); font-size: 24px; }
.cart-cta { width: 100%; margin-top: var(--space-4); }
.cart-trust { font-size: 13px; color: var(--color-ink-warm); margin-top: var(--space-4); text-align: center; }
.cart-trust-meta { font-size: 11px; color: var(--color-ink-mute); margin-top: 4px; text-align: center; line-height: 1.5; }

.cart-empty { text-align: center; padding: var(--space-20) 0; }
.cart-empty h2 { margin-bottom: var(--space-3); }
.cart-empty p { color: var(--color-ink-mute); margin-bottom: var(--space-6); }


/* ============================================================
   SITEMAP
   ============================================================ */
/* SITEMAP */
.sitemap-hero { padding: var(--space-12) 0 var(--space-8); text-align: center; }
.sitemap-hero h1 { font-size: clamp(32px, 4.5vw, 56px); margin-bottom: var(--space-4); }
.sitemap-hero .lede { max-width: 56ch; margin: 0 auto; }
.sitemap-group-wide { grid-column: 1 / -1; }
.sitemap-group { padding: var(--space-4) 0; }
.sitemap { padding-bottom: var(--space-20); }
.sitemap-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-10); }
@media (min-width: 768px) { .sitemap-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .sitemap-grid { grid-template-columns: repeat(2, 1fr); } }
.sitemap-group h2 {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--color-ink-deep);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-wave-100);
}
.sitemap-group ul { list-style: none; padding: 0; margin: 0 0 var(--space-4); }
.sitemap-group li { padding: var(--space-2) 0; border-bottom: 1px dashed var(--color-wave-100); }
.sitemap-group li:last-child { border-bottom: none; }
.sitemap-group a { color: var(--color-ink-warm); font-weight: 500; }
.sitemap-group a:hover { color: var(--color-ink-deep); border-bottom: 1px solid var(--color-ink-deep); }
.sitemap-meta { display: block; font-size: 12px; color: var(--color-ink-mute); font-weight: 400; margin-top: 2px; }
.sitemap-stub { font-size: 12px; color: var(--color-ink-mute); margin: var(--space-3) 0 4px; }
.sitemap-stubs li { font-size: 13px; color: var(--color-ink-mute); padding: 4px 0; border-bottom: none; }
.stub-label { font-style: italic; }


/* ============================================================
   LEGAL (privacy, terms, shipping-returns, refund-policy) —
   long-form prose with consistent typography
   ============================================================ */
.legal {
  padding: var(--space-12) 0 var(--space-20);
  max-width: 760px;
  margin: 0 auto;
  padding-left: var(--space-6);
  padding-right: var(--space-6);
}
.legal h1 {
  font-size: clamp(36px, 5vw, 56px);
  margin-bottom: var(--space-4);
}
.legal h2 {
  font-family: var(--font-display);
  font-size: 26px;
  margin: var(--space-10) 0 var(--space-3);
  color: var(--color-ink-deep);
}
.legal p, .legal ul, .legal ol { color: var(--color-ink-warm); line-height: 1.7; margin-bottom: var(--space-4); }
.legal ul, .legal ol { padding-left: var(--space-6); }
.legal li { margin-bottom: var(--space-2); }
.legal strong { color: var(--color-ink-deep); font-weight: 600; }
.legal em { font-style: italic; }
.legal a { color: var(--color-ink-deep); border-bottom: 1px solid var(--color-wave-300); }
.legal a:hover { border-bottom-color: var(--color-ink-deep); }

.shipping-table { width: 100%; border-collapse: collapse; margin: var(--space-4) 0 var(--space-6); font-size: 14px; }
.shipping-table th,
.shipping-table td { padding: var(--space-3); text-align: left; border-bottom: 1px solid var(--color-wave-100); vertical-align: top; }
.shipping-table th { background: var(--color-bg-tint); font-weight: 600; color: var(--color-ink-deep); font-size: 13px; }
.shipping-table td:first-child { font-weight: 500; color: var(--color-ink-deep); }

/* 404 EMPTY STATE */
.empty-state { padding: var(--space-20) 0; text-align: center; }
.empty-state h1 { font-size: clamp(32px, 4.5vw, 56px); margin-bottom: var(--space-3); }
.empty-state .lede { max-width: 50ch; margin: 0 auto var(--space-10); }
.empty-state-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  max-width: 800px;
  margin: 0 auto var(--space-10);
}
@media (min-width: 768px) { .empty-state-grid { grid-template-columns: repeat(2, 1fr); } }
.empty-state-card {
  display: block;
  text-align: left;
  padding: var(--space-6);
  background: var(--color-bg-tint);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-wave-100);
  text-decoration: none;
  color: inherit;
  transition: transform var(--motion-base), border-color var(--motion-base);
}
.empty-state-card:hover { transform: translateY(-2px); border-color: var(--color-wave-500); }
.empty-state-card h2 { font-size: 18px; margin-bottom: var(--space-2); }
.empty-state-card p { font-size: 14px; color: var(--color-ink-mute); }
.empty-state-meta { font-size: 14px; color: var(--color-ink-mute); }
.empty-state-meta a { color: var(--color-ink-warm); border-bottom: 1px solid var(--color-wave-300); }

/* FAQ */
.faq-hero { padding: var(--space-12) 0 var(--space-8); text-align: center; }
.faq-hero h1 { font-size: clamp(36px, 5vw, 56px); margin-bottom: var(--space-4); }
.faq-hero .lede { max-width: 50ch; margin: 0 auto; }
.faq-hero .lede a { color: var(--color-ink-deep); border-bottom: 1px solid var(--color-wave-300); }

.faq-search { padding: 0 0 var(--space-6); }
.faq-search-field {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  max-width: 500px;
  margin: 0 auto;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-wave-100);
  border-radius: var(--radius-full);
  background: var(--color-bg-cream);
}
.faq-search-field:focus-within { border-color: var(--color-wave-500); }
.faq-search-icon { width: 18px; height: 18px; color: var(--color-ink-mute); flex-shrink: 0; }
.faq-search-field input {
  flex: 1;
  border: none;
  background: none;
  font-size: 15px;
  font-family: var(--font-sans);
  color: var(--color-ink-deep);
}
.faq-search-field input:focus { outline: none; }

.faq-list { padding: var(--space-8) 0 var(--space-20); max-width: 760px; margin: 0 auto; padding-left: var(--space-6); padding-right: var(--space-6); }
.faq-cat {
  font-family: var(--font-display);
  font-size: 24px;
  color: var(--color-ink-deep);
  margin: var(--space-12) 0 var(--space-4);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-wave-100);
}
.faq-cat:first-of-type { margin-top: 0; }

.faq-cta {
  padding: var(--space-16) 0;
  background: var(--color-bg-tint);
  text-align: center;
}
.faq-cta h2 { margin-bottom: var(--space-3); }
.faq-cta p { color: var(--color-ink-warm); }
.faq-cta a { color: var(--color-ink-deep); border-bottom: 1px solid var(--color-wave-300); }

/* FLAVOURS GUIDE */
.flavours-hero { padding: var(--space-12) 0 var(--space-8); text-align: center; }
.flavours-hero h1 { font-size: clamp(36px, 5vw, 60px); margin-bottom: var(--space-4); }
.flavours-hero .lede { max-width: 60ch; margin: 0 auto; }
.flavours-hero .lede a { color: var(--color-ink-deep); border-bottom: 1px solid var(--color-wave-300); }

.flavours-filter { padding: 0 0 var(--space-6); }
.chip-row { display: flex; gap: var(--space-2); flex-wrap: wrap; justify-content: center; }
.chip {
  padding: 8px 16px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-wave-100);
  background: var(--color-bg-cream);
  font-size: 13px;
  color: var(--color-ink-warm);
  cursor: pointer;
  transition: all var(--motion-base);
}
.chip:hover { border-color: var(--color-wave-300); }
.chip.is-active { background: var(--color-ink-deep); color: var(--color-bg-cream); border-color: var(--color-ink-deep); }

.flavours { padding: var(--space-8) 0 var(--space-20); }
.flavours-cat {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  font-family: var(--font-display);
  font-size: 28px;
  color: var(--color-ink-deep);
  margin: var(--space-12) 0 var(--space-6);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-wave-100);
}
.flavours-cat:first-of-type { margin-top: 0; }
.flavours-count { font-size: 16px; color: var(--color-ink-mute); font-family: var(--font-sans); font-weight: 400; }

.flavours-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  list-style: none;
  padding: 0;
  margin: 0;
}
@media (min-width: 640px) { .flavours-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .flavours-grid { grid-template-columns: repeat(4, 1fr); } }

.flavour-card {
  position: relative;
  display: block;
  background: var(--color-bg-cream);
  border: 1px solid var(--color-wave-100);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  text-align: center;
  text-decoration: none;
  color: inherit;
  transition: all var(--motion-base);
}
.flavour-card:hover { border-color: var(--color-wave-500); transform: translateY(-1px); }
.flavour-card img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: var(--radius-sm); margin-bottom: var(--space-2); background: var(--color-bg-tint); }
.flavour-card h3 { font-family: var(--font-display); font-size: 16px; margin-bottom: 4px; color: var(--color-ink-deep); }
.flavour-card p { font-size: 12px; color: var(--color-ink-mute); line-height: 1.4; }
.flavour-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  background: var(--color-ink-deep);
  color: var(--color-bg-cream);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
}

.flavours-stockists { padding: var(--space-12) 0; background: var(--color-bg-tint); }
.flavours-stockists h2 { text-align: center; margin-bottom: var(--space-3); }
.flavours-stockists p { text-align: center; color: var(--color-ink-warm); margin-bottom: var(--space-6); max-width: 50ch; margin-left: auto; margin-right: auto; }
.stockists {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-4);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 640px) { .stockists { grid-template-columns: repeat(2, 1fr); } }
.stockists li { padding: var(--space-2) 0; color: var(--color-ink-warm); border-bottom: 1px dashed var(--color-wave-100); }
.stockists strong { color: var(--color-ink-deep); }
.flavours-meta { text-align: center; font-size: 13px; color: var(--color-ink-mute); }
.flavours-meta a { color: var(--color-ink-warm); }

/* ABOUT */
.about-hero { padding: var(--space-12) 0 var(--space-8); }
.about-hero-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-10); align-items: center; }
@media (min-width: 1024px) { .about-hero-grid { grid-template-columns: 1fr 1.4fr; gap: var(--space-12); } }
.about-hero-photo img { width: 100%; height: auto; max-width: 480px; border-radius: var(--radius-lg); background: var(--color-bg-tint); }
.about-hero-text h1 { font-size: clamp(36px, 5vw, 56px); margin-bottom: var(--space-6); }
.about-hero-text .lede { font-size: 18px; line-height: 1.6; color: var(--color-ink-warm); margin-bottom: var(--space-4); }
.about-hero-text a { color: var(--color-ink-deep); border-bottom: 1px solid var(--color-wave-300); }

.about-story { padding: var(--space-16) 0; max-width: 960px; margin: 0 auto; padding-left: var(--space-6); padding-right: var(--space-6); }
.about-story h2 { font-size: 32px; margin-bottom: var(--space-6); }
.story-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-8); }
@media (min-width: 768px) { .story-grid { grid-template-columns: 1fr 1fr; gap: var(--space-12); } }
.story-text p { color: var(--color-ink-warm); margin-bottom: var(--space-4); line-height: 1.7; font-size: 16px; }
.story-text a { color: var(--color-ink-deep); border-bottom: 1px solid var(--color-wave-300); }
.story-pullquote {
  font-family: var(--font-display);
  font-size: 24px;
  line-height: 1.4;
  color: var(--color-ink-deep);
  font-style: italic;
  border-left: 3px solid var(--color-wave-500);
  padding-left: var(--space-6);
  margin: var(--space-6) 0;
}

.about-process { padding: var(--space-20) 0; background: var(--color-bg-tint); }
.about-process h2 { text-align: center; margin-bottom: var(--space-3); font-size: 32px; }
.process-lede { text-align: center; color: var(--color-ink-mute); margin-bottom: var(--space-12); }
.process-grid { display: flex; flex-direction: column; gap: var(--space-12); max-width: 960px; margin: 0 auto; padding: 0 var(--space-6); }
.process-step { display: grid; grid-template-columns: 1fr; gap: var(--space-6); align-items: center; }
@media (min-width: 768px) { .process-step { grid-template-columns: 1fr 1fr; gap: var(--space-10); } }
.process-step-reverse > img { order: 1; }
@media (min-width: 768px) { .process-step-reverse > img { order: 2; } }
.process-step img { width: 100%; height: auto; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--radius-lg); background: var(--color-bg-cream); }
.process-num {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-wave-700);
  margin-bottom: var(--space-2);
}
.process-step h3 { font-size: 24px; margin-bottom: var(--space-3); }
.process-step p { color: var(--color-ink-warm); line-height: 1.6; }

.about-cacao { padding: var(--space-20) 0; max-width: 1200px; margin: 0 auto; padding-left: var(--space-6); padding-right: var(--space-6); }
.about-cacao h2 { text-align: center; margin-bottom: var(--space-4); font-size: 32px; }
.about-cacao > p { text-align: center; color: var(--color-ink-warm); margin: 0 auto var(--space-12); max-width: 50ch; }
.cacao-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-4); }
@media (min-width: 768px) { .cacao-grid { grid-template-columns: repeat(2, 1fr); } }
.cacao-card { background: var(--color-bg-tint); padding: var(--space-6); border-radius: var(--radius-lg); border: 1px solid var(--color-wave-100); }
.cacao-card h3 { font-size: 20px; margin-bottom: 4px; }
.cacao-region { font-size: 12px; color: var(--color-wave-700); font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: var(--space-3); }
.cacao-card p { color: var(--color-ink-warm); line-height: 1.6; font-size: 14px; }

.about-team { padding: var(--space-20) 0; background: var(--color-bg-tint); }
.about-team h2 { text-align: center; margin-bottom: var(--space-3); font-size: 32px; }
.about-team > p { text-align: center; color: var(--color-ink-mute); margin-bottom: var(--space-12); }
.team-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-4); max-width: 1000px; margin: 0 auto; padding: 0 var(--space-6); }
@media (min-width: 640px) { .team-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) {
  .team-grid { grid-template-columns: repeat(3, 1fr); }
  /* Center the last 2 cards when 5 members total: 3+2 layout */
  .team-grid > li:nth-child(4) { grid-column: 1 / 2; margin-left: 16.6667%; }
  .team-grid > li:nth-child(5) { grid-column: 2 / 3; margin-right: 16.6667%; }
}
.team-member { background: var(--color-bg-cream); padding: var(--space-6); border-radius: var(--radius-lg); border: 1px solid var(--color-wave-100); }
.team-avatar { width: 56px; height: 56px; border-radius: 50%; background: var(--color-wave-100); color: var(--color-ink-deep); display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 22px; font-weight: 500; margin-bottom: var(--space-3); }
.team-member h3 { font-size: 20px; margin-bottom: 2px; }
.team-member p { color: var(--color-ink-mute); font-size: 14px; margin-bottom: var(--space-2); }
.team-member p:last-child { color: var(--color-ink-warm); font-size: 13px; line-height: 1.5; margin-bottom: 0; }

.about-values { padding: var(--space-20) 0; max-width: 960px; margin: 0 auto; padding-left: var(--space-6); padding-right: var(--space-6); }
.about-values h2 { text-align: center; margin-bottom: var(--space-8); font-size: 32px; }
.values-grid { display: grid; gap: var(--space-6); }
.value-item h3 { font-size: 20px; margin-bottom: var(--space-3); color: var(--color-ink-deep); }
.value-item p { color: var(--color-ink-warm); line-height: 1.6; }
.about-press-h { font-family: var(--font-sans); font-size: 13px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-ink-mute); text-align: center; margin: var(--space-12) 0 var(--space-4); }
.about-press { list-style: none; padding: 0; margin: 0; text-align: center; }
.about-press li { padding: var(--space-2) 0; color: var(--color-ink-warm); }
.about-press em { color: var(--color-ink-deep); font-weight: 600; font-style: italic; margin-right: var(--space-2); }

.about-cta { padding: var(--space-20) 0; background: var(--color-bg-tint); text-align: center; }
.about-cta h2 { margin-bottom: var(--space-3); font-size: 32px; }
.about-cta p { color: var(--color-ink-warm); max-width: 56ch; margin: 0 auto var(--space-3); line-height: 1.6; }
.about-cta-address { font-weight: 600; color: var(--color-ink-deep); margin-bottom: var(--space-6); }
.about-cta-buttons { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; }

/* JOURNAL */
.journal-hero { padding: var(--space-12) 0 var(--space-8); text-align: center; }
.journal-hero h1 { font-size: clamp(36px, 5vw, 60px); margin-bottom: var(--space-4); }
.journal-hero .lede { max-width: 50ch; margin: 0 auto; }

.journal { padding: var(--space-8) 0 var(--space-20); max-width: 1200px; margin: 0 auto; padding-left: var(--space-6); padding-right: var(--space-6); }
.journal-featured { margin-bottom: var(--space-16); }
.journal-card-large { display: grid; grid-template-columns: 1fr; gap: var(--space-6); align-items: center; text-decoration: none; color: inherit; }
@media (min-width: 768px) { .journal-card-large { grid-template-columns: 1.4fr 1fr; gap: var(--space-10); } }
.journal-card-large .journal-img img { width: 100%; aspect-ratio: 16/10; object-fit: cover; border-radius: var(--radius-lg); background: var(--color-bg-tint); }
.journal-card-large h2 { font-size: clamp(28px, 3.5vw, 42px); margin-bottom: var(--space-3); }
.journal-card-large p { color: var(--color-ink-warm); font-size: 16px; line-height: 1.6; margin-bottom: var(--space-4); }
.journal-read { color: var(--color-wave-700); font-weight: 600; }

.journal-section-h { font-family: var(--font-display); font-size: 24px; margin-bottom: var(--space-6); padding-bottom: var(--space-2); border-bottom: 1px solid var(--color-wave-100); }
.journal-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-6); list-style: none; padding: 0; margin: 0 0 var(--space-8); }
@media (min-width: 640px) { .journal-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .journal-grid { grid-template-columns: repeat(3, 1fr); } }
.journal-card { display: flex; flex-direction: column; text-decoration: none; color: inherit; background: var(--color-bg-cream); border: 1px solid var(--color-wave-100); border-radius: var(--radius-lg); overflow: hidden; transition: all var(--motion-base); }
.journal-card:hover { transform: translateY(-2px); border-color: var(--color-wave-300); box-shadow: var(--shadow-md); }
.journal-card .journal-img img { width: 100%; aspect-ratio: 4/3; object-fit: cover; background: var(--color-bg-tint); }
.journal-card .journal-meta { display: flex; gap: var(--space-2); padding: var(--space-3) var(--space-4) 0; font-size: 11px; color: var(--color-ink-mute); align-items: center; }
.journal-cat { color: var(--color-wave-700); font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; }
.journal-date::before { content: '· '; margin: 0 4px; }
.journal-card h3 { font-size: 20px; margin: var(--space-2) var(--space-4) var(--space-2); color: var(--color-ink-deep); line-height: 1.3; }
.journal-card p { padding: 0 var(--space-4) var(--space-4); color: var(--color-ink-warm); font-size: 14px; line-height: 1.5; }
.journal-archive-link { text-align: center; }
.journal-archive-link a { color: var(--color-ink-warm); font-weight: 500; border-bottom: 1px solid var(--color-wave-300); }
.journal-archive-link a:hover { color: var(--color-ink-deep); }

.journal-cta { padding: var(--space-16) 0; background: var(--color-bg-tint); text-align: center; }
.journal-cta h2 { margin-bottom: var(--space-3); font-size: 28px; }
.journal-cta p { color: var(--color-ink-warm); margin-bottom: var(--space-4); }
.journal-form { display: flex; gap: var(--space-2); max-width: 420px; margin: 0 auto; }
.journal-form input { flex: 1; padding: 12px 16px; border: 1px solid var(--color-wave-100); border-radius: var(--radius-md); font-size: 14px; font-family: var(--font-sans); }
.journal-form input:focus { outline: 2px solid var(--color-wave-500); outline-offset: 2px; }

/* ACCOUNT */
.account-hero { padding: var(--space-12) 0 var(--space-8); }
.account-hero h1 { font-size: clamp(32px, 4.5vw, 48px); margin-bottom: var(--space-3); }
.account-hero .lede { color: var(--color-ink-mute); }

.account { padding: var(--space-8) 0 var(--space-20); }
.account-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-8); }
@media (min-width: 1024px) { .account-grid { grid-template-columns: 220px 1fr; gap: var(--space-12); } }
.account-sidebar { position: sticky; top: 100px; align-self: start; }
.account-sidebar ul { list-style: none; padding: 0; margin: 0; }
.account-sidebar li { border-bottom: 1px solid var(--color-wave-100); }
.account-sidebar a { display: block; padding: var(--space-3) 0; color: var(--color-ink-warm); text-decoration: none; }
.account-sidebar a:hover { color: var(--color-ink-deep); }
.account-sidebar a.is-active { color: var(--color-ink-deep); font-weight: 600; }

.account-main section { margin-bottom: var(--space-16); }
.account-main section:last-child { margin-bottom: 0; }
.account-section-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: var(--space-6); padding-bottom: var(--space-3); border-bottom: 1px solid var(--color-wave-100); }
.account-section-head h2 { font-size: 24px; }
.muted { color: var(--color-ink-mute); font-size: 14px; font-weight: 400; font-family: var(--font-sans); }

.account-empty { color: var(--color-ink-mute); padding: var(--space-8) 0; }
.account-empty a { color: var(--color-ink-deep); border-bottom: 1px solid var(--color-wave-300); }

.order-list { list-style: none; padding: 0; margin: 0; }
.order-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  padding: var(--space-5) 0;
  border-bottom: 1px solid var(--color-wave-100);
}
@media (min-width: 768px) { .order-row { grid-template-columns: 2fr 1fr 1fr; gap: var(--space-4); align-items: center; } }
.order-meta { display: flex; flex-direction: column; gap: 4px; }
.order-id { font-weight: 600; color: var(--color-ink-deep); font-family: var(--font-sans); }
.order-date { font-size: 13px; color: var(--color-ink-mute); }
.order-status { display: flex; gap: var(--space-3); align-items: center; }
.order-badge { display: inline-block; padding: 4px 10px; border-radius: var(--radius-full); font-size: 11px; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; background: var(--color-wave-50); color: var(--color-wave-700); }
.order-badge-delivered { background: var(--color-wave-50); color: var(--color-wave-700); }
.order-total { font-weight: 600; color: var(--color-ink-deep); font-size: 16px; }
.order-items { display: flex; gap: 6px; align-items: center; }
.order-items img { width: 40px; height: 40px; object-fit: cover; border-radius: var(--radius-sm); background: var(--color-bg-tint); }
.order-items-more { font-size: 12px; color: var(--color-ink-mute); font-weight: 500; }
.order-actions { display: flex; gap: var(--space-2); }

.address-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr; gap: var(--space-3); }
@media (min-width: 768px) { .address-list { grid-template-columns: repeat(2, 1fr); } }
.address-card { background: var(--color-bg-tint); padding: var(--space-5); border-radius: var(--radius-md); border: 1px solid var(--color-wave-100); }
.address-label { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-ink-mute); margin-bottom: var(--space-2); }
.address-card p { line-height: 1.5; color: var(--color-ink-warm); margin-bottom: var(--space-2); }
.address-actions { display: flex; gap: var(--space-3); margin-top: var(--space-3); }
.address-actions button { background: none; border: none; color: var(--color-ink-mute); font-size: 13px; cursor: pointer; padding: 0; text-decoration: underline; }
.address-actions button:hover { color: var(--color-ink-deep); }

.account-form { display: flex; flex-direction: column; gap: var(--space-4); max-width: 480px; }
.account-form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; font-weight: 500; color: var(--color-ink-deep); }
.account-form input {
  padding: 10px 14px;
  border: 1px solid var(--color-wave-100);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--color-ink-deep);
  background: var(--color-bg-paper);
  font-weight: 400;
}
.account-form input:focus { outline: 2px solid var(--color-wave-500); outline-offset: 2px; }

/* Mobile nav: when .nav-links has .is-open, show as a slide-down panel */
@media (max-width: 781px) {
  .nav-links {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    background: rgba(255, 255, 255, 0.98);
    -webkit-backdrop-filter: saturate(180%) blur(8px);
    backdrop-filter: saturate(180%) blur(8px);
    border-top: 1px solid var(--color-wave-100);
    border-bottom: 1px solid var(--color-wave-100);
    padding: 1rem;
    gap: 0.5rem;
    display: none;
    max-height: calc(100vh - 64px);
    overflow-y: auto;
  }
  .nav-links.is-open {
    display: flex !important;
  }
  .nav-links.is-open > * {
    padding: 0.5rem 0;
  }
  body.nav-open {
    overflow: hidden;
  }
  .nav {
    position: relative;
  }
}
