@charset "UTF-8";
/* === SELF-HOSTED FONTS - Pill System v3.0 ===
   Téléchargées depuis Google Fonts, servies en /assets/fonts/.
   Conforme à la CSP (font-src 'self') et servi localement. */
/* Size-adjusted fallback fonts (aligned with eryon-vitrine).
   Hold the layout during woff2 swap so we don't see a CLS jump
   when "Inter", "Inter Tight" or "JetBrains Mono" finally land. */
@font-face {
  font-family: "Inter Fallback";
  src: local("Arial"), local("Helvetica"), local("Liberation Sans");
  size-adjust: 107.4%;
  ascent-override: 90.2%;
  descent-override: 22.48%;
  line-gap-override: 0%;
}
@font-face {
  font-family: "Inter Tight Fallback";
  src: local("Arial"), local("Helvetica"), local("Liberation Sans");
  size-adjust: 102%;
  ascent-override: 90%;
  descent-override: 22%;
  line-gap-override: 0%;
}
@font-face {
  font-family: "JetBrains Mono Fallback";
  src: local("Menlo"), local("Consolas"), local("Courier New"), local("Liberation Mono");
  size-adjust: 96%;
  ascent-override: 75%;
  descent-override: 25%;
  line-gap-override: 0%;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/fonts/inter/400-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/fonts/inter/400-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/inter/500-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/inter/500-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/inter/600-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/inter/600-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/fonts/inter/700-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/fonts/inter/700-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Inter Tight";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/inter-tight/500-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Inter Tight";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/inter-tight/500-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Inter Tight";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/inter-tight/600-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Inter Tight";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/inter-tight/600-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Inter Tight";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/fonts/inter-tight/700-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Inter Tight";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/fonts/inter-tight/700-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Inter Tight";
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("/assets/fonts/inter-tight/800-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "Inter Tight";
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("/assets/fonts/inter-tight/800-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "JetBrains Mono";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/fonts/jetbrains-mono/400-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "JetBrains Mono";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/fonts/jetbrains-mono/400-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "JetBrains Mono";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/jetbrains-mono/500-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "JetBrains Mono";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/jetbrains-mono/500-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "JetBrains Mono";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/jetbrains-mono/600-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: "JetBrains Mono";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/jetbrains-mono/600-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
:root {
  /* === PILL SYSTEM v3.0 - tokens canoniques (cf. design.md §15) === */
  /* Canvas */
  --pill-bg: #F5EFE6;
  --pill-bg-warm: #EFE7DA;
  --pill-bg-soft: #FAF6EF;
  --pill-bg-tech: #EAEEF4;
  --pill-bg-blue: #D2E3FF;
  --pill-bg-teal: #CAFFFA;
  --pill-bg-card: #FFFFFF;
  --pill-bg-card-2: #FBF8F3;
  /* Text */
  --pill-ink: #000B70;
  --pill-ink-soft: #1A2470;
  --pill-muted: #575756;
  --pill-subtle: #9C9DAA;
  /* Lines */
  --pill-line: rgba(0, 11, 112, 0.14);
  --pill-line-2: rgba(0, 11, 112, 0.07);
  /* Accents */
  --pill-blue: #0D17E6;
  --pill-blue-deep: #000B70;
  --pill-blue-soft: #D2E3FF;
  --pill-blue-tint: #EAEEF4;
  --pill-teal: #00C3AF;
  --pill-teal-deep: #007A6F;
  --pill-teal-soft: #CAFFFA;
  --pill-cyan: #00D0EF;
  --pill-cyan-soft: #CCEFF5;
  --pill-coral: #0D17E6;
  --pill-coral-soft:#D2E3FF;
  --pill-yellow: #00D0EF;
  --pill-warning-text: #9A3412;
  /* Type */
  --font-display: "Inter Tight", "Inter Tight Fallback", "Inter", "Inter Fallback", system-ui, sans-serif;
  --font-sans: "Inter", "Inter Fallback", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", "JetBrains Mono Fallback", ui-monospace, Menlo, monospace;
  /* Spacing (rythme 4px) */
  --sp-1: 4px;
  --sp-2: 8px;
  --sp-3: 12px;
  --sp-4: 16px;
  --sp-5: 20px;
  --sp-6: 24px;
  --sp-8: 32px;
  --sp-10: 40px;
  --sp-12: 48px;
  --sp-16: 64px;
  --sp-20: 80px;
  --sp-24: 96px;
  --sp-32: 128px;
  /* Radii canoniques */
  --r-sm: 8px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-xl: 32px;
  --r-pill: 999px;
  /* Shadows */
  --sh-sm: 0 2px 0 rgba(0,11,112,0.18);
  --sh-md: 0 18px 48px -16px rgba(0,11,112,0.20);
  --sh-lg: 0 24px 60px -20px rgba(0,11,112,0.24);
  /* === ALIAS RETROCOMPAT - anciens noms re-routés vers Pill System ===
     À conserver tant que les sélecteurs (.action-button, .panel, .display, etc.)
     n'ont pas été migrés en Phase 3+. Ne PAS supprimer aveuglément. */
  --ivory: var(--pill-bg-card); /* blanc carte (PAS le canvas) */
  --ivory-2: var(--pill-bg-soft);
  --paper: rgba(255, 255, 255, 0.88);
  --paper-strong: rgba(255, 255, 255, 0.96);
  --charcoal: var(--pill-ink); /* texte courant -> encre */
  --charcoal-2: var(--pill-muted);
  --charcoal-3: #5F6170;
  --charcoal-4: #b5b5b3; /* gris très clair, pas d'équivalent strict */
  --line: var(--pill-line);
  --line-strong: var(--pill-line);
  --copper: var(--pill-teal); /* turquoise primaire */
  --copper-deep: var(--pill-teal-deep);
  --sage: #5dccc3; /* inchangé : pas d'équivalent strict */
  --ink: var(--pill-blue); /* ATTENTION: c'est l'ACCENT, pas l'encre texte */
  --danger: #c53030;
  --ok: #2f855a;
  --shadow-soft: var(--sh-md);
  --radius-xl: 32px;
  --radius-lg: 20px; /* hors palette - nettoyé en Phase 3 */
  --radius-md: 14px; /* hors palette - nettoyé en Phase 3 */
  --content-width: 1320px;
  --serif: var(--font-display); /* transitionnel : Fraunces -> Inter Tight */
  --sans: var(--font-sans);
  --mono: var(--font-mono);
  /* Anciens gradients redéfinis en couleur PLATE (anti-fallback). */
  --eryon-gradient-hero: var(--pill-blue);
  --eryon-gradient-soft: var(--pill-teal);
  /* Alias des nouvelles pages - re-routés vers Pill System */
  --eryon-turquoise: var(--pill-teal);
  --eryon-turquoise-light: var(--pill-teal-soft);
  --eryon-turquoise-dark: var(--pill-teal-deep);
  --eryon-blue-bright: var(--pill-cyan);
  --eryon-blue-deep: var(--pill-blue); /* accent, pas encre */
  --eryon-anthracite: var(--pill-muted);
}

* {
  box-sizing: border-box;
}

/* L'attribut HTML [hidden] doit toujours l'emporter sur un display: explicite
   (sinon les éléments masqués par défaut puis révélés en JS - succès de formulaire,
   messages d'erreur - restent visibles). */
[hidden] {
  display: none !important;
}

html {
  min-height: 100%;
  background: var(--pill-bg);
}

body {
  min-height: 100vh;
  margin: 0;
  color: var(--pill-ink);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  background: var(--pill-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  border: 0;
  padding: 0;
  background: none;
  color: inherit;
}

a {
  color: inherit;
  text-decoration: none;
}

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

::selection {
  background: var(--charcoal);
  color: var(--ivory);
}

.app-shell {
  min-height: 100vh;
  position: relative;
}

.app-shell.is-private {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  min-height: 100vh;
}

.app-shell.is-private .app-main {
  min-width: 0;
  overflow-x: hidden;
  background: #fff;
}

/* Impersonation banner (native switch_user): shown at the top of the private
   area while a super-admin is impersonating another user. */
.impersonation-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  padding: 10px 20px;
  background: #b87333;
  color: #fff;
  font-size: 13px;
  font-weight: 600;
}

.impersonation-banner .text-link {
  color: #fff;
  text-decoration: underline;
  white-space: nowrap;
}

/* Progress bar for a running review. Two modes:
   - default: an indeterminate sliding bar (shown before we know the percentage);
   - .is-determinate: a real bar whose width = percent of finished steps. */
.review-progress {
  margin-top: 16px;
}

.review-progress__bar {
  height: 6px;
  border-radius: 999px;
  background: rgba(184, 115, 51, 0.15);
  overflow: hidden;
  position: relative;
}

.review-progress__fill {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 40%;
  border-radius: 999px;
  background: #b87333;
  animation: review-progress-slide 1.4s ease-in-out infinite;
}

/* Real progress: the JS sets the width, so we stop the sliding animation. The fill is a
   <span> (inline), so it must become a block once positioned statically — otherwise width
   and height are ignored and the bar renders empty. */
.review-progress__bar.is-determinate .review-progress__fill {
  position: static;
  display: block;
  animation: none;
  width: 0;
  transition: width 0.6s ease;
}

@keyframes review-progress-slide {
  0% {
    left: -40%;
  }
  100% {
    left: 100%;
  }
}
.review-progress__eta {
  margin-top: 8px;
  font-size: 13px;
  color: #555;
}

.review-steps {
  margin-top: 12px;
  font-size: 13px;
}

.review-steps__toggle {
  cursor: pointer;
  color: var(--copper-deep);
  font-weight: 600;
  list-style: none;
}

.review-steps__toggle::-webkit-details-marker {
  display: none;
}

.review-steps__list {
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.review-steps__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 7px 0;
  border-bottom: 1px solid rgba(184, 115, 51, 0.12);
}

.review-steps__item:last-child {
  border-bottom: 0;
}

.review-steps__label {
  color: var(--ink);
}

@media (prefers-reduced-motion: reduce) {
  .review-progress__fill {
    animation: none;
    width: 100%;
    opacity: 0.5;
  }
}
.app-shell.is-private .page {
  width: min(100% - 48px, 1280px);
  padding: 36px 0 64px;
}

/* Private pages: downscaled typography for a calmer density */
.app-shell.is-private .section-title {
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.12;
}

.app-shell.is-private h1.section-title {
  font-size: clamp(24px, 2.4vw, 32px);
}

.app-shell.is-private .detail-section .section-title,
.app-shell.is-private .panel .section-title,
.app-shell.is-private .reviewers-panel .section-title,
.app-shell.is-private .documents-panel .section-title,
.app-shell.is-private .timeline-panel .section-title,
.app-shell.is-private .deliverables-panel .section-title {
  font-size: clamp(18px, 1.6vw, 22px);
}

.app-shell.is-private .kpi-value {
  font-size: clamp(26px, 2.6vw, 34px);
}

.app-shell.is-private .summary-block .stat-value {
  font-size: clamp(22px, 2.2vw, 28px);
}

.app-shell.is-private .section-copy,
.app-shell.is-private .muted {
  font-size: 13px;
}

.app-shell.is-private .eyebrow {
  font-size: 10px;
}

.app-shell.is-private .reviewers-total-value {
  font-size: clamp(22px, 2.4vw, 30px);
}

.app-shell.is-private .credits-amount {
  font-size: clamp(34px, 4vw, 54px);
}

.app-shell.is-private .kpi-row {
  margin-top: 24px;
}

.app-shell.is-private .dashboard-toolbar {
  margin-top: 24px;
}

.app-shell.is-private .panel,
.app-shell.is-private .detail-section,
.app-shell.is-private .reviewers-panel,
.app-shell.is-private .documents-panel,
.app-shell.is-private .timeline-panel,
.app-shell.is-private .deliverables-panel,
.app-shell.is-private .credits-panel,
.app-shell.is-private .pricing-panel {
  margin-top: 24px;
}

.app-shell.is-private .panel + .panel,
.app-shell.is-private .panel + .reviewers-panel,
.app-shell.is-private .panel + .documents-panel,
.app-shell.is-private .reviewers-panel + .documents-panel,
.app-shell.is-private .documents-panel + .timeline-panel,
.app-shell.is-private .timeline-panel + .deliverables-panel {
  margin-top: 22px;
}

/* Project detail: compact layout */
.project-detail .home-section {
  margin-top: 28px;
}

.project-detail .section-head {
  margin-bottom: 12px;
}

.project-detail .panel {
  padding: 22px;
}

.meta-grid {
  grid-template-columns: 1fr 1fr;
  gap: 10px 48px;
}

.meta-grid .meta-row {
  padding-top: 8px;
  font-size: 13px;
}

.meta-grid .meta-row:nth-child(-n+2) {
  border-top: 0;
  padding-top: 0;
}

.project-detail .review-action {
  background: var(--pill-bg-soft);
  border-color: var(--pill-line);
}

@media (max-width: 600px) {
  .meta-grid {
    grid-template-columns: 1fr;
  }
  .meta-grid .meta-row:nth-child(2) {
    border-top: 1px solid var(--line);
    padding-top: 8px;
  }
}
.page {
  width: min(100% - 48px, var(--content-width));
  margin: 0 auto;
  padding: 32px 0 64px;
  position: relative;
  z-index: 1;
  animation: page-in 420ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.topbar {
  width: min(100% - 48px, var(--content-width));
  margin: 0 auto;
  height: 64px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  position: relative;
  z-index: 5;
}

.topbar .brand {
  flex: 0 0 auto;
}

.pill-wm {
  display: inline-flex;
  align-items: center;
  gap: 0.18em;
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1;
  color: var(--pill-ink);
}

.pill-wm .pw-pill {
  display: inline-block;
  padding: 0.06em 0.36em 0.14em;
  border-radius: var(--r-pill);
  background: var(--pill-blue);
  color: #fff;
  line-height: 1;
}

/* ── VITRINE NAVBAR — copié de eryon-vitrine/assets/styles/redesign/layout.css ── */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: rgba(245, 239, 230, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--pill-line-2);
  transition: background 0.3s ease;
}

.nav-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--sp-8);
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-shrink: 0;
}

.nav-logo img {
  height: 28px;
  width: 100px;
}

.nav-pill-one {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.03em;
  background: var(--pill-blue);
  color: #fff;
  padding: 0.06em 0.36em 0.14em;
  border-radius: var(--r-pill);
  line-height: 1;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
}

.nav-link {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--pill-ink);
  padding: 8px 14px;
  border-radius: var(--r-pill);
  transition: background 0.2s ease, color 0.2s ease;
  text-decoration: none;
}

.nav-link:hover {
  background: rgba(0, 11, 112, 0.06);
}

.nav-link.active {
  background: var(--pill-ink);
  color: var(--pill-bg);
}

.nav-dropdown {
  position: relative;
}

.nav-dropdown-trigger {
  display: flex;
  align-items: center;
  gap: 4px;
}

.nav-dropdown-trigger::after {
  content: "";
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4px solid currentColor;
  opacity: 0.5;
  transition: transform 0.2s ease;
}

@media (hover: hover) and (pointer: fine) and (min-width: 901px) {
  .nav-dropdown:hover .nav-dropdown-trigger::after {
    transform: rotate(180deg);
  }
}
.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  min-width: 240px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
  padding: var(--sp-3);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

@media (hover: hover) and (pointer: fine) and (min-width: 901px) {
  .nav-dropdown-menu {
    opacity: 0;
    visibility: hidden;
    transform: translateX(-50%) translateY(-8px);
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
  }
  .nav-dropdown:hover .nav-dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
  }
}
.nav-dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  min-height: 44px;
  padding: 12px 16px;
  margin: 2px 0;
  border-radius: var(--r-md);
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--pill-ink);
  transition: background 0.15s ease;
  line-height: 1.3;
  text-decoration: none;
}

.nav-dropdown-item:hover {
  background: var(--pill-bg-soft);
}

.nav-cta {
  margin-left: var(--sp-3);
}

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
}

.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--pill-ink);
  border-radius: 2px;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

/* Boutons §7 — variantes Pill System (btn-primary, btn-ghost, btn-sm) */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 22px;
  border-radius: var(--r-pill);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: -0.005em;
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.btn-sm {
  padding: 8px 16px;
  font-size: 13px;
}

.btn-primary {
  background: var(--pill-ink);
  color: var(--pill-bg);
  border-color: var(--pill-ink);
}

.btn-primary:hover {
  transform: translateY(-1px);
  background: var(--pill-blue);
  border-color: var(--pill-blue);
}

.btn-ghost {
  background: transparent;
  color: var(--pill-ink);
  border: 1px solid var(--pill-ink);
}

.btn-ghost:hover {
  background: var(--pill-ink);
  color: var(--pill-bg);
}

@media (max-width: 900px) {
  .nav-toggle {
    display: flex;
  }
  .nav-links {
    display: none;
    position: absolute;
    top: 64px;
    left: 0;
    right: 0;
    z-index: 99;
    background: var(--pill-bg-card);
    border-bottom: 1px solid var(--pill-line);
    flex-direction: column;
    padding: var(--sp-5) var(--sp-8);
    gap: var(--sp-1);
    align-items: stretch;
  }
  .nav-links.open {
    display: flex;
  }
  .nav-link {
    padding: 12px 16px;
  }
  .nav-cta {
    margin-left: 0;
    margin-top: var(--sp-3);
  }
}
/* ── FIN NAVBAR VITRINE ── */
/* ── LAYOUT VITRINE — copié de eryon-vitrine/assets/styles/redesign/layout.css ── */
.section {
  padding: var(--sp-20) 0;
}

.section-warm {
  background: var(--pill-bg-warm);
}

.wrap-narrow {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 var(--sp-8);
}

/* ── FAQ — copié de eryon-vitrine/assets/styles/redesign/components.css ── */
.faq-item {
  border-bottom: 1px solid var(--pill-line);
  padding: var(--sp-6) 0;
}

.faq-item summary {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 17px;
  letter-spacing: -0.015em;
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}

.faq-item summary::before {
  content: "+";
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--pill-bg-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 400;
  color: var(--pill-blue);
  transition: transform 0.25s ease, background 0.25s ease;
}

.faq-item[open] summary::before {
  content: "−";
  background: var(--pill-blue);
  color: #fff;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item summary:hover {
  color: var(--pill-blue);
}

.faq-item .faq-body {
  padding: var(--sp-4) 0 0 44px;
  font-size: 15px;
  line-height: 1.6;
  color: var(--pill-ink-soft);
}

/* ── FIN FAQ ── */
.action-button:focus-visible,
.ghost-button:focus-visible,
.text-link:focus-visible {
  outline: 3px solid var(--pill-blue);
  outline-offset: 3px;
}

.text-link:focus-visible {
  color: var(--pill-blue);
  border-color: var(--pill-blue);
}

@media (max-width: 640px) {
  .topbar-actions .action-button,
  .topbar-actions .ghost-button {
    flex: 1 1 150px;
  }
}
.nav-link:focus-visible,
.action-button:focus-visible,
.ghost-button:focus-visible,
.text-link:focus-visible {
  text-decoration: none;
}

.nav-link:focus:not(:focus-visible),
.action-button:focus:not(:focus-visible),
.ghost-button:focus:not(:focus-visible),
.text-link:focus:not(:focus-visible) {
  outline: none;
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}

.footer {
  margin-top: 80px;
  padding: 64px 0 32px;
  background: var(--pill-ink);
  color: var(--pill-bg);
}

.footer strong,
.footer .footer-title {
  color: rgba(245, 239, 230, 0.85);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: 20px;
}

.footer .footer-link,
.footer .footer-text,
.footer p.muted {
  color: rgba(245, 239, 230, 0.9);
}

.footer .footer-link:hover,
.footer .footer-link:focus-visible {
  color: var(--pill-bg);
}

.footer .pill-wm {
  color: var(--pill-bg);
}

.footer .pill-wm .pw-pill {
  background: var(--pill-blue);
  color: #fff;
}

.footer .brand-logo {
  filter: brightness(0) invert(1);
}

.footer-bottom {
  border-top: 1px solid rgba(245, 239, 230, 0.12);
  color: rgba(245, 239, 230, 0.85);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.footer > .footer-grid {
  width: min(100% - 48px, var(--content-width));
  margin: 0 auto;
}

.footer .pill-wm {
  font-size: 22px;
  margin-bottom: 14px;
}

.footer strong {
  display: block;
  margin-bottom: 12px;
  font-family: var(--font-display);
  color: var(--pill-ink);
}

@media (max-width: 980px) {
  .topbar {
    align-items: flex-start;
    flex-direction: column;
  }
  .nav-links {
    justify-content: flex-start;
  }
}
@media (max-width: 640px) {
  .page {
    width: min(100% - 32px, var(--content-width));
    padding: 24px 0 48px;
  }
  .topbar,
  .footer > .footer-grid {
    width: min(100% - 32px, var(--content-width));
  }
  .topbar {
    gap: 12px;
    padding: 16px 0 10px;
  }
  .nav-links {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: nowrap;
    gap: 8px;
    overflow-x: auto;
    padding: 2px 0 8px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .nav-links::-webkit-scrollbar {
    display: none;
  }
  .nav-link {
    flex: 0 0 auto;
    min-height: 40px;
    background: rgba(255, 255, 255, 0.52);
    border: 1px solid var(--pill-line);
  }
  .topbar-actions {
    width: 100%;
    flex-wrap: wrap;
  }
  .topbar-actions .language-switcher {
    width: 100%;
    justify-content: space-between;
  }
  .topbar-actions .action-button,
  .topbar-actions .ghost-button {
    min-height: 44px;
  }
  .footer {
    margin-top: 64px;
    padding: 40px 0 32px;
  }
  .footer > .footer-grid {
    gap: 24px;
  }
}
/* Sidebar - private layout (DA alignée avec eryon-vitrine : canvas crème,
   border line ink, tokens pill partout). */
.sidebar {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  align-self: start;
  height: 100vh;
  display: -ms-grid;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 20px;
  padding: 28px 20px;
  border-right: 1px solid var(--pill-line);
  background: var(--pill-bg);
  box-shadow: 1px 0 6px rgba(0, 11, 112, 0.04);
  z-index: 2;
  /* overflow visible : laisse le popover de déconnexion sortir à droite.
     Le scroll des menus longs est porté par .sidebar-nav. */
  overflow: visible;
}

.sidebar-brand {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 4px 6px;
}

.sidebar-brand .brand-button {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.sidebar-brand .brand-mark {
  width: 40px;
  height: 40px;
  cursor: pointer;
}

.sidebar-brand .brand-logo {
  height: 22px;
  width: auto;
  flex-shrink: 0;
}

.sidebar-brand .brand-logo--mark {
  display: none;
}

.sidebar-brand .nav-pill-one {
  font-size: 16px;
}

.sidebar-brand .brand-name {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--pill-ink);
  line-height: 1;
}

.sidebar-brand .brand-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pill-muted);
  margin-top: 4px;
}

.sidebar-nav {
  display: grid;
  gap: 4px;
  align-content: start;
  margin-top: 8px;
  min-height: 0;
  overflow-y: auto;
}

.sidebar-link {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 14px;
  border-radius: var(--r-pill);
  border: 0;
  background: transparent;
  color: var(--pill-ink-soft);
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.01em;
  cursor: pointer;
  text-align: left;
  transition: background 180ms, color 180ms;
}

.sidebar-link:hover {
  background: rgba(0, 11, 112, 0.07);
  color: var(--pill-ink);
}

.sidebar-link.is-active {
  background: var(--pill-ink);
  color: var(--pill-bg);
}

.sidebar-icon {
  width: 22px;
  display: inline-grid;
  place-items: center;
  font-size: 16px;
  color: var(--pill-teal);
}

.sidebar-link.is-active .sidebar-icon {
  color: var(--pill-teal);
}

.sidebar-badge {
  margin-left: auto;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  flex-shrink: 0;
  background: var(--danger);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
}

.sidebar-link.is-active .sidebar-badge {
  background: var(--paper-strong);
  color: var(--pill-ink);
}

/* removed: sidebar-sub (projects menu items are now top-level) */
.sidebar-footer {
  display: grid;
  gap: 12px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

a.sidebar-credits-slim,
.sidebar-credits-slim {
  display: block;
  font-size: 12px;
  color: var(--charcoal-3);
  padding: 4px 8px;
  letter-spacing: 0.04em;
  text-align: center;
  text-decoration: none;
  border-radius: 10px;
  transition: background 150ms ease;
}

a.sidebar-credits-slim:hover {
  background: rgba(28, 26, 23, 0.06);
  color: var(--ink);
}

.sidebar-credits-slim span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.sidebar-credits-slim span::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--copper);
}

.sidebar-lang {
  position: relative;
}

.sidebar-lang-current {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px;
  border-radius: 10px;
  font-size: 13px;
  color: var(--ink);
  cursor: pointer;
  transition: background 150ms ease;
}

.sidebar-lang-current:hover {
  background: rgba(28, 26, 23, 0.06);
}

.sidebar-lang-menu {
  display: none;
  position: absolute;
  left: 100%;
  bottom: 0;
  z-index: 30;
  min-width: 180px;
  padding: 4px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: var(--shadow-soft, 0 12px 30px rgba(27, 24, 21, 0.16));
}

.sidebar-lang:hover .sidebar-lang-menu,
.sidebar-lang:focus-within .sidebar-lang-menu {
  display: block;
}

.sidebar-lang-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 14px;
  border-radius: 8px;
  font-size: 13px;
  color: var(--charcoal-3);
  text-decoration: none;
  white-space: nowrap;
  transition: background 150ms ease;
}

.sidebar-lang-link:hover {
  background: rgba(28, 26, 23, 0.06);
  color: var(--ink);
}

.app-shell.is-private.is-collapsed .sidebar-lang-current span:last-child {
  display: none;
}

.app-shell.is-private.is-collapsed .sidebar-lang-current {
  justify-content: center;
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 8px;
  border: 0;
  background: transparent;
  color: inherit;
  border-radius: 10px;
  cursor: pointer;
  font: inherit;
  text-align: left;
  transition: background 150ms ease;
}

.sidebar-user:hover,
.sidebar-user.is-active {
  background: rgba(28, 26, 23, 0.06);
}

.sidebar-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--charcoal);
  color: var(--ivory);
  display: grid;
  place-items: center;
  font-family: var(--serif);
  font-size: 14px;
  letter-spacing: 0.02em;
}

.sidebar-user-meta {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.sidebar-user-name {
  font-size: 13px;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-user-mail {
  font-size: 11px;
  color: var(--charcoal-3);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-logout {
  min-height: 38px;
  font-size: 12px;
}

/* Progress chip on project rows */
.progress-chip {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(184, 115, 51, 0.12);
  color: var(--copper-deep);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.04em;
}

.dashboard-toolbar {
  display: flex;
  align-items: center;
  gap: 14px;
}

.dashboard-search {
  position: relative;
  flex: 1 1 360px;
  min-width: 220px;
}

.dashboard-search .field-input {
  width: 100%;
  min-height: 46px;
  padding-left: 42px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
}

.dashboard-search-icon {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--charcoal-3);
  font-size: 18px;
  pointer-events: none;
}

.dashboard-toolbar-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  color: var(--charcoal-3);
  font-size: 12px;
}

.dashboard-toolbar-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(0, 194, 175, 0.08);
  color: var(--charcoal-2);
  white-space: nowrap;
}

.new-project-panel {
  margin-top: 22px;
  margin-bottom: 30px;
  border-color: rgba(0, 194, 175, 0.24);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(0, 194, 175, 0.06));
}

.target-country-panel {
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: rgba(255, 255, 255, 0.74);
}

.target-country-intro {
  margin: 0;
  color: var(--charcoal-3);
  font-size: 13px;
  line-height: 1.35;
}

.target-country-picker {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(148px, 1fr));
  gap: 8px;
}

.target-country-option {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  min-height: 40px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid var(--line-strong);
  background: rgba(255, 255, 255, 0.92);
  color: var(--charcoal-2);
  font-size: 13px;
  line-height: 1.2;
  cursor: pointer;
  transition: border-color 160ms ease, background 160ms ease, color 160ms ease, box-shadow 160ms ease;
}

.target-country-option input {
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--copper);
}

.target-country-option:has(input:checked) {
  border-color: rgba(0, 194, 175, 0.56);
  background: rgba(0, 194, 175, 0.12);
  color: var(--charcoal);
}

.target-country-option:focus-within {
  outline: 2px solid rgba(28, 26, 23, 0.18);
  outline-offset: 2px;
}

.target-country-flag {
  flex: 0 0 22px;
  width: 22px;
  line-height: 1;
  text-align: center;
  font-size: 18px;
}

.target-country-flag .fi {
  width: 22px;
  height: 16px;
  border-radius: 2px;
}

.target-country-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.target-country-other {
  min-height: 40px;
  padding: 10px 12px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
}

.project-row .progress-bar {
  margin-top: 6px;
}

