/* Winshark Casino — Tiefsee-Industrial Design System */
/* TYPO-08 Tight Industrial · SPACE-08 Even Decimal · CONT-10 Cinematic */
/* GEO-04 Mild Modern · MOTION-08 Mixed Curated · BP-07 */

:root {
  --color-primary: #141723;
  --color-accent: #00baf7;
  --color-accent-pressed: #009ed2;
  --color-bg: #10131b;
  --color-bg-elevated: #181c28;
  --color-gradient-light: #f6d102;
  --color-gradient-mid: #1f2334;
  --color-text: #ffffff;
  --color-text-muted: #bdbdbd;
  --color-rg-banner: #dc2626;

  --font-display: "Fira Sans", "Outfit", system-ui, sans-serif;
  --font-body: "Fira Sans", system-ui, sans-serif;

  --fs-h1: 56px;
  --fs-h2: 38px;
  --fs-h3: 24px;
  --fs-h4: 18px;
  --fs-h5: 15px;
  --fs-h6: 13px;
  --fs-body: 16px;
  --fs-small: 13px;
  --fs-micro: 11px;

  --lh-tight: 1.0;
  --lh-normal: 1.4;
  --lh-loose: 1.6;

  --ls-tight: -0.02em;
  --ls-normal: 0.02em;
  --ls-wide: 0.1em;

  --fw-regular: 500;
  --fw-medium: 700;
  --fw-bold: 900;

  --space-2xs: 5px;
  --space-xs: 10px;
  --space-sm: 15px;
  --space-md: 25px;
  --space-lg: 40px;
  --space-xl: 60px;
  --space-2xl: 90px;
  --space-3xl: 140px;

  --container-narrow: 600px;
  --container-readable: 630px;
  --container-default: 1100px;
  --container-site: 1140px;
  --container-padding-mobile: 16px;
  --container-padding-tablet: 24px;
  --container-padding-desktop: 32px;

  --bp-sm: 500px;
  --bp-md: 800px;
  --bp-lg: 1100px;
  --bp-xl: 1480px;

  --radius-xs: 2px;
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 14px;
  --radius-pill: 9999px;
  --radius-circle: 50%;

  --shadow-xs: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm: 0 2px 4px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 10px rgba(0,0,0,0.10);
  --shadow-lg: 0 8px 20px rgba(0,0,0,0.14);

  --dur-fast: 150ms;
  --dur-base: 220ms;
  --dur-slow: 450ms;
  --ease-out: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-in: cubic-bezier(0.55, 0.06, 0.68, 0.19);
  --ease-in-out: cubic-bezier(0.645, 0.045, 0.355, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  --header-height-desktop: 80px;
  --header-height-mobile: 64px;

  --section-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
}

@media (max-width: 800px) {
  :root {
    --fs-h1: 34px;
    --fs-h2: 26px;
    --fs-h3: 20px;
    --fs-h4: 16px;
    --fs-h5: 14px;
    --fs-h6: 12px;
    --fs-body: 15px;
    --fs-small: 12px;
    --fs-micro: 10px;
  }
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; }
html, body { overflow-x: clip; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-weight: var(--fw-regular);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  background: var(--color-bg);
  color: var(--color-text);
  padding-top: var(--header-height-desktop);
  -webkit-font-smoothing: antialiased;
}
@media (max-width: 800px) {
  body { padding-top: var(--header-height-mobile); }
}
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; cursor: pointer; }
ul, ol { padding-left: var(--space-md); }

/* A11y */
.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;
}
.skip-link {
  position: absolute;
  top: -200px;
  left: var(--space-md);
  background: var(--color-accent);
  color: var(--color-bg);
  padding: var(--space-xs) var(--space-md);
  z-index: 200;
  border-radius: var(--radius-sm);
  font-weight: var(--fw-bold);
}
.skip-link:not(:focus) { top: -200px !important; }
.skip-link:focus { top: var(--space-xs); }

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

