/* QA Portfolio — light, professional dashboard-style layout */

:root {
  /* Palette site : 1 vive (violet iris) + 2 surfaces douces — titre holo inchangé */
  --accent: #6d28d9;
  --accent-soft: #8b5cf6;
  --accent-hover: #5b21b6;
  --accent-muted: #a78bfa;
  --surface-warm: #f4f2f7;
  --surface-cool: #eae8f2;
  --pastel-a: #ede9fe;
  --pastel-a-text: #5b21b6;
  --pastel-b: #e8eaf4;
  --pastel-b-text: #4338ca;
  --bg-page: var(--surface-cool);
  --bg-sidebar: var(--surface-warm);
  --bg-main: #ffffff;
  --home-hero-bg: var(--surface-warm);
  --navy: #1e1b4b;
  --navy-soft: #312e81;
  --home-hero-accent: var(--accent-soft);
  --text: var(--navy);
  --text-muted: #64608a;
  --border: #ddd8ea;
  --disk-glow: rgba(139, 92, 246, 0.11);
  --disk-glow-soft: rgba(109, 40, 217, 0.045);
  --disk-core: #ebe7f5;
  --disk-mid: #e2dcf5;
  --disk-edge: #ddd6fe;
  --disk-fill-tail: rgba(186, 170, 238, 0.28);
  --disk-empty-core: #e0d9ef;
  --disk-empty-edge: #d4cae8;
  --disk-fill-light: #f0ecfa;
  --disk-fill-mid: #e8e4f5;
  --shadow: 0 1px 3px rgba(30, 27, 75, 0.06), 0 1px 2px rgba(30, 27, 75, 0.04);
  --shadow-card: 0 4px 14px rgba(30, 27, 75, 0.07);
  --radius: 12px;
  --radius-sm: 8px;
  --sidebar-width: 260px;
  --font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --edge-x: clamp(1rem, 3vw, 2rem);
  --edge-left: max(var(--edge-x), env(safe-area-inset-left, 0px));
  --edge-right: max(var(--edge-x), env(safe-area-inset-right, 0px));
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  background: var(--bg-page);
  -webkit-text-size-adjust: 100%;
  overflow-x: clip;
}

body {
  margin: 0;
  font-family: var(--font);
  color: var(--text);
  background: var(--home-hero-bg);
  line-height: 1.55;
  min-height: 100vh;
  min-height: 100dvh;
  width: 100%;
}

/* Skip link — WCAG 2.4.1 */
.skip-link {
  position: absolute;
  left: var(--edge-left);
  top: 0;
  z-index: 500;
  padding: 0.55rem 0.85rem;
  background: var(--navy);
  color: #fff;
  font-size: 0.8125rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  transform: translateY(-120%);
  transition: transform 0.18s ease;
}

.skip-link:focus {
  transform: translateY(0);
  outline: 2px solid var(--accent-muted);
  outline-offset: 3px;
}

/* Visible focus — keyboard users (WCAG 2.4.7) */
a:focus-visible,
button:focus-visible,
.btn:focus-visible,
.lang-btn:focus-visible,
.menu-toggle:focus-visible,
.nav-drawer__link:focus-visible,
.project-card--link:focus-visible,
.project-row:focus-visible,
.home-diapo__fab:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible {
  outline: 2px solid var(--accent-soft);
  outline-offset: 3px;
}

a {
  color: var(--accent);
  text-decoration: none;
}

/* Soulignement réservé aux liens texte — pas aux cartes, nav, marque, boutons */
a:hover:not(.brand-link):not(.top-bar__brand):not(.project-card--link):not(.project-row):not(.nav-drawer__link):not(.project-back):not(.btn):not(.home-diapo__fab):not(.home-scroll-cue):not(.lang-btn) {
  text-decoration: underline;
}

a.top-bar__brand,
a.top-bar__brand:hover,
a.top-bar__brand:focus-visible,
a.top-bar__brand:active {
  text-decoration: none;
  color: var(--navy);
}

a.top-bar__brand:hover {
  color: var(--accent);
}

a.project-card--link,
a.project-card--link:hover,
a.project-row,
a.project-row:hover {
  text-decoration: none;
}

.nav-primary a,
.nav-primary a:hover,
.top-bar__nav a,
.top-bar__nav a:hover,
.top-bar-links a,
.top-bar-links a:hover,
.nav-drawer__social a,
.nav-drawer__social a:hover,
.footer-links a,
.footer-links a:hover {
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* ——— Unified shell: nav horizontale (home), pas de bandeau sidebar ——— */
.app > .sidebar,
.nav-backdrop,
.menu-toggle {
  display: none !important;
}

.app {
  display: block;
  min-height: 100vh;
}

/* Sidebar */
.sidebar {
  width: var(--sidebar-width);
  flex-shrink: 0;
  background: var(--bg-sidebar);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: 1.25rem 0 1.5rem;
  position: sticky;
  top: 0;
  align-self: flex-start;
  height: 100vh;
  overflow-y: auto;
}

.brand {
  padding: 0 1.25rem 1.25rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: 1rem;
}

/* Whole brand block links home. Flex column stacks name + tag; excluded from global a:hover underline. */
.brand-link {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.25rem;
  text-decoration: none;
  color: inherit;
  position: relative;
  z-index: 1;
}

.brand-link:hover,
.brand-link:focus-visible,
.brand-link:active,
.brand-link:visited {
  text-decoration: none;
}

.brand-link .brand-name,
.brand-link .brand-tag {
  text-decoration: none;
}

.brand-link:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

.brand-link:hover .brand-name,
.brand-link:focus-visible .brand-name {
  color: var(--accent);
}

.brand-name {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: -0.02em;
  display: block;
  width: 100%;
}

.brand-tag {
  font-size: 0.8125rem;
  color: var(--text-muted);
  margin: 0;
  display: block;
  width: 100%;
}

.nav-primary {
  list-style: none;
  margin: 0;
  padding: 0 0.75rem;
}

.nav-primary li {
  margin: 0.125rem 0;
}

.nav-primary a {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.625rem 0.75rem;
  border-radius: var(--radius-sm);
  color: var(--navy-soft);
  font-size: 0.9375rem;
  font-weight: 500;
  text-decoration: none;
  border-left: 3px solid transparent;
  transition: background 0.15s ease, color 0.15s ease;
}

.nav-primary a:hover {
  background: rgba(255, 255, 255, 0.85);
  color: var(--navy);
}

.nav-primary a.active {
  background: #fff;
  color: var(--navy);
  border-left-color: var(--accent);
  box-shadow: var(--shadow);
}

.nav-icon {
  width: 1.25rem;
  height: 1.25rem;
  opacity: 0.85;
  flex-shrink: 0;
}

.sidebar-cta {
  margin-top: auto;
  padding: 1rem 1.25rem 0;
}

.sidebar-cta-card {
  background: linear-gradient(145deg, #1e3a5f 0%, #1e293b 100%);
  color: #f8fafc;
  border-radius: var(--radius);
  padding: 1.25rem;
  box-shadow: var(--shadow-card);
}

.sidebar-cta-card p {
  margin: 0 0 0.75rem;
  font-size: 0.875rem;
  line-height: 1.45;
  opacity: 0.95;
}

.sidebar-cta-card .btn {
  width: 100%;
  text-align: center;
  background: #fff;
  color: var(--navy);
  font-weight: 600;
  border: none;
}

.sidebar-cta-card .btn:hover {
  background: #f1f5f9;
  text-decoration: none;
}

/* Guide pages: nav suffit — pas de CTA sidebar qui duplique un item du menu */
body[data-page$="Guide"] .sidebar-cta {
  display: none;
}

/* Main column */
.main-wrap {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  background: var(--home-hero-bg);
  position: relative;
  z-index: 1;
}

.top-bar {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15, 23, 42, 0.07);
  padding: 0.75rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.top-bar-links {
  display: flex;
  gap: 1.25rem;
  flex-wrap: wrap;
}

.top-bar-links a {
  font-size: 0.875rem;
  color: var(--text-muted);
  font-weight: 500;
  text-decoration: none;
}

.top-bar-links a:hover {
  color: var(--navy);
  text-decoration: underline;
}

.menu-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  cursor: pointer;
  color: var(--navy);
  opacity: 0.72;
  transition: opacity 0.18s ease, border-color 0.18s ease;
}

.menu-toggle:focus-visible {
  outline: 2px solid var(--accent-muted);
  outline-offset: 3px;
  opacity: 1;
}

.menu-toggle__svg {
  display: block;
  width: 1.125rem;
  height: 1.125rem;
}

.main-content {
  position: relative;
  z-index: 2;
  flex: 1;
  padding: 1.75rem var(--edge-right) 2.5rem var(--edge-left);
  max-width: 960px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.page-title {
  font-size: clamp(1.75rem, 4vw, 2.125rem);
  font-weight: 700;
  color: var(--navy);
  letter-spacing: -0.03em;
  margin: 0 0 0.5rem;
}

.page-lead {
  font-size: 1.0625rem;
  color: var(--text-muted);
  margin: 0 0 2rem;
  max-width: 52ch;
}

.section {
  margin-bottom: 2.5rem;
}

.section-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--navy);
  margin: 0 0 1rem;
  letter-spacing: -0.02em;
  padding-left: 0.65rem;
  border-left: 3px solid var(--accent-soft);
}

/* Home page — hero pleine largeur */
body[data-page="index"] .main-wrap {
  background: var(--home-hero-bg);
}

body[data-page="index"] .top-bar {
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15, 23, 42, 0.07);
}

/* Top bar — martyna style (logo | numbered nav | lang + links) — index only */
.top-bar--home {
  display: grid;
  grid-template-columns: minmax(7rem, auto) minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.75rem 1.25rem;
  padding: 0.85rem var(--edge-right) 0.85rem var(--edge-left);
}

.top-bar__brand {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--navy);
  text-decoration: none;
  letter-spacing: -0.03em;
  white-space: nowrap;
  text-transform: lowercase;
}

.top-bar__brand:hover {
  color: var(--accent);
}

.top-bar__nav {
  min-width: 0;
}

.top-bar__nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.35rem 1.1rem;
}

.top-bar__nav a {
  display: inline-flex;
  align-items: baseline;
  gap: 0.2rem;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #94a3b8;
  text-decoration: none;
  white-space: nowrap;
}

.top-bar__nav a:hover {
  color: var(--navy);
  text-decoration: none;
}

.top-bar__nav a.is-active {
  color: var(--navy);
  box-shadow: inset 0 -2px 0 var(--accent-soft);
}

.top-bar__num {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  opacity: 0.9;
}

.top-bar__right {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* Shell drawer nav — phones/tablettes ≤1024px + écrans scindés (classe JS) */
.nav-drawer {
  display: none;
}

@keyframes nav-drawer-orb-a {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }
  50% {
    transform: translate(-12px, 18px) scale(1.08);
  }
}

@keyframes nav-drawer-orb-b {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }
  50% {
    transform: translate(16px, -14px) scale(0.94);
  }
}

@keyframes nav-drawer-orb-c {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }
  50% {
    transform: translate(-8px, -10px) scale(1.05);
  }
}

html:has(body.shell-drawer-nav.nav-open) {
  background: #100e19;
}

