/* ============================================================
   HØLY / Ritual Care™ — holy.css
   Token kit + shared chrome. One source of truth.
   Port target: Shopify theme (assets/holy.css).
   ============================================================ */

/* ---------- 1 · Tokens ---------- */
:root {
  /* Palette */
  --off-white: #F4EFE6;
  --ecru: #EDE4D3;
  --pale-stone: #D7CFC1;
  --tone-system: #D7CFC1;
  --tone-ars: #E1DCD2;
  --tone-pcc: #DCD5C9;
  --tone-vsg: #E4E0D6;
  --ink: #1F1B16;
  --ink-soft: rgba(31,27,22,0.7);
  --ink-quiet: rgba(31,27,22,0.45);
  --ink-faint: rgba(31,27,22,0.16);
  --ochre: #B18B6B;

  /* Type */
  --font-display: 'EB Garamond', Georgia, serif;
  --font-body: 'Inter', system-ui, sans-serif;
  --font-sys: 'Figtree', 'Inter', system-ui, sans-serif;
  --font-cat: 'Merriweather', Georgia, serif;

  /* Spacing scale — 8px base. Use these, not raw px. */
  --space-1: 8px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 32px;
  --space-5: 40px;
  --space-6: 48px;
  --space-7: 56px;
  --space-8: 64px;
  --space-9: 72px;
  --space-10: 80px;
  --space-11: 88px;
  --space-12: 96px;

  /* Fluid space — 390px floor → 1440px ceiling */
  --space-section: clamp(64px, 8vw, 128px);
  --space-block: clamp(32px, 4vw, 64px);
  --page-pad-x: clamp(32px, 5vw, 80px);

  /* Chrome metrics */
  --bar-h: 48px;            /* announcement bar — Aesop-scale (#42, ref ~50px) */
  --header-pad-y: 18px;
}

/* ---------- 2 · Reset ---------- */
* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--off-white); color: var(--ink);
  font-family: var(--font-body); font-size: 15px; line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: none; padding: 0; color: inherit; }
img { max-width: 100%; display: block; }

/* ---------- 3 · Geo bar (announcement) ---------- */
.geo-bar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 101;
  background: var(--ink); color: rgba(244,239,230,0.88);
  padding: 0 var(--page-pad-x);
  display: flex; justify-content: center; align-items: center; gap: 18px;
  font-family: var(--font-body); font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase;
  height: var(--bar-h);
}
.geo-bar__rotor { position: relative; height: 1.4em; overflow: hidden; min-width: 360px; }
.geo-bar__line {
  position: absolute; inset: 0;
  display: flex; justify-content: center; align-items: center; gap: 12px;
  opacity: 0; transition: opacity 420ms ease;
}
.geo-bar__line.is-active { opacity: 1; }
.geo-bar a { color: inherit; border-bottom: 1px solid rgba(244,239,230,0.4); }
@media (max-width: 640px) {
  .geo-bar { font-size: 12px; letter-spacing: 0.12em; }
  .geo-bar__rotor { min-width: 0; width: 100%; }
}

/* ---------- 4 · Site header ---------- */
.site-header {
  position: fixed; top: var(--bar-h); left: 0; right: 0; z-index: 100;
  padding: var(--header-pad-y) var(--page-pad-x);
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: var(--space-3);
  background: transparent; transition: background 320ms;
}
.site-header.is-tonal { background: rgba(244,239,230,0.78); backdrop-filter: blur(8px); }
.nav-left, .nav-right { display: flex; gap: var(--space-3); align-items: center; }
.nav-right { justify-content: flex-end; }
.site-header a { font-family: var(--font-body); font-size: 12px; letter-spacing: 0.06em; color: inherit; }
.menu-trigger {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-body); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
}
.menu-trigger__bars { display: inline-flex; flex-direction: column; gap: 4px; }
.menu-trigger__bars span { display: block; width: 22px; height: 1px; background: currentColor; }
@media (max-width: 640px) {
  .site-header { padding: 14px 18px; gap: var(--space-2); }
  .nav-left, .nav-right { gap: var(--space-2); }
  .menu-trigger { font-size: 11px; letter-spacing: 0.14em; }
}

