:root {
  --color-primary: #ff9d07;
  --color-accent: #00b6a0;
  --color-accent-pressed: #018a79;
  --color-bg: #210e03;
  --color-bg-elevated: #2c1606;
  --color-bg-card: #1a0a02;
  --color-gradient-light: #cc7702;
  --color-gradient-mid: #feb44e;
  --color-text: #FFFFFF;
  --color-text-muted: #c0bebe;
  --color-border: rgba(255, 189, 83, 0.18);
  --color-rg-banner: #dc2626;
  --container-site: 1360px;
  --container-readable: 720px;
  --container-padding-desktop: 32px;
  --container-padding-mobile: 16px;
  --font-display: 'Cinzel', 'Albertus Nova', Georgia, serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --space-xs: 8px;
  --space-sm: 12px;
  --space-md: 20px;
  --space-lg: 32px;
  --space-xl: 56px;
  --space-2xl: 96px;
  --radius-sm: 4px;
  --radius-md: 10px;
  --radius-lg: 18px;
  --radius-pill: 999px;
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.25);
  --shadow-md: 0 8px 30px rgba(0, 0, 0, 0.45);
  --shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.6);
  --header-h-desktop: 132px;
  --header-h-mobile: 72px;
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
html, body { overflow-x: clip; }
body { margin: 0; font-family: var(--font-body); font-size: 16px; line-height: 1.6; color: var(--color-text); background: var(--color-bg); padding-top: var(--header-h-desktop); }
img, svg { max-width: 100%; height: auto; display: block; }
a { color: var(--color-accent); text-decoration: none; transition: color 0.2s; }
a:hover { color: var(--color-accent-pressed); }
button { font-family: inherit; cursor: pointer; }

