/* =========================================================
   WHITE NOVA — DESIGN SYSTEM
   Premium minimal B2B agency
   ========================================================= */

/* ---------- FONTS ----------
   Space Grotesk : hiérarchie forte, titres, chiffres, UI
   Lemon Milk    : usage SIGNATURE uniquement (watermarks, accents)
   Inter (system fallback): corps de texte si besoin
   -------------------------------------------------------- */

@font-face {
  font-family: 'Space Grotesk';
  src: url('../fonts/SpaceGrotesk-Light.woff2') format('woff2');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Space Grotesk';
  src: url('../fonts/SpaceGrotesk-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Space Grotesk';
  src: url('../fonts/SpaceGrotesk-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Space Grotesk';
  src: url('../fonts/SpaceGrotesk-SemiBold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Space Grotesk';
  src: url('../fonts/SpaceGrotesk-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Lemon Milk';
  src: url('../fonts/LEMONMILK-Light.woff2') format('woff2');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Lemon Milk';
  src: url('../fonts/LEMONMILK-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Lemon Milk';
  src: url('../fonts/LEMONMILK-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Lemon Milk';
  src: url('../fonts/LEMONMILK-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ---------- TOKENS ---------- */
:root {
  /* Brand — cold digital grey */
  --wn-bg: #d7d9d4;
  --wn-bg-soft: #dfe0dc;
  --wn-bg-deep: #cbccc7;
  --wn-bg-cool: #c5c7c2;
  --wn-ink: #0a0a0a;
  --wn-ink-pure: #000000;
  --wn-ink-80: rgba(10, 10, 10, 0.82);
  --wn-ink-70: rgba(10, 10, 10, 0.72);
  --wn-ink-55: rgba(10, 10, 10, 0.52);
  --wn-ink-35: rgba(10, 10, 10, 0.32);
  --wn-ink-15: rgba(10, 10, 10, 0.13);
  --wn-ink-08: rgba(10, 10, 10, 0.07);
  --wn-ink-04: rgba(10, 10, 10, 0.04);

  /* Accent replaced by pure monochrome system */
  --wn-accent: #0a0a0a;
  --wn-accent-soft: #1a1a1a;
  --wn-accent-deep: #000000;
  --wn-accent-tint: rgba(10, 10, 10, 0.06);
  --wn-accent-line: rgba(10, 10, 10, 0.22);

  /* Typography */
  --font-display: 'Space Grotesk', 'Helvetica Neue', Arial, sans-serif;
  --font-body: 'Space Grotesk', 'Helvetica Neue', Arial, sans-serif;
  --font-signature: 'Lemon Milk', 'Space Grotesk', 'Helvetica Neue', Arial, sans-serif;

  /* Scale */
  --fs-mega: clamp(3.5rem, 9vw, 8rem);
  --fs-hero: clamp(2.75rem, 6.5vw, 6rem);
  --fs-h1: clamp(2.25rem, 4.5vw, 4rem);
  --fs-h2: clamp(1.75rem, 3.2vw, 2.75rem);
  --fs-h3: clamp(1.25rem, 1.9vw, 1.65rem);
  --fs-h4: clamp(1.05rem, 1.4vw, 1.2rem);
  --fs-body: clamp(0.95rem, 1.05vw, 1.05rem);
  --fs-small: 0.82rem;
  --fs-micro: 0.72rem;

  /* Spacing */
  --sp-1: 0.25rem; --sp-2: 0.5rem; --sp-3: 0.75rem; --sp-4: 1rem;
  --sp-5: 1.5rem; --sp-6: 2rem; --sp-7: 3rem; --sp-8: 4rem;
  --sp-9: 6rem; --sp-10: 8rem; --sp-11: 10rem;

  /* Radii */
  --r-sm: 6px; --r-md: 12px; --r-lg: 20px; --r-pill: 999px;

  /* Motion */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.76, 0, 0.24, 1);
  --ease-smooth: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-soft: cubic-bezier(0.4, 0, 0.2, 1);
  --d-fast: 280ms;
  --d-base: 560ms;
  --d-slow: 900ms;
  --d-xslow: 1400ms;

  /* Layout */
  --container: 1320px;
  --gutter: clamp(1.25rem, 4vw, 2.5rem);
  --header-h: 72px;

  /* Shadow */
  --shadow-1: 0 1px 2px rgba(0,0,0,0.05), 0 4px 14px rgba(0,0,0,0.04);
  --shadow-2: 0 8px 28px rgba(0,0,0,0.09), 0 2px 6px rgba(0,0,0,0.05);
  --shadow-focus: 0 0 0 3px rgba(10, 10, 10, 0.15);
}

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
img, svg, video { display: block; max-width: 100%; height: auto; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; padding: 0; }
a { color: inherit; text-decoration: none; }
ul, ol { margin: 0; padding: 0; list-style: none; }
input, textarea, select { font: inherit; color: inherit; }

/* ---------- BASE ---------- */
body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.6;
  color: var(--wn-ink);
  background: var(--wn-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  background-image:
    radial-gradient(rgba(0,0,0,0.035) 1px, transparent 1px);
  background-size: 3px 3px;
}

::selection { background: var(--wn-accent); color: var(--wn-bg); }

/* ---------- TYPOGRAPHY ---------- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0;
  color: var(--wn-ink);
}
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); line-height: 1.08; }
h3 { font-size: var(--fs-h3); line-height: 1.2; }
h4 { font-size: var(--fs-h4); line-height: 1.3; letter-spacing: -0.01em; }
p { margin: 0 0 1em; color: var(--wn-ink-70); }
strong { font-weight: 600; color: var(--wn-ink); }
em { font-style: italic; }
small { font-size: var(--fs-small); color: var(--wn-ink-55); }

.eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-micro);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}
.eyebrow::before {
  content: '';
  width: 28px;
  height: 1px;
  background: var(--wn-ink-35);
}
.eyebrow.is-accent { color: var(--wn-accent); }
.eyebrow.is-accent::before { background: var(--wn-accent); }

.display {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-hero);
  line-height: 0.98;
  letter-spacing: -0.035em;
}
.mega {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-mega);
  line-height: 0.9;
  letter-spacing: -0.045em;
}
.lede {
  font-family: var(--font-body);
  font-size: clamp(1.05rem, 1.3vw, 1.25rem);
  line-height: 1.55;
  color: var(--wn-ink-70);
  max-width: 62ch;
  font-weight: 400;
}

.accent { color: var(--wn-accent); }
.ink-55 { color: var(--wn-ink-55); }
.text-balance { text-wrap: balance; }

/* ---------- LAYOUT ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-inline: var(--gutter);
}
.section { padding-block: clamp(4rem, 9vw, 8rem); position: relative; }
.section--tight { padding-block: clamp(3rem, 6vw, 5rem); }
.section--hero { padding-top: calc(var(--header-h) + clamp(3rem, 7vw, 6rem)); padding-bottom: clamp(4rem, 8vw, 7rem); }

.divider {
  border: 0;
  border-top: 1px solid var(--wn-ink-15);
  margin: 0;
}

.grid { display: grid; gap: var(--sp-5); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-2-3 { grid-template-columns: 2fr 3fr; gap: clamp(2rem, 6vw, 5rem); }
.grid-1-2 { grid-template-columns: 1fr 2fr; gap: clamp(2rem, 6vw, 5rem); }

@media (max-width: 900px) {
  .grid-2, .grid-3, .grid-4, .grid-2-3, .grid-1-2 { grid-template-columns: 1fr; }
}

/* ---------- HEADER ---------- */
.header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  height: var(--header-h);
  display: flex;
  align-items: center;
  background: rgba(217, 215, 212, 0);
  backdrop-filter: blur(0);
  -webkit-backdrop-filter: blur(0);
  transition: background var(--d-base) var(--ease-out),
              backdrop-filter var(--d-base) var(--ease-out),
              border-color var(--d-base) var(--ease-out);
  border-bottom: 1px solid transparent;
}
.header.is-scrolled {
  background: rgba(217, 215, 212, 0.82);
  backdrop-filter: blur(14px) saturate(120%);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  border-bottom-color: var(--wn-ink-08);
}
.header__inner {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-5);
}
.header__logo {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: -0.01em;
}
.header__logo img,
.header__logo svg { height: 22px; width: auto; }
.header__logo .logo-txt {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: 0.02em;
  font-size: 1.02rem;
}

.nav { display: flex; align-items: center; gap: clamp(1rem, 2vw, 2rem); }
.nav__link {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.92rem;
  position: relative;
  padding: 0.3rem 0;
  color: var(--wn-ink);
  transition: color var(--d-fast) var(--ease-out);
}
.nav__link::after {
  content: '';
  position: absolute;
  left: 0; bottom: 0;
  width: 100%;
  height: 1px;
  background: var(--wn-ink);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform var(--d-base) var(--ease-out);
}
.nav__link:hover::after,
.nav__link.is-active::after { transform: scaleX(1); transform-origin: left; }
.nav__link.is-active { color: var(--wn-accent); }

.header__right { display: flex; align-items: center; gap: var(--sp-4); }

.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.82rem;
  letter-spacing: 0.05em;
  color: var(--wn-ink-55);
}
.lang-switch a {
  padding: 0.2rem 0.4rem;
  border-radius: var(--r-sm);
  transition: color var(--d-fast) var(--ease-out);
}
.lang-switch a.is-active { color: var(--wn-ink); font-weight: 600; }
.lang-switch a:hover { color: var(--wn-accent); }
.lang-switch .sep { opacity: 0.4; }

.menu-toggle {
  display: none;
  width: 40px; height: 40px;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-sm);
  transition: background var(--d-fast) var(--ease-out);
}
.menu-toggle:hover { background: var(--wn-ink-08); }
.menu-toggle span {
  display: block;
  width: 22px; height: 1.5px;
  background: var(--wn-ink);
  position: relative;
  transition: transform var(--d-base) var(--ease-out), background var(--d-base) var(--ease-out);
}
.menu-toggle span::before,
.menu-toggle span::after {
  content: '';
  position: absolute;
  left: 0;
  width: 22px; height: 1.5px;
  background: var(--wn-ink);
  transition: transform var(--d-base) var(--ease-out);
}
.menu-toggle span::before { top: -7px; }
.menu-toggle span::after { top: 7px; }
.is-menu-open .menu-toggle span { background: transparent; }
.is-menu-open .menu-toggle span::before { transform: translateY(7px) rotate(45deg); }
.is-menu-open .menu-toggle span::after { transform: translateY(-7px) rotate(-45deg); }

/* Mobile panel */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--wn-bg);
  z-index: 95;
  display: flex;
  flex-direction: column;
  padding: calc(var(--header-h) + 2rem) var(--gutter) 2rem;
  transform: translateY(-100%);
  transition: transform var(--d-slow) var(--ease-in-out);
  pointer-events: none;
  overflow-y: auto;
}
.is-menu-open .mobile-menu {
  transform: translateY(0);
  pointer-events: auto;
}
.mobile-menu__nav { display: flex; flex-direction: column; gap: 0; }
.mobile-menu__nav a {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.6rem, 6vw, 2.4rem);
  letter-spacing: -0.02em;
  padding: 0.9rem 0;
  border-bottom: 1px solid var(--wn-ink-15);
  opacity: 0;
  transform: translateY(14px);
  transition: opacity var(--d-base) var(--ease-out), transform var(--d-base) var(--ease-out), color var(--d-fast) var(--ease-out);
}
.mobile-menu__nav a:hover { color: var(--wn-accent); }
.is-menu-open .mobile-menu__nav a { opacity: 1; transform: translateY(0); }
.is-menu-open .mobile-menu__nav a:nth-child(1) { transition-delay: 120ms; }
.is-menu-open .mobile-menu__nav a:nth-child(2) { transition-delay: 180ms; }
.is-menu-open .mobile-menu__nav a:nth-child(3) { transition-delay: 240ms; }
.is-menu-open .mobile-menu__nav a:nth-child(4) { transition-delay: 300ms; }
.is-menu-open .mobile-menu__nav a:nth-child(5) { transition-delay: 360ms; }
.is-menu-open .mobile-menu__nav a:nth-child(6) { transition-delay: 420ms; }
.is-menu-open .mobile-menu__nav a:nth-child(7) { transition-delay: 480ms; }

.mobile-menu__foot {
  margin-top: auto;
  padding-top: 2rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--wn-ink-55);
  font-size: var(--fs-small);
}

@media (max-width: 900px) {
  .nav, .header__right .lang-switch { display: none; }
  .menu-toggle { display: inline-flex; }
  .header__right { gap: 0.5rem; }
}

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  padding: 0.95rem 1.5rem;
  border-radius: var(--r-pill);
  line-height: 1;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid transparent;
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
  transition: transform 500ms var(--ease-out),
              color 420ms var(--ease-out),
              background 420ms var(--ease-out),
              border-color 420ms var(--ease-out);
}
.btn .arr {
  display: inline-block;
  transition: transform 500ms var(--ease-out);
  will-change: transform;
}
.btn:hover .arr { transform: translateX(5px); }
.btn:active { transform: scale(0.97); }

/* Primary — solid black / invert to light on hover via fill */
.btn--primary {
  background: var(--wn-ink);
  color: var(--wn-bg);
  border-color: var(--wn-ink);
}
.btn--primary::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--wn-bg);
  z-index: -1;
  transform: translateY(101%);
  transition: transform 700ms var(--ease-out);
}
.btn--primary:hover::before { transform: translateY(0); }
.btn--primary:hover { color: var(--wn-ink); }

/* Ghost — outline, fills black on hover */
.btn--ghost {
  background: transparent;
  color: var(--wn-ink);
  border-color: var(--wn-ink-35);
}
.btn--ghost::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--wn-ink);
  z-index: -1;
  transform: translateY(101%);
  transition: transform 700ms var(--ease-out);
}
.btn--ghost:hover::before { transform: translateY(0); }
.btn--ghost:hover { color: var(--wn-bg); border-color: var(--wn-ink); }

/* Accent — now identical to primary (no blue). Kept for markup back-compat. */
.btn--accent {
  background: var(--wn-ink);
  color: var(--wn-bg);
  border-color: var(--wn-ink);
}
.btn--accent::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--wn-bg);
  z-index: -1;
  transform: translateY(101%);
  transition: transform 700ms var(--ease-out);
}
.btn--accent:hover::before { transform: translateY(0); }
.btn--accent:hover { color: var(--wn-ink); }

/* Inverted on dark backgrounds */
.section--dark .btn--primary,
.section--dark .btn--accent {
  background: var(--wn-bg);
  color: var(--wn-ink);
  border-color: var(--wn-bg);
}
.section--dark .btn--primary::before,
.section--dark .btn--accent::before { background: var(--wn-ink); }
.section--dark .btn--primary:hover,
.section--dark .btn--accent:hover { color: var(--wn-bg); }
.section--dark .btn--ghost {
  color: var(--wn-bg);
  border-color: rgba(255,255,255,0.28);
}
.section--dark .btn--ghost::before { background: var(--wn-bg); }
.section--dark .btn--ghost:hover { color: var(--wn-ink); border-color: var(--wn-bg); }

