/* Studio 1279 — main stylesheet (Editorial Maison).
   All values come from tokens.css. The aesthetic is editorial: generous
   whitespace, hairline rules, large display serif numerals, a single
   oxblood accent. */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-fg);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  font-feature-settings: "ss01", "kern";
  letter-spacing: var(--tracking-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img { max-width: 100%; height: auto; display: block; }

a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color var(--duration-fast) var(--ease),
              border-color var(--duration-fast) var(--ease);
}
a:hover, a:focus-visible {
  color: var(--color-accent);
  border-bottom-color: currentColor;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-snug);
  margin: 0 0 var(--space-4);
  color: var(--color-fg);
}
h1 { font-size: var(--fs-3xl); letter-spacing: var(--tracking-tight); }
h2 { font-size: var(--fs-2xl); }
h3 { font-size: var(--fs-xl); }
h4 { font-size: var(--fs-lg); }

p { margin: 0 0 var(--space-4); max-width: 64ch; }

::selection { background: var(--color-accent); color: var(--color-paper); }

.eyebrow {
  text-transform: uppercase;
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  color: var(--color-accent);
  font-weight: 500;
  margin-bottom: var(--space-3);
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}
.eyebrow::before {
  content: "";
  width: 24px;
  height: 1px;
  background: currentColor;
  opacity: 0.6;
}

.lead {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-xl);
  color: var(--color-fg-soft);
  line-height: var(--lh-snug);
  max-width: 36ch;
}

.muted { color: var(--color-muted); font-size: var(--fs-sm); }
.visually-hidden {
  position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.skip-link {
  position: absolute; top: -100px; left: 0; padding: var(--space-3) var(--space-4);
  background: var(--color-fg); color: var(--color-paper); z-index: 100;
  font-size: var(--fs-sm); letter-spacing: var(--tracking-wide);
}
.skip-link:focus { top: 0; }

.display, .h-display {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-display);
  line-height: 0.92;
  letter-spacing: var(--tracking-tight);
  margin: 0;
}
.display--sm { font-size: var(--fs-display-sm); }
.display--italic { font-style: italic; font-weight: 400; }

.script { font-family: var(--font-script); font-weight: 400; }

.rule {
  display: block;
  width: 100%;
  height: 1px;
  background: var(--color-border);
  border: 0;
  margin: var(--space-5) 0;
}
.rule--brass { background: var(--color-brass); opacity: 0.5; }
.rule--accent { background: var(--color-accent); opacity: 0.7; }
.rule--short { width: 64px; }

/* ── Container ────────────────────────────────────────────────────────── */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding-inline: var(--container-pad);
}
.container--narrow { max-width: var(--container-narrow); }

/* ── Header ───────────────────────────────────────────────────────────── */
.site-header {
  position: sticky; top: 0; z-index: 20;
  background: color-mix(in srgb, var(--color-paper) 92%, transparent);
  border-bottom: 1px solid var(--color-border);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
}
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  padding-block: var(--space-4); gap: var(--space-5);
}

.brand {
  display: inline-flex; align-items: center; gap: var(--space-3);
  color: var(--color-fg);
  border: 0;
  text-decoration: none;
}
.brand:hover { color: var(--color-fg); border: 0; }
.brand__mark {
  width: 44px; height: 44px;
  display: inline-block;
  border-radius: 3px;
  overflow: hidden;
  flex-shrink: 0;
  box-shadow:
    0 1px 2px hsla(22, 14%, 0%, 0.12),
    0 0 0 1px hsla(22, 14%, 0%, 0.04);
  transition: transform var(--duration-base) var(--ease-display);
}
.brand:hover .brand__mark { transform: translateY(-1px); }
.brand__lockup {
  display: inline-flex; flex-direction: column;
  line-height: 1; gap: 4px;
  min-width: 0;
}
.brand__italic {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.375rem;
  font-weight: 500;
  letter-spacing: var(--tracking-snug);
  white-space: nowrap;
}
.brand__caption {
  font-family: var(--font-body);
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-muted);
  white-space: nowrap;
}

.primary-nav {
  display: none; gap: var(--space-6); align-items: center;
  font-size: var(--fs-sm); letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  font-weight: 500;
}
.primary-nav a {
  color: var(--color-fg-soft);
  padding-block: var(--space-2);
  position: relative;
  border-bottom: 0;
}
/* Editorial growing underline on hover/focus instead of an instant border. */
.primary-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: var(--color-accent);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--duration-base) var(--ease);
}
.primary-nav a:hover,
.primary-nav a:focus-visible { color: var(--color-accent); }
.primary-nav a:hover::after,
.primary-nav a:focus-visible::after { transform: scaleX(1); }

.header-actions { display: inline-flex; gap: var(--space-4); align-items: center; }
.lang-toggle {
  font-weight: 600; color: var(--color-fg);
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-fg); border-radius: 0;
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wider);
}
.lang-toggle:hover { background: var(--color-fg); color: var(--color-paper); border-color: var(--color-fg); }

.cart-link {
  position: relative; color: var(--color-fg);
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
}
.cart-link__icon { width: 22px; height: 22px; }
.cart-count {
  position: absolute; top: 2px; right: 2px; min-width: 18px; height: 18px;
  background: var(--color-accent); color: var(--color-paper);
  border-radius: var(--radius-pill);
  font-size: 10px; line-height: 18px; text-align: center; padding-inline: 4px;
  letter-spacing: 0;
  font-family: var(--font-body);
  font-weight: 600;
}
.cart-count[data-count="0"] { display: none; }

@media (min-width: 880px) {
  .primary-nav { display: inline-flex; }
}

/* ── Hamburger toggle ──────────────────────────────────────────────────── */
.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px; height: 44px;
  padding: 10px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-fg);
  flex-shrink: 0;
}
.nav-toggle__bar {
  display: block;
  height: 1.5px;
  background: currentColor;
  transform-origin: center;
  transition: transform 0.28s var(--ease-display), opacity 0.2s ease;
  width: 22px;
}
/* X state */
.nav-toggle[aria-expanded='true'] .nav-toggle__bar:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
}
.nav-toggle[aria-expanded='true'] .nav-toggle__bar:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.nav-toggle[aria-expanded='true'] .nav-toggle__bar:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
}
@media (min-width: 880px) {
  .nav-toggle { display: none; }
}

/* ── Mobile nav overlay ────────────────────────────────────────────────── */
.mobile-nav {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: var(--color-ink-950);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: var(--space-10) var(--space-8);
  /* Hidden state — slide up + fade out */
  opacity: 0;
  transform: translateY(-100%);
  pointer-events: none;
  transition:
    opacity 0.35s var(--ease-display),
    transform 0.35s var(--ease-display);
}
.mobile-nav.is-open {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media (min-width: 880px) {
  .mobile-nav { display: none !important; }
}

.mobile-nav__links {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  width: 100%;
}
.mobile-nav__links a {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-display-sm);
  font-weight: 500;
  color: var(--color-bone);
  letter-spacing: var(--tracking-snug);
  line-height: var(--lh-tight);
  padding-block: var(--space-3);
  border-bottom: 1px solid color-mix(in srgb, var(--color-border) 12%, transparent);
  transition: color 0.18s ease, padding-left 0.22s ease;
}
.mobile-nav__links a:last-child {
  border-bottom: none;
}
.mobile-nav__links a:hover,
.mobile-nav__links a:focus-visible {
  color: var(--color-accent-warm);
  padding-left: var(--space-3);
  outline: none;
}

.mobile-nav__meta {
  margin-top: var(--space-8);
  display: flex;
  align-items: center;
  gap: var(--space-5);
}
.mobile-nav__rule {
  display: block;
  width: 32px;
  height: 1px;
  background: var(--color-brass);
  opacity: 0.5;
}
.mobile-nav__lang {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wider);
  color: var(--color-brass);
  text-transform: uppercase;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-brass-soft);
  opacity: 0.8;
  transition: opacity 0.18s ease;
}
.mobile-nav__lang:hover { opacity: 1; }

/* ── Hero ─────────────────────────────────────────────────────────────── */
.hero {
  padding-block: var(--space-8) var(--space-8);
  background: var(--color-paper);
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 12% 12%, color-mix(in srgb, var(--color-accent) 4%, transparent), transparent 50%),
    radial-gradient(circle at 88% 88%, color-mix(in srgb, var(--color-brass) 6%, transparent), transparent 55%);
  pointer-events: none;
}

/* `.hero--home .hero__grid` (base + ≥880px override) is defined once in the
   “New home hero (editorial opener)” section below; the duplicate that lived
   here carried the same/overridden values and was removed. */
.hero h1 {
  font-size: clamp(2.5rem, 7vw + 1rem, 6rem);
  line-height: 0.94;
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-5);
}
.hero h1 .hero__italic {
  display: block;
  font-style: italic; font-weight: 400;
  font-size: 0.42em;
  letter-spacing: var(--tracking-snug);
  margin-bottom: var(--space-3);
  color: var(--color-fg-soft);
}
.hero h1 .hero__numeral {
  display: block;
  letter-spacing: 0.02em;
}

.hero__rule {
  display: block;
  width: 64px; height: 2px;
  background: var(--color-accent);
  margin-block: var(--space-5);
}

.hero__visual img {
  border-radius: 0;
  box-shadow: var(--shadow-2);
  width: 100%;
}
.hero__visual--photo img { aspect-ratio: 4/5; object-fit: cover; }

.hero__caption {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
  margin-top: var(--space-3);
  display: flex; gap: var(--space-3); align-items: center;
}

.hero--inner {
  padding-block: var(--space-8) var(--space-7);
  border-bottom: 1px solid var(--color-border);
  text-align: center;
  /* Faded salon photo — same technique as the editorial hero, heavier overlay
     so the compact inner header stays legible on every page. */
  background:
    linear-gradient(to bottom,
      color-mix(in srgb, var(--color-paper) 90%, transparent),
      color-mix(in srgb, var(--color-paper) 84%, transparent) 50%,
      color-mix(in srgb, var(--color-paper) 92%, transparent)),
    url("/static/img/photos/hair-wash-area.webp") center 40% / cover no-repeat;
  position: relative;
  overflow: hidden;
}
.hero--inner h1 {
  font-size: clamp(2.5rem, 5vw + 1rem, 4.5rem);
  margin-bottom: var(--space-4);
}
.hero--inner .lead { margin-inline: auto; }

/* ── Buttons ──────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: var(--space-4) var(--space-6);
  font-weight: 600;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  border: 1px solid transparent;
  border-radius: 0;
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease),
              color var(--duration-fast) var(--ease),
              border-color var(--duration-fast) var(--ease),
              transform var(--duration-fast) var(--ease);
  text-decoration: none;
  font-family: var(--font-body);
  gap: var(--space-3);
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn:focus-visible { outline: 2px solid currentColor; outline-offset: 3px; }
/* Outline-only buttons — no filled backgrounds. Primary/accent carry the
   oxblood accent so they stay the eye-catching brand action; ghost is a quiet
   ink outline for secondary actions. Hover deepens the colour and slides the
   arrow rather than filling a background. */
.btn--primary { background: transparent; color: var(--color-accent); border-color: var(--color-accent); }
.btn--primary:hover { color: var(--color-accent-strong); border-color: var(--color-accent-strong); }
.btn--accent { background: transparent; color: var(--color-accent); border-color: var(--color-accent); }
.btn--accent:hover { color: var(--color-accent-strong); border-color: var(--color-accent-strong); }
.btn--ghost { background: transparent; color: var(--color-fg); border-color: var(--color-border); }
.btn--ghost:hover { color: var(--color-fg); border-color: var(--color-fg); }
.btn--small { padding: var(--space-3) var(--space-4); font-size: 0.6875rem; }
.btn--large { padding: var(--space-5) var(--space-7); font-size: var(--fs-sm); }
.btn::after {
  content: "→";
  display: inline-block;
  transition: transform var(--duration-fast) var(--ease);
  font-size: 1.1em;
  letter-spacing: 0;
  margin-inline-start: var(--space-1);
}
.btn:hover::after { transform: translateX(3px); }
.btn--no-arrow::after { display: none; }

