/* ======================================================================
 * Normandie Séminaire — refonte éditoriale "Maritime"
 * Portage 1:1 du prototype Anthropic Design (chat handoff 2026-05-01)
 * Palette : Côte fleurie (default) / Brume (seafoam) / Crépuscule (dusk)
 * Typo    : Poppins (sans), Instrument Serif (italique), JetBrains Mono (méta)
 * ====================================================================== */

:root {
  /* Maritime / Côte fleurie palette */
  --paper: #F4ECD8;
  --bg: #EFE4CB;
  --bg-elev: #E5D7B6;
  --ink: #0E1F2C;
  --ink-soft: #1A3548;
  --muted: #6F6549;
  --rule: #D6C8A4;
  --accent: #C75327;          /* terracotta brûlée */
  --accent-2: #E8A33D;         /* golden hour */
  --accent-3: #1F3B4D;         /* slate sea */
  --cream: #FBF6E9;
  --shadow: 0 30px 80px -30px rgba(14,31,44,.35);

  --serif: "Instrument Serif", "Cormorant Garamond", Georgia, serif;
  --serif-display: "Instrument Serif", "Cormorant Garamond", Georgia, serif;
  --sans: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

  --maxw: 1480px;
  --gutter: clamp(20px, 4vw, 72px);
}

[data-palette="dusk"] {
  --paper: #1B1410;
  --bg: #14100D;
  --bg-elev: #221913;
  --ink: #F4ECD8;
  --ink-soft: #E5D7B6;
  --muted: #9A8A6A;
  --rule: #2F2519;
  --accent: #E07142;
  --accent-2: #F4B854;
  --accent-3: #6B8FA0;
  --cream: #1F1812;
  --shadow: 0 30px 80px -30px rgba(0,0,0,.6);
}

[data-palette="seafoam"] {
  --paper: #EFE9DC;
  --bg: #DDE7E0;
  --bg-elev: #C9D6CD;
  --ink: #0F2A2E;
  --ink-soft: #1A3A3F;
  --muted: #5A6F6C;
  --rule: #B6C2B7;
  --accent: #C7572A;
  --accent-2: #DDB257;
  --accent-3: #2A5856;
  --cream: #F4EFE6;
  --shadow: 0 30px 80px -30px rgba(15,42,46,.3);
}

/* ── Reset & base ── */
.ns-redesign,
body.ns-redesign,
body.home,
body.normandie-seminaire-redesign {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
html.ns-redesign,
body.ns-redesign { scroll-behavior: smooth; scroll-padding-top: 110px; }
.ns-redesign :target,
.ns-redesign section[id] { scroll-margin-top: 110px; }

/* Atmospheric gradient backdrop */
body.ns-redesign {
  position: relative;
  background:
    radial-gradient(ellipse 80% 60% at 80% -10%, color-mix(in oklab, var(--accent-2) 28%, transparent), transparent 60%),
    radial-gradient(ellipse 60% 40% at 10% 20%, color-mix(in oklab, var(--accent) 12%, transparent), transparent 65%),
    radial-gradient(ellipse 70% 50% at 50% 100%, color-mix(in oklab, var(--accent-3) 14%, transparent), transparent 70%),
    var(--bg);
  background-attachment: fixed;
}

.ns-redesign ::selection { background: var(--accent); color: var(--cream); }
.ns-redesign a { color: inherit; text-decoration: none; }
.ns-redesign img, .ns-redesign svg { display: block; max-width: 100%; }
.ns-redesign button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }

/* ── Type ── */
.ns-redesign .serif { font-family: var(--serif); font-weight: 400; letter-spacing: -0.01em; }
.ns-redesign .sans { font-family: var(--sans); }
.ns-redesign .mono { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; }

.ns-redesign .display-xl { font-family: var(--sans); font-weight: 700; font-size: clamp(72px, 15vw, 280px); line-height: 0.86; letter-spacing: -0.045em; }
.ns-redesign .display-l  { font-family: var(--sans); font-weight: 700; font-size: clamp(52px, 9vw, 144px); line-height: 0.9; letter-spacing: -0.035em; }
.ns-redesign .display-m  { font-family: var(--sans); font-weight: 700; font-size: clamp(40px, 6vw, 84px); line-height: 0.98; letter-spacing: -0.025em; }
.ns-redesign .display-s  { font-family: var(--sans); font-weight: 700; font-size: clamp(30px, 3.6vw, 52px); line-height: 1.02; letter-spacing: -0.015em; }
.ns-redesign .it { font-style: italic; }

.ns-redesign .eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
  display: inline-flex; align-items: center; gap: 12px;
}
.ns-redesign .eyebrow::before {
  content: ""; display: inline-block;
  width: 28px; height: 1px;
  background: var(--accent);
}

/* ── Layout ── */
.ns-redesign .shell {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

.ns-redesign .section {
  padding-block: clamp(100px, 14vw, 220px);
  position: relative;
}

.ns-redesign .rule { height: 1px; background: var(--rule); width: 100%; }

/* ── Nav (floating pill) ── */
.ns-redesign .ns-nav {
  position: fixed;
  top: 16px; left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  width: calc(100% - var(--gutter) * 2);
  max-width: 1480px;
  padding: 14px 22px;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 24px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--paper) 70%, transparent);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  box-shadow: 0 10px 40px -20px color-mix(in oklab, var(--ink) 35%, transparent);
  transition: top .4s ease, padding .4s ease, background .4s ease, box-shadow .4s ease, transform .6s cubic-bezier(.2,.7,.2,1), opacity .6s;
  animation: navIn 1.1s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes navIn {
  from { transform: translate(-50%, -120%); opacity: 0; }
  to   { transform: translate(-50%, 0); opacity: 1; }
}
.ns-redesign .ns-nav.scrolled {
  top: 12px;
  padding: 11px 18px;
  background: color-mix(in oklab, var(--paper) 88%, transparent);
  box-shadow: 0 14px 50px -18px color-mix(in oklab, var(--ink) 45%, transparent);
}
.ns-redesign .nav-brand {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--sans); font-weight: 700; font-size: 18px; letter-spacing: -0.015em;
  white-space: nowrap;
}
.ns-redesign .nav-brand .dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--accent-2), var(--accent));
  display: inline-block;
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--accent) 18%, transparent);
}
.ns-redesign .nav-brand .sep { font-style: italic; color: var(--accent); margin: 0 1px; }
.ns-redesign .nav-links { display: flex; gap: 32px; justify-content: center; font-size: 13px; align-items: center; list-style: none; margin: 0; padding: 0; }
.ns-redesign .nav-links li { display: inline-flex; align-items: center; list-style: none; margin: 0; padding: 0; }
.ns-redesign .nav-links a { position: relative; padding: 6px 0; color: var(--ink-soft); transition: color .2s; display: inline-block; }
.ns-redesign .nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: 0;
  background: var(--accent); transition: width .35s ease;
}
.ns-redesign .nav-links a:hover,
.ns-redesign .nav-links li.current-menu-item > a,
.ns-redesign .nav-links li.current-menu-ancestor > a { color: var(--ink); }
.ns-redesign .nav-links a:hover::after,
.ns-redesign .nav-links li.current-menu-item > a::after { width: 100%; }
/* Sous-menus depth 2 */
.ns-redesign .nav-links li.menu-item-has-children { position: relative; }
.ns-redesign .nav-links .sub-menu {
  display: none;
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  margin-top: 12px; padding: 12px;
  background: color-mix(in oklab, var(--paper) 92%, transparent);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  border-radius: 14px;
  box-shadow: 0 16px 50px -20px color-mix(in oklab, var(--ink) 35%, transparent);
  flex-direction: column; gap: 4px; min-width: 220px; z-index: 110; list-style: none;
}
.ns-redesign .nav-links li.menu-item-has-children:hover > .sub-menu,
.ns-redesign .nav-links li.menu-item-has-children:focus-within > .sub-menu { display: flex; }
.ns-redesign .nav-links .sub-menu a { padding: 8px 12px; border-radius: 6px; white-space: nowrap; }
.ns-redesign .nav-links .sub-menu a:hover { background: color-mix(in oklab, var(--accent-2) 14%, transparent); }
.ns-redesign .nav-links .sub-menu a::after { display: none; }
.ns-redesign .nav-cta {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  background: var(--ink); color: var(--cream);
  border-radius: 999px;
  font-size: 13px; font-weight: 500;
  white-space: nowrap;
  transition: transform .25s, background .25s, padding .25s;
}
.ns-redesign .nav-cta:hover { transform: translateY(-1px); background: var(--accent); padding-right: 22px; }
.ns-redesign .nav-tel {
  font-family: var(--mono);
  font-size: 11.5px; letter-spacing: 0.08em; color: var(--ink);
  white-space: nowrap;
  padding-left: 18px; border-left: 1px solid var(--rule);
  transition: color .2s;
}
.ns-redesign .nav-tel:hover { color: var(--accent-2); }

@media (max-width: 1180px) { .ns-redesign .nav-tel { display: none; } .ns-redesign .ns-nav { grid-template-columns: auto 1fr auto; } }
@media (max-width: 880px)  { .ns-redesign .nav-links { display: none; } .ns-redesign .ns-nav { grid-template-columns: 1fr auto; } }

/* ── Buttons ── */
.ns-redesign .btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 18px 28px; border-radius: 999px;
  font-size: 14px; font-weight: 500; letter-spacing: 0.005em;
  cursor: pointer; border: none;
  background: var(--ink); color: var(--cream);
  transition: transform .25s, box-shadow .25s, background .25s;
}
.ns-redesign .btn:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.ns-redesign .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.ns-redesign .btn-ghost:hover { background: var(--ink); color: var(--cream); }
/* btn-accent : single source of truth — taille canonique. Override final ligne ~1400. */
.ns-redesign .btn-accent {
  background: var(--accent);
  color: var(--cream);
  box-shadow: 0 12px 30px -12px color-mix(in oklab, var(--accent) 60%, transparent);
}

.ns-redesign .arrow-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; letter-spacing: 0.02em;
  border-bottom: 1px solid currentColor; padding-bottom: 2px;
  transition: gap .25s;
}
.ns-redesign .arrow-link:hover { gap: 14px; }

/* ── Reveal animations ── */
.ns-redesign .reveal { opacity: 0; transform: translateY(28px); transition: opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1); }
.ns-redesign .reveal.in { opacity: 1; transform: none; }
.ns-redesign .reveal-stagger > * { opacity: 0; transform: translateY(24px); transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); }
.ns-redesign .reveal-stagger.in > * { opacity: 1; transform: none; }
.ns-redesign .reveal-stagger.in > *:nth-child(1) { transition-delay: 0ms; }
.ns-redesign .reveal-stagger.in > *:nth-child(2) { transition-delay: 90ms; }
.ns-redesign .reveal-stagger.in > *:nth-child(3) { transition-delay: 180ms; }
.ns-redesign .reveal-stagger.in > *:nth-child(4) { transition-delay: 270ms; }
.ns-redesign .reveal-stagger.in > *:nth-child(5) { transition-delay: 360ms; }
.ns-redesign .reveal-stagger.in > *:nth-child(6) { transition-delay: 450ms; }

.ns-redesign .reveal-mask {
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 0%, transparent 0%);
  mask-image: linear-gradient(180deg, #000 0%, #000 0%, transparent 0%);
  transition: -webkit-mask-image 1.4s cubic-bezier(.2,.7,.15,1), mask-image 1.4s cubic-bezier(.2,.7,.15,1);
}
.ns-redesign .reveal-mask.in {
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 100%, transparent 100%);
  mask-image: linear-gradient(180deg, #000 0%, #000 100%, transparent 100%);
}
.ns-redesign .reveal-scale { opacity: 0; transform: scale(0.94); transition: opacity 1.1s cubic-bezier(.2,.7,.2,1), transform 1.1s cubic-bezier(.2,.7,.2,1); }
.ns-redesign .reveal-scale.in { opacity: 1; transform: none; }
.ns-redesign .reveal-left  { opacity: 0; transform: translateX(-40px); transition: opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1); }
.ns-redesign .reveal-right { opacity: 0; transform: translateX(40px);  transition: opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1); }
.ns-redesign .reveal-left.in, .ns-redesign .reveal-right.in { opacity: 1; transform: none; }

.ns-redesign .split-text { display: inline; }
.ns-redesign .split-text .word { display: inline-block; overflow: hidden; vertical-align: bottom; padding-bottom: 0.08em; }
.ns-redesign .split-text .word .inner {
  display: inline-block; transform: translateY(110%);
  transition: transform 1.1s cubic-bezier(.2,.7,.15,1);
  white-space: nowrap;
}
.ns-redesign .split-text.in .word .inner { transform: translateY(0); }

/* ── Marquee ── */
.ns-redesign .marquee {
  display: flex; overflow: hidden; gap: 60px;
  border-block: 1px solid color-mix(in oklab, var(--ink) 14%, transparent);
  padding-block: 28px;
  font-family: var(--serif);
  font-size: clamp(32px, 5vw, 80px);
  letter-spacing: -0.025em;
  white-space: nowrap;
  background: color-mix(in oklab, var(--ink) 4%, transparent);
}
.ns-redesign .marquee-track { display: flex; gap: 60px; animation: marquee 38s linear infinite; flex-shrink: 0; }
.ns-redesign .marquee-track > span { display: inline-flex; align-items: center; gap: 60px; }
.ns-redesign .marquee-track .star { color: var(--accent); font-size: 0.6em; }
@keyframes marquee { to { transform: translateX(-100%); } }

/* ── HERO ── */
.ns-redesign .hero {
  min-height: 100vh;
  padding-top: 150px; padding-bottom: 70px;
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative; overflow: hidden;
}
.ns-redesign .hero-meta {
  display: flex; flex-wrap: wrap; gap: 14px 28px; align-items: center;
  font-size: 11px; font-family: var(--mono);
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-soft);
  padding-bottom: 22px;
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 14%, transparent);
  position: relative; z-index: 2;
}
.ns-redesign .hero-meta > .pulse { margin-left: auto; }
.ns-redesign .hero-meta .pulse { display: inline-flex; align-items: center; gap: 10px; }
.ns-redesign .hero-meta .pulse::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent); animation: pulse 1.8s infinite;
}
.ns-redesign .hero-meta .badge {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
  padding: 6px 12px; border: 1px solid color-mix(in oklab, var(--ink) 22%, transparent);
  border-radius: 999px; background: color-mix(in oklab, var(--cream) 60%, transparent);
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--accent) 60%, transparent); }
  70% { box-shadow: 0 0 0 14px color-mix(in oklab, var(--accent) 0%, transparent); }
  100% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--accent) 0%, transparent); }
}
.ns-redesign .hero-headline {
  margin-top: clamp(16px, 3vw, 40px);
  margin-bottom: clamp(28px, 5vw, 70px);
  position: relative; z-index: 3;
  max-width: 1200px;
}
.ns-redesign .hero-headline h1 {
  font-family: var(--sans); font-weight: 800;
  /* Réduit max pour que les 3 lignes tiennent toujours sans clipping */
  font-size: clamp(40px, 7.5vw, 124px);
  line-height: 0.96; letter-spacing: -0.04em;
}
.ns-redesign .hero-headline .row { display: block; }
.ns-redesign .hero-headline .row > * { display: inline; }
.ns-redesign .hero-headline em {
  background: linear-gradient(110deg, var(--accent) 10%, var(--accent-2) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  font-style: italic; font-family: var(--serif); font-weight: 400;
}
.ns-redesign .hero-headline .ornament {
  display: inline-block; vertical-align: middle;
  margin: 0 0.1em 0.15em;
  width: 0.85em; height: 0.85em;
  background: radial-gradient(circle at 30% 30%, var(--accent-2), var(--accent));
  border-radius: 50%;
  box-shadow: 0 0 0 0.06em color-mix(in oklab, var(--accent) 16%, transparent);
}
.ns-redesign .hero-foot {
  display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 40px; align-items: end;
  padding-top: 32px;
  border-top: 1px solid color-mix(in oklab, var(--ink) 12%, transparent);
  position: relative; z-index: 2;
}
.ns-redesign .hero-foot p { color: var(--ink-soft); max-width: 38ch; font-size: 15.5px; line-height: 1.55; font-weight: 400; }
@media (max-width: 880px) { .ns-redesign .hero-foot { grid-template-columns: 1fr; gap: 24px; } }
.ns-redesign .hero-sun {
  position: absolute; width: 44vmin; height: 44vmin;
  right: 4vw; top: 22vh;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, color-mix(in oklab, var(--accent-2) 75%, var(--paper)) 0%, color-mix(in oklab, var(--accent) 35%, transparent) 40%, transparent 75%);
  filter: blur(36px); opacity: 0.32; z-index: 0;
  pointer-events: none; mix-blend-mode: multiply; will-change: transform;
}
[data-palette="dusk"] .ns-redesign .hero-sun {
  mix-blend-mode: screen; opacity: 0.6;
  background: radial-gradient(circle at 50% 50%, var(--accent-2), color-mix(in oklab, var(--accent) 80%, transparent) 40%, transparent 70%);
}
.ns-redesign .hero-photo {
  position: absolute; right: -8vw; top: 8vh;
  width: 42vw; height: 56vh;
  background-size: cover; background-position: center; background-repeat: no-repeat;
  background-image: url("https://images.unsplash.com/photo-1551918120-9739cb430c6d?auto=format&fit=crop&w=1600&q=80");
  border-radius: 6px; z-index: 0;
  opacity: 0.32; mix-blend-mode: multiply;
  filter: saturate(0.7) contrast(1.05);
  mask-image: radial-gradient(ellipse 70% 70% at 70% 50%, black 20%, transparent 90%);
  -webkit-mask-image: radial-gradient(ellipse 70% 70% at 70% 50%, black 20%, transparent 90%);
  pointer-events: none; will-change: transform;
}
@media (max-width: 1024px) { .ns-redesign .hero-photo { display: none; } }
[data-palette="dusk"] .ns-redesign .hero-photo { mix-blend-mode: screen; opacity: 0.5; }

/* Hero video — full-width plein hero, derrière le contenu, traitement maritime */
.ns-redesign .hero-video-wrap {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  border-radius: 0;
  /* Fade vers les bords pour fondre dans la palette maritime */
  mask-image: radial-gradient(ellipse 95% 110% at 50% 45%, black 30%, transparent 92%);
  -webkit-mask-image: radial-gradient(ellipse 95% 110% at 50% 45%, black 30%, transparent 92%);
}
.ns-redesign .hero-video {
  position: absolute;
  top: 50%; left: 50%;
  min-width: 100%; min-height: 100%;
  width: auto; height: auto;
  transform: translate(-50%, -50%);
  object-fit: cover;
  opacity: 0;
  filter: saturate(0.65) contrast(1.05) blur(2px);
  mix-blend-mode: multiply;
  transition: opacity 0.9s ease-in-out;
  will-change: opacity, transform;
}
.ns-redesign .hero-video.is-loaded { opacity: 0.42; }
[data-palette="dusk"] .ns-redesign .hero-video { mix-blend-mode: screen; }
[data-palette="dusk"] .ns-redesign .hero-video.is-loaded { opacity: 0.55; }
[data-palette="seafoam"] .ns-redesign .hero-video.is-loaded { opacity: 0.38; }
@media (prefers-reduced-motion: reduce) {
  .ns-redesign .hero-video { filter: saturate(0.65) contrast(1.05); }
}
.ns-redesign .hero-ticker { display: flex; align-items: center; gap: 14px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-soft); }
.ns-redesign .hero-ticker .num { font-family: var(--serif); font-style: italic; font-size: 28px; letter-spacing: -0.02em; color: var(--accent); }
.ns-redesign .cta-stack { display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
.ns-redesign .scroll-cue { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-soft); }
.ns-redesign .scroll-cue .line { display: inline-block; width: 32px; height: 1px; background: linear-gradient(90deg, transparent, var(--accent)); position: relative; overflow: hidden; }
.ns-redesign .scroll-cue .line::after { content: ""; position: absolute; left: -100%; top: 0; width: 50%; height: 100%; background: var(--accent); animation: scroll-cue 1.8s infinite ease-in-out; }
@keyframes scroll-cue { to { left: 150%; } }

/* ── Bignum (parallax behind sections) ── */
.ns-redesign .bignum {
  position: absolute;
  font-family: var(--serif); font-style: italic;
  color: color-mix(in oklab, var(--accent) 10%, transparent);
  font-size: clamp(220px, 32vw, 540px);
  line-height: 0.78;
  pointer-events: none; z-index: 0; user-select: none;
  letter-spacing: -0.05em; will-change: transform;
}

/* ── Bento manifesto ── */
.ns-redesign .bento { display: grid; grid-template-columns: repeat(6, 1fr); grid-auto-rows: minmax(180px, auto); gap: 18px; }
.ns-redesign .bento .card {
  border-radius: 6px; padding: 28px;
  background: var(--paper);
  border: 1px solid color-mix(in oklab, var(--ink) 8%, transparent);
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative; overflow: hidden;
  transition: transform .6s cubic-bezier(.2,.7,.2,1), box-shadow .6s;
}
.ns-redesign .bento .card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.ns-redesign .bento .b1 { grid-column: span 4; grid-row: span 2;
  background: radial-gradient(ellipse at 80% 0%, color-mix(in oklab, var(--accent-2) 30%, transparent), transparent 60%), var(--ink);
  color: var(--cream); border-color: var(--ink); }
.ns-redesign .bento .b2 { grid-column: span 2; background: var(--cream); }
.ns-redesign .bento .b3 { grid-column: span 2; background: var(--accent); color: var(--cream); border-color: var(--accent); }
.ns-redesign .bento .b4 { grid-column: span 4; background: linear-gradient(135deg, var(--accent-2) 0%, var(--accent) 100%); color: var(--ink); border: 0; }
.ns-redesign .bento .b5 { grid-column: span 2; background: var(--accent-3); color: var(--cream); border-color: var(--accent-3); }
.ns-redesign .bento .b6 { grid-column: span 4; background: var(--cream); }
@media (max-width: 880px) {
  .ns-redesign .bento { grid-template-columns: 1fr; }
  .ns-redesign .bento .card { grid-column: span 1 !important; grid-row: auto !important; }
}
.ns-redesign .bento h3 { font-family: var(--sans); font-weight: 700; font-size: clamp(24px, 2.6vw, 38px); line-height: 1.05; letter-spacing: -0.02em; margin-bottom: 12px; }
.ns-redesign .bento p { font-size: 15px; line-height: 1.55; opacity: 0.85; max-width: 36ch; }
.ns-redesign .bento .tag-mini { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; opacity: 0.7; }

/* ── Approach split ── */
.ns-redesign .split {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
  border-radius: 6px; overflow: hidden; background: var(--paper);
}
.ns-redesign .split > div { padding: 48px; }
.ns-redesign .split > div + div { border-left: 1px solid var(--rule); background: color-mix(in oklab, var(--ink) 4%, var(--paper)); }
.ns-redesign .split h3 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-bottom: 32px; }
.ns-redesign .split ul { list-style: none; display: flex; flex-direction: column; gap: 16px; padding: 0; }
.ns-redesign .split li {
  display: grid; grid-template-columns: 28px 1fr; gap: 14px;
  font-family: var(--sans); font-weight: 600; font-size: clamp(18px, 1.5vw, 22px); line-height: 1.35; letter-spacing: -0.01em;
}
.ns-redesign .split li::before { content: ""; display: inline-block; width: 18px; height: 18px; border-radius: 50%; margin-top: 8px; }
.ns-redesign .split .yes li::before { background: radial-gradient(circle at 30% 30%, var(--accent-2), var(--accent)); }
.ns-redesign .split .no li { color: var(--muted); text-decoration: line-through; text-decoration-thickness: 1px; text-decoration-color: color-mix(in oklab, var(--muted) 60%, transparent); }
.ns-redesign .split .no li::before { background: transparent; border: 1px solid var(--muted); }
@media (max-width: 880px) {
  .ns-redesign .split { grid-template-columns: 1fr; }
  .ns-redesign .split > div + div { border-left: 0; border-top: 1px solid var(--rule); }
}

/* ── Process steps ── */
.ns-redesign .proc-step {
  display: grid; grid-template-columns: 120px 1fr 200px; gap: 32px;
  padding: 44px 0; border-top: 1px solid var(--rule);
  align-items: start;
  transition: padding .5s, background .5s; position: relative;
}
.ns-redesign .proc-step::before {
  content: ""; position: absolute; left: 0; top: 0; height: 1px; width: 0;
  background: var(--accent); transition: width 1s cubic-bezier(.2,.7,.2,1);
}
.ns-redesign .proc-step.in::before { width: 100%; }
.ns-redesign .proc-step:hover { padding-left: 16px; background: color-mix(in oklab, var(--accent) 5%, transparent); }
.ns-redesign .proc-step:last-child { border-bottom: 1px solid var(--rule); }
.ns-redesign .proc-step .pnum {
  font-family: var(--sans); font-weight: 800; font-size: clamp(48px, 6vw, 80px); line-height: 1;
  color: var(--accent); font-style: normal;
  transform: translateX(-30px); opacity: 0.4;
  transition: transform 1s cubic-bezier(.2,.7,.2,1), opacity 1s;
  letter-spacing: -0.04em;
}
.ns-redesign .proc-step.in .pnum { transform: none; opacity: 1; }
.ns-redesign .proc-step h3 { font-family: var(--sans); font-weight: 700; font-size: clamp(24px, 2.6vw, 36px); line-height: 1.1; margin-bottom: 14px; letter-spacing: -0.02em; }
.ns-redesign .proc-step p { color: var(--ink-soft); font-size: 15.5px; line-height: 1.6; max-width: 56ch; }
.ns-redesign .proc-step .when { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); text-align: right; padding-top: 12px; }
@media (max-width: 880px) {
  .ns-redesign .proc-step { grid-template-columns: 1fr; gap: 12px; padding: 32px 0; }
  .ns-redesign .proc-step .when { text-align: left; }
}

