/* Dragonslots Casino — dragon-fantasy dark theme
   Spec: TYPO-08 / SPACE-09 / CONT-06 / GEO-01 / MOTION-03
   Class roots: header=passerelle / footer=grille / hero=salon / etc. */

:root {
  --color-primary: #150504;
  --color-accent: #fdf82f;
  --color-accent-pressed: #fffe05;
  --color-bg: #150505;
  --color-bg-elevated: #1e0908;
  --color-bg-card: #210b09;
  --color-gradient-light: #2f0f0d;
  --color-gradient-mid: #4cb239;
  --color-text: #ffffff;
  --color-text-muted: #c1bebe;
  --color-border: #3a1815;
  --color-rg-banner: #dc2626;

  /* Typography — TYPO-08 (medium-large desktop) */
  --font-display: 'Poppins', Arial, sans-serif;
  --font-body: 'Poppins', Arial, sans-serif;
  --fz-base: 17px;
  --fz-sm: 14px;
  --fz-lg: 19px;
  --fz-h1: clamp(2.25rem, 4.5vw, 3.6rem);
  --fz-h2: clamp(1.65rem, 2.8vw, 2.35rem);
  --fz-h3: clamp(1.15rem, 1.5vw, 1.35rem);
  --lh-body: 1.7;
  --lh-tight: 1.18;

  /* Spacing — SPACE-09 */
  --space-xxs: 4px;
  --space-xs: 8px;
  --space-sm: 14px;
  --space-md: 22px;
  --space-lg: 36px;
  --space-xl: 56px;
  --space-2xl: 88px;
  --space-3xl: 120px;

  /* Container — CONT-06 */
  --container-site: 1280px;
  --container-readable: 720px;
  --container-padding-desktop: 32px;
  --container-padding-mobile: 18px;

  /* Geometry — GEO-01 (subtle radii) */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 14px;
  --radius-pill: 999px;

  /* Motion — MOTION-03 */
  --ease: cubic-bezier(.22,.61,.36,1);
  --dur-fast: 160ms;
  --dur: 240ms;

  /* Header dimensions */
  --header-height-desktop: 96px;
  --header-height-mobile: 72px;
}

* { box-sizing: border-box; }
html, body { overflow-x: clip; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fz-base);
  line-height: var(--lh-body);
  color: var(--color-text);
  background: var(--color-bg);
  background-image:
    radial-gradient(ellipse at 18% 12%, rgba(76, 178, 57, 0.05), transparent 55%),
    radial-gradient(ellipse at 85% 5%, rgba(253, 248, 47, 0.04), transparent 50%);
  background-attachment: fixed;
  padding-top: var(--header-height-desktop);
}

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

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: var(--lh-tight);
  letter-spacing: -0.005em;
  margin: 0 0 var(--space-md);
}

h1 { font-size: var(--fz-h1); }
h2 { font-size: var(--fz-h2); }
h3 { font-size: var(--fz-h3); }

p { margin: 0 0 var(--space-md); }

a {
  color: var(--color-accent);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease);
}
a:hover { color: var(--color-accent-pressed); }

/* Skip link — off-screen by 200px */
.skip-link {
  position: absolute;
  top: -200px !important;
  left: var(--space-md);
  background: var(--color-accent);
  color: var(--color-primary);
  padding: 10px 18px;
  border-radius: var(--radius-md);
  font-weight: 600;
  z-index: 999;
}
.skip-link:focus { top: 12px !important; outline: 3px solid var(--color-accent-pressed); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition: none !important; animation: none !important; }
}

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0;
  margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0;
}

/* ===================== HEADER (passerelle, HEAD-06 Magazine Logo) ===================== */
.passerelle {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: rgba(21, 5, 5, 0.92);
  border-bottom: 1px solid var(--color-border);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: padding var(--dur) var(--ease);
}
.passerelle.is-shrunk {
  padding: 4px 0;
}

