:root {
  --color-bg-cream: #DCC9B3;
  --color-bg-paper: #EAD9C0;
  --color-bg-deep: #1F130E;
  --color-bg-night: #2B1B14;
  --color-fg: #1F130E;
  --color-fg-on-deep: #DCC9B3;
  --color-wood: #774C30;
  --color-ochre: #9D7556;
  --color-taupe: #B7917A;
  --color-rule-light: rgba(31,19,14,0.18);
  --color-rule-deep: rgba(220,201,179,0.22);
  --font-display: "Bodoni Moda", "Times New Roman", serif;
  --font-body: "Manrope", -apple-system, system-ui, sans-serif;
  --space-1: 0.5rem;
  --space-2: 1rem;
  --space-3: 1.5rem;
  --space-4: 2.5rem;
  --space-5: 4rem;
  --space-6: 6rem;
  --space-7: 9rem;
  --tracking-caps: 0.22em;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; }
body {
  background: var(--color-bg-cream);
  color: var(--color-fg);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
}

.small-caps {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
}

.top-bar {
  background: var(--color-bg-deep);
  color: var(--color-fg-on-deep);
  text-align: center;
  padding: var(--space-1) var(--space-2);
  font-size: 0.78rem;
}

nav.primary {
  background: var(--color-bg-cream);
  padding: var(--space-3) var(--space-5);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--space-3);
  border-bottom: 1px solid var(--color-rule-light);
}

nav.primary ul {
  list-style: none;
  display: flex;
  gap: var(--space-3);
}

nav.primary ul:last-child { justify-content: flex-end; }

nav.primary a {
  color: var(--color-fg);
  text-decoration: none;
}

nav.primary a:hover { color: var(--color-wood); }
nav.primary a.active { color: var(--color-wood); }

.logo {
  text-decoration: none;
  color: var(--color-fg);
  font-family: var(--font-display);
  font-style: italic;
  line-height: 0.95;
  display: inline-flex;
  align-items: baseline;
  gap: 0.18em;
}

.logo .article {
  font-size: 0.82rem;
  font-style: italic;
  font-weight: 400;
  color: var(--color-wood);
  letter-spacing: 0.02em;
}

.logo .name {
  font-size: 1.65rem;
  font-weight: 500;
  letter-spacing: -0.01em;
}

/* HOME HERO — full width moody, no photo, dim warm tone */
.hero {
  background: var(--color-bg-deep);
  color: var(--color-fg-on-deep);
  min-height: 75vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: end;
  gap: var(--space-6);
  padding: var(--space-6) var(--space-5) var(--space-5);
  position: relative;
  overflow: hidden;
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 75% 35%, rgba(157,117,86,0.45) 0%, transparent 70%),
    radial-gradient(ellipse 80% 60% at 20% 80%, rgba(31,19,14,0.92) 0%, transparent 60%);
  pointer-events: none;
}

.hero-overlay-text { position: relative; z-index: 2; }
.hero-overlay-text .small-caps { color: var(--color-taupe); }
.hero-eyebrow { margin-bottom: var(--space-3); }

.hero h1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(4rem, 11vw, 9rem);
  line-height: 0.92;
  letter-spacing: -0.02em;
  color: var(--color-fg-on-deep);
  margin-bottom: var(--space-3);
}

.hero h1 .article {
  display: block;
  font-style: italic;
  font-size: 0.5em;
  font-weight: 400;
  color: var(--color-taupe);
  margin-bottom: -0.1em;
  letter-spacing: 0.02em;
}

.hero-content-right {
  position: relative;
  z-index: 2;
  align-self: end;
  max-width: 36ch;
  padding-bottom: var(--space-2);
}

.hero-content-right p {
  font-size: 0.95rem;
  color: var(--color-fg-on-deep);
  opacity: 0.84;
  margin-bottom: var(--space-3);
}

.hero-cta {
  display: inline-block;
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--color-fg-on-deep);
  text-decoration: none;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--color-fg-on-deep);
}

.hero-cta:hover {
  color: var(--color-ochre);
  border-color: var(--color-ochre);
}

/* PAGE HERO — for child pages, mini moody */
.page-hero {
  background: var(--color-bg-deep);
  color: var(--color-fg-on-deep);
  padding: var(--space-7) var(--space-5) var(--space-6);
  position: relative;
  overflow: hidden;
}

.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 60% at 80% 30%, rgba(157,117,86,0.32) 0%, transparent 70%),
    radial-gradient(ellipse 70% 60% at 20% 90%, rgba(31,19,14,0.85) 0%, transparent 60%);
  pointer-events: none;
}

.page-hero-inner {
  position: relative;
  z-index: 2;
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--space-6);
  align-items: end;
}

.page-hero .small-caps { color: var(--color-taupe); display: block; margin-bottom: var(--space-3); }

.page-hero h1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(3.5rem, 8vw, 6.5rem);
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--color-fg-on-deep);
}