.cta-row {
  display: flex; gap: var(--space-3); flex-wrap: wrap;
  margin-block: var(--space-6);
}

/* ── Section spacing ──────────────────────────────────────────────────── */
.section { padding-block: var(--space-8); }
.section--alt { background: var(--color-paper-2); }
.section--deep { background: var(--color-ink-950); color: var(--color-paper); }
.section--deep h1, .section--deep h2, .section--deep h3 { color: var(--color-paper); }
.section--deep .muted { color: var(--color-ink-300); }
.section--deep a:hover { color: var(--color-brass); }

.section__header {
  display: grid; gap: var(--space-3); margin-bottom: var(--space-7);
  text-align: center;
}
.section__header h2 { margin: 0; }
.section__header .lead { margin-inline: auto; }
.section__header--row {
  display: flex; align-items: baseline; justify-content: space-between;
  text-align: left; flex-wrap: wrap; gap: var(--space-4);
}
.section__more {
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wider); font-weight: 600;
  color: var(--color-accent);
}
.section__cta { margin: var(--space-6) 0 0; text-align: center; }

/* ── Service catalog groups (subheaders inside /services + /ongles) ────── */
.service-group { margin-bottom: var(--space-8); }
.service-group:last-child { margin-bottom: 0; }
.service-group__header {
  display: flex; align-items: center; gap: var(--space-4);
  margin: 0 0 var(--space-5);
}
.service-group__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2vw + 0.6rem, 2rem);
  font-style: italic; font-weight: 500;
  color: var(--color-fg);
  white-space: nowrap;
}
.service-group__rule {
  flex: 1; height: 1px;
  background: linear-gradient(to right, var(--color-border) 0%, transparent 100%);
  transform-origin: left center;
  transform: scaleX(0);
  transition: transform 900ms var(--ease-display) 200ms;
}
.is-revealed .service-group__rule,
.service-group.is-revealed .service-group__rule {
  transform: scaleX(1);
}

.value-strip {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .value-strip { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1060px) { .value-strip { grid-template-columns: repeat(4, 1fr); } }
.value-strip li {
  padding: var(--space-5);
  border: 1px solid var(--color-border);
  background: var(--color-bg-elevated);
  border-radius: var(--radius-lg);
}
.value-strip li p { margin: 0; color: var(--color-fg-soft); font-size: var(--fs-sm); }
.value-strip__eyebrow {
  margin: 0 0 var(--space-2) !important;
  text-transform: uppercase; letter-spacing: var(--tracking-wider);
  font-size: var(--fs-xs); font-weight: 600;
  color: var(--color-fg) !important;
}

/* ── Category grid ────────────────────────────────────────────────────── */
.categories { background: var(--color-paper-2); }
.category-grid {
  display: grid; gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) and (max-width: 1059px) { .category-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1060px) { .category-grid { grid-template-columns: repeat(4, 1fr); } }
.category-card {
  display: flex; flex-direction: column;
  background: var(--color-bone);
  border: 1px solid var(--color-border);
  border-radius: 0;
  overflow: hidden;
  color: inherit; text-decoration: none;
  transition: transform var(--duration-base) var(--ease),
              box-shadow var(--duration-base) var(--ease),
              border-color var(--duration-base) var(--ease);
}
.category-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-3);
  border-color: var(--color-accent);
  color: inherit;
}
.category-card figure { margin: 0; aspect-ratio: 1 / 1; overflow: hidden; }
.category-card figure img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1200ms var(--ease-display);
}
.category-card:hover figure img { transform: scale(1.04); }
.category-card__body { padding: var(--space-6); }
.category-card__body h3 {
  font-size: var(--fs-xl); margin: 0 0 var(--space-3);
  font-style: italic; font-weight: 500;
}
.category-card__body p { color: var(--color-fg-soft); margin: 0 0 var(--space-3); }

/* ── Social icons ─────────────────────────────────────────────────────── */
.social-icons {
  list-style: none; padding: 0; margin: 0;
  display: inline-flex; gap: var(--space-3); align-items: center;
}
.social-icons a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border: 1px solid var(--color-border); border-radius: var(--radius-pill);
  color: var(--color-fg);
  transition: background var(--duration-fast) var(--ease),
              color var(--duration-fast) var(--ease),
              border-color var(--duration-fast) var(--ease);
}
.social-icons a:hover {
  background: var(--color-fg); color: var(--color-bg); border-color: var(--color-fg);
  text-decoration: none;
}
.social-icons svg { width: 18px; height: 18px; }
.site-footer .social-icons a { border-color: color-mix(in srgb, var(--color-paper) 18%, transparent); color: var(--color-paper); }
.site-footer .social-icons a:hover { background: var(--color-bg); color: var(--color-fg); border-color: var(--color-bg); }

/* ── Booking wizard — pickers + slot grid + inline form ───────────────── */
.booking-progress {
  list-style: none; padding: 0;
  margin: 0 0 var(--space-5);
  display: inline-flex; align-items: center; gap: var(--space-2);
  flex-wrap: wrap;
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-fg-soft);
}
.booking-progress__step {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  background: var(--color-bg-elevated);
  transition: background var(--duration-fast) var(--ease),
              color var(--duration-fast) var(--ease),
              border-color var(--duration-fast) var(--ease);
}
.booking-progress__num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--color-paper-2); color: var(--color-fg-soft);
  font-weight: 600; font-size: 11px;
}
.booking-progress__label { font-weight: 600; }
.booking-progress__sep {
  width: 18px; height: 1px; background: var(--color-border);
  list-style: none;
}
.booking-progress__step.is-done { color: var(--color-fg); border-color: var(--color-border); }
.booking-progress__step.is-done .booking-progress__num { background: var(--color-fg); color: var(--color-paper); }
.booking-progress__step.is-current {
  background: var(--color-fg); color: var(--color-paper); border-color: var(--color-fg);
}
.booking-progress__step.is-current .booking-progress__num { background: var(--color-paper); color: var(--color-fg); }
@media (max-width: 520px) {
  .booking-progress__label { display: none; }
  .booking-progress__step { padding: var(--space-1); }
}

.reserver-grid {
  display: grid; gap: var(--space-5);
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.reserver-service-card {
  display: flex; flex-direction: column;
  background: var(--color-bg-elevated); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); overflow: hidden;
  color: inherit; text-decoration: none;
  transition: transform var(--duration-base) var(--ease), box-shadow var(--duration-base) var(--ease);
}
.reserver-service-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-2); color: inherit; text-decoration: none; }
.reserver-service-card figure { margin: 0; aspect-ratio: 4/3; overflow: hidden; background: var(--color-paper-2); }
.reserver-service-card figure img { width: 100%; height: 100%; object-fit: cover; }
.reserver-service-card__body { padding: var(--space-5); }
.reserver-service-card__body h3 {
  margin: 0 0 var(--space-2); font-family: var(--font-display);
  font-style: italic; font-weight: 500; font-size: var(--fs-lg);
}
.reserver-service-card__body .price {
  margin-top: var(--space-3); font-size: var(--fs-sm); color: var(--color-fg-soft);
}

.staff-grid {
  display: grid; gap: var(--space-5);
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}
.staff-card {
  display: flex; flex-direction: column;
  background: var(--color-bg-elevated); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); overflow: hidden;
  color: inherit; text-decoration: none;
  transition: transform var(--duration-base) var(--ease), box-shadow var(--duration-base) var(--ease);
}
.staff-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-2); color: inherit; text-decoration: none; }
.staff-card__photo { margin: 0; aspect-ratio: 4/5; overflow: hidden; background: var(--color-paper-2); }
.staff-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.staff-card__body { padding: var(--space-5); }
.staff-card__body h3 {
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: var(--fs-xl); margin: var(--space-2) 0 var(--space-3);
}
.staff-card__bio { color: var(--color-fg-soft); margin-bottom: var(--space-3); font-size: var(--fs-sm); }
.staff-card__cta {
  color: var(--color-accent); font-weight: 600;
  font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: var(--tracking-wider);
}

.reserve-layout {
  display: grid; gap: var(--space-6);
  grid-template-columns: 1fr;
}
@media (min-width: 880px) { .reserve-layout { grid-template-columns: 300px 1fr; align-items: start; } }
.reserve-sidebar {
  background: var(--color-bg-elevated); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-5);
  position: sticky; top: 100px;
}
.reserve-sidebar h2 {
  font-family: var(--font-display); font-size: var(--fs-xl);
  font-style: italic; font-weight: 500;
  margin-block: var(--space-3) var(--space-2);
}
.reserve-sidebar__photo {
  margin: 0 0 var(--space-3); aspect-ratio: 4/5; overflow: hidden;
  border-radius: var(--radius-md); background: var(--color-paper-2);
}
.reserve-sidebar__photo img { width: 100%; height: 100%; object-fit: cover; }

.day-block { margin-bottom: var(--space-6); }
.day-block__date {
  font-family: var(--font-display); font-size: var(--fs-lg);
  font-style: italic; font-weight: 500;
  margin: 0 0 var(--space-3); color: var(--color-fg);
  border-bottom: 1px solid var(--color-border); padding-bottom: var(--space-2);
}
.slot-grid {
  display: grid; gap: var(--space-2);
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
}
.slot-button-form { margin: 0; }
.slot-button {
  width: 100%;
  padding: var(--space-3); font-weight: 500; font-size: var(--fs-sm);
  background: var(--color-bg-elevated); color: var(--color-fg);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  cursor: pointer; font-family: inherit;
  transition: all var(--duration-fast) var(--ease);
  letter-spacing: 0.02em;
}
.slot-button:hover {
  background: var(--color-accent); color: var(--color-paper);
  border-color: var(--color-accent);
  transform: translateY(-1px);
}
.slot-button:disabled { cursor: default; opacity: 0.45; transform: none; }
.slot-button--loading {
  background: var(--color-accent); color: var(--color-paper);
  border-color: var(--color-accent); opacity: 1;
  animation: slot-pulse var(--duration-base) var(--ease) infinite alternate;
}
@keyframes slot-pulse { to { opacity: 0.7; } }
@media (prefers-reduced-motion: reduce) { .slot-button--loading { animation: none; } }

.reserve-sidebar__tz {
  font-size: var(--fs-xs); margin-top: var(--space-3);
  padding-top: var(--space-3); border-top: 1px solid var(--color-border);
}

.reserve-form__fields {
  border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  background: var(--color-bg-elevated); padding: var(--space-5);
  margin: 0 0 var(--space-5);
}
.reserve-form__legend {
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: var(--fs-lg); padding: 0 var(--space-2);
  color: var(--color-fg);
}
.reserve-form__grid {
  display: grid; gap: var(--space-3) var(--space-4);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .reserve-form__grid { grid-template-columns: 1fr 1fr; }
}
.reserve-form__label {
  display: grid; gap: var(--space-1);
  font-size: var(--fs-sm); color: var(--color-fg-soft);
}
.reserve-form__label span em {
  color: var(--color-accent); font-style: normal;
}
.reserve-form__label--full { grid-column: 1 / -1; }
.reserve-form__label input,
.reserve-form__label textarea {
  padding: var(--space-3); border: 1px solid var(--color-border);
  border-radius: var(--radius-sm); font-family: inherit; font-size: var(--fs-base);
  background: var(--color-bg); color: var(--color-fg);
  width: 100%;
}
.reserve-form__label input:focus,
.reserve-form__label textarea:focus {
  outline: 2px solid var(--color-accent); outline-offset: 1px; border-color: var(--color-accent);
}
.reserve-form__hint {
  margin: 0 0 var(--space-4); font-size: var(--fs-sm);
  color: var(--color-fg-soft);
}
.reserve-form__hint--error {
  color: var(--color-accent); font-weight: 600;
}
.reserve-form__slots > .day-block:last-child { margin-bottom: 0; }
.category-card__arrow {
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-accent); font-weight: 600;
}

