:root {
  --border-medium: 2px;
  --border-thick: 4px;
  --border-thin: 1px;
  --bp-lg: 1080px;
  --bp-md: 760px;
  --bp-sm: 480px;
  --bp-xl: 1480px;
  --color-accent: #fce000;
  --color-accent-pressed: #d7b700;
  --color-bg: #000000;
  --color-bg-elevated: #161616;
  --color-bg-deep: #050505;
  --color-border-soft: rgba(255, 255, 255, 0.08);
  --color-border-line: rgba(255, 255, 255, 0.16);
  --color-gradient-light: #ffee85;
  --color-gradient-mid: #44c04c;
  --color-primary: #000000;
  --color-rg-banner: #dc2626;
  --color-text: #ffffff;
  --color-text-muted: #bebdbd;
  --container-default: 920px;
  --container-narrow: 600px;
  --container-padding-desktop: 48px;
  --container-padding-mobile: 16px;
  --container-padding-tablet: 24px;
  --container-site: 1340px;
  --container-wide: 1480px;
  --dur-base: 180ms;
  --dur-fast: 120ms;
  --dur-slow: 260ms;
  --ease-in: cubic-bezier(0.6, 0.0, 0.7, 0.3);
  --ease-in-out: cubic-bezier(0.5, 0.0, 0.5, 1.0);
  --ease-out: cubic-bezier(0.3, 0.7, 0.4, 1.0);
  --ease-spring: cubic-bezier(0.5, 0.0, 0.5, 1.0);
  --font-body: "Outfit", "Helvetica Neue", Arial, sans-serif;
  --font-display: "Bebas Neue", "Impact", "Arial Narrow", sans-serif;
  --fs-body: 16px;
  --fs-h1: 60px;
  --fs-h2: 34px;
  --fs-h3: 24px;
  --fs-h4: 19px;
  --fs-h5: 16px;
  --fs-h6: 14px;
  --fs-micro: 10px;
  --fs-small: 13px;
  --fw-bold: 800;
  --fw-medium: 600;
  --fw-regular: 400;
  --lh-loose: 1.65;
  --lh-normal: 1.5;
  --lh-tight: 1.1;
  --ls-normal: 0;
  --ls-tight: -0.02em;
  --ls-wide: 0.06em;
  --radius-circle: 50%;
  --radius-lg: 24px;
  --radius-md: 12px;
  --radius-pill: 9999px;
  --radius-sm: 4px;
  --radius-xs: 0;
  --shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.14);
  --shadow-md: 0 6px 16px rgba(0, 0, 0, 0.10);
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.07);
  --shadow-xs: 0 1px 0 rgba(0, 0, 0, 0.10);
  --space-2xl: 64px;
  --space-2xs: 4px;
  --space-3xl: 96px;
  --space-lg: 24px;
  --space-md: 16px;
  --space-sm: 12px;
  --space-xl: 40px;
  --space-xs: 8px;
  --z-cookie: 90;
  --z-drawer: 80;
  --z-header: 50;
}

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

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  margin: 0;
  min-height: 100vh;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

img,
picture,
svg {
  display: block;
  max-width: 100%;
}

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

a:hover {
  color: var(--color-accent-pressed);
}

button {
  cursor: pointer;
  font: inherit;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--color-text);
  font-family: var(--font-display);
  margin: 0 0 var(--space-md);
}

h1 {
  font-size: var(--fs-h1);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-tight);
  line-height: var(--lh-tight);
  text-transform: uppercase;
}

h2 {
  font-size: var(--fs-h2);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-normal);
  line-height: var(--lh-tight);
}

h3 {
  font-family: var(--font-body);
  font-size: var(--fs-h3);
  font-weight: var(--fw-medium);
  line-height: var(--lh-tight);
}

h4 {
  font-family: var(--font-body);
  font-size: var(--fs-h4);
  font-weight: var(--fw-medium);
}

