﻿/* ═══════════════════════════════════════════════════════════════
   MTA — style.css
   Inspiration : Boffi.com + Louis Vuitton
   Palette : #FAFAF8 (blanc pur) · #111110 (noir encre) · #C4A882 (or chaud)
   Typo : Cormorant Garamond (display) + Jost (corps)
   ═══════════════════════════════════════════════════════════════ */

/* ─── Reset ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:        #111110;
  --beige:     #1C1A17;
  --beige-md:  #252320;
  --ink:       #F0ECE4;
  --ink-mid:   #C0BAB0;
  --ink-light: #7A7870;
  --gold:      #C4A06A;
  --gold-lt:   #D4B47C;
  --gold-dk:   #A07840;
  --white:     #FFFFFF;
  --serif:     'Cormorant Garamond', Georgia, serif;
  --sans:      'Jost', -apple-system, sans-serif;
  --nav-h:     58px;
  --ease:      cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

html { scroll-behavior: smooth; font-size: 16px; overflow-x: hidden; }

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 300;
  line-height: 1.75;
  overflow-x: hidden;
}
body.is-loading { overflow: hidden; }

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* ─── Typography scale ───────────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--serif);
  font-weight: 300;
  line-height: 1.1;
  letter-spacing: -0.01em;
}
h1 { font-size: clamp(3.5rem, 8vw, 7rem); }
h2 { font-size: clamp(2.5rem, 5vw, 4.5rem); }
h3 { font-size: clamp(2rem, 3.5vw, 3rem); }
em { font-style: italic; font-weight: 200; }
p  { font-size: 0.875rem; line-height: 1.9; color: var(--ink-mid); max-width: 58ch; }

/* ─── Loader ─────────────────────────────────────────────── */
#loader {
  position: fixed;
  inset: 0;
  background: #0D0D0C;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2.5rem;
  transition: opacity 0.6s var(--ease), visibility 0.6s var(--ease);
}
#loader.hidden { opacity: 0; visibility: hidden; pointer-events: none; }

.loader-logo {
  color: #F0ECE4;
  width: 140px;
  height: auto;
  opacity: 0;
  animation: heroFadeUp 0.8s 0.2s var(--ease) forwards;
}
.loader-logo svg { width: 100%; height: auto; }

.loader-bar {
  width: 160px;
  height: 1px;
  background: rgba(255,255,255,0.15);
  overflow: hidden;
}
.loader-fill {
  height: 100%;
  width: 0;
  background: var(--gold);
  transition: width 1s var(--ease);
}

/* ─── Section label row (Boffi-style) ───────────────────── */
.section-label-row {
  display: flex;
  align-items: center;
  gap: 2rem;
  padding: 5rem 5vw 4rem;
  max-width: 1400px;
  margin: 0 auto;
}
.label-rule {
  flex: 1;
  border: none;
  border-top: 1px solid rgba(255,255,255,0.1);
}
.section-label {
  font-family: var(--serif);
  font-size: 1.9rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ink);
  white-space: nowrap;
}

/* ─── Text link ──────────────────────────────────────────── */
.text-link {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink);
  padding-bottom: 2px;
  border-bottom: 1px solid var(--ink);
  transition: color 0.3s, border-color 0.3s, gap 0.3s;
}
.text-link:hover { color: var(--gold-dk); border-color: var(--gold-dk); gap: 1.2rem; }
.text-link svg { flex-shrink: 0; transition: transform 0.3s; }
.text-link:hover svg { transform: translateX(4px); }

/* ═══════════════════════════════════════════════════════════
   NAVIGATION — Boffi centered logo / LV symmetric nav
   ═══════════════════════════════════════════════════════════ */
#header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--nav-h);
  background: var(--bg);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
#nav {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 3vw;
  position: relative;
}

