/* =====================================================
   JOYCE MARTENS BEAUTY — Styles
   ===================================================== */

/* -------------------------------------------------------
   Variables CSS
   ------------------------------------------------------- */
:root {
  --color-bg:      #090909;
  --color-surface: #141414;
  --color-text:    #EDEDED;
  --color-muted:   #5A5A5A;
  --color-accent:  #C8C8C8;
  --color-warm:    #E2D6CF;

  --font-display: 'Syne', sans-serif;
  --font-serif:   'DM Serif Display', serif;
  --font-body:    'DM Sans', sans-serif;

  --hero-title-size: clamp(4rem, 10vw, 8rem);
  --section-title-size: clamp(2rem, 5vw, 4rem);

  --max-w:      1200px;
  --gutter:     clamp(1.5rem, 5vw, 4rem);
  --transition: 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* -------------------------------------------------------
   Reset
   ------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background-color: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-weight: 300;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img   { display: block; max-width: 100%; height: auto; }
a     { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }

/* -------------------------------------------------------
   Typographie partagée
   ------------------------------------------------------- */
h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}

.section-tag {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 0.82rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--color-warm);
  margin-bottom: 0.9rem;
}

.section-intro {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--gutter);
  margin-bottom: 3rem;
}

.section-title {
  font-size: var(--section-title-size);
  color: var(--color-text);
}

/* -------------------------------------------------------
   Boutons
   ------------------------------------------------------- */
.btn-outline {
  display: inline-block;
  position: relative;
  overflow: hidden;
  padding: 1rem 3rem;
  border: 1px solid rgba(237,237,237,0.55);
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text);
  background: transparent;
  cursor: pointer;
  transition: color 0.45s ease 0.04s, border-color 0.45s ease;
  z-index: 0;
}
.btn-outline::before {
  content: '';
  position: absolute;
  top: -6px; bottom: -6px; left: -6px; right: -6px;
  background: linear-gradient(102deg, #d9cdc5 0%, #e2d6cf 45%, #d4c9c2 100%);
  clip-path: polygon(0% 12%, 4% 0%, 100% 6%, 97% 88%, 100% 100%, 3% 96%);
  transform: translateX(-115%) skewX(-8deg);
  transition: transform 0.52s cubic-bezier(0.22, 0.61, 0.36, 1);
  z-index: -1;
}
.btn-outline:hover::before { transform: translateX(6px) skewX(-8deg); }
.btn-outline:hover { color: #1c1410; border-color: transparent; }

/* -------------------------------------------------------
   Page transition veil
   ------------------------------------------------------- */
#page-veil {
  position: fixed;
  inset: 0;
  background: #090909;
  z-index: 9998;
  pointer-events: none;
  transition: opacity 0.38s ease;
}

/* Section anchor offset — padding interne des sections suffit à dégager le header */
#prestations, #lookbook, #bridge, #about, #contact {
  scroll-margin-top: 0;
}

/* -------------------------------------------------------
   Preloader
   ------------------------------------------------------- */
.preloader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--color-bg);
  overflow: hidden;
}
.preloader-grid {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 140vw;
  display: flex;
  flex-direction: row;
  gap: 8px;
  overflow: visible;
}
.preloader-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10vh;
}
.preloader-col .preloader-cell:first-child {
  margin-bottom: 12vh; /* séparation plus grande après photo 1 */
}
.preloader-col:nth-child(3) {
  position: relative;
  z-index: 5;
}
.preloader-cell {
  height: 32vh;
  flex-shrink: 0;
  overflow: hidden;
  will-change: transform, opacity;
}
.preloader-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.preloader-cell--center {
  transform-origin: center center;
  position: relative;
  z-index: 2;
}
.preloader-title {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10000;
  display: none;
  flex-direction: column;
  align-items: center;
  gap: 0.15em;
  font-family: var(--font-display);
  font-weight: 800;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--color-text);
  text-shadow: 0 2px 40px rgba(0,0,0,0.95);
  white-space: nowrap;
  pointer-events: none;
}
.preloader-title-row {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.6em;
  font-size: clamp(3rem, 9vw, 7rem);
}
.preloader-beauty {
  font-size: clamp(0.7rem, 1.6vw, 1.3rem);
  font-weight: 400;
  letter-spacing: 0.5em;
  text-transform: uppercase;
  font-family: var(--font-display);
  text-shadow: none;
}

/* -------------------------------------------------------
   Header / Nav
   ------------------------------------------------------- */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: 1.5rem var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background var(--transition), backdrop-filter var(--transition);
}
.site-header.scrolled {
  background: rgba(9,9,9,0.85);
  backdrop-filter: blur(12px);
}
.nav-logo {
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}
.nav-links {
  display: flex;
  gap: 2.5rem;
  list-style: none;
}
.nav-link {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
  transition: color var(--transition);
  position: relative;
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 1px;
  background: currentColor;
  transition: width 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
.nav-link:hover { color: var(--color-text); }
.nav-link:hover::after { width: 100%; }

.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 4px;
}
.hamburger span {
  display: block;
  width: 22px;
  height: 1px;
  background: var(--color-text);
  transition: transform var(--transition), opacity var(--transition);
}
.hamburger.open span:first-child { transform: translateY(6px) rotate(45deg); }
.hamburger.open span:last-child  { transform: translateY(-6px) rotate(-45deg); }