.run-outcome-notice {
  margin-top: 24px;
  padding: 16px 18px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(0, 194, 175, 0.24);
  background: rgba(0, 194, 175, 0.08);
}

.run-outcome-notice[data-tone=danger] {
  border-color: rgba(197, 48, 48, 0.34);
  background: rgba(197, 48, 48, 0.08);
}

.run-outcome-notice h2 {
  margin: 0 0 6px;
  font-size: 17px;
  line-height: 1.25;
}

.run-outcome-notice p {
  margin: 0;
  color: var(--charcoal-2);
  font-size: 13px;
  line-height: 1.55;
}

.run-outcome-notice .eyebrow {
  color: var(--copper-deep);
  margin-bottom: 4px;
}

.run-outcome-notice[data-tone=danger] .eyebrow,
.run-outcome-notice[data-tone=danger] h2 {
  color: var(--danger);
}

.run-outcome-notice .run-outcome-reason {
  margin-top: 6px;
  font-weight: 700;
  color: var(--charcoal);
}

/* Reviewers selection module */
.reviewers-panel,
.documents-panel,
.timeline-panel,
.deliverables-panel {
  margin-top: 28px;
  padding: 28px;
  border-radius: var(--radius-xl);
  border: 1px solid var(--line);
  background: var(--paper);
  box-shadow: var(--shadow-soft);
}

.reviewers-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 20px;
  align-items: center;
  margin-bottom: 20px;
}

.reviewers-total {
  display: grid;
  gap: 6px;
  justify-items: end;
  padding: 14px 20px;
  border-radius: var(--radius-md);
  background: rgba(184, 115, 51, 0.08);
  border: 1px solid rgba(184, 115, 51, 0.25);
}

.reviewers-total-value {
  font-family: var(--serif);
  font-size: clamp(28px, 3vw, 38px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--copper-deep);
}

.reviewers-total-value small {
  font-family: var(--sans);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--charcoal-3);
}

.reviewers-bundle {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ok);
}

.reviewers-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px;
}

.reviewer-card {
  padding: 18px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.5);
  text-align: left;
  font: inherit;
  cursor: pointer;
  display: grid;
  gap: 8px;
  transition: border-color 150ms, background 150ms, transform 150ms;
}

.reviewer-card:hover {
  transform: translateY(-1px);
  border-color: var(--line-strong);
}

.reviewer-card.is-active {
  border-color: var(--charcoal);
  background: rgba(28, 26, 23, 0.04);
  box-shadow: 0 0 0 3px rgba(28, 26, 23, 0.04);
}

/* Coming-soon axis (scientific today) : not clickable, fade the content. */
.reviewer-card.is-disabled,
.reviewer-card[disabled] {
  opacity: 0.85;
  cursor: not-allowed;
  pointer-events: none;
  filter: grayscale(20%);
}

.reviewer-card.is-disabled:hover,
.reviewer-card[disabled]:hover {
  transform: none;
  border-color: var(--line);
}

.reviewer-top {
  display: flex;
  align-items: center;
  gap: 10px;
}

.reviewer-tick {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  display: inline-grid;
  place-items: center;
  font-size: 12px;
  color: var(--ivory);
  background: transparent;
}

.reviewer-card.is-active .reviewer-tick {
  background: var(--charcoal);
  border-color: var(--charcoal);
}

.reviewer-card strong {
  font-family: var(--serif);
  font-size: 17px;
  letter-spacing: -0.01em;
}

.reviewer-price {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-variant-numeric: tabular-nums;
  color: var(--charcoal-2);
  font-size: 14px;
}

.reviewer-free {
  color: var(--ok);
  font-size: 12px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.scientific-validation-sub {
  margin-top: 18px;
  padding: 16px;
  border: 1px dashed rgba(50, 120, 90, 0.35);
  border-radius: var(--radius-md);
  background: rgba(50, 120, 90, 0.05);
}

.scientific-validation-option {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  cursor: pointer;
}

.scientific-validation-option input {
  width: 18px;
  height: 18px;
  accent-color: var(--charcoal);
}

.scientific-validation-copy {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.scientific-validation-copy strong {
  font-family: var(--serif);
  font-size: 16px;
}

.scientific-validation-copy span {
  color: var(--charcoal-3);
  font-size: 13px;
}

.scientific-validation-price {
  white-space: nowrap;
  color: var(--ok);
  font-weight: 800;
  font-size: 13px;
}

.regulations-sub {
  margin-top: 18px;
  padding: 18px;
  border: 1px dashed rgba(184, 115, 51, 0.35);
  border-radius: var(--radius-md);
  background: rgba(184, 115, 51, 0.04);
  display: grid;
  gap: 14px;
}

.regulations-head {
  display: grid;
  gap: 4px;
}

.regulations-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 10px;
}

.regulations-compact-grid {
  display: grid;
  gap: 8px;
}

.regulations-more {
  display: grid;
  gap: 8px;
}

.regulations-more summary {
  width: fit-content;
  cursor: pointer;
  color: var(--copper-deep);
  font-size: 13px;
  font-weight: 700;
}

.regulation-chip {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.6);
  text-align: left;
  font: inherit;
  cursor: pointer;
  transition: border-color 150ms, background 150ms;
}

.regulation-chip:hover {
  border-color: var(--line-strong);
}

.regulation-chip.is-active {
  border-color: var(--charcoal);
  background: rgba(184, 115, 51, 0.1);
}

.regulation-chip.is-readonly {
  cursor: default;
}

.regulation-chip.is-readonly:hover {
  border-color: var(--charcoal);
}

.regulation-tick {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  display: inline-grid;
  place-items: center;
  font-size: 11px;
  flex: 0 0 auto;
}

.regulation-chip.is-active .regulation-tick {
  background: var(--charcoal);
  border-color: var(--charcoal);
  color: var(--ivory);
}

.regulation-body {
  display: grid;
  gap: 2px;
}

.regulation-desc {
  font-size: 12px;
  color: var(--charcoal-2);
  line-height: 1.45;
}

.section-subtitle {
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: -0.01em;
  margin: 0 0 10px 0;
}

/* Documents drop zones */
.documents-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

@media (max-width: 820px) {
  .documents-grid {
    grid-template-columns: 1fr;
  }
}
.dropzone-wrapper {
  display: grid;
  gap: 12px;
}

.dropzone {
  display: grid;
  gap: 10px;
}

.dropzone-label {
  position: relative;
  display: grid;
  grid-template-rows: auto auto;
  justify-items: center;
  gap: 8px;
  min-height: 160px;
  padding: 22px 18px;
  border: 2px dashed rgba(28, 26, 23, 0.22);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.42);
  cursor: pointer;
  text-align: center;
  transition: border-color 150ms, background 150ms;
}

.dropzone-label:hover,
.dropzone-label:focus-within {
  border-color: var(--charcoal);
  background: rgba(255, 255, 255, 0.7);
}

.dropzone-label.is-dragover {
  border-color: var(--eryon-turquoise);
  background: var(--eryon-turquoise-light);
}

.dropzone-label input[type=file] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.dropzone-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: var(--eryon-turquoise-light);
  color: var(--eryon-turquoise-dark);
  font-size: 22px;
}

.dropzone-copy {
  display: grid;
  gap: 4px;
}

.dropzone-copy strong {
  font-family: var(--serif);
  font-size: 17px;
  letter-spacing: -0.02em;
}

.dropzone-copy .muted {
  font-size: 12px;
}

.dropzone-cta {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--charcoal-3);
  margin-top: 4px;
}

/* Fixed-height file list that never reflows the page */
.files-box {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 8px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.55);
  height: 180px;
  overflow: hidden;
}

.files-box-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12px;
}

.files-box-list {
  overflow-y: auto;
  display: grid;
  gap: 6px;
  padding-right: 4px;
  /* Make the scrollbar visible even on macOS/iOS so the user knows there is more content */
  scrollbar-gutter: stable;
  scrollbar-width: thin;
  scrollbar-color: rgba(28, 26, 23, 0.35) transparent;
}

.files-box-list::-webkit-scrollbar {
  width: 8px;
  -webkit-appearance: none;
}

.files-box-list::-webkit-scrollbar-track {
  background: rgba(28, 26, 23, 0.04);
  border-radius: 4px;
}

.files-box-list::-webkit-scrollbar-thumb {
  background: rgba(28, 26, 23, 0.28);
  border-radius: 4px;
}

.files-box-list::-webkit-scrollbar-thumb:hover {
  background: rgba(28, 26, 23, 0.5);
}

/* Bottom fade hint so the user sees there's more to scroll */
.files-box {
  position: relative;
}

.files-box::after {
  content: "";
  position: absolute;
  left: 12px;
  right: 16px;
  bottom: 12px;
  height: 24px;
  background: linear-gradient(to top, rgba(255, 255, 255, 0.85), rgba(255, 255, 255, 0));
  pointer-events: none;
  opacity: 0;
  transition: opacity 150ms ease;
}

.files-box.is-scrollable::after {
  opacity: 1;
}

.files-box-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid var(--line);
}

.files-box-info {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.files-box-info strong {
  font-size: 13px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--ink);
}

.files-box-info .muted {
  font-size: 11px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.files-box-actions {
  display: flex;
  gap: 4px;
}

.icon-button {
  width: 30px;
  height: 30px;
  display: inline-grid;
  place-items: center;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.6);
  border-radius: 8px;
  font-size: 14px;
  color: var(--charcoal-2);
  cursor: pointer;
  transition: background 120ms, border-color 120ms, color 120ms;
}

.icon-button:hover {
  background: rgba(28, 26, 23, 0.06);
  border-color: var(--line-strong);
  color: var(--charcoal);
}

.icon-button.is-danger:hover {
  color: var(--danger);
  border-color: rgba(139, 59, 50, 0.35);
  background: rgba(139, 59, 50, 0.06);
}

.files-box-empty {
  margin: 0;
  padding: 16px 8px;
  color: var(--charcoal-3);
  font-size: 12px;
  text-align: center;
}

/* Agents timeline */
.timeline-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.run-poll-hint {
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--copper-deep);
}

.run-progress {
  margin: 14px 0 18px;
  display: grid;
  gap: 8px;
}

.run-progress-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  font-size: 13px;
}

.run-progress-current {
  font-weight: 500;
  color: var(--charcoal);
}

.run-progress-count {
  font-variant-numeric: tabular-nums;
  font-size: 12px;
}

.run-progress-track {
  height: 8px;
  border-radius: 999px;
  background: rgba(28, 26, 23, 0.08);
  overflow: hidden;
  position: relative;
}

.run-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--copper-deep), #d39567);
  border-radius: inherit;
  transition: width 400ms ease;
}

.run-progress-fill.is-active::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.35) 50%, transparent 100%);
  animation: run-progress-shimmer 1.6s linear infinite;
}

.run-progress-fill.is-done {
  background: var(--ok);
}

@keyframes run-progress-shimmer {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(100%);
  }
}
.inline-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--charcoal-2);
  cursor: pointer;
}

.inline-check input[type=checkbox] {
  width: 18px;
  height: 18px;
  accent-color: var(--charcoal);
}

.timeline-feed {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;
  max-height: 360px;
  overflow-y: auto;
}

.timeline-event {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.45);
  border: 1px solid var(--line);
}

.timeline-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-top: 6px;
  background: var(--charcoal-4);
}

.timeline-event[data-status=running] .timeline-dot {
  background: var(--copper);
  box-shadow: 0 0 0 4px rgba(184, 115, 51, 0.2);
}

.timeline-event[data-status=completed] .timeline-dot {
  background: var(--ok);
}

.timeline-event[data-status=failed] .timeline-dot {
  background: var(--danger);
}

.timeline-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 2px;
  font-size: 13px;
}

.timeline-event p {
  margin: 0;
  color: var(--charcoal-2);
  font-size: 13px;
  line-height: 1.5;
}

/* Deliverables */
.deliverables-panel {
  display: grid;
  grid-template-columns: minmax(220px, 0.8fr) minmax(0, 1.2fr);
  gap: 24px;
  align-items: start;
}

.deliverables-left {
  display: grid;
  gap: 10px;
  padding: 20px;
  border-radius: var(--radius-md);
  background: linear-gradient(145deg, rgba(28, 26, 23, 0.03), rgba(184, 115, 51, 0.08));
  border: 1px solid var(--line);
}

.deliverables-left .section-title {
  font-family: var(--serif);
  font-size: 26px;
  letter-spacing: -0.03em;
  margin: 0;
}

.deliverables-left .section-copy {
  margin: 0;
  line-height: 1.5;
}

.deliverables-left .action-button {
  width: 100%;
  justify-content: center;
}

@media (max-width: 820px) {
  .deliverables-panel {
    grid-template-columns: 1fr;
  }
  .reviewers-head {
    grid-template-columns: 1fr;
  }
  .reviewers-total {
    justify-items: start;
  }
}
/* Upload queue floating widget (bottom-left of private shell) */
.upload-widget {
  position: fixed;
  left: 24px;
  bottom: 24px;
  width: min(360px, 100vw - 48px);
  padding: 14px 16px;
  background: rgba(250, 247, 241, 0.98);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(27, 24, 21, 0.2);
  z-index: 25;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  display: grid;
  gap: 8px;
}

.upload-widget-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 13px;
}

.upload-widget-head-right {
  display: flex;
  align-items: center;
  gap: 8px;
}

.upload-widget.is-expanded {
  max-height: 70vh;
}

.upload-widget-list li.is-clickable {
  cursor: pointer;
  border-radius: 6px;
  padding: 2px 4px;
  margin-left: -4px;
  margin-right: -4px;
}

.upload-widget-list li.is-clickable:hover {
  background: rgba(139, 59, 50, 0.06);
}

.upload-widget-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.upload-widget-error-detail {
  margin-top: 4px;
  padding: 6px 8px;
  border-radius: 6px;
  background: rgba(139, 59, 50, 0.1);
  color: var(--danger);
  font-size: 11px;
  line-height: 1.4;
  word-break: break-word;
}

.upload-widget.is-expanded .upload-widget-list {
  max-height: 55vh;
}

.upload-widget-errors {
  color: var(--danger);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.upload-widget-bar {
  height: 4px;
}

.upload-widget-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 4px;
  max-height: 150px;
  overflow-y: auto;
}

.upload-widget-list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 12px;
  padding: 4px 0;
}

.upload-widget-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  flex: 1;
}

.upload-widget-status {
  font-size: 11px;
  color: var(--charcoal-3);
}

.upload-widget-list li[data-status=uploading] .upload-widget-status {
  color: var(--copper-deep);
}

.upload-widget-list li[data-status=done] .upload-widget-status {
  color: var(--ok);
}

.upload-widget-list li[data-status=error] .upload-widget-status {
  color: var(--danger);
}

.upload-widget-list li[data-status=skipped] .upload-widget-status {
  color: var(--charcoal-3);
  font-style: italic;
}

/* Form row alignment: every input + hint/msg slot has the same height so split-rows line up */
.form-row {
  align-content: start;
}

.field-msg {
  font-size: 12px;
  line-height: 1.3;
  min-height: 16px;
  color: var(--charcoal-3);
  transition: color 150ms;
}

.field-msg.is-ok {
  color: var(--ok);
}

.field-msg.is-error {
  color: var(--danger);
}

.field-msg.is-muted {
  color: var(--charcoal-4);
  font-style: italic;
}

.field-input.has-ok {
  border-color: rgba(55, 87, 63, 0.55);
  box-shadow: 0 0 0 3px rgba(55, 87, 63, 0.08);
}

.field-input.has-error,
.dropzone.has-error {
  border-color: rgba(139, 59, 50, 0.6);
  box-shadow: 0 0 0 3px rgba(139, 59, 50, 0.08);
}

/* Auth : divider + Google button */
.auth-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--charcoal-3);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 4px 0;
}

.auth-divider::before,
.auth-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--line);
}

.google-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
  background: rgba(255, 255, 255, 0.85);
  color: var(--charcoal);
  font: inherit;
  font-size: 14px;
  cursor: pointer;
  transition: background 150ms, border-color 150ms, transform 120ms;
}

.google-button:hover {
  background: rgb(255, 255, 255);
  border-color: var(--charcoal);
  transform: translateY(-1px);
}

.google-icon {
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, #4285F4 0%, #EA4335 33%, #FBBC05 66%, #34A853 100%);
  color: #fff;
  font-weight: 700;
  font-size: 12px;
  font-family: var(--sans);
}

/* Danger zone (account deletion) */
.danger-zone {
  border: 1px solid rgba(139, 59, 50, 0.3);
  background: rgba(139, 59, 50, 0.04);
}

.danger-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 20px;
  border-radius: 999px;
  background: var(--danger);
  color: #fff;
  border: 0;
  font: inherit;
  font-size: 14px;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background 150ms, transform 120ms;
}

.danger-button:hover {
  background: #a94a40;
  transform: translateY(-1px);
}

/* Admin AI settings */
.ai-settings-list {
  display: grid;
  gap: 14px;
}

.ai-setting {
  display: grid;
  gap: 10px;
  padding: 16px 18px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.55);
}

.ai-setting-head {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
}

.ai-setting-head strong {
  display: block;
  font-size: 13px;
}

.ai-setting-head .muted {
  display: block;
  font-size: 11px;
  font-family: var(--mono);
}

.ai-setting-history {
  display: grid;
  gap: 6px;
  margin-top: 8px;
  font-size: 12px;
}

.ai-setting-history-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 4px 0;
  border-top: 1px solid var(--line);
}

.ai-setting-history-row:first-child {
  border-top: 0;
}

/* Launch run modal */
.launch-modal {
  position: fixed;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  width: min(520px, 100vw - 32px);
  padding: 28px 30px;
  border-radius: var(--radius-xl);
  background: var(--paper-strong);
  border: 1px solid var(--line);
  box-shadow: 0 28px 80px rgba(27, 24, 21, 0.24);
  z-index: 40;
  display: grid;
  gap: 16px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.launch-modal .section-title {
  margin: 0;
  font-size: clamp(22px, 2.5vw, 28px);
}

.launch-spinner {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 3px solid rgba(28, 26, 23, 0.12);
  border-top-color: var(--copper);
  animation: launch-spin 0.9s linear infinite;
  margin: 0 auto;
}

@keyframes launch-spin {
  to {
    transform: rotate(360deg);
  }
}
.launch-breakdown {
  display: grid;
  gap: 10px;
  padding: 16px 18px;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid var(--line);
}

.launch-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 14px;
}

.launch-row.is-danger strong {
  color: var(--danger);
}

.launch-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.field-hint.is-danger {
  color: var(--danger);
}

.overlay {
  position: fixed;
  inset: 0;
  background: rgba(27, 24, 21, 0.32);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 35;
}

/* Help widget (bottom-right floating) */
.help-widget {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 30;
  display: grid;
  justify-items: end;
  gap: 10px;
}

.help-toggle {
  position: relative;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: var(--charcoal);
  color: var(--ivory);
  display: grid;
  place-items: center;
  border: 0;
  cursor: pointer;
  box-shadow: 0 14px 34px rgba(27, 24, 21, 0.25);
  font-family: var(--serif);
  font-size: 22px;
  transition: transform 180ms ease, background 180ms ease;
}

.help-toggle:hover {
  transform: translateY(-2px);
  background: var(--charcoal-2);
}

.help-toggle-badge,
.help-unread-badge {
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--danger);
  color: #fff;
  display: inline-grid;
  place-items: center;
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1;
}

.help-toggle-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  border: 2px solid #fbf8f1;
}

.help-popup {
  width: min(380px, 100vw - 32px);
  max-height: min(640px, 100vh - 120px);
  border-radius: 24px;
  background: #fbf8f1;
  border: 1px solid var(--line);
  box-shadow: 0 28px 80px rgba(27, 24, 21, 0.28);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  overflow: hidden;
  animation: page-in 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.help-hero {
  background: linear-gradient(155deg, #1a1a1a 0%, #2a231b 75%);
  color: var(--ivory);
  padding: 24px 22px 36px;
}

.help-hero-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}

.help-hero-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  font-family: var(--serif);
  letter-spacing: -0.01em;
}

.help-logo {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--copper), var(--copper-deep));
  display: inline-grid;
  place-items: center;
  color: var(--ivory);
  font-size: 14px;
  font-family: var(--sans);
  font-weight: 700;
}

.help-close {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 0;
  background: rgba(255, 255, 255, 0.08);
  color: var(--ivory);
  font-size: 16px;
  cursor: pointer;
  transition: background 150ms;
}

.help-close:hover {
  background: rgba(255, 255, 255, 0.18);
}

.help-hero-title {
  margin: 0;
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--ivory);
}

.help-body {
  padding: 16px;
  overflow-y: auto;
}

.help-cards {
  display: grid;
  gap: 10px;
}

.help-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 14px;
  color: var(--charcoal);
  text-align: left;
  text-decoration: none;
  cursor: pointer;
  font: inherit;
  transition: transform 150ms, border-color 150ms, box-shadow 150ms;
}

.help-card:hover {
  transform: translateY(-1px);
  border-color: var(--line-strong);
  box-shadow: 0 6px 18px rgba(27, 24, 21, 0.08);
}

.help-card strong {
  display: block;
  font-size: 14px;
  margin-bottom: 2px;
}

.help-card p {
  margin: 0;
  font-size: 12px;
  line-height: 1.35;
}

.help-card-arrow {
  font-size: 16px;
  color: var(--copper-deep);
}

.help-card-chip {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--charcoal-3);
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--ivory-2);
}

.help-card-cta strong {
  color: var(--copper-deep);
}

.help-tabs {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  border-top: 1px solid var(--line);
  background: #fff;
}

.help-tab {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 10px 4px;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: 10px;
  letter-spacing: 0.02em;
  color: var(--charcoal-3);
  cursor: pointer;
  transition: color 150ms;
}

.help-unread-badge {
  position: absolute;
  top: 5px;
  right: calc(50% - 26px);
  min-width: 16px;
  height: 16px;
  font-size: 9px;
}

.help-tab-icon {
  font-size: 16px;
  line-height: 1;
}

.help-tab.is-active {
  color: var(--copper-deep);
}

.help-tab.is-active .help-tab-icon {
  filter: drop-shadow(0 0 0 var(--copper));
}

.help-messages {
  display: grid;
  gap: 14px;
}

.help-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  padding: 0 2px;
}

.help-section-head > div {
  min-width: 0;
}

.help-section-head strong {
  display: block;
  font-size: 14px;
  line-height: 1.2;
}

.help-section-head p {
  margin: 2px 0 0;
  font-size: 12px;
  line-height: 1.35;
}

.help-inline-action {
  min-height: 32px;
  padding: 0 12px;
  font-size: 12px;
  white-space: nowrap;
}

.help-composer {
  display: grid;
  gap: 6px;
  padding: 14px;
  border-radius: 14px;
  background: #fff;
  border: 1px solid var(--line);
}

.help-composer .field-label {
  font-size: 11px;
}

.help-composer .field-input,
.help-composer .field-textarea {
  font-size: 13px;
  padding: 10px 12px;
  border-radius: 10px;
}

.help-composer .field-textarea {
  min-height: 80px;
}

.help-composer .action-button {
  min-height: 36px;
  padding: 0 14px;
  font-size: 13px;
}

.help-thread {
  display: grid;
  gap: 10px;
}

.help-message {
  padding: 12px 14px;
  border-radius: var(--r-md);
  background: #fff;
  border: 1px solid var(--line);
}

.help-message-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 4px;
  font-size: 12px;
}

.help-message p {
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.help-message-reply {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(184, 115, 51, 0.08);
  border: 1px solid rgba(184, 115, 51, 0.2);
}

.help-message-reply .eyebrow {
  font-size: 10px;
  color: var(--copper-deep);
  margin-bottom: 4px;
  display: block;
}

/* Support conversations */
.support-page {
  display: grid;
  gap: 24px;
}

.support-page > section {
  display: grid;
  gap: 18px;
}

.app-shell.is-private .support-page.is-user > section {
  gap: 10px;
}

.app-shell.is-private .support-page.is-user .support-page-head {
  margin-bottom: 0;
}

.app-shell.is-private .support-page.is-user .support-new-message-panel {
  margin-top: 0;
}

.app-shell.is-private .support-page.is-user .support-panel-head {
  margin-bottom: 10px;
}

.support-admin-dashboard {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.62);
  box-shadow: var(--shadow-soft);
}

.support-admin-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}

.support-admin-kpi {
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 13px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: rgba(245, 239, 230, 0.44);
  color: var(--charcoal);
  cursor: pointer;
  text-align: left;
}

.support-admin-kpi:hover,
.support-admin-kpi.is-active {
  border-color: rgba(0, 11, 112, 0.28);
  background: rgba(255, 255, 255, 0.88);
}

.support-admin-kpi span {
  color: var(--charcoal-3);
  font-size: 11px;
  letter-spacing: 0.08em;
  line-height: 1.25;
  text-transform: uppercase;
}

.support-admin-kpi strong {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 600;
  line-height: 1;
}

.support-admin-filter-form {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(180px, 240px) auto;
  gap: 12px;
  align-items: end;
}

.support-admin-search,
.support-admin-status-filter {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.support-admin-filter-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

.support-inbox {
  display: grid;
  grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.support-inbox-list {
  display: grid;
  gap: 10px;
  min-width: 0;
  align-content: start;
}

.support-inbox-item {
  display: grid;
  gap: 8px;
  width: 100%;
  min-width: 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.62);
  color: var(--charcoal);
  cursor: pointer;
  text-align: left;
  box-shadow: none;
}

.support-inbox-item:hover,
.support-inbox-item.is-active {
  border-color: rgba(0, 11, 112, 0.28);
  background: rgba(255, 255, 255, 0.9);
}

.support-inbox-item.has-unread {
  border-color: rgba(197, 48, 48, 0.32);
}

.support-inbox-item-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  min-width: 0;
}

