/* =========================================================
   GRAINE PÂTISSERIE — main.css
   Editorial botanical modernism · v2 (2026)
   ========================================================= */

/* ---------- TOKENS ---------- */
:root {
  /* paper / surface */
  --paper:        #F0E8D5;
  --paper-deep:   #E5DAC1;
  --paper-warm:   #ECE2CB;

  /* ink */
  --ink:          #14110D;
  --ink-soft:     #4D4338;
  --ink-mute:     #6F6353;

  /* accents */
  --tomato:       #C8341A;
  --tomato-deep:  #8E2110;
  --olive:        #4F5A30;
  --olive-soft:   #7B8453;
  --sand:         #BCA68A;

  /* lines */
  --line:         rgba(20, 17, 13, 0.10);
  --line-strong:  rgba(20, 17, 13, 0.22);
  --line-tomato:  rgba(200, 52, 26, 0.30);

  /* type */
  --font-display: 'Instrument Serif', 'Cormorant Garamond', Georgia, serif;
  --font-body:    'DM Sans', ui-sans-serif, system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;
  --font-hand:    'Caveat', 'Brush Script MT', cursive;

  /* layout */
  --max:          1480px;
  --gutter:       clamp(1.25rem, 3.5vw, 3rem);
  --topbar-h:     34px;

  /* motion */
  --ease:         cubic-bezier(.2,.7,.2,1);
  --ease-soft:    cubic-bezier(.4,0,.2,1);
}

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

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

body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

/* paper grain overlay */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 200;
  mix-blend-mode: multiply;
  opacity: 0.55;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='280' height='280'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.078  0 0 0 0 0.067  0 0 0 0 0.051  0 0 0 0.06 0'/></filter><rect width='280' height='280' filter='url(%23n)'/></svg>");
}

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

/* mentions-legales page */
.legal {
  max-width: 760px;
  margin: 0 auto;
  padding: 6rem var(--gutter) 4rem;
}
.legal-head {
  margin-bottom: 4rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid var(--line);
}
.legal-head h1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(3rem, 7vw, 5.5rem);
  line-height: 0.92;
  letter-spacing: -0.02em;
  margin: 1.2rem 0 1.5rem;
}
.legal-head h1 em { font-style: italic; color: var(--tomato); }
.legal-head .lead {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.15rem;
  color: var(--ink-soft);
}
.legal-block {
  margin-bottom: 3rem;
}
.legal-block h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin-bottom: 1rem;
  color: var(--olive);
}
.legal-block p {
  color: var(--ink-soft);
  line-height: 1.65;
  margin-bottom: 0.9rem;
  font-size: 1rem;
}
.legal-block p.note {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--ink-mute);
  font-size: 0.95rem;
}
.legal-block a { border-bottom: 1px solid var(--olive); }
.legal-block a:hover { color: var(--tomato); border-color: var(--tomato); }
.legal-back { margin-top: 4rem; padding-top: 2rem; border-top: 1px solid var(--line); }

/* skip-to-content link — visible only when keyboard-focused */
.skip-link {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 999;
  padding: 0.7rem 1.1rem;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  border-radius: 0 0 6px 0;
  transform: translateY(-110%);
  transition: transform .25s var(--ease);
}
.skip-link:focus { transform: translateY(0); outline: 2px solid var(--tomato); outline-offset: 2px; }

/* visible focus rings for keyboard users (do not touch mouse focus) */
:focus-visible {
  outline: 2px solid var(--tomato);
  outline-offset: 2px;
  border-radius: 4px;
}
.btn:focus-visible,
.nav-cta:focus-visible,
.cn-follow-cta:focus-visible,
.float-cta:focus-visible { outline-offset: 4px; }

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

/* ---------- TYPE PRIMITIVES ---------- */
.display {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: 0.9;
  letter-spacing: -0.018em;
}
.italic { font-style: italic; }

.serif-i {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
}

.eyebrow {
  font-family: var(--font-mono);
  font-size: 0.71rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.eyebrow .dot {
  display: inline-block;
  width: 5px;
  height: 5px;
  background: var(--tomato);
  border-radius: 50%;
  margin-right: 8px;
  vertical-align: middle;
  animation: pulse 2.4s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.4; transform: scale(1.4); }
}

/* ---------- TOPBAR ---------- */
.topbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 60;
  height: var(--topbar-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--gutter);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.topbar-left, .topbar-right, .topbar-center {
  display: flex;
  align-items: center;
  gap: 1.4rem;
}
.topbar-center { color: var(--paper); opacity: 0.85; }

.topbar .live::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  background: var(--tomato);
  border-radius: 50%;
  margin-right: 8px;
  vertical-align: middle;
  animation: pulse 2.4s ease-in-out infinite;
}

.topbar .marker {
  color: var(--sand);
  margin: 0 0.4rem;
  opacity: 0.6;
}

.scroll-progress {
  position: fixed;
  top: var(--topbar-h);
  left: 0;
  height: 1px;
  width: 0%;
  background: var(--tomato);
  z-index: 70;
  transition: width 0.08s linear;
}

/* ---------- NAV ---------- */
.nav {
  position: fixed;
  top: var(--topbar-h);
  left: 0; right: 0;
  z-index: 55;
  padding: 1.25rem var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: rgba(240, 232, 213, 0.78);
  backdrop-filter: blur(14px) saturate(1.2);
  -webkit-backdrop-filter: blur(14px) saturate(1.2);
  border-bottom: 1px solid transparent;
  transition: border-color .3s ease, padding .3s ease;
}
.nav.scrolled {
  border-bottom-color: var(--line);
  padding: 0.85rem var(--gutter);
}

.nav-logo {
  display: flex;
  align-items: center;
  color: var(--ink);
  height: 42px;
  transition: opacity .3s var(--ease-soft);
}
.nav-logo:hover { opacity: 0.78; }
.nav-logo img {
  height: 100%;
  width: auto;
  display: block;
}
.nav.scrolled .nav-logo { height: 34px; }

.nav-links {
  display: flex;
  align-items: center;
  gap: 2.4rem;
  font-size: 0.92rem;
  font-weight: 400;
  letter-spacing: -0.005em;
}

.nav-links a {
  position: relative;
  padding: 0.3rem 0;
  transition: color .3s var(--ease-soft);
}
.nav-links a::before {
  content: '';
  position: absolute;
  left: 0; bottom: -2px;
  width: 0%;
  height: 1px;
  background: var(--ink);
  transition: width .4s var(--ease);
}
.nav-links a:hover::before { width: 100%; }

.nav-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.5rem !important; 
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
  border-radius: 999px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.12rem;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 1;
  transition: all .35s var(--ease);
}
.nav-cta:hover {
  background: var(--tomato);
  color: var(--paper);
  border-color: var(--tomato);
}
.nav-cta .leaf-icon {
  color: var(--tomato);
  flex: none;
  transition: color .35s var(--ease), transform .35s var(--ease);
}
.nav-cta:hover .leaf-icon {
  color: var(--paper);
  transform: rotate(-12deg);
}
.nav-cta::before { display: none !important; }