/* ---------- 5 · Lockup ---------- */
.lockup { display: inline-flex; align-items: baseline; gap: 0; line-height: 1; text-decoration: none; color: var(--ink); }
.lockup__holy { font-family: var(--font-display); font-weight: 400; font-size: 26px; letter-spacing: 0.03em; line-height: 1; color: var(--ink); flex: 0 0 auto; }

/* Logo animation (Preston spec 2026-06-10) — slash-first intro, letters
   file out of / into the slash with per-letter stagger (Anthropic-style),
   transform/opacity only so nothing reflows mid-letter. State classes on
   .lockup are JS-driven:
     --slash      slash visible (alone or with letters)
     --out        slash + RITUAL CARE™ containers expanded
     --nomark     cycle box collapsed to zero (slash-only beats)
     --fold-holy  HØLY letters tucked into the slash
     --fold-rc    RITUAL CARE™ letters tucked into the slash
     --rev        reversed stagger order (collapse mirrors the file-out) */
.lockup__cycle { position: relative; display: inline-flex; align-items: center; justify-content: center; width: 76px; flex: 0 0 auto; font-family: var(--font-display); font-size: 26px; line-height: 1; transition: width 500ms cubic-bezier(0.32, 0.72, 0, 1); }
.lockup--nomark .lockup__cycle { width: 0; overflow: hidden; }
.lockup__mark { position: absolute; inset: 0; display: inline-flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 500ms ease-in-out; color: var(--ink); pointer-events: none; white-space: nowrap; }
.lockup__mark.is-active { opacity: 1; }
.lockup__mark--holy { font-family: var(--font-display); font-weight: 400; font-size: 26px; letter-spacing: 0.03em; --n: 3; }
.lockup__mark[data-mark="georuk"] svg { height: 28px; width: auto; display: block; }
/* The letters. --d is each letter's stagger index (set inline, ordered
   outward from the slash); --n is the group's max index for reversal. */
.lk-l { display: inline-block; opacity: 1; transform: none;
  transition: opacity 460ms cubic-bezier(0.19, 1, 0.22, 1), transform 460ms cubic-bezier(0.19, 1, 0.22, 1);
  transition-delay: calc(var(--d) * 30ms); }
.lockup--rev .lk-l { transition-delay: calc((var(--n) - var(--d)) * 24ms); }
.lockup--fold-holy .lockup__mark--holy .lk-l { opacity: 0; transform: translateX(18px); }
.lockup--fold-rc .lockup__rc .lk-l { opacity: 0; transform: translateX(-18px); }
.lockup__slash, .lockup__rc {
  max-width: 0; margin-left: 0; opacity: 0; overflow: hidden; white-space: nowrap;
  transition: max-width 300ms cubic-bezier(0.32, 0.72, 0, 1), margin-left 300ms cubic-bezier(0.32, 0.72, 0, 1), opacity 280ms ease;
}
.lockup__slash { font-family: var(--font-display); font-weight: 300; font-size: 25px; color: var(--ink-quiet); line-height: 1; }
.lockup__rc { font-family: var(--font-sys); font-weight: 500; font-size: 15.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink); position: relative; top: -2px; --n: 10; }
.lockup__rc sup { font-size: 0.34em; vertical-align: 1.6em; margin-left: 0.18em; letter-spacing: 0; opacity: 0.55; }
.lockup--slash .lockup__slash, .lockup--out .lockup__slash { max-width: 24px; opacity: 1; margin-left: 8px; }
.lockup--out .lockup__rc { max-width: 240px; opacity: 1; margin-left: 8px; }
@media (prefers-reduced-motion: reduce) {
  .lockup__cycle, .lockup__mark, .lk-l, .lockup__slash, .lockup__rc { transition: none !important; }
}
@media (max-width: 640px) {
  .lockup__holy { font-size: 22px; }
  .lockup__cycle { width: 64px; font-size: 22px; }
  .lockup__mark--holy { font-size: 22px; }
  .lockup__mark[data-mark="georuk"] svg { height: 24px; }
  .lockup__slash { font-size: 21px; }
  .lockup__rc { font-size: 13px; letter-spacing: 0.08em; top: -2px; }
}