.support-inbox-item-head strong {
  min-width: 0;
  color: var(--pill-ink);
  font-size: 14px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.support-inbox-item-head span {
  flex: 0 0 auto;
  color: var(--charcoal-3);
  font-size: 10px;
  line-height: 1.3;
}

.support-inbox-item-meta {
  color: var(--charcoal-3);
  font-size: 12px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.support-history-number {
  color: var(--charcoal-3);
  font-size: 10px;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
  overflow-wrap: anywhere;
}

.support-inbox-preview {
  color: var(--charcoal-2);
  display: -webkit-box;
  font-size: 12px;
  line-height: 1.45;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.support-inbox-item .status-chip {
  justify-self: start;
  min-height: 28px;
  padding: 0 10px;
  font-size: 10px;
}

.support-active-pane {
  min-width: 0;
}

.support-conversation-list {
  display: grid;
  gap: 14px;
}

.support-conversation {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: var(--shadow-soft);
  min-width: 0;
}

.support-conversation.has-unread {
  border-color: rgba(197, 48, 48, 0.36);
  background: rgba(255, 255, 255, 0.9);
}

.support-conversation-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.support-conversation-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.support-conversation-head > div {
  min-width: 0;
}

.support-conversation-head strong {
  display: block;
  overflow-wrap: anywhere;
}

.support-conversation-head .muted {
  margin: 4px 0 0;
  font-size: 12px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.support-thread {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-radius: var(--radius-md);
  background: rgba(245, 239, 230, 0.52);
  border: 1px solid rgba(0, 11, 112, 0.06);
}

.support-thread-item {
  display: flex;
  justify-content: flex-start;
  min-width: 0;
}

.support-thread-item.is-mine {
  justify-content: flex-end;
}

.support-bubble {
  display: grid;
  gap: 8px;
  width: fit-content;
  max-width: min(760px, 88%);
  min-width: min(260px, 100%);
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--charcoal);
  overflow-wrap: anywhere;
}

.support-thread-item.is-mine .support-bubble {
  border-color: rgba(0, 195, 175, 0.28);
  background: rgba(202, 255, 250, 0.46);
}

.support-bubble-meta {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  color: var(--charcoal-3);
  font-size: 11px;
  line-height: 1.3;
}

.support-bubble-meta strong {
  color: var(--charcoal);
  font-size: 12px;
}

.support-bubble p {
  margin: 0;
  white-space: pre-wrap;
  line-height: 1.5;
  font-size: 13px;
}

.support-attachment {
  display: grid;
  gap: 6px;
  max-width: 320px;
  color: var(--copper-deep);
  font-size: 12px;
  text-decoration: none;
}

.support-attachment img {
  display: block;
  width: 100%;
  max-height: 220px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: var(--paper-strong);
}

.support-reply-form {
  display: grid;
  gap: 10px;
  padding-top: 2px;
}

.support-reply-form .field-textarea {
  min-height: 84px;
}

.support-reply-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.support-reply-actions .field-input {
  flex: 1 1 260px;
}

.support-reply-actions .action-button {
  flex: 0 0 auto;
}

.support-closed-note {
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: rgba(245, 239, 230, 0.52);
}

/* Inline forms (account tabs) */
.inline-form {
  padding: 18px 20px;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.4);
  border: 1px solid var(--line);
  margin-bottom: 20px;
}

.simulator .members-table {
  margin-top: 16px;
}

.simulator-note {
  margin: 12px 0 0;
  color: var(--charcoal-3);
  font-size: 13px;
  line-height: 1.45;
}

.simulator-control {
  display: grid;
  gap: 8px;
  max-width: 320px;
}

.credit-pack-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.credit-pack-button {
  min-height: 78px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: rgba(255, 255, 255, 0.62);
  color: var(--charcoal);
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 5px;
  transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

.credit-pack-button:hover,
.credit-pack-button.is-selected {
  border-color: rgba(184, 115, 51, 0.48);
  background: rgba(250, 247, 241, 0.96);
}

.credit-pack-button:hover {
  transform: translateY(-1px);
}

.credit-pack-button strong {
  font-family: var(--serif);
  font-size: 20px;
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.credit-pack-button span {
  color: var(--charcoal-3);
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

@media (max-width: 960px) {
  .app-shell.is-private {
    grid-template-columns: 1fr;
  }
  .sidebar {
    position: relative;
    height: auto;
    border-right: 0;
    border-bottom: 1px solid var(--line);
    grid-template-rows: auto;
    grid-template-columns: 1fr;
  }
  .sidebar-nav {
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    overflow-x: auto;
    gap: 8px;
    padding: 0 4px 8px;
  }
  .sidebar-link {
    flex: 0 0 auto;
    min-width: max-content;
    white-space: nowrap;
    padding: 10px 12px;
  }
  .sidebar-icon {
    flex: 0 0 22px;
  }
  .sidebar-sub {
    display: none;
  }
  .sidebar-footer {
    display: none;
  }
  .help-widget {
    right: 16px;
    bottom: 16px;
  }
  .support-admin-filter-form {
    grid-template-columns: 1fr;
  }
  .support-admin-filter-actions {
    justify-content: stretch;
  }
  .support-admin-filter-actions .ghost-button {
    flex: 1 1 160px;
  }
  .support-inbox {
    grid-template-columns: 1fr;
  }
  .support-inbox-list {
    grid-auto-flow: column;
    grid-auto-columns: minmax(260px, 82vw);
    overflow-x: auto;
    padding-bottom: 4px;
  }
  .support-conversation {
    padding: 14px;
  }
  .support-conversation-head {
    display: grid;
  }
  .support-thread {
    padding: 10px;
  }
  .support-bubble {
    max-width: 100%;
    min-width: 0;
  }
  .support-reply-actions {
    display: grid;
  }
  .support-reply-actions .field-input,
  .support-reply-actions .action-button {
    width: 100%;
  }
}
/* KPI row + overview grid for dashboard */
.kpi-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
  margin-top: 28px;
}

.kpi-card {
  display: grid;
  gap: 6px;
  padding: 22px 24px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.6);
  box-shadow: var(--shadow-soft);
}

.kpi-value {
  font-family: var(--serif);
  font-size: clamp(34px, 4vw, 48px);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--charcoal);
}

.kpi-card:first-child .kpi-value {
  color: var(--copper-deep);
}

/* Carte KPI cliquable : remplace les anciens boutons d'accès aux listes */
a.kpi-card {
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

a.kpi-card:hover {
  border-color: var(--copper);
  box-shadow: var(--shadow-medium, var(--shadow-soft));
  transform: translateY(-2px);
}

a.kpi-card:focus-visible {
  outline: none;
  border-color: var(--copper);
  box-shadow: 0 0 0 3px rgba(0, 195, 175, 0.25);
}

.admin-status-page {
  display: grid;
  gap: 24px;
}

.admin-status-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 176px;
  gap: 24px;
  align-items: center;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: var(--shadow-soft);
}

.status-score-ring {
  --status-color: var(--charcoal-3);
  width: 164px;
  aspect-ratio: 1;
  justify-self: end;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: conic-gradient(var(--status-color) calc(var(--score) * 1%), rgba(36, 24, 18, 0.12) 0);
}

.status-score-ring[data-status=operational] {
  --status-color: var(--ok);
}

.status-score-ring[data-status=monitoring] {
  --status-color: #a76518;
}

.status-score-ring[data-status=degraded],
.status-score-ring[data-status=outage],
.status-score-ring[data-status=major_outage] {
  --status-color: var(--danger);
}

.status-score-inner {
  width: 116px;
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  align-content: center;
  border-radius: 50%;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.96);
}

.status-score-inner span {
  font-family: var(--serif);
  font-size: 44px;
  line-height: 1;
  letter-spacing: 0;
  color: var(--charcoal);
}

.status-score-inner small {
  color: var(--charcoal-3);
  font-size: 12px;
}

.admin-status-time {
  font-size: 30px;
  letter-spacing: 0;
}

.status-component-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
}

.status-component {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.72);
}

.status-component[data-status=monitoring] {
  border-color: rgba(167, 101, 24, 0.3);
  background: rgba(167, 101, 24, 0.08);
}

.status-component[data-status=degraded],
.status-component[data-status=outage],
.status-component[data-status=major_outage] {
  border-color: rgba(184, 64, 47, 0.3);
  background: rgba(184, 64, 47, 0.08);
}

.status-component-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.status-component p {
  margin: 0;
  color: var(--charcoal-2);
  font-size: 13px;
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.status-component-metric {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--charcoal-3);
  font-family: var(--mono);
  font-size: 12px;
  overflow-wrap: anywhere;
}

.status-metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.status-metric-grid > div {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.68);
}

.status-metric-grid strong {
  font-family: var(--serif);
  font-size: 26px;
  line-height: 1;
  letter-spacing: 0;
  color: var(--charcoal);
}

.status-metric-grid small {
  color: var(--charcoal-3);
  overflow-wrap: anywhere;
}

.admin-errors-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
  color: var(--charcoal-3);
  font-family: var(--mono);
  font-size: 12px;
}

.admin-errors-summary span {
  max-width: 100%;
  padding: 6px 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.62);
  overflow-wrap: anywhere;
}

.admin-errors-table td {
  vertical-align: top;
}

.admin-errors-table small {
  display: block;
  margin-top: 4px;
  color: var(--charcoal-3);
  overflow-wrap: anywhere;
}

.admin-error-message {
  max-width: 360px;
  color: var(--charcoal-2);
  font-size: 13px;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

@media (max-width: 760px) {
  .admin-status-hero {
    grid-template-columns: 1fr;
  }
  .status-score-ring {
    width: 140px;
    justify-self: start;
  }
  .status-score-inner {
    width: 100px;
  }
}
.overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 24px;
  margin-top: 28px;
}

.overview-grid + .panel {
  margin-top: 28px;
}

@media (max-width: 1100px) {
  .overview-grid {
    grid-template-columns: 1fr;
  }
}
@keyframes page-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.chrome {
  width: min(100% - 48px, var(--content-width));
  margin: 0 auto;
  padding-top: 28px;
  position: relative;
  z-index: 2;
}

/* Backdrop-blur réservé aux éléments flottants (chrome, modals, toasts).
   Les cartes (.panel, .auth-panel, .summary-block, etc.) sont posées plates
   en blanc opaque sur le canvas crème, conformément au Pill System v3 §13.3. */
.chrome-bar,
.loading-overlay,
.toast,
.terms-modal {
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.chrome-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 18px 22px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(250, 247, 241, 0.72);
  box-shadow: var(--shadow-soft);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}

.brand-logo {
  width: 32px;
  height: 32px;
  display: block;
  flex-shrink: 0;
}

.brand-mark {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  display: grid;
  place-items: center;
  position: relative;
}

.brand-mark::before,
.brand-mark::after {
  content: "";
  position: absolute;
  inset: 10px;
  border-radius: 50%;
  border: 1px solid rgba(28, 26, 23, 0.24);
}

.brand-mark::after {
  inset: 18px;
  background: var(--charcoal);
  border: 0;
}

.brand-copy {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.brand-name {
  font-family: var(--serif);
  font-size: 24px;
  line-height: 0.9;
  letter-spacing: -0.04em;
}

.brand-name em {
  color: var(--copper-deep);
  font-style: italic;
}

.brand-tag {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 11px;
  color: var(--charcoal-3);
}

.chrome-bar .chrome-nav {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.text-link,
.ghost-button,
.action-button,
.subtle-button {
  transition: color 180ms ease, border-color 180ms ease, background 180ms ease, transform 180ms ease, opacity 180ms ease;
}

.chrome-bar .nav-link {
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: var(--charcoal-3);
  font-size: 13px;
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
}

.chrome-bar .nav-link.is-active,
.chrome-bar .nav-link:hover {
  color: var(--charcoal);
  background: rgba(28, 26, 23, 0.06);
}

/* Public navbar: fixed at top, edge-to-edge, mimics eryon-vitrine .nav.
   The outer .chrome wrapper is neutralized (no width clamp, no padding)
   when it carries a chrome-bar-public child so the fixed bar can span
   the full viewport without inheriting the content-width cap. */
.chrome:has(.chrome-bar-public) {
  position: static;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

.app-shell:has(.chrome-bar-public),
.app-shell:has(.nav) {
  padding-top: 76px;
}

.chrome-bar-public {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  gap: clamp(14px, 2vw, 28px);
  padding: 0 max(24px, (100vw - var(--content-width)) / 2);
  border-radius: 0;
  border: 0;
  border-bottom: 1px solid var(--pill-line-2, rgba(0, 11, 112, 0.07));
  background: rgba(245, 239, 230, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: none;
}

.brand-button {
  display: inline-flex;
  align-items: center;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: inherit;
  text-decoration: none;
}

.brand-button:focus-visible {
  outline: 2px solid var(--copper-deep);
  outline-offset: 4px;
  border-radius: 999px;
}

.nav-public {
  justify-content: center;
  gap: 4px;
  flex-wrap: nowrap;
}

.chrome-bar-public .brand-button {
  flex: 0 0 auto;
}

.chrome-bar-public .chrome-cta {
  margin-left: auto;
}

.chrome-bar-public .nav-public .nav-link {
  padding: 8px 14px;
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--pill-ink);
  white-space: nowrap;
}

.chrome-bar-public .nav-public .nav-link.is-active {
  background: var(--pill-ink);
  color: var(--pill-bg);
}

.chrome-bar-public .nav-public .nav-link:hover {
  background: rgba(0, 11, 112, 0.07);
  color: var(--pill-ink);
}

.chrome-bar-public .nav-public .nav-link.is-active:hover {
  background: var(--pill-ink);
  color: var(--pill-bg);
}

.chrome-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.language-switcher {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  min-width: 0;
  color: var(--charcoal);
  isolation: isolate;
}

.language-switcher-current {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 0 34px 0 13px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 10px 24px rgba(28, 26, 23, 0.08);
  font-size: 13px;
  font-weight: 650;
  white-space: nowrap;
  transition: border-color 180ms ease, background 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.language-switcher-current::after {
  content: "⌄";
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-54%);
  font-size: 14px;
  color: var(--charcoal-3);
  pointer-events: none;
}

.language-switcher-flag {
  display: inline-block;
  width: 20px;
  height: 14px;
  line-height: 1;
  border-radius: 2px;
}

.language-switcher-text {
  line-height: 1;
}

.language-switcher-select {
  position: absolute;
  inset: 0;
  width: 100%;
  min-width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  z-index: 2;
}

.language-switcher:hover .language-switcher-current,
.language-switcher:focus-within .language-switcher-current {
  border-color: var(--charcoal);
  background: #fff;
  box-shadow: 0 14px 30px rgba(28, 26, 23, 0.12);
  transform: translateY(-1px);
}

.language-switcher:focus-within .language-switcher-current {
  outline: 2px solid var(--copper-deep);
  outline-offset: 2px;
}

.chrome-bar-public > .language-switcher-public {
  margin-left: auto;
}

.language-switcher-public .language-switcher-current {
  background: var(--pill-bg);
  box-shadow: none;
}

.language-switcher-public:hover .language-switcher-current,
.language-switcher-public:focus-within .language-switcher-current {
  background: var(--pill-bg);
  box-shadow: none;
}

.language-settings-select {
  font-weight: 650;
}

.nav-cta-login {
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.01em;
  text-transform: none;
  padding: 8px 14px;
  white-space: nowrap;
}

.nav-cta-register {
  padding: 12px 22px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.005em;
  text-transform: none;
  white-space: nowrap;
  min-height: auto;
}

@media (max-width: 1280px) {
  .chrome-bar-public .brand-tag {
    display: none;
  }
}
.nav-burger {
  display: none;
  background: transparent;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  width: 44px;
  height: 44px;
  cursor: pointer;
  padding: 0;
  position: relative;
  flex-shrink: 0;
}

.nav-burger span {
  position: absolute;
  left: 12px;
  right: 12px;
  height: 2px;
  background: var(--charcoal);
  border-radius: 2px;
  transition: transform 180ms ease, opacity 180ms ease, top 180ms ease;
}

.nav-burger span:nth-child(1) {
  top: 15px;
}

.nav-burger span:nth-child(2) {
  top: 21px;
}

.nav-burger span:nth-child(3) {
  top: 27px;
}

.chrome-bar-public.is-mobile-open .nav-burger span:nth-child(1) {
  top: 21px;
  transform: rotate(45deg);
}

.chrome-bar-public.is-mobile-open .nav-burger span:nth-child(2) {
  opacity: 0;
}

.chrome-bar-public.is-mobile-open .nav-burger span:nth-child(3) {
  top: 21px;
  transform: rotate(-45deg);
}

@media (max-width: 1100px) {
  .chrome-bar-public {
    flex-wrap: wrap;
    border-radius: 22px;
    padding: 14px 18px;
  }
  .nav-burger {
    display: block;
  }
  .nav-public,
  .chrome-bar-public .chrome-cta {
    display: none;
    flex-basis: 100%;
    order: 3;
  }
  .chrome-bar-public.is-mobile-open .nav-public,
  .chrome-bar-public.is-mobile-open .chrome-cta {
    display: flex;
  }
  .chrome-bar-public.is-mobile-open .nav-public {
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    padding-top: 8px;
    border-top: 1px solid var(--line);
  }
  .chrome-bar-public.is-mobile-open .nav-public .nav-link {
    text-align: left;
    padding: 12px 14px;
  }
  .chrome-bar-public.is-mobile-open .chrome-cta {
    flex-wrap: wrap;
    gap: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--line);
  }
  .chrome-bar-public.is-mobile-open .nav-cta-register {
    flex: 1 1 auto;
    text-align: center;
  }
}
.user-meta {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.micro {
  font-size: 12px;
  color: var(--charcoal-3);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.mono {
  font-family: var(--mono);
}

.poster {
  display: grid;
  grid-template-columns: 1fr;
  gap: 56px;
  padding-top: 44px;
}

.poster-copy {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 32px;
}

.poster-copy .lead {
  max-width: 72ch;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--pill-muted);
}

.eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: currentColor;
  opacity: 0.5;
}

/* Trait .eyebrow réservé aux pages publiques et auth.
   Dans l'app privée/admin (.app-shell.is-private), l'eyebrow garde sa typo
   mono mais perd le trait pour préserver la densité opérationnelle. */
.app-shell.is-private .eyebrow::before {
  display: none;
}

.display {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(48px, 7vw, 96px);
  line-height: 0.96;
  letter-spacing: -0.05em;
  margin: 0;
  text-wrap: pretty;
}

/* `<em>` à l'intérieur d'un .display devient un pill-mark Pill System (§4).
   Aucun changement de markup nécessaire : tous les `<em>` existants en hero
   prennent la capsule bleue automatiquement. */
.display em {
  font-style: normal;
  font-weight: 600;
  background: var(--pill-blue);
  color: #fff;
  padding: 0.04em 0.32em 0.14em;
  border-radius: var(--r-pill);
  display: inline-block;
  line-height: 1;
  letter-spacing: -0.03em;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.lead {
  max-width: 60ch;
  font-size: 20px;
  line-height: 1.5;
  color: var(--pill-ink-soft);
}

.cta-row,
.button-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Boutons Pill System §7 : 3 variantes (primary / accent / ghost), toutes en
   pill (radius 999), Inter Tight 14px weight 500, casse normale, sans ombre. */
.action-button,
.ghost-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 22px;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.005em;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.action-button {
  color: var(--pill-bg);
  background: var(--pill-ink);
  border-color: var(--pill-ink);
}

.action-button:hover {
  transform: translateY(-1px);
  background: var(--pill-blue);
  border-color: var(--pill-blue);
}

.ghost-button {
  color: var(--pill-ink);
  border-color: var(--pill-ink);
  background: transparent;
}

.ghost-button:hover {
  background: var(--pill-ink);
  color: var(--pill-bg);
}

.text-link {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--pill-ink);
  border-bottom: 1px solid var(--pill-ink);
  padding-bottom: 2px;
  cursor: pointer;
  text-decoration: none;
  transition: color 0.2s ease, border-color 0.2s ease;
}

.text-link:hover {
  color: var(--pill-blue);
  border-color: var(--pill-blue);
}

.poster-side {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.poster-side .panel {
  display: grid;
  grid-template-columns: minmax(220px, 0.72fr) minmax(0, 1fr);
  gap: 28px;
  align-items: end;
  padding: 30px 32px;
}

.poster-side .section-head {
  margin: 0;
}

.poster-side .stack {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
}

.poster-side .meta-row {
  display: grid;
  gap: 8px;
  padding: 10px 18px;
  border-top: 0;
  border-left: 1px solid var(--pill-line);
}

.poster-side .meta-row:first-child {
  border-left: 0;
  padding-left: 0;
}

.poster-side .meta-row span {
  color: var(--pill-muted);
}

.poster-side .meta-row strong {
  font-family: var(--font-display);
  color: var(--pill-ink);
  letter-spacing: -0.02em;
}

/* === Vidéo démo hero (design.md §13.2 radius 24px, §13.3 ombre cartes) === */
.hero-video-frame {
  position: relative;
  aspect-ratio: 16/9;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--pill-line);
  background: var(--pill-ink);
  box-shadow: var(--sh-md, 0 18px 48px -16px rgba(0, 11, 112, 0.2));
}

.hero-video-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.hero-video-caption {
  margin: 14px 0 0;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pill-muted);
}

/* === Section « 4 axes de revue » autonome === */
.home-axes-section {
  margin-top: 56px;
}

.home-axes-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 28px;
}

@media (max-width: 980px) {
  .home-axes-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 540px) {
  .home-axes-grid {
    grid-template-columns: 1fr;
  }
}
/* === Cartes 4 axes - flip 3D horizontal (variante A validée) === */
.home-axis-card {
  position: relative;
  min-height: 280px;
  perspective: 1400px;
  cursor: pointer;
  border-radius: var(--r-lg);
  background: transparent;
  border: 0;
  padding: 0;
}

.home-axis-card:focus-visible {
  outline: 2px solid var(--pill-blue);
  outline-offset: 3px;
}

.home-axis-card .axis-inner {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 280px;
  transition: transform 0.7s cubic-bezier(0.22, 0.68, 0.36, 1);
  transform-style: preserve-3d;
}

.home-axis-card.is-open .axis-inner {
  transform: rotateY(180deg);
}

.home-axis-card .axis-front,
.home-axis-card .axis-back {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 24px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transition: border-color 0.18s ease;
}

.home-axis-card .axis-back {
  background: var(--pill-ink);
  color: #fff;
  transform: rotateY(180deg);
  overflow-y: auto;
}

.home-axis-card .axis-back .capability-axis {
  color: rgba(255, 255, 255, 0.65);
}

.home-axis-card .axis-back .capability-title {
  color: #fff;
}

.home-axis-card .axis-back .capability-body {
  color: rgba(255, 255, 255, 0.86);
  font-size: 13.5px;
  line-height: 1.55;
}

.home-axis-card:hover .axis-front {
  border-color: var(--pill-blue);
}

.home-axis-card .axis-front::after {
  content: "";
  position: absolute;
  top: 24px;
  right: 24px;
  width: 38px;
  height: 10px;
  border-radius: var(--r-pill);
  background: var(--pill-teal);
}

.home-axis-card:nth-child(2) .axis-front::after {
  background: var(--pill-blue);
}

.home-axis-card:nth-child(3) .axis-front::after {
  background: var(--pill-ink);
}

.home-axis-card:nth-child(4) .axis-front::after {
  background: var(--pill-cyan);
}

.axis-flip-hint {
  margin: auto 0 0;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pill-blue);
  padding-top: 12px;
  border-top: 1px dashed var(--pill-line);
}

.axis-back-close {
  margin: auto 0 0;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
  padding-top: 12px;
  border-top: 1px dashed rgba(255, 255, 255, 0.2);
}

/* === Section intro « À quoi sert EryonOne » === */
.home-intro-section {
  margin-top: 64px;
}

.home-intro {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: 48px;
  align-items: start;
}

@media (max-width: 900px) {
  .home-intro {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}
.home-intro-title {
  grid-column: 1/-1;
  max-width: 22ch;
}

.home-intro-body {
  display: grid;
  gap: 14px;
  max-width: 60ch;
}

.home-intro-body p {
  font-size: 17px;
  line-height: 1.6;
  color: var(--pill-ink-soft);
  margin: 0;
}

.home-intro-bullets {
  list-style: none;
  margin: 0;
  padding: 24px 28px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
  display: grid;
  gap: 12px;
}

.home-intro-bullets li {
  position: relative;
  padding-left: 28px;
  font-size: 15px;
  line-height: 1.5;
  color: var(--pill-ink);
}

.home-intro-bullets li::before {
  content: "→";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--pill-blue);
  font-weight: 600;
}

.home-intro-bullets strong {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.02em;
}

/* === Section « Trois engagements » - variation manifeste === */
.home-pledge-section {
  margin-top: 72px;
}

.home-pledge-list {
  list-style: none;
  margin: 28px 0 0;
  padding: 0;
  display: grid;
  gap: 0;
  border-top: 1px solid var(--pill-line);
}

.home-pledge-row {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 32px;
  align-items: start;
  padding: 32px 0;
  border-bottom: 1px solid var(--pill-line);
}

@media (max-width: 720px) {
  .home-pledge-row {
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 18px;
  }
}
.home-pledge-num {
  font-family: var(--font-display);
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--pill-blue);
}

.home-pledge-copy {
  display: grid;
  gap: 10px;
  max-width: 70ch;
}

.home-pledge-copy .capability-title {
  font-size: 22px;
  line-height: 1.2;
}

.home-pledge-copy .capability-body {
  font-size: 15.5px;
  line-height: 1.65;
}

/* === Carte « Structure d'un commentaire / finding » === */
.home-finding-section {
  margin-top: 80px;
}

.finding-card-demo {
  margin-top: 32px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
  padding: 32px;
  display: grid;
  gap: 24px;
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 600px) {
  .finding-card-demo {
    padding: 22px;
  }
}
.finding-card-demo-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--pill-line);
  flex-wrap: wrap;
}

.finding-card-demo-axis {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  background: var(--pill-blue);
  color: #fff;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 500;
}

.finding-card-demo-id {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--pill-muted);
}

.finding-card-demo-block {
  display: grid;
  gap: 8px;
}

.finding-card-demo-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--pill-muted);
  margin: 0;
}

.finding-card-demo-text {
  font-size: 15px;
  line-height: 1.6;
  color: var(--pill-ink-soft);
  margin: 0;
}

.finding-card-demo-quote {
  margin: 4px 0 0;
  padding: 4px 0 4px 16px;
  border-left: 4px solid var(--pill-ink);
  font-style: normal;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.55;
  color: var(--pill-ink);
  background: transparent;
}

.finding-card-demo-block-suggest {
  background: var(--pill-bg-soft);
  border: 1px dashed var(--pill-teal-deep, #007A6F);
  border-radius: var(--r-lg);
  padding: 18px 20px;
}

.finding-card-demo-block-suggest .finding-card-demo-label {
  color: var(--pill-teal-deep, #007A6F);
}

.finding-card-demo-foot {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-top: 16px;
  border-top: 1px dashed var(--pill-line);
  flex-wrap: wrap;
}

.finding-card-demo-action {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 8px 14px;
  border-radius: var(--r-pill);
  border: 1px solid var(--pill-line);
  color: var(--pill-ink);
  cursor: default;
}

.finding-card-demo-action-note {
  font-size: 13px;
  color: var(--pill-muted);
  margin-left: auto;
}

/* === Section « 3 formats de rapport » === */
.home-formats-section {
  margin-top: 72px;
}

.home-formats-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 28px;
}

@media (max-width: 900px) {
  .home-formats-grid {
    grid-template-columns: 1fr;
  }
}
.home-format-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 28px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
}

.home-format-card .capability-index {
  font-size: 12px;
  font-weight: 600;
  color: var(--pill-blue);
  background: var(--pill-bg-soft);
  border-color: var(--pill-blue);
}

.home-format-card[data-format=csv] .capability-index {
  color: var(--pill-teal-deep, #007A6F);
  border-color: var(--pill-teal-deep, #007A6F);
}

.home-format-card[data-format=html] .capability-index {
  color: var(--pill-ink);
  border-color: var(--pill-ink);
}

.home-format-cta {
  margin-top: auto;
  align-self: flex-start;
}

.home-formats-note {
  margin-top: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pill-muted);
}

/* ================================================================
   Home v2 - Hero + Architecture + Links
   ================================================================ */
.home-v2 .page,
.home-v2 {
  /* permettre au hero de respirer en haut sans casser le wrap */
}

.home-hero-v2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  padding: 32px 0 48px;
  border-bottom: 1px solid var(--pill-line);
  margin-bottom: 12px;
}

.home-hero-v2-copy {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.home-hero-v2-title {
  margin: 0;
  max-width: none;
}

.home-hero-v2-lead {
  margin: 0;
  max-width: 90ch;
  font-size: 19px;
  line-height: 1.55;
  color: var(--pill-ink-soft);
}

.home-hero-v2 .cta-row {
  margin-top: 4px;
}

/* === Vidéo large en pleine largeur de container === */
.home-hero-v2-video {
  margin-top: 12px;
}

.hero-video-frame-large {
  /* Hérite de .hero-video-frame mais s'étend en pleine largeur */
  aspect-ratio: 16/9;
  max-width: 100%;
}

/* ================================================================
   Section Architecture - animation scroll-triggered
   ================================================================ */
.home-arch-section {
  margin-top: 64px;
}

.home-arch-copy {
  max-width: 72ch;
  font-size: 17px;
  line-height: 1.65;
  color: var(--pill-ink-soft);
}

.home-arch-reveal {
  margin-top: 56px;
  display: grid;
  gap: 28px;
  padding: 48px 0;
  border-top: 1px solid var(--pill-line);
  border-bottom: 1px solid var(--pill-line);
}

.home-arch-line {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(28px, 5vw, 56px);
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 1.05;
  color: var(--pill-ink);
  max-width: 22ch;
  /* État initial caché */
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.7s cubic-bezier(0.22, 0.68, 0.36, 1), transform 0.7s cubic-bezier(0.22, 0.68, 0.36, 1);
  will-change: opacity, transform;
}

.home-arch-line:nth-child(1) {
  transition-delay: 0s;
}

.home-arch-line:nth-child(2) {
  transition-delay: 0.08s;
}

.home-arch-line:nth-child(3) {
  transition-delay: 0.16s;
}

.home-arch-line:nth-child(4) {
  transition-delay: 0.24s;
}

.home-arch-line.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.home-arch-line-final {
  color: var(--pill-blue);
}

/* Mouvement réduit - désactive l'animation */
@media (prefers-reduced-motion: reduce) {
  .home-arch-line {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
/* ================================================================
   Section « Pour aller plus loin » - link cards
   ================================================================ */
.home-links-section {
  margin-top: 64px;
}

.home-links-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}

@media (max-width: 720px) {
  .home-links-grid {
    grid-template-columns: 1fr;
  }
}
.home-link-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 28px 30px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
  text-decoration: none;
  color: var(--pill-ink);
  transition: border-color 0.18s ease, transform 0.18s ease;
}

.home-link-card:hover {
  transform: translateY(-2px);
  border-color: var(--pill-blue);
}

.home-link-card:hover .home-link-arrow {
  transform: translateX(4px);
  color: var(--pill-blue);
}

.home-link-card .capability-title {
  font-size: 22px;
}

.home-link-card .capability-body {
  color: var(--pill-muted);
  font-size: 14.5px;
  line-height: 1.6;
}

.home-link-arrow {
  position: absolute;
  top: 28px;
  right: 30px;
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  color: var(--pill-ink-soft);
  transition: transform 0.18s ease, color 0.18s ease;
}

/* ================================================================
   Page /referentiels - MDR + ANSM actifs, suivants en route
   ================================================================ */
.ref-active-section {
  display: grid;
  gap: 24px;
  margin-top: 56px;
}

.ref-card {
  position: relative;
  padding: 36px 38px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
}

@media (max-width: 720px) {
  .ref-card {
    padding: 26px 22px;
  }
}
.ref-card-head {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--pill-line);
  margin-bottom: 24px;
}