/* Container helper */
.shell {
  width: 100%;
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
@media (max-width: 800px) {
  .shell { padding-inline: var(--container-padding-mobile); }
}

/* ============================ HEADER (HEAD-04 sticky transparent over hero) */
.repere {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--header-height-desktop);
  z-index: 100;
  background: var(--color-bg);
  transition: background var(--dur-base) var(--ease-out), backdrop-filter var(--dur-base) var(--ease-out);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
body[data-current="/"] .repere {
  background: transparent;
  border-bottom-color: transparent;
}
body[data-current="/"] .repere.is-scrolled {
  background: rgba(16, 19, 27, 0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom-color: rgba(255,255,255,0.05);
}
.repere-inner {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  max-width: 1440px;
  margin-inline: auto;
  padding-inline: var(--space-md);
  height: 100%;
}
.repere-logo {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  margin-right: auto;
}
.repere-logo img,
.repere-logo-img {
  height: 88px;
  width: auto;
  display: block;
  flex-shrink: 0;
}
@media (max-width: 800px) {
  .repere { height: var(--header-height-mobile); }
  .repere-logo img, .repere-logo-img { height: 60px; }
}

.repere-nav { display: flex; align-items: center; }
.repere-nav-list {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: var(--space-2xs);
}
.repere-nav-item { position: relative; }
.repere-nav-item--more { position: relative; }
.repere-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  padding: var(--space-2xs) var(--space-sm);
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-normal);
  text-decoration: none;
  background: transparent;
  border: 0;
  white-space: nowrap;
  transition: color var(--dur-fast) var(--ease-out);
}
.repere-link:hover,
.repere-link:focus,
.repere-link[aria-current="page"] {
  color: var(--color-text);
}
.repere-more-toggle { cursor: pointer; }
.repere-more-chevron {
  font-size: 10px;
  transition: transform var(--dur-fast) var(--ease-out);
}
.repere-more-toggle[aria-expanded="true"] .repere-more-chevron { transform: rotate(180deg); }
.repere-more-menu {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  margin: 0;
  padding: var(--space-xs) 0;
  list-style: none;
  background: var(--color-bg-elevated);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  min-width: 220px;
  z-index: 110;
}
.repere-more-menu[hidden] { display: none; }
.repere-more-link {
  display: block;
  padding: var(--space-xs) var(--space-md);
  color: var(--color-text);
  text-decoration: none;
  white-space: nowrap;
  font-size: var(--fs-small);
}
.repere-more-link:hover,
.repere-more-link:focus { background: rgba(0,186,247,0.08); color: var(--color-accent); }

.repere-toggle {
  display: none;
  margin-left: auto;
  background: transparent;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
  color: var(--color-text);
  font-size: 18px;
}

