/* ===========================================================
   GRAÏA — Landing page styles
   Source of truth: handoff /Claude design/design_handoff_landing_b/colors_and_type.css
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Bagel+Fat+One&family=Montserrat:wght@400;500;600;700;800&display=swap');

:root {
  --graia-coral: #ED696A;
  --graia-peach: #F8B069;
  --graia-sky:   #78B0E0;
  --graia-leaf:  #85C384;
  --graia-ink:   #192B20;
  --graia-cream: #E3DCCA;

  --graia-ink-90: rgba(25, 43, 44, 0.92);
  --graia-ink-70: rgba(25, 43, 44, 0.70);
  --graia-ink-40: rgba(25, 43, 44, 0.40);
  --graia-ink-10: rgba(25, 43, 44, 0.10);
  --graia-cream-80: rgba(227, 220, 202, 0.80);
  --graia-cream-65: rgba(227, 220, 202, 0.65);
  --graia-cream-20: rgba(227, 220, 202, 0.20);

  --fg: var(--graia-ink);
  --bg: var(--graia-cream);
  --bg-elevated: #EDE7D8;

  --font-display: 'Bagel Fat One', Impact, sans-serif;
  --font-title:   'Anton', 'Bebas Neue', 'Oswald', sans-serif;
  --font-body:    'Montserrat', system-ui, -apple-system, 'Helvetica Neue', sans-serif;

  --ease-snap: cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* ===========================================================
   Bandeau immatriculation — toggleable depuis api/config.php
   À retirer (SHOW_INCORPORATION_BANNER=false) dès SIRET obtenu.
   =========================================================== */
.incorp-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 8px 16px;
  background: var(--graia-peach);
  color: var(--graia-ink);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  border-bottom: 2px solid var(--graia-ink);
  text-align: center;
  line-height: 1.4;
}
.incorp-banner__dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 999px;
  background: var(--graia-coral);
  border: 1px solid var(--graia-ink);
  flex-shrink: 0;
  font-size: 0;
  animation: incorp-pulse 2s ease-in-out infinite;
}
@keyframes incorp-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.5; transform: scale(0.8); }
}
@media (prefers-reduced-motion: reduce) {
  .incorp-banner__dot { animation: none; }
}
@media (max-width: 540px) {
  .incorp-banner { font-size: 11px; padding: 7px 12px; gap: 8px; }
}

/* ===========================================================
   Accessibility — focus visible global (WCAG 2.1 SC 2.4.7)
   Toute cible interactive a un anneau de focus net.
   =========================================================== */
.btn:focus-visible,
.quiz__choice:focus-visible,
.quiz__tag:focus-visible,
.quiz__back:focus-visible,
.quiz__next:focus-visible,
.quiz__skip:focus-visible,
.quiz__field:focus-visible,
.nav__links a:focus-visible,
.nav__burger:focus-visible,
.social__post:focus-visible,
.footer__col a:focus-visible,
.newsletter__row input:focus-visible,
.newsletter__row button:focus-visible,
.newsletter__consent input:focus-visible,
.quiz__contact-field input:focus-visible,
.quiz__contact-check input:focus-visible {
  outline: 3px solid var(--graia-sky);
  outline-offset: 3px;
  border-radius: 4px;
}

@media (prefers-reduced-motion: reduce) {
  /* Étendu : pas de transition / animation hors essentiel */
  .btn, .social__post, .quiz__progress-fill,
  .quiz__choice, .quiz__tag, .quiz__head {
    transition: none !important;
    animation: none !important;
  }
}

/* ===========================================================
   Reset + base
   =========================================================== */
*, *::before, *::after { box-sizing: border-box; }
html, body {
  margin: 0;
  background: var(--graia-ink);
  color: var(--graia-cream);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
button { font: inherit; cursor: pointer; }

/* ===========================================================
   Pills, buttons, cards
   =========================================================== */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 6px 12px;
  border: 2px solid var(--graia-ink);
  border-radius: 999px;
  background: var(--graia-cream);
  color: var(--graia-ink);
}
.pill--coral { background: var(--graia-coral); }
.pill--leaf  { background: var(--graia-leaf); }
.pill--peach { background: var(--graia-peach); }
.pill--sky   { background: var(--graia-sky); }
.pill--ink   { background: var(--graia-ink); color: var(--graia-cream); }
.pill--ghost-ink { background: transparent; border-color: var(--graia-cream); color: var(--graia-cream); }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 14px 24px;
  border: 2px solid var(--graia-ink);
  background: var(--graia-ink);
  color: var(--graia-cream);
  border-radius: 999px;
  text-decoration: none;
  transition: transform 120ms var(--ease-snap),
              box-shadow 120ms var(--ease-snap),
              filter 120ms var(--ease-snap);
  box-shadow: 3px 3px 0 0 var(--graia-ink);
}
.btn:hover  { filter: brightness(0.92); }
.btn:active { transform: translate(2px, 2px); box-shadow: 0 0 0 0 var(--graia-ink); }
.btn:focus-visible { outline: 3px solid var(--graia-sky); outline-offset: 3px; }