/* Skip-link */
.skip-link { position: absolute; top: -200px !important; left: 8px; background: var(--color-primary); color: #000; padding: 12px 16px; z-index: 999; border-radius: var(--radius-sm); }
.skip-link:focus { top: 8px !important; }

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

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

/* ===== HEADER (.pupitre) HEAD-09 ===== */
.pupitre { position: fixed; top: 0; left: 0; right: 0; z-index: 100; background: linear-gradient(180deg, rgba(33, 14, 3, 0.98) 0%, rgba(33, 14, 3, 0.94) 100%); backdrop-filter: blur(8px); border-bottom: 1px solid var(--color-border); transition: box-shadow 0.3s; }
.pupitre.is-scrolled { box-shadow: var(--shadow-md); }
.pupitre-inner { max-width: 1440px; margin: 0 auto; padding: 14px var(--container-padding-desktop); display: flex; align-items: center; gap: var(--space-lg); }
.pupitre-brand { flex-shrink: 0; display: flex; align-items: center; }
.pupitre-logo, .pupitre-logo-img { flex-shrink: 0; }
.pupitre-logo-img { height: 88px; width: auto; mix-blend-mode: screen; }
.pupitre-nav { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.pupitre-nav-row { list-style: none; margin: 0; padding: 0; display: flex; gap: var(--space-md); justify-content: center; flex-wrap: nowrap; }
.pupitre-nav-divider { height: 1px; background: var(--color-border); width: 60%; margin: 0 auto; }
.pupitre-nav-item {}
.pupitre-nav-link { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.08em; font-size: 13px; color: var(--color-text); padding: 6px 4px; border-bottom: 2px solid transparent; transition: color 0.2s, border-color 0.2s; }
.pupitre-nav-link:hover { color: var(--color-gradient-mid); border-bottom-color: var(--color-primary); }
.pupitre-nav-link.is-current { color: var(--color-primary); border-bottom-color: var(--color-primary); }
.pupitre-actions { display: flex; align-items: center; gap: var(--space-sm); flex-shrink: 0; }
.pupitre-auth-btn { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.08em; font-size: 12px; padding: 10px var(--space-lg); background: linear-gradient(135deg, var(--color-gradient-light) 0%, var(--color-gradient-mid) 100%); color: #1a0a02; border-radius: var(--radius-pill); white-space: nowrap; flex-shrink: 0; font-weight: 700; }
.pupitre-auth-btn:hover { background: linear-gradient(135deg, var(--color-gradient-mid) 0%, var(--color-primary) 100%); color: #1a0a02; }
.pupitre-toggle { display: none; margin-left: auto !important; background: transparent; border: 1px solid var(--color-border); width: 44px; height: 44px; border-radius: var(--radius-sm); align-items: center; justify-content: center; flex-direction: column; gap: 5px; padding: 0; }
.pupitre-toggle-bar { display: block; width: 22px; height: 2px; background: var(--color-primary); transition: transform 0.2s; }
.pupitre-mobile { display: none; }

@media (max-width: 980px) {
  body { padding-top: var(--header-h-mobile); }
  .pupitre-inner { padding: 10px var(--container-padding-mobile); }
  .pupitre-logo-img { height: 60px; }
  .pupitre-nav { display: none; }
  .pupitre-auth-btn { display: none; }
  .pupitre-toggle { display: flex; }
  .pupitre-mobile { display: block; position: fixed; top: var(--header-h-mobile); left: 0; right: 0; bottom: 0; background: var(--color-bg-elevated); padding: var(--space-lg) var(--container-padding-mobile); transform: translateY(-120%); transition: transform 0.3s; z-index: 99; overflow-y: auto; }
  .pupitre-mobile.is-open { transform: translateY(0); }
  .pupitre-mobile-list { list-style: none; margin: 0 0 var(--space-lg); padding: 0; display: flex; flex-direction: column; gap: 4px; }
  .pupitre-mobile-link { display: block; padding: 14px 16px; font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.08em; font-size: 14px; color: var(--color-text); border-bottom: 1px solid var(--color-border); }
  .pupitre-mobile-link.is-current, .pupitre-mobile-link:hover { color: var(--color-primary); }
  .pupitre-mobile-auth { display: block; text-align: center; padding: 14px var(--space-lg); background: linear-gradient(135deg, var(--color-gradient-light), var(--color-gradient-mid)); color: #1a0a02; border-radius: var(--radius-pill); font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 700; }
  .pupitre-mobile-auth:hover { color: #1a0a02; }
}

/* ===== HERO (.stele) HERO-02 split ===== */
.stele { padding: var(--space-2xl) 0 var(--space-2xl); background: radial-gradient(ellipse at top left, rgba(255, 156, 7, 0.18) 0%, transparent 60%), radial-gradient(ellipse at bottom right, rgba(0, 182, 160, 0.12) 0%, transparent 55%), var(--color-bg); position: relative; overflow: hidden; }
.stele-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: 1.2fr 1fr; gap: var(--space-2xl); align-items: center; }
.stele-text {}
.stele-eyebrow { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.18em; font-size: 13px; color: var(--color-gradient-mid); margin: 0 0 var(--space-md); }
.stele-h1 { font-family: var(--font-display); font-size: clamp(36px, 4.4vw, 60px); font-weight: 700; line-height: 1.08; margin: 0 0 var(--space-md); background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-gradient-mid) 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.stele-subtitle { font-size: 18px; line-height: 1.6; color: var(--color-text-muted); max-width: 580px; margin: 0 0 var(--space-lg); }
.stele-cta { display: flex; flex-direction: column; gap: var(--space-sm); align-items: flex-start; }
.stele-cta-btn { display: inline-block; padding: 16px var(--space-xl); background: linear-gradient(135deg, var(--color-gradient-light), var(--color-primary), var(--color-gradient-mid)); color: #1a0a02; font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.12em; font-weight: 700; font-size: 15px; border-radius: var(--radius-pill); box-shadow: 0 14px 40px rgba(255, 156, 7, 0.35); }
.stele-cta-btn:hover { background: linear-gradient(135deg, var(--color-gradient-mid), var(--color-gradient-light)); color: #1a0a02; transform: translateY(-1px); }
.stele-cta-note { color: var(--color-text-muted); font-size: 13px; margin: 0; }
.stele-media { position: relative; }
.stele-img { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); width: 100%; height: auto; aspect-ratio: 1 / 1; object-fit: cover; }
.stele-glow { position: absolute; inset: -30px; background: radial-gradient(circle at center, rgba(255, 189, 83, 0.3) 0%, transparent 65%); pointer-events: none; z-index: -1; filter: blur(40px); }
@media (max-width: 900px) {
  .stele { padding: var(--space-xl) 0; }
  .stele-inner { grid-template-columns: 1fr; gap: var(--space-xl); padding: 0 var(--container-padding-mobile); }
  .stele-h1 { font-size: clamp(32px, 8vw, 42px); }
}

/* ===== PAGE-HEADER (.salon) PHEAD-05 ===== */
.salon { padding: var(--space-2xl) 0 var(--space-xl); background: linear-gradient(180deg, rgba(255, 156, 7, 0.08) 0%, transparent 100%); border-bottom: 1px solid var(--color-border); }
.salon-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: 0 var(--container-padding-desktop); text-align: center; }
.salon-eyebrow { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.2em; color: var(--color-gradient-mid); font-size: 13px; margin: 0 0 var(--space-md); }
.salon-h1 { font-family: var(--font-display); font-size: clamp(32px, 4vw, 48px); margin: 0 0 var(--space-md); background: linear-gradient(135deg, var(--color-primary), var(--color-gradient-mid)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; line-height: 1.1; }
.salon-lede { max-width: 760px; margin: 0 auto; color: var(--color-text-muted); font-size: 17px; line-height: 1.55; }
@media (max-width: 900px) {
  .salon { padding: var(--space-xl) 0 var(--space-lg); }
  .salon-inner { padding: 0 var(--container-padding-mobile); }
}

/* ===== BREADCRUMBS (.module) BREAD-05 ===== */
.module { padding: var(--space-md) 0 0; background: var(--color-bg); }
.module-list { list-style: none; margin: 0 auto; padding: 0 var(--container-padding-desktop); max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); display: flex; flex-wrap: wrap; gap: 10px; font-size: 13px; color: var(--color-text-muted); }
.module-item {}
.module-link { color: var(--color-gradient-mid); font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.08em; font-size: 12px; }
.module-link:hover { color: var(--color-primary); }
.module-sep { color: var(--color-border); }
.module-current { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.08em; font-size: 12px; color: var(--color-text); }
@media (max-width: 900px) { .module-list { padding: 0 var(--container-padding-mobile); } }

/* ===== PROSE (.balise) PROSE-04 ===== */
.balise { padding: var(--space-xl) 0; background: var(--color-bg); }
.balise-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: 0 var(--container-padding-desktop); }
.balise-h2 { font-family: var(--font-display); font-size: clamp(26px, 2.6vw, 34px); margin: var(--space-xl) 0 var(--space-md); color: var(--color-primary); line-height: 1.2; border-left: 3px solid var(--color-gradient-mid); padding-left: var(--space-md); }
.balise-h2:first-child { margin-top: 0; }
.balise-h3 { font-family: var(--font-display); font-size: 22px; margin: var(--space-lg) 0 var(--space-sm); color: var(--color-gradient-mid); }
.balise-p { font-size: 16px; line-height: 1.75; margin: 0 0 var(--space-md); color: var(--color-text); }
.balise-p strong { color: var(--color-gradient-mid); }
.balise-p em { color: var(--color-text-muted); font-style: italic; }
.balise-link { color: var(--color-accent); border-bottom: 1px dashed var(--color-accent); padding-bottom: 1px; }
.balise-link:hover { color: var(--color-gradient-mid); border-bottom-color: var(--color-gradient-mid); }
.balise-ul, .balise-ol { padding-left: var(--space-md); margin: 0 0 var(--space-md); }
.balise-li { margin-bottom: var(--space-xs); line-height: 1.7; }
.balise-figure { margin: var(--space-lg) 0; }
.balise-figure-img { width: 100%; height: auto; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
@media (max-width: 900px) { .balise-inner { padding: 0 var(--container-padding-mobile); } }

/* ===== ITEMS-GRID (.mosaique) GRID-12 ===== */
.mosaique { padding: var(--space-xl) 0; background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-elevated) 100%); }
.mosaique-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: 0 var(--container-padding-desktop); }
.mosaique-heading { font-family: var(--font-display); font-size: clamp(28px, 3vw, 38px); margin: 0 0 var(--space-xl); text-align: center; color: var(--color-primary); }
.mosaique-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-md); }
.mosaique-item { position: relative; padding: var(--space-lg) var(--space-md) var(--space-md); background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--radius-lg); transition: transform 0.2s, border-color 0.2s; }
.mosaique-item:hover { transform: translateY(-3px); border-color: var(--color-primary); }
.mosaique-num { position: absolute; top: -14px; left: var(--space-md); font-family: var(--font-display); font-size: 18px; color: var(--color-bg); background: linear-gradient(135deg, var(--color-gradient-light), var(--color-gradient-mid)); padding: 4px 12px; border-radius: var(--radius-pill); font-weight: 700; }
.mosaique-title { font-family: var(--font-display); font-size: 17px; margin: 0 0 var(--space-sm); color: var(--color-gradient-mid); line-height: 1.3; }
.mosaique-text { margin: 0; color: var(--color-text-muted); font-size: 14.5px; line-height: 1.55; }
@media (max-width: 900px) { .mosaique-inner { padding: 0 var(--container-padding-mobile); } }