.btn--small { padding: 0.65rem 1.1rem; font-size: 0.8rem; }
.btn--large { padding: 1.1rem 1.9rem; font-size: 0.95rem; }

.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-weight: 500;
  font-size: 0.95rem;
  color: var(--wn-ink);
  padding-bottom: 2px;
  border-bottom: 1px solid var(--wn-ink);
  transition: gap var(--d-base) var(--ease-out), color var(--d-fast) var(--ease-out), border-color var(--d-fast) var(--ease-out);
}
.link-arrow:hover { gap: 0.9rem; color: var(--wn-accent); border-color: var(--wn-accent); }

/* ---------- HERO ---------- */
.hero {
  position: relative;
  padding-top: calc(var(--header-h) + clamp(3rem, 8vw, 5rem));
  padding-bottom: clamp(4rem, 8vw, 7rem);
}
.hero__eyebrow { margin-bottom: 1.5rem; }
.hero__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-hero);
  line-height: 0.96;
  letter-spacing: -0.04em;
  max-width: 14ch;
}
.hero__title .accent { color: var(--wn-accent); }
.hero__sub {
  margin-top: clamp(1.25rem, 2.5vw, 2rem);
  max-width: 56ch;
  font-size: clamp(1rem, 1.2vw, 1.15rem);
  color: var(--wn-ink-70);
  line-height: 1.55;
}
.hero__cta {
  margin-top: clamp(2rem, 4vw, 3rem);
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}
.hero__meta {
  margin-top: clamp(3rem, 6vw, 5rem);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-5);
  border-top: 1px solid var(--wn-ink-15);
  padding-top: 1.75rem;
}
.hero__meta > div { display: flex; flex-direction: column; gap: 0.25rem; }
.hero__meta .k { font-family: var(--font-display); font-size: clamp(1.4rem, 2.2vw, 2.1rem); font-weight: 500; letter-spacing: -0.02em; }
.hero__meta .v { font-size: 0.8rem; color: var(--wn-ink-55); text-transform: uppercase; letter-spacing: 0.14em; }
@media (max-width: 800px) { .hero__meta { grid-template-columns: repeat(2, 1fr); } }

/* ---------- CARD ---------- */
.card {
  position: relative;
  background: var(--wn-bg-soft);
  border: 1px solid var(--wn-ink-08);
  border-radius: var(--r-lg);
  padding: clamp(1.5rem, 2.5vw, 2rem);
  transition: transform var(--d-base) var(--ease-out),
              border-color var(--d-base) var(--ease-out),
              box-shadow var(--d-base) var(--ease-out),
              background var(--d-base) var(--ease-out);
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
.card::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  background: var(--wn-accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--d-slow) var(--ease-out);
}
.card:hover {
  transform: translateY(-4px);
  border-color: var(--wn-ink-15);
  box-shadow: var(--shadow-2);
  background: #eceae7;
}
.card:hover::after { transform: scaleX(1); }
.card__index {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--wn-accent);
  letter-spacing: 0.08em;
}
.card__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.3rem, 1.8vw, 1.55rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
}
.card__desc { color: var(--wn-ink-70); font-size: 0.95rem; line-height: 1.6; margin: 0; }
.card__list { display: flex; flex-direction: column; gap: 0.4rem; margin-top: 0.4rem; }
.card__list li { font-size: 0.9rem; color: var(--wn-ink-70); padding-left: 1rem; position: relative; }
.card__list li::before {
  content: '';
  position: absolute;
  left: 0; top: 0.75em;
  width: 8px; height: 1px;
  background: var(--wn-accent);
}
.card__foot {
  margin-top: auto;
  padding-top: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.card--dark {
  background: var(--wn-ink);
  color: var(--wn-bg);
  border-color: var(--wn-ink);
}
.card--dark .card__title,
.card--dark h3, .card--dark h4 { color: var(--wn-bg); }
.card--dark .card__desc { color: rgba(217, 215, 212, 0.72); }
.card--dark:hover { background: var(--wn-accent-deep); border-color: var(--wn-accent-deep); }

/* ---------- FEATURE / SERVICE ROW ---------- */
.service-row {
  display: grid;
  grid-template-columns: 80px 1fr 1fr auto;
  gap: clamp(1rem, 3vw, 2.5rem);
  align-items: start;
  padding: clamp(1.75rem, 3vw, 2.5rem) 0;
  border-top: 1px solid var(--wn-ink-15);
  transition: background var(--d-base) var(--ease-out);
  position: relative;
}
.service-row:last-child { border-bottom: 1px solid var(--wn-ink-15); }
.service-row:hover { background: var(--wn-bg-soft); }
.service-row:hover .service-row__title { color: var(--wn-accent); }
.service-row__num {
  font-family: var(--font-display);
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  color: var(--wn-ink-55);
  padding-top: 0.5rem;
}
.service-row__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  transition: color var(--d-base) var(--ease-out);
}
.service-row__desc { color: var(--wn-ink-70); font-size: 0.98rem; line-height: 1.6; margin: 0; }
.service-row__arr {
  align-self: center;
  width: 44px; height: 44px;
  border-radius: 999px;
  border: 1px solid var(--wn-ink-15);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all var(--d-base) var(--ease-out);
}
.service-row:hover .service-row__arr {
  background: var(--wn-accent);
  border-color: var(--wn-accent);
  color: var(--wn-bg);
}
@media (max-width: 900px) {
  .service-row { grid-template-columns: 1fr; gap: 0.6rem; padding: 1.5rem 0; }
  .service-row__num { padding-top: 0; }
  .service-row__arr { display: none; }
}

/* ---------- STEP / METHOD ---------- */
.step {
  display: grid;
  grid-template-columns: 120px 1fr;
  grid-template-areas:
    "num  title"
    "num  body";
  gap: clamp(0.5rem, 1.5vw, 1rem) clamp(1rem, 3vw, 3rem);
  align-items: start;
  padding: clamp(2rem, 4vw, 3rem) 0;
  border-top: 1px solid var(--wn-ink-15);
}
.step:last-child { border-bottom: 1px solid var(--wn-ink-15); }
.step__num {
  grid-area: num;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.2rem, 4.5vw, 3.8rem);
  letter-spacing: -0.02em;
  color: var(--wn-accent);
  line-height: 1;
}
.step h3, .step__title {
  grid-area: title;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.3rem, 2.2vw, 1.75rem);
  line-height: 1.2;
  letter-spacing: -0.015em;
  margin: 0 0 0.5rem;
}
.step p, .step__body {
  grid-area: body;
  color: var(--wn-ink-70);
  max-width: 65ch;
  line-height: 1.6;
  margin: 0;
  font-size: 0.96rem;
}
@media (max-width: 680px) {
  .step {
    grid-template-columns: 1fr;
    grid-template-areas: "num" "title" "body";
    gap: 0.75rem;
  }
}
.step__tags { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: 1rem; }
.step__tags span {
  font-family: var(--font-body);
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
  border: 1px solid var(--wn-ink-15);
  border-radius: var(--r-pill);
  padding: 0.35rem 0.7rem;
}
@media (max-width: 700px) { .step { grid-template-columns: 1fr; gap: 0.5rem; } }

/* ---------- CASE ---------- */
.case {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: var(--r-lg);
  background: var(--wn-bg-soft);
  border: 1px solid var(--wn-ink-08);
  padding: clamp(1.75rem, 2.5vw, 2.25rem);
  transition: transform var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out), background var(--d-base) var(--ease-out);
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.case:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); background: #eceae7; }
.case__visual {
  aspect-ratio: 16 / 10;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, #3a2f22 0%, #8b6f47 60%, #a88a5f 100%);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: 1rem;
  color: var(--wn-bg);
}
.case__visual::before {
  content: '';
  position: absolute;
  inset: -2px;
  background:
    radial-gradient(circle at 25% 20%, rgba(255,255,255,0.18), transparent 45%),
    radial-gradient(circle at 75% 80%, rgba(0,0,0,0.35), transparent 55%);
  pointer-events: none;
}
.case__visual--alt1 { background: linear-gradient(135deg, #0a0a0a, #2a2a2a 70%, #444); }
.case__visual--alt2 { background: linear-gradient(135deg, #8b6f47 0%, #cfcdca 100%); color: #0a0a0a; }
.case__visual--alt3 { background: linear-gradient(135deg, #3a3a3a 0%, #8b6f47 100%); }
.case__visual--alt4 { background: linear-gradient(160deg, #6b5333 0%, #cfcdca 120%); }
.case__visual--alt5 { background: linear-gradient(135deg, #000 0%, #8b6f47 100%); }
.case__visual__mark {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  letter-spacing: -0.03em;
  line-height: 1;
  position: relative;
  z-index: 2;
}
.case__meta {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-body);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
}
.case__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.25rem, 1.7vw, 1.45rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
}
.case__desc { color: var(--wn-ink-70); margin: 0; font-size: 0.94rem; }
.case__kpis { display: flex; gap: 1.25rem; margin-top: auto; padding-top: 0.5rem; }
.case__kpi { display: flex; flex-direction: column; gap: 0.1rem; }
.case__kpi .k {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
  color: var(--wn-accent);
}
.case__kpi .v {
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
}

/* ---------- FAQ ---------- */
.faq { border-top: 1px solid var(--wn-ink-15); }
.faq__item { border-bottom: 1px solid var(--wn-ink-15); }
.faq__q {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  text-align: left;
  padding: 1.5rem 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  letter-spacing: -0.01em;
  transition: color var(--d-base) var(--ease-out);
  cursor: pointer;
}
.faq__q:hover { color: var(--wn-accent); }
.faq__icn {
  flex: 0 0 auto;
  width: 28px; height: 28px;
  border-radius: 999px;
  border: 1px solid var(--wn-ink-35);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  line-height: 1;
  position: relative;
  transition: all var(--d-base) var(--ease-out);
}
.faq__icn::before, .faq__icn::after {
  content: '';
  position: absolute;
  background: var(--wn-ink);
  transition: transform var(--d-base) var(--ease-out), background var(--d-base) var(--ease-out);
}
.faq__icn::before { width: 10px; height: 1.5px; }
.faq__icn::after { width: 1.5px; height: 10px; }
.faq__item.is-open .faq__icn { background: var(--wn-accent); border-color: var(--wn-accent); }
.faq__item.is-open .faq__icn::before,
.faq__item.is-open .faq__icn::after { background: #fff; }
.faq__item.is-open .faq__icn::after { transform: rotate(90deg); }
.faq__a {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--d-slow) var(--ease-in-out);
}
.faq__a > div {
  padding: 0 0 1.5rem;
  max-width: 78ch;
  color: var(--wn-ink-70);
  line-height: 1.65;
}
.faq__item.is-open .faq__a { max-height: 640px; }

/* ---------- MARQUEE ---------- */
.marquee {
  overflow: hidden;
  border-top: 1px solid var(--wn-ink-15);
  border-bottom: 1px solid var(--wn-ink-15);
  padding: 1.25rem 0;
  position: relative;
}
.marquee__track {
  display: flex;
  gap: 3rem;
  white-space: nowrap;
  animation: marquee 48s linear infinite;
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.2vw, 1.9rem);
  font-weight: 400;
  letter-spacing: -0.015em;
  color: var(--wn-ink-55);
}
.marquee__track span::after {
  content: '●';
  margin-left: 3rem;
  color: var(--wn-accent);
  font-size: 0.5em;
  vertical-align: middle;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ---------- FORM ---------- */
.form { display: grid; gap: 1.25rem; }
.form__row { display: grid; gap: 1.25rem; grid-template-columns: 1fr 1fr; }
@media (max-width: 700px) { .form__row { grid-template-columns: 1fr; } }
.field { display: flex; flex-direction: column; gap: 0.45rem; }
.field label {
  font-family: var(--font-body);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
  font-weight: 500;
}
.field input, .field textarea, .field select {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--wn-ink-35);
  padding: 0.65rem 0;
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--wn-ink);
  transition: border-color var(--d-base) var(--ease-out);
  outline: none;
}
.field input:focus, .field textarea:focus, .field select:focus { border-color: var(--wn-accent); }
.field textarea { min-height: 140px; resize: vertical; }

/* ---------- CONTACT BLOCK ---------- */
.contact-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
@media (max-width: 900px) { .contact-block { grid-template-columns: 1fr; } }
.contact-list { display: flex; flex-direction: column; gap: 1.5rem; }
.contact-list__item { display: flex; flex-direction: column; gap: 0.15rem; }
.contact-list__item .k {
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
}
.contact-list__item .v {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.35rem;
  letter-spacing: -0.01em;
}

/* ---------- CTA BLOCK ---------- */
.cta-block {
  background: var(--wn-ink);
  color: var(--wn-bg);
  border-radius: var(--r-lg);
  padding: clamp(2.5rem, 6vw, 5rem);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 2rem;
  position: relative;
  overflow: hidden;
}
.cta-block::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 88% 50%, rgba(139, 111, 71, 0.55), transparent 55%);
  pointer-events: none;
}
.cta-block h2 {
  color: var(--wn-bg);
  font-size: clamp(1.8rem, 3.6vw, 3rem);
  letter-spacing: -0.03em;
  line-height: 1.05;
  max-width: 22ch;
  position: relative;
}
.cta-block .btn { position: relative; }
.cta-block .btn--primary { background: var(--wn-bg); color: var(--wn-ink); }
.cta-block .btn--primary::before { background: var(--wn-accent); }
.cta-block .btn--primary:hover { color: #fff; }
@media (max-width: 800px) { .cta-block { grid-template-columns: 1fr; } }

/* ---------- FOOTER ---------- */
.footer {
  border-top: 1px solid var(--wn-ink-15);
  padding: clamp(3rem, 6vw, 5rem) 0 1.5rem;
  margin-top: clamp(3rem, 6vw, 5rem);
  font-size: 0.92rem;
}
.footer__top {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap: 2rem;
  align-items: start;
  padding-bottom: 3rem;
}
.footer__brand { display: flex; flex-direction: column; gap: 1rem; max-width: 32ch; }
.footer__brand .logo {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.1rem;
  letter-spacing: 0.01em;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.footer__brand p { color: var(--wn-ink-70); font-size: 0.9rem; line-height: 1.55; margin: 0; }
.footer__col h5 {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
  margin-bottom: 1rem;
}
.footer__col ul { display: flex; flex-direction: column; gap: 0.55rem; }
.footer__col a {
  font-family: var(--font-body);
  font-size: 0.92rem;
  color: var(--wn-ink);
  transition: color var(--d-fast) var(--ease-out);
}
.footer__col a:hover { color: var(--wn-accent); }
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--wn-ink-15);
  color: var(--wn-ink-55);
  font-size: 0.8rem;
  flex-wrap: wrap;
}
.footer__bottom a:hover { color: var(--wn-accent); }
.footer__mega {
  font-family: var(--font-display);
  font-size: clamp(4rem, 18vw, 18rem);
  font-weight: 500;
  letter-spacing: -0.05em;
  line-height: 0.9;
  color: var(--wn-ink);
  opacity: 0.08;
  margin: 2rem 0 -0.15em;
  user-select: none;
  pointer-events: none;
  text-align: center;
}
@media (max-width: 900px) { .footer__top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .footer__top { grid-template-columns: 1fr; } }

/* ---------- SECTION HEADER ---------- */
.section-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: end;
  margin-bottom: clamp(2rem, 4vw, 3.5rem);
}
@media (max-width: 800px) { .section-head { grid-template-columns: 1fr; align-items: start; } }
.section-head h2 { font-size: clamp(1.9rem, 3.4vw, 3rem); letter-spacing: -0.025em; max-width: 20ch; }
.section-head__right { color: var(--wn-ink-70); max-width: 58ch; }

/* ---------- DEEP SECTION ---------- */
.section--dark {
  background: var(--wn-ink);
  color: var(--wn-bg);
}
.section--dark h1, .section--dark h2, .section--dark h3, .section--dark h4 { color: var(--wn-bg); }
.section--dark p { color: rgba(217, 215, 212, 0.72); }
.section--dark .eyebrow { color: rgba(217, 215, 212, 0.55); }
.section--dark .eyebrow::before { background: rgba(217, 215, 212, 0.35); }
.section--dark .divider { border-color: rgba(217, 215, 212, 0.15); }
.section--dark .case, .section--dark .card { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.08); color: var(--wn-bg); }
.section--dark .case:hover, .section--dark .card:hover { background: rgba(255,255,255,0.05); }
.section--dark .case__desc, .section--dark .card__desc { color: rgba(217, 215, 212, 0.7); }

/* ---------- UTILITIES ---------- */
.u-mt-0 { margin-top: 0; }
.u-mb-0 { margin-bottom: 0; }
.u-ta-center { text-align: center; }
.u-max-60 { max-width: 60ch; }
.u-max-70 { max-width: 70ch; }
.u-flex { display: flex; gap: 1rem; flex-wrap: wrap; }
.u-flex-col { display: flex; flex-direction: column; gap: 1rem; }

/* Pills */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.8rem;
  border: 1px solid var(--wn-ink-15);
  border-radius: var(--r-pill);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--wn-ink-70);
  background: var(--wn-bg-soft);
}
.pill .dot {
  width: 6px; height: 6px; border-radius: 999px; background: var(--wn-accent);
  box-shadow: 0 0 0 0 rgba(139,111,71,0.5);
  animation: pulse 2.4s ease-out infinite;
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(139,111,71,0.45); }
  70% { box-shadow: 0 0 0 8px rgba(139,111,71,0); }
  100% { box-shadow: 0 0 0 0 rgba(139,111,71,0); }
}