.btn--coral { background: var(--graia-coral); color: var(--graia-ink); }
.btn--leaf  { background: var(--graia-leaf);  color: var(--graia-ink); }
.btn--peach { background: var(--graia-peach); color: var(--graia-ink); }
.btn--cream { background: var(--graia-cream); color: var(--graia-ink); }
.btn--ghost { background: transparent; color: inherit; }
.btn--ghost-cream { background: transparent; color: var(--graia-cream); border-color: var(--graia-cream); box-shadow: 3px 3px 0 0 var(--graia-cream); }
.btn--ghost-cream:hover { background: var(--graia-cream); color: var(--graia-ink); filter: none; }

.btn--lg { font-size: 17px; padding: 18px 32px; box-shadow: 5px 5px 0 0 var(--graia-ink); }
.btn--sm { font-size: 13px; padding: 10px 16px; }

.card {
  background: var(--graia-cream);
  border: 2px solid var(--graia-ink);
  border-radius: 6px;
  box-shadow: 5px 5px 0 0 var(--graia-ink);
  padding: 24px;
  color: var(--graia-ink);
}
.card--coral { background: var(--graia-coral); }
.card--leaf  { background: var(--graia-leaf); }
.card--peach { background: var(--graia-peach); }
.card--sky   { background: var(--graia-sky); }

.eyebrow {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--graia-cream-65);
  margin-bottom: 12px;
  display: block;
}

/* ===========================================================
   Nav (sticky)
   =========================================================== */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 14px 32px;
  background: var(--graia-ink);
  color: var(--graia-cream);
  border-bottom: 2px solid var(--graia-cream-20);
}
.nav__brand { display: flex; align-items: baseline; gap: 8px; text-decoration: none; color: inherit; }
.nav__brand .word { font-family: var(--font-display); font-size: 30px; letter-spacing: -1px; line-height: 0.9; }
.nav__brand .tag  { font-family: var(--font-title); font-size: 9px; letter-spacing: 4px; text-transform: uppercase; opacity: 0.8; }
.nav__brand .tag .hash { color: var(--graia-coral); }
.nav__links { display: flex; gap: 22px; align-items: center; }
.nav__links a {
  color: inherit;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-decoration: none;
  transition: color 120ms;
}
.nav__links a:hover {
  color: var(--graia-coral);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 6px;
}
.nav__social { display: inline-flex; gap: 8px; }
/* Hit area 48x48 via padding transparent autour du cercle visible 30x30 (WCAG AAA touch target) */
.nav__social .dot {
  width: 30px; height: 30px;
  padding: 0;
  border-radius: 999px;
  border: 2px solid var(--graia-cream);
  background: var(--graia-ink);
  color: var(--graia-cream);
  display: grid; place-items: center;
  font-family: var(--font-title);
  font-size: 12px; text-transform: lowercase;
  text-decoration: none;
  transition: background 120ms, color 120ms;
  position: relative;
}
.nav__social .dot::before {
  content: '';
  position: absolute;
  inset: -9px; /* 30px + 18px = 48px hit area, invisible */
}
.nav__social .dot:hover { background: var(--graia-cream); color: var(--graia-ink); }
.nav__social .dot:focus-visible { outline: 3px solid var(--graia-coral); outline-offset: 4px; }

.nav__burger { display: none; background: none; border: 0; color: inherit; font-size: 22px; padding: 8px; }

@media (max-width: 860px) {
  .nav__links a { display: none; }
  .nav__burger { display: inline-flex; }
  .nav__links.open a { display: inline-flex; }
  .nav__links.open {
    position: absolute; top: 100%; right: 16px;
    flex-direction: column;
    background: var(--graia-ink);
    padding: 16px 20px;
    border: 2px solid var(--graia-cream-20);
    border-radius: 8px;
    gap: 12px;
    box-shadow: 5px 5px 0 0 var(--graia-coral);
  }
}

/* ===========================================================
   Hero
   =========================================================== */
.hero {
  padding: 40px 32px 80px;
  position: relative;
  overflow: hidden;
}
.hero__wrap {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 48px;
  align-items: center;
}
.hero__pills { display: flex; gap: 8px; margin-bottom: 24px; flex-wrap: wrap; }
.hero__title {
  font-family: var(--font-display);
  font-size: clamp(72px, 11vw, 168px);
  line-height: 0.84;
  text-transform: uppercase;
  margin: 0;
  color: var(--graia-cream);
}
.hero__title .end-dot { color: var(--graia-coral); }
.hero__subtitle {
  font-family: var(--font-title);
  font-size: clamp(20px, 2vw, 28px);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.2;
  margin-top: 24px;
  max-width: 520px;
  color: var(--graia-cream);
}
.hero__subtitle .muted { color: var(--graia-cream-65); }
.hero__paragraph {
  font-size: 16px;
  line-height: 1.55;
  margin-top: 20px;
  max-width: 480px;
  color: var(--graia-cream-65);
}
.hero__ctas { display: flex; gap: 12px; margin-top: 32px; flex-wrap: wrap; }
/* Symétrise les 2 CTAs hero : sinon le ghost paraît subordonné par sa largeur (174 vs 274) */
.hero__ctas .btn--lg { min-width: 248px; }
@media (max-width: 540px) {
  .hero__ctas .btn--lg { min-width: 0; width: 100%; }
}