.mobile-menu {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 90;
  background: var(--color-bg);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2.5rem;
}
.mobile-menu.open { display: flex; }
.mobile-link {
  font-family: var(--font-display);
  font-size: clamp(2rem, 6vw, 3.5rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  color: var(--color-text);
  transition: color var(--transition);
}
.mobile-link:hover { color: var(--color-accent); }

/* -------------------------------------------------------
   Hero
   ------------------------------------------------------- */
.hero-section {
  position: sticky;
  top: 0;
  z-index: 0;
  height: 100vh;
  min-height: 600px;
  overflow: hidden;
  display: flex;
  align-items: center;
}
.hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-repeat: no-repeat;
  transform: scale(1.05);
  transition: transform 0.1s;
}
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(9,9,9,0.85) 0%,
    rgba(9,9,9,0.3) 50%,
    rgba(9,9,9,0.2) 100%
  );
}
.hero-content {
  position: relative;
  z-index: 2;
  padding: 0 var(--gutter);
  max-width: calc(var(--max-w) + var(--gutter) * 2);
  width: 100%;
}
.hero-title {
  font-size: var(--hero-title-size);
  line-height: 1.0;
  color: var(--color-text);
  margin-bottom: 1.5rem;
  overflow: hidden;
}
.hero-title-mixed { overflow: visible; }
.hero-title-mixed span { display: block; }
.hero-title-mixed em {
  display: block;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0.01em;
  line-height: 1.0;
  font-size: 0.88em;
}
.hero-title-mixed em:first-of-type {
  font-family: var(--font-body);
  font-style: normal;
  font-weight: 300;
  font-size: 0.62em;
  letter-spacing: 0.14em;
  line-height: 1.0;
  color: rgba(237,237,237,0.60);
  text-transform: lowercase;
}
/* État initial caché — révélé par initHeroReveal() */
.hero-title-mixed span,
.hero-title-mixed em {
  clip-path: inset(100% 0 0 0);
}
.hero-subtitle {
  display: block;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 300;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 1.25rem;
  opacity: 0;
}
.hero-cta { opacity: 0; }

.hero-phrase {
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  line-height: 1.05;
  color: var(--color-text);
  margin-bottom: 2rem;
  opacity: 0;
}
.hero-phrase .hp-serif {
  display: block;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
}
.hero-phrase .hp-light {
  display: block;
  font-family: var(--font-body);
  font-weight: 300;
  opacity: 0.65;
}
.hero-phrase .hp-strong {
  display: block;
  font-family: var(--font-display);
  font-weight: 700;
}

.scroll-down {
  position: absolute;
  bottom: 2rem;
  right: var(--gutter);
  font-family: var(--font-body);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-muted);
  writing-mode: vertical-rl;
  opacity: 0;
}

/* -------------------------------------------------------
   Prestations
   ------------------------------------------------------- */
.prestations-section {
  position: relative;
  z-index: 1;
  background: var(--color-bg);
  padding: clamp(5rem, 12vh, 9rem) 0;
}
.prestations-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--color-surface);
  border: 1px solid var(--color-surface);
  max-width: var(--max-w);
  margin: 0 auto;
  position: relative;
}
.prestation-card {
  background: var(--color-bg);
  padding: 2.5rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  position: relative;
  overflow: hidden;
  transition: background var(--transition);
}
.prestation-card:hover { background: var(--color-surface); }
.prestation-num {
  font-family: var(--font-display);
  font-size: 5rem;
  font-weight: 800;
  color: var(--color-surface);
  line-height: 1;
  letter-spacing: -0.04em;
  position: absolute;
  top: 1rem;
  right: 1.5rem;
  transition: color var(--transition);
}
.prestation-card:hover .prestation-num { color: rgba(200,200,200,0.06); }
.prestation-name {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text);
  position: relative;
  z-index: 1;
}
.prestation-desc {
  font-size: 0.85rem;
  color: var(--color-muted);
  line-height: 1.6;
  position: relative;
  z-index: 1;
  flex: 1;
}
.prestation-cta {
  font-family: var(--font-body);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-top: 0.5rem;
  position: relative;
  z-index: 1;
  transition: color var(--transition);
}
.prestation-card:hover .prestation-cta { color: var(--color-text); }

/* Inline prestations cards (scratch reveal) */
.inline-card {
  background: var(--color-bg);
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.07);
  transition: background 0.3s ease, border-color 0.3s ease;
  display: flex;
  flex-direction: column;
  --mx: 50%;
  --my: 50%;
  --spotlight: 0;
}
.inline-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    400px circle at var(--mx) var(--my),
    rgba(226, 214, 207, 0.10) 0%,
    transparent 65%
  );
  opacity: var(--spotlight);
  transition: opacity 0.5s ease;
  pointer-events: none;
  z-index: 0;
}
.inline-card:hover { border-color: rgba(255,255,255,0.15); }
a.inline-card {
  display: flex;
  flex-direction: column;
  color: inherit;
  text-decoration: none;
}
a.inline-card:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: -2px;
}
.inline-card:hover { background: var(--color-surface); }
.inline-card-inner {
  padding: 5rem 2rem;
  display: flex;
  flex-direction: column;
  flex: 1;
  position: relative;
  z-index: 1;
}
.inline-card-name {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text);
  margin-bottom: 1rem;
}
.inline-card-desc {
  font-family: var(--font-body);
  font-size: 0.88rem;
  font-weight: 300;
  color: rgba(237,237,237,0.62);
  line-height: 1.6;
  flex: 1;
  margin-bottom: 1.5rem;
}
.inline-card-footer {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-top: 1.5rem;
}
.inline-card-price {
  font-family: var(--font-body);
  font-size: 0.78rem;
  color: rgba(237,237,237,0.55);
}
.inline-card-price strong {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-text);
  margin-left: 0.25rem;
}
.inline-card-cta {
  font-family: var(--font-body);
  font-size: 0.82rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-accent);
  transition: color var(--transition);
  white-space: nowrap;
}
.inline-card:hover .inline-card-cta { color: var(--color-text); }