.page-hero p.intro {
  font-size: 0.98rem;
  line-height: 1.65;
  opacity: 0.86;
  max-width: 38ch;
  align-self: end;
  padding-bottom: var(--space-2);
}

/* BROWSE STRIP — home (4 categories) */
.browse-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  background: var(--color-rule-light);
  margin: 0;
}

.browse-card {
  background: var(--color-bg-cream);
  padding: var(--space-5) var(--space-3);
  min-height: 18rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  text-decoration: none;
  color: var(--color-fg);
  position: relative;
  transition: background 0.2s;
}

.browse-card:nth-child(2) { background: var(--color-bg-paper); }
.browse-card:nth-child(3) { background: var(--color-bg-cream); }
.browse-card:nth-child(4) { background: var(--color-bg-paper); }

.browse-card:hover { background: var(--color-taupe); }

.browse-card .small-caps { color: var(--color-wood); margin-bottom: var(--space-2); }

.browse-card h3 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 2rem;
  line-height: 1;
  margin-bottom: var(--space-3);
}

.browse-card p {
  font-size: 0.85rem;
  opacity: 0.7;
}

.browse-card .arrow {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  align-self: flex-end;
  color: var(--color-wood);
}

/* EDITORIAL 2-col alternating */
.editorial-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: var(--space-7);
  max-width: 1280px;
  margin: var(--space-7) auto;
  padding: 0 var(--space-5);
}

.editorial-split .text .label {
  color: var(--color-wood);
  margin-bottom: var(--space-3);
  display: block;
}

.editorial-split .text h2 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1;
  margin-bottom: var(--space-4);
  letter-spacing: -0.01em;
}

.editorial-split .text p {
  font-size: 1rem;
  line-height: 1.75;
  margin-bottom: var(--space-3);
  max-width: 42ch;
}

.atmosphere {
  background: var(--color-bg-deep);
  aspect-ratio: 4 / 5;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.atmosphere::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 40% at 50% 60%, rgba(157,117,86,0.35) 0%, transparent 70%),
    radial-gradient(ellipse 30% 60% at 50% 20%, rgba(220,201,179,0.06) 0%, transparent 70%);
}

.atmosphere-glyph {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 14rem;
  line-height: 0.85;
  color: var(--color-bg-cream);
  opacity: 0.92;
  letter-spacing: -0.02em;
  position: relative;
  z-index: 1;
}

.atmosphere-glyph .ampersand {
  color: var(--color-ochre);
  font-style: italic;
}

.editorial-split.reverse { direction: rtl; }
.editorial-split.reverse > * { direction: ltr; }

/* MENU LIST — child carte pages */
.carte-page {
  max-width: 880px;
  margin: var(--space-7) auto;
  padding: 0 var(--space-5);
}

.carte-page .lede {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  line-height: 1.5;
  max-width: 56ch;
  margin: 0 auto var(--space-6);
  text-align: center;
  color: var(--color-fg);
  opacity: 0.86;
}

.menu-block { margin-bottom: var(--space-6); }

.menu-block h2 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 2.4rem;
  line-height: 1;
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-rule-light);
  letter-spacing: -0.01em;
}

.menu-block .subhead {
  color: var(--color-wood);
  margin-bottom: var(--space-3);
  display: block;
}

.menu-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px dashed var(--color-rule-light);
  align-items: baseline;
}

.menu-item:last-child { border-bottom: none; }

.menu-item .name {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1.1;
}

.menu-item .meta {
  font-size: 0.78rem;
  color: var(--color-wood);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  margin-top: 0.3rem;
  display: block;
}

.menu-item .desc {
  font-size: 0.92rem;
  margin-top: 0.4rem;
  color: var(--color-fg);
  opacity: 0.78;
  line-height: 1.5;
  max-width: 56ch;
}

.menu-item .price {
  font-family: var(--font-body);
  font-weight: 500;
  font-feature-settings: "tnum";
  font-size: 1rem;
  white-space: nowrap;
  align-self: start;
  padding-top: 0.4rem;
  color: var(--color-fg);
}

/* CROSS-LINKS at bottom of category pages */
.cross-links {
  background: var(--color-bg-paper);
  padding: var(--space-6) var(--space-5);
  border-top: 1px solid var(--color-rule-light);
  border-bottom: 1px solid var(--color-rule-light);
}

.cross-links-inner {
  max-width: 1280px;
  margin: 0 auto;
}

.cross-links .label {
  color: var(--color-wood);
  display: block;
  margin-bottom: var(--space-3);
}

.cross-links-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
}

.cross-link {
  text-decoration: none;
  color: var(--color-fg);
  padding: var(--space-3) 0;
  border-top: 1px solid var(--color-rule-light);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.6rem;
  transition: color 0.2s;
}

.cross-link:hover { color: var(--color-wood); }