/* ---------- 6 · Menu drawer — The Index ---------- */
.menu-drawer {
  position: fixed; inset: 0; z-index: 200;
  background: var(--off-white);
  padding: var(--space-4) var(--page-pad-x) var(--space-8);
  display: flex; flex-direction: column;
  transform: translateY(-100%);
  transition: transform 480ms cubic-bezier(0.32, 0.72, 0, 1);
  visibility: hidden; pointer-events: none;
}
.menu-drawer.is-open { transform: translateY(0); visibility: visible; pointer-events: auto; }
.menu-drawer__top { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; margin-bottom: clamp(48px, 6vw, 96px); }
.menu-drawer .lockup__slash, .menu-drawer .lockup__rc { max-width: none; opacity: 1; margin-left: 8px; }
.menu-drawer__close {
  font-family: var(--font-body); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-soft); padding: 12px 0 12px 16px;
  display: inline-flex; align-items: center; gap: 10px; justify-self: end;
  transition: color 200ms;
}
.menu-drawer__close::after { content: "×"; font-family: var(--font-display); font-size: 20px; font-weight: 300; line-height: 0.6; }
.menu-drawer__close:hover { color: var(--ink); }
.menu-drawer__index {
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: clamp(48px, 8vw, 128px);
  max-width: 1280px; margin: 0 auto; width: 100%; flex: 1; align-items: start;
}
.menu-drawer__primary { display: flex; flex-direction: column; gap: clamp(14px, 1.6vw, 20px); }
.menu-drawer__primary a {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(30px, 3.2vw, 44px); line-height: 1.1; letter-spacing: -0.01em;
  color: var(--ink); width: fit-content; transition: opacity 220ms ease;
}
.menu-drawer__primary:hover a:not(:hover) { opacity: 0.32; }
.menu-drawer__primary a sup { font-size: 0.38em; vertical-align: 1.1em; margin-left: 0.12em; opacity: 0.7; }
.menu-drawer__primary .status { font-family: var(--font-body); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-quiet); margin-left: 12px; vertical-align: super; }
.menu-drawer__side { display: flex; flex-direction: column; gap: 44px; padding-top: 12px; }
.menu-drawer__group summary, .menu-drawer__group h4 {
  font-family: var(--font-body); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-quiet); margin: 0 0 20px; font-weight: 500; list-style: none;
}
.menu-drawer__group summary::-webkit-details-marker { display: none; }
.menu-drawer__group ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 13px; }
.menu-drawer__group a {
  font-family: var(--font-sys); font-weight: 400; font-size: 13px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink); white-space: nowrap;
}
.menu-drawer__group a sup { font-size: 0.55em; vertical-align: 0.7em; margin-left: 0.15em; opacity: 0.7; letter-spacing: 0; font-weight: 400; }
.menu-drawer__group--house a { font-family: var(--font-body); font-size: 14px; letter-spacing: 0.02em; text-transform: none; white-space: normal; }
.menu-drawer__group .status { font-family: var(--font-body); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-quiet); margin-left: 10px; vertical-align: middle; }
@media (min-width: 641px) {
  .menu-drawer__group summary { pointer-events: none; cursor: default; }
}
.menu-drawer__cta {
  position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center; gap: 16px;
  background: var(--ink); color: var(--off-white);
  font-family: var(--font-body); font-size: 15px; letter-spacing: 0.24em; text-transform: uppercase;
  padding: 30px 22px; min-height: 88px; margin-top: var(--space-3); transition: opacity 200ms;
}
.menu-drawer__cta:hover { opacity: 0.92; }
/* Left media slot — facial image clipped on a / edge (the HØLY slash).
   Placeholder: same image as the ritual-bar hero, same treatment, until
   the bar shoot delivers a facial / foot-soak still (Preston 2026-06-10). */