h5,
h6 {
  font-family: var(--font-body);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

h5 { font-size: var(--fs-h5); }
h6 { font-size: var(--fs-h6); }

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

ul,
ol {
  margin: 0 0 var(--space-md);
  padding-inline-start: var(--space-xl);
}

hr {
  border: 0;
  border-top: 1px solid var(--color-border-line);
  margin: var(--space-xl) 0;
}

main {
  display: block;
}

.skip-link {
  background: var(--color-accent);
  color: var(--color-bg);
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  left: 50%;
  padding: var(--space-sm) var(--space-md);
  position: absolute;
  top: -100px;
  transform: translateX(-50%);
  z-index: 1000;
}

.skip-link:focus {
  top: var(--space-xs);
}

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

:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

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

.medaillon {
  background: var(--color-bg);
  border-bottom: var(--border-medium) solid var(--color-text);
  border-top: var(--border-medium) solid var(--color-accent);
  position: relative;
  z-index: var(--z-header);
}

.medaillon-inner {
  align-items: center;
  display: flex;
  gap: var(--space-lg);
  justify-content: space-between;
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  min-height: 100px;
  padding-block: var(--space-sm);
  padding-inline: var(--container-padding-desktop);
}

.medaillon-logo {
  align-items: center;
  display: inline-flex;
  flex: 0 0 auto;
}

.medaillon-logo img {
  height: 80px;
  width: auto;
  display: block;
}

@media (max-width: 819px) {
  .medaillon-logo img { height: 60px; }
}

.medaillon-nav {
  flex: 1 1 auto;
}

.medaillon-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  justify-content: flex-end;
  list-style: none;
  margin: 0;
  padding: 0;
}

.medaillon-list li {
  align-items: center;
  display: inline-flex;
  gap: var(--space-md);
}

.medaillon-list li + li::before {
  background: var(--color-accent);
  border-radius: var(--radius-circle);
  content: "";
  display: inline-block;
  height: 4px;
  width: 4px;
}

.medaillon-link {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  padding: var(--space-xs) 0;
  text-transform: uppercase;
  white-space: nowrap;
  transition: color var(--dur-fast) var(--ease-out);
}

.medaillon-link:hover,
body[data-current="/"] .medaillon-link[data-nav="/"],
body[data-current="/bonuses/"] .medaillon-link[data-nav="/bonuses/"],
body[data-current="/apk/"] .medaillon-link[data-nav="/apk/"],
body[data-current="/team/"] .medaillon-link[data-nav="/team/"],
body[data-current="/sign-in/"] .medaillon-link[data-nav="/sign-in/"],
body[data-current="/help-hilfe/"] .medaillon-link[data-nav="/help-hilfe/"] {
  color: var(--color-accent);
}

.medaillon-auth {
  align-items: center;
  display: inline-flex;
  flex: 0 0 auto;
  gap: var(--space-sm);
}

.medaillon-auth-btn {
  background: transparent;
  border: 1px solid var(--color-text);
  color: var(--color-text);
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  padding: 10px 18px;
  text-transform: uppercase;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}

.medaillon-auth-btn:hover {
  background: var(--color-text);
  color: var(--color-bg);
}

.medaillon-toggle {
  background: transparent;
  border: 1px solid var(--color-text);
  color: var(--color-text);
  display: none;
  flex-direction: column;
  gap: 4px;
  height: 40px;
  justify-content: center;
  padding: 0 10px;
  width: 44px;
}

.medaillon-toggle span {
  background: var(--color-text);
  display: block;
  height: 2px;
  width: 20px;
}

.medaillon-mobile {
  display: none;
}

.medaillon-mobile.is-open {
  display: block;
}

.medaillon-mobile-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  list-style: none;
  margin: 0;
  padding: var(--space-md) var(--container-padding-mobile);
}

.medaillon-mobile-link {
  color: var(--color-text);
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  padding: var(--space-sm) 0;
  text-transform: uppercase;
}

.medaillon-mobile-link:hover {
  color: var(--color-accent);
}