body.shell-drawer-nav {
  &.nav-open {
    overflow: hidden;
    background: #100e19;
  }

  .menu-toggle {
    display: flex !important;
    border: 1px solid rgba(30, 27, 75, 0.14);
    opacity: 1;
  }

  .menu-toggle:hover {
    opacity: 1;
    border-color: rgba(109, 40, 217, 0.32);
  }

  &.nav-open .nav-backdrop {
    display: block !important;
    background: rgba(17, 15, 28, 0.42);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    inset: 0;
    width: 100%;
    height: 100%;
    min-height: 100dvh;
  }

  .top-bar--home {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto;
    align-items: center;
    gap: 0.5rem 0.75rem;
    padding-top: max(0.65rem, env(safe-area-inset-top, 0px));
    padding-right: var(--edge-right);
    padding-bottom: 0.65rem;
    padding-left: var(--edge-left);
  }

  .top-bar__brand {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
  }

  .top-bar__nav {
    display: none;
  }

  .top-bar__right {
    grid-column: 2;
    grid-row: 1;
    border-top: 0;
    padding-top: 0;
    gap: 0.5rem;
    flex-wrap: nowrap;
  }

  .top-bar__right .top-bar-links {
    display: none;
  }

  .nav-drawer {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(86vw, 20.5rem);
    height: 100%;
    min-height: 100dvh;
    max-height: 100dvh;
    z-index: 200;
    overflow: hidden;
    border-left: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 0;
    background: #100e19;
    box-shadow: -18px 0 56px rgba(15, 10, 40, 0.38);
    transform: translateX(100%);
    visibility: hidden;
    pointer-events: none;
    transition:
      transform 0.38s cubic-bezier(0.32, 0.72, 0, 1),
      visibility 0.38s;
    padding-top: env(safe-area-inset-top, 0px);
    padding-bottom: env(safe-area-inset-bottom, 0px);
    padding-right: env(safe-area-inset-right, 0px);
    box-sizing: border-box;
  }

  &.nav-open .nav-drawer {
    transform: translateX(0);
    visibility: visible;
    pointer-events: auto;
  }

  .nav-drawer__holo {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
  }

  .nav-drawer__holo::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
      radial-gradient(circle at 82% 12%, rgba(56, 189, 248, 0.14) 0%, transparent 42%),
      radial-gradient(circle at 68% 88%, rgba(244, 114, 182, 0.1) 0%, transparent 38%),
      linear-gradient(165deg, rgba(139, 92, 246, 0.08) 0%, transparent 55%);
    opacity: 0.95;
  }

  .nav-drawer__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(52px);
    will-change: transform;
  }

  .nav-drawer__orb--a {
    width: 11rem;
    height: 11rem;
    top: -2.5rem;
    right: -2rem;
    background: radial-gradient(circle, rgba(139, 92, 246, 0.72) 0%, rgba(139, 92, 246, 0) 72%);
    animation: nav-drawer-orb-a 13s ease-in-out infinite;
  }

  .nav-drawer__orb--b {
    width: 9rem;
    height: 9rem;
    bottom: 18%;
    left: -2.5rem;
    background: radial-gradient(circle, rgba(99, 102, 241, 0.55) 0%, rgba(99, 102, 241, 0) 70%);
    animation: nav-drawer-orb-b 10s ease-in-out infinite;
  }

  .nav-drawer__orb--c {
    width: 7rem;
    height: 7rem;
    top: 42%;
    right: 10%;
    background: radial-gradient(circle, rgba(34, 211, 238, 0.42) 0%, rgba(34, 211, 238, 0) 68%);
    animation: nav-drawer-orb-c 8s ease-in-out infinite;
  }

  .nav-drawer__inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    padding: 1.15rem 1.1rem 1.35rem;
    overflow-y: auto;
    overscroll-behavior: contain;
    background: linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.045) 0%,
      rgba(255, 255, 255, 0.015) 38%,
      rgba(16, 14, 25, 0.55) 100%
    );
    backdrop-filter: blur(18px) saturate(130%);
    -webkit-backdrop-filter: blur(18px) saturate(130%);
  }

  .nav-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
    padding-bottom: 0.95rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    flex-shrink: 0;
  }

  .nav-drawer__brand {
    font-size: 0.9375rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.9);
    letter-spacing: -0.03em;
    text-transform: lowercase;
  }

  .nav-drawer__close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 0;
    background: transparent;
    color: rgba(255, 255, 255, 0.72);
    cursor: pointer;
    flex-shrink: 0;
    transition: border-color 0.18s ease, color 0.18s ease;
  }

  .nav-drawer__close:hover {
    color: rgba(255, 255, 255, 0.95);
    border-color: rgba(167, 139, 250, 0.45);
    background: transparent;
  }

  .nav-drawer__close svg {
    width: 0.8125rem;
    height: 0.8125rem;
  }

  .nav-drawer__close:focus-visible {
    outline: 2px solid rgba(167, 139, 250, 0.55);
    outline-offset: 3px;
  }

  .nav-drawer__section + .nav-drawer__section {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
  }

  .nav-drawer__section {
    flex-shrink: 0;
  }

  .nav-drawer__label {
    margin: 0 0 0.55rem;
    font-size: 0.625rem;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(167, 139, 250, 0.52);
  }

  .nav-drawer__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
  }

  .nav-drawer__list li {
    flex-shrink: 0;
  }

  .nav-drawer__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    padding: 0.55rem 0.5rem 0.55rem 0.75rem;
    color: rgba(255, 255, 255, 0.78);
    text-decoration: none;
    border-radius: 0;
    border: none;
    border-left: 2px solid transparent;
    flex-shrink: 0;
    line-height: 1.35;
    transition:
      color 0.18s ease,
      background 0.18s ease,
      border-color 0.18s ease;
  }

  .nav-drawer__link:hover {
    text-decoration: none;
    color: rgba(255, 255, 255, 0.95);
    background: rgba(255, 255, 255, 0.03);
    border-left-color: rgba(255, 255, 255, 0.12);
  }

  .nav-drawer__link--primary {
    font-size: 0.975rem;
    font-weight: 600;
    letter-spacing: -0.015em;
    padding: 0.62rem 0.5rem;
  }

  .nav-drawer__link--secondary {
    font-size: 0.8125rem;
    font-weight: 400;
    color: rgba(255, 255, 255, 0.58);
  }

  .nav-drawer__link.is-active {
    color: #f5f3ff;
    background: rgba(255, 255, 255, 0.04);
    border-left-color: rgba(167, 139, 250, 0.88);
    box-shadow: none;
  }

  .nav-drawer__link--primary.is-active {
    background: rgba(255, 255, 255, 0.04);
  }

  .nav-drawer__chevron {
    width: 0.875rem;
    height: 0.875rem;
    flex-shrink: 0;
    opacity: 0.35;
  }

  .nav-drawer__link:hover .nav-drawer__chevron,
  .nav-drawer__link.is-active .nav-drawer__chevron {
    opacity: 0.62;
  }

  .nav-drawer__foot {
    margin-top: auto;
    padding-top: 1.35rem;
    flex-shrink: 0;
  }

  .nav-drawer__social {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem 0.85rem;
    padding-top: 0.95rem;
    border-top: 1px solid rgba(255, 255, 255, 0.07);
  }

  .nav-drawer__social a {
    font-size: 0.6875rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.42);
    text-decoration: none;
    transition: color 0.18s ease;
  }

  .nav-drawer__social a:hover {
    color: rgba(255, 255, 255, 0.78);
    text-decoration: none;
  }
}

body.is-dual-screen.shell-drawer-nav .nav-drawer {
  width: min(calc(50vw - 1.25rem), 20.5rem);
}

/* Volet : tout visible sans scroll en paysage mobile */
@media (orientation: landscape) and (max-height: 520px) {
  body.shell-drawer-nav .nav-drawer__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: auto minmax(0, 1fr) auto;
    column-gap: 0.65rem;
    row-gap: 0;
    height: 100%;
    min-height: 0;
    padding: 0.65rem 0.8rem 0.7rem;
    overflow: hidden;
  }

  body.shell-drawer-nav .nav-drawer__head {
    grid-column: 1 / -1;
    margin-bottom: 0.45rem;
    padding-bottom: 0.4rem;
  }

  body.shell-drawer-nav .nav-drawer__section + .nav-drawer__section {
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
  }

  body.shell-drawer-nav .nav-drawer__label {
    margin-bottom: 0.18rem;
    font-size: 0.5625rem;
  }

  body.shell-drawer-nav .nav-drawer__list {
    gap: 0;
  }

  body.shell-drawer-nav .nav-drawer__link--primary {
    font-size: 0.8125rem;
    padding: 0.3rem 0.35rem 0.3rem 0.5rem;
    line-height: 1.28;
  }

  body.shell-drawer-nav .nav-drawer__link--secondary {
    font-size: 0.71875rem;
    padding: 0.26rem 0.35rem 0.26rem 0.5rem;
    line-height: 1.28;
  }

  body.shell-drawer-nav .nav-drawer__chevron {
    width: 0.75rem;
    height: 0.75rem;
  }

  body.shell-drawer-nav .nav-drawer__foot {
    grid-column: 1 / -1;
    margin-top: 0;
    padding-top: 0.35rem;
  }

  body.shell-drawer-nav .nav-drawer__social {
    padding-top: 0.4rem;
    gap: 0.35rem 0.6rem;
  }

  body.shell-drawer-nav .nav-drawer__social a {
    font-size: 0.625rem;
  }

  body.shell-drawer-nav .nav-drawer__orb {
    opacity: 0.45;
    filter: blur(40px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .nav-drawer__orb--a,
  .nav-drawer__orb--b,
  .nav-drawer__orb--c {
    animation: none;
  }
}

@media (max-width: 767px) {
  body.shell-drawer-nav .top-bar--home {
    padding-top: max(0.55rem, env(safe-area-inset-top, 0px));
    padding-right: var(--edge-right);
    padding-bottom: 0.55rem;
    padding-left: var(--edge-left);
  }

  .top-bar__brand {
    font-size: 0.975rem;
  }

  .main-wrap,
  .app,
  .home-diapo {
    width: 100%;
    max-width: 100%;
  }

  .home-diapo__slide {
    padding-left: max(1.15rem, env(safe-area-inset-left, 0px));
    padding-right: max(1.15rem, env(safe-area-inset-right, 0px));
  }

  .main-content {
    padding-left: var(--edge-left);
    padding-right: var(--edge-right);
  }
}

/* Tablettes paysage — marges latérales plus généreuses */
@media (min-width: 768px) and (orientation: landscape) {
  :root {
    --edge-x: clamp(1.35rem, 4.5vw, 2.75rem);
  }

  html.is-dual-screen,
  body.is-dual-screen {
    --dual-pane-gutter: clamp(1.35rem, 4.5vw, 2.75rem);
    --edge-x: clamp(1.35rem, 4.5vw, 2.75rem);
  }
}

.main-content--home {
  padding: 0;
  max-width: none;
  width: 100%;
  overflow-x: clip;
}

.main-content--home > .section--featured,
.main-content--home > .section--future {
  padding-left: var(--edge-left);
  padding-right: var(--edge-right);
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
}

.main-content--home > .section--featured {
  padding-top: 2.5rem;
}

/* —— Home diaporama: strict 2-panel clip + FAB inside viewport —— */
.home-diapo {
  --home-diapo-h: min(78vh, 680px);
  --home-disk-size: clamp(168px, 28vmin, 300px);
  --load-p: 0;
  position: relative;
  margin: 0;
  background: var(--home-hero-bg);
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  overflow-x: clip;
}

.home-diapo__viewport {
  position: relative;
  height: var(--home-diapo-h);
  overflow: hidden;
  isolation: isolate;
}

.home-diapo__track {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  height: calc(var(--home-diapo-h) * 2);
  width: 100%;
  transition: transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}

.home-diapo.is-slide-2 .home-diapo__track {
  transform: translateY(-50%);
}

.home-diapo__slide {
  position: relative;
  box-sizing: border-box;
  flex: 0 0 var(--home-diapo-h);
  height: var(--home-diapo-h);
  min-height: 0;
  max-height: var(--home-diapo-h);
  width: 100%;
  overflow: hidden;
  padding: clamp(1.75rem, 5vw, 3rem) clamp(1.25rem, 4vw, 3rem);
  padding-bottom: clamp(4.25rem, 8vw, 5rem);
}

.home-diapo__slide--2 {
  background: linear-gradient(180deg, #faf9fc 0%, var(--surface-warm) 100%);
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.home-diapo__backdrop {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

/* Decorative disk: dans le flux slide-inner (grille desktop / empilé mobile) */
.home-diapo__load {
  --load-p: 0;
  --load-deg: 0deg;
  position: relative;
  flex-shrink: 0;
  width: var(--home-disk-size);
  height: var(--home-disk-size);
  margin: 0.35rem auto 0;
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
  overflow: hidden;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.28),
    0 0 18px var(--disk-glow-soft),
    0 8px 20px rgba(109, 40, 217, 0.03);
  background:
    radial-gradient(circle at 40% 30%, rgba(255, 255, 255, 0.2) 0%, transparent 46%),
    radial-gradient(circle at 50% 58%, var(--disk-empty-core) 0%, var(--disk-empty-edge) 100%);
  transition: background 0.55s ease, box-shadow 0.55s ease;
}

.home-diapo__load.is-filling {
  background:
    conic-gradient(
      from -90deg,
      var(--disk-fill-light) 0deg,
      var(--disk-fill-mid) var(--load-deg),
      transparent var(--load-deg),
      transparent 360deg
    ),
    radial-gradient(circle at 40% 30%, rgba(255, 255, 255, 0.18) 0%, transparent 46%),
    radial-gradient(circle at 50% 58%, var(--disk-empty-core) 0%, var(--disk-empty-edge) 100%);
}

.home-diapo__slide--1 .home-diapo__vline {
  display: none;
}

.home-diapo__load::before {
  content: "";
  position: absolute;
  inset: -8%;
  border-radius: 50%;
  background: radial-gradient(
    ellipse 85% 58% at 50% 50%,
    rgba(255, 255, 255, 0.32) 0%,
    rgba(196, 181, 253, 0.08) 42%,
    transparent 68%
  );
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.55s ease;
}

.home-diapo__load.is-loaded {
  background:
    radial-gradient(circle at 34% 28%, rgba(255, 255, 255, 0.55) 0%, rgba(255, 255, 255, 0) 42%),
    radial-gradient(circle at 28% 24%, rgba(244, 240, 255, 0.85) 0%, rgba(255, 255, 255, 0) 36%),
    radial-gradient(circle at 74% 80%, var(--disk-fill-tail) 0%, rgba(186, 170, 238, 0) 46%),
    radial-gradient(circle at 50% 52%, var(--disk-fill-light) 0%, var(--disk-mid) 48%, var(--disk-edge) 100%);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.45),
    0 0 28px var(--disk-glow-soft),
    0 10px 24px rgba(109, 40, 217, 0.04);
  animation: home-disk-breathe 18s ease-in-out infinite;
}

.home-diapo__load.is-loaded::before {
  opacity: 0.38;
  animation: home-disk-shimmer 36s linear infinite;
}

@keyframes home-disk-breathe {
  0%,
  100% {
    box-shadow:
      0 0 0 1px rgba(255, 255, 255, 0.45),
      0 0 28px var(--disk-glow-soft),
      0 10px 24px rgba(109, 40, 217, 0.04);
  }
  50% {
    box-shadow:
      0 0 0 1px rgba(255, 255, 255, 0.5),
      0 0 36px var(--disk-glow),
      0 12px 28px rgba(109, 40, 217, 0.06);
  }
}

@keyframes home-disk-shimmer {
  to {
    transform: rotate(360deg);
  }
}

.home-diapo__vline {
  position: absolute;
  right: clamp(0.75rem, 2.5vw, 1.5rem);
  top: 16%;
  bottom: 28%;
  width: 1px;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(139, 92, 246, 0.09) 14%,
    rgba(167, 139, 250, 0.09) 86%,
    transparent 100%
  );
  z-index: 1;
}

.home-diapo__slide-inner {
  position: relative;
  z-index: 2;
  height: 100%;
  width: 100%;
  max-width: min(52rem, 100%);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1rem;
}

.home-diapo__slide--1 .home-diapo__slide-inner {
  max-width: min(56rem, 100%);
}

.home-diapo__slide-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 0;
}

/* Mobile : fine barre de progression (remplace le disque 3D) */
.home-diapo__slide-main::after {
  content: "";
  display: none;
}

.home-diapo__hero-text {
  margin: 0;
  font-size: clamp(1.65rem, 4.2vw, 2.85rem);
  font-weight: 700;
  line-height: 1.22;
  letter-spacing: -0.04em;
  color: var(--navy);
  max-width: 42rem;
  text-wrap: pretty;
}

.home-diapo__hero-text .home-diapo__hero-line2 {
  font-weight: 600;
  color: #334155;
  font-size: 0.92em;
}

/* Hero accent — irisé sur les lettres uniquement (pas de halo autour) */
.home-diapo__accent {
  position: relative;
  display: inline-block;
  font-weight: 700;
  white-space: nowrap;
  background: linear-gradient(
    125deg,
    #4338ca 0%,
    #6366f1 8%,
    #8b5cf6 16%,
    #d946ef 24%,
    #06b6d4 32%,
    #a855f7 40%,
    #f472b6 48%,
    #0ea5e9 56%,
    #818cf8 64%,
    #22d3ee 72%,
    #c026d3 80%,
    #38bdf8 88%,
    #6366f1 94%,
    #4338ca 100%
  );
  background-size: 280% 280%;
  background-position: 0% 45%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 0.4px rgba(255, 255, 255, 0.35);
  paint-order: stroke fill;
  animation: holo-accent-flow 11s cubic-bezier(0.42, 0, 0.58, 1) infinite;
}