.menu-drawer__cta-media {
  position: absolute; top: 0; bottom: 0; left: 0;
  width: clamp(200px, 26%, 380px);
  background-image: url('https://images.pexels.com/photos/3997989/pexels-photo-3997989.jpeg?cs=srgb&fm=jpg&w=1200');
  background-size: cover; background-position: center 30%;
  filter: grayscale(0.25) sepia(0.08) brightness(0.94);
  clip-path: polygon(0 0, 100% 0, calc(100% - 56px) 100%, 0 100%);
  pointer-events: none;
}
.menu-drawer__cta-label, .menu-drawer__cta-arrow { position: relative; z-index: 1; }
.menu-drawer__cta-arrow { font-size: 17px; letter-spacing: 0; }
.menu-drawer__bottom {
  margin-top: var(--space-8); padding-top: var(--space-4);
  border-top: 1px solid rgba(31,27,22,0.08);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-body); font-size: 13px; letter-spacing: 0.08em; color: var(--ink-quiet);
}
/* Locale switch rides the bottom row's middle slot — between
   "By appointment only." (Utah) / "HOLY LTD CO" and the temple line. */
.menu-drawer__bottom .locale-switch__list { left: 50%; transform: translateX(-50%); }
@media (max-width: 640px) {
  .menu-drawer { padding: 18px 18px 24px; overflow-y: auto; }
  .menu-drawer__top { margin-bottom: 36px; }
  .menu-drawer__top .lockup__holy { font-size: 20px; }
  .menu-drawer__index { grid-template-columns: 1fr; gap: 36px; }
  .menu-drawer__primary { gap: var(--space-2); }
  .menu-drawer__primary a { font-size: 30px; }
  .menu-drawer__side { gap: 0; padding-top: 0; border-top: 1px solid var(--ink-faint); }
  .menu-drawer__group summary { margin: 0; padding: 16px 0; cursor: pointer; display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--ink-faint); }
  .menu-drawer__group summary::after { content: "+"; font-family: var(--font-display); font-size: 18px; font-weight: 300; color: var(--ink-soft); line-height: 1; }
  .menu-drawer__group[open] summary::after { content: "−"; }
  .menu-drawer__group[open] summary { border-bottom: none; }
  .menu-drawer__group ul { padding: 2px 0 18px; border-bottom: 1px solid var(--ink-faint); gap: 15px; }
  .menu-drawer__group--house h4 { margin: 0; padding: 16px 0 12px; }
  .menu-drawer__cta { font-size: 13px; letter-spacing: 0.2em; padding: 24px 16px 24px 28%; min-height: 72px; }
  .menu-drawer__cta-media { width: clamp(96px, 24%, 160px); clip-path: polygon(0 0, 100% 0, calc(100% - 32px) 100%, 0 100%); }
  .menu-drawer__bottom { font-size: 11px; flex-direction: column; gap: 6px; align-items: flex-start; }
  .menu-drawer__bottom .locale-switch__list { left: 0; transform: none; }
}