/* Grid lines decorative */
.grid-lines {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, var(--wn-ink-08) 1px, transparent 1px);
  background-size: calc(100% / 12) 100%;
  pointer-events: none;
  opacity: 0.5;
  mask-image: linear-gradient(to bottom, transparent, black 20%, black 80%, transparent);
}

/* Scroll progress */
.scroll-prog {
  position: fixed;
  top: 0; left: 0;
  height: 2px;
  width: 0%;
  background: var(--wn-accent);
  z-index: 200;
  transition: width 80ms linear;
}

/* Breadcrumb */
.breadcrumb {
  display: flex;
  gap: 0.5rem;
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
  margin-bottom: 1.5rem;
}
.breadcrumb a { color: var(--wn-ink-55); transition: color var(--d-fast) var(--ease-out); }
.breadcrumb a:hover { color: var(--wn-accent); }
.breadcrumb span { color: var(--wn-ink-35); }

/* Large quote */
.quote {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.6rem, 2.8vw, 2.3rem);
  line-height: 1.25;
  letter-spacing: -0.02em;
  max-width: 30ch;
}
.quote__src {
  margin-top: 1.25rem;
  font-family: var(--font-body);
  font-size: 0.82rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
}

/* Prose */
.prose { max-width: 72ch; }
.prose h2 { margin: 2.5rem 0 0.75rem; font-size: clamp(1.4rem, 2vw, 1.75rem); }
.prose h3 { margin: 2rem 0 0.5rem; font-size: clamp(1.15rem, 1.4vw, 1.35rem); }
.prose p { color: var(--wn-ink-70); line-height: 1.7; margin: 0 0 1em; }
.prose ul { margin: 1em 0; padding-left: 0; display: flex; flex-direction: column; gap: 0.5rem; }
.prose ul li { padding-left: 1.5rem; position: relative; color: var(--wn-ink-70); }
.prose ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 0.8em;
  width: 14px; height: 1px;
  background: var(--wn-accent);
}
.prose a { color: var(--wn-accent); border-bottom: 1px solid currentColor; }
.prose strong { color: var(--wn-ink); }

/* Stats row */
.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--wn-ink-15);
  border: 1px solid var(--wn-ink-15);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.stats__cell {
  background: var(--wn-bg);
  padding: clamp(1.25rem, 2.5vw, 2rem);
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.stats__cell .k {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.8rem, 3.2vw, 2.75rem);
  line-height: 1;
  letter-spacing: -0.02em;
}
.stats__cell .v {
  font-size: 0.82rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
}
@media (max-width: 800px) { .stats { grid-template-columns: repeat(2, 1fr); } }

/* Tag list */
.tag-list { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.tag-list span {
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--wn-ink-70);
  padding: 0.35rem 0.7rem;
  border: 1px solid var(--wn-ink-15);
  border-radius: var(--r-pill);
}

/* Hero split */
.hero-split {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: clamp(2rem, 6vw, 5rem);
  align-items: end;
}
@media (max-width: 900px) { .hero-split { grid-template-columns: 1fr; } }

/* Quote card */
.quote-card {
  background: var(--wn-bg-soft);
  border: 1px solid var(--wn-ink-08);
  border-radius: var(--r-lg);
  padding: clamp(2rem, 3vw, 2.5rem);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.quote-card__text {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.1rem, 1.4vw, 1.35rem);
  line-height: 1.35;
  letter-spacing: -0.01em;
}
.quote-card__who { display: flex; flex-direction: column; gap: 0.15rem; }
.quote-card__who .n { font-weight: 600; font-size: 0.95rem; }
.quote-card__who .r { font-size: 0.8rem; color: var(--wn-ink-55); }

/* =========================================
   PHASE 2 COMPONENTS — about, work, method, faq, contact, legal
   ========================================= */

/* Section inner-hero (for non-home pages) */
.section--hero-inner {
  padding-top: calc(var(--header-h) + clamp(3rem, 6vw, 5rem));
  padding-bottom: clamp(2.2rem, 4vw, 3.4rem);
}
.section--soft { background: #cecbc7; }

/* Display heading used on inner pages */
.h1-display {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5.6vw, 4.6rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  font-weight: 500;
  margin: 1rem 0 1.5rem;
  max-width: 22ch;
}
.h2 {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.2vw, 2.8rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 500;
  max-width: 28ch;
  margin: 0.5rem 0 1.2rem;
}
.h2-dark {
  font-family: var(--font-display);
  color: var(--wn-bg);
  font-size: clamp(1.8rem, 3.2vw, 2.8rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: 500;
  max-width: 28ch;
  margin: 0.5rem 0 1.2rem;
}
.h3 {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 2vw, 1.75rem);
  line-height: 1.2;
  letter-spacing: -0.01em;
  font-weight: 500;
  margin: 0.4rem 0 1rem;
}
.h3-light {
  font-family: var(--font-display);
  color: var(--wn-bg);
  font-size: clamp(1.3rem, 2vw, 1.75rem);
  line-height: 1.2;
  font-weight: 500;
  margin: 0.4rem 0 1rem;
}
.eyebrow--light { color: rgba(217,215,212,0.6) !important; }
.eyebrow--light::before { background: rgba(217,215,212,0.4) !important; }

/* two-col generic layout */
.two-col {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.two-col--dark > * { color: rgba(255,255,255,0.85); }
@media (max-width: 860px) { .two-col { grid-template-columns: 1fr; } }

/* Values grid (manifest cards) */
.values-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
@media (max-width: 1040px) { .values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .values-grid { grid-template-columns: 1fr; } }
.value-card {
  background: var(--wn-bg);
  border: 1px solid var(--wn-ink-15);
  border-radius: var(--radius-lg);
  padding: 1.6rem 1.5rem;
  transition: transform var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out), border-color var(--d-base);
}
.value-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: var(--wn-ink-35); }
.value-card h4 {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 500;
  margin: 0 0 0.6rem;
  letter-spacing: -0.005em;
}
.value-card p { font-size: 0.92rem; color: var(--wn-ink-70); line-height: 1.55; margin: 0; }

/* Who / differentiator cards grid */
.who-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-top: 2rem;
}
@media (max-width: 1040px) { .who-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .who-grid { grid-template-columns: 1fr; } }
.who-card {
  background: var(--wn-bg);
  border: 1px solid var(--wn-ink-15);
  border-radius: var(--radius-lg);
  padding: 1.6rem 1.5rem;
  transition: transform var(--d-base) var(--ease-out), box-shadow var(--d-base) var(--ease-out), border-color var(--d-base);
  position: relative;
  overflow: hidden;
}
.who-card::before {
  content: ""; position: absolute; top: 0; left: 0; width: 28px; height: 2px;
  background: var(--wn-accent); transform: scaleX(0); transform-origin: left;
  transition: transform var(--d-slow) var(--ease-out);
}
.who-card:hover::before { transform: scaleX(1); }
.who-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: var(--wn-ink-35); }
.who-card h4 { font-family: var(--font-display); font-size: 1.1rem; font-weight: 500; margin: 0 0 0.6rem; letter-spacing: -0.005em; }
.who-card p { font-size: 0.92rem; color: var(--wn-ink-70); line-height: 1.55; margin: 0; }
.section--soft .who-card, .section--soft .value-card { background: #d5d2ce; }

/* Steps container */
.steps { display: flex; flex-direction: column; margin-top: 2rem; border-top: 1px solid var(--wn-ink-15); }

/* List of values (principles) */
.list-values {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column;
  border-top: 1px solid var(--wn-ink-15);
}
.list-values li {
  padding: 1.2rem 0;
  border-bottom: 1px solid var(--wn-ink-15);
  font-size: 1rem;
  color: var(--wn-ink-70);
  line-height: 1.5;
  position: relative;
  padding-left: 2.4rem;
  counter-increment: lv;
}
.list-values { counter-reset: lv; }
.list-values li::before {
  content: counter(lv, decimal-leading-zero);
  position: absolute; left: 0; top: 1.3rem;
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  color: var(--wn-accent);
  font-weight: 500;
}

/* Quote card variants */
.quote-card {
  background: var(--wn-bg);
  border: 1px solid var(--wn-ink-15);
  border-radius: var(--radius-xl);
  padding: clamp(1.5rem, 3vw, 2.4rem);
  position: relative;
}
.quote-card--large { padding: clamp(2rem, 4vw, 3rem); }
.quote-card--dark {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.1);
  color: #fff;
}
.quote-card--dark p { color: rgba(255,255,255,0.85); }
.quote-card__meta {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-top: 1.2rem;
  align-items: center;
  font-size: 0.85rem;
  color: var(--wn-ink-55);
}
.quote-card__meta--light { color: rgba(255,255,255,0.6); }

/* =========================================
   WORK / CASE-FULL
   ========================================= */
.case-full { padding-block: clamp(2.5rem, 5vw, 4.5rem); }
.case-full__inner {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: start;
}
.case-full--flip .case-full__inner { grid-template-columns: 1.1fr 0.9fr; direction: rtl; }
.case-full--flip .case-full__inner > * { direction: ltr; }
@media (max-width: 900px) {
  .case-full__inner, .case-full--flip .case-full__inner { grid-template-columns: 1fr; direction: ltr; }
}
.case-full__visual {
  aspect-ratio: 4/5;
  border-radius: var(--radius-xl);
  padding: 1.5rem;
  position: relative;
  overflow: hidden;
  display: flex; flex-direction: column; justify-content: space-between;
  color: #fff;
  min-height: 380px;
}
.case-full__visual::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.12), transparent 55%);
  pointer-events: none;
}
.case-full__num {
  font-family: var(--font-display);
  font-size: 0.85rem;
  letter-spacing: 0.24em;
  opacity: 0.7;
}
.case-full__name {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 2.4vw, 2.1rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 500;
}
.case-visual--alt1 { background: linear-gradient(135deg, #0a0a0a, #2a2a2a 70%, #444); }
.case-visual--alt2 { background: linear-gradient(135deg, #8b6f47 0%, #c9b089 100%); }
.case-visual--alt3 { background: linear-gradient(135deg, #3a3a3a 0%, #8b6f47 100%); }
.case-visual--alt4 { background: linear-gradient(160deg, #6b5333 0%, #b89e75 120%); }
.case-visual--alt5 { background: linear-gradient(135deg, #000 0%, #8b6f47 100%); }

.case-full__body { display: flex; flex-direction: column; gap: 1rem; }
.case-full__body .tag {
  align-self: flex-start;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--wn-accent);
  padding: 0.35rem 0.7rem;
  border: 1px solid var(--wn-accent);
  border-radius: 999px;
}
.case-full__kind {
  font-size: 0.9rem;
  color: var(--wn-ink-55);
  margin: -0.5rem 0 0.5rem;
  letter-spacing: 0.02em;
}
.case-full__block { padding-block: 0.5rem; }
.case-full__block h4 {
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
  margin: 0 0 0.5rem;
  font-weight: 500;
}
.case-full__block p { color: var(--wn-ink-70); line-height: 1.6; margin: 0; font-size: 0.96rem; }
.case-full__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.5rem; }
.case-full__list li {
  padding-left: 1.4rem;
  position: relative;
  color: var(--wn-ink-70);
  font-size: 0.94rem;
  line-height: 1.5;
}
.case-full__list li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.55rem;
  width: 14px; height: 1.5px;
  background: var(--wn-accent);
}
.case-full__kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.8rem;
  margin-top: 0.6rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--wn-ink-15);
}
.kpi { display: flex; flex-direction: column; gap: 0.1rem; }
.kpi strong {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--wn-ink);
}
.kpi span {
  font-size: 0.72rem;
  color: var(--wn-ink-55);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* =========================================
   METHODOLOGY
   ========================================= */
.method-nav {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--wn-ink-15);
}
.method-nav a {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.6rem 1rem;
  border: 1px solid var(--wn-ink-15);
  border-radius: 999px;
  font-size: 0.85rem;
  color: var(--wn-ink);
  background: transparent;
  transition: all var(--d-fast) var(--ease-out);
}
.method-nav a span {
  font-family: var(--font-display);
  color: var(--wn-accent);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
}
.method-nav a:hover { background: var(--wn-ink); color: var(--wn-bg); border-color: var(--wn-ink); }

.method-step { padding-block: clamp(2.5rem, 5vw, 4rem); border-top: 1px solid var(--wn-ink-15); }
.method-step:first-of-type { border-top: none; }
.method-step__head {
  display: flex;
  align-items: baseline;
  gap: 1.5rem;
  margin-bottom: 1.6rem;
}
.method-step__num {
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 5.2rem);
  font-weight: 500;
  color: var(--wn-accent);
  line-height: 0.9;
  letter-spacing: -0.03em;
  flex-shrink: 0;
}
.method-step__meta {
  font-size: 0.85rem;
  color: var(--wn-ink-55);
  margin: 0.4rem 0 0;
  display: flex;
  gap: 0.75rem;
  align-items: center;
}
.method-step__meta span:first-child {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0.2rem 0.5rem;
  background: var(--wn-ink-10);
  border-radius: 4px;
  color: var(--wn-ink-55);
}
.method-step__body { padding-left: clamp(0rem, 10vw, 6rem); }
.method-step__lead {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 1.6vw, 1.4rem);
  line-height: 1.4;
  color: var(--wn-ink);
  margin: 0 0 1.4rem;
  max-width: 56ch;
  letter-spacing: -0.005em;
}
.method-step__cols {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 2rem;
  padding-top: 1rem;
  border-top: 1px solid var(--wn-ink-15);
}
.method-step__cols h5 {
  font-family: var(--font-display);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
  margin: 0 0 0.8rem;
  font-weight: 500;
}
.method-step__cols ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.4rem; }
.method-step__cols ul li {
  padding-left: 1.4rem;
  position: relative;
  color: var(--wn-ink-70);
  font-size: 0.94rem;
  line-height: 1.55;
}
.method-step__cols ul li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.6rem;
  width: 12px; height: 1.5px;
  background: var(--wn-accent);
}
.method-step__cols p { color: var(--wn-ink-70); line-height: 1.55; margin: 0; font-size: 0.94rem; }
@media (max-width: 780px) {
  .method-step__body { padding-left: 0; }
  .method-step__cols { grid-template-columns: 1fr; }
  .method-step__head { flex-direction: column; gap: 0.6rem; }
}