.ref-card-tag {
  align-self: flex-start;
  padding: 5px 12px;
  background: var(--pill-blue);
  color: #fff;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.ref-card-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(24px, 3.2vw, 32px);
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1.1;
  color: var(--pill-ink);
}

.ref-card-lead {
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
  color: var(--pill-ink-soft);
  max-width: 70ch;
}

.ref-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 32px;
}

@media (max-width: 720px) {
  .ref-card-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}
.ref-card-block {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ref-card-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.ref-card-list li {
  position: relative;
  padding-left: 22px;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--pill-ink-soft);
}

.ref-card-list li::before {
  content: "→";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--pill-blue);
  font-weight: 600;
}

.ref-card-foot {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px dashed var(--pill-line);
}

.ref-card-foot-note {
  margin: 0;
  font-size: 13px;
  line-height: 1.55;
  color: var(--pill-muted);
}

/* === Référentiels prévus (liste verticale numérotée) === */
.ref-planned-section {
  margin-top: 64px;
}

.ref-planned-list {
  list-style: none;
  margin: 28px 0 0;
  padding: 0;
  border-top: 1px solid var(--pill-line);
}

.ref-planned-item {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 24px;
  padding: 24px 0;
  border-bottom: 1px solid var(--pill-line);
  align-items: start;
}

@media (max-width: 720px) {
  .ref-planned-item {
    grid-template-columns: 52px minmax(0, 1fr);
    gap: 14px;
  }
}
.ref-planned-num {
  font-family: var(--font-display);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--pill-muted);
}

.ref-planned-copy {
  display: grid;
  gap: 8px;
  max-width: 70ch;
}

.ref-planned-copy .capability-title {
  font-size: 19px;
}

.ref-planned-copy .capability-body {
  font-size: 14.5px;
  line-height: 1.6;
}

.ref-planned-note {
  margin-top: 24px;
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--pill-muted);
}

.target-stage {
  position: relative;
  min-height: 580px;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0)), rgba(255, 248, 239, 0.48);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.target-stage::before,
.target-stage::after {
  content: "";
  position: absolute;
  inset: auto;
  border-radius: 50%;
  border: 1px solid rgba(28, 26, 23, 0.12);
}

.target-stage::before {
  width: 420px;
  height: 420px;
  top: 70px;
  left: 50%;
  transform: translateX(-50%);
  animation: pulse-ring 10s ease-in-out infinite;
}

.target-stage::after {
  width: 150px;
  height: 150px;
  top: 205px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(28, 26, 23, 0.92);
  border: 0;
  box-shadow: 0 0 0 36px rgba(28, 26, 23, 0.06);
}

@keyframes pulse-ring {
  0%, 100% {
    transform: translateX(-50%) scale(1);
  }
  50% {
    transform: translateX(-50%) scale(1.03);
  }
}
.target-line {
  position: absolute;
  left: 12%;
  right: 12%;
  top: 280px;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--copper) 18%, var(--copper) 82%, transparent 100%);
}

.target-content {
  position: absolute;
  inset: auto 26px 26px 26px;
  display: grid;
  gap: 18px;
}

.panel,
.auth-panel,
.detail-section,
.summary-block,
.empty-state,
.document-stripe,
.project-row {
  border: 1px solid var(--pill-line);
  background: var(--pill-bg-card);
  box-shadow: none;
}

.panel,
.auth-panel,
.detail-section,
.empty-state {
  border-radius: var(--radius-xl);
  padding: 28px;
}

.panel-subtle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border: 1px solid var(--pill-line);
  border-radius: var(--radius-lg);
  background: var(--pill-bg-soft);
}

.document-stripe,
.project-row,
.summary-block {
  border-radius: var(--radius-lg);
  padding: 22px;
}

.grid-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.stat-block {
  display: grid;
  gap: 8px;
}

.stat-value {
  font-family: var(--serif);
  font-size: clamp(30px, 5vw, 54px);
  line-height: 0.95;
  letter-spacing: -0.05em;
}

.stat-label {
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--charcoal-3);
}

.meta-stack,
.stack {
  display: grid;
  gap: 12px;
}

.meta-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
  font-size: 14px;
}

.meta-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.status-chip,
.axis-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 13px;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.48);
}

.status-chip[data-tone=draft] {
  color: var(--charcoal-3);
}

.status-chip[data-tone=uploaded] {
  color: var(--ink);
}

.status-chip[data-tone=uploaded_pending] {
  color: var(--copper-deep);
}

.status-chip[data-tone=queued] {
  color: var(--copper-deep);
}

.status-chip[data-tone=processing] {
  color: var(--ink);
}

.status-chip[data-tone=running] {
  color: var(--ink);
}

.status-chip[data-tone=cancelling],
.status-chip[data-tone=cancelled] {
  color: var(--pill-warning-text);
}

.status-chip[data-tone=completed] {
  color: var(--ok);
}

.status-chip[data-tone=failed] {
  color: var(--danger);
}

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}

.section-head {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: end;
  margin-bottom: var(--sp-12);
}

.section-head .eyebrow {
  margin-bottom: var(--sp-4);
}

.section-head .section-numeral {
  width: 100%;
  margin-bottom: var(--sp-3);
}

.section-head .section-title {
  margin-bottom: var(--sp-5);
}

.section-head .lead {
  margin-top: var(--sp-4);
}

.section-title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1;
  letter-spacing: -0.04em;
  text-wrap: pretty;
}

.section-copy {
  max-width: 56ch;
  color: var(--charcoal-2);
  line-height: 1.7;
}

.public-grid,
.private-grid,
.detail-grid {
  display: grid;
  gap: 22px;
}

.public-grid {
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
  margin-top: 34px;
}

.home-section {
  margin-top: 56px;
}

.home-section-warm {
  background: var(--pill-bg-warm);
  padding: 80px 0;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  padding-left: calc(50vw - 50%);
  padding-right: calc(50vw - 50%);
}

.cta-section {
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}

.cta-section .section-title {
  margin-bottom: 14px;
}

.cta-section .lead {
  margin: 0 auto 28px;
  max-width: 50ch;
}

.cta-section .cta-row {
  justify-content: center;
}

.action-button--accent {
  background: var(--pill-blue);
  color: #fff;
  border-color: var(--pill-blue);
}

.action-button--accent:hover {
  transform: translateY(-1px);
  filter: brightness(1.08);
}

.home-reasons {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-top: 22px;
}

@media (max-width: 900px) {
  .home-reasons {
    grid-template-columns: 1fr;
  }
  .poster-side .panel {
    grid-template-columns: 1fr;
    align-items: start;
  }
  .poster-side .stack {
    grid-template-columns: 1fr;
  }
  .poster-side .meta-row {
    padding: 12px 0 0;
    border-left: 0;
    border-top: 1px solid var(--pill-line);
  }
  .poster-side .meta-row:first-child {
    border-top: 0;
    padding-top: 0;
  }
}
.home-cta {
  margin-top: 72px;
}

.securite-section {
  margin-top: 48px;
}

.securite-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 22px;
}

.securite-grid-single {
  grid-template-columns: 1fr;
}

.securite-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 22px 24px;
  background: rgba(255, 255, 255, 0.58);
  box-shadow: var(--shadow-soft);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.securite-card h3 {
  font-family: var(--serif);
  font-size: 20px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 0;
  color: var(--charcoal);
}

.securite-card p {
  margin: 0;
  color: var(--charcoal-2);
  line-height: 1.55;
  font-size: 14.5px;
}

.securite-card p strong {
  color: var(--charcoal);
  font-weight: 600;
}

.securite-card p em {
  color: var(--charcoal-3);
  font-style: italic;
}

.securite-card p code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 13px;
  padding: 1px 6px;
  border-radius: 6px;
  background: rgba(28, 26, 23, 0.06);
  color: var(--charcoal);
}

.securite-card-caveat {
  border-color: rgba(184, 115, 51, 0.35);
  background: rgba(255, 246, 232, 0.55);
}

.securite-card-caveat h3 {
  color: var(--charcoal);
}

.securite-card-caveat h3::before {
  content: "⚠ ";
  color: #c88a3a;
  font-size: 0.85em;
  margin-right: 4px;
}

@media (max-width: 820px) {
  .securite-grid {
    grid-template-columns: 1fr;
  }
  .securite-card {
    padding: 20px 20px;
  }
}
.public-footer {
  margin-top: 0;
  padding: 64px 0 32px;
  background: var(--pill-ink);
  color: var(--pill-bg);
  position: relative;
}

.public-footer .footer-title,
.public-footer strong {
  color: rgba(245, 239, 230, 0.85);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: 20px;
}

.public-footer .footer-link,
.public-footer .footer-text {
  color: rgba(245, 239, 230, 0.9);
}

.public-footer .footer-link:hover,
.public-footer .footer-link:focus-visible {
  color: var(--pill-bg);
}

.public-footer .footer-bottom {
  border-top-color: rgba(245, 239, 230, 0.12);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245, 239, 230, 0.85);
}

.footer-legal-links {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  align-items: center;
}

.public-footer .footer-legal-links a {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245, 239, 230, 0.85);
  text-decoration: none;
  transition: color 0.15s;
}

.public-footer .footer-legal-links a:hover {
  color: var(--pill-bg);
}

.footer-linkedin-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(245, 239, 230, 0.85);
  transition: color 0.2s;
  min-width: 32px;
  min-height: 32px;
  padding: 4px;
}

.footer-linkedin-link:hover {
  color: var(--pill-bg);
}

.public-footer .pill-wm {
  color: var(--pill-bg);
}

.public-footer .pill-wm .pw-pill {
  background: var(--pill-blue);
  color: #fff;
}

.public-footer .brand-logo {
  filter: brightness(0) invert(1);
}

.public-footer-inner {
  width: min(100% - 48px, var(--content-width));
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 44px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: 32px;
}

.footer-brand-col {
  gap: 18px;
}

.footer-brand-col .pill-wm {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.03em;
}

.footer-brand-col .footer-text {
  max-width: 34ch;
  line-height: 1.6;
}

.footer-stickers {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 4px;
}

.public-footer .footer-stickers .sticker {
  font-size: 11px;
  padding: 6px 12px;
  --rot: 0deg;
}

.footer-col {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
}

.footer-title {
  font-family: var(--serif);
  font-size: 14px;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--charcoal);
  margin: 0 0 6px;
  font-weight: 600;
}

.footer-link {
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  font: inherit;
  color: var(--charcoal-2);
  cursor: pointer;
  text-align: left;
  font-size: 14px;
  line-height: 1.5;
  transition: color 160ms ease;
  text-decoration: none;
}

.footer-link:hover,
.footer-link:focus-visible {
  color: var(--copper-deep);
  outline: none;
}

.footer-text {
  margin: 0;
  color: var(--charcoal-2);
  font-size: 14px;
  line-height: 1.5;
}

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding-top: 28px;
  border-top: 1px solid rgba(28, 26, 23, 0.1);
  flex-wrap: wrap;
}

.footer-bottom-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.footer-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}

.footer-bottom-name {
  font-family: var(--serif);
  font-size: 18px;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--charcoal);
}

.footer-bottom-name em {
  color: var(--copper-deep);
  font-style: italic;
}

.footer-bottom-copy {
  font-size: 12px;
  color: var(--charcoal-3);
}

.footer-bottom-note {
  margin: 0;
  font-size: 12px;
  color: var(--charcoal-3);
  letter-spacing: 0.02em;
}

@media (max-width: 820px) {
  .public-footer {
    margin-top: 88px;
    padding: 52px 0 34px;
  }
  .public-footer-inner {
    gap: 34px;
  }
  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
  }
  .footer-brand-col {
    grid-column: 1/-1;
  }
  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
}
@media (max-width: 520px) {
  .public-footer {
    margin-top: 72px;
    padding: 44px 0 30px;
  }
  .public-footer-inner {
    width: min(100% - 32px, var(--content-width));
    gap: 28px;
  }
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .footer-col {
    gap: 10px;
  }
  .footer-link {
    min-height: 32px;
    display: inline-flex;
    align-items: center;
  }
  .footer-bottom-brand {
    gap: 8px 12px;
  }
}
.legal-page .legal-content {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.legal-block {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 24px 26px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.58);
}

.legal-block-title {
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 0 0 4px;
  color: var(--charcoal);
}

.legal-block p {
  margin: 0;
  color: var(--charcoal-2);
  line-height: 1.6;
  font-size: 15px;
}

.legal-block p strong {
  color: var(--charcoal);
  font-weight: 600;
}

.legal-block p em {
  color: var(--charcoal-3);
  font-style: italic;
}

.legal-block p code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 13px;
  padding: 1px 6px;
  border-radius: 6px;
  background: rgba(28, 26, 23, 0.06);
  color: var(--charcoal);
}

.contact-section {
  margin-top: 48px;
}

.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 36px;
  align-items: start;
}

.contact-intro {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.contact-intro .section-copy {
  margin: 0;
}

.contact-side-cards {
  display: grid;
  gap: 16px;
  margin-top: 28px;
}

.contact-side-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 22px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
}

/* === Page « Ce que ça change pour vous » === */
.ccc-page .about-hero {
  padding-bottom: 8px;
}

.ccc-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}

@media (max-width: 900px) {
  .ccc-steps {
    grid-template-columns: 1fr;
  }
}
.ccc-step {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 28px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
  transition: transform 0.18s ease, border-color 0.18s ease;
}

.ccc-step:hover {
  transform: translateY(-2px);
  border-color: var(--pill-blue);
}

.ccc-step::after {
  content: "";
  position: absolute;
  top: 28px;
  right: 28px;
  width: 38px;
  height: 10px;
  border-radius: var(--r-pill);
  background: var(--pill-teal);
}

.ccc-step:nth-child(2)::after {
  background: var(--pill-blue);
}

.ccc-step:nth-child(3)::after {
  background: var(--pill-ink);
}

.ccc-compare {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

@media (max-width: 720px) {
  .ccc-compare {
    grid-template-columns: 1fr;
  }
}
.ccc-compare-col {
  padding: 24px;
  background: var(--pill-bg-soft);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
}

.ccc-compare-col-after {
  background: var(--pill-bg-card);
  border-color: var(--pill-blue);
}

.ccc-compare-col .seo-list {
  margin-top: 12px;
}

.contact-form-wrap {
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 26px 28px;
  box-shadow: var(--shadow-soft);
}

.contact-form-wrap-embedded {
  margin-top: 22px;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.contact-form-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.contact-form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.contact-form-label {
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--charcoal-3);
  font-weight: 600;
}

.contact-form-input,
.contact-form-textarea {
  width: 100%;
  padding: 11px 14px;
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.9);
  font: inherit;
  color: var(--charcoal);
  transition: border-color 160ms ease, box-shadow 160ms ease;
}

.contact-form-input:focus,
.contact-form-textarea:focus {
  outline: none;
  border-color: var(--copper-deep);
  box-shadow: 0 0 0 3px rgba(0, 172, 197, 0.18);
}

.contact-form-textarea {
  min-height: 140px;
  resize: vertical;
  font-family: inherit;
  line-height: 1.5;
}

.contact-form-input:disabled,
.contact-form-textarea:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.contact-form-honeypot {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.contact-form-error {
  margin: 0;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(210, 70, 60, 0.08);
  border: 1px solid rgba(210, 70, 60, 0.32);
  color: #8a2a24;
  font-size: 14px;
}

.contact-form-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.contact-form-note {
  margin: 0;
  font-size: 12px;
  color: var(--charcoal-3);
}

.contact-form-success {
  padding: 22px 24px;
  border-radius: var(--radius-lg);
  background: rgba(0, 194, 175, 0.1);
  border: 1px solid rgba(0, 172, 197, 0.32);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.contact-form-success-title {
  font-family: var(--serif);
  font-size: 20px;
  margin: 0;
  color: var(--charcoal);
  letter-spacing: -0.02em;
}

.contact-form-success-copy {
  margin: 0;
  color: var(--charcoal-2);
  font-size: 14.5px;
  line-height: 1.5;
}

@media (max-width: 820px) {
  .contact-layout {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .contact-form-row {
    grid-template-columns: 1fr;
  }
  .contact-form-wrap {
    padding: 22px 20px;
  }
}
.home-refs-group {
  margin-top: 24px;
}

.home-refs-subhead {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--pill-muted);
  margin: 0 0 14px;
}

.home-refs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}

.ref-card {
  min-height: 210px;
  padding: 22px;
  border-radius: var(--r-lg);
  border: 1px solid var(--pill-line);
  background: var(--pill-bg-card);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ref-card.is-planned {
  opacity: 1;
  background: var(--pill-bg-card);
}

.ref-code {
  align-self: flex-start;
  padding: 5px 10px;
  font-size: 11px;
  font-family: var(--font-mono);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pill-ink);
  background: var(--pill-bg-soft);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-pill);
}

.ref-card.is-planned .ref-code {
  color: var(--pill-muted);
  background: var(--pill-bg-soft);
}

.ref-name {
  font-family: var(--font-display);
  font-size: 21px;
  line-height: 1.08;
  margin: 0;
  letter-spacing: -0.03em;
  color: var(--pill-ink);
}

.ref-desc {
  font-size: 14px;
  color: var(--pill-muted);
  line-height: 1.55;
  margin: 0;
}

.ref-status {
  width: fit-content;
  padding: 5px 10px;
  border-radius: var(--r-pill);
  background: var(--pill-teal-soft);
  font-size: 11px;
  font-family: var(--font-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pill-teal-deep);
  margin-top: auto;
}

.ref-card.is-planned .ref-status {
  background: var(--pill-bg-soft);
  border: 1px solid var(--pill-line);
  color: var(--pill-muted);
}

.pricing-table-wrap {
  margin-top: 22px;
  overflow-x: auto;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: var(--ivory);
}

.pricing-details {
  margin-top: 28px;
  border-radius: 14px;
}

.pricing-details > summary {
  list-style: none;
  cursor: pointer;
}

.pricing-details > summary::-webkit-details-marker {
  display: none;
}

.pricing-details-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  border: 1px solid var(--pill-teal-deep);
  border-radius: 999px;
  background: transparent;
  color: var(--pill-teal-deep);
  font-weight: 600;
  font-size: 14px;
  transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

.pricing-details-toggle:hover {
  background: var(--pill-teal-deep);
  color: var(--ivory);
  transform: translateY(-1px);
}

.pricing-details-chevron {
  display: inline-block;
  transition: transform 0.2s ease;
  font-size: 12px;
}

.pricing-details[open] .pricing-details-chevron {
  transform: rotate(180deg);
}

.pricing-details[open] > summary {
  margin-bottom: 8px;
}

.capabilities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
  gap: 16px;
  margin-top: 28px;
}

.capability-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 220px;
  padding: 24px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
  transition: transform 0.18s ease, border-color 0.18s ease;
}

.capability-card::after {
  content: "";
  position: absolute;
  top: 24px;
  right: 24px;
  width: 38px;
  height: 10px;
  border-radius: var(--r-pill);
  background: var(--pill-teal);
}

.capability-card:nth-child(3n+2)::after {
  background: var(--pill-blue);
}

.capability-card:nth-child(3n)::after {
  background: var(--pill-ink);
}

.capability-card:hover {
  transform: translateY(-2px);
  border-color: var(--pill-blue);
}

.capability-index {
  width: fit-content;
  min-width: 44px;
  padding: 6px 10px;
  border: 1px solid var(--pill-line);
  border-radius: var(--r-pill);
  background: var(--pill-bg-soft);
  color: var(--pill-muted);
  font-family: var(--font-mono);
  font-size: 11px;
  line-height: 1;
  letter-spacing: 0.12em;
}

.capability-axis {
  margin: 0;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--pill-muted);
}

.capability-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1.08;
  font-weight: 600;
  letter-spacing: -0.03em;
  color: var(--pill-ink);
}

.capability-body {
  margin: 0;
  font-size: 14.5px;
  line-height: 1.58;
  color: var(--pill-muted);
}

.pricing-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.pricing-table thead th {
  text-align: right;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--charcoal-3);
  padding: 16px 18px;
  background: var(--ivory-2);
  border-bottom: 1px solid var(--line);
}

.pricing-table thead th:first-child {
  text-align: left;
}

.pricing-table tbody th {
  text-align: left;
  font-weight: 500;
  padding: 14px 18px;
  color: var(--ink);
  border-bottom: 1px solid var(--line);
}

.pricing-table tbody td {
  text-align: right;
  padding: 14px 18px;
  color: var(--charcoal-2);
  border-bottom: 1px solid var(--line);
  font-variant-numeric: tabular-nums;
}

.pricing-table tbody tr:last-child th,
.pricing-table tbody tr:last-child td {
  border-bottom: 0;
}

.pricing-cell-value {
  display: inline-grid;
  justify-items: end;
  gap: 2px;
  min-width: 0;
  overflow-wrap: anywhere;
}

.pricing-cell-value .muted {
  display: block;
  margin-top: 2px;
  font-size: 12px;
  line-height: 1.35;
}

.pricing-table-footnote {
  margin: 14px 4px 0;
  font-size: 13px;
  color: var(--charcoal-3);
  line-height: 1.5;
}

@media (max-width: 860px) {
  .pricing-page .pricing-table-wrap {
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
  }
  .pricing-page .pricing-table {
    display: block;
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 14px;
  }
  .pricing-page .pricing-table thead {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    white-space: nowrap;
  }
  .pricing-page .pricing-table tbody {
    display: grid;
    gap: 12px;
  }
  .pricing-page .pricing-table tbody tr {
    display: grid;
    gap: 0;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: var(--ivory);
    box-shadow: 0 10px 24px rgba(30, 35, 48, 0.07);
  }
  .pricing-page .pricing-table tbody th,
  .pricing-page .pricing-table tbody td {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: baseline;
    gap: 16px;
    min-width: 0;
    padding: 10px 0;
    border-bottom: 1px solid var(--line);
    text-align: right;
  }
  .pricing-page .pricing-table tbody th {
    display: block;
    padding-top: 0;
    text-align: left;
    font-family: var(--font-display);
    font-size: 18px;
    line-height: 1.2;
    color: var(--ink);
  }
  .pricing-page .pricing-table tbody td::before {
    content: attr(data-label);
    min-width: 0;
    text-align: left;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--charcoal-3);
  }
  .pricing-page .pricing-table tbody td .pricing-cell-value {
    justify-self: end;
    text-align: right;
  }
  .pricing-page .pricing-table tbody td:last-child {
    padding-bottom: 0;
    border-bottom: 0;
  }
  .pricing-page .pricing-table tbody td .muted {
    display: block;
    margin-top: 3px;
    font-size: 12px;
    line-height: 1.35;
  }
  .pricing-page .pricing-table tbody tr.pricing-empty-row {
    display: block;
  }
  .pricing-page .pricing-table tbody tr.pricing-empty-row td {
    display: block;
    padding: 0;
    border-bottom: 0;
    text-align: left;
  }
  .pricing-page .pricing-table tbody tr.pricing-empty-row td::before {
    content: none;
  }
  .pricing-page .pricing-table-footnote {
    margin: 16px 0 0;
  }
}
.home-calc-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.95fr);
  gap: 32px;
  margin-top: 24px;
  padding: 32px;
  border-radius: var(--r-lg);
  border: 1px solid var(--pill-line);
  background: var(--pill-bg-card);
  align-items: stretch;
}

.home-calc-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.home-calc-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.home-calc-label {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--pill-muted);
  font-family: var(--font-mono);
  font-weight: 500;
}

.home-calc-select {
  padding: 14px 16px;
  border-radius: var(--r-md);
  border: 1px solid var(--pill-line);
  background: var(--pill-bg-soft);
  font-size: 15px;
  color: var(--pill-ink);
  cursor: pointer;
}

.home-calc-select:focus {
  outline: 2px solid var(--pill-blue);
  outline-offset: 1px;
}

.home-calc-axes {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}

.home-calc-axis {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: var(--r-pill);
  border: 1px solid var(--pill-line);
  background: var(--pill-bg-card);
  cursor: pointer;
  font-family: var(--font-display);
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--pill-ink);
  user-select: none;
  transition: border-color 0.15s ease, background 0.15s ease, transform 0.15s ease;
}

.home-calc-axis:hover {
  border-color: var(--pill-blue);
}

.home-calc-axis input[type=checkbox] {
  width: 14px;
  height: 14px;
  accent-color: var(--pill-blue);
}

.home-calc-axis:has(input:checked) {
  border-color: var(--pill-blue);
  background: var(--pill-blue);
  color: #fff;
}

.home-calc-axis:has(input:checked) input[type=checkbox] {
  accent-color: #fff;
}

.home-calc-result {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
  padding: 32px 28px;
  border-radius: var(--r-lg);
  background: var(--pill-ink);
  color: var(--pill-bg);
  position: relative;
  overflow: hidden;
}

.home-calc-result::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--pill-blue) 0% 50%, var(--pill-teal) 50% 100%);
  /* exception : ruban duo spectrum bar - design.md §11.3 explicitement autorisé */
}

.home-calc-result .eyebrow {
  color: rgba(255, 255, 255, 0.78);
  margin-top: 4px;
}

.home-calc-result .eyebrow::before {
  background: rgba(255, 255, 255, 0.4);
}

.home-calc-total {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(40px, 6vw, 64px);
  font-weight: 700;
  letter-spacing: -0.05em;
  line-height: 0.96;
  font-variant-numeric: tabular-nums;
  overflow-wrap: anywhere;
}

.home-calc-saving {
  margin: 0;
  min-height: 18px;
  font-size: 13px;
  color: rgba(245, 239, 230, 0.78);
}

.home-calc-result .action-button {
  margin-top: 16px;
  color: var(--pill-ink);
  background: var(--pill-bg);
  border-color: var(--pill-bg);
}

.home-calc-result .action-button[disabled] {
  opacity: 0.55;
  cursor: not-allowed;
}

@media (max-width: 820px) {
  .home-calc-panel {
    grid-template-columns: 1fr;
    padding: 22px;
  }
}
.seo-page,
.pricing-page {
  padding-top: 32px;
}

.seo-hero {
  display: grid;
  align-items: start;
  padding: 0 0 clamp(32px, 5vw, 56px);
  border-bottom: 1px solid var(--pill-line);
}

.seo-hero-copy {
  display: grid;
  gap: 18px;
}

.seo-hero .display,
.about-hero .display {
  max-width: none;
}

.seo-hero .lead,
.about-hero .lead {
  max-width: 72ch;
}

.seo-chip-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
}

.seo-section {
  display: grid;
  gap: 22px;
}

.seo-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}

.seo-card {
  display: grid;
  align-content: start;
  gap: 12px;
  min-height: 180px;
  padding: 22px;
  border: 1px solid var(--pill-line);
  border-radius: var(--r-md);
  background: var(--pill-bg-card);
}

.seo-card {
  position: relative;
}

.seo-card::after {
  content: "";
  position: absolute;
  top: 20px;
  right: 20px;
  width: 36px;
  height: 8px;
  border-radius: var(--r-pill);
  background: var(--pill-teal);
}

.seo-card:nth-child(3n+2)::after {
  background: var(--pill-blue);
}

.seo-card:nth-child(3n)::after {
  background: var(--pill-ink);
}

.seo-section-split {
  grid-template-columns: minmax(260px, 0.8fr) minmax(0, 1.2fr);
  align-items: start;
  padding: 30px 0;
  border-top: 1px solid var(--pill-line);
  border-bottom: 1px solid var(--pill-line);
}

.seo-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.seo-list li {
  position: relative;
  padding: 14px 16px 14px 44px;
  border: 1px solid var(--pill-line);
  border-radius: var(--r-md);
  background: var(--pill-bg-soft);
  color: var(--pill-muted);
  line-height: 1.55;
}

.seo-list li::before {
  content: "";
  position: absolute;
  left: 16px;
  top: 19px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--pill-teal);
}

.seo-warning {
  padding: 26px;
  border: 1px solid rgba(13, 23, 230, 0.18);
  border-radius: var(--r-md);
  background: var(--pill-bg-tech);
}

.seo-warning .section-copy {
  max-width: 860px;
}

.seo-faq-section {
  gap: 24px;
  padding: clamp(30px, 5vw, 48px) 0;
  border-top: 1px solid var(--pill-line);
  border-bottom: 1px solid var(--pill-line);
}

.seo-faq-section .section-copy {
  max-width: 720px;
}

.seo-faq-grid {
  display: grid;
  gap: 0;
  max-width: 800px;
}

.seo-faq-column {
  display: grid;
  gap: 0;
}

.seo-faq-item {
  border-bottom: 1px solid var(--pill-line);
  padding: 20px 0;
}

.seo-faq-item summary {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 17px;
  letter-spacing: -0.015em;
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 16px;
}

.seo-faq-item summary:hover h3 {
  color: var(--pill-blue);
}