.repere-mobile {
  display: none;
  position: fixed;
  inset: var(--header-height-mobile) 0 0 0;
  background: var(--color-bg);
  z-index: 99;
  padding: var(--space-lg) var(--space-md);
  overflow-y: auto;
}
.repere-mobile.is-open { display: block; }
.repere-mobile-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.repere-mobile-link {
  display: block;
  padding: var(--space-sm) var(--space-md);
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.repere-mobile-link[aria-current="page"] { color: var(--color-accent); }

@media (max-width: 1099px) {
  .repere-nav, .repere-auth { display: none; }
  .repere-toggle { display: inline-flex; align-items: center; gap: 8px; }
}
@media (min-width: 1100px) {
  .repere-mobile { display: none !important; }
}

/* ============================ RG-BANNER + sticky stacking */
.rg-banner {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 101;
  min-height: 28px;
  display: none; /* not used here — keep for safety */
}

/* ============================ HERO (HERO-04 Slider) */
.lutrin {
  position: relative;
  width: 100%;
  margin-top: calc(var(--header-height-desktop) * -1);
  overflow: hidden;
  background: var(--color-bg);
}
@media (max-width: 800px) {
  .lutrin { margin-top: calc(var(--header-height-mobile) * -1); }
}
.lutrin-track {
  position: relative;
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  width: 100%;
  height: 640px;
}
@media (max-width: 800px) {
  .lutrin-track { height: 520px; }
}
.lutrin-slide {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  opacity: 0;
  transition: opacity var(--dur-slow) var(--ease-in-out);
  pointer-events: none;
}
.lutrin-slide.is-active { opacity: 1; pointer-events: auto; }
.lutrin-slide img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.lutrin-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(16,19,27,0.25) 0%, rgba(16,19,27,0.85) 100%);
}
.lutrin-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--section-width);
  margin-inline: auto;
  padding: var(--space-3xl) var(--container-padding-desktop) var(--space-2xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  align-items: flex-start;
}
@media (max-width: 800px) {
  .lutrin-content { padding: var(--space-2xl) var(--container-padding-mobile) var(--space-xl); }
}
.lutrin-eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-micro);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--color-accent);
  margin: 0;
}
.lutrin-title {
  font-family: var(--font-display);
  font-size: var(--fs-h1);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-tight);
  line-height: var(--lh-tight);
  text-transform: uppercase;
  color: var(--color-text);
  margin: 0;
  max-width: 900px;
}
.lutrin-subtitle {
  font-size: var(--fs-h5);
  line-height: var(--lh-loose);
  color: var(--color-text);
  max-width: 640px;
  margin: 0;
}
.lutrin-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: var(--space-sm);
  background: var(--color-accent);
  color: var(--color-bg);
  padding: 14px 28px;
  border-radius: var(--radius-md);
  font-family: var(--font-display);
  font-size: var(--fs-h6);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  text-decoration: none;
  transition: transform var(--dur-base) var(--ease-spring), box-shadow var(--dur-base) var(--ease-out);
}
.lutrin-cta:hover,
.lutrin-cta:focus { transform: scale(1.04); background: var(--color-accent-pressed); color: var(--color-bg); box-shadow: var(--shadow-lg); }

.lutrin-controls {
  position: absolute;
  bottom: var(--space-lg);
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  gap: var(--space-md);
  align-items: center;
}
.lutrin-prev, .lutrin-next {
  width: 44px; height: 44px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--radius-circle);
  color: var(--color-text);
  font-size: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.lutrin-prev:hover, .lutrin-next:hover { background: var(--color-accent); color: var(--color-bg); }
.lutrin-dots {
  display: inline-flex;
  gap: 10px;
  background: transparent;
  border: 0;
  padding: 0;
}
.lutrin-dots button {
  width: 10px; height: 10px;
  border-radius: var(--radius-circle);
  background: rgba(255,255,255,0.3);
  border: 0;
  padding: 0;
}
.lutrin-dots button[aria-current="true"] { background: var(--color-accent); }
@media (max-width: 800px) {
  .lutrin-prev, .lutrin-next { display: none; }
}

/* ============================ PAGE-HEADER (PHEAD-03 Big Block) */
.arcade {
  background: var(--color-primary);
  padding-block: var(--space-3xl);
}
.arcade-inner {
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.arcade-title {
  font-family: var(--font-display);
  font-size: clamp(36px, 6vw, 64px);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-tight);
  line-height: var(--lh-tight);
  color: var(--color-text);
  margin: 0 0 var(--space-md);
}
.arcade-description {
  font-size: var(--fs-h5);
  line-height: var(--lh-loose);
  color: rgba(255,255,255,0.7);
  max-width: 760px;
  margin: 0;
}
@media (max-width: 800px) {
  .arcade { padding-block: var(--space-2xl); }
  .arcade-inner { padding-inline: var(--container-padding-mobile); }
}