.passerelle-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 16px var(--space-md);
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  min-height: calc(var(--header-height-desktop) - 24px);
}

.passerelle-brand {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
}
.passerelle-logo,
.passerelle-logo-img,
.passerelle-brand img {
  flex-shrink: 0;
}
.passerelle-logo-img {
  height: 88px;
  width: auto;
  display: block;
  mix-blend-mode: screen;
}
.passerelle.is-shrunk .passerelle-logo-img {
  height: 72px;
}

.passerelle-nav {
  flex: 1;
}
.passerelle-nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-end;
  gap: 6px;
}
.passerelle-nav-link {
  display: inline-block;
  padding: 10px 12px;
  color: var(--color-text);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.01em;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  position: relative;
}
.passerelle-nav-link:hover {
  color: var(--color-accent);
  background: rgba(253, 248, 47, 0.06);
}
.passerelle-nav-link[aria-current="page"] {
  color: var(--color-accent);
}
.passerelle-nav-link[aria-current="page"]::after {
  content: "";
  position: absolute;
  left: 12px; right: 12px;
  bottom: 4px;
  height: 2px;
  background: var(--color-accent);
  border-radius: var(--radius-pill);
}

.passerelle-toggle {
  display: none;
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 10px;
  cursor: pointer;
  margin-left: auto !important;
  flex-shrink: 0;
}
.passerelle-toggle-bar {
  display: block;
  width: 22px; height: 2px;
  background: var(--color-text);
  margin: 4px 0;
  transition: transform var(--dur-fast) var(--ease);
}

.passerelle-drawer { display: none; }

@media (max-width: 1100px) {
  .passerelle-nav { display: none; }
  .passerelle-toggle { display: block; }
  .passerelle-drawer {
    display: block;
    position: fixed;
    top: var(--header-height-mobile);
    left: 0; right: 0;
    background: var(--color-bg-elevated);
    border-top: 1px solid var(--color-border);
    max-height: calc(100vh - var(--header-height-mobile));
    overflow-y: auto;
  }
  .passerelle-drawer[hidden] { display: none; }
  .passerelle-drawer-list {
    list-style: none;
    margin: 0; padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
  .passerelle-drawer-link {
    display: block;
    padding: 14px 18px;
    color: var(--color-text);
    border-radius: var(--radius-md);
    font-weight: 500;
    font-size: 16px;
  }
  .passerelle-drawer-link[aria-current="page"] {
    color: var(--color-accent);
    background: rgba(253, 248, 47, 0.08);
  }
}

@media (max-width: 720px) {
  body { padding-top: var(--header-height-mobile); }
  .passerelle-inner {
    min-height: calc(var(--header-height-mobile) - 16px);
    padding: 10px var(--container-padding-mobile);
  }
  .passerelle-logo-img {
    height: 60px;
  }
}

/* ===================== HERO (salon, HERO-04) ===================== */
.salon {
  padding: var(--space-2xl) 0 var(--space-xl);
  background:
    radial-gradient(ellipse at 80% 30%, rgba(76, 178, 57, 0.12), transparent 60%),
    linear-gradient(155deg, var(--color-gradient-light), var(--color-bg) 65%);
  position: relative;
  overflow: hidden;
}
.salon::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(253, 248, 47, 0.06) 1px, transparent 1px);
  background-size: 36px 36px;
  opacity: 0.5;
  pointer-events: none;
}
.salon-inner {
  position: relative;
  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: 1.05fr 0.95fr;
  gap: var(--space-2xl);
  align-items: center;
}
.salon-eyebrow {
  display: inline-block;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent);
  background: rgba(253, 248, 47, 0.08);
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-md);
  border: 1px solid rgba(253, 248, 47, 0.25);
}
.salon-title {
  font-size: var(--fz-h1);
  margin-bottom: var(--space-md);
  background: linear-gradient(180deg, #ffffff, #c1bebe);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.salon-subtitle {
  max-width: 560px;
  color: var(--color-text-muted);
  font-size: var(--fz-lg);
  margin-bottom: var(--space-lg);
}
.salon-actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); align-items: center; }
.salon-cta {
  display: inline-block;
  background: var(--color-accent);
  color: var(--color-primary);
  padding: 14px 30px;
  font-weight: 700;
  font-size: 16px;
  border-radius: var(--radius-md);
  letter-spacing: 0.01em;
  box-shadow: 0 14px 32px rgba(253, 248, 47, 0.22);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.salon-cta:hover {
  background: var(--color-accent-pressed);
  color: var(--color-primary);
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(253, 248, 47, 0.32);
}
.salon-link {
  color: var(--color-text);
  padding: 12px 18px;
  border-bottom: 1px solid var(--color-border);
  font-weight: 500;
}
.salon-link:hover { color: var(--color-accent); border-color: var(--color-accent); }

.salon-figure {
  margin: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
  box-shadow: 0 40px 80px rgba(0,0,0,0.45);
}
.salon-figure img { width: 100%; height: auto; }

@media (max-width: 980px) {
  .salon-inner { grid-template-columns: 1fr; gap: var(--space-xl); }
}
@media (max-width: 720px) {
  .salon { padding: var(--space-xl) 0; }
  .salon-inner { padding: 0 var(--container-padding-mobile); }
}

/* ===================== PAGE-HEADER (niche, PHEAD-05) ===================== */
.niche {
  padding: var(--space-xl) 0 var(--space-lg);
  border-bottom: 1px solid var(--color-border);
  background: linear-gradient(180deg, rgba(47, 15, 13, 0.4), transparent);
}
.niche-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.niche-eyebrow {
  display: inline-block;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-md);
}
.niche-title { margin-bottom: var(--space-md); }
.niche-lede {
  color: var(--color-text-muted);
  font-size: var(--fz-lg);
  max-width: 760px;
  margin: 0;
}
@media (max-width: 720px) {
  .niche-inner { padding: 0 var(--container-padding-mobile); }
}