.cross-link .arrow {
  font-size: 1.1rem;
  color: var(--color-wood);
}

/* PROMO STRIP */
.promo-strip {
  background: var(--color-bg-paper);
  padding: var(--space-6) var(--space-5);
  border-top: 1px solid var(--color-rule-light);
  border-bottom: 1px solid var(--color-rule-light);
}

.promo-strip .inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 3fr 1fr;
  gap: var(--space-5);
  align-items: center;
}

.promo-strip .label { color: var(--color-wood); }

.promo-strip h3 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 2rem;
  line-height: 1.1;
}

.promo-strip p {
  font-size: 0.95rem;
  line-height: 1.65;
}

.promo-strip .arrow-link {
  font-family: var(--font-body);
  text-decoration: none;
  color: var(--color-fg);
  font-weight: 500;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  justify-self: end;
}

/* HISTOIRE editorial */
.histoire {
  max-width: 720px;
  margin: var(--space-7) auto;
  padding: 0 var(--space-5);
}

.histoire .label {
  color: var(--color-wood);
  margin-bottom: var(--space-3);
  display: block;
}

.histoire h2 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.05;
  margin-bottom: var(--space-4);
  letter-spacing: -0.01em;
}

.histoire p {
  font-size: 1.05rem;
  line-height: 1.75;
  margin-bottom: var(--space-3);
}

.histoire blockquote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.5rem;
  line-height: 1.4;
  border-left: 2px solid var(--color-wood);
  padding-left: var(--space-3);
  margin: var(--space-5) 0;
  max-width: 50ch;
}

.histoire blockquote cite {
  display: block;
  font-family: var(--font-body);
  font-style: normal;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  margin-top: var(--space-2);
  color: var(--color-wood);
}

/* INFOS — dark footer-like 4-col */
.infos {
  background: var(--color-bg-deep);
  color: var(--color-fg-on-deep);
  padding: var(--space-6) var(--space-5);
}

.infos-grid {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--space-5);
}

.infos-grid .brand h2 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 3rem;
  line-height: 0.95;
  margin-bottom: var(--space-2);
}

.infos-grid .brand p {
  font-size: 0.9rem;
  opacity: 0.78;
  max-width: 32ch;
}

.infos-grid .block .small-caps {
  color: var(--color-taupe);
  margin-bottom: var(--space-2);
  display: block;
}

.infos-grid .block h4 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.3rem;
  margin-bottom: var(--space-2);
  color: var(--color-fg-on-deep);
}

.infos-grid .block p, .infos-grid .block a, .infos-grid .block li {
  font-size: 0.88rem;
  line-height: 1.85;
  color: var(--color-fg-on-deep);
  opacity: 0.85;
  text-decoration: none;
}

.infos-grid .block a:hover { color: var(--color-ochre); opacity: 1; }
.infos-grid .block ul { list-style: none; }
.infos-grid .block .closed { opacity: 0.45; }

footer.bottom {
  background: var(--color-bg-deep);
  color: var(--color-taupe);
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--color-rule-deep);
  text-align: center;
}

@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; padding: var(--space-5) var(--space-3); min-height: 60vh; }
  .browse-strip { grid-template-columns: repeat(2, 1fr); }
  .editorial-split, .editorial-split.reverse { grid-template-columns: 1fr; gap: var(--space-4); direction: ltr; padding: 0 var(--space-3); }
  .promo-strip .inner { grid-template-columns: 1fr; }
  .infos-grid { grid-template-columns: 1fr 1fr; }
  nav.primary ul { display: none; }
  nav.primary { grid-template-columns: 1fr; }
  .page-hero-inner { grid-template-columns: 1fr; gap: var(--space-3); }
  .cross-links-grid { grid-template-columns: 1fr; }
  .menu-item { grid-template-columns: 1fr; }
  .menu-item .price { padding-top: var(--space-1); }
}

/* ---------- insta-feed (v2) ---------- */
.insta-feed {
  padding: var(--space-6) var(--space-4);
  text-align: center;
  background: var(--color-bg-cream, var(--color-bg));
}
.insta-feed .section-label {
  display: block;
  font-family: var(--font-body);
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.6;
  margin-bottom: var(--space-3);
}
.insta-feed .insta-handle-link {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  text-decoration: none;
  color: inherit;
  margin-bottom: var(--space-4);
}
.insta-feed .insta-handle {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 5vw, 3rem);
  line-height: 1;
  font-style: italic;
}
.insta-feed .insta-arrow {
  font-family: var(--font-body);
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  opacity: 0.7;
}
.insta-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-1);
  max-width: 1100px;
  margin: 0 auto;
}
.insta-cell {
  display: block;
  aspect-ratio: 1;
  overflow: hidden;
  position: relative;
}
.insta-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.insta-cell:hover img {
  transform: scale(1.05);
}
@media (max-width: 720px) {
  .insta-grid { grid-template-columns: repeat(2, 1fr); }
}