.home-diapo__accent::after {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    148deg,
    rgba(255, 255, 255, 0.75) 0%,
    rgba(255, 255, 255, 0.2) 22%,
    transparent 46%
  );
  background-size: 160% 160%;
  background-position: 10% 14%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  mix-blend-mode: soft-light;
  animation: holo-accent-specular 9s ease-in-out infinite;
}

@keyframes holo-accent-flow {
  0% {
    background-position: 0% 45%;
  }
  18% {
    background-position: 38% 62%;
  }
  36% {
    background-position: 72% 32%;
  }
  54% {
    background-position: 52% 78%;
  }
  72% {
    background-position: 22% 38%;
  }
  88% {
    background-position: 88% 52%;
  }
  100% {
    background-position: 0% 45%;
  }
}

@keyframes holo-accent-specular {
  0%,
  100% {
    background-position: 10% 14%;
    opacity: 0.75;
  }
  45% {
    background-position: 38% 32%;
    opacity: 0.95;
  }
  70% {
    background-position: 22% 40%;
    opacity: 0.8;
  }
}

.home-diapo__slide-foot {
  flex-shrink: 0;
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding-top: 0.25rem;
}

.home-diapo__quote {
  margin: 0;
  flex: 1;
  min-width: min(100%, 16rem);
  font-size: 0.8125rem;
  line-height: 1.45;
  font-style: italic;
  color: #94a3b8;
  max-width: 28ch;
}

.home-diapo__social {
  display: flex;
  justify-content: flex-end;
  gap: 1.35rem;
  flex-wrap: wrap;
  flex-shrink: 0;
}

.home-diapo__social a {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--navy-soft);
  text-decoration: none;
}

.home-diapo__social a:hover {
  color: var(--home-hero-accent);
  text-decoration: none;
}

.home-diapo__slide2-title {
  margin: 0 0 0.75rem;
  font-size: clamp(1.35rem, 3vw, 1.75rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--navy);
}

.home-diapo__slide2-lead {
  margin: 0 0 1rem;
  font-size: 1rem;
  line-height: 1.55;
  color: var(--text);
  max-width: 52ch;
}

.home-diapo__slide2-list {
  margin: 0 0 1.25rem;
  padding-left: 1.15rem;
  color: var(--text-muted);
  font-size: 0.9375rem;
  max-width: 52ch;
}

.home-diapo__slide2-list li {
  margin-bottom: 0.45rem;
}

.home-diapo__slide2-list li::marker {
  color: #94a3b8;
}

.home-diapo__slide2-list strong {
  color: var(--navy-soft);
}

.home-diapo__slide-inner--2 {
  justify-content: flex-start;
  padding-right: 0.5rem;
  padding-bottom: 4.5rem;
}

.home-diapo__slide2-links {
  margin: 0 !important;
}

.home-diapo__viewport .home-diapo__fab {
  position: absolute;
  right: clamp(1rem, 3vw, 2rem);
  bottom: clamp(1rem, 3vw, 1.75rem);
  z-index: 20;
  min-height: 2.75rem;
  padding: 0.55rem 0.65rem 0.55rem 0.85rem;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: var(--navy);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  box-shadow: 0 4px 20px rgba(15, 23, 42, 0.08);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    border-color 0.2s ease,
    background 0.2s ease;
}

.home-diapo__fab-num {
  font-size: 0.6875rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.06em;
  color: #94a3b8;
}

.home-diapo__fab-label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--navy);
  white-space: nowrap;
}

.home-diapo__fab-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.65rem;
  height: 1.65rem;
  margin-left: 0.15rem;
  border-radius: 50%;
  background: rgba(109, 40, 217, 0.1);
  color: var(--accent-soft);
  flex-shrink: 0;
  transition: background 0.2s ease;
}

.home-diapo__fab:hover {
  transform: translateY(-1px);
  border-color: rgba(109, 40, 217, 0.22);
  box-shadow: 0 8px 24px rgba(30, 27, 75, 0.08);
}

.home-diapo__fab:hover .home-diapo__fab-mark {
  background: rgba(109, 40, 217, 0.16);
}

.home-diapo__fab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

.home-diapo__fab-icon {
  display: block;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

.home-diapo.is-slide-2 .home-diapo__fab-icon {
  transform: rotate(180deg);
}

@media (prefers-reduced-motion: reduce) {
  .home-diapo__track {
    transition-duration: 0.01ms;
  }

  .home-diapo__fab-icon {
    transition-duration: 0.01ms;
  }

  .home-diapo__accent {
    animation: none;
    background-position: 40% 50%;
  }

  .home-diapo__accent::after {
    animation: none;
    background-position: 20% 25%;
    opacity: 0.85;
  }

  .home-diapo__load::before,
  .home-diapo__load.is-loaded::before {
    opacity: 0.38;
  }

  .home-diapo__load,
  .home-diapo__load.is-loaded,
  .home-diapo__load.is-loaded::before {
    animation: none !important;
  }
}

@media (min-width: 768px) {
  .home-diapo__slide--1 {
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--home-disk-size);
    grid-template-rows: minmax(0, 1fr);
    column-gap: clamp(1rem, 2.5vw, 2rem);
    align-items: center;
  }

  .home-diapo__slide--1 .home-diapo__slide-inner {
    grid-column: 1;
    grid-row: 1;
    height: 100%;
    max-width: none;
  }

  .home-diapo__slide--1 > .home-diapo__load {
    grid-column: 2;
    grid-row: 1;
    margin: 0;
    justify-self: center;
    align-self: center;
    width: var(--home-disk-size);
    height: var(--home-disk-size);
  }
}

/* Paysage mobile (iPhone horizontal) : layout compact, marges + safe-area */
@media (orientation: landscape) and (max-height: 520px) and (max-width: 932px) {
  :root {
    --edge-x: 1.15rem;
    --edge-left: max(2.75rem, env(safe-area-inset-left, 0px));
    --edge-right: max(1.15rem, env(safe-area-inset-right, 0px));
  }

  .home-diapo {
    --home-diapo-h: max(11.5rem, min(52dvh, 15.5rem));
    --home-disk-size: clamp(52px, 14vh, 72px);
    padding-bottom: max(0.65rem, env(safe-area-inset-bottom, 0px));
  }

  .home-diapo__viewport {
    display: flex;
    flex-direction: column;
    height: auto;
    min-height: var(--home-diapo-h);
    overflow: visible;
    padding-bottom: max(0.65rem, env(safe-area-inset-bottom, 0px));
  }

  .home-diapo__track {
    height: auto;
    transform: none !important;
  }

  .home-diapo:not(.is-slide-2) .home-diapo__slide--2 {
    display: none;
  }

  .home-diapo.is-slide-2 .home-diapo__slide--1 {
    display: none;
  }

  .home-diapo__slide {
    flex: 0 0 auto;
    height: auto;
    max-height: none;
    min-height: 0;
    padding: 0;
  }

  /* Priorité sur min-width:768 (grille) et dual-screen */
  .home-diapo__slide--1 {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    min-height: var(--home-diapo-h);
    padding:
      0.65rem
      var(--edge-right)
      max(0.65rem, env(safe-area-inset-bottom, 0px))
      var(--edge-left);
    box-sizing: border-box;
  }

  .home-diapo__slide--2 {
    padding:
      0.35rem
      var(--edge-right)
      max(0.65rem, env(safe-area-inset-bottom, 0px))
      var(--edge-left);
    box-sizing: border-box;
  }

  .home-diapo__slide--1 > .home-diapo__load {
    position: relative;
    grid-column: unset;
    grid-row: unset;
    order: 2;
    flex-shrink: 0;
    width: var(--home-disk-size);
    height: var(--home-disk-size);
    max-width: var(--home-disk-size);
    max-height: var(--home-disk-size);
    margin: 0.15rem auto 0;
    align-self: center;
    justify-self: unset;
  }

  .home-diapo__slide--1 .home-diapo__slide-inner {
    order: 1;
    flex: 0 1 auto;
    min-width: 0;
    height: auto;
    max-width: min(34rem, 100%);
    width: 100%;
    grid-column: unset;
    grid-row: unset;
    gap: 0.35rem;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 0;
    overflow: visible;
  }

  .home-diapo__slide-inner--2 {
    gap: 0.3rem;
    padding: 0;
    height: auto;
    justify-content: flex-start;
  }

  .home-diapo__slide-main {
    flex: 0 1 auto;
    justify-content: center;
    align-items: center;
    min-height: 0;
    width: 100%;
  }

  .home-diapo__slide--1 .home-diapo__slide-main::after {
    display: none !important;
  }

  .home-diapo__slide-foot {
    display: none;
  }

  .home-diapo__hero-text {
    font-size: clamp(1.05rem, 4.8vh, 1.45rem);
    line-height: 1.24;
    max-width: min(34rem, 100%);
    margin-inline: auto;
    text-align: center;
  }

  .home-diapo__hero-text .home-diapo__hero-line2 {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.86em;
    line-height: 1.22;
  }

  .home-diapo__slide2-title {
    font-size: clamp(0.82rem, 2.2vw, 0.975rem);
    margin: 0 0 0.2rem;
    line-height: 1.15;
  }

  .home-diapo__slide2-lead {
    font-size: 0.72rem;
    line-height: 1.22;
    margin: 0 0 0.25rem;
  }

  .home-diapo__slide2-list {
    font-size: 0.68rem;
    line-height: 1.22;
    margin: 0;
    padding-left: 0.95rem;
  }

  .home-diapo__slide2-list li {
    margin-bottom: 0.12rem;
  }

  .home-diapo__slide2-links {
    display: none;
  }

  .home-diapo__accent {
    white-space: normal;
  }

  .home-diapo__scroll-cue {
    display: none !important;
  }

  .home-diapo__viewport .home-diapo__fab {
    position: relative;
    right: auto;
    bottom: auto;
    align-self: center;
    margin: 0.35rem auto 0;
    min-height: 1.85rem;
    padding: 0.32rem 0.55rem 0.32rem 0.65rem;
    transform: none;
    display: inline-flex;
  }

  .home-diapo__fab-label {
    font-size: 0.625rem;
  }

  .home-diapo__fab-num {
    font-size: 0.625rem;
  }

  .home-diapo__orb {
    opacity: 0.28;
  }

  body.shell-drawer-nav .top-bar--home {
    padding-top: max(0.35rem, env(safe-area-inset-top, 0px));
    padding-bottom: 0.35rem;
    padding-left: var(--edge-left);
    padding-right: var(--edge-right);
  }

  .main-content--home > .section--featured,
  .main-content--home > .section--future {
    padding-left: var(--edge-left);
    padding-right: var(--edge-right);
  }
}

/* Écrans scindés : texte panneau gauche, disque panneau droit */
@media (spanning: single-fold-vertical),
  (horizontal-viewport-segments: 2),
  (min-width: 900px) and (max-width: 1300px) and (min-height: 600px) and (max-height: 820px) and (min-aspect-ratio: 3/2) and (max-aspect-ratio: 41/20) {
  :root {
    --dual-pane-gutter: clamp(1.25rem, 4vw, 2.25rem);
    --dual-pane-max: calc(50vw - var(--dual-pane-gutter) - 0.75rem);
    --dual-pane-half: calc(50vw - var(--dual-pane-gutter));
    --dual-pane-gap: calc(var(--dual-pane-gutter) * 2);
    --edge-x: clamp(1.25rem, 4vw, 2.25rem);
    --edge-left: max(var(--edge-x), env(safe-area-inset-left, 0px));
    --edge-right: max(var(--edge-x), env(safe-area-inset-right, 0px));
  }

  .top-bar--home {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto;
    align-items: center;
  }

  body:not(.shell-drawer-nav) .top-bar--home {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    align-items: start;
  }

  body:not(.shell-drawer-nav) .top-bar__brand {
    grid-column: 1;
    grid-row: 1;
  }

  body:not(.shell-drawer-nav) .top-bar__nav {
    grid-column: 1;
    grid-row: 2;
    min-width: 0;
    max-width: 100%;
  }

  body:not(.shell-drawer-nav) .top-bar__right {
    grid-column: 2;
    grid-row: 1 / span 2;
    justify-self: end;
    align-self: center;
    max-width: 100%;
    border-top: 0;
    padding-top: 0;
  }

  .home-diapo__slide--1 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: minmax(0, 1fr);
    column-gap: 0;
    padding: 0;
    align-items: stretch;
  }

  .home-diapo__slide--1 .home-diapo__slide-inner {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
    max-width: 100%;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: clamp(1rem, 3vw, 1.75rem);
    box-sizing: border-box;
    justify-content: center;
    overflow-x: clip;
    overflow-y: auto;
  }

  .home-diapo__slide--1 > .home-diapo__load {
    grid-column: 2;
    grid-row: 1;
    display: block;
    position: relative;
    width: min(72%, 240px);
    height: min(72%, 240px);
    max-width: min(38vw, 260px);
    max-height: min(38vw, 260px);
    margin: auto;
    opacity: 1;
    align-self: center;
    justify-self: center;
  }

  .home-diapo__slide--1 .home-diapo__hero-text {
    max-width: 100%;
    font-size: clamp(1.05rem, 2.6vw, 1.55rem);
    line-height: 1.28;
  }

  .home-diapo__slide--1 .home-diapo__slide-main::after {
    display: none;
  }

  .home-diapo__viewport .home-diapo__fab {
    left: 75vw;
    right: auto;
    transform: translateX(-50%);
    bottom: clamp(0.85rem, 2.5vw, 1.25rem);
    max-width: calc(var(--dual-pane-half) - var(--dual-pane-gutter) * 2);
  }

  .home-diapo__fab:hover {
    transform: translateX(-50%) translateY(-1px);
  }

  .home-diapo__slide--1 .home-diapo__slide-foot {
    padding-right: 0;
    padding-bottom: 0.25rem;
  }

  .home-diapo__slide--1 .home-diapo__social {
    display: none;
  }

  .top-bar--home {
    background: rgba(255, 255, 255, 0.94);
  }

  .page-title,
  .home-diapo__slide2-title {
    scroll-margin-top: 5.5rem;
  }
}