.carnet {
  background: var(--color-bg);
  padding-block: var(--space-3xl);
}

.carnet-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.carnet-frame {
  background: var(--color-bg);
  box-shadow: 0 0 0 8px transparent, 0 0 0 9px var(--color-text);
  outline: 4px solid var(--color-text);
  outline-offset: 0;
  padding: var(--space-2xl);
}

.carnet-content {
  display: grid;
  gap: var(--space-lg);
}

.carnet-eyebrow {
  color: var(--color-accent);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  font-style: italic;
  margin: 0;
}

.carnet h1 {
  margin: 0;
}

.carnet-divider {
  background: var(--color-accent);
  border: 0;
  height: 1px;
  margin: 0;
  width: 80px;
}

.carnet-subtitle {
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-h5);
  line-height: var(--lh-loose);
  margin: 0;
  max-width: 540px;
}

.carnet-cta {
  background: var(--color-accent);
  border-radius: var(--radius-xs);
  color: var(--color-bg);
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fs-h5);
  font-weight: var(--fw-bold);
  justify-self: start;
  letter-spacing: var(--ls-wide);
  padding: 18px 36px;
  text-transform: uppercase;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}

.carnet-cta:hover {
  background: var(--color-accent-pressed);
  color: var(--color-bg);
}

.carnet-meta {
  color: var(--color-text-muted);
  font-size: var(--fs-small);
  margin: 0;
}

.carnet-meta time {
  color: var(--color-text);
}

.rubrique {
  background: var(--color-bg);
  padding-block: var(--space-2xl);
}

.rubrique-inner {
  display: block;
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.rubrique-number {
  align-self: start;
  color: var(--color-accent);
  font-family: var(--font-display);
  font-size: 84px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-tight);
  line-height: var(--lh-tight);
}

.rubrique-body h1 {
  margin: 0 0 var(--space-md);
}

.rubrique-description {
  color: var(--color-text-muted);
  font-size: var(--fs-h5);
  line-height: var(--lh-loose);
  margin: 0 0 var(--space-md);
}

.rubrique-meta {
  color: var(--color-text-muted);
  font-size: var(--fs-small);
}

.rubrique-meta time {
  color: var(--color-text);
}

.coupole {
  background: var(--color-bg);
  padding-block: var(--space-xl);
}

.coupole-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.coupole-heading {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  margin: 0 0 var(--space-xl);
}

.coupole-featured {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-lg);
  color: var(--color-text);
  margin-bottom: var(--space-xl);
  padding: var(--space-2xl);
}

.coupole-featured-title {
  color: var(--color-accent);
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-md);
}

.coupole-featured-text {
  color: var(--color-text);
  font-size: var(--fs-h5);
  line-height: var(--lh-normal);
  margin: 0;
}

.coupole-list {
  display: grid;
  gap: var(--space-lg);
  grid-template-columns: repeat(2, 1fr);
  list-style: none;
  margin: 0;
  padding: 0;
}

.coupole-item {
  border-top: var(--border-medium) solid var(--color-accent);
  padding: var(--space-md) 0 0;
}

.coupole-item-title {
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  margin: 0 0 var(--space-xs);
}

.coupole-item-text {
  color: var(--color-text-muted);
  font-size: var(--fs-small);
  line-height: var(--lh-normal);
  margin: 0;
}

.vitrine {
  background: var(--color-bg);
  padding-block: var(--space-xl);
}

.vitrine-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.vitrine-heading {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  margin: 0 0 var(--space-xl);
}

.vitrine-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  list-style: none;
  margin: 0;
  padding: 0;
}

.vitrine-item {
  border-bottom: 1px solid var(--color-border-line);
  display: grid;
  gap: var(--space-md);
  grid-template-columns: 60px 1fr;
  padding-block: var(--space-md);
}

.vitrine-number {
  align-self: start;
  color: var(--color-accent);
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
}

.vitrine-question {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: var(--fw-bold);
  margin: 0 0 var(--space-sm);
}