.nav-burger {
  display: none;
  flex-direction: column;
  gap: 6px;
  background: none;
  border: none;
  padding: 0.4rem;
}
.nav-burger span {
  width: 22px;
  height: 1px;
  background: var(--ink);
  transition: transform .35s var(--ease);
}
.nav-burger.open span:nth-child(1) { transform: translateY(3.5px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { transform: translateY(-3.5px) rotate(-45deg); }

/* ---------- VERTICAL MARGIN LABEL ---------- */
.margin-label {
  position: fixed;
  left: 0.85rem;
  bottom: 2rem;
  z-index: 40;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.95rem;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--olive);
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  pointer-events: none;
  user-select: none;
  opacity: 0.78;
}
.margin-label .seed-mark {
  display: inline-block;
  width: 5px; height: 5px;
  background: var(--olive);
  border-radius: 50%;
  margin: 0.6rem 0;
}

/* ---------- HERO ---------- */
.hero {
  padding: calc(var(--topbar-h) + 5rem) var(--gutter) 2.5rem;
  max-width: var(--max);
  margin: 0 auto;
  position: relative;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  grid-template-rows: auto auto auto;
  gap: 1.8rem 4rem;
  align-items: end;
}

.hero-meta {
  grid-column: 1 / -1;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 1rem;
  padding-bottom: 0.9rem;
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.hero-meta .left { display: flex; gap: 1.4rem; align-items: center; }
.hero-meta .right { display: flex; gap: 1.4rem; align-items: center; }
.hero-meta .marker { color: var(--sand); opacity: 0.6; }

.hero-text {
  align-self: end;
  position: relative;
  z-index: 2;
}

.hero-sprig {
  color: var(--olive);
  margin-bottom: 1.6rem;
  display: block;
  opacity: 0;
  animation: fadeUp 1s var(--ease) 0.2s forwards;
}

.hero-headline {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(3.2rem, 9.5vw, 8.5rem);
  line-height: 0.92;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.hero-headline .line {
  display: block;
  overflow: hidden;
}
.hero-headline .line > span {
  display: block;
  transform: translateY(110%);
  animation: rise 1.1s var(--ease) forwards;
}
.hero-headline .line:nth-child(1) > span { animation-delay: .25s; }
.hero-headline .line:nth-child(2) > span { animation-delay: .38s; }
.hero-headline .line:nth-child(3) > span { animation-delay: .51s; }
.hero-headline .line:nth-child(4) > span { animation-delay: .64s; }

.hero-headline em {
  font-style: italic;
  color: var(--tomato);
  font-weight: 400;
}

.hero-headline .punctum {
  color: var(--tomato);
  font-style: normal;
}

@keyframes rise { to { transform: translateY(0); } }

.hero-lead {
  margin-top: 1.8rem;
  max-width: 30rem;
  font-size: 1.02rem;
  line-height: 1.55;
  color: var(--ink-soft);
  opacity: 0;
  animation: fadeUp 1s var(--ease) 0.85s forwards;
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

.hero-actions {
  margin-top: 1.8rem;
  display: flex;
  align-items: center;
  gap: 1.6rem;
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeUp 1s var(--ease) 1s forwards;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  padding: 1rem 1.5rem;
  border-radius: 999px;
  font-size: 0.92rem;
  font-weight: 500;
  letter-spacing: 0.005em;
  transition: all .35s var(--ease);
  white-space: nowrap;
}
.btn-primary {
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
}
.btn-primary:hover { background: var(--tomato); border-color: var(--tomato); }
.btn-primary .arrow { transition: transform .35s var(--ease); }
.btn-primary:hover .arrow { transform: translate(3px, -3px); }

.btn-ghost {
  color: var(--ink);
  border-bottom: 1px solid var(--ink);
  border-radius: 0;
  padding: 0.4rem 0;
}
.btn-ghost:hover { color: var(--tomato); border-color: var(--tomato); }

.hero-visual {
  align-self: end;
  position: relative;
  aspect-ratio: 5 / 4;
  width: 100%;
  max-height: 56vh;
  opacity: 0;
  transform: translateY(40px);
  animation: heroRise 1.3s var(--ease) 0.7s forwards;
}
@keyframes heroRise { to { opacity: 1; transform: translateY(0); } }

.hero-visual .frame {
  position: absolute;
  inset: 0;
  overflow: hidden;
  border-radius: 2px;
}
.hero-visual img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: 60% center;
  transform: scale(1.02);
  transition: transform 12s var(--ease);
  filter: contrast(1.04) saturate(1.02);
}
.hero-visual:hover img { transform: scale(1.12); }

.hero-visual .credit {
  position: absolute;
  top: 1rem; left: 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--paper);
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  z-index: 2;
}
.hero-visual .credit .red {
  width: 6px; height: 6px;
  background: var(--tomato);
  border-radius: 50%;
}

.hero-visual .caption {
  position: absolute;
  bottom: 1.1rem; left: 1.1rem; right: 1.1rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  z-index: 2;
}
.hero-visual .caption .name {
  background: var(--paper);
  padding: 0.55rem 0.95rem;
  border-radius: 999px;
  font-family: var(--font-display);
  font-size: 1rem;
}
.hero-visual .caption .name em {
  color: var(--tomato);
  font-style: italic;
}
.hero-visual .caption .tag {
  background: var(--ink);
  color: var(--paper);
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

/* hero side index */
.hero-side {
  grid-column: 1 / -1;
  margin-top: 2rem;
  padding-top: 1.1rem;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1.4rem;
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeUp 1s var(--ease) 1.15s forwards;
}
.hero-side .item {
  font-size: 0.86rem;
  color: var(--ink-soft);
  display: flex;
  gap: 0.55rem;
  align-items: baseline;
  letter-spacing: -0.005em;
}
.hero-side .item .serif-i {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--olive);
  font-weight: 400;
}

/* ---------- MARQUEE ---------- */
.marquee {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 1.6rem 0;
  overflow: hidden;
  background: var(--paper);
  position: relative;
}
.marquee-track {
  display: flex;
  gap: 2.4rem;
  align-items: center;
  white-space: nowrap;
  animation: scrollLeft 48s linear infinite;
  width: max-content;
}
.marquee-track .item {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 400;
  color: var(--ink);
  line-height: 1;
}
.marquee-track .item.it { font-style: italic; color: var(--tomato); }
.marquee-track .item.ar {
  font-family: 'Amiri', 'Noto Naskh Arabic', serif;
  font-style: normal;
  color: var(--olive);
  font-size: clamp(1.5rem, 3.4vw, 2.6rem);
}
.marquee-track .star {
  color: var(--ink-mute);
  font-size: 1rem;
  opacity: 0.7;
}
@keyframes scrollLeft { to { transform: translateX(-50%); } }

/* ---------- SECTION ---------- */
section {
  padding: 7rem var(--gutter);
  max-width: var(--max);
  margin: 0 auto;
  position: relative;
}
section.bleed {
  max-width: none;
  margin: 0;
  padding-left: 0;
  padding-right: 0;
}
section.bleed > .inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.section-mark {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 3rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--line);
  position: relative;
}
.section-mark::after {
  content: '';
  position: absolute;
  bottom: -1px; left: 0;
  width: 80px;
  height: 1px;
  background: var(--olive);
}
.section-mark .left {
  display: flex;
  align-items: baseline;
  gap: 1.2rem;
}
.section-mark .num {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 3.8rem;
  line-height: 1;
  color: var(--tomato);
  letter-spacing: -0.02em;
}
.section-mark .label {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--olive);
}
.section-mark .right {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.05rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink-mute);
}
.section-mark .mark-sprig {
  color: var(--olive);
  margin-left: 0.4rem;
  flex-shrink: 0;
  align-self: center;
}