/* Scratch card canvas overlay */
.scratch-canvas {
  position: absolute;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 2;
}
.scratch-cursor {
  position: absolute;
  width: 88px;
  height: 88px;
  border-radius: 50%;
  border: 1px solid rgba(237,237,237,0.45);
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 3;
  opacity: 0;
}

/* -------------------------------------------------------
   Lookbook — cartes + galerie
   ------------------------------------------------------- */
.lookbook-section {
  position: relative;
  z-index: 1;
  background: var(--color-bg);
  padding: clamp(5rem, 10vh, 8rem) 0 4rem;
  overflow: hidden;
}

/* Barre de navigation de la galerie fullscreen */
.lb-gallery-nav {
  flex: 0 0 auto;
  height: clamp(3.5rem, 6vh, 4.5rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--gutter);
  border-bottom: 1px solid rgba(237,237,237,0.08);
  position: relative;
}
.lb-gallery-title {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-display);
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-muted);
  pointer-events: none;
}
.lb-back-label {
  font-family: var(--font-display);
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-text);
  clip-path: inset(0 100% 0 0);
}

/* Bouton fermer (dans la nav galerie) */
.lb-close {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-family: var(--font-display);
  font-size: 0.6rem;
  font-weight: 400;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(237,237,237,0.55);
  transition: color 0.25s ease;
  position: relative;
}
.lb-close::after {
  content: '';
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 0;
  height: 1px;
  background: rgba(237,237,237,0.4);
  transition: width 0.3s ease;
}
.lb-close:hover { color: rgba(237,237,237,0.9); }
.lb-close:hover::after { width: 100%; }

/* Pied de galerie : hint + compteur */
.lb-gallery-footer {
  flex: 0 0 auto;
  padding: 0.6rem var(--gutter);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.15rem;
}
.lb-hint {
  font-family: var(--font-display);
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--color-muted);
  opacity: 0;
  pointer-events: none;
}

/* Scène commune cartes / galerie */
.lb-stage {
  position: relative;
  height: 60vh;
  margin-top: 2rem;
}

/* 3 cartes */
.lb-cards {
  display: flex;
  justify-content: center;
  gap: 2vw;
  height: 100%;
}
.lb-card {
  flex: 0 0 26vw;
  height: 100%;
  position: relative;
  overflow: hidden;
  cursor: crosshair;
}
.lb-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
  display: block;
}
.lb-card:hover .lb-card-img { transform: scale(1.02); }
.lb-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(9,9,9,0.75) 0%, rgba(9,9,9,0) 50%);
  pointer-events: none;
}
.lb-card-label {
  position: absolute;
  bottom: 1.5rem;
  left: 0;
  right: 0;
  text-align: center;
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-text);
  pointer-events: none;
}

/* Galerie — overlay fullscreen indépendant */
.lb-gallery {
  position: fixed;
  inset: 0;
  z-index: 200;
  pointer-events: none;
  opacity: 0;
  background: var(--color-bg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.lb-track-wrap {
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden;
  cursor: none;
}
.lb-track {
  display: flex;
  align-items: center;
  height: 100%;
  gap: 2vw;
  padding: 0 38vw; /* (100vw - 24vw) / 2 — centre la 1ère et dernière photo */
  will-change: transform;
}

/* Photo individuelle */
.lb-photo {
  flex: 0 0 auto;
  width: 24vw;
  overflow: hidden;
  position: relative;
  height: clamp(50vh, 75vh, 700px);
}
.lb-photo-inner {
  position: absolute;
  top: 0;
  left: -10%;
  width: 120%;
  height: 100%;
  will-change: transform;
}
.lb-photo-inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Compteur */
.lb-counter {
  text-align: center;
  font-family: var(--font-display);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: var(--color-warm);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

/* Curseur custom — cercle ring */
.lb-cursor {
  position: fixed;
  pointer-events: none;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 1px solid rgba(237,237,237,0.55);
  background: rgba(9,9,9,0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 400;
  color: rgba(237,237,237,0.85);
  z-index: 100;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity 0.25s ease;
  user-select: none;
  backdrop-filter: blur(4px);
}

/* -------------------------------------------------------
   Pont Beauty × Photo
   ------------------------------------------------------- */
.bridge-section {
  position: relative;
  z-index: 1;
  background: var(--color-bg);
  padding: clamp(5rem, 12vh, 9rem) var(--gutter);
}
.bridge-inner {
  display: grid;
  grid-template-columns: 1fr 1px 1fr;
  gap: 0;
  max-width: var(--max-w);
  margin: 0 auto 3rem;
  height: clamp(280px, 45vw, 480px);
}
.bridge-divider {
  background: var(--color-muted);
  opacity: 0.3;
  align-self: stretch;
}
.bridge-side {
  position: relative;
  overflow: hidden;
}
.bridge-side img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}
.bridge-side:hover img { transform: scale(1.03); }
.bridge-label {
  position: absolute;
  bottom: 1.2rem;
  left: 1.5rem;
  font-family: var(--font-body);
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent);
  background: rgba(9,9,9,0.6);
  padding: 0.3rem 0.7rem;
  backdrop-filter: blur(4px);
}
.bridge-text {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
}
.bridge-headline {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.3rem, 3vw, 2rem);
  color: var(--color-text);
  line-height: 1.4;
  margin-bottom: 2rem;
}

/* -------------------------------------------------------
   À propos
   ------------------------------------------------------- */
.about-section {
  position: relative;
  z-index: 1;
  background: var(--color-bg);
  padding: clamp(5rem, 12vh, 9rem) var(--gutter);
}
.about-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(3rem, 6vw, 6rem);
  align-items: start;
}
.about-photo-wrap {
  aspect-ratio: 3/4;
  overflow: hidden;
}
.about-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.about-name {
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  margin-bottom: 0.3rem;
}
.about-role {
  font-family: var(--font-body);
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 2rem;
}
.about-text p {
  font-size: 0.95rem;
  color: rgba(237,237,237,0.8);
  line-height: 1.8;
  margin-bottom: 1.2rem;
}