/* ===== REVIEWS (.loggia) REV-03 ===== */
.loggia { padding: var(--space-xl) 0; background: var(--color-bg); }
.loggia-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: 0 var(--container-padding-desktop); }
.loggia-heading { font-family: var(--font-display); font-size: clamp(28px, 3vw, 38px); margin: 0 0 var(--space-xl); text-align: center; color: var(--color-primary); }
.loggia-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: var(--space-md); }
.loggia-item { padding: var(--space-md); background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.loggia-stars { font-size: 22px; color: var(--color-gradient-mid); letter-spacing: 2px; }
.loggia-rating { font-family: var(--font-display); font-size: 13px; color: var(--color-text-muted); margin: 4px 0 var(--space-sm); }
.loggia-text { font-size: 14.5px; line-height: 1.6; color: var(--color-text); margin: 0 0 var(--space-md); font-style: italic; }
.loggia-meta { display: flex; justify-content: space-between; align-items: center; font-size: 13px; color: var(--color-text-muted); margin: 0; }
.loggia-author { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.06em; font-size: 12px; color: var(--color-gradient-mid); }
@media (max-width: 900px) { .loggia-inner { padding: 0 var(--container-padding-mobile); } }

/* ===== FAQ (.corniche) FAQ-05 ===== */
.corniche { padding: var(--space-xl) 0; background: var(--color-bg-elevated); }
.corniche-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: 0 var(--container-padding-desktop); }
.corniche-heading { font-family: var(--font-display); font-size: clamp(28px, 3vw, 38px); margin: 0 0 var(--space-xl); text-align: center; color: var(--color-primary); }
.corniche-list { display: flex; flex-direction: column; gap: var(--space-sm); }
.corniche-item { background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--radius-md); overflow: hidden; }
.corniche-item[open] { border-color: var(--color-primary); }
.corniche-q { display: flex; justify-content: space-between; align-items: center; padding: var(--space-md) var(--space-lg); cursor: pointer; font-family: var(--font-display); font-size: 16px; color: var(--color-gradient-mid); list-style: none; gap: var(--space-md); }
.corniche-q::-webkit-details-marker { display: none; }
.corniche-q-text { flex: 1; }
.corniche-q-icon { font-size: 22px; color: var(--color-primary); transition: transform 0.2s; flex-shrink: 0; }
.corniche-item[open] .corniche-q-icon { transform: rotate(45deg); }
.corniche-a { padding: 0 var(--space-lg) var(--space-md); }
.corniche-a p { margin: 0; color: var(--color-text); line-height: 1.65; font-size: 15px; }
@media (max-width: 900px) { .corniche-inner { padding: 0 var(--container-padding-mobile); } .corniche-q { padding: var(--space-md); font-size: 15px; } .corniche-a { padding: 0 var(--space-md) var(--space-md); } }