.trust-row {
  list-style: none; padding: 0; margin: var(--space-5) 0 0;
  display: grid; gap: var(--space-3);
  color: var(--color-fg-soft); font-size: var(--fs-sm);
}
.trust-row li {
  display: inline-flex; gap: var(--space-3); align-items: center;
  font-family: var(--font-body);
}
.trust-row li::before {
  content: ""; width: 20px; height: 1px;
  background: var(--color-accent);
}

/* ── Section intros ───────────────────────────────────────────────────── */
.section__intro {
  max-width: 56ch;
  margin: 0 auto var(--space-6);
  color: var(--color-fg-soft);
  font-size: var(--fs-md);
  line-height: var(--lh-snug);
  text-align: center;
}

/* Rendered CMS prose (markdown → HTML via the `markdown` filter). */
.prose { color: var(--color-fg-soft); line-height: var(--lh-base); }
.prose > :first-child { margin-top: 0; }
.prose > :last-child { margin-bottom: 0; }
.prose p { margin: 0 0 var(--space-4); }
.prose strong { color: var(--color-fg); font-weight: 600; }
.prose em { font-style: italic; }
.prose a { color: var(--color-accent); }
.prose ul, .prose ol { margin: 0 0 var(--space-4) var(--space-5); }
.prose li { margin-bottom: var(--space-2); }
/* When prose doubles as the centered section intro, keep it readable left-aligned. */
.prose.section__intro { text-align: left; font-size: var(--fs-md); }

/* ── Service cards (editorial, asymmetric) ────────────────────────────── */
.service-grid {
  display: grid;
  gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 640px)  { .service-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .service-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); } }

.service-card {
  display: flex;
  flex-direction: column;
  background: var(--color-bone);
  border: 1px solid var(--color-border);
  overflow: hidden;
  transition: transform var(--duration-base) var(--ease),
              box-shadow var(--duration-base) var(--ease),
              border-color var(--duration-base) var(--ease);
}
.service-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-2);
  border-color: var(--color-fg);
}
.service-card__media {
  position: relative;
  aspect-ratio: 4 / 3;
  margin: 0;
  background: linear-gradient(135deg, var(--color-paper-2), var(--color-paper-3));
  overflow: hidden;
}
.service-card__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 800ms var(--ease-display);
}
.service-card:hover .service-card__media img { transform: scale(1.05); }
.service-card__placeholder {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--color-ink-900);
  color: var(--color-paper);
}
.service-card__mark {
  font-family: var(--font-display);
  font-size: 4.5rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  border-bottom: 2px solid var(--color-accent);
  padding-bottom: 0.05em;
}
.service-card__body {
  padding: var(--space-5);
  display: flex; flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}
.service-card__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.3rem, 1.5vw + 0.7rem, 1.65rem);
  line-height: 1.15;
  margin: 0;
}
.service-card__desc {
  color: var(--color-fg-soft);
  font-size: var(--fs-sm);
  line-height: var(--lh-snug);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.service-card__meta {
  margin: var(--space-2) 0 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}
.service-card__meta > div { display: flex; flex-direction: column; gap: 2px; }
.service-card__meta dt {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
}
.service-card__meta dd {
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  color: var(--color-fg);
}
.service-card__cta { margin-top: auto; align-self: stretch; text-align: center; }

/* ── Cards (products) ─────────────────────────────────────────────────── */
.card-grid {
  display: grid; gap: var(--space-4);
  grid-template-columns: 1fr;
}
@media (min-width: 520px)  { .card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 880px)  { .card-grid { grid-template-columns: repeat(3, 1fr); gap: var(--space-5); } }
@media (min-width: 1280px) { .card-grid { grid-template-columns: repeat(4, 1fr); } }
.card {
  background: var(--color-bone);
  border: 1px solid var(--color-border);
  border-radius: 0;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform var(--duration-base) var(--ease),
              box-shadow var(--duration-base) var(--ease),
              border-color var(--duration-base) var(--ease);
}
.card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-2);
  border-color: var(--color-fg);
}
.card__link { color: inherit; display: flex; flex-direction: column; flex: 1; border: 0; }
.card__link:hover { color: inherit; border: 0; }
.card__image {
  aspect-ratio: 4 / 5;
  background: var(--color-paper-2);
  margin: 0; overflow: hidden;
  position: relative;
}
.card__image img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 800ms var(--ease-display);
}
.card:hover .card__image img { transform: scale(1.03); }
/* Brand mark overlay — appears on every product image except Studio Noir
   merch (those SVGs already burn the noir lockup into the asset). */
.card__image:not([data-noir])::after,
.product-detail__gallery:not([data-noir])::after {
  content: "";
  position: absolute;
  right: var(--space-3);
  bottom: var(--space-3);
  width: 52px;
  height: 52px;
  background: url("/static/img/brand-mark-paper.svg") center / contain no-repeat;
  opacity: 0.78;
  filter: drop-shadow(0 1px 2px hsl(22 14% 8% / 0.45));
  pointer-events: none;
  z-index: 1;
}
.product-detail__gallery { position: relative; }
.product-detail__gallery:not([data-noir])::after { width: 84px; height: 84px; opacity: 0.85; }
.card__body { padding: var(--space-5); flex: 1; }
.card__brand {
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
  margin-bottom: var(--space-2);
  display: block;
}
.card__title, .card__body h3 {
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 1vw + 0.7rem, 1.3rem);
  margin: 0 0 var(--space-2);
  font-style: italic; font-weight: 500;
  line-height: 1.2;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.card__desc {
  color: var(--color-fg-soft);
  font-size: var(--fs-sm);
  line-height: var(--lh-snug);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.card__price {
  margin-top: var(--space-4);
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  color: var(--color-fg);
}
.card__vol { color: var(--color-muted); font-size: var(--fs-sm); font-family: var(--font-body); }
.card__add { padding: 0 var(--space-5) var(--space-5); }
.card__add .btn { width: 100%; }
.card__badge {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  padding: 4px 10px;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  background: var(--color-paper);
  color: var(--color-fg);
  border: 1px solid var(--color-border);
  z-index: 1;
}
.card__badge--noir {
  background: var(--color-ink-900);
  color: var(--color-paper);
  border-color: var(--color-ink-950);
}
.card__badge--soldout {
  background: var(--color-ink-700);
  color: var(--color-paper);
  border-color: var(--color-ink-800);
}
/* Out-of-stock products read as unavailable at a glance, not just via the button. */
.card--soldout .card__image img { opacity: 0.55; filter: grayscale(0.35); }
.card--soldout:hover .card__image img { transform: none; }

/* ── Mobile refinements (≤ 640 px) ─────────────────────────────────────── */
@media (max-width: 640px) {
  /* Tighten container padding so cards reach the screen edge minus a small gutter */
  :root { --container-pad: var(--space-4); }

  /* Header: hide the caption on small screens, keep the mark + wordmark and actions */
  .site-header__inner { gap: var(--space-3); padding-block: var(--space-3); }
  .brand { gap: var(--space-2); }
  .brand__mark { width: 36px; height: 36px; }
  .brand__caption { display: none; }
  .brand__italic { font-size: var(--fs-md); }
  .lang-toggle { padding: var(--space-1) var(--space-2); font-size: 11px; }

  /* Hero blocks: trim outer padding on small screens */
  .hero, .hero--inner, .hero--editorial { padding-block: var(--space-6); }
  .cta-row { flex-direction: column; align-items: stretch; }
  .cta-row .btn { width: 100%; text-align: center; }

  /* Section padding tighter */
  .section { padding-block: var(--space-6); }
  .section__intro { margin-bottom: var(--space-4); font-size: var(--fs-sm); }

  /* Card images stay close to a comfortable square on phones */
  .card__image { aspect-ratio: 1 / 1; }
  .service-card__media { aspect-ratio: 16 / 10; }

  /* Footer stacks tightly */
  .site-footer__top { gap: var(--space-3); }

  /* Filter pill wraps cleanly */
  .filter-pill { width: 100%; justify-content: space-between; }

  /* Tables / admin lists become horizontally scrollable instead of overflowing */
  .admin-table, .admin-content table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }
}

/* ── Very small phones (≤ 380 px) ──────────────────────────────────────── */
@media (max-width: 380px) {
  :root { --container-pad: var(--space-3); }
  .brand__italic { font-size: var(--fs-sm); }
  .brand__mark { width: 32px; height: 32px; }
  .site-header__inner { gap: var(--space-2); }
}

/* ── Product detail ───────────────────────────────────────────────────── */
.product-detail__grid {
  display: grid; gap: var(--space-7); grid-template-columns: 1fr;
}
.product-detail__gallery img {
  border-radius: 0;
  box-shadow: var(--shadow-1);
  width: 100%; aspect-ratio: 4 / 5; object-fit: cover;
}
.product-detail__info h1 {
  font-size: clamp(2rem, 4vw + 1rem, 4rem);
  font-style: italic; font-weight: 500;
}
.product-detail__brand {
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-accent);
  margin-bottom: var(--space-3);
  display: block;
}
.price--xl {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  margin: var(--space-5) 0;
  color: var(--color-fg);
}
.product-detail__buy {
  display: flex; align-items: end; gap: var(--space-3); flex-wrap: wrap;
  margin-block: var(--space-6);
}
.product-detail__buy label {
  display: flex; flex-direction: column;
  font-size: var(--fs-xs); color: var(--color-muted);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
}
.product-detail__buy input[type="number"] {
  width: 80px; padding: var(--space-3);
  border: 1px solid var(--color-border); border-radius: 0;
  font-size: var(--fs-base); background: var(--color-bone);
}
.product-detail__details {
  border-top: 1px solid var(--color-border);
  padding-block: var(--space-4);
}
.product-detail__details summary {
  cursor: pointer; font-weight: 500;
  font-family: var(--font-display); font-size: var(--fs-lg);
  font-style: italic;
}

/* Shared shipping-cue icon (replaces the 🚚 emoji). */
.shipping-cue__icon {
  width: 1.3em; height: 1.3em; vertical-align: -0.28em;
  color: var(--color-accent); margin-right: 0.35em;
}
.shipping-cue--left { text-align: left; margin-top: var(--space-4); }

/* PDP trust row — reassurance directly under the buy button. */
.product-trust {
  list-style: none; margin: var(--space-5) 0 0; padding: var(--space-5) 0 0;
  border-top: 1px solid var(--color-border);
  display: grid; gap: var(--space-3);
}
.product-trust li {
  display: flex; align-items: center; gap: var(--space-3);
  font-size: var(--fs-sm); color: var(--color-fg-soft); line-height: var(--lh-snug);
}
.product-trust svg { width: 20px; height: 20px; flex: none; color: var(--color-accent); }

