:root {
  --color-primary: #000000;
  --color-accent: #219bff;
  --color-accent-pressed: #0278eb;
  --color-bg: #0b0b11;
  --color-bg-elevated: #14141c;
  --color-bg-card: #181822;
  --color-gradient-light: #c7ff07;
  --color-gradient-mid: #e11d34;
  --color-text: #ffffff;
  --color-text-muted: #bebebe;
  --color-border: #2a2a36;
  --color-border-strong: #3a3a4a;
  --color-rg-banner: #dc2626;

  --font-display: "Saira Semi Condensed", "Bebas Neue", "Oswald", system-ui, sans-serif;
  --font-body: "Saira Semi Condensed", "Inter", system-ui, sans-serif;

  --container-site: 1440px;
  --container-readable: 720px;
  --container-padding-desktop: 32px;
  --container-padding-mobile: 16px;

  --space-3xs: 4px;
  --space-2xs: 8px;
  --space-xs: 12px;
  --space-sm: 16px;
  --space-md: 24px;
  --space-lg: 36px;
  --space-xl: 56px;
  --space-2xl: 80px;
  --space-3xl: 112px;

  --fs-xs: 13px;
  --fs-sm: 15px;
  --fs-base: 17px;
  --fs-md: 19px;
  --fs-lg: 23px;
  --fs-xl: 30px;
  --fs-2xl: 40px;
  --fs-3xl: 56px;
  --fs-4xl: 72px;

  --lh-tight: 1.15;
  --lh-snug: 1.3;
  --lh-normal: 1.55;
  --lh-loose: 1.7;

  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 14px;
  --radius-xl: 22px;
  --radius-pill: 999px;

  --transition: 220ms cubic-bezier(.2,.7,.3,1);

  --header-height-desktop: 92px;
  --header-height-mobile: 72px;
}

@media (max-width: 720px) {
  :root {
    --fs-3xl: 38px;
    --fs-2xl: 30px;
    --fs-xl: 24px;
    --fs-lg: 20px;
    --space-2xl: 56px;
    --space-xl: 40px;
  }
}

*, *::before, *::after { box-sizing: border-box; }
html, body { overflow-x: clip; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-accent); text-decoration: none; }
a:hover { color: var(--color-accent-pressed); }
button { font-family: inherit; }