/* ===================== PROSE (coffre, PROSE-07) ===================== */
.coffre {
  padding: var(--space-xl) 0;
}
.coffre-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.coffre-heading {
  margin-bottom: var(--space-md);
  position: relative;
  padding-bottom: var(--space-sm);
}
.coffre-heading::after {
  content: "";
  display: block;
  width: 60px;
  height: 3px;
  background: var(--color-accent);
  margin-top: var(--space-sm);
  border-radius: var(--radius-pill);
}
.coffre-body p {
  color: var(--color-text);
}
.coffre-body strong { color: var(--color-accent); font-weight: 600; }
.coffre-body a { border-bottom: 1px dashed var(--color-accent); }
.coffre-body a:hover { border-bottom-style: solid; }

@media (max-width: 720px) {
  .coffre-inner { padding: 0 var(--container-padding-mobile); }
  .coffre { padding: var(--space-lg) 0; }
}

/* ===================== ITEMS GRID (rosace, GRID-05) ===================== */
.rosace { padding: var(--space-xl) 0; background: linear-gradient(180deg, transparent, rgba(47, 15, 13, 0.35)); }
.rosace-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.rosace-heading { margin-bottom: var(--space-lg); }
.rosace-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
}
.rosace-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  position: relative;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.rosace-card:hover {
  transform: translateY(-3px);
  border-color: var(--color-accent);
}
.rosace-card-index {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  color: var(--color-accent);
  opacity: 0.85;
  line-height: 1;
}
.rosace-card-title {
  font-size: var(--fz-h3);
  margin: 0;
}
.rosace-card-text {
  font-size: 15px;
  color: var(--color-text-muted);
  margin: 0;
}