/* -------------------------------------------------------
   Instagram
   ------------------------------------------------------- */
.insta-section {
  position: relative;
  z-index: 1;
  background: var(--color-bg);
  padding: clamp(4rem, 8vw, 7rem) var(--gutter);
  border-top: 1px solid var(--color-surface);
  text-align: center;
}
.insta-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.9rem;
}
.insta-handle {
  font-family: var(--font-display);
  font-size: clamp(0.85rem, 1.5vw, 1.1rem);
  font-weight: 400;
  letter-spacing: 0.18em;
  line-height: 1;
  color: rgba(237,237,237,0.55);
}
.insta-tagline {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.3rem, 2.8vw, 2rem);
  color: var(--color-text);
  margin-top: 0.15rem;
}
.insta-cta {
  margin-top: 0.8rem;
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(237,237,237,0.50);
  border-bottom: 1px solid rgba(237,237,237,0.18);
  padding-bottom: 2px;
  transition: color 0.3s ease, border-color 0.3s ease;
}
.insta-cta:hover {
  color: var(--color-text);
  border-color: rgba(237,237,237,0.45);
}

/* -------------------------------------------------------
   Contact
   ------------------------------------------------------- */
.contact-section {
  position: relative;
  z-index: 1;
  background: var(--color-bg);
  padding: clamp(5rem, 12vh, 9rem) var(--gutter);
  border-top: 1px solid var(--color-surface);
}
.contact-inner {
  max-width: 640px;
  margin: 0 auto;
}
.contact-form {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  margin-bottom: 2.5rem;
}
.form-field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.form-label {
  font-family: var(--font-body);
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-warm);
}
.form-input,
.form-select,
.form-textarea {
  background: var(--color-surface);
  border: 1px solid transparent;
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 300;
  padding: 0.85rem 1rem;
  outline: none;
  transition: border-color var(--transition);
  width: 100%;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus { border-color: var(--color-accent); }
.form-select { appearance: none; cursor: pointer; }
.form-textarea { resize: none; min-height: 120px; }
.form-textarea::placeholder {
  color: rgba(255,255,255,0.2);
  font-style: italic;
}
.form-submit {
  align-self: flex-start;
}

.contact-instagram {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.8rem;
  color: var(--color-muted);
  transition: color var(--transition);
}
.contact-instagram:hover { color: var(--color-accent); }

/* Contact — micro-interactions */
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  box-shadow: 0 0 0 2px rgba(200, 200, 200, 0.15);
}

.service-btn {
  transition: transform 0.15s ease, background var(--transition), color var(--transition);
}
.service-btn:hover {
  transform: scale(1.02);
}

.btn-outline:active {
  transform: scale(0.97);
  transition: transform 0.12s ease;
}

.contact-success {
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--color-accent);
  letter-spacing: 0.05em;
  opacity: 0;
  transition: opacity 0.4s ease;
}

/* -------------------------------------------------------
   Footer
   ------------------------------------------------------- */
.site-footer {
  position: relative;
  z-index: 1;
  background: var(--color-bg);
  padding: 3rem var(--gutter);
  border-top: 1px solid var(--color-surface);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 2rem;
}
.footer-col {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.footer-col--left {
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 300;
  letter-spacing: 0.08em;
  color: var(--color-muted);
}
.footer-col--center {
  align-items: center;
  text-align: center;
  gap: 0.6rem;
}
.footer-col--right {
  align-items: flex-end;
}
.footer-logo {
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-text);
}
.footer-top {
  font-size: 0.8rem;
  color: var(--color-muted);
  transition: color var(--transition);
  line-height: 1;
}
.footer-top:hover { color: var(--color-text); }
.footer-copy {
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 300;
  color: var(--color-muted);
  letter-spacing: 0.05em;
}
.footer-links {
  display: flex;
  gap: 1.5rem;
  list-style: none;
}
.footer-link {
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 300;
  letter-spacing: 0.08em;
  color: var(--color-muted);
  transition: color var(--transition);
}
.footer-link:hover { color: var(--color-text); }

/* -------------------------------------------------------
   Section reveals — clip-path cut
   ------------------------------------------------------- */
.reveal-cut {
  clip-path: inset(100% 0 0 0);
}

/* -------------------------------------------------------
   Tarifs page
   ------------------------------------------------------- */