.vitrine-answer {
  color: var(--color-text-muted);
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  margin: 0;
}

.chapitre {
  background: var(--color-bg);
  padding-block: var(--space-xl);
}

.chapitre-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.chapitre-heading {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  margin: 0 0 var(--space-xl);
}

.chapitre-list {
  display: flex;
  flex-direction: column;
  list-style: none;
  margin: 0;
  padding: 0;
}

.chapitre-item {
  border-bottom: 1px solid var(--color-border-soft);
  display: grid;
  gap: var(--space-xs);
  grid-template-areas:
    "author date"
    "text   text";
  grid-template-columns: 1fr auto;
  padding-block: var(--space-md);
}

.chapitre-author {
  color: var(--color-text);
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  grid-area: author;
  margin: 0;
}

.chapitre-rating {
  color: var(--color-accent);
  font-weight: var(--fw-bold);
  margin-left: var(--space-sm);
}

.chapitre-date {
  color: var(--color-text-muted);
  font-size: var(--fs-small);
  grid-area: date;
}

.chapitre-text {
  color: var(--color-text-muted);
  font-size: var(--fs-body);
  grid-area: text;
  line-height: var(--lh-normal);
  margin: 0;
}

.tympan {
  background: var(--color-bg-elevated);
  border-block: 1px solid var(--color-accent);
  color: var(--color-text);
  padding-block: var(--space-2xl);
  width: 100%;
}

.tympan-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
  text-align: center;
}

.tympan-title {
  color: var(--color-text);
  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);
  margin: 0 0 var(--space-md);
  text-transform: uppercase;
}

.tympan-text {
  color: var(--color-text);
  font-size: var(--fs-h5);
  line-height: var(--lh-normal);
  margin: 0 auto var(--space-xl);
  max-width: 600px;
  opacity: 0.7;
}

.tympan-button {
  background: var(--color-accent);
  color: var(--color-bg);
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fs-h5);
  font-weight: var(--fw-bold);
  height: 64px;
  letter-spacing: var(--ls-wide);
  line-height: 64px;
  padding-inline: var(--space-2xl);
  text-transform: uppercase;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}

.tympan-button:hover {
  background: var(--color-accent-pressed);
  color: var(--color-bg);
}

.porte {
  background: var(--color-bg);
  padding-block: var(--space-xl);
}

.porte-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.porte h2 {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  margin: var(--space-2xl) 0 var(--space-md);
  padding-left: 0;
}

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

.porte h3 {
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-h3);
  margin: var(--space-xl) 0 var(--space-md);
  padding-left: var(--space-2xl);
}

.porte p,
.porte ol,
.porte ul {
  color: var(--color-text-muted);
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  padding-left: var(--space-2xl);
}

.porte ol,
.porte ul {
  padding-left: calc(var(--space-2xl) + var(--space-lg));
}

.porte strong {
  color: var(--color-text);
}

.porte a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.porte a:hover {
  color: var(--color-accent-pressed);
}

.balise {
  background: var(--color-bg);
  padding-block: var(--space-2xl);
}

.balise-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.balise-heading {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  margin: 0 0 var(--space-xl);
}

.balise-grid {
  display: grid;
  gap: var(--space-md);
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  list-style: none;
  margin: 0;
  padding: 0;
}

.balise-card {
  background: var(--color-bg-elevated);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding: var(--space-lg);
}

.balise-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
}