.seo-faq-item summary:focus-visible {
  outline: 3px solid rgba(0, 163, 163, 0.28);
  outline-offset: 3px;
}

.seo-faq-item summary::-webkit-details-marker {
  display: none;
}

.seo-faq-item summary::before {
  content: "+";
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--pill-bg-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 400;
  color: var(--pill-blue);
  transition: transform 250ms ease, background 250ms ease, color 250ms ease;
}

.seo-faq-item[open] summary::before {
  content: "−";
  background: var(--pill-blue);
  color: #fff;
}

.seo-faq-item h3,
.pricing-credit-box h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 17px;
  line-height: 1.3;
  font-weight: 600;
  color: var(--pill-ink);
  overflow-wrap: anywhere;
  transition: color 160ms ease;
}

.seo-faq-item p {
  margin: 0;
  padding: 12px 0 0 44px;
  font-size: 15px;
  color: var(--pill-muted);
  line-height: 1.6;
}

.seo-faq-item[open] p {
  animation: faq-reveal 180ms ease-out;
}

@keyframes faq-reveal {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.pricing-credit-box p {
  margin: 0;
  color: var(--pill-muted);
  line-height: 1.6;
}

.pricing-notices {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.pricing-notices p {
  margin: 0;
  padding: 8px 12px;
  border: 1px solid var(--pill-line);
  border-radius: var(--r-pill);
  background: var(--pill-bg-soft);
  color: var(--pill-muted);
  font-size: 13px;
}

.pricing-notices-standalone {
  margin-top: 0;
}

.pricing-credit-box {
  display: grid;
  gap: 10px;
  padding: 22px;
  border: 1px solid var(--pill-line);
  border-radius: var(--r-md);
  background: var(--pill-bg-card);
}

.pricing-empty {
  border: 1px dashed var(--pill-line);
  border-radius: var(--r-md);
  background: var(--pill-bg-soft);
}

@media (max-width: 820px) {
  .seo-hero {
    min-height: 0;
    padding-top: 0;
  }
  .seo-section-split {
    grid-template-columns: 1fr;
  }
  .seo-card {
    min-height: 0;
  }
  .seo-faq-item summary {
    font-size: 15px;
  }
  .seo-faq-item p {
    padding: 0 14px 16px 56px;
  }
}
.about-page .about-hero {
  padding: 72px 0 36px;
}

.about-page .display {
  max-width: none;
}

.about-mission-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 22px;
  margin-top: 22px;
}

.about-goals {
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 15px;
  line-height: 1.55;
  color: var(--charcoal-2);
}

.about-goals li {
  position: relative;
  padding-left: 20px;
}

.about-goals li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 10px;
  height: 2px;
  background: var(--copper);
}

.about-team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 22px;
  margin-top: 22px;
}

.about-team-card {
  padding: 28px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: var(--ivory);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.team-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--eryon-gradient-hero, linear-gradient(135deg, #00d0ef 0%, #0003d5 100%));
  color: var(--ivory);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  font-weight: 600;
  letter-spacing: 0.02em;
  margin-bottom: 4px;
  box-shadow: 0 6px 20px rgba(0, 3, 213, 0.15);
}

.team-name {
  margin: 0;
  font-size: 20px;
  line-height: 1.2;
  color: var(--ink);
}

.team-role {
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--copper);
}

.team-bio {
  margin: 0;
  font-size: 14px;
  color: var(--charcoal-2);
  line-height: 1.6;
}

.about-where-panel {
  padding: 32px;
}

.roadmap-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
  margin-bottom: 24px;
}

.roadmap-filter {
  padding: 8px 16px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--ivory);
  color: var(--charcoal-2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 150ms, color 150ms, background 150ms;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.roadmap-filter:hover {
  border-color: var(--copper);
  color: var(--ink);
}

.roadmap-filter.is-active {
  background: var(--ink);
  color: var(--ivory);
  border-color: var(--ink);
}

.roadmap-filter-count {
  font-size: 11px;
  font-weight: 600;
  padding: 1px 7px;
  border-radius: 10px;
  background: rgba(0, 194, 175, 0.12);
  color: var(--copper-deep);
  letter-spacing: 0.02em;
}

.roadmap-filter.is-active .roadmap-filter-count {
  background: rgba(255, 255, 255, 0.18);
  color: var(--ivory);
}

.roadmap-list {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.roadmap-timeline {
  position: relative;
  padding-left: 48px;
  margin-top: 24px;
}

.roadmap-timeline-spine {
  position: absolute;
  left: 18px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: linear-gradient(to bottom, var(--copper) 0%, var(--copper) 50%, var(--line) 100%);
  border-radius: 2px;
  opacity: 0.6;
}

.roadmap-entry {
  position: relative;
  padding: 22px 26px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: var(--ivory);
  display: flex;
  flex-direction: column;
  gap: 10px;
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity 0.45s ease, transform 0.45s ease, border-color 0.2s ease;
}

.roadmap-entry.is-visible {
  opacity: 1;
  transform: translateX(0);
}

.roadmap-entry-dot {
  position: absolute;
  left: -38px;
  top: 28px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--ivory);
  border: 3px solid var(--line);
  box-shadow: 0 0 0 4px var(--ivory);
  transition: background 0.3s ease, border-color 0.3s ease;
}

.roadmap-entry-dot[data-status=shipped] {
  background: var(--copper);
  border-color: var(--copper);
}

.roadmap-entry-dot[data-status=in-progress],
.roadmap-entry-dot[data-status=progress] {
  background: var(--ivory);
  border-color: var(--copper);
  animation: roadmap-dot-pulse 1.6s ease-in-out infinite;
}

.roadmap-entry-dot[data-status=planned] {
  background: var(--ivory);
  border-color: var(--line);
}

.roadmap-entry-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.roadmap-entry:hover {
  border-color: var(--copper);
}

@keyframes roadmap-dot-pulse {
  0%, 100% {
    box-shadow: 0 0 0 4px var(--ivory), 0 0 0 6px rgba(0, 194, 175, 0.25);
  }
  50% {
    box-shadow: 0 0 0 4px var(--ivory), 0 0 0 10px rgba(0, 194, 175, 0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .roadmap-entry {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .roadmap-entry-dot[data-status=in-progress],
  .roadmap-entry-dot[data-status=progress] {
    animation: none;
  }
}
.home-calc-presets-block {
  margin-top: 0;
  margin-bottom: 28px;
}

.home-calc-presets-label {
  margin: 0 0 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--pill-muted);
}

.home-calc-presets-grid {
  display: flex;
  flex-wrap: nowrap;
  gap: 14px;
  overflow-x: auto;
  overflow-y: visible;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding: 4px 4px 16px;
  margin: 0 -4px;
  scrollbar-color: var(--pill-ink, #000B70) transparent;
  scrollbar-width: thin;
}

.home-calc-presets-grid::-webkit-scrollbar {
  height: 8px;
}

.home-calc-presets-grid::-webkit-scrollbar-track {
  background: transparent;
}

.home-calc-presets-grid::-webkit-scrollbar-thumb {
  background: rgba(0, 11, 112, 0.18);
  border-radius: 999px;
}

.home-calc-presets-grid::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 11, 112, 0.32);
}

.home-calc-presets-grid > .home-calc-preset {
  flex: 0 0 auto;
  width: 260px;
  scroll-snap-align: start;
}

.home-calc-preset.is-selected {
  border-color: var(--pill-blue);
  box-shadow: 0 0 0 2px var(--pill-blue, #000B70) inset;
}

.home-calc-preset.is-selected .home-calc-preset-price {
  background: var(--pill-blue);
}

.home-calc-preset {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 160px;
  padding: 20px 22px 18px;
  text-align: left;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg);
  cursor: pointer;
  color: var(--pill-ink);
  transition: border-color 0.18s ease, transform 0.15s ease;
}

.home-calc-preset:hover {
  transform: translateY(-2px);
  border-color: var(--pill-blue);
}

.home-calc-preset:focus-visible {
  outline: 2px solid var(--pill-blue);
  outline-offset: 2px;
}

/* Numéral en gros, en haut à gauche - signature Eryon plutôt que pill discret */
.home-calc-preset-icon {
  display: inline-block;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--pill-blue);
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  margin-bottom: 4px;
}

/* Méta en flow normal sous le numéro */
.home-calc-preset-meta {
  align-self: flex-start;
  padding: 4px 10px;
  background: var(--pill-bg-soft);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pill-muted);
}

.home-calc-preset-title {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.home-calc-preset-body {
  font-size: 13px;
  line-height: 1.5;
  color: var(--pill-muted);
  flex-grow: 1;
}

.home-calc-preset-price {
  align-self: flex-start;
  margin-top: 6px;
  padding: 6px 12px;
  background: var(--pill-ink);
  color: #fff;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.06em;
  font-variant-numeric: tabular-nums;
}

.home-calc-preset:hover .home-calc-preset-price {
  background: var(--pill-blue);
}

/* Refonte page sécurité - alignée Pill System v3.0 (design.md §14 règle #04 : pas de gradient) */
.sec-page {
  --sec-tint: rgba(0, 194, 175, 0.05);
  --sec-tint-strong: rgba(0, 194, 175, 0.10);
  --sec-border: var(--pill-line);
}

.sec-hero {
  margin-top: 0;
  position: relative;
}

.sec-hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: start;
}

@media (max-width: 760px) {
  .sec-hero-grid {
    gap: 28px;
  }
}
.sec-hero-copy .display {
  margin: 12px 0 14px;
}

.sec-hero-copy .lead {
  margin: 0 0 28px;
  color: var(--charcoal-2);
  max-width: 56ch;
}

.sec-hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  padding-top: 20px;
  border-top: 1px solid var(--sec-border);
}

@media (max-width: 600px) {
  .sec-hero-stats {
    grid-template-columns: 1fr;
  }
}
.sec-hero-stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.sec-hero-stat-value {
  font-family: var(--font-display);
  font-size: clamp(32px, 4vw, 44px);
  font-weight: 600;
  letter-spacing: -0.03em;
  color: var(--pill-ink);
  line-height: 1.05;
  font-feature-settings: "tnum";
}

.sec-hero-stat-label {
  font-size: 12px;
  line-height: 1.4;
  color: var(--charcoal-3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 500;
}

.sec-hero-visual {
  display: flex;
  justify-content: center;
  align-items: center;
}

.sec-hero-shield {
  width: 180px;
  height: 180px;
  color: var(--pill-teal);
  opacity: 0.9;
}

.sec-hero-shield svg {
  width: 100%;
  height: 100%;
  stroke-width: 1.2;
}

.sec-section {
  margin-top: 56px;
}

.sec-section-tinted {
  background: var(--sec-tint);
  border-radius: var(--r-lg);
  padding: 36px 32px;
}

@media (max-width: 760px) {
  .sec-section-tinted {
    padding: 28px 20px;
  }
}
.sec-section-head {
  margin-bottom: 24px;
  max-width: 64ch;
}

.sec-section-head .eyebrow {
  color: #006A60;
  font-weight: 600;
}

.sec-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.sec-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 980px) {
  .sec-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 600px) {
  .sec-grid, .sec-grid-2 {
    grid-template-columns: 1fr;
  }
}
.sec-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 22px 22px;
  background: var(--ivory);
  border: 1px solid var(--sec-border);
  border-radius: 16px;
  transition: transform 0.18s ease, border-color 0.18s ease;
}

.sec-card:hover {
  transform: translateY(-1px);
  border-color: var(--copper);
}

.sec-card-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--sec-tint-strong);
  color: var(--copper-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.sec-card-icon svg {
  width: 22px;
  height: 22px;
}

.sec-card-title {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.35;
}

.sec-card-body {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--charcoal-2);
}

.sec-card-body code {
  font-size: 12.5px;
  padding: 1px 5px;
  background: var(--sec-tint-strong);
  border-radius: 4px;
  color: var(--ink);
}

.sec-honesty {
  margin-top: 56px;
}

.sec-honesty-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

@media (max-width: 760px) {
  .sec-honesty-grid {
    grid-template-columns: 1fr;
  }
}
.sec-honesty-card {
  padding: 24px 26px;
  background: var(--ivory);
  border: 1px dashed rgba(0, 3, 213, 0.2);
  border-radius: 16px;
}

.sec-honesty-card h3 {
  margin: 0 0 8px;
  font-size: 16px;
  color: var(--ink);
}

.sec-honesty-card p {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--charcoal-2);
}

.about-partners .section-head {
  margin-bottom: 22px;
}

.partners-marquee {
  position: relative;
  overflow: hidden;
  margin-top: 20px;
  -webkit-mask-image: linear-gradient(to right, transparent 0, black 8%, black 92%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0, black 8%, black 92%, transparent 100%);
}

.partners-marquee-track {
  display: flex;
  gap: 48px;
  width: max-content;
  animation: partners-scroll 40s linear infinite;
  padding: 8px 0;
}

.partners-marquee:hover .partners-marquee-track {
  animation-play-state: paused;
}

.partner-logo {
  flex: 0 0 auto;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.7;
  transition: opacity 0.2s ease;
}

.partner-logo:hover {
  opacity: 1;
}

.partner-logo img {
  height: 100%;
  width: auto;
  max-width: 240px;
  object-fit: contain;
}

@keyframes partners-scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
@media (prefers-reduced-motion: reduce) {
  .partners-marquee-track {
    animation: none;
  }
}
.roadmap-entry-head {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.roadmap-date {
  font-size: 13px;
  font-weight: 500;
  color: var(--charcoal-3);
  letter-spacing: 0.04em;
}

.roadmap-status-pill {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
}

.roadmap-status-pill[data-tone=shipped] {
  background: rgba(0, 194, 175, 0.15);
  color: var(--copper-deep);
}

.roadmap-status-pill[data-tone=progress] {
  background: rgba(0, 208, 239, 0.18);
  color: #0a7a9b;
}

.roadmap-status-pill[data-tone=planned] {
  background: var(--ivory-2);
  color: var(--charcoal-3);
  border: 1px solid var(--line);
}

.roadmap-title {
  margin: 0;
  font-size: 19px;
  line-height: 1.35;
  color: var(--ink);
}

.roadmap-body {
  margin: 0;
  font-size: 14px;
  line-height: 1.65;
  color: var(--charcoal-2);
}

.roadmap-empty {
  padding: 32px;
  text-align: center;
  color: var(--charcoal-3);
  border-radius: 16px;
  border: 1px dashed var(--line);
}

.home-roadmap-preview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 18px;
  margin-top: 22px;
}

.home-roadmap-preview-item {
  padding: 20px 22px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--ivory);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.home-roadmap-preview-title {
  margin: 0;
  font-size: 15px;
  line-height: 1.35;
  color: var(--ink);
}

.private-grid {
  grid-template-columns: minmax(300px, 0.85fr) minmax(0, 1.15fr);
  margin-top: 30px;
}

.summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 28px;
}

.summary-block {
  display: grid;
  gap: 12px;
}

.summary-block .stat-value {
  font-size: 42px;
}

.form-grid {
  display: grid;
  gap: 18px;
}

.form-row {
  display: grid;
  gap: 10px;
}

.split-row {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.field-label {
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--charcoal-3);
}

.field-input,
.field-select,
.field-textarea,
.file-shell {
  width: 100%;
  border-radius: 18px;
  border: 1px solid var(--line-strong);
  background: rgba(255, 255, 255, 0.76);
  color: var(--charcoal);
  padding: 16px 18px;
}

.field-input:focus,
.field-select:focus,
.field-textarea:focus,
.file-shell:focus-within {
  outline: none;
  border-color: var(--charcoal);
  box-shadow: 0 0 0 3px rgba(28, 26, 23, 0.06);
}

/* === Création rapide de projet : champs sans box, grille de pays === */
.project-new-form {
  display: grid;
  gap: 22px;
}

.project-new-form .field-hint {
  margin: -4px 0 2px;
  font-size: 14px;
  color: var(--charcoal-3);
}

.project-new-form .field-note {
  margin: 0;
  font-size: 13px;
  color: var(--charcoal-3);
  line-height: 1.5;
}

.zone-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.zone-button {
  padding: 6px 14px;
  border-radius: 20px;
  border: 1px solid var(--line-strong);
  background: rgba(255, 255, 255, 0.76);
  font-size: 0.85rem;
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease;
}

.zone-button:hover {
  border-color: var(--charcoal);
}

.zone-button.is-active {
  border-color: var(--copper);
  background: var(--pill-teal-soft);
  color: var(--charcoal);
}

.country-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
}

.country-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--line-strong);
  background: rgba(255, 255, 255, 0.76);
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.country-card:hover {
  border-color: var(--charcoal);
}

.country-card input[type=checkbox] {
  width: 18px;
  height: 18px;
  margin: 0;
  flex: 0 0 auto;
  accent-color: var(--copper);
  cursor: pointer;
}

.country-card:has(input:checked) {
  border-color: var(--copper);
  background: var(--pill-teal-soft);
  box-shadow: 0 0 0 1px var(--copper) inset;
}

.country-flag {
  font-size: 18px;
  line-height: 1;
  flex: 0 0 auto;
  border-radius: 2px;
}

.country-name {
  font-size: 14px;
  color: var(--charcoal);
}

.country-other {
  margin-top: 4px;
}

/* Axes de relecture : cartes à cocher, 4 colonnes sur une seule ligne */
.axis-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 720px) {
  .axis-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.axis-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid var(--line-strong);
  background: rgba(255, 255, 255, 0.76);
  cursor: pointer;
  overflow: hidden;
  transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.axis-card:hover {
  border-color: var(--charcoal);
}

.axis-card input[type=checkbox] {
  width: 18px;
  height: 18px;
  margin: 2px 0 0;
  flex: 0 0 auto;
  accent-color: var(--copper);
  cursor: pointer;
}

.axis-card:has(input:checked) {
  border-color: var(--copper);
  background: var(--pill-teal-soft);
  box-shadow: 0 0 0 1px var(--copper) inset;
}

.axis-card.is-soon {
  opacity: 0.6;
  cursor: not-allowed;
}

.axis-card.is-soon input[type=checkbox] {
  cursor: not-allowed;
}

.axis-body {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.axis-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--charcoal);
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.axis-soon {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  color: var(--copper-deep);
  border: 1px solid var(--copper);
  border-radius: 999px;
  padding: 1px 8px;
}

.axis-desc {
  font-size: 12px;
  color: var(--charcoal-3);
  line-height: 1.45;
}

/* Référentiels réglementaires : cartes à cocher */
.regulation-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
}

.regulation-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--line-strong);
  background: rgba(255, 255, 255, 0.76);
  cursor: pointer;
  transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

.regulation-card:hover {
  border-color: var(--charcoal);
}

.regulation-card input[type=checkbox] {
  width: 18px;
  height: 18px;
  margin: 2px 0 0;
  flex: 0 0 auto;
  accent-color: var(--copper);
  cursor: pointer;
}

.regulation-card:has(input:checked) {
  border-color: var(--copper);
  background: var(--pill-teal-soft);
  box-shadow: 0 0 0 1px var(--copper) inset;
}

.regulation-card {
  align-items: center;
}

.regulation-card .regulation-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
}

/* Message de succès de formulaire (ex. préférences enregistrées) */
.form-success {
  margin: 0;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid var(--copper);
  background: var(--pill-teal-soft);
  color: var(--copper-deep);
  font-size: 14px;
}

/* Console admin : tableaux sans box (on retire le chrome du .panel autour) */
.app-shell.is-private .admin-main .panel:has(.pricing-table-wrap) {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  min-width: 0;
  overflow: hidden;
}

/* Modale « solde insuffisant » (fiche projet, après tentative de lancement) */
.credit-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgba(0, 11, 112, 0.32);
  backdrop-filter: blur(2px);
}

.credit-modal {
  width: 100%;
  max-width: 460px;
  display: grid;
  gap: 14px;
  padding: 28px;
  border-radius: var(--radius-lg);
  background: #fff;
  box-shadow: 0 24px 60px rgba(0, 11, 112, 0.22);
}

.credit-breakdown {
  display: grid;
  gap: 8px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.7);
}

.credit-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  font-size: 14px;
}

.credit-row span {
  color: var(--charcoal-3);
}

.credit-row.is-missing strong,
.credit-row--danger strong {
  color: #c0392b;
}

.credit-row--ok strong {
  color: var(--ok);
}

.credit-modal-eyebrow {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--charcoal-3);
}

.credit-modal-eyebrow--danger {
  color: #c0392b;
}

.credit-modal-headline {
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--charcoal);
}

.credit-modal-copy {
  font-size: 14px;
  color: var(--charcoal-3);
  line-height: 1.55;
}

.credit-modal-spinner {
  width: 36px;
  height: 36px;
  border: 3px solid var(--line);
  border-top-color: var(--ink);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  margin: 8px auto;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.credit-modal-actions {
  display: flex;
  gap: 10px;
  justify-content: center;
  margin-top: 6px;
}

.action-button--outline {
  background: transparent;
  border: 2px solid var(--ink);
  color: var(--ink);
}

.action-button--outline:hover {
  background: rgba(0, 11, 112, 0.06);
}

.action-button--danger {
  background: var(--danger);
  border-color: var(--danger);
  color: #fff;
}

.action-button--danger:hover {
  background: #a82020;
}

.ai-lab-document-strip,
.ai-lab-run-panel {
  margin-top: 18px;
}

.ai-lab-review-shell {
  margin-top: 18px;
}

.ai-lab-review-menu {
  display: grid;
  grid-template-columns: auto repeat(4, minmax(0, 1fr));
  gap: 10px;
  align-items: stretch;
}

.ai-lab-menu-title {
  display: inline-flex;
  align-items: center;
  color: var(--charcoal-3);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.ai-lab-review-tab {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 72px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.58);
  color: var(--charcoal);
  text-decoration: none;
}

.ai-lab-review-tab span {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.ai-lab-review-tab strong,
.ai-lab-review-tab small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ai-lab-review-tab small {
  color: var(--charcoal-3);
  font-size: 12px;
}

.ai-lab-review-tab em {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 28px;
  height: 28px;
  border-radius: 999px;
  background: var(--cloud);
  color: var(--charcoal-3);
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
}

.ai-lab-review-tab:hover,
.ai-lab-review-tab.is-active {
  border-color: var(--charcoal);
  background: #ffffff;
}

.ai-lab-review-tab.is-active em {
  background: var(--charcoal);
  color: #ffffff;
}

.ai-lab-review-page {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 18px;
  align-items: center;
  margin-top: 14px;
}

.ai-lab-process-flow {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.ai-lab-process-flow span {
  min-height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.52);
  color: var(--charcoal-3);
  font-size: 12px;
  font-weight: 700;
  text-align: center;
}

.ai-lab-process-flow span:not(:last-child),
.ai-lab-process-flow span.is-enabled {
  color: var(--charcoal);
  background: #ffffff;
}

.ai-lab-active-service-field {
  display: grid;
  gap: 6px;
}

.ai-lab-active-service-field small {
  color: var(--charcoal-3);
  font-size: 12px;
  line-height: 1.4;
}

.ai-lab-document-panel .form-grid {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
}

.ai-lab-run-panel .form-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: start;
}

.ai-lab-run-panel .form-row,
.ai-lab-workflow-builder {
  min-width: 0;
}

.ai-lab-workflow-builder {
  grid-column: 1/-1;
}

.ai-lab-provider-row {
  grid-column: 1/-1;
}

.ai-lab-provider-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}

.ai-lab-provider-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.46);
  cursor: pointer;
}

.ai-lab-provider-toggle input {
  width: 18px;
  height: 18px;
  margin: 0;
}

.ai-lab-provider-toggle span {
  display: grid;
  gap: 2px;
}

.ai-lab-provider-toggle small {
  color: var(--charcoal-3);
  font-size: 12px;
}

.ai-lab-field-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.ai-lab-inline-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.ai-lab-submit-row {
  grid-column: 1/-1;
  justify-content: flex-end;
}

.ai-lab-model-list {
  display: grid;
  gap: 12px;
}

.ai-lab-model-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.42);
}

.ai-lab-workflow-row {
  grid-template-columns: minmax(110px, 0.7fr) minmax(140px, 0.95fr) minmax(150px, 1fr) minmax(78px, 0.42fr) minmax(190px, 1.2fr) minmax(190px, 1.15fr) auto;
}

.ai-lab-model-actions {
  display: flex;
  gap: 6px;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-self: center;
}

.ai-lab-icon-button {
  width: 36px;
  min-width: 36px;
  min-height: 36px;
  justify-content: center;
  padding: 0;
  font-size: 15px;
  line-height: 1;
  letter-spacing: 0;
  text-transform: none;
}

.subtle-button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.subtle-button:disabled:hover {
  border-color: var(--line);
}

@media (max-width: 1180px) {
  .ai-lab-review-menu {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .ai-lab-menu-title {
    grid-column: 1/-1;
  }
  .ai-lab-review-page {
    grid-template-columns: 1fr;
  }
  .ai-lab-run-panel .form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .ai-lab-workflow-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .ai-lab-model-actions {
    justify-content: flex-start;
  }
}
@media (max-width: 720px) {
  .ai-lab-review-menu,
  .ai-lab-process-flow {
    grid-template-columns: 1fr;
  }
  .ai-lab-review-tab strong,
  .ai-lab-review-tab small {
    white-space: normal;
  }
  .ai-lab-document-panel .form-grid,
  .ai-lab-run-panel .form-grid {
    grid-template-columns: 1fr;
  }
  .ai-lab-field-head {
    align-items: stretch;
  }
  .ai-lab-inline-actions {
    width: 100%;
  }
  .ai-lab-inline-actions .subtle-button {
    flex: 1 1 140px;
    justify-content: center;
  }
  .ai-lab-model-row,
  .ai-lab-workflow-row {
    grid-template-columns: 1fr;
  }
  .ai-lab-model-actions {
    justify-content: flex-start;
  }
}
.password-field-control {
  position: relative;
}

.password-field-control .field-input {
  padding-right: 104px;
}

.password-toggle {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--charcoal-2);
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 700;
  padding: 8px 12px;
}

.password-toggle:hover,
.password-toggle:focus-visible {
  color: var(--charcoal);
  border-color: var(--line-strong);
  outline: none;
}

.field-textarea {
  min-height: 140px;
  resize: vertical;
}

.field-hint,
.muted {
  color: var(--charcoal-3);
  line-height: 1.6;
}

.field-hint {
  font-size: 13px;
}

.checkbox-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  line-height: 1.65;
  color: var(--charcoal-2);
}

.checkbox-row input {
  width: 18px;
  height: 18px;
  accent-color: var(--charcoal);
  margin-top: 2px;
}

.checkbox-group {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 10px;
}

.checkbox-line {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.42);
}

.checkbox-line input {
  width: 18px;
  height: 18px;
  margin-top: 3px;
  accent-color: var(--charcoal);
}

.checkbox-line span {
  display: grid;
  gap: 2px;
}

.checkbox-line small {
  color: var(--charcoal-3);
  line-height: 1.4;
}

.altcha-register-row {
  display: grid;
  gap: 8px;
}

.altcha-register-row altcha-widget {
  --altcha-max-width: 100%;
  --altcha-border-radius: 8px;
  --altcha-color-border: #d8d1c1;
  --altcha-color-border-focus: #264039;
  --altcha-color-active: #264039;
  --altcha-color-text: #26312e;
}

.project-list {
  display: grid;
  gap: 14px;
}

.project-row {
  display: grid;
  gap: 14px;
  cursor: pointer;
}

.project-row:hover {
  transform: translateY(-2px);
  border-color: rgba(28, 26, 23, 0.28);
}

.project-topline,
.inline-cluster {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.project-title {
  margin: 0;
  font-family: var(--serif);
  font-size: 30px;
  line-height: 0.96;
  letter-spacing: -0.04em;
}

.project-footer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  border-top: 1px solid var(--line);
  padding-top: 14px;
}

.workflow-panel {
  margin-top: 24px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(245, 249, 250, 0.78)), radial-gradient(circle at 12% 16%, rgba(0, 194, 175, 0.12), transparent 42%);
  box-shadow: var(--shadow-soft);
}

.workflow-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px;
  flex-wrap: wrap;
}

.workflow-panel .section-title {
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.08;
}

.workflow-credit-pill {
  display: grid;
  gap: 2px;
  justify-items: end;
  min-width: 160px;
  padding: 14px 16px;
  border: 1px solid rgba(0, 194, 175, 0.24);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.72);
}

.workflow-credit-pill span {
  font-family: var(--serif);
  font-size: 34px;
  line-height: 1;
  color: var(--copper-deep);
}

.workflow-credit-pill small {
  color: var(--charcoal-2);
  font-size: 12px;
}

.workflow-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.workflow-step {
  display: grid;
  align-content: start;
  gap: 8px;
  min-height: 128px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.58);
  color: var(--charcoal-2);
}

.workflow-step-number {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: rgba(87, 87, 86, 0.1);
  color: var(--charcoal);
  font-size: 12px;
  font-weight: 800;
}