.tarifs-hero {
  padding: calc(var(--gutter) * 2 + 80px) var(--gutter) clamp(3rem, 6vh, 5rem);
  max-width: var(--max-w);
  margin: 0 auto;
}
.tarifs-hero .section-title {
  font-size: clamp(2.5rem, 6vw, 4.5rem);
}
.t-tag {
  display: inline-block;
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: 1rem;
}
.tarifs-sections {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--gutter) clamp(4rem, 10vh, 8rem);
}
.tarifs-section {
  display: grid;
  grid-template-columns: 460px 1fr;
  gap: 5rem;
  padding: clamp(3rem, 6vh, 5rem) 0;
  border-top: 1px solid var(--color-surface);
  scroll-margin-top: 5rem;
}
.t-sec-num {
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-warm);
  margin-bottom: 1.6rem;
}
.t-sec-title {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  color: var(--color-text);
  line-height: 1.05;
  margin-bottom: 1.5rem;
  overflow-wrap: break-word;
}
.t-sec-desc {
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 300;
  font-style: italic;
  color: rgba(237,237,237,0.72);
  line-height: 1.7;
}
.tarifs-rows {
  display: flex;
  flex-direction: column;
}
.t-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2rem;
  align-items: center;
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--color-surface);
}
.t-row:first-child { border-top: 1px solid var(--color-surface); }
.t-row-name {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text);
  margin-bottom: 0.3rem;
}
.t-row-detail {
  font-family: var(--font-body);
  font-size: 0.88rem;
  font-weight: 300;
  color: rgba(237,237,237,0.72);
  line-height: 1.5;
}
.t-price {
  text-align: right;
  flex-shrink: 0;
}
.t-price-from {
  display: block;
  font-family: var(--font-body);
  font-size: 0.65rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-warm);
  margin-bottom: 0.15rem;
}
.t-price-val {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--color-text);
}
.t-price-devis {
  font-family: var(--font-body);
  font-size: 1rem;
  font-style: italic;
  color: var(--color-warm);
}
.t-price-unit {
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 400;
  font-style: italic;
  color: var(--color-warm);
}
.t-price-note {
  display: block;
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 400;
  font-style: italic;
  color: var(--color-warm);
  margin-top: 0.4rem;
  max-width: 160px;
  margin-left: auto;
}
.tarifs-note {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--gutter) clamp(2.5rem, 5vh, 4rem);
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-style: italic;
  color: var(--color-warm);
}
.tarifs-cta {
  padding: clamp(3rem, 6vh, 5rem) var(--gutter);
  max-width: var(--max-w);
  margin: 0 auto;
  text-align: center;
  border-top: 1px solid var(--color-surface);
}

.service-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  padding: clamp(3rem, 6vh, 5rem) var(--gutter);
  max-width: var(--max-w);
  margin: 0 auto;
  border-top: 1px solid var(--color-surface);
}

/* -------------------------------------------------------
   Zoom lightbox — photo individuelle galerie lookbook
   ------------------------------------------------------- */
#lb-zoom {
  position: fixed;
  inset: 0;
  z-index: 300;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s ease;
}
#lb-zoom.active {
  opacity: 1;
  pointer-events: auto;
}
.lb-zoom-bg {
  position: absolute;
  inset: 0;
  background: rgba(9,9,9,0.93);
  cursor: pointer;
}
.lb-zoom-inner {
  position: relative;
  z-index: 1;
  max-width: 88vw;
  max-height: 88vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lb-zoom-img {
  display: block;
  max-width: 88vw;
  max-height: 88vh;
  width: auto;
  height: auto;
  object-fit: contain;
  user-select: none;
  -webkit-user-drag: none;
}
.lb-zoom-prev,
.lb-zoom-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  background: none;
  border: none;
  color: rgba(237,237,237,0.4);
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 0.05em;
  cursor: pointer;
  padding: 24px 20px;
  transition: color 0.15s;
}
.lb-zoom-prev:hover,
.lb-zoom-next:hover { color: rgba(237,237,237,0.9); }
.lb-zoom-prev { left: 12px; }
.lb-zoom-next { right: 12px; }
.lb-zoom-close {
  position: absolute;
  top: 20px;
  right: 28px;
  z-index: 2;
  background: none;
  border: none;
  color: rgba(237,237,237,0.4);
  font-family: var(--font-display);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  padding: 8px 0;
  transition: color 0.15s;
}
.lb-zoom-close:hover { color: rgba(237,237,237,0.9); }
.lb-zoom-counter {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-display);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: var(--color-muted);
  white-space: nowrap;
  z-index: 2;
  pointer-events: none;
}

/* ================================================
   PORTFOLIO HUB — grille cards
   ================================================ */
.portfolio-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gutter);
  padding: 0 var(--gutter) 6rem;
  max-width: calc(var(--max-w) + var(--gutter) * 2);
  margin: 0 auto;
}

.portfolio-card {
  position: relative;
  overflow: hidden;
  aspect-ratio: 3/4;
  display: block;
  text-decoration: none;
  background: var(--color-surface);
  animation: portfolio-iris-open 1.3s cubic-bezier(0.16, 1, 0.3, 1) both;
  animation-delay: 0.42s;
}

.portfolio-card:nth-child(2) { animation-delay: 0.55s; }
.portfolio-card:nth-child(3),
.portfolio-card:nth-child(4) { animation-delay: 0s; animation-play-state: paused; }
.portfolio-card:nth-child(3).is-visible,
.portfolio-card:nth-child(4).is-visible { animation-play-state: running; }

@keyframes portfolio-iris-open {
  from { clip-path: circle(0% at 50% 40%); }
  to   { clip-path: circle(120% at 50% 40%); }
}

@media (prefers-reduced-motion: reduce) {
  .portfolio-card { animation: none; }
}

.portfolio-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,0.07) 50%, transparent 70%);
  z-index: 3;
  transform: translateX(-130%);
  transition: transform 0.8s ease;
  pointer-events: none;
}

.portfolio-card:hover::before {
  transform: translateX(130%);
}