@media (max-width: 1100px) {
  .rosace-list { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .rosace-inner { padding: 0 var(--container-padding-mobile); }
  .rosace-list { grid-template-columns: 1fr; }
  .rosace { padding: var(--space-lg) 0; }
}

/* ===================== FAQ (nef, FAQ-05) ===================== */
.nef { padding: var(--space-xl) 0; }
.nef-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.nef-heading { margin-bottom: var(--space-lg); }
.nef-list { display: flex; flex-direction: column; gap: 12px; }
.nef-item {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: border-color var(--dur) var(--ease);
}
.nef-item[open] { border-color: var(--color-accent); }
.nef-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding: 18px 22px;
  cursor: pointer;
  list-style: none;
  font-weight: 600;
  font-size: 16px;
  color: var(--color-text);
}
.nef-q::-webkit-details-marker { display: none; }
.nef-q-icon {
  width: 22px;
  height: 22px;
  border: 1px solid var(--color-accent);
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
  transition: transform var(--dur) var(--ease);
}
.nef-q-icon::before, .nef-q-icon::after {
  content: "";
  position: absolute;
  background: var(--color-accent);
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
}
.nef-q-icon::before { width: 10px; height: 2px; }
.nef-q-icon::after { width: 2px; height: 10px; }
.nef-item[open] .nef-q-icon::after { display: none; }
.nef-a {
  padding: 0 22px 22px;
  color: var(--color-text-muted);
}
.nef-a p { margin: 0; }

@media (max-width: 720px) {
  .nef-inner { padding: 0 var(--container-padding-mobile); }
  .nef { padding: var(--space-lg) 0; }
}

/* ===================== REVIEWS (blason, REV-08) ===================== */
.blason { padding: var(--space-xl) 0; background: linear-gradient(180deg, rgba(47, 15, 13, 0.35), transparent); }
.blason-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.blason-heading { margin-bottom: var(--space-lg); }
.blason-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-md);
}
.blason-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius-md);
  padding: var(--space-md);
}
.blason-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: 10px;
}
.blason-author {
  font-weight: 600;
  color: var(--color-text);
  font-size: 15px;
}
.blason-stars {
  color: var(--color-accent);
  letter-spacing: 0.05em;
  font-size: 16px;
}
.blason-text { color: var(--color-text-muted); margin: 0; font-size: 15px; }