.nav-tagline {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 1.55rem;
  letter-spacing: 0.06em;
  white-space: nowrap;
  pointer-events: none;
  user-select: none;

  /* Dégradé or luxe */
  background: linear-gradient(
    135deg,
    #8A6A38 0%,
    #C9A84C 28%,
    #F0D080 48%,
    #C9A84C 68%,
    #8A6A38 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;

  /* Halo lumineux subtil */
  filter: drop-shadow(0 1px 12px rgba(201,168,76,0.35));
}


.nav-links {
  display: flex;
  align-items: center;
  gap: 2.8rem;
}

.nav-left, .nav-right {
  display: flex;
  align-items: center;
  gap: 2.5rem;
}
.nav-right { justify-content: flex-end; }

.nav-link {
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #7A6848;
  transition: color 0.3s;
  position: relative;
  padding-bottom: 2px;
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 0; height: 1px;
  background: #7A6848;
  transition: width 0.35s var(--ease);
}
.nav-link:hover { color: #4A3E28; }
.nav-link:hover::after { width: 100%; }

.nav-cta {
  color: var(--gold) !important;
  background: transparent;
  border: 1.5px solid var(--gold) !important;
  padding: 0.6rem 1.9rem !important;
  letter-spacing: 0.28em;
  font-weight: 700;
  font-size: 0.72rem;
  transition: background 0.35s, color 0.35s, box-shadow 0.35s, border-color 0.35s !important;
}
.nav-cta::after { display: none !important; }
.nav-cta:hover {
  background: var(--gold) !important;
  color: #0D0D0C !important;
  border-color: var(--gold) !important;
  box-shadow: 0 0 18px rgba(196,164,100,0.3), 0 4px 24px rgba(196,164,100,0.2) !important;
}

.nav-brand {
  display: flex;
  align-items: center;
  color: var(--ink);
  transition: opacity 0.3s;
  flex-shrink: 0;
}
.nav-brand:hover { opacity: 0.7; }
.logo-nav { width: 88px; height: 37px; display: block; }

/* Burger */
.nav-burger { display: none; flex-direction: column; gap: 6px; padding: 4px; justify-self: end; }
.burger-inner { display: flex; flex-direction: column; gap: 6px; }
.burger-inner span { display: block; width: 22px; height: 1px; background: var(--ink); transition: all 0.35s; }
.nav-burger.open .burger-inner span:first-child { transform: translateY(7px) rotate(45deg); }
.nav-burger.open .burger-inner span:last-child  { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--ink);
  z-index: 900;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2.5rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s var(--ease), visibility 0.5s;
}
.mobile-menu.open { opacity: 1; visibility: visible; }
/* Mobile menu brand */
.mm-brand {
  color: rgba(255,255,255,0.6);
  transition: color 0.3s;
  margin-bottom: 1rem;
}
.mm-brand:hover { color: var(--gold-lt); }
.mm-link {
  font-family: var(--serif);
  font-size: 2.5rem;
  font-weight: 300;
  color: rgba(255,255,255,0.8);
  letter-spacing: 0.05em;
  transition: color 0.3s;
}
.mm-link:hover { color: var(--gold); }
.mm-cta {
  font-family: var(--sans);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--gold) !important;
  border-bottom: 1px solid var(--gold);
  font-weight: 400;
  padding-bottom: 3px;
  margin-top: 1rem;
}

/* ═══════════════════════════════════════════════════════════
   HERO — Cinématique, plein écran, typographie centrale
   ═══════════════════════════════════════════════════════════ */
#hero {
  position: relative;
  height: 100svh;
  min-height: 640px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.hero-bg {
  position: absolute;
  inset: 0;
}

/* Hero ghost monogram — supprimé */
.hero-monogram { display: none; }

/* ── Hero background : fond sombre élégant ── */
.hero-bg-img {
  position: absolute;
  inset: 0;
  background: #141210;
}

/* Halo central chaud — lumière d'atelier */
.hero-bg-img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 75% 65% at 50% 48%,
    rgba(180,145,90,0.09) 0%,
    rgba(120,95,55,0.05) 45%,
    transparent 75%
  );
  z-index: 1;
}

/* Grille architecturale — supprimée */
.hero-bg-img::after { display: none; }

/* Canvas tunnel */
.hero-tunnel {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 3;
  pointer-events: none;
  display: none;
}

/* Vignette : bords sombres, effet cinéma */
.hero-vignette {
  position: absolute;
  inset: 0;
  z-index: 4;
  background:
    radial-gradient(ellipse 100% 100% at 50% 50%, transparent 40%, rgba(0,0,0,0.55) 100%),
    linear-gradient(to bottom, rgba(0,0,0,0.15) 0%, transparent 18%, transparent 78%, rgba(0,0,0,0.4) 100%);
  pointer-events: none;
}

.hero-content {
  position: relative;
  z-index: 5;
  text-align: center;
  color: var(--white);
  padding: 2rem;
}

.hero-eyebrow {
  font-family: var(--sans);
  font-size: 0.6rem;
  font-weight: 300;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.5rem;
  max-width: none;
  opacity: 0;
  animation: heroFadeUp 1s 0.4s var(--ease) forwards;
}

.hero-sep {
  color: var(--gold);
  margin-bottom: 1.5rem;
  opacity: 0;
  animation: heroFadeUp 1s 0.55s var(--ease) forwards;
  display: flex;
  justify-content: center;
}

.hero-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 3rem;
}
.ht-line {
  display: block;
  color: var(--white);
  overflow: hidden;
  opacity: 0;
  transform: translateY(60px);
  animation: heroSlide 1.2s var(--ease) forwards;
}
.ht-line:first-child { animation-delay: 0.6s; }
.ht-line:last-child  { animation-delay: 0.85s; }
.ht-italic { font-style: italic; font-weight: 200; color: rgba(255,255,255,0.75); }

.hero-ctas {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  flex-wrap: wrap;
  opacity: 0;
  animation: heroFadeUp 1s 1.3s var(--ease) forwards;
}

.cta-link {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  font-family: var(--sans);
  font-size: 0.65rem;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--white);
  padding-bottom: 2px;
  border-bottom: 1px solid rgba(255,255,255,0.4);
  transition: gap 0.35s, border-color 0.3s, color 0.3s;
}
.cta-link:hover { gap: 1.4rem; border-color: var(--gold); color: var(--gold); }
.cta-link svg { transition: transform 0.35s; flex-shrink: 0; }
.cta-link:hover svg { transform: translateX(5px); }

.cta-link--outline {
  color: rgba(255,255,255,0.5);
  border-bottom-color: rgba(255,255,255,0.15);
}
.cta-link--outline:hover { color: rgba(255,255,255,0.8); border-color: rgba(255,255,255,0.4); }