.section-head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 4rem;
  margin-bottom: 4.5rem;
  align-items: end;
}
.section-head h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.8rem, 7vw, 6.5rem);
  line-height: 0.92;
  letter-spacing: -0.02em;
}
.section-head h2 em { color: var(--tomato); font-style: italic; }
.section-head .desc {
  color: var(--ink-soft);
  line-height: 1.6;
  font-size: 1rem;
  max-width: 30rem;
  padding-bottom: 0.4rem;
}

/* ---------- MANIFESTO ---------- */
.manifesto {
  background: var(--paper-warm);
  padding: 8rem var(--gutter);
}
.manifesto .inner {
  max-width: var(--max);
  margin: 0 auto;
}
.manifesto-quote {
  position: relative;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.2rem, 5.5vw, 5rem);
  line-height: 1.05;
  letter-spacing: -0.018em;
  color: var(--ink);
  max-width: 22ch;
  margin-bottom: 5rem;
  padding-left: 4.5rem;
}
.manifesto-quote em { color: var(--tomato); font-style: italic; }
.manifesto-quote .quote-sprig {
  position: absolute;
  left: 0;
  top: -0.4rem;
  color: var(--olive);
}
@media (max-width: 760px) {
  .manifesto-quote { padding-left: 0; padding-top: 5rem; }
  .manifesto-quote .quote-sprig { left: -0.5rem; top: 0; }
}

.manifesto-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;
}
.manifesto-portrait {
  position: relative;
  aspect-ratio: 3 / 4;
  background: var(--paper-deep);
  overflow: hidden;
  border-radius: 2px;
}
.manifesto-portrait .portrait-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.02) saturate(0.95) sepia(0.04);
}
.manifesto-portrait .stamp {
  position: absolute;
  top: 1.2rem; right: 1.2rem;
  width: 92px; height: 92px;
  border: 1px solid var(--olive);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.95rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--olive);
  text-align: center;
  line-height: 1.15;
  background: rgba(240, 232, 213, 0.92);
  backdrop-filter: blur(6px);
}

.manifesto-text p {
  color: var(--ink-soft);
  line-height: 1.7;
  margin-bottom: 1.4rem;
  font-size: 1.02rem;
}
.manifesto-text p:first-of-type::first-letter {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 4.5rem;
  float: left;
  line-height: 0.85;
  margin: 0.18rem 0.55rem -0.1rem 0;
  color: var(--tomato);
}
.aymen-signature {
  margin-top: 2.6rem;
  padding-top: 1.4rem;
  border-top: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.aymen-signature .hand {
  font-family: var(--font-hand);
  font-weight: 600;
  font-size: 4.4rem;
  line-height: 0.95;
  color: var(--ink);
  letter-spacing: -0.005em;
  display: inline-block;
  transform: rotate(-4deg) translateX(2px);
  transform-origin: left center;
  margin-bottom: 0.6rem;
  width: max-content;
}
.aymen-signature .hand::after {
  content: '';
  display: block;
  width: 110%;
  height: 6px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 6' preserveAspectRatio='none'><path d='M0 4 Q 20 1 40 4 T 80 4 T 120 4' fill='none' stroke='%23C8341A' stroke-width='1.4' stroke-linecap='round'/></svg>") no-repeat;
  background-size: 100% 100%;
  margin-top: -0.2rem;
  margin-left: -2%;
}
.aymen-signature .role {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--ink-mute);
  letter-spacing: 0;
  text-transform: none;
}

/* ---------- SUR-MESURE (B2B) ---------- */
.surmesure-rail {
  display: flex;
  gap: 1.5rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 1.5rem;
  margin: 0 calc(-1 * var(--gutter)) 0;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  scrollbar-width: thin;
  scrollbar-color: var(--ink-mute) transparent;
}
.surmesure-rail::-webkit-scrollbar { height: 4px; }
.surmesure-rail::-webkit-scrollbar-thumb { background: var(--ink-mute); }
.surmesure-rail::-webkit-scrollbar-track { background: transparent; }

.sm-card {
  flex: 0 0 clamp(280px, 28vw, 380px);
  scroll-snap-align: start;
  position: relative;
  cursor: pointer;
  transition: transform .5s var(--ease);
}
.sm-card:hover { transform: translateY(-4px); }

.sm-card .img {
  aspect-ratio: 3 / 4;
  background: var(--paper-deep);
  overflow: hidden;
  border-radius: 2px;
  position: relative;
}
.sm-card .img > div {
  width: 100%; height: 100%;
  background-size: cover;
  background-position: center;
  transition: transform 1.2s var(--ease);
  filter: contrast(1.04) saturate(0.96);
}
.sm-card:hover .img > div { transform: scale(1.06); }

.sm-card .img .index {
  position: absolute;
  top: 0.9rem; left: 0.9rem;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: var(--paper);
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  color: var(--ink-soft);
}
.sm-card .img .arrow {
  position: absolute;
  bottom: 0.9rem; right: 0.9rem;
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--paper);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .3s var(--ease), transform .4s var(--ease);
}
.sm-card:hover .img .arrow {
  background: var(--tomato);
  transform: rotate(-45deg);
}
.sm-card:hover .img .arrow svg { color: var(--paper); }

.sm-card .label {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 1rem;
}
.sm-card h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.85rem;
  line-height: 1;
  letter-spacing: -0.01em;
}
.sm-card h3 em { font-style: italic; color: var(--tomato); }
.sm-card .meta {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--olive);
}
.sm-card .desc {
  margin-top: 0.6rem;
  color: var(--ink-soft);
  font-size: 0.92rem;
  line-height: 1.55;
  max-width: 30ch;
}

.surmesure-rail-nav {
  margin-top: 1rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.surmesure-rail-nav .ctrls {
  display: flex; gap: 0.5rem;
}
.surmesure-rail-nav button {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: transparent;
  border: 1px solid var(--ink);
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .3s var(--ease);
}
.surmesure-rail-nav button:hover {
  background: var(--ink);
  color: var(--paper);
}

/* ---------- SAISON ---------- */
.saison-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 2rem 1.5rem;
}
.creation {
  cursor: default;
}
.creation:nth-child(1) { grid-column: 1 / 6; margin-top: 2rem; }
.creation:nth-child(2) { grid-column: 6 / 10; margin-top: 6rem; }
.creation:nth-child(3) { grid-column: 10 / 13; margin-top: 1rem; }
.creation:nth-child(4) { grid-column: 1 / 4; margin-top: 4rem; }
.creation:nth-child(5) { grid-column: 4 / 9; margin-top: 1rem; }
.creation:nth-child(6) { grid-column: 9 / 13; margin-top: 5rem; }

.creation-img {
  position: relative;
  aspect-ratio: 4 / 5;
  background: var(--paper-deep);
  overflow: hidden;
  border-radius: 2px;
  margin-bottom: 1rem;
}
.creation:nth-child(2) .creation-img,
.creation:nth-child(5) .creation-img { aspect-ratio: 5 / 4; }

.creation-img > div {
  width: 100%; height: 100%;
  background-size: cover;
  background-position: center;
  transition: transform 1.2s var(--ease);
  filter: contrast(1.05) saturate(1);
}
.creation:hover .creation-img > div { transform: scale(1.05); }

.creation-img .nbr {
  position: absolute;
  top: 0.85rem; right: 0.85rem;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  background: var(--paper);
  width: 38px; height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tomato);
}

.creation-meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.5rem;
}
.creation h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.7rem;
  line-height: 1.05;
  letter-spacing: -0.01em;
}
.creation h3 em { font-style: italic; color: var(--tomato); }
.creation .tag {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--olive);
  white-space: nowrap;
}
.creation .ingredients {
  margin-top: 0.5rem;
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 32ch;
}