.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute;
  left: 16px;
  top: -200px !important;
  background: var(--color-accent);
  color: #fff;
  padding: 8px 14px;
  border-radius: var(--radius-md);
  z-index: 999;
}
.skip-link:focus { top: 16px !important; }

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* RG banner — top strip */
.rg-banner {
  background: var(--color-rg-banner);
  color: #fff;
  font-size: var(--fs-xs);
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 7px var(--container-padding-mobile);
  margin: 0;
  text-align: center;
  position: relative;
  z-index: 2;
}
.rg-banner a { color: #fff; text-decoration: underline; }

/* ============ HEADER (HEAD-08, NAV-01, AUTH-LOGIN) ============ */
.paroi {
  background: var(--color-bg-elevated);
  border-bottom: 1px solid var(--color-border);
  position: relative;
  z-index: 30;
}
.paroi-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 14px var(--container-padding-desktop);
  display: flex;
  align-items: center;
  gap: var(--space-md);
}
.paroi-brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  flex-shrink: 0;
}
.paroi-logo-pill {
  display: inline-flex;
  align-items: center;
  background: #fff;
  padding: 6px 14px;
  border-radius: var(--radius-md);
  flex-shrink: 0;
}
.paroi-logo, .paroi-logo img {
  flex-shrink: 0;
}
.paroi-logo-img {
  height: 88px;
  width: auto;
  display: block;
}
.paroi-nav {
  display: flex;
  flex: 1;
  justify-content: flex-end;
}
.paroi-nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: nowrap;
  gap: var(--space-md);
  align-items: center;
}
.paroi-nav-link {
  color: var(--color-text);
  font-size: var(--fs-sm);
  letter-spacing: .03em;
  text-transform: uppercase;
  padding: 8px 4px;
  transition: color var(--transition);
  border-bottom: 2px solid transparent;
}
.paroi-nav-link:hover {
  color: var(--color-gradient-light);
  border-bottom-color: var(--color-gradient-light);
}
[aria-current="page"].paroi-nav-link {
  color: var(--color-gradient-light);
  border-bottom-color: var(--color-gradient-light);
}
.paroi-auth {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
}
.paroi-auth-btn {
  display: inline-flex;
  align-items: center;
  background: var(--color-accent);
  color: #fff;
  padding: 10px 22px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap;
  flex-shrink: 0;
  font-weight: 600;
  transition: background var(--transition), color var(--transition);
}
.paroi-auth-btn:hover {
  background: var(--color-accent-pressed);
  color: #fff;
}
.paroi-toggle {
  display: none;
  margin-left: auto !important;
  background: transparent;
  border: 1px solid var(--color-border-strong);
  color: var(--color-text);
  border-radius: var(--radius-md);
  padding: 8px 12px;
  cursor: pointer;
}
.paroi-toggle-bar {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-text);
  margin: 4px 0;
}
.paroi-mobile {
  display: none;
}
.paroi-mobile.is-open {
  display: block;
  position: absolute;
  top: 100%;
  left: 0; right: 0;
  background: var(--color-bg-elevated);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-md) var(--container-padding-mobile);
  z-index: 25;
}
.paroi-mobile-list {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.paroi-mobile-link {
  display: block;
  padding: 14px;
  color: var(--color-text);
  border-radius: var(--radius-md);
  font-size: var(--fs-md);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.paroi-mobile-link:hover {
  background: var(--color-bg-card);
  color: var(--color-gradient-light);
}
.paroi-mobile [aria-current="page"] {
  color: var(--color-gradient-light);
}
.paroi-mobile-auth {
  margin-top: var(--space-md);
  text-align: center;
  display: block;
  background: var(--color-accent);
  color: #fff;
  padding: 14px;
  border-radius: var(--radius-md);
  text-transform: uppercase;
}

@media (max-width: 1024px) {
  .paroi-nav, .paroi-auth { display: none; }
  .paroi-toggle { display: block; }
  .paroi-logo-img { height: 60px; }
  .paroi-inner { padding: 12px var(--container-padding-mobile); }
}

/* ============ HERO (HERO-09) ============ */
.dossier {
  background: linear-gradient(135deg, rgba(33,155,255,.18) 0%, rgba(225,29,52,.15) 60%, rgba(199,255,7,.10) 100%), var(--color-bg);
  position: relative;
  overflow: hidden;
}
.dossier-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: var(--space-2xl) var(--container-padding-desktop);
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
  gap: var(--space-2xl);
  align-items: center;
}
.dossier-eyebrow {
  display: inline-block;
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: .25em;
  color: var(--color-gradient-light);
  margin-bottom: var(--space-md);
  border-left: 3px solid var(--color-gradient-light);
  padding-left: var(--space-xs);
}
.dossier-title {
  font-family: var(--font-display);
  font-size: var(--fs-4xl);
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-md);
  font-weight: 700;
  letter-spacing: -.01em;
}
.dossier-title-accent {
  background: linear-gradient(110deg, var(--color-gradient-light), var(--color-accent) 55%, var(--color-gradient-mid));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.dossier-subtitle {
  font-size: var(--fs-md);
  color: var(--color-text-muted);
  margin: 0 0 var(--space-lg);
  max-width: 580px;
  line-height: var(--lh-loose);
}
.dossier-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(120deg, var(--color-accent), var(--color-accent-pressed));
  color: #fff;
  padding: 16px 32px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-md);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 600;
  transition: transform var(--transition), background var(--transition), color var(--transition);
  border: 1px solid rgba(255,255,255,.08);
}
.dossier-cta:hover {
  transform: translateY(-2px);
  background: var(--color-gradient-light);
  color: var(--color-primary);
}
.dossier-media {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.6);
  border: 1px solid rgba(199,255,7,.12);
}
.dossier-media img {
  width: 100%;
  height: auto;
  display: block;
}
@media (max-width: 960px) {
  .dossier-inner {
    grid-template-columns: 1fr;
    padding: var(--space-xl) var(--container-padding-mobile);
    gap: var(--space-xl);
  }
  .dossier-title { font-size: var(--fs-3xl); }
}