/* Scroll indicator */
.hero-scroll {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
}
.hs-line {
  width: 1px;
  height: 48px;
  background: linear-gradient(to bottom, var(--gold), transparent);
  animation: scrollPulse 2.2s infinite;
}
.hero-scroll span {
  font-family: var(--sans);
  font-size: 0.52rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.3);
}

@keyframes heroFadeUp {
  0%   { opacity: 0; transform: translateY(20px); }
  100% { opacity: 1; transform: translateY(0); }
}
@keyframes heroSlide {
  0%   { opacity: 0; transform: translateY(60px); }
  100% { opacity: 1; transform: translateY(0); }
}
@keyframes scrollPulse {
  0%, 100% { opacity: 0.3; transform: scaleY(0.6); transform-origin: top; }
  50%       { opacity: 1;   transform: scaleY(1);   transform-origin: top; }
}

@keyframes heroKenBurns {
  0%   { transform: scale(1.07); }
  100% { transform: scale(1.0); }
}

/* Bande de séparation blanche — supprimée */
.hero-divider { display: none; }

/* ═══════════════════════════════════════════════════════════
   MARQUEE — LV-style scrolling band
   ═══════════════════════════════════════════════════════════ */
/* ─── Marquee — beige tint ──────────────────────────────── */
.marquee-wrap {
  overflow: hidden;
  border-top: 1px solid rgba(255,255,255,0.07);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  padding: 1rem 0;
  background: var(--beige);
  user-select: none;
}
.marquee-track {
  display: flex;
  align-items: center;
  gap: 0;
  width: max-content;
  animation: marquee 22s linear infinite;
}
.marquee-track span {
  font-family: var(--serif);
  font-size: 1rem;
  font-weight: 300;
  font-style: italic;
  color: var(--ink-mid);
  padding: 0 1.8rem;
  white-space: nowrap;
}
.marquee-dot {
  font-style: normal !important;
  color: var(--gold) !important;
  padding: 0 !important;
  font-family: var(--sans) !important;
  font-size: 0.7rem !important;
}
@keyframes marquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.marquee-wrap:hover .marquee-track { animation-play-state: paused; }

/* ═══════════════════════════════════════════════════════════
   RÉALISATIONS — carousel plein cadre style Boffi
   ═══════════════════════════════════════════════════════════ */
#realisations { background: var(--ink); overflow: hidden; margin: 0; padding: 0; max-width: 100vw; }

.rl-carousel { cursor: grab; }
.rl-carousel.is-grabbing { cursor: grabbing; }

.rl-carousel {
  position: relative;
  width: 100%;
  height: 100svh;
  min-height: 520px;
  overflow: hidden;
  display: block;
}

.rl-track {
  display: flex;
  height: 100%;
  transition: transform 0.75s cubic-bezier(0.77, 0, 0.175, 1);
  will-change: transform;
  user-select: none;
  opacity: 0;
}

.rl-slide {
  position: relative;
  flex: 0 0 100%;
  height: 100%;
  overflow: hidden;
}

/* Images : parfaitement cadrées plein écran */
.rl-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center center;
  image-rendering: auto;
  transition: none;
}
.rl-slide.is-active .rl-bg { transform: none; }

.rl-bg--1 {
  background-image: url('Image%20MTA%20acceuil/photo-1640357154220-9775b0f31dec.avif');
  background-position: center 30%;
}
.rl-bg--2 {
  background-image: url('Image%20MTA%20acceuil/photo-1695002817411-203c7f19dfa3.avif');
  background-position: center center;
}
.rl-bg--3 {
  background-image: url('Image%20MTA%20acceuil/premium_photo-1680382578857-c331ead9ed51.avif');
  background-position: center center;
}

/* Dégradé bas Boffi — lire le texte sans masquer la photo */
.rl-fog {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, rgba(0,0,0,0.42) 0%, rgba(0,0,0,0.10) 30%, transparent 55%),
    linear-gradient(to top,    rgba(0,0,0,0.38) 0%, rgba(0,0,0,0.08) 35%, transparent 60%);
  pointer-events: none;
}

/* Phrase signature — haut de slide */
.rl-signature {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 6vh;
  pointer-events: none;
  z-index: 5;
}
.rl-signature-text {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(2rem, 4.5vw, 4.2rem);
  color: rgba(255,255,255,0.92);
  letter-spacing: 0.02em;
  line-height: 1;
  text-align: center;
  text-shadow: 0 2px 40px rgba(0,0,0,0.35);
  position: relative;
}
.rl-signature-text::before,
.rl-signature-text::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 3.5vw;
  height: 1px;
  background: rgba(255,255,255,0.45);
}
.rl-signature-text::before { right: calc(100% + 1.8rem); }
.rl-signature-text::after  { left:  calc(100% + 1.8rem); }

/* Texte ancré bas-gauche — style Boffi */
.rl-content {
  position: absolute;
  bottom: 0;
  left: 0;
  padding: 4rem 5vw 5rem;
  color: var(--white);
  max-width: 90vw;
  opacity: 1;
  transform: translateY(0);
}
.rl-slide.is-active .rl-content {
  opacity: 1;
  transform: translateY(0);
}