.portfolio-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  animation: portfolio-img-settle 1.3s cubic-bezier(0.16, 1, 0.3, 1) both;
  animation-delay: 0.42s;
}
.portfolio-card:nth-child(2) .portfolio-card-img { animation-delay: 0.55s; }
.portfolio-card:nth-child(3) .portfolio-card-img,
.portfolio-card:nth-child(4) .portfolio-card-img { animation-delay: 0s; animation-play-state: paused; }
.portfolio-card:nth-child(3).is-visible .portfolio-card-img,
.portfolio-card:nth-child(4).is-visible .portfolio-card-img { animation-play-state: running; }

@keyframes portfolio-img-settle {
  from { transform: scale(1.09); }
  to   { transform: scale(1); }
}

.portfolio-card:hover .portfolio-card-img {
  transform: scale(1.07);
}

.portfolio-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(9,9,9,0.78) 0%, rgba(9,9,9,0.15) 55%, transparent 80%);
  transition: opacity 0.4s ease;
}

.portfolio-card-body {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.5rem var(--gutter);
  transition: transform 0.4s ease;
}

.portfolio-card:hover .portfolio-card-body {
  transform: translateY(-6px);
}

.portfolio-card-title {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text);
  margin: 0 0 0.3rem;
}

.portfolio-card-desc {
  font-family: var(--font-body);
  font-size: 0.8rem;
  color: var(--color-warm);
  margin: 0;
  opacity: 0.65;
  transition: opacity 0.35s ease;
}

.portfolio-card:hover .portfolio-card-desc {
  opacity: 1;
}

.portfolio-card-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  font-family: var(--font-display);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-warm);
  background: rgba(9,9,9,0.65);
  padding: 0.3rem 0.7rem;
}

/* ================================================
   PORTFOLIO SOUS-PAGES — section + grille photos
   ================================================ */
.portfolio-section {
  padding: 0 var(--gutter) 6rem;
  max-width: calc(var(--max-w) + var(--gutter) * 2);
  margin: 0 auto;
}

.portfolio-intro {
  max-width: 600px;
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.75;
  color: var(--color-accent);
  margin: 0 0 3rem;
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: calc(var(--gutter) * 0.4);
  padding-top: 1.5rem;
}

.portfolio-grid-item {
  overflow: hidden;
  aspect-ratio: 2/3;
  cursor: pointer;
  background: var(--color-surface);
  opacity: 0;
  clip-path: inset(6% 0 0 0);
  transition: opacity 0.65s ease, clip-path 0.75s cubic-bezier(0.16, 1, 0.3, 1);
}

.portfolio-grid-item.is-visible {
  opacity: 1;
  clip-path: inset(0 0 0 0);
}

/* Vague éditoriale : cols latérales en haut, colonne centrale en bas */
.portfolio-grid-item:nth-child(3n-2),
.portfolio-grid-item:nth-child(3n)   { transform: translateY(-1.2rem); }
.portfolio-grid-item:nth-child(3n-1) { transform: translateY(1.2rem); }

@media (prefers-reduced-motion: reduce) {
  .portfolio-grid-item { opacity: 1; clip-path: none; transition: none; }
}

.portfolio-grid-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.portfolio-grid-item:hover img {
  transform: scale(1.04);
}

.portfolio-cta {
  padding: 3rem var(--gutter);
  text-align: center;
}

/* ================================================
   LOOKBOOK — VOIR TOUT lien footer galerie
   ================================================ */
.lb-voir-tout {
  font-family: var(--font-display);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-warm);
  text-decoration: none;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.lb-voir-tout:hover {
  color: var(--color-text);
}

/* -------------------------------------------------------
   Responsive
   ------------------------------------------------------- */
@media (max-width: 900px) {
  .prestations-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .nav-links { display: none; }
  .hamburger { display: flex; }

  .inline-card-inner { padding: 2rem 1.5rem; }

  .lb-stage { height: auto; }
  .lb-cards {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    justify-content: flex-start;
    gap: 3vw;
    padding: 0 var(--gutter);
    height: 65vw;
  }
  .lb-card {
    flex: 0 0 80vw;
    height: 100%;
    scroll-snap-align: start;
  }
  .lb-photo { width: 42vw; }
  .lb-track  { padding-inline: 29vw; } /* (100vw - 42vw) / 2 — centrage mobile */
  .lb-cursor { display: none; }

  .bridge-inner {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr 1px 1fr;
    height: auto;
  }
  .bridge-side { height: 220px; }
  .bridge-divider { height: 1px; width: 100%; }

  .about-inner { grid-template-columns: 1fr; }
  .about-photo-wrap { max-width: 280px; }

  .site-footer { grid-template-columns: 1fr; gap: 1.5rem; }
  .footer-col--center { align-items: flex-start; text-align: left; }
  .footer-col--right { align-items: flex-start; }
  .tarifs-section { grid-template-columns: 1fr; gap: 2rem; }
  .portfolio-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .hero-title { font-size: clamp(2.8rem, 12vw, 5rem); }
  .prestations-grid { grid-template-columns: 1fr; }
  .portfolio-cards { grid-template-columns: 1fr; }
  .portfolio-grid  { grid-template-columns: 1fr; }
}

/* -------------------------------------------------------
   Formulaire — boutons de sélection de service
   ------------------------------------------------------- */
.service-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
  justify-content: center;
}
.service-btn {
  padding: 0.6rem 1.6rem;
  border: 1px solid #2a2a2a;
  border-radius: 20px;
  background: #1a1a1a;
  color: #666;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: border-color 0.3s, color 0.3s, background 0.3s, transform 0.3s;
}
.service-btn:hover {
  border-color: rgba(226, 214, 207, 0.4);
  color: #ccc;
  background: rgba(226, 214, 207, 0.06);
  transform: scale(1.03);
}
.service-btn.active {
  border-color: var(--color-warm);
  color: var(--color-warm);
  background: rgba(226, 214, 207, 0.08);
}
.service-btn:focus-visible {
  outline: 2px solid rgba(237,237,237,0.45);
  outline-offset: 3px;
}