/* ============================ BREADCRUMBS (BREAD-03 Chevron Editorial) */
.secteur {
  padding-block: var(--space-md);
  background: var(--color-bg);
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.secteur-inner {
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  font-family: var(--font-body);
  font-size: var(--fs-small);
}
.secteur-link { color: var(--color-text-muted); text-decoration: none; }
.secteur-link:hover { color: var(--color-text); }
.secteur-current { color: var(--color-text); }
.secteur-sep {
  color: rgba(0,186,247,0.7);
  margin-inline: var(--space-xs);
}
@media (max-width: 800px) {
  .secteur-inner { padding-inline: var(--container-padding-mobile); }
}

/* ============================ INLINE-CTA (INLINE-CTA-07) */
.etiquette {
  padding-block: var(--space-2xl);
  background: var(--color-bg);
}
.etiquette-inner {
  max-width: 540px;
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-sm);
}
.etiquette-icon {
  font-size: var(--fs-h1);
  color: var(--color-accent);
  line-height: 1;
  margin: 0 0 var(--space-2xs);
}
.etiquette-heading {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-text);
  margin: 0;
}
.etiquette-subtext {
  font-size: var(--fs-body);
  color: var(--color-text-muted);
  margin: 0;
  line-height: var(--lh-loose);
}
.etiquette-btn {
  display: inline-block;
  background: var(--color-accent);
  color: var(--color-bg);
  padding: var(--space-md) var(--space-2xl);
  border-radius: var(--radius-md);
  font-family: var(--font-display);
  font-size: var(--fs-h6);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  text-decoration: none;
  margin-top: var(--space-xs);
  transition: background var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-spring);
}
.etiquette-btn:hover,
.etiquette-btn:focus { background: var(--color-accent-pressed); color: var(--color-bg); transform: scale(1.03); }

/* ============================ PROSE (PROSE-06 Centered Quiet) */
.mosaique {
  padding-block: var(--space-2xl);
}
.mosaique-inner {
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  text-align: center;
}
.mosaique h2 {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-text);
  margin-top: var(--space-2xl);
  margin-bottom: var(--space-md);
  text-align: center;
}
.mosaique h2:first-child { margin-top: 0; }
.mosaique p {
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  color: var(--color-text-muted);
  margin-block: 0 var(--space-md);
  text-align: center;
}
.mosaique a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.mosaique a:hover { color: var(--color-accent-pressed); }
@media (max-width: 800px) {
  .mosaique { padding-block: var(--space-xl); }
  .mosaique-inner { padding-inline: var(--container-padding-mobile); }
}

/* ============================ ITEMS-GRID (GRID-08 Top-Border Accent) */
.stele {
  padding-block: var(--space-2xl);
  background: var(--color-bg);
}
.stele-inner {
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.stele-heading {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: var(--ls-tight);
  color: var(--color-text);
  margin: 0 0 var(--space-xl);
}
.stele-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}
.stele-item {
  background: var(--color-bg-elevated);
  border-top: 4px solid var(--color-accent);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  transition: box-shadow var(--dur-base) var(--ease-out);
}
.stele-item:hover { box-shadow: var(--shadow-md); }
.stele-item-title {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: var(--fw-medium);
  color: var(--color-text);
  margin: 0;
}
.stele-item-text {
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  color: var(--color-text-muted);
  margin: 0;
}
@media (max-width: 1099px) {
  .stele-list { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 800px) {
  .stele { padding-block: var(--space-xl); }
  .stele-inner { padding-inline: var(--container-padding-mobile); }
  .stele-list { grid-template-columns: 1fr; }
}

/* ============================ FAQ (FAQ-06 Anchored Linked List) */
.encart {
  padding-block: var(--space-2xl);
  background: var(--color-bg);
}
.encart-inner {
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.encart-heading {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: var(--ls-tight);
  color: var(--color-text);
  margin: 0 0 var(--space-lg);
}
.encart-toc {
  padding: var(--space-lg);
  background: rgba(20, 23, 35, 0.6);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2xl);
}
.encart-toc ol {
  margin: 0;
  padding-left: var(--space-lg);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xs) var(--space-lg);
}
.encart-toc li { font-size: var(--fs-body); color: var(--color-text-muted); }
.encart-toc a { color: var(--color-text-muted); text-decoration: none; }
.encart-toc a:hover { color: var(--color-text); }
.encart-list { margin: 0; }
.encart-list dt {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: var(--fw-medium);
  color: var(--color-text);
  margin-top: var(--space-lg);
  padding-top: var(--space-md);
  border-top: 1px solid rgba(255,255,255,0.08);
  scroll-margin-top: 100px;
}
.encart-list dt:first-child { border-top: 0; padding-top: 0; margin-top: 0; }
.encart-list dd {
  margin: var(--space-sm) 0 0 0;
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  color: var(--color-text-muted);
}
@media (max-width: 800px) {
  .encart { padding-block: var(--space-xl); }
  .encart-inner { padding-inline: var(--container-padding-mobile); }
  .encart-toc ol { grid-template-columns: 1fr; }
}