@media (max-width: 980px) {
  .blason-list { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .blason-inner { padding: 0 var(--container-padding-mobile); }
  .blason { padding: var(--space-lg) 0; }
}

/* ===================== CTA (trumeau, CTA-07) ===================== */
.trumeau {
  padding: var(--space-xl) 0;
}
.trumeau-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.trumeau-inner > * {
  max-width: 100%;
}
.trumeau {
  text-align: center;
}
.trumeau-inner {
  background: linear-gradient(135deg, var(--color-gradient-light) 0%, #1e0908 60%);
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg);
  position: relative;
  overflow: hidden;
}
.trumeau-inner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 75% 20%, rgba(76, 178, 57, 0.18), transparent 55%);
  pointer-events: none;
}
.trumeau-title {
  position: relative;
  margin-bottom: var(--space-md);
}
.trumeau-text {
  position: relative;
  color: var(--color-text-muted);
  max-width: 580px;
  margin: 0 auto var(--space-lg);
}
.trumeau-btn {
  position: relative;
  display: inline-block;
  background: var(--color-accent);
  color: var(--color-primary);
  padding: 14px 36px;
  font-weight: 700;
  border-radius: var(--radius-md);
  font-size: 16px;
  letter-spacing: 0.02em;
  box-shadow: 0 14px 32px rgba(253, 248, 47, 0.25);
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.trumeau-btn:hover {
  background: var(--color-accent-pressed);
  color: var(--color-primary);
  transform: translateY(-2px);
}

@media (max-width: 720px) {
  .trumeau-inner { padding: var(--space-lg) var(--container-padding-mobile); }
  .trumeau { padding: var(--space-lg) var(--container-padding-mobile); }
}

/* ===================== TABLE (annexe, TABLE-08) ===================== */
.annexe-wrap { padding: var(--space-xl) 0; }
.annexe-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
  overflow-x: auto;
}
.annexe {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.annexe th, .annexe td {
  padding: 14px 18px;
  text-align: left;
  border-bottom: 1px solid var(--color-border);
  font-size: 15px;
}
.annexe thead th {
  background: var(--color-gradient-light);
  color: var(--color-accent);
  font-weight: 700;
  letter-spacing: 0.04em;
  font-size: 13px;
  text-transform: uppercase;
}
.annexe tbody tr:last-child td { border-bottom: none; }
.annexe-caption { color: var(--color-text-muted); padding: var(--space-sm); text-align: left; }

@media (max-width: 720px) {
  .annexe-inner { padding: 0 var(--container-padding-mobile); }
  .annexe-wrap { padding: var(--space-lg) 0; }
}

/* ===================== LEGAL (placard, LEGAL-05) ===================== */
.placard { padding: var(--space-xl) 0; }
.placard-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.placard-updated {
  display: inline-block;
  font-size: 13px;
  color: var(--color-text-muted);
  background: var(--color-bg-card);
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  margin-bottom: var(--space-md);
  border: 1px solid var(--color-border);
}
.placard-intro {
  font-size: var(--fz-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--space-lg);
}
.placard-section { margin-bottom: var(--space-xl); }
.placard-section-heading {
  font-size: var(--fz-h3);
  color: var(--color-accent);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--color-border);
}
.placard-section p { color: var(--color-text-muted); }
.placard-section a { color: var(--color-accent); border-bottom: 1px dashed var(--color-accent); }
.placard-contacts ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.placard-contacts li {
  background: var(--color-bg-card);
  padding: 12px 16px;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  color: var(--color-text);
}
.placard-disclaimer {
  margin-top: var(--space-xl);
  padding: var(--space-md);
  background: rgba(47, 15, 13, 0.45);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius-sm);
  color: var(--color-text-muted);
  font-size: 14px;
}

@media (max-width: 720px) {
  .placard-inner { padding: 0 var(--container-padding-mobile); }
  .placard { padding: var(--space-lg) 0; }
}

/* ===================== CONTACT FORM (tribune, FORM-07) ===================== */
.tribune { padding: var(--space-xl) 0; }
.tribune-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.tribune-intro {
  font-size: var(--fz-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--space-lg);
  max-width: 780px;
}
.tribune-form {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  max-width: 760px;
}
.tribune-label { display: flex; flex-direction: column; gap: 6px; font-weight: 500; color: var(--color-text); font-size: 14px; }
.tribune-label input, .tribune-label textarea {
  font-family: var(--font-body);
  font-size: 15px;
  background: var(--color-bg-elevated);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.tribune-label input:focus, .tribune-label textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(253, 248, 47, 0.15);
}
.tribune-submit {
  align-self: flex-start;
  background: var(--color-accent);
  color: var(--color-primary);
  border: none;
  padding: 14px 32px;
  font-weight: 700;
  font-size: 15px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.tribune-submit:hover {
  background: var(--color-accent-pressed);
  color: var(--color-primary);
  transform: translateY(-2px);
}
.tribune-success {
  max-width: 760px;
  background: rgba(76, 178, 57, 0.12);
  border: 1px solid var(--color-gradient-mid);
  color: var(--color-text);
  padding: var(--space-md);
  border-radius: var(--radius-md);
  margin-top: var(--space-md);
}

@media (max-width: 720px) {
  .tribune-inner { padding: 0 var(--container-padding-mobile); }
  .tribune-form { padding: var(--space-md); }
}

/* ===================== AUTHOR CARD (vestiaire, AUTH-02) ===================== */
.vestiaire { padding: var(--space-xl) 0; }
.vestiaire-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: 220px 1fr;
  gap: var(--space-xl);
  align-items: start;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding-block: var(--space-lg);
  padding-inline: var(--space-xl);
}
.vestiaire-figure { margin: 0; }
.vestiaire-figure img {
  width: 220px; height: 220px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--color-accent);
}
.vestiaire-name { margin-bottom: 4px; }
.vestiaire-role {
  color: var(--color-accent);
  font-weight: 500;
  margin: 0 0 var(--space-md);
}
.vestiaire-bio { color: var(--color-text-muted); }
.vestiaire-expertise { margin-top: var(--space-md); }
.vestiaire-sub { color: var(--color-text); font-size: 15px; margin-bottom: var(--space-xs); }
.vestiaire-expertise ul { color: var(--color-text-muted); padding-left: 20px; margin: 0; }
.vestiaire-expertise li { margin-bottom: 4px; }