.workflow-step strong {
  color: var(--charcoal);
}

.workflow-step span:last-child {
  font-size: 13px;
  line-height: 1.45;
}

.workflow-step[data-state=active] {
  border-color: rgba(0, 194, 175, 0.42);
  background: rgba(0, 194, 175, 0.08);
}

.workflow-step[data-state=active] .workflow-step-number {
  background: var(--copper);
  color: #fff;
}

.workflow-step[data-state=completed] {
  border-color: rgba(47, 133, 90, 0.3);
  background: rgba(47, 133, 90, 0.08);
}

.workflow-step[data-state=completed] .workflow-step-number {
  background: var(--ok);
  color: #fff;
}

.workflow-step[data-state=danger] {
  border-color: rgba(197, 48, 48, 0.32);
  background: rgba(197, 48, 48, 0.08);
}

.workflow-step[data-state=danger] .workflow-step-number {
  background: var(--danger);
  color: #fff;
}

.project-next-action {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.58);
}

.project-next-action span {
  color: var(--charcoal-3);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.project-next-action strong {
  color: var(--charcoal);
}

.project-next-action em {
  color: var(--charcoal-2);
  font-size: 13px;
  font-style: normal;
  line-height: 1.45;
}

.project-next-action[data-tone=active],
.project-next-action[data-tone=queued] {
  border-color: rgba(0, 194, 175, 0.3);
}

.project-next-action[data-tone=danger] {
  border-color: rgba(197, 48, 48, 0.3);
  background: rgba(197, 48, 48, 0.06);
}

.project-next-action[data-tone=warning] {
  border-color: rgba(221, 107, 32, 0.3);
  background: rgba(221, 107, 32, 0.07);
}

.project-next-action[data-tone=completed] {
  border-color: rgba(47, 133, 90, 0.3);
  background: rgba(47, 133, 90, 0.06);
}

.insights-disclosure {
  margin-top: 24px;
}

.insights-disclosure > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 18px 22px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.64);
  box-shadow: var(--shadow-soft);
  cursor: pointer;
  list-style: none;
}

.insights-disclosure > summary::-webkit-details-marker {
  display: none;
}

.insights-disclosure summary span:first-child {
  display: grid;
  gap: 3px;
}

.insights-disclosure summary small {
  color: var(--charcoal-2);
  font-size: 13px;
}

.insights-disclosure-icon {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: rgba(0, 194, 175, 0.1);
  color: var(--copper-deep);
  font-weight: 800;
}

.insights-disclosure[open] .insights-disclosure-icon {
  transform: rotate(45deg);
}

.insights-disclosure > .panel {
  margin-top: 12px;
}

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.kpi-item {
  display: grid;
  gap: 8px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.54);
}

.kpi-item strong {
  font-family: var(--serif);
  font-size: 34px;
  line-height: 0.95;
  letter-spacing: -0.05em;
}

.upload-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.file-shell {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  overflow: hidden;
}

.file-shell input[type=file] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.file-shell strong {
  display: block;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.file-name {
  color: var(--charcoal-3);
  font-size: 13px;
}

.detail-grid {
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
  margin-top: 28px;
}

.detail-section {
  display: grid;
  gap: 18px;
}

.detail-section + .detail-section {
  margin-top: 22px;
}

.timeline {
  display: grid;
  gap: 12px;
}

.timeline-row {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 14px 0;
  border-top: 1px solid var(--line);
}

.timeline-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.progress-bar {
  position: relative;
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(28, 26, 23, 0.08);
}

.progress-bar > span {
  position: absolute;
  inset: 0 auto 0 0;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--copper), var(--copper-deep));
  transition: width 0.4s ease;
}

.phases-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.phase-card {
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--paper);
  display: grid;
  gap: 8px;
}

.phase-card[data-status=completed] {
  border-color: rgba(55, 87, 63, 0.35);
  background: rgba(55, 87, 63, 0.06);
}

.phase-card[data-status=running] {
  border-color: rgba(184, 115, 51, 0.45);
  background: rgba(184, 115, 51, 0.08);
}

.phase-card[data-status=failed] {
  border-color: rgba(139, 59, 50, 0.45);
  background: rgba(139, 59, 50, 0.06);
}

.phase-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.phase-label {
  font-weight: 600;
}

.findings-list,
.artifacts-list,
.meta-list {
  display: grid;
  gap: 12px;
}

.finding-item,
.artifact-item {
  padding: 16px 0;
  border-top: 1px solid var(--line);
}

.finding-item:first-child,
.artifact-item:first-child {
  padding-top: 0;
  border-top: 0;
}

.finding-item details {
  margin-top: 10px;
}

.finding-item summary {
  cursor: pointer;
  color: var(--copper-deep);
}

.findings-panel {
  display: grid;
  gap: 18px;
}

.findings-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0, 194, 175, 0.05);
}

.findings-filter-menus {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  min-width: 0;
}

.findings-filter-menu {
  position: relative;
}

.findings-filter-menu summary {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-width: 190px;
  min-height: 40px;
  padding: 8px 11px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--paper-strong);
  color: var(--charcoal-2);
  cursor: pointer;
  list-style: none;
}

.findings-filter-menu summary::-webkit-details-marker {
  display: none;
}

.findings-filter-menu summary::after {
  content: "▾";
  color: var(--copper-deep);
  font-size: 12px;
}

.findings-filter-menu[open] summary {
  border-color: var(--copper-deep);
  box-shadow: 0 0 0 3px rgba(0, 194, 175, 0.12);
}

.findings-filter-menu summary strong {
  color: var(--charcoal);
  font-size: 13px;
}

.findings-filter-popover {
  position: absolute;
  z-index: 30;
  top: calc(100% + 8px);
  left: 0;
  display: grid;
  gap: 8px;
  min-width: 260px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 18px 46px rgba(0, 3, 213, 0.14);
}

.findings-bulk-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  margin-left: auto;
}

.findings-filter-group {
  display: grid;
  gap: 8px;
}

.findings-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.findings-filter-button {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 38px;
  padding: 8px 11px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--paper-strong);
  color: var(--charcoal-2);
  cursor: pointer;
  transition: border-color 160ms ease, background 160ms ease, color 160ms ease, transform 160ms ease;
}

.findings-filter-button:hover {
  border-color: rgba(0, 172, 197, 0.45);
  transform: translateY(-1px);
}

.findings-filter-button strong {
  min-width: 22px;
  padding: 2px 6px;
  border-radius: 6px;
  background: rgba(87, 87, 86, 0.08);
  color: var(--charcoal);
  font-size: 12px;
  text-align: center;
}

.findings-filter-button.is-active {
  border-color: var(--copper-deep);
  background: var(--copper-deep);
  color: #ffffff;
}

.findings-filter-button.is-active strong {
  background: rgba(255, 255, 255, 0.18);
  color: #ffffff;
}

.findings-card-grid {
  display: grid;
  gap: 12px;
}

.finding-card {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--copper);
  border-radius: 8px;
  background: var(--paper-strong);
  box-shadow: 0 12px 34px rgba(0, 3, 213, 0.06);
}

.finding-card.is-pending-delete {
  border-color: rgba(197, 48, 48, 0.34);
  border-left-color: var(--danger);
  background: rgba(197, 48, 48, 0.04);
}

.finding-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.finding-card-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.finding-index,
.finding-page {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 7px;
  border-radius: 6px;
  background: rgba(0, 3, 213, 0.08);
  color: var(--ink);
  font-size: 12px;
  font-weight: 700;
}

.finding-page {
  flex: 0 0 auto;
  background: rgba(0, 194, 175, 0.1);
  color: var(--copper-deep);
}

.finding-pending-badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 7px;
  border-radius: 6px;
  background: rgba(197, 48, 48, 0.1);
  color: var(--danger);
  font-size: 12px;
  font-weight: 700;
}

.finding-card-title {
  margin: 0;
  color: var(--charcoal);
  font-size: 16px;
  line-height: 1.35;
}

.finding-comment,
.finding-excerpt,
.finding-reference,
.finding-detail p,
.finding-advice p {
  margin: 0;
  line-height: 1.55;
}

.finding-comment {
  color: var(--charcoal-2);
}

.finding-excerpt {
  padding-left: 12px;
  border-left: 3px solid rgba(0, 194, 175, 0.32);
  color: var(--charcoal-3);
  font-size: 13px;
}

.finding-advice {
  display: grid;
  gap: 5px;
  padding: 11px 12px;
  border: 1px solid rgba(47, 133, 90, 0.18);
  border-radius: 8px;
  background: rgba(47, 133, 90, 0.06);
}

.finding-detail {
  display: grid;
  gap: 5px;
}

.finding-detail span,
.finding-advice span {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.finding-detail span {
  color: var(--muted);
}

.finding-detail.is-quote p {
  padding-left: 12px;
  border-left: 3px solid rgba(0, 194, 175, 0.32);
  color: var(--charcoal-3);
  font-size: 13px;
}

.finding-detail.is-reference p {
  color: var(--charcoal);
  font-weight: 700;
}

.finding-advice span {
  color: var(--ok);
}

.finding-reference {
  color: var(--charcoal-3);
  font-size: 13px;
}

.finding-card-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  padding-top: 4px;
}

.subtle-button.is-danger {
  color: var(--danger);
}

.artifact-note {
  font-size: 13px;
  color: var(--charcoal-3);
}

.auth-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
  gap: 28px;
  align-items: stretch;
  min-height: calc(100vh - 130px);
  padding-top: 28px;
}

.auth-shell-login {
  align-items: center;
  min-height: calc(100vh - 220px);
  padding-top: 56px;
  padding-bottom: 80px;
}

.auth-copy {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 30px;
}

.auth-shell-login .auth-copy {
  justify-content: center;
}

.auth-panel {
  display: grid;
  gap: 22px;
  align-self: center;
}

.auth-title {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(36px, 5vw, 64px);
  line-height: 0.95;
  letter-spacing: -0.05em;
}

.auth-list {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.auth-list li {
  display: flex;
  gap: 12px;
  line-height: 1.65;
}

.auth-list li::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 10px;
  background: var(--copper);
  flex: 0 0 auto;
}

.terms-modal {
  position: fixed;
  inset: 30px;
  z-index: 30;
  border-radius: 28px;
  border: 1px solid var(--line-strong);
  background: var(--paper-strong);
  box-shadow: 0 30px 90px rgba(17, 15, 13, 0.16);
  overflow: hidden;
  display: grid;
  grid-template-rows: auto 1fr;
}

.terms-modal header {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: center;
  padding: 24px 28px;
  border-bottom: 1px solid var(--line);
}

.terms-body {
  padding: 28px;
  overflow: auto;
  line-height: 1.8;
}

.terms-body h1,
.terms-body h2 {
  font-family: var(--serif);
  letter-spacing: -0.04em;
}

.terms-body h1 {
  font-size: 40px;
  line-height: 0.96;
}

.terms-body h2 {
  margin-top: 28px;
  font-size: 24px;
}

.terms-body p,
.terms-body ul {
  margin: 14px 0 0;
}

.terms-body ul {
  padding-left: 20px;
}

.overlay {
  position: fixed;
  inset: 0;
  background: rgba(22, 19, 17, 0.4);
  z-index: 20;
}

.toast {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 40;
  max-width: min(420px, 100vw - 36px);
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid var(--line-strong);
  background: rgba(250, 247, 241, 0.88);
  box-shadow: var(--shadow-soft);
}

.toast[data-tone=error] {
  border-color: rgba(139, 59, 50, 0.28);
}

.toast-stack {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 45;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: min(380px, 100vw - 40px);
  pointer-events: none;
}

.toast-item {
  pointer-events: auto;
  position: relative;
  padding: 12px 44px 12px 16px;
  border-radius: 14px;
  border: 1px solid var(--line-strong);
  background: rgba(250, 247, 241, 0.94);
  box-shadow: 0 14px 30px rgba(27, 24, 21, 0.14);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  display: grid;
  gap: 2px;
  font-size: 13px;
  animation: toast-in 240ms cubic-bezier(0.2, 0.8, 0.2, 1);
  transition: opacity 400ms ease, transform 400ms cubic-bezier(0.4, 0, 0.2, 1), filter 400ms ease;
  transform-origin: bottom right;
}

.toast-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 999px;
  background: rgba(27, 24, 21, 0.06);
  color: var(--charcoal-3);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font: inherit;
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
}

.toast-close:hover,
.toast-close:focus-visible {
  background: rgba(27, 24, 21, 0.12);
  color: var(--charcoal);
  outline: none;
}

.toast-item strong {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--charcoal-3);
}

.toast-item p {
  margin: 0;
  line-height: 1.45;
  color: var(--charcoal);
  overflow-wrap: anywhere;
}

.toast-item[data-tone=error] {
  border-color: rgba(139, 59, 50, 0.35);
}

.toast-item[data-tone=error] strong {
  color: var(--danger);
}

.toast-item.is-leaving {
  opacity: 0;
  transform: translateY(-10px) scale(0.98);
  filter: blur(6px);
}

@keyframes toast-in {
  from {
    opacity: 0;
    transform: translateY(14px) scale(0.96);
    filter: blur(2px);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}
.loading-overlay {
  position: fixed;
  inset: auto 24px 24px auto;
  z-index: 50;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-radius: 999px;
  border: 1px solid var(--line-strong);
  background: rgba(250, 247, 241, 0.9);
  box-shadow: var(--shadow-soft);
}

.spinner {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid rgba(28, 26, 23, 0.16);
  border-top-color: var(--charcoal);
  animation: spin 0.85s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.empty-state {
  display: grid;
  gap: 12px;
  text-align: left;
}

.subtle-button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.48);
  cursor: pointer;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.subtle-button:hover {
  border-color: var(--charcoal);
}

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

/* ==== Editorial polish v6 ==== */
/* Section heads align to top (long titles + buttons at top, not at bottom baseline) */
.section-head {
  align-items: flex-start;
  flex-wrap: wrap;
}

/* Scale detail section titles down - the huge 44px is for the homepage hero */
.detail-section .section-title {
  font-size: clamp(22px, 2vw, 28px);
  line-height: 1.1;
  letter-spacing: -0.03em;
}

/* Breathing room between stacked blocks */
.detail-section + .detail-section {
  margin-top: 28px;
}

.summary-grid {
  gap: 20px;
  margin-top: 32px;
}

.detail-grid {
  gap: 28px;
  margin-top: 32px;
}

/* Long filenames, mime-types and text must never escape their card */
.artifact-item p,
.finding-item p,
.finding-card p,
.finding-card-title,
.artifact-note,
.meta-row,
.stat-value,
.phase-label,
.file-name,
.section-copy {
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Stat values responsive instead of fixed 42px */
.summary-block .stat-value {
  font-size: clamp(26px, 3.2vw, 40px);
}

/* Stat labels wrap cleanly */
.stat-label {
  white-space: normal;
  line-height: 1.4;
}

/* Chips never wrap internally */
.status-chip,
.axis-chip {
  white-space: nowrap;
}

/* Pricing panel title smaller + consistent */
.detail-section .section-title strong {
  font-family: var(--serif);
  color: var(--copper-deep);
  font-weight: 600;
}

/* Phase card editorial tone */
.phase-card {
  padding: 16px 18px;
}

.phase-label {
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: -0.02em;
  line-height: 1.15;
}

.phase-card .muted {
  font-size: 12px;
  letter-spacing: 0.04em;
}

/* Summary block: spacing between label/value/hint */
.summary-block {
  gap: 10px;
}

/* Tabs - used on Account page */
.tabs {
  display: flex;
  gap: 4px;
  margin: 28px 0 20px;
  padding: 6px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.58);
  overflow-x: auto;
}

.tab {
  flex: 0 0 auto;
  padding: 10px 18px;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: var(--charcoal-2);
  font: inherit;
  font-size: 13px;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}

.tab:hover {
  color: var(--charcoal);
}

.tab.is-active {
  background: var(--charcoal);
  color: var(--ivory);
}

.tab-panel {
  display: grid;
  gap: 24px;
}

/* Members / ledger table */
.members-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.members-table thead th {
  text-align: left;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--charcoal-3);
  font-weight: 500;
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
}

.members-table tbody td {
  padding: 14px 12px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}

.members-table tbody tr:last-child td {
  border-bottom: 0;
}

.members-table tbody tr:hover {
  background: rgba(255, 255, 255, 0.52);
}

@media (max-width: 720px) {
  .workflow-panel {
    padding: 18px;
  }
  .workflow-credit-pill {
    justify-items: start;
    width: 100%;
  }
  .workflow-steps {
    grid-template-columns: 1fr;
  }
  .workflow-step {
    min-height: auto;
  }
  .insights-disclosure > summary {
    align-items: flex-start;
  }
  .dashboard-toolbar {
    align-items: stretch;
    flex-direction: column;
  }
  .dashboard-search {
    flex-basis: auto;
    min-width: 0;
  }
  .dashboard-toolbar-meta {
    justify-content: space-between;
  }
  .dashboard-toolbar .ghost-button {
    width: 100%;
    justify-content: center;
  }
  .members-table {
    font-size: 13px;
  }
  .members-table thead th,
  .members-table tbody td {
    padding: 10px 8px;
  }
}
/* Credits panel - hero card on Projects page */
.credits-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(240px, 0.8fr);
  gap: 28px;
  padding: 28px 32px;
  margin-top: 28px;
  border-radius: var(--radius-xl);
  border: 1px solid var(--line);
  background: radial-gradient(circle at 12% 28%, rgba(184, 115, 51, 0.14), transparent 52%), linear-gradient(140deg, rgba(250, 247, 241, 0.94), rgba(239, 232, 218, 0.8));
  box-shadow: var(--shadow-soft);
  align-items: center;
}

.credits-panel.is-low {
  border-color: rgba(139, 59, 50, 0.35);
  background: radial-gradient(circle at 12% 28%, rgba(139, 59, 50, 0.18), transparent 52%), linear-gradient(140deg, rgba(250, 247, 241, 0.94), rgba(239, 232, 218, 0.8));
}

.credits-main {
  display: grid;
  gap: 10px;
}

.credits-amount {
  font-family: var(--serif);
  font-size: clamp(42px, 6vw, 72px);
  line-height: 1;
  letter-spacing: -0.05em;
  color: var(--copper-deep);
}

.credits-amount span {
  font-size: 0.42em;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--charcoal-3);
  font-family: var(--sans);
  margin-left: 8px;
  vertical-align: middle;
}

.credits-copy {
  color: var(--charcoal-2);
  max-width: 58ch;
  line-height: 1.6;
}

.credits-ratio {
  margin: 0;
  color: var(--copper-deep);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.credits-actions {
  display: grid;
  gap: 10px;
  align-items: start;
  justify-items: end;
}

.credits-actions .muted {
  text-align: right;
  font-size: 12px;
  letter-spacing: 0.04em;
}

@media (max-width: 900px) {
  .credits-panel {
    grid-template-columns: 1fr;
    padding: 24px;
  }
  .credit-pack-grid {
    grid-template-columns: 1fr;
  }
  .credits-actions {
    justify-items: start;
  }
  .credits-actions .muted {
    text-align: left;
  }
}
/* Pricing panel - editorial look */
.pricing-panel .section-title {
  font-family: var(--serif);
  color: var(--copper-deep);
  font-size: clamp(32px, 4vw, 48px);
  letter-spacing: -0.04em;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 14px;
  padding-top: 8px;
  border-top: 1px solid var(--line);
}

.pricing-axis {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.42);
  border: 1px solid var(--line);
}

.pricing-amount {
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: -0.02em;
  color: var(--charcoal);
}

.pricing-note {
  font-size: 14px;
  line-height: 1.6;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  background: rgba(184, 115, 51, 0.08);
  color: var(--charcoal-2);
  margin: 0;
}

.pricing-note strong {
  color: var(--copper-deep);
}

/* Buttons inside artifact/file rows */
.artifact-item .button-row,
.finding-item .button-row {
  margin-top: 10px;
}

/* Upload blocks: more compact to leave room for file list below */
.upload-grid {
  gap: 16px;
}

/* Section head on narrow screens - stack buttons below title */
@media (max-width: 720px) {
  .section-head {
    gap: 14px;
  }
  .section-head .button-row {
    width: 100%;
  }
  .findings-toolbar {
    display: grid;
    padding: 12px;
  }
  .findings-filter-menus,
  .findings-bulk-actions {
    width: 100%;
  }
  .findings-filter-menu,
  .findings-filter-menu summary {
    width: 100%;
  }
  .findings-filter-popover {
    position: static;
    margin-top: 8px;
    width: 100%;
  }
  .findings-filter-button {
    flex: 1 1 auto;
  }
  .finding-card-head {
    display: grid;
  }
}
@media (max-width: 1100px) {
  .poster,
  .auth-shell,
  .public-grid,
  .private-grid,
  .detail-grid {
    grid-template-columns: 1fr;
  }
  .summary-grid,
  .kpi-grid,
  .upload-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .timeline-row {
    grid-template-columns: 1fr;
    justify-items: start;
  }
}
@media (max-width: 720px) {
  .page,
  .chrome {
    width: min(100% - 28px, var(--content-width));
  }
  .chrome-bar:not(.chrome-bar-public) {
    border-radius: 28px;
    align-items: flex-start;
    flex-direction: column;
  }
  .display {
    font-size: clamp(46px, 16vw, 74px);
  }
  .split-row,
  .summary-grid,
  .kpi-grid,
  .grid-two,
  .upload-grid {
    grid-template-columns: 1fr;
  }
  .panel,
  .auth-panel,
  .detail-section,
  .empty-state {
    padding: 22px;
    border-radius: 24px;
  }
  .panel-subtle {
    align-items: stretch;
    flex-direction: column;
  }
  .document-stripe,
  .project-row,
  .summary-block {
    padding: 18px;
  }
  .target-stage {
    min-height: 460px;
  }
  .target-stage::before {
    width: 320px;
    height: 320px;
    top: 56px;
  }
  .target-stage::after {
    width: 110px;
    height: 110px;
    top: 161px;
  }
  .target-line {
    top: 216px;
    left: 7%;
    right: 7%;
  }
  .terms-modal {
    inset: 12px;
  }
}
@media (max-width: 540px) {
  .display {
    font-size: clamp(42px, 12vw, 50px);
    max-width: 100%;
  }
}
/* === Verify-pending page (PR1+PR2) === */
/* Full-screen "in-progress account" landing after register or before email verified.
   Replaces the discrete auth-panel that owners reported as "just a message at the bottom". */
.verify-pending-page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 80px);
  padding: 32px 16px;
}

.verify-pending-hero {
  width: 100%;
  max-width: 640px;
}

.verify-pending-card {
  background: #fff;
  border: 1px solid rgba(36, 24, 18, 0.08);
  border-radius: 24px;
  padding: 48px 40px;
  box-shadow: 0 30px 80px -40px rgba(36, 24, 18, 0.25);
  text-align: center;
}

.verify-pending-eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  font-weight: 600;
  color: #b8753a;
  margin: 0 0 16px;
}

.verify-pending-title {
  font-size: clamp(24px, 3.4vw, 32px);
  line-height: 1.2;
  font-weight: 700;
  color: #241812;
  margin: 0 0 20px;
  letter-spacing: -0.01em;
}

.verify-pending-lead {
  font-size: 17px;
  line-height: 1.5;
  color: #3d2e25;
  margin: 0 0 12px;
}

.verify-pending-lead strong {
  color: #241812;
  font-weight: 600;
}

.verify-pending-help {
  font-size: 15px;
  color: #6b594d;
  margin: 0 0 32px;
}

.verify-pending-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

.verify-pending-cta {
  min-width: 220px;
}

.verify-pending-cta:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

.verify-pending-error {
  margin: 24px 0 0;
  padding: 12px 16px;
  background: rgba(184, 64, 47, 0.08);
  border: 1px solid rgba(184, 64, 47, 0.25);
  border-radius: var(--r-md);
  color: #8a3322;
  font-size: 14px;
}

.verify-pending-change-form {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid rgba(36, 24, 18, 0.08);
  text-align: left;
}

.verify-pending-change-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: center;
  margin-top: 8px;
}

.password-reset-box {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.password-reset-box summary {
  cursor: pointer;
  color: var(--copper-deep);
  font-weight: 600;
}

.password-reset-form {
  margin-top: 14px;
}

@media (max-width: 540px) {
  .scientific-validation-option {
    grid-template-columns: auto minmax(0, 1fr);
  }
  .scientific-validation-price {
    grid-column: 2;
    white-space: normal;
  }
  .verify-pending-card {
    padding: 32px 24px;
    border-radius: 18px;
  }
  .verify-pending-actions {
    flex-direction: column;
  }
  .verify-pending-cta {
    width: 100%;
  }
  .verify-pending-change-row {
    grid-template-columns: 1fr;
  }
}
/* ==========================================================================
   PILL SYSTEM v3.0 - Composants canoniques
   Référence : design.md §4 (pill-mark), §6 (sticker), §8 (chip/numeral),
   §9 (stat-pill, pricing-row), §11.3 (spectrum).
   À utiliser explicitement dans le markup (zone marketing & auth).
   ========================================================================== */
/* §4 - Pill mark : un mot dans une capsule colorée, à l'intérieur d'un titre. */
.pill-mark {
  font-family: var(--font-display);
  font-weight: 600;
  background: var(--pill-blue);
  color: #fff;
  padding: 0.08em 0.32em 0.16em;
  border-radius: var(--r-pill);
  display: inline;
  line-height: 1.15;
  letter-spacing: -0.03em;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.pill-mark.tone-teal {
  background: var(--pill-teal);
  color: #fff;
}

.pill-mark.tone-cyan {
  background: var(--pill-cyan);
  color: var(--pill-ink);
}

.pill-mark.tone-ink {
  background: var(--pill-ink);
  color: var(--pill-bg);
}

.pill-mark.tone-outline {
  background: transparent;
  color: var(--pill-ink);
  box-shadow: inset 0 0 0 2px var(--pill-ink);
}

/* §6 - Sticker : capsule avec rotation légère et ombre dure. */
.sticker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px 11px;
  border-radius: var(--r-pill);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: -0.005em;
  white-space: nowrap;
  box-shadow: var(--sh-sm);
  transform: rotate(var(--rot, -2deg));
  transition: transform 0.25s ease;
}

.sticker:hover {
  transform: rotate(0deg) translateY(-2px);
}

.sticker.tone-blue {
  background: var(--pill-blue);
  color: #fff;
  --rot: -3deg;
}

.sticker.tone-teal {
  background: var(--pill-teal);
  color: #fff;
  --rot: 2deg;
}

.sticker.tone-cyan {
  background: var(--pill-cyan);
  color: #fff;
  --rot: -1deg;
}

.sticker.tone-coral {
  background: var(--pill-blue);
  color: #fff;
  --rot: 3deg;
}

.sticker.tone-yellow {
  background: var(--pill-cyan);
  color: var(--pill-ink);
  --rot: -2deg;
}

.sticker.tone-ink {
  background: var(--pill-ink);
  color: var(--pill-bg);
  --rot: 1deg;
}

.sticker.tone-cream {
  background: var(--pill-bg-card);
  color: var(--pill-ink);
  --rot: -1.5deg;
  box-shadow: var(--sh-sm), inset 0 0 0 1px var(--pill-line);
}

/* §8.1 - Chip : tag mono uppercase. */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px 7px;
  border-radius: var(--r-pill);
  background: var(--pill-line-2);
  color: var(--pill-ink-soft);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 500;
}

.chip.tone-blue {
  background: var(--pill-blue);
  color: #fff;
}

.chip.tone-teal {
  background: var(--pill-teal);
  color: var(--pill-ink);
}

.chip.tone-cyan {
  background: var(--pill-cyan);
  color: var(--pill-ink);
}

.chip.tone-ink {
  background: var(--pill-ink);
  color: var(--pill-bg);
}

.chip.tone-outline {
  background: transparent;
  color: var(--pill-ink);
  box-shadow: inset 0 0 0 1.5px var(--pill-ink);
}

/* §8.2 - Glyphe duo (bleu/teal) pour précéder un eyebrow. */
.duo-glyph {
  display: inline-block;
  width: 20px;
  height: 9px;
  background: linear-gradient(90deg, var(--pill-blue) 0 50%, var(--pill-teal) 50% 100%);
  border-radius: var(--r-pill);
}

/* §8.3 - Section numeral : numéro en pill bleue + texte mono. */
.section-numeral {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--pill-muted);
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-weight: 500;
}

.section-numeral .n {
  background: var(--pill-blue);
  color: #fff;
  padding: 4px 11px 5px;
  border-radius: var(--r-pill);
  font-size: 10px;
  letter-spacing: 0.1em;
  font-weight: 600;
}

/* §9.2 - Stat pill : chiffre clé avec mot en pill. */
.stat-pill {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 24px 28px;
  border-radius: var(--r-xl);
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
}

.stat-pill .num {
  font-family: var(--font-display);
  font-size: 48px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--pill-ink);
}