/* ---------- CARNET (Instagram) ---------- */
.carnet { padding-top: 7rem; padding-bottom: 7rem; }

.carnet-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 2.4rem 1.6rem;
}

.cn-card {
  display: flex;
  flex-direction: column;
  color: var(--ink);
  text-decoration: none;
  transition: transform .5s var(--ease);
}
.cn-card:hover { transform: translateY(-4px); }

.cn-card:nth-child(1) { grid-column: 1 / 7; }
.cn-card:nth-child(2) { grid-column: 7 / 13; margin-top: 3rem; }
.cn-card:nth-child(3) { grid-column: 1 / 5; margin-top: 1rem; }
.cn-card:nth-child(4) { grid-column: 5 / 9; margin-top: 4rem; }
.cn-card:nth-child(5) { grid-column: 9 / 13; margin-top: 1rem; }
.cn-card:nth-child(6) { grid-column: 3 / 9; margin-top: 2rem; }

.cn-img {
  position: relative;
  aspect-ratio: 1 / 1;
  background: var(--paper-deep);
  overflow: hidden;
  border-radius: 2px;
  margin-bottom: 1rem;
}
.cn-card:nth-child(1) .cn-img { aspect-ratio: 5 / 4; }
.cn-card:nth-child(6) .cn-img { aspect-ratio: 4 / 3; }

.cn-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease);
  filter: contrast(1.04) saturate(1);
}
.cn-card:hover .cn-img img { transform: scale(1.05); }

.cn-badge {
  position: absolute;
  top: 0.85rem; left: 0.85rem;
  background: var(--paper);
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--olive);
}

.cn-corner {
  position: absolute;
  bottom: 0.85rem; right: 0.85rem;
  width: 34px; height: 34px;
  background: var(--paper);
  color: var(--ink);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .35s var(--ease), color .35s var(--ease), transform .4s var(--ease);
}
.cn-card:hover .cn-corner {
  background: var(--olive);
  color: var(--paper);
  transform: rotate(-45deg);
}

.cn-cap {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.18rem;
  line-height: 1.35;
  color: var(--ink);
  margin-bottom: 0.85rem;
  letter-spacing: -0.005em;
}

.cn-foot {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 0.86rem;
  color: var(--ink-mute);
  border-top: 1px solid var(--line);
  padding-top: 0.7rem;
}
.cn-handle {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--olive);
}
.cn-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--ink);
  font-family: var(--font-display);
  font-style: italic;
}
.cn-link .leaf-icon { color: var(--olive); }

/* follow CTA */
.cn-follow {
  margin-top: 6rem;
  padding-top: 3.5rem;
  border-top: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 2rem;
}

.cn-handle-big {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(3rem, 9vw, 8rem);
  line-height: 0.95;
  letter-spacing: -0.025em;
  color: var(--ink);
}
.cn-handle-big em {
  font-style: italic;
  color: var(--tomato);
}

.cn-follow-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.9rem 1.8rem;
  border: 1px solid var(--ink);
  border-radius: 999px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.18rem;
  color: var(--ink);
  background: transparent;
  transition: all .35s var(--ease);
}
.cn-follow-cta:hover {
  background: var(--olive);
  border-color: var(--olive);
  color: var(--paper);
}
.cn-follow-cta .leaf-icon { color: var(--olive); transition: color .35s var(--ease), transform .35s var(--ease); }
.cn-follow-cta:hover .leaf-icon { color: var(--paper); transform: rotate(-12deg); }

@media (max-width: 1100px) {
  .carnet-grid { gap: 2rem 1.2rem; }
  .cn-card:nth-child(1) { grid-column: 1 / 8; margin-top: 0; }
  .cn-card:nth-child(2) { grid-column: 8 / 13; margin-top: 4rem; }
  .cn-card:nth-child(3) { grid-column: 1 / 7; margin-top: 2rem; }
  .cn-card:nth-child(4) { grid-column: 7 / 13; margin-top: 4rem; }
  .cn-card:nth-child(5) { grid-column: 1 / 7; margin-top: 1rem; }
  .cn-card:nth-child(6) { grid-column: 7 / 13; margin-top: 4rem; }
}
@media (max-width: 760px) {
  .carnet-grid > .cn-card { grid-column: 1 / 13 !important; margin-top: 0 !important; }
  .cn-card .cn-img { aspect-ratio: 1 / 1 !important; }
}

/* ---------- PROCESS ---------- */
.process {
  background: var(--ink);
  color: var(--paper);
}
.process .inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 7rem var(--gutter);
}
.process-mark {
  display: block;
  height: 70px;
  width: auto;
  margin: 0 0 2.5rem;
  opacity: 0.92;
}
.process .section-mark {
  border-bottom-color: rgba(240, 232, 213, 0.18);
}
.process .section-mark .num { color: var(--tomato); }
.process .section-mark .label,
.process .section-mark .right { color: rgba(240, 232, 213, 0.6); }

.process h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.8rem, 7vw, 6rem);
  line-height: 0.92;
  letter-spacing: -0.02em;
  max-width: 18ch;
  margin-bottom: 4rem;
}
.process h2 em { color: var(--tomato); font-style: italic; }

.steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid rgba(240, 232, 213, 0.18);
}
.step {
  padding: 2.6rem 1.6rem 2.6rem 0;
  border-right: 1px solid rgba(240, 232, 213, 0.18);
  position: relative;
}
.step:last-child { border-right: none; }
.step:not(:first-child) { padding-left: 1.6rem; }

.step .nbr {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.9rem;
  color: var(--tomato);
  margin-bottom: 1.2rem;
}
.step h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.85rem;
  line-height: 1;
  letter-spacing: -0.01em;
  margin-bottom: 1rem;
  color: var(--paper);
}
.step h3 em { font-style: italic; color: var(--tomato); }
.step p {
  color: rgba(240, 232, 213, 0.7);
  font-size: 0.94rem;
  line-height: 1.6;
}