html.is-dual-screen .home-diapo__slide--1,
body.is-dual-screen .home-diapo__slide--1 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: minmax(0, 1fr);
  column-gap: 0;
  padding: 0;
  align-items: stretch;
}

html.is-dual-screen .home-diapo__slide--1 .home-diapo__slide-inner,
body.is-dual-screen .home-diapo__slide--1 .home-diapo__slide-inner {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
  max-width: 100%;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: clamp(1rem, 3vw, 1.75rem);
  box-sizing: border-box;
  justify-content: center;
  overflow-x: clip;
  overflow-y: auto;
}

html.is-dual-screen .home-diapo__slide--1 > .home-diapo__load,
body.is-dual-screen .home-diapo__slide--1 > .home-diapo__load {
  grid-column: 2;
  grid-row: 1;
  display: block;
  position: relative;
  width: min(72%, 240px);
  height: min(72%, 240px);
  max-width: min(38vw, 260px);
  max-height: min(38vw, 260px);
  margin: auto;
  opacity: 1;
  align-self: center;
  justify-self: center;
}

html.is-dual-screen .home-diapo__slide--1 .home-diapo__hero-text,
body.is-dual-screen .home-diapo__slide--1 .home-diapo__hero-text {
  max-width: 100%;
  font-size: clamp(1.05rem, 2.6vw, 1.55rem);
  line-height: 1.28;
}

html.is-dual-screen .home-diapo__slide--1 .home-diapo__slide-main::after,
body.is-dual-screen .home-diapo__slide--1 .home-diapo__slide-main::after {
  display: none;
}

html.is-dual-screen .home-diapo__viewport .home-diapo__fab,
body.is-dual-screen .home-diapo__viewport .home-diapo__fab {
  left: 75vw;
  right: auto;
  transform: translateX(-50%);
  bottom: clamp(0.85rem, 2.5vw, 1.25rem);
  max-width: calc(var(--dual-pane-half) - var(--dual-pane-gutter) * 2);
}

html.is-dual-screen .home-diapo__slide--1 .home-diapo__social,
body.is-dual-screen .home-diapo__slide--1 .home-diapo__social {
  display: none;
}

html.is-dual-screen .home-diapo__slide--2 .home-diapo__slide-inner,
body.is-dual-screen .home-diapo__slide--2 .home-diapo__slide-inner {
  max-width: none;
  width: 100%;
  margin: 0;
  padding: 0 clamp(1rem, 3vw, 1.75rem);
  box-sizing: border-box;
}

html.is-dual-screen .home-diapo__fab:hover,
body.is-dual-screen .home-diapo__fab:hover {
  transform: translateX(-50%) translateY(-1px);
}

html.is-dual-screen .top-bar--home,
body.is-dual-screen .top-bar--home {
  background: rgba(255, 255, 255, 0.94);
}

html.is-dual-screen .page-title,
html.is-dual-screen .home-diapo__slide2-title,
body.is-dual-screen .page-title,
body.is-dual-screen .home-diapo__slide2-title {
  scroll-margin-top: 5.5rem;
}

/* Dual-screen — deux panneaux : texte/hero split, grilles 2 colonnes (gauche/droite) */
html.is-dual-screen,
body.is-dual-screen {
  --dual-pane-gutter: clamp(1.25rem, 4vw, 2.25rem);
  --dual-pane-max: calc(50vw - var(--dual-pane-gutter) - 0.75rem);
  --dual-pane-half: calc(50vw - var(--dual-pane-gutter));
  --dual-pane-gap: calc(var(--dual-pane-gutter) * 2);
  --edge-x: clamp(1.25rem, 4vw, 2.25rem);
  --edge-left: max(var(--edge-x), env(safe-area-inset-left, 0px));
  --edge-right: max(var(--edge-x), env(safe-area-inset-right, 0px));
}

@media (spanning: single-fold-vertical),
  (horizontal-viewport-segments: 2),
  (min-width: 900px) and (max-width: 1300px) and (min-height: 600px) and (max-height: 820px) and (min-aspect-ratio: 3/2) and (max-aspect-ratio: 41/20) {
  .home-diapo__viewport .home-diapo__fab {
    left: 75vw;
    right: auto;
    transform: translateX(-50%);
    bottom: clamp(0.85rem, 2.5vw, 1.25rem);
    max-width: calc(var(--dual-pane-half) - var(--dual-pane-gutter) * 2);
  }

  .home-diapo__fab:hover {
    transform: translateX(-50%) translateY(-1px);
  }

  .home-diapo__slide--1 .home-diapo__social {
    display: none;
  }

  .home-diapo__slide--1 .home-diapo__slide-foot {
    padding-right: 0;
    padding-bottom: 0.25rem;
  }

  .home-diapo__slide--2 .home-diapo__slide-inner {
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 0 clamp(1rem, 3vw, 1.75rem);
    box-sizing: border-box;
  }

  .main-content:not(.main-content--home):not(.has-workflow-showcase) {
    max-width: var(--dual-pane-max);
    width: 100%;
    margin: 0;
    margin-left: var(--dual-pane-gutter);
    margin-right: auto;
    padding: 1.75rem 0 2.5rem;
    padding-right: var(--dual-pane-gutter);
    box-sizing: border-box;
  }

  .main-content.has-workflow-showcase {
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 1.75rem var(--dual-pane-gutter) 2.5rem;
    box-sizing: border-box;
  }

  .main-content.has-workflow-showcase > :not(#workflow-showcase-root) {
    max-width: var(--dual-pane-max);
    margin-left: 0;
    margin-right: auto;
  }

  .main-content:not(.main-content--home) > .section:has(.project-list),
  .main-content:not(.main-content--home) .project-grid {
    max-width: none;
    width: 100%;
    margin-left: calc(-1 * var(--dual-pane-gutter));
    padding-left: var(--dual-pane-gutter);
    box-sizing: border-box;
  }

  .main-content:not(.main-content--home) .section:has(.project-list) > .section-title {
    max-width: var(--dual-pane-max);
    margin-left: 0;
  }

  .project-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 0;
    row-gap: 0.75rem;
    max-width: none;
    width: 100%;
  }

  .project-list .project-row {
    margin-bottom: 0;
    min-width: 0;
  }

  .project-list .project-row:nth-child(odd) {
    margin-right: calc(var(--dual-pane-gutter) * 0.4);
  }

  .project-list .project-row:nth-child(even) {
    margin-left: calc(var(--dual-pane-gutter) * 0.4);
  }

  .site-footer {
    padding-left: var(--edge-left);
    padding-right: var(--edge-right);
  }

  .main-content--home > .section--featured {
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 2.5rem 0 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 0;
    box-sizing: border-box;
  }

  .main-content--home > .section--featured .section-title,
  .main-content--home > .section--featured .section-intro,
  .main-content--home > .section--featured .home-cta-projects {
    grid-column: 1;
    padding-right: 0.75rem;
  }

  .main-content--home > .section--featured .project-grid {
    grid-column: 1 / -1;
    grid-template-columns: 1fr 1fr;
    column-gap: 0;
    row-gap: 1rem;
    width: 100%;
  }

  .main-content--home > .section--featured .project-card:nth-child(odd) {
    margin-right: calc(var(--dual-pane-gutter) * 0.4);
  }

  .main-content--home > .section--featured .project-card:nth-child(even) {
    margin-left: calc(var(--dual-pane-gutter) * 0.4);
  }

  .main-content--home > .section--future {
    max-width: var(--dual-pane-max);
    margin-left: var(--dual-pane-gutter);
    margin-right: auto;
    padding-left: var(--edge-left);
    padding-right: var(--edge-right);
    box-sizing: border-box;
  }

  .project-grid:not(.project-grid--home),
  .stats-grid {
    grid-template-columns: 1fr 1fr;
    column-gap: 0;
    row-gap: 1rem;
  }

  .project-grid:not(.project-grid--home) .project-card:nth-child(odd),
  .stats-grid > *:nth-child(odd) {
    margin-right: calc(var(--dual-pane-gutter) * 0.4);
  }

  .project-grid:not(.project-grid--home) .project-card:nth-child(even),
  .stats-grid > *:nth-child(even) {
    margin-left: calc(var(--dual-pane-gutter) * 0.4);
  }

  .site-footer-inner {
    max-width: var(--dual-pane-max);
    width: 100%;
    margin: 0;
    padding: 1.5rem 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    box-sizing: border-box;
    gap: 0.75rem 1rem;
  }

  .site-footer-inner .footer-links {
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 0.85rem 1rem;
  }

  .page-atmosphere {
    clip-path: none;
    opacity: 0.45;
    width: var(--dual-pane-half);
    left: auto;
    right: 0;
  }

  .workflow-showcase {
    grid-template-columns: 1fr 1fr;
    column-gap: var(--dual-pane-gutter);
  }

  .top-bar--home {
    background: rgba(255, 255, 255, 0.94);
  }
}

html.is-dual-screen .main-content:not(.main-content--home):not(.has-workflow-showcase),
body.is-dual-screen .main-content:not(.main-content--home):not(.has-workflow-showcase) {
  max-width: var(--dual-pane-max);
  width: 100%;
  margin: 0;
  margin-left: var(--dual-pane-gutter);
  margin-right: auto;
  padding: 1.75rem 0 2.5rem;
  padding-right: var(--dual-pane-gutter);
  box-sizing: border-box;
}

html.is-dual-screen .main-content.has-workflow-showcase,
body.is-dual-screen .main-content.has-workflow-showcase {
  max-width: none;
  width: 100%;
  margin: 0;
  padding: 1.75rem var(--dual-pane-gutter) 2.5rem;
  box-sizing: border-box;
}

html.is-dual-screen .main-content.has-workflow-showcase > :not(#workflow-showcase-root),
body.is-dual-screen .main-content.has-workflow-showcase > :not(#workflow-showcase-root) {
  max-width: var(--dual-pane-max);
  margin-left: 0;
  margin-right: auto;
}

html.is-dual-screen .main-content:not(.main-content--home) > .section:has(.project-list),
html.is-dual-screen .main-content:not(.main-content--home) .project-grid,
body.is-dual-screen .main-content:not(.main-content--home) > .section:has(.project-list),
body.is-dual-screen .main-content:not(.main-content--home) .project-grid {
  max-width: none;
  width: 100%;
  margin-left: calc(-1 * var(--dual-pane-gutter));
  padding-left: var(--dual-pane-gutter);
  box-sizing: border-box;
}

html.is-dual-screen .main-content:not(.main-content--home) .section:has(.project-list) > .section-title,
body.is-dual-screen .main-content:not(.main-content--home) .section:has(.project-list) > .section-title {
  max-width: var(--dual-pane-max);
  margin-left: 0;
}

html.is-dual-screen .project-list,
body.is-dual-screen .project-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 0;
  row-gap: 0.75rem;
  max-width: none;
  width: 100%;
}

html.is-dual-screen .project-list .project-row,
body.is-dual-screen .project-list .project-row {
  margin-bottom: 0;
  min-width: 0;
}

html.is-dual-screen .project-list .project-row:nth-child(odd),
body.is-dual-screen .project-list .project-row:nth-child(odd) {
  margin-right: calc(var(--dual-pane-gutter) * 0.4);
}

html.is-dual-screen .project-list .project-row:nth-child(even),
body.is-dual-screen .project-list .project-row:nth-child(even) {
  margin-left: calc(var(--dual-pane-gutter) * 0.4);
}

html.is-dual-screen .main-content.has-workflow-showcase > :not(#workflow-showcase-root),
body.is-dual-screen .main-content.has-workflow-showcase > :not(#workflow-showcase-root) {
  max-width: var(--dual-pane-max);
  margin-left: 0;
  margin-right: auto;
}

html.is-dual-screen .main-content.has-workflow-showcase #workflow-showcase-root,
body.is-dual-screen .main-content.has-workflow-showcase #workflow-showcase-root {
  max-width: none;
  width: 100%;
}

html.is-dual-screen .site-footer,
body.is-dual-screen .site-footer {
  padding-left: var(--edge-left);
  padding-right: var(--edge-right);
}

html.is-dual-screen .main-content--home > .section--featured,
body.is-dual-screen .main-content--home > .section--featured {
  max-width: none;
  width: 100%;
  margin: 0;
  padding: 2.5rem 0 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 0;
  box-sizing: border-box;
}

html.is-dual-screen .main-content--home > .section--featured .section-title,
html.is-dual-screen .main-content--home > .section--featured .section-intro,
html.is-dual-screen .main-content--home > .section--featured .home-cta-projects,
body.is-dual-screen .main-content--home > .section--featured .section-title,
body.is-dual-screen .main-content--home > .section--featured .section-intro,
body.is-dual-screen .main-content--home > .section--featured .home-cta-projects {
  grid-column: 1;
  padding-right: 0.75rem;
}

html.is-dual-screen .main-content--home > .section--featured .project-grid,
body.is-dual-screen .main-content--home > .section--featured .project-grid {
  grid-column: 1 / -1;
  grid-template-columns: 1fr 1fr;
  column-gap: 0;
  row-gap: 1rem;
  width: 100%;
}

html.is-dual-screen .main-content--home > .section--featured .project-card:nth-child(odd),
body.is-dual-screen .main-content--home > .section--featured .project-card:nth-child(odd) {
  margin-right: calc(var(--dual-pane-gutter) * 0.4);
}

html.is-dual-screen .main-content--home > .section--featured .project-card:nth-child(even),
body.is-dual-screen .main-content--home > .section--featured .project-card:nth-child(even) {
  margin-left: calc(var(--dual-pane-gutter) * 0.4);
}

html.is-dual-screen .main-content--home > .section--future,
body.is-dual-screen .main-content--home > .section--future {
  max-width: var(--dual-pane-max);
  margin-left: var(--dual-pane-gutter);
  margin-right: auto;
  padding-left: var(--edge-left);
  padding-right: var(--edge-right);
  box-sizing: border-box;
}

html.is-dual-screen .project-grid:not(.project-grid--home),
html.is-dual-screen .stats-grid,
body.is-dual-screen .project-grid:not(.project-grid--home),
body.is-dual-screen .stats-grid {
  grid-template-columns: 1fr 1fr;
  column-gap: 0;
  row-gap: 1rem;
}

html.is-dual-screen .project-grid:not(.project-grid--home) .project-card:nth-child(odd),
html.is-dual-screen .stats-grid > *:nth-child(odd),
body.is-dual-screen .project-grid:not(.project-grid--home) .project-card:nth-child(odd),
body.is-dual-screen .stats-grid > *:nth-child(odd) {
  margin-right: calc(var(--dual-pane-gutter) * 0.4);
}