/* Mobile sticky add-to-cart — submits the main buy form via its `form` id. */
.pdp-sticky {
  position: fixed; inset: auto 0 0 0; z-index: 40;
  display: none; align-items: center; gap: var(--space-4);
  padding: var(--space-3) var(--container-pad);
  background: color-mix(in srgb, var(--color-bone) 93%, transparent);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border-top: 1px solid var(--color-border); box-shadow: var(--shadow-2);
}
.pdp-sticky__price {
  font-family: var(--font-display); font-size: var(--fs-lg);
  font-weight: 500; white-space: nowrap;
}
.pdp-sticky .btn { flex: 1; }
@media (max-width: 880px) {
  .pdp-sticky { display: flex; }
  body:has(.pdp-sticky) { padding-bottom: 72px; }
}

@media (min-width: 880px) {
  .product-detail__grid { grid-template-columns: 1fr 1fr; align-items: start; }
}

/* ── Two-column ───────────────────────────────────────────────────────── */
.two-col { display: grid; gap: var(--space-6); grid-template-columns: 1fr; }
@media (min-width: 880px) { .two-col { grid-template-columns: 1fr 1fr; } }
.map-card { margin: 0; }
.map-card iframe { width: 100%; height: 340px; border: 0; border-radius: 0; box-shadow: var(--shadow-1); }
.bullets { padding-left: 0; margin: var(--space-5) 0; list-style: none; }
.bullets li {
  margin-bottom: var(--space-3);
  position: relative;
  padding-left: var(--space-5);
}
.bullets li::before {
  content: ""; position: absolute; left: 0; top: 0.7em;
  width: 14px; height: 1px;
  background: var(--color-accent);
}

/* ── Promotions ───────────────────────────────────────────────────────── */
.promo-strip {
  background: var(--color-paper-2);
  padding-block: var(--space-5);
  border-block: 1px solid var(--color-border);
}
.promo-tiles {
  list-style: none; padding: 0; margin: 0;
  display: flex; gap: var(--space-4); flex-wrap: wrap;
  justify-content: center;
}
.promo-tile {
  background: var(--color-bone);
  border: 1px solid var(--color-accent);
  border-radius: 0;
  padding: var(--space-3) var(--space-5);
  display: inline-flex; gap: var(--space-4); align-items: center;
}
.promo-tile__code {
  font-family: var(--font-mono);
  background: var(--color-accent); color: var(--color-paper);
  padding: var(--space-1) var(--space-3);
  letter-spacing: var(--tracking-wide);
  font-size: var(--fs-xs);
  font-weight: 600;
}
.promo-tile__desc { color: var(--color-fg-soft); font-size: var(--fs-sm); }
.shipping-cue {
  text-align: center; margin-top: var(--space-6);
  color: var(--color-fg-soft);
  font-family: var(--font-display); font-style: italic; font-size: var(--fs-md);
}

/* ── Testimonials ─────────────────────────────────────────────────────── */
.testimonial-grid { display: grid; gap: var(--space-6); grid-template-columns: 1fr; }
.testimonial {
  background: var(--color-bone);
  border: 1px solid var(--color-border);
  border-radius: 0;
  padding: var(--space-6);
  margin: 0;
  position: relative;
}
.testimonial::before {
  content: "“";
  position: absolute; top: var(--space-3); left: var(--space-5);
  font-family: var(--font-display);
  font-size: 5rem; line-height: 1;
  color: var(--color-accent);
  opacity: 0.4;
}
.testimonial p {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-lg);
  line-height: var(--lh-snug);
  margin: var(--space-6) 0 var(--space-4);
}
.testimonial footer {
  display: flex; align-items: center; justify-content: space-between;
  color: var(--color-muted); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-3);
}
.stars { color: var(--color-accent); letter-spacing: 2px; }
@media (min-width: 880px) { .testimonial-grid { grid-template-columns: repeat(2, 1fr); } }

/* ── FAQ ──────────────────────────────────────────────────────────────── */
.faq { display: grid; gap: 0; }
.faq__item {
  border-bottom: 1px solid var(--color-border);
  padding-block: var(--space-5);
}
.faq__item dt {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-lg);
  font-weight: 500;
  margin-bottom: var(--space-3);
}
.faq__item dd { margin: 0; color: var(--color-fg-soft); }

/* ── Cart ─────────────────────────────────────────────────────────────── */
.cart-layout { display: grid; gap: var(--space-7); grid-template-columns: 1fr; }
@media (min-width: 980px) { .cart-layout { grid-template-columns: 2fr 1fr; align-items: start; } }
.cart-table { width: 100%; border-collapse: collapse; }
.cart-table th, .cart-table td {
  text-align: left; padding: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.cart-table th {
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
  font-weight: 600;
}
.qty-form { display: inline-flex; gap: var(--space-2); align-items: center; }
/* Live-update busy state: dim + lock the cart while a change is in flight
   (cart.js toggles aria-busy). Avoids disabling inputs, which would drop them
   from the submitted form data. */
.cart-layout[aria-busy="true"] { opacity: 0.55; pointer-events: none; transition: opacity var(--duration-fast) var(--ease); }
.qty-form input {
  width: 64px; padding: var(--space-2);
  border: 1px solid var(--color-border); border-radius: 0;
  font-size: var(--fs-base);
}
.link {
  background: none; border: 0; padding: 0;
  color: var(--color-accent); cursor: pointer;
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  font-weight: 500;
}
.empty-state {
  font-family: var(--font-display); font-style: italic;
  font-size: var(--fs-2xl); color: var(--color-muted);
  text-align: center; padding: var(--space-7) var(--space-4);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
}
.cart-summary {
  background: var(--color-bone);
  border: 1px solid var(--color-border); border-radius: 0;
  padding: var(--space-6);
}
/* Booking status pill — used on the public reserver_confirmed page (the
   admin.css copies aren't loaded on the public site). Token-based so it
   re-themes with the rest of the site. */
.status-line { margin: var(--space-3) 0 var(--space-4); }
.status {
  display: inline-block;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-pill);
  font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.04em;
  background: var(--color-paper-2); color: var(--color-fg);
}
.status--pending { background: var(--color-brass-soft); color: var(--color-fg); }

.summary-list { display: grid; gap: var(--space-2); margin: 0 0 var(--space-5); }
.summary-list > div { display: flex; justify-content: space-between; }
.summary-list dt {
  color: var(--color-muted); margin: 0;
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}
.summary-list dd { margin: 0; font-weight: 500; font-family: var(--font-display); }
.summary-list__total {
  border-top: 1px solid var(--color-fg); padding-top: var(--space-4);
  font-size: var(--fs-lg); font-weight: 700;
}
.summary-list__total dt { font-weight: 600; color: var(--color-fg); }
.summary-list__total dd { font-size: var(--fs-xl); font-weight: 500; }

.promo-form, .checkout-form { display: grid; gap: var(--space-3); margin-top: var(--space-5); }
.promo-form { grid-template-columns: 1fr auto; align-items: end; gap: var(--space-3); }
.promo-form label { grid-column: 1 / -1; font-size: var(--fs-xs); color: var(--color-muted); text-transform: uppercase; letter-spacing: var(--tracking-wide); }
.promo-form input {
  padding: var(--space-3); border: 1px solid var(--color-border); border-radius: 0;
  background: var(--color-bone);
}
.checkout-form fieldset { border: 0; padding: 0; margin: 0; display: grid; gap: var(--space-3); }
.checkout-form legend {
  font-family: var(--font-display); font-style: italic;
  font-size: var(--fs-lg); font-weight: 500;
  padding: 0; margin-bottom: var(--space-3);
}
.checkout-form label {
  display: grid; gap: var(--space-2);
  font-size: var(--fs-xs); color: var(--color-muted);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
}
.checkout-form input, .checkout-form textarea {
  padding: var(--space-4); border: 1px solid var(--color-border);
  border-radius: 0; font-family: inherit; font-size: var(--fs-base);
  background: var(--color-bone);
  color: var(--color-fg);
}
.checkout-form input:focus, .checkout-form textarea:focus, .checkout-form select:focus {
  outline: 2px solid var(--color-accent); outline-offset: 1px; border-color: var(--color-accent);
}
.checkout-form__shipping label { display: inline-flex; gap: var(--space-2); align-items: center; }
.checkout-form button[type="submit"] { width: 100%; margin-top: var(--space-4); }

/* ── Form (contact) ───────────────────────────────────────────────────── */
.form { display: grid; gap: var(--space-3); max-width: 520px; }
.form label {
  display: grid; gap: var(--space-2);
  font-size: var(--fs-xs); color: var(--color-muted);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
}
.form input, .form textarea {
  padding: var(--space-4); border: 1px solid var(--color-border);
  border-radius: 0; font-family: inherit; font-size: var(--fs-base);
  background: var(--color-bone); color: var(--color-fg);
}
.form input:focus, .form textarea:focus { outline: 2px solid var(--color-accent); outline-offset: 1px; border-color: var(--color-accent); }
.alert { padding: var(--space-4); border-radius: 0; border-left: 3px solid; font-size: var(--fs-sm); }
.alert--success { background: var(--color-success-soft); color: var(--color-success); border-left-color: var(--color-success); }
.alert--error { background: var(--color-error-soft); color: var(--color-error); border-left-color: var(--color-error); }

/* ── Lists ────────────────────────────────────────────────────────────── */
.numbered-list { padding-left: 1.2em; }
.numbered-list li { margin-bottom: var(--space-3); }

.social { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--space-2); }
.social--row { display: inline-flex; gap: var(--space-4); }
.hours { list-style: none; padding: 0; margin: 0; color: var(--color-fg-soft); }
.hours li { padding-block: var(--space-1); font-size: var(--fs-sm); }

/* ── Footer ───────────────────────────────────────────────────────────── */
.site-footer {
  /* Readable paper tint for muted footer copy on the noir ground. The base
     `.hours` color (--color-fg-soft) is a dark ink meant for light surfaces. */
  --footer-muted: color-mix(in srgb, var(--color-paper) 84%, transparent);
  background: var(--color-ink-950);
  color: var(--color-paper);
  padding-block: var(--space-8) var(--space-6);
  margin-top: var(--space-9);
}
.site-footer a { color: var(--color-paper-2); border-bottom-color: transparent; }
.site-footer a:hover { color: var(--color-brass); border-bottom-color: var(--color-brass); }

.site-footer__top {
  text-align: center;
  padding-bottom: var(--space-7);
  border-bottom: 1px solid color-mix(in srgb, var(--color-paper) 16%, transparent);
  margin-bottom: var(--space-7);
}
.site-footer__seal {
  width: clamp(132px, 18vw, 168px);
  margin: 0 auto;
  color: var(--color-brass-bright);
}
.site-footer__seal svg { width: 100%; height: auto; display: block; }
.site-footer__tagline {
  margin: 0;
  color: var(--color-paper-2);
  font-size: var(--fs-sm);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}
.site-footer__grid {
  display: grid; gap: var(--space-6);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .site-footer__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .site-footer__grid { grid-template-columns: repeat(4, 1fr); } }
.footer-block__title {
  text-transform: uppercase; letter-spacing: var(--tracking-wider);
  font-size: var(--fs-xs); font-weight: 600;
  color: var(--color-brass);
  margin: 0 0 var(--space-4);
  font-family: var(--font-body);
}
.footer-block__handle {
  margin-top: var(--space-3);
  font-size: var(--fs-sm);
  color: var(--color-ink-300);
}
.footer-block address {
  font-style: normal; font-size: var(--fs-sm);
  color: var(--footer-muted);
  line-height: var(--lh-loose);
}
.footer-links, .site-footer .social, .site-footer .hours {
  list-style: none; padding: 0; margin: 0;
}
.footer-links li, .site-footer .social li, .site-footer .hours li {
  padding-block: var(--space-1); font-size: var(--fs-sm);
}
/* Hours sit on the noir footer, not a light surface — override the dark base. */
.site-footer .hours { color: var(--footer-muted); }
.site-footer__base {
  border-top: 1px solid color-mix(in srgb, var(--color-paper) 12%, transparent);
  padding-top: var(--space-5); margin-top: var(--space-7);
  color: color-mix(in srgb, var(--color-paper) 55%, transparent);
  font-size: var(--fs-xs);
  text-align: center;
  display: flex; flex-direction: column; gap: var(--space-2);
}
.site-footer__signature {
  font-family: var(--font-display); font-style: italic;
  color: color-mix(in srgb, var(--color-paper) 70%, transparent);
  font-size: var(--fs-sm);
  margin: 0;
}
.site-footer__base p { margin: 0; }