.vestiaire-articles {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: var(--space-lg) auto 0;
  padding: 0 var(--container-padding-desktop);
}
.vestiaire-articles-heading {
  font-size: var(--fz-h3);
  margin-bottom: var(--space-md);
}
.vestiaire-articles-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-sm);
}
.vestiaire-articles-list li {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 14px 18px;
}
.vestiaire-articles-list a {
  color: var(--color-text);
  font-weight: 500;
  border-bottom: 1px dashed var(--color-accent);
}
.vestiaire-articles-list a:hover { color: var(--color-accent); }

@media (max-width: 720px) {
  .vestiaire-inner { grid-template-columns: 1fr; gap: var(--space-md); padding-inline: var(--container-padding-mobile); }
  .vestiaire-figure img { width: 160px; height: 160px; margin: 0 auto; }
  .vestiaire { padding: var(--space-lg) 0; }
  .vestiaire-articles { padding: 0 var(--container-padding-mobile); }
}

/* ===================== AUTHOR BYLINE (tympan, BYLINE-05) ===================== */
.tympan { padding: var(--space-lg) 0 var(--space-xl); }
.tympan-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: var(--space-md) var(--container-padding-desktop);
  border-top: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  gap: var(--space-md);
}
.tympan-portrait { flex-shrink: 0; }
.tympan-portrait img {
  width: 72px; height: 72px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--color-accent);
}
.tympan-meta { display: flex; flex-direction: column; gap: 2px; line-height: 1.3; }
.tympan-label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-muted);
}
.tympan-name {
  font-weight: 700;
  color: var(--color-accent);
  font-size: 17px;
}
.tympan-name:hover { color: var(--color-accent-pressed); }
.tympan-role { color: var(--color-text-muted); font-size: 14px; }

@media (max-width: 720px) {
  .tympan-inner { padding: var(--space-md) var(--container-padding-mobile); }
}