.stat-pill .num em {
  font-style: normal;
  background: var(--pill-blue);
  color: #fff;
  padding: 0.04em 0.28em 0.14em;
  border-radius: var(--r-pill);
  display: inline-block;
}

.stat-pill .lbl {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--pill-muted);
}

/* §9.3 - Pricing row : ligne tarif en pill. */
.pricing-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 18px 28px;
  border-radius: var(--r-pill);
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  font-family: var(--font-display);
  font-weight: 500;
}

.pricing-row .price {
  font-family: var(--font-mono);
  color: var(--pill-blue);
  font-weight: 600;
}

.pricing-row.featured {
  background: var(--pill-blue);
  color: #fff;
  border-color: var(--pill-blue);
}

.pricing-row.featured .price {
  color: #fff;
}

/* §11.3 - Spectrum bar : ruban duo bleu/teal (à utiliser avec parcimonie). */
.spectrum {
  height: 4px;
  border-radius: var(--r-pill);
  background: linear-gradient(90deg, var(--pill-blue) 0 50%, var(--pill-teal) 50% 100%);
  width: 80px;
}

/* ============================================================
   §12 - Home v3 refresh (mai 2026)
   KPI strip, axes flat, document type skeleton, FAQ tweaks.
   ============================================================ */
/* §12.1 - KPI flottants discrets, alignés à droite de l'eyebrow hero. */
.home-hero-v2-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.home-hero-kpi {
  display: inline-flex;
  align-items: baseline;
  gap: 20px;
  opacity: 0;
  animation: kpi-fade-in 0.6s ease-out 0.25s forwards;
}

@keyframes kpi-fade-in {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.home-hero-kpi-item {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  font-family: var(--font-mono, "JetBrains Mono", ui-monospace, monospace);
}

.home-hero-kpi-value {
  font-family: var(--font-display, "Inter Tight", system-ui, sans-serif);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
  color: var(--pill-ink, #000B70);
}

.home-hero-kpi-value.is-animating {
  color: var(--pill-blue, #000B70);
}

.home-hero-kpi-label {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pill-muted, #6F7493);
}

@media (max-width: 720px) {
  .home-hero-kpi {
    gap: 12px;
  }
  .home-hero-kpi-value {
    font-size: 14px;
  }
  .home-hero-kpi-label {
    font-size: 9px;
  }
}
/* §12.2 - Axes flat (suppression du flip).                     */
.home-axes-grid.home-axes-grid-flat {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.home-axis-flat {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 24px;
  border-radius: 16px;
  background: var(--pill-bg-card, #FFFEFB);
  border: 1px solid var(--pill-line, rgba(0, 11, 112, 0.1));
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.home-axis-flat:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px -22px rgba(0, 11, 112, 0.32);
  border-color: rgba(0, 11, 112, 0.18);
}

.home-axis-flat .capability-index {
  font-family: var(--font-mono, "JetBrains Mono", ui-monospace, monospace);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: rgba(0, 11, 112, 0.42);
}

.home-axis-flat .capability-axis {
  font-family: var(--font-mono, "JetBrains Mono", ui-monospace, monospace);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pill-teal, #007A6F);
  margin: 0;
}

.home-axis-flat .capability-title {
  font-family: var(--font-display, "Inter Tight", system-ui, sans-serif);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.25;
  margin: 0;
}

.home-axis-flat .capability-body {
  font-size: 14px;
  color: var(--pill-ink-soft, #3A3F66);
  line-height: 1.5;
  margin: 0;
}

@media (max-width: 960px) {
  .home-axes-grid.home-axes-grid-flat {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 560px) {
  .home-axes-grid.home-axes-grid-flat {
    grid-template-columns: 1fr;
  }
}
/* §12.3 - Skeleton "lignes noires" devant la carte finding démo. */
.finding-skeleton-preview {
  margin: 28px auto 18px;
  max-width: 720px;
  padding: 22px 28px;
  border-radius: 14px;
  background: var(--pill-bg-card, #FFFEFB);
  border: 1px dashed rgba(0, 11, 112, 0.18);
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
}

.finding-skeleton-label {
  font-family: var(--font-mono, "JetBrains Mono", ui-monospace, monospace);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(0, 11, 112, 0.5);
}

.finding-skeleton-lines {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.finding-skeleton-line {
  --w: 80%;
  --d: 0s;
  display: block;
  height: 5px;
  border-radius: 2px;
  background: var(--pill-ink, #000B70);
  opacity: 0;
  width: 0;
  animation: skeleton-grow 1.4s cubic-bezier(0.22, 0.9, 0.28, 1) forwards;
  animation-delay: var(--d);
  transform-origin: left center;
}

@keyframes skeleton-grow {
  0% {
    width: 0;
    opacity: 0;
  }
  15% {
    opacity: 0.85;
  }
  100% {
    width: var(--w);
    opacity: 0.72;
  }
}
.finding-skeleton-arrow {
  position: absolute;
  bottom: -14px;
  left: 50%;
  transform: translateX(-50%);
  width: 28px;
  height: 28px;
  line-height: 28px;
  text-align: center;
  background: var(--pill-ink, #000B70);
  color: #fff;
  border-radius: 50%;
  font-family: var(--font-display, "Inter Tight", system-ui, sans-serif);
  font-size: 14px;
  font-weight: 600;
}

@media (prefers-reduced-motion: reduce) {
  .finding-skeleton-line {
    animation: none;
    width: var(--w);
    opacity: 0.72;
  }
}
/* §12.4 - Rôles métier sur la page Ce que ça change. */
.ccc-roles-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 24px;
}

.ccc-role {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 22px;
  border-radius: 14px;
  background: var(--pill-bg-card, #FFFEFB);
  border: 1px solid var(--pill-line, rgba(0, 11, 112, 0.1));
}

.ccc-role .capability-axis {
  font-family: var(--font-mono, "JetBrains Mono", ui-monospace, monospace);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pill-teal, #007A6F);
  margin: 0;
}

.ccc-role .capability-title {
  font-family: var(--font-display, "Inter Tight", system-ui, sans-serif);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.25;
  margin: 0;
}

.ccc-role .capability-body {
  font-size: 14px;
  color: var(--pill-ink-soft, #3A3F66);
  line-height: 1.55;
  margin: 0;
}

@media (max-width: 720px) {
  .ccc-roles-grid {
    grid-template-columns: 1fr;
  }
}
/* §12.5 - Liste des 3 règles tarifs (page /tarifs). */
.pricing-rules-list {
  list-style: none;
  margin: 24px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.pricing-rules-list li {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 22px;
  border-radius: 14px;
  background: var(--pill-bg-card, #FFFEFB);
  border: 1px solid var(--pill-line, rgba(0, 11, 112, 0.1));
}

.pricing-rules-list .capability-index {
  font-family: var(--font-mono, "JetBrains Mono", ui-monospace, monospace);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: rgba(0, 11, 112, 0.42);
}

.pricing-rules-list .capability-title {
  font-family: var(--font-display, "Inter Tight", system-ui, sans-serif);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.25;
  margin: 0;
}

.pricing-rules-list .capability-body {
  font-size: 14px;
  color: var(--pill-ink-soft, #3A3F66);
  line-height: 1.55;
  margin: 0;
}

@media (max-width: 820px) {
  .pricing-rules-list {
    grid-template-columns: 1fr;
  }
}
/* §12.6 - Pricing hero chips wrapper (page /tarifs). */
.pricing-hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

/* §12.7 - Tableau de prix replié (page /tarifs). */
.pricing-table-details {
  border: 1px solid var(--pill-line, rgba(0, 11, 112, 0.1));
  border-radius: 14px;
  background: var(--pill-bg-card, #FFFEFB);
  overflow: hidden;
}

.pricing-table-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 24px;
  cursor: pointer;
  list-style: none;
  user-select: none;
  transition: background 0.15s ease;
}

.pricing-table-summary::-webkit-details-marker {
  display: none;
}

.pricing-table-summary::after {
  content: "+";
  flex: 0 0 28px;
  text-align: center;
  width: 28px;
  height: 28px;
  line-height: 26px;
  border-radius: 50%;
  background: var(--pill-ink, #000B70);
  color: #fff;
  font-family: var(--font-display, "Inter Tight", system-ui, sans-serif);
  font-size: 18px;
  font-weight: 600;
  transition: transform 0.18s ease, background 0.18s ease;
}

.pricing-table-details[open] .pricing-table-summary::after {
  content: "−";
  background: var(--pill-blue, #000B70);
}

.pricing-table-summary:hover {
  background: rgba(0, 11, 112, 0.03);
}

.pricing-table-summary-label {
  font-family: var(--font-display, "Inter Tight", system-ui, sans-serif);
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--pill-ink, #000B70);
}

.pricing-table-summary-hint {
  flex: 1;
  text-align: right;
  font-family: var(--font-mono, "JetBrains Mono", ui-monospace, monospace);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pill-muted, #6F7493);
}

.pricing-table-details-body {
  padding: 4px 24px 22px;
  border-top: 1px solid var(--pill-line, rgba(0, 11, 112, 0.1));
}

.pricing-table-details-body .section-copy {
  margin: 14px 0 18px;
}

/* ====================================================================
   REDESIGN V3 — Home, Sécurité, CCC, Roadmap (additions)
   Conforme Pill System v3.0. Réutilise --pill-* déjà définis plus haut.
   ==================================================================== */
/* --- Scroll reveal — visible par défaut, anim au .in (filet de sécurité côté JS) --- */
.home-v3-reveal {
  opacity: 1;
  transform: none;
}

.home-v3-reveal.in {
  animation: home-v3-reveal-up 0.8s cubic-bezier(0.22, 0.68, 0.36, 1) both;
}

.home-v3-reveal-stagger > * {
  opacity: 1;
  transform: none;
}

.home-v3-reveal-stagger.in > * {
  animation: home-v3-reveal-up 0.7s ease both;
}

.home-v3-reveal-stagger.in > *:nth-child(1) {
  animation-delay: 0s;
}

.home-v3-reveal-stagger.in > *:nth-child(2) {
  animation-delay: 0.07s;
}

.home-v3-reveal-stagger.in > *:nth-child(3) {
  animation-delay: 0.14s;
}

.home-v3-reveal-stagger.in > *:nth-child(4) {
  animation-delay: 0.21s;
}

.home-v3-reveal-stagger.in > *:nth-child(5) {
  animation-delay: 0.28s;
}

.home-v3-reveal-stagger.in > *:nth-child(6) {
  animation-delay: 0.35s;
}

@keyframes home-v3-reveal-up {
  from {
    opacity: 0;
    transform: translateY(22px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}
@media (prefers-reduced-motion: reduce) {
  .home-v3-reveal,
  .home-v3-reveal-stagger > *,
  .home-v3-eyebrow-dot::before,
  .home-v3-process-node::after,
  .home-v3-marquee,
  .home-v3-cta-card::before,
  .sec-hero-shield-ring,
  .roadmap-page-v3 .roadmap-entry-dot[data-status=in_progress] {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
  .home-v3-eyebrow-dot::before {
    opacity: 1 !important;
  }
  .sec-hero-shield-ring {
    opacity: 0.35 !important;
  }
  .home-v3-cta-card::before {
    opacity: 0.6 !important;
  }
}
/* --- Section wrappers --- */
.home-v3-section {
  padding: 80px 0;
  position: relative;
}

.home-v3-section-warm {
  background: var(--pill-bg-warm);
}

@media (max-width: 760px) {
  .home-v3-section {
    padding: 56px 0;
  }
}
/* Section-head centrage dans les sections full-bleed.
   1240px = rail de contenu commun aux grilles v3 (axes, process, steps, compare…). */
.home-v3-section .section-head,
.home-section .section-head {
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
}

/* --- Hero --- */
.home-v3-hero {
  position: relative;
  padding: 64px 0 48px;
  overflow: hidden;
}

.home-v3-hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 48px;
  align-items: center;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 24px;
}

@media (max-width: 980px) {
  .home-v3-hero-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}
.home-v3-hero-copy {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.home-v3-hero-title {
  margin: 0;
  max-width: 18ch;
}

.home-v3-hero-lead {
  margin: 0;
  max-width: 54ch;
  font-size: 19px;
  line-height: 1.55;
  color: var(--pill-ink-soft);
}

.home-v3-eyebrow-dot {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.home-v3-eyebrow-dot::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--pill-teal);
  animation: home-v3-pulse 2.4s ease-in-out infinite;
  flex-shrink: 0;
}

@keyframes home-v3-pulse {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.5;
    transform: scale(0.85);
  }
}
.home-v3-stickers {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 4px;
}

.home-v3-hero-video {
  width: 100%;
}

.home-v3-hero-deco {
  position: absolute;
  right: -60px;
  bottom: -40px;
  width: 280px;
  height: 280px;
  opacity: 0.18;
  pointer-events: none;
  z-index: 0;
}

@media (max-width: 980px) {
  .home-v3-hero-deco {
    display: none;
  }
}
/* --- 4 axes (tone-colored cards) --- */
.home-v3-axes-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-top: 32px;
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 24px;
}

@media (max-width: 980px) {
  .home-v3-axes-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 560px) {
  .home-v3-axes-grid {
    grid-template-columns: 1fr;
  }
}
.home-v3-axis {
  position: relative;
  padding: 28px 24px 26px;
  border-radius: var(--r-lg, 24px);
  overflow: hidden;
  transition: transform 0.25s, box-shadow 0.25s;
  border: 1px solid transparent;
}

.home-v3-axis:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-md, 0 18px 48px -16px rgba(0, 11, 112, 0.2));
}

.home-v3-axis-idx {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  opacity: 0.7;
  margin-bottom: 14px;
}

.home-v3-axis-ax {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 8px;
  opacity: 0.8;
}

.home-v3-axis h3 {
  margin: 0 0 10px;
  font-size: 20px;
}

.home-v3-axis p {
  font-size: 13.5px;
  line-height: 1.55;
  margin: 0;
}

.home-v3-axis-deco {
  position: absolute;
  right: -30px;
  bottom: -30px;
  width: 120px;
  height: 120px;
  opacity: 0.22;
  pointer-events: none;
  transition: transform 0.4s;
}

.home-v3-axis:hover .home-v3-axis-deco {
  transform: rotate(-12deg) scale(1.1);
}

.home-v3-axis.tone-blue {
  background: var(--pill-bg-blue);
  color: var(--pill-ink);
}

.home-v3-axis.tone-teal {
  background: var(--pill-bg-teal);
  color: var(--pill-teal-deep);
}

.home-v3-axis.tone-cream {
  background: var(--pill-bg-card-2);
  color: var(--pill-ink);
  border-color: var(--pill-line);
}

.home-v3-axis.tone-ink {
  background: var(--pill-ink);
  color: var(--pill-bg);
}

.home-v3-axis.tone-ink h3 {
  color: #fff;
}

/* --- Process horizontal --- */
.home-v3-process {
  position: relative;
  margin-top: 40px;
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 24px;
}

.home-v3-process-track {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  position: relative;
}

.home-v3-process-track::before {
  content: "";
  position: absolute;
  left: 32px;
  right: 32px;
  top: 24px;
  height: 2px;
  background: var(--pill-line);
  z-index: 0;
}

.home-v3-process-track::after {
  content: "";
  position: absolute;
  left: 32px;
  top: 24px;
  height: 2px;
  background: linear-gradient(90deg, var(--pill-blue), var(--pill-teal));
  z-index: 1;
  width: 0;
  transition: width 2.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.home-v3-process.in .home-v3-process-track::after, .home-v3-process-track.in::after {
  width: calc(100% - 64px);
}

@media (max-width: 760px) {
  .home-v3-process-track {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .home-v3-process-track::before, .home-v3-process-track::after {
    display: none;
  }
}
.home-v3-process-step {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 0 8px;
}

.home-v3-process-node {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--pill-bg);
  border: 2px solid var(--pill-blue);
  color: var(--pill-blue);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  position: relative;
  transition: transform 0.3s;
}

.home-v3-section-warm .home-v3-process-node {
  background: var(--pill-bg-warm);
}

.home-v3-process-step:hover .home-v3-process-node {
  transform: scale(1.08);
}

.home-v3-process-node::after {
  content: "";
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  border: 2px solid var(--pill-blue);
  opacity: 0;
  animation: home-v3-halo 3s ease-in-out infinite;
}

.home-v3-process-step:nth-child(1) .home-v3-process-node::after {
  animation-delay: 0s;
}

.home-v3-process-step:nth-child(2) .home-v3-process-node::after {
  animation-delay: 0.4s;
}

.home-v3-process-step:nth-child(3) .home-v3-process-node::after {
  animation-delay: 0.8s;
}

.home-v3-process-step:nth-child(4) .home-v3-process-node::after {
  animation-delay: 1.2s;
}

@keyframes home-v3-halo {
  0%, 100% {
    opacity: 0;
    transform: scale(1);
  }
  50% {
    opacity: 0.4;
    transform: scale(1.15);
  }
}
.home-v3-process-step h3 {
  font-size: 17px;
  margin: 0 0 6px;
}

.home-v3-process-step p {
  font-size: 13px;
  color: var(--pill-ink-soft);
  max-width: 24ch;
  margin: 0 auto;
  line-height: 1.5;
}

/* --- Section ink IA/sécurité --- */
/* §04 — Section IA (cream + chips colorées) */
.home-v3-section-ai {
  background: var(--pill-bg);
}

.home-v3-ai-head {
  max-width: 760px;
  margin: 0 auto 40px;
  padding: 0 24px;
  text-align: center;
}

.home-v3-ai-head .section-numeral {
  justify-content: center;
}

.home-v3-ai-head .section-title {
  text-align: center;
  margin-top: 14px;
}

.home-v3-ai-head .lead {
  margin: 18px auto 0;
  max-width: 60ch;
}

.home-v3-ai-chips-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 24px;
}

@media (max-width: 900px) {
  .home-v3-ai-chips-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 520px) {
  .home-v3-ai-chips-grid {
    grid-template-columns: 1fr;
  }
}
.home-v3-ai-chip-card {
  padding: 24px 22px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg, 24px);
  transition: transform 0.25s, box-shadow 0.25s, border-color 0.25s;
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
  overflow: hidden;
}

.home-v3-ai-chip-card::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 3px;
  background: var(--pill-blue);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.35s cubic-bezier(0.22, 0.68, 0.36, 1);
}

.home-v3-ai-chip-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-md, 0 18px 48px -16px rgba(0, 11, 112, 0.2));
  border-color: var(--pill-blue);
}

.home-v3-ai-chip-card:hover::after {
  transform: scaleX(1);
}

.home-v3-ai-chip-card.is-accent {
  background: linear-gradient(135deg, var(--pill-bg-teal), var(--pill-bg-card-2));
  border-color: var(--pill-teal-soft);
}

.home-v3-ai-chip-card.is-accent::after {
  background: var(--pill-teal);
}

.home-v3-ai-chip-card.is-soft {
  background: var(--pill-bg-card-2);
  border-style: dashed;
}

.home-v3-ai-chip-icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--pill-bg-blue);
  color: var(--pill-blue);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  font-weight: 700;
}

.home-v3-ai-chip-card.is-accent .home-v3-ai-chip-icon {
  background: rgba(0, 195, 175, 0.2);
  color: var(--pill-teal-deep);
}

.home-v3-ai-chip-card.is-soft .home-v3-ai-chip-icon {
  background: var(--pill-bg);
  color: var(--pill-muted);
}

.home-v3-ai-chip-card h3 {
  font-size: 18px;
  margin: 0;
  color: var(--pill-ink);
  letter-spacing: -0.02em;
}

.home-v3-ai-chip-card p {
  font-size: 13px;
  line-height: 1.5;
  color: var(--pill-muted);
  margin: 0;
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
}

/* Engagements (ZDR + Pas d'entraînement) */
.home-v3-ai-engagements {
  max-width: 1240px;
  margin: 40px auto 0;
  padding: 0 24px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}

@media (max-width: 760px) {
  .home-v3-ai-engagements {
    grid-template-columns: 1fr;
  }
}
.home-v3-ai-engagement {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 20px 22px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-left: 3px solid var(--pill-teal);
  border-radius: var(--r-md, 16px);
}

.home-v3-ai-engagement p {
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--pill-ink-soft);
}

.home-v3-ai-engagement strong {
  color: var(--pill-ink);
}

.home-v3-ai-engagement-bullet {
  flex-shrink: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--pill-teal);
  margin-top: 7px;
}

.home-v3-ai-engagement-bullet.is-alt {
  background: var(--pill-blue);
}

.home-v3-ai-engagement:nth-child(2) {
  border-left-color: var(--pill-blue);
}

/* --- Trust section + marquee --- */
.home-v3-trust-section {
  padding-top: 56px;
}

.home-v3-marquee-wrap {
  margin-top: 32px;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

.home-v3-marquee {
  display: flex;
  gap: 56px;
  width: max-content;
  animation: home-v3-scroll-x 30s linear infinite;
  align-items: center;
}

.home-v3-marquee:hover {
  animation-play-state: paused;
}

@keyframes home-v3-scroll-x {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
.home-v3-logo-card {
  height: 56px;
  display: flex;
  align-items: center;
  padding: 0 22px;
  background: #fff;
  border: 1px solid var(--pill-line);
  border-radius: var(--r-pill, 999px);
  white-space: nowrap;
  opacity: 0.85;
  transition: opacity 0.2s, transform 0.2s;
}

.home-v3-logo-card:hover {
  opacity: 1;
  transform: translateY(-2px);
}

.home-v3-logo-card img {
  height: 28px;
  width: auto;
  max-width: 160px;
  object-fit: contain;
  display: block;
}

/* --- CTA card aurora --- */
.home-v3-cta-card {
  background: linear-gradient(135deg, var(--pill-ink) 0%, #000540 100%);
  color: var(--pill-bg);
  border-radius: var(--r-xl, 32px);
  padding: 64px 48px;
  text-align: center;
  position: relative;
  overflow: hidden;
  max-width: 1240px;
  margin: 0 auto;
}

.home-v3-cta-card::before {
  content: "";
  position: absolute;
  inset: -50%;
  background: radial-gradient(circle at 30% 40%, rgba(0, 195, 175, 0.15), transparent 50%), radial-gradient(circle at 70% 60%, rgba(13, 23, 230, 0.25), transparent 50%);
  animation: home-v3-aurora 12s linear infinite;
  pointer-events: none;
}

@keyframes home-v3-aurora {
  0%, 100% {
    transform: rotate(0);
  }
  50% {
    transform: rotate(180deg);
  }
}
.home-v3-cta-card h2 {
  color: #fff;
  position: relative;
  margin: 0 auto 14px;
  max-width: 20ch;
}

.home-v3-cta-card .lead {
  color: rgba(245, 239, 230, 0.8);
  position: relative;
  margin: 0 auto 28px;
  max-width: 50ch;
}

.home-v3-cta-card .cta-row {
  justify-content: center;
  position: relative;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.home-v3-cta-primary {
  background: var(--pill-teal) !important;
  color: var(--pill-ink) !important;
}

.home-v3-cta-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 0 rgba(0, 122, 111, 0.3);
}

.home-v3-cta-ghost {
  border-color: rgba(245, 239, 230, 0.4) !important;
  color: #fff !important;
  background: transparent !important;
}

.home-v3-cta-ghost:hover {
  background: #fff !important;
  color: var(--pill-ink) !important;
}

/* --- Sécurité v3 : shield avec 3 anneaux pulsants --- */
.sec-hero-shield-pulse {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sec-hero-shield-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid rgba(0, 195, 175, 0.45);
  pointer-events: none;
  animation: sec-shield-ring 3s ease-out infinite;
}

.sec-hero-shield-ring:nth-child(2) {
  animation-delay: 1s;
}

.sec-hero-shield-ring:nth-child(3) {
  animation-delay: 2s;
}

@keyframes sec-shield-ring {
  0% {
    transform: scale(0.55);
    opacity: 0;
  }
  30% {
    opacity: 0.65;
  }
  100% {
    transform: scale(1.45);
    opacity: 0;
  }
}
.sec-hero-shield-core {
  position: relative;
  width: 60%;
  height: 60%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--pill-teal);
}

.sec-hero-shield-core svg {
  width: 100%;
  height: 100%;
  stroke-width: 1.4;
}

/* Compatibilité : section numérotée dans la page Sécurité — la pastille reste lisible
   sur fond crème. */
.sec-page-v3 .sec-section .section-numeral .n {
  background: var(--pill-blue);
  color: #fff;
}

.sec-page-v3 .sec-section-tinted .section-numeral .n {
  background: var(--pill-teal);
  color: var(--pill-ink);
}

/* IA chip layout (utilisée si on l'incrustait dans la sécu — pour l'instant juste sécurité par sec-grid). */
.sec-page-v3 .sec-card {
  transition: transform 0.25s, box-shadow 0.25s, border-color 0.25s;
}

.sec-page-v3 .sec-card:hover {
  transform: translateY(-3px);
}

/* --- Ce que ça change v3 --- */
.ccc-page-v3 .ccc-steps-v3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 32px;
}

@media (max-width: 860px) {
  .ccc-page-v3 .ccc-steps-v3 {
    grid-template-columns: 1fr;
  }
}
.ccc-page-v3 .ccc-step-v3 {
  padding: 28px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg, 24px);
  transition: transform 0.25s, box-shadow 0.25s, border-color 0.25s;
}

.ccc-page-v3 .ccc-step-v3:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-md, 0 18px 48px -16px rgba(0, 11, 112, 0.2));
  border-color: var(--pill-blue);
}

.ccc-page-v3 .ccc-step-idx {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--pill-subtle);
  margin-bottom: 14px;
}

.ccc-page-v3 .ccc-step-verb {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--pill-blue);
  font-weight: 600;
  margin: 0 0 8px;
}

.ccc-page-v3 .ccc-step-v3 .capability-title {
  font-size: 20px;
  margin-bottom: 10px;
}

.ccc-page-v3 .ccc-step-v3 .capability-body {
  font-size: 14px;
  color: var(--pill-ink-soft);
  line-height: 1.6;
  margin: 0;
}

/* Compare grid (avant / après) */
.ccc-page-v3 .ccc-compare-v3 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 32px;
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 760px) {
  .ccc-page-v3 .ccc-compare-v3 {
    grid-template-columns: 1fr;
  }
}
.ccc-page-v3 .ccc-compare-col-v3 {
  padding: 28px;
  border-radius: var(--r-lg, 24px);
  position: relative;
  transition: transform 0.25s, box-shadow 0.25s;
}

.ccc-page-v3 .ccc-compare-col-v3:hover {
  transform: translateY(-2px);
  box-shadow: var(--sh-md, 0 18px 48px -16px rgba(0, 11, 112, 0.2));
}

.ccc-page-v3 .ccc-compare-col-v3.is-before {
  background: var(--pill-bg-warm);
  border: 1px solid var(--pill-line);
}

.ccc-page-v3 .ccc-compare-col-v3.is-after {
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  overflow: hidden;
}

.ccc-page-v3 .ccc-compare-col-v3.is-after::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  background: linear-gradient(90deg, var(--pill-blue), var(--pill-teal));
}

.ccc-page-v3 .ccc-compare-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pill-muted);
  margin: 0 0 14px;
}

.ccc-page-v3 .ccc-compare-col-v3.is-after .ccc-compare-tag {
  color: var(--pill-blue);
}

.ccc-page-v3 .ccc-compare-title {
  font-size: 20px;
  margin: 0 0 18px;
}

.ccc-page-v3 .ccc-compare-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ccc-page-v3 .ccc-compare-list li {
  padding: 10px 0 10px 28px;
  position: relative;
  font-size: 14px;
  line-height: 1.5;
  color: var(--pill-ink-soft);
  border-bottom: 1px dashed var(--pill-line-2);
}

.ccc-page-v3 .ccc-compare-list li:last-child {
  border-bottom: none;
}

.ccc-page-v3 .ccc-compare-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 14px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
}

.ccc-page-v3 .ccc-compare-col-v3.is-before .ccc-compare-list li::before {
  background: var(--crit-soft, #FCE5E9);
  border: 1.5px solid var(--crit, #C8102E);
}

.ccc-page-v3 .ccc-compare-col-v3.is-after .ccc-compare-list li::before {
  content: "✓";
  background: var(--pill-blue);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  line-height: 14px;
  text-align: center;
  border: none;
}

/* Role cards */
.ccc-page-v3 .ccc-roles-grid-v3 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-top: 32px;
}

@media (max-width: 760px) {
  .ccc-page-v3 .ccc-roles-grid-v3 {
    grid-template-columns: 1fr;
  }
}
.ccc-page-v3 .ccc-role-v3 {
  padding: 26px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg, 24px);
  transition: transform 0.25s, box-shadow 0.25s;
  position: relative;
  overflow: hidden;
}

.ccc-page-v3 .ccc-role-v3:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh-md, 0 18px 48px -16px rgba(0, 11, 112, 0.2));
}