.hero__photo { position: relative; }
.hero__photo .frame {
  aspect-ratio: 4/5;
  background: var(--graia-leaf);
  border: 3px solid var(--graia-ink);
  border-radius: 8px;
  box-shadow: 12px 12px 0 0 var(--graia-coral);
  position: relative;
  overflow: hidden;
}
.hero__photo .frame .ph {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 160px;
}
.hero__photo .frame .ph--img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.hero__photo .frame .cap {
  position: absolute;
  bottom: 14px; left: 14px; right: 14px;
  padding: 10px 14px;
  background: var(--graia-ink);
  color: var(--graia-cream);
  border: 2px solid var(--graia-ink);
  border-radius: 4px;
  font-family: var(--font-title);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  display: flex;
  justify-content: space-between;
}
.hero__photo .frame .cap .ok { color: var(--graia-leaf); }
.hero__photo .stick {
  position: absolute;
  background: var(--graia-peach);
  border: 2px solid var(--graia-ink);
  padding: 10px 16px;
  border-radius: 4px;
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1;
  box-shadow: 4px 4px 0 0 var(--graia-ink);
  color: var(--graia-ink);
}
.hero__photo .stick--1 { top: -18px; left: -28px; transform: rotate(-8deg); background: var(--graia-peach); }
.hero__photo .stick--2 { bottom: -22px; right: -22px; transform: rotate(6deg); background: var(--graia-sky); font-size: 18px; }

@media (max-width: 860px) {
  .hero__wrap { grid-template-columns: 1fr; gap: 56px; }
  .hero { padding: 24px 20px 64px; }
  .hero__title { font-size: clamp(64px, 16vw, 110px); }
  .hero__photo .stick--1 { left: -8px; }
  .hero__photo .stick--2 { right: -4px; }
}
/* [MOBILE 540px] hero : titre plus petit, stickers contenus */
@media (max-width: 540px) {
  .hero { padding: 20px 16px 48px; }
  .hero__title { font-size: clamp(48px, 14vw, 80px); }
  .hero__photo .stick--1 { left: 0; top: -10px; font-size: 16px; padding: 7px 12px; }
  .hero__photo .stick--2 { right: 0; bottom: -14px; font-size: 14px; padding: 7px 12px; }
}

/* ===========================================================
   Ticker
   =========================================================== */
.ticker {
  background: var(--graia-coral);
  color: var(--graia-ink);
  border-top: 2px solid var(--graia-ink);
  border-bottom: 2px solid var(--graia-ink);
  padding: 14px 0;
  overflow: hidden;
  position: relative;
}
.ticker__track {
  display: inline-flex;
  gap: 32px;
  white-space: nowrap;
  padding-left: 32px;
  animation: tickerScroll 40s linear infinite;
}
.ticker__track > span {
  font-family: var(--font-title);
  font-size: 18px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.ticker__track > .hash {
  font-family: var(--font-display);
  font-size: 28px;
  letter-spacing: 0;
  color: var(--graia-ink);
  opacity: 0.85;
}
@keyframes tickerScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .ticker__track { animation: none; }
}

/* ===========================================================
   Sections (generic)
   =========================================================== */
.section {
  padding: 96px 32px;
  border-bottom: 2px solid var(--graia-ink);
}
.section__wrap { max-width: 1180px; margin: 0 auto; }
/* [MOBILE] padding vertical réduit pour toutes les sections */
@media (max-width: 860px) {
  .section { padding: 64px 20px; }
}
@media (max-width: 540px) {
  .section { padding: 48px 16px; }
}

/* Concept */
.concept { background: var(--graia-ink); color: var(--graia-cream); }
.concept .row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 48px;
  margin-top: 16px;
  align-items: start;
}
.concept .row > h2 {
  font-family: var(--font-title);
  font-size: clamp(38px, 4.5vw, 64px);
  line-height: 1;
  text-transform: uppercase;
  margin: 0;
}
.concept .row > h2 .mid { color: var(--graia-coral); }
.concept .row > h2 .sub { color: var(--graia-cream-65); font-size: 0.55em; display: block; margin-top: 8px; }
.concept .col { border-left: 2px solid var(--graia-cream); padding-left: 24px; }
.concept .col h3 { font-family: var(--font-title); font-size: 18px; text-transform: uppercase; margin: 0 0 10px; color: var(--graia-coral); letter-spacing: 3px; }
.concept .col p { font-size: 14px; line-height: 1.55; color: var(--graia-cream-65); margin: 0; }
.concept .deck { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 64px; }
.concept .deck-card { padding: 22px; }
.concept .deck-card .big { font-family: var(--font-display); font-size: 76px; line-height: 0.9; color: var(--graia-ink); }
.concept .deck-card .sub { font-family: var(--font-title); font-size: 16px; text-transform: uppercase; letter-spacing: 0.06em; margin-top: 6px; }
.concept .deck-card .txt { font-size: 13px; line-height: 1.4; margin-top: 10px; color: var(--graia-ink); opacity: 0.85; }
@media (max-width: 860px) {
  .concept .row { grid-template-columns: 1fr; gap: 28px; }
  .concept .deck { grid-template-columns: repeat(2, 1fr); }
}