/* ============ PAGE HEADER (PHEAD-06) ============ */
.bureau {
  padding: var(--space-2xl) 0 var(--space-xl);
  background: linear-gradient(180deg, var(--color-bg-elevated), var(--color-bg));
  border-bottom: 1px solid var(--color-border);
}
.bureau-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
  text-align: center;
}
.bureau-eyebrow {
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: .3em;
  color: var(--color-gradient-light);
  margin-bottom: var(--space-md);
}
.bureau-title {
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-md);
  font-weight: 700;
}
.bureau-meta {
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
  margin-top: var(--space-xs);
  display: flex;
  justify-content: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
}
@media (max-width: 720px) {
  .bureau { padding: var(--space-xl) 0 var(--space-lg); }
  .bureau-inner { padding: 0 var(--container-padding-mobile); }
  .bureau-title { font-size: var(--fs-2xl); }
}

/* ============ PROSE (PROSE-08) ============ */
.arcade {
  padding: var(--space-2xl) 0;
}
.arcade-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.arcade-section {
  margin-bottom: var(--space-xl);
}
.arcade-section h2 {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  line-height: var(--lh-snug);
  margin: 0 0 var(--space-md);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--color-border);
  position: relative;
}
.arcade-section h2::before {
  content: "";
  position: absolute;
  bottom: -1px; left: 0;
  width: 64px; height: 2px;
  background: var(--color-gradient-light);
}
.arcade-section p {
  font-size: var(--fs-base);
  line-height: var(--lh-loose);
  color: var(--color-text-muted);
  margin: 0 0 var(--space-md);
}
.arcade-section p strong { color: var(--color-text); }
.arcade-section a { color: var(--color-accent); text-decoration: underline; text-underline-offset: 3px; }
.arcade-section a:hover { color: var(--color-gradient-light); }
.arcade-section ul, .arcade-section ol {
  padding-left: 24px;
  margin: 0 0 var(--space-md);
  color: var(--color-text-muted);
  line-height: var(--lh-loose);
}
.arcade-section li { margin-bottom: var(--space-2xs); }
.arcade-figure {
  margin: var(--space-lg) 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
}
.arcade-figure img { width: 100%; display: block; }
.arcade-figure-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
  margin: var(--space-lg) 0;
}
@media (max-width: 720px) {
  .arcade { padding: var(--space-xl) 0; }
  .arcade-inner { padding: 0 var(--container-padding-mobile); }
  .arcade-section h2 { font-size: var(--fs-xl); }
  .arcade-figure-row { grid-template-columns: 1fr; }
}