html.is-dual-screen .project-grid:not(.project-grid--home) .project-card:nth-child(even),
html.is-dual-screen .stats-grid > *:nth-child(even),
body.is-dual-screen .project-grid:not(.project-grid--home) .project-card:nth-child(even),
body.is-dual-screen .stats-grid > *:nth-child(even) {
  margin-left: calc(var(--dual-pane-gutter) * 0.4);
}

html.is-dual-screen .site-footer-inner,
body.is-dual-screen .site-footer-inner {
  max-width: var(--dual-pane-max);
  width: 100%;
  margin: 0;
  padding: 1.5rem 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  box-sizing: border-box;
  gap: 0.75rem 1rem;
}

html.is-dual-screen .site-footer-inner .footer-links,
body.is-dual-screen .site-footer-inner .footer-links {
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 0.85rem 1rem;
}

html.is-dual-screen .main-content.has-workflow-showcase,
body.is-dual-screen .main-content.has-workflow-showcase {
  max-width: none;
  width: 100%;
  margin: 0;
  padding: 1.75rem var(--dual-pane-gutter) 2.5rem;
  box-sizing: border-box;
}

html.is-dual-screen .workflow-showcase,
body.is-dual-screen .workflow-showcase {
  grid-template-columns: 1fr 1fr;
  column-gap: var(--dual-pane-gutter);
}

html.is-dual-screen .page-atmosphere,
body.is-dual-screen .page-atmosphere {
  clip-path: none;
  opacity: 0.45;
  width: var(--dual-pane-half);
  left: auto;
  right: 0;
}

/* ——— Dual-screen layout v2 : contenu dispatché sur 2 panneaux ——— */
@media (spanning: single-fold-vertical),
  (horizontal-viewport-segments: 2),
  (min-width: 900px) and (max-width: 1300px) and (min-height: 600px) and (max-height: 820px) and (min-aspect-ratio: 3/2) and (max-aspect-ratio: 41/20) {
  .home-diapo__slide--2 .home-diapo__slide-inner--2 {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: var(--dual-pane-gap);
    align-content: start;
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }

  .home-diapo__slide--2 .home-diapo__slide2-title,
  .home-diapo__slide--2 .home-diapo__slide2-lead,
  .home-diapo__slide--2 .home-diapo__slide2-list {
    grid-column: 1;
    max-width: 100%;
    min-width: 0;
  }

  .home-diapo__slide--2 .home-diapo__slide2-links {
    grid-column: 2;
    align-self: end;
    min-width: 0;
  }

  .main-content--home {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: var(--dual-pane-gap);
    max-width: none;
    width: 100%;
    padding-left: var(--edge-left);
    padding-right: var(--edge-right);
    box-sizing: border-box;
  }

  .main-content--home > .home-diapo {
    grid-column: 1 / -1;
  }

  .main-content--home > .section--featured {
    grid-column: 1 / -1;
    column-gap: var(--dual-pane-gap);
  }

  .main-content--home > .section--future {
    grid-column: 2;
    max-width: none;
    margin: 0;
    padding: 2.5rem 0 0;
    align-self: start;
  }

  .main-content:not(.main-content--home):not(.has-workflow-showcase):not(.prose) {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: var(--dual-pane-gap);
    row-gap: 1.25rem;
    align-items: start;
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 1.75rem var(--dual-pane-gutter) 2.5rem;
    box-sizing: border-box;
  }

  .main-content.prose:not(.main-content--home) {
    display: block;
    max-width: var(--dual-pane-max);
    width: 100%;
    margin: 0;
    margin-left: var(--dual-pane-gutter);
    margin-right: auto;
    padding: 1.75rem 0 2.5rem;
    padding-right: var(--dual-pane-gutter);
    box-sizing: border-box;
  }

  .main-content.prose:not(.main-content--home) > * {
    max-width: 100%;
    min-width: 0;
  }

  .main-content:not(.main-content--home) > .page-title,
  .main-content:not(.main-content--home) > .page-lead,
  .main-content:not(.main-content--home) > .career-actions {
    grid-column: 1;
    max-width: 100%;
    min-width: 0;
  }

  .main-content:not(.prose):not(.main-content--home) > p:not(.page-lead) {
    grid-column: 1;
    min-width: 0;
  }

  .main-content:not(.prose):not(.main-content--home) > #career-profile,
  .main-content:not(.prose):not(.main-content--home) > #career-filters,
  .main-content:not(.prose):not(.main-content--home) > #career-education {
    grid-column: 1;
  }

  .main-content:not(.prose):not(.main-content--home) > #career-impact,
  .main-content:not(.prose):not(.main-content--home) > #career-experiences {
    grid-column: 2;
  }

  .main-content > .section:has(.project-list),
  .main-content > .section:has(.project-grid) {
    grid-column: 1 / -1;
    min-width: 0;
    margin: 0;
    padding: 0;
  }

  .main-content > .section#future-additions {
    grid-column: 2;
    align-self: start;
  }

  .main-content.has-workflow-showcase {
    display: block;
    max-width: none;
    width: 100%;
    margin: 0;
    padding: 1.75rem var(--dual-pane-gutter) 2.5rem;
    box-sizing: border-box;
  }

  .main-content.has-workflow-showcase #workflow-showcase-root {
    max-width: none;
    width: 100%;
    margin-bottom: 1.5rem;
  }

  .main-content.has-workflow-showcase > [id$="-guide-content"] {
    max-width: var(--dual-pane-max);
    margin-left: 0;
    margin-right: auto;
    column-count: unset;
  }

  .project-list {
    column-gap: var(--dual-pane-gap);
  }

  .project-list .project-row:nth-child(odd) {
    margin-right: 0;
  }

  .project-list .project-row:nth-child(even) {
    margin-left: 0;
  }

  .main-content--home > .section--featured .project-grid,
  .project-grid:not(.project-grid--home),
  .stats-grid {
    column-gap: var(--dual-pane-gap);
  }

  .main-content--home > .section--featured .project-card:nth-child(odd),
  .project-grid:not(.project-grid--home) .project-card:nth-child(odd),
  .stats-grid > *:nth-child(odd) {
    margin-right: 0;
  }

  .main-content--home > .section--featured .project-card:nth-child(even),
  .project-grid:not(.project-grid--home) .project-card:nth-child(even),
  .stats-grid > *:nth-child(even) {
    margin-left: 0;
  }

  .site-footer-inner {
    max-width: var(--dual-pane-max);
    margin: 0;
    padding: 1.5rem 0;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 0.65rem;
  }

  .site-footer-inner .footer-links {
    justify-content: flex-start;
    gap: 0.65rem 0.85rem;
  }

  .main-content :where(p, li, h1, h2, h3, h4, .card, .project-row, .project-row-body) {
    min-width: 0;
    overflow-wrap: break-word;
  }

  .project-row {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }
}

html.is-dual-screen .home-diapo__slide--2 .home-diapo__slide-inner--2,
body.is-dual-screen .home-diapo__slide--2 .home-diapo__slide-inner--2 {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  column-gap: var(--dual-pane-gap);
  align-content: start;
  max-width: none;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html.is-dual-screen .home-diapo__slide--2 .home-diapo__slide2-title,
html.is-dual-screen .home-diapo__slide--2 .home-diapo__slide2-lead,
html.is-dual-screen .home-diapo__slide--2 .home-diapo__slide2-list,
body.is-dual-screen .home-diapo__slide--2 .home-diapo__slide2-title,
body.is-dual-screen .home-diapo__slide--2 .home-diapo__slide2-lead,
body.is-dual-screen .home-diapo__slide--2 .home-diapo__slide2-list {
  grid-column: 1;
  max-width: 100%;
  min-width: 0;
}

html.is-dual-screen .home-diapo__slide--2 .home-diapo__slide2-links,
body.is-dual-screen .home-diapo__slide--2 .home-diapo__slide2-links {
  grid-column: 2;
  align-self: end;
  min-width: 0;
}

html.is-dual-screen .main-content--home,
body.is-dual-screen .main-content--home {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  column-gap: var(--dual-pane-gap);
  max-width: none;
  width: 100%;
  padding-left: var(--edge-left);
  padding-right: var(--edge-right);
  box-sizing: border-box;
}

html.is-dual-screen .main-content--home > .home-diapo,
body.is-dual-screen .main-content--home > .home-diapo {
  grid-column: 1 / -1;
}

html.is-dual-screen .main-content--home > .section--featured,
body.is-dual-screen .main-content--home > .section--featured {
  grid-column: 1 / -1;
  column-gap: var(--dual-pane-gap);
}

html.is-dual-screen .main-content--home > .section--future,
body.is-dual-screen .main-content--home > .section--future {
  grid-column: 2;
  max-width: none;
  margin: 0;
  padding: 2.5rem 0 0;
  align-self: start;
}

html.is-dual-screen .main-content:not(.main-content--home):not(.has-workflow-showcase):not(.prose),
body.is-dual-screen .main-content:not(.main-content--home):not(.has-workflow-showcase):not(.prose) {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  column-gap: var(--dual-pane-gap);
  row-gap: 1.25rem;
  align-items: start;
  max-width: none;
  width: 100%;
  margin: 0;
  padding: 1.75rem var(--dual-pane-gutter) 2.5rem;
  box-sizing: border-box;
}

html.is-dual-screen .main-content.prose:not(.main-content--home),
body.is-dual-screen .main-content.prose:not(.main-content--home) {
  display: block;
  max-width: var(--dual-pane-max);
  width: 100%;
  margin: 0;
  margin-left: var(--dual-pane-gutter);
  margin-right: auto;
  padding: 1.75rem 0 2.5rem;
  padding-right: var(--dual-pane-gutter);
  box-sizing: border-box;
}

html.is-dual-screen .main-content.prose:not(.main-content--home) > *,
body.is-dual-screen .main-content.prose:not(.main-content--home) > * {
  max-width: 100%;
  min-width: 0;
}

html.is-dual-screen .main-content:not(.main-content--home) > .page-title,
html.is-dual-screen .main-content:not(.main-content--home) > .page-lead,
html.is-dual-screen .main-content:not(.main-content--home) > .career-actions,
body.is-dual-screen .main-content:not(.main-content--home) > .page-title,
body.is-dual-screen .main-content:not(.main-content--home) > .page-lead,
body.is-dual-screen .main-content:not(.main-content--home) > .career-actions {
  grid-column: 1;
  max-width: 100%;
  min-width: 0;
}

html.is-dual-screen .main-content:not(.prose):not(.main-content--home) > p:not(.page-lead),
body.is-dual-screen .main-content:not(.prose):not(.main-content--home) > p:not(.page-lead) {
  grid-column: 1;
  min-width: 0;
}

html.is-dual-screen .main-content:not(.prose):not(.main-content--home) > #career-profile,
html.is-dual-screen .main-content:not(.prose):not(.main-content--home) > #career-filters,
html.is-dual-screen .main-content:not(.prose):not(.main-content--home) > #career-education,
body.is-dual-screen .main-content:not(.prose):not(.main-content--home) > #career-profile,
body.is-dual-screen .main-content:not(.prose):not(.main-content--home) > #career-filters,
body.is-dual-screen .main-content:not(.prose):not(.main-content--home) > #career-education {
  grid-column: 1;
}

html.is-dual-screen .main-content:not(.prose):not(.main-content--home) > #career-impact,
html.is-dual-screen .main-content:not(.prose):not(.main-content--home) > #career-experiences,
body.is-dual-screen .main-content:not(.prose):not(.main-content--home) > #career-impact,
body.is-dual-screen .main-content:not(.prose):not(.main-content--home) > #career-experiences {
  grid-column: 2;
}

html.is-dual-screen .main-content > .section:has(.project-list),
html.is-dual-screen .main-content > .section:has(.project-grid),
body.is-dual-screen .main-content > .section:has(.project-list),
body.is-dual-screen .main-content > .section:has(.project-grid) {
  grid-column: 1 / -1;
  min-width: 0;
  margin: 0;
  padding: 0;
}

html.is-dual-screen .main-content > .section#future-additions,
body.is-dual-screen .main-content > .section#future-additions {
  grid-column: 2;
  align-self: start;
}

html.is-dual-screen .main-content.has-workflow-showcase,
body.is-dual-screen .main-content.has-workflow-showcase {
  display: block;
  max-width: none;
  width: 100%;
  margin: 0;
  padding: 1.75rem var(--dual-pane-gutter) 2.5rem;
  box-sizing: border-box;
}

html.is-dual-screen .main-content.has-workflow-showcase #workflow-showcase-root,
body.is-dual-screen .main-content.has-workflow-showcase #workflow-showcase-root {
  max-width: none;
  width: 100%;
  margin-bottom: 1.5rem;
}

html.is-dual-screen .main-content.has-workflow-showcase > [id$="-guide-content"],
body.is-dual-screen .main-content.has-workflow-showcase > [id$="-guide-content"] {
  max-width: var(--dual-pane-max);
  margin-left: 0;
  margin-right: auto;
  column-count: unset;
}

html.is-dual-screen .project-list,
body.is-dual-screen .project-list {
  column-gap: var(--dual-pane-gap);
}

html.is-dual-screen .project-list .project-row:nth-child(odd),
body.is-dual-screen .project-list .project-row:nth-child(odd) {
  margin-right: 0;
}

html.is-dual-screen .project-list .project-row:nth-child(even),
body.is-dual-screen .project-list .project-row:nth-child(even) {
  margin-left: 0;
}

html.is-dual-screen .main-content--home > .section--featured .project-grid,
html.is-dual-screen .project-grid:not(.project-grid--home),
html.is-dual-screen .stats-grid,
body.is-dual-screen .main-content--home > .section--featured .project-grid,
body.is-dual-screen .project-grid:not(.project-grid--home),
body.is-dual-screen .stats-grid {
  column-gap: var(--dual-pane-gap);
}

html.is-dual-screen .main-content--home > .section--featured .project-card:nth-child(odd),
html.is-dual-screen .project-grid:not(.project-grid--home) .project-card:nth-child(odd),
html.is-dual-screen .stats-grid > *:nth-child(odd),
body.is-dual-screen .main-content--home > .section--featured .project-card:nth-child(odd),
body.is-dual-screen .project-grid:not(.project-grid--home) .project-card:nth-child(odd),
body.is-dual-screen .stats-grid > *:nth-child(odd) {
  margin-right: 0;
}