/* ── Stats ── */
.ns-redesign .stat { display: flex; flex-direction: column; gap: 8px; }
.ns-redesign .stat .num {
  font-family: var(--sans); font-weight: 800;
  font-size: clamp(64px, 9vw, 144px); line-height: 0.92; letter-spacing: -0.04em;
  background: linear-gradient(180deg, var(--ink) 30%, color-mix(in oklab, var(--ink) 60%, transparent));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.ns-redesign .stat .num em { color: var(--accent); -webkit-text-fill-color: var(--accent); font-style: italic; font-family: var(--serif); font-weight: 400; }
.ns-redesign .stat .lbl { font-family: var(--mono); font-size: 11px; color: var(--muted); letter-spacing: 0.16em; text-transform: uppercase; }

/* ── Method tags ── */
.ns-redesign .tag {
  display: inline-flex; align-items: center; padding: 9px 16px;
  border: 1px solid color-mix(in oklab, var(--ink) 18%, transparent);
  border-radius: 999px; font-size: 13px;
  background: var(--paper);
  transition: background .25s, color .25s, border-color .25s, transform .25s;
  cursor: default;
}
.ns-redesign .tag:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); transform: translateY(-2px); }
.ns-redesign .tag .it { color: var(--accent); margin-right: 4px; }
.ns-redesign .reveal-stagger > .tag { transform: translateY(20px) scale(0.96); opacity: 0; }
.ns-redesign .reveal-stagger.in > .tag { transform: none; opacity: 1; }
.ns-redesign .reveal-stagger.in > .tag:nth-child(7n+1) { transition-delay: 40ms; }
.ns-redesign .reveal-stagger.in > .tag:nth-child(7n+2) { transition-delay: 110ms; }
.ns-redesign .reveal-stagger.in > .tag:nth-child(7n+3) { transition-delay: 180ms; }
.ns-redesign .reveal-stagger.in > .tag:nth-child(7n+4) { transition-delay: 250ms; }
.ns-redesign .reveal-stagger.in > .tag:nth-child(7n+5) { transition-delay: 320ms; }
.ns-redesign .reveal-stagger.in > .tag:nth-child(7n+6) { transition-delay: 390ms; }
.ns-redesign .reveal-stagger.in > .tag:nth-child(7n+7) { transition-delay: 460ms; }

/* ── Lieux H-track ── */
.ns-redesign .h-track-section { position: relative; height: 380vh; }
.ns-redesign .h-track-pin { position: sticky; top: 0; height: 100vh; display: flex; flex-direction: column; justify-content: center; overflow: hidden; }
.ns-redesign .h-track-rail { display: flex; gap: 28px; padding: 0 var(--gutter); will-change: transform; }
.ns-redesign .h-track-card { flex: 0 0 clamp(280px, 28vw, 400px); display: flex; flex-direction: column; }
.ns-redesign .h-track-card .img { aspect-ratio: 4/5; margin-bottom: 14px; overflow: hidden; border-radius: 4px; position: relative; }
.ns-redesign .h-track-card .img .ph {
  width: 100%; height: 100%;
  background-color: var(--bg-elev);
  background-image: var(--photo, none), repeating-linear-gradient(135deg, transparent 0 13px, color-mix(in oklab, var(--ink) 8%, transparent) 13px 14px);
  background-size: cover; background-position: center; background-repeat: no-repeat;
  display: flex; align-items: flex-end; justify-content: space-between;
  padding: 14px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: #fff; text-shadow: 0 1px 4px rgba(0,0,0,0.5);
  transition: transform 1.2s ease;
  position: relative;
}
.ns-redesign .h-track-card .img .ph::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.55) 100%); pointer-events: none; }
.ns-redesign .h-track-card .img .ph > span { position: relative; z-index: 1; }
.ns-redesign .h-track-card:hover .ph { transform: scale(1.06); }
.ns-redesign .h-track-card h4 { font-family: var(--sans); font-weight: 700; font-size: 24px; line-height: 1.15; letter-spacing: -0.02em; }
.ns-redesign .h-track-card .meta { display: flex; justify-content: space-between; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin-top: 8px; }
.ns-redesign .h-track-head { display: grid; grid-template-columns: 1fr auto; align-items: end; gap: 32px; padding: 0 var(--gutter) 48px; }
.ns-redesign .h-track-progress { height: 2px; width: 200px; background: var(--rule); position: relative; overflow: hidden; }
.ns-redesign .h-track-progress > div { position: absolute; left: 0; top: 0; bottom: 0; background: var(--accent); transform-origin: left; }

/* ── Map ── */
.ns-redesign .map-wrap {
  position: relative; aspect-ratio: 16/11;
  background: radial-gradient(ellipse at 30% 20%, color-mix(in oklab, var(--accent-2) 20%, transparent), transparent 60%), var(--paper);
  border: 1px solid var(--rule);
  border-radius: 8px; overflow: hidden;
}
.ns-redesign .map-pin {
  position: absolute; width: 14px; height: 14px; border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--accent-2), var(--accent));
  transform: translate(-50%, -50%); cursor: pointer; transition: transform .3s;
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--accent) 18%, transparent);
}
.ns-redesign .map-pin::after {
  content: ""; position: absolute; inset: -8px; border-radius: 50%;
  border: 1px solid var(--accent); opacity: 0.4; animation: ping 2.4s ease-out infinite;
}
.ns-redesign .map-pin:hover { transform: translate(-50%, -50%) scale(1.5); }
.ns-redesign .map-pin .label {
  position: absolute; left: 22px; top: -4px;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--cream); white-space: nowrap;
  background: var(--ink); padding: 6px 10px; border-radius: 4px;
  opacity: 0; transform: translateX(-4px);
  transition: opacity .25s, transform .25s; pointer-events: none;
}
.ns-redesign .map-pin:hover .label { opacity: 1; transform: translateX(0); }
@keyframes ping {
  0% { transform: scale(1); opacity: 0.6; }
  100% { transform: scale(2.8); opacity: 0; }
}

/* ── Manifesto block ── */
.ns-redesign .manifesto-block {
  font-family: var(--sans); font-weight: 700;
  font-size: clamp(28px, 3.8vw, 60px); line-height: 1.15; letter-spacing: -0.025em;
}
.ns-redesign .manifesto-block .strike { text-decoration: line-through; text-decoration-color: var(--accent); text-decoration-thickness: 3px; opacity: 0.45; }
.ns-redesign .manifesto-block em {
  background: linear-gradient(120deg, var(--accent) 0%, var(--accent-2) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  font-style: italic; font-family: var(--serif); font-weight: 400;
}

/* ── Form ── */
.ns-redesign .form-card {
  background: radial-gradient(ellipse at top right, color-mix(in oklab, var(--accent-2) 14%, transparent), transparent 60%), var(--cream);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: clamp(28px, 4vw, 56px);
  box-shadow: var(--shadow);
}
.ns-redesign .field { display: flex; flex-direction: column; gap: 8px; margin-bottom: 22px; }
.ns-redesign .field label { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }
.ns-redesign .field input,
.ns-redesign .field select,
.ns-redesign .field textarea {
  background: transparent; border: none; border-bottom: 1px solid var(--rule);
  padding: 10px 0; font-family: var(--sans); font-size: 16px; color: var(--ink);
  outline: none; transition: border-color .25s;
}
.ns-redesign .field input:focus,
.ns-redesign .field select:focus,
.ns-redesign .field textarea:focus { border-bottom-color: var(--accent); }
.ns-redesign .field textarea { resize: vertical; min-height: 80px; }
.ns-redesign .fields-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 32px; }
@media (max-width: 700px) { .ns-redesign .fields-grid { grid-template-columns: 1fr; } }
.ns-redesign .form-rgpd { margin-top: 18px; font-size: 11.5px; line-height: 1.55; color: var(--muted); max-width: 60ch; }
.ns-redesign .form-rgpd a { color: var(--ink-soft); border-bottom: 1px solid color-mix(in oklab, var(--ink) 25%, transparent); }
.ns-redesign .form-rgpd a:hover { color: var(--accent-2); border-bottom-color: var(--accent-2); }

/* ── Facilitator ── */
.ns-redesign .facilitator { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(40px, 6vw, 80px); align-items: center; }
.ns-redesign .facilitator .portrait {
  aspect-ratio: 4/5;
  background-color: var(--bg-elev);
  background-image: var(--photo, none), repeating-linear-gradient(135deg, transparent 0 13px, color-mix(in oklab, var(--ink) 8%, transparent) 13px 14px);
  background-size: cover; background-position: center; background-repeat: no-repeat;
  display: flex; align-items: flex-end;
  padding: 20px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: #fff; text-shadow: 0 1px 4px rgba(0,0,0,0.5);
  border-radius: 6px; position: relative;
}
.ns-redesign .facilitator .portrait::after { content: "Photo · Yoan Lureault"; position: absolute; bottom: 20px; left: 20px; }
@media (max-width: 880px) { .ns-redesign .facilitator { grid-template-columns: 1fr; } }

/* ── Cursor ── */
.ns-redesign .cursor-dot {
  position: fixed; pointer-events: none;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent);
  z-index: 9999; mix-blend-mode: difference;
  transform: translate(-50%, -50%);
  transition: width .3s, height .3s, opacity .3s, background .3s;
  opacity: 0;
}
@media (hover: hover) and (pointer: fine) { .ns-redesign .cursor-dot { opacity: 1; } }
.ns-redesign .cursor-dot.lg { width: 48px; height: 48px; background: transparent; border: 1px solid var(--accent); }

/* ── Scroll progress + chapter rail ── */
.ns-redesign .scroll-bar { position: fixed; left: 0; top: 0; right: 0; height: 2px; z-index: 200; background: transparent; }
.ns-redesign .scroll-bar > div { height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-2)); transform-origin: left; will-change: transform; }
.ns-redesign .scroll-prog {
  position: fixed; right: 16px; top: 50%; transform: translateY(-50%);
  z-index: 50; display: flex; flex-direction: column; gap: 7px;
  font-family: var(--mono); font-size: 8px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink); opacity: 0.35; pointer-events: none; transition: opacity .35s;
  max-width: 110px;
}
.ns-redesign .scroll-prog:hover { opacity: 0.8; }
@media (max-width: 1480px) { .ns-redesign .scroll-prog { display: none; } }
.ns-redesign .scroll-prog .row { display: flex; align-items: center; gap: 8px; transition: opacity .35s, color .35s; }
.ns-redesign .scroll-prog .row .bar { display: inline-block; width: 10px; height: 1px; background: currentColor; transition: width .35s; }
.ns-redesign .scroll-prog .row.on { opacity: 1; color: var(--accent); }
.ns-redesign .scroll-prog .row.on .bar { width: 22px; }
.ns-redesign .scroll-prog .row .lbl { min-width: 80px; font-size: 8.5px; }

/* ── Footer ── */
.ns-redesign .ns-footer {
  background:
    radial-gradient(ellipse at 80% 0%, color-mix(in oklab, var(--accent) 30%, transparent), transparent 60%),
    radial-gradient(ellipse at 0% 100%, color-mix(in oklab, var(--accent-3) 40%, transparent), transparent 60%),
    var(--ink);
  color: var(--cream);
  padding: clamp(80px, 10vw, 160px) var(--gutter) 40px;
  position: relative; overflow: hidden;
}
.ns-redesign .ns-footer .footer-display {
  font-family: var(--sans); font-weight: 800;
  font-size: clamp(64px, 13vw, 220px); line-height: 0.92; letter-spacing: -0.045em;
  margin-bottom: 80px;
}
.ns-redesign .ns-footer .footer-display em {
  background: linear-gradient(120deg, var(--accent-2), var(--accent));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  font-style: italic; font-family: var(--serif); font-weight: 400;
}
.ns-redesign .ns-footer .footer-grid {
  display: grid; grid-template-columns: 1.1fr 1fr 1fr 1fr 1.2fr;
  gap: 40px;
  padding: 48px 0;
  border-top: 1px solid color-mix(in oklab, var(--cream) 18%, transparent);
}
@media (max-width: 1100px) { .ns-redesign .ns-footer .footer-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .ns-redesign .ns-footer .footer-grid { grid-template-columns: 1fr; } }
.ns-redesign .ns-footer h5 { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; opacity: 0.55; margin-bottom: 16px; }
.ns-redesign .ns-footer ul { list-style: none; display: flex; flex-direction: column; gap: 10px; font-size: 14.5px; padding: 0; }
.ns-redesign .ns-footer ul a { transition: color .25s; }
.ns-redesign .ns-footer ul a:hover { color: var(--accent-2); }
.ns-redesign .ns-footer .copy { display: flex; justify-content: space-between; padding-top: 28px; font-size: 12px; opacity: 0.55; border-top: 1px solid color-mix(in oklab, var(--cream) 14%, transparent); margin-top: 40px; flex-wrap: wrap; gap: 12px; }
.ns-redesign .ns-footer .footer-tagline { max-width: 56ch; font-size: 14.5px; line-height: 1.7; color: color-mix(in oklab, var(--paper) 70%, transparent); margin: -12px 0 48px; }
.ns-redesign .ns-footer .eco li { margin-bottom: 12px; }
.ns-redesign .ns-footer .eco a { display: flex; flex-direction: column; gap: 2px; color: color-mix(in oklab, var(--paper) 80%, transparent); }
.ns-redesign .ns-footer .eco strong { font-family: var(--sans); font-weight: 600; font-size: 14px; color: var(--paper); }
.ns-redesign .ns-footer .eco span { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.55; }
.ns-redesign .ns-footer .eco a:hover strong { color: var(--accent); }

/* ── Drag hint ── */
.ns-redesign .drag-hint {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--muted);
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border: 1px dashed var(--rule); border-radius: 999px;
}
.ns-redesign .drag-hint .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }

/* ── GoFurther ── */
.ns-redesign .further-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.ns-redesign .further-card {
  display: flex; flex-direction: column; gap: 16px;
  padding: 36px 32px 32px; min-height: 280px;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 22px;
  position: relative; overflow: hidden;
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s;
}
.ns-redesign .further-card::after {
  content: ""; position: absolute;
  inset: auto -40% -60% auto;
  width: 60%; height: 120%;
  background: radial-gradient(ellipse, color-mix(in oklab, var(--accent-3) 30%, transparent), transparent 70%);
  opacity: 0; transition: opacity .5s; pointer-events: none;
}
.ns-redesign .further-card:hover { transform: translateY(-4px); border-color: color-mix(in oklab, var(--accent-2) 30%, var(--rule)); box-shadow: 0 18px 40px -22px color-mix(in oklab, var(--ink) 30%, transparent); }
.ns-redesign .further-card:hover::after { opacity: 0.7; }
.ns-redesign .further-card .kicker { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-2); }
.ns-redesign .further-card h3 { font-family: var(--sans); font-weight: 700; font-size: clamp(24px, 2.2vw, 32px); line-height: 1.05; letter-spacing: -0.025em; margin: 0; }
.ns-redesign .further-card p { color: var(--ink-soft); font-size: 14.5px; line-height: 1.55; margin: 0; }
.ns-redesign .further-card .arrow-link { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; }
@media (max-width: 880px) { .ns-redesign .further-grid { grid-template-columns: 1fr; } }

/* ── Map CTA chips ── */
.ns-redesign .micro-intro { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent-2); margin-bottom: 18px; opacity: 0.9; }
.ns-redesign .map-ctas { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.ns-redesign .chip-link {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 16px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink);
  background: color-mix(in oklab, var(--paper) 70%, var(--accent-3) 4%);
  border: 1px solid var(--rule); border-radius: 100px;
  transition: transform .2s, background .25s, border-color .25s, color .2s;
}
.ns-redesign .chip-link span { color: var(--accent-2); transition: transform .25s; }
.ns-redesign .chip-link:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); transform: translateY(-1px); }
.ns-redesign .chip-link:hover span { transform: translateX(3px); color: var(--accent); }

/* ── Cols ── */
.ns-redesign .cols-2 { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 8vw, 120px); }
@media (max-width: 880px) { .ns-redesign .cols-2 { grid-template-columns: 1fr; } }

/* ── Grain overlay ── */
body.ns-redesign.grain::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none; z-index: 99;
  opacity: 0.05;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.6'/></svg>");
}
[data-palette="dusk"] body.ns-redesign.grain::before { mix-blend-mode: screen; opacity: 0.08; }

/* ── FAQ section override (héritée du build précédent) ── */
.ns-redesign .faq-section { background: color-mix(in oklab, var(--paper) 70%, var(--bg-elev)); padding: clamp(80px, 10vw, 140px) 0; }
.ns-redesign .faq-section__intro { max-width: 720px; margin: 0 auto var(--space-12, 3rem); text-align: center; }
.ns-redesign .faq-section__title { font-family: var(--sans); font-weight: 700; color: var(--ink); }
.ns-redesign .faq-item { border-bottom: 1px solid color-mix(in oklab, var(--ink) 12%, transparent); }
.ns-redesign .faq-item__question { color: var(--ink); font-family: var(--sans); }
.ns-redesign .faq-item__question:hover { color: var(--accent); }
.ns-redesign .faq-item__answer { color: var(--ink-soft); }

/* ── Social proof override ── */
.ns-redesign .social-proof-section { background: linear-gradient(180deg, var(--paper) 0%, var(--bg) 100%); }
.ns-redesign .kpi-bar { background: var(--ink); }
.ns-redesign .kpi-bar__number { color: var(--accent-2); }
.ns-redesign .case-study { background: var(--cream); border: 1px solid var(--rule); }
.ns-redesign .case-study__col h4 { color: var(--accent); }

/* ──────────────────────────────────────────────────────────────────────
 * Pages internes (single, page, archive, search) — application maritime
 * ────────────────────────────────────────────────────────────────────── */

/* Padding top global pour laisser passer la nav flottante */
.ns-redesign:not(.home) #page { padding-top: 110px; }

/* Container WP standard → mêmes règles que .shell */
.ns-redesign .site .container,
.ns-redesign .site-main {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

/* Headings dans les contenus WP : Poppins partout, Instrument Serif pour les italiques */
.ns-redesign .entry-content h1,
.ns-redesign .entry-title,
.ns-redesign .page-title,
.ns-redesign .page-hero__title,
.ns-redesign .single-title {
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--ink);
  font-size: clamp(36px, 5vw, 72px);
  margin: 0 0 24px;
}
.ns-redesign .entry-content h2,
.ns-redesign h2.section-title {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(28px, 3.5vw, 48px);
  letter-spacing: -0.025em;
  line-height: 1.1;
  color: var(--ink);
  margin: 64px 0 20px;
}
.ns-redesign .entry-content h3 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(22px, 2.4vw, 30px);
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--ink);
  margin: 40px 0 16px;
}
.ns-redesign .entry-content h4 {
  font-family: var(--sans);
  font-weight: 600;
  font-size: clamp(18px, 1.6vw, 22px);
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 32px 0 12px;
}
.ns-redesign .entry-content em,
.ns-redesign .entry-content i,
.ns-redesign h2 em, .ns-redesign h1 em, .ns-redesign h3 em {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
}

/* Paragraphes corps de texte */
.ns-redesign .entry-content p,
.ns-redesign .page-content p,
.ns-redesign .single-content p {
  font-family: var(--sans);
  font-size: 16.5px;
  line-height: 1.75;
  color: var(--ink-soft);
  margin: 0 0 18px;
  max-width: 72ch;
}
.ns-redesign .entry-content strong { color: var(--ink); }
.ns-redesign .entry-content blockquote {
  border-left: 3px solid var(--accent);
  padding: 8px 0 8px 28px;
  margin: 32px 0;
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.5;
  color: var(--ink);
}
.ns-redesign .entry-content ul,
.ns-redesign .entry-content ol {
  font-size: 16.5px;
  line-height: 1.75;
  color: var(--ink-soft);
  margin: 0 0 24px;
  padding-left: 1.4em;
  max-width: 72ch;
}
.ns-redesign .entry-content li { margin-bottom: 8px; }
.ns-redesign .entry-content a {
  color: var(--accent);
  border-bottom: 1px solid color-mix(in oklab, var(--accent) 40%, transparent);
  transition: color .2s, border-color .2s;
}
.ns-redesign .entry-content a:hover {
  color: var(--ink);
  border-bottom-color: var(--ink);
}
.ns-redesign .entry-content img {
  border-radius: 8px;
  margin: 32px 0;
  box-shadow: 0 12px 40px -20px color-mix(in oklab, var(--ink) 25%, transparent);
}
.ns-redesign .entry-content code {
  background: color-mix(in oklab, var(--ink) 8%, transparent);
  padding: 2px 8px;
  border-radius: 4px;
  font-family: var(--mono);
  font-size: 13px;
}
.ns-redesign .entry-content pre {
  background: var(--ink);
  color: var(--cream);
  padding: 24px;
  border-radius: 8px;
  font-family: var(--mono);
  font-size: 13px;
  overflow-x: auto;
  margin: 32px 0;
}
.ns-redesign .entry-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 32px 0;
  font-size: 15px;
}
.ns-redesign .entry-content th,
.ns-redesign .entry-content td {
  text-align: left;
  padding: 12px 16px;
  border-bottom: 1px solid var(--rule);
}
.ns-redesign .entry-content th {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}

/* Page hero standard (page.php, archive.php) */
.ns-redesign .page-hero,
.ns-redesign .archive-header {
  padding: clamp(60px, 10vw, 140px) 0 clamp(40px, 6vw, 80px);
  position: relative;
}
.ns-redesign .page-hero h1,
.ns-redesign .archive-header h1 {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(40px, 7vw, 96px);
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--ink);
  margin: 0 0 24px;
  max-width: 18ch;
}
.ns-redesign .page-hero p,
.ns-redesign .archive-header p {
  font-family: var(--sans);
  font-size: 18px;
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 56ch;
}

/* Article cards (blog) — uniformiser au design maritime */
.ns-redesign .article-card,
.ns-redesign .post-card {
  background: var(--paper);
  border: 1px solid color-mix(in oklab, var(--ink) 8%, transparent);
  border-radius: 12px;
  overflow: hidden;
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s;
}
.ns-redesign .article-card:hover,
.ns-redesign .post-card:hover {
  transform: translateY(-4px);
  border-color: color-mix(in oklab, var(--accent-2) 30%, var(--rule));
  box-shadow: 0 18px 40px -22px color-mix(in oklab, var(--ink) 30%, transparent);
}
.ns-redesign .article-card h2,
.ns-redesign .article-card h3,
.ns-redesign .post-card h2 {
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: -0.02em;
}

/* Single post layout (single.php) */
.ns-redesign .single-post .entry-content {
  max-width: 760px;
  margin: 0 auto;
}
.ns-redesign .single-post .article-header {
  text-align: center;
  margin-bottom: 56px;
}
.ns-redesign .single-post .article-meta {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

/* Boutons WP existants alignés sur le maritime */
.ns-redesign .btn-primary,
.ns-redesign .btn.btn-primary {
  background: var(--accent) !important;
  color: var(--cream) !important;
  border-radius: 999px;
  padding: 14px 24px;
  font-family: var(--sans);
  font-weight: 500;
  font-size: 14px;
  border: none;
}
.ns-redesign .btn-primary:hover,
.ns-redesign .btn.btn-primary:hover {
  background: var(--ink) !important;
  transform: translateY(-2px);
}
.ns-redesign .btn-secondary,
.ns-redesign .btn.btn-secondary {
  background: var(--ink) !important;
  color: var(--cream) !important;
  border-radius: 999px;
  padding: 14px 24px;
}
.ns-redesign .btn-outline-dark,
.ns-redesign .btn.btn-outline-dark {
  background: transparent !important;
  color: var(--ink) !important;
  border: 1px solid var(--ink) !important;
  border-radius: 999px;
  padding: 13px 23px;
}
.ns-redesign .btn-outline-light,
.ns-redesign .btn.btn-outline-light {
  background: transparent !important;
  color: var(--cream) !important;
  border: 1px solid var(--cream) !important;
  border-radius: 999px;
}

/* Sections legacy (sombres) → palette maritime */
.ns-redesign .section-dark {
  background: var(--ink) !important;
  color: var(--cream) !important;
}
.ns-redesign .section-dark h1,
.ns-redesign .section-dark h2,
.ns-redesign .section-dark h3,
.ns-redesign .section-dark h4 { color: var(--cream) !important; }
.ns-redesign .section-dark p { color: color-mix(in oklab, var(--cream) 78%, transparent) !important; }

.ns-redesign .section-light { background: var(--paper) !important; }

/* HubSpot section legacy uniformisée */
.ns-redesign .hubspot-section {
  background: var(--ink) !important;
  color: var(--cream) !important;
}
.ns-redesign .hubspot-section__title {
  font-family: var(--sans);
  font-weight: 800;
  letter-spacing: -0.035em;
  color: var(--cream);
}

/* Top banner legacy : caché si nav maritime active */
.ns-redesign .top-banner { display: none !important; }
.ns-redesign #site-header { display: none !important; }
.ns-redesign #sticky-cta { display: none !important; }

/* Page templates : containers communs */
.ns-redesign .container { padding-left: var(--gutter); padding-right: var(--gutter); }

/* Forms WP par défaut */
.ns-redesign .form-input,
.ns-redesign .form-select,
.ns-redesign .form-textarea,
.ns-redesign input[type="text"],
.ns-redesign input[type="email"],
.ns-redesign input[type="tel"],
.ns-redesign input[type="search"],
.ns-redesign textarea,
.ns-redesign select {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 6px;
  padding: 12px 16px;
  font-family: var(--sans);
  font-size: 15px;
  color: var(--ink);
  width: 100%;
  transition: border-color .2s, box-shadow .2s;
}
.ns-redesign .form-input:focus,
.ns-redesign .form-select:focus,
.ns-redesign .form-textarea:focus,
.ns-redesign input:focus,
.ns-redesign textarea:focus,
.ns-redesign select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 20%, transparent);
}