/* ===== CTA (.quai) CTA-07 ===== */
.quai { padding: var(--space-2xl) 0; background: linear-gradient(135deg, rgba(255, 156, 7, 0.18), rgba(0, 182, 160, 0.08)); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.quai-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: 0 var(--container-padding-desktop); text-align: center; }
.quai-title { font-family: var(--font-display); font-size: clamp(28px, 3.2vw, 40px); margin: 0 0 var(--space-md); color: var(--color-primary); }
.quai-text { max-width: 720px; margin: 0 auto var(--space-lg); color: var(--color-text); font-size: 17px; line-height: 1.6; }
.quai-btn { display: inline-block; padding: 18px var(--space-2xl); background: linear-gradient(135deg, var(--color-gradient-light), var(--color-primary), var(--color-gradient-mid)); color: #1a0a02; font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.14em; font-weight: 700; font-size: 15px; border-radius: var(--radius-pill); box-shadow: 0 16px 40px rgba(255, 156, 7, 0.4); }
.quai-btn:hover { color: #1a0a02; background: linear-gradient(135deg, var(--color-gradient-mid), var(--color-gradient-light)); transform: translateY(-1px); }
@media (max-width: 900px) { .quai { padding: var(--space-xl) 0; } .quai-inner { padding: 0 var(--container-padding-mobile); } }

/* ===== TABLE (.borne) TABLE-04 ===== */
.borne { padding: var(--space-xl) 0; background: var(--color-bg); }
.borne-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: 0 var(--container-padding-desktop); }
.borne-scroll { overflow-x: auto; border-radius: var(--radius-lg); border: 1px solid var(--color-border); }
.borne-tbl { width: 100%; border-collapse: collapse; background: var(--color-bg-card); }
.borne-th { padding: var(--space-md); text-align: left; background: linear-gradient(180deg, rgba(255, 156, 7, 0.18), rgba(255, 156, 7, 0.06)); color: var(--color-gradient-mid); font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.08em; font-size: 12px; border-bottom: 1px solid var(--color-border); }
.borne-td { padding: var(--space-md); border-bottom: 1px solid var(--color-border); font-size: 14.5px; color: var(--color-text); }
.borne-tbl tbody tr:hover { background: rgba(255, 156, 7, 0.04); }
.borne-tbl tbody tr:last-child td { border-bottom: 0; }
@media (max-width: 900px) { .borne-inner { padding: 0 var(--container-padding-mobile); } }

/* ===== BYLINE (.cahier) BYLINE-07 ===== */
.cahier { display: flex; gap: var(--space-md); align-items: center; max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: var(--space-xl) auto; padding: var(--space-md) var(--container-padding-desktop); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.cahier-portrait-link { flex-shrink: 0; }
.cahier-portrait { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; border: 2px solid var(--color-gradient-mid); }
.cahier-meta { flex: 1; }
.cahier-label { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.08em; font-size: 11px; color: var(--color-text-muted); margin: 0; }
.cahier-name { font-family: var(--font-display); font-size: 17px; color: var(--color-primary); display: block; margin: 4px 0; }
.cahier-name:hover { color: var(--color-gradient-mid); }
.cahier-role { font-size: 13px; color: var(--color-text-muted); margin: 0; }
.cahier-dates { display: flex; gap: var(--space-md); flex-wrap: wrap; margin-top: 6px; }
.cahier-time { font-size: 12px; color: var(--color-text-muted); font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.06em; }
@media (max-width: 900px) { .cahier { padding: var(--space-md) var(--container-padding-mobile); } }

/* ===== AUTHOR CARD (.carnet) AUTH-07 ===== */
.carnet { padding: var(--space-2xl) 0 var(--space-xl); background: linear-gradient(180deg, rgba(255, 156, 7, 0.08), transparent); }
.carnet-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: 0 var(--container-padding-desktop); }
.carnet-hero { display: flex; align-items: center; gap: var(--space-lg); margin-bottom: var(--space-xl); }
.carnet-portrait { width: 140px; height: 140px; border-radius: 50%; object-fit: cover; border: 3px solid var(--color-gradient-mid); box-shadow: var(--shadow-md); }
.carnet-head {}
.carnet-name { font-family: var(--font-display); font-size: clamp(32px, 3.5vw, 44px); margin: 0 0 var(--space-sm); color: var(--color-primary); line-height: 1.1; }
.carnet-role { font-size: 16px; color: var(--color-gradient-mid); margin: 0; }
.carnet-bio { font-size: 17px; line-height: 1.65; color: var(--color-text); margin-bottom: var(--space-lg); }
.carnet-bio p { margin: 0; }
.carnet-expertise { background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-md) var(--space-lg); }
.carnet-expertise-heading { font-family: var(--font-display); font-size: 18px; color: var(--color-gradient-mid); margin: 0 0 var(--space-sm); }
.carnet-expertise-list { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.carnet-expertise-list li { background: rgba(255, 156, 7, 0.12); padding: 6px 14px; border-radius: var(--radius-pill); font-size: 13.5px; color: var(--color-text); }
.carnet-articles { margin-top: var(--space-xl); }
.carnet-articles-heading { font-family: var(--font-display); font-size: clamp(22px, 2.4vw, 28px); margin: 0 0 var(--space-md); color: var(--color-primary); }
.carnet-articles-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-sm); }
.carnet-articles-item {}
.carnet-articles-link { display: block; padding: var(--space-md); background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--radius-md); color: var(--color-gradient-mid); font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.06em; font-size: 14px; line-height: 1.3; transition: border-color 0.2s; }
.carnet-articles-link:hover { color: var(--color-primary); border-color: var(--color-primary); }
@media (max-width: 900px) { .carnet { padding: var(--space-xl) 0; } .carnet-inner { padding: 0 var(--container-padding-mobile); } .carnet-hero { flex-direction: column; text-align: center; gap: var(--space-md); } .carnet-portrait { width: 120px; height: 120px; } }