html.is-dual-screen .main-content--home > .section--featured .project-card:nth-child(even),
html.is-dual-screen .project-grid:not(.project-grid--home) .project-card:nth-child(even),
html.is-dual-screen .stats-grid > *:nth-child(even),
body.is-dual-screen .main-content--home > .section--featured .project-card:nth-child(even),
body.is-dual-screen .project-grid:not(.project-grid--home) .project-card:nth-child(even),
body.is-dual-screen .stats-grid > *:nth-child(even) {
  margin-left: 0;
}

html.is-dual-screen .site-footer-inner,
body.is-dual-screen .site-footer-inner {
  max-width: var(--dual-pane-max);
  margin: 0;
  padding: 1.5rem 0;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0.65rem;
}

html.is-dual-screen .site-footer-inner .footer-links,
body.is-dual-screen .site-footer-inner .footer-links {
  justify-content: flex-start;
  gap: 0.65rem 0.85rem;
}

html.is-dual-screen .main-content :where(p, li, h1, h2, h3, h4, .card, .project-row, .project-row-body),
body.is-dual-screen .main-content :where(p, li, h1, h2, h3, h4, .card, .project-row, .project-row-body) {
  min-width: 0;
  overflow-wrap: break-word;
}

html.is-dual-screen .project-row,
body.is-dual-screen .project-row {
  grid-template-columns: auto minmax(0, 1fr) auto;
}

html.is-dual-screen .home-diapo__slide--1 .home-diapo__slide-inner,
body.is-dual-screen .home-diapo__slide--1 .home-diapo__slide-inner {
  overflow-x: clip;
  overflow-y: auto;
}

@media (max-width: 767px) {
  .home-diapo {
    --home-diapo-h: auto;
    padding-bottom: 0.85rem;
  }

  .home-diapo__viewport {
    height: auto;
    overflow: visible;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.35rem;
    padding-bottom: 0.35rem;
  }

  .home-diapo__track {
    height: auto;
    transform: none !important;
  }

  .home-diapo__slide {
    flex: 0 0 auto;
    height: auto;
    max-height: none;
    min-height: 0;
    padding: 1.15rem 1.15rem 0.5rem;
  }

  .home-diapo:not(.is-slide-2) .home-diapo__slide--2 {
    display: none;
  }

  .home-diapo.is-slide-2 .home-diapo__slide--1 {
    display: none;
  }

  .home-diapo__slide--1 .home-diapo__slide-inner {
    gap: 0.9rem;
    justify-content: flex-start;
    height: auto;
  }

  .home-diapo__slide--1 .home-diapo__slide-main {
    flex: 0 1 auto;
    justify-content: flex-start;
  }

  /* Disque mobile : taille définie plus bas (section hero motion) */
  .home-diapo__slide--1 > .home-diapo__load {
    pointer-events: none;
  }

  .home-diapo__slide--1 .home-diapo__slide-main::after {
    display: block;
    width: 100%;
    height: 3px;
    margin-top: 1rem;
    border-radius: 999px;
    background: linear-gradient(
      90deg,
      var(--accent-soft) 0%,
      var(--accent-muted) calc(var(--load-p, 0) * 100%),
      rgba(167, 139, 250, 0.1) calc(var(--load-p, 0) * 100%),
      rgba(167, 139, 250, 0.1) 100%
    );
  }

  .home-diapo__hero-text {
    max-width: 100%;
    font-size: clamp(1.22rem, 5.8vw, 1.62rem);
    line-height: 1.38;
  }

  .home-diapo__hero-text .home-diapo__hero-line2 {
    display: block;
    margin-top: 0.55rem;
  }

  .home-diapo__accent {
    white-space: normal;
  }

  .home-diapo__slide--1 .home-diapo__social {
    display: none;
  }

  .home-diapo__slide-foot {
    margin-top: 0.5rem;
    padding-top: 0.35rem;
  }

  .home-diapo__quote {
    font-size: 0.75rem;
    max-width: none;
    line-height: 1.5;
  }

  /* FAB dans le flux — plus de chevauchement avec la citation */
  .home-diapo__viewport .home-diapo__fab {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    transform: none;
    align-self: center;
    margin: 1.15rem auto 0.5rem;
    max-width: calc(100% - 2rem);
    flex-shrink: 0;
  }

  .home-diapo__fab:hover {
    transform: translateY(-1px);
  }

  .home-diapo__slide-inner--2 {
    padding-bottom: 0.75rem;
  }

  .main-content--home > .section--featured {
    padding-top: 2.15rem;
  }
}

@media (max-width: 640px) {
  .home-diapo__vline {
    display: none;
  }

  .home-diapo__hero-text {
    font-size: clamp(1.14rem, 5.6vw, 1.48rem);
  }

  .home-diapo__viewport .home-diapo__fab {
    margin-bottom: 0.55rem;
  }

  .main-content--home > .section--featured {
    padding-top: 2rem;
  }
}

@media (max-width: 520px) {
  .home-diapo__slide-foot {
    flex-direction: column;
    align-items: flex-start;
  }

  .home-diapo__social {
    justify-content: flex-start;
  }
}

/* —— Home hero : ambiance + entrée en scène —— */
.home-diapo__ambient {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
}

.home-diapo__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(42px);
  opacity: 0.55;
  will-change: transform;
}

.home-diapo__orb--a {
  width: min(42vw, 180px);
  height: min(42vw, 180px);
  top: -8%;
  right: -6%;
  background: radial-gradient(circle, rgba(167, 139, 250, 0.55) 0%, rgba(167, 139, 250, 0) 70%);
  animation: home-orb-drift-a 14s ease-in-out infinite;
}

.home-diapo__orb--b {
  width: min(34vw, 140px);
  height: min(34vw, 140px);
  bottom: 8%;
  left: -8%;
  background: radial-gradient(circle, rgba(99, 102, 241, 0.4) 0%, rgba(99, 102, 241, 0) 72%);
  animation: home-orb-drift-b 11s ease-in-out infinite;
}

.home-diapo__orb--c {
  width: min(28vw, 110px);
  height: min(28vw, 110px);
  top: 38%;
  right: 18%;
  background: radial-gradient(circle, rgba(244, 114, 182, 0.28) 0%, rgba(244, 114, 182, 0) 70%);
  animation: home-orb-drift-c 9s ease-in-out infinite;
}

@keyframes home-orb-drift-a {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }
  50% {
    transform: translate(-12px, 16px) scale(1.06);
  }
}

@keyframes home-orb-drift-b {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }
  50% {
    transform: translate(14px, -10px) scale(1.08);
  }
}

@keyframes home-orb-drift-c {
  0%,
  100% {
    transform: translate(0, 0) scale(0.95);
    opacity: 0.35;
  }
  50% {
    transform: translate(-8px, 12px) scale(1.05);
    opacity: 0.55;
  }
}

@keyframes home-rise-in {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes home-scale-in {
  from {
    opacity: 0;
    transform: scale(0.82);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes home-scroll-pulse {
  0%,
  100% {
    transform: translateY(0);
    opacity: 0.55;
  }
  50% {
    transform: translateY(5px);
    opacity: 1;
  }
}

@keyframes home-fab-mark-pulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(109, 40, 217, 0.18);
  }
  50% {
    box-shadow: 0 0 0 6px rgba(109, 40, 217, 0);
  }
}

.home-diapo__scroll-cue {
  display: none;
  text-decoration: none;
  color: inherit;
}

html.home-animate .home-diapo__slide--1 .home-diapo__hero-text {
  animation: home-rise-in 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.08s both;
}

html.home-animate .home-diapo__slide--1 .home-diapo__slide-main::after {
  animation: home-rise-in 0.65s cubic-bezier(0.22, 1, 0.36, 1) 0.28s both;
}

html.home-animate .home-diapo__slide--1 .home-diapo__quote {
  animation: home-rise-in 0.65s cubic-bezier(0.22, 1, 0.36, 1) 0.42s both;
}

html.home-animate .home-diapo__viewport .home-diapo__fab {
  animation: home-rise-in 0.65s cubic-bezier(0.22, 1, 0.36, 1) 0.52s both;
}

html.home-animate .home-diapo__scroll-cue {
  animation: home-rise-in 0.6s cubic-bezier(0.22, 1, 0.36, 1) 0.72s both;
}

html.home-animate .home-diapo__slide--1 > .home-diapo__load {
  animation: home-scale-in 0.85s cubic-bezier(0.22, 1, 0.36, 1) 0.02s both;
}

#home-diapo.is-hero-live .home-diapo__slide--1 .home-diapo__slide-main::after {
  box-shadow: 0 0 14px rgba(139, 92, 246, 0.28);
  transition: box-shadow 0.45s ease;
}

#home-diapo.is-hero-live .home-diapo__fab-mark {
  animation: home-fab-mark-pulse 2.4s ease-in-out infinite;
}

@media (max-width: 767px) {
  .home-diapo__slide--1 {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }

  .home-diapo__slide--1 > .home-diapo__backdrop {
    position: absolute;
    inset: 0;
  }

  .home-diapo__slide--1 > .home-diapo__load {
    position: relative;
    width: clamp(58px, 17vw, 76px);
    height: clamp(58px, 17vw, 76px);
    margin: 0.5rem auto 1.1rem;
    opacity: 1;
    overflow: hidden;
    pointer-events: none;
    flex-shrink: 0;
    order: 0;
    --home-disk-size: clamp(58px, 17vw, 76px);
  }

  .home-diapo__slide--1 > .home-diapo__slide-inner {
    order: 1;
  }

  .home-diapo__scroll-cue {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 0.5rem auto 1rem;
    padding: 0.35rem 0.5rem 0;
  }

  .home-diapo__scroll-cue-dot {
    display: block;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--accent-muted);
    box-shadow: 0 0 0 4px rgba(167, 139, 250, 0.14);
    animation: home-scroll-pulse 2.1s ease-in-out infinite;
  }

  .home-diapo__scroll-cue::after {
    content: "";
    display: block;
    width: 1px;
    height: 32px;
    margin-top: 0.5rem;
    background: linear-gradient(180deg, rgba(139, 92, 246, 0.45), transparent);
    animation: home-scroll-pulse 2.1s ease-in-out infinite;
  }

  .home-diapo.is-slide-2 .home-diapo__scroll-cue {
    display: none;
  }

  .home-diapo__viewport .home-diapo__fab {
    box-shadow:
      0 6px 28px rgba(109, 40, 217, 0.14),
      0 0 0 1px rgba(255, 255, 255, 0.85);
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-diapo__orb,
  .home-diapo__scroll-cue-dot,
  .home-diapo__scroll-cue::after,
  #home-diapo.is-hero-live .home-diapo__fab-mark {
    animation: none !important;
  }

  html.home-animate .home-diapo__slide--1 .home-diapo__hero-text,
  html.home-animate .home-diapo__slide--1 .home-diapo__slide-main::after,
  html.home-animate .home-diapo__slide--1 .home-diapo__quote,
  html.home-animate .home-diapo__viewport .home-diapo__fab,
  html.home-animate .home-diapo__scroll-cue,
  html.home-animate .home-diapo__slide--1 > .home-diapo__load {
    animation: none !important;
  }
}

/* Scroll-in blocks (enabled via html.home-animate from main.js) */
html.home-animate .home-reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.65s ease, transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}

html.home-animate .home-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

html.home-animate #featured-projects .project-card {
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity 0.55s ease,
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.15s ease,
    border-color 0.15s ease;
}

html.home-animate #featured-projects.is-inview .project-card:nth-child(1) {
  transition-delay: 0.05s;
}

html.home-animate #featured-projects.is-inview .project-card:nth-child(2) {
  transition-delay: 0.12s;
}

html.home-animate #featured-projects.is-inview .project-card:nth-child(3) {
  transition-delay: 0.19s;
}

html.home-animate #featured-projects.is-inview .project-card {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  html.home-animate .home-reveal,
  html.home-animate #featured-projects .project-card {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

.main-content--home .page-lead--home {
  max-width: 58ch;
  margin-bottom: 1.25rem;
}

.home-quick-links {
  margin: 0 0 2rem;
}

.home-quick-links ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.home-quick-links a {
  display: inline-block;
  padding: 0.45rem 0.9rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--navy-soft);
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 999px;
  text-decoration: none;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  backdrop-filter: blur(6px);
  transition: border-color 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.home-quick-links a:hover {
  border-color: var(--accent);
  color: var(--accent);
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(30, 64, 175, 0.12);
}

.home-value {
  margin-bottom: 2.25rem;
}

.home-value-lead {
  margin: 0 0 1rem;
  font-size: 1rem;
  color: var(--text);
  max-width: 58ch;
  line-height: 1.55;
}

.home-value-list {
  margin: 0;
  padding-left: 1.15rem;
  color: var(--text-muted);
  font-size: 0.9375rem;
  max-width: 58ch;
}

.home-value-list li {
  margin-bottom: 0.5rem;
}

.home-value-list li::marker {
  color: #94a3b8;
}

.home-value-list strong {
  color: var(--navy-soft);
}

.section-intro {
  margin: -0.35rem 0 1.25rem;
  font-size: 0.9375rem;
  color: var(--text-muted);
  max-width: 52ch;
}

.section-intro--muted {
  margin-bottom: 0.75rem;
}

.section--featured .section-title {
  margin-bottom: 0.35rem;
}

.project-grid--home {
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}

@media (min-width: 900px) {
  .project-grid--home {
    grid-template-columns: repeat(3, 1fr);
  }
}

.home-cta-projects {
  margin-top: 1.5rem;
  padding-top: 0.25rem;
}

.home-cta-projects-btn {
  padding: 0.65rem 1.25rem;
  font-size: 0.9375rem;
}

.section--future {
  padding-top: 1.25rem;
  border-top: 1px solid var(--border);
  margin-bottom: 1rem;
}

.future-list {
  margin-top: 0;
}

/* Stats grid */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
}

.stat-card {
  background: var(--bg-main);
  border-radius: var(--radius);
  padding: 1.25rem;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--border);
}

.stat-card-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  margin-bottom: 0.75rem;
}

.stat-card-icon.blue {
  background: #dbeafe;
  color: #1d4ed8;
}

.stat-card-icon.green {
  background: var(--pastel-b);
  color: var(--pastel-b-text);
}

.stat-card-icon.amber {
  background: var(--pastel-a);
  color: var(--pastel-a-text);
}