/* ── Brand page ───────────────────────────────────────────────────────── */
/* Note: an earlier `.brand-page .brand-hero` / `.brand-hero__{eyebrow,accent,…}`
   set lived here but was dead — no template references `.brand-page` and the
   active brand hero (see “Brand showcase” below) owns the `.brand-hero__*`
   namespace used by templates/pages/marque.html. Removed to end the collision. */
.brand-block { padding-block: var(--space-9); }
.brand-block + .brand-block { border-top: 1px solid var(--color-border); }
.brand-block__index {
  font-family: var(--font-mono); font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  color: var(--color-accent);
}
.brand-block__title {
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-weight: 500;
  margin: var(--space-3) 0 var(--space-5);
  line-height: 1.05;
}
.brand-block__lead {
  font-family: var(--font-display); font-style: italic;
  font-size: var(--fs-xl);
  color: var(--color-fg-soft);
  max-width: 52ch;
  margin-bottom: var(--space-7);
}
.brand-grid {
  display: grid; gap: var(--space-6);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .brand-grid--2 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 980px) { .brand-grid--3 { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 980px) { .brand-grid--4 { grid-template-columns: repeat(4, 1fr); } }

.brand-card {
  background: var(--color-bone);
  border: 1px solid var(--color-border);
  padding: var(--space-6);
  display: grid; gap: var(--space-4);
}
.brand-card--dark {
  background: var(--color-ink-950); color: var(--color-paper);
  border-color: var(--color-ink-800);
}
.brand-card__label {
  font-family: var(--font-body);
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
}
.brand-card--dark .brand-card__label { color: color-mix(in srgb, var(--color-paper) 62%, transparent); }
.brand-card__title {
  font-family: var(--font-display); font-style: italic;
  font-size: var(--fs-xl); margin: 0;
}
.brand-card svg, .brand-card img {
  width: 100%; height: auto; display: block;
}
.brand-card__caption {
  font-size: var(--fs-sm); color: var(--color-fg-soft);
  margin: 0;
}

/* `.swatch` (+ modifiers, `__name`, `__hex`) is defined once in the palette
   block below. An earlier chip/meta swatch variant lived here but was dead
   (no template used `.swatch__chip`/`.swatch__meta`) and its `.swatch__name`
   forced a fixed ink colour that fought the tile modifiers — removed. */
.specimen {
  display: grid; gap: var(--space-4);
  padding-block: var(--space-5);
  border-block: 1px solid var(--color-border);
}
.specimen__meta {
  font-family: var(--font-body); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
}
.specimen__sample-display {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(3rem, 10vw, 7rem);
  line-height: 0.95; letter-spacing: var(--tracking-tight);
  margin: 0;
}
.specimen__sample-italic {
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(2rem, 6vw, 4rem);
  margin: 0;
}
.specimen__sample-body {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  line-height: var(--lh-base);
  max-width: 56ch;
  margin: 0;
}
.specimen__scale {
  display: grid; gap: var(--space-3);
  margin-top: var(--space-4);
}
.specimen__scale-row {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--space-5); align-items: baseline;
}
.specimen__scale-row dt {
  font-family: var(--font-mono);
  font-size: var(--fs-xs); color: var(--color-muted);
  letter-spacing: var(--tracking-wide);
}
.specimen__scale-row dd {
  margin: 0;
  font-family: var(--font-display);
}

.illus-thumb {
  background: var(--color-bone);
  border: 1px solid var(--color-border);
  aspect-ratio: 1;
  display: grid; place-items: center;
  padding: var(--space-5);
  color: var(--color-fg);
  transition: border-color var(--duration-base) var(--ease),
              color var(--duration-base) var(--ease);
}
.illus-thumb:hover { border-color: var(--color-accent); color: var(--color-accent); }
.illus-thumb svg { width: 100%; height: 100%; }
.illus-thumb__label {
  font-family: var(--font-body); font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: var(--tracking-wider);
  text-align: center; color: var(--color-muted);
  margin: var(--space-3) 0 0;
}

.pkg-showcase {
  background: var(--color-paper-2);
  padding: var(--space-7) var(--space-5);
  display: grid; place-items: center;
  border: 1px solid var(--color-border);
}
.pkg-showcase img { max-width: 100%; max-height: 580px; width: auto; }
.pkg-showcase--single img { max-height: 480px; }

.voice-pair {
  display: grid; gap: var(--space-3);
}
.voice-pair__do, .voice-pair__dont {
  padding: var(--space-5);
  border: 1px solid var(--color-border);
  font-family: var(--font-display); font-style: italic;
  font-size: var(--fs-lg);
  line-height: var(--lh-snug);
}
.voice-pair__do { border-left: 3px solid var(--color-accent); background: var(--color-bone); }
.voice-pair__dont { border-left: 3px solid var(--color-muted); color: var(--color-muted); }
.voice-pair__tag {
  display: block; font-family: var(--font-body); font-style: normal;
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wider); color: var(--color-accent);
  margin-bottom: var(--space-2);
}
.voice-pair__dont .voice-pair__tag { color: var(--color-muted); }

/* ── Brand showcase (/marque · /brand) ────────────────────────────────── */
.brand-hero {
  background: var(--color-bg-deep);
  padding-block: var(--space-8);
  border-bottom: 1px solid var(--color-border);
}
.brand-hero__grid {
  display: grid; gap: var(--space-7); grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 880px) { .brand-hero__grid { grid-template-columns: 1.1fr 1fr; } }
.brand-hero__display {
  font-family: var(--font-display);
  font-size: clamp(4rem, 12vw, 8.5rem);
  font-weight: 400; line-height: 0.95;
  letter-spacing: var(--tracking-tight);
  margin: var(--space-3) 0 var(--space-2); color: var(--color-fg);
}
.brand-hero__italic { font-style: italic; display: block; font-size: 0.5em; font-weight: 500; }
.brand-hero__numeral { display: block; font-weight: 500; }
.brand-hero__rule { width: 88px; height: 2px; background: var(--color-accent); border: 0; margin: var(--space-3) 0; }
.brand-hero__caption {
  font-family: var(--font-display); font-style: italic;
  font-size: var(--fs-xl); font-weight: 500; margin: 0 0 var(--space-2);
  color: var(--color-fg-soft);
}
.brand-hero__address { font-size: var(--fs-sm); color: var(--color-muted); letter-spacing: 0.02em; }
.brand-hero__lockup svg {
  width: 100%; max-width: 360px; height: auto;
  box-shadow: var(--shadow-3); border-radius: var(--radius-md);
}

.brand-section { padding-block: var(--space-7); }
.brand-section--paper { background: var(--color-paper-2); }
.brand-section--noir {
  background:
    radial-gradient(ellipse 1200px 600px at 50% 30%, var(--color-noir-1), var(--color-noir-3) 60%, var(--color-noir-4) 100%);
  color: var(--color-paper);
  padding-block: var(--space-8);
}
.brand-section--noir .eyebrow { color: var(--color-accent-on-noir); }
.brand-section--noir h2 { color: var(--color-paper); }
.brand-section--noir .brand-section__lede { color: var(--color-paper-muted-on-noir-2); }
.brand-section--noir .mockup figcaption {
  color: var(--color-paper-muted-on-noir-3);
  font-size: var(--fs-sm);
  margin-top: var(--space-3);
  text-align: center;
}
.brand-section--noir .mockup {
  background:
    radial-gradient(ellipse 80% 50% at 50% 100%, var(--color-noir-6), transparent 80%),
    linear-gradient(155deg, var(--color-noir-1), var(--color-noir-3) 60%, var(--color-noir-2));
  border: 1px solid var(--color-ink-700);
  border-radius: var(--radius-md);
  padding: var(--space-5) var(--space-4) var(--space-4);
  position: relative;
  transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
  box-shadow: 0 4px 18px hsla(22, 14%, 0%, 0.45);
}
.brand-section--noir .mockup::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, color-mix(in srgb, var(--color-paper) 4%, transparent), transparent 30%);
  pointer-events: none;
}
.brand-section--noir .mockup:hover {
  transform: translateY(-4px);
  border-color: var(--color-accent-noir-glow);
  box-shadow: 0 16px 40px hsla(22, 14%, 0%, 0.7), 0 0 0 1px color-mix(in srgb, var(--color-accent-noir-glow) 20%, transparent);
}
.noir-coda {
  margin-top: var(--space-6);
  text-align: center;
  color: var(--color-paper-muted-on-noir-soft);
  font-size: var(--fs-sm);
  letter-spacing: var(--tracking-snug);
}

/* ── Home Studio Noir spotlight ─────────────────────────────────────── */
.section--noir {
  background:
    radial-gradient(ellipse 1400px 700px at 20% 50%, var(--color-noir-1), var(--color-ink-900) 60%, var(--color-noir-5) 100%);
  color: var(--color-paper);
  padding-block: var(--space-8);
  margin-block: var(--space-7);
  position: relative;
  overflow: hidden;
}
.section--noir::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--color-accent-noir-glow) 6%, transparent) 50%, transparent);
  pointer-events: none;
}
.noir-strip {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: center;
}
@media (min-width: 880px) {
  .noir-strip { grid-template-columns: 1.1fr 1fr; gap: var(--space-7); }
}
.noir-strip__copy .eyebrow { color: var(--color-accent-on-noir); }
.noir-strip__copy h2 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(2.4rem, 5vw + 1rem, 4rem);
  letter-spacing: var(--tracking-snug);
  line-height: 1.05;
  color: var(--color-paper);
  margin: var(--space-3) 0;
}
.noir-strip__lede {
  color: var(--color-paper-muted-on-noir);
  font-size: var(--fs-md);
  line-height: var(--lh-snug);
  max-width: 52ch;
}
.noir-strip__ctas {
  margin-top: var(--space-5);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
  align-items: center;
}
.noir-strip__btn {
  background: transparent;
  border-color: var(--color-accent-on-noir);
  color: var(--color-accent-on-noir);
}
.noir-strip__btn:hover { color: var(--color-paper); border-color: var(--color-paper); }
.section--noir .link--quiet {
  color: var(--color-paper-muted-on-noir-2);
  border-bottom: 1px solid color-mix(in srgb, var(--color-paper-muted-on-noir-2) 25%, transparent);
}
.section--noir .link--quiet:hover { color: var(--color-paper); border-color: var(--color-accent-noir-line); }
.noir-strip__showcase {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--space-4);
  align-items: center;
}
@media (max-width: 720px) { .noir-strip__showcase { grid-template-columns: 1fr; } }
.noir-strip__hero {
  width: 100%;
  max-width: 360px;
  aspect-ratio: 1 / 1;
  margin: 0 auto;
  border-radius: 2px;
  overflow: hidden;
  box-shadow: 0 24px 56px hsla(22, 14%, 0%, 0.55), 0 0 0 1px color-mix(in srgb, var(--color-paper) 4%, transparent);
}
.noir-strip__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
.noir-strip__grid img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  background:
    radial-gradient(ellipse 80% 50% at 50% 100%, var(--color-noir-6), transparent 80%),
    linear-gradient(155deg, var(--color-noir-1), var(--color-noir-3) 60%, var(--color-noir-2));
  border: 1px solid var(--color-ink-700);
  padding: var(--space-4);
  box-shadow: 0 6px 22px hsla(22, 14%, 0%, 0.5);
  transition: transform 0.4s ease;
}
.noir-strip__grid img:hover { transform: translateY(-3px) rotate(-0.5deg); }