/* Comments */
.ns-redesign .comments-area {
  margin-top: 64px;
  padding-top: 48px;
  border-top: 1px solid var(--rule);
}

/* Pagination */
.ns-redesign .pagination,
.ns-redesign .nav-links {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-top: 48px;
}
.ns-redesign .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border-radius: 999px;
  border: 1px solid var(--rule);
  font-family: var(--mono);
  font-size: 13px;
  color: var(--ink);
  transition: background .2s, color .2s, border-color .2s;
}
.ns-redesign .page-numbers:hover,
.ns-redesign .page-numbers.current {
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
}

/* Sidebar widgets */
.ns-redesign .widget {
  margin-bottom: 40px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--rule);
}
.ns-redesign .widget-title {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 16px;
}

/* 404 */
.ns-redesign .error-404 {
  text-align: center;
  padding: clamp(80px, 12vw, 200px) 0;
}
.ns-redesign .error-404 h1 {
  font-size: clamp(120px, 20vw, 280px);
  font-family: var(--serif);
  font-style: italic;
  color: var(--accent);
  line-height: 0.85;
  margin: 0;
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ FULL PASS DESIGN — overrides finaux (UX/UI/contrast)
 * ║ Ce bloc gagne en cascade ; toutes les déviations vs le prototype.
 * ╚════════════════════════════════════════════════════════════════════ */

/* ── HERO RESET ── */
/* Annule le padding shell par défaut sur le hero pour que vidéo prenne tout */
.ns-redesign .hero {
  min-height: 100vh;
  min-height: 100dvh;
  padding-top: 130px;
  padding-bottom: 60px;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: clamp(20px, 3vw, 40px);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

/* Vidéo de fond pleine largeur, centrée, bien visible */
.ns-redesign .hero-video-wrap {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  mask-image: none;
  -webkit-mask-image: none;
}
.ns-redesign .hero-video {
  position: absolute;
  top: 50%; left: 50%;
  min-width: 100%; min-height: 100%;
  width: auto; height: auto;
  transform: translate(-50%, -50%);
  object-fit: cover;
  opacity: 0;
  filter: saturate(0.7) contrast(1.04);
  mix-blend-mode: normal;
  transition: opacity 1.2s ease-in-out;
}
.ns-redesign .hero-video.is-loaded { opacity: 0.55; }
[data-palette="dusk"] .ns-redesign .hero-video.is-loaded { opacity: 0.7; }
[data-palette="seafoam"] .ns-redesign .hero-video.is-loaded { opacity: 0.5; }

/* Overlay : voile clair pour garder lisibilité texte sans tuer la vidéo */
.ns-redesign .hero-video-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(180deg,
      color-mix(in oklab, var(--paper) 25%, transparent) 0%,
      color-mix(in oklab, var(--paper) 55%, transparent) 70%,
      var(--paper) 100%),
    radial-gradient(ellipse 70% 60% at 30% 40%,
      color-mix(in oklab, var(--paper) 50%, transparent) 0%,
      transparent 60%);
}
[data-palette="dusk"] .ns-redesign .hero-video-overlay {
  background:
    linear-gradient(180deg,
      color-mix(in oklab, var(--bg) 30%, transparent) 0%,
      color-mix(in oklab, var(--bg) 70%, transparent) 80%,
      var(--bg) 100%);
}

/* Léopards normands en filigrane — calque entre vidéo et texte, à droite */
.ns-redesign .hero-leopards {
  position: absolute;
  right: clamp(-30px, -2vw, 60px);
  top: 50%;
  transform: translateY(-50%);
  width: clamp(220px, 32vw, 460px);
  height: auto;
  z-index: 2;
  opacity: 0.18;
  filter: saturate(0.8) contrast(1.1);
  pointer-events: none;
  mix-blend-mode: multiply;
  user-select: none;
}
[data-palette="dusk"] .ns-redesign .hero-leopards {
  opacity: 0.32;
  mix-blend-mode: screen;
  filter: saturate(1.2) brightness(1.1);
}
@media (max-width: 880px) {
  .ns-redesign .hero-leopards {
    right: 50%;
    transform: translate(50%, -50%);
    opacity: 0.10;
    width: 80vw;
  }
}

/* Sun désaturé pour ne pas tuer le texte */
.ns-redesign .hero-sun {
  width: 32vmin;
  height: 32vmin;
  right: 8vw;
  top: 18vh;
  opacity: 0.18;
  z-index: 2;
}

/* Photo fallback si pas de vidéo : plus discrète */
.ns-redesign .hero-photo {
  z-index: 1;
  opacity: 0.22;
}

/* Hero meta et headline au-dessus de tout */
.ns-redesign .hero-meta,
.ns-redesign .hero-headline,
.ns-redesign .hero-foot {
  position: relative;
  z-index: 4;
}

/* HEADLINE : taille drastiquement réduite pour que les 3 lignes tiennent */
.ns-redesign .hero-headline { margin: 0; max-width: 16ch; }
.ns-redesign .hero-headline h1 {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(36px, 5.8vw, 92px);
  line-height: 1.02;
  letter-spacing: -0.035em;
  color: var(--ink);
  text-shadow: 0 2px 14px color-mix(in oklab, var(--paper) 80%, transparent);
}
.ns-redesign .hero-headline em {
  background: linear-gradient(110deg, var(--accent) 10%, var(--accent-2) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-style: italic;
  font-family: var(--serif);
  font-weight: 400;
  -webkit-text-fill-color: transparent;
}
.ns-redesign .hero-headline .ornament {
  display: inline-block;
  vertical-align: middle;
  margin-left: 0.15em;
  width: 0.5em; height: 0.5em;
  background: radial-gradient(circle at 30% 30%, var(--accent-2), var(--accent));
  border-radius: 50%;
}
[data-palette="dusk"] .ns-redesign .hero-headline h1 {
  color: var(--ink);
  text-shadow: 0 2px 18px color-mix(in oklab, var(--bg) 80%, transparent);
}

/* Hero meta : un peu plus contrasté */
.ns-redesign .hero-meta {
  color: var(--ink);
  font-weight: 500;
  background: color-mix(in oklab, var(--paper) 65%, transparent);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  padding: 14px 22px;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--ink) 14%, transparent);
}
.ns-redesign .hero-meta .badge {
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
}

/* Hero foot fond glass pour lisibilité */
.ns-redesign .hero-foot {
  background: color-mix(in oklab, var(--paper) 85%, transparent);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  padding: 28px;
  border-radius: 14px;
  border: 1px solid color-mix(in oklab, var(--ink) 8%, transparent);
}
.ns-redesign .hero-foot p { color: var(--ink); font-weight: 400; }
.ns-redesign .hero-foot p strong { color: var(--ink); font-weight: 700; }

/* CTA accent : plus contrasté */
.ns-redesign .btn-accent {
  background: var(--accent) !important;
  color: var(--cream) !important;
  font-weight: 600;
  padding: 16px 28px;
  box-shadow: 0 16px 40px -16px color-mix(in oklab, var(--accent) 70%, transparent);
}
.ns-redesign .btn-accent:hover {
  background: var(--ink) !important;
  transform: translateY(-2px);
  box-shadow: 0 18px 44px -14px color-mix(in oklab, var(--ink) 65%, transparent);
}

/* ── NAV : menu WP propre, sur une ligne, items courts ── */
.ns-redesign .ns-nav {
  grid-template-columns: auto 1fr auto auto;
  gap: clamp(16px, 2vw, 32px);
  padding: 12px 18px 12px 22px;
  max-width: 1380px;
}
.ns-redesign .nav-brand { font-size: 16px; }
.ns-redesign .nav-brand img { display: none !important; } /* WP custom logo désactivé dans la pill */
.ns-redesign .nav-links {
  font-size: 13px;
  gap: clamp(14px, 1.6vw, 28px);
  flex-wrap: nowrap;
  white-space: nowrap;
  overflow: hidden;
  min-width: 0;
}
.ns-redesign .nav-links li { white-space: nowrap; }
.ns-redesign .nav-links a {
  white-space: nowrap;
  font-weight: 500;
  font-size: 13px;
  text-transform: none;
  letter-spacing: 0;
  padding: 4px 0;
}
@media (max-width: 1280px) { .ns-redesign .nav-links { font-size: 12.5px; gap: 18px; } }
@media (max-width: 1100px) { .ns-redesign .nav-links { gap: 14px; font-size: 12px; } }
@media (max-width: 980px)  { .ns-redesign .nav-links { display: none; } .ns-redesign .ns-nav { grid-template-columns: 1fr auto auto; } }
@media (max-width: 640px)  { .ns-redesign .nav-tel { display: none; } .ns-redesign .ns-nav { grid-template-columns: 1fr auto; padding: 10px 14px; } .ns-redesign .nav-cta { padding: 8px 14px; font-size: 12px; } }

/* Définitivement neutraliser le legacy header sur ALL contexte ns-redesign */
.ns-redesign #site-header,
.ns-redesign .top-banner,
.ns-redesign #sticky-cta,
.ns-redesign .hubspot-section { display: none !important; }

/* ── FAQ home — refonte au style /animateur-seminaire-normandie/ ── */
.ns-redesign #faq.faq-section {
  background: linear-gradient(180deg, var(--paper) 0%, color-mix(in oklab, var(--bg-elev) 60%, var(--paper)) 100%);
  padding: clamp(80px, 12vw, 160px) 0;
}
.ns-redesign #faq .faq-section__intro,
.ns-redesign #faq .faq-section__list {
  max-width: 880px;
  margin-inline: auto;
}
.ns-redesign #faq .faq-section__list { display: flex; flex-direction: column; gap: 14px; border-top: 0; }
.ns-redesign #faq .faq-item {
  background: var(--cream);
  border: 1px solid color-mix(in oklab, var(--ink) 8%, transparent);
  border-radius: 14px;
  margin: 0;
  padding: 0;
  overflow: hidden;
  transition: border-color .25s, box-shadow .25s;
}
.ns-redesign #faq .faq-item:hover { border-color: color-mix(in oklab, var(--accent) 30%, transparent); }
.ns-redesign #faq .faq-item[open] {
  border-color: var(--accent);
  box-shadow: 0 14px 36px -20px color-mix(in oklab, var(--accent) 35%, transparent);
}
.ns-redesign #faq .faq-item__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 26px;
  cursor: pointer;
  list-style: none;
  font-size: 16.5px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.4;
  transition: color .2s;
  font-family: var(--sans);
}
.ns-redesign #faq .faq-item__question::-webkit-details-marker,
.ns-redesign #faq .faq-item__question::marker { display: none; content: ''; }
.ns-redesign #faq .faq-item__question:hover { color: var(--accent); }
.ns-redesign #faq .faq-item__icon {
  flex-shrink: 0;
  width: 30px; height: 30px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1.5rem; font-weight: 300; line-height: 1;
  color: var(--accent);
  border: 0;
  transition: transform .25s ease;
}
.ns-redesign #faq .faq-item[open] .faq-item__icon { transform: rotate(45deg); }
.ns-redesign #faq .faq-item__answer {
  padding: 0 26px 24px;
  color: var(--ink-soft);
  font-size: 15.5px;
  line-height: 1.75;
}
.ns-redesign #faq .faq-item__answer p { margin: 0 0 10px; max-width: none; }
.ns-redesign #faq .faq-item__answer p:last-child { margin: 0; }
.ns-redesign #faq .faq-item__answer ul { margin: 8px 0 12px; padding-left: 20px; }
.ns-redesign #faq .faq-item__answer li { margin-bottom: 6px; color: var(--ink-soft); }
.ns-redesign #faq .faq-item__answer a {
  color: var(--accent);
  border-bottom: 1px solid color-mix(in oklab, var(--accent) 50%, transparent);
  font-weight: 500;
}
.ns-redesign #faq .faq-item__answer a:hover { color: var(--ink); border-color: var(--ink); }

/* ── BENTO contraste — texte clair sur fonds sombres ── */
.ns-redesign .bento .b1 { color: var(--cream); }
.ns-redesign .bento .b1 h3,
.ns-redesign .bento .b1 p,
.ns-redesign .bento .b1 .tag-mini { color: var(--cream); }
.ns-redesign .bento .b1 h3 { font-weight: 800; }
.ns-redesign .bento .b1 em.it { color: var(--accent-2) !important; -webkit-text-fill-color: var(--accent-2) !important; background: none !important; -webkit-background-clip: initial !important; background-clip: initial !important; }
.ns-redesign .bento .b1 p { opacity: 1; color: color-mix(in oklab, var(--cream) 88%, transparent); }

.ns-redesign .bento .b3 { color: var(--cream); }
.ns-redesign .bento .b3 h3,
.ns-redesign .bento .b3 p,
.ns-redesign .bento .b3 .tag-mini { color: var(--cream); }
.ns-redesign .bento .b3 em.it { color: var(--accent-2) !important; -webkit-text-fill-color: var(--accent-2) !important; }

.ns-redesign .bento .b4 { color: var(--ink); }
.ns-redesign .bento .b4 h3 em.it { color: var(--ink) !important; -webkit-text-fill-color: var(--ink) !important; background: none !important; }

.ns-redesign .bento .b5 { color: var(--cream); }
.ns-redesign .bento .b5 h3,
.ns-redesign .bento .b5 p,
.ns-redesign .bento .b5 .tag-mini { color: var(--cream); }
.ns-redesign .bento .b5 em.it { color: var(--accent-2) !important; -webkit-text-fill-color: var(--accent-2) !important; }

/* ── CARTE NORMANDIE : on remplace le SVG France pourri par une vraie image ── */
.ns-redesign .map-wrap {
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--paper) 80%, transparent) 0%, transparent 30%),
    url("https://images.unsplash.com/photo-1572226572041-6e9b08e5da95?auto=format&fit=crop&w=1600&q=80") center/cover no-repeat,
    var(--paper);
  border: 1px solid var(--rule);
  position: relative;
  overflow: hidden;
}
.ns-redesign .map-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 90% 90% at 50% 60%, transparent 30%, color-mix(in oklab, var(--paper) 70%, transparent) 100%);
  pointer-events: none;
  z-index: 1;
}
.ns-redesign .map-wrap > svg { display: none; } /* Plus de pseudo-France SVG */
.ns-redesign .map-pin { z-index: 2; }
.ns-redesign .map-pin .label {
  font-weight: 600;
  background: var(--ink);
  color: var(--cream);
}

/* ── CONTRAST PUSH global ── */
.ns-redesign .eyebrow { color: var(--accent); font-weight: 600; opacity: 1; }
.ns-redesign .eyebrow::before { background: var(--accent); width: 40px; height: 2px; }
.ns-redesign .display-l,
.ns-redesign .display-m,
.ns-redesign .display-s,
.ns-redesign h2.display-l,
.ns-redesign h2.display-m { color: var(--ink); }
.ns-redesign .manifesto-block { color: var(--ink); }
.ns-redesign .proc-step h3 { color: var(--ink); }
.ns-redesign .proc-step p { color: var(--ink-soft); font-weight: 400; }
.ns-redesign .stat .num { color: var(--ink); -webkit-text-fill-color: var(--ink); background: none; }
.ns-redesign .stat .num em { color: var(--accent); -webkit-text-fill-color: var(--accent); }
.ns-redesign .stat .lbl { color: var(--ink-soft); font-weight: 500; }
.ns-redesign .tag {
  background: var(--cream);
  border-color: color-mix(in oklab, var(--ink) 25%, transparent);
  color: var(--ink);
  font-weight: 500;
}
.ns-redesign .tag:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }

/* Footer plus dense + lisible */
.ns-redesign .ns-footer { color: var(--cream); }
.ns-redesign .ns-footer h5 { opacity: 0.7; color: color-mix(in oklab, var(--accent-2) 70%, var(--cream)); }
.ns-redesign .ns-footer ul a { color: color-mix(in oklab, var(--cream) 90%, transparent); }
.ns-redesign .ns-footer ul a:hover { color: var(--accent-2); }

/* Section preuves : cards plus contrastées */
.ns-redesign .further-card { border: 1px solid color-mix(in oklab, var(--ink) 12%, transparent); }
.ns-redesign .further-card h3 { color: var(--ink); }
.ns-redesign .further-card p { color: var(--ink-soft); font-weight: 400; }
.ns-redesign .further-card .kicker { color: var(--accent); font-weight: 600; }
.ns-redesign .further-card .arrow-link { color: var(--accent); border-color: var(--accent); }

/* Section prix : cards bien lisibles */
.ns-redesign #tarifs .further-card h3 {
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--ink);
}
.ns-redesign #tarifs .further-card[style*="background: var(--ink)"] h3 { color: var(--cream); }

/* Animations reveal — désactiver opacity:0 si JS ne charge pas */
.no-js .ns-redesign .reveal,
.no-js .ns-redesign .reveal-stagger > *,
.no-js .ns-redesign .reveal-mask,
.no-js .ns-redesign .reveal-scale,
.no-js .ns-redesign .reveal-left,
.no-js .ns-redesign .reveal-right { opacity: 1 !important; transform: none !important; }

/* ╔════════════════════════════════════════════════════════════════════
 * ║ EFFET SIGNATURE : vidéo masquée par les léopards normands
 * ╚════════════════════════════════════════════════════════════════════ */

.ns-redesign .hero-video-wrap--leopards {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
  /* Pas de masque sur le wrap, juste sur la vidéo elle-même */
}

.ns-redesign .hero-video-wrap--leopards .hero-video {
  position: absolute;
  /* Centré sur la moitié droite du hero — les léopards sont là */
  top: 50%;
  left: auto; right: 0;
  transform: translate(0, -50%);
  width: clamp(420px, 52vw, 880px);
  height: auto;
  min-width: 0; min-height: 0;
  max-width: none;
  max-height: 100vh;
  aspect-ratio: 1.6 / 1;
  object-fit: cover;
  /* MASK : la vidéo n'apparaît qu'à l'intérieur des léopards */
  -webkit-mask-image: url("../../images/svg/leopards-normandie.svg");
  mask-image: url("../../images/svg/leopards-normandie.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-mode: alpha;
  mask-mode: alpha;
  /* Plus dense : la vidéo dans les léopards est saturée et bien visible */
  opacity: 0;
  filter: saturate(1) contrast(1.05);
  mix-blend-mode: normal;
  transition: opacity 1.2s ease-in-out;
}
.ns-redesign .hero-video-wrap--leopards .hero-video.is-loaded { opacity: 1; }

/* Outline / contour des léopards en arrière, pour un fallback élégant si video pas chargée */
.ns-redesign .hero-video-wrap--leopards::before {
  content: "";
  position: absolute;
  top: 50%; right: 0;
  transform: translateY(-50%);
  width: clamp(420px, 52vw, 880px);
  aspect-ratio: 1.6 / 1;
  background-color: color-mix(in oklab, var(--accent) 14%, transparent);
  -webkit-mask-image: url("../../images/svg/leopards-normandie.svg");
  mask-image: url("../../images/svg/leopards-normandie.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  z-index: 0;
}

/* Plus de overlay couvrant tout le hero (sinon ça cache la vidéo dans les léopards) */
.ns-redesign .hero-video-wrap--leopards .hero-video-overlay { display: none; }

@media (max-width: 880px) {
  .ns-redesign .hero-video-wrap--leopards .hero-video,
  .ns-redesign .hero-video-wrap--leopards::before {
    width: 90vw;
    right: 5vw;
    top: 60%;
    opacity: 0.3;
  }
  .ns-redesign .hero-video-wrap--leopards .hero-video.is-loaded { opacity: 0.55; }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ NETTOYAGE FINAL : supprimer toute trace de WP custom logo dans la nav
 * ╚════════════════════════════════════════════════════════════════════ */
.ns-redesign .ns-nav .custom-logo,
.ns-redesign .ns-nav .custom-logo-link,
.ns-redesign .ns-nav img[class*="logo"] { display: none !important; }

/* Cacher TOUS les éléments legacy même par sécurité */
body.ns-redesign #site-header,
body.ns-redesign .top-banner,
body.ns-redesign #sticky-cta,
body.ns-redesign .site-branding,
body.ns-redesign .header-cta,
body.ns-redesign .header-phone,
body.ns-redesign #primary-navigation,
body.ns-redesign #mobile-navigation,
body.ns-redesign .mobile-menu-toggle { display: none !important; }

/* ╔════════════════════════════════════════════════════════════════════
 * ║ NAV MENU — fix final pour wp_nav_menu output
 * ║ Markup réel : <div class="nav-links"><ul id="ns-primary-menu"
 * ║                  class="ns-nav-menu menu"><li><a></a></li>...</ul></div>
 * ╚════════════════════════════════════════════════════════════════════ */

.ns-redesign .ns-nav { z-index: 110; }

/* Conteneur central : flex centré, full width entre brand et CTAs */
.ns-redesign .ns-nav .nav-links {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;          /* essentiel pour que le shrink marche dans grid */
  font-size: 13px;
}

/* Le UL injecté par WP */
.ns-redesign .ns-nav .nav-links > ul,
.ns-redesign .ns-nav .nav-links .ns-nav-menu,
.ns-redesign .ns-nav .nav-links .nav-menu {
  display: flex;
  align-items: center;
  gap: clamp(14px, 1.6vw, 28px);
  list-style: none;
  margin: 0;
  padding: 0;
  flex-wrap: nowrap;
  white-space: nowrap;
}

/* Items */
.ns-redesign .ns-nav .nav-links li {
  display: inline-flex;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
  white-space: nowrap;
  position: relative;
}

/* Liens */
.ns-redesign .ns-nav .nav-links a {
  display: inline-block;
  padding: 6px 0;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  text-decoration: none;
  color: var(--ink-soft);
  white-space: nowrap;
  position: relative;
  transition: color .2s;
}
.ns-redesign .ns-nav .nav-links a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  height: 1px; width: 0;
  background: var(--accent);
  transition: width .35s ease;
}
.ns-redesign .ns-nav .nav-links a:hover,
.ns-redesign .ns-nav .nav-links li.current-menu-item > a,
.ns-redesign .ns-nav .nav-links li.current-menu-ancestor > a { color: var(--ink); }
.ns-redesign .ns-nav .nav-links a:hover::after,
.ns-redesign .ns-nav .nav-links li.current-menu-item > a::after { width: 100%; }

/* Sous-menu (depth 2) */
.ns-redesign .ns-nav .nav-links .sub-menu,
.ns-redesign .ns-nav .nav-links ul.children {
  display: none;
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%);
  flex-direction: column;
  gap: 4px;
  min-width: 220px;
  padding: 12px;
  background: color-mix(in oklab, var(--paper) 92%, transparent);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  border-radius: 14px;
  box-shadow: 0 16px 50px -20px color-mix(in oklab, var(--ink) 35%, transparent);
  list-style: none;
  z-index: 200;
}
.ns-redesign .ns-nav .nav-links li.menu-item-has-children:hover > .sub-menu,
.ns-redesign .ns-nav .nav-links li.menu-item-has-children:focus-within > .sub-menu,
.ns-redesign .ns-nav .nav-links li:hover > ul.children { display: flex; }
.ns-redesign .ns-nav .nav-links .sub-menu li,
.ns-redesign .ns-nav .nav-links ul.children li { width: 100%; }
.ns-redesign .ns-nav .nav-links .sub-menu a,
.ns-redesign .ns-nav .nav-links ul.children a {
  width: 100%;
  padding: 8px 12px;
  border-radius: 6px;
}
.ns-redesign .ns-nav .nav-links .sub-menu a:hover {
  background: color-mix(in oklab, var(--accent-2) 14%, transparent);
}
.ns-redesign .ns-nav .nav-links .sub-menu a::after { display: none; }

/* Breakpoints — quand ça serre, shrink puis hide */
@media (max-width: 1300px) {
  .ns-redesign .ns-nav .nav-links a { font-size: 12.5px; }
  .ns-redesign .ns-nav .nav-links > ul { gap: 18px; }
}
@media (max-width: 1100px) {
  .ns-redesign .ns-nav .nav-links a { font-size: 12px; }
  .ns-redesign .ns-nav .nav-links > ul { gap: 14px; }
}
@media (max-width: 980px) {
  .ns-redesign .ns-nav .nav-links { display: none; }
  .ns-redesign .ns-nav { grid-template-columns: 1fr auto auto; }
}
@media (max-width: 640px) {
  .ns-redesign .ns-nav .nav-tel { display: none; }
  .ns-redesign .ns-nav { grid-template-columns: 1fr auto; padding: 10px 14px; }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ HOTFIX URGENT — taille hero, ornament, pastille logo
 * ╚════════════════════════════════════════════════════════════════════ */

/* Hero headline drastiquement réduit */
.ns-redesign .hero-headline h1 {
  font-size: clamp(34px, 4.6vw, 64px) !important;
  line-height: 1.04 !important;
  letter-spacing: -0.025em !important;
  font-weight: 800;
  max-width: 14ch;
}
.ns-redesign .hero-headline { max-width: 14ch; }
.ns-redesign .hero-headline .ornament { display: none !important; }

/* Hero sun calmé */
.ns-redesign .hero-sun {
  width: 24vmin !important;
  height: 24vmin !important;
  right: 6vw !important;
  top: 14vh !important;
  opacity: 0.10 !important;
  filter: blur(60px);
}

/* Hero photo désactivée si vidéo (évite double couche) */
.ns-redesign .hero:has(.hero-video-wrap) .hero-photo { display: none; }

/* TOUTE image dans .ns-nav est nukée (custom logo, menu image, etc.) */
.ns-redesign .ns-nav img,
.ns-redesign .ns-nav svg.custom-logo,
.ns-redesign .ns-nav .custom-logo-link,
.ns-redesign .ns-nav .menu-image,
.ns-redesign .ns-nav .wp-block-site-logo,
.ns-redesign .ns-nav [class*="logo"]:not(.nav-brand):not(.nav-cta),
.ns-redesign .ns-nav [class*="brand"]:not(.nav-brand) {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
}
/* Sauf l'icône SVG du CTA qu'on veut garder */
.ns-redesign .ns-nav .nav-cta svg { display: inline-block !important; visibility: visible !important; width: 12px !important; height: 12px !important; }
/* Burger : visible UNIQUEMENT sous 980px */
.ns-redesign .ns-nav .ns-burger { display: none; }
@media (max-width: 980px) {
  .ns-redesign .ns-nav .ns-burger { display: inline-flex !important; }
}

/* Padding container hero — moins d'air pour qu'il rentre */
.ns-redesign .hero {
  padding-top: 110px !important;
  padding-bottom: 50px !important;
  min-height: 92vh;
}

/* SplitText sécurité : si JS pas chargé, le texte s'affiche quand même */
.ns-redesign .split-text .word .inner { transform: translateY(0) !important; }
.ns-redesign .split-text:not(.in) .word { overflow: visible; }

/* Hero video bien lisible */
.ns-redesign .hero-video.is-loaded { opacity: 1 !important; }

/* La pastille du brand : pas de cercle cyan parasite */
.ns-redesign .nav-brand .dot {
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--accent) 22%, transparent) !important;
  outline: none !important;
}
.ns-redesign .nav-brand:focus,
.ns-redesign .nav-brand:focus-visible { outline: none !important; }