/* ============================ DATA-TABLE (TABLE-06 Magazine Editorial) */
.affiche {
  padding-block: var(--space-2xl);
  background: var(--color-bg);
}
.affiche-inner {
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.affiche-wrap {
  overflow-x: auto;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255,255,255,0.05);
}
.affiche-table {
  width: 100%;
  border-collapse: collapse;
}
.affiche-table caption {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-style: italic;
  color: var(--color-text-muted);
  text-align: center;
  padding-block-end: var(--space-md);
  caption-side: top;
}
.affiche-table caption::before {
  content: "";
  display: block;
  width: 40px;
  height: 2px;
  background: var(--color-accent);
  margin: 0 auto var(--space-xs);
}
.affiche-table thead th {
  background: var(--color-bg-elevated);
  color: var(--color-text);
  font-family: var(--font-body);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  font-size: var(--fs-small);
  text-align: left;
  padding: var(--space-md);
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
.affiche-table tbody td {
  padding: var(--space-md);
  font-size: var(--fs-body);
  color: var(--color-text-muted);
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.affiche-table tbody tr:last-child td { border-bottom: 0; }
.affiche-table tbody td:first-child {
  color: var(--color-text);
  font-weight: var(--fw-bold);
}
@media (max-width: 800px) {
  .affiche { padding-block: var(--space-xl); }
  .affiche-inner { padding-inline: var(--container-padding-mobile); }
}

/* ============================ REVIEWS (REV-05) — empty for this site */
.chevet { padding-block: var(--space-2xl); }

/* ============================ CTA-BLOCK (CTA-10 Magazine Pull-Quote) */
.brochure {
  padding-block: var(--space-3xl);
  background: var(--color-bg);
  text-align: center;
}
.brochure-inner {
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.brochure-statement {
  font-family: var(--font-display);
  font-size: var(--fs-h1);
  font-style: italic;
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  color: var(--color-text);
  max-width: 900px;
  margin: 0 auto var(--space-md);
  position: relative;
  padding: 0;
}
.brochure-statement p { margin: 0; }
.brochure-statement::before {
  content: "“";
  display: block;
  font-family: var(--font-display);
  font-size: 120px;
  line-height: 0.7;
  color: var(--color-accent);
  margin-bottom: var(--space-sm);
}
.brochure-sub {
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  color: var(--color-text-muted);
  max-width: 580px;
  margin: 0 auto var(--space-lg);
}
.brochure-link {
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fs-h5);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 6px;
}
.brochure-link:hover { color: var(--color-text); background: transparent; }
@media (max-width: 800px) {
  .brochure { padding-block: var(--space-2xl); }
  .brochure-inner { padding-inline: var(--container-padding-mobile); }
}

/* ============================ AUTHOR-BYLINE (BYLINE-04 Quote-Style) */
.zone {
  padding-block: var(--space-xl);
  background: var(--color-bg);
}
.zone-inner {
  max-width: 640px;
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  text-align: center;
}
.zone-quote {
  margin: 0;
  padding: 0;
  border: 0;
}
.zone-quote::before {
  content: "“";
  font-family: var(--font-display);
  font-size: var(--fs-h1);
  color: var(--color-accent);
  display: block;
  line-height: 0.6;
  margin-bottom: var(--space-sm);
}
.zone-quote p {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-style: italic;
  color: var(--color-text);
  margin: 0 0 var(--space-md);
  line-height: var(--lh-normal);
}
.zone-attribution {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  flex-wrap: wrap;
  justify-content: center;
}
.zone-portrait {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-circle);
  object-fit: cover;
}
.zone-name a {
  color: var(--color-accent);
  font-weight: var(--fw-bold);
  font-style: normal;
  text-decoration: none;
}
.zone-name a:hover { text-decoration: underline; }
.zone-role {
  font-size: var(--fs-small);
  font-style: italic;
  color: var(--color-text-muted);
}

/* ============================ AUTHOR-CARD (AUTH-05 + AUTH-06 hybrid for /team/) */
.socle {
  padding-block: var(--space-2xl);
}
.socle-inner {
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.socle-card {
  background: var(--color-bg-elevated);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--space-xl);
  align-items: start;
}
.socle-portrait {
  width: 200px;
  height: 250px;
  object-fit: cover;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
}
.socle-body { display: flex; flex-direction: column; gap: var(--space-sm); }
.socle-eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-micro);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--color-accent);
  margin: 0;
}
.socle-name {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  font-weight: var(--fw-bold);
  color: var(--color-text);
  margin: 0;
  text-transform: uppercase;
  letter-spacing: var(--ls-tight);
}
.socle-bio {
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  color: var(--color-text);
  margin: 0;
}
.socle-expertise {
  margin: var(--space-sm) 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
}
.socle-expertise li {
  background: rgba(0,186,247,0.08);
  border: 1px solid rgba(0,186,247,0.25);
  color: var(--color-text);
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-small);
}
.socle-articles {
  margin-top: var(--space-xl);
  background: var(--color-bg-elevated);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
}
.socle-articles-heading {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-medium);
  color: var(--color-text);
  margin: 0 0 var(--space-md);
}
.socle-articles-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.socle-articles-item {
  border-bottom: 1px solid rgba(255,255,255,0.06);
  padding-bottom: var(--space-sm);
}
.socle-articles-item:last-child { border-bottom: 0; padding-bottom: 0; }
.socle-articles-item a {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h5);
  font-weight: var(--fw-medium);
  text-decoration: none;
}
.socle-articles-item a:hover { color: var(--color-accent); }
@media (max-width: 800px) {
  .socle { padding-block: var(--space-xl); }
  .socle-inner { padding-inline: var(--container-padding-mobile); }
  .socle-card {
    grid-template-columns: 1fr;
    padding: var(--space-lg);
  }
  .socle-portrait { width: 100%; max-width: 220px; height: auto; aspect-ratio: 4/5; }
}