/* ── Canonical brand mark ──────────────────────────────────────────────
   The square monogram used in headers, og-image, footer, and the brand
   page. Inherits ink colour from `color:` (so it can be re-themed via
   the parent — cream on noir, or ink on paper). */
.brand-mark { display: inline-block; }
.brand-mark__svg { display: block; width: 100%; height: auto; }
.brand-mark__square { fill: currentColor; }
.brand-mark__type   { fill: var(--brand-mark-fg, var(--color-paper)); }
.brand-mark__numeral { fill: var(--brand-mark-fg, var(--color-paper)); }
.brand-mark__rule   { stroke: var(--color-accent); }
.brand-mark--noir {
  color: var(--color-ink-950);
  --brand-mark-fg: var(--color-paper);
  box-shadow: 0 8px 28px hsla(22, 14%, 0%, 0.18);
  border-radius: 2px;
}
.brand-mark--paper {
  color: var(--color-paper);
  --brand-mark-fg: var(--color-ink-950);
  border: 1px solid var(--color-border);
}

/* Tag filter pill on /produits */
.filter-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-bg-elevated);
  margin-bottom: var(--space-5);
  font-size: var(--fs-sm);
}
.filter-pill__label { color: var(--color-muted); text-transform: uppercase; letter-spacing: var(--tracking-wider); font-size: var(--fs-xs); }
.filter-pill__clear {
  color: var(--color-accent);
  text-decoration: none;
  margin-left: var(--space-2);
}
.filter-pill__clear:hover { text-decoration: underline; }
/* `.empty-state` is defined once near the cart/booking utilities (merged from
   a duplicate that previously lived here). */
.brand-section__head { max-width: var(--container-narrow); margin: 0 auto var(--space-6); text-align: center; }
.brand-section__head h2 {
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: clamp(2rem, 4vw + 1rem, var(--fs-2xl));
  letter-spacing: var(--tracking-snug); line-height: 1.15;
  margin: var(--space-3) 0;
}
.brand-section__lede {
  color: var(--color-fg-soft); max-width: 56ch; margin: 0 auto;
  font-size: var(--fs-md); line-height: var(--lh-snug);
}

.type-grid { display: grid; gap: var(--space-5); grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.type-spec {
  background: var(--color-bg-elevated); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-5);
}
.type-spec__label {
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wider); color: var(--color-accent);
}
.type-spec__sample {
  font-size: clamp(3rem, 4vw + 1rem, 4.5rem); line-height: 1;
  margin: var(--space-3) 0; color: var(--color-fg);
}
.type-spec__sample--display { font-family: var(--font-display); font-weight: 500; }
.type-spec__sample--body    { font-family: var(--font-body); font-weight: 400; letter-spacing: 0.01em; }
.type-spec__sample--script  { font-family: var(--font-script); }
.type-spec__name { margin: 0 0 var(--space-1); font-weight: 600; }
.type-spec__weights { color: var(--color-muted); font-size: var(--fs-sm); margin: 0; }

.palette-grid { display: grid; gap: var(--space-3); grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.swatch {
  padding: var(--space-6) var(--space-5);
  border-radius: var(--radius-md);
  display: flex; flex-direction: column; gap: var(--space-3);
  aspect-ratio: 4/3; justify-content: flex-end;
}
.swatch--bordered { border: 1px solid var(--color-border); }
.swatch--noir    { background: var(--color-ink-950); color: var(--color-paper); }
.swatch--oxblood { background: var(--color-accent);  color: var(--color-paper); }
.swatch--brass   { background: var(--color-brass);   color: var(--color-ink-950); }
.swatch--bone    { background: var(--color-paper);   color: var(--color-ink-900); }
.swatch--ivoire  { background: var(--color-bone);    color: var(--color-ink-900); }
.swatch__name { font-family: var(--font-display); font-style: italic; font-weight: 500; font-size: var(--fs-md); margin: 0; }
.swatch__hex { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.06em; margin: 0; opacity: 0.85; }

.mockup-grid { display: grid; gap: var(--space-5); grid-template-columns: 1fr; }
.mockup-grid--cards { grid-template-columns: 1fr; }
@media (min-width: 720px) { .mockup-grid--cards { grid-template-columns: 1fr 1fr; } }
.mockup-grid--bottles { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.mockup-grid--folder { grid-template-columns: 1fr; gap: var(--space-7); }
.mockup-grid--noir { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
@media (min-width: 880px) { .mockup-grid--noir { grid-template-columns: repeat(4, 1fr); gap: var(--space-4); } }
.mockup-grid--noir .mockup svg {
  width: 100%; max-width: 280px; height: auto; display: block; margin: 0 auto;
  filter: drop-shadow(0 16px 40px hsla(22, 14%, 0%, 0.55));
}
@media (min-width: 880px) { .mockup-grid--folder { grid-template-columns: 1.4fr 1fr; align-items: end; } }

.mockup { margin: 0; display: flex; flex-direction: column; gap: var(--space-3); }
.mockup svg {
  width: 100%; height: auto;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-2);
  background: transparent;
}
.mockup--bottle svg, .mockup--tote svg {
  box-shadow: none; filter: drop-shadow(0 18px 32px rgba(15,12,8,0.18));
}
.mockup figcaption {
  font-family: var(--font-display); font-style: italic;
  color: var(--color-fg-soft); font-size: var(--fs-sm);
  text-align: center; margin-top: var(--space-2);
}

.brand-cta { text-align: center; max-width: var(--container-narrow); margin: 0 auto; }
.brand-cta h2 {
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: clamp(2rem, 4vw + 1rem, var(--fs-2xl));
  margin: var(--space-3) 0 var(--space-5);
  letter-spacing: var(--tracking-snug);
}
.brand-cta .cta-row { justify-content: center; }

/* ── Additional marque blocks: motion · illustrations · voice · manifesto ─ */
.motion-stage {
  background: var(--color-ink-950); color: var(--color-paper);
  border: 1px solid var(--color-ink-800);
  aspect-ratio: 1 / 1;
  display: grid; place-items: center;
  position: relative; overflow: hidden;
  padding: var(--space-5);
}
.motion-stage > svg { width: 100%; height: 100%; display: block; }
.motion-stage--paper {
  background: var(--color-paper); color: var(--color-fg);
  border-color: var(--color-border);
}
.motion-pair {
  display: grid; gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .motion-pair { grid-template-columns: 1fr 1fr; } }
.motion-caption {
  font-family: var(--font-display); font-style: italic;
  font-size: var(--fs-md); color: var(--color-fg-soft);
  max-width: 48ch;
  margin-top: var(--space-4);
}

.illus-grid {
  display: grid; gap: var(--space-4);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 720px) { .illus-grid { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1080px) { .illus-grid { grid-template-columns: repeat(6, 1fr); } }
.illus-tile {
  display: grid; gap: var(--space-3);
  text-align: center;
  background: var(--color-bone);
  border: 1px solid var(--color-border);
  padding: var(--space-5) var(--space-4);
  aspect-ratio: 1; place-content: center;
  color: var(--color-fg);
  transition: color var(--duration-base) var(--ease),
              border-color var(--duration-base) var(--ease);
}
.illus-tile:hover { color: var(--color-accent); border-color: var(--color-accent); }
.brand-section--paper .illus-tile { background: var(--color-paper); }
.illus-tile img, .illus-tile svg {
  width: 58%; height: auto; margin-inline: auto; display: block;
  color: currentColor;
}
.illus-tile span {
  font-family: var(--font-body);
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
}

.voice-grid {
  display: grid; gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) { .voice-grid { grid-template-columns: 1fr 1fr; } }
.voice-col {
  background: var(--color-bone);
  border: 1px solid var(--color-border);
  padding: var(--space-6);
  display: grid; gap: var(--space-3);
}
.brand-section--paper .voice-col { background: var(--color-paper); }
.voice-col h3 {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-xl);
  margin: 0;
  font-weight: 500;
}
.voice-col__intro {
  color: var(--color-fg-soft);
  font-size: var(--fs-sm);
  margin: 0 0 var(--space-3);
}
.voice-col--do { border-left: 3px solid var(--color-accent); }
.voice-col--dont { border-left: 3px solid var(--color-muted); }
.voice-col__list {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 0;
}
.voice-col__list li {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-md);
  color: var(--color-fg);
  line-height: var(--lh-snug);
  padding: var(--space-4) 0;
  border-top: 1px dashed var(--color-border);
}
.voice-col__list li:first-child { border-top: 0; }
.voice-col--dont .voice-col__list li { color: var(--color-muted); }

.tone-strip {
  display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-5);
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(1.5rem, 3vw + 0.5rem, 2.5rem);
  line-height: 1.1;
  color: var(--color-fg);
  margin-top: var(--space-5);
}
.tone-strip span {
  display: inline-block;
  position: relative;
  padding-right: var(--space-5);
}
.tone-strip span:not(:last-child)::after {
  content: "·";
  position: absolute; right: 0; top: 50%;
  transform: translateY(-50%);
  color: var(--color-accent);
  font-style: normal;
}

.manifesto {
  background: var(--color-ink-950); color: var(--color-paper);
  padding-block: clamp(var(--space-7), 12vw, var(--space-9));
  position: relative; overflow: hidden;
  text-align: center;
}
.manifesto::after {
  content: ""; position: absolute; inset: 24px;
  border: 1px solid color-mix(in srgb, var(--color-paper) 16%, transparent);
  pointer-events: none;
}
.manifesto .container { position: relative; z-index: 1; }
.manifesto .eyebrow {
  color: color-mix(in srgb, var(--color-paper) 70%, transparent);
  justify-content: center;
}
.manifesto .eyebrow::before { background: color-mix(in srgb, var(--color-paper) 50%, transparent); }
.manifesto blockquote {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.75rem, 3.5vw + 1rem, 3.5rem);
  line-height: 1.18;
  margin: var(--space-6) auto 0;
  max-width: 26ch;
  color: var(--color-paper);
}
.manifesto cite {
  display: block;
  font-family: var(--font-body);
  font-style: normal;
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: color-mix(in srgb, var(--color-paper) 62%, transparent);
  margin-top: var(--space-5);
}
.manifesto__rule {
  display: inline-block; width: 64px; height: 2px;
  background: var(--color-accent);
  margin-block: var(--space-4);
}