.rl-cat {
  display: block;
  font-family: var(--sans);
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.38em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.85);
  margin-bottom: 0.9rem;
}

.rl-title {
  font-family: var(--sans);
  font-size: clamp(3rem, 5vw, 5rem);
  font-weight: 900;
  line-height: 0.9;
  color: var(--white);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 1.5rem;
}
.rl-title em {
  display: block;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  text-transform: none;
  font-size: clamp(1rem, 1.6vw, 1.4rem);
  color: rgba(255,255,255,0.75);
  letter-spacing: 0;
}

.rl-desc {
  font-family: var(--sans);
  font-size: clamp(0.9rem, 1.2vw, 1.3rem);
  font-weight: 600;
  color: rgba(255,255,255,0.95);
  line-height: 1.5;
  max-width: 70ch;
  margin-bottom: 2.5rem;
}

.rl-specs {
  display: flex;
  gap: 2.8rem;
  margin-bottom: 2rem;
}
.rl-spec { display: flex; flex-direction: column; gap: 0.25rem; }
.rl-spec span {
  font-family: var(--sans);
  font-size: 0.52rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.28);
}
.rl-spec strong {
  font-family: var(--serif);
  font-size: 0.92rem;
  font-weight: 400;
  color: rgba(255,255,255,0.65);
}

/* Bouton style Boffi — blanc avec bordure */
.rl-cta {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  font-family: var(--sans);
  font-size: 0.6rem;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--white);
  background: transparent;
  border: 1px solid rgba(255,255,255,0.55);
  padding: 0.75rem 1.6rem;
  transition: background 0.3s, border-color 0.3s, gap 0.3s;
}
.rl-cta:hover {
  background: rgba(255,255,255,0.12);
  border-color: var(--white);
  gap: 1.5rem;
}
.rl-cta svg { transition: transform 0.35s; flex-shrink: 0; }
.rl-cta:hover svg { transform: translateX(5px); }

/* Flèches style Boffi — simples, sur les bords */
.rl-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.7);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: color 0.3s;
}
.rl-arrow:hover { color: var(--white); }
.rl-arrow--prev { left: 1.5vw; }
.rl-arrow--next { right: 1.5vw; }
.rl-arrow:disabled { opacity: 0.18; pointer-events: none; }

/* UI bas : dots + counter */
.rl-ui {
  position: absolute;
  bottom: 2.5rem;
  right: 4vw;
  display: flex;
  align-items: center;
  gap: 2rem;
  z-index: 10;
}
.rl-dots { display: flex; align-items: center; gap: 0.65rem; }
.rl-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(255,255,255,0.22);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.3s, transform 0.3s;
}
.rl-dot--active { background: var(--white); transform: scale(1.5); }
.rl-counter {
  font-family: var(--sans);
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.rl-cur   { color: rgba(255,255,255,0.65); }
.rl-slash { color: rgba(255,255,255,0.2); }
.rl-tot   { color: rgba(255,255,255,0.3); }



/* ═══════════════════════════════════════════════════════════
   NOS PRESTATIONS — grille LV-style
   ═══════════════════════════════════════════════════════════ */
#prestations {
  background: var(--bg);
  padding-bottom: 8vw;
  overflow: visible;
}

.cat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  max-width: 1520px;
  margin: 0 auto;
  padding: 0 4vw 4vw;
  perspective: 1600px;
  perspective-origin: 50% 30%;
  align-items: start;
}

.cat-card {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  padding: 0 0 1.6rem;
  background: #1C1A17;
  box-shadow:
    0 2px 8px rgba(0,0,0,0.2),
    0 8px 24px rgba(0,0,0,0.3);
  transform-style: preserve-3d;
  will-change: transform, box-shadow;
  transition: box-shadow 0.5s var(--ease), transform 0.5s var(--ease);
}
/* Stagger vertical — illusion de profondeur */
.cat-card:nth-child(4n+1) { margin-top: 4rem; }
.cat-card:nth-child(4n+2) { margin-top: 0; }
.cat-card:nth-child(4n+3) { margin-top: 6rem; }
.cat-card:nth-child(4n+4) { margin-top: 2rem; }

.cat-card:hover {
  box-shadow:
    0 16px 40px rgba(0,0,0,0.10),
    0 40px 80px rgba(0,0,0,0.08),
    0 2px 6px rgba(0,0,0,0.04);
}