.ccc-page-v3 .ccc-role-v3::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: var(--pill-blue);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.35s;
}

.ccc-page-v3 .ccc-role-v3:hover::before {
  transform: scaleY(1);
}

.ccc-page-v3 .ccc-role-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--pill-blue);
  font-weight: 600;
  margin: 0 0 8px;
}

.ccc-page-v3 .ccc-role-v3 .capability-title {
  font-size: 19px;
  margin: 0 0 10px;
}

.ccc-page-v3 .ccc-role-v3 .capability-body {
  font-size: 14px;
  color: var(--pill-ink-soft);
  line-height: 1.6;
  margin: 0;
}

/* Ce que ça ne change pas — bloc centré */
.ccc-page-v3 .ccc-not-changing {
  text-align: center;
}

.ccc-page-v3 .ccc-not-changing-inner {
  max-width: 60ch;
  margin: 0 auto;
}

.ccc-page-v3 .ccc-not-changing .section-title {
  margin: 6px 0 18px;
}

.ccc-page-v3 .ccc-not-changing .section-copy {
  margin: 0 auto;
}

/* --- Roadmap v3 — filtres pillule + spine gradient + dots animés --- */
.roadmap-page-v3 .roadmap-filters {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 40px;
}

.roadmap-page-v3 .roadmap-filter {
  padding: 8px 16px;
  background: #fff;
  border: 1.5px solid var(--pill-line);
  border-radius: var(--r-pill, 999px);
  font-family: var(--font-sans);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--pill-ink-soft);
  cursor: pointer;
  transition: all 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.roadmap-page-v3 .roadmap-filter:hover {
  border-color: var(--pill-blue-soft);
  transform: translateY(-1px);
}

.roadmap-page-v3 .roadmap-filter.is-active {
  background: var(--pill-ink);
  border-color: var(--pill-ink);
  color: #fff;
}

.roadmap-page-v3 .roadmap-filter-count {
  background: var(--pill-bg-warm);
  color: var(--pill-ink);
  padding: 1px 8px;
  border-radius: var(--r-pill, 999px);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  min-width: 24px;
  text-align: center;
}

.roadmap-page-v3 .roadmap-filter.is-active .roadmap-filter-count {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}

/* Timeline — renforce le spine en gradient */
.roadmap-page-v3 .roadmap-timeline-spine {
  background: linear-gradient(180deg, var(--pill-blue), var(--pill-teal), transparent) !important;
}

/* Dots colorés + pulsation sur in_progress */
.roadmap-page-v3 .roadmap-entry-dot[data-status=shipped] {
  background: var(--ok, #007A6F);
  border-color: var(--ok, #007A6F);
}

.roadmap-page-v3 .roadmap-entry-dot[data-status=in_progress] {
  background: var(--pill-blue);
  border-color: var(--pill-blue);
  box-shadow: 0 0 0 4px rgba(13, 23, 230, 0.18);
  animation: roadmap-v3-dot-pulse 1.8s ease-in-out infinite;
}

.roadmap-page-v3 .roadmap-entry-dot[data-status=planned] {
  background: #fff;
  border-color: var(--pill-subtle);
}

@keyframes roadmap-v3-dot-pulse {
  0%, 100% {
    box-shadow: 0 0 0 4px rgba(13, 23, 230, 0.18);
  }
  50% {
    box-shadow: 0 0 0 8px rgba(13, 23, 230, 0.06);
  }
}
/* Entry hover slide */
.roadmap-page-v3 .roadmap-entry {
  transition: transform 0.2s, box-shadow 0.2s;
}

.roadmap-page-v3 .roadmap-entry:hover {
  transform: translateX(4px);
  box-shadow: var(--sh-md, 0 18px 48px -16px rgba(0, 11, 112, 0.2));
}

/* ============================================================
   PRICING v3 — refonte page /tarifs
   ============================================================ */
.pricing-page-v3 {
  background: var(--pill-bg);
}

/* Hero split : copy + carte exemple */
.pricing-page-v3 .pricing-v3-hero-grid {
  align-items: stretch;
  gap: 40px;
}

@media (max-width: 980px) {
  .pricing-page-v3 .pricing-v3-hero-grid {
    grid-template-columns: 1fr;
  }
}
.pricing-v3-hero-card {
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg, 24px);
  padding: 28px 26px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: var(--sh-md, 0 18px 48px -16px rgba(0, 11, 112, 0.2));
  position: relative;
  overflow: hidden;
}

.pricing-v3-hero-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  background: linear-gradient(90deg, var(--pill-blue), var(--pill-teal));
}

.pricing-v3-hero-card-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pill-blue);
  font-weight: 600;
}

.pricing-v3-hero-card-title {
  font-family: var(--font-display);
  font-size: 17px;
  letter-spacing: -0.02em;
  color: var(--pill-ink);
  margin: 0;
  line-height: 1.3;
}

.pricing-v3-hero-card-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pricing-v3-hero-card-list li {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 10px 0;
  border-bottom: 1px dashed var(--pill-line-2);
  font-size: 13.5px;
  color: var(--pill-ink-soft);
}

.pricing-v3-hero-card-list li:last-child {
  border-bottom: none;
}

.pricing-v3-hero-card-list li span:first-child {
  font-weight: 500;
  color: var(--pill-ink);
}

.pricing-v3-hero-card-list li span:last-child {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--pill-muted);
  text-align: right;
}

.pricing-v3-hero-card-list li.is-bonus {
  background: var(--pill-bg-teal);
  margin: 4px -8px 0;
  padding: 10px 12px;
  border-radius: var(--r-sm, 8px);
  border-bottom: none;
}

.pricing-v3-hero-card-list li.is-bonus span:last-child {
  color: var(--pill-teal-deep);
  font-weight: 600;
}

.pricing-v3-hero-card-foot {
  margin: 0;
  font-size: 12px;
  color: var(--pill-muted);
  font-style: italic;
}

/* Pricing logic: axes + document format */
.pricing-v3-rates-grid {
  max-width: 1240px;
  margin: 32px auto 0;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

@media (max-width: 860px) {
  .pricing-v3-rates-grid {
    grid-template-columns: 1fr;
  }
}
.pricing-v3-rates-block {
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg, 24px);
  padding: 24px;
}

.pricing-v3-rates-block-title {
  font-size: 17px;
  letter-spacing: -0.02em;
  color: var(--pill-ink);
  margin: 0 0 18px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}

.pricing-v3-rates-block-hint {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pill-muted);
  font-weight: 400;
}

.pricing-v3-rates-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

@media (max-width: 480px) {
  .pricing-v3-rates-list {
    grid-template-columns: 1fr;
  }
}
.pricing-v3-rate-cell {
  padding: 14px 16px;
  border-radius: var(--r-md, 16px);
  background: var(--pill-bg-card-2);
  border: 1px solid var(--pill-line);
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: border-color 0.2s, transform 0.2s;
}

.pricing-v3-rate-cell:hover {
  transform: translateY(-2px);
}

.pricing-v3-rate-cell.tone-blue {
  border-left: 3px solid var(--pill-blue);
}

.pricing-v3-rate-cell.tone-teal {
  border-left: 3px solid var(--pill-teal);
}

.pricing-v3-rate-cell.tone-cream {
  border-left: 3px solid var(--pill-bg-warm);
  background: var(--pill-bg-warm);
}

.pricing-v3-rate-cell.tone-ink {
  border-left: 3px solid var(--pill-ink);
}

.pricing-v3-rate-axis {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pill-muted);
}

.pricing-v3-rate-value {
  font-size: 14px;
  color: var(--pill-ink);
  line-height: 1.4;
}

.pricing-v3-format-list {
  display: grid;
  gap: 10px;
}

.pricing-v3-format-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border-radius: var(--r-sm);
  background: var(--pill-bg-card-2);
  border: 1px solid var(--pill-line);
}

.pricing-v3-format-row strong {
  color: var(--pill-ink);
}

.pricing-v3-format-row span {
  color: var(--pill-muted);
  text-align: right;
}

.pricing-v3-format-row.is-muted {
  background: var(--pill-bg-teal);
  border-color: var(--pill-teal-soft);
}

.pricing-v3-format-row.is-coming-soon {
  background: rgba(156, 157, 170, 0.1);
  border-color: rgba(156, 157, 170, 0.24);
  color: var(--pill-muted);
}

.pricing-v3-format-row.is-coming-soon strong,
.pricing-v3-format-row.is-coming-soon span {
  color: var(--pill-muted);
}

.pricing-v3-format-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 4px 9px;
  border-radius: var(--r-pill);
  background: rgba(156, 157, 170, 0.14);
  border: 1px solid rgba(156, 157, 170, 0.24);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

@media (max-width: 520px) {
  .pricing-v3-format-row {
    flex-direction: column;
    gap: 4px;
  }
  .pricing-v3-format-row span {
    text-align: left;
  }
}
/* Référence rate card */
.pricing-v3-reference-rate {
  max-width: 1240px;
  margin: 24px auto 0;
  padding: 22px 26px;
  background: linear-gradient(135deg, var(--pill-bg-teal), var(--pill-bg-card-2));
  border: 1px solid var(--pill-teal-soft);
  border-radius: var(--r-lg, 24px);
  display: flex;
  gap: 18px;
  align-items: center;
}

@media (max-width: 760px) {
  .pricing-v3-reference-rate {
    margin-left: 24px;
    margin-right: 24px;
    padding: 18px 20px;
    flex-direction: column;
    align-items: flex-start;
  }
}
.pricing-v3-reference-rate-icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(0, 195, 175, 0.2);
  color: var(--pill-teal-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 700;
}

.pricing-v3-reference-rate h3 {
  margin: 0 0 4px;
  font-size: 17px;
  color: var(--pill-ink);
  letter-spacing: -0.02em;
}

.pricing-v3-reference-rate p {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--pill-ink-soft);
}

.pricing-v3-reference-rate strong {
  color: var(--pill-ink);
}

/* Dégressivité */
.pricing-v3-degressive-grid {
  max-width: 1240px;
  margin: 32px auto 0;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

@media (max-width: 860px) {
  .pricing-v3-degressive-grid {
    grid-template-columns: 1fr;
  }
}
.pricing-v3-degressive-block {
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg, 24px);
  padding: 24px;
}

.pricing-v3-degressive-block h3 {
  margin: 0 0 18px;
  font-size: 17px;
  color: var(--pill-ink);
  letter-spacing: -0.02em;
}

.pricing-v3-tier-row {
  display: grid;
  grid-template-columns: 1fr 1.5fr auto;
  align-items: center;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px dashed var(--pill-line-2);
}

.pricing-v3-tier-row:last-child {
  border-bottom: none;
}

.pricing-v3-tier-range {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--pill-ink-soft);
}

.pricing-v3-tier-bar {
  display: block;
  height: 8px;
  background: var(--pill-bg-card-2);
  border-radius: var(--r-pill, 999px);
  position: relative;
  overflow: hidden;
}

.pricing-v3-tier-fill {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--pill-blue), var(--pill-blue-soft));
  border-radius: var(--r-pill, 999px);
  transition: width 0.8s cubic-bezier(0.22, 0.68, 0.36, 1);
}

.pricing-v3-tier-fill.is-teal {
  background: linear-gradient(90deg, var(--pill-teal), var(--pill-teal-soft));
}

.pricing-v3-tier-mult {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  color: var(--pill-blue);
  min-width: 44px;
  text-align: right;
}

.pricing-v3-degressive-block:nth-child(2) .pricing-v3-tier-mult {
  color: var(--pill-teal-deep);
}

.pricing-v3-tier-empty {
  color: var(--pill-muted);
  font-size: 13.5px;
}

/* Règles cards */
.pricing-v3-rules-grid {
  max-width: 1240px;
  margin: 32px auto 0;
  padding: 0 24px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

@media (max-width: 860px) {
  .pricing-v3-rules-grid {
    grid-template-columns: 1fr;
  }
}
.pricing-v3-rule-card {
  padding: 28px 26px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-lg, 24px);
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: transform 0.25s, box-shadow 0.25s, border-color 0.25s;
}

.pricing-v3-rule-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-md, 0 18px 48px -16px rgba(0, 11, 112, 0.2));
  border-color: var(--pill-blue);
}

.pricing-v3-rule-card.is-accent {
  background: linear-gradient(135deg, var(--pill-bg-teal), var(--pill-bg-card-2));
  border-color: var(--pill-teal-soft);
}

.pricing-v3-rule-card.is-accent:hover {
  border-color: var(--pill-teal);
}

.pricing-v3-rule-idx {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--pill-subtle);
}

.pricing-v3-rule-card h3 {
  margin: 0;
  font-size: 19px;
  color: var(--pill-ink);
  letter-spacing: -0.02em;
  line-height: 1.25;
}

.pricing-v3-rule-card p {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--pill-ink-soft);
}

/* Table details — léger restyling pour s'aligner avec v3 */
.pricing-v3-table-section {
  padding-top: 0;
}

.pricing-v3-table-details {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 24px;
}

.pricing-v3-table-summary {
  cursor: pointer;
  padding: 18px 22px;
  background: var(--pill-bg-card);
  border: 1px solid var(--pill-line);
  border-radius: var(--r-md, 16px);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  transition: border-color 0.2s;
}

.pricing-v3-table-summary:hover {
  border-color: var(--pill-blue);
}

.pricing-v3-table-summary-label {
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--pill-ink);
}

.pricing-v3-table-summary-hint {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pill-muted);
}

/* Reduced motion : aurora + tier bar */
@media (prefers-reduced-motion: reduce) {
  .pricing-v3-tier-fill {
    transition: none !important;
  }
}
/* Pages publiques full-bleed : backgrounds de section sur toute la largeur.
   La contrainte de largeur est portée par chaque inner wrapper (grilles, section-head…).  */
.page.home-v3,
.page.pricing-page-v3,
.page.ccc-page-v3 {
  width: 100%;
  max-width: none;
  padding-left: 0;
  padding-right: 0;
}

@media (max-width: 720px) {
  .page.home-v3,
  .page.pricing-page-v3,
  .page.ccc-page-v3 {
    width: 100%;
  }
}
@media (max-width: 640px) {
  .page.home-v3,
  .page.pricing-page-v3,
  .page.ccc-page-v3 {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
  }
}
/* Rail de contenu commun (1240px + gouttières 24px) pour tous les wrappers
   internes des pages full-bleed qui n'ont pas leur propre contrainte de largeur.
   Le fond/bordure des sections reste pleine largeur, leur contenu est recentré. */
.page.home-v3 .seo-faq-grid,
.page.pricing-page-v3 .seo-faq-grid,
.page.ccc-page-v3 .seo-faq-grid,
.page.ccc-page-v3 .about-hero,
.page.ccc-page-v3 .ccc-steps-v3,
.page.ccc-page-v3 .ccc-roles-grid-v3 {
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
}

/* Blocs qui portent déjà leur propre max-width : on ajoute juste les gouttières. */
.page.ccc-page-v3 .ccc-compare-v3,
.page.ccc-page-v3 .ccc-not-changing-inner {
  padding-left: 24px;
  padding-right: 24px;
}

/* CTA card : largeur contrainte + centrée, avec gouttières de 24px sur les bords. */
.page.home-v3 .home-v3-cta-card,
.page.pricing-page-v3 .home-v3-cta-card,
.page.ccc-page-v3 .home-v3-cta-card {
  width: min(100% - 48px, 1240px);
  margin-left: auto;
  margin-right: auto;
}

/* Marquee : pas de padding (overflow:hidden ne clipe pas le padding), juste
   une largeur contrainte et centrée — le masque dégradé fond aux bords du contenu. */
.page.home-v3 .partners-marquee {
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
}

/* ===== Console admin (Twig SSR) ===== */
.admin-layout {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}

.admin-sidebar {
  position: sticky;
  top: 96px;
  display: grid;
  gap: 12px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.6);
  box-shadow: var(--shadow-soft);
}

.admin-sidebar-title {
  margin: 0;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted, #8a8378);
}

.admin-sidebar-nav {
  display: grid;
  gap: 4px;
}

.admin-sidebar-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 10px;
  color: var(--charcoal);
  text-decoration: none;
  font-size: 14px;
  transition: background 0.15s ease, color 0.15s ease;
}

.admin-sidebar-link:hover {
  background: var(--pill-bg, #f5efe6);
}

.admin-sidebar-link.is-active {
  background: var(--charcoal);
  color: #fff;
}

.admin-badge-super {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 6px;
  background: var(--copper-deep, #b06a3d);
  color: #fff;
}

.admin-sidebar-link.is-active .admin-badge-super {
  background: rgba(255, 255, 255, 0.25);
}

.admin-main {
  display: grid;
  gap: 20px;
  min-width: 0;
}

.kpi-label {
  margin: 0;
  font-size: 13px;
  color: var(--muted, #8a8378);
}

.kpi-sub {
  margin: 0;
  font-size: 12px;
}

@media (max-width: 860px) {
  .admin-layout {
    grid-template-columns: 1fr;
  }
  .admin-sidebar {
    position: static;
  }
  .admin-sidebar-nav {
    grid-auto-flow: column;
    grid-auto-columns: max-content;
    overflow-x: auto;
  }
}
/* Console admin — filtres & actions */
.admin-filter {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.admin-filter input[type=search] {
  flex: 1 1 260px;
  min-width: 0;
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font: inherit;
}

.admin-filter select {
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font: inherit;
}

.admin-pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  align-items: center;
  justify-content: center;
  margin-top: 16px;
}

.admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.admin-actions .text-link {
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
  font: inherit;
  color: var(--copper-deep, #b06a3d);
}

.admin-error {
  margin-bottom: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(190, 60, 50, 0.1);
  color: #9b2c22;
  font-size: 14px;
}

.text-strong {
  font-weight: 600;
}

/* Console admin — select inline & danger */
.admin-inline-select {
  padding: 5px 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  font: inherit;
  font-size: 13px;
}

.admin-actions .text-link.admin-danger {
  color: #9b2c22;
}

/* Breadcrumb — tout en haut de .app-main */
.admin-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--charcoal-3, #8a8378);
  padding: 10px 32px;
  border-bottom: 1px solid var(--pill-line-2);
  background: var(--pill-bg-soft);
}

.admin-breadcrumb a {
  color: var(--copper-deep);
  text-decoration: none;
}

.admin-breadcrumb a:hover {
  text-decoration: underline;
}

.admin-breadcrumb .separator {
  color: var(--charcoal-3, #8a8378);
}

/* Console admin — colonne Nom alignée à gauche */
.admin-main .pricing-table thead th:nth-child(2),
.admin-main .pricing-table tbody td:nth-child(2) {
  text-align: left;
}

/* Console admin — modale audit détail */
.audit-modal {
  max-width: 640px;
  width: 90vw;
  border: 1px solid var(--pill-line);
  border-radius: 12px;
  padding: 0;
  background: var(--pill-bg-card);
  box-shadow: 0 8px 32px rgba(0, 11, 112, 0.12);
}

.audit-modal::backdrop {
  background: rgba(0, 0, 0, 0.35);
}

.audit-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 18px;
  border-bottom: 1px solid var(--pill-line-2);
}

.audit-modal-close {
  background: none;
  border: 0;
  font-size: 20px;
  cursor: pointer;
  color: var(--charcoal-3, #8a8378);
  line-height: 1;
}

.audit-modal-json {
  padding: 16px 18px;
  margin: 0;
  font-size: 12px;
  line-height: 1.5;
  max-height: 60vh;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-all;
}

/* Console admin — formulaires de création */
.admin-create summary {
  cursor: pointer;
}

.admin-form {
  margin-top: 14px;
}

.admin-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
  margin-bottom: 14px;
}

.admin-form-grid > div,
.admin-form-grid > label {
  display: grid;
  gap: 5px;
  font-size: 13px;
  color: var(--muted, #8a8378);
}

.admin-form-grid input,
.admin-form-grid select {
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font: inherit;
  font-size: 14px;
  color: var(--charcoal);
}

/* Console admin — champ large */
/* Interrupteur (toggle) du SwitchType — rendu par le thème de form (form/theme.html.twig).
   La checkbox native est masquée mais reste focusable au clavier ; la piste + le curseur
   sont rendus en CSS. Réutilisable sur tout champ booléen via App\Form\Type\SwitchType. */
.form-switch {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
}

.form-switch input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.form-switch-track {
  position: relative;
  flex: 0 0 auto;
  width: 42px;
  height: 24px;
  border-radius: 999px;
  background: var(--pill-line);
  transition: background 0.18s ease;
}

.form-switch-track::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 2px rgba(0, 11, 112, 0.25);
  transition: transform 0.18s ease;
}

.form-switch input:checked + .form-switch-track {
  background: var(--pill-blue);
}

.form-switch input:checked + .form-switch-track::after {
  transform: translateX(18px);
}

.form-switch input:focus-visible + .form-switch-track {
  outline: 2px solid var(--pill-blue);
  outline-offset: 2px;
}

.admin-form-wide {
  grid-column: 1/-1;
}

.admin-form-grid textarea {
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font: inherit;
  font-size: 14px;
  color: var(--charcoal);
  resize: vertical;
}

button.status-chip {
  cursor: pointer;
  border: 0;
  font: inherit;
}

/* Console admin — listes & métadonnées */
.admin-list {
  margin: 8px 0 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
}

.admin-list li {
  font-size: 14px;
}

.admin-meta {
  font-size: 11px;
  word-break: break-all;
  color: var(--muted, #8a8378);
}

/* Console admin — statut opérationnel */
.admin-status-hero-row {
  display: flex;
  align-items: center;
  gap: 22px;
  flex-wrap: wrap;
}

.admin-score {
  display: grid;
  place-items: center;
  width: 96px;
  height: 96px;
  border-radius: 50%;
  border: 3px solid var(--line);
  flex-shrink: 0;
}

.admin-score[data-tone=completed] {
  border-color: #2f8f5b;
}

.admin-score[data-tone=failed] {
  border-color: #9b2c22;
}

.admin-score[data-tone=processing] {
  border-color: #b06a3d;
}

.admin-score-value {
  font-size: 32px;
  font-weight: 700;
  line-height: 1;
}

.admin-components {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.admin-component {
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: rgba(255, 255, 255, 0.5);
}

.admin-component-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}

/* Console admin — réglages IA */
.admin-setting {
  display: grid;
  gap: 12px;
}

.admin-setting-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.admin-setting-head .mono {
  margin-left: 8px;
}

.admin-setting-value {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font: inherit;
  font-size: 14px;
  color: var(--charcoal);
  resize: vertical;
}

textarea.admin-setting-value {
  font-family: var(--mono, monospace);
  font-size: 13px;
}

.admin-setting-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.admin-setting-actions input[name=note] {
  flex: 1 1 220px;
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font: inherit;
  font-size: 13px;
}

.admin-history {
  margin-top: 4px;
}

.admin-history summary {
  cursor: pointer;
}

/* Console admin — monitor live */
.admin-monitor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.admin-autorefresh {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--muted, #8a8378);
}

.admin-progress {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 12px;
}

.admin-progress-bar {
  flex: 1;
  height: 8px;
  border-radius: 999px;
  background: var(--pill-bg, #f5efe6);
  overflow: hidden;
}

.admin-progress-bar span {
  display: block;
  height: 100%;
  background: var(--copper-deep, #b06a3d);
  width: 0;
  transition: width 0.4s ease;
}

.admin-events li {
  font-size: 13px;
}

/* Console admin — AI Lab */
.admin-models {
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 12px 14px;
  margin-bottom: 14px;
}

.admin-models legend {
  padding: 0 6px;
}

.admin-model-check {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin: 4px 14px 4px 0;
  font-size: 13px;
}

/* Partie SaaS privée (app + console admin) : pas d'animation d'entrée de page.
   Préférence produit — les animations décoratives n'apportent rien à l'utilisateur.
   Les indicateurs d'état (spinners, barres de progression de run, toasts) restent
   actifs car ils véhiculent une information. */
.app-shell.is-private .page {
  animation: none;
}

/* ===== Sidebar repliable (espace privé) ===== */
/* Déconnexion : popover flottant au-dessus de « mon compte » (position absolue
   → n'occupe pas de place dans le flux, donc ne décale pas le menu au survol).
   Révélé au survol / focus de la zone compte. */
.sidebar-account {
  position: relative;
}

.sidebar-logout {
  display: none;
  position: absolute;
  left: 100%;
  bottom: 0;
  z-index: 30;
  min-width: 180px;
  padding: 9px 14px;
  text-align: left;
  white-space: nowrap;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: var(--shadow-soft, 0 12px 30px rgba(27, 24, 21, 0.16));
}

.sidebar-account:hover .sidebar-logout,
.sidebar-account:focus-within .sidebar-logout {
  display: block;
}

/* Toggle de repli, en bas du menu. */
.sidebar-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  margin-top: 10px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.5);
  color: var(--muted, #8a8378);
  cursor: pointer;
  font: inherit;
  font-size: 13px;
  transition: background 0.15s ease;
}

.sidebar-toggle:hover {
  background: var(--pill-bg, #f5efe6);
}

.sidebar-toggle-icon {
  font-size: 15px;
  font-weight: 600;
  line-height: 1;
}

.sidebar-toggle-expand {
  display: none;
}

.app-shell.is-private.is-collapsed {
  grid-template-columns: 72px minmax(0, 1fr);
}

.app-shell.is-private.is-collapsed .sidebar-toggle {
  justify-content: center;
  padding-left: 0;
  padding-right: 0;
}

.app-shell.is-private.is-collapsed .sidebar-toggle-collapse {
  display: none;
}

.app-shell.is-private.is-collapsed .sidebar-toggle-expand {
  display: inline;
}

.app-shell.is-private.is-collapsed .brand-copy,
.app-shell.is-private.is-collapsed .brand-logo--full,
.app-shell.is-private.is-collapsed .nav-pill-one,
.app-shell.is-private.is-collapsed .sidebar-link span:not(.sidebar-icon),
.app-shell.is-private.is-collapsed .sidebar-credits-slim,
.app-shell.is-private.is-collapsed .sidebar-user-meta,
.app-shell.is-private.is-collapsed .sidebar-toggle-label {
  display: none;
}

.app-shell.is-private.is-collapsed .brand-logo--mark {
  display: block;
}

/* Settings hub cards */
.settings-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

@media (max-width: 1024px) {
  .settings-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 640px) {
  .settings-grid {
    grid-template-columns: 1fr;
  }
}
.settings-card {
  border-radius: 10px;
  border: 1px solid var(--pill-line);
  background: var(--pill-bg-card);
  overflow: hidden;
}

.settings-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 16px;
  background: var(--pill-ink);
  color: #fff;
  font-weight: 600;
  font-size: 0.92rem;
}

.settings-card-header i {
  font-size: 16px;
  width: 20px;
  text-align: center;
  flex-shrink: 0;
}

.settings-card-body {
  display: flex;
  flex-direction: column;
}

.settings-card-link {
  display: block;
  padding: 10px 16px;
  color: var(--pill-ink);
  text-decoration: none;
  font-size: 0.9rem;
  border-top: 1px solid var(--pill-line-2);
  transition: background 0.12s ease;
}

.settings-card-link:first-child {
  border-top: none;
}

.settings-card-link:hover {
  background: var(--pill-bg-soft);
  color: var(--copper-deep);
}

.app-shell.is-private.is-collapsed .sidebar-brand,
.app-shell.is-private.is-collapsed .sidebar-link,
.app-shell.is-private.is-collapsed .sidebar-user {
  justify-content: center;
  padding-left: 0;
  padding-right: 0;
}

.app-shell.is-private.is-collapsed .sidebar-brand .brand-button {
  justify-content: center;
  flex: unset;
}

/* « Rester connecté » (login) */
.auth-remember {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--charcoal);
  cursor: pointer;
}

.auth-remember input {
  width: 16px;
  height: 16px;
}

.text-right {
  text-align: right;
}

.text-danger {
  color: var(--danger);
}

.text-ok {
  color: var(--ok);
}

.ledger-actions {
  display: flex;
  gap: 12px;
  white-space: nowrap;
}

/* ── 2FA OTP digits ── */
.otp-digits {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin: 16px 0;
}

.otp-digit {
  width: 3rem;
  height: 3.2rem;
  text-align: center;
  font-size: 1.4rem;
  font-weight: 600;
  padding: 0;
  border-radius: 10px;
}

.twofa-providers {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
}

.twofa-providers .subtle-button.active {
  background: var(--copper-deep, #b06a3d);
  color: #fff;
}

/* ── TOTP setup ── */
.totp-setup {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  align-items: flex-start;
  margin: 16px 0;
}

.totp-qr svg {
  width: 180px;
  height: 180px;
}

.totp-manual {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.totp-manual code {
  word-break: break-all;
  font-size: 13px;
  padding: 8px 12px;
  background: var(--cream-light, #faf7f2);
  border-radius: 8px;
}

/*# sourceMappingURL=app-7d1043473d.output.css.map */