.stat-card-icon.slate {
  background: var(--surface-cool);
  color: var(--text-muted);
}

.stat-value {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--navy);
  line-height: 1.2;
}

.stat-label {
  font-size: 0.875rem;
  color: var(--text-muted);
  margin-top: 0.25rem;
}

/* Cards */
.card {
  background: var(--bg-main);
  border-radius: var(--radius);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  padding: 1.25rem 1.5rem;
  margin-bottom: 1rem;
}

.card h3 {
  font-size: 1.0625rem;
  margin: 0 0 0.5rem;
  color: var(--navy);
}

.card p {
  margin: 0;
  font-size: 0.9375rem;
  color: var(--text-muted);
}

/* Badges */
.badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.375rem;
  margin-top: 0.75rem;
}

.badge {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.25rem 0.5rem;
  border-radius: 999px;
}

.badge-public {
  background: var(--pastel-b);
  color: var(--pastel-b-text);
}

.badge-private {
  background: var(--pastel-a);
  color: var(--pastel-a-text);
}

.badge-wip {
  background: var(--surface-cool);
  color: var(--accent);
}

.badge-anon {
  background: var(--surface-cool);
  color: var(--text-muted);
  border: 1px solid var(--border);
}

/* Project rows (list style) */
.project-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.project-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1rem;
  align-items: center;
  padding: 1.125rem 1.25rem;
  background: var(--bg-main);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 0.75rem;
  box-shadow: var(--shadow);
  transition: border-color 0.15s ease;
}

.project-row:hover {
  border-color: #cbd5e1;
}

.project-row-num {
  font-size: 1.25rem;
  font-weight: 700;
  color: #cbd5e1;
  min-width: 2rem;
  font-variant-numeric: tabular-nums;
}

.project-row-body h3 {
  margin: 0 0 0.25rem;
  font-size: 1rem;
  font-weight: 600;
  color: var(--navy);
}

.project-row-body p {
  margin: 0;
  font-size: 0.875rem;
  color: var(--text-muted);
  line-height: 1.45;
}

.project-row-meta-line {
  margin: 0.5rem 0 0 !important;
  font-size: 0.8125rem !important;
  color: var(--text-muted) !important;
  line-height: 1.4 !important;
}

.project-card-status {
  margin: 0.35rem 0 0;
  font-size: 0.8125rem;
  color: var(--text-muted);
}

.project-card-focus {
  margin: 0.35rem 0 0.5rem;
  font-size: 0.8125rem;
  color: var(--text-muted);
}

.project-row-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.5rem;
}

.project-row-arrow {
  color: #94a3b8;
  font-size: 1.25rem;
  line-height: 1;
}

a.project-row {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

a.project-row:hover .project-row-arrow {
  color: var(--accent);
}

/* Project grid (cards) */
.project-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}

.project-card {
  background: var(--bg-main);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
}

.project-card-visual {
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 0.8125rem;
  border-bottom: 1px solid var(--border);
}

.project-card-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.project-card-visual--screenshot img {
  object-fit: contain;
  background: #f1f5f9;
  padding: 0.35rem;
}

.project-card-body {
  padding: 1.125rem 1.25rem 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.project-card-body h3 {
  font-size: 1rem;
  margin: 0 0 0.5rem;
  color: var(--navy);
}

.project-card-body p {
  font-size: 0.875rem;
  color: var(--text-muted);
  margin: 0 0 0.75rem;
  flex: 1;
}

a.project-card--link {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  transition:
    box-shadow 0.15s ease,
    border-color 0.15s ease;
}

a.project-card--link:hover {
  text-decoration: none;
  box-shadow: var(--shadow-card);
  border-color: #cbd5e1;
}

.project-card-cta {
  margin-top: 0.75rem !important;
  margin-bottom: 0 !important;
  font-size: 0.8125rem !important;
  color: var(--accent) !important;
  font-weight: 600;
}

/* Project detail page (project.html) */
.project-detail-page {
  max-width: 52rem;
}

.project-back {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--navy-soft);
  margin-bottom: 1.25rem;
  text-decoration: none;
}

.project-back:hover {
  color: var(--accent);
}

.project-back-icon {
  flex-shrink: 0;
}

.project-detail-meta {
  font-size: 0.9375rem;
  color: var(--text-muted);
  margin: 0 0 0.5rem;
}

.project-detail-body {
  white-space: pre-line;
  margin: 0 0 1.25rem;
  line-height: 1.6;
}

.project-detail-gallery {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin: 1.5rem 0;
}

.project-detail-figure {
  margin: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: #f8fafc;
}

.project-detail-figure img {
  width: 100%;
  height: auto;
  display: block;
  vertical-align: middle;
}

.project-detail-figure figcaption {
  padding: 0.65rem 0.85rem;
  font-size: 0.8125rem;
  color: var(--text-muted);
  line-height: 1.45;
  border-top: 1px solid var(--border);
}

.project-video-placeholder {
  margin-top: 1rem;
  padding: 1rem 1.15rem;
  font-size: 0.9375rem;
  color: var(--text-muted);
}

.project-video-placeholder p {
  margin: 0;
}

/* Screenshot block */
.screenshot-block {
  border: 1px dashed var(--border);
  border-radius: var(--radius-sm);
  background: #f8fafc;
  padding: 2rem 1rem;
  text-align: center;
  color: var(--text-muted);
  font-size: 0.875rem;
  margin: 1rem 0;
}

.screenshot-block strong {
  display: block;
  color: var(--navy-soft);
  margin-bottom: 0.25rem;
}

/* Lists content */
.content-list {
  margin: 0;
  padding-left: 1.25rem;
  color: var(--text-muted);
  font-size: 0.9375rem;
}

.content-list li {
  margin-bottom: 0.5rem;
}

.content-list li::marker {
  color: #94a3b8;
}

/* Buttons */
.btn {
  display: inline-block;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: var(--radius-sm);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s ease;
}

.btn-primary {
  background: var(--accent);
  color: #fff;
}

.btn-primary:hover {
  background: var(--accent-hover);
  text-decoration: none;
  color: #fff;
}

.btn-outline {
  border: 1px solid var(--border);
  background: var(--bg-main);
  color: var(--navy);
}

.btn-outline:hover {
  background: var(--bg-sidebar);
  text-decoration: none;
}

/* Footer */
.site-footer {
  position: relative;
  z-index: 2;
  margin-top: auto;
  padding: 1.5rem var(--edge-right) max(1.5rem, env(safe-area-inset-bottom, 0px)) var(--edge-left);
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.45);
  font-size: 0.8125rem;
  color: var(--text-muted);
}

.site-footer-inner {
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.footer-links {
  display: flex;
  gap: 1.25rem;
}

.footer-links a {
  color: var(--text-muted);
  font-weight: 500;
}

.footer-links a:hover {
  color: var(--navy);
}

/* Prose blocks */
.prose h2 {
  font-size: 1.25rem;
  color: var(--navy);
  margin: 1.75rem 0 0.75rem;
}

.prose h2:first-child {
  margin-top: 0;
}

.prose p {
  color: var(--text-muted);
  margin: 0 0 1rem;
  font-size: 0.9375rem;
}

.prose code {
  font-family: ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, monospace;
  font-size: 0.9em;
  background: #f1f5f9;
  padding: 0.15em 0.45em;
  border-radius: 4px;
  color: var(--navy-soft);
}

.prose strong {
  color: var(--navy-soft);
  font-weight: 600;
}

.prose .placeholder-note {
  font-size: 0.875rem;
  font-style: italic;
  border-left: 3px solid #cbd5e1;
  padding-left: 1rem;
  margin: 1rem 0;
}

/* Responsive */
@media (max-width: 900px) {
  .app {
    flex-direction: column;
  }

  .sidebar {
    position: fixed;
    left: 0;
    top: 0;
    height: 100vh;
    z-index: 200;
    transform: translateX(-100%);
    transition: transform 0.2s ease;
    box-shadow: 4px 0 24px rgba(15, 23, 42, 0.12);
  }

  body.nav-open .sidebar {
    transform: translateX(0);
  }

  .menu-toggle {
    display: flex;
  }

  .main-wrap {
    width: 100%;
  }

  .project-row {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .project-row-num {
    display: none;
  }

  .project-row-meta {
    align-items: flex-start;
    flex-direction: row;
    flex-wrap: wrap;
  }
}

.nav-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.35);
  z-index: 199;
}

body.nav-open .nav-backdrop {
  display: block;
}

@media (max-width: 520px) {
  .stats-grid {
    grid-template-columns: 1fr;
  }

  .top-bar {
    padding: 0.625rem 1rem;
  }

  .main-content {
    padding: 1.25rem 1rem 2rem;
  }
}

/* Language switch + top bar cluster */
.top-bar-end {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-left: auto;
}

.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  border: none;
  border-radius: 0;
  overflow: visible;
  background: transparent;
}

.lang-btn {
  border: none;
  padding: 0.1rem 0;
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  color: rgba(100, 96, 138, 0.48);
  background: transparent;
  font-family: inherit;
  line-height: 1.2;
}

.lang-btn + .lang-btn {
  border-left: none;
  padding-left: 0;
}

.lang-btn:hover:not(.is-active) {
  background: transparent;
  color: var(--navy);
}

.lang-btn.is-active {
  background: transparent;
  color: var(--navy);
  font-weight: 600;
}

/* Career */
.career-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.career-cv-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.career-actions .btn {
  text-decoration: none;
}

.career-actions .btn:hover {
  text-decoration: none;
}

.career-hint {
  font-size: 0.8125rem;
  color: var(--text-muted);
  margin: 0;
  max-width: 42rem;
}

.career-headline {
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--navy-soft);
}

.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.filter-btn {
  border: 1px solid var(--border);
  background: var(--bg-main);
  color: var(--navy-soft);
  font-size: 0.8125rem;
  font-weight: 600;
  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.filter-btn:hover {
  border-color: #cbd5e1;
  background: var(--bg-sidebar);
}

.filter-btn.is-active {
  background: var(--navy-soft);
  color: #fff;
  border-color: var(--navy-soft);
}

.career-card-head {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 0.75rem;
}

.career-card-index {
  font-size: 1.25rem;
  font-weight: 700;
  color: #cbd5e1;
  min-width: 2rem;
  line-height: 1.2;
}

.career-dates {
  margin: 0.25rem 0 0;
  font-size: 0.875rem;
  color: var(--text-muted);
}

.career-meta {
  margin: 0.15rem 0 0;
  font-size: 0.875rem;
  color: var(--text-muted);
}

.career-card h4 {
  font-size: 0.9375rem;
  margin: 1rem 0 0.5rem;
  color: var(--navy);
}

.career-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 1rem;
}

.career-tag {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 0.25rem 0.5rem;
  border-radius: 6px;
  background: #f1f5f9;
  color: var(--navy-soft);
  border: 1px solid var(--border);
}

.career-edu-card h3 {
  font-size: 1rem;
  margin: 0 0 0.25rem;
  color: var(--navy);
}

.career-edu-block + .career-edu-block {
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--border);
}

.career-exp-lead {
  margin-top: -0.5rem !important;
}

.career-empty {
  color: var(--text-muted);
  font-size: 0.9375rem;
}

.career-impact-list li {
  margin-bottom: 0.5rem;
}

/* ——— Zephyr guide (long-form project page) ——— */
.project-detail-guide {
  margin: 0 0 1rem;
}

.zephyr-guide-page .guide-section {
  margin-top: 2.25rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
}

.zephyr-guide-page .guide-section:first-of-type {
  margin-top: 1.5rem;
  padding-top: 0;
  border-top: none;
}

.zephyr-guide-page .guide-section h2 {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 1rem;
  letter-spacing: -0.02em;
}

.zephyr-guide-page .guide-section h3 {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--navy-soft);
  margin: 1.35rem 0 0.65rem;
}

.zephyr-guide-page .guide-section h4 {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--navy-soft);
  margin: 1.1rem 0 0.5rem;
}

.zephyr-guide-page .guide-p {
  margin: 0 0 0.85rem;
  max-width: 48rem;
}

.zephyr-guide-page .guide-lead {
  margin-bottom: 1rem;
}

.zephyr-guide-page .guide-list {
  margin: 0.5rem 0 1rem;
  max-width: 48rem;
}

.zephyr-guide-page .guide-callout {
  margin: 1.25rem 0;
  padding: 1rem 1.15rem;
  border-radius: var(--radius-sm);
  border-left: 4px solid var(--accent);
  background: #eff6ff;
  color: var(--navy-soft);
  font-size: 0.9375rem;
}

.zephyr-guide-page .guide-callout p {
  margin: 0;
}

.zephyr-guide-page .guide-pre {
  margin: 1rem 0;
  padding: 1rem 1.1rem;
  font-size: 0.75rem;
  line-height: 1.45;
  overflow-x: auto;
  border-radius: var(--radius-sm);
  background: #f8fafc;
  border: 1px solid var(--border);
  color: var(--navy-soft);
}

.zephyr-guide-page .guide-table-wrap {
  margin: 1rem 0 1.25rem;
  overflow-x: auto;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--bg-main);
}

.zephyr-guide-page .guide-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.zephyr-guide-page .guide-table th,
.zephyr-guide-page .guide-table td {
  padding: 0.65rem 0.85rem;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid var(--border);
}

.zephyr-guide-page .guide-table th {
  background: #f8fafc;
  font-weight: 600;
  color: var(--navy);
}

.zephyr-guide-page .guide-table tr:last-child td {
  border-bottom: none;
}

.zephyr-guide-page .guide-placeholder {
  margin: 1.35rem 0;
  padding: 1rem 1.15rem;
  border-radius: var(--radius-sm);
  border: 2px dashed #cbd5e1;
  background: #f8fafc;
}

.zephyr-guide-page .guide-placeholder--video {
  border-color: #94a3b8;
  background: #f1f5f9;
}

.zephyr-guide-page .guide-placeholder-label {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: 0.5rem;
}

.zephyr-guide-page .guide-placeholder-instruction {
  margin: 0;
  font-size: 0.875rem;
  color: var(--navy-soft);
  line-height: 1.5;
}

.zephyr-guide-page .guide-hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: 2rem 0;
}

.zephyr-guide-page .guide-quote {
  margin: 1.5rem 0;
  padding: 0 0 0 1rem;
  border-left: 3px solid var(--border);
  color: var(--text-muted);
  font-size: 0.9375rem;
}

.zephyr-guide-page .guide-quote p {
  margin: 0;
}