/* ── BURGER + DRAWER MOBILE ── */
.ns-redesign .ns-burger {
  display: none;
  flex-direction: column;
  gap: 4px;
  width: 38px; height: 38px;
  align-items: center; justify-content: center;
  background: transparent; border: 1px solid color-mix(in oklab, var(--ink) 18%, transparent);
  border-radius: 999px; cursor: pointer;
  transition: background .2s, border-color .2s;
}
.ns-redesign .ns-burger:hover { background: color-mix(in oklab, var(--ink) 8%, transparent); }
.ns-redesign .ns-burger span {
  display: block; width: 16px; height: 1.5px;
  background: var(--ink); border-radius: 2px;
  transition: transform .25s, opacity .25s;
}
@media (max-width: 980px) { .ns-redesign .ns-burger { display: inline-flex; } }
@media (min-width: 981px) { .ns-redesign .ns-burger { display: none !important; } }

.ns-redesign .ns-mobile-drawer {
  position: fixed; inset: 0; z-index: 200;
  background: var(--paper);
  transform: translateX(100%); transition: transform .35s cubic-bezier(.2,.7,.2,1);
  pointer-events: none; overflow-y: auto;
}
.ns-redesign .ns-mobile-drawer.is-open { transform: translateX(0); pointer-events: auto; }
.ns-redesign .ns-mobile-drawer__inner { padding: 24px; max-width: 480px; margin-left: auto; min-height: 100vh; display: flex; flex-direction: column; gap: 24px; }
.ns-redesign .ns-mobile-drawer__head { display: flex; justify-content: space-between; align-items: center; }
.ns-redesign .ns-mobile-close { font-size: 36px; line-height: 1; background: transparent; border: 0; cursor: pointer; color: var(--ink); padding: 4px 12px; }
.ns-redesign .ns-mobile-nav .ns-mobile-menu { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--rule); }
.ns-redesign .ns-mobile-nav .ns-mobile-menu li { border-bottom: 1px solid var(--rule); }
.ns-redesign .ns-mobile-nav .ns-mobile-menu a { display: block; padding: 18px 0; font-size: 18px; font-weight: 600; color: var(--ink); }
.ns-redesign .ns-mobile-nav .ns-mobile-menu a:hover { color: var(--accent); }
.ns-redesign .ns-mobile-nav .sub-menu { list-style: none; padding-left: 14px; margin: 0 0 12px; border-top: 1px solid var(--rule); }
.ns-redesign .ns-mobile-nav .sub-menu a { padding: 12px 0; font-size: 15px; font-weight: 500; color: var(--ink-soft); }
.ns-redesign .ns-mobile-drawer__cta { margin-top: auto; padding-top: 24px; border-top: 1px solid var(--rule); }
.ns-redesign .ns-mobile-tel { display: flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: 14px; color: var(--ink); padding: 12px 0; }
.ns-redesign .ns-mobile-tel:hover { color: var(--accent); }

body.ns-drawer-open { overflow: hidden; }

/* ╔════════════════════════════════════════════════════════════════════
 * ║ HERO VIDEO ROBUSTE — vidéo full-bleed + léopards overlay
 * ║ (override final — gagne sur tous les essais précédents)
 * ╚════════════════════════════════════════════════════════════════════ */

.ns-redesign .hero-video-wrap,
.ns-redesign .hero-video-wrap--leopards {
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
}
.ns-redesign .hero-video-wrap--leopards::before { display: none !important; }

.ns-redesign .hero-video {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  min-width: 100% !important;
  min-height: 100% !important;
  width: auto !important; height: auto !important;
  max-width: none !important; max-height: none !important;
  object-fit: cover !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
  mix-blend-mode: normal !important;
  opacity: 0;
  filter: saturate(0.85) contrast(1.05) brightness(0.96);
  transition: opacity 1s ease-in-out;
}
.ns-redesign .hero-video.is-loaded { opacity: 0.5; }
[data-palette="dusk"] .ns-redesign .hero-video.is-loaded { opacity: 0.65; }

/* Voile clair pour lisibilité texte */
.ns-redesign .hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(180deg,
      color-mix(in oklab, var(--paper) 35%, transparent) 0%,
      color-mix(in oklab, var(--paper) 60%, transparent) 60%,
      var(--paper) 100%),
    linear-gradient(90deg,
      color-mix(in oklab, var(--paper) 70%, transparent) 0%,
      transparent 45%,
      transparent 55%,
      color-mix(in oklab, var(--paper) 35%, transparent) 100%);
}
[data-palette="dusk"] .ns-redesign .hero::before {
  background:
    linear-gradient(180deg,
      color-mix(in oklab, var(--bg) 40%, transparent) 0%,
      color-mix(in oklab, var(--bg) 75%, transparent) 70%,
      var(--bg) 100%);
}

/* Léopards overlay : SVG transparent en image, mix-blend pour fondre */
.ns-redesign .hero::after {
  content: "";
  position: absolute;
  right: -4vw;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(360px, 50vw, 760px);
  aspect-ratio: 1.6 / 1;
  background-image: url("../../images/svg/leopards-normandie.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  opacity: 0.16;
  mix-blend-mode: multiply;
  pointer-events: none;
  z-index: 2;
  filter: contrast(1.1);
}
[data-palette="dusk"] .ns-redesign .hero::after { mix-blend-mode: screen; opacity: 0.25; }
@media (max-width: 880px) {
  .ns-redesign .hero::after { right: -10vw; width: 80vw; opacity: 0.10; }
}

/* Tout le contenu du hero au-dessus */
.ns-redesign .hero > .hero-meta,
.ns-redesign .hero > .hero-headline,
.ns-redesign .hero > .hero-foot,
.ns-redesign .hero > .hero-scroll { z-index: 3 !important; position: relative; }

/* Hero-sun désactivé (la vidéo + voile fait le job) */
.ns-redesign .hero-sun { display: none !important; }

/* ╔════════════════════════════════════════════════════════════════════
 * ║ HERO LAYOUT FINAL — meta, foot, scroll cue
 * ╚════════════════════════════════════════════════════════════════════ */

/* Meta unifiée en pill discrète */
.ns-redesign .hero-meta {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  font-size: 11.5px;
  font-family: var(--mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
  padding: 12px 22px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--paper) 80%, transparent);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid color-mix(in oklab, var(--ink) 12%, transparent);
  width: fit-content;
  align-self: flex-start;
  font-weight: 500;
}
.ns-redesign .hero-meta__sep { opacity: 0.35; }
.ns-redesign .hero-meta .badge {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em;
  padding: 4px 10px; border-radius: 999px;
  background: var(--ink); color: var(--cream);
  border: 0;
}
.ns-redesign .hero-meta .pulse { display: inline-flex; align-items: center; gap: 8px; color: var(--accent); font-weight: 600; }
.ns-redesign .hero-meta .pulse::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent); animation: pulse 1.8s infinite;
}

/* Hero foot : grid 3 colonnes (intro / cta / stat) */
.ns-redesign .hero-foot {
  display: grid;
  grid-template-columns: 1.4fr 1fr 0.8fr;
  gap: clamp(20px, 3vw, 48px);
  align-items: end;
  padding: 28px 32px;
  border-radius: 16px;
  background: color-mix(in oklab, var(--paper) 90%, transparent);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  backdrop-filter: blur(16px) saturate(140%);
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  position: relative;
  z-index: 3;
}
.ns-redesign .hero-foot__intro p {
  color: var(--ink);
  font-size: 15px;
  line-height: 1.55;
  margin: 0;
  max-width: 42ch;
  font-weight: 400;
}
.ns-redesign .hero-foot__intro strong { color: var(--ink); font-weight: 700; }
.ns-redesign .hero-foot__intro em { color: var(--accent); font-style: italic; font-family: var(--serif); font-weight: 400; -webkit-text-fill-color: var(--accent); background: none; }
.ns-redesign .hero-foot__cta { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; }
.ns-redesign .hero-foot__note {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  text-transform: uppercase;
}
.ns-redesign .hero-foot__stat { display: flex; flex-direction: column; align-items: flex-end; text-align: right; gap: 6px; }
.ns-redesign .hero-foot__stat-num {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--accent);
}
.ns-redesign .hero-foot__stat-num sup {
  font-size: 0.5em;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  margin-left: 0.05em;
  vertical-align: super;
}
.ns-redesign .hero-foot__stat-label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  line-height: 1.4;
}
@media (max-width: 880px) {
  .ns-redesign .hero-foot { grid-template-columns: 1fr; padding: 22px; gap: 18px; }
  .ns-redesign .hero-foot__stat { align-items: flex-start; text-align: left; }
}

/* Scroll cue, en bas du hero, centré */
.ns-redesign .hero-scroll {
  position: absolute;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  z-index: 4;
  text-decoration: none;
  transition: color .2s, transform .2s;
}
.ns-redesign .hero-scroll:hover { color: var(--accent); transform: translateX(-50%) translateY(2px); }
.ns-redesign .hero-scroll svg { animation: scrollBounce 2s ease-in-out infinite; }
@keyframes scrollBounce {
  0%, 100% { transform: translateY(0); opacity: 0.6; }
  50%      { transform: translateY(4px); opacity: 1; }
}
@media (max-width: 880px) { .ns-redesign .hero-scroll { display: none; } }

/* Plus de pulse animation à la fin du fichier */
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 color-mix(in oklab, var(--accent) 60%, transparent); }
  70%  { box-shadow: 0 0 0 12px color-mix(in oklab, var(--accent) 0%, transparent); }
  100% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--accent) 0%, transparent); }
}

/* Eyebrows simplifiés */
.ns-redesign .eyebrow {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  opacity: 1;
}
.ns-redesign .eyebrow::before {
  content: ""; display: inline-block;
  width: 32px; height: 2px;
  background: var(--accent);
  border-radius: 2px;
}

/* Bento card 5 — chiffre 72% propre */
.ns-redesign .bento .b5 {
  background: var(--accent-3);
  color: var(--cream);
}
.ns-redesign .bento .b5 h3,
.ns-redesign .bento .b5 p,
.ns-redesign .bento .b5 .tag-mini { color: var(--cream); }

/* ╔════════════════════════════════════════════════════════════════════
 * ║ RESET D'URGENCE — fix layout hero + nav cassée
 * ║ (override final, gagne sur tous les essais précédents)
 * ╚════════════════════════════════════════════════════════════════════ */

/* HERO HEADLINE : laisser flow naturel — virer le max-width: 14ch toxique */
.ns-redesign .hero-headline {
  max-width: none !important;
  width: 100%;
  margin: 0;
}
.ns-redesign .hero-headline h1 {
  font-size: clamp(36px, 5vw, 76px) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.025em !important;
  font-weight: 800;
  max-width: 18ch;     /* plus permissif : permet 4-5 mots par ligne */
  color: var(--ink);
}
.ns-redesign .hero-headline .row {
  display: block;
  white-space: normal;
}

/* SplitText : autoriser le wrap dans le mot lui-même → pas de mots géants qui débordent */
.ns-redesign .split-text { display: inline; white-space: normal; }
.ns-redesign .split-text .word { display: inline-block; overflow: visible; padding: 0; vertical-align: baseline; }
.ns-redesign .split-text .word .inner { transform: none !important; transition: none; }

/* NAV : burger STRICTEMENT mobile-only */
@media (min-width: 981px) {
  .ns-redesign .ns-burger { display: none !important; }
}

/* La nav pill : grid 4 colonnes, items dedans */
.ns-redesign .ns-nav {
  display: grid !important;
  grid-template-columns: auto 1fr auto auto !important;
  align-items: center;
  gap: clamp(20px, 2.5vw, 32px);
  padding: 12px 18px 12px 22px !important;
  max-width: 1380px;
}
.ns-redesign .ns-nav .nav-links {
  flex: 1 1 auto;
  min-width: 0;
  justify-content: center;
}
.ns-redesign .ns-nav .nav-links > ul,
.ns-redesign .ns-nav .nav-links .ns-nav-menu {
  display: flex !important;
  flex-wrap: nowrap !important;
  white-space: nowrap !important;
  margin: 0; padding: 0;
}

/* Léopards : MOINS dominants, derrière le texte */
.ns-redesign .hero::after {
  width: clamp(280px, 38vw, 580px) !important;
  right: -3vw !important;
  opacity: 0.10 !important;
  filter: contrast(1) !important;
}
@media (max-width: 880px) {
  .ns-redesign .hero::after { opacity: 0.07 !important; }
}

/* Hero-meta visible et propre */
.ns-redesign .hero-meta {
  opacity: 1;
  visibility: visible;
  transform: none;
  display: inline-flex !important;
  align-self: flex-start;
}

/* Hero foot : ne JAMAIS dépasser la moitié de l'écran (laisser place aux léopards) */
.ns-redesign .hero-foot {
  max-width: 980px;
}
.ns-redesign .hero {
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  gap: clamp(20px, 3vw, 36px) !important;
  padding-top: 110px !important;
  padding-bottom: 70px !important;
  min-height: 88vh;
}

/* Le scroll cue plus discret */
.ns-redesign .hero-scroll {
  bottom: 16px;
  font-size: 9px;
  opacity: 0.5;
}
.ns-redesign .hero-scroll svg { width: 12px; height: 18px; }

/* Custom logo WP : on garde mort */
.ns-redesign .ns-nav .nav-brand .custom-logo,
.ns-redesign .ns-nav .nav-brand img {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important; height: 0 !important;
}

/* Suppression cyan ring sur dot brand */
.ns-redesign .nav-brand,
.ns-redesign .nav-brand:focus,
.ns-redesign .nav-brand:focus-visible,
.ns-redesign .nav-brand:active {
  outline: none !important;
  box-shadow: none !important;
}
.ns-redesign .nav-brand .dot {
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 22%, transparent) !important;
  outline: 0 !important;
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ FIX VIDÉO HERO — la vidéo doit être PLEINEMENT visible
 * ╚════════════════════════════════════════════════════════════════════ */

/* Vidéo bien visible dès le départ, fade-in léger */
.ns-redesign .hero-video {
  opacity: 0.85 !important;
  filter: saturate(0.95) contrast(1.02) !important;
  mix-blend-mode: normal !important;
  transition: opacity .8s ease-in-out;
}
.ns-redesign .hero-video.is-loaded { opacity: 1 !important; }

/* Voile très léger juste pour garder lisibilité texte sur le côté gauche */
.ns-redesign .hero::before {
  background:
    linear-gradient(90deg,
      color-mix(in oklab, var(--paper) 70%, transparent) 0%,
      color-mix(in oklab, var(--paper) 35%, transparent) 50%,
      color-mix(in oklab, var(--paper) 18%, transparent) 100%),
    linear-gradient(180deg,
      transparent 0%,
      transparent 70%,
      color-mix(in oklab, var(--paper) 50%, transparent) 100%) !important;
  z-index: 1 !important;
}
[data-palette="dusk"] .ns-redesign .hero::before {
  background:
    linear-gradient(90deg,
      color-mix(in oklab, var(--bg) 75%, transparent) 0%,
      color-mix(in oklab, var(--bg) 30%, transparent) 60%,
      transparent 100%) !important;
}

/* Léopards : très subtils pour ne pas voler la vedette à la vidéo */
.ns-redesign .hero::after {
  opacity: 0.08 !important;
  z-index: 2 !important;
}

/* La vidéo et son wrapper toujours derrière les overlays */
.ns-redesign .hero-video-wrap,
.ns-redesign .hero-video-wrap--leopards {
  z-index: 0 !important;
}
.ns-redesign .hero-video {
  z-index: 0 !important;
}

/* Hero foot fond plus opaque pour rester lisible sur la vidéo */
.ns-redesign .hero-foot {
  background: color-mix(in oklab, var(--paper) 95%, transparent) !important;
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  backdrop-filter: blur(20px) saturate(140%);
}
.ns-redesign .hero-meta {
  background: color-mix(in oklab, var(--paper) 92%, transparent) !important;
}

/* Empêcher tout `display: none` sur la vidéo */
.ns-redesign .hero-video,
.ns-redesign .hero-video-wrap,
.ns-redesign .hero-video-wrap--leopards {
  display: block !important;
  visibility: visible !important;
}

/* Si le JS n'ajoute pas .is-loaded à temps, la vidéo s'affiche quand même */
.no-js .ns-redesign .hero-video,
.ns-redesign .hero-video:not(.is-loaded) { opacity: 0.85 !important; }

/* ╔════════════════════════════════════════════════════════════════════
 * ║ TARIFS — 5 cards sur une ligne en desktop
 * ╚════════════════════════════════════════════════════════════════════ */

.ns-redesign .pricing-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
  max-width: 100%;
  width: 100%;
}
@media (max-width: 1280px) { .ns-redesign .pricing-grid { grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 12px; } }
@media (max-width: 1100px) { .ns-redesign .pricing-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 760px)  { .ns-redesign .pricing-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 520px)  { .ns-redesign .pricing-grid { grid-template-columns: 1fr; } }

.ns-redesign .pricing-grid .further-card {
  padding: 24px 20px 22px;
  min-height: 0;
  border-radius: 14px;
  gap: 10px;
}
.ns-redesign .pricing-grid .further-card h3 {
  font-size: clamp(20px, 1.7vw, 26px) !important;
  letter-spacing: -0.025em;
  white-space: nowrap;
  font-weight: 800;
}
.ns-redesign .pricing-grid .further-card p {
  font-size: 13.5px;
  line-height: 1.5;
}
.ns-redesign .pricing-grid .further-card .kicker {
  font-size: 9.5px;
  letter-spacing: 0.16em;
}
.ns-redesign .pricing-grid .further-card .arrow-link {
  font-size: 9.5px;
  letter-spacing: 0.14em;
  border-color: color-mix(in oklab, currentColor 30%, transparent);
}
@media (max-width: 1280px) {
  .ns-redesign .pricing-grid .further-card h3 { font-size: clamp(20px, 1.6vw, 24px) !important; }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ FAQ HOME — toggle "+" / "−" (au lieu de "+" qui rotate en ×)
 * ╚════════════════════════════════════════════════════════════════════ */

.ns-redesign #faq .faq-item__question::after {
  content: "+";
  flex-shrink: 0;
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--sans);
  font-size: 22px;
  font-weight: 300;
  line-height: 1;
  color: var(--accent);
  border-radius: 999px;
  transition: background .2s, color .2s;
  margin-left: 16px;
}
.ns-redesign #faq .faq-item[open] .faq-item__question::after {
  content: "−"; /* moins typographique, pas un - tiret */
  background: var(--accent);
  color: var(--cream);
  transform: none;
}
.ns-redesign #faq .faq-item__question:hover::after {
  background: color-mix(in oklab, var(--accent) 15%, transparent);
}
.ns-redesign #faq .faq-item[open] .faq-item__question:hover::after {
  background: var(--ink);
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ FORCE FINAL : VIDEO VISIBLE — strip TOUT ce qui peut la cacher
 * ║ Override absolu, gagne sur tout le reste.
 * ╚════════════════════════════════════════════════════════════════════ */

body.ns-redesign .hero-video,
body.ns-redesign .hero-video.is-loaded {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  filter: none !important;
  mix-blend-mode: normal !important;
  -webkit-mask: none !important;
  mask: none !important;
  z-index: 0 !important;
}
body.ns-redesign .hero-video-wrap,
body.ns-redesign .hero-video-wrap--leopards {
  display: block !important;
  visibility: visible !important;
  position: absolute !important;
  inset: 0 !important;
  overflow: hidden !important;
  z-index: 0 !important;
  -webkit-mask: none !important;
  mask: none !important;
  background-color: var(--bg-elev);
}
body.ns-redesign .hero-video-wrap--leopards::before { display: none !important; }

/* Voile très léger : plus du tout opaque en bas */
body.ns-redesign .hero::before {
  background:
    linear-gradient(90deg,
      color-mix(in oklab, var(--paper) 80%, transparent) 0%,
      color-mix(in oklab, var(--paper) 35%, transparent) 45%,
      transparent 80%) !important;
  z-index: 1 !important;
  pointer-events: none;
}

/* Léopards super discrets */
body.ns-redesign .hero::after {
  opacity: 0.06 !important;
  width: clamp(220px, 30vw, 460px) !important;
  z-index: 2 !important;
  pointer-events: none;
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ FORMULAIRE 3 CHAMPS + CALENDLY — style propre
 * ╚════════════════════════════════════════════════════════════════════ */

.ns-redesign .contact-options {
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
}

.ns-redesign .contact-calendly-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 28px 32px;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  color: var(--cream);
  border-radius: 16px;
  text-decoration: none;
  transition: transform .3s, box-shadow .3s;
  position: relative;
  overflow: hidden;
}
.ns-redesign .contact-calendly-card::before {
  content: "";
  position: absolute;
  top: -40%; right: -20%;
  width: 60%; height: 200%;
  background: radial-gradient(ellipse, color-mix(in oklab, var(--cream) 30%, transparent), transparent 65%);
  pointer-events: none;
}
.ns-redesign .contact-calendly-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 24px 50px -20px color-mix(in oklab, var(--accent) 65%, transparent);
}
.ns-redesign .contact-calendly-card__kicker {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--cream) 85%, transparent);
}
.ns-redesign .contact-calendly-card h3 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--cream);
  margin: 4px 0 0;
}
.ns-redesign .contact-calendly-card p {
  font-size: 14.5px;
  line-height: 1.55;
  color: color-mix(in oklab, var(--cream) 88%, transparent);
  margin: 0;
}
.ns-redesign .contact-calendly-card .btn {
  background: var(--ink) !important;
  color: var(--cream) !important;
  align-self: flex-start;
  margin-top: 6px;
}

.ns-redesign .contact-options__or {
  position: relative;
  text-align: center;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 8px 0;
}
.ns-redesign .contact-options__or span {
  background: var(--cream);
  padding: 0 14px;
  position: relative;
  z-index: 1;
}
.ns-redesign .contact-options__or::before {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 50%;
  height: 1px;
  background: var(--rule);
  z-index: 0;
}

/* Form card propre */
.ns-redesign .form-card {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 16px;
  padding: clamp(24px, 3vw, 40px);
  box-shadow: 0 14px 40px -22px color-mix(in oklab, var(--ink) 22%, transparent);
}
.ns-redesign .form-card .field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 18px;
}
.ns-redesign .form-card label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}
.ns-redesign .form-card input,
.ns-redesign .form-card textarea,
.ns-redesign .form-card select {
  background: transparent;
  border: 0;
  border-bottom: 1.5px solid var(--rule);
  padding: 12px 0;
  font-family: var(--sans);
  font-size: 16px;
  color: var(--ink);
  outline: none;
  transition: border-color .25s;
  border-radius: 0;
}
.ns-redesign .form-card input:focus,
.ns-redesign .form-card textarea:focus,
.ns-redesign .form-card select:focus {
  border-bottom-color: var(--accent);
}
.ns-redesign .form-card input::placeholder,
.ns-redesign .form-card textarea::placeholder {
  color: color-mix(in oklab, var(--ink) 30%, transparent);
}