/* ============ ITEMS GRID (GRID-09) ============ */
.socle {
  padding: var(--space-2xl) 0;
  background: var(--color-bg-elevated);
}
.socle-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.socle-heading {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  margin: 0 0 var(--space-md);
  text-align: left;
}
.socle-sub {
  color: var(--color-text-muted);
  margin: 0 0 var(--space-xl);
  max-width: 720px;
}
.socle-list {
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}
.socle-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: transform var(--transition), border-color var(--transition);
  position: relative;
  overflow: hidden;
}
.socle-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 3px;
  background: linear-gradient(90deg, var(--color-accent), var(--color-gradient-light));
  opacity: .8;
}
.socle-card:hover {
  transform: translateY(-4px);
  border-color: var(--color-border-strong);
}
.socle-card-title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  margin: 0 0 var(--space-sm);
  line-height: var(--lh-snug);
}
.socle-card-text {
  color: var(--color-text-muted);
  margin: 0;
  font-size: var(--fs-sm);
  line-height: var(--lh-loose);
}
@media (max-width: 1024px) {
  .socle-list { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .socle { padding: var(--space-xl) 0; }
  .socle-inner { padding: 0 var(--container-padding-mobile); }
  .socle-list { grid-template-columns: 1fr; }
  .socle-heading { font-size: var(--fs-xl); }
}

/* ============ FAQ (FAQ-04) ============ */
.feuille {
  padding: var(--space-2xl) 0;
}
.feuille-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.feuille-heading {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  margin: 0 0 var(--space-lg);
  text-align: center;
}
.feuille-list { display: flex; flex-direction: column; gap: var(--space-xs); }
.feuille-item {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-elevated);
  overflow: hidden;
}
.feuille-item[open] { border-color: var(--color-gradient-light); }
.feuille-q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  cursor: pointer;
  font-size: var(--fs-md);
  font-weight: 600;
  list-style: none;
  background: transparent;
  border: 0;
  width: 100%;
  text-align: left;
  color: var(--color-text);
  font-family: inherit;
}
.feuille-q::-webkit-details-marker { display: none; }
.feuille-q-icon {
  font-size: 22px;
  line-height: 1;
  color: var(--color-gradient-light);
  transition: transform var(--transition);
  flex-shrink: 0;
}
.feuille-item[open] .feuille-q-icon { transform: rotate(45deg); }
.feuille-a {
  padding: 0 var(--space-lg) var(--space-md);
  color: var(--color-text-muted);
  line-height: var(--lh-loose);
  margin: 0;
}
@media (max-width: 720px) {
  .feuille { padding: var(--space-xl) 0; }
  .feuille-inner { padding: 0 var(--container-padding-mobile); }
  .feuille-heading { font-size: var(--fs-xl); }
  .feuille-q { padding: var(--space-sm) var(--space-md); font-size: var(--fs-base); }
  .feuille-a { padding: 0 var(--space-md) var(--space-sm); }
}

/* ============ CTA-BLOCK (CTA-05) ============ */
.rubrique {
  padding: var(--space-2xl) 0;
}
.rubrique-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.rubrique-box {
  background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-pressed) 45%, var(--color-gradient-mid) 100%);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  text-align: center;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(199,255,7,.18);
}
.rubrique-box::before {
  content: "";
  position: absolute;
  top: -50%; left: -10%;
  width: 60%; height: 200%;
  background: linear-gradient(75deg, rgba(199,255,7,.15), transparent 60%);
  pointer-events: none;
}
.rubrique-title {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  margin: 0 0 var(--space-sm);
  color: #fff;
}
.rubrique-sub {
  margin: 0 auto var(--space-lg);
  max-width: 580px;
  color: rgba(255,255,255,.92);
  line-height: var(--lh-loose);
}
.rubrique-btn {
  display: inline-flex;
  align-items: center;
  background: var(--color-primary);
  color: #fff;
  padding: 16px 36px;
  border-radius: var(--radius-pill);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 700;
  transition: background var(--transition), color var(--transition);
}
.rubrique-btn:hover {
  background: var(--color-gradient-light);
  color: var(--color-primary);
}
@media (max-width: 720px) {
  .rubrique { padding: var(--space-xl) 0; }
  .rubrique-inner { padding: 0 var(--container-padding-mobile); }
  .rubrique-box { padding: var(--space-xl) var(--space-md); }
  .rubrique-title { font-size: var(--fs-xl); }
}