/* ── Home page maison intro ───────────────────────────────────────────── */
.maison {
  background: var(--color-paper);
  padding-block: clamp(var(--space-7), 12vw, var(--space-9));
  border-bottom: 1px solid var(--color-border);
  position: relative; overflow: hidden;
}
.maison::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 8% 10%, color-mix(in srgb, var(--color-accent) 5%, transparent), transparent 45%),
    radial-gradient(circle at 92% 90%, color-mix(in srgb, var(--color-brass) 8%, transparent), transparent 50%);
  pointer-events: none;
}
.maison__grid {
  display: grid; gap: var(--space-7);
  grid-template-columns: 1fr;
  align-items: center;
  position: relative; z-index: 1;
}
@media (min-width: 880px) {
  .maison__grid { grid-template-columns: 1.05fr 1fr; gap: var(--space-8); }
}
.maison__type { display: grid; gap: var(--space-3); }
.maison__display {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 0.88;
  letter-spacing: var(--tracking-tight);
  margin: var(--space-2) 0 var(--space-1);
  display: grid; gap: var(--space-2);
}
.maison__display .maison__italic {
  font-style: italic; font-weight: 400;
  font-size: clamp(1.75rem, 3.5vw, 3rem);
  color: var(--color-fg-soft);
  letter-spacing: var(--tracking-snug);
}
.maison__display .maison__numeral {
  font-size: clamp(4.5rem, 14vw, 11rem);
  letter-spacing: 0.04em;
  color: var(--color-fg);
}
.maison__rule {
  display: inline-block; width: 96px; height: 2px;
  background: var(--color-accent);
  margin: var(--space-3) 0;
}
.maison__tagline {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.5rem, 2.5vw + 0.5rem, 2.5rem);
  margin: 0;
  line-height: 1.18;
  color: var(--color-fg);
  max-width: 18ch;
}
.maison__manifesto {
  max-width: 44ch;
  font-size: var(--fs-md);
  color: var(--color-fg-soft);
  margin: var(--space-4) 0 var(--space-5);
}
.maison__cta { display: inline-flex; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-3); }
.maison__motion {
  position: relative;
  background: var(--color-bone);
  border: 1px solid var(--color-border);
  padding: var(--space-5);
}
.maison__motion svg {
  width: 100%; height: auto; display: block;
  color: var(--color-fg);
}
.maison__caption {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
  display: inline-flex; gap: var(--space-3); align-items: center;
  margin-top: var(--space-4);
}
.maison__caption::before {
  content: ""; width: 24px; height: 1px; background: var(--color-accent);
}

.book-step { padding-block: var(--space-8); }
.book-step__progress {
  display: flex; align-items: center; gap: var(--space-3);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
  margin-bottom: var(--space-6);
}
.book-step__progress strong { color: var(--color-fg); }

.brand-index {
  background: var(--color-paper-2);
  padding-block: var(--space-4);
  border-block: 1px solid var(--color-border);
  display: none;
}
@media (min-width: 980px) { .brand-index { display: block; } }
.brand-index__list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-5);
  justify-content: center; align-items: center;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
}
.brand-index__list a {
  color: var(--color-muted);
  padding-block: var(--space-1);
}
.brand-index__list a:hover { color: var(--color-fg); border-bottom-color: var(--color-accent); }

/* ── Home hero — editorial type-first opener ─────────────────────────── */
.hero--editorial {
  --hero-photo: url("/static/img/photos/hair-stations.webp");
  padding-block: clamp(var(--space-5), 5vw, var(--space-7))
                 clamp(var(--space-6), 7vw, var(--space-8));
  /* Atmospheric salon photo, faded deep into the paper so the editorial type
     stays crisp. Warm overlay + brand radials sit above the image. */
  background:
    radial-gradient(ellipse 1100px 480px at 50% -10%, color-mix(in srgb, var(--color-accent-warm) 6%, transparent), transparent 65%),
    radial-gradient(ellipse 700px 460px at 50% 118%, color-mix(in srgb, var(--color-brass) 8%, transparent), transparent 60%),
    linear-gradient(to bottom,
      color-mix(in srgb, var(--color-paper) 88%, transparent),
      color-mix(in srgb, var(--color-paper) 80%, transparent) 45%,
      color-mix(in srgb, var(--color-paper) 90%, transparent)),
    var(--hero-photo) center 38% / cover no-repeat;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.hero-editorial__wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}
.hero-editorial__eyebrow {
  margin: 0;
  /* Hero already has its own oxblood accents (ampersand + rule between
     lines), so the eyebrow drops its leading rule to keep the centered
     block visually balanced. */
  gap: 0;
}
.hero-editorial__eyebrow::before { display: none; }
.hero-editorial__display {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.75rem, 7vw + 1rem, 6.5rem);
  line-height: 0.95;
  letter-spacing: var(--tracking-tight);
  color: var(--color-fg);
  margin: 0;
  display: grid;
  justify-items: center;
  gap: clamp(var(--space-2), 1vw, var(--space-3));
  max-width: 18ch;
}
.hero-editorial__italic {
  font-style: italic;
  display: block;
}
.hero-editorial__amp {
  font-style: italic;
  font-weight: 400;
  color: var(--color-accent);
  font-size: 0.78em;
  line-height: 1;
  display: block;
}
.hero-editorial__rule {
  display: block;
  width: clamp(48px, 6vw, 88px);
  height: 1px;
  background: var(--color-accent);
  margin: clamp(var(--space-2), 1vw, var(--space-3)) 0;
  opacity: 0.55;
}
.hero-editorial__sub {
  font-size: clamp(1.1rem, 1.4vw + 0.5rem, 1.6rem);
  font-style: italic;
  font-weight: 400;
  color: var(--color-fg-soft);
  letter-spacing: var(--tracking-snug);
  display: block;
}
.hero-editorial__lede {
  margin: 0;
  max-width: 56ch;
  font-size: clamp(var(--fs-base), 0.8vw + 0.7rem, var(--fs-md));
  line-height: 1.65;
  color: var(--color-fg-soft);
}
.hero-editorial__ctas {
  margin-top: var(--space-2);
  justify-content: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.hero-editorial__trust {
  list-style: none;
  padding: 0;
  margin: var(--space-3) 0 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: clamp(var(--space-3), 2vw, var(--space-5));
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
}
.hero-editorial__trust li {
  position: relative;
}
.hero-editorial__trust li + li::before {
  content: "·";
  position: absolute;
  left: calc(clamp(var(--space-3), 2vw, var(--space-5)) * -0.5);
  top: 50%;
  transform: translate(-50%, -50%);
  color: var(--color-brass);
  opacity: 0.6;
}
@media (max-width: 640px) {
  .hero-editorial__wrap { gap: var(--space-4); }
  .hero-editorial__display { max-width: 14ch; }
  .hero-editorial__trust {
    gap: var(--space-3);
    font-size: 0.6875rem;
  }
}
.site-footer__top {
  display: flex; flex-direction: column; align-items: center;
  gap: var(--space-4);
}
.brand__lockup { gap: 2px; }
.brand__caption { letter-spacing: var(--tracking-wider); }

/* Subtle oxblood underline under wordmark on hover */
.brand__italic { position: relative; display: inline-block; }
.brand__italic::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -3px;
  height: 1px; background: var(--color-accent);
  transform: scaleX(0); transform-origin: left center;
  transition: transform var(--duration-base) var(--ease-display);
}
.brand:hover .brand__italic::after,
.brand:focus-visible .brand__italic::after { transform: scaleX(1); }

/* ── New home hero (editorial opener) ─────────────────────────────────── */
.hero--home {
  padding-block: clamp(var(--space-7), 10vw, var(--space-9))
                 clamp(var(--space-7), 8vw, var(--space-8));
}
.hero--home .hero__grid {
  display: grid; gap: var(--space-7);
  grid-template-columns: 1fr;
  align-items: center;
  position: relative; z-index: 1;
}
@media (min-width: 880px) {
  .hero--home .hero__grid { grid-template-columns: 1.1fr 1fr; gap: var(--space-8); }
}

.hero__type { display: grid; gap: var(--space-3); max-width: 56ch; }
.hero__display {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 0.86;
  letter-spacing: var(--tracking-tight);
  margin: var(--space-2) 0;
  display: grid; gap: var(--space-2);
}
.hero__display .hero__italic {
  font-style: italic; font-weight: 400;
  font-size: clamp(1.75rem, 3.5vw, 3rem);
  color: var(--color-fg-soft);
  letter-spacing: var(--tracking-snug);
}
.hero__display .hero__numeral {
  font-size: clamp(4.5rem, 13vw, 10.5rem);
  letter-spacing: 0.04em;
  color: var(--color-fg);
}

.hero__rule {
  display: inline-block;
  width: 96px; height: 2px;
  background: var(--color-accent);
  margin: var(--space-3) 0;
  border-radius: 0;
}

.hero__tagline {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.5rem, 2.5vw + 0.5rem, 2.5rem);
  line-height: 1.18;
  color: var(--color-fg);
  margin: 0;
  max-width: 22ch;
}
.hero__subhead {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  line-height: var(--lh-base);
  color: var(--color-fg-soft);
  margin: var(--space-3) 0 var(--space-5);
  max-width: 48ch;
}

.hero__visual {
  position: relative;
  margin: 0;
}
.hero__visual img {
  width: 100%; height: auto;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  box-shadow: var(--shadow-3);
  display: block;
}
.hero__visual--photo::after {
  content: ""; position: absolute;
  top: -16px; left: -16px; right: 16px; bottom: 16px;
  border: 1px solid var(--color-accent);
  opacity: 0.5;
  pointer-events: none;
  z-index: -1;
}
.hero__caption {
  margin-top: var(--space-3);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-muted);
  display: inline-flex; gap: var(--space-3); align-items: center;
}
.hero__caption::before {
  content: ""; width: 24px; height: 1px; background: var(--color-accent);
}

/* Trust row — restyled to drop the emoji style for hairline-accent style */
.hero--home .trust-row {
  list-style: none; padding: 0; margin: var(--space-6) 0 0;
  display: grid; gap: var(--space-3);
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  color: var(--color-fg-soft);
}
.hero--home .trust-row li {
  display: inline-flex; gap: var(--space-3); align-items: center;
  padding: 0;
}
.hero--home .trust-row li::before {
  content: ""; width: 20px; height: 1px; background: var(--color-accent);
  flex-shrink: 0;
}

/* ── Reveal motion system ─────────────────────────────────────────────── */
/* Default: an element with [data-reveal] starts hidden+offset, then
   transitions to its natural state once .is-revealed is applied (by
   `/static/js/reveal.js`). Children with [data-reveal-item] stagger their
   transitions in order. */

[data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 900ms var(--ease-display),
              transform 900ms var(--ease-display);
  will-change: opacity, transform;
}
[data-reveal].is-revealed {
  opacity: 1;
  transform: translateY(0);
}