/* ============================ LEGAL-SECTION (LEGAL-07 Magazine Editorial) */
.billet {
  padding-block: var(--space-2xl);
}
.billet-inner {
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.billet-eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-micro);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--color-accent);
  margin: 0 0 var(--space-md);
}
.billet-intro {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-style: italic;
  color: var(--color-text);
  line-height: var(--lh-normal);
  margin: 0 0 var(--space-2xl);
}
.billet-section { margin-block: var(--space-xl); }
.billet-section h3 {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-style: italic;
  font-weight: var(--fw-medium);
  color: var(--color-text);
  margin: 0 0 var(--space-md);
}
.billet-section h3::after {
  content: "";
  display: block;
  width: 80px;
  height: 2px;
  background: var(--color-accent);
  margin-top: var(--space-xs);
}
.billet-section p {
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  color: var(--color-text-muted);
  margin-block: 0 var(--space-md);
}
.billet-section p:first-of-type::first-letter {
  font-family: var(--font-display);
  font-size: calc(var(--fs-body) * 3);
  color: var(--color-accent);
  float: left;
  line-height: 1;
  padding: 4px 10px 0 0;
}
.billet-meta {
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  margin: 0 0 var(--space-lg);
}
.billet-contacts {
  background: var(--color-bg-elevated);
  border-left: 4px solid var(--color-accent);
  padding: var(--space-lg) var(--space-xl);
  margin-block: var(--space-xl);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.billet-contacts h3 {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-style: normal;
  color: var(--color-text);
  margin: 0 0 var(--space-sm);
}
.billet-contacts h3::after { display: none; }
.billet-contacts ul { margin: 0; padding-left: var(--space-md); }
.billet-contacts li { font-size: var(--fs-body); color: var(--color-text-muted); margin-bottom: var(--space-2xs); }
.billet-disclaimer {
  font-size: var(--fs-small);
  font-style: italic;
  color: var(--color-text-muted);
  margin-top: var(--space-xl);
  padding-top: var(--space-md);
  border-top: 1px solid rgba(255,255,255,0.05);
}
@media (max-width: 800px) {
  .billet { padding-block: var(--space-xl); }
  .billet-inner { padding-inline: var(--container-padding-mobile); }
}

/* ============================ CONTACT-FORM (FORM-07 Card-Style with Accent Header) */
.classeur {
  padding-block: var(--space-2xl);
}
.classeur-inner {
  max-width: 720px;
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.classeur-intro {
  font-size: var(--fs-h5);
  color: var(--color-text-muted);
  line-height: var(--lh-loose);
  margin-block: 0 var(--space-lg);
  text-align: center;
}
.classeur-card {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-bg-elevated);
  box-shadow: var(--shadow-md);
}
.classeur-card::before {
  content: "";
  display: block;
  height: 8px;
  background: var(--color-accent);
}
.classeur-form {
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.classeur-field { display: flex; flex-direction: column; gap: var(--space-2xs); }
.classeur-label {
  font-family: var(--font-body);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--color-text);
}
.classeur-input,
.classeur-textarea {
  background: var(--color-bg);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-sm);
  padding: var(--space-sm) var(--space-md);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  resize: vertical;
}
.classeur-textarea { min-height: 140px; }
.classeur-input:focus,
.classeur-textarea:focus {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  border-color: var(--color-accent);
}
.classeur-submit {
  align-self: center;
  margin-top: var(--space-sm);
  background: var(--color-accent);
  color: var(--color-bg);
  border: 0;
  padding: 14px 36px;
  border-radius: var(--radius-md);
  font-family: var(--font-display);
  font-size: var(--fs-h6);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  cursor: pointer;
}
.classeur-submit:hover,
.classeur-submit:focus { background: var(--color-accent-pressed); color: var(--color-bg); }
.classeur-success {
  display: none;
  background: rgba(0,186,247,0.08);
  border: 1px solid rgba(0,186,247,0.3);
  color: var(--color-text);
  padding: var(--space-md) var(--space-lg);
  border-radius: var(--radius-md);
  text-align: center;
}
.classeur-success.is-visible { display: block; }
@media (max-width: 800px) {
  .classeur { padding-block: var(--space-xl); }
  .classeur-inner { padding-inline: var(--container-padding-mobile); }
  .classeur-form { padding: var(--space-lg); }
}