/* ---------- 6b · Cart drawer — the Bag ---------- */
.cart-scrim {
  position: fixed; inset: 0; z-index: 210;
  background: rgba(31,27,22,0.32);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 360ms ease, visibility 360ms;
}
.cart-scrim.is-open { opacity: 1; visibility: visible; pointer-events: auto; }
.cart-drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 220;
  width: min(460px, 100vw);
  background: var(--off-white);
  display: flex; flex-direction: column;
  padding: 22px 28px 28px;
  transform: translateX(100%);
  transition: transform 480ms cubic-bezier(0.32, 0.72, 0, 1);
  visibility: hidden; pointer-events: none;
  overflow-y: auto;
}
.cart-drawer.is-open { transform: translateX(0); visibility: visible; pointer-events: auto; }
.cart-drawer__top {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 18px; margin-bottom: 28px;
  border-bottom: 1px solid var(--ink-faint);
}
.cart-drawer__label { font-family: var(--font-body); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink); font-weight: 500; }
.cart-drawer__count { color: var(--ink-quiet); margin-left: 4px; }
.cart-drawer__close {
  font-family: var(--font-body); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-soft); padding: 10px 0 10px 14px;
  display: inline-flex; align-items: center; gap: 9px; transition: color 200ms;
}
.cart-drawer__close::after { content: "×"; font-family: var(--font-display); font-size: 19px; font-weight: 300; line-height: 0.6; }
.cart-drawer__close:hover { color: var(--ink); }
/* Empty state — the bag sells before it holds */
.cart-empty__lead { font-family: var(--font-display); font-weight: 400; font-size: 30px; line-height: 1.1; letter-spacing: -0.01em; margin: 6px 0 6px; }
.cart-empty__sub { font-family: var(--font-display); font-style: italic; font-size: 17px; color: var(--ink-soft); margin: 0 0 24px; }
.cart-empty__rows { display: flex; flex-direction: column; }
.cart-keep {
  display: grid; grid-template-columns: 76px 1fr auto; gap: 16px; align-items: center;
  padding: 16px 0; border-top: 1px solid var(--ink-faint);
}
.cart-keep:last-child { border-bottom: 1px solid var(--ink-faint); }
.cart-keep__img { width: 76px; height: 90px; background: var(--ecru); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.cart-keep__img img { width: 100%; height: 100%; object-fit: cover; }
.cart-keep__meta { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.cart-keep__verb { font-family: var(--font-body); font-size: 9.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ochre); font-weight: 500; }
.cart-keep__name { font-family: var(--font-display); font-weight: 400; font-size: 17px; line-height: 1.15; color: var(--ink); }
.cart-keep__why { font-family: var(--font-display); font-style: italic; font-size: 13px; line-height: 1.4; color: var(--ink-soft); }
.cart-keep__price { font-family: var(--font-body); font-size: 11.5px; letter-spacing: 0.04em; color: var(--ink-quiet); margin-top: 2px; }
.cart-keep__add {
  font-family: var(--font-body); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink); border: 1px solid var(--ink); padding: 10px 16px;
  transition: background 200ms, color 200ms; align-self: center; cursor: pointer;
}
.cart-keep__add:hover { background: var(--ink); color: var(--off-white); }
.cart-empty__map {
  display: inline-block; margin-top: 26px;
  font-family: var(--font-display); font-style: italic; font-size: 15px; color: var(--ink-soft);
  text-decoration: underline; text-underline-offset: 5px; transition: color 200ms;
}
.cart-empty__map:hover { color: var(--ink); }
/* Filled state */
.cart-filled { display: flex; flex-direction: column; flex: 1; }
.cart-lines { flex: 1; }
/* Provision cross-sell — rides every checkout flow (Preston 2026-06-10) */
.cart-provision { margin-top: 28px; }
.cart-provision__label { font-family: var(--font-body); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-quiet); font-weight: 500; margin: 0 0 4px; }
.cart-provision__sub { font-family: var(--font-display); font-style: italic; font-size: 13.5px; line-height: 1.5; color: var(--ink-soft); margin: 0 0 12px; }
.cart-provision .cart-keep:last-child { border-bottom: 0; }
.cart-line {
  display: grid; grid-template-columns: 76px 1fr auto; gap: 16px; align-items: start;
  padding: 16px 0; border-top: 1px solid var(--ink-faint);
}
.cart-line:last-child { border-bottom: 1px solid var(--ink-faint); }
.cart-line__img { width: 76px; height: 90px; background: var(--ecru); overflow: hidden; }
.cart-line__img img { width: 100%; height: 100%; object-fit: cover; }
.cart-line__meta { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.cart-line__step { font-family: var(--font-body); font-size: 9.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-quiet); }
.cart-line__step sup { font-size: 0.6em; vertical-align: 0.8em; margin-left: 0.1em; }
.cart-line__name { font-family: var(--font-display); font-weight: 400; font-size: 17px; line-height: 1.15; color: var(--ink); }
.cart-line__qty { display: inline-flex; align-items: center; gap: 12px; margin-top: 8px; }
.cart-line__qty button {
  width: 24px; height: 24px; border: 1px solid var(--ink-faint); color: var(--ink-soft);
  font-family: var(--font-display); font-size: 15px; line-height: 1; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; transition: border-color 200ms, color 200ms;
}
.cart-line__qty button:hover { border-color: var(--ink); color: var(--ink); }
.cart-line__qty span { font-family: var(--font-body); font-size: 12px; color: var(--ink); min-width: 14px; text-align: center; }
.cart-line__right { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }
.cart-line__price { font-family: var(--font-body); font-size: 13px; letter-spacing: 0.02em; color: var(--ink); }
.cart-line__was { font-family: var(--font-body); font-size: 11px; color: var(--ink-quiet); text-decoration: line-through; }
.cart-line__remove { font-family: var(--font-body); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-quiet); cursor: pointer; transition: color 200ms; margin-top: 4px; }
.cart-line__remove:hover { color: var(--ink); }
/* Auto-Ritual — default ON the moment an item lands */
.cart-line__auto { display: inline-flex; align-items: center; gap: 8px; margin-top: 9px; cursor: pointer; user-select: none; }
.cart-line__auto input { position: absolute; opacity: 0; pointer-events: none; }
.cart-line__auto .tick {
  width: 13px; height: 13px; border: 1px solid var(--ink); flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center; transition: background 200ms;
}
.cart-line__auto input:checked + .tick { background: var(--ink); }
.cart-line__auto input:checked + .tick::after { content: "✓"; color: var(--off-white); font-size: 9px; line-height: 1; }
.cart-line__auto .lbl { font-family: var(--font-body); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-soft); }
.cart-line__auto .lbl em { font-style: normal; color: var(--ochre); }
.cart-foot { margin-top: 28px; }
.cart-foot__row { display: flex; justify-content: space-between; align-items: baseline; padding-top: 18px; border-top: 1px solid var(--ink); }
.cart-foot__k { font-family: var(--font-body); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink); font-weight: 500; }
.cart-foot__v { font-family: var(--font-display); font-size: 22px; color: var(--ink); }
.cart-foot__auto { font-family: var(--font-display); font-style: italic; font-size: 13px; color: var(--ink-soft); margin: 10px 0 18px; }
.cart-foot__cta {
  display: flex; align-items: center; justify-content: center;
  background: var(--ink); color: var(--off-white);
  font-family: var(--font-body); font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase;
  padding: 19px 24px; transition: opacity 200ms;
}
.cart-foot__cta:hover { opacity: 0.92; }
.cart-foot__fine { font-family: var(--font-display); font-style: italic; font-size: 12px; color: var(--ink-quiet); text-align: center; margin: 12px 0 0; }
@media (max-width: 640px) {
  .cart-drawer { padding: 18px 18px 24px; }
  .cart-empty__lead { font-size: 26px; }
}