.balise-label {
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: var(--fs-micro);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

.balise-value {
  color: var(--color-text);
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
}

.brochure {
  background: var(--color-bg);
  padding-block: var(--space-2xl);
}

.brochure-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.brochure-intro {
  color: var(--color-text);
  font-size: var(--fs-h5);
  line-height: var(--lh-loose);
  margin: 0 0 var(--space-xl);
}

.brochure-list {
  margin: 0;
}

.brochure-term {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: var(--fw-bold);
  margin-block-end: var(--space-xs);
  margin-block-start: var(--space-lg);
  position: relative;
  padding-top: var(--space-md);
}

.brochure-term::before {
  background: var(--color-accent);
  content: "";
  height: 2px;
  left: 0;
  position: absolute;
  top: 0;
  width: 30px;
}

.brochure-definition {
  color: var(--color-text-muted);
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  margin-block-end: var(--space-md);
  margin-inline-start: 0;
}

.brochure-definition p {
  margin: 0 0 var(--space-sm);
}

.brochure-contacts {
  border-top: 1px solid var(--color-border-line);
  margin-top: var(--space-2xl);
  padding-top: var(--space-lg);
}

.brochure-contacts h3 {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  margin: 0 0 var(--space-md);
}

.brochure-contacts ul {
  color: var(--color-text-muted);
  list-style: disc;
  margin: 0 0 var(--space-lg);
  padding-inline-start: var(--space-lg);
}

.brochure-disclaimer {
  color: var(--color-text-muted);
  font-size: var(--fs-small);
  font-style: italic;
  margin: 0;
}

.cahier {
  background: var(--color-bg);
  padding-block: var(--space-2xl);
}

.cahier-form {
  display: block;
}

.cahier-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.cahier-intro {
  color: var(--color-text-muted);
  font-size: var(--fs-h5);
  line-height: var(--lh-loose);
  margin: 0 0 var(--space-xl);
}

.cahier-card {
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.cahier-accent {
  background: var(--color-accent);
  height: 8px;
}

.cahier-body {
  background: var(--color-bg-elevated);
  padding: var(--space-xl);
}

.cahier-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  margin-bottom: var(--space-lg);
}

.cahier-label {
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

.cahier-input,
.cahier-textarea {
  background: var(--color-bg);
  border: 1px solid var(--color-border-line);
  border-radius: var(--radius-xs);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  padding: var(--space-sm) var(--space-md);
  width: 100%;
}

.cahier-textarea {
  min-height: 160px;
  resize: vertical;
}

.cahier-input:focus,
.cahier-textarea:focus {
  border-color: var(--color-accent);
  outline: none;
}

.cahier-submit {
  background: var(--color-accent);
  border: 0;
  color: var(--color-bg);
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fs-h5);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  margin-top: var(--space-md);
  padding: 16px 36px;
  text-transform: uppercase;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}

.cahier-submit:hover {
  background: var(--color-accent-pressed);
  color: var(--color-bg);
}

.cahier-success {
  background: var(--color-bg);
  border: 1px solid var(--color-accent);
  color: var(--color-text);
  display: none;
  font-size: var(--fs-body);
  margin-top: var(--space-md);
  padding: var(--space-md);
}

.cahier-success.is-visible {
  display: block;
}

.etabli {
  background: var(--color-bg);
  padding-block: var(--space-2xl);
}

.etabli-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
  text-align: center;
}

.etabli-card {
  margin: 0 auto;
  max-width: 600px;
}

.etabli-portrait {
  border-radius: var(--radius-circle);
  display: block;
  height: 140px;
  margin: 0 auto var(--space-lg);
  object-fit: cover;
  object-position: center top;
  width: 140px;
}

.etabli-job {
  color: var(--color-accent);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  margin: 0 0 var(--space-sm);
  text-transform: uppercase;
}

.etabli-name {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  margin: 0 0 var(--space-md);
}

.etabli-bio {
  color: var(--color-text-muted);
  font-size: var(--fs-body);
  line-height: var(--lh-loose);
  margin: 0 0 var(--space-md);
}

.etabli-expertise {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.etabli-tag {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-line);
  color: var(--color-text);
  display: inline-block;
  font-size: var(--fs-small);
  padding: 6px 12px;
}

.encart {
  background: var(--color-bg);
  padding-block: var(--space-lg);
}

.encart-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.encart-card {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-soft);
  border-radius: var(--radius-md);
  display: flex;
  gap: var(--space-md);
  margin: 0 auto;
  max-width: 720px;
  padding: var(--space-lg);
}