/* ——— Page load: éviter le flash contenu/nav avant JS ——— */
body.js-pending .main-content,
body.js-pending .site-footer {
  visibility: hidden;
}

/* ——— Ambiance par type de page (lien visuel avec le disque home) ——— */
.page-atmosphere {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.page-atmosphere--orbit .page-atmosphere__orb {
  --atmosphere-deg: 0deg;
  position: absolute;
  right: clamp(0.5rem, 4vw, 3rem);
  top: clamp(3.5rem, 12vh, 7rem);
  width: min(36vmin, 280px);
  height: min(36vmin, 280px);
  border-radius: 50%;
  opacity: 0.6;
  background: conic-gradient(
    from -90deg,
    rgba(255, 251, 235, 0.55) 0deg,
    rgba(254, 243, 199, 0.5) 45deg,
    rgba(255, 255, 255, 0.9) var(--atmosphere-deg),
    transparent var(--atmosphere-deg)
  );
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.15);
}

.page-atmosphere--orbit .page-atmosphere__vline {
  position: absolute;
  left: clamp(1rem, 5vw, 3rem);
  top: 4rem;
  bottom: 20%;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(15, 23, 42, 0.07), transparent);
}

.page-atmosphere--nodes .page-atmosphere__graph {
  position: absolute;
  right: 2rem;
  top: 5rem;
  width: min(220px, 40vw);
  height: auto;
  opacity: 0.35;
}

.page-atmosphere__node {
  fill: rgba(139, 92, 246, 0.4);
  animation: atmosphere-node 4s ease-in-out infinite;
}

.page-atmosphere__node--b {
  fill: rgba(109, 40, 217, 0.38);
  animation-delay: 0.6s;
}

.page-atmosphere__node--c {
  fill: rgba(99, 102, 241, 0.35);
  animation-delay: 1.2s;
}

.page-atmosphere__edge {
  fill: none;
  stroke: rgba(109, 40, 217, 0.2);
  stroke-width: 2;
  stroke-dasharray: 6 8;
  animation: atmosphere-dash 6s linear infinite;
}

.page-atmosphere--brackets {
  left: auto;
  right: 0;
  top: 5rem;
  bottom: 2rem;
  width: min(240px, 26vw);
  height: auto;
  font-family: ui-monospace, monospace;
  font-size: clamp(3.5rem, 8vw, 6rem);
  font-weight: 300;
  color: rgba(109, 40, 217, 0.09);
  -webkit-mask-image: linear-gradient(to left, rgba(0, 0, 0, 0.85) 35%, transparent 100%);
  mask-image: linear-gradient(to left, rgba(0, 0, 0, 0.85) 35%, transparent 100%);
}

.page-atmosphere__bracket {
  position: absolute;
  top: 12%;
  animation: atmosphere-float 5s ease-in-out infinite;
}

.page-atmosphere__bracket--l {
  right: 48%;
}

.page-atmosphere__bracket--r {
  right: 4%;
  animation-delay: 0.8s;
}

.page-atmosphere--arc .page-atmosphere__arc-line {
  position: absolute;
  left: 8%;
  top: 20%;
  width: 2px;
  height: 40%;
  background: linear-gradient(180deg, transparent, rgba(139, 92, 246, 0.28), transparent);
  transform-origin: top;
  animation: atmosphere-arc 3s ease-out forwards;
}

.page-atmosphere--stack .page-atmosphere__sheet {
  position: absolute;
  right: 3rem;
  top: 5rem;
  width: 120px;
  height: 150px;
  border-radius: 8px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.5);
  animation: atmosphere-float 6s ease-in-out infinite;
}

.page-atmosphere__sheet--2 {
  transform: translate(12px, 14px) rotate(3deg);
  animation-delay: 0.5s;
}

.page-atmosphere__sheet--3 {
  transform: translate(24px, 28px) rotate(6deg);
  animation-delay: 1s;
}

@keyframes atmosphere-node {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.35;
  }
  50% {
    transform: scale(1.15);
    opacity: 0.65;
  }
}

@keyframes atmosphere-dash {
  to {
    stroke-dashoffset: -40;
  }
}

@keyframes atmosphere-float {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-8px);
  }
}

@keyframes atmosphere-arc {
  from {
    transform: scaleY(0);
  }
  to {
    transform: scaleY(1);
  }
}

@media (max-width: 900px) {
  .page-atmosphere--brackets {
    opacity: 0.5;
    width: min(160px, 22vw);
  }
}

@media (max-width: 640px) {
  .page-atmosphere--brackets {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .page-atmosphere__node,
  .page-atmosphere__edge,
  .page-atmosphere__bracket,
  .page-atmosphere__sheet,
  .page-atmosphere__arc-line {
    animation: none !important;
  }
}

/* ——— Guide pages: fil d'Ariane ——— */
.guide-page {
  --guide-article-max: 52rem;
}

.guide-breadcrumb-slot {
  margin-bottom: 1.25rem;
}

.guide-breadcrumb__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  font-size: 0.8125rem;
  line-height: 1.4;
}

.guide-breadcrumb__item {
  display: inline-flex;
  align-items: center;
  color: var(--text-muted);
}

.guide-breadcrumb__item:not(:last-child)::after {
  content: "/";
  margin-left: 0.5rem;
  color: rgba(100, 116, 139, 0.55);
  font-weight: 400;
}

.guide-breadcrumb__item a {
  color: var(--navy-soft);
  font-weight: 600;
  text-decoration: none;
}

.guide-breadcrumb__item a:hover {
  color: var(--accent);
  text-decoration: none;
}

.guide-breadcrumb__item--current {
  color: var(--text-muted);
  font-weight: 500;
  max-width: min(100%, 42ch);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.main-content.guide-page.has-workflow-showcase > .guide-article,
.main-content.guide-page.has-workflow-showcase > .page-title,
.main-content.guide-page.has-workflow-showcase > .page-lead,
.main-content.guide-page.has-workflow-showcase > [id$="-guide-content"] {
  max-width: var(--guide-article-max);
}

.guide-animate .guide-reveal {
  opacity: 0;
  transform: translateY(10px);
  transition:
    opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--guide-reveal-delay, 0ms);
}

.guide-animate .guide-reveal.is-visible {
  opacity: 1;
  transform: none;
}

/* ——— Workflow showcase (n8n-style guide hero) ——— */
:root {
  --n8n-workflow-canvas-height: clamp(440px, 58vh, 680px);
}

.has-workflow-showcase > .page-title,
.has-workflow-showcase > .page-lead:first-of-type {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.main-content.has-workflow-showcase {
  max-width: min(1200px, calc(100vw - 3rem));
  padding-left: clamp(1rem, 3vw, 2.5rem);
  padding-right: clamp(1rem, 3vw, 2.5rem);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

.main-content.has-workflow-showcase > :not(#workflow-showcase-root) {
  max-width: var(--guide-article-max, 52rem);
}

.workflow-showcase {
  display: grid;
  grid-template-columns: minmax(240px, 380px) minmax(0, 1fr);
  gap: clamp(1.5rem, 3vw, 3rem);
  align-items: start;
  margin: 0 0 2.5rem;
  padding: 0;
  color: var(--text);
  max-width: none;
}

.workflow-showcase--n8n {
  margin-top: 0;
}

.workflow-showcase__copy {
  padding: 0.5rem 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.workflow-showcase__tools {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 1rem;
}

.workflow-showcase__tool {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.7rem;
  border-radius: 999px;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: var(--surface-elevated, #f4f4f5);
  border: 1px solid var(--border, #e4e4e7);
  color: var(--text-muted, #52525b);
}

.workflow-showcase__title {
  font-size: clamp(1.5rem, 2.8vw, 2.125rem);
  font-weight: 700;
  line-height: 1.15;
  margin: 0 0 0.85rem;
  letter-spacing: -0.03em;
  color: var(--text);
}

.workflow-showcase__lead {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--text-muted, #52525b);
  margin: 0 0 1rem;
  max-width: 38ch;
}

.workflow-showcase__notice {
  font-size: 0.8125rem;
  line-height: 1.55;
  color: var(--text-muted, #64748b);
  margin: 0 0 1rem;
  max-width: 42ch;
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-sm);
  background: #f8fafc;
  border: 1px solid var(--border, #e2e8f0);
}

.workflow-showcase__notice--public {
  background: var(--pastel-b);
  border-color: #d4d0e8;
  color: var(--pastel-b-text);
}

.workflow-showcase__notice--demo {
  background: var(--pastel-a);
  border-color: #ddd6fe;
  color: var(--pastel-a-text);
}

.badge-tier,
.workflow-showcase__tier {
  background: var(--pastel-a);
  color: var(--accent);
  border: 1px solid #ddd6fe;
}

.workflow-showcase__stages,
.workflow-showcase__stages-copy .workflow-showcase__stages {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.75rem;
}

.workflow-showcase__stages li {
  display: grid;
  gap: 0.25rem;
  padding: 0.75rem 1rem;
  border-radius: var(--radius-sm);
  background: var(--surface-warm);
  border: 1px solid var(--border);
}

.workflow-showcase__stages li strong {
  font-size: 0.875rem;
  color: var(--navy, #0f172a);
}

.workflow-showcase__stages li span {
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--text-muted, #64748b);
}

.workflow-showcase__stages-copy {
  margin: 0 0 1rem;
  max-width: 42ch;
}

.workflow-showcase__stages-panel {
  padding: 1.25rem 1.5rem;
  min-height: var(--n8n-workflow-canvas-height, 420px);
  display: flex;
  align-items: stretch;
  width: 100%;
}

.workflow-showcase__stages-panel .workflow-showcase__stages {
  width: 100%;
  align-content: center;
}

.workflow-showcase__chain-toggle {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}

.workflow-showcase__chain-btn {
  font: inherit;
  font-size: 0.8125rem;
  padding: 0.45rem 0.85rem;
  border-radius: 999px;
  border: 1px solid var(--border, #e2e8f0);
  background: #fff;
  color: var(--text-muted, #64748b);
  cursor: pointer;
}

.workflow-showcase__chain-btn.is-active {
  background: #eff6ff;
  border-color: #93c5fd;
  color: #1d4ed8;
}

.workflow-showcase__request-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem 1rem;
}

.workflow-showcase__request {
  font-size: 0.875rem;
  padding: 0.55rem 1rem;
}

.workflow-showcase__request-link {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--accent);
}

.workflow-showcase__frame-note {
  margin: 0;
  padding: 0.65rem 1rem;
  font-size: 0.75rem;
  line-height: 1.45;
  color: var(--text-muted, #64748b);
  background: #f8fafc;
  border-top: 1px solid var(--border, #e2e8f0);
}

.workflow-showcase__frame-note a {
  font-weight: 600;
  color: var(--accent);
}

.workflow-showcase__stages {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.workflow-showcase__stage {
  display: flex;
  gap: 0.65rem;
  align-items: flex-start;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: #94a3b8;
}

.workflow-showcase__stage-num {
  flex-shrink: 0;
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6875rem;
  font-weight: 700;
  background: rgba(255, 107, 53, 0.18);
  color: #ff8a65;
  border: 1px solid rgba(255, 107, 53, 0.35);
}

.workflow-showcase__stage-body {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.workflow-showcase__stage-body strong {
  color: #f1f5f9;
  font-weight: 600;
}

.workflow-showcase__canvas {
  min-width: 0;
}

.workflow-showcase__frame {
  position: relative;
  border-radius: calc(var(--radius) + 8px);
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 12px 32px rgba(15, 23, 42, 0.08);
}
}

.workflow-showcase__preview {
  display: block;
  width: 100%;
}

.workflow-showcase__preview n8n-demo {
  display: block;
  width: 100%;
  height: auto;
  --n8n-workflow-min-height: var(--n8n-workflow-canvas-height);
  user-select: none;
  -webkit-user-select: none;
}

.n8n-demo-shell {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: var(--n8n-workflow-canvas-height);
  color: var(--text-muted, #71717a);
  font-size: 0.875rem;
}

.n8n-demo-shell__error {
  margin: 0;
  padding: 1rem;
  text-align: center;
  color: var(--text-muted, #71717a);
}

.workflow-showcase__viewport {
  aspect-ratio: 16 / 10;
  overflow: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem;
}

.workflow-showcase__viewport img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  transform-origin: center center;
  transition: transform 0.15s ease;
  border-radius: 4px;
}

.workflow-showcase__controls {
  position: absolute;
  left: 0.65rem;
  bottom: 0.65rem;
  display: inline-flex;
  gap: 0.25rem;
  padding: 0.25rem;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.72);
  backdrop-filter: blur(6px);
}

.workflow-showcase__ctrl {
  width: 1.75rem;
  height: 1.75rem;
  border: none;
  border-radius: 999px;
  background: transparent;
  color: #f8fafc;
  font-size: 0.875rem;
  line-height: 1;
  cursor: pointer;
}

.workflow-showcase__ctrl:hover {
  background: rgba(255, 255, 255, 0.12);
}

.project-card-visual--diagram {
  background:
    radial-gradient(circle at 1px 1px, rgba(148, 163, 184, 0.35) 1px, transparent 0)
      0 0 / 14px 14px,
    linear-gradient(160deg, #1e293b 0%, #0f172a 100%);
}

.project-card-visual--diagram img {
  object-fit: contain;
  padding: 0.65rem;
}

@media (max-width: 900px) {
  .main-content.has-workflow-showcase {
    max-width: none;
  }

  .workflow-showcase {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  .workflow-showcase__canvas {
    order: -1;
  }

  :root {
    --n8n-workflow-canvas-height: clamp(360px, 52vh, 520px);
  }
}

/* Dual-screen overrides after workflow showcase base rules */
html.is-dual-screen .main-content.has-workflow-showcase > :not(#workflow-showcase-root),
body.is-dual-screen .main-content.has-workflow-showcase > :not(#workflow-showcase-root) {
  max-width: var(--dual-pane-max);
  margin-left: 0;
  margin-right: auto;
}

html.is-dual-screen .main-content.has-workflow-showcase,
body.is-dual-screen .main-content.has-workflow-showcase {
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

html.is-dual-screen .workflow-showcase,
body.is-dual-screen .workflow-showcase {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  column-gap: var(--dual-pane-gap);
  max-width: none;
}

html.is-dual-screen .site-footer,
body.is-dual-screen .site-footer {
  padding-bottom: max(1.5rem, env(safe-area-inset-bottom, 0px));
}