/* ===== LEGAL (.placard) LEGAL-05 ===== */
.placard { padding: var(--space-2xl) 0; background: var(--color-bg); }
.placard-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: 0 var(--container-padding-desktop); }
.placard-header { margin-bottom: var(--space-xl); border-bottom: 1px solid var(--color-border); padding-bottom: var(--space-lg); }
.placard-h1 { font-family: var(--font-display); font-size: clamp(32px, 4vw, 48px); margin: 0 0 var(--space-md); color: var(--color-primary); line-height: 1.1; }
.placard-updated { font-size: 13px; color: var(--color-text-muted); margin: 0 0 var(--space-md); font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.06em; }
.placard-intro { font-size: 17px; line-height: 1.6; color: var(--color-text); margin: 0; }
.placard-body {}
.placard-block { margin-bottom: var(--space-xl); }
.placard-h2 { font-family: var(--font-display); font-size: clamp(22px, 2.4vw, 28px); margin: 0 0 var(--space-md); color: var(--color-gradient-mid); border-left: 3px solid var(--color-gradient-mid); padding-left: var(--space-md); }
.placard-p { font-size: 16px; line-height: 1.75; margin: 0 0 var(--space-md); color: var(--color-text); }
.placard-list { padding-left: var(--space-md); }
.placard-list li { margin-bottom: var(--space-sm); }
.placard-disclaimer { background: var(--color-bg-card); border-left: 4px solid var(--color-gradient-mid); padding: var(--space-md) var(--space-lg); margin-top: var(--space-xl); font-style: italic; color: var(--color-text-muted); border-radius: 0 var(--radius-md) var(--radius-md) 0; }
@media (max-width: 900px) { .placard { padding: var(--space-xl) 0; } .placard-inner { padding: 0 var(--container-padding-mobile); } }