/* -------------------------------------------------------
   Hub Prestations — Bandes éditoriales
   ------------------------------------------------------- */

.hub-header {
  padding: 7rem var(--gutter) 2rem;
  max-width: var(--max-w);
  margin: 0 auto;
}

.hub-tag {
  display: block;
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-warm);
  margin-bottom: 1.2rem;
}

.hub-h1-strong {
  display: block;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--color-text);
}

.hub-h1-geo {
  display: block;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  color: rgba(237,237,237,0.6);
  margin-top: 1rem;
  line-height: 1.6;
  max-width: 480px;
}

.hub-band {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 80vh;
  border-top: 1px solid var(--color-surface);
}

.hub-band:nth-child(even) .hub-band-img  { grid-column: 2; grid-row: 1; }
.hub-band:nth-child(even) .hub-band-text { grid-column: 1; grid-row: 1; }

.hub-band-img {
  position: relative;
  overflow: hidden;
  background: var(--color-surface);
  height: 100%;
}

.hub-band-img img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
  display: block;
  transition: transform 0.6s ease-out;
}

.hub-band:hover .hub-band-img img {
  transform: scale(1.04);
}

.hub-band-img::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hub-band:nth-child(odd) .hub-band-img::after {
  background: linear-gradient(to right, transparent 60%, rgba(9,9,9,0.25) 100%);
}

.hub-band:nth-child(even) .hub-band-img::after {
  background: linear-gradient(to left, transparent 60%, rgba(9,9,9,0.25) 100%);
}

.hub-band-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 4rem 5rem;
}

.hub-band-text .btn-outline {
  align-self: flex-start;
  padding: 0.58rem 1.5rem;
  font-size: 0.67rem;
  letter-spacing: 0.14em;
}

.hub-band-num {
  font-family: var(--font-display);
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-warm);
  margin-bottom: 1.8rem;
}

.hub-band-name {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin-bottom: 1.4rem;
  color: var(--color-text);
  text-transform: uppercase;
}

.hub-band-tagline {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  color: var(--color-warm);
  line-height: 1.5;
  max-width: 320px;
  margin-bottom: 2rem;
}

.hub-band-details {
  list-style: none;
  padding: 0;
  margin: 0 0 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.hub-band-details li {
  font-size: 0.88rem;
  font-weight: 400;
  color: rgba(237,237,237,0.7);
  padding-left: 1.2rem;
  position: relative;
}

.hub-band-details li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: rgba(237,237,237,0.25);
  font-size: 0.7rem;
}

.hub-bottom-cta {
  padding: 5rem 3rem 7rem;
  text-align: center;
  border-top: 1px solid var(--color-surface);
}

.hub-bottom-cta p {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--color-warm);
  margin-bottom: 2rem;
}

/* -------------------------------------------------------
   Sous-pages service — Hero + Teaser portrait
   ------------------------------------------------------- */

.sp-hero {
  padding: 7rem var(--gutter) 3rem;
  max-width: var(--max-w);
  margin: 0 auto;
}

.sp-breadcrumb {
  display: block;
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-warm);
  margin-bottom: 1.2rem;
}

.sp-breadcrumb a {
  color: inherit;
  opacity: 0.6;
  text-decoration: none;
  transition: color 0.2s, opacity 0.2s;
}

.sp-breadcrumb a:hover {
  opacity: 1;
  color: rgba(237,237,237,0.65);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

.sp-breadcrumb-current {
  color: var(--color-text);
  opacity: 1;
}

.sp-h1 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-bottom: 1rem;
  color: var(--color-text);
}

.sp-intro {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  color: var(--color-warm);
  max-width: 480px;
  line-height: 1.6;
}
.sp-intro + .sp-intro {
  margin-top: 0.75em;
}

/* Décalage éditorial du second paragraphe */
.sp-hero .sp-intro + .sp-intro {
  margin-left: clamp(1.5rem, 6vw, 6rem);
}

/* Animations d'intro — synchro veil 0.38s */
@keyframes sp-enter-down {
  from { opacity: 0; transform: translateY(1.6rem); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes sp-enter-left {
  from { opacity: 0; transform: translateX(-2rem); }
  to   { opacity: 1; transform: translateX(0); }
}

.sp-hero .sp-breadcrumb,
.sp-hero .sp-h1 {
  animation: sp-enter-down 0.7s cubic-bezier(0.16, 1, 0.3, 1) both;
}

.sp-hero .sp-intro {
  animation: sp-enter-left 0.7s cubic-bezier(0.16, 1, 0.3, 1) both;
}

.sp-hero .sp-breadcrumb              { animation-delay: 0.42s; }
.sp-hero .sp-h1                      { animation-delay: 0.54s; }
.sp-hero .sp-intro                   { animation-delay: 0.68s; }
.sp-hero .sp-intro + .sp-intro       { animation-delay: 0.82s; }

@media (prefers-reduced-motion: reduce) {
  .sp-hero .sp-breadcrumb,
  .sp-hero .sp-h1,
  .sp-hero .sp-intro { animation: none; opacity: 1; }
}

.sp-teaser {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  /* Hauteur de LIGNE définie (pas height sur le conteneur) : sinon la ligne
     reste "auto", height:100% des <img> ne résout pas, l'image s'affiche à sa
     hauteur naturelle et object-fit/object-position (recadrage) n'a aucun effet. */
  grid-auto-rows: 60vh;
  overflow: hidden;
  background: var(--color-surface);
  margin-bottom: 1.5rem;
}

.sp-teaser img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
  display: block;
}

.sp-portfolio-link {
  display: block;
  text-align: center;
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(237,237,237,0.55);
  text-decoration: none;
  padding: 1rem;
  margin-bottom: 2rem;
  transition: color 0.2s;
}

.sp-portfolio-link:hover { color: var(--color-text); }

.sp-jmp-link {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--gutter) 2rem;
  font-size: 0.88rem;
  color: rgba(237,237,237,0.45);
}