/* ============ LEGAL SECTION (LEGAL-01) ============ */
.manchette {
  padding: var(--space-xl) 0 var(--space-2xl);
}
.manchette-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: var(--space-xl);
}
.manchette-section { margin-bottom: var(--space-xl); }
.manchette-section h2 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  margin: 0 0 var(--space-sm);
  padding-bottom: var(--space-2xs);
  border-bottom: 1px solid var(--color-border);
}
.manchette-section p {
  color: var(--color-text-muted);
  line-height: var(--lh-loose);
  margin: 0 0 var(--space-sm);
}
.manchette-intro {
  font-size: var(--fs-md);
  color: var(--color-text);
  margin: 0 0 var(--space-xl);
  padding-left: var(--space-md);
  border-left: 3px solid var(--color-gradient-light);
}
.manchette-aside {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  height: fit-content;
  position: sticky;
  top: var(--space-md);
}
.manchette-aside h3 {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  margin: 0 0 var(--space-sm);
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--color-gradient-light);
}
.manchette-aside ul {
  list-style: none;
  margin: 0; padding: 0;
}
.manchette-aside li {
  padding: var(--space-2xs) 0;
  border-bottom: 1px dashed var(--color-border);
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
}
.manchette-aside li:last-child { border-bottom: 0; }
.manchette-disclaimer {
  margin-top: var(--space-xl);
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  font-style: italic;
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
}
@media (max-width: 960px) {
  .manchette-inner { grid-template-columns: 1fr; padding: 0 var(--container-padding-mobile); }
  .manchette-aside { position: static; }
}

/* ============ AUTHOR BYLINE (BYLINE-06) ============ */
.retable {
  margin: var(--space-2xl) 0 var(--space-xl);
  padding: var(--space-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-bg-elevated);
  display: flex;
  gap: var(--space-md);
  align-items: center;
}
.retable-portrait {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 2px solid var(--color-gradient-light);
}
.retable-portrait img { width: 100%; height: 100%; object-fit: cover; }
.retable-meta { flex: 1; }
.retable-eyebrow {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: 2px;
}
.retable-name {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
}
.retable-name a { color: var(--color-text); }
.retable-name a:hover { color: var(--color-gradient-light); }
.retable-role {
  display: block;
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  margin-top: 2px;
}
.retable-dates {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-2xs);
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

/* ============ AUTHOR CARD (AUTH-02) ============ */
.pupitre {
  padding: var(--space-2xl) 0;
}
.pupitre-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.pupitre-card {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-xl);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  align-items: start;
}
.pupitre-portrait {
  width: 220px;
  height: 220px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 2px solid var(--color-gradient-light);
}
.pupitre-portrait img { width: 100%; height: 100%; object-fit: cover; }
.pupitre-name {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  margin: 0 0 var(--space-2xs);
}
.pupitre-role {
  font-size: var(--fs-md);
  color: var(--color-gradient-light);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin: 0 0 var(--space-md);
}
.pupitre-bio {
  color: var(--color-text-muted);
  line-height: var(--lh-loose);
  margin: 0 0 var(--space-md);
}
.pupitre-expertise-heading {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin: 0 0 var(--space-sm);
}
.pupitre-expertise {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs);
}
.pupitre-expertise li {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}
.pupitre-articles {
  margin-top: var(--space-xl);
  padding: var(--space-lg);
  border-top: 1px solid var(--color-border);
}
.pupitre-articles-heading {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  margin: 0 0 var(--space-md);
}
.pupitre-articles-list {
  list-style: none;
  margin: 0; padding: 0;
}
.pupitre-articles-item {
  padding: var(--space-sm) 0;
  border-bottom: 1px dashed var(--color-border);
}
.pupitre-articles-item:last-child { border-bottom: 0; }
.pupitre-articles-item a {
  color: var(--color-text);
  font-size: var(--fs-md);
  display: inline-flex;
  gap: var(--space-2xs);
  align-items: center;
}
.pupitre-articles-item a::before { content: "→"; color: var(--color-gradient-light); }
.pupitre-articles-item a:hover { color: var(--color-gradient-light); }
@media (max-width: 720px) {
  .pupitre { padding: var(--space-xl) 0; }
  .pupitre-inner { padding: 0 var(--container-padding-mobile); }
  .pupitre-card { grid-template-columns: 1fr; padding: var(--space-lg); text-align: center; }
  .pupitre-portrait { width: 160px; height: 160px; margin: 0 auto; }
  .pupitre-expertise { justify-content: center; }
}