/* ---------- PRECOMMANDE FORM ---------- */
.precommande {
  background: var(--paper-warm);
  padding: 7rem var(--gutter);
}
.precommande .inner {
  max-width: var(--max);
  margin: 0 auto;
}
.precommande-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 5rem;
  align-items: start;
}
.precommande-aside h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.6rem, 6vw, 5rem);
  line-height: 0.94;
  letter-spacing: -0.02em;
  margin-bottom: 1.6rem;
}
.precommande-aside h2 em { color: var(--tomato); font-style: italic; }
.precommande-aside p {
  color: var(--ink-soft);
  line-height: 1.6;
  margin-bottom: 1.2rem;
  max-width: 32ch;
}
.precommande-aside .contact-list {
  margin-top: 2.5rem;
  border-top: 1px solid var(--line);
  padding-top: 1.6rem;
}
.precommande-aside .contact-list .row {
  display: flex;
  justify-content: space-between;
  padding: 0.85rem 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.precommande-aside .contact-list .row:last-child { border-bottom: none; }
.precommande-aside .contact-list .row .lab {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.precommande-aside .contact-list .row .val {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--ink);
}

.form-card {
  background: var(--paper);
  padding: 2.6rem;
  border: 1px solid var(--line);
  border-radius: 4px;
  position: relative;
}
.form-card::before {
  content: '';
  position: absolute;
  top: -1px; left: -1px;
  width: 24px; height: 24px;
  border-top: 1px solid var(--tomato);
  border-left: 1px solid var(--tomato);
}
.form-card::after {
  content: '';
  position: absolute;
  bottom: -1px; right: -1px;
  width: 24px; height: 24px;
  border-bottom: 1px solid var(--tomato);
  border-right: 1px solid var(--tomato);
}

.form-step {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  margin-bottom: 1.8rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.form-step .pip {
  width: 6px; height: 6px;
  background: var(--tomato);
  border-radius: 50%;
}

fieldset {
  border: none;
  padding: 0;
  margin: 0 0 2rem;
}
.field-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 0.85rem;
}

.type-options {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.6rem;
}
.type-options label {
  position: relative;
  cursor: pointer;
}
.type-options input { position: absolute; opacity: 0; pointer-events: none; }
.type-options span {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  font-size: 0.92rem;
  transition: all .25s var(--ease);
}
.type-options span::before {
  content: '';
  width: 7px; height: 7px;
  background: transparent;
  border: 1px solid var(--ink-mute);
  border-radius: 50%;
  transition: all .25s var(--ease);
}
.type-options input:checked + span {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.type-options input:checked + span::before {
  background: var(--tomato);
  border-color: var(--tomato);
}

.row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.input-line {
  position: relative;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 0.5rem;
}
.input-line input,
.input-line textarea,
.input-line select {
  width: 100%;
  background: transparent;
  border: none;
  outline: none;
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--ink);
  padding: 0.4rem 0;
  resize: vertical;
}
.input-line textarea { min-height: 90px; }
.input-line input::placeholder,
.input-line textarea::placeholder { color: var(--ink-mute); }

.form-card .submit-row {
  margin-top: 1rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}
.form-card .submit-row .small {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  max-width: 28ch;
  line-height: 1.6;
}

button.btn-submit {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  background: var(--tomato);
  color: var(--paper);
  border: none;
  border-radius: 999px;
  padding: 1rem 1.6rem;
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0.005em;
  transition: all .35s var(--ease);
}
button.btn-submit:hover {
  background: var(--ink);
}
button.btn-submit .arrow { transition: transform .35s var(--ease); }
button.btn-submit:hover .arrow { transform: translate(3px, -3px); }

.form-success {
  display: none;
  background: var(--paper);
  padding: 2.6rem;
  border: 1px solid var(--tomato);
  border-radius: 4px;
  text-align: center;
}
.form-success.visible { display: block; }
.form-success h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: 2.4rem;
  color: var(--tomato);
  margin-bottom: 1rem;
}
.form-success p {
  color: var(--ink-soft);
  line-height: 1.6;
  max-width: 40ch;
  margin: 0 auto;
}

/* ---------- FOOTER ---------- */
footer {
  padding: 6rem var(--gutter) 2rem;
  border-top: 1px solid var(--line);
  background: var(--paper);
  position: relative;
}
.footer-mark {
  margin: 0 auto 2rem;
  max-width: var(--max);
  display: flex;
  justify-content: flex-start;
}
.footer-mark img {
  height: clamp(120px, 18vw, 220px);
  width: auto;
  display: block;
  color: var(--ink);
}
.footer-sprig {
  color: var(--olive);
  margin-top: 1.6rem;
  display: block;
}

.footer-grid {
  max-width: var(--max);
  margin: 3rem auto 0;
  padding-top: 3rem;
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 3rem;
  align-items: start;
}
.footer-tag {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  color: var(--ink-soft);
  max-width: 26ch;
  line-height: 1.3;
}
.footer-col h4 {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.3rem;
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
  color: var(--olive);
  margin-bottom: 1rem;
}
.footer-col a {
  display: block;
  padding: 0.4rem 0;
  font-size: 0.95rem;
  transition: color .25s var(--ease);
}
.footer-col a:hover { color: var(--tomato); }
.footer-col p {
  font-size: 0.95rem;
  color: var(--ink-soft);
  padding: 0.4rem 0;
}

.footer-bottom {
  max-width: var(--max);
  margin: 4rem auto 0;
  padding-top: 1.6rem;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  flex-wrap: wrap;
  gap: 1rem;
}
.footer-bottom .right .it {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  text-transform: none;
  letter-spacing: 0;
  color: var(--ink);
}

/* ---------- FLOATING PRECOMMANDE ---------- */
.float-cta {
  position: fixed;
  bottom: 1.6rem;
  right: 1.6rem;
  z-index: 50;
  background: var(--ink);
  color: var(--paper);
  padding: 0.85rem 1.3rem 0.9rem 1rem;
  border-radius: 999px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.1rem;
  font-weight: 400;
  letter-spacing: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  box-shadow: 0 12px 32px -8px rgba(20, 17, 13, 0.30);
  transform: translateY(140%);
  transition: transform .5s var(--ease), background .35s var(--ease);
}
.float-cta.visible { transform: translateY(0); }
.float-cta:hover { background: var(--olive); }
.float-cta .leaf-icon {
  color: var(--olive);
  flex: none;
  transition: color .35s var(--ease), transform .35s var(--ease);
}
.float-cta:hover .leaf-icon {
  color: var(--paper);
  transform: rotate(-12deg);
}

/* ---------- REVEAL ANIMATION ---------- */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 1s var(--ease), transform 1s var(--ease);
}
.reveal.in {
  opacity: 1;
  transform: translateY(0);
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1100px) {
  .section-head { grid-template-columns: 1fr; gap: 2rem; }
  .precommande-grid { grid-template-columns: 1fr; gap: 3rem; }
  .manifesto-grid { grid-template-columns: 1fr; gap: 3rem; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem; }

  .creation:nth-child(1) { grid-column: 1 / 8; margin-top: 0; }
  .creation:nth-child(2) { grid-column: 8 / 13; margin-top: 4rem; }
  .creation:nth-child(3) { grid-column: 1 / 6; margin-top: 2rem; }
  .creation:nth-child(4) { grid-column: 6 / 13; margin-top: 4rem; }
  .creation:nth-child(5) { grid-column: 1 / 7; margin-top: 2rem; }
  .creation:nth-child(6) { grid-column: 7 / 13; margin-top: 5rem; }

  .steps { grid-template-columns: repeat(2, 1fr); }
  .step:nth-child(2) { border-right: none; }
  .step:nth-child(1), .step:nth-child(2) { border-bottom: 1px solid rgba(240, 232, 213, 0.18); }
}