/* ---------- 6c · On-brand field validation — site-wide rule ----------
   Never the native browser bubble (Preston 2026-06-10). !important wins
   over per-page <style> blocks that restyle inputs at equal specificity. */
input.is-error, textarea.is-error, select.is-error { border-color: #A83428 !important; }
.field-error { font-family: var(--font-display); font-style: italic; font-size: 13.5px; color: #A83428; margin: 6px 0 0; text-align: left; }

/* ---------- 7 · Footer ---------- */
footer {
  background: var(--ink); color: rgba(244,239,230,0.7);
  padding: var(--space-10) var(--page-pad-x) 36px;
  text-align: left; font-family: var(--font-body); font-size: 11px; letter-spacing: 0.1em;
}
.ft-mark { font-family: var(--font-display); font-size: 36px; letter-spacing: 0.04em; color: var(--off-white); text-align: center; margin: 0 0 var(--space-7); }
.ft-cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); max-width: 1200px; margin: 0 auto var(--space-8); }
.ft-cols h4 { font-family: var(--font-body); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(244,239,230,0.55); margin: 0 0 18px; font-weight: 500; }
.ft-cols ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.ft-cols a { font-size: 13px; letter-spacing: 0.02em; color: rgba(244,239,230,0.72); transition: color 200ms; }
.ft-cols a:hover { color: var(--off-white); }
.ft-cols a sup { font-size: 0.55em; vertical-align: 0.7em; margin-left: 0.12em; opacity: 0.7; }
.ft-btm {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding-top: var(--space-4); border-top: 1px solid rgba(244,239,230,0.1); color: rgba(244,239,230,0.45);
}
@media (max-width: 900px) { .ft-cols { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); } }
@media (max-width: 640px) {
  footer { padding: var(--space-7) 18px var(--space-4); }
  .ft-btm { flex-direction: column; gap: 14px; text-align: center; }
}
@media (max-width: 600px) { .ft-cols { grid-template-columns: 1fr; } }