/* ===== CONTACT FORM (.panneau) FORM-07 ===== */
.panneau { padding: var(--space-xl) 0; background: var(--color-bg-elevated); }
.panneau-inner { max-width: 720px; margin: 0 auto; padding: 0 var(--container-padding-desktop); }
.panneau-heading { font-family: var(--font-display); font-size: clamp(26px, 2.8vw, 34px); margin: 0 0 var(--space-md); color: var(--color-primary); }
.panneau-intro { color: var(--color-text-muted); margin: 0 0 var(--space-lg); line-height: 1.55; }
.panneau-form { display: flex; flex-direction: column; gap: var(--space-md); }
.panneau-field { display: flex; flex-direction: column; gap: 6px; }
.panneau-label { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.06em; font-size: 12px; color: var(--color-gradient-mid); }
.panneau-input, .panneau-textarea { padding: 14px 16px; background: var(--color-bg-card); border: 1px solid var(--color-border); border-radius: var(--radius-md); color: var(--color-text); font: inherit; font-size: 15px; }
.panneau-input:focus, .panneau-textarea:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(255, 156, 7, 0.2); }
.panneau-textarea { resize: vertical; min-height: 140px; }
.panneau-submit { padding: 14px var(--space-xl); background: linear-gradient(135deg, var(--color-gradient-light), var(--color-primary), var(--color-gradient-mid)); color: #1a0a02; font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.12em; font-size: 14px; font-weight: 700; border: 0; border-radius: var(--radius-pill); align-self: flex-start; box-shadow: 0 12px 30px rgba(255, 156, 7, 0.35); }
.panneau-submit:hover { background: linear-gradient(135deg, var(--color-gradient-mid), var(--color-gradient-light)); color: #1a0a02; }
.panneau-success { padding: var(--space-md); background: rgba(0, 182, 160, 0.15); border: 1px solid var(--color-accent); border-radius: var(--radius-md); color: var(--color-accent); }
@media (max-width: 900px) { .panneau-inner { padding: 0 var(--container-padding-mobile); } }

/* ===== ERROR (.fresque) ERR-01 ===== */
.fresque { padding: var(--space-2xl) 0; min-height: calc(100vh - var(--header-h-desktop) - 480px); display: flex; align-items: center; background: radial-gradient(ellipse at center, rgba(255, 156, 7, 0.18), transparent 70%), var(--color-bg); }
.fresque-inner { max-width: 720px; margin: 0 auto; padding: 0 var(--container-padding-desktop); text-align: center; }
.fresque-code { font-family: var(--font-display); font-size: clamp(80px, 12vw, 160px); margin: 0 0 var(--space-sm); line-height: 1; background: linear-gradient(135deg, var(--color-primary), var(--color-gradient-mid)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.fresque-title { font-family: var(--font-display); font-size: clamp(24px, 3vw, 36px); color: var(--color-primary); margin: 0 0 var(--space-md); line-height: 1.2; }
.fresque-text { font-size: 17px; line-height: 1.6; color: var(--color-text-muted); margin: 0 0 var(--space-lg); }
.fresque-btn { display: inline-block; padding: 16px var(--space-xl); background: linear-gradient(135deg, var(--color-gradient-light), var(--color-primary), var(--color-gradient-mid)); color: #1a0a02; font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.12em; font-size: 14px; font-weight: 700; border-radius: var(--radius-pill); }
.fresque-btn:hover { color: #1a0a02; background: linear-gradient(135deg, var(--color-gradient-mid), var(--color-gradient-light)); }

/* ===== FOOTER (.chambre) FOOT-01 ===== */
.chambre { background: linear-gradient(180deg, #1a0a02 0%, #0f0601 100%); border-top: 1px solid var(--color-border); margin-top: var(--space-2xl); }
.chambre-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: var(--space-2xl) var(--container-padding-desktop) var(--space-xl); display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: var(--space-xl); }
.chambre-col {}
.chambre-col-brand {}
.chambre-brand-link { display: inline-block; margin-bottom: var(--space-md); }
.chambre-logo-img { height: 64px; width: auto; mix-blend-mode: screen; }
.chambre-tagline { color: var(--color-text-muted); font-size: 14px; line-height: 1.55; margin: 0 0 var(--space-md); }
.chambre-age { display: flex; align-items: center; gap: var(--space-sm); }
.chambre-age-badge { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, var(--color-rg-banner), #b91c1c); color: #fff; font-family: var(--font-display); font-weight: 700; font-size: 14px; }
.chambre-age-note { color: var(--color-text-muted); font-size: 13px; }
.chambre-heading { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.1em; font-size: 14px; color: var(--color-gradient-mid); margin: 0 0 var(--space-md); }
.chambre-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-sm); }
.chambre-link { color: var(--color-text-muted); font-size: 14px; }
.chambre-link:hover { color: var(--color-primary); }
.chambre-contact-line { color: var(--color-text-muted); font-size: 14px; margin: 0 0 var(--space-sm); }
.chambre-license { color: var(--color-text-muted); font-size: 12px; margin: var(--space-md) 0 0; opacity: 0.7; }
.chambre-bottom { border-top: 1px solid var(--color-border); background: #0a0401; }
.chambre-bottom-inner { max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop)); margin: 0 auto; padding: var(--space-md) var(--container-padding-desktop); display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-sm); font-size: 12.5px; color: var(--color-text-muted); }
.chambre-copy { margin: 0; }
.chambre-disclaimer { margin: 0; opacity: 0.8; }
@media (max-width: 980px) {
  .chambre-inner { grid-template-columns: 1fr 1fr; padding: var(--space-xl) var(--container-padding-mobile); gap: var(--space-lg); }
  .chambre-col-brand { grid-column: 1 / -1; }
  .chambre-bottom-inner { padding: var(--space-md) var(--container-padding-mobile); flex-direction: column; }
}
@media (max-width: 580px) {
  .chambre-inner { grid-template-columns: 1fr; }
}

/* ===== COOKIE (.undefined) COOK-07 ===== */
.undefined { position: fixed; bottom: 16px; left: 50%; transform: translateX(-50%); z-index: 200; max-width: 720px; width: calc(100% - 32px); background: var(--color-bg-elevated); border: 1px solid var(--color-primary); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: var(--space-md) var(--space-lg); }
.undefined[hidden] { display: none; }
.undefined-inner { display: flex; align-items: center; gap: var(--space-md); }
.undefined-message { flex: 1; color: var(--color-text); font-size: 14px; line-height: 1.5; margin: 0; }
.undefined-actions { display: flex; gap: var(--space-sm); flex-shrink: 0; }
.undefined-button { padding: 10px 18px; border-radius: var(--radius-pill); font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.06em; font-size: 12px; border: 0; }
.undefined-decline { background: transparent; color: var(--color-text-muted); border: 1px solid var(--color-border); }
.undefined-decline:hover { color: var(--color-text); border-color: var(--color-primary); background: var(--color-bg-card); }
.undefined-accept { background: linear-gradient(135deg, var(--color-gradient-light), var(--color-primary), var(--color-gradient-mid)); color: #1a0a02; font-weight: 700; }
.undefined-accept:hover { background: linear-gradient(135deg, var(--color-gradient-mid), var(--color-gradient-light)); color: #1a0a02; }
@media (max-width: 720px) {
  .undefined, .undefined-inner {
    padding: 12px 14px !important;
    gap: 8px !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
  }
  .undefined-inner { flex-direction: column; align-items: stretch; }
  .undefined-button { padding: 8px 14px !important; font-size: 12px !important; min-height: 36px !important; }
}
