/* === 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. */
@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", system-ui, sans-serif;
    --font-sans:    "Inter", system-ui, sans-serif;
    --font-mono:    "JetBrains Mono", 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: 1180px;
    --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;
}

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

body {
    min-height: 100vh;
    margin: 0;
    color: var(--pill-ink);
    font-family: var(--font-sans);
    background: var(--pill-bg);
    -webkit-font-smoothing: antialiased;
    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;
}

.app-shell.is-private .page {
    width: min(calc(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;
}

.page {
    width: min(calc(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(calc(100% - 48px), var(--content-width));
    margin: 0 auto;
    padding: 22px 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;
}

.nav-links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    flex-wrap: wrap;
}

.nav-link {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 12px;
    border-radius: var(--r-pill);
    color: var(--pill-ink-soft);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
}

.nav-link:hover,
.nav-link.is-active {
    color: var(--pill-blue);
    background: rgba(13, 23, 230, 0.07);
}

.nav-link:focus-visible {
    color: var(--pill-blue);
    background: rgba(13, 23, 230, 0.07);
    outline: 3px solid var(--pill-blue);
    outline-offset: 2px;
}

.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: 56px 0 40px;
    border-top: 1px solid var(--pill-line);
    background: var(--pill-bg-soft);
}

.footer > .footer-grid {
    width: min(calc(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(calc(100% - 32px), var(--content-width));
        padding: 24px 0 48px;
    }

    .topbar,
    .footer > .footer-grid {
        width: min(calc(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 */
.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(--line);
    background: rgba(250, 247, 241, 0.92);
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
    box-shadow: 1px 0 0 rgba(28, 26, 23, 0.02);
    z-index: 2;
    overflow-y: auto;
}

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

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

.sidebar-brand .brand-name {
    font-size: 20px;
}

.sidebar-brand .brand-tag {
    font-size: 10px;
}

.sidebar-nav {
    display: grid;
    gap: 4px;
    align-content: start;
    margin-top: 8px;
}

.sidebar-link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 14px;
    border-radius: 12px;
    border: 0;
    background: transparent;
    color: var(--charcoal-2);
    font: inherit;
    font-size: 14px;
    cursor: pointer;
    text-align: left;
    transition: background 180ms, color 180ms;
}

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

.sidebar-link.is-active {
    background: var(--charcoal);
    color: var(--ivory);
}

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

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

/* 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);
}

.sidebar-credits-slim {
    font-size: 12px;
    color: var(--charcoal-3);
    padding: 0 6px;
    letter-spacing: 0.04em;
}

.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-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 {
    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;
    padding: 14px 16px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.72);
    box-shadow: 0 16px 44px rgba(0, 3, 213, 0.05);
}

.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: 12px;
    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;
    font-size: 18px;
    line-height: 1;
    text-align: center;
}

.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);
}

.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 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: rgba(184, 115, 51, 0.14);
    color: var(--copper-deep);
    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;
}

.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, calc(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 {
    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: rgba(255, 255, 255, 1);
    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, calc(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 {
    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-popup {
    width: min(380px, calc(100vw - 32px));
    max-height: min(640px, calc(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 {
    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-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-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: 12px;
    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;
}

/* 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-control {
    display: grid;
    gap: 8px;
    max-width: 320px;
}

@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: minmax(0, 1fr);
        overflow-x: auto;
    }
    .sidebar-sub {
        display: none;
    }
    .sidebar-footer {
        display: none;
    }
    .help-widget {
        right: 16px;
        bottom: 16px;
    }
}

/* 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);
}

.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(calc(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);
}

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

.nav-link,
.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;
}

.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;
}

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

.chrome-bar-public {
    display: flex;
    align-items: center;
    gap: clamp(14px, 2vw, 28px);
    padding: 14px 20px;
}

.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 12px;
    font-size: 12px;
    letter-spacing: 0.06em;
    white-space: nowrap;
}

.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 {
    font-size: 17px;
    line-height: 1;
}

.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: 12px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 6px 4px;
    white-space: nowrap;
}

.nav-cta-register {
    padding: 9px 16px;
    font-size: 12px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
}

@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: minmax(0, 1.05fr) minmax(360px, 0.95fr);
    gap: 56px;
    align-items: center;
    padding-top: 44px;
}

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

.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(56px, 8vw, 112px);
    line-height: 0.96;
    letter-spacing: 0;
    margin: 0;
    max-width: 9ch;
    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: 52ch;
    font-size: 17px;
    line-height: 1.75;
    color: var(--charcoal-2);
}

.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;
    min-height: 48px;
    padding: 0 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;
    transition: transform .2s ease, background .2s ease, color .2s ease, border-color .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 .2s ease, border-color .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.20));
}

.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;
    max-width: 920px;
}

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

.home-hero-v2-lead {
    margin: 0;
    max-width: 64ch;
    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: 18px;
}

.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-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: 120px;
    padding: 64px 0 40px;
    border-top: 1px solid rgba(28, 26, 23, 0.12);
    background:
        linear-gradient(180deg, rgba(10, 18, 24, 0.04), rgba(10, 18, 24, 0.08)),
        var(--ivory);
    position: relative;
}

.public-footer::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(0, 172, 197, 0.4), transparent);
}

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

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

.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.10);
    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-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(calc(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.10);
    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 {
    max-width: 860px;
    display: grid;
    gap: 18px;
}

.seo-hero .display {
    max-width: 980px;
}

.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;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    align-items: start;
    counter-reset: faq;
}

.seo-faq-column {
    display: grid;
    gap: 12px;
    align-content: start;
}

.seo-faq-item {
    counter-increment: faq;
    border: 1px solid var(--pill-line);
    border-radius: var(--r-sm);
    background: var(--pill-bg-card);
    box-shadow: var(--shadow-soft);
    overflow: hidden;
    transition: border-color 160ms ease, background-color 160ms ease, box-shadow 160ms ease;
}

.seo-faq-item[open] {
    border-color: rgba(0, 163, 163, 0.34);
    background: var(--pill-bg-soft);
    box-shadow: 0 14px 34px rgba(20, 25, 40, 0.08);
}

.seo-faq-item summary {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) 24px;
    gap: 12px;
    align-items: center;
    padding: 13px 14px;
    cursor: pointer;
    list-style: none;
}

.seo-faq-item summary:hover h3,
.seo-faq-item summary:focus-visible h3 {
    color: var(--pill-teal-strong);
}

.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: counter(faq, decimal-leading-zero);
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: var(--pill-ink);
    color: #ffffff;
    font-size: 12px;
    font-weight: 700;
}

.seo-faq-item summary::after {
    content: "+";
    display: grid;
    place-items: center;
    width: 24px;
    height: 24px;
    border: 1px solid var(--pill-line);
    border-radius: 50%;
    color: var(--pill-ink);
    font-size: 16px;
    line-height: 1;
    transition: background-color 160ms ease, border-color 160ms ease;
}

.seo-faq-item[open] summary::after {
    content: "-";
    border-color: rgba(0, 163, 163, 0.42);
    background: rgba(0, 163, 163, 0.12);
}

.seo-faq-item h3,
.pricing-credit-box h3 {
    margin: 0;
    font-family: var(--font-display);
    font-size: 18px;
    line-height: 1.22;
    font-weight: 600;
    color: var(--pill-ink);
    overflow-wrap: anywhere;
    transition: color 160ms ease;
}

.seo-faq-item p {
    margin: 0;
    padding: 0 18px 18px 60px;
    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-grid {
        grid-template-columns: 1fr;
    }

    .seo-faq-item summary {
        grid-template-columns: 32px minmax(0, 1fr) 24px;
        padding: 12px;
    }

    .seo-faq-item summary::before {
        width: 32px;
        height: 32px;
    }

    .seo-faq-item p {
        padding: 0 14px 16px 56px;
    }
}

.about-page .about-hero {
    padding: 72px 0 36px;
}

.about-page .display {
    max-width: 14ch;
}

.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: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 12px;
}

.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 haut à droite, en pill mono */
.home-calc-preset-meta {
    position: absolute;
    top: 20px;
    right: 22px;
    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;
    padding: 32px 44px;
    border-radius: var(--r-lg);
    background: var(--pill-bg-card);
    border: 1px solid var(--pill-line);
    overflow: hidden;
    position: relative;
}

.sec-hero-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 40px;
    align-items: start;
}

@media (max-width: 760px) {
    .sec-hero { padding: 20px 24px 28px; }
    .sec-hero-grid { grid-template-columns: 1fr; 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.20);
    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);
}

.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.10);
    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.30);
    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.30);
}

.project-next-action[data-tone="danger"] {
    border-color: rgba(197, 48, 48, 0.30);
    background: rgba(197, 48, 48, 0.06);
}

.project-next-action[data-tone="warning"] {
    border-color: rgba(221, 107, 32, 0.30);
    background: rgba(221, 107, 32, 0.07);
}

.project-next-action[data-tone="completed"] {
    border-color: rgba(47, 133, 90, 0.30);
    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.10);
    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.10);
    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.10);
    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, calc(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, calc(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-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;
    }
    .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(calc(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: 12px;
    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.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;
}
.pill-mark.tone-teal    { background: var(--pill-teal); color: var(--pill-ink); }
.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 .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: var(--pill-ink); --rot: 2deg; }
.sticker.tone-cyan  { background: var(--pill-cyan); color: var(--pill-ink); --rot: -1deg; }
.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;
}