/* ---------- 7b · Market / locale switch (globalization pass 2026-06-10) ----------
   Quiet register — a wayfinding whisper, not a control panel. Lives in the
   menu drawer (light) and footer (dark). Panel opens upward: both placements
   sit at the bottom of their containers. */
.locale-switch { position: relative; font-family: var(--font-body); }
.locale-switch__trigger {
  list-style: none; cursor: pointer; display: inline-flex; align-items: center; gap: 8px;
  font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-quiet);
  transition: color 200ms;
}
.locale-switch__trigger::-webkit-details-marker { display: none; }
.locale-switch__trigger::after { content: "+"; font-family: var(--font-display); font-size: 14px; font-weight: 300; line-height: 1; }
.locale-switch[open] .locale-switch__trigger::after { content: "−"; }
.locale-switch__trigger:hover { color: var(--ink); }
.locale-switch__list {
  position: absolute; bottom: calc(100% + 10px); left: 0; z-index: 5;
  min-width: 280px; max-height: 320px; overflow-y: auto;
  list-style: none; margin: 0; padding: 8px 0;
  background: var(--off-white); border: 1px solid var(--ink-faint);
  box-shadow: 0 12px 32px rgba(31,27,22,0.12);
}
.locale-switch__list button {
  display: flex; justify-content: space-between; align-items: baseline; gap: 16px; width: 100%;
  background: none; border: 0; cursor: pointer; text-align: left;
  padding: 10px 18px;
  font-family: var(--font-body); font-size: 12.5px; letter-spacing: 0.02em; color: var(--ink);
  transition: background 160ms;
}
.locale-switch__list button:hover { background: var(--ecru); }
.locale-switch__list button span { font-size: 10.5px; letter-spacing: 0.06em; color: var(--ink-quiet); white-space: nowrap; }
.locale-switch__list button span em { font-style: italic; font-family: var(--font-display); color: var(--ochre); }
/* Footer (dark) context */
.ft-btm .locale-switch__trigger { color: rgba(244,239,230,0.45); }
.ft-btm .locale-switch__trigger:hover { color: var(--off-white); }
.ft-btm .locale-switch__list { left: auto; right: 0; }
@media (max-width: 640px) {
  .ft-btm .locale-switch__list { left: 50%; right: auto; transform: translateX(-50%); }
}

/* ---------- 8 · Build annotation ---------- */
.annot--tag {
  position: fixed; top: 84px; right: 16px;
  font-family: ui-monospace, monospace; font-size: 9px;
  color: rgba(31,27,22,0.4); letter-spacing: 0.04em; text-transform: uppercase;
  z-index: 10;
}
@media (max-width: 640px) { .annot--tag { display: none; } }