/* Sondage */
.sondage { background: var(--graia-coral); color: var(--graia-ink); }
.sondage .wrap {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 56px;
  align-items: start;
  max-width: 1100px;
  margin: 0 auto;
}
.sondage .intro { position: sticky; top: 96px; }
.sondage .intro .eyebrow { color: var(--graia-ink); opacity: 0.7; }
.sondage .intro h2 {
  font-family: var(--font-display);
  font-size: clamp(56px, 8vw, 110px);
  line-height: 0.88;
  text-transform: uppercase;
  margin: 0;
}
.sondage .intro h2 .end { color: var(--graia-cream); }
.sondage .intro p { font-size: 16px; line-height: 1.55; margin-top: 20px; max-width: 380px; font-weight: 500; }
.sondage .intro ul { list-style: none; padding: 0; margin-top: 24px; display: grid; gap: 8px; }
.sondage .intro li { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; line-height: 1.4; }
.sondage .intro li .arr { color: var(--graia-ink); font-weight: 800; }
@media (max-width: 860px) {
  .sondage .wrap { grid-template-columns: 1fr; gap: 32px; }
  .sondage .intro { position: static; }
}

/* Quiz card */
.quiz {
  background: var(--graia-cream);
  border: 2px solid var(--graia-ink);
  border-radius: 8px;
  box-shadow: 8px 8px 0 0 var(--graia-ink);
  overflow: hidden;
  color: var(--graia-ink);
}
.quiz__progress { height: 8px; background: var(--graia-ink-10); border-bottom: 2px solid var(--graia-ink); position: relative; }
.quiz__progress-fill { width: 0; height: 100%; background: var(--graia-coral); transition: width 0.4s var(--ease-snap), background-color 0.4s; }
.quiz__head { display: flex; align-items: center; justify-content: space-between; padding: 14px 24px; border-bottom: 2px solid var(--graia-ink); background: var(--graia-coral); color: var(--graia-ink); transition: background 0.3s; }
.quiz__head .counter { font-family: var(--font-display); font-size: 26px; line-height: 1; }
.quiz__head .counter .total { opacity: 0.55; }
.quiz__body { padding: 36px 32px 32px; min-height: 320px; }
.quiz__q { font-family: var(--font-title); font-size: clamp(26px, 3.4vw, 38px); line-height: 1.05; text-transform: uppercase; margin: 0 0 6px; }
.quiz__sub { font-size: 14px; opacity: 0.7; margin-bottom: 22px; }
.quiz__opts { display: grid; gap: 10px; margin-top: 18px; }
.quiz__choice {
  text-align: left;
  padding: 14px 18px;
  border: 2px solid var(--graia-ink);
  border-radius: 6px;
  background: transparent;
  color: var(--graia-ink);
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 600;
  box-shadow: none;
  transform: none;
  transition: all 120ms var(--ease-snap);
}
.quiz__choice:hover { background: rgba(25,43,44,0.04); }
.quiz__choice.is-active {
  background: var(--graia-coral);
  box-shadow: 4px 4px 0 0 var(--graia-ink);
  transform: translate(-2px,-2px);
}
.quiz__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.quiz__tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 8px 14px;
  border: 2px solid var(--graia-ink);
  border-radius: 999px;
  background: transparent;
  color: var(--graia-ink);
  transition: all 120ms var(--ease-snap);
}
.quiz__tag.is-active { background: var(--graia-coral); }
.quiz__slider-val {
  font-family: var(--font-display);
  font-size: 64px;
  line-height: 1;
  color: var(--graia-coral);
  text-align: center;
  text-shadow: 3px 3px 0 var(--graia-ink);
  margin-top: 24px;
}
.quiz__slider-val .unit { font-size: 28px; margin-left: 8px; }
.quiz__slider input[type=range] { width: 100%; margin-top: 16px; accent-color: var(--graia-coral); }
.quiz__slider-bounds { display: flex; justify-content: space-between; font-size: 12px; font-weight: 700; opacity: 0.55; margin-top: 4px; }
.quiz__field {
  width: 100%;
  font-family: var(--font-body);
  font-size: 16px;
  padding: 14px 16px;
  background: transparent;
  border: 2px solid var(--graia-ink);
  border-radius: 4px;
  color: var(--graia-ink);
  margin-top: 18px;
  outline: none;
}
.quiz__field:focus { outline: 3px solid var(--graia-sky); outline-offset: 2px; }
.quiz__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 24px;
  border-top: 2px solid var(--graia-ink);
  background: rgba(25,43,44,0.04);
}
.quiz__back, .quiz__next {
  background: transparent;
  border: 0;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--graia-ink);
}
.quiz__back:disabled { opacity: 0.3; cursor: not-allowed; }
.quiz__next:disabled,
.quiz__next[aria-disabled="true"] {
  opacity: 0.35;
  cursor: not-allowed;
  filter: grayscale(0.4);
  pointer-events: none; /* protection clic + écho au disabled */
}
.quiz__progress-label { font-family: var(--font-body); font-size: 12px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; opacity: 0.6; }
.quiz__done {
  text-align: center;
  padding: 48px 24px;
}
.quiz__done .big {
  font-family: var(--font-display);
  font-size: clamp(60px, 9vw, 110px);
  line-height: 0.9;
  color: var(--graia-ink);
  margin: 0;
}
.quiz__done .big .frr { color: var(--graia-coral); }
.quiz__done p { font-size: 16px; max-width: 480px; margin: 24px auto; opacity: 0.75; }