/* =========================================
   FAQ
   ========================================= */
.faq-group { display: grid; grid-template-columns: 1fr 2fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
@media (max-width: 860px) { .faq-group { grid-template-columns: 1fr; } }
.faq-group__head {
  position: sticky;
  top: calc(var(--header-h) + 1.5rem);
}
.faq-group__head .eyebrow {
  font-size: 0.75rem;
  letter-spacing: 0.24em;
  margin: 0 0 0.5rem;
}
.faq-group__head h2 { margin: 0; }
.faq--list { border-top: 1px solid var(--wn-ink-15); margin: 0; }
.faq--list .faq__item {
  border-bottom: 1px solid var(--wn-ink-15);
  padding: 0;
}
.faq--list summary {
  cursor: pointer;
  list-style: none;
  padding: 1.1rem 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  transition: color var(--d-fast);
}
.faq--list summary::-webkit-details-marker { display: none; }
.faq--list summary:hover { color: var(--wn-accent); }
.faq__q {
  font-family: var(--font-display);
  font-size: clamp(1rem, 1.3vw, 1.1rem);
  font-weight: 500;
  letter-spacing: -0.005em;
  line-height: 1.35;
}
.faq__plus {
  display: block;
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 1px solid var(--wn-ink-35);
  position: relative;
  flex-shrink: 0;
  transition: all var(--d-fast);
}
.faq__plus::before, .faq__plus::after {
  content: ""; position: absolute;
  top: 50%; left: 50%;
  background: var(--wn-ink);
  transform: translate(-50%, -50%);
  transition: all var(--d-fast) var(--ease-out);
}
.faq__plus::before { width: 10px; height: 1.5px; }
.faq__plus::after { width: 1.5px; height: 10px; }
.faq--list details[open] .faq__plus {
  background: var(--wn-accent); border-color: var(--wn-accent);
}
.faq--list details[open] .faq__plus::before,
.faq--list details[open] .faq__plus::after { background: #fff; }
.faq--list details[open] .faq__plus::after { transform: translate(-50%, -50%) rotate(90deg); }
.faq--list .faq__a { padding: 0 0 1.4rem; }
.faq--list .faq__a p { color: var(--wn-ink-70); margin: 0; line-height: 1.6; max-width: 70ch; }

/* =========================================
   CONTACT
   ========================================= */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 1.5rem;
}
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-card {
  display: block;
  position: relative;
  padding: 1.8rem 1.6rem;
  background: var(--wn-bg);
  border: 1px solid var(--wn-ink-15);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: inherit;
  transition: all var(--d-base) var(--ease-out);
}
.contact-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: var(--wn-accent); }
.contact-card .eyebrow { margin: 0 0 0.8rem; color: var(--wn-accent); }
.contact-card .eyebrow::before { background: var(--wn-accent); }
.contact-card h3 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 500;
  margin: 0 0 0.6rem;
  letter-spacing: -0.01em;
}
.contact-card p { font-size: 0.9rem; color: var(--wn-ink-70); line-height: 1.5; margin: 0 0 1rem; }
.contact-card__arr {
  position: absolute; top: 1.6rem; right: 1.6rem;
  font-size: 1.1rem;
  color: var(--wn-ink-55);
  transition: transform var(--d-fast) var(--ease-out), color var(--d-fast);
}
.contact-card:hover .contact-card__arr { transform: translateX(4px); color: var(--wn-accent); }

.contact-split {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: start;
}
@media (max-width: 960px) { .contact-split { grid-template-columns: 1fr; } }

/* Form */
.form__field { display: flex; flex-direction: column; gap: 0.4rem; }
.form__field span {
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
  font-weight: 500;
}
.form__field input,
.form__field select,
.form__field textarea {
  width: 100%;
  padding: 0.85rem 1rem;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--wn-ink);
  background: var(--wn-bg);
  border: 1px solid var(--wn-ink-15);
  border-radius: 10px;
  transition: all var(--d-fast) var(--ease-out);
  outline: none;
}
.form__field select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--wn-ink-55) 50%), linear-gradient(135deg, var(--wn-ink-55) 50%, transparent 50%); background-position: calc(100% - 20px) center, calc(100% - 14px) center; background-size: 6px 6px, 6px 6px; background-repeat: no-repeat; padding-right: 2rem; }
.form__field input:focus,
.form__field select:focus,
.form__field textarea:focus { border-color: var(--wn-accent); box-shadow: 0 0 0 3px rgba(139,111,71,0.15); }
.form__field textarea { resize: vertical; font-family: var(--font-body); min-height: 140px; line-height: 1.5; }
.form__consent {
  display: flex; align-items: flex-start; gap: 0.6rem;
  font-size: 0.85rem;
  color: var(--wn-ink-70);
  line-height: 1.5;
  cursor: pointer;
  padding: 0.4rem 0;
}
.form__consent input { flex-shrink: 0; margin-top: 0.2rem; accent-color: var(--wn-accent); width: 16px; height: 16px; }
.form__consent span { max-width: 60ch; }
.form__note {
  font-size: 0.78rem;
  color: var(--wn-ink-55);
  margin: 0;
  line-height: 1.45;
}
.form button[type="submit"] { align-self: flex-start; }

/* Avail card */
.avail-card {
  background: var(--wn-bg);
  border: 1px solid var(--wn-ink-15);
  border-radius: var(--radius-xl);
  padding: 1.6rem;
  margin-bottom: 1rem;
}
.avail-card .eyebrow { margin: 0 0 1.2rem; }
.avail-card--dark {
  background: var(--wn-ink);
  border-color: transparent;
  color: var(--wn-bg);
  position: relative;
  overflow: hidden;
}
.avail-card--dark::before {
  content: ""; position: absolute;
  width: 220px; height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(139,111,71,0.55), transparent 60%);
  bottom: -80px; right: -80px;
  pointer-events: none;
}
.avail-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding: 0.7rem 0;
  border-bottom: 1px dashed var(--wn-ink-15);
  font-size: 0.9rem;
}
.avail-row:last-child { border-bottom: none; }
.avail-row__label { color: var(--wn-ink-55); }
.avail-row__val { color: var(--wn-ink); font-weight: 500; text-align: right; }

/* =========================================
   LEGAL PAGES
   ========================================= */
.legal { max-width: 760px; margin-left: 0; margin-right: auto; }
.legal__sec { padding-block: 1.4rem; border-top: 1px solid var(--wn-ink-15); }
.legal__sec:first-child { border-top: none; }
.legal__sec h2 { margin: 0 0 1rem; }
.legal__sec p { color: var(--wn-ink-70); line-height: 1.65; margin: 0 0 0.7rem; font-size: 0.96rem; }
.legal__updated {
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
  margin-top: 1.5rem;
}

/* Tag utility */
.tag {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--wn-accent);
  border: 1px solid var(--wn-accent);
  border-radius: 999px;
}

/* Step container when inside .section--dark already inherits color — tweak for readable contrast */
.section--dark .method-step__cols ul li, .section--dark .method-step__cols p { color: rgba(255,255,255,0.72); }
.section--dark .method-step__cols ul li::before { background: var(--wn-accent); }


/* =========================================
   PHASE 3 — CUSTOM CURSOR, REFINED ANIMATIONS, LOGO
   ========================================= */

/* Hide native cursor once custom cursor active (desktop only) */
@media (hover: hover) and (pointer: fine) {
  html.has-cursor,
  html.has-cursor * { cursor: none !important; }
  html.has-cursor input,
  html.has-cursor textarea,
  html.has-cursor select { cursor: text !important; }
}

/* Custom cursor elements */
.cursor {
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: difference;
  will-change: transform;
  opacity: 0;
  transition: opacity 280ms var(--ease-out);
}
html.has-cursor .cursor { opacity: 1; }

.cursor--dot {
  width: 6px; height: 6px;
  background: #fff;
  border-radius: 50%;
}
.cursor--ring {
  width: 36px; height: 36px;
  border: 1.5px solid rgba(255, 255, 255, 0.55);
  border-radius: 50%;
  transition: width 360ms var(--ease-smooth), height 360ms var(--ease-smooth),
              border-color 280ms var(--ease-out), background 280ms var(--ease-out);
}
html.cursor-hover .cursor--ring {
  width: 64px; height: 64px;
  border-color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.06);
}
html.cursor-hover .cursor--dot {
  opacity: 0;
}
html.cursor-down .cursor--ring {
  width: 24px; height: 24px;
  background: rgba(255, 255, 255, 0.15);
}

/* Header logo image (replaces inline SVG wordmark) */
.header__logo img,
.footer__brand .logo img {
  display: block;
  height: 34px;
  width: auto;
  transition: opacity 280ms var(--ease-out), transform 420ms var(--ease-smooth);
}
.footer__brand .logo img { height: 44px; }
.header__logo:hover img { opacity: 0.78; }

/* Header becomes more premium on scroll */
.header {
  transition: background 420ms var(--ease-out), backdrop-filter 420ms var(--ease-out),
              border-color 420ms var(--ease-out), transform 520ms var(--ease-smooth),
              box-shadow 420ms var(--ease-out);
}
.header.is-scrolled {
  background: rgba(217, 215, 212, 0.82);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom-color: rgba(0, 0, 0, 0.08);
  box-shadow: 0 1px 0 rgba(0,0,0,0.04);
}
.header.is-hidden { transform: translateY(-100%); }

/* Improved curtain — slower, more fluid */
.curtain { transition: opacity 620ms var(--ease-smooth); }
.curtain.is-lifted .curtain__panel--top { transform: translateY(-100%); }
.curtain.is-lifted .curtain__panel--bot { transform: translateY(100%); }
.curtain.is-lifted .curtain__brand { opacity: 0; transform: translate(-50%, -50%) scale(0.92); }
.curtain.is-gone { opacity: 0; pointer-events: none; }
.curtain__panel {
  transition: transform 1100ms cubic-bezier(0.86, 0, 0.07, 1);
}

/* Smooth page initial reveal — fade body in */
body.is-loading main,
body.is-loading .header,
body.is-loading .footer { opacity: 0; }
main, .header, .footer {
  transition: opacity 720ms var(--ease-smooth);
}
body:not(.is-loading) main,
body:not(.is-loading) .header,
body:not(.is-loading) .footer { opacity: 1; }

/* Reveal animations — more fluid, longer */
[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 900ms var(--ease-smooth), transform 900ms var(--ease-smooth);
  will-change: opacity, transform;
}
[data-reveal].is-in { opacity: 1; transform: translateY(0); }

/* Hero staggered reveal */
[data-hero] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 1100ms var(--ease-smooth), transform 1100ms var(--ease-smooth);
}
[data-hero].is-in { opacity: 1; transform: translateY(0); }

/* Service rows — dimming effect on sibling hover */
.service-row {
  transition: transform 520ms var(--ease-smooth),
              opacity 420ms var(--ease-out),
              background 380ms var(--ease-out),
              border-color 380ms var(--ease-out),
              color 280ms var(--ease-out);
}
.service-row.is-dim { opacity: 0.42; }
.service-row:hover { opacity: 1; }

/* Buttons: smoother transforms */
.btn {
  transition: background 320ms var(--ease-out),
              color 320ms var(--ease-out),
              border-color 320ms var(--ease-out),
              transform 420ms var(--ease-smooth),
              box-shadow 420ms var(--ease-smooth);
  will-change: transform;
}
.btn .arr { transition: transform 380ms var(--ease-smooth); }
.btn:hover .arr { transform: translateX(6px); }

/* Cards hover lift — softer */
.card, .case, .who-card, .value-card, .contact-card {
  transition: transform 520ms var(--ease-smooth),
              box-shadow 520ms var(--ease-smooth),
              border-color 380ms var(--ease-out),
              background 380ms var(--ease-out);
  will-change: transform;
}

/* FAQ smoother */
.faq__a { transition: max-height 560ms var(--ease-smooth), opacity 480ms var(--ease-out); }

/* Link underline hover for nav items */
.nav__link {
  position: relative;
  transition: color 280ms var(--ease-out);
}
.nav__link::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -4px;
  height: 1.5px;
  background: var(--wn-ink);
  transform: scaleX(0);
  transform-origin: right center;
  transition: transform 420ms var(--ease-smooth);
}
.nav__link:hover::after,
.nav__link.is-active::after {
  transform: scaleX(1);
  transform-origin: left center;
}