.ns-redesign .form-extra {
  margin: 8px 0 16px;
  border-top: 1px solid var(--rule);
  padding-top: 14px;
}
.ns-redesign .form-extra > summary {
  cursor: pointer;
  list-style: none;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
}
.ns-redesign .form-extra > summary::-webkit-details-marker { display: none; }
.ns-redesign .form-extra[open] > summary span { transform: rotate(45deg); }
.ns-redesign .form-extra > summary span {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px;
  border: 1px solid currentColor;
  border-radius: 50%;
  font-size: 14px;
  transition: transform .2s;
}
.ns-redesign .form-extra .fields-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 16px;
}
@media (max-width: 700px) {
  .ns-redesign .form-extra .fields-grid { grid-template-columns: 1fr; }
}

/* Contact row override : laisser le flex naturel */
.ns-redesign .contact-row {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(32px, 5vw, 60px);
}
@media (max-width: 880px) {
  .ns-redesign .contact-row { grid-template-columns: 1fr; }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ BLOG MAGAZINE — style éditorial haut de gamme
 * ╚════════════════════════════════════════════════════════════════════ */

.ns-redesign .ns-blog-magazine { background: var(--paper); }

/* Masthead */
.ns-redesign .mag-masthead {
  padding: clamp(80px, 10vw, 160px) 0 clamp(40px, 6vw, 80px);
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
}
.ns-redesign .mag-masthead__inner { max-width: 980px; }
.ns-redesign .mag-masthead__edition {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  display: inline-block;
  margin-bottom: 24px;
}
.ns-redesign .mag-masthead__title {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(52px, 8vw, 120px);
  line-height: 0.95;
  letter-spacing: -0.04em;
  color: var(--ink);
  margin: 0 0 32px;
}
.ns-redesign .mag-masthead__title em {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  background: linear-gradient(110deg, var(--accent) 10%, var(--accent-2) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.ns-redesign .mag-masthead__lead {
  font-family: var(--sans);
  font-size: clamp(16px, 1.4vw, 19px);
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 56ch;
  margin: 0 0 24px;
}
.ns-redesign .mag-masthead__meta {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 12px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
.ns-redesign .mag-masthead__sep { opacity: 0.4; }

/* Hero article */
.ns-redesign .mag-hero {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 0;
  background: var(--cream);
  border-bottom: 1px solid var(--rule);
  margin-bottom: 0;
}
@media (max-width: 980px) { .ns-redesign .mag-hero { grid-template-columns: 1fr; } }
.ns-redesign .mag-hero__media {
  display: block;
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
}
.ns-redesign .mag-hero__img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  margin: 0 !important;
  border-radius: 0 !important;
  transition: transform .8s ease;
  display: block;
}
.ns-redesign .mag-hero__img--placeholder {
  background:
    radial-gradient(ellipse at 30% 20%, color-mix(in oklab, var(--accent-2) 20%, transparent), transparent 60%),
    repeating-linear-gradient(135deg, var(--bg-elev) 0 16px, color-mix(in oklab, var(--ink) 6%, var(--bg-elev)) 16px 17px);
}
.ns-redesign .mag-hero__media:hover .mag-hero__img { transform: scale(1.04); }
.ns-redesign .mag-hero__content {
  padding: clamp(40px, 5vw, 80px) clamp(32px, 4vw, 64px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 24px;
}
.ns-redesign .mag-hero__cat {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.ns-redesign .mag-hero__cat a {
  color: var(--accent);
  font-weight: 600;
}
.ns-redesign .mag-hero__cat a:hover { color: var(--ink); }
.ns-redesign .mag-hero__date { color: var(--muted); }
.ns-redesign .mag-hero__title {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(28px, 3.5vw, 48px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin: 0;
}
.ns-redesign .mag-hero__title a { color: var(--ink); border: 0; }
.ns-redesign .mag-hero__title a:hover { color: var(--accent); }
.ns-redesign .mag-hero__excerpt {
  font-family: var(--sans);
  font-size: clamp(15px, 1.2vw, 17px);
  line-height: 1.65;
  color: var(--ink-soft);
  margin: 0;
}
.ns-redesign .mag-hero__meta {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 10px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.ns-redesign .mag-hero__sep { opacity: 0.4; }
.ns-redesign .mag-hero__cta { align-self: flex-start; margin-top: 8px; }

/* Section heads */
.ns-redesign .mag-section-head {
  margin: clamp(60px, 8vw, 100px) 0 clamp(28px, 4vw, 48px);
}
.ns-redesign .mag-section-head--with-filters {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 32px;
  flex-wrap: wrap;
}
.ns-redesign .mag-section-title {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(28px, 3.5vw, 44px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin: 8px 0 0;
  color: var(--ink);
}

/* Featured 3-up */
.ns-redesign .mag-featured__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 2vw, 28px);
  padding-bottom: clamp(40px, 5vw, 80px);
  border-bottom: 1px solid var(--rule);
}
@media (max-width: 880px) { .ns-redesign .mag-featured__grid { grid-template-columns: 1fr; } }
.ns-redesign .mag-featured__card { display: flex; flex-direction: column; gap: 16px; }
.ns-redesign .mag-featured__media {
  display: block;
  aspect-ratio: 4/3;
  overflow: hidden;
  border-radius: 6px;
}
.ns-redesign .mag-featured__img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  margin: 0 !important;
  border-radius: 0 !important;
  display: block;
  transition: transform .6s ease;
}
.ns-redesign .mag-featured__img--placeholder {
  background:
    radial-gradient(ellipse at 50% 80%, color-mix(in oklab, var(--accent) 16%, transparent), transparent 60%),
    repeating-linear-gradient(135deg, var(--bg-elev) 0 13px, color-mix(in oklab, var(--ink) 6%, var(--bg-elev)) 13px 14px);
}
.ns-redesign .mag-featured__media:hover .mag-featured__img { transform: scale(1.05); }
.ns-redesign .mag-featured__body { padding: 0 4px; }
.ns-redesign .mag-featured__cat {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  margin-bottom: 10px;
}
.ns-redesign .mag-featured__title {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(20px, 1.8vw, 26px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
}
.ns-redesign .mag-featured__title a { color: var(--ink); border: 0; }
.ns-redesign .mag-featured__title a:hover { color: var(--accent); }
.ns-redesign .mag-featured__meta {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
.ns-redesign .mag-featured__sep { margin: 0 6px; opacity: 0.4; }

/* Filtres */
.ns-redesign .mag-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.ns-redesign .mag-filter {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  background: transparent;
  border: 1px solid var(--rule);
  border-radius: 999px;
  font-weight: 500;
  transition: all .25s;
}
.ns-redesign .mag-filter:hover { border-color: var(--ink); color: var(--ink); }
.ns-redesign .mag-filter.is-active { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.ns-redesign .mag-filter__count {
  font-size: 9.5px;
  opacity: 0.6;
  font-weight: 400;
}

/* Grille principale + sidebar */
.ns-redesign .mag-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: clamp(40px, 5vw, 72px);
  padding-bottom: clamp(80px, 10vw, 160px);
}
@media (max-width: 1100px) { .ns-redesign .mag-grid { grid-template-columns: 1fr; } }

.ns-redesign .mag-grid__main {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 3vw, 48px) clamp(16px, 2vw, 28px);
  align-content: start;
}
@media (max-width: 760px) { .ns-redesign .mag-grid__main { grid-template-columns: 1fr; } }

.ns-redesign .mag-card { display: flex; flex-direction: column; gap: 14px; }
.ns-redesign .mag-card__media { display: block; aspect-ratio: 16/10; overflow: hidden; border-radius: 4px; }
.ns-redesign .mag-card__img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  margin: 0 !important;
  border-radius: 0 !important;
  display: block;
  transition: transform .6s ease;
}
.ns-redesign .mag-card__img--placeholder {
  background:
    radial-gradient(ellipse at 60% 40%, color-mix(in oklab, var(--accent-2) 14%, transparent), transparent 60%),
    repeating-linear-gradient(135deg, var(--bg-elev) 0 11px, color-mix(in oklab, var(--ink) 5%, var(--bg-elev)) 11px 12px);
}
.ns-redesign .mag-card__media:hover .mag-card__img { transform: scale(1.05); }
.ns-redesign .mag-card__cat {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  margin-bottom: 8px;
}
.ns-redesign .mag-card__title {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.25;
  letter-spacing: -0.015em;
  margin: 0 0 10px;
}
.ns-redesign .mag-card__title a { color: var(--ink); border: 0; }
.ns-redesign .mag-card__title a:hover { color: var(--accent); }
.ns-redesign .mag-card__excerpt {
  font-family: var(--sans);
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 12px;
}
.ns-redesign .mag-card__meta {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ns-redesign .mag-card__sep { opacity: 0.4; }

.ns-redesign .mag-grid__empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 80px 20px;
  color: var(--ink-soft);
  font-size: 16px;
}

/* Pagination */
.ns-redesign .mag-pagination {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid var(--rule);
  justify-content: center;
}
.ns-redesign .mag-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid var(--rule);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  color: var(--ink);
  text-decoration: none;
  background: transparent;
  transition: all .2s;
}
.ns-redesign .mag-pagination .page-numbers:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.ns-redesign .mag-pagination .page-numbers.current {
  background: var(--accent);
  color: var(--cream);
  border-color: var(--accent);
}

/* Sidebar */
.ns-redesign .mag-sidebar {
  position: sticky;
  top: 110px;
  align-self: start;
  display: flex;
  flex-direction: column;
  gap: 28px;
}
@media (max-width: 1100px) { .ns-redesign .mag-sidebar { position: static; } }

.ns-redesign .mag-sidebar__block {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 12px;
  padding: 24px;
}
.ns-redesign .mag-sidebar__block h4 {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0 0 12px;
  font-weight: 600;
}
.ns-redesign .mag-sidebar__block p {
  font-family: var(--sans);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0 0 14px;
  max-width: none;
}

/* Author card */
.ns-redesign .mag-author { text-align: center; }
.ns-redesign .mag-author__avatar {
  width: 96px;
  height: 96px;
  margin: 0 auto 16px;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid var(--cream);
  box-shadow: 0 8px 24px -10px color-mix(in oklab, var(--ink) 30%, transparent);
}
.ns-redesign .mag-author__avatar img { width: 100%; height: 100%; object-fit: cover; margin: 0; border-radius: 50%; box-shadow: none; }
.ns-redesign .mag-author__name {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 18px;
  color: var(--ink);
  margin: 0 0 8px !important;
}
.ns-redesign .mag-author__bio {
  font-size: 14px !important;
  color: var(--ink-soft);
  margin-bottom: 12px !important;
}

/* Newsletter */
.ns-redesign .mag-newsletter__form { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; }
.ns-redesign .mag-newsletter__form input[type="email"] {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--rule);
  border-radius: 8px;
  font-family: var(--sans);
  font-size: 14px;
  background: var(--paper);
  color: var(--ink);
}
.ns-redesign .mag-newsletter__form input[type="email"]:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent);
}
.ns-redesign .mag-newsletter__form .btn { width: 100%; justify-content: center; padding: 12px; font-size: 13px; }

/* Pillar links */
.ns-redesign .mag-pillars ul { list-style: none; padding: 0; margin: 0; max-width: none; }
.ns-redesign .mag-pillars li { padding: 10px 0; border-bottom: 1px solid var(--rule); }
.ns-redesign .mag-pillars li:last-child { border-bottom: 0; }
.ns-redesign .mag-pillars li a {
  display: block;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--ink);
  text-decoration: none;
  border: 0;
  font-weight: 500;
  transition: color .2s;
}
.ns-redesign .mag-pillars li a:hover { color: var(--accent); }

/* Sidebar CTA */
.ns-redesign .mag-sidebar-cta {
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
}
.ns-redesign .mag-sidebar-cta__kicker {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-2);
  margin-bottom: 10px;
  font-weight: 600;
}
.ns-redesign .mag-sidebar-cta h4 {
  font-family: var(--sans);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  text-transform: none;
  color: var(--cream);
  margin: 0 0 8px;
}
.ns-redesign .mag-sidebar-cta p { color: color-mix(in oklab, var(--cream) 80%, transparent); margin-bottom: 16px; }
.ns-redesign .mag-sidebar-cta .btn { width: 100%; justify-content: center; }

/* ╔════════════════════════════════════════════════════════════════════
 * ║ QUIZ NORMANDIE — fun & drôle, 5 questions
 * ╚════════════════════════════════════════════════════════════════════ */

.ns-redesign .ns-quiz {
  background: linear-gradient(180deg, var(--paper) 0%, var(--bg-elev) 100%);
  border-radius: 0;
}
.ns-redesign .ns-quiz__intro { max-width: 720px; margin: 0 auto clamp(32px, 5vw, 56px); text-align: center; }
.ns-redesign .ns-quiz__intro .eyebrow { justify-content: center; }
.ns-redesign .ns-quiz__intro h2 { margin: 16px 0 12px; }
.ns-redesign .ns-quiz__intro h2 em.it { font-family: var(--serif); font-style: italic; font-weight: 400; background: linear-gradient(110deg, var(--accent), var(--accent-2)); -webkit-background-clip: text; background-clip: text; color: transparent; -webkit-text-fill-color: transparent; }
.ns-redesign .ns-quiz__lead { color: var(--ink-soft); font-size: 16px; line-height: 1.6; margin: 0; }

.ns-redesign .ns-quiz__panel {
  max-width: 760px;
  margin: 0 auto;
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 20px;
  padding: clamp(24px, 4vw, 48px);
  box-shadow: 0 24px 60px -30px color-mix(in oklab, var(--ink) 30%, transparent);
}

.ns-redesign .ns-quiz__progress {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 24px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}
.ns-redesign .ns-quiz__progress-bar {
  display: block;
  flex: 1;
  height: 3px;
  background: var(--accent);
  border-radius: 999px;
  transition: width .5s cubic-bezier(.2,.7,.2,1);
  position: relative;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
}
.ns-redesign .ns-quiz__progress-bar::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--rule);
  border-radius: 999px;
  z-index: -1;
  width: calc(100% / var(--quiz-progress, 1));
}
.ns-redesign .ns-quiz__progress-text strong { color: var(--accent); font-weight: 700; }

.ns-redesign .ns-quiz__list { list-style: none; margin: 0; padding: 0; }
.ns-redesign .ns-quiz__q { display: none; }
.ns-redesign .ns-quiz__q.is-active { display: block; animation: quizFadeIn .4s ease-out; }
@keyframes quizFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: none; }
}

.ns-redesign .ns-quiz__q h3 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.3;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0 0 24px;
}
.ns-redesign .ns-quiz__q h3 em.it {
  font-family: var(--serif);
  font-style: italic;
  color: var(--accent);
  font-weight: 400;
}

.ns-redesign .ns-quiz__choices {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 18px;
}
.ns-redesign .ns-quiz__choice {
  text-align: left;
  padding: 16px 20px;
  background: var(--paper);
  border: 1.5px solid var(--rule);
  border-radius: 12px;
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.45;
  color: var(--ink);
  cursor: pointer;
  transition: all .2s;
  position: relative;
}
.ns-redesign .ns-quiz__choice:hover:not([disabled]) {
  border-color: var(--ink);
  background: var(--cream);
  transform: translateY(-1px);
}
.ns-redesign .ns-quiz__choice.is-correct {
  border-color: #2D9970;
  background: color-mix(in oklab, #2D9970 12%, var(--cream));
  color: var(--ink);
}
.ns-redesign .ns-quiz__choice.is-correct::after {
  content: "✓";
  position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  color: #2D9970; font-weight: 700;
}
.ns-redesign .ns-quiz__choice.is-wrong {
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 12%, var(--cream));
  opacity: 0.7;
}
.ns-redesign .ns-quiz__choice.is-wrong::after {
  content: "✗";
  position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  color: var(--accent); font-weight: 700;
}
.ns-redesign .ns-quiz__choice[disabled] { cursor: default; }

.ns-redesign .ns-quiz__feedback {
  display: none;
  padding: 16px 20px;
  background: color-mix(in oklab, var(--accent-2) 14%, var(--cream));
  border-left: 3px solid var(--accent);
  border-radius: 0 8px 8px 0;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink);
  margin-top: 8px;
  animation: quizFadeIn .3s ease-out;
}
.ns-redesign .ns-quiz__q.is-answered .ns-quiz__feedback { display: block; }
.ns-redesign .ns-quiz__feedback p { margin: 0; max-width: none; }
.ns-redesign .ns-quiz__feedback strong { color: var(--accent); }

/* Résultat final */
.ns-redesign .ns-quiz__result { display: none; text-align: center; padding: 12px 0; }
.ns-redesign .ns-quiz__result.is-shown { display: block; animation: quizFadeIn .5s ease-out; }
.ns-redesign .ns-quiz__score {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  margin-bottom: 18px;
}
.ns-redesign .ns-quiz__score-num {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(56px, 8vw, 96px);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--accent);
}
.ns-redesign .ns-quiz__score-total {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(28px, 4vw, 40px);
  color: var(--ink-soft);
}
.ns-redesign .ns-quiz__result h3 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(22px, 2.4vw, 32px);
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0 0 12px;
}
.ns-redesign .ns-quiz__result p {
  color: var(--ink-soft);
  font-size: 16px;
  line-height: 1.6;
  margin: 0 auto 28px;
  max-width: 48ch;
}
.ns-redesign .ns-quiz__cta {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.ns-redesign .ns-quiz__restart {
  background: transparent;
  border: 0;
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  cursor: pointer;
  padding: 6px;
  transition: color .2s;
}
.ns-redesign .ns-quiz__restart:hover { color: var(--accent); }

/* (bloc retiré : hero demi-cadre — remplacé par le bloc final FULL-BLEED en bas du fichier) */

/* ╔════════════════════════════════════════════════════════════════════
 * ║ ARTICLE SINGLE — style "Le Carnet" (port 1:1 prototype)
 * ╚════════════════════════════════════════════════════════════════════ */

/* Reading progress bar (top viewport) */
.ns-redesign .article-reading-progress {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: transparent;
  z-index: 200;
  pointer-events: none;
}
.ns-redesign .article-reading-progress > div {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  transform: scaleX(0);
  transform-origin: left;
  will-change: transform;
}

/* Cat pills */
.ns-redesign .cat-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 12px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, var(--ink) 18%, transparent);
  background: color-mix(in oklab, var(--paper) 60%, transparent);
  color: var(--ink);
  width: max-content;
}
.ns-redesign .cat-pill::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
}
.ns-redesign .cat-pill[data-cat="methode"]::before,
.ns-redesign .cat-pill[data-cat="methodes"]::before { background: var(--accent-2); }
.ns-redesign .cat-pill[data-cat="cas"]::before,
.ns-redesign .cat-pill[data-cat="cas-etude"]::before,
.ns-redesign .cat-pill[data-cat="cas-d-etude"]::before { background: var(--accent-3); }
.ns-redesign .cat-pill[data-cat="lieux"]::before,
.ns-redesign .cat-pill[data-cat="lieu"]::before { background: oklch(0.65 0.13 150); }
.ns-redesign .cat-pill[data-cat="format"]::before,
.ns-redesign .cat-pill[data-cat="formats"]::before { background: var(--accent); }
.ns-redesign .cat-pill[data-cat="tribune"]::before { background: oklch(0.55 0.18 25); }

/* dotsep utilitaire */
.ns-redesign .dotsep { color: var(--muted); opacity: 0.5; }

/* Article head */
.ns-redesign .article-head {
  padding-top: clamp(140px, 16vw, 220px);
  padding-bottom: clamp(40px, 5vw, 80px);
  background: var(--paper);
}
.ns-redesign .article-meta-top {
  display: inline-flex; align-items: center; gap: 12px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.ns-redesign .article-meta-top .mono {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--muted);
}
.ns-redesign .article-title {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(40px, 7vw, 110px);
  line-height: 0.94;
  letter-spacing: -0.04em;
  margin: 0 0 32px;
  max-width: 22ch;
  text-wrap: pretty;
  color: var(--ink);
}
.ns-redesign .article-title em,
.ns-redesign .article-title em.it {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  background: linear-gradient(110deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.ns-redesign .article-deck {
  font-family: var(--serif);
  font-size: clamp(20px, 2.2vw, 30px);
  line-height: 1.35;
  letter-spacing: -0.01em;
  color: var(--ink-soft);
  max-width: 56ch;
  margin: 0 0 56px;
  font-style: italic;
}
.ns-redesign .article-deck em.it {
  font-style: italic;
  background: linear-gradient(110deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

/* Byline */
.ns-redesign .article-byline {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 20px;
  align-items: center;
  padding: 22px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.ns-redesign .byline-photo {
  width: 56px; height: 56px;
  border-radius: 50%;
  background-size: cover; background-position: center;
  border: 2px solid var(--paper);
  box-shadow: 0 0 0 1px var(--rule);
}
.ns-redesign .byline-text { display: flex; flex-direction: column; gap: 2px; }
.ns-redesign .byline-by {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--muted);
}
.ns-redesign .byline-name {
  font-family: var(--serif); font-style: italic;
  font-size: 22px; letter-spacing: -0.005em;
  color: var(--ink);
}
.ns-redesign .byline-name em.it { font-style: italic; }
.ns-redesign .byline-role {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--muted);
}
.ns-redesign .article-share { display: flex; gap: 8px; }
.ns-redesign .article-share button {
  padding: 9px 14px;
  background: transparent;
  border: 1px solid var(--rule);
  border-radius: 999px;
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink);
  cursor: pointer;
  transition: background .25s, border-color .25s, color .25s;
}
.ns-redesign .article-share button:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.ns-redesign .article-share button.is-saved { background: var(--accent); color: var(--cream); border-color: var(--accent); }
@media (max-width: 720px) {
  .ns-redesign .article-byline { grid-template-columns: auto 1fr; }
  .ns-redesign .article-share { grid-column: 1 / -1; flex-wrap: wrap; }
}

/* Hero image */
.ns-redesign .article-hero-img {
  margin: 0 var(--gutter) clamp(40px, 5vw, 70px);
}
.ns-redesign .hero-photo-large {
  aspect-ratio: 21 / 9;
  background-size: cover;
  background-position: center;
  border-radius: 24px;
  border: 1px solid var(--rule);
}
.ns-redesign .hero-photo-caption {
  display: flex; gap: 14px;
  margin-top: 14px;
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--muted);
}
.ns-redesign .hero-photo-caption .mono { color: var(--accent-2); }

/* Body grid */
.ns-redesign .article-body {
  padding-bottom: clamp(60px, 8vw, 120px);
}
.ns-redesign .article-grid {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr) 1fr;
  gap: 60px;
}
@media (max-width: 1100px) {
  .ns-redesign .article-grid { grid-template-columns: 1fr; }
  .ns-redesign .article-toc { display: none; }
}

/* TOC */
.ns-redesign .article-toc { position: relative; }
.ns-redesign .toc-sticky {
  position: sticky; top: 130px;
  display: flex; flex-direction: column; gap: 18px;
}
.ns-redesign .toc-sticky .eyebrow { color: var(--accent); }
.ns-redesign .toc-sticky ol {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 4px;
  border-left: 1px solid var(--rule);
}
.ns-redesign .toc-sticky ol li { margin: 0; }
.ns-redesign .toc-sticky ol li a {
  display: block;
  padding: 8px 0 8px 16px;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-soft);
  text-decoration: none;
  transition: color .25s, padding .25s, border-color .25s;
  border-left: 2px solid transparent;
  margin-left: -1px;
  border-bottom: 0;
}
.ns-redesign .toc-sticky ol li a:hover,
.ns-redesign .toc-sticky ol li a.is-active {
  color: var(--accent);
  padding-left: 22px;
  border-left-color: var(--accent);
}
.ns-redesign .toc-progress {
  display: flex; align-items: center; gap: 12px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--rule);
}
.ns-redesign .toc-progress > div {
  flex: 1; height: 4px;
  background: color-mix(in oklab, var(--ink) 8%, transparent);
  border-radius: 999px;
  overflow: hidden;
  position: relative;
}
.ns-redesign .toc-bar {
  position: absolute; inset: 0;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  border-radius: 999px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .15s;
}
.ns-redesign .toc-progress .mono {
  font-family: var(--mono); font-size: 9.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--muted);
}