.sp-jmp-link a {
  color: rgba(237,237,237,0.5);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: color 0.2s;
}

.sp-jmp-link a:hover { color: var(--color-text); }

/* -------------------------------------------------------
   FAQ Éditorial — pages prestations
   ------------------------------------------------------- */

.faq-section {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 4rem var(--gutter) 2rem;
}

.faq-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.faq-item {
  border-bottom: 1px solid rgba(237,237,237,0.08);
  padding: 3rem 0;
}

.faq-item:first-child {
  border-top: 1px solid rgba(237,237,237,0.08);
}

.faq-item-inner {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 0 4rem;
  align-items: start;
}

.faq-left {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.faq-num {
  display: block;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(3rem, 6vw, 5.5rem);
  line-height: 1;
  color: var(--color-accent);
}

@supports (-webkit-text-stroke: 1px transparent) {
  .faq-num {
    -webkit-text-stroke: 1.5px var(--color-accent);
    color: transparent;
  }
}

.faq-question {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1rem, 1.5vw, 1.18rem);
  letter-spacing: -0.01em;
  line-height: 1.5;
  color: var(--color-text);
  margin: 0;
}

.faq-answer-text {
  font-size: 0.93rem;
  line-height: 1.78;
  color: var(--color-warm);
  margin: 0;
  padding-top: 0.5rem;
}

/* -------------------------------------------------------
   Animations — Prestations reveal
   (prefers-reduced-motion: no-preference requis)
   ------------------------------------------------------- */

@media (prefers-reduced-motion: no-preference) {

  .hub-header {
    opacity: 0;
    transform: translateY(20px);
    animation: jmbFadeUp 0.5s ease-out 0.1s forwards;
  }

  .sp-hero {
    opacity: 0;
    transform: translateY(20px);
    animation: jmbFadeUp 0.5s ease-out 0.1s forwards;
  }

  @keyframes jmbFadeUp {
    to { opacity: 1; transform: none; }
  }

  .reveal-img {
    clip-path: inset(0 100% 0 0);
    transition: clip-path 0.9s cubic-bezier(0.76, 0, 0.24, 1);
  }

  .reveal-img-right {
    clip-path: inset(0 0 0 100%);
    transition: clip-path 0.9s cubic-bezier(0.76, 0, 0.24, 1);
  }

  .reveal-img.is-visible,
  .reveal-img-right.is-visible {
    clip-path: inset(0 0% 0 0);
  }

  .stagger-item {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.5s ease-out, transform 0.5s ease-out;
  }

  .stagger-item.is-visible {
    opacity: 1;
    transform: none;
  }

  .sp-page .tarifs-section {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 0.4s ease-out, transform 0.4s ease-out;
  }

  .sp-page .tarifs-section.is-visible {
    opacity: 1;
    transform: none;
  }

  .sp-page .faq-item {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity 0.38s ease-out, transform 0.38s ease-out;
  }

  .sp-page .faq-item.is-visible {
    opacity: 1;
    transform: none;
  }

  /* Contact page — stagger fade-in */
  .contact-fade-1 { opacity: 0; animation: jmbFadeUp 0.5s ease-out 0s      forwards; }
  .contact-fade-2 { opacity: 0; animation: jmbFadeUp 0.5s ease-out 0.08s   forwards; }
  .contact-fade-3 { opacity: 0; animation: jmbFadeUp 0.5s ease-out 0.16s   forwards; }
  .contact-fade-4 { opacity: 0; animation: jmbFadeUp 0.5s ease-out 0.24s   forwards; }

}

/* -------------------------------------------------------
   Responsive — Hub + sous-pages prestations
   ------------------------------------------------------- */

@media (max-width: 900px) {
  .hub-band {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .hub-band-img {
    height: 55vw;
    min-height: 220px;
  }

  /* Reset grid-column — image toujours au-dessus sur mobile */
  .hub-band:nth-child(even) .hub-band-img { grid-column: auto; }
  .hub-band:nth-child(even) .hub-band-text { grid-column: auto; }

  .hub-band-text {
    padding: 3rem var(--gutter);
  }

  .sp-teaser {
    grid-auto-rows: 40vh;
  }

  .faq-item-inner {
    grid-template-columns: 1fr;
    gap: 1rem 0;
  }
}

@media (max-width: 600px) {
  .hub-header {
    padding: 5rem 1.5rem 1.5rem;
  }

  .hub-band-text {
    padding: 2rem 1.5rem;
  }

  .sp-teaser {
    grid-template-columns: 1fr;
    height: auto;
    grid-auto-rows: auto; /* annule le 40vh hérité : en 1 colonne, la hauteur vient de l'img (45vw) */
  }

  .sp-teaser img {
    height: 45vw;
  }

  .sp-hero {
    padding: 5rem 1.5rem 2rem;
  }

  .faq-num {
    font-size: clamp(2.5rem, 10vw, 3.5rem);
  }

  .faq-item {
    padding: 2rem 0;
  }
}