/* ── Formulaire contact post-sondage ─────────────────────────── */
.quiz__contact {
  max-width: 460px;
  margin: 12px auto 0;
  padding: 24px;
  border: 2px solid var(--graia-ink);
  border-radius: 8px;
  background: rgba(237, 105, 106, 0.08);
  box-shadow: 5px 5px 0 0 var(--graia-ink);
  text-align: left;
}
.quiz__contact-head { text-align: center; margin-bottom: 18px; }
.quiz__contact-eyebrow {
  font-family: var(--font-body);
  font-size: 11px; font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--graia-coral);
}
.quiz__contact-title {
  font-family: var(--font-title);
  font-size: 24px;
  line-height: 1.05;
  text-transform: uppercase;
  margin: 4px 0 8px;
  color: var(--graia-ink);
}
.quiz__contact-sub {
  font-size: 13px;
  line-height: 1.45;
  margin: 0;
  color: var(--graia-ink);
  opacity: 0.7;
}
.quiz__contact-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}
.quiz__contact-field {
  display: block;
  margin-bottom: 10px;
}
.quiz__contact-field > span {
  display: block;
  font-size: 11px; font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--graia-ink);
  opacity: 0.65;
  margin-bottom: 5px;
}
.quiz__contact-field input {
  width: 100%;
  padding: 11px 14px;
  font-family: var(--font-body);
  font-size: 15px;
  background: var(--graia-cream);
  border: 2px solid var(--graia-ink);
  border-radius: 6px;
  color: var(--graia-ink);
  outline: none;
}
.quiz__contact-field input:focus {
  outline: 3px solid var(--graia-sky);
  outline-offset: 2px;
}
.quiz__contact-field input::placeholder { color: var(--graia-ink-40); }

.quiz__contact-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 12px 0 16px;
  font-size: 13px;
  line-height: 1.4;
  color: var(--graia-ink);
  cursor: pointer;
}
.quiz__contact-check input[type=checkbox] {
  width: 18px; height: 18px;
  margin-top: 2px;
  accent-color: var(--graia-coral);
  flex-shrink: 0;
}
.quiz__contact-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
}
.quiz__skip {
  background: transparent;
  border: 0;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--graia-ink);
  opacity: 0.55;
  cursor: pointer;
  padding: 4px 8px;
}
.quiz__skip:hover { opacity: 0.85; text-decoration: underline; }
.quiz__contact-msg {
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--graia-coral);
  min-height: 18px;
  margin-top: 10px;
}
.quiz__contact-msg.err { color: var(--graia-coral); }

.quiz__contact-success {
  display: flex; flex-direction: column;
  align-items: center; gap: 12px;
  padding: 12px 8px;
  text-align: center;
}
.quiz__contact-success-icon {
  width: 56px; height: 56px;
  border-radius: 999px;
  background: var(--graia-leaf);
  border: 2px solid var(--graia-ink);
  color: var(--graia-ink);
  display: grid; place-items: center;
  font-size: 28px; font-weight: 800;
  box-shadow: 4px 4px 0 0 var(--graia-ink);
}
.quiz__contact-success-text {
  font-family: var(--font-title);
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--graia-ink);
  max-width: 360px;
}

@media (max-width: 540px) {
  .quiz__contact-row { grid-template-columns: 1fr; }
}
/* [MOBILE] Quiz tags : touch target minimum 44px */
@media (max-width: 860px) {
  .quiz__tag {
    padding: 12px 14px;
    min-height: 44px;
  }
  .quiz__choice {
    padding: 14px 16px;
    min-height: 44px;
  }
  .quiz__body { padding: 24px 16px 20px; }
  .quiz__foot { padding: 14px 16px; }
}

/* ===========================================================
   Newsletter section
   =========================================================== */