/* Prose */
.ns-redesign .article-prose {
  grid-column: 2 / -1;
  font-family: "Instrument Serif", Georgia, serif;
  font-size: 19.5px;
  line-height: 1.65;
  color: var(--ink);
  max-width: 70ch;
}
@media (max-width: 1100px) {
  .ns-redesign .article-prose { grid-column: 1 / -1; max-width: 70ch; margin: 0 auto; }
}
.ns-redesign .article-prose p { margin: 0 0 1.4em; max-width: none; color: var(--ink); }
.ns-redesign .article-prose strong { font-weight: 600; color: var(--ink); }
.ns-redesign .article-prose em { font-style: italic; }
.ns-redesign .article-prose a {
  color: var(--accent);
  border-bottom: 1px solid color-mix(in oklab, var(--accent) 50%, transparent);
}
.ns-redesign .article-prose a:hover { color: var(--ink); border-bottom-color: var(--ink); }
.ns-redesign .article-prose h2 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(24px, 2.8vw, 38px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  margin: 1.6em 0 0.6em;
  color: var(--ink);
  text-wrap: balance;
  scroll-margin-top: 130px;
}
.ns-redesign .article-prose h2::before {
  content: "";
  display: block;
  width: 48px; height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  margin-bottom: 16px;
  border-radius: 2px;
}
.ns-redesign .article-prose h3 {
  font-family: var(--sans);
  font-weight: 600;
  font-size: clamp(20px, 2.2vw, 26px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 1.4em 0 0.5em;
  color: var(--ink);
}
.ns-redesign .article-prose ul,
.ns-redesign .article-prose ol {
  margin: 0 0 1.4em;
  padding-left: 1.4em;
  font-family: "Instrument Serif", Georgia, serif;
  font-size: 19.5px;
  line-height: 1.65;
}
.ns-redesign .article-prose li { margin-bottom: 0.6em; }

/* Lead + dropcap */
.ns-redesign .article-lead {
  font-size: clamp(20px, 1.6vw, 24px) !important;
  line-height: 1.5;
  color: var(--ink-soft);
  margin-bottom: 1.5em;
}
.ns-redesign .article-lead .dropcap {
  float: left;
  font-family: var(--serif);
  font-size: 84px;
  line-height: 0.8;
  font-style: italic;
  font-weight: 400;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  padding: 4px 12px 0 0;
}

/* Pullquote */
.ns-redesign .article-prose blockquote,
.ns-redesign .article-pullquote {
  margin: 2em 0;
  padding: 0 0 0 32px;
  border-left: 2px solid;
  border-image: linear-gradient(180deg, var(--accent), var(--accent-2)) 1;
  position: relative;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(22px, 2.2vw, 30px);
  line-height: 1.3;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.ns-redesign .article-pullquote .pq-mark {
  position: absolute;
  top: -20px; left: -8px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 80px;
  line-height: 0.8;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  opacity: 0.4;
}
.ns-redesign .article-pullquote blockquote {
  margin: 0; padding: 0; border: 0;
  background: transparent;
  font-size: inherit;
}

/* Article list (ordered with serif numbers) */
.ns-redesign .article-prose ol.article-list {
  padding-left: 0;
  counter-reset: art;
  list-style: none;
  margin: 1.4em 0;
}
.ns-redesign .article-prose ol.article-list li {
  counter-increment: art;
  padding-left: 60px;
  position: relative;
  margin-bottom: 1.4em;
}
.ns-redesign .article-prose ol.article-list li::before {
  content: counter(art, decimal-leading-zero);
  position: absolute;
  left: 0; top: -4px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 36px;
  line-height: 1;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  letter-spacing: -0.02em;
}

/* Signoff */
.ns-redesign .article-signoff {
  text-align: center;
  font-family: var(--serif) !important;
  font-size: 24px !important;
  color: var(--accent);
  letter-spacing: 0.4em;
  margin: 3em 0 !important;
}

/* CTA in-article */
.ns-redesign .article-cta {
  margin-top: 3em;
  padding: 32px;
  background: color-mix(in oklab, var(--paper) 70%, transparent);
  border: 1px solid var(--rule);
  border-radius: 20px;
  display: flex; flex-direction: column; gap: 12px;
  align-items: flex-start;
  font-family: var(--sans);
  font-size: 16px;
}
.ns-redesign .article-cta .cta-note {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--muted);
}

/* Related */
.ns-redesign .related {
  padding-top: clamp(60px, 8vw, 100px);
  padding-bottom: clamp(60px, 8vw, 100px);
  border-top: 1px solid var(--rule);
}
.ns-redesign .related-head { margin-bottom: 40px; }
.ns-redesign .related-head .eyebrow { color: var(--accent); justify-content: flex-start; }
.ns-redesign .related-head h2 { margin-top: 8px; }
.ns-redesign .related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
@media (max-width: 880px) { .ns-redesign .related-grid { grid-template-columns: 1fr; } }

.ns-redesign .art-card {
  display: flex; flex-direction: column; gap: 16px;
  text-decoration: none;
  color: inherit;
  transition: transform .35s ease;
}
.ns-redesign .art-card:hover { transform: translateY(-3px); }
.ns-redesign .art-img {
  aspect-ratio: 4 / 3;
  background-size: cover;
  background-position: center;
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  border: 1px solid var(--rule);
}
.ns-redesign .art-img-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(14,31,44,0.18) 100%);
  opacity: 0;
  transition: opacity .35s;
}
.ns-redesign .art-card:hover .art-img-overlay { opacity: 1; }
.ns-redesign .art-body {
  display: flex; flex-direction: column; gap: 12px;
}
.ns-redesign .art-card h3 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(20px, 1.8vw, 24px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--ink);
  text-wrap: pretty;
}
.ns-redesign .art-card:hover h3 { color: var(--accent); }
.ns-redesign .meta-row {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--muted);
}
.ns-redesign .meta-row .dotsep { opacity: 0.4; }

/* Newsletter inline (article + blog) */
.ns-redesign .newsletter {
  padding: clamp(60px, 8vw, 120px) var(--gutter);
  margin: clamp(40px, 6vw, 80px) 0 0;
  position: relative;
  overflow: hidden;
}
.ns-redesign .newsletter::before {
  content: "";
  position: absolute; inset: 0 var(--gutter);
  background:
    radial-gradient(ellipse at 80% 50%, color-mix(in oklab, var(--accent-2) 22%, transparent), transparent 60%),
    color-mix(in oklab, var(--ink) 96%, transparent);
  border-radius: 32px;
  pointer-events: none;
  z-index: 0;
}
.ns-redesign .nl-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 80px;
  align-items: center;
  padding: clamp(40px, 5vw, 70px);
  color: var(--cream);
  position: relative;
  z-index: 1;
}
.ns-redesign .nl-grid .eyebrow { color: color-mix(in oklab, var(--cream) 70%, transparent); }
.ns-redesign .nl-grid .eyebrow::before { background: var(--accent-2); }
.ns-redesign .nl-grid h2 {
  font-family: var(--sans); font-weight: 800;
  font-size: clamp(36px, 4.5vw, 64px);
  line-height: 1; letter-spacing: -0.035em;
  color: var(--cream);
  margin: 18px 0 24px;
}
.ns-redesign .nl-grid h2 em.it {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  background: linear-gradient(110deg, var(--accent-2), var(--accent));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.ns-redesign .nl-grid p {
  font-size: 16px; line-height: 1.55;
  color: color-mix(in oklab, var(--cream) 78%, transparent);
  max-width: 48ch;
}
.ns-redesign .nl-form {
  display: flex; flex-direction: column; gap: 14px;
  background: color-mix(in oklab, var(--cream) 8%, transparent);
  border: 1px solid color-mix(in oklab, var(--cream) 14%, transparent);
  padding: 28px;
  border-radius: 20px;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
.ns-redesign .nl-field { display: flex; flex-direction: column; gap: 6px; }
.ns-redesign .nl-field label {
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: color-mix(in oklab, var(--cream) 60%, transparent);
}
.ns-redesign .nl-field input {
  background: transparent;
  border: 0;
  border-bottom: 1px solid color-mix(in oklab, var(--cream) 25%, transparent);
  border-radius: 0;
  padding: 10px 0;
  font-family: var(--serif);
  font-size: 22px;
  color: var(--cream);
  outline: none;
}
.ns-redesign .nl-field input::placeholder { color: color-mix(in oklab, var(--cream) 30%, transparent); }
.ns-redesign .nl-field input:focus { border-bottom-color: var(--accent-2); box-shadow: none; }
.ns-redesign .nl-form .btn { margin-top: 6px; align-self: flex-start; }
.ns-redesign .nl-rgpd {
  margin-top: 8px;
  font-family: var(--mono); font-size: 10.5px;
  letter-spacing: 0.1em;
  color: color-mix(in oklab, var(--cream) 50%, transparent);
}
.ns-redesign .nl-rgpd a { border-bottom: 1px solid currentColor; color: var(--accent-2); }
@media (max-width: 880px) {
  .ns-redesign .nl-grid { grid-template-columns: 1fr; gap: 32px; padding: 32px; }
}

/* Padding-top body article (sous nav flottante) */
.ns-redesign.single #page,
.ns-redesign.single-post #page { padding-top: 0 !important; }

/* ╔════════════════════════════════════════════════════════════════════
 * ║ HERO FINAL — vidéo full-bleed floutée + léopards bien visibles
 * ║ Dernier override (gagne sur tout)
 * ╚════════════════════════════════════════════════════════════════════ */

/* HERO : retire la padding pour que le bg fasse FULL BLEED */
body.ns-redesign .hero,
body.ns-redesign header.hero {
  padding: 0 !important;
  position: relative !important;
  overflow: hidden !important;
  min-height: 92vh;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  background: var(--paper);
  isolation: isolate;
}

/* Le contenu (meta/headline/foot/scroll) reçoit la padding interne */
body.ns-redesign .hero > .hero-meta,
body.ns-redesign .hero > .hero-headline,
body.ns-redesign .hero > .hero-foot {
  position: relative !important;
  z-index: 4 !important;
  margin-left: var(--gutter);
  margin-right: var(--gutter);
}
body.ns-redesign .hero > .hero-meta { margin-top: 130px; }
body.ns-redesign .hero > .hero-foot { margin-bottom: 60px; }
body.ns-redesign .hero > .hero-headline {
  margin-top: clamp(20px, 3vw, 40px);
  margin-bottom: clamp(20px, 3vw, 40px);
}

/* VIDEO : FULL BLEED — touche tous les bords */
body.ns-redesign .hero-video-wrap,
body.ns-redesign .hero-video-wrap--leopards {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  z-index: 0 !important;
  overflow: hidden !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
  background: var(--paper);
}
body.ns-redesign .hero-video-wrap--leopards::before { display: none !important; }

body.ns-redesign .hero-video {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  min-width: 100% !important;
  min-height: 100% !important;
  width: auto !important;
  height: auto !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  /* FLOU 10px → on voit l'ambiance pas les visages */
  filter: blur(10px) saturate(0.9) contrast(1) brightness(0.98) !important;
  /* ALPHA 50% comme demandé */
  opacity: 0.5 !important;
  mix-blend-mode: normal !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
  z-index: 0 !important;
  /* Évite que le blur crée un halo aux bords */
  will-change: transform;
  transform-origin: center;
  scale: 1.05; /* compense le blur qui rétrécit visuellement */
}
body.ns-redesign .hero-video.is-loaded { opacity: 0.5 !important; }

/* Voile latéral léger pour lisibilité du texte (gauche) */
body.ns-redesign .hero::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg,
      color-mix(in oklab, var(--paper) 70%, transparent) 0%,
      color-mix(in oklab, var(--paper) 35%, transparent) 50%,
      color-mix(in oklab, var(--paper) 15%, transparent) 100%),
    linear-gradient(180deg,
      color-mix(in oklab, var(--paper) 25%, transparent) 0%,
      transparent 30%,
      transparent 75%,
      color-mix(in oklab, var(--paper) 60%, transparent) 100%) !important;
}

/* LÉOPARDS — bien visibles à droite */
body.ns-redesign .hero::after {
  content: "" !important;
  position: absolute !important;
  top: 50% !important;
  right: -2vw !important;
  transform: translateY(-50%) !important;
  width: clamp(420px, 55vw, 920px) !important;
  height: 70% !important;
  background-image: url("../../images/svg/leopards-normandie.svg") !important;
  background-repeat: no-repeat !important;
  background-position: center right !important;
  background-size: contain !important;
  /* Bien visibles (50% comme demandé) */
  opacity: 0.55 !important;
  /* Blend mode multiply rend l'or des léopards (couleur du SVG) plus chaud sur fond crème */
  mix-blend-mode: multiply !important;
  pointer-events: none !important;
  z-index: 2 !important;
  filter: contrast(1.15) saturate(1.1) drop-shadow(0 4px 24px rgba(199, 83, 39, 0.18));
}
[data-palette="dusk"] body.ns-redesign .hero::after {
  mix-blend-mode: screen !important;
  opacity: 0.7 !important;
}

@media (max-width: 980px) {
  body.ns-redesign .hero::after {
    right: -10vw !important;
    width: 95vw !important;
    opacity: 0.30 !important;
  }
  body.ns-redesign .hero > .hero-meta { margin-top: 110px; }
}

/* Photo fallback si pas de vidéo */
body.ns-redesign .hero:has(.hero-video-wrap) .hero-photo,
body.ns-redesign .hero:has(.hero-video) .hero-photo { display: none !important; }
body.ns-redesign .hero-photo {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background-size: cover !important;
  background-position: center !important;
  filter: blur(10px) saturate(0.9);
  opacity: 0.5;
  z-index: 0;
  margin: 0;
  border-radius: 0;
  mask: none !important;
  -webkit-mask: none !important;
}

/* Sun OFF (les léopards font le focus visuel) */
body.ns-redesign .hero-sun { display: none !important; }