@media (max-width: 760px) {
  :root { --topbar-h: 30px; }
  .topbar { font-size: 0.62rem; padding: 0 1rem; }
  .topbar-center { display: none; }
  .topbar-left .marker:first-of-type, .topbar-left .item:nth-child(3) { display: none; }
  .topbar-right .item:nth-child(3) { display: none; }

  .nav-links { display: none; }
  .nav-burger { display: flex; }

  .hero {
    grid-template-columns: 1fr;
    gap: 2.5rem;
    padding-top: calc(var(--topbar-h) + 5.5rem);
  }
  .hero-meta { flex-wrap: wrap; gap: 0.5rem; }
  .hero-meta .left, .hero-meta .right { gap: 0.7rem; }
  .hero-side { flex-wrap: wrap; gap: 1rem; }

  section { padding: 5rem var(--gutter); }
  .manifesto, .process .inner, .precommande { padding-top: 5rem; padding-bottom: 5rem; }

  .saison-grid > .creation { grid-column: 1 / 13 !important; margin-top: 0 !important; }

  .steps { grid-template-columns: 1fr; }
  .step { border-right: none; border-bottom: 1px solid rgba(240, 232, 213, 0.18); padding: 2rem 0 !important; }
  .step:last-child { border-bottom: none; }

  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .footer-col:first-child { grid-column: 1 / -1; }

  .row-2 { grid-template-columns: 1fr; }
  .type-options { grid-template-columns: 1fr; }

  /* form-card tighter on mobile so date pickers + 100% inputs breathe */
  .form-card { padding: 1.8rem 1.4rem; }
  .form-success { padding: 2rem 1.4rem; }

  .float-cta { bottom: 1rem; right: 1rem; padding: 0.7rem 1rem; font-size: 0.82rem; }
  .margin-label { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* =========================================================
   2026 — scroll-driven motion · :has() state · soft cursor
   Progressive enhancement, fallbacks remain functional.
   ========================================================= */

/* ---------- scroll-driven hero parallax + sprig sway ---------- */
@supports (animation-timeline: scroll()) {
  .hero-visual img {
    animation: hero-img-drift linear both;
    animation-timeline: scroll(root);
    animation-range: 0 90vh;
    will-change: transform, filter;
  }
  @keyframes hero-img-drift {
    to {
      transform: scale(1.08) translateY(-3%);
      filter: contrast(1.07) saturate(1.08);
    }
  }

  .hero-text {
    animation: hero-text-drift linear both;
    animation-timeline: scroll(root);
    animation-range: 0 90vh;
    will-change: transform, opacity;
  }
  @keyframes hero-text-drift {
    to { transform: translateY(-32px); opacity: 0.55; }
  }

  .hero-sprig {
    animation: hero-sprig-sway linear both;
    animation-timeline: scroll(root);
    animation-range: 0 60vh;
    transform-origin: 50% 100%;
    will-change: transform;
  }
  @keyframes hero-sprig-sway {
    to { transform: rotate(-10deg) translateY(-4px); }
  }

  /* native reveals — supersedes the JS observer when supported */
  .reveal {
    animation: native-reveal linear both;
    animation-timeline: view();
    animation-range: entry 6% cover 26%;
    opacity: 1;
    transform: none;
  }
  @keyframes native-reveal {
    from { opacity: 0; transform: translateY(28px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  /* footer mark sinks in as you reach the bottom */
  .footer-mark img {
    animation: footer-mark-rise linear both;
    animation-timeline: view();
    animation-range: entry 0% cover 60%;
    transform-origin: left bottom;
  }
  @keyframes footer-mark-rise {
    from { transform: translateY(40px); opacity: 0.4; }
    to   { transform: translateY(0);    opacity: 1; }
  }

  /* manifesto quote scales subtly through view */
  .manifesto-quote {
    animation: quote-bloom linear both;
    animation-timeline: view();
    animation-range: entry 8% cover 40%;
    transform-origin: 0% 50%;
  }
  @keyframes quote-bloom {
    from { opacity: 0.6; transform: translateX(-6px); }
    to   { opacity: 1;   transform: translateX(0); }
  }
}

/* ---------- growing sprig scroll indicator (right margin) ---------- */
.scroll-sprig {
  position: fixed;
  right: 1.4rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 35;
  width: 36px;
  height: 92px;
  color: var(--olive);
  pointer-events: none;
  opacity: 0.85;
}
.scroll-sprig svg { width: 100%; height: 100%; display: block; overflow: visible; }
.scroll-sprig .leaf,
.scroll-sprig .seed-top {
  transform-box: fill-box;
  transform-origin: center;
}

/* hide & animate via scroll when natively supported */
@supports (animation-timeline: scroll()) {
  .scroll-sprig .stem {
    stroke-dasharray: 80;
    stroke-dashoffset: 80;
    animation: stem-grow linear both;
    animation-timeline: scroll(root);
    animation-range: 0% 100%;
  }
  .scroll-sprig .leaf,
  .scroll-sprig .seed-top {
    transform: scale(0);
    opacity: 0;
  }
  .scroll-sprig .leaf-1 {
    animation: leaf-bloom linear both;
    animation-timeline: scroll(root);
    animation-range: 8% 28%;
    transform-origin: 100% 100%;
  }
  .scroll-sprig .leaf-2 {
    animation: leaf-bloom linear both;
    animation-timeline: scroll(root);
    animation-range: 28% 52%;
    transform-origin: 0% 50%;
  }
  .scroll-sprig .leaf-3 {
    animation: leaf-bloom linear both;
    animation-timeline: scroll(root);
    animation-range: 52% 78%;
    transform-origin: 100% 50%;
  }
  .scroll-sprig .seed-top {
    animation: seed-pop linear both;
    animation-timeline: scroll(root);
    animation-range: 78% 96%;
  }
  @keyframes stem-grow {
    to { stroke-dashoffset: 0; }
  }
  @keyframes leaf-bloom {
    from { transform: scale(0) rotate(-8deg); opacity: 0; }
    to   { transform: scale(1) rotate(0);     opacity: 1; }
  }
  @keyframes seed-pop {
    from { transform: scale(0); opacity: 0; }
    60%  { transform: scale(1.4); opacity: 1; }
    to   { transform: scale(1); opacity: 1; }
  }
}

@media (max-width: 1100px) {
  .scroll-sprig { display: none; }
}

/* ---------- :has() — form valid-state glow ---------- */
.form-card::before,
.form-card::after,
.form-card .btn-submit {
  transition: width .55s var(--ease), height .55s var(--ease),
              border-color .55s var(--ease), background .35s var(--ease),
              box-shadow .45s var(--ease), transform .35s var(--ease);
}

.form-card:has(input[name="type"]:checked):has(input[name="date"]:valid):has(input[name="couverts"]:valid):has(textarea[name="message"]:valid):has(input[name="name"]:valid):has(input[name="phone"]:valid):has(input[name="email"]:valid)::before,
.form-card:has(input[name="type"]:checked):has(input[name="date"]:valid):has(input[name="couverts"]:valid):has(textarea[name="message"]:valid):has(input[name="name"]:valid):has(input[name="phone"]:valid):has(input[name="email"]:valid)::after {
  border-color: var(--olive);
  width: 56px;
  height: 56px;
}

.form-card:has(input[name="type"]:checked):has(input[name="date"]:valid):has(input[name="couverts"]:valid):has(textarea[name="message"]:valid):has(input[name="name"]:valid):has(input[name="phone"]:valid):has(input[name="email"]:valid) .btn-submit {
  background: var(--olive);
  box-shadow: 0 0 0 4px rgba(79, 90, 48, 0.16),
              0 14px 32px -10px rgba(79, 90, 48, 0.45);
}

/* live-glow per-field: any single valid input also nudges its line */
.input-line:has(input:valid:not(:placeholder-shown)),
.input-line:has(textarea:valid:not(:placeholder-shown)) {
  border-bottom-color: var(--olive);
}
.input-line { transition: border-bottom-color .35s var(--ease); }

/* ---------- inline validation (replaces native browser tooltips) ---------- */
.input-line.has-error,
.type-options.has-error label > span {
  border-bottom-color: var(--tomato);
}
.type-options.has-error label > span {
  border-color: var(--tomato);
}
.field-error {
  display: block;
  margin-top: 0.45rem;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.86rem;
  line-height: 1.4;
  color: var(--tomato);
  animation: errorIn .25s var(--ease) both;
}
.field-error::before {
  content: '↳ ';
  opacity: 0.7;
  margin-right: 0.15em;
}
@keyframes errorIn {
  from { opacity: 0; transform: translateY(-3px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* =========================================================
   CARTE — printed-menu-as-form (v2 · editorial review pass)
   - dot leaders carry the row rhythm (the menu signature)
   - mono bracketed steppers replace the cart-pill control
   - asymmetric italic masthead, marginal chapter numerals
   - receipt-style recap with perforation top + Caveat total
   - tomato = action / selection · olive = quiet confirmation
   ========================================================= */

.carte-body { background: var(--paper-warm); }

.carte-page {
  /* a single left rail every section-like block aligns to.
     marginal numerals project leftward into this rail (left: 0). */
  --rail: clamp(2.5rem, 6vw, 4.5rem);
  max-width: 920px;
  margin: 0 auto;
  padding: calc(var(--topbar-h) + 5rem) var(--gutter) 6rem;
  position: relative;
}
/* printer's-mark corner ticks at the top of the page */
.carte-page::before,
.carte-page::after {
  content: '+';
  position: absolute;
  top: calc(var(--topbar-h) + 1.6rem);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--ink-mute);
  opacity: 0.4;
  pointer-events: none;
  user-select: none;
}
.carte-page::before { left: clamp(0.5rem, 1.5vw, 1rem); }
.carte-page::after  { right: clamp(0.5rem, 1.5vw, 1rem); }

/* ---------- masthead (asymmetric, italic, signed) ---------- */
.carte-masthead {
  text-align: left;
  padding: 2rem 0 3rem var(--rail);
  border-bottom: 1px solid var(--line);
  margin-bottom: 3.5rem;
}
.cm-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 1.4rem;
}
.cm-eyebrow .cm-dot {
  width: 6px; height: 6px;
  background: var(--tomato);
  border-radius: 50%;
}
.cm-eyebrow .cm-sprig { color: var(--olive); }

.carte-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(3.6rem, 9vw, 7rem);
  line-height: 0.95;
  letter-spacing: -0.022em;
  color: var(--ink);
  display: block;
  margin: 0 0 1.6rem;
}
.carte-title em {
  font-style: italic;
  color: var(--tomato);
}

.cm-intro {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 1.7vw, 1.3rem);
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 52ch;
  margin: 0;
}
.cm-intro em {
  font-style: italic;
  color: var(--tomato);
}

.cm-sig {
  display: flex;
  justify-content: flex-end;
  margin-top: 1.6rem;
  padding-right: 0.5rem;
}
.cm-sig-name {
  font-family: var(--font-hand);
  font-size: 2rem;
  line-height: 1;
  color: var(--tomato);
  transform: rotate(-2deg);
  transform-origin: right center;
}

/* ---------- form / sections ---------- */
.carte-form {
  display: flex;
  flex-direction: column;
  gap: 4rem;
}

/* marginal chapter numerals — the eyebrow drops out into the gutter */
.carte-section {
  position: relative;
  padding-left: var(--rail);
}
.cs-eyebrow {
  position: absolute;
  left: 0;
  top: -0.1em;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(2.4rem, 4.5vw, 3.6rem);
  line-height: 1;
  color: var(--ink-soft);
  letter-spacing: -0.02em;
  user-select: none;
}

.carte-section-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1.2rem;
  width: 100%;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid var(--line-strong);
  margin-bottom: 1.4rem;
}
.cs-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.7rem, 3vw, 2.3rem);
  line-height: 1;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.cs-count {
  font-family: var(--font-mono);
  font-size: 0.64rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  white-space: nowrap;
}

.carte-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  /* belt-and-suspenders: kill UA default ol padding-inline-start (40px),
     which `* { padding: 0 }` doesn't always clobber for logical properties */
  padding: 0;
  padding-inline-start: 0;
  margin: 0;
  width: 100%;
}

/* ---------- item rows (dot-leader rhythm) ---------- */
.carte-row {
  display: block;
  width: 100%;
  padding: 1.05rem 0 1.25rem;
  position: relative;
  transition: padding-left .35s var(--ease);
}
.carte-row + .carte-row { border-top: none; }

/* selected row: tomato side-bar + indent (the strongest moment of the page) */
.carte-row:has([data-qty]:not([value="0"])) {
  padding-left: 1.2rem;
}
.carte-row:has([data-qty]:not([value="0"]))::before {
  content: '';
  position: absolute;
  left: 0;
  top: 1.05rem;
  bottom: 1.25rem;
  width: 2px;
  background: var(--tomato);
  border-radius: 1px;
}

.row-line {
  display: flex;
  align-items: baseline;
  gap: 0.55rem;
  width: 100%;
}
.row-line .leader {
  flex: 1;
  border-bottom: 1px dotted var(--ink-mute);
  height: 0;
  transform: translateY(-0.4em);
  opacity: 0.45;
  min-width: 2rem;
}

.carte-name {
  flex: 0 1 auto;
  /* baseline column width so short names don't read as orphaned next to long ones */
  min-width: clamp(7rem, 26vw, 13rem);
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.3rem, 2.1vw, 1.6rem);
  line-height: 1.15;
  letter-spacing: -0.012em;
  color: var(--ink);
  margin: 0;
}
.carte-name em {
  font-style: italic;
  color: var(--tomato);
}