.news { background: var(--graia-ink); color: var(--graia-cream); }
.news .wrap {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.news h2 {
  font-family: var(--font-title);
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1;
  text-transform: uppercase;
  margin: 0;
}
.news h2 .accent { color: var(--graia-peach); }
.news p { font-size: 16px; line-height: 1.55; margin-top: 20px; color: var(--graia-cream-65); }
.newsletter { margin-top: 28px; display: flex; flex-direction: column; gap: 10px; max-width: 520px; }
.newsletter__row {
  display: flex; gap: 8px; padding: 6px;
  border: 2px solid var(--graia-cream);
  border-radius: 999px;
  background: rgba(227,220,202,0.08);
  box-shadow: 5px 5px 0 0 var(--graia-cream);
}
.newsletter__row input {
  flex: 1; border: 0; background: transparent;
  padding: 12px 16px;
  font-family: var(--font-body); font-size: 15px;
  color: var(--graia-cream); outline: none;
}
.newsletter__row input::placeholder { color: var(--graia-cream-65); }
.newsletter__row button {
  border-radius: 999px;
  padding: 12px 20px;
  border: 2px solid var(--graia-ink);
  background: var(--graia-peach);
  color: var(--graia-ink);
  font-family: var(--font-body);
  font-weight: 800; font-size: 13px;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.newsletter__row button:hover { filter: brightness(0.93); }
.newsletter__row button:active { transform: translate(2px,2px); }
.newsletter__meta {
  display: flex; justify-content: space-between; gap: 12px;
  font-size: 12px; color: var(--graia-cream-65);
}
.newsletter__meta strong { color: var(--graia-peach); }
.newsletter__msg { font-size: 13px; font-weight: 600; color: var(--graia-leaf); min-height: 18px; }
.newsletter__msg.err { color: var(--graia-coral); }

.news .stats { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.news .stat-card { padding: 24px; }
.news .stat-card .num { font-family: var(--font-display); font-size: 62px; line-height: 0.9; color: var(--graia-ink); }
.news .stat-card .lab { font-family: var(--font-title); font-size: 13px; text-transform: uppercase; letter-spacing: 0.06em; margin-top: 8px; color: var(--graia-ink); }
/* Stat card en mode "bientôt" (compteur sous seuil) : .num plus discret, sans crier le 0 */
.news .stat-card.is-soon { opacity: 0.78; }
.news .stat-card.is-soon .num {
  font-family: var(--font-title);
  font-size: 28px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0.7;
}
@media (max-width: 860px) {
  .news .wrap { grid-template-columns: 1fr; gap: 32px; }
}
/* [MOBILE 540px] newsletter : input + bouton en colonne */
@media (max-width: 540px) {
  .newsletter__row {
    flex-direction: column;
    border-radius: 12px;
    padding: 10px;
    gap: 8px;
  }
  .newsletter__row input {
    padding: 12px 12px;
    width: 100%;
  }
  .newsletter__row button {
    width: 100%;
    min-height: 44px;
    border-radius: 8px;
  }
}

/* ===========================================================
   Roadmap
   =========================================================== */
.road { background: rgba(227,220,202,0.04); color: var(--graia-cream); }
.road .head { text-align: center; margin-bottom: 56px; }
.road h2 {
  font-family: var(--font-title);
  font-size: clamp(40px, 5vw, 60px);
  line-height: 0.95;
  text-transform: uppercase;
  margin: 0;
}
.road .list { position: relative; max-width: 720px; margin: 0 auto; padding-left: 60px; }
.road .rail { position: absolute; left: 24px; top: 12px; bottom: 12px; width: 3px; background: var(--graia-cream-20); }
.road .step { position: relative; margin-bottom: 32px; }
.road .step .dot {
  position: absolute; left: -50px; top: 6px;
  width: 28px; height: 28px;
  border-radius: 999px;
  border: 3px solid var(--graia-ink);
  display: grid; place-items: center;
  font-size: 13px; font-weight: 800;
  background: var(--graia-ink);
  color: var(--graia-cream);
}
.road .step.done .dot { background: var(--graia-leaf); color: var(--graia-ink); }
.road .step.now  .dot { background: var(--graia-coral); color: var(--graia-ink); box-shadow: 0 0 0 6px rgba(237,105,106,0.30); }
.road .step .body {
  padding: 14px 20px;
  border: 2px solid var(--graia-ink);
  border-radius: 6px;
  background: transparent;
}
/* Steps "next" sur le fond sombre ink : bordure ink invisible → cream à 18% pour structurer sans dominer */
.road .step:not(.now):not(.done) .body {
  border-color: rgba(227, 220, 202, 0.18);
}
.road .step.now .body {
  background: var(--graia-coral);
  color: var(--graia-ink);
  box-shadow: 5px 5px 0 0 var(--graia-ink);
}
.road .step .top { display: flex; align-items: baseline; gap: 12px; margin-bottom: 4px; flex-wrap: wrap; }
.road .step .date { font-family: var(--font-display); font-size: 22px; line-height: 1; color: var(--graia-coral); }
.road .step.done .date { color: var(--graia-leaf); }
.road .step.now .date  { color: var(--graia-ink); }
.road .step .label { font-family: var(--font-title); font-size: 18px; text-transform: uppercase; letter-spacing: 0.04em; }
.road .step .txt { font-size: 14px; line-height: 1.5; color: var(--graia-cream-65); }
.road .step.now .txt { color: var(--graia-ink); opacity: 0.9; }
/* [MOBILE] roadmap : padding-left et dot réduits */
@media (max-width: 540px) {
  .road .list { padding-left: 44px; }
  .road .rail { left: 20px; }
  .road .step .dot { left: -36px; width: 24px; height: 24px; font-size: 11px; }
}

/* ===========================================================
   Social mosaic
   =========================================================== */
.social { background: var(--graia-ink); color: var(--graia-cream); }
.social__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.social__post {
  position: relative;
  aspect-ratio: 1/1;
  border: 2px solid var(--graia-ink);
  border-radius: 6px;
  padding: 14px;
  display: flex; flex-direction: column; justify-content: space-between;
  color: var(--graia-ink);
  text-decoration: none;
  overflow: hidden;
  transition: transform 200ms var(--ease-snap);
}
.social__post:hover { transform: translate(-3px, -3px); }
.social__post .head { display: flex; justify-content: space-between; }
.social__post .head .likes { font-size: 12px; font-weight: 700; }
.social__post .emo { font-size: 80px; text-align: right; line-height: 1; opacity: 0.85; }
.social__post .cap { font-family: var(--font-body); font-size: 13px; font-weight: 700; line-height: 1.3; position: relative; }
.social__post.coral { background: var(--graia-coral); }
.social__post.peach { background: var(--graia-peach); }
.social__post.leaf  { background: var(--graia-leaf); }
.social__post.sky   { background: var(--graia-sky); }

/* Posts avec image réelle : l'image couvre la carte, overlay sombre en bas pour lisibilité du caption */
.social__post.has-img { color: var(--graia-cream); }
.social__post-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
.social__post.has-img::after {
  content: '';
  position: absolute; left: 0; right: 0; bottom: 0;
  height: 55%;
  background: linear-gradient(to top, rgba(25,43,44,0.85), rgba(25,43,44,0));
  z-index: 1;
  pointer-events: none;
}
.social__post.has-img .head,
.social__post.has-img .cap { position: relative; z-index: 2; }
.social__post.has-img .head .likes { color: var(--graia-cream); text-shadow: 0 1px 3px rgba(0,0,0,0.5); }
@media (max-width: 860px) {
  .social__grid { grid-template-columns: 1fr 1fr; }
}
/* [MOBILE 480px] social grid : 1 colonne sur très petit écran */
@media (max-width: 480px) {
  .social__grid { grid-template-columns: 1fr; }
}

/* ===========================================================
   Footer
   =========================================================== */
.footer {
  background: var(--graia-ink);
  color: var(--graia-cream);
  padding: 56px 32px 24px;
  border-top: 2px solid var(--graia-ink);
}
.footer__wrap { max-width: 1280px; margin: 0 auto; }
.footer__word {
  font-family: var(--font-display);
  font-size: clamp(80px, 12vw, 180px);
  line-height: 0.9;
  color: var(--graia-coral);
}
.footer__word .hash { color: var(--graia-cream); }
.footer__cols {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 32px;
  margin-top: 32px;
  padding-top: 24px;
  border-top: 2px solid var(--graia-cream-20);
}
.footer__pitch { font-family: var(--font-title); font-size: 14px; text-transform: uppercase; letter-spacing: 0.04em; line-height: 1.4; }
.footer__loc { font-size: 12px; opacity: 0.6; margin-top: 12px; }
.footer__col-title { font-family: var(--font-title); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 12px; color: var(--graia-peach); }
.footer__col a { display: block; font-size: 13px; margin-bottom: 6px; opacity: 0.85; text-decoration: none; color: inherit; }
.footer__col a:hover { color: var(--graia-coral); opacity: 1; }
.footer__copy { margin-top: 32px; font-size: 10px; opacity: 0.5; letter-spacing: 0.08em; text-transform: uppercase; }
@media (max-width: 860px) {
  .footer__cols { grid-template-columns: 1fr 1fr; }
}
/* [MOBILE 540px] footer : colonnes en stack, word plus petit */
@media (max-width: 540px) {
  .footer__cols { grid-template-columns: 1fr; gap: 24px; }
  .footer { padding: 40px 16px 20px; }
  .footer__word { font-size: clamp(56px, 18vw, 80px); }
}

/* ===========================================================
   Toasts (newsletter feedback)
   =========================================================== */
.toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  padding: 14px 24px;
  background: var(--graia-leaf);
  color: var(--graia-ink);
  border: 2px solid var(--graia-ink);
  border-radius: 999px;
  font-family: var(--font-body);
  font-weight: 800;
  font-size: 14px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  box-shadow: 5px 5px 0 0 var(--graia-ink);
  opacity: 0;
  transition: all 280ms var(--ease-snap);
  pointer-events: none;
  z-index: 80;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.err  { background: var(--graia-coral); }

/* ===========================================================
   Newsletter consent checkbox
   =========================================================== */
.newsletter__consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  line-height: 1.45;
  color: var(--graia-cream-65);
  cursor: pointer;
  margin-top: 2px;
}
.newsletter__consent input[type=checkbox] {
  width: 18px;
  height: 18px;
  margin-top: 1px;
  flex-shrink: 0;
  accent-color: var(--graia-coral);
  cursor: pointer;
}
.newsletter__consent a {
  color: var(--graia-peach);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.newsletter__consent a:hover { color: var(--graia-cream); }

/* ===========================================================
   Pages légales (.legal-page)
   =========================================================== */
.legal-page {
  background: var(--graia-ink);
  color: var(--graia-cream);
  min-height: calc(100vh - 64px);
  padding: 56px 24px 96px;
}
.legal-page__wrap {
  max-width: 720px;
  margin: 0 auto;
  font-family: var(--font-body);
  line-height: 1.65;
}
.legal-page__title {
  font-family: var(--font-title);
  font-size: clamp(36px, 5vw, 56px);
  text-transform: uppercase;
  line-height: 1;
  margin: 0 0 20px;
  color: var(--graia-cream);
}
.legal-page__intro {
  font-size: 15px;
  color: var(--graia-cream-65);
  margin: 0 0 40px;
  padding-bottom: 32px;
  border-bottom: 2px solid var(--graia-cream-20);
}
.legal-section {
  margin-bottom: 36px;
  padding-bottom: 36px;
  border-bottom: 1px solid var(--graia-cream-20);
}
.legal-section:last-of-type {
  border-bottom: none;
}
.legal-section h2 {
  font-family: var(--font-title);
  font-size: 18px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--graia-coral);
  margin: 0 0 14px;
}
.legal-section p {
  font-size: 14px;
  line-height: 1.65;
  color: var(--graia-cream-65);
  margin: 0 0 12px;
}
.legal-section p:last-child { margin-bottom: 0; }
.legal-section strong { color: var(--graia-cream); }
.legal-section ul {
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
  display: grid;
  gap: 8px;
}
.legal-section ul li {
  font-size: 14px;
  line-height: 1.55;
  color: var(--graia-cream-65);
  padding-left: 18px;
  position: relative;
}
.legal-section ul li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--graia-coral);
  font-weight: 800;
}
.legal-section a {
  color: var(--graia-peach);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.legal-section a:hover { color: var(--graia-cream); }
.legal-placeholder-note {
  font-size: 12px !important;
  font-style: italic;
  color: var(--graia-peach) !important;
  opacity: 0.8;
  margin-top: 8px !important;
}
.legal-page__update {
  font-size: 12px;
  color: var(--graia-cream-65);
  opacity: 0.6;
  margin-top: 48px;
  font-style: italic;
}
.legal-page__update a {
  color: var(--graia-cream-65);
  text-decoration: underline;
  text-underline-offset: 2px;
}
@media (max-width: 600px) {
  .legal-page { padding: 40px 20px 72px; }
}

/* Listes ordonnées (utilisé pour le calendrier de recrutement) */
.legal-section ol {
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
  counter-reset: legal-counter;
  display: grid;
  gap: 10px;
}
.legal-section ol li {
  font-size: 14px;
  line-height: 1.55;
  color: var(--graia-cream-65);
  padding-left: 32px;
  position: relative;
  counter-increment: legal-counter;
}
.legal-section ol li::before {
  content: counter(legal-counter);
  position: absolute;
  left: 0;
  top: 1px;
  width: 22px; height: 22px;
  border-radius: 999px;
  border: 1.5px solid var(--graia-coral);
  display: grid; place-items: center;
  font-size: 11px; font-weight: 800;
  color: var(--graia-coral);
  font-family: var(--font-body);
}

/* Recrutement-specific : eyebrow + bouton CTA mailto au milieu de section */
.recrutement-page .legal-section em { color: var(--graia-cream); font-style: italic; opacity: 0.85; }
.recrutement-page .legal-section .btn { color: var(--graia-ink); text-decoration: none; }

/* CTA inline dans un step de roadmap (ex: 'Voir le poste →' → /recrutement.php) */
.road__step-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  padding: 6px 12px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--graia-ink);
  background: var(--graia-cream);
  border: 2px solid var(--graia-ink);
  border-radius: 999px;
  text-decoration: none;
  box-shadow: 3px 3px 0 0 var(--graia-ink);
  transition: transform 120ms var(--ease-snap), box-shadow 120ms var(--ease-snap);
}
.road__step-cta:hover { transform: translate(-1px, -1px); box-shadow: 4px 4px 0 0 var(--graia-ink); }
.road__step-cta:active { transform: translate(2px, 2px); box-shadow: 0 0 0 0 var(--graia-ink); }
.road__step-cta:focus-visible { outline: 3px solid var(--graia-sky); outline-offset: 3px; }
/* Sur fond ink (step "next"), on contraste avec leaf */
.road .step:not(.now):not(.done) .road__step-cta {
  background: var(--graia-leaf);
  border-color: var(--graia-ink);
  box-shadow: 3px 3px 0 0 var(--graia-ink);
}

/* ===========================================================
   Utility
   =========================================================== */
.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;
}