/* Scroll cue plus discret */
body.ns-redesign .hero-scroll {
  position: absolute !important;
  bottom: 18px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  z-index: 4 !important;
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ RESPONSIVE PASS COMPLET — mobile, tablet, desktop
 * ║ Override final — gagne sur tout. Tap targets ≥ 44px.
 * ╚════════════════════════════════════════════════════════════════════ */

/* ─── NAV : grid avec slot burger ─── */

/* Desktop ≥1200px : brand | links | tel | cta (burger hidden) */
@media (min-width: 1201px) {
  body.ns-redesign .ns-nav {
    grid-template-columns: auto minmax(0, 1fr) auto auto !important;
  }
  body.ns-redesign .ns-burger { display: none !important; }
}

/* Laptop 981-1200px : same but smaller */
@media (min-width: 981px) and (max-width: 1200px) {
  body.ns-redesign .ns-nav {
    grid-template-columns: auto minmax(0, 1fr) auto auto !important;
    padding: 10px 16px 10px 18px !important;
  }
  body.ns-redesign .nav-brand { font-size: 14px; }
  body.ns-redesign .ns-nav .nav-links a { font-size: 12px; }
  body.ns-redesign .ns-nav .nav-links > ul { gap: 14px !important; }
  body.ns-redesign .ns-burger { display: none !important; }
}

/* Tablet 641-980px : brand | (links hidden) | tel | cta | burger */
@media (max-width: 980px) and (min-width: 641px) {
  body.ns-redesign .ns-nav {
    grid-template-columns: auto auto auto auto !important;
    justify-content: space-between !important;
    gap: 12px !important;
    padding: 10px 14px !important;
    width: calc(100% - 32px);
  }
  body.ns-redesign .ns-nav .nav-links { display: none !important; }
  body.ns-redesign .ns-burger {
    display: inline-flex !important;
    width: 42px; height: 42px;
  }
  body.ns-redesign .nav-brand { font-size: 14px; }
  body.ns-redesign .nav-tel { padding-left: 12px !important; font-size: 11px; }
  body.ns-redesign .nav-cta { padding: 8px 14px !important; font-size: 12px !important; }
}

/* Mobile ≤640px : brand | burger only */
@media (max-width: 640px) {
  body.ns-redesign .ns-nav {
    top: 12px;
    width: calc(100% - 24px);
    grid-template-columns: 1fr auto !important;
    gap: 10px !important;
    padding: 8px 12px 8px 18px !important;
  }
  body.ns-redesign .ns-nav .nav-links,
  body.ns-redesign .ns-nav .nav-tel,
  body.ns-redesign .ns-nav .nav-cta { display: none !important; }
  body.ns-redesign .ns-burger {
    display: inline-flex !important;
    width: 44px; height: 44px;
    border: 1.5px solid color-mix(in oklab, var(--ink) 25%, transparent);
  }
  body.ns-redesign .nav-brand { font-size: 13.5px; gap: 8px; }
  body.ns-redesign .nav-brand .dot { width: 8px; height: 8px; }
}

/* Burger lines : taille tap target */
body.ns-redesign .ns-burger { cursor: pointer; touch-action: manipulation; }
body.ns-redesign .ns-burger span {
  width: 18px;
  height: 2px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform .25s, opacity .25s;
}

/* Drawer mobile — propre et plein écran */
body.ns-redesign .ns-mobile-drawer {
  position: fixed !important;
  inset: 0 !important;
  z-index: 200 !important;
  background: var(--paper);
  transform: translateX(100%);
  transition: transform .35s cubic-bezier(.2,.7,.2,1);
  pointer-events: none;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
body.ns-redesign .ns-mobile-drawer.is-open {
  transform: translateX(0);
  pointer-events: auto;
}
body.ns-redesign .ns-mobile-drawer__inner {
  padding: 22px;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex; flex-direction: column;
  gap: 24px;
}
body.ns-redesign .ns-mobile-drawer__head {
  display: flex; justify-content: space-between; align-items: center;
}
body.ns-redesign .ns-mobile-close {
  width: 44px; height: 44px;
  background: transparent;
  border: 1px solid var(--rule);
  border-radius: 999px;
  font-size: 24px; line-height: 1;
  color: var(--ink);
  cursor: pointer; padding: 0;
  display: inline-flex; align-items: center; justify-content: center;
}
body.ns-redesign .ns-mobile-nav .ns-mobile-menu {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column;
  border-top: 1px solid var(--rule);
}
body.ns-redesign .ns-mobile-nav .ns-mobile-menu li {
  border-bottom: 1px solid var(--rule);
  margin: 0; padding: 0;
}
body.ns-redesign .ns-mobile-nav .ns-mobile-menu a {
  display: block;
  padding: 18px 4px;
  font-family: var(--sans);
  font-size: 18px; font-weight: 600;
  color: var(--ink);
  text-decoration: none;
  border: 0;
}
body.ns-redesign .ns-mobile-nav .ns-mobile-menu a:hover { color: var(--accent); }
body.ns-redesign .ns-mobile-nav .sub-menu {
  list-style: none;
  padding: 0 0 12px 14px;
  margin: 0;
  border-top: 1px solid var(--rule);
}
body.ns-redesign .ns-mobile-nav .sub-menu li { border-bottom: 0; }
body.ns-redesign .ns-mobile-nav .sub-menu a {
  padding: 12px 0;
  font-size: 15px; font-weight: 500;
  color: var(--ink-soft);
}
body.ns-redesign .ns-mobile-drawer__cta {
  margin-top: auto;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 12px;
}
body.ns-redesign .ns-mobile-tel {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: 0.1em;
  color: var(--ink);
  text-decoration: none;
  padding: 12px 0;
}
body.ns-redesign .ns-mobile-tel:hover { color: var(--accent); }

/* Quand le drawer est ouvert, on bloque le scroll body */
body.ns-redesign.ns-drawer-open { overflow: hidden !important; }

/* ╔════════════════════════════════════════════════════════════════════
 * ║ HERO MOBILE
 * ╚════════════════════════════════════════════════════════════════════ */

@media (max-width: 880px) {
  body.ns-redesign .hero {
    min-height: 88vh;
    min-height: 88dvh;
  }
  body.ns-redesign .hero > .hero-meta {
    margin-top: 100px !important;
    padding: 10px 14px !important;
    font-size: 9.5px !important;
    gap: 8px 10px !important;
    flex-wrap: wrap;
  }
  body.ns-redesign .hero-meta .badge { font-size: 9px; padding: 3px 8px; }
  body.ns-redesign .hero-meta__sep { display: none; }
  body.ns-redesign .hero-headline h1 {
    font-size: clamp(30px, 9vw, 52px) !important;
    line-height: 1.05 !important;
  }
  body.ns-redesign .hero-foot {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    padding: 20px !important;
  }
  body.ns-redesign .hero-foot__intro p { font-size: 14px; }
  body.ns-redesign .hero-foot__cta { width: 100%; }
  body.ns-redesign .hero-foot__cta .btn { width: 100%; justify-content: center; }
  body.ns-redesign .hero-foot__stat {
    align-items: flex-start;
    text-align: left;
    border-top: 1px solid var(--rule);
    padding-top: 14px;
    flex-direction: row;
    align-items: baseline;
    gap: 12px;
  }
  body.ns-redesign .hero-foot__stat-num { font-size: 36px; }
  body.ns-redesign .hero-foot__stat-label { font-size: 10px; }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ SECTIONS MOBILE — paddings et grilles
 * ╚════════════════════════════════════════════════════════════════════ */

@media (max-width: 880px) {
  body.ns-redesign .section { padding-block: clamp(56px, 10vw, 100px) !important; }
  body.ns-redesign .display-l { font-size: clamp(36px, 9vw, 60px) !important; }
  body.ns-redesign .display-m { font-size: clamp(30px, 7.5vw, 48px) !important; }
  body.ns-redesign .display-s { font-size: clamp(24px, 6vw, 36px) !important; }

  /* Bento : 1 col, padding réduit */
  body.ns-redesign .bento { grid-template-columns: 1fr !important; gap: 14px !important; }
  body.ns-redesign .bento .card { padding: 22px 20px !important; min-height: 0; }
  body.ns-redesign .bento h3 { font-size: clamp(22px, 5.5vw, 32px) !important; }

  /* Approach split : empilé */
  body.ns-redesign .split { grid-template-columns: 1fr !important; }
  body.ns-redesign .split > div { padding: 28px 22px !important; }
  body.ns-redesign .split li { font-size: 16px !important; line-height: 1.4; }

  /* Process steps : 1 colonne */
  body.ns-redesign .proc-step {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    padding: 28px 0 !important;
  }
  body.ns-redesign .proc-step:hover { padding-left: 0 !important; }
  body.ns-redesign .proc-step .when { text-align: left !important; padding-top: 4px; font-size: 10.5px !important; }
  body.ns-redesign .proc-step .pnum { font-size: 44px !important; }
  body.ns-redesign .proc-step h3 { font-size: 22px !important; }

  /* GoFurther : 1 col */
  body.ns-redesign .further-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
  body.ns-redesign .further-card { padding: 24px 20px !important; min-height: 0 !important; }

  /* Lieux H-track : convertir en grid vertical sur mobile (sticky scroll cassé sur petit écran) */
  body.ns-redesign .h-track-section {
    height: auto !important;
    padding: clamp(56px, 10vw, 100px) 0;
  }
  body.ns-redesign .h-track-pin {
    position: static !important;
    height: auto !important;
    overflow: visible;
  }
  body.ns-redesign .h-track-head {
    grid-template-columns: 1fr !important;
    gap: 20px;
    padding: 0 var(--gutter) 30px;
  }
  body.ns-redesign .h-track-progress { display: none; }
  body.ns-redesign .h-track-rail {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 16px !important;
    padding: 0 var(--gutter) !important;
    transform: none !important;
  }
  body.ns-redesign .h-track-card {
    flex: 0 1 auto !important;
    width: 100% !important;
    transform: none !important;
  }
  body.ns-redesign .h-track-card .img { aspect-ratio: 1 / 1; }
  body.ns-redesign .h-track-card h4 { font-size: 18px; }

  /* Carte Normandie : grille verticale */
  body.ns-redesign .map-row {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  body.ns-redesign .map-wrap { aspect-ratio: 4 / 3; }
  body.ns-redesign .map-ctas { gap: 8px; }
  body.ns-redesign .chip-link { font-size: 10.5px; padding: 8px 12px; }

  /* Méthodes : tags en colonne */
  body.ns-redesign #methodes .reveal-stagger { gap: 8px !important; }
  body.ns-redesign .tag { font-size: 12px; padding: 8px 14px; }

  /* Tarifs : 1 col mobile, 2 col tablet */
  body.ns-redesign .pricing-grid { gap: 12px !important; }

  /* Quiz */
  body.ns-redesign .ns-quiz__panel { padding: 22px !important; }
  body.ns-redesign .ns-quiz__q h3 { font-size: 18px !important; }
  body.ns-redesign .ns-quiz__choice { padding: 14px 16px; font-size: 14px; }

  /* Facilitateur */
  body.ns-redesign .facilitator { grid-template-columns: 1fr !important; gap: 28px !important; }
  body.ns-redesign .facilitator .portrait { aspect-ratio: 1 / 1; }

  /* FAQ */
  body.ns-redesign #faq .faq-section__title { font-size: clamp(28px, 7vw, 38px) !important; }
  body.ns-redesign #faq .faq-item__question { padding: 18px 18px !important; font-size: 15px !important; }
  body.ns-redesign #faq .faq-item__answer { padding: 0 18px 20px !important; font-size: 14.5px; }

  /* Preuves sociales */
  body.ns-redesign .kpi-bar {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 18px !important;
    padding: 22px !important;
    border-radius: 14px !important;
  }
  body.ns-redesign .kpi-bar > div { flex: 0 0 calc(50% - 9px); min-width: 0 !important; }
  body.ns-redesign .case-study {
    padding: 28px 22px !important;
  }
  body.ns-redesign .case-study .case-study__body,
  body.ns-redesign .case-study div[style*="grid-template-columns:repeat(3"] {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }

  /* Contact section */
  body.ns-redesign .contact-row { grid-template-columns: 1fr !important; gap: 32px !important; }
  body.ns-redesign .contact-calendly-card { padding: 22px !important; }
  body.ns-redesign .form-card { padding: 22px !important; border-radius: 14px !important; }
  body.ns-redesign .fields-grid { grid-template-columns: 1fr !important; }
  body.ns-redesign .form-extra .fields-grid { grid-template-columns: 1fr !important; }

  /* Footer */
  body.ns-redesign .ns-footer .footer-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 28px !important;
  }
  body.ns-redesign .ns-footer .footer-display { font-size: clamp(48px, 14vw, 88px) !important; }
  body.ns-redesign .ns-footer .copy {
    flex-direction: column;
    gap: 8px;
    align-items: flex-start;
  }
}

@media (max-width: 520px) {
  /* Footer : 1 col */
  body.ns-redesign .ns-footer .footer-grid { grid-template-columns: 1fr !important; }
  body.ns-redesign .ns-footer { padding: 60px 18px 30px !important; }
  /* Lieux : 1 col mobile */
  body.ns-redesign .h-track-rail { grid-template-columns: 1fr !important; }
  /* KPI : 1 par ligne */
  body.ns-redesign .kpi-bar > div { flex: 0 0 100%; }
  /* Hero foot stat */
  body.ns-redesign .hero-foot__stat { flex-direction: row; align-items: baseline; gap: 10px; }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ ARTICLE SINGLE — MOBILE
 * ╚════════════════════════════════════════════════════════════════════ */

@media (max-width: 880px) {
  body.ns-redesign .article-head {
    padding-top: clamp(110px, 16vw, 160px) !important;
    padding-bottom: 30px !important;
  }
  body.ns-redesign .article-title { font-size: clamp(32px, 8vw, 48px) !important; }
  body.ns-redesign .article-deck { font-size: 18px !important; line-height: 1.4; }
  body.ns-redesign .article-byline { grid-template-columns: auto 1fr !important; }
  body.ns-redesign .article-share {
    grid-column: 1 / -1 !important;
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  body.ns-redesign .hero-photo-large { aspect-ratio: 16 / 10; border-radius: 14px; }
  body.ns-redesign .article-prose { font-size: 17px; }
  body.ns-redesign .article-prose h2 { font-size: 22px !important; }
  body.ns-redesign .article-prose ol.article-list li { padding-left: 44px; }
  body.ns-redesign .article-prose ol.article-list li::before { font-size: 28px; }
  body.ns-redesign .article-lead { font-size: 18px !important; }
  body.ns-redesign .article-lead .dropcap { font-size: 60px; padding: 0 8px 0 0; }

  body.ns-redesign .related-grid { grid-template-columns: 1fr !important; }
  body.ns-redesign .nl-grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    padding: 28px !important;
  }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ BLOG MAGAZINE — MOBILE
 * ╚════════════════════════════════════════════════════════════════════ */

@media (max-width: 1100px) {
  body.ns-redesign .mag-grid { grid-template-columns: 1fr !important; }
  body.ns-redesign .mag-sidebar { position: static !important; }
}
@media (max-width: 880px) {
  body.ns-redesign .mag-hero { grid-template-columns: 1fr !important; }
  body.ns-redesign .mag-hero__content { padding: 28px 22px !important; }
  body.ns-redesign .mag-featured__grid,
  body.ns-redesign .mag-grid__main { grid-template-columns: 1fr !important; }
  body.ns-redesign .mag-masthead__title { font-size: clamp(40px, 10vw, 60px) !important; }
  body.ns-redesign .mag-section-head--with-filters { flex-direction: column; align-items: flex-start; }
  body.ns-redesign .mag-filters { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 4px; }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ TAP TARGETS minimum 44×44px partout (WCAG 2.5.5)
 * ╚════════════════════════════════════════════════════════════════════ */

@media (max-width: 880px) {
  body.ns-redesign .btn,
  body.ns-redesign .btn-accent,
  body.ns-redesign .nav-cta,
  body.ns-redesign .arrow-link,
  body.ns-redesign .chip-link,
  body.ns-redesign .mag-filter,
  body.ns-redesign .ns-quiz__choice,
  body.ns-redesign .article-share button {
    min-height: 44px;
  }
  body.ns-redesign input[type="email"],
  body.ns-redesign input[type="text"],
  body.ns-redesign input[type="tel"],
  body.ns-redesign textarea,
  body.ns-redesign select { min-height: 44px; font-size: 16px !important; /* évite zoom iOS */ }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ Accessibilité : focus visible
 * ╚════════════════════════════════════════════════════════════════════ */

body.ns-redesign a:focus-visible,
body.ns-redesign button:focus-visible,
body.ns-redesign input:focus-visible,
body.ns-redesign textarea:focus-visible,
body.ns-redesign select:focus-visible,
body.ns-redesign .ns-quiz__choice:focus-visible,
body.ns-redesign details summary:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

/* Respect prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  body.ns-redesign .reveal,
  body.ns-redesign .reveal-stagger > *,
  body.ns-redesign .reveal-mask,
  body.ns-redesign .reveal-scale,
  body.ns-redesign .reveal-left,
  body.ns-redesign .reveal-right { opacity: 1 !important; transform: none !important; transition: none !important; }
  body.ns-redesign * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  body.ns-redesign .hero-video { filter: blur(10px) saturate(0.9) !important; }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ LÉOPARDS FULL-WIDTH + BIEN VISIBLES (override final)
 * ╚════════════════════════════════════════════════════════════════════ */

body.ns-redesign .hero::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;                    /* TOUTE la largeur du hero */
  width: 100% !important;
  height: 100% !important;
  transform: none !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;

  background-image: url("../../images/svg/leopards-normandie.svg") !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;     /* centré */
  background-size: 90% auto !important;              /* prend quasi toute la largeur */

  /* Bien visibles */
  opacity: 0.75 !important;
  mix-blend-mode: multiply !important;
  pointer-events: none !important;
  z-index: 2 !important;
  filter: contrast(1.2) saturate(1.15) drop-shadow(0 8px 32px rgba(199, 83, 39, 0.25));
}
[data-palette="dusk"] body.ns-redesign .hero::after {
  mix-blend-mode: screen !important;
  opacity: 0.85 !important;
}

@media (max-width: 980px) {
  body.ns-redesign .hero::after {
    background-size: 130% auto !important;     /* déborde un peu pour rester chargé visuellement */
    background-position: center center !important;
    opacity: 0.55 !important;
  }
}
@media (max-width: 640px) {
  body.ns-redesign .hero::after {
    background-size: 160% auto !important;
    opacity: 0.45 !important;
  }
}

/* La vidéo reste discrète derrière */
body.ns-redesign .hero-video {
  opacity: 0.4 !important;
  filter: blur(14px) saturate(0.8) brightness(0.95) !important;
}
body.ns-redesign .hero-video.is-loaded { opacity: 0.4 !important; }

/* ╔════════════════════════════════════════════════════════════════════
 * ║ MENU : item-image NORMANDIE → texte "Choisir la Normandie"
 * ║ La pastille jaune vient d'un menu item WP avec <img> au lieu de texte
 * ║ Lien : choisirlanormandie.fr
 * ╚════════════════════════════════════════════════════════════════════ */

/* Cacher TOUS les <img> dans le menu nav (desktop + mobile) */
body.ns-redesign .ns-nav .nav-links img,
body.ns-redesign .ns-mobile-drawer .ns-mobile-menu img,
body.ns-redesign .ns-nav .nav-links a img,
body.ns-redesign .ns-mobile-nav a img {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  opacity: 0 !important;
  position: absolute !important;
  pointer-events: none !important;
}

/* Remplacer le menu item qui contient une image par du texte
   (ciblage : tout <a> dont le seul enfant est <img>) */
body.ns-redesign .ns-nav .nav-links a:has(> img:only-child),
body.ns-redesign .ns-mobile-nav a:has(> img:only-child) {
  display: inline-flex !important;
  align-items: center !important;
  font-size: 0 !important; /* hide any whitespace */
}
body.ns-redesign .ns-nav .nav-links a:has(> img:only-child)::before,
body.ns-redesign .ns-mobile-nav a:has(> img:only-child)::before {
  content: "Choisir la Normandie";
  font-family: var(--sans);
  font-size: 13px !important;
  font-weight: 500;
  color: var(--ink-soft);
  letter-spacing: 0;
  text-transform: none;
  display: inline-block;
}

/* Mobile drawer : taille adaptée */
body.ns-redesign .ns-mobile-nav a:has(> img:only-child)::before {
  font-size: 18px !important;
  font-weight: 600;
  color: var(--ink);
  padding: 18px 0;
}

/* Fallback pour les browsers sans :has() (mais Safari 15.4+, FF 121+ supportent) */
@supports not selector(:has(*)) {
  body.ns-redesign .ns-nav .nav-links a img,
  body.ns-redesign .ns-mobile-nav a img {
    display: none !important;
  }
  /* Sans :has, le texte n'est pas remplacé. Au moins l'image disparaît. */
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
 * ║                                                                            ║
 * ║    HERO ABSOLU — VIDÉO PLEIN CADRE + LÉOPARDS PLEIN CADRE                  ║
 * ║                                                                            ║
 * ║    Ce bloc est le DERNIER override.                                        ║
 * ║    Il efface toutes les règles précédentes sur .hero-video* / .hero::      ║
 * ║    Sélecteur high-spec : html.ns-redesign body.ns-redesign header.hero ... ║
 * ║                                                                            ║
 * ╚════════════════════════════════════════════════════════════════════════════╝ */

/* Le hero : conteneur full-bleed, sans padding, overflow hidden */
html body.ns-redesign header.hero,
html body.ns-redesign .hero {
  position: relative !important;
  overflow: hidden !important;
  isolation: isolate !important;
  padding: 0 !important;
  margin: 0 !important;
  min-height: 92vh;
  min-height: 92dvh;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  background: var(--paper) !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* Wrap de la vidéo : FULL-BLEED, aucun mask, aucune restriction */
html body.ns-redesign header.hero .hero-video-wrap,
html body.ns-redesign header.hero .hero-video-wrap--leopards,
html body.ns-redesign .hero .hero-video-wrap,
html body.ns-redesign .hero .hero-video-wrap--leopards {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  z-index: 0 !important;
  overflow: hidden !important;
  display: block !important;
  visibility: visible !important;
  -webkit-mask: none !important;
  mask: none !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
  background: var(--bg-elev) !important;
}
html body.ns-redesign header.hero .hero-video-wrap--leopards::before,
html body.ns-redesign .hero .hero-video-wrap--leopards::before { display: none !important; }

/* Vidéo elle-même : full-bleed centrée, blur léger pour discrétion, alpha 0.55 */
html body.ns-redesign header.hero .hero-video,
html body.ns-redesign .hero .hero-video {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) scale(1.06) !important;
  width: auto !important;
  height: auto !important;
  min-width: 100% !important;
  min-height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  z-index: 0 !important;
  display: block !important;
  visibility: visible !important;
  opacity: 0.55 !important;
  filter: blur(8px) saturate(0.85) brightness(0.96) !important;
  mix-blend-mode: normal !important;
  -webkit-mask: none !important;
  mask: none !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
}
html body.ns-redesign header.hero .hero-video.is-loaded,
html body.ns-redesign .hero .hero-video.is-loaded { opacity: 0.55 !important; }

/* Voile uniforme léger sur TOUTE la largeur (lisibilité du texte) */
html body.ns-redesign header.hero::before,
html body.ns-redesign .hero::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  pointer-events: none !important;
  background:
    radial-gradient(ellipse 60% 80% at 22% 50%, color-mix(in oklab, var(--paper) 75%, transparent) 0%, transparent 60%),
    linear-gradient(180deg, transparent 0%, transparent 70%, color-mix(in oklab, var(--paper) 35%, transparent) 100%) !important;
}
[data-palette="dusk"] html body.ns-redesign .hero::before {
  background:
    radial-gradient(ellipse 60% 80% at 22% 50%, color-mix(in oklab, var(--bg) 80%, transparent) 0%, transparent 60%),
    linear-gradient(180deg, transparent 0%, transparent 70%, color-mix(in oklab, var(--bg) 50%, transparent) 100%) !important;
}

/* Léopards : FULL-BLEED, bien visibles, par-dessus la vidéo */
html body.ns-redesign header.hero::after,
html body.ns-redesign .hero::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  transform: none !important;
  background-image: url("../../images/svg/leopards-normandie.svg") !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: 95% auto !important;
  background-color: transparent !important;
  opacity: 0.85 !important;
  mix-blend-mode: multiply !important;
  pointer-events: none !important;
  z-index: 2 !important;
  filter: contrast(1.2) saturate(1.2) drop-shadow(0 6px 24px rgba(199, 83, 39, 0.25)) !important;
}
[data-palette="dusk"] html body.ns-redesign .hero::after {
  mix-blend-mode: screen !important;
  opacity: 0.95 !important;
}

/* Mobile : léopards toujours full-bleed mais opacity réduite (lisibilité) */
@media (max-width: 980px) {
  html body.ns-redesign header.hero::after,
  html body.ns-redesign .hero::after {
    background-size: 130% auto !important;
    opacity: 0.55 !important;
  }
}
@media (max-width: 640px) {
  html body.ns-redesign header.hero::after,
  html body.ns-redesign .hero::after {
    background-size: 170% auto !important;
    opacity: 0.40 !important;
  }
}

/* Hero foot : margin gauche/droite/bas pour la padding visuelle */
html body.ns-redesign header.hero > .hero-meta,
html body.ns-redesign header.hero > .hero-headline,
html body.ns-redesign header.hero > .hero-foot,
html body.ns-redesign header.hero > .hero-scroll,
html body.ns-redesign .hero > .hero-meta,
html body.ns-redesign .hero > .hero-headline,
html body.ns-redesign .hero > .hero-foot,
html body.ns-redesign .hero > .hero-scroll {
  position: relative !important;
  z-index: 4 !important;
}
html body.ns-redesign header.hero > .hero-meta,
html body.ns-redesign .hero > .hero-meta {
  margin: 130px var(--gutter) 0 var(--gutter) !important;
  align-self: flex-start;
}
html body.ns-redesign header.hero > .hero-headline,
html body.ns-redesign .hero > .hero-headline {
  margin: clamp(20px, 3vw, 40px) var(--gutter) clamp(20px, 3vw, 40px) var(--gutter) !important;
}
html body.ns-redesign header.hero > .hero-foot,
html body.ns-redesign .hero > .hero-foot {
  margin: 0 var(--gutter) 60px var(--gutter) !important;
}

/* hero-photo désactivée si vidéo présente */
html body.ns-redesign .hero:has(.hero-video-wrap) .hero-photo,
html body.ns-redesign .hero:has(.hero-video) .hero-photo,
html body.ns-redesign .hero:has(.hero-video-wrap--leopards) .hero-photo {
  display: none !important;
}

/* Sun OFF — les léopards font le focus */
html body.ns-redesign .hero-sun { display: none !important; }

@media (max-width: 880px) {
  html body.ns-redesign header.hero > .hero-meta,
  html body.ns-redesign .hero > .hero-meta {
    margin-top: 100px !important;
  }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ LÉOPARDS : opacity 20% max (override final demandé par Yoan)
 * ╚════════════════════════════════════════════════════════════════════ */

html body.ns-redesign header.hero::after,
html body.ns-redesign .hero::after {
  opacity: 0.20 !important;
}
[data-palette="dusk"] html body.ns-redesign .hero::after {
  opacity: 0.30 !important;
}
@media (max-width: 980px) {
  html body.ns-redesign header.hero::after,
  html body.ns-redesign .hero::after {
    opacity: 0.15 !important;
  }
}
@media (max-width: 640px) {
  html body.ns-redesign header.hero::after,
  html body.ns-redesign .hero::after {
    opacity: 0.10 !important;
  }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ NAV POLISH FINAL — design premium, pill aérée, hover propre
 * ╚════════════════════════════════════════════════════════════════════ */

/* Pill : plus arrondie, ombre subtile, fond très light */
html body.ns-redesign .ns-nav {
  top: 18px !important;
  padding: 8px 8px 8px 24px !important;
  border-radius: 100px !important;
  background: color-mix(in oklab, var(--paper) 88%, transparent) !important;
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  backdrop-filter: blur(24px) saturate(180%);
  border: 1px solid color-mix(in oklab, var(--ink) 6%, transparent) !important;
  box-shadow:
    0 1px 0 0 color-mix(in oklab, var(--cream) 50%, transparent) inset,
    0 12px 32px -16px color-mix(in oklab, var(--ink) 25%, transparent) !important;
  gap: 8px !important;
  grid-template-columns: auto 1fr auto auto auto !important;
}
html body.ns-redesign .ns-nav.scrolled {
  top: 12px !important;
  background: color-mix(in oklab, var(--paper) 95%, transparent) !important;
  box-shadow: 0 16px 40px -16px color-mix(in oklab, var(--ink) 35%, transparent) !important;
}

/* Brand : plus aéré, dot plus précis */
html body.ns-redesign .nav-brand {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-family: var(--sans) !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  letter-spacing: -0.015em !important;
  white-space: nowrap !important;
  color: var(--ink) !important;
  padding: 4px 8px !important;
  border-radius: 999px !important;
  text-decoration: none !important;
}
html body.ns-redesign .nav-brand .dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  background: var(--accent) !important;
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent) !important;
  flex-shrink: 0;
}
html body.ns-redesign .nav-brand .sep { color: var(--accent); margin: 0 1px; font-style: italic; opacity: 0.5; }
html body.ns-redesign .nav-brand:hover .dot {
  box-shadow: 0 0 0 5px color-mix(in oklab, var(--accent) 22%, transparent) !important;
  transition: box-shadow .25s ease;
}

/* Menu : centré, hover en pill clair (pas underline) */
html body.ns-redesign .ns-nav .nav-links {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
html body.ns-redesign .ns-nav .nav-links > ul,
html body.ns-redesign .ns-nav .nav-links .ns-nav-menu {
  display: flex !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  white-space: nowrap !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: 4px !important;
}
html body.ns-redesign .ns-nav .nav-links li {
  display: inline-flex !important;
  align-items: center !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  position: relative;
}
html body.ns-redesign .ns-nav .nav-links a {
  display: inline-block !important;
  padding: 9px 14px !important;
  border-radius: 999px !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  text-decoration: none !important;
  color: var(--ink-soft) !important;
  white-space: nowrap !important;
  position: relative;
  transition: background .2s ease, color .2s ease !important;
  background: transparent !important;
  border-bottom: 0 !important;
}
/* Plus de ::after underline (on bascule sur background) */
html body.ns-redesign .ns-nav .nav-links a::after { display: none !important; }
html body.ns-redesign .ns-nav .nav-links a:hover {
  background: color-mix(in oklab, var(--ink) 6%, transparent) !important;
  color: var(--ink) !important;
}
html body.ns-redesign .ns-nav .nav-links li.current-menu-item > a,
html body.ns-redesign .ns-nav .nav-links li.current-menu-ancestor > a {
  background: var(--ink) !important;
  color: var(--cream) !important;
  font-weight: 600 !important;
}

/* Téléphone : épuré */
html body.ns-redesign .nav-tel {
  font-family: var(--mono) !important;
  font-size: 11.5px !important;
  letter-spacing: 0.05em !important;
  color: var(--ink-soft) !important;
  white-space: nowrap !important;
  padding: 8px 14px 8px 18px !important;
  margin-left: 6px;
  border-left: 1px solid color-mix(in oklab, var(--ink) 14%, transparent) !important;
  border-radius: 0 !important;
  transition: color .2s !important;
}
html body.ns-redesign .nav-tel:hover { color: var(--accent) !important; }

/* CTA : punchy */
html body.ns-redesign .nav-cta {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 10px 18px !important;
  background: var(--ink) !important;
  color: var(--cream) !important;
  border-radius: 999px !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: -0.005em !important;
  white-space: nowrap !important;
  text-decoration: none !important;
  transition: background .25s ease, transform .2s ease !important;
}
html body.ns-redesign .nav-cta:hover {
  background: var(--accent) !important;
  transform: translateY(-1px);
}
html body.ns-redesign .nav-cta svg {
  width: 12px !important; height: 12px !important;
  display: inline-block !important;
}

/* Sous-menu : mieux positionné */
html body.ns-redesign .ns-nav .nav-links li.menu-item-has-children > a::before {
  content: "" ;
  display: inline-block;
  width: 5px; height: 5px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translate(-2px, -2px);
  margin-right: 6px;
  margin-bottom: 2px;
  opacity: 0.5;
}

/* Breakpoints : labels plus courts si serré */
@media (min-width: 1101px) and (max-width: 1280px) {
  html body.ns-redesign .ns-nav .nav-links a { padding: 8px 11px !important; font-size: 12.5px !important; }
  html body.ns-redesign .ns-nav .nav-links > ul { gap: 2px !important; }
  html body.ns-redesign .nav-brand { font-size: 14px !important; }
  html body.ns-redesign .nav-tel { font-size: 11px !important; padding: 8px 10px 8px 14px !important; }
  html body.ns-redesign .nav-cta { padding: 10px 14px !important; font-size: 12px !important; }
}
@media (min-width: 981px) and (max-width: 1100px) {
  html body.ns-redesign .ns-nav .nav-links a { padding: 8px 9px !important; font-size: 12px !important; }
  html body.ns-redesign .nav-tel { display: none !important; }
  html body.ns-redesign .ns-nav { grid-template-columns: auto 1fr auto auto !important; }
}

/* Burger : look propre */
html body.ns-redesign .ns-burger {
  width: 44px !important; height: 44px !important;
  background: color-mix(in oklab, var(--ink) 5%, transparent) !important;
  border: 0 !important;
  border-radius: 999px !important;
  cursor: pointer;
  display: none;
  flex-direction: column !important;
  gap: 4px !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background .2s ease;
}
html body.ns-redesign .ns-burger:hover { background: color-mix(in oklab, var(--ink) 12%, transparent) !important; }
html body.ns-redesign .ns-burger span {
  display: block !important;
  width: 16px !important;
  height: 1.5px !important;
  background: var(--ink) !important;
  border-radius: 2px !important;
}

@media (min-width: 981px) {
  html body.ns-redesign .ns-burger { display: none !important; }
}
@media (max-width: 980px) {
  html body.ns-redesign .ns-burger { display: inline-flex !important; }
  html body.ns-redesign .ns-nav .nav-links { display: none !important; }
}

/* Mobile pill */
@media (max-width: 640px) {
  html body.ns-redesign .ns-nav {
    padding: 6px 6px 6px 16px !important;
    gap: 6px !important;
    grid-template-columns: 1fr auto auto !important;
  }
  html body.ns-redesign .nav-tel { display: none !important; }
  html body.ns-redesign .nav-cta {
    padding: 9px 14px !important;
    font-size: 12px !important;
  }
}
@media (max-width: 480px) {
  html body.ns-redesign .ns-nav { grid-template-columns: 1fr auto !important; }
  html body.ns-redesign .nav-cta { display: none !important; }
}

/* ╔════════════════════════════════════════════════════════════════════
 * ║ CITY PAGES — pages villes Normandie (template-city.php)
 * ╚════════════════════════════════════════════════════════════════════ */

.ns-redesign .ns-city-page { background: var(--paper); }

/* HERO ville : image full-bleed, dégradé voile, contenu sur 1/2 gauche */
.ns-redesign .city-hero {
  position: relative;
  min-height: 88vh;
  min-height: 88dvh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  padding: 130px 0 60px;
  isolation: isolate;
}
.ns-redesign .city-hero__bg {
  position: absolute;
  inset: 0;
  background-image: var(--city-hero-bg);
  background-size: cover;
  background-position: center;
  z-index: 0;
  filter: saturate(0.9);
}
.ns-redesign .city-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg,
      color-mix(in oklab, var(--paper) 92%, transparent) 0%,
      color-mix(in oklab, var(--paper) 75%, transparent) 35%,
      color-mix(in oklab, var(--paper) 25%, transparent) 65%,
      transparent 100%),
    linear-gradient(180deg, transparent 0%, transparent 50%, color-mix(in oklab, var(--ink) 30%, transparent) 100%);
}
.ns-redesign .city-hero__inner {
  position: relative;
  z-index: 2;
  width: 100%;
}
.ns-redesign .city-hero__content { max-width: 720px; }
.ns-redesign .city-hero__kicker {
  display: inline-block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  margin-bottom: 20px;
  padding: 6px 14px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--cream) 80%, transparent);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border: 1px solid color-mix(in oklab, var(--accent) 30%, transparent);
}
.ns-redesign .city-hero__title {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(48px, 8vw, 110px);
  line-height: 0.95;
  letter-spacing: -0.04em;
  margin: 0 0 20px;
  color: var(--ink);
}
.ns-redesign .city-hero__title em {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  background: linear-gradient(110deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.ns-redesign .city-hero__tagline {
  font-family: var(--serif);
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.35;
  color: var(--ink);
  font-style: italic;
  margin: 0 0 16px;
}
.ns-redesign .city-hero__lead {
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 28px;
  max-width: 560px;
  font-weight: 400;
}
.ns-redesign .city-hero__meta { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 28px; }
.ns-redesign .city-hero__chip {
  display: inline-block;
  padding: 8px 14px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink);
  background: color-mix(in oklab, var(--cream) 85%, transparent);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border: 1px solid color-mix(in oklab, var(--ink) 12%, transparent);
  border-radius: 999px;
  font-weight: 500;
}
.ns-redesign .city-hero__chip--accent {
  background: var(--ink) !important;
  color: var(--cream) !important;
  border-color: var(--ink);
}
.ns-redesign .city-hero__cta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}
.ns-redesign .city-hero__cta-note {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

@media (max-width: 880px) {
  .ns-redesign .city-hero { padding-top: 110px; min-height: 80vh; }
  .ns-redesign .city-hero__overlay {
    background:
      linear-gradient(180deg,
        color-mix(in oklab, var(--paper) 75%, transparent) 0%,
        color-mix(in oklab, var(--paper) 60%, transparent) 50%,
        color-mix(in oklab, var(--paper) 95%, transparent) 100%);
  }
  .ns-redesign .city-hero__content { max-width: 100%; }
}

/* USP grid */
.ns-redesign .city-usp { padding: 60px 0; background: var(--cream); border-bottom: 1px solid var(--rule); }
.ns-redesign .city-usp__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
@media (max-width: 980px) { .ns-redesign .city-usp__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .ns-redesign .city-usp__grid { grid-template-columns: 1fr; } }
.ns-redesign .city-usp__item {
  display: flex; gap: 14px; align-items: flex-start;
}
.ns-redesign .city-usp__check {
  flex-shrink: 0;
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent);
  color: var(--cream);
  border-radius: 50%;
  font-weight: 700;
  font-size: 14px;
}
.ns-redesign .city-usp__item p {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink);
  font-weight: 500;
}

/* HOOK */
.ns-redesign .city-hook {
  padding: clamp(60px, 8vw, 100px) 0 30px;
  text-align: center;
  max-width: 880px;
  margin: 0 auto;
}
.ns-redesign .city-hook p {
  font-family: var(--serif);
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.4;
  color: var(--ink);
  font-style: italic;
  margin: 0;
}

/* SECTIONS */
.ns-redesign .city-section {
  padding: clamp(60px, 8vw, 100px) 0;
}
.ns-redesign .city-section--alt { background: var(--cream); }
.ns-redesign .city-section__head {
  max-width: 780px;
  margin-bottom: 32px;
}
.ns-redesign .city-section__head .display-m { margin: 8px 0 0; }
.ns-redesign .city-section__head .display-m em {
  font-family: var(--serif); font-style: italic; font-weight: 400;
  background: linear-gradient(110deg, var(--accent), var(--accent-2));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  -webkit-text-fill-color: transparent;
}
.ns-redesign .city-section__body {
  max-width: 780px;
  font-size: 17px;
  line-height: 1.75;
  color: var(--ink);
}
.ns-redesign .city-section__body.prose p { margin: 0 0 18px; }
.ns-redesign .city-section__body.prose strong { color: var(--ink); font-weight: 600; }
.ns-redesign .city-section__body.prose ul {
  list-style: none;
  padding: 0;
  margin: 24px 0;
}
.ns-redesign .city-section__body.prose ul li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 12px;
  font-size: 16px;
  line-height: 1.6;
}
.ns-redesign .city-section__body.prose ul li::before {
  content: "→";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent);
  font-weight: 700;
  font-family: var(--serif);
}