/* ===================== ERROR (fresque, ERR-07) ===================== */
.fresque {
  min-height: 60vh;
  display: flex;
  align-items: center;
  padding: var(--space-2xl) 0;
}
.fresque-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
  text-align: center;
}
.fresque-code {
  font-family: var(--font-display);
  font-size: clamp(7rem, 18vw, 12rem);
  font-weight: 700;
  color: var(--color-accent);
  line-height: 1;
  letter-spacing: -0.04em;
  margin: 0 0 var(--space-md);
  opacity: 0.85;
}
.fresque-title { margin-bottom: var(--space-md); }
.fresque-text { color: var(--color-text-muted); max-width: 580px; margin: 0 auto var(--space-lg); }
.fresque-btn {
  display: inline-block;
  background: var(--color-accent);
  color: var(--color-primary);
  padding: 14px 32px;
  font-weight: 700;
  border-radius: var(--radius-md);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.fresque-btn:hover {
  background: var(--color-accent-pressed);
  color: var(--color-primary);
  transform: translateY(-2px);
}

/* ===================== PAGE CONTEXT IMAGE ===================== */
.page-context-image { padding: var(--space-md) 0 var(--space-lg); }
.page-context-image-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.page-context-image figure {
  margin: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: var(--color-bg-card);
}
.page-context-image img {
  width: 100%;
  max-height: 520px;
  object-fit: cover;
}
@media (max-width: 720px) {
  .page-context-image-inner { padding: 0 var(--container-padding-mobile); }
}

/* ===================== FOOTER (grille, FOOT-10) ===================== */
.grille {
  background: #0e0303;
  border-top: 1px solid var(--color-border);
  padding: var(--space-2xl) 0 var(--space-lg);
  margin-top: var(--space-2xl);
}
.grille-inner {
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  margin: 0 auto;
  padding: 0 var(--container-padding-desktop);
}
.grille-masthead {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-lg);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-lg);
}
.grille-brand {
  flex-shrink: 0;
  display: inline-flex;
}
.grille-logo {
  height: 72px;
  width: auto;
  mix-blend-mode: screen;
}
.grille-tagline {
  color: var(--color-text-muted);
  font-size: 15px;
  max-width: 520px;
  margin: 0;
}
.grille-columns {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl);
  margin-bottom: var(--space-lg);
}
.grille-col-heading {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-sm);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--color-border);
}
.grille-col-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.grille-col-list a {
  color: var(--color-text);
  font-size: 14px;
  padding: 4px 0;
  display: inline-block;
}
.grille-col-list a:hover { color: var(--color-accent); }
.grille-contacts a {
  color: var(--color-accent);
  font-size: 13px;
}
.grille-baseline {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
  color: var(--color-text-muted);
  font-size: 13px;
}
.grille-rg {
  background: rgba(220, 38, 38, 0.12);
  border-left: 3px solid var(--color-rg-banner);
  padding: 12px 16px;
  border-radius: var(--radius-sm);
  margin: 0;
  font-size: 13px;
  line-height: 1.55;
}
.grille-rg a { color: var(--color-accent); }
.grille-copy { margin: 0; }

@media (max-width: 980px) {
  .grille-columns { grid-template-columns: repeat(2, 1fr); gap: var(--space-lg); }
}
@media (max-width: 720px) {
  .grille { padding: var(--space-xl) 0 var(--space-md); margin-top: var(--space-xl); }
  .grille-inner { padding: 0 var(--container-padding-mobile); }
  .grille-columns { grid-template-columns: 1fr; }
  .grille-masthead { flex-direction: column; align-items: flex-start; gap: var(--space-md); }
}

/* ===================== COOKIE BANNER (panneau, COOK-03) ===================== */
.panneau {
  position: fixed;
  bottom: 16px;
  left: 16px;
  right: 16px;
  z-index: 110;
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-lg);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5);
  max-width: 720px;
  margin: 0 auto;
}
.panneau[hidden] { display: none; }
.panneau-inner {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: 16px 20px;
  flex-wrap: wrap;
}
.panneau-message {
  flex: 1 1 320px;
  margin: 0;
  color: var(--color-text);
  font-size: 14px;
  line-height: 1.5;
}
.panneau-actions {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}
.panneau-button {
  padding: 10px 22px;
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: 14px;
  border: 1px solid transparent;
  cursor: pointer;
  font-family: var(--font-body);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.panneau-button--accept {
  background: var(--color-accent);
  color: var(--color-primary);
}
.panneau-button--accept:hover {
  background: var(--color-accent-pressed);
  color: var(--color-primary);
}
.panneau-button--decline {
  background: transparent;
  color: var(--color-text);
  border-color: var(--color-border);
}
.panneau-button--decline:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

@media (max-width: 720px) {
  .panneau, .panneau-inner {
    padding: 12px 14px !important;
    gap: 8px !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
  }
  .panneau-title, .panneau-heading { display: none !important; }
  .panneau-button, .panneau button {
    padding: 8px 14px !important;
    font-size: 12px !important;
    min-height: 36px !important;
  }
  .panneau { bottom: 12px; left: 12px; right: 12px; }
  .panneau-message { flex: 1 1 100%; }
}