/* ============================ COOKIE-BANNER (COOK-03 Corner Card) */
.poteau {
  position: fixed;
  inset-block-end: var(--space-md);
  inset-inline-end: var(--space-md);
  width: 360px;
  max-width: calc(100vw - 2 * var(--space-md));
  background: var(--color-bg-elevated);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: var(--space-lg);
  z-index: 90;
  display: none;
  flex-direction: column;
  gap: var(--space-md);
}
.poteau.is-visible { display: flex; }
.poteau-title {
  font-family: var(--font-display);
  font-size: var(--fs-h5);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--color-accent);
  margin: 0;
}
.poteau-message {
  font-size: var(--fs-small);
  line-height: var(--lh-normal);
  color: var(--color-text-muted);
  margin: 0;
}
.poteau-actions { display: flex; gap: var(--space-sm); }
.poteau-button {
  flex: 1;
  height: 40px;
  border: 0;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-weight: var(--fw-bold);
  font-size: var(--fs-small);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  cursor: pointer;
}
.poteau-button--accept {
  background: var(--color-accent);
  color: var(--color-bg);
}
.poteau-button--accept:hover { background: var(--color-accent-pressed); color: var(--color-bg); }
.poteau-button--decline {
  background: transparent;
  color: var(--color-text);
  border: 1px solid rgba(255,255,255,0.2);
}
.poteau-button--decline:hover { background: rgba(255,255,255,0.05); color: var(--color-text); }
@media (max-width: 720px) {
  .poteau, .poteau-inner {
    padding: 12px 14px !important;
    gap: 8px !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
    inset-inline-start: var(--space-md);
    inset-inline-end: var(--space-md);
    width: auto;
  }
  .poteau-title { display: none !important; }
  .poteau-button {
    padding: 8px 14px !important;
    font-size: 12px !important;
    min-height: 36px !important;
  }
}