.carte-desc {
  font-family: var(--font-body);
  font-size: 0.92rem;
  color: var(--ink-soft);
  line-height: 1.5;
  max-width: 64ch;
  margin: 0.4rem 0 0;
}
.carte-unit {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.92rem;
  color: var(--ink-mute);
  letter-spacing: 0;
  text-transform: none;
  margin-left: 0.15em;
}

/* ---------- mono bracketed stepper (no pill, no fill) ---------- */
.carte-stepper {
  display: inline-flex;
  align-items: baseline;
  justify-content: flex-end;
  gap: 0.25rem;
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
  flex: 0 0 auto;
  /* fixed total width so every stepper terminates at the same x-position
     across rows, regardless of selected qty (1, 10, 99) */
  width: 7.5rem;
  font-family: var(--font-mono);
  color: var(--ink-soft);
  transition: color .25s var(--ease);
  position: relative;
  user-select: none;
}
.carte-stepper::before {
  content: '[';
  font-family: var(--font-mono);
  font-size: 1.15rem;
  color: var(--ink-mute);
  margin-right: 0.35rem;
  line-height: 1;
}
.carte-stepper::after {
  content: ']';
  font-family: var(--font-mono);
  font-size: 1.15rem;
  color: var(--ink-mute);
  margin-left: 0.35rem;
  line-height: 1;
}
.carte-row:has([data-qty]:not([value="0"])) .carte-stepper { color: var(--tomato); }
.carte-row:has([data-qty]:not([value="0"])) .carte-stepper::before,
.carte-row:has([data-qty]:not([value="0"])) .carte-stepper::after { color: var(--tomato); }

.qty-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  min-height: 32px;
  padding: 0 0.35rem;
  border: none;
  background: transparent;
  border-radius: 0;
  font-family: var(--font-mono);
  font-size: 1.1rem;
  font-weight: 500;
  color: inherit;
  cursor: pointer;
  line-height: 1;
  transition: color .2s var(--ease), transform .15s var(--ease);
}
.qty-btn:hover { color: var(--tomato); }
.qty-btn:active { transform: scale(0.86); }
.qty-btn:disabled {
  opacity: 0.25;
  cursor: not-allowed;
}
.qty-btn:disabled:hover { color: inherit; }