/* PRATIQUE — 4 cards */
.ns-redesign .city-pratique { padding: 30px 0; background: var(--paper); }
.ns-redesign .city-pratique__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}
@media (max-width: 980px) { .ns-redesign .city-pratique__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .ns-redesign .city-pratique__grid { grid-template-columns: 1fr; } }
.ns-redesign .city-pratique__card {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 14px;
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ns-redesign .city-pratique__label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
}
.ns-redesign .city-pratique__card strong {
  font-family: var(--sans);
  font-size: 17px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.ns-redesign .city-pratique__card--lieux ul {
  list-style: none;
  padding: 0;
  margin: 4px 0 0;
}
.ns-redesign .city-pratique__card--lieux li {
  font-size: 13.5px;
  color: var(--ink-soft);
  padding: 4px 0;
  line-height: 1.45;
}
.ns-redesign .city-pratique__card--lieux li::before {
  content: "·";
  color: var(--accent);
  font-weight: 700;
  margin-right: 8px;
}

/* TARIFS section */
.ns-redesign .city-tarifs { padding: clamp(60px, 8vw, 100px) 0; background: var(--paper); }
.ns-redesign .city-tarifs .city-section__head {
  max-width: 780px;
  margin: 0 auto clamp(32px, 5vw, 56px);
  padding: 0 var(--gutter);
}
.ns-redesign .city-tarifs__lead {
  font-size: 16px;
  line-height: 1.65;
  color: var(--ink-soft);
  margin: 16px 0 0;
}
.ns-redesign .city-tarifs__lead a { color: var(--accent); border-bottom: 1px solid currentColor; }
.ns-redesign .city-tarifs .pricing-grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}

/* CTA FINAL */
.ns-redesign .city-cta-final {
  background:
    radial-gradient(ellipse at 80% 20%, color-mix(in oklab, var(--accent) 45%, transparent), transparent 60%),
    radial-gradient(ellipse at 20% 80%, color-mix(in oklab, var(--accent-2) 30%, transparent), transparent 60%),
    var(--ink);
  color: var(--cream);
  padding: clamp(80px, 10vw, 140px) 0;
}
.ns-redesign .city-cta-final__inner {
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}
.ns-redesign .city-cta-final__inner h2 {
  color: var(--cream);
  margin: 0 0 16px;
  font-size: clamp(32px, 5vw, 56px);
}
.ns-redesign .city-cta-final__inner h2 em {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  background: linear-gradient(110deg, var(--accent-2), var(--accent));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.ns-redesign .city-cta-final__inner p {
  font-size: 17px;
  color: color-mix(in oklab, var(--cream) 80%, transparent);
  max-width: 560px;
  margin: 0 auto 32px;
}
.ns-redesign .city-cta-final__buttons {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
}
.ns-redesign .city-cta-final__buttons .btn-ghost {
  background: transparent;
  color: var(--cream);
  border: 1px solid color-mix(in oklab, var(--cream) 35%, transparent);
}
.ns-redesign .city-cta-final__buttons .btn-ghost:hover {
  background: color-mix(in oklab, var(--cream) 15%, transparent);
  border-color: var(--cream);
  color: var(--cream);
}

/* FAQ commune (page-faq global) */
.ns-redesign .ns-page-faq {
  padding: clamp(60px, 8vw, 100px) 0;
  background: linear-gradient(180deg, var(--paper) 0%, color-mix(in oklab, var(--bg-elev) 70%, var(--paper)) 100%);
}
.ns-redesign .ns-page-faq__inner {
  max-width: 920px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.ns-redesign .ns-page-faq__head {
  text-align: center;
  margin-bottom: clamp(32px, 4vw, 48px);
}
.ns-redesign .ns-page-faq__head h2 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(28px, 3.5vw, 44px);
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 12px 0 0;
}
.ns-redesign .ns-page-faq__list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ns-redesign .ns-page-faq__list .faq-item {
  background: var(--cream);
  border: 1px solid color-mix(in oklab, var(--ink) 8%, transparent);
  border-radius: 14px;
  margin: 0;
  padding: 0;
  overflow: hidden;
  transition: border-color .25s, box-shadow .25s;
}
.ns-redesign .ns-page-faq__list .faq-item:hover { border-color: color-mix(in oklab, var(--accent) 30%, transparent); }
.ns-redesign .ns-page-faq__list .faq-item[open] {
  border-color: var(--accent);
  box-shadow: 0 14px 36px -20px color-mix(in oklab, var(--accent) 35%, transparent);
}
.ns-redesign .ns-page-faq__list .faq-item__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 26px;
  cursor: pointer;
  list-style: none;
  font-size: 16.5px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.4;
  font-family: var(--sans);
}
.ns-redesign .ns-page-faq__list .faq-item__question::-webkit-details-marker,
.ns-redesign .ns-page-faq__list .faq-item__question::marker { display: none; content: ''; }
.ns-redesign .ns-page-faq__list .faq-item__question::after {
  content: "+";
  flex-shrink: 0;
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--sans); font-size: 22px; font-weight: 300;
  color: var(--accent);
  border-radius: 999px;
  transition: background .2s, color .2s;
  margin-left: 16px;
}
.ns-redesign .ns-page-faq__list .faq-item[open] .faq-item__question::after {
  content: "−";
  background: var(--accent);
  color: var(--cream);
}
.ns-redesign .ns-page-faq__list .faq-item__answer {
  padding: 0 26px 24px;
  color: var(--ink-soft);
  font-size: 15.5px;
  line-height: 1.75;
}
.ns-redesign .ns-page-faq__list .faq-item__answer p { margin: 0; }
.ns-redesign .ns-page-faq__list .faq-item__answer a {
  color: var(--accent);
  border-bottom: 1px solid color-mix(in oklab, var(--accent) 50%, transparent);
}

/* Mobile city pages */
@media (max-width: 880px) {
  .ns-redesign .city-hero__title { font-size: clamp(40px, 12vw, 70px) !important; }
  .ns-redesign .city-section__body { font-size: 16px; }
  .ns-redesign .city-cta-final__buttons { flex-direction: column; align-items: stretch; }
}

/* ============================================================
   SERVICE PAGES + DEFAULT PAGE — MARITIME UNIVERSAL
   ============================================================ */

/* HERO variants for service / generic pages */
.ns-redesign .hero--service,
.ns-redesign .hero--page { min-height: clamp(520px, 70vh, 760px); }

.ns-redesign .hero-photo--gradient {
  background: linear-gradient(135deg, var(--accent-3) 0%, var(--ink) 60%, color-mix(in oklab, var(--accent) 40%, var(--ink)) 100%) !important;
  opacity: 0.65;
}

.ns-redesign .hero-breadcrumb {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--cream) 80%, transparent);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.ns-redesign .hero-breadcrumb a {
  color: color-mix(in oklab, var(--cream) 70%, transparent);
  text-decoration: none;
  transition: color 0.2s;
}
.ns-redesign .hero-breadcrumb a:hover { color: var(--accent-2); }
.ns-redesign .hero-breadcrumb .sep { opacity: 0.5; }
.ns-redesign .hero-breadcrumb [aria-current] { color: var(--accent-2); }

/* CTA pill — premium button */
.ns-redesign .cta-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 26px;
  background: var(--ink);
  color: var(--cream);
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.01em;
  border-radius: 999px;
  text-decoration: none;
  border: 1px solid var(--ink);
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
  cursor: pointer;
  white-space: nowrap;
}
.ns-redesign .cta-pill:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 8px 24px -12px color-mix(in oklab, var(--accent) 60%, transparent);
}
.ns-redesign .cta-pill--ghost {
  background: transparent;
  color: var(--ink);
  border-color: color-mix(in oklab, var(--ink) 25%, transparent);
}
.ns-redesign .cta-pill--ghost:hover {
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
}
.ns-redesign .cta-pill--full { width: 100%; justify-content: center; }

/* card-link — discreet arrow link inside cards */
.ns-redesign .card-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 16px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in oklab, var(--accent) 30%, transparent);
  padding-bottom: 2px;
  transition: color 0.2s, border-color 0.2s;
}
.ns-redesign .card-link:hover {
  color: var(--ink);
  border-color: var(--ink);
}

/* method-card — numbered method cards */
.ns-redesign .method-card {
  position: relative;
  padding: 32px 28px 28px;
  background: var(--paper);
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  border-radius: 12px;
  transition: transform 0.3s, border-color 0.3s, box-shadow 0.3s;
}
.ns-redesign .method-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in oklab, var(--accent) 30%, transparent);
  box-shadow: 0 18px 40px -22px color-mix(in oklab, var(--ink) 30%, transparent);
}
.ns-redesign .method-card__num {
  display: block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--accent);
  margin-bottom: 16px;
  font-weight: 600;
}
.ns-redesign .method-card h3 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
  color: var(--ink);
}
.ns-redesign .method-card p {
  color: var(--ink-soft);
  font-size: 14.5px;
  line-height: 1.6;
  margin: 0;
}

/* format-card — service formats with tag */
.ns-redesign .format-card {
  position: relative;
  display: block;
  padding: 28px;
  background: var(--paper);
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  border-radius: 12px;
  text-decoration: none;
  color: var(--ink);
  transition: transform 0.3s, border-color 0.3s, box-shadow 0.3s;
}
.ns-redesign .format-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in oklab, var(--accent) 30%, transparent);
  box-shadow: 0 18px 40px -22px color-mix(in oklab, var(--ink) 30%, transparent);
}
.ns-redesign .format-card__tag {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  background: color-mix(in oklab, var(--accent) 10%, var(--paper));
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: 16px;
}
.ns-redesign .format-card h3 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
  color: var(--ink);
}
.ns-redesign .format-card p {
  color: var(--ink-soft);
  font-size: 14.5px;
  line-height: 1.6;
  margin: 0;
}

/* price-card — pricing tier cards (5 columns) */
.ns-redesign .price-card {
  position: relative;
  padding: 28px 22px;
  background: var(--paper);
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform 0.3s, border-color 0.3s, box-shadow 0.3s;
}
.ns-redesign .price-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in oklab, var(--accent) 30%, transparent);
  box-shadow: 0 18px 40px -22px color-mix(in oklab, var(--ink) 30%, transparent);
}
.ns-redesign .price-card--featured {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--cream);
}
.ns-redesign .price-card--featured:hover {
  border-color: var(--accent);
}
.ns-redesign .price-card__tier {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
}
.ns-redesign .price-card--featured .price-card__tier { color: var(--accent-2); }
.ns-redesign .price-card__amount {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(28px, 2.4vw, 38px);
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin-top: 4px;
}
.ns-redesign .price-card--featured .price-card__amount { color: var(--cream); }
.ns-redesign .price-card__amount sup { font-size: 0.5em; vertical-align: top; opacity: 0.7; }
.ns-redesign .price-card__unit {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--muted);
  text-transform: uppercase;
}
.ns-redesign .price-card--featured .price-card__unit { color: color-mix(in oklab, var(--cream) 70%, transparent); }
.ns-redesign .price-card__features {
  list-style: none;
  padding: 0;
  margin: 16px 0 0;
  display: grid;
  gap: 8px;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--ink-soft);
  border-top: 1px dashed color-mix(in oklab, var(--ink) 15%, transparent);
  padding-top: 16px;
}
.ns-redesign .price-card--featured .price-card__features {
  color: color-mix(in oklab, var(--cream) 85%, transparent);
  border-top-color: color-mix(in oklab, var(--cream) 25%, transparent);
}

/* facilitator-grid — Yoan portrait layout (alias of .facilitator) */
.ns-redesign .facilitator-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
}
.ns-redesign .facilitator-grid .portrait {
  aspect-ratio: 4/5;
  background-color: var(--bg-elev);
  background-image: var(--photo, none), repeating-linear-gradient(135deg, transparent 0 13px, color-mix(in oklab, var(--ink) 8%, transparent) 13px 14px);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: flex-end;
  padding: 20px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  border-radius: 6px;
  position: relative;
}
.ns-redesign .facilitator-grid .portrait::after {
  content: "Photo · Yoan Lureault";
  position: absolute;
  bottom: 20px;
  left: 20px;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
}
@media (max-width: 880px) {
  .ns-redesign .facilitator-grid { grid-template-columns: 1fr; }
}

/* card-symptome — comparison cards */
.ns-redesign .card-symptome { transition: transform 0.3s, box-shadow 0.3s; }
.ns-redesign .card-symptome:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 40px -22px color-mix(in oklab, var(--ink) 25%, transparent);
}

/* form-card */
.ns-redesign .form-card {
  background: var(--paper);
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  border-radius: 16px;
  padding: 32px;
}
.ns-redesign .form-card .field input,
.ns-redesign .form-card .field textarea {
  background: #fff;
  border: 1px solid color-mix(in oklab, var(--ink) 15%, transparent);
  border-radius: 8px;
  padding: 12px 14px;
  font-family: var(--sans);
  font-size: 15px;
  color: var(--ink);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.ns-redesign .form-card .field input:focus,
.ns-redesign .form-card .field textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent);
}
.ns-redesign .form-card .field__label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
}

/* cta-final — closing CTA */
.ns-redesign .cta-final {
  background: var(--paper);
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  border-radius: 16px;
  padding: clamp(40px, 5vw, 64px);
  text-align: left;
  position: relative;
  overflow: hidden;
}
.ns-redesign .cta-final::before {
  content: "";
  position: absolute;
  top: -40%;
  right: -10%;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, color-mix(in oklab, var(--accent-2) 25%, transparent) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}

/* ── ns-prose — Maritime typography for the_content() ── */
.ns-redesign .ns-prose {
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.75;
  color: var(--ink-soft);
  max-width: 72ch;
  margin: 0 auto;
}
.ns-redesign .ns-prose > * + * { margin-top: 1.4em; }
.ns-redesign .ns-prose h2 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(28px, 3vw, 38px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin-top: 2.2em;
  margin-bottom: 0.6em;
}
.ns-redesign .ns-prose h2 em,
.ns-redesign .ns-prose h2 i {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  color: var(--accent);
}
.ns-redesign .ns-prose h3 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(22px, 2.2vw, 26px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-top: 2em;
  margin-bottom: 0.5em;
}
.ns-redesign .ns-prose h4 {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 18px;
  line-height: 1.3;
  color: var(--ink);
  margin-top: 1.6em;
  margin-bottom: 0.4em;
}
.ns-redesign .ns-prose p { margin: 0; }
.ns-redesign .ns-prose a {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in oklab, var(--accent) 35%, transparent);
  transition: color 0.2s, border-color 0.2s;
}
.ns-redesign .ns-prose a:hover {
  color: var(--ink);
  border-color: var(--ink);
}
.ns-redesign .ns-prose strong { color: var(--ink); font-weight: 700; }
.ns-redesign .ns-prose ul,
.ns-redesign .ns-prose ol {
  padding-left: 0;
  list-style: none;
}
.ns-redesign .ns-prose ul li,
.ns-redesign .ns-prose ol li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 10px;
  line-height: 1.7;
}
.ns-redesign .ns-prose ul li::before {
  content: "—";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent);
  font-weight: 700;
}
.ns-redesign .ns-prose ol { counter-reset: prose-counter; }
.ns-redesign .ns-prose ol li {
  counter-increment: prose-counter;
}
.ns-redesign .ns-prose ol li::before {
  content: counter(prose-counter, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 0;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--accent);
  font-weight: 600;
  padding-top: 4px;
}
.ns-redesign .ns-prose blockquote {
  border-left: 3px solid var(--accent);
  padding: 8px 0 8px 24px;
  margin: 1.8em 0;
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.5;
  color: var(--ink);
}
.ns-redesign .ns-prose img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
  margin: 1.5em 0;
}
.ns-redesign .ns-prose figure { margin: 2em 0; }
.ns-redesign .ns-prose figure figcaption {
  margin-top: 12px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: center;
}
.ns-redesign .ns-prose code {
  background: color-mix(in oklab, var(--ink) 6%, var(--paper));
  padding: 2px 6px;
  border-radius: 4px;
  font-family: var(--mono);
  font-size: 0.9em;
  color: var(--ink);
}
.ns-redesign .ns-prose pre {
  background: var(--ink);
  color: var(--cream);
  padding: 20px;
  border-radius: 8px;
  overflow-x: auto;
  font-size: 14px;
  line-height: 1.6;
}
.ns-redesign .ns-prose pre code {
  background: none;
  padding: 0;
  color: inherit;
}
.ns-redesign .ns-prose table {
  width: 100%;
  border-collapse: collapse;
  margin: 2em 0;
  font-size: 15px;
}
.ns-redesign .ns-prose th,
.ns-redesign .ns-prose td {
  padding: 14px 16px;
  text-align: left;
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 12%, transparent);
}
.ns-redesign .ns-prose th {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
}
.ns-redesign .ns-prose hr {
  border: none;
  height: 1px;
  background: color-mix(in oklab, var(--ink) 12%, transparent);
  margin: 3em 0;
}

/* ── Default page Maritime — sectional layout ── */
.ns-redesign .ns-page-default .ns-prose {
  font-size: 18px;
}

/* Service page layout tweaks */
.ns-redesign .ns-service-page .contact-row { align-items: start; }
@media (max-width: 880px) {
  .ns-redesign .ns-service-page .contact-row { grid-template-columns: 1fr !important; gap: 32px !important; }
  .ns-redesign .ns-page-default .cta-final { padding: 32px 24px; }
}

/* responsive prose */
@media (max-width: 700px) {
  .ns-redesign .ns-prose { font-size: 16px; }
  .ns-redesign .ns-prose h2 { font-size: 26px; }
  .ns-redesign .ns-prose h3 { font-size: 20px; }
  .ns-redesign .ns-prose blockquote { font-size: 18px; padding-left: 18px; }
}

/* ============================================================
   FOOTER FORM MARITIME — visible sur toutes les pages (sauf home)
   ============================================================ */
.ns-redesign .ns-footer-form {
  background: linear-gradient(180deg, var(--paper) 0%, color-mix(in oklab, var(--accent-2) 8%, var(--paper)) 100%);
  padding: clamp(64px, 10vw, 120px) 0;
  border-top: 1px solid color-mix(in oklab, var(--ink) 8%, transparent);
  border-bottom: 1px solid color-mix(in oklab, var(--ink) 8%, transparent);
}
.ns-redesign .ns-footer-form__inner {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: start;
}
@media (max-width: 880px) {
  .ns-redesign .ns-footer-form__inner { grid-template-columns: 1fr; gap: 40px; }
}
.ns-redesign .ns-footer-form__copy .display-m {
  margin: 8px 0 16px;
  max-width: 18ch;
}
.ns-redesign .ns-footer-form__lead {
  color: var(--ink-soft);
  font-size: 17px;
  line-height: 1.65;
  max-width: 50ch;
  margin: 0 0 24px;
}
.ns-redesign .ns-footer-form__bullets {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: grid;
  gap: 8px;
  color: var(--ink);
  font-size: 15px;
}
.ns-redesign .ns-footer-form__phone {
  font-size: 15px;
  color: var(--ink-soft);
  margin: 0;
}
.ns-redesign .ns-footer-form__phone a {
  color: var(--ink);
  border-bottom: 1px solid color-mix(in oklab, var(--accent) 50%, transparent);
  text-decoration: none;
  transition: color 0.2s, border-color 0.2s;
}
.ns-redesign .ns-footer-form__phone a:hover {
  color: var(--accent);
  border-color: var(--accent);
}

.ns-redesign .ns-footer-form__form {
  background: #fff;
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  border-radius: 16px;
  padding: clamp(28px, 3vw, 40px);
  box-shadow: 0 30px 60px -30px color-mix(in oklab, var(--ink) 25%, transparent);
  position: relative;
  overflow: hidden;
}
.ns-redesign .ns-footer-form__form::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent) 0%, var(--accent-2) 50%, var(--accent) 100%);
  background-size: 200% 100%;
  animation: ns-gradient-move 4s ease infinite;
}
@keyframes ns-gradient-move {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}
.ns-redesign .ns-footer-form__row {
  display: grid;
  gap: 16px;
  margin-bottom: 16px;
}
.ns-redesign .ns-footer-form__row--2 {
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 600px) {
  .ns-redesign .ns-footer-form__row--2 { grid-template-columns: 1fr; }
}
.ns-redesign .ns-footer-form__form .field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}
.ns-redesign .ns-footer-form__form .field__label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 600;
}
.ns-redesign .ns-footer-form__form input,
.ns-redesign .ns-footer-form__form select,
.ns-redesign .ns-footer-form__form textarea {
  width: 100%;
  padding: 12px 14px;
  font-family: var(--sans);
  font-size: 15px;
  color: var(--ink);
  background: #fff;
  border: 1px solid color-mix(in oklab, var(--ink) 18%, transparent);
  border-radius: 8px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.ns-redesign .ns-footer-form__form input:focus,
.ns-redesign .ns-footer-form__form select:focus,
.ns-redesign .ns-footer-form__form textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent);
}
.ns-redesign .ns-footer-form__form textarea {
  resize: vertical;
  min-height: 90px;
}
.ns-redesign .ns-footer-form__form .cta-pill--full {
  margin-top: 8px;
}
.ns-redesign .ns-footer-form__note {
  font-size: 12px;
  color: var(--muted);
  text-align: center;
  margin: 12px 0 0;
}

.ns-redesign .ns-footer-form__success {
  background: #fff;
  border: 1px solid color-mix(in oklab, var(--ink) 10%, transparent);
  border-radius: 16px;
  padding: 48px 32px;
  text-align: center;
}
.ns-redesign .ns-footer-form__success-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, #059669, #10b981);
  color: #fff;
  font-size: 32px;
  border-radius: 50%;
  margin-bottom: 16px;
}
.ns-redesign .ns-footer-form__success h3 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 22px;
  color: var(--ink);
  margin: 0 0 8px;
}
.ns-redesign .ns-footer-form__success p {
  color: var(--ink-soft);
  margin: 0;
}

/* ============================================================
   NAV LINKEDIN BUTTON — visible sur tout le site dans la pill nav
   ============================================================ */
.ns-redesign .nav-linkedin {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: color-mix(in oklab, var(--ink) 6%, transparent);
  color: var(--ink);
  text-decoration: none;
  transition: background 0.2s, color 0.2s, transform 0.2s;
  flex-shrink: 0;
}
.ns-redesign .nav-linkedin:hover {
  background: #0a66c2;
  color: #fff;
  transform: translateY(-1px);
}
.ns-redesign .nav-linkedin svg {
  width: 16px;
  height: 16px;
}
@media (max-width: 980px) {
  .ns-redesign .nav-linkedin { display: none; }
}

/* LinkedIn ghost button (.cta-pill--ghost.ns-cta--linkedin) — uniformiser SVG + label */
.ns-redesign .ns-cta--linkedin {
  gap: 8px;
}
.ns-redesign .ns-cta--linkedin:hover {
  background: #0a66c2;
  border-color: #0a66c2;
  color: #fff;
}
.ns-redesign .ns-cta--linkedin svg {
  flex-shrink: 0;
}