.encart-portrait {
  flex: 0 0 auto;
}

.encart-portrait img {
  border-radius: var(--radius-circle);
  height: 64px;
  object-fit: cover;
  object-position: center top;
  width: 64px;
}

.encart-body {
  flex: 1 1 auto;
}

.encart-label {
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: var(--fs-micro);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  margin: 0 0 var(--space-2xs);
  text-transform: uppercase;
}

.encart-name {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: var(--fw-bold);
  margin: 0 0 var(--space-2xs);
}

.encart-name a {
  color: var(--color-text);
}

.encart-name a:hover {
  color: var(--color-accent);
}

.encart-role {
  color: var(--color-text-muted);
  font-size: var(--fs-small);
  margin: 0 0 var(--space-xs);
}

.encart-bio {
  color: var(--color-text-muted);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  margin: 0 0 var(--space-sm);
}

.encart-dates {
  color: var(--color-text-muted);
  font-size: var(--fs-small);
  margin: 0 0 var(--space-xs);
}

.encart-dates time {
  color: var(--color-text);
}

.encart-link {
  color: var(--color-accent);
  font-family: var(--font-body);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

.encart-link:hover {
  color: var(--color-accent-pressed);
}

.buffet {
  background: var(--color-primary);
  border-top: 1px solid var(--color-border-soft);
  bottom: 0;
  display: none;
  left: 0;
  padding-block: var(--space-md);
  padding-inline: var(--container-padding-desktop);
  position: fixed;
  right: 0;
  z-index: var(--z-cookie);
}

.buffet.is-visible {
  display: block;
}

.buffet-inner {
  align-items: center;
  display: flex;
  gap: var(--space-md);
  justify-content: space-between;
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
}

.buffet-message {
  color: var(--color-text-muted);
  flex: 1 1 auto;
  font-size: var(--fs-small);
  margin: 0;
}

.buffet-actions {
  display: flex;
  flex-shrink: 0;
  gap: var(--space-sm);
}

.buffet-btn {
  background: transparent;
  border: 1px solid var(--color-text);
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  padding: 8px 18px;
  text-transform: uppercase;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}

.buffet-btn:hover {
  background: var(--color-text);
  color: var(--color-bg);
}

.buffet-btn--accept {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-bg);
}

.buffet-btn--accept:hover {
  background: var(--color-accent-pressed);
  border-color: var(--color-accent-pressed);
  color: var(--color-bg);
}

.lutrin {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.85) 100%), url("/display-dark/postcard.webp") center / cover no-repeat var(--color-bg);
  display: flex;
  min-height: 100vh;
  position: relative;
}

.lutrin-inner {
  align-items: center;
  display: flex;
  justify-content: center;
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-block: var(--space-3xl);
  padding-inline: var(--container-padding-desktop);
  width: 100%;
}

.lutrin-content {
  backdrop-filter: blur(4px);
  background: rgba(0, 0, 0, 0.55);
  padding: var(--space-2xl);
  text-align: center;
}

.lutrin-title {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h1);
  font-weight: var(--fw-bold);
  margin: 0 0 var(--space-md);
  text-transform: uppercase;
}

.lutrin-text {
  color: var(--color-text);
  font-size: var(--fs-h5);
  line-height: var(--lh-loose);
  margin: 0 auto var(--space-xl);
  max-width: 600px;
}

.lutrin-button {
  background: var(--color-accent);
  color: var(--color-bg);
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--fs-h5);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  padding: 18px 36px;
  text-transform: uppercase;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}

.lutrin-button:hover {
  background: var(--color-accent-pressed);
  color: var(--color-bg);
}

.cloche {
  background: var(--color-bg);
  border-top: 1px solid var(--color-border-line);
  padding-block: var(--space-3xl);
}

.cloche-inner {
  margin-inline: auto;
  max-width: calc(var(--container-site) + 2 * var(--container-padding-desktop));
  padding-inline: var(--container-padding-desktop);
}

.cloche-manifesto {
  text-align: center;
}