/* Cursor interaction on text */
html.has-cursor a,
html.has-cursor button { cursor: none !important; }

/* Touch — show native cursor everywhere */
@media (hover: none) {
  .cursor { display: none !important; }
}

/* Prevent cursor flash on first paint */
.cursor { transform: translate3d(-100px, -100px, 0); }

/* Reduce motion support */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
  .cursor { display: none !important; }
}

/* Scroll progress bar — more refined */
.scroll-prog {
  position: fixed;
  top: 0; left: 0;
  right: 0;
  height: 2px;
  background: transparent;
  transform-origin: left center;
  transform: scaleX(0);
  z-index: 200;
  pointer-events: none;
}
.scroll-prog::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, var(--wn-accent), var(--wn-accent-deep));
  transform-origin: left;
}

/* Scroll progress uses JS transform scaleX */
.scroll-prog {
  background: linear-gradient(90deg, var(--wn-accent), var(--wn-accent-deep));
}

/* Mega number / mega text display refinement */
.footer__mega {
  transition: letter-spacing 1.2s var(--ease-smooth), opacity 1.2s var(--ease-smooth);
}

/* Case cards gradient update for warm palette */
.case__visual--alt1 { background: linear-gradient(135deg, #0a0a0a, #2a2520 70%, #3a3228); }
.case__visual--alt2 { background: linear-gradient(135deg, #8b6f47 0%, #d9d7d4 100%); color: #0a0a0a; }
.case__visual--alt3 { background: linear-gradient(135deg, #3a3a3a 0%, #8b6f47 100%); }
.case__visual--alt4 { background: linear-gradient(160deg, #4a3820 0%, #d9d7d4 120%); }
.case__visual--alt5 { background: linear-gradient(135deg, #000 0%, #8b6f47 100%); }
.case-visual--alt1 { background: linear-gradient(135deg, #0a0a0a, #2a2520 70%, #3a3228); }
.case-visual--alt2 { background: linear-gradient(135deg, #8b6f47 0%, #c9b089 100%); }
.case-visual--alt3 { background: linear-gradient(135deg, #3a3a3a 0%, #8b6f47 100%); }
.case-visual--alt4 { background: linear-gradient(160deg, #4a3820 0%, #b89e75 120%); }
.case-visual--alt5 { background: linear-gradient(135deg, #000 0%, #8b6f47 100%); }

/* Noisy background texture (very subtle) */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.025;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode: multiply;
}

/* Selection */
::selection { background: var(--wn-accent); color: #fff; }

/* No-scroll when mobile menu open */
body.no-scroll { overflow: hidden; }

/* Make accent badges/chips use the warm color */
.tag, .eyebrow {
  color: var(--wn-accent-deep);
}
.eyebrow::before { background: var(--wn-accent-deep); }

/* Improved ring focus */
:focus-visible {
  outline: 2px solid var(--wn-accent);
  outline-offset: 3px;
  border-radius: 4px;
}

/* CTA block orb (was blue radial) */
.cta-block__orb {
  background: radial-gradient(circle at 20% 30%, rgba(139, 111, 71, 0.35), transparent 60%),
              radial-gradient(circle at 88% 50%, rgba(139, 111, 71, 0.28), transparent 55%);
}

/* =========================================================
   PHASE 3 — LOGO, CURSOR, GRAIN, POLISH
   ========================================================= */

/* ---- Logo image (header / footer) ---- */
.logo-mark {
  display: block;
  width: 36px;
  height: 36px;
  object-fit: contain;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.header__logo {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  text-decoration: none;
  color: inherit;
  transition: opacity 0.25s ease;
}
.header__logo:hover .logo-mark { transform: rotate(-8deg) scale(1.05); }
.footer__brand .logo .logo-mark { width: 44px; height: 44px; }

/* Curtain big logo */
.curtain__logo {
  width: clamp(90px, 12vw, 140px);
  height: auto;
  display: block;
  margin: 0 auto;
  animation: curtainLogoBreath 2.2s ease-in-out infinite;
}
@keyframes curtainLogoBreath {
  0%, 100% { transform: scale(1); opacity: 0.95; }
  50% { transform: scale(1.04); opacity: 1; }
}

/* ---- Custom cursor ---- */
.cursor {
  position: fixed;
  top: 0;
  left: 0;
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: difference;
  will-change: transform;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.cursor.is-active { opacity: 1; }
.cursor__dot {
  position: absolute;
  top: 0; left: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ffffff;
  transform: translate(-50%, -50%);
  transition: transform 0.18s cubic-bezier(0.33, 1, 0.68, 1),
              opacity 0.18s ease,
              background 0.2s ease;
  will-change: transform;
}
.cursor__ring {
  position: absolute;
  top: 0; left: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1.2px solid rgba(255, 255, 255, 0.75);
  transform: translate(-50%, -50%);
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
              width 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              height 0.35s cubic-bezier(0.16, 1, 0.3, 1),
              opacity 0.3s ease,
              border-color 0.3s ease,
              background 0.3s ease;
  will-change: transform;
}
.cursor__label {
  position: absolute;
  top: 0; left: 0;
  transform: translate(-50%, -50%);
  font-family: var(--font-display);
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #ffffff;
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
  transition: opacity 0.3s ease;
}
/* States */
.cursor.is-hidden .cursor__dot,
.cursor.is-hidden .cursor__ring { opacity: 0; }
.cursor.is-link .cursor__ring {
  width: 54px;
  height: 54px;
  border-color: rgba(255, 255, 255, 0.95);
}
.cursor.is-link .cursor__dot { transform: translate(-50%, -50%) scale(0); }
.cursor.is-btn .cursor__ring {
  width: 72px;
  height: 72px;
  background: rgba(255, 255, 255, 0.88);
  border-color: transparent;
}
.cursor.is-btn .cursor__dot { background: #000; transform: translate(-50%, -50%) scale(1.2); }
.cursor.is-drag .cursor__ring {
  width: 90px;
  height: 90px;
  background: rgba(255, 255, 255, 0.95);
  border-color: transparent;
}
.cursor.is-drag .cursor__dot { opacity: 0; }
.cursor.is-drag .cursor__label { opacity: 1; color: #000; }
.cursor.is-text .cursor__ring { width: 3px; height: 24px; border-radius: 2px; background: #fff; border-color: transparent; }
.cursor.is-text .cursor__dot { opacity: 0; }

/* Hide custom cursor on coarse pointers (touch) */
@media (hover: none), (pointer: coarse) {
  .cursor { display: none !important; }
  html, body { cursor: auto !important; }
}
/* Only hide the OS cursor when custom is active */
html.has-cursor,
html.has-cursor *,
html.has-cursor a,
html.has-cursor button,
html.has-cursor input,
html.has-cursor select,
html.has-cursor textarea {
  cursor: none !important;
}

/* ---- Grain overlay (subtle premium texture) ---- */
.grain {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9998;
  opacity: 0.06;
  mix-blend-mode: multiply;
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.9 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/></svg>");
  background-size: 220px 220px;
}
@media (prefers-reduced-motion: reduce) { .grain { display: none; } }

/* ---- Magnetic / hover on buttons: smoother transition baseline ---- */
.btn { transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                    background 0.3s ease,
                    color 0.3s ease,
                    border-color 0.3s ease; }
.btn .arr { transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1); }
.btn:hover { transform: translateY(-2px); }
.btn:hover .arr { transform: translateX(6px); }

/* ---- Nav link refinement ---- */
.nav__link {
  position: relative;
  padding-block: 0.4rem;
  transition: color 0.3s ease;
}
.nav__link::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.45s cubic-bezier(0.76, 0, 0.24, 1);
}
.nav__link:hover::after { transform: scaleX(1); transform-origin: left; }
.nav__link.is-active::after { transform: scaleX(1); background: var(--wn-accent); }

/* ---- Lang switch refinement ---- */
.lang-switch a {
  transition: color 0.3s ease, opacity 0.3s ease;
}
.lang-switch a:not(.is-active) { opacity: 0.55; }
.lang-switch a:not(.is-active):hover { opacity: 1; color: var(--wn-accent); }

/* ---- Cards hover elevation smoothed ---- */
.card, .value-card, .who-card, .contact-card, .case {
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
              box-shadow 0.5s cubic-bezier(0.16, 1, 0.3, 1),
              border-color 0.3s ease,
              background 0.3s ease;
}

/* ---- Service rows hover ---- */
.service-row {
  transition: background 0.4s ease, padding-left 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.service-row:hover { padding-left: 1.5rem; }

/* ---- Form focus micro-improvement ---- */
.form__field input, .form__field select, .form__field textarea {
  transition: border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

/* ---- Header shrink smoother on scroll ---- */
.header { transition: backdrop-filter 0.4s ease, background 0.4s ease, padding 0.4s ease, box-shadow 0.4s ease; }
.header.is-scrolled { box-shadow: 0 1px 0 rgba(0,0,0,0.06); }

/* ---- Scroll progress bar accent update ---- */
.scroll-prog { background: var(--wn-accent); }

/* ---- Footer logo refinement ---- */
.footer__brand .logo {
  display: inline-flex;
  align-items: center;
}

/* ---- Hide OS cursor only when JS has marked cursor active (prevents flash on load) ---- */

/* ---- Text selection ---- */
::selection { background: var(--wn-accent); color: var(--wn-bg); }

/* ---- Buttons have no native cursor when custom cursor active (reinforcement) ---- */
html.has-cursor a, html.has-cursor button { cursor: none !important; }

/* ---- Fix: service index card descriptions wrapping nicely ---- */
.service-row { display: grid; grid-template-columns: 60px 1fr auto; gap: 1.25rem; align-items: baseline; padding: 1.5rem 0; border-bottom: 1px solid var(--wn-ink-15); color: inherit; text-decoration: none; }
.service-row:last-child { border-bottom: none; }
.service-row__num { font-family: var(--font-display); color: var(--wn-accent); font-size: 0.8rem; letter-spacing: 0.18em; font-weight: 500; }
.service-row__title { font-family: var(--font-display); font-size: clamp(1.3rem, 2vw, 1.75rem); font-weight: 500; letter-spacing: -0.01em; margin: 0 0 0.4rem; }
.service-row__desc { font-size: 0.95rem; color: var(--wn-ink-70); line-height: 1.55; margin: 0; max-width: 62ch; }
.service-row__arr { font-family: var(--font-display); color: var(--wn-ink-55); font-size: 1.2rem; align-self: center; transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), color 0.3s ease; }
.service-row:hover .service-row__arr { color: var(--wn-accent); transform: translateX(8px); }
@media (max-width: 680px) { .service-row { grid-template-columns: 40px 1fr; } .service-row__arr { grid-column: 2; justify-self: end; } }

/* ---- Home hero title polish ---- */
.hero__title .accent { color: var(--wn-accent); position: relative; }

/* ---- Dark sections: adjust accent usage ---- */
.section--dark .btn--accent { background: var(--wn-accent); color: #fff; }
.section--dark .btn--accent:hover { background: var(--wn-accent-soft); }

/* ---- Curtain panels ---- */
.curtain {
  position: fixed;
  inset: 0;
  z-index: 10000;
  pointer-events: none;
}
.curtain__panel {
  position: absolute;
  left: 0; right: 0;
  background: #0a0a0a;
  height: 50vh;
}
.curtain__panel--top { top: 0; transform: translateY(0); }
.curtain__panel--bot { bottom: 0; transform: translateY(0); }
.curtain__line {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  background: rgba(255,255,255,0.18);
}
.curtain__progress {
  position: absolute;
  left: 0; top: 0;
  height: 1px;
  background: var(--wn-accent);
  width: 0;
}
.curtain__brand {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  text-align: center;
}
.curtain.is-done .curtain__panel--top { transform: translateY(-100%); transition: transform 1.1s cubic-bezier(0.76, 0, 0.24, 1); }
.curtain.is-done .curtain__panel--bot { transform: translateY(100%); transition: transform 1.1s cubic-bezier(0.76, 0, 0.24, 1); }
.curtain.is-done .curtain__brand { opacity: 0; transition: opacity 0.4s ease; }

/* ---- Mobile menu toggle ---- */
.menu-toggle { display: none; background: transparent; border: none; width: 44px; height: 44px; padding: 0; align-items: center; justify-content: center; }
.menu-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: currentColor;
  position: relative;
  transition: background 0.2s ease;
}
.menu-toggle span::before, .menu-toggle span::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 2px;
  background: currentColor;
  transition: transform 0.35s cubic-bezier(0.76,0,0.24,1), top 0.2s ease;
}
.menu-toggle span::before { top: -7px; }
.menu-toggle span::after { top: 7px; }
.menu-toggle[aria-expanded="true"] span { background: transparent; }
.menu-toggle[aria-expanded="true"] span::before { top: 0; transform: rotate(45deg); }
.menu-toggle[aria-expanded="true"] span::after { top: 0; transform: rotate(-45deg); }
@media (max-width: 960px) {
  .menu-toggle { display: inline-flex; }
  .nav { display: none; }
}

/* ---- Mobile menu overlay ---- */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--wn-ink);
  color: var(--wn-bg);
  z-index: 95;
  padding: calc(var(--header-h, 72px) + 2rem) 2rem 2rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 2rem;
  transform: translateY(-101%);
  transition: transform 0.6s cubic-bezier(0.76, 0, 0.24, 1);
  visibility: hidden;
}
.mobile-menu.is-open { transform: translateY(0); visibility: visible; }
.mobile-menu__nav { display: flex; flex-direction: column; gap: 0.25rem; }
.mobile-menu__nav a {
  font-family: var(--font-display);
  font-size: clamp(2rem, 7vw, 3rem);
  letter-spacing: -0.02em;
  font-weight: 500;
  color: inherit;
  text-decoration: none;
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.mobile-menu__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.55);
  letter-spacing: 0.08em;
}
.mobile-menu__foot .lang-switch a { color: rgba(255,255,255,0.7); }
.mobile-menu__foot .lang-switch a.is-active { color: #fff; opacity: 1; }
@media (min-width: 961px) { .mobile-menu { display: none; } }


/* =========================================================
   FIXES — orphan classes found on pages
   ========================================================= */

.btn--large {
  padding: 1rem 1.8rem;
  font-size: 0.95rem;
}

.contact-split__left { display: flex; flex-direction: column; gap: 1.5rem; min-width: 0; }
.contact-split__right { display: flex; flex-direction: column; gap: 1rem; position: sticky; top: calc(var(--header-h, 72px) + 1rem); }
@media (max-width: 960px) { .contact-split__right { position: static; } }

.counter { display: inline-block; }

.method-step__inner {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.services-list {
  display: flex;
  flex-direction: column;
}


/* =========================================================
   FINAL FIX — service-row layout (resolve conflicts)
   The HTML emits 4 children: num, title, desc, arr
   We use grid-template-areas so title+desc stack while arr stays right.
   ========================================================= */
.service-row {
  display: grid !important;
  grid-template-columns: 70px 1fr auto;
  grid-template-areas:
    "num title arr"
    "num desc  arr";
  gap: 0.35rem 1.5rem;
  padding: 2rem 1.5rem 2rem 0;
  border-bottom: 1px solid var(--wn-ink-15);
  color: inherit;
  text-decoration: none;
  align-items: baseline;
  transition: background 0.45s cubic-bezier(0.16, 1, 0.3, 1),
              padding 0.45s cubic-bezier(0.16, 1, 0.3, 1);
}
.service-row:hover {
  background: rgba(0, 0, 0, 0.03);
  padding-left: 1.5rem;
}
.service-row:last-child { border-bottom: none; }
.service-row__num {
  grid-area: num;
  font-family: var(--font-display);
  color: var(--wn-accent);
  font-size: 0.8rem;
  letter-spacing: 0.2em;
  font-weight: 500;
  padding-top: 0.5rem;
}
.service-row__title {
  grid-area: title;
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 2vw, 1.75rem);
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0;
  transition: color 0.3s ease;
}
.service-row:hover .service-row__title { color: var(--wn-accent); }
.service-row__desc {
  grid-area: desc;
  font-size: 0.95rem;
  color: var(--wn-ink-70);
  line-height: 1.55;
  margin: 0;
  max-width: 62ch;
}
.service-row__arr {
  grid-area: arr;
  align-self: center;
  font-family: var(--font-display);
  color: var(--wn-ink-55);
  font-size: 1.4rem;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), color 0.3s ease;
}
.service-row:hover .service-row__arr {
  color: var(--wn-accent);
  transform: translateX(10px);
}
@media (max-width: 680px) {
  .service-row {
    grid-template-columns: 48px 1fr;
    grid-template-areas:
      "num title"
      "num desc";
    padding: 1.5rem 0;
  }
  .service-row__arr { display: none; }
  .service-row:hover { padding-left: 0.5rem; }
}

/* =========================================================
   REFONTE 2 — COLD DIGITAL OVERRIDES
   Scrub warm/blue residuals, tighten the premium feel
   ========================================================= */

/* Cold case-visual gradients (graphite + steel, no warm tones) */
.case__visual--alt1, .case-visual--alt1 { background: linear-gradient(135deg, #0a0a0a 0%, #1e1e1e 60%, #2b2b2b 100%) !important; }
.case__visual--alt2, .case-visual--alt2 { background: linear-gradient(135deg, #2a2a2a 0%, #4a4a4a 55%, #6e6e6e 100%) !important; color: var(--wn-bg) !important; }
.case__visual--alt3, .case-visual--alt3 { background: linear-gradient(135deg, #1a1a1a 0%, #3a3a3a 55%, #555 100%) !important; }
.case__visual--alt4, .case-visual--alt4 { background: linear-gradient(160deg, #0a0a0a 0%, #222 50%, #3c3c3c 100%) !important; }
.case__visual--alt5, .case-visual--alt5 { background: linear-gradient(135deg, #000 0%, #242424 60%, #3a3a3a 100%) !important; }

/* Selection — monochrome */
::selection { background: var(--wn-ink) !important; color: var(--wn-bg) !important; }

/* Scroll progress bar — pure black */
.scroll-prog { background: var(--wn-ink) !important; }

/* Cursor ring accent → black difference-blended */
.cursor__dot, .cursor__ring { filter: none; }

/* Nav link underline — neutral */
.nav__link.is-active::after { background: var(--wn-ink) !important; }
.nav__link::after { background: var(--wn-ink) !important; }

/* Eyebrow line — black */
.eyebrow::before { background: var(--wn-ink) !important; }
.eyebrow { color: var(--wn-ink-70) !important; }
.eyebrow--light { color: rgba(255,255,255,0.6) !important; }
.eyebrow--light::before { background: rgba(255,255,255,0.5) !important; }

/* Tag (on case) — neutral outline, no blue */
.tag {
  color: var(--wn-ink) !important;
  border-color: var(--wn-ink) !important;
  background: transparent;
}

/* Step number — black instead of blue */
.step__num, .method-step__num, .why-card__num, .service-row__num {
  color: var(--wn-ink) !important;
}

/* Why-card number has a lighter monospace feel */
.why-card__num { color: rgba(255,255,255,0.45) !important; }

/* Service-row hover title — stays black, underline emerges */
.service-row:hover .service-row__title { color: var(--wn-ink) !important; }

/* Pricing / accent callouts in service details */
.pricing__amount { color: var(--wn-ink) !important; }

/* Hero accent span — cold dark grey, not blue */
.hero__title .accent { color: var(--wn-ink) !important; position: relative; font-style: italic; font-weight: 400; }
.hero__title .accent::after {
  content: "";
  position: absolute;
  left: 0; bottom: -0.08em;
  width: 100%; height: 2px;
  background: var(--wn-ink);
  transform: scaleX(0); transform-origin: left;
  transition: transform 1.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.is-in .hero__title .accent::after,
[data-hero].is-in .hero__title .accent::after { transform: scaleX(1); transition-delay: 0.6s; }

/* Radial orbs — cold, neutral tint */
.cta-block__orb {
  background: radial-gradient(circle at center, rgba(255,255,255,0.08), transparent 60%) !important;
}

/* CTA block — keep dark with subtle cold wash */
.cta-block {
  background: var(--wn-ink) !important;
  border-radius: var(--r-lg);
  overflow: hidden;
  position: relative;
}
.cta-block::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 0%, rgba(255,255,255,0.04), transparent 55%),
              radial-gradient(circle at 80% 100%, rgba(255,255,255,0.03), transparent 50%);
  pointer-events: none;
}

/* Avail-card dark variant — neutral black */
.avail-card--dark { background: var(--wn-ink) !important; border-color: transparent !important; }
.avail-card--dark::before {
  background: radial-gradient(circle, rgba(255,255,255,0.08), transparent 60%) !important;
}

/* Form focus — neutral shadow */
.form__field input:focus,
.form__field select:focus,
.form__field textarea:focus {
  border-color: var(--wn-ink) !important;
  box-shadow: 0 0 0 3px rgba(10,10,10,0.1) !important;
}

/* Form checkbox accent */
.form__consent input { accent-color: var(--wn-ink) !important; }

/* FAQ plus icon active state — pure black */
.faq--list details[open] .faq__plus {
  background: var(--wn-ink) !important;
  border-color: var(--wn-ink) !important;
}

/* Case tag accent — neutral */
.case-full__body .tag {
  color: var(--wn-ink) !important;
  border-color: var(--wn-ink) !important;
}

/* Contact card accent line — neutral, only the ::before gets bg */
.contact-card .eyebrow {
  color: var(--wn-ink) !important;
  background: transparent !important;
}
.contact-card .eyebrow::before { background: var(--wn-ink) !important; }
.contact-card:hover { border-color: var(--wn-ink) !important; }
.contact-card:hover .contact-card__arr { color: var(--wn-ink) !important; }

/* Method step meta pill */
.method-step__meta span:first-child {
  background: var(--wn-ink-08) !important;
  color: var(--wn-ink-70) !important;
}

/* Quote card — refined cold */
.quote-card {
  background: var(--wn-bg-soft) !important;
  border: 1px solid var(--wn-ink-15);
}
.section--soft .quote-card { background: var(--wn-bg) !important; }

/* Make sure NO element has blue traces */
[class*="blue"], [class*="accent--blue"] { background: inherit !important; color: inherit !important; }

/* Lang-switch active hover */
.lang-switch a:not(.is-active):hover {
  color: var(--wn-ink) !important;
  opacity: 1;
}

/* Link-arrow styling */
.link-arrow {
  color: var(--wn-ink) !important;
  border-bottom: 1px solid var(--wn-ink-35);
  padding-bottom: 0.25rem;
  font-weight: 500;
  font-family: var(--font-display);
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  text-decoration: none;
  transition: border-color 0.4s var(--ease-out), letter-spacing 0.4s var(--ease-out);
}
.link-arrow:hover {
  border-color: var(--wn-ink);
  letter-spacing: 0.04em;
}

/* =========================================================
   WHY SECTION — home page (replaces old Work section)
   ========================================================= */
.why-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-top: 3rem;
}
@media (max-width: 1040px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .why-grid { grid-template-columns: 1fr; } }

.why-card {
  padding: 1.8rem 1.6rem 1.6rem;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--r-lg);
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  position: relative;
  overflow: hidden;
  transition: background 0.6s var(--ease-out),
              border-color 0.6s var(--ease-out),
              transform 0.6s var(--ease-out);
  min-height: 220px;
}
.why-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 0; height: 1px;
  background: rgba(255,255,255,0.6);
  transition: width 0.8s var(--ease-out);
}
.why-card:hover {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.22);
  transform: translateY(-4px);
}
.why-card:hover::before { width: 60%; }
.why-card__num {
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: 0.2em;
  font-weight: 500;
  color: rgba(255,255,255,0.45);
  margin-bottom: 0.3rem;
}
.why-card h3 {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--wn-bg);
  line-height: 1.25;
}
.why-card p {
  color: rgba(255,255,255,0.7);
  font-size: 0.9rem;
  line-height: 1.55;
  margin: 0;
}

/* =========================================================
   ANIMATIONS — final polish pass
   ========================================================= */

/* Header — cold glass effect on scroll */
.header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 90;
  padding-block: 1rem;
  background: transparent;
  transition: background 0.5s var(--ease-out),
              backdrop-filter 0.5s var(--ease-out),
              padding 0.5s var(--ease-out),
              border-color 0.5s var(--ease-out);
  border-bottom: 1px solid transparent;
}
.header.is-scrolled {
  background: rgba(215, 217, 212, 0.85);
  backdrop-filter: saturate(180%) blur(16px);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  padding-block: 0.65rem;
  border-bottom-color: var(--wn-ink-15);
}
.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}
.header__right {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}
.nav {
  display: flex;
  gap: 1.75rem;
  align-items: center;
}
.nav__link {
  color: var(--wn-ink);
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 400;
  letter-spacing: 0.01em;
  font-family: var(--font-display);
}
.lang-switch {
  display: inline-flex;
  gap: 0.35rem;
  align-items: center;
  font-family: var(--font-display);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  color: var(--wn-ink-55);
}
.lang-switch a { color: inherit; text-decoration: none; }
.lang-switch a.is-active { color: var(--wn-ink); }
.lang-switch .sep { opacity: 0.4; }

/* Hero — subtle parallax on scroll via CSS only */
.hero {
  min-height: 82vh;
  padding-top: calc(var(--header-h) + 3rem);
  padding-bottom: 4rem;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.hero__title {
  font-family: var(--font-display);
  font-size: var(--fs-hero);
  line-height: 1.02;
  letter-spacing: -0.035em;
  font-weight: 500;
  margin: 0 0 2rem;
  max-width: 20ch;
}
.hero__sub {
  font-size: 1.05rem;
  color: var(--wn-ink-70);
  max-width: 52ch;
  line-height: 1.55;
  margin: 0 0 2.2rem;
}
.hero__cta {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
  margin-bottom: 3rem;
}
.hero__meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  padding-top: 2rem;
  border-top: 1px solid var(--wn-ink-15);
  max-width: 780px;
}
@media (max-width: 680px) { .hero__meta { grid-template-columns: repeat(2, 1fr); } }

/* Card / case generic hover — refined */
.case, .card {
  transition: transform 0.6s var(--ease-out),
              box-shadow 0.6s var(--ease-out),
              border-color 0.4s ease,
              background 0.4s ease;
}
.case:hover, .card:hover {
  transform: translateY(-6px);
}

/* Section-head two-column layout for home sections */
.section-head {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: end;
  margin-bottom: 2rem;
}
.section-head__right {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: flex-start;
}
.section-head__right p { color: var(--wn-ink-70); max-width: 52ch; margin: 0; line-height: 1.55; }
@media (max-width: 860px) {
  .section-head { grid-template-columns: 1fr; align-items: start; }
}

/* Grid helpers used in home */
.grid { display: grid; gap: 1rem; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 960px) { .grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .grid-3 { grid-template-columns: 1fr; } }

/* Container baseline */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.section { padding-block: clamp(4rem, 7vw, 7rem); }

/* Base body + html */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
html, body { margin: 0; padding: 0; background: var(--wn-bg); color: var(--wn-ink); font-family: var(--font-body); font-size: var(--fs-body); line-height: 1.55; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.015em; }
a { color: inherit; }

/* Footer refinement */
.footer {
  background: var(--wn-bg-cool);
  border-top: 1px solid var(--wn-ink-15);
  padding-block: 4rem 1.5rem;
  margin-top: 4rem;
}
.footer__top {
  display: grid;
  grid-template-columns: 1.5fr repeat(3, 1fr);
  gap: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid var(--wn-ink-15);
}
@media (max-width: 860px) {
  .footer__top { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 560px) { .footer__top { grid-template-columns: 1fr; } }
.footer__brand { display: flex; flex-direction: column; gap: 0.9rem; max-width: 36ch; }
.footer__brand p { color: var(--wn-ink-70); font-size: 0.9rem; line-height: 1.55; margin: 0; }
.footer__col h5 {
  font-family: var(--font-display);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--wn-ink-55);
  font-weight: 500;
  margin: 0 0 1rem;
}
.footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.55rem; }
.footer__col a {
  color: var(--wn-ink-70);
  text-decoration: none;
  font-size: 0.88rem;
  transition: color 0.3s ease, padding-left 0.3s ease;
}
.footer__col a:hover { color: var(--wn-ink); padding-left: 6px; }
.footer__mega {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(4rem, 12vw, 10rem);
  letter-spacing: -0.04em;
  color: var(--wn-ink);
  opacity: 0.08;
  text-align: center;
  margin: 2rem 0 1.5rem;
  line-height: 0.9;
  user-select: none;
}
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  font-size: 0.78rem;
  color: var(--wn-ink-55);
  padding-top: 1rem;
  border-top: 1px solid var(--wn-ink-15);
}
.footer__bottom a { color: inherit; text-decoration: none; transition: color 0.3s ease; }
.footer__bottom a:hover { color: var(--wn-ink); }


/* =========================================================
   FINAL MOBILE NAV FIX — enforce burger on <= 960px
   Specificity override, wins over any earlier rule
   ========================================================= */
@media (max-width: 960px) {
  .header .nav { display: none !important; }
  .header .menu-toggle { display: inline-flex !important; }
  .header__right { gap: 0.9rem; }
}
@media (min-width: 961px) {
  .header .menu-toggle { display: none !important; }
  .mobile-menu { display: none !important; }
}

/* Make sure the lang-switch stays visible on mobile (next to burger) */
@media (max-width: 560px) {
  .header .lang-switch { font-size: 0.72rem; }
  .header .btn--small { display: none; }
}

/* Ensure header logo stays visible */
.header__logo .logo-mark { width: 34px; height: 34px; }
@media (max-width: 560px) { .header__logo .logo-mark { width: 30px; height: 30px; } }

/* =========================================================
   MOBILE RESPONSIVE POLISH
   ========================================================= */
@media (max-width: 860px) {
  .section { padding-block: clamp(3rem, 6vw, 5rem); }
  .hero { min-height: auto; padding-top: calc(var(--header-h) + 2rem); }
  .hero__title { font-size: clamp(2.2rem, 8vw, 3.4rem); }
  .hero__meta { grid-template-columns: repeat(2, 1fr); }
  .h1-display { font-size: clamp(2rem, 7vw, 3rem); }
  .h2, .h2-dark { font-size: clamp(1.5rem, 5vw, 2.2rem); }
}
@media (max-width: 560px) {
  .hero__cta { flex-direction: column; align-items: stretch; gap: 0.6rem; }
  .hero__cta .btn { justify-content: center; }
}

/* =========================================================
   SECTION TRANSITIONS — subtle gradient joiners
   ========================================================= */
.section--dark + .section,
.section + .section--dark {
  position: relative;
}

/* Prevent hidden overflow glitch on narrow screens */
html, body { overflow-x: hidden; max-width: 100%; }

/* Accessibility: focus ring that matches design */
:focus-visible {
  outline: 2px solid var(--wn-ink);
  outline-offset: 3px;
}
.btn:focus-visible { outline-offset: 4px; }
a:focus-visible { outline-offset: 4px; border-radius: 2px; }

/* Prevent bottom spacing collision when main ends on dark section */
main > .section:last-child { margin-bottom: 0; }


/* =========================================================
   CORRECTION PASS 3 — CURSOR + CURTAIN REMOVAL, LOGO SIZE UP
   ========================================================= */

/* Hard-disable cursor + curtain + grain (if anything stale ships) */
.cursor, .grain { display: none !important; }
html { cursor: auto !important; }
html *, html a, html button { cursor: revert !important; }
a, button, [role="button"], .btn, .menu-toggle, label { cursor: pointer !important; }
input, select, textarea { cursor: text !important; }
input[type="checkbox"], input[type="radio"], input[type="submit"] { cursor: pointer !important; }

/* Body is always ready now (no curtain gating) */
body, body:not(.is-ready) main { opacity: 1 !important; }

/* Logo — increase header presence */
.header__logo .logo-mark {
  width: 48px !important;
  height: 48px !important;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.header.is-scrolled .header__logo .logo-mark {
  width: 42px !important;
  height: 42px !important;
}
.header__logo:hover .logo-mark { transform: rotate(-6deg) scale(1.04); }

@media (max-width: 560px) {
  .header__logo .logo-mark { width: 42px !important; height: 42px !important; }
  .header.is-scrolled .header__logo .logo-mark { width: 38px !important; height: 38px !important; }
}

/* Header vertical padding slightly bumped for bigger logo */
.header { padding-block: 1.1rem; }
.header.is-scrolled { padding-block: 0.7rem; }

/* Footer brand logo proportional */
.footer__brand .logo .logo-mark {
  width: 54px !important;
  height: 54px !important;
}

/* =========================================================
   PAGE TRANSITION — fade only (no curtain)
   ========================================================= */
body {
  transition: opacity 260ms ease;
}
body.is-leaving {
  opacity: 0.2;
  pointer-events: none;
}


/* =========================================================
   FORM POLISH
   ========================================================= */
.form__req {
  display: inline-block;
  margin-left: 0.25rem;
  font-style: normal;
  color: var(--wn-ink-55);
  font-size: 0.85em;
}
.form__field input,
.form__field select,
.form__field textarea {
  background: var(--wn-bg-soft);
  border: 1px solid var(--wn-ink-15);
  border-radius: 10px;
  padding: 0.95rem 1.1rem;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--wn-ink);
  transition: border-color 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
  width: 100%;
}
.form__field input:hover,
.form__field select:hover,
.form__field textarea:hover {
  border-color: var(--wn-ink-35);
  background: var(--wn-bg);
}
.form__field input::placeholder,
.form__field textarea::placeholder { color: var(--wn-ink-35); }
.form__field textarea { resize: vertical; min-height: 140px; line-height: 1.55; }

.form__consent {
  display: flex;
  gap: 0.7rem;
  align-items: flex-start;
  font-size: 0.85rem;
  color: var(--wn-ink-70);
  line-height: 1.5;
  cursor: pointer;
  padding: 0.25rem 0;
}
.form__consent input[type="checkbox"] {
  margin-top: 0.15rem;
  width: 17px; height: 17px;
  accent-color: var(--wn-ink);
  flex-shrink: 0;
}
.form button[type="submit"] {
  align-self: flex-start;
  margin-top: 0.5rem;
}
.form__note {
  font-size: 0.78rem;
  color: var(--wn-ink-55);
  line-height: 1.5;
  margin: 0.5rem 0 0;
  max-width: 56ch;
}

/* Contact page overall tighter spacing */
.contact-split { gap: clamp(2rem, 4vw, 3rem); }
.contact-split__left .form { gap: 1.4rem; }

@media (max-width: 680px) {
  .form__row { grid-template-columns: 1fr !important; gap: 1rem !important; }
  .form button[type="submit"] { width: 100%; justify-content: center; align-self: stretch; }
}

/* Contact cards grid — better mobile */
@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr !important; }
}


/* =========================================================
   TYPOGRAPHY PASS — Space Grotesk + Lemon Milk
   
   Lemon Milk = usage signature / décoratif UNIQUEMENT
   On la réserve à :
   - watermark géant WHITE NOVA en footer
   - logo wordmark textuel éventuel (curtain / brand stamp)
   - AUCUN texte courant, AUCUN titre de lecture
   
   Space Grotesk = tout le reste (headings + body + UI)
   ========================================================= */

/* Space Grotesk as global default — forces override */
html, body {
  font-family: 'Space Grotesk', 'Helvetica Neue', Arial, sans-serif !important;
  font-weight: 400;
  letter-spacing: -0.005em;
}
h1, h2, h3, h4, h5, h6,
.h1-display, .h2, .h2-dark, .h3, .h3-light,
.hero__title, .eyebrow,
.nav__link, .btn, .lang-switch,
.stats__cell .k, .hero__meta .k, .kpi strong, .counter,
.service-row__title, .step__title, .method-step__num,
.why-card h3, .who-card h4, .value-card h4, .contact-card h3,
.footer__col h5, .footer__bottom {
  font-family: 'Space Grotesk', 'Helvetica Neue', Arial, sans-serif !important;
}

/* Headings weight pass — Space Grotesk looks best at 500 for display */
h1, .h1-display, .hero__title { font-weight: 500 !important; letter-spacing: -0.035em !important; }
h2, .h2, .h2-dark             { font-weight: 500 !important; letter-spacing: -0.025em !important; }
h3, .h3                        { font-weight: 500 !important; letter-spacing: -0.015em !important; }
h4, h5                         { font-weight: 500 !important; letter-spacing: -0.01em !important; }

/* Body text weight stays at 400, leading a bit tighter for Space Grotesk */
body, p, li, td, th, input, textarea, select, label {
  font-weight: 400;
  line-height: 1.55;
}
p { letter-spacing: -0.005em; }

/* Chiffres mis en avant — Space Grotesk 500, feature variantes OT si dispos */
.kpi strong, .stats__cell .k, .hero__meta .k, .counter,
.method-step__num, .why-card__num, .service-row__num {
  font-variant-numeric: tabular-nums lining-nums;
  font-feature-settings: "tnum", "lnum", "ss01";
}

/* =========================================================
   LEMON MILK — signature placements (rares, calibrés)
   ========================================================= */

/* 1. Footer mega watermark — là c'est LE moment */
.footer__mega {
  font-family: var(--font-signature) !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;   /* LM a déjà du tracking intégré */
  text-transform: uppercase;
  opacity: 0.07 !important;
}

/* 2. Curtain brand (reste cachée mais cohérente) */
.curtain__brand {
  font-family: var(--font-signature) !important;
  font-weight: 400 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase;
}

/* 3. Home hero eyebrow pour signer AGENCE DIGITALE — CÔTE D'AZUR  */
.hero .eyebrow {
  font-family: var(--font-signature) !important;
  font-weight: 400 !important;
  letter-spacing: 0.24em !important;
  text-transform: uppercase;
  font-size: 0.7rem !important;
}

/* 4. Footer brand eyebrow location */
.footer__brand p:last-of-type {
  font-family: var(--font-signature) !important;
  font-weight: 400 !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase;
  font-size: 0.7rem !important;
}

/* Le reste des .eyebrow garde Space Grotesk pour la lisibilité UX */
.eyebrow:not(.hero .eyebrow) {
  font-family: var(--font-display) !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase;
  font-size: 0.72rem;
  font-weight: 500;
}

/* =========================================================
   Nav + UI refinements with Space Grotesk
   ========================================================= */
.nav__link {
  font-size: 0.86rem;
  font-weight: 400;
  letter-spacing: 0.005em;
}
.btn {
  letter-spacing: 0.01em;
  font-weight: 500;
}
.lang-switch {
  font-weight: 500;
  letter-spacing: 0.14em;
}

/* =========================================================
   Breadcrumb + form fields hierarchy
   ========================================================= */
.breadcrumb { letter-spacing: 0.16em; font-weight: 500; font-size: 0.72rem; text-transform: uppercase; }
.form__field span { font-weight: 500; }

/* =========================================================
   Optical rendering
   ========================================================= */
body { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }


/* =========================================================
   NEXT-GRID — maillage interne pillar pages
   ========================================================= */
.next-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 2rem;
}
@media (max-width: 900px) { .next-grid { grid-template-columns: 1fr; } }

.next-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 1.8rem 1.6rem;
  background: var(--wn-bg-soft);
  border: 1px solid var(--wn-ink-15);
  border-radius: var(--r-lg);
  text-decoration: none;
  color: inherit;
  min-height: 170px;
  position: relative;
  overflow: hidden;
  transition: background 0.5s var(--ease-out),
              border-color 0.5s var(--ease-out),
              transform 0.5s var(--ease-out);
}
.next-card:hover {
  background: var(--wn-ink);
  color: var(--wn-bg);
  border-color: var(--wn-ink);
  transform: translateY(-4px);
}
.next-card h3 {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0 0 0.5rem;
  line-height: 1.25;
}
.next-card p {
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--wn-ink-70);
  margin: 0;
  transition: color 0.4s ease;
}
.next-card:hover p { color: rgba(255,255,255,0.7); }
.next-card__arr {
  align-self: flex-end;
  font-size: 1.3rem;
  color: var(--wn-ink-35);
  transition: transform 0.5s var(--ease-out), color 0.4s ease;
  margin-top: 1rem;
}
.next-card:hover .next-card__arr {
  color: var(--wn-bg);
  transform: translateX(8px);
}

/* =========================================================
   TWO-COL — local SEO block on services index
   ========================================================= */
.two-col {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.two-col p { margin: 0 0 1.2rem; line-height: 1.65; color: var(--wn-ink-70); max-width: 62ch; }
.two-col p:last-child { margin-bottom: 0; }
.two-col h2 { margin: 0; }
@media (max-width: 860px) { .two-col { grid-template-columns: 1fr; } }

.section--soft { background: var(--wn-bg-soft); padding-block: clamp(4rem, 7vw, 7rem); }

/* =========================================================
   CURTAIN PREMIUM — cinematic entry
   Philosophy: two black panels split vertically, Lemon Milk
   brand mark + progress bar in the middle, reveal after boot.
   ========================================================= */
body.is-loading { overflow: hidden; }
body.is-loading main,
body.is-loading .header,
body.is-loading .footer { opacity: 0; transform: translateY(18px); }

.curtain {
  position: fixed; inset: 0; z-index: 10000;
  pointer-events: none;
  display: grid; grid-template-rows: 1fr 1fr;
}
.curtain__panel {
  background: #0a0a0a;
  transition: transform 900ms cubic-bezier(0.76, 0, 0.24, 1);
}
.curtain__panel--top { transform-origin: top; }
.curtain__panel--bot { transform-origin: bottom; }

.curtain__center {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 1.4rem;
  transition: opacity 420ms var(--ease-out);
}
.curtain__mark {
  font-family: var(--font-signature);
  font-weight: 700;
  color: #ffffff;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(8px);
  animation: curtainMarkIn 700ms 160ms cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@keyframes curtainMarkIn {
  to { opacity: 1; transform: translateY(0); }
}
.curtain__progress {
  width: clamp(120px, 18vw, 220px);
  height: 1px;
  background: rgba(255,255,255,0.18);
  overflow: hidden;
  opacity: 0;
  animation: curtainBarIn 400ms 260ms ease forwards;
}
@keyframes curtainBarIn { to { opacity: 1; } }
.curtain__progress__bar {
  display: block; height: 100%;
  background: #ffffff;
  transform: scaleX(0); transform-origin: left;
  animation: curtainBarFill 900ms 300ms cubic-bezier(0.65, 0, 0.35, 1) forwards;
}
@keyframes curtainBarFill { to { transform: scaleX(1); } }

/* Reveal state — JS toggles body.is-ready (removes is-loading) */
body.is-ready .curtain__panel--top { transform: translateY(-100%); }
body.is-ready .curtain__panel--bot { transform: translateY(100%); }
body.is-ready .curtain__center { opacity: 0; transition-delay: 100ms; }
body.is-ready .curtain { pointer-events: none; }

/* Content fade-in after curtain */
body.is-ready main,
body.is-ready .header,
body.is-ready .footer {
  opacity: 1; transform: translateY(0);
  transition: opacity 700ms 300ms var(--ease-out), transform 900ms 300ms var(--ease-out);
}

/* Hide curtain fully once done */
body.is-done .curtain { display: none; }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  body.is-loading { overflow: auto; }
  body.is-loading main, body.is-loading .header, body.is-loading .footer { opacity: 1; transform: none; }
  .curtain { display: none !important; }
}


/* =========================================================
   HERO — cinematic staged reveal
   ========================================================= */
.hero {
  padding-top: clamp(7rem, 12vw, 10rem);
  padding-bottom: clamp(4rem, 7vw, 7rem);
  position: relative;
}
.hero .eyebrow {
  opacity: 0; transform: translateY(14px);
  animation: heroLineIn 900ms 200ms var(--ease-out) forwards;
}
.hero__title {
  margin-top: 2rem;
  margin-bottom: 2.4rem !important;
}
.hero__title .reveal-line {
  display: block; overflow: hidden; padding-bottom: 0.08em;
}
.hero__title .reveal-line > span {
  display: block;
  transform: translateY(110%) rotate(4deg);
  transition: transform 1100ms cubic-bezier(0.16, 1, 0.3, 1);
}
body.is-ready .hero__title .reveal-line > span { transform: translateY(0) rotate(0deg); }
body.is-ready .hero__title .reveal-line:nth-child(1) > span { transition-delay: 450ms; }
body.is-ready .hero__title .reveal-line:nth-child(2) > span { transition-delay: 580ms; }
body.is-ready .hero__title .reveal-line:nth-child(3) > span { transition-delay: 710ms; }

.hero__sub {
  opacity: 0; transform: translateY(16px);
  max-width: 56ch;
  margin: 0 0 2.8rem !important;
}
body.is-ready .hero__sub {
  animation: heroLineIn 900ms 980ms var(--ease-out) forwards;
}

.hero__cta {
  opacity: 0; transform: translateY(12px);
  display: flex; gap: 1rem; flex-wrap: wrap;
  margin-bottom: 4rem;
}
body.is-ready .hero__cta {
  animation: heroLineIn 800ms 1150ms var(--ease-out) forwards;
}

.hero__meta {
  opacity: 0; transform: translateY(12px);
  padding-top: 2.4rem;
}
body.is-ready .hero__meta {
  animation: heroLineIn 900ms 1320ms var(--ease-out) forwards;
}

@keyframes heroLineIn {
  to { opacity: 1; transform: translateY(0); }
}

/* =========================================================
   SPACING PASS — breathing room between hierarchy
   ========================================================= */
h1, .h1-display { margin: 0 0 1.6rem !important; }
h2, .h2, .h2-dark { margin: 0 0 1.3rem !important; }
h3, .h3 { margin: 0 0 0.85rem !important; }
h4 { margin: 0 0 0.7rem !important; }
.section-head { margin-bottom: 3rem !important; }
.section-head .eyebrow { margin-bottom: 1.1rem; display: inline-block; }
.section-head h2 { margin-top: 0.2rem !important; }
.section-head__right p { margin: 0.6rem 0 0; }

.eyebrow + h1, .eyebrow + h2, .eyebrow + h3,
.eyebrow + .hero__title { margin-top: 1.25rem !important; }

/* Paragraphs after titles */
h1 + p, h2 + p, h3 + p, h4 + p { margin-top: 1.2rem; }

/* Cards internal spacing */
.card, .why-card, .who-card, .value-card, .contact-card, .next-card {
  padding: 2rem 1.8rem !important;
}
.card h3, .why-card h3, .who-card h3, .value-card h3 {
  margin-bottom: 0.8rem !important;
}
.card p, .why-card p, .who-card p, .value-card p, .contact-card p, .next-card p {
  margin-top: 0.6rem;
  line-height: 1.6;
}

/* Section vertical rhythm */
.section { padding-block: clamp(5rem, 9vw, 9rem) !important; }
.section--tight { padding-block: clamp(3rem, 6vw, 5rem) !important; }
.section--hero { padding-block: clamp(6rem, 11vw, 9rem) 2rem !important; }

/* Form spacing */
.form { gap: 1.6rem !important; }
.form__row { gap: 1.4rem !important; }
.form__field span { margin-bottom: 0.6rem; display: inline-block; font-weight: 500; font-size: 0.82rem; letter-spacing: 0.04em; }
.form__field { display: flex; flex-direction: column; gap: 0.3rem; }
.form__consent { margin-top: 0.4rem; }
.form button[type="submit"] { margin-top: 1rem !important; }

/* Breadcrumb spacing */
.breadcrumb { margin-bottom: 2.4rem; display: flex; gap: 0.6rem; align-items: center; }
.breadcrumb a { text-decoration: none; color: var(--wn-ink-55); transition: color 0.3s ease; }
.breadcrumb a:hover { color: var(--wn-ink); }
.breadcrumb span { color: var(--wn-ink-35); }

/* KPI / stat cell */
.hero__meta { display: grid; gap: 2rem 1.5rem; grid-template-columns: repeat(4, 1fr); }
.hero__meta .stat,
.hero__meta > div { display: flex; flex-direction: column; gap: 0.45rem; }
.hero__meta .k, .hero__meta strong {
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  font-weight: 500; letter-spacing: -0.02em; line-height: 1;
}
.hero__meta .v, .hero__meta small {
  font-size: 0.74rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--wn-ink-55);
  font-weight: 500;
}
@media (max-width: 680px) { .hero__meta { grid-template-columns: repeat(2, 1fr); gap: 1.6rem; } }

/* =========================================================
   CARDS / HOVER — premium lift
   ========================================================= */
.card, .why-card, .who-card, .value-card, .contact-card, .next-card {
  transition: transform 600ms var(--ease-out),
              background 500ms var(--ease-out),
              border-color 500ms var(--ease-out),
              box-shadow 600ms var(--ease-out);
  will-change: transform;
}
.card:hover, .who-card:hover, .value-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 48px -24px rgba(10,10,10,0.18);
}

/* =========================================================
   SECTION REVEALS — directional fade-up staggered
   ========================================================= */
[data-reveal]:not(.is-in) {
  opacity: 0;
  transform: translateY(32px);
}
[data-reveal].is-in {
  opacity: 1; transform: translateY(0);
  transition: opacity 900ms var(--ease-out), transform 1100ms var(--ease-out);
}
[data-stagger] > * {
  opacity: 0; transform: translateY(24px);
  transition: opacity 800ms var(--ease-out), transform 900ms var(--ease-out);
}
[data-stagger].is-in > * { opacity: 1; transform: translateY(0); }

/* Word-level reveal hook (optional) */
.split-word { display: inline-block; overflow: hidden; padding-bottom: 0.1em; }
.split-word > span { display: inline-block; transform: translateY(110%); transition: transform 900ms var(--ease-out); }
.is-in .split-word > span, body.is-ready .split-word > span { transform: translateY(0); }

/* =========================================================
   MOBILE MENU — cinematic slide
   ========================================================= */
.mobile-menu {
  position: fixed; inset: 0;
  background: #0a0a0a; color: var(--wn-bg);
  z-index: 80;
  padding: calc(var(--header-h) + 2rem) var(--gutter) 3rem;
  display: flex; flex-direction: column; gap: 1.2rem;
  transform: translateY(-100%);
  transition: transform 700ms cubic-bezier(0.76, 0, 0.24, 1);
  overflow-y: auto;
}
.mobile-menu.is-open { transform: translateY(0); }
.mobile-menu a {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 6vw, 2.6rem);
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--wn-bg);
  text-decoration: none;
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  opacity: 0; transform: translateY(20px);
  transition: opacity 600ms var(--ease-out), transform 700ms var(--ease-out), padding-left 400ms ease;
}
.mobile-menu.is-open a { opacity: 1; transform: translateY(0); }
.mobile-menu.is-open a:nth-child(1) { transition-delay: 200ms; }
.mobile-menu.is-open a:nth-child(2) { transition-delay: 280ms; }
.mobile-menu.is-open a:nth-child(3) { transition-delay: 360ms; }
.mobile-menu.is-open a:nth-child(4) { transition-delay: 440ms; }
.mobile-menu.is-open a:nth-child(5) { transition-delay: 520ms; }
.mobile-menu a:hover { padding-left: 1rem; color: #ffffff; }

/* Burger visual state */
.menu-toggle {
  background: transparent;
  border: 1px solid var(--wn-ink-15);
  width: 44px; height: 44px;
  border-radius: 50%;
  display: none;
  align-items: center; justify-content: center;
  cursor: pointer;
  transition: border-color 0.3s ease, background 0.3s ease;
}
.menu-toggle:hover { border-color: var(--wn-ink); }
.menu-toggle__bars { display: flex; flex-direction: column; gap: 5px; }
.menu-toggle__bars span {
  display: block; width: 18px; height: 1.5px; background: var(--wn-ink);
  transition: transform 0.35s var(--ease-out), opacity 0.25s ease;
}
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
}
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] .menu-toggle__bars span:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
}


/* =========================================================
   CURTAIN — override precedent rules (final authority)
   ========================================================= */
.curtain {
  position: fixed !important;
  top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
  width: 100% !important; height: 100% !important;
  z-index: 10000 !important;
  display: grid !important;
  grid-template-rows: 1fr 1fr !important;
  grid-template-columns: 1fr !important;
  pointer-events: none;
}
.curtain__panel {
  position: relative !important;
  background: #0a0a0a !important;
  width: 100% !important;
  height: 100% !important;
  transition: transform 900ms cubic-bezier(0.76, 0, 0.24, 1) !important;
}
.curtain__panel--top { transform-origin: top !important; transform: translateY(0) !important; }
.curtain__panel--bot { transform-origin: bottom !important; transform: translateY(0) !important; }
body.is-ready .curtain__panel--top { transform: translateY(-100%) !important; }
body.is-ready .curtain__panel--bot { transform: translateY(100%) !important; }
body.is-done .curtain { display: none !important; }

/* =========================================================
   MOBILE MENU — final z-index + fullscreen fix
   ========================================================= */
.mobile-menu {
  z-index: 95 !important;
  width: 100% !important;
  height: 100vh !important;
  height: 100dvh !important;
}
.header { z-index: 96 !important; }
.mobile-menu.is-open ~ * { /* ensure no bleeding */ }


/* =========================================================
   INTERNAL PAGES — no heavy staged hero reveal
   Only a gentle fade-up for content, no curtain
   ========================================================= */
body.page-inner .hero__title .reveal-line > span {
  transform: translateY(0) !important;
  transition: none !important;
}
body.page-inner .hero .eyebrow,
body.page-inner .hero__sub,
body.page-inner .hero__cta,
body.page-inner .hero__meta {
  opacity: 1 !important;
  transform: translateY(0) !important;
  animation: none !important;
}

/* Smooth subtle fade-in on internal pages load */
body.page-inner main {
  animation: innerPageIn 600ms cubic-bezier(0.16, 1, 0.3, 1) both;
}
@keyframes innerPageIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* =========================================================
   FAQ — robust accordion (details/summary) + visual polish
   ========================================================= */
.faq details,
.faq-item,
details[data-faq] {
  border-bottom: 1px solid var(--wn-ink-15);
  padding: 1.4rem 0;
}
.faq details[open],
details[data-faq][open] { padding-bottom: 1.8rem; }

.faq summary,
details[data-faq] > summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  font-family: var(--font-display);
  font-size: clamp(1rem, 1.3vw, 1.15rem);
  font-weight: 500;
  color: var(--wn-ink);
  padding: 0.4rem 0;
  transition: color 0.3s ease;
}
.faq summary::-webkit-details-marker,
details[data-faq] > summary::-webkit-details-marker { display: none; }
.faq summary:hover,
details[data-faq] > summary:hover { color: var(--wn-ink); }

.faq summary::after,
details[data-faq] > summary::after {
  content: "+";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 1px solid var(--wn-ink-15);
  font-size: 1.2rem;
  font-weight: 400;
  color: var(--wn-ink);
  transition: transform 0.35s var(--ease-out), background 0.35s ease, color 0.3s ease, border-color 0.3s ease;
  flex-shrink: 0;
}
.faq details[open] > summary::after,
details[data-faq][open] > summary::after {
  content: "×";
  transform: rotate(0);
  background: var(--wn-ink);
  color: var(--wn-bg);
  border-color: var(--wn-ink);
}

.faq details > *:not(summary),
details[data-faq] > *:not(summary) {
  margin-top: 1rem;
  color: var(--wn-ink-70);
  line-height: 1.65;
  max-width: 72ch;
  animation: faqContentIn 400ms var(--ease-out);
}
@keyframes faqContentIn {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

/* =========================================================
   PAGE TRANSITIONS — lighter, no black curtain between pages
   ========================================================= */
body.is-leaving {
  opacity: 0 !important;
  transform: none !important;
  transition: opacity 220ms ease-out !important;
}

/* =========================================================
   MOBILE — final hardening
   ========================================================= */
@media (max-width: 960px) {
  .header { padding-block: 0.8rem; }
  .header__logo .logo-mark { width: 40px !important; height: 40px !important; }
  .hero { padding-top: calc(var(--header-h) + 1.5rem); padding-bottom: 3rem; }
  .hero__title { font-size: clamp(2rem, 8vw, 3rem) !important; margin-bottom: 1.6rem !important; }
  .hero__sub { margin-bottom: 2rem !important; }
  .hero__cta { flex-direction: column; align-items: stretch; gap: 0.75rem; margin-bottom: 2.4rem; }
  .hero__cta .btn { justify-content: center; width: 100%; }
  .hero__meta { grid-template-columns: repeat(2, 1fr); gap: 1.4rem; padding-top: 1.8rem; }
  .section { padding-block: 3.5rem !important; }
  .section-head { margin-bottom: 2rem !important; grid-template-columns: 1fr !important; gap: 1rem !important; }
  .why-grid, .grid-3, .grid-4, .next-grid { grid-template-columns: 1fr !important; gap: 0.8rem; }
  .card, .why-card, .who-card, .value-card, .next-card, .contact-card { padding: 1.5rem 1.3rem !important; }
  .footer__top { grid-template-columns: 1fr !important; gap: 2rem !important; }
  .footer__mega { font-size: clamp(3rem, 14vw, 6rem) !important; }
  .breadcrumb { margin-bottom: 1.5rem; font-size: 0.65rem; }
  .contact-split { grid-template-columns: 1fr !important; gap: 2rem; }
}

/* Bigger touch targets on mobile */
@media (max-width: 560px) {
  .btn { padding: 0.9rem 1.4rem; font-size: 0.88rem; min-height: 48px; }
  .nav__link, .footer__col a, .breadcrumb a { padding: 0.25rem 0; }
  summary { padding: 0.7rem 0 !important; }
}

/* Prevent 16px input zoom on iOS */
@media (max-width: 560px) {
  input[type="text"], input[type="email"], input[type="tel"], textarea, select {
    font-size: 16px !important;
  }
}

/* =========================================================
   FAQ — cleanup: hide any legacy SVG/plus icons from old markup
   ========================================================= */
.faq summary .faq__plus,
.faq summary .faq__icon,
details[data-faq] > summary .faq__plus,
details[data-faq] > summary .faq__icon,
.faq summary svg,
details[data-faq] > summary svg {
  display: none !important;
}


/* =========================================================
   INTERNAL PAGES — make content always visible by default
   (JS reveals still fire, but nothing ever stays hidden)
   ========================================================= */
body.page-inner [data-reveal],
body.page-inner [data-stagger],
body.page-inner [data-stagger] > * {
  opacity: 1 !important;
  transform: none !important;
}

/* Home: after curtain (is-done state), safety-reveal any leftover blocks */
body.page-home.is-done [data-reveal]:not(.is-in),
body.page-home.is-done [data-stagger]:not(.is-in),
body.page-home.is-done [data-stagger]:not(.is-in) > * {
  opacity: 1 !important;
  transform: none !important;
  transition: opacity 600ms var(--ease-out) !important;
}