/* ============ CONTACT FORM (FORM-08) ============ */
.lisere {
  padding: var(--space-2xl) 0;
}
.lisere-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  gap: var(--space-2xl);
}
.lisere-intro {
  color: var(--color-text-muted);
  line-height: var(--lh-loose);
}
.lisere-info-title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  margin: 0 0 var(--space-md);
}
.lisere-channels {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.lisere-channels li {
  padding: var(--space-sm) var(--space-md);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.lisere-channels strong { color: var(--color-gradient-light); display: block; margin-bottom: 4px; }
.lisere-form {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
}
.lisere-field {
  display: block;
  margin-bottom: var(--space-md);
}
.lisere-label {
  display: block;
  margin-bottom: 6px;
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--color-text-muted);
}
.lisere-input,
.lisere-textarea {
  width: 100%;
  background: var(--color-bg);
  border: 1px solid var(--color-border-strong);
  color: var(--color-text);
  padding: 12px 14px;
  border-radius: var(--radius-md);
  font-family: inherit;
  font-size: var(--fs-base);
}
.lisere-textarea { min-height: 140px; resize: vertical; }
.lisere-input:focus,
.lisere-textarea:focus {
  outline: 2px solid var(--color-accent);
  outline-offset: 1px;
}
.lisere-submit {
  display: inline-flex;
  align-items: center;
  background: var(--color-accent);
  color: #fff;
  border: 0;
  padding: 14px 32px;
  border-radius: var(--radius-pill);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
}
.lisere-submit:hover {
  background: var(--color-gradient-light);
  color: var(--color-primary);
}
.lisere-success {
  display: none;
  padding: var(--space-md);
  background: rgba(199,255,7,.12);
  border: 1px solid var(--color-gradient-light);
  border-radius: var(--radius-md);
  margin-top: var(--space-md);
  color: var(--color-gradient-light);
}
.lisere-success.is-visible { display: block; }
@media (max-width: 960px) {
  .lisere-inner { grid-template-columns: 1fr; padding: 0 var(--container-padding-mobile); gap: var(--space-xl); }
  .lisere-form { padding: var(--space-lg); }
}

/* ============ COOKIE BANNER (COOK-02) ============ */
.etabli {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-xl);
  padding: var(--space-md) var(--space-lg);
  display: none;
  align-items: center;
  gap: var(--space-md);
  max-width: 900px;
  width: calc(100% - 40px);
  box-shadow: 0 20px 40px -10px rgba(0,0,0,.6);
  z-index: 60;
  flex-wrap: wrap;
}
.etabli.is-visible { display: flex; }
.etabli-message {
  flex: 1;
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
  min-width: 240px;
  margin: 0;
}
.etabli-actions { display: flex; gap: var(--space-2xs); flex-shrink: 0; }
.etabli-button {
  border: 0;
  cursor: pointer;
  padding: 10px 20px;
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: var(--fs-sm);
  font-family: inherit;
  transition: background var(--transition);
}
.etabli-button-accept {
  background: var(--color-accent);
  color: #fff;
}
.etabli-button-accept:hover { background: var(--color-accent-pressed); }
.etabli-button-decline {
  background: transparent;
  color: var(--color-text);
  border: 1px solid var(--color-border-strong);
}
.etabli-button-decline:hover { background: var(--color-bg-elevated); }
@media (max-width: 720px) {
  .etabli, .etabli-inner {
    padding: 12px 14px !important;
    gap: 8px !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
  }
  .etabli-message { font-size: 12.5px !important; }
  .etabli-button {
    padding: 8px 14px !important;
    font-size: 12px !important;
    min-height: 36px !important;
  }
}