/* ============================ ERROR-BLOCK (ERR-06 Bordered Card) */
.loggia {
  padding-block: var(--space-3xl);
}
.loggia-inner {
  max-width: 720px;
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
}
.loggia-card {
  background: var(--color-bg-elevated);
  border: 2px solid var(--color-accent);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  align-items: center;
  text-align: center;
}
.loggia-title {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-tight);
  color: var(--color-text);
  margin: 0;
}
.loggia-text {
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  color: var(--color-text-muted);
  margin: 0;
}
.loggia-button {
  display: inline-block;
  background: var(--color-accent);
  color: var(--color-bg);
  padding: var(--space-md) var(--space-xl);
  border-radius: var(--radius-md);
  font-family: var(--font-display);
  font-size: var(--fs-h6);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  text-decoration: none;
  margin-top: var(--space-sm);
}
.loggia-button:hover,
.loggia-button:focus { background: var(--color-accent-pressed); color: var(--color-bg); }

/* ============================ FOOTER (FOOT-05 Four-Column Information-Dense) */
.panneau {
  background: var(--color-primary);
  padding-block: var(--space-2xl);
  margin-top: var(--space-2xl);
}
.panneau-inner {
  max-width: var(--section-width);
  margin-inline: auto;
  padding-inline: var(--container-padding-desktop);
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--space-xl);
}
.panneau-brand { display: flex; flex-direction: column; gap: var(--space-md); }
.panneau-brand img {
  height: 80px;
  width: auto;
  margin-bottom: var(--space-2xs);
}
.panneau-tag {
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  line-height: var(--lh-loose);
  margin: 0;
}
.panneau-col h6 {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: var(--fs-small);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--color-text);
  margin: 0 0 var(--space-md);
}
.panneau-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}
.panneau-list a {
  font-family: var(--font-body);
  font-weight: var(--fw-regular);
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  text-decoration: none;
}
.panneau-list a:hover { color: var(--color-accent); }
.panneau-bottom {
  max-width: var(--section-width);
  margin-inline: auto;
  padding: var(--space-lg) var(--container-padding-desktop) 0;
  margin-top: var(--space-xl);
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
}
.panneau-copy {
  font-size: var(--fs-small);
  color: var(--color-text-muted);
  margin: 0;
  text-align: center;
  flex: 1;
}
.panneau-rg {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  background: var(--color-rg-banner);
  color: #fff;
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: var(--fs-small);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  padding: 6px 14px;
  border-radius: var(--radius-pill);
}
@media (max-width: 1099px) {
  .panneau-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 800px) {
  .panneau { padding-block: var(--space-xl); }
  .panneau-inner { grid-template-columns: 1fr; padding-inline: var(--container-padding-mobile); }
  .panneau-bottom { padding-inline: var(--container-padding-mobile); flex-direction: column; }
}