[data-reveal-item] {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 700ms var(--ease-display) 0ms,
              transform 700ms var(--ease-display) 0ms;
}
.is-revealed > [data-reveal-item],
.is-revealed [data-reveal-item] {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger the children of a revealed parent (works for the home hero). */
.is-revealed > [data-reveal-item]:nth-child(1),
.is-revealed > * [data-reveal-item]:nth-child(1) { transition-delay: 0ms; }
.is-revealed > [data-reveal-item]:nth-child(2),
.is-revealed > * [data-reveal-item]:nth-child(2) { transition-delay: 90ms; }
.is-revealed > [data-reveal-item]:nth-child(3),
.is-revealed > * [data-reveal-item]:nth-child(3) { transition-delay: 180ms; }
.is-revealed > [data-reveal-item]:nth-child(4),
.is-revealed > * [data-reveal-item]:nth-child(4) { transition-delay: 270ms; }
.is-revealed > [data-reveal-item]:nth-child(5),
.is-revealed > * [data-reveal-item]:nth-child(5) { transition-delay: 380ms; }
.is-revealed > [data-reveal-item]:nth-child(6),
.is-revealed > * [data-reveal-item]:nth-child(6) { transition-delay: 490ms; }
.is-revealed > [data-reveal-item]:nth-child(7),
.is-revealed > * [data-reveal-item]:nth-child(7) { transition-delay: 600ms; }
.is-revealed > [data-reveal-item]:nth-child(8),
.is-revealed > * [data-reveal-item]:nth-child(8) { transition-delay: 720ms; }

/* The hairline rule draws from left, not fades from below. */
[data-reveal-item="rule"] {
  transform: scaleX(0);
  transform-origin: left center;
  opacity: 1;
  transition: transform 1000ms var(--ease-display) 380ms;
}
.is-revealed [data-reveal-item="rule"] {
  transform: scaleX(1);
}

/* Cards and category-cards: cheaper reveal — shorter distance, less weight. */
.card[data-reveal],
.category-card[data-reveal],
.testimonial[data-reveal] {
  transform: translateY(20px);
  transition: opacity 700ms var(--ease-display),
              transform 700ms var(--ease-display),
              border-color var(--duration-base) var(--ease),
              box-shadow var(--duration-base) var(--ease);
}

/* Stagger sibling cards in a grid so they don't all appear at once. */
.category-grid > .category-card[data-reveal]:nth-child(2) { transition-delay: 90ms; }
.category-grid > .category-card[data-reveal]:nth-child(3) { transition-delay: 180ms; }

.card-grid > .card[data-reveal]:nth-child(2)   { transition-delay: 70ms; }
.card-grid > .card[data-reveal]:nth-child(3)   { transition-delay: 140ms; }
.card-grid > .card[data-reveal]:nth-child(4)   { transition-delay: 210ms; }

.testimonial-grid > .testimonial[data-reveal]:nth-child(2) { transition-delay: 120ms; }

/* Brand-page sections — a softer reveal for the editorial cadence. */
.brand-section[data-reveal] {
  transform: translateY(36px);
  transition: opacity 1100ms var(--ease-display),
              transform 1100ms var(--ease-display);
}

@media (prefers-reduced-motion: reduce) {
  [data-reveal],
  [data-reveal-item],
  .card[data-reveal],
  .category-card[data-reveal],
  .testimonial[data-reveal],
  .brand-section[data-reveal] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* ── Photo Ken Burns drift on home hero (subtle, slow) ────────────────── */
@keyframes hero-photo-drift {
  from { transform: scale(1.04); }
  to   { transform: scale(1); }
}
.hero__visual--photo img {
  animation: hero-photo-drift 9000ms var(--ease-display) both;
}
@media (prefers-reduced-motion: reduce) {
  .hero__visual--photo img { animation: none; }
}

/* ── Toast ───────────────────────────────────────────────────────────────
   Small status cards rendered into #toast-container, fired by toast.js.
   Bottom-right on desktop; top-center on mobile so they don't collide
   with the sticky checkout bar. */
.toast-container {
  position: fixed;
  z-index: 1000;
  right: var(--space-5);
  bottom: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  pointer-events: none;
  max-width: min(360px, calc(100vw - var(--space-7)));
}
@media (max-width: 767px) {
  .toast-container {
    right: var(--space-3);
    left: var(--space-3);
    /* Sit below the sticky site header. */
    top: calc(env(safe-area-inset-top, 0px) + 92px);
    bottom: auto;
    max-width: none;
    align-items: center;
  }
}

.toast {
  pointer-events: auto;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bone);
  /* Opaque fallback so the toast never shows the header through it. */
  background-color: var(--color-bone);
  color: var(--color-fg);
  border: 1px solid var(--color-border);
  border-left: 3px solid var(--color-fg);
  box-shadow: var(--shadow-2);
  border-radius: 0;
  font-size: var(--fs-sm);
  line-height: var(--lh-snug);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 220ms var(--ease-display),
              transform 220ms var(--ease-display);
  cursor: pointer;
  width: 100%;
}
.toast--in {
  opacity: 1;
  transform: translateY(0);
}
.toast--leaving {
  opacity: 0;
  transform: translateY(-6px);
}

.toast__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-pill);
  background: var(--color-fg);
  flex-shrink: 0;
}
.toast__msg {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-md);
  line-height: var(--lh-snug);
  color: var(--color-fg);
}
.toast__close {
  background: none;
  border: 0;
  padding: 0 var(--space-1);
  font-size: var(--fs-lg);
  line-height: 1;
  color: var(--color-muted);
  cursor: pointer;
  font-family: inherit;
}
.toast__close:hover { color: var(--color-fg); }

.toast--success { border-left-color: var(--color-success); }
.toast--success .toast__dot { background: var(--color-success); }

.toast--warn { border-left-color: var(--color-error); }
.toast--warn .toast__dot { background: var(--color-error); }

.toast--info { border-left-color: var(--color-accent); }
.toast--info .toast__dot { background: var(--color-accent); }

@media (max-width: 767px) {
  .toast {
    max-width: min(440px, 100%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .toast,
  .toast--in,
  .toast--leaving {
    transition: none;
    transform: none;
  }
}

/* ── Cart polish ────────────────────────────────────────────────────────
   Tightens the cart summary, adds the collapsible promo, an empty-state
   card, and a checkout button with the running total. */
.cart-summary__title {
  margin: 0 0 var(--space-4);
  font-size: var(--fs-xl);
  font-style: italic;
  font-weight: 500;
}

.cart-empty {
  display: grid;
  gap: var(--space-4);
  text-align: center;
  padding: var(--space-8) var(--space-5);
  background: var(--color-bone);
  border: 1px solid var(--color-border);
}
.cart-empty__hint {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-2xl);
  color: var(--color-fg);
  margin: 0;
  line-height: var(--lh-snug);
}
.cart-empty__lead {
  color: var(--color-muted);
  font-size: var(--fs-md);
  margin: 0 auto;
  max-width: 36ch;
}
.cart-empty__ctas {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
  flex-wrap: wrap;
  margin-top: var(--space-3);
}

/* Mobile: stop the cart-table from forcing horizontal page overflow.
   We hide the THEAD and reflow each row as a stacked card. */
@media (max-width: 767px) {
  .cart-layout { grid-template-columns: minmax(0, 1fr); }
  .cart-layout__items { min-width: 0; overflow: hidden; }
  .cart-table { table-layout: fixed; width: 100%; }
  .cart-table thead { display: none; }
  .cart-table tr {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--space-2) var(--space-4);
    padding: var(--space-4) 0;
    border-bottom: 1px solid var(--color-border);
  }
  .cart-table td { padding: 0; border: 0; }
  .cart-table td:nth-child(1) { grid-column: 1 / 2; }
  .cart-table td:nth-child(2) { grid-column: 1 / -1; }
  .cart-table td:nth-child(3) {
    grid-column: 2 / 3; grid-row: 1;
    align-self: start;
    font-weight: 600; text-align: right;
  }
  .cart-table td:nth-child(4) {
    grid-column: 1 / -1;
    text-align: right;
  }
  .qty-form { gap: var(--space-2); }
  .qty-form input { width: 56px; }
  .cart-summary { padding: var(--space-5); }
}

/* Promo toggle — collapsible "Got a promo code?" disclosure. */
.promo-toggle {
  margin: 0 0 var(--space-5);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-3) 0;
}
.promo-toggle__summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-muted);
  user-select: none;
}
.promo-toggle__summary::-webkit-details-marker { display: none; }
.promo-toggle__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border: 1px solid var(--color-muted);
  border-radius: var(--radius-pill);
  font-size: var(--fs-sm);
  line-height: 1;
  color: var(--color-muted);
  transition: transform var(--duration-fast) var(--ease);
}
.promo-toggle[open] .promo-toggle__icon {
  transform: rotate(45deg);
  border-color: var(--color-fg);
  color: var(--color-fg);
}
.promo-toggle[open] .promo-toggle__summary {
  color: var(--color-fg);
}
.promo-toggle .promo-form {
  margin-top: var(--space-3);
}
.promo-toggle__note {
  margin: var(--space-2) 0 0;
  font-size: var(--fs-xs);
  color: var(--color-muted);
}

/* Cleaner summary list with separators between sections. */
.summary-list__row { display: flex; justify-content: space-between; align-items: baseline; }
.summary-list__row--discount dd { color: var(--color-success); }
.summary-list__sub {
  display: grid;
  gap: var(--space-1);
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-border);
}
.summary-list__row--tax dt,
.summary-list__row--tax dd {
  font-size: var(--fs-xs);
  color: var(--color-muted);
  font-family: var(--font-body);
  font-weight: 400;
}
.summary-list__total {
  margin-top: var(--space-3);
}

/* Checkout submit pulled higher in the visual hierarchy. */
.checkout-form__submit {
  width: 100%;
  margin-top: var(--space-5);
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: var(--space-2);
}
.checkout-form__submit-total {
  font-weight: 500;
  opacity: 0.85;
}

/* ── Sticky checkout (mobile) ──────────────────────────────────────────
   A pinned footer bar that surfaces the running total + checkout CTA on
   small viewports. Hidden on desktop where the summary is already in view. */
.sticky-checkout {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 90;
  background: var(--color-bone);
  border-top: 1px solid var(--color-border);
  box-shadow: 0 -8px 24px color-mix(in srgb, var(--color-ink-950) 8%, transparent);
  padding: var(--space-3) var(--space-4);
  padding-bottom: calc(var(--space-3) + env(safe-area-inset-bottom, 0px));
  display: none;
}
.sticky-checkout__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  max-width: var(--container-max);
  margin: 0 auto;
}
.sticky-checkout__total {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}
.sticky-checkout__total-label {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-muted);
}
.sticky-checkout__total-amount {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  color: var(--color-fg);
}
.sticky-checkout__cta {
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .sticky-checkout { display: block; }
  /* Leave room at page bottom so the sticky bar doesn't cover content. */
  body:has(.sticky-checkout) main { padding-bottom: 88px; }
}


/* ── Mobile booking bar — persistent "Réserver" once past the hero ──────── */
.book-bar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 30;
  display: none;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  padding-bottom: calc(var(--space-2) + env(safe-area-inset-bottom, 0px));
  background: color-mix(in srgb, var(--color-paper) 96%, transparent);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-top: 1px solid var(--color-border);
  box-shadow: 0 -8px 24px color-mix(in srgb, var(--color-ink-950) 10%, transparent);
  transform: translateY(110%);
  transition: transform var(--duration-base) var(--ease-display);
}
.book-bar.is-visible { transform: translateY(0); }
.book-bar__call {
  flex-shrink: 0;
  width: 44px; height: 44px;
  display: grid; place-items: center;
  border: 1px solid var(--color-border); color: var(--color-fg);
}
.book-bar__call:hover { background: var(--color-accent); color: var(--color-paper); border-color: var(--color-accent); }
.book-bar__call svg { width: 20px; height: 20px; }
.book-bar__cta { flex: 1; }
@media (max-width: 879px) { .book-bar { display: flex; } }

/* ── Trust / credibility band (home, under the hero) ──────────────────── */
.section--trustbar {
  padding-block: var(--space-6);
  border-block: 1px solid var(--color-border);
  background: var(--color-bg-elevated);
}
.trust-strip {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: var(--space-5) var(--space-4);
  grid-template-columns: repeat(2, 1fr);
  text-align: center;
}
@media (min-width: 880px) { .trust-strip { grid-template-columns: repeat(4, 1fr); } }
.trust-strip li { padding-inline: var(--space-3); }
@media (min-width: 880px) { .trust-strip li + li { border-left: 1px solid var(--color-border); } }
.trust-strip__stat {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-xl); font-weight: 600; line-height: 1.05;
  letter-spacing: var(--tracking-snug);
  color: var(--color-fg);
}
.trust-strip__stat--stars { color: var(--color-brass); font-size: var(--fs-lg); letter-spacing: 2px; }
.trust-strip__label {
  display: block; margin-top: var(--space-2);
  font-size: var(--fs-xs); text-transform: uppercase;
  letter-spacing: var(--tracking-wide); color: var(--color-muted);
}