.cloche-statement {
  color: var(--color-text);
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  font-weight: var(--fw-bold);
  margin: 0 auto var(--space-md);
  max-width: 720px;
}

.cloche-cta {
  color: var(--color-accent);
  font-family: var(--font-display);
  font-size: var(--fs-h5);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-decoration: underline;
  text-transform: uppercase;
}

.cloche-cta:hover {
  color: var(--color-accent-pressed);
}

.cloche-divider {
  background: rgba(255, 255, 255, 0.1);
  height: 1px;
  margin-block: var(--space-xl);
}

.cloche-meta {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-lg);
  justify-content: space-between;
}

.cloche-logo {
  align-items: center;
  display: inline-flex;
}

.cloche-logo img {
  height: 64px;
  width: auto;
  display: block;
}

.cloche-nav,
.cloche-legal {
  list-style: none;
  margin: 0;
  padding: 0;
}

.cloche-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.cloche-legal {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

.cloche-nav a,
.cloche-legal a {
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: var(--fs-small);
}

.cloche-nav a:hover,
.cloche-legal a:hover {
  color: var(--color-accent);
}

.cloche-copyright {
  color: var(--color-text-muted);
  display: block;
  font-size: var(--fs-small);
  margin-top: var(--space-lg);
  text-align: center;
}

.cloche-license {
  color: var(--color-text-muted);
  font-size: var(--fs-small);
  margin-top: var(--space-sm);
  text-align: center;
}

@media (max-width: 1080px) {
  .medaillon-list,
  .medaillon-auth {
    display: none;
  }

  .medaillon-toggle {
    display: flex;
  }

  .medaillon-inner {
    min-height: 72px;
  }

  .medaillon {
    border-bottom: 0;
  }

  .coupole-list {
    grid-template-columns: 1fr;
  }

  .cloche-meta {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 760px) {
  :root {
    --fs-body: 15px;
    --fs-h1: 36px;
    --fs-h2: 26px;
    --fs-h3: 20px;
    --fs-h4: 17px;
    --fs-h5: 14px;
    --fs-h6: 12px;
    --fs-micro: 9px;
    --fs-small: 12px;
  }

  .carnet {
    padding-block: var(--space-xl);
  }

  .carnet-frame {
    padding: var(--space-xl);
  }

  .carnet-cta {
    font-size: var(--fs-body);
    padding: 14px 24px;
  }

  .rubrique-inner {
    grid-template-columns: 1fr;
  }

  .rubrique-number {
    font-size: 56px;
  }

  .porte h3,
  .porte p,
  .porte ol,
  .porte ul {
    padding-left: var(--space-md);
  }

  .porte ol,
  .porte ul {
    padding-left: calc(var(--space-md) + var(--space-lg));
  }

  .chapitre-item {
    grid-template-areas:
      "author"
      "date"
      "text";
    grid-template-columns: 1fr;
  }

  .chapitre-date {
    margin-bottom: var(--space-xs);
  }

  .tympan-title {
    font-size: var(--fs-h2);
  }

  .tympan-button {
    font-size: var(--fs-body);
    height: 52px;
    line-height: 52px;
    padding-inline: var(--space-lg);
  }

  .encart-card {
    flex-direction: column;
  }

  .buffet-inner {
    flex-direction: column;
    align-items: stretch;
  }

  .buffet-actions {
    flex-direction: row;
    justify-content: stretch;
  }

  .buffet-btn {
    flex: 1 1 auto;
  }

  .cloche-meta {
    align-items: stretch;
  }

  .lutrin-title {
    font-size: var(--fs-h2);
  }
}


/* page-img injected */
.dejydi-img {
  display: block;
  width: 100%;
  max-width: 440px;
  max-height: 55vh;
  height: auto;
  margin: var(--space-md) auto;
  object-fit: contain;
  border-radius: var(--radius-md, 12px);
}
@media (max-width: 599px) {
  .dejydi-img { max-width: 100%; max-height: 50vh; }
}