/* ============ ERROR BLOCK (ERR-01) ============ */
.vitrine {
  padding: var(--space-3xl) 0;
  text-align: center;
}
.vitrine-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.vitrine-code {
  font-family: var(--font-display);
  font-size: 160px;
  line-height: 1;
  background: linear-gradient(110deg, var(--color-gradient-light), var(--color-accent), var(--color-gradient-mid));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin: 0;
  letter-spacing: -.02em;
}
.vitrine-title {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  margin: var(--space-md) 0;
}
.vitrine-text {
  color: var(--color-text-muted);
  max-width: 540px;
  margin: 0 auto var(--space-xl);
  line-height: var(--lh-loose);
}
.vitrine-btn {
  display: inline-flex;
  background: var(--color-accent);
  color: #fff;
  padding: 16px 32px;
  border-radius: var(--radius-pill);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 600;
  transition: background var(--transition), color var(--transition);
}
.vitrine-btn:hover {
  background: var(--color-gradient-light);
  color: var(--color-primary);
}
@media (max-width: 720px) {
  .vitrine-code { font-size: 100px; }
}

/* ============ FOOTER (FOOT-08 — Editorial Masthead) ============ */
.fiche {
  background: var(--color-bg-elevated);
  border-top: 1px solid var(--color-border);
  padding: var(--space-2xl) 0 var(--space-md);
  margin-top: var(--space-xl);
}
.fiche-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.fiche-masthead {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 2px solid var(--color-text);
  border-bottom: 2px solid var(--color-text);
  padding: var(--space-md) 0;
  margin-bottom: var(--space-xl);
  gap: var(--space-md);
  flex-wrap: wrap;
  font-family: var(--font-display);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}
.fiche-masthead-edition { font-weight: 600; color: var(--color-gradient-light); }
.fiche-masthead-brand {
  font-size: var(--fs-md);
  color: var(--color-text);
  font-weight: 700;
  letter-spacing: .18em;
}
.fiche-masthead-issue::before { content: "N°"; opacity: .7; margin-right: 2px; }
.fiche-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--space-xl);
  margin-bottom: var(--space-xl);
}
.fiche-brand-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.fiche-logo-pill {
  display: inline-flex;
  align-items: center;
  background: #fff;
  padding: 6px 14px;
  border-radius: var(--radius-md);
  align-self: flex-start;
}
.fiche-logo-img { height: 64px; width: auto; display: block; }
.fiche-brand-text {
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
  line-height: var(--lh-loose);
  max-width: 320px;
}
.fiche-col-heading {
  font-family: var(--font-display);
  font-size: var(--fs-sm);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--color-gradient-light);
  margin: 0 0 var(--space-md);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--color-border);
}
.fiche-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
}
.fiche-list a {
  color: var(--color-text-muted);
  font-size: var(--fs-sm);
  transition: color var(--transition);
}
.fiche-list a:hover { color: var(--color-gradient-light); }
.fiche-bottom {
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-md);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
}
.fiche-copyright { margin: 0; }
.fiche-license { text-transform: uppercase; letter-spacing: .08em; }
.fiche-rg-line { color: var(--color-rg-banner); font-weight: 600; }
@media (max-width: 960px) {
  .fiche-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .fiche-inner { padding: 0 var(--container-padding-mobile); }
  .fiche { padding: var(--space-xl) 0 var(--space-md); }
  .fiche-grid { grid-template-columns: 1fr; gap: var(--space-md); }
  .fiche-masthead { font-size: 12px; }
  .fiche-logo-img { height: 56px; }
}