.qty-val {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 1.05rem;
  font-weight: 500;
  min-width: 2.4ch; /* fits up to 99 without the stepper jiggling on selection */
  text-align: center;
  color: inherit;
  font-variant-numeric: tabular-nums;
}

/* ---------- coordinates / back of menu ---------- */
.carte-coords {
  position: relative;
  padding-left: var(--rail);
  margin-top: 2rem;
  padding-top: 4rem;
}
.cc-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1.2rem;
  width: 100%;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid var(--line-strong);
  margin-bottom: 2.4rem;
}
.cc-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 3rem;
  align-items: start;
}
.cc-aside {
  position: sticky;
  top: 6rem;
}
.cc-note {
  font-family: var(--font-display);
  font-size: 1.25rem;
  line-height: 1.45;
  color: var(--ink-soft);
  margin-bottom: 1.8rem;
}
.cc-note em { font-style: italic; color: var(--tomato); }
.cc-list .row {
  display: flex;
  justify-content: space-between;
  gap: 0.8rem;
  padding: 0.8rem 0;
  border-bottom: 1px solid var(--line);
}
.cc-list .row:last-child { border-bottom: none; }
.cc-list .lab {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.cc-list .val {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  color: var(--ink);
  text-align: right;
}

/* ---------- recap (receipt-stub) ---------- */
.carte-recap {
  margin: 2.4rem 0 1.4rem;
  padding: 2.2rem 1.6rem 1.4rem;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 2px;
  position: relative;
}
/* perforated top edge — radial gradient as background, top-aligned */
.carte-recap::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 14px;
  background-image: radial-gradient(circle 3px at center, var(--paper-warm) 0 3px, transparent 3.5px);
  background-size: 14px 14px;
  background-repeat: repeat-x;
  background-position: 0 4px;
  pointer-events: none;
  border-top: 0;
  border-left: 0;
}
.carte-recap::after { content: none; display: none; } /* drop bottom corner bracket */

.carte-recap .recap-lab {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 0.7rem;
}
.recap-empty {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--ink-mute);
  font-size: 1.05rem;
}
.recap-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  margin: 0 0 0.4rem;
}
.recap-list li {
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
  font-size: 0.92rem;
  line-height: 1.4;
}
.recap-list li .nm {
  flex: 0 1 auto;
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--ink);
}
.recap-list li .dots {
  flex: 1;
  border-bottom: 1px dotted var(--ink-mute);
  height: 0;
  transform: translateY(-0.4em);
  opacity: 0.45;
  min-width: 1rem;
}
.recap-list li .q {
  flex: 0 0 auto;
  font-family: var(--font-mono);
  color: var(--tomato);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  min-width: 2ch;
  text-align: right;
}
.recap-tot {
  display: block;
  font-family: var(--font-hand);
  font-size: 1.7rem;
  line-height: 1;
  color: var(--tomato);
  letter-spacing: 0;
  text-transform: none;
  padding-top: 0.6rem;
  margin-top: 0.4rem;
  border-top: 1px dashed var(--line);
  width: 100%;
  text-align: right;
  transform: rotate(-1.5deg);
  transform-origin: right center;
}

/* ---------- submit row (centered, italic disclaimer) ---------- */
.carte-form .submit-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1rem;
  margin-top: 0.4rem;
}
.carte-form .submit-row .small {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.92rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--ink-mute);
  max-width: 42ch;
  line-height: 1.5;
}

/* ---------- floating tally (soft, not sticky-cart) ---------- */
.carte-tally {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.75rem 1.2rem;
  background: var(--paper);
  color: var(--tomato);
  border: 1px solid var(--tomato);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  z-index: 50;
  transition: all .3s var(--ease);
  box-shadow: 0 14px 32px -14px rgba(200, 52, 26, 0.28);
}
.carte-tally[data-active="true"] {
  background: var(--tomato);
  color: var(--paper);
  box-shadow: 0 18px 36px -12px rgba(200, 52, 26, 0.4);
}
.carte-tally:hover { transform: translateY(-2px); }
.carte-tally .ct-leaf { display: inline-flex; }

/* ---------- nav active state ---------- */
/* applied only to plain links, never to the .nav-cta pill (which has its own
   filled-pill treatment and would end up with red-on-red text + a stray underline) */
.nav-links a.active:not(.nav-cta) { color: var(--tomato); }
.nav-links a.active:not(.nav-cta)::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 1px;
  background: var(--tomato);
}
.nav-links a { position: relative; }

/* ---------- responsive ---------- */
@media (max-width: 820px) {
  .carte-page {
    padding: calc(var(--topbar-h) + 4rem) var(--gutter) 5rem;
  }
  .carte-page::before,
  .carte-page::after { top: calc(var(--topbar-h) + 1rem); }

  .carte-masthead {
    padding: 1.2rem 0 2.4rem;
    margin-bottom: 2.4rem;
  }
  .cm-sig-name { font-size: 1.7rem; }

  /* tighter rail on mobile so a long item name doesn't crowd the stepper */
  .carte-page { --rail: clamp(2rem, 8vw, 3rem); }
  .cs-eyebrow { font-size: clamp(2rem, 7vw, 2.6rem); }

  /* row stays inline (the leader is the whole point) but on very narrow screens
     tightens up. The desc still wraps below as a continuation. */
  .row-line { gap: 0.4rem; }
  .carte-name { min-width: clamp(5rem, 38vw, 9rem); }
  .carte-stepper { width: auto; min-width: 6.5rem; }
  .qty-btn { min-width: 32px; min-height: 38px; padding: 0 0.45rem; }
  .qty-val { font-size: 1.1rem; min-width: 2ch; }
  .carte-stepper::before,
  .carte-stepper::after { font-size: 1.2rem; }

  .cc-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .cc-aside { position: static; }

  .carte-tally {
    bottom: 1rem;
    right: 1rem;
    padding: 0.65rem 1rem;
    font-size: 0.62rem;
  }
  .carte-recap {
    padding: 1.8rem 1.2rem 1.2rem;
  }
}

@media (max-width: 480px) {
  .carte-title { font-size: clamp(2.8rem, 13vw, 4.2rem); }
  .cm-intro { font-size: 1rem; }
  .carte-name { font-size: 1.15rem; }
  .row-line { flex-wrap: nowrap; }
  .recap-tot { font-size: 1.5rem; }
  .carte-tally {
    bottom: 0.85rem;
    right: 0.85rem;
    padding: 0.6rem 0.95rem;
    font-size: 0.6rem;
    gap: 0.5rem;
  }
  .carte-tally .ct-text { white-space: nowrap; }
}

/* =========================================================
   MOBILE AUDIT — global fixes
   ========================================================= */

/* anchorable sections clear the fixed nav even on direct hash-load */
section[id],
main[id] {
  scroll-margin-top: calc(var(--topbar-h) + 90px);
}

/* tally fade-out used when the in-form recap is on screen */
.carte-tally {
  transition: opacity .3s var(--ease),
              transform .3s var(--ease),
              background .35s var(--ease),
              box-shadow .35s var(--ease);
}
.carte-tally.dim {
  opacity: 0;
  transform: translateY(16px);
  pointer-events: none;
}

@media (max-width: 760px) {
  /* topbar-right hides "FR" via :nth-child(3); also hide the dangling marker */
  .topbar-right .marker { display: none; }
  /* three hero buttons fit better with a tighter, asymmetric gap */
  .hero-actions { gap: 0.9rem 1.3rem; margin-top: 1.4rem; }
}