.cat-img-wrap {
  overflow: hidden;
  aspect-ratio: 3 / 4;
  margin-bottom: 1.4rem;
  background: var(--beige);
}
.cat-img {
  width: 100%;
  height: 120%;
  margin-top: -10%;
  background-size: cover;
  background-position: center 50%;
  will-change: transform;
  transition: transform 0.8s var(--ease);
}
.cat-card:hover .cat-img { transform: scale(1.04) translateY(-2%); }
.cat-img--gradient {
  background: linear-gradient(160deg, #EDE6D8 0%, #D4CABC 40%, #B8A898 100%);
}
.cat-img--c1 { background: linear-gradient(160deg, #2C2C2A 0%, #1A1A18 100%); }
.cat-img--c2 { background: linear-gradient(160deg, #B8935A 0%, #8A6A38 100%); }
.cat-img--c3 { background: linear-gradient(160deg, #4A5568 0%, #2D3748 100%); }
.cat-img--c4 { background: linear-gradient(160deg, #EDE6D8 0%, #C4B49A 100%); }
.cat-img--c5 { background: linear-gradient(160deg, #8B7355 0%, #5C4A2A 100%); }
.cat-img--c6 { background: linear-gradient(160deg, #6B7280 0%, #374151 100%); }
.cat-img--c7 { background: linear-gradient(160deg, #D4CABC 0%, #A89880 100%); }
.cat-img--c8 { background: linear-gradient(160deg, #3D4A3E 0%, #2A3428 100%); }

/* Overlay hover LV — pseudo-élément qui fade in en une autre couleur */
.cat-img { position: relative; }
.cat-img::after {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.cat-card:hover .cat-img::after { opacity: 1; }

.cat-img--c1::after { background: linear-gradient(160deg, #B8935A 0%, #8A6A38 100%); }
.cat-img--c2::after { background: linear-gradient(160deg, #EDE6D8 0%, #C4B49A 100%); }
.cat-img--c3::after { background: linear-gradient(160deg, #3D4A3E 0%, #2A3428 100%); }
.cat-img--c4::after { background: linear-gradient(160deg, #2C2C2A 0%, #1A1A18 100%); }
.cat-img--c5::after { background: linear-gradient(160deg, #4A5568 0%, #2D3748 100%); }
.cat-img--c6::after { background: linear-gradient(160deg, #B8935A 0%, #8A6A38 100%); }
.cat-img--c7::after { background: linear-gradient(160deg, #3D4A3E 0%, #2A3428 100%); }
.cat-img--c8::after { background: linear-gradient(160deg, #D4CABC 0%, #A89880 100%); }

.cat-info {
  padding: 0 1.4rem;
}

.cat-tag {
  display: block;
  font-family: var(--sans);
  font-size: 0.55rem;
  font-weight: 400;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-light);
  margin-bottom: 0.5rem;
}

.cat-name {
  font-family: var(--serif);
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 0.45rem;
  line-height: 1.3;
}

.cat-detail {
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 300;
  color: var(--ink-light);
  line-height: 1.65;
  max-width: none;
}

/* ═══════════════════════════════════════════════════════════
   CHIFFRES — plein écran sombre, Boffi-style
   ═══════════════════════════════════════════════════════════ */
#chiffres {
  position: relative;
  padding: 4vw 5vw;
  overflow: hidden;
}
.chiffres-bg {
  position: absolute;
  inset: 0;
  background: #0D0D0C;
}
.chiffres-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(196,168,130,0.06) 1px, transparent 1px);
  background-size: 40px 40px;
}

.chiffres-content {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  max-width: 1200px;
  margin: 0 auto 4rem;
}

.chiffre-sep {
  width: 1px;
  height: 80px;
  background: rgba(196,164,100,0.25);
  flex-shrink: 0;
}

.chiffre-col {
  flex: 1;
  text-align: center;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}
.chiffre-col--pct { flex-direction: row; flex-wrap: wrap; justify-content: center; }
.chiffre-col--pct .cl { flex-basis: 100%; }

.cn {
  font-family: var(--serif);
  font-size: clamp(3.5rem, 6vw, 5.5rem);
  font-weight: 200;
  color: var(--gold);
  line-height: 1;
}
.cn-suf {
  font-family: var(--serif);
  font-size: clamp(2rem, 3vw, 3rem);
  font-weight: 200;
  color: var(--gold);
  line-height: 1;
  align-self: flex-start;
  margin-top: 0.5rem;
}
.cl {
  font-family: var(--sans);
  font-size: 0.6rem;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.3);
}

.chiffres-quote {
  position: relative;
  z-index: 1;
  text-align: center;
  font-family: var(--serif);
  font-size: clamp(1.2rem, 2.5vw, 1.8rem);
  font-style: italic;
  font-weight: 300;
  color: rgba(255,255,255,0.35);
  line-height: 1.6;
  max-width: 60ch;
  margin: 0 auto;
}

/* ═══════════════════════════════════════════════════════════
   SAVOIR-FAIRE — grille 4 colonnes, très Boffi
   ═══════════════════════════════════════════════════════════ */
#savoir-faire { background: var(--bg); padding-bottom: 0; }

.sf-intro {
  padding: 0 5vw 5vw;
  max-width: 1400px;
  margin: 0 auto;
  text-align: center;
}
.sf-intro h2 {
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  color: var(--ink);
  max-width: none;
  margin: 0 auto;
}
.sf-intro h2 em { display: block; }

.sf-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid rgba(255,255,255,0.1);
  margin: 0 auto;
}

.sf-step {
  padding: 3.5rem 2.5rem;
  border-right: 1px solid rgba(255,255,255,0.07);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  background: #1C1A17;
  position: relative;
  overflow: hidden;
  transition: background 0.4s, box-shadow 0.4s;
}
.sf-step:hover {
  background: #242118;
  box-shadow: 0 8px 40px rgba(17,17,16,0.07);
}

.sf-num {
  font-family: var(--serif);
  font-size: 5rem;
  font-weight: 200;
  color: var(--gold);
  -webkit-text-stroke: 0;
  line-height: 1;
  margin-bottom: 2rem;
  display: block;
  opacity: 0.75;
}

.sf-step h3 {
  font-size: 1.35rem;
  font-family: var(--serif);
  font-weight: 400;
  color: #F0ECE4;
  margin-bottom: 1rem;
}
.sf-step p { max-width: none; font-size: 0.83rem; color: rgba(240,236,228,0.6); }

/* Materials — fond sombre luxe */
.materials-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  max-width: 100%;
  margin: 4rem 0 0;
  background: #131110;
}
.mat-item {
  display: flex;
  flex-direction: column;
  border-right: 1px solid rgba(255,255,255,0.07);
  overflow: hidden;
  transition: box-shadow 0.4s;
  cursor: default;
}
.mat-item:last-child { border-right: none; }
.mat-item:hover { box-shadow: 0 -3px 0 var(--gold) inset; }

.mat-block {
  height: 260px;
  transition: transform 5s ease;
}
.mat-item:hover .mat-block { transform: scale(1.05); }

.mat-pierre { background: linear-gradient(160deg, #E0D8CC 0%, #C4BAB0 40%, #A09690 100%); }
.mat-bois   { background: linear-gradient(160deg, #D4904A 0%, #A66020 40%, #5E3008 100%); }
.mat-metal  { background: linear-gradient(160deg, #D8D8D4 0%, #A8A8A0 35%, #606058 70%, #3A3A34 100%); }
.mat-marbre { background: linear-gradient(160deg, #F8F4EE 0%, #E8E0D2 30%, #D0C4B0 60%, #B8AA98 100%); }
.mat-verre  { background: linear-gradient(160deg, #D8EEF8 0%, #A8D4EC 40%, #70AECE 70%, #4490B8 100%); }

.mat-name {
  font-family: var(--serif);
  font-size: 1.05rem;
  font-weight: 400;
  color: rgba(255,255,255,0.90);
  padding: 1.1rem 1.4rem 0.2rem;
}
.mat-sub {
  font-family: var(--sans);
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(196,168,130,0.70);
  padding: 0 1.4rem 1.6rem;
}

/* ═══════════════════════════════════════════════════════════
   ÉDITO — plein écran citation (LV-style citational break)
   ═══════════════════════════════════════════════════════════ */
#edito {
  position: relative;
  height: 70vh;
  min-height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.edito-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #1C1814 0%, #2A2420 50%, #161210 100%);
}
.edito-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 80% at 30% 50%, rgba(196,168,130,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 40% 60% at 80% 50%, rgba(196,168,130,0.04) 0%, transparent 50%);
}
.edito-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.2);
}
.edito-text {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 2rem;
}
.edito-label {
  font-family: var(--sans);
  font-size: 0.58rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 2rem;
  max-width: none;
}
.edito-text blockquote {
  font-family: var(--serif);
  font-size: clamp(1.8rem, 4vw, 3.5rem);
  font-weight: 200;
  font-style: italic;
  color: rgba(255,255,255,0.85);
  line-height: 1.4;
  letter-spacing: -0.01em;
}

/* ═══════════════════════════════════════════════════════════
   CONTACT — blanc épuré, LV-style
   ═══════════════════════════════════════════════════════════ */
#contact { background: var(--bg); padding-bottom: 8vw; }

.contact-inner {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 8vw;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 5vw;
  align-items: start;
}

.contact-left h2 { color: var(--ink); margin-bottom: 1.5rem; font-size: clamp(2rem, 3.5vw, 3rem); }
.contact-left > p { margin-bottom: 3rem; }

.contact-coords { display: flex; flex-direction: column; gap: 1.5rem; }
.coord { display: flex; flex-direction: column; gap: 0.3rem; }
.coord > span:first-child {
  font-family: var(--sans);
  font-size: 0.72rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold);
}
.coord > a, .coord > span:last-child {
  font-family: var(--serif);
  font-size: 1.45rem;
  color: var(--ink);
  transition: color 0.3s;
}
.coord > a:hover { color: var(--gold-dk); }

/* Form */
.contact-form { display: flex; flex-direction: column; gap: 1.5rem; }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.cf-field { display: flex; flex-direction: column; gap: 0.6rem; }
.cf-field--full { grid-column: 1 / -1; }

label {
  font-family: var(--sans);
  font-size: 0.58rem;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ink-light);
}
label em { font-size: 0.55rem; text-transform: none; letter-spacing: 0; font-style: italic; color: rgba(138,138,132,0.6); }

input, select, textarea {
  font-family: var(--sans);
  font-size: 0.9rem;
  font-weight: 300;
  color: var(--ink);
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,0.18);
  padding: 0.75rem 0;
  outline: none;
  width: 100%;
  transition: border-color 0.3s;
  border-radius: 0;
  appearance: none;
}
input:focus, select:focus, textarea:focus { border-bottom-color: var(--gold-lt); }
input::placeholder, textarea::placeholder { color: rgba(255,255,255,0.2); font-size: 0.85rem; }
input.cf-error, select.cf-error, textarea.cf-error { border-bottom-color: #B83232; }

select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23F0ECE4' stroke-width='1' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0 center;
  padding-right: 1.5rem;
  cursor: pointer;
}
select option { background: #1C1A17; color: var(--ink); }
textarea { resize: vertical; min-height: 120px; }

/* ── Custom select (contact form & modale devis) ── */
.cf-select {
  position: relative;
}
.cf-select__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  font-family: var(--sans);
  font-size: 0.9rem;
  font-weight: 300;
  color: rgba(255,255,255,0.2);
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,0.18);
  padding: 0.75rem 0;
  outline: none;
  cursor: pointer;
  text-align: left;
  transition: border-color 0.3s;
}
.cf-select__trigger:focus { border-bottom-color: var(--gold-lt); }
.cf-select__trigger.has-value { color: var(--ink); }
.cf-select__trigger.cf-error { border-bottom-color: #B83232; }
.cf-select__arrow {
  flex-shrink: 0;
  color: rgba(240,236,228,0.5);
  transition: transform 0.3s var(--ease);
}
.cf-select.is-open .cf-select__arrow { transform: rotate(180deg); }
.cf-select__panel {
  position: absolute;
  top: calc(100% + 2px);
  left: 0; right: 0;
  background: #1C1A17;
  border: 1px solid rgba(196,160,106,0.2);
  border-top: 2px solid var(--gold);
  z-index: 600;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(-6px);
  transition: max-height 0.35s var(--ease), opacity 0.3s var(--ease), transform 0.3s var(--ease);
  pointer-events: none;
  display: flex;
  flex-direction: column;
}
.cf-select.is-open .cf-select__panel {
  max-height: 216px;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.cf-select__scroll {
  overflow-y: auto;
  flex: 1;
  scrollbar-width: thin;
  scrollbar-color: rgba(196,160,106,0.3) transparent;
}
.cf-select__scroll::-webkit-scrollbar { width: 3px; }
.cf-select__scroll::-webkit-scrollbar-thumb { background: rgba(196,160,106,0.35); border-radius: 2px; }
.cf-select__option {
  display: block;
  width: 100%;
  padding: 0.85rem 1rem;
  font-family: var(--sans);
  font-size: 0.82rem;
  font-weight: 300;
  color: rgba(240,236,228,0.65);
  background: transparent;
  border: none;
  text-align: left;
  cursor: pointer;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  transition: color 0.2s, background 0.2s;
  outline: none;
}
.cf-select__option:hover { color: var(--gold); background: rgba(196,160,106,0.07); }
.cf-select__option.is-selected { color: var(--gold); border-left: 2px solid var(--gold); padding-left: calc(1rem - 2px); }
.cf-select__more {
  display: none;
  position: relative;
  flex-shrink: 0;
  height: 32px;
  background: linear-gradient(to top, #1C1A17 55%, transparent);
  pointer-events: auto;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  padding-bottom: 4px;
  border: none;
  width: 100%;
  outline: none;
}
.cf-select__more:hover svg { opacity: 1; }
.cf-select__more svg { animation: cfBounce 1.4s infinite; opacity: 0.6; transition: opacity 0.2s; }
@keyframes cfBounce {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(4px); }
}
.cf-select.is-open .cf-select__more { display: flex; }
.cf-select.is-open.no-more .cf-select__more { display: none; }

.cf-footer {
  display: flex;
  align-items: center;
  gap: 2rem;
  padding-top: 0.5rem;
}

.cf-submit {
  display: inline-flex;
  align-items: center;
  gap: 0.9rem;
  font-family: var(--sans);
  font-size: 0.65rem;
  font-weight: 400;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ink);
  padding-bottom: 2px;
  border-bottom: 1px solid var(--ink);
  transition: color 0.3s, border-color 0.3s, gap 0.3s;
}
.cf-submit:hover { color: var(--gold-dk); border-bottom-color: var(--gold-dk); gap: 1.5rem; }
.cf-submit:disabled { opacity: 0.4; pointer-events: none; }
.cf-submit svg { transition: transform 0.35s; flex-shrink: 0; }
.cf-submit:hover svg { transform: translateX(5px); }

.cf-note {
  font-size: 0.65rem;
  color: rgba(255,255,255,0.3);
  max-width: none;
}

.cf-success {
  padding: 1.2rem 0;
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--gold-dk);
  border-top: 1px solid rgba(196,168,130,0.3);
  animation: heroFadeUp 0.6s var(--ease) forwards;
}

/* ═══════════════════════════════════════════════════════════
   MODALE DEVIS
   ═══════════════════════════════════════════════════════════ */
.devis-modal {
  position: fixed;
  inset: 0;
  z-index: 8000;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  visibility: hidden;
}
.devis-modal.is-open {
  pointer-events: auto;
  visibility: visible;
}

/* Fond sombre */
.devis-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(10, 9, 8, 0.82);
  backdrop-filter: blur(4px);
  opacity: 0;
  transition: opacity 0.4s var(--ease);
  cursor: pointer;
}
.devis-modal.is-open .devis-modal__overlay {
  opacity: 1;
}

/* Panneau */
.devis-modal__panel {
  position: relative;
  background: var(--beige);
  border: 1px solid rgba(255,255,255,0.07);
  width: min(680px, 92vw);
  max-height: 90vh;
  overflow-y: auto;
  padding: 3.5rem 3.5rem 3rem;
  transform: translateY(28px);
  opacity: 0;
  transition: transform 0.45s var(--ease), opacity 0.45s var(--ease);
  scrollbar-width: thin;
  scrollbar-color: var(--gold-dk) transparent;
}
.devis-modal.is-open .devis-modal__panel {
  transform: translateY(0);
  opacity: 1;
}

/* Bouton fermeture */
.devis-modal__close {
  position: absolute;
  top: 1.4rem;
  right: 1.4rem;
  color: var(--ink-mid);
  transition: color 0.25s;
  padding: 4px;
}
.devis-modal__close:hover { color: var(--ink); }

/* En-tête */
.devis-modal__head {
  margin-bottom: 2.2rem;
}
.devis-modal__label {
  display: block;
  font-family: var(--sans);
  font-size: 0.65rem;
  font-weight: 400;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 0.9rem;
}
.devis-modal__head h2 {
  font-size: clamp(2rem, 4vw, 2.8rem);
  margin-bottom: 0.6rem;
}
.devis-modal__head p {
  font-size: 0.82rem;
  color: var(--ink-mid);
  max-width: none;
}

/* Réduit un peu le formulaire à l'intérieur de la modale */
.devis-modal__form .cf-row { gap: 1rem; }
.devis-modal__form .cf-field label { font-size: 0.65rem; }
.devis-modal__form textarea { rows: 4; }

/* Empêche le scroll du body quand la modale est ouverte */
body.modal-open { overflow: hidden; }

/* ═══════════════════════════════════════════════════════════
   FOOTER — discret, épuré
   ═══════════════════════════════════════════════════════════ */
#footer {
  background: #0D0D0C;
  padding: 5vw;
}
.footer-top {
  text-align: center;
  margin-bottom: 3rem;
}
/* Footer brand badge */
.ft-brand {
  display: flex;
  justify-content: center;
  margin-bottom: 1rem;
  transition: opacity 0.35s;
  color: rgba(255,255,255,0.7);
}
.ft-brand:hover { opacity: 0.65; color: var(--gold-lt); }
.logo-badge { width: 110px; height: auto; display: block; }

.footer-bot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid rgba(255,255,255,0.07);
  padding-top: 2rem;
  flex-wrap: wrap;
  gap: 1rem;
  max-width: 1200px;
  margin: 0 auto;
}
.ft-nav { display: flex; gap: 2.5rem; }
.ft-nav a {
  font-family: var(--sans);
  font-size: 0.6rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.35);
  transition: color 0.3s;
}
.ft-nav a:hover { color: var(--gold); }
.ft-legal {
  font-family: var(--sans);
  font-size: 0.58rem;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,0.2);
}

/* ═══════════════════════════════════════════════════════════
   SCROLL REVEAL
   ═══════════════════════════════════════════════════════════ */
[data-reveal] {
  opacity: 0;
  transition: opacity 1s var(--ease), transform 1s var(--ease);
}
[data-reveal="up"]    { transform: translateY(50px); }
[data-reveal="left"]  { transform: translateX(-50px); }
[data-reveal="right"] { transform: translateX(50px); }
[data-reveal="fade"]  { transform: none; }
[data-reveal].revealed { opacity: 1; transform: none; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .sf-steps { grid-template-columns: 1fr 1fr; }
  .materials-row { grid-template-columns: repeat(3, 1fr); }

  .cat-grid { grid-template-columns: 1fr 1fr; perspective: none; }
  .cat-card:nth-child(4n+1),
  .cat-card:nth-child(4n+2),
  .cat-card:nth-child(4n+3),
  .cat-card:nth-child(4n+4) { margin-top: 0; }

  .contact-inner { grid-template-columns: 1fr; gap: 4rem; }
}

@media (max-width: 768px) {
  .nav-left, .nav-right { display: none; }
  #nav { grid-template-columns: 1fr auto 1fr; }
  .nav-burger { display: flex; }

  .sf-steps { grid-template-columns: 1fr; }
  .materials-row { grid-template-columns: 1fr 1fr; }
  .chiffres-content { flex-wrap: wrap; gap: 2rem; }
  .chiffre-sep { display: none; }
  .chiffre-col { flex: 0 0 40%; }

  .cf-row { grid-template-columns: 1fr; }
  .footer-bot { flex-direction: column; align-items: center; text-align: center; }
  .ft-nav { justify-content: center; }

  .pm-meta { flex-direction: column; }
  .pm-meta-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.06); }

  .rl-carousel { height: 78vh; min-height: 480px; }
  .rl-content { padding: 7vw 5vw; max-width: 100%; }
  .rl-title { font-size: clamp(2rem, 6vw, 4rem); }
  .rl-desc { display: block; font-size: 1.3rem; font-weight: 600; }
  .rl-specs { gap: 1.5rem; }
  .rl-arrow { width: 40px; height: 40px; }
  .rl-arrow--prev { left: 1rem; }
  .rl-arrow--next { right: 1rem; }
}

@media (max-width: 480px) {
  .hero-ctas { flex-direction: column; align-items: center; }
  .materials-row { grid-template-columns: 1fr 1fr; }
  .section-label-row { padding: 3.5rem 2rem 2.5rem; }
}
