/* ============================================================
 * SEMAFOR — main.css (V42 — Neural Expressive)
 * Couche 1 : TOKENS  (variables CSS racine, palette, échelles)
 * Couche 2 : PRIMITIVES (reset, base éléments, helpers)
 * Couche 3 : COMPOSANTS (onglets, tableau, toolbar, scores, etc.)
 * ============================================================ */

/* ── @font-face self-hosted ─────────────────────────────────── */

@font-face {
  font-family: "Inter";
  src: url("../fonts/Inter.var.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal oblique 0deg 10deg;
  font-display: swap;
}

@font-face {
  font-family: "Inter Display";
  src: url("../fonts/Inter.var.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "JetBrains Mono";
  src: url("../fonts/JetBrainsMono-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "JetBrains Mono";
  src: url("../fonts/JetBrainsMono-Medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "JetBrains Mono";
  src: url("../fonts/JetBrainsMono-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ============================================================
 * COUCHE 1 — TOKENS
 * Mode clair (défaut V42)
 * ============================================================ */

:root {
  /* ── Dégradé signature (analyse en cours, score pulse) ── */
  --gradient-signature: linear-gradient(135deg, #4f8ef7 0%, #8b5cf6 50%, #ec4899 100%);

  /* ── Arrière-plans ── */
  --color-bg-base:     #ffffff;
  --color-bg-surface:  #f7f8fa;
  --color-bg-elevated: #ffffff;
  --color-bg-overlay:  rgba(15, 17, 21, .55);

  /* ── Bordures ── */
  --color-border-subtle:  #e5e7eb;
  --color-border-default: #cbd0d8;
  --color-border-strong:  #9aa0a8;

  /* ── Textes ── */
  --color-text-primary:   #0a0a0d;
  --color-text-secondary: #5b616b;
  --color-text-muted:     #9aa0a8;
  --color-text-inverse:   #ffffff;

  /* ── Accent produit — bleu Sémafor #4f8ef7 ── */
  --color-accent:        #4f8ef7;
  --color-accent-soft:   #eaf1ff;
  --color-accent-strong: #2563eb;

  /* ── Statuts sémantiques (mots-clés, validation) ── */
  --color-success:      #10b981;
  --color-success-soft: #ecfdf5;
  --color-warning:      #f59e0b;
  --color-warning-soft: #fffbeb;
  --color-danger:       #ef4444;
  --color-danger-soft:  #fef2f2;
  --color-info:         #0ea5e9;
  --color-info-soft:    #f0f9ff;
  --color-neutral:      #6b7280;
  --color-neutral-soft: #f3f4f6;

  /* ── Éditeur / suggestions IA ── */
  --editor-suggest-active:          var(--color-accent);
  --editor-suggest-add-bg:          rgba(16, 185, 129, .18);
  --editor-suggest-add-border:      rgba(16, 185, 129, .42);
  --editor-suggest-remove-bg:       rgba(239, 68, 68, .18);
  --editor-suggest-remove-border:   rgba(239, 68, 68, .42);
  --editor-diff-add:                var(--color-success);
  --editor-diff-add-bg:             var(--color-success-soft);
  --editor-diff-remove:             var(--color-danger);
  --editor-diff-remove-bg:          var(--color-danger-soft);
  --editor-goto-hl-bg:              rgba(255, 200, 0, .55);
  --editor-goto-hl-fg:              #1a1a1a;
  --editor-highlight-bg:            rgba(255, 235, 150, .45);
  --editor-highlight-selection:     rgba(255, 228, 130, .65);

  /* ── Typographie ── */
  --font-sans:    "Inter", "Inter Fallback", system-ui, -apple-system, sans-serif;
  --font-display: "Inter Display", "Inter", system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", "JetBrains Mono Fallback", ui-monospace, monospace;

  --text-xs:   12px;
  --text-sm:   13px;
  --text-base: 14px;
  --text-md:   16px;
  --text-lg:   18px;
  --text-xl:   22px;
  --text-2xl:  28px;
  --text-3xl:  36px;

  --lh-xs:   1.4;
  --lh-sm:   1.45;
  --lh-base: 1.55;
  --lh-md:   1.55;
  --lh-lg:   1.4;
  --lh-xl:   1.3;
  --lh-2xl:  1.25;
  --lh-3xl:  1.2;

  --font-weight-regular:  400;
  --font-weight-medium:   500;
  --font-weight-semibold: 600;
  --font-weight-bold:     700;

  /* ── Espacement — grille 8px stricte ── */
  --space-0: 0;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;

  /* ── Rayons ── */
  --radius-xs:   2px;
  --radius-sm:   4px;
  --radius-md:   6px;
  --radius-lg:   8px;
  --radius-xl:   10px;
  --radius-2xl:  12px;
  --radius-full: 9999px;

  /* ── Ombres ── */
  --shadow-xs:    0 1px 2px rgba(0, 0, 0, .04);
  --shadow-sm:    0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);
  --shadow-md:    0 4px 8px rgba(0, 0, 0, .08);
  --shadow-lg:    0 8px 24px rgba(0, 0, 0, .12);
  --shadow-xl:    0 16px 48px rgba(0, 0, 0, .16);
  --shadow-focus: 0 0 0 3px rgba(79, 142, 247, .25);

  /* ── Durées & easings ── */
  --duration-instant:    0ms;
  --duration-fast:       120ms;
  --duration-base:       200ms;
  --duration-slow:       320ms;
  --duration-deliberate: 480ms;

  --ease-default: cubic-bezier(.2, .8, .2, 1);
  --ease-in:      cubic-bezier(.4, 0, 1, 1);
  --ease-out:     cubic-bezier(0, 0, .2, 1);
  --ease-spring:  cubic-bezier(.34, 1.56, .64, 1);

  /* ── Z-index ── */
  --z-base:             0;
  --z-dropdown:         100;
  --z-sticky:           200;
  --z-fixed:            300;
  --z-overlay-backdrop: 900;
  --z-modal:            1000;
  --z-tooltip:          1100;
  --z-toast:            1200;

  /* ── Largeurs de bordure ── */
  --border-width-thin:   1px;
  --border-width-medium: 2px;
  --border-width-thick:  3px;

  /* ── Layout header ── */
  --header-logo-max-h: 2.5rem;
  --app-header-height: calc(2 * var(--space-4) + var(--header-logo-max-h));

  /* ── Rétrocompat — aliases vers nouveaux tokens ── */
  --color-bg:               var(--color-bg-base);
  --color-surface:          var(--color-bg-surface);
  --color-surface-elevated: var(--color-bg-elevated);
  --color-border:           var(--color-border-default);
  --color-border-muted:     var(--color-border-subtle);
  --color-text:             var(--color-text-primary);
  --color-accent-dim:       var(--color-accent-soft);
  --color-danger-bg:        var(--color-danger-soft);
  --color-warn:             var(--color-warning);
  --color-ok:               var(--color-success);
  --color-ok-bg:            var(--color-success-soft);
  --shadow-soft:            var(--shadow-lg);

  /* Rétrocompat — tokens éditeur (anciens noms) */
  --goto-hl-bg:                       var(--editor-goto-hl-bg);
  --goto-hl-color:                    var(--editor-goto-hl-fg);
  --hl-yellow-bg:                     var(--editor-highlight-bg);
  --hl-yellow-selection:              var(--editor-highlight-selection);
  --suggestion-active:                var(--editor-suggest-active);
  --suggestion-active-bg:             var(--color-accent-soft);
  --suggestion-pending-add:           var(--editor-suggest-add-bg);
  --suggestion-pending-add-border:    var(--editor-suggest-add-border);
  --suggestion-pending-remove:        var(--editor-suggest-remove-bg);
  --suggestion-pending-remove-border: var(--editor-suggest-remove-border);
  --suggestion-accepted:              var(--color-success);
  --suggestion-accepted-bg:           var(--color-success-soft);
  --suggestion-rejected:              var(--color-danger);
  --suggestion-rejected-bg:           var(--color-danger-soft);
  --diff-added:                       var(--editor-diff-add);
  --diff-removed:                     var(--editor-diff-remove);
  --diff-added-bg:                    var(--editor-diff-add-bg);
  --diff-removed-bg:                  var(--editor-diff-remove-bg);
}

/* ── Mode sombre ─────────────────────────────────────────────── */

[data-theme="dark"] {
  /* Arrière-plans */
  --color-bg-base:     #0a0a0d;
  --color-bg-surface:  #15161a;
  --color-bg-elevated: #1d1e23;
  --color-bg-overlay:  rgba(0, 0, 0, .65);

  /* Bordures */
  --color-border-subtle:  #26282e;
  --color-border-default: #3a3d44;
  --color-border-strong:  #5a5d65;

  /* Textes */
  --color-text-primary:   #f5f6f8;
  --color-text-secondary: #a0a4ad;
  --color-text-muted:     #6b6f78;
  --color-text-inverse:   #0a0a0d;

  /* Accent */
  --color-accent:        #5fa3ff;
  --color-accent-soft:   #1a2540;
  --color-accent-strong: #7eb4ff;

  /* Statuts */
  --color-success:      #34d399;
  --color-success-soft: #0a2820;
  --color-warning:      #fbbf24;
  --color-warning-soft: #2a2010;
  --color-danger:       #f87171;
  --color-danger-soft:  #2a1212;
  --color-info:         #38bdf8;
  --color-info-soft:    #0a2030;
  --color-neutral:      #9ca3af;
  --color-neutral-soft: #1a1c20;

  /* Éditeur sombre */
  --editor-suggest-add-bg:        rgba(52, 211, 153, .18);
  --editor-suggest-add-border:    rgba(52, 211, 153, .42);
  --editor-suggest-remove-bg:     rgba(248, 113, 113, .18);
  --editor-suggest-remove-border: rgba(248, 113, 113, .42);
  --editor-goto-hl-bg:            rgba(255, 210, 0, .72);
  --editor-highlight-bg:          rgba(255, 245, 200, .35);
  --editor-highlight-selection:   rgba(255, 240, 180, .55);

  /* Ombres renforcées */
  --shadow-xs:    0 1px 2px rgba(0, 0, 0, .30);
  --shadow-sm:    0 1px 3px rgba(0, 0, 0, .40), 0 1px 2px rgba(0, 0, 0, .30);
  --shadow-md:    0 4px 8px rgba(0, 0, 0, .45);
  --shadow-lg:    0 8px 24px rgba(0, 0, 0, .55);
  --shadow-xl:    0 16px 48px rgba(0, 0, 0, .65);
  --shadow-focus: 0 0 0 3px rgba(95, 163, 255, .35);
}

/* ── Visibilité par mode d'interface (Épuré / Rédacteur / SEO) ── */

[data-ui-mode="epure"] [data-mode-min="redacteur"],
[data-ui-mode="epure"] [data-mode-min="seo"],
[data-ui-mode="epure"] [data-summary-min="redacteur"],
[data-ui-mode="epure"] [data-summary-min="seo"],
[data-ui-mode="epure"] [data-control-min="redacteur"],
[data-ui-mode="epure"] [data-control-min="seo"] {
  display: none !important;
}

[data-ui-mode="redacteur"] [data-mode-min="seo"],
[data-ui-mode="redacteur"] [data-summary-min="seo"],
[data-ui-mode="redacteur"] [data-control-min="seo"] {
  display: none !important;
}

[data-ui-mode="redacteur"] [data-mode-max="epure"],
[data-ui-mode="seo"] [data-mode-max="epure"] {
  display: none !important;
}

/* rétrocompat V42 (migration localStorage en cours) */
[data-ui-mode="decouverte"] [data-mode-min="standard"],
[data-ui-mode="decouverte"] [data-mode-min="expert"],
[data-ui-mode="decouverte"] [data-mode-min="redacteur"],
[data-ui-mode="decouverte"] [data-mode-min="seo"] {
  display: none !important;
}

[data-ui-mode="standard"] [data-mode-min="expert"],
[data-ui-mode="standard"] [data-mode-min="seo"] {
  display: none !important;
}

[data-ui-mode="redacteur"] .epure-only,
[data-ui-mode="seo"] .epure-only {
  display: none !important;
}

.seo-emphasis-entete .seo-sub-tab[data-seo-subtab="seo-entete"] {
  font-weight: 600;
  box-shadow: inset 0 -2px 0 var(--color-accent);
}

body.page-type-emphasis-enrich .tabs-workshop .tab[data-tab="enrichissement"] {
  font-weight: 600;
}

.epure-mini-audit {
  margin: var(--space-3) 0;
  padding: var(--space-3);
  background: var(--color-surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.epure-mini-audit__list {
  list-style: none;
  margin: var(--space-2) 0 0;
  padding: 0;
}

.epure-mini-audit__list li {
  display: flex;
  gap: var(--space-2);
  align-items: flex-start;
  padding: var(--space-1) 0;
  font-size: 0.875rem;
}

.epure-mini-audit__icon {
  flex-shrink: 0;
}

.epure-mini-audit__btn {
  display: flex;
  gap: var(--space-2);
  align-items: flex-start;
  width: 100%;
  margin: 0;
  padding: var(--space-1);
  border: 0;
  border-radius: var(--radius-sm);
  background: transparent;
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.epure-mini-audit__item--action .epure-mini-audit__btn:hover,
.epure-mini-audit__item--action .epure-mini-audit__btn:focus-visible {
  background: rgba(37, 99, 235, 0.08);
  outline: 2px solid var(--color-accent);
  outline-offset: 1px;
}

.epure-mini-audit__list li:not(.epure-mini-audit__item--action) {
  cursor: default;
}

.ai-assist-accordion.ai-epure-simplified .ai-assist-hint::after {
  content: " — une suggestion à la fois";
}

/* ============================================================
 * COUCHE 2 — PRIMITIVES
 * ============================================================ */

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

html {
  font-size: 16px;
}

body.app-body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-sans);
  background: var(--color-bg);
  color: var(--color-text);
  line-height: 1.5;
}

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

.app-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ============================================================
 * COUCHE 3 — COMPOSANTS
 * ============================================================ */

/* ── App header ── */
.app-header {
  position: sticky;
  top: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border-muted);
  background: var(--color-surface);
}

/* ── Heroicons sprite (macro `icon`) ── */
.icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  flex-shrink: 0;
  vertical-align: -0.125em;
  fill: none;
  stroke: currentColor;
  overflow: visible;
}

.icon--sm {
  width: 0.875em;
  height: 0.875em;
}

.icon--xs {
  width: 1em;
  height: 1em;
}

.counter .icon {
  width: 1.3em;
  height: 1.3em;
  flex-shrink: 0;
}

.kw-expression .icon,
.col-action .icon,
.kw-review-actions .icon {
  width: 1.15em;
  height: 1.15em;
}

.icon-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25em;
  vertical-align: middle;
}

.icon--md {
  width: 1.125em;
  height: 1.125em;
}

.icon--status-ok { color: var(--color-success); }
.icon--status-warn { color: var(--color-warning); }
.icon--status-danger { color: var(--color-danger); }
.icon--status-info { color: var(--color-accent); }
.icon--status-muted { color: var(--color-text-muted); }

.app-header-start {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  min-width: 0;
  flex: 1 1 auto;
}

.app-breadcrumb {
  min-width: 0;
  flex: 1 1 auto;
  overflow: hidden;
}

.app-breadcrumb__list {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
  white-space: nowrap;
  min-width: 0;
}

.app-breadcrumb__item {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  max-width: 12rem;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.app-breadcrumb__item:not(:last-child) {
  flex-shrink: 1;
}

.app-breadcrumb__item:last-child {
  flex-shrink: 0;
  max-width: 16rem;
  color: var(--color-text-primary);
  font-weight: var(--font-weight-medium);
}

.app-breadcrumb__item + .app-breadcrumb__item::before {
  content: "›";
  margin: 0 var(--space-2);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

.app-breadcrumb__link {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  color: inherit;
  text-decoration: none;
}

.app-breadcrumb__link:hover {
  color: var(--color-accent);
}

.app-breadcrumb__current {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.btn .icon,
.chip .icon {
  margin-right: 0.25em;
}

.alpha-banner {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  margin: 0 0 var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid rgba(245, 158, 11, 0.45);
  background: var(--color-warning-soft);
  color: var(--color-text-primary);
  font-size: var(--text-sm);
  line-height: var(--lh-sm);
}

.alpha-banner__icon {
  flex-shrink: 0;
  margin-top: 0.1em;
  color: var(--color-warning);
}

.alpha-banner__text strong {
  font-weight: var(--font-weight-semibold);
}

/* Lot F — utilitaires layout (remplace style="" inline templates) */
.section-head--hero {
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.section-head--hero .page-title {
  margin: 0;
  flex: 1;
}

.pages-search-input {
  margin-bottom: var(--space-2);
  padding: var(--space-2) var(--space-3);
  width: 100%;
  box-sizing: border-box;
}

.dialog--wide {
  max-width: 680px;
  width: 100%;
}

.field-label--mt-sm {
  margin-top: 0.6rem;
}

.field-label--mt-xs {
  margin-top: 0.4rem;
}

.field--mt-md {
  margin-top: 0.75rem;
}

.advisor-result--gen {
  margin-top: 0.5rem;
  min-height: 1.2em;
}

.advisor-result--new {
  margin-top: 0.4rem;
}

.dialog-actions--mb-sm {
  margin-bottom: 0.5rem;
}

.dialog-actions--mt-md {
  margin-top: 1rem;
}

.gen-proposal-divider {
  border: none;
  border-top: 1px solid var(--color-border-muted);
  margin: 1rem 0;
}

.gen-proposal-title {
  margin: 0 0 0.6rem;
  font-size: 1rem;
}

.gen-advisor-badge {
  margin-bottom: 0.5rem;
}

.gen-pilier-row {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 0.5rem;
}

.input--flex-2 {
  flex: 2;
  min-width: 0;
}

.input--flex-1 {
  flex: 1;
  min-width: 0;
}

.gen-satellites-list {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin-bottom: 0.5rem;
}

.btn--align-start {
  align-self: flex-start;
}

.gen-serp-urls--spaced {
  margin-top: 0.75rem;
  margin-bottom: 0.25rem;
}

.badge--lg {
  font-size: 1rem;
}

.cocon-pilier-block {
  margin-bottom: 0.75rem;
}

.subpanel-title--sm {
  font-size: 0.95rem;
  margin-top: 0.5rem;
}

.data-list--indented {
  margin: 0;
  padding-left: 1.2rem;
}

.data-list__item--spaced {
  margin-bottom: 0.5rem;
}

.cocon-detail-input {
  min-width: 220px;
}

.settings-field--disabled {
  opacity: 0.5;
}

.login-page {
  max-width: 28rem;
  margin: var(--space-8) auto;
}

.login-page__brand {
  margin: 0 0 var(--space-5);
  text-align: center;
}

.login-page__logo {
  display: inline-block;
  max-width: min(200px, 70vw);
  height: auto;
  object-fit: contain;
}

.login-page__title {
  font-size: 1.5rem;
  margin-bottom: var(--space-2);
}

.login-page__lead {
  margin-bottom: var(--space-6);
}

.login-page__error {
  color: var(--color-danger);
  margin-bottom: var(--space-4);
}

.login-page__footer {
  margin-top: var(--space-6);
  font-size: 0.9rem;
  color: var(--color-text-muted);
}

.input--max-w-sm {
  max-width: 200px;
}

.input--max-w-md {
  max-width: 220px;
}

.suggestion-cache-banner {
  background: var(--color-accent-soft);
  padding: var(--space-2) var(--space-3);
  font-size: 0.85em;
  border-bottom: 1px solid rgba(79, 142, 247, 0.35);
}

.import-status:not(.is-visible) {
  display: none;
}

.import-status.is-visible {
  display: inline;
}

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

.header-right {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  justify-content: flex-end;
}

.btn-theme-toggle {
  font-family: var(--font-sans);
  font-size: 0.8rem;
  font-weight: 600;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-surface-elevated);
  color: var(--color-text-muted);
  cursor: pointer;
  flex-shrink: 0;
}

.btn-theme-toggle:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
  background: var(--color-accent-dim);
}

/* Lien aide (? ) — même famille visuelle que le bouton thème */
.btn-header-help {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  height: 2.25rem;
  font-family: var(--font-sans);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  padding: 0 var(--space-2);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-surface-elevated);
  color: var(--color-text-muted);
  text-decoration: none;
  flex-shrink: 0;
}

.btn-header-help:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
  background: var(--color-accent-dim);
}

/* Bouton signalement bug (beta) */
.btn-bug-report {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  height: 2.25rem;
  padding: 0 var(--space-3);
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(220, 38, 38, 0.45);
  background: rgba(220, 38, 38, 0.08);
  color: #b91c1c;
  cursor: pointer;
  transition: background var(--duration-fast), border-color var(--duration-fast);
}

.btn-bug-report:hover {
  background: rgba(220, 38, 38, 0.15);
  border-color: #dc2626;
  color: #991b1b;
}

.btn-bug-report:focus-visible {
  outline: 2px solid #dc2626;
  outline-offset: 2px;
}

/* Modal bug report */
.bug-report-overlay {
  position: fixed;
  inset: 0;
  z-index: 2200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background: rgba(15, 23, 42, 0.55);
}

.bug-report-overlay.hidden {
  display: none !important;
}

body.bug-report-open {
  overflow: hidden;
}

.bug-report-modal {
  width: min(520px, 100%);
  max-height: min(90vh, 720px);
  display: flex;
  flex-direction: column;
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-soft);
}

.bug-report-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border-muted);
}

.bug-report-title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
}

.bug-report-close {
  border: none;
  background: transparent;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
  color: var(--color-text-secondary);
  padding: 0 var(--space-1);
}

.bug-report-close:hover {
  color: var(--color-text);
}

.bug-report-modal-body {
  padding: var(--space-4) var(--space-5);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.bug-report-severity {
  border: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.bug-report-severity .field-label {
  width: 100%;
  margin-bottom: var(--space-1);
}

.bug-report-radio {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: 0.88rem;
  cursor: pointer;
}

.bug-report-textarea {
  width: 100%;
  min-height: 120px;
  resize: vertical;
}

.bug-report-screenshot-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.bug-report-screenshot-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.bug-report-screenshot-thumb {
  display: block;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-sm);
  overflow: hidden;
  line-height: 0;
}

.bug-report-screenshot-thumb img {
  display: block;
  max-width: 200px;
  max-height: 120px;
  object-fit: contain;
  background: var(--color-bg);
}

.bug-report-modal-foot {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5) var(--space-4);
  border-top: 1px solid var(--color-border-muted);
}

/* ── Sélecteur de mode d'interface (V42 Brief 2) ── */

.ui-mode-switcher {
  display: flex;
  align-items: center;
  gap: 2px;
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-full);
  padding: 3px;
  flex-shrink: 0;
}

/* ── Interrupteur Recommandations (guidance) ── */

.reco-mode-switcher {
  display: flex;
  align-items: center;
  gap: 2px;
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-full);
  padding: 3px 3px 3px var(--space-2);
  flex-shrink: 0;
}

.reco-mode-switcher__label {
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
  white-space: nowrap;
  padding-right: var(--space-1);
}

.reco-mode-btn {
  display: flex;
  align-items: center;
  padding: var(--space-1) var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: color var(--duration-fast) var(--ease-default),
              background var(--duration-fast) var(--ease-default);
}

.reco-mode-btn:hover {
  color: var(--color-text-primary);
}

.reco-mode-btn[aria-pressed="true"] {
  box-shadow: var(--shadow-xs);
}

.reco-mode-btn[data-reco="on"][aria-pressed="true"] {
  background: var(--color-success);
  color: #ffffff;
}

.reco-mode-btn[data-reco="off"][aria-pressed="true"] {
  background: var(--color-danger);
  color: #ffffff;
}

.reco-mode-btn[data-reco="on"][aria-pressed="true"]:hover {
  color: #ffffff;
  filter: brightness(1.05);
}

.reco-mode-btn[data-reco="off"][aria-pressed="true"]:hover {
  color: #ffffff;
  filter: brightness(1.05);
}

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

.ui-mode-btn {
  display: flex;
  align-items: center;
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: color var(--duration-fast) var(--ease-default),
              background var(--duration-fast) var(--ease-default);
  white-space: nowrap;
}

.ui-mode-btn:hover {
  color: var(--color-text-primary);
}

.ui-mode-btn[aria-pressed="true"] {
  background: var(--color-accent);
  color: var(--color-text-inverse);
  box-shadow: var(--shadow-xs);
}

.ui-mode-btn:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

.ui-mode-btn__label--short {
  display: none;
}

@media (max-width: 900px) {
  .ui-mode-btn {
    font-size: 11px;
    padding: var(--space-1) var(--space-2);
  }
}

@media (max-width: 768px) {
  .ui-mode-btn__label--full {
    display: none;
  }
  .ui-mode-btn__label--short {
    display: inline;
  }
}

/* ══ Page Aide — layout pleine largeur ══════════════════════════════════════ */

.app-main.aide-main {
  max-width: none;
  padding: 0;
}

/* Layout sidebar + contenu */
.aide-page {
  display: flex;
  align-items: flex-start;
  min-height: calc(100vh - var(--app-header-height));
}

/* Sidebar */
.aide-sidebar {
  width: 220px;
  flex-shrink: 0;
  position: sticky;
  top: var(--app-header-height);
  max-height: calc(100vh - var(--app-header-height));
  overflow-y: auto;
  padding: var(--space-6) var(--space-4);
  border-right: 1px solid var(--color-border-muted);
  scrollbar-width: thin;
}

.aide-sidebar-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.aide-sidebar-label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  margin: 0 0 var(--space-2);
}

.aide-nav {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.aide-nav-link {
  display: block;
  padding: 6px var(--space-3);
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: background var(--duration-fast), color var(--duration-fast);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.aide-nav-link:hover {
  background: var(--color-bg);
  color: var(--color-text);
}

.aide-nav-link.active {
  background: var(--color-accent-soft);
  color: var(--color-accent);
  font-weight: 600;
}

/* Contenu principal */
.aide-content {
  flex: 1;
  min-width: 0;
  padding: var(--space-6) var(--space-7);
  max-width: 900px;
}

/* Hero */
.aide-hero {
  margin-bottom: var(--space-7);
}

.aide-hero-title {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  margin: 0 0 var(--space-2);
  color: var(--color-text);
}

.aide-hero-lead {
  font-size: 1.05rem;
  color: var(--color-text-secondary);
  margin: 0;
}

/* Sections */
.aide-section {
  padding-top: var(--space-7);
  border-top: 1px solid var(--color-border-muted);
  margin-top: var(--space-7);
}

.aide-section:first-of-type {
  margin-top: 0;
  border-top: none;
  padding-top: 0;
}

.aide-section-title {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0 0 var(--space-4);
  color: var(--color-text);
}

.aide-h3 {
  font-size: 0.95rem;
  font-weight: 700;
  margin: var(--space-5) 0 var(--space-2);
  color: var(--color-text);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Steps */
.aide-steps {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.aide-step {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-md);
}

.aide-step-num {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-accent);
  color: #fff;
  font-weight: 700;
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.aide-step-body {
  flex: 1;
  min-width: 0;
}

.aide-step-body strong {
  display: block;
  margin-bottom: var(--space-1);
}

.aide-step-body p {
  margin: 0;
  font-size: 0.9rem;
  color: var(--color-text-secondary);
}

/* Cards */
.aide-cards-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-3);
  margin: var(--space-4) 0;
}

.aide-card {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-md);
}

.aide-card--sm {
  flex-direction: column;
  gap: var(--space-1);
}

.aide-card--sm p {
  margin: 0;
  font-size: 0.85rem;
  color: var(--color-text-secondary);
}

.aide-card--expert-only {
  border-color: rgba(139, 92, 246, 0.3);
  background: rgba(139, 92, 246, 0.04);
}

.aide-card-icon {
  font-size: 1.4rem;
  line-height: 1;
  flex-shrink: 0;
}

.aide-card-body {
  flex: 1;
  min-width: 0;
}

.aide-card-body strong {
  display: block;
  margin-bottom: var(--space-1);
}

.aide-card-body p {
  margin: 0;
  font-size: 0.85rem;
  color: var(--color-text-secondary);
}

/* Modes */
.aide-mode-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-3);
  margin: var(--space-4) 0;
}

.aide-mode-card {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-muted);
}

.aide-mode-card ul {
  margin: var(--space-2) 0 0;
  padding-left: var(--space-4);
  font-size: 0.85rem;
  color: var(--color-text-secondary);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.aide-mode-card--decouverte {
  background: var(--color-success-soft);
  border-color: rgba(16, 185, 129, 0.35);
}

.aide-mode-card--standard {
  background: var(--color-info-soft);
  border-color: rgba(59, 130, 246, 0.35);
}

.aide-mode-card--expert {
  background: rgba(139, 92, 246, 0.06);
  border-color: rgba(139, 92, 246, 0.3);
}

.aide-mode-badge {
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.aide-mode-card--decouverte .aide-mode-badge { color: #047857; }
.aide-mode-card--standard .aide-mode-badge { color: #1d4ed8; }
.aide-mode-card--expert .aide-mode-badge { color: #7c3aed; }

/* Callouts */
.aide-callout {
  margin: var(--space-4) 0;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-muted);
  background: var(--color-bg-surface);
  font-size: 0.9rem;
}

.aide-callout--tip {
  background: var(--color-success-soft);
  border-color: rgba(16, 185, 129, 0.35);
}

.aide-callout--info {
  background: var(--color-info-soft);
  border-color: rgba(59, 130, 246, 0.35);
}

/* Table */
.aide-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: var(--space-3) 0;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-md);
}

.aide-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.aide-table th {
  background: var(--color-bg-surface);
  font-weight: 600;
  text-align: left;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border-muted);
  white-space: nowrap;
}

.aide-table td {
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border-muted);
  vertical-align: top;
}

.aide-table tr:last-child td {
  border-bottom: none;
}

.aide-table tr:hover td {
  background: var(--color-bg);
}

/* Badges statut */
.aide-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
}

.aide-badge--ajouter { background: var(--color-info-soft); color: #1d4ed8; }
.aide-badge--optimal { background: var(--color-success-soft); color: #047857; }
.aide-badge--insuffisant { background: var(--color-warning-soft); color: #b45309; }
.aide-badge--reduire { background: rgba(239, 68, 68, 0.1); color: #b91c1c; }
.aide-badge--verifier { background: rgba(139, 92, 246, 0.1); color: #6d28d9; }
.aide-badge--ignore { background: var(--color-neutral-soft); color: var(--color-text-secondary); }
.aide-badge-expert {
  display: inline-block;
  padding: 1px 6px;
  border-radius: var(--radius-sm);
  font-size: 0.68rem;
  font-weight: 700;
  background: rgba(139, 92, 246, 0.12);
  color: #7c3aed;
  vertical-align: middle;
  margin-left: 4px;
}

/* Tags / chips */
.aide-tags-row,
.aide-chips-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: var(--space-2) 0 var(--space-4);
}

.aide-tag {
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-muted);
  font-size: 0.82rem;
  color: var(--color-text-secondary);
}

.aide-chip {
  padding: 3px 10px;
  border-radius: 20px;
  background: var(--color-bg);
  border: 1px solid var(--color-border-default);
  font-size: 0.78rem;
  color: var(--color-text-secondary);
}

/* Toolbar preview */
.aide-toolbar-preview {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  margin: var(--space-3) 0 var(--space-4);
  color: var(--color-text-secondary);
}

.aide-toolbar-sep {
  color: var(--color-border-default);
  margin: 0 2px;
}

.aide-toolbar-group {
  color: var(--color-text);
}

/* Raccourcis clavier */
.aide-shortcut-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-2);
  margin: var(--space-3) 0;
}

.aide-shortcut {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-sm);
  font-size: 0.82rem;
}

.aide-shortcut span {
  color: var(--color-text-secondary);
}

kbd {
  display: inline-block;
  padding: 1px 5px;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  background: var(--color-bg);
  border: 1px solid var(--color-border-default);
  border-radius: 3px;
  box-shadow: 0 1px 0 var(--color-border-default);
  white-space: nowrap;
}

.code-inline {
  font-family: var(--font-mono);
  font-size: 0.82em;
  background: var(--color-bg);
  border: 1px solid var(--color-border-muted);
  border-radius: 3px;
  padding: 1px 4px;
}

/* Responsive */
@media (max-width: 900px) {
  .aide-sidebar {
    display: none;
  }
  .aide-content {
    padding: var(--space-5) var(--space-5);
  }
  .aide-hero-title {
    font-size: 1.5rem;
  }
}

@media (max-width: 640px) {
  .aide-mode-cards,
  .aide-cards-row {
    grid-template-columns: 1fr;
  }
  .aide-content {
    padding: var(--space-4);
  }
}

.brand-link {
  position: relative;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
}

.brand-logo-wrap {
  display: grid;
  place-items: start center;
  flex-shrink: 0;
  min-height: var(--header-logo-max-h);
}

.brand-logo {
  grid-area: 1 / 1;
  max-height: var(--header-logo-max-h);
  width: auto;
  max-width: min(200px, 42vw);
  object-fit: contain;
  object-position: left center;
}

/* Sombre → logo blanc ; clair → logo noir */
.brand-logo--for-light-ui {
  display: none;
}

[data-theme="light"] .brand-logo--for-light-ui {
  display: block;
}

[data-theme="light"] .brand-logo--for-dark-ui {
  display: none;
}

.brand-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 2px;
  min-width: 0;
}

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

.brand-tag {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  line-height: 1.35;
}

.header-nav .link-muted {
  color: var(--color-text-muted);
  text-decoration: none;
  font-size: 0.9rem;
}

.header-nav .link-muted:hover {
  color: var(--color-accent);
}

.app-main {
  flex: 1;
  padding: var(--space-5);
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
}

.app-main.app-main-workshop {
  max-width: none;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}

/* Onglet fixe bureau : scores + sauvegarde rapide (60px) */
.editor-score-dock {
  display: none;
}

@media (min-width: 1024px) {
  .editor-score-dock {
    display: block;
    position: fixed;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 60px;
    max-height: min(90vh, calc(100vh - var(--app-header-height) - var(--space-5)));
    z-index: 45;
    box-sizing: border-box;
    padding: var(--space-2) var(--space-1);
    border-radius: var(--radius-md) 0 0 var(--radius-md);
    border: 1px solid rgba(203, 208, 216, 0.65);
    border-right: none;
    background: rgba(255, 255, 255, 0.80);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    box-shadow: -4px 0 20px rgba(0, 0, 0, 0.12);
    overflow-y: auto;
  }

  [data-theme="light"] .editor-score-dock {
    background: rgba(255, 255, 255, 0.80);
    box-shadow: -3px 0 16px var(--shadow-sm);
  }

  .editor-score-dock__inner {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-2);
    text-align: center;
  }

  .editor-score-dock__block {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    align-items: center;
  }

  .editor-score-dock__label {
    font-size: 0.58rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
    line-height: 1.2;
  }

  .editor-score-dock__value-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.1rem;
    width: 100%;
  }

  .editor-score-dock__value {
    font-size: 0.78rem;
    line-height: 1.25;
    word-break: break-word;
  }

  .editor-score-dock__value--target {
    font-size: 0.65rem;
  }

  .editor-score-dock__loading {
    font-size: 0.55rem;
    opacity: 0;
    transition: opacity 0.2s;
    line-height: 1.1;
  }

  .editor-score-dock__loading.visible {
    opacity: 1;
  }

  .editor-score-dock__progress {
    width: 100%;
    margin: 0;
    height: 4px;
    border-radius: var(--radius-sm);
  }

  .editor-score-dock__progress .progress-bar {
    min-height: 4px;
  }

  .editor-score-dock__label--stacked {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    line-height: 1.05;
    text-transform: none;
    letter-spacing: 0.02em;
    font-weight: 600;
  }

  .editor-score-dock__label-line {
    display: block;
    font-size: 0.52rem;
    color: var(--color-text-muted);
  }

  .editor-score-dock__block--volume {
    gap: 0.25rem;
  }

  .editor-score-dock__volume-stack {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.18rem;
    width: 100%;
    line-height: 1.1;
  }

  .editor-score-dock__volume-bound {
    font-size: 0.58rem;
    color: var(--color-text-muted);
  }

  .editor-score-dock__volume-current {
    font-weight: 700;
    font-size: 0.72rem;
    color: var(--color-accent);
  }

  .editor-score-dock .word-count-signal--dock {
    padding: 0.1rem 0;
  }

  .editor-score-dock__save {
    width: 100%;
    padding: 0.3rem var(--space-1);
    font-size: 0.95rem;
    line-height: 1;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .editor-score-dock__save-icon {
    display: inline-block;
    line-height: 1;
  }
}

/* Atelier rédaction : éditeur à gauche, onglets d’analyse à droite */
.workshop {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  align-items: stretch;
}

@media (min-width: 1024px) {
  .workshop {
    flex-direction: row;
    align-items: flex-start;
    min-width: 0;
  }

  /* Colonne gauche : flux naturel — la page défile.
     Les métas défilent avec la page ; seul le panneau éditeur colle. */
  .workshop-editor-col {
    flex: 1 1 48%;
    min-width: 0;
    display: flex;
    flex-direction: column;
  }

  /* Inner : pas de scroll propre, s'étend avec son contenu */
  .workshop-editor-col-inner {
    display: flex;
    flex-direction: column;
  }

  /* Colonne analyse : sticky sous le header, hauteur viewport restante */
  .workshop-tools-col {
    flex: 1 1 46%;
    min-width: 0;
    max-width: 100%;
    position: sticky;
    top: var(--app-header-height);
    height: calc(100vh - var(--app-header-height));
    max-height: calc(100vh - var(--app-header-height));
    overflow: hidden;
    display: flex;
    flex-direction: column;
  }

  .workshop-resizer {
    display: block;
    align-self: stretch;
    position: sticky;
    top: var(--app-header-height);
    height: calc(100vh - var(--app-header-height));
  }
}

.workshop-resizer {
  display: none;
  flex-shrink: 0;
  width: 7px;
  margin: 0 1px;
  align-self: stretch;
  min-height: 160px;
  cursor: col-resize;
  border-radius: var(--radius-sm);
  background: var(--color-border-muted);
  border: 1px solid transparent;
  box-sizing: border-box;
}

.workshop-resizer:hover,
.workshop-resizer:focus-visible {
  background: var(--color-accent-dim);
  border-color: var(--color-border);
  outline: none;
}

body.workshop-resizing {
  cursor: col-resize !important;
  user-select: none;
}

.workshop-editor-title,
.workshop-tools-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 var(--space-2);
}

.workshop-editor-hint {
  margin: 0 0 var(--space-3);
}

.panel-meta-fields {
  margin-bottom: var(--space-4);
  padding: var(--space-4);
}

.panel-meta-fields--tab {
  margin-bottom: 0;
  padding: 0;
}

/* V43 — Schema JSON-LD */
.schema-jsonld-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}

.schema-jsonld-head .subpanel-title {
  margin: 0;
}

.schema-jsonld-hint {
  margin: 0 0 var(--space-3);
}

.schema-form-wrap .schema-field {
  margin-bottom: var(--space-3);
}

.schema-field-req {
  color: var(--color-warning, #c67600);
}

.schema-field-incomplete {
  border-color: var(--color-warning, #e6a020) !important;
  box-shadow: 0 0 0 1px rgba(230, 160, 32, 0.35);
}

.schema-view-toggle-wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  margin: var(--space-3) 0;
}

.schema-incomplete-badge {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #8a5500;
  background: rgba(230, 160, 32, 0.15);
  border-radius: var(--radius-sm, 4px);
}

.schema-jsonld-code {
  width: 100%;
  min-height: 14rem;
  font-size: 0.8rem;
  line-height: 1.4;
  resize: vertical;
  margin-bottom: var(--space-3);
}

.schema-code-view.hidden,
.schema-form-wrap.hidden {
  display: none !important;
}

/* ── Sous-onglets SEO (Analyse SEO / En-tête & JSON-LD) ── */
.seo-sub-tabs,
.enrich-sub-tabs {
  display: flex;
  gap: var(--space-1);
  margin-bottom: var(--space-4);
  border-bottom: 2px solid var(--border-muted, #e2e8f0);
  padding-bottom: 0;
}
.seo-sub-tab,
.enrich-sub-tab {
  padding: 0.35rem 0.85rem;
  font-size: 0.82rem;
  font-weight: 500;
  border: none;
  background: none;
  cursor: pointer;
  color: var(--text-muted, #64748b);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  border-radius: var(--radius-sm, 4px) var(--radius-sm, 4px) 0 0;
  transition: color 0.15s, border-color 0.15s;
}
.seo-sub-tab:hover,
.enrich-sub-tab:hover {
  color: var(--text, #1e293b);
  background: var(--bg-hover, #f1f5f9);
}
.seo-sub-tab.active,
.seo-sub-tab[aria-selected="true"],
.enrich-sub-tab.active,
.enrich-sub-tab[aria-selected="true"] {
  color: var(--primary, #2563eb);
  border-bottom-color: var(--primary, #2563eb);
  font-weight: 600;
}

/* ── Plan rédacteur (sous-onglet SEO) ── */
.plan-editorial-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.plan-warnings {
  margin: var(--space-3) 0;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm, 4px);
  background: #fef9c3;
  border: 1px solid #fde047;
}
.plan-warning-msg {
  margin: 0;
  font-size: 0.85rem;
}
.plan-sections {
  list-style: none;
  padding: 0;
  margin: var(--space-3) 0;
}
.plan-section {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border-muted, #e2e8f0);
}
.plan-section-head {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.plan-section-title {
  flex: 1 1 auto;
  font-weight: 600;
}
.plan-freq {
  flex-shrink: 0;
}
.plan-kw-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: var(--space-2);
}
.plan-kw-chip {
  display: inline-block;
  padding: 0.15rem 0.5rem;
  font-size: 0.75rem;
  border-radius: 999px;
  background: var(--surface-muted, #f1f5f9);
  border: 1px solid var(--border-muted, #e2e8f0);
}
.plan-kw-chip--gap {
  background: #fff7ed;
  border-color: #fdba74;
}
.plan-questions {
  margin: var(--space-2) 0 0 1.5rem;
}
.plan-uncovered,
.plan-unmatched {
  margin-top: var(--space-4);
}

.llm-jsonld-hint {
  margin-top: var(--space-2);
  padding: 0.35rem 0.6rem;
  border-left: 3px solid var(--primary, #2563eb);
  background: rgba(37, 99, 235, 0.06);
  border-radius: 0 var(--radius-sm, 4px) var(--radius-sm, 4px) 0;
  font-size: 0.78rem;
}

.schema-ia-prefilled-badge {
  display: inline-block;
  margin-bottom: var(--space-3);
  padding: 0.15rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: #1a5c3a;
  background: rgba(40, 167, 69, 0.12);
  border-radius: var(--radius-sm, 4px);
}

.schema-analysis-prefilled-badge {
  display: inline-block;
  margin: 0 var(--space-2) var(--space-3) 0;
  padding: 0.15rem 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-info, #2563eb);
  background: rgba(37, 99, 235, 0.1);
  border-radius: var(--radius-sm, 4px);
}

.meta-prefill-badge {
  display: inline-block;
  margin-left: var(--space-2);
  padding: 0.1rem 0.45rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--color-info, #2563eb);
  background: rgba(37, 99, 235, 0.1);
  border-radius: var(--radius-sm, 4px);
  vertical-align: middle;
}

.kw-priority-label {
  font-size: 0.78rem;
  white-space: nowrap;
}

.schema-project-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-width: 52rem;
}

.schema-project-entity-row {
  display: grid;
  grid-template-columns: minmax(14rem, 22rem) 1fr;
  gap: var(--space-3);
  align-items: start;
}

.schema-project-entity-hint {
  margin: 0;
  line-height: 1.45;
  padding-top: 0.35rem;
}

.schema-project-entity-guide {
  margin: 0;
  padding: 0.65rem 0.85rem;
  border: 1px solid var(--color-border-subtle, #e8e8ec);
  border-radius: var(--radius-sm, 4px);
  background: var(--color-surface-muted, rgba(0, 0, 0, 0.02));
}

.schema-project-entity-guide ul {
  margin: 0.5rem 0 0;
  padding-left: 1.15rem;
}

@media (max-width: 720px) {
  .schema-project-entity-row {
    grid-template-columns: 1fr;
  }
}

.schema-project-founders {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-border-subtle, #e8e8ec);
}

.schema-project-founders-intro {
  margin: 0.35rem 0 0;
  max-width: 42rem;
}

.schema-project-founders-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.schema-founder-row {
  padding: var(--space-3);
  border: 1px solid var(--color-border-subtle, #e8e8ec);
  border-radius: var(--radius-sm, 4px);
  background: var(--color-surface-muted, rgba(0, 0, 0, 0.02));
}

.schema-founder-row-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: var(--space-3);
  align-items: end;
}

.schema-founder-remove {
  align-self: end;
  margin-bottom: 0.1rem;
}

@media (max-width: 900px) {
  .schema-founder-row-grid {
    grid-template-columns: 1fr 1fr;
  }
  .schema-founder-remove {
    grid-column: 1 / -1;
    justify-self: start;
  }
}

@media (max-width: 560px) {
  .schema-founder-row-grid {
    grid-template-columns: 1fr;
  }
}

.schema-project-address-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

@media (max-width: 640px) {
  .schema-project-address-grid {
    grid-template-columns: 1fr;
  }
}

.schema-checkbox {
  width: 1.1rem;
  height: 1.1rem;
  margin-top: 0.25rem;
}

.field-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.field-stack:last-child {
  margin-bottom: 0;
}

.textarea-meta {
  min-height: 4.5rem;
  resize: vertical;
  font-family: var(--font-sans);
  line-height: 1.45;
}

.workshop-editor-panel {
  display: flex;
  flex-direction: column;
  margin-bottom: 0;
  position: sticky;
  top: var(--app-header-height);
  z-index: 4;
  height: calc(100vh - var(--app-header-height));
  min-height: 0;
  width: 100%;
  box-sizing: border-box;
  overflow: visible;
}

.workshop-editor-col .workshop-editor-panel .editor-area {
  flex: 1;
  min-height: 260px;
  max-height: none;
}

.workshop-editor-panel .editor-wrapper-minimap {
  flex: 1;
  min-height: 0;
  display: flex;
  overflow: hidden;
}

.workshop-panels-scroll {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  min-height: 0;
  min-width: 0;
  padding-right: var(--space-2);
}

.workshop-panels-scroll .tab-panel {
  min-width: 0;
  max-width: 100%;
}

.workshop-panels-scroll .tab-panel .panel {
  max-width: 100%;
  box-sizing: border-box;
}

.tabs-workshop {
  flex-shrink: 0;
}

.metrics-rows {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.metric-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-4);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border-muted);
}

.metric-row:last-child {
  border-bottom: none;
}

.metric-row-label {
  font-size: 0.9rem;
  color: var(--color-text-muted);
  flex: 1 1 50%;
  padding-right: var(--space-2);
}

.metric-row-value {
  flex: 0 0 auto;
  text-align: right;
  font-size: 0.95rem;
}

.paa-empty {
  line-height: 1.55;
  max-width: 40rem;
}

.seo-hn-order .seo-hn-structure {
  margin: 0 0 var(--space-2);
  font-size: 0.88rem;
  color: var(--color-text-muted);
}

.seo-hn-order .seo-hn-ok {
  margin: 0;
  color: var(--color-ok);
}

.seo-hn-errors {
  margin: var(--space-2) 0 0;
  padding-left: var(--space-4);
  color: var(--color-warn);
  font-size: 0.88rem;
}

.seo-hn-errors li {
  margin-bottom: var(--space-2);
}

.keyword-vol-main {
  margin: 0 0 var(--space-2);
  font-size: 1.1rem;
  color: var(--color-accent);
}

.app-footer {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--color-border-muted);
  background: var(--color-surface);
}

.footer-note {
  font-size: 0.8rem;
  color: var(--color-text-muted);
}

.panel {
  background: var(--color-surface);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  margin-bottom: var(--space-5);
  box-shadow: var(--shadow-soft);
}

.panel-hero {
  border-color: var(--color-border);
}

/* ── Toolbar barre haute V42 Brief 4 ─────────────────────────────────────── */

.panel-toolbar {
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--color-border-subtle);
}

.toolbar-main-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  min-height: 2.75rem;
}

.toolbar-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2) var(--space-3);
}

.toolbar-group--targeting { flex: 1 1 auto; min-width: 0; }

.toolbar-field-keyword {
  flex: 1 1 10rem;
  min-width: 0;
  max-width: 28rem;
  margin: 0;
}

.toolbar-field-keyword .input {
  width: auto;
  min-width: 8rem;
  max-width: 100%;
  field-sizing: content;
}

.toolbar-field-page-type {
  flex: 0 0 auto;
  margin: 0;
}

.toolbar-field-page-type select {
  min-width: 8rem;
}

.toolbar-sep {
  flex: 1 1 var(--space-2);
  min-width: var(--space-1);
}

/* Groupe compact de métriques (Score / LLM / Mots) — Lot D */
.toolbar-metrics {
  display: flex;
  align-items: center;
  gap: 0;
  flex-shrink: 0;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-md);
  background: var(--color-surface-raised);
  padding: var(--space-1) var(--space-2);
  white-space: nowrap;
}

.toolbar-metric {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-2);
}

.toolbar-metric-label {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-secondary);
  flex-shrink: 0;
}

.toolbar-metric-sep {
  width: 1px;
  height: 1.25rem;
  background: var(--color-border-subtle);
  flex-shrink: 0;
  margin: 0 var(--space-1);
}

.toolbar-score-inline {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
  white-space: nowrap;
}

.toolbar-score-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.toolbar-score-value {
  font-size: 1.1rem;
  font-weight: var(--font-weight-semibold);
  color: var(--color-accent);
  min-width: 2.5ch;
}

.toolbar-score-bar {
  width: 52px;
  height: 5px;
  border-radius: 99px;
  overflow: hidden;
  background: var(--color-border-subtle);
  flex-shrink: 0;
}

/* === LLM READINESS Phase A === */
.toolbar-score-inline--llm .toolbar-score-value {
  min-width: 2ch;
}

.toolbar-score-phase {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.llm-ready-header {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.llm-ready-global-value {
  font-size: 1.75rem;
  font-weight: var(--font-weight-semibold);
  color: var(--color-accent);
}

.llm-ready-hint {
  margin: 0;
  flex: 1 1 100%;
}

.llm-family--pending {
  opacity: 0.55;
}

.llm-subscores {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.llm-subscore-row {
  display: grid;
  grid-template-columns: 1fr auto 120px;
  gap: var(--space-2);
  align-items: center;
}

.llm-subscore-row--family {
  border-bottom: 1px solid var(--color-border-subtle);
  padding-bottom: var(--space-2);
  margin-bottom: var(--space-1);
}

.llm-subscore-details {
  grid-column: 1 / -1;
  margin: 0;
  white-space: pre-wrap;
  font-size: 0.72rem;
}

.llm-details {
  grid-column: 1 / -1;
  margin: var(--space-1) 0 0 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.2rem 0.75rem;
  font-size: 0.78rem;
  line-height: 1.45;
}

.llm-details dt {
  margin: 0;
  color: var(--color-text-muted, #666);
  font-weight: 500;
}

.llm-details dd {
  margin: 0;
  color: var(--color-text-primary, inherit);
}

.llm-detail-badge {
  display: inline-block;
  font-size: 0.72rem;
  margin-left: 0.2rem;
  font-weight: 600;
}

.llm-detail-badge--ok {
  color: #2e7d32;
}

.llm-detail-badge--warn {
  color: #ed6c02;
}

.llm-detail-badge--bad {
  color: #d32f2f;
}

/* Encart conseil par sous-score */
.llm-subscore-guidance {
  grid-column: 1 / -1;
  margin: 0.1rem 0 0.1rem 0;
  padding: 0.25rem 0.55rem;
  font-size: 0.78rem;
  line-height: 1.45;
  border-radius: 3px;
  border-left: 3px solid transparent;
}

.llm-subscore-guidance--ok {
  color: #1b5e20;
  background: #f1f8e9;
  border-left-color: #43a047;
}

.llm-subscore-guidance--warn {
  color: #7f5400;
  background: #fff8e1;
  border-left-color: #ffa000;
}

.llm-subscore-guidance--bad {
  color: #7f0000;
  background: #fce4ec;
  border-left-color: #e53935;
}

.llm-subscore-guidance--crit {
  color: #fff;
  background: #b71c1c;
  border-left-color: #7f0000;
}

/* Bouton info tooltip à côté des titres de famille */
.llm-family-info-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.2em;
  height: 1.2em;
  margin-left: 0.4rem;
  padding: 0;
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
  color: var(--color-text-muted, #888);
  background: transparent;
  border: 1px solid var(--color-border-subtle, #ccc);
  border-radius: 50%;
  cursor: help;
  vertical-align: middle;
  position: relative;
  top: -1px;
}

.llm-family-info-btn:hover,
.llm-family-info-btn:focus {
  color: var(--color-text-primary, #333);
  border-color: var(--color-border, #999);
  background: var(--color-bg-subtle, #f5f5f5);
  outline: none;
}

.llm-rewrite-hints {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-subtle, #f8f8f8);
  border-radius: var(--radius-sm, 4px);
  border-left: 3px solid var(--color-border-subtle);
}

.llm-rewrite-hints__heading {
  margin: 0 0 var(--space-2) 0;
  font-weight: 600;
  font-size: 0.88rem;
}

.llm-rewrite-hints__intro {
  margin: 0 0 var(--space-2) 0;
}

.llm-holistic-intro {
  margin: 0 0 var(--space-2) 0;
  max-width: 42rem;
}

.llm-holistic-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.llm-rewrite-hints__list {
  margin: 0;
  padding-left: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.llm-rewrite-hints__item {
  font-size: 0.84rem;
  color: var(--color-text-primary, inherit);
  line-height: 1.45;
}

.llm-rewrite-hints__text {
  color: var(--color-text-muted, #666);
}

.llm-subscore-bar {
  height: 6px;
  border-radius: 99px;
  background: var(--color-border-subtle);
  overflow: hidden;
}

.toolbar-words-inline {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
  white-space: nowrap;
}

.toolbar-words-value {
  font-size: 1rem;
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  min-width: 3.5ch;
}

.toolbar-words-range {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
}

.toolbar-words-inline .word-count-signal {
  padding: 0;
}

.toolbar-words-inline .word-count-signal__lamp {
  width: 0.85rem;
  height: 0.85rem;
}

.options-menu {
  position: relative;
  flex-shrink: 0;
}

.options-menu-toggle {
  cursor: pointer;
  list-style: none;
}

.options-menu-toggle::-webkit-details-marker { display: none; }

.options-menu[open] .options-menu-toggle {
  background: var(--color-accent-soft);
  color: var(--color-accent-strong);
  border-color: var(--color-accent-soft);
}

.options-menu-panel {
  position: absolute;
  top: calc(100% + var(--space-1));
  right: 0;
  z-index: var(--z-dropdown);
  min-width: 280px;
  padding: var(--space-2);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.options-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-1);
}

.options-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.options-url-row {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.options-url-row .input {
  flex: 1 1 0;
  min-width: 0;
}

.options-full-width {
  width: 100%;
  justify-content: flex-start;
}

.options-feedback {
  min-height: 1em;
}

.options-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  padding: var(--space-1) 0;
}

.options-item-label {
  line-height: 1.3;
}

.options-divider {
  margin: var(--space-1) 0;
  border: none;
  border-top: 1px solid var(--color-border-subtle);
}

.toolbar-context-row {
  display: none;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2) var(--space-4);
  margin-top: var(--space-2);
}

/* Afficher la ligne seulement s'il y a un message ou une alerte */
.toolbar-context-row:has(.serp-alert-banner:not(.hidden)),
.toolbar-context-row:has(#corpus-directory-info:not(.hidden)),
.toolbar-context-row:has(.form-msg:not(:empty)) {
  display: flex;
}

.toolbar-context-row .form-msg {
  margin: 0;
  font-size: 0.85em;
}

.toolbar-context-row .serp-alert-banner {
  flex: 1;
  margin: 0;
}

.score-history-details {
  margin-top: var(--space-2);
}

.score-history-summary {
  cursor: pointer;
  font-size: 0.82rem;
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  padding: var(--space-1) 0;
  list-style: none;
}

.score-history-summary::-webkit-details-marker { display: none; }

.score-history-details[open] .score-history-summary {
  color: var(--color-accent-strong);
  margin-bottom: var(--space-2);
}

.score-history-details .score-history-wrapper {
  margin-top: var(--space-1);
}

@media (max-width: 640px) {
  .toolbar-main-row { gap: var(--space-2); }
  .toolbar-group--targeting { flex-direction: column; align-items: flex-start; }
  .toolbar-sep { display: none; }
  .toolbar-score-inline,
  .toolbar-words-inline { flex-shrink: 1; }
  .toolbar-metrics { flex-shrink: 1; overflow-x: auto; }
}

.panel-editor {
  padding: 0;
  overflow: visible;
  display: flex;
  flex-direction: column;
}

.editor-toolbar {
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  overflow: visible;
  padding: 0;
  border-bottom: 1px solid var(--color-border-muted);
  background: var(--color-bg-subtle, #f0f0f1);
  position: sticky;
  top: 0;
  z-index: 5;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}

.editor-toolbar-scroll {
  display: flex;
  flex: 1 1 auto;
  min-width: 0;
  flex-wrap: nowrap;
  overflow-x: auto;
  scrollbar-width: thin;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
}

.editor-toolbar-group {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2px;
}

.editor-toolbar-group--tools {
  display: none;
}

.editor-toolbar-plus {
  position: relative;
  flex-shrink: 0;
  align-self: center;
  padding: var(--space-2) var(--space-3) var(--space-2) 0;
}

.editor-toolbar-plus-toggle {
  cursor: pointer;
  list-style: none;
  font-size: 0.78rem;
}

.editor-toolbar-plus-toggle::-webkit-details-marker { display: none; }

.editor-toolbar-plus[open] .editor-toolbar-plus-toggle {
  background: var(--color-accent-soft);
  color: var(--color-accent-strong);
  border-color: var(--color-accent-soft);
}

.editor-toolbar-plus-menu {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  z-index: var(--z-fixed);
  min-width: 200px;
  padding: var(--space-1);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.editor-toolbar-plus-group {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.editor-toolbar-plus-item {
  display: flex;
  align-items: center;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  text-align: left;
  width: 100%;
  justify-content: flex-start;
  font-size: 0.82rem;
  white-space: nowrap;
}

.editor-toolbar-plus-item:hover,
.editor-toolbar-plus-item:focus-visible {
  background: var(--color-accent-soft);
  color: var(--color-accent-strong);
  border-color: transparent;
  outline: none;
}

.editor-toolbar-plus-sep {
  margin: var(--space-1) 0;
  border: none;
  border-top: 1px solid var(--color-border-subtle);
}

.editor-toolbar-label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  margin-right: var(--space-2);
}

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

.editor-block-format {
  font-family: var(--font-sans);
  font-size: 0.8rem;
  padding: var(--space-2) var(--space-3);
  padding-right: 1.75rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text);
  cursor: pointer;
  min-width: 7.5rem;
  max-width: 10rem;
}

.editor-block-format:hover {
  border-color: var(--color-accent);
}

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

.editor-block-format:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.editor-toolbar-sep {
  width: 1px;
  height: 1.35rem;
  background: var(--color-border);
  margin: 0 var(--space-1);
  flex-shrink: 0;
}

.btn-editor {
  font-family: var(--font-sans);
  font-size: 0.8rem;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text);
  cursor: pointer;
  display: inline-block;
  user-select: none;
  -webkit-user-select: none;
}

button.btn-editor {
  margin: 0;
  appearance: none;
  -webkit-appearance: none;
}

.btn-editor:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

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

.btn-editor:disabled,
.btn-editor[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}

.btn-editor:disabled:hover,
.btn-editor[aria-disabled="true"]:hover {
  border-color: var(--color-border);
  color: var(--color-text);
}

.btn-editor-icon {
  min-width: 2rem;
  padding: var(--space-2);
  text-align: center;
  font-weight: 600;
  line-height: 1.2;
}

.btn-editor-icon.btn-editor-cmd-underline {
  text-decoration: underline;
  font-weight: 500;
}

.btn-editor[aria-pressed="true"] {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}

.btn-editor[aria-pressed="true"]:hover {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
  opacity: 0.92;
}

.editor-html-area {
  display: block;
  width: 100%;
  min-height: 320px;
  max-height: 70vh;
  box-sizing: border-box;
  padding: var(--space-5);
  font-family: var(--font-mono);
  font-size: 0.85rem;
  line-height: 1.5;
  background: var(--color-bg);
  border: none;
  color: var(--color-text);
  resize: vertical;
  tab-size: 2;
}

.editor-html-area:focus {
  outline: 2px solid var(--color-accent);
  outline-offset: -2px;
}

.editor-html-area[hidden],
.editor-html-area.hidden {
  display: none !important;
  pointer-events: none !important;
  position: absolute !important;
  width: 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
}

#content-editor[hidden] {
  display: none !important;
}

.panel-warn {
  border-color: var(--color-warn);
}

.page-title {
  margin: 0 0 var(--space-2);
  font-size: 1.75rem;
  font-weight: 700;
}

.page-lead {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.95rem;
}

.section-title {
  margin: 0 0 var(--space-4);
  font-size: 1.1rem;
  font-weight: 600;
}

.section-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.empty-state {
  color: var(--color-text-muted);
  margin: 0;
}

.muted {
  color: var(--color-text-muted);
}

.small {
  font-size: 0.85rem;
}

.code-inline {
  font-family: var(--font-mono);
  font-size: 0.88em;
  background: var(--color-bg);
  padding: 0.1em 0.35em;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-muted);
}

.form-grid {
  display: grid;
  gap: var(--space-4);
  max-width: 32rem;
}

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

.field-inline {
  flex-direction: row;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.field-check {
  flex-direction: row;
  align-items: center;
  gap: var(--space-2);
}

.field-label {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.field-actions {
  margin-top: var(--space-2);
}

.input {
  font-family: var(--font-sans);
  font-size: 1rem;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text);
}

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

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

.input-select {
  cursor: pointer;
}

.input-sm {
  padding: var(--space-2) var(--space-3);
  font-size: 0.9rem;
}

.checkbox {
  width: 1rem;
  height: 1rem;
  accent-color: var(--color-accent);
}

.btn {
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
}

.btn-primary {
  background: var(--color-accent);
  color: #04120c;
}

.btn-primary:hover {
  filter: brightness(1.05);
}

.btn-secondary {
  background: var(--color-surface-elevated);
  color: var(--color-text);
  border-color: var(--color-border);
}

.btn-secondary:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.btn-ghost {
  background: transparent;
  color: var(--color-text-muted);
  border-color: var(--color-border);
}

.btn-ghost:hover {
  background: var(--color-accent-dim);
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.btn-sm {
  padding: var(--space-2) var(--space-3);
  font-size: 0.85rem;
}

.btn-accept {
  background: var(--color-accent);
  color: #04120c;
}

.btn-skip {
  background: var(--color-surface-elevated);
  color: var(--color-text);
  border: 1px solid var(--color-border);
}

.btn-reject {
  background: var(--color-danger-bg);
  color: var(--color-danger);
  border-color: var(--color-danger);
}

.form-msg {
  min-height: 1.25em;
  font-size: 0.9rem;
  color: var(--color-text-muted);
  margin-top: var(--space-3);
}

.serp-alert-banner {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-warn);
  background: rgba(210, 153, 34, 0.12);
  color: var(--color-text);
  font-size: 0.9rem;
  line-height: 1.45;
}

.serp-alert-banner.hidden {
  display: none;
}

.toolbar-analyze-group {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.serp-source-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  flex-shrink: 0;
  font-size: 0.72rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  white-space: nowrap;
  line-height: 1.3;
}

.serp-source-badge.hidden { display: none; }

.serp-source-prefix {
  font-weight: 500;
  opacity: 0.85;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.65rem;
}

.serp-source-text {
  font-weight: 600;
}

/* SERP en cache local */
.serp-source-cache {
  background: var(--color-info-soft);
  border-color: rgba(14, 165, 233, 0.35);
  color: #0369a1;
}

.serp-source-cache .serp-source-prefix { color: #0284c7; }

/* SERP fraîche (API / scraping) */
.serp-source-serper,
.serp-source-google_direct {
  background: var(--color-success-soft);
  border-color: rgba(16, 185, 129, 0.35);
  color: #047857;
}

.serp-source-serper .serp-source-prefix,
.serp-source-google_direct .serp-source-prefix { color: #059669; }

/* SERP cache périmé */
.serp-source-stale_cache {
  background: var(--color-warning-soft);
  border-color: rgba(245, 158, 11, 0.45);
  color: #b45309;
}

.serp-source-stale_cache .serp-source-prefix { color: #d97706; }

/* Replay figé (fixtures / debug) */
.serp-source-frozen-replay {
  background: var(--color-neutral-soft);
  border-color: var(--color-border-default);
  color: var(--color-text-secondary);
}

/* Rétrocompat — anciennes classes */
.serp-provider-badge {
  font-size: 0.72rem;
  padding: 2px 8px;
  border-radius: 10px;
  font-weight: 500;
  vertical-align: middle;
  white-space: nowrap;
}

.serp-provider-serper {
  background: rgba(79, 255, 176, 0.12);
  color: var(--color-accent);
}

.serp-provider-cache {
  background: rgba(100, 150, 255, 0.12);
  color: #6496ff;
}

.serp-provider-google_direct {
  background: rgba(255, 180, 0, 0.12);
  color: #ffb400;
}

.serp-provider-stale_cache {
  background: rgba(255, 100, 0, 0.12);
  color: #ff6400;
}

.serp-stale-warning {
  margin: var(--space-2) 0 0;
  padding: var(--space-2) var(--space-3);
  background: rgba(255, 100, 0, 0.08);
  border: 1px solid rgba(255, 100, 0, 0.25);
  border-radius: var(--radius-sm);
  font-size: 0.82rem;
  color: #cc5500;
}

.inline-form {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

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

.project-card-link {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-muted);
  background: var(--color-bg);
  text-decoration: none;
  color: inherit;
}

.project-card-link:hover {
  border-color: var(--color-accent);
}

.project-card-name {
  font-weight: 600;
}

.project-card-meta {
  font-size: 0.85rem;
  color: var(--color-text-muted);
}

.table-wrap {
  overflow-x: auto;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-muted);
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.data-table th,
.data-table td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--color-border-muted);
}

.data-table th {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  background: var(--color-bg);
}

.data-table tbody tr:hover {
  background: var(--color-accent-dim);
}

.col-num {
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.table-link {
  color: var(--color-accent);
  text-decoration: none;
  font-weight: 500;
}

.table-link:hover {
  text-decoration: underline;
}

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

.warn-card {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
}

.warn-head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}

.warn-severity {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
}

.warn-severity-high {
  background: var(--color-danger-bg);
  color: var(--color-danger);
}

.warn-severity-medium {
  background: rgba(210, 153, 34, 0.15);
  color: var(--color-warn);
}

.warn-ratio {
  font-size: 0.85rem;
}

.warn-pair {
  margin: 0 0 var(--space-2);
  font-size: 0.9rem;
}

.warn-kw {
  margin: 0;
  font-size: 0.8rem;
  color: var(--color-text-muted);
}

.toolbar-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: flex-end;
  margin-bottom: var(--space-5);
}

.toolbar-row-spaced {
  justify-content: space-between;
  align-items: center;
}



.score-label {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: var(--space-2);
}

.score-value {
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--color-accent);
  margin-bottom: var(--space-3);
}

.score-value-secondary {
  color: var(--color-text);
}

.progress {
  height: 8px;
  border-radius: 999px;
  background: var(--color-border-muted);
  overflow: hidden;
}

.progress-bar {
  height: 100%;
  width: 0%;
  border-radius: 999px;
  /* Couleur unie mise à jour par JS selon la valeur (rouge → orange → jaune → vert) */
  background: var(--_bar-color, var(--color-success));
  transition: width 0.35s ease, background 0.35s ease;
}

.progress-neutral .progress-bar-neutral {
  background: var(--_bar-color, var(--color-success));
}

.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  padding: var(--space-2);
  background: var(--color-surface);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-muted);
}

.tab {
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 600;
  padding: var(--space-3) var(--space-4);
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
}

.tab:hover {
  color: var(--color-text);
}

.tab.active {
  background: var(--color-accent-dim);
  color: var(--color-accent);
}

.tab-panel {
  display: none;
}

.tab-panel.active {
  display: block;
}

.editor-area {
  display: block;
  min-height: 320px;
  max-height: 70vh;
  overflow-y: auto;
  overflow-x: hidden;
  padding: var(--space-5);
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.6;
  background: var(--color-bg);
  border: none;
  color: var(--color-text);
  cursor: text;
  -webkit-user-select: text;
  user-select: text;
  box-sizing: border-box;
  width: 100%;
  /* Indicateur visuel : bordure top fine toujours visible */
  border-top: 1px solid var(--color-border-muted);
  outline: none;
}

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

.editor-area p {
  margin: 0 0 var(--space-3);
}

.editor-area p:last-child {
  margin-bottom: 0;
}

.editor-area h1 {
  font-size: 1.6rem;
  font-weight: 700;
  margin: var(--space-5) 0 var(--space-3);
  line-height: 1.2;
}

.editor-area h1:first-child {
  margin-top: 0;
}

.editor-area h2 {
  font-size: 1.35rem;
  font-weight: 700;
  margin: var(--space-5) 0 var(--space-3);
  line-height: 1.25;
}

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

.editor-area h3 {
  font-size: 1.15rem;
  font-weight: 600;
  margin: var(--space-4) 0 var(--space-2);
  line-height: 1.3;
}

.editor-area h4 {
  font-size: 1.05rem;
  font-weight: 600;
  margin: var(--space-3) 0 var(--space-2);
  line-height: 1.35;
  color: var(--color-text-muted);
}

.editor-area ul,
.editor-area ol {
  margin: 0 0 var(--space-3);
  padding-left: 1.5rem;
}

.editor-area li {
  margin-bottom: var(--space-2);
}

.editor-area blockquote {
  margin: 0 0 var(--space-3);
  padding-left: var(--space-4);
  border-left: 3px solid var(--color-border);
  color: var(--color-text-muted);
}

.editor-area hr {
  border: none;
  border-top: 1px solid var(--color-border);
  margin: var(--space-4) 0;
}

.editor-area table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 var(--space-3);
}

.editor-area td,
.editor-area th {
  border: 1px solid var(--color-border);
  padding: var(--space-2) var(--space-3);
  vertical-align: top;
}

.editor-area a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* V29 fix — !important requis : Chrome/Safari écrasent la couleur des <a>
   dans un contenteditable avec leur style UA (noir, pas de soulignement). */
[contenteditable] a,
[contenteditable] a[href] {
  color: var(--color-accent) !important;
  text-decoration: underline !important;
  text-underline-offset: 2px;
  cursor: pointer;
}

[contenteditable] a[href]:visited {
  color: var(--color-accent) !important;
}

.editor-area strong {
  font-weight: 700;
}

.editor-area em {
  font-style: italic;
}

mark.hl-red {
  background: var(--color-danger-bg);
  color: var(--color-danger);
}

mark.hl-green {
  background: var(--color-ok-bg);
  color: var(--color-ok);
}

mark.hl-orange {
  background: rgba(210, 153, 34, 0.25);
  color: var(--color-warn);
}

mark.hl-yellow {
  background: var(--hl-yellow-bg);
  color: var(--goto-hl-color);
}

/* Infobulles Sémafor — fond clair, affichage immédiat (remplace title natif) */
.semafor-rect-tooltip {
  position: fixed;
  z-index: var(--z-tooltip, 1100);
  box-sizing: border-box;
  max-width: min(380px, calc(100vw - 20px));
  padding: 10px 14px;
  background: #ffffff;
  color: #1a1a2e;
  border: 1px solid #d8dce6;
  border-radius: var(--radius-md, 8px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  pointer-events: none;
}

.semafor-rect-tooltip.hidden {
  display: none !important;
}

.semafor-tip-anchor {
  cursor: help;
}

th.semafor-tip-anchor,
.semafor-tip-anchor.context-text {
  cursor: help;
}

/* Clic « Voir dans le texte » : fond jaune léger, texte foncé (lisible) */
mark.semafor-goto-hl {
  background: var(--goto-hl-bg);
  color: var(--goto-hl-color);
  border-radius: 2px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

mark.semafor-goto-hl.semafor-goto-hl-danger {
  background: var(--color-danger-bg);
  color: var(--color-danger);
}

mark.semafor-goto-hl.semafor-goto-hl-safe {
  background: var(--color-ok-bg);
  color: var(--color-ok);
}

mark.semafor-goto-hl.semafor-goto-hl-warn {
  background: rgba(255, 179, 71, 0.65);
  color: #1a1a1a;
}

/* Clic mot-clé sémantique / redondances : surlignage sans <mark> (CSS Custom Highlight API) */
::highlight(semafor-hl-yellow) {
  background-color: var(--hl-yellow-bg);
  color: var(--goto-hl-color);
}
::highlight(semafor-hl-red) {
  background-color: rgba(248, 81, 73, 0.4);
}
::highlight(semafor-hl-green) {
  background-color: rgba(63, 185, 80, 0.38);
}
::highlight(semafor-hl-orange) {
  background-color: rgba(210, 153, 34, 0.42);
}

/* Occurrences « secondaires » au clic tableau sémantique (toutes sauf accent sur l’actif via <mark>) — C.4 jaune discret */
::highlight(semafor-hl-semantic-soft) {
  background-color: rgba(255, 230, 0, 0.22);
  color: inherit;
}

[data-theme="light"] ::highlight(semafor-hl-semantic-soft) {
  background-color: rgba(255, 200, 0, 0.28);
}

/* Navigateurs sans Highlight API : couleur de sélection (ne modifie pas le contenu) */
.editor-area.editor-semfind-active::selection {
  background: var(--hl-yellow-selection);
  color: var(--goto-hl-color);
}
.editor-area.editor-semfind-active[data-semfind="red"]::selection {
  background: rgba(248, 81, 73, 0.45);
}
.editor-area.editor-semfind-active[data-semfind="green"]::selection {
  background: rgba(63, 185, 80, 0.42);
}
.editor-area.editor-semfind-active[data-semfind="orange"]::selection {
  background: rgba(210, 153, 34, 0.45);
}

ins.diff-add {
  background: rgba(79, 255, 176, 0.2);
  text-decoration: none;
}

del.diff-remove {
  background: var(--color-danger-bg);
  text-decoration: line-through;
  color: var(--color-danger);
}

.badge-optimal,
.badge-ajouter,
.badge-enlever,
.badge-insuffisant {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
}

.badge-optimal {
  background: var(--color-ok-bg);
  color: var(--color-ok);
}

.badge-ajouter {
  background: rgba(88, 166, 255, 0.15);
  color: var(--color-accent);
}

.badge-enlever {
  background: var(--color-danger-bg);
  color: var(--color-danger);
}

.badge-insuffisant {
  background: rgba(210, 153, 34, 0.18);
  color: var(--color-warning);
}

.term-type-badge {
  font-size: 0.75rem;
  margin-left: 2px;
  opacity: 0.9;
  cursor: help;
}

.badge-ignored {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  background: var(--color-border-muted);
  color: var(--color-text-muted);
}

.badge {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
}

.badge-add_keyword {
  background: rgba(88, 166, 255, 0.2);
  color: var(--color-accent);
}

.badge-remove_redundancy {
  background: rgba(210, 153, 34, 0.2);
  color: var(--color-warn);
}

.badge-rephrase {
  background: var(--color-accent-dim);
  color: var(--color-accent);
}

.suggestion-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  background: var(--color-bg);
  margin-top: var(--space-4);
}

.suggestion-count {
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--color-text-muted);
  margin: var(--space-2) 0;
}

.diff-inline {
  display: grid;
  gap: var(--space-3);
  margin: var(--space-4) 0;
  font-family: var(--font-mono);
  font-size: 0.88rem;
  line-height: 1.5;
}

/* Suggestions IA : pas de barré (illisible sur long HTML) — repères « Avant / Après » */
.diff-inline del {
  display: block;
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  border-left: 4px solid var(--color-danger);
  background: rgba(248, 81, 73, 0.08);
  color: var(--color-text);
  text-decoration: none;
  word-break: break-word;
  overflow-wrap: anywhere;
  white-space: pre-wrap;
}

.diff-inline del::before {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--color-danger);
  margin-bottom: var(--space-2);
  content: "Avant";
}

.diff-inline ins {
  display: block;
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  border-left: 4px solid var(--color-ok);
  background: var(--color-ok-bg);
  color: var(--color-text);
  text-decoration: none;
  word-break: break-word;
  overflow-wrap: anywhere;
  white-space: pre-wrap;
}

.diff-inline ins::before {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--color-ok);
  margin-bottom: var(--space-2);
  content: "Après";
}

.suggestion-reason {
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

.suggestion-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.pulse {
  animation: pulse-row 1s ease;
}

@keyframes pulse-row {
  0% {
    box-shadow: 0 0 0 0 rgba(79, 255, 176, 0.5);
    background: transparent;
  }
  50% {
    box-shadow: 0 0 0 6px rgba(79, 255, 176, 0);
    background: var(--color-accent-dim);
  }
  100% {
    box-shadow: none;
    background: transparent;
  }
}

.filter-bar {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.filter-bar-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

/* Lot E — ligne de filtres sur une seule ligne scrollable */
.filter-bar-row--status {
  flex-wrap: nowrap;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 2px;
}
.filter-bar-row--status::-webkit-scrollbar { display: none; }

.filter-bar-row--secondary {
  justify-content: space-between;
}

.filter-bar-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.filter-bar-group--tools {
  margin-left: auto;
}

.filter-label--actions {
  color: var(--color-text-muted);
}

.btn-filter-action {
  font-family: var(--font-sans);
  font-size: 0.82rem;
  font-weight: 600;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text);
  cursor: pointer;
  white-space: nowrap;
}

.btn-ai-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35em;
}

.btn-ai-action .icon {
  flex-shrink: 0;
}

.btn-filter-action.btn-ai-action {
  display: inline-flex;
}

.btn-filter-action:hover {
  border-color: var(--color-accent);
  background: var(--color-accent-dim);
}

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

.ui-hint-banner {
  display: none;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  margin: 0 var(--space-4) var(--space-3);
  background: var(--color-accent-dim);
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  line-height: 1.45;
}

[data-ui-mode="epure"] .ui-hint-banner:not([hidden]) {
  display: flex;
}

[data-ui-mode="decouverte"] .ui-hint-banner:not([hidden]) {
  display: flex;
}

.ui-hint-banner__dismiss {
  margin-left: auto;
  border: none;
  background: transparent;
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
  color: var(--color-text-muted);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
}

.ui-hint-banner__dismiss:hover {
  color: var(--color-text);
  background: rgba(0, 0, 0, 0.06);
}

/* ── Prochaines actions (post-analyse) ── */
.next-actions-panel {
  margin: var(--space-3) var(--space-4) 0;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-raised, #f6f8fa);
}

.next-actions-panel.hidden {
  display: none;
}

.next-actions-header {
  margin-bottom: var(--space-2);
}

.next-actions-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 var(--space-1);
}

.next-actions-subtitle {
  margin: 0;
}

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

.next-actions-item {
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-bg, #fff);
}

.next-actions-item-head {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  margin-bottom: var(--space-1);
}

.next-actions-badge {
  flex-shrink: 0;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.15rem 0.45rem;
  border-radius: var(--radius-sm);
  background: var(--color-border);
  color: var(--color-text-muted);
}

.next-actions-p0 .next-actions-badge {
  background: #cf222e22;
  color: #cf222e;
}

.next-actions-p1 .next-actions-badge {
  background: #bf870022;
  color: #9a6700;
}

.next-actions-p2 .next-actions-badge {
  background: #0969da22;
  color: #0969da;
}

.next-actions-label {
  font-weight: 500;
  line-height: 1.35;
}

.next-actions-why {
  margin: var(--space-1) 0;
}

.next-actions-why summary {
  cursor: pointer;
  font-size: 0.85rem;
  color: var(--color-text-muted);
}

.next-actions-why-summary {
  margin: var(--space-1) 0 0;
}

.next-actions-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.next-actions-confidence-low {
  opacity: 0.88;
  border-color: var(--color-warning, #9a6700);
}

.next-actions-confidence-low .next-actions-label {
  color: var(--color-text-muted);
}

.next-actions-confidence-medium .next-actions-badge {
  background: #bf870033;
  color: var(--color-warning, #9a6700);
}

.action-why-sources {
  list-style: none;
  margin: var(--space-1) 0 0;
  padding: 0;
  font-size: 0.8rem;
}

.action-why-sources li {
  margin: 0.2rem 0;
}

.action-why-sources code {
  font-size: 0.75rem;
  color: var(--color-text-muted);
}

.action-why-link {
  margin-top: var(--space-2);
}

.enrich-collapsed-note {
  margin: var(--space-3) 0;
  padding: var(--space-3);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-raised, #f6f8fa);
}

.enrich-collapsed-note__text {
  margin: 0 0 var(--space-2);
}

.enrich-collapsed-note__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.counter-clickable {
  cursor: pointer;
  font-family: inherit;
  text-align: left;
}

.counter-clickable:hover {
  filter: brightness(0.97);
}

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

.counter-clickable.active {
  box-shadow: 0 0 0 2px var(--color-accent);
}

/* Sticky dans le scroll du panneau d'analyse */
#panel-semantic .filter-bar {
  position: sticky;
  top: 0;
  z-index: 20;
  background: var(--color-surface);
  padding-top: var(--space-3);
  padding-bottom: var(--space-3);
  margin-top: calc(-1 * var(--space-3));
  margin-bottom: var(--space-2);
}

.filter-label {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  margin-right: var(--space-2);
}

.chip {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text-muted);
  cursor: pointer;
}

.chip.active {
  border-color: var(--color-accent);
  color: var(--color-accent);
  background: var(--color-accent-dim);
}

.chip-primary-soft {
  border-color: var(--color-accent);
  color: var(--color-text);
  background: var(--color-accent-dim);
  font-weight: 600;
}

.chip-toggle.active {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.device-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.device-toggle-label {
  font-size: 0.8rem;
}

.subpanel {
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-border-muted);
}

.subpanel-title {
  margin: 0 0 var(--space-3);
  font-size: 1rem;
}

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

.seo-tags {
  display: grid;
  gap: var(--space-4);
}

.seo-tag-block {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-muted);
  background: var(--color-bg);
}

.seo-tag-head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}

.seo-status {
  font-size: 1.1rem;
}

.seo-tag-title {
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
}

.seo-tag-text {
  margin: 0;
  font-size: 0.9rem;
  color: var(--color-text-muted);
  word-break: break-word;
}

.seo-v21-checks {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.seo-v21-row {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: var(--space-3);
  row-gap: var(--space-1);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-muted);
  background: var(--color-bg);
  font-size: 0.9rem;
  align-items: start;
}

.seo-v21-icon {
  grid-row: 1 / span 2;
  font-size: 1.1rem;
  line-height: 1.4;
}

.seo-v21-label {
  grid-column: 2;
  font-weight: 600;
  color: var(--color-text);
}

.seo-v21-msg {
  grid-column: 2;
  color: var(--color-text-muted);
  word-break: break-word;
}

.seo-v21-checks .seo-v21-absent,
.seo-v21-checks .hn-absent-list {
  margin: 0 0 var(--space-2) var(--space-6);
  padding-left: var(--space-3);
  border-left: 2px solid var(--color-border-muted);
}

/* V25.1 — listes d’URLs sous le contrôle « Liens sortants (volume) » */
.seo-v21-checks .audit-links-detail {
  margin: 0 0 var(--space-2) 0;
  padding: 0 0 0 var(--space-2);
  font-size: 0.85rem;
  width: 100%;
  max-width: 100%;
}

.seo-v21-checks .audit-links-detail summary {
  cursor: pointer;
  color: var(--color-text-muted, var(--color-text-secondary));
  list-style: none;
}

.seo-v21-checks .audit-links-detail summary::-webkit-details-marker {
  display: none;
}

.seo-v21-checks .audit-links-list {
  margin: var(--space-1) 0 0 var(--space-3);
  padding: 0;
  list-style: disc;
}

.seo-v21-checks .audit-links-list li {
  margin: 0.1rem 0;
  word-break: break-all;
}

.seo-v21-checks .audit-links-list a {
  color: var(--color-link, #2563eb);
}

.audit-status-ok {
  border-left: 3px solid var(--color-success, #2e7d32);
}

.audit-status-warning {
  border-left: 3px solid var(--color-warning, #f9a825);
}

.audit-status-error {
  border-left: 3px solid var(--color-danger, #c62828);
}

.audit-status-info {
  border-left: 3px solid var(--color-border-strong, #90a4ae);
}

.outline {
  list-style: none;
  margin: 0;
  padding: 0;
}

.outline li {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--space-2) var(--space-3);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--color-border-muted);
  font-size: 0.9rem;
}

.outline-tag {
  flex: 0 0 auto;
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--color-accent);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.outline-text {
  flex: 1;
  min-width: 0;
  word-break: break-word;
  color: var(--color-text);
}

.outline .lvl-1 {
  font-weight: 700;
}

.outline .lvl-1 .outline-text {
  color: var(--color-accent);
}

.outline .lvl-2 {
  padding-left: var(--space-4);
}

.outline .lvl-3 {
  padding-left: var(--space-6);
}

.metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-3);
  margin: 0;
}

.metrics-grid dt {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0;
}

.metrics-grid dd {
  margin: var(--space-1) 0 0;
  font-family: var(--font-mono);
  font-size: 1rem;
}

.paa-questions-root {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.paa-section-title {
  margin: 0 0 var(--space-2);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text-muted);
  letter-spacing: 0.02em;
}

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

.paa-corpus-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--space-3);
  justify-content: space-between;
}

.paa-item-corpus .paa-q {
  flex: 1 1 12rem;
  margin: 0;
}

.badge-freq {
  flex-shrink: 0;
  display: inline-block;
  padding: 0.2rem 0.55rem;
  font-size: 0.75rem;
  font-weight: 600;
  font-family: var(--font-mono);
  color: var(--color-text-muted);
  background: var(--color-surface-elevated);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-sm);
}

.paa-item {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-muted);
  background: var(--color-bg);
}

.paa-q {
  margin: 0 0 var(--space-3);
  font-weight: 600;
}

.ai-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin: var(--space-4) 0;
}

.ai-loading {
  padding: var(--space-3);
  color: var(--color-accent);
  font-family: var(--font-mono);
}

.suggestion-panel {
  min-height: 2rem;
}

.diff-panel {
  margin-top: var(--space-5);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
}

.diff-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-3);
}

.diff-panel-actions {
  display: flex;
  gap: var(--space-2);
}

.diff-view {
  margin: 0;
  white-space: pre-wrap;
  word-break: break-word;
  font-family: var(--font-mono);
  font-size: 0.85rem;
  line-height: 1.5;
  max-height: 50vh;
  overflow: auto;
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-muted);
  background: var(--color-surface);
}

.hidden {
  display: none !important;
}

.kw-row {
  cursor: pointer;
}

.kw-row td {
  font-size: 0.88rem;
}

/* ── Tableau sémantique V5 (TextFocus) ───────────────────────────────── */
.semantic-table-wrap.table-scroll {
  overflow-x: auto;
  /* clip laisse passer sticky des enfants vers le scroll container parent */
  overflow-y: clip;
  -webkit-overflow-scrolling: touch;
  width: 100%;
  max-width: 100%;
  margin: 0 calc(-1 * var(--space-2));
  padding: 0 var(--space-2);
  box-sizing: border-box;
}

.semantic-table {
  width: max-content;
  max-width: none;
  min-width: min(100%, 520px);
  font-size: 0.8rem;
  table-layout: auto;
}

/* En-tête : sticky sur chaque ``th`` (scroll = .workshop-panels-scroll ; onglets au-dessus, hors flux). */
.semantic-table thead th {
  position: sticky;
  top: 0;
  z-index: 19;
  box-shadow: 0 1px 0 var(--color-border-muted);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  white-space: nowrap;
  padding: var(--space-2) var(--space-2);
  background: var(--color-bg);
}

.semantic-table td {
  padding: var(--space-2) var(--space-2);
  vertical-align: top;
}

.semantic-table th.col-num,
.semantic-table td.col-num {
  text-align: center;
}

.semantic-table td.col-num .freq-bar-cell,
.semantic-table td.col-num .interest-bar-cell {
  justify-content: center;
}

.th-sortable {
  cursor: pointer;
  user-select: none;
}

.th-sortable:hover {
  color: var(--color-text);
}

.th-sorted-asc::after {
  content: " \2191";
  opacity: 0.65;
  font-size: 0.8em;
}

.th-sorted-desc::after {
  content: " \2193";
  opacity: 0.65;
  font-size: 0.8em;
}

.semantic-table .col-context {
  max-width: min(160px, 28vw);
  color: var(--color-text-muted);
  font-size: 0.75rem;
}

.context-text {
  display: block;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.freq-bar-cell {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}

.freq-bar {
  width: 40px;
  height: 4px;
  background: var(--color-border-muted);
  border-radius: 2px;
  overflow: hidden;
}

.freq-bar > span {
  display: block;
  height: 100%;
  background: var(--color-accent);
  border-radius: 2px;
}

.interest-bar-cell {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}

.freq-high {
  color: var(--color-accent);
  font-weight: 600;
}

.freq-medium {
  color: var(--color-warn);
}

.freq-zero {
  color: var(--color-text-muted);
  opacity: 0.55;
}

.semantic-table .tfidf {
  color: var(--color-text-muted);
  font-size: 0.8rem;
}

.kw-row.kw-ignored {
  opacity: 0.55;
  background: var(--color-surface-elevated);
}

.kw-row.kw-ignored .kw-expression {
  color: var(--color-text-muted);
}

.kw-row.protected {
  background: rgba(79, 255, 176, 0.04);
}

.protected-badge {
  font-size: 0.75rem;
  opacity: 0.65;
  margin-left: 4px;
}

.col-action {
  width: 2.5rem;
  text-align: center;
}

.btn-trash-keyword {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 2px 4px;
  font-size: 1rem;
  line-height: 1;
  opacity: 0.55;
  border-radius: var(--radius-sm);
}

.btn-trash-keyword:hover {
  opacity: 1;
  background: var(--color-danger-bg);
}

/* ── V6 : éditeur + minimap + suggestions cartes + historique ───────── */
.editor-wrapper-minimap {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 0;
  min-height: 280px;
  flex: 1;
  min-height: 0;
  position: relative;
}

/* Hôte du scroll + mini-rail occurrences (C.4) — pas enfant de .editor-scroll (overflow) */
.editor-scroll-host {
  position: relative;
  flex: 1;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.editor-scroll {
  flex: 1;
  min-width: 0;
  min-height: 0;
  overflow: auto;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-muted);
}

.editor-scroll-host .editor-scroll {
  flex: 1;
  min-height: 0;
}

/* Mini-rail positions occurrences (bord droit zone scroll, pas la scrollbar OS) */
.semafor-scrollbar-markers {
  position: absolute;
  top: 0;
  right: 0;
  width: 6px;
  height: 100%;
  pointer-events: none;
  z-index: 2;
  box-sizing: border-box;
}

.semafor-scrollbar-marker {
  position: absolute;
  right: 0;
  width: 6px;
  height: 4px;
  background: rgba(255, 200, 0, 0.85);
  border-radius: 2px;
  transform: translateY(-50%);
}

.editor-wrapper-minimap .editor-area {
  min-height: 260px;
  border: none;
  border-radius: 0;
}

.editor-minimap {
  width: 8px;
  flex-shrink: 0;
  position: relative;
  background: var(--color-surface-elevated);
  border: 1px solid var(--color-border-muted);
  border-left: none;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  min-height: 120px;
}

.minimap-marker {
  position: absolute;
  left: 0;
  right: 0;
  width: 100%;
  height: 5px;
  margin-top: -2px;
  border-radius: 2px;
  cursor: pointer;
  transition: height 0.1s;
}

.minimap-marker:hover {
  height: 8px;
}

.marker-pending-add {
  background: var(--suggestion-pending-add-border);
}
.marker-pending-remove {
  background: var(--suggestion-pending-remove-border);
}
.marker-accepted {
  background: var(--suggestion-accepted);
}
.marker-rejected {
  background: var(--suggestion-rejected);
  opacity: 0.45;
}

.suggestion-header-v6 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}

.suggestion-header-badges {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  justify-content: flex-end;
}

/* Confiance IA (auto-évaluation modèle) + escalade */
.confidence-badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.8rem;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-muted);
  color: var(--color-text-muted);
}

.confidence-high {
  color: var(--color-ok);
  border-color: rgba(63, 185, 80, 0.35);
  background: var(--color-ok-bg);
}

.confidence-medium {
  color: var(--color-warn);
  border-color: rgba(210, 153, 34, 0.35);
  background: rgba(210, 153, 34, 0.12);
}

.confidence-low {
  color: var(--color-danger);
  border-color: rgba(248, 81, 73, 0.35);
  background: var(--color-danger-bg);
}

.ai-model-escalated-badge {
  border-style: dashed;
}

.ai-escalation-banner {
  margin-bottom: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-accent-dim);
}

.ai-escalation-banner-text {
  margin: 0 0 var(--space-2);
  font-size: 0.88rem;
  color: var(--color-text);
}

.ai-escalation-banner-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

.diff-panel-ai-meta {
  margin-bottom: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.diff-panel-ai-meta .ai-escalation-banner {
  margin-bottom: 0;
}

.suggestion-cards {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-height: 55vh;
  overflow-y: auto;
}

.faq-suggestions-block {
  margin-top: var(--space-3);
  padding: var(--space-3);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-muted, rgba(0, 0, 0, 0.02));
}

.faq-suggestions-title {
  font-weight: 600;
  margin-bottom: var(--space-2);
  font-size: 0.9rem;
}

.faq-suggestion-item + .faq-suggestion-item {
  margin-top: var(--space-2);
}

.faq-suggestion-answer {
  margin-top: var(--space-1);
  color: var(--color-text-muted, #555);
  font-size: 0.92rem;
}

.suggestion-card-v6 {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  transition: box-shadow 0.15s;
}

.suggestion-card-v6.card-pending-add {
  border-color: var(--suggestion-pending-add-border);
  background: var(--suggestion-pending-add);
}

.suggestion-card-v6.card-pending-remove {
  border-color: var(--suggestion-pending-remove-border);
  background: var(--suggestion-pending-remove);
}

.suggestion-card-v6.card-accepted {
  border-color: var(--suggestion-accepted);
  background: var(--suggestion-accepted-bg);
  opacity: 0.92;
}

.suggestion-card-v6.card-rejected {
  border-color: var(--suggestion-rejected);
  background: var(--suggestion-rejected-bg);
  opacity: 0.65;
}

.suggestion-card-v6.card-focused {
  outline: 2px solid var(--suggestion-active);
  outline-offset: 2px;
}

.card-body-v6 {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.card-field-v6 {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.card-field-label-v6 {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
}

.card-field-value-v6 {
  font-size: 0.88rem;
  line-height: 1.5;
  word-break: break-word;
}

.card-actions-v6 {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-border-muted);
}

.card-actions-v6-done {
  justify-content: flex-start;
}

/* Blocs suggestion dans le WYSIWYG (#content-editor) — pas de texte barré (cf. SEMAFOR_REGLES_AFFICHAGE_V1) */
.semafor-ai-inline-block {
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  position: relative;
  margin: var(--space-3) 0;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-elevated);
}

.semafor-ai-inline-block .cursor-actions {
  user-select: none;
}

.semafor-ai-inline-block.cursor-block-active {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  box-shadow: 0 0 0 3px rgba(79, 176, 255, 0.15);
}

.semafor-ai-inline-block .semafor-ai-orig-store {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.semafor-ai-line-label {
  display: block;
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  margin-bottom: 2px;
}

.semafor-ai-line-html {
  text-decoration: none;
  color: inherit;
}

.cursor-line {
  display: block;
  width: 100%;
  box-sizing: border-box;
}

.cursor-line-remove {
  background: rgba(255, 79, 79, 0.1);
  padding: 4px 8px 4px 10px;
  line-height: 1.55;
  margin-top: var(--space-2);
  border-radius: var(--radius-sm);
}

.cursor-line-remove .semafor-ai-line-html {
  color: #c44;
}

.cursor-line-add {
  background: rgba(79, 255, 176, 0.08);
  padding: 4px 8px 4px 10px;
  line-height: 1.55;
  border-radius: var(--radius-sm);
}

.cursor-line-reason {
  background: rgba(255, 200, 50, 0.07);
  padding: 4px 8px;
  font-size: 0.82rem;
  color: var(--color-text-muted);
  line-height: 1.45;
  margin-top: 2px;
  border-radius: var(--radius-sm);
}

.cursor-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  padding: var(--space-2) 0 0;
  margin-top: var(--space-2);
  border-top: 1px solid var(--color-border-muted);
}

.cursor-actions-done {
  justify-content: flex-start;
}

.cursor-counter {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-right: 4px;
}

.cursor-btn {
  font-size: 0.78rem;
  padding: 3px 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text);
  cursor: pointer;
}

.cursor-btn:hover {
  background: var(--color-surface-elevated);
}

.cursor-btn-nav {
  padding: 3px 8px;
}

.cursor-btn-ignore:hover {
  border-color: var(--color-danger);
  color: var(--color-danger);
}

.cursor-btn-accept {
  background: rgba(79, 255, 176, 0.12);
  border-color: var(--color-accent);
  font-weight: 600;
}

.score-value-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

/* Plein écran pendant /api/analyze */
.analyze-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(12, 14, 18, 0.58);
  backdrop-filter: blur(3px);
}

.analyze-overlay[hidden] {
  display: none !important;
}

.analyze-overlay-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3, 0.75rem);
  padding: var(--space-5, 1.5rem);
}

.analyze-spinner {
  width: 3rem;
  height: 3rem;
  border: 3px solid rgba(255, 255, 255, 0.18);
  border-top-color: var(--color-accent);
  border-radius: 50%;
  animation: semafor-analyze-spin 0.8s linear infinite;
}

@keyframes semafor-analyze-spin {
  to {
    transform: rotate(360deg);
  }
}

.analyze-overlay-text {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 500;
  color: #f4f4f5;
}

/* B.2 — modale « Générer un cocon » : même .analyze-spinner que l’analyse sémantique */
.gen-cocon-serp-loading {
  display: none;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3, 0.75rem);
  padding: var(--space-4, 1rem) 0;
  text-align: center;
}

.gen-cocon-serp-loading.is-visible {
  display: flex;
}

.gen-cocon-serp-loading .gen-cocon-serp-loading-text {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-text-muted, #71717a);
}

.gen-cocon-serp-loading .gen-cocon-serp-loading-hint {
  margin: 0;
  font-size: 0.8rem;
  color: var(--color-text-muted, #71717a);
  opacity: 0.9;
}

body.analyze-overlay-open {
  overflow: hidden;
}

.new-page-form-hint {
  margin-top: 0.35rem;
}

.score-loading {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  min-height: 1em;
  opacity: 0;
  transition: opacity 0.2s;
}

.score-loading.visible {
  opacity: 1;
}

.word-count-ok {
  color: var(--color-accent);
}

.word-count-low {
  color: #4f9fff;
}

.word-count-high {
  color: var(--color-danger);
}

.card-header-v6 {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.card-status-v6 {
  font-size: 0.8rem;
  color: var(--color-text-muted);
}

.card-actions-v6 {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.versions-list {
  margin-top: var(--space-4);
}

.version-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  background: var(--color-surface);
}

.version-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
}

.version-label {
  font-weight: 600;
  color: var(--color-text, inherit);
}

.version-label--auto {
  color: var(--color-accent);
}

.version-filter-bar {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  margin-left: auto;
}

.version-filter-btn.is-active {
  background: var(--color-surface-elevated, rgba(255, 255, 255, 0.08));
  color: var(--color-accent);
}

.version-source-badge {
  font-size: 0.75rem;
  padding: 0.1rem 0.45rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-muted);
}

.version-source-manual {
  color: var(--color-text-muted);
}

.version-source-auto {
  color: var(--color-accent);
  border-color: color-mix(in srgb, var(--color-accent) 35%, transparent);
}

.diff-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background: rgba(0, 0, 0, 0.65);
}

.diff-modal.hidden {
  display: none !important;
}

.diff-modal-inner {
  background: var(--color-surface-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  max-width: 900px;
  width: 100%;
  max-height: 82vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-soft);
}

.diff-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4);
  border-bottom: 1px solid var(--color-border-muted);
}

.diff-modal-title {
  margin: 0;
  font-size: 1.05rem;
}

.diff-modal-content {
  padding: var(--space-4);
  overflow: auto;
  font-family: var(--font-mono);
  font-size: 0.85rem;
  line-height: 1.65;
  white-space: pre-wrap;
}

.diff-modal-content ins.diff-added {
  background: var(--diff-added-bg);
  color: var(--diff-added);
  text-decoration: none;
  border-radius: 2px;
  padding: 0 2px;
}

.diff-modal-content del.diff-removed {
  background: var(--diff-removed-bg);
  color: var(--diff-removed);
  border-radius: 2px;
  padding: 0 2px;
}

/* Modale export Prompt IA (Markdown) */
.ai-prompt-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}

.ai-prompt-modal.hidden {
  display: none !important;
}

.ai-prompt-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
}

.ai-prompt-modal-inner {
  position: relative;
  z-index: 1;
  background: var(--color-surface-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  max-width: 440px;
  width: 100%;
  padding: var(--space-4);
  box-shadow: var(--shadow-soft);
}

.ai-prompt-modal-inner--split {
  max-width: min(1120px, 96vw);
  max-height: min(88vh, 900px);
  display: flex;
  flex-direction: column;
  padding: var(--space-3) var(--space-4) var(--space-4);
}

.ai-prompt-modal-body {
  display: flex;
  gap: var(--space-4);
  flex: 1;
  min-height: 0;
  margin-top: var(--space-2);
}

.ai-prompt-modal-diff {
  flex: 0 0 38%;
  min-width: 260px;
  max-width: 420px;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: var(--space-3);
  background: var(--color-surface, #f8f9fb);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.ai-prompt-diff-head {
  flex-shrink: 0;
  margin-bottom: var(--space-2);
}

.ai-prompt-diff-title {
  margin: 0 0 var(--space-1);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.ai-prompt-diff-intro {
  margin: 0;
  line-height: 1.4;
}

.ai-prompt-diff-cards-scroll {
  flex: 1;
  min-height: 120px;
  max-height: none;
  overflow-y: auto;
  margin: var(--space-2) 0;
  padding-right: var(--space-1);
}

.ai-prompt-diff-status {
  flex-shrink: 0;
  min-height: 1.25rem;
}

/* ── Sous-onglets de la colonne gauche du pop-up Prompt IA ── */
.ai-prompt-subtabs {
  display: flex;
  flex-shrink: 0;
  gap: var(--space-1);
  margin-bottom: var(--space-2);
  border-bottom: 2px solid var(--border-muted, #e2e8f0);
}
.ai-prompt-subtab {
  padding: 0.3rem 0.6rem;
  font-size: 0.78rem;
  font-weight: 500;
  border: none;
  background: transparent;
  color: var(--text-muted, #64748b);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  border-radius: var(--radius-sm, 4px) var(--radius-sm, 4px) 0 0;
  transition: color 0.15s, border-color 0.15s;
}
.ai-prompt-subtab:hover {
  color: var(--text, #1e293b);
  background: var(--bg-hover, #f1f5f9);
}
.ai-prompt-subtab.active,
.ai-prompt-subtab[aria-selected="true"] {
  color: var(--primary, #2563eb);
  border-bottom-color: var(--primary, #2563eb);
  font-weight: 600;
}

.ai-prompt-subpanel {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding-right: var(--space-1);
}
.ai-prompt-subpanel[hidden] {
  display: none;
}

/* ── Onglet Questions du pop-up + panneau Enrichissement → Questions ── */
.ai-prompt-questions-root {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.ai-prompt-question-section {
  margin: var(--space-2) 0 var(--space-1);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text, #1e293b);
}
.ai-prompt-question-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.ai-prompt-question-item {
  padding: var(--space-2);
  background: var(--color-surface, #fff);
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: var(--radius-md, 6px);
}
.ai-prompt-question-q {
  margin: 0 0 var(--space-1);
  font-size: 0.84rem;
  line-height: 1.35;
}
.ai-prompt-question-checks,
.paa-question-checks {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1) var(--space-3);
}
.ai-prompt-qcheck,
.paa-qcheck {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.78rem;
  color: var(--text-muted, #475569);
  cursor: pointer;
  user-select: none;
}
.ai-prompt-qcheck input,
.paa-qcheck input {
  cursor: pointer;
}
.paa-question-checks {
  margin-top: var(--space-1);
}

.ai-prompt-live-status {
  font-size: 0.78rem;
  color: var(--text-muted, #64748b);
  min-width: 5rem;
}

.ai-prompt-modal-prompt {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.ai-prompt-modal-prompt .ai-prompt-modal-hint {
  margin-bottom: var(--space-2);
}

.ai-prompt-modal-prompt .ai-prompt-modal-textarea {
  flex: 1;
  min-height: 280px;
  max-height: none;
}

@media (max-width: 820px) {
  .ai-prompt-modal-body {
    flex-direction: column;
  }

  .ai-prompt-modal-diff {
    flex: none;
    max-width: none;
    max-height: 38vh;
  }

  .ai-prompt-diff-cards-scroll {
    max-height: 28vh;
  }
}

.ai-prompt-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}

.ai-prompt-modal-title {
  margin: 0;
  font-size: 1.05rem;
}

.ai-prompt-modal-hint {
  margin: 0 0 var(--space-4);
  line-height: 1.45;
}

.ai-prompt-diff-hint {
  margin: 0 0 var(--space-3);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  line-height: 1.45;
}

.ai-prompt-diff-hint--info {
  background: #f0f4ff;
  border: 1px solid #c5d4f5;
  color: #1e3a6e;
}

.ai-prompt-diff-hint--ok {
  background: #edf7ed;
  border: 1px solid #b8ddb9;
  color: #1b5e20;
}

.ai-prompt-diff-hint--warn {
  background: #fff8e6;
  border: 1px solid #f0d78c;
  color: #7a5a00;
}

.ai-prompt-modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.ai-prompt-modal-options {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3) var(--space-4);
  margin: 0 0 var(--space-3);
}

.ai-prompt-opt {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.ai-prompt-opt .input-inline {
  width: 4.25rem;
  padding: 0.25rem 0.35rem;
  font-size: 0.9rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
}

.ai-prompt-modal-textarea {
  display: block;
  width: 100%;
  box-sizing: border-box;
  min-height: 240px;
  margin: 0 0 var(--space-3);
  padding: var(--space-2) var(--space-3);
  font-family: ui-monospace, monospace;
  font-size: 0.8rem;
  line-height: 1.4;
  resize: vertical;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg, #fafafa);
  color: inherit;
}

.ai-prompt-modal-textarea::placeholder {
  color: var(--color-text-muted);
}

body.ai-prompt-modal-open {
  overflow: hidden;
}

/* ════════════════════════════════════════════════════════════
   V7 — Compteurs statuts sémantiques + légende term_type
   ════════════════════════════════════════════════════════════ */

/* ── Diagnostic rapide (Comp-2+6) ─────────────────────────────────────────── */
.quick-diagnostic {
  background: var(--color-surface, #161b22);
  border: 1px solid var(--color-border, #30363d);
  border-radius: var(--radius-md, 6px);
  padding: 10px 14px;
  margin-bottom: 10px;
  font-size: 0.82rem;
}
.qd-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  border-bottom: 1px solid var(--color-border-subtle, #21262d);
}
.qd-row:last-child { border-bottom: none; }
.qd-label {
  min-width: 175px;
  color: var(--color-text-muted, var(--color-text-muted));
  flex-shrink: 0;
}
.qd-ok   { color: var(--color-ok,      var(--color-success)); font-weight: 600; }
.qd-warn { color: var(--color-warning,  var(--color-warning)); font-weight: 600; }
.qd-err  { color: var(--color-danger,  var(--color-danger)); font-weight: 600; }
.qd-bar  {
  flex: 1;
  background: var(--color-border, #30363d);
  border-radius: 3px;
  height: 6px;
  min-width: 80px;
  overflow: hidden;
}
.qd-bar span {
  display: block;
  height: 100%;
  border-radius: 3px;
  transition: width 0.3s;
}
.qd-bar .qd-ok   { background: var(--color-ok,     var(--color-success)); }
.qd-bar .qd-warn { background: var(--color-warning, var(--color-warning)); }
.qd-bar .qd-err  { background: var(--color-danger,  var(--color-danger)); }

/* Comp-4 — sous-n-grams redondants */
tr.kw-redundant td {
  opacity: 0.55;
}
tr.kw-redundant:hover td {
  opacity: 0.8;
}
.kw-badge-redundant {
  display: inline-block;
  margin-left: 4px;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--color-muted, var(--color-text-muted));
  background: var(--bg-subtle, rgba(139, 148, 158, 0.12));
  border: 1px solid var(--color-border, rgba(139, 148, 158, 0.3));
  border-radius: var(--radius-sm, 3px);
  padding: 0 3px;
  vertical-align: middle;
  cursor: help;
}
tr.kw-forced-keep .kw-badge-redundant {
  display: none;
}
.btn-forced-keep,
.btn-forced-keep-reset {
  font-size: 0.7rem;
  padding: 1px 5px;
  border-radius: var(--radius-sm, 3px);
  border: 1px solid var(--color-border, rgba(139, 148, 158, 0.3));
  background: var(--bg-subtle, rgba(139, 148, 158, 0.08));
  color: var(--color-muted, var(--color-text-muted));
  cursor: pointer;
  margin-right: 3px;
}
.btn-forced-keep:hover {
  background: var(--color-ok-bg, var(--color-success-soft));
  color: var(--color-ok, var(--color-success));
  border-color: var(--color-ok, var(--color-success));
}
.btn-forced-keep-reset:hover {
  background: var(--color-warning-bg, rgba(210, 153, 34, 0.12));
  color: var(--color-warning, var(--color-warning));
  border-color: var(--color-warning, var(--color-warning));
}
#btn-hide-redundant {
  cursor: pointer;
  user-select: none;
}

.semantic-counters {
  display: flex;
  gap: var(--space-2);
  padding: 0 0 var(--space-3);
  flex-wrap: nowrap;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  align-items: center;
}
.semantic-counters::-webkit-scrollbar { display: none; }

#panel-semantic .semantic-counters {
  padding-top: 0;
  margin-bottom: var(--space-2);
}

.counter {
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
  font-size: 0.8rem;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  white-space: nowrap;
  appearance: none;
  -webkit-appearance: none;
  font-family: inherit;
  color: var(--color-text-primary);
}

.counter-all       { border-color: var(--color-border-default); }
.counter-optimal     { border-color: var(--color-ok); }
.counter-insuffisant { border-color: var(--color-warning); }
.counter-ajouter     { border-color: var(--color-accent); }
.counter-enlever     { border-color: var(--color-danger); }
.counter-local       { border-color: var(--color-info); }
.counter-review      { border-color: var(--color-warning); }
.counter-ignored     { border-color: var(--color-neutral); }
.counter-toggle      { border-color: var(--color-border-default); color: var(--color-text-secondary); }

.counter-review.counter-pulse {
  animation: counter-review-pulse 1.8s ease-in-out infinite;
}

@keyframes counter-review-pulse {
  0%, 100% {
    background: var(--color-surface);
    box-shadow: none;
    border-color: var(--color-warning);
  }
  50% {
    background: var(--color-warning-soft);
    box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.45);
    border-color: var(--color-warning);
  }
}

/* Lot E — chips avec compteur intégré */
.chip-count {
  font-weight: var(--font-weight-semibold);
  font-variant-numeric: tabular-nums;
}

.chip--ajouter        { border-color: var(--color-accent); }
.chip--ajouter.active { background: var(--color-accent-soft); color: var(--color-accent-strong); border-color: var(--color-accent); }
.chip--optimal        { border-color: var(--color-ok); }
.chip--optimal.active { background: rgba(16, 185, 129, 0.12); color: var(--color-ok); border-color: var(--color-ok); }
.chip--insuffisant        { border-color: var(--color-warning); }
.chip--insuffisant.active { background: var(--color-warning-soft); color: var(--color-warning); border-color: var(--color-warning); }
.chip--enlever        { border-color: var(--color-danger); }
.chip--enlever.active { background: rgba(239, 68, 68, 0.10); color: var(--color-danger); border-color: var(--color-danger); }

.term-type-legend {
  display: flex;
  gap: var(--space-4);
  font-size: 0.78rem;
  color: var(--color-text-muted);
  padding: var(--space-2) 0 var(--space-3);
  border-top: 1px solid var(--color-border-light, var(--color-border));
  margin-top: var(--space-3);
  flex-wrap: wrap;
  align-items: center;
}

/* ════════════════════════════════════════════════════════════
   V4 — Tableau Concurrence enrichi : flags, alertes, recap
   ════════════════════════════════════════════════════════════ */

.competitor-row.comp-excluded td {
  opacity: 0.55;
}

.flag-cell {
  white-space: nowrap;
}

.flag-badge {
  font-size: 0.78rem;
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

.flag-authority { background: rgba(255, 79, 79, 0.12); color: var(--color-danger); }
.flag-thin      { background: rgba(255, 165, 0, 0.12); color: var(--color-warning); }
.flag-excluded  { background: var(--color-surface); color: var(--color-text-muted); }
.flag-trusted   { background: var(--color-success-soft); color: var(--color-ok); }
.flag-normal    { color: var(--color-text-muted); }

.badge-excluded {
  font-size: 0.7rem;
  margin-left: 4px;
}

/* Crawl concurrent : rendu JS (Playwright fallback) */
.badge-crawl-js {
  font-size: 0.72rem;
  margin-left: 0.35em;
  color: #3b82f6;
  white-space: nowrap;
  font-weight: 500;
}

/* Crawl concurrent : texte issu des blocs JSON-LD (brief V18-C) */
.badge-crawl-jsonld {
  font-size: 0.72rem;
  margin-left: 0.35em;
  color: #7c3aed;
  white-space: nowrap;
  font-weight: 500;
}

/* Crawl concurrent : body complet retenu par la cascade (brief V18) */
.badge-crawl-body {
  font-size: 0.72rem;
  margin-left: 0.35em;
  color: #6b7280;
  white-space: nowrap;
  font-weight: 500;
}

.btn-action-sm {
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 2px 5px;
  font-size: 0.8rem;
  cursor: pointer;
  margin-right: 2px;
  transition: background 0.15s;
}

.btn-action-sm:hover {
  background: var(--color-surface-elevated);
}

/* ── Onglet Concurrence V42d (Brief 6) ────────────────────────────────────── */

.compete-action-bar {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}

.compete-plus {
  position: relative;
  margin-left: auto;
  flex-shrink: 0;
}

.compete-plus-toggle {
  cursor: pointer;
  list-style: none;
}

.compete-plus-toggle::-webkit-details-marker { display: none; }

.compete-plus[open] .compete-plus-toggle {
  background: var(--color-accent-soft);
  color: var(--color-accent-strong);
  border-color: var(--color-accent-soft);
}

.compete-plus-menu {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  z-index: var(--z-dropdown);
  min-width: 280px;
  padding: var(--space-2);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.compete-plus-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-1) 0;
}

.compete-plus-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
}

.compete-plus-sep {
  margin: var(--space-1) 0;
  border: none;
  border-top: 1px solid var(--color-border-subtle);
}

.wc-recap-details {
  margin: var(--space-3) 0;
}

.wc-recap-summary {
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-text-secondary);
  padding: var(--space-2) 0;
  user-select: none;
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.wc-recap-summary::-webkit-details-marker { display: none; }

.wc-recap-summary::before {
  content: "▶";
  font-size: 0.65rem;
  transition: transform var(--duration-fast);
  color: var(--color-text-muted);
}

.wc-recap-details[open] .wc-recap-summary::before {
  transform: rotate(90deg);
}

.wc-recap-summary:hover {
  color: var(--color-accent);
}

.competition-level {
  font-size: 0.85rem;
  padding: var(--space-2) 0 var(--space-3);
  font-weight: 600;
}

.competition-level.hidden { display: none; }

.badge-competition-fort   { color: var(--color-danger); }
.badge-competition-moyen  { color: var(--color-warning); }
.badge-competition-faible { color: var(--color-ok); }

/* V19 — score concurrence réel (PR + CV + ads) */
.competition-v19 {
  margin: var(--space-2) 0 var(--space-3);
}

.competition-v19 .competition-badge {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.5rem;
  padding: 0.4rem 0.75rem;
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: 0.9rem;
  border: 1px solid var(--color-border-muted);
}

.competition-v19 .competition-emoji {
  flex-shrink: 0;
}

.competition-v19 .competition-label {
  margin-left: 0.15rem;
}

.competition-v19 .competition-score {
  font-size: 0.8rem;
  font-weight: 700;
  font-family: var(--font-mono);
  opacity: 0.9;
  margin-left: 0.25rem;
}

.competition-v19 .competition-pr-note {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-text-muted);
  margin-left: 0.25rem;
}

.competition-v19 .competition-details {
  margin-top: var(--space-2);
  font-size: 0.85rem;
  color: var(--color-text-muted);
}

.competition-v19 .competition-details summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--color-accent);
}

.competition-v19 .competition-details ul {
  margin: var(--space-2) 0 0;
  padding-left: 1.25rem;
}

.competition-v19 .competition-intent-note {
  margin-top: var(--space-1);
  color: var(--color-text-muted);
  font-style: italic;
  font-size: 0.8rem;
  list-style: none;
  margin-left: -1.25rem;
}

.competition-faible {
  background: rgba(40, 167, 69, 0.12);
  color: var(--color-ok);
}

.competition-moderee {
  background: rgba(201, 162, 39, 0.15);
  color: #856404;
}

.competition-significative {
  background: rgba(253, 232, 200, 0.35);
  color: #7d4e00;
}

.competition-difficile {
  background: rgba(220, 53, 69, 0.12);
  color: var(--color-danger);
}

.competition-tres-difficile {
  background: rgba(108, 48, 52, 0.2);
  color: #4a0000;
}

.competition-inconnu {
  background: var(--color-surface-elevated);
  color: var(--color-text-muted);
}

.alert {
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  margin-bottom: var(--space-2);
}

.alert-warning {
  background: rgba(255, 165, 0, 0.1);
  border-left: 3px solid var(--color-warning);
}

.alert-info {
  background: rgba(88, 166, 255, 0.08);
  border-left: 3px solid var(--color-accent);
}

.alert-domains {
  display: block;
  font-size: 0.78rem;
  margin-top: 2px;
}

.add-competitor-form {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  flex-wrap: wrap;
  padding: var(--space-2) 0;
}

.semafor-toast {
  position: fixed;
  bottom: var(--space-5);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2100;
  padding: var(--space-3) var(--space-5);
  background: var(--color-surface-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-soft);
  font-size: 0.9rem;
}

.semafor-toast.hidden {
  display: none !important;
}

.semafor-toast.semafor-toast--warning {
  border-color: #d97706;
  background: #fffbeb;
}

/* ── Quota bêta (header) ─────────────────────────────────────────────────── */
.usage-quota-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-muted);
  background: var(--color-surface-elevated);
  font-size: 0.82rem;
  color: var(--color-text-muted);
  max-width: 9rem;
}

.usage-quota-bar {
  display: block;
  width: 3rem;
  height: 0.35rem;
  border-radius: 999px;
  background: var(--color-border-muted);
  overflow: hidden;
  flex-shrink: 0;
}

.usage-quota-fill {
  display: block;
  height: 100%;
  width: 0%;
  background: var(--color-accent);
  border-radius: inherit;
  transition: width 0.25s ease;
}

.usage-quota-label {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  color: var(--color-text);
  font-weight: 500;
}

.usage-logout-form {
  margin: 0;
  display: inline-flex;
}

.btn-logout {
  font-family: var(--font-sans);
  font-size: 0.82rem;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
}

.btn-logout:hover {
  color: var(--color-text);
  border-color: var(--color-border-muted);
  background: var(--color-bg);
}

/* Redondances V15 — repère visuel léger dans le tableau */
.redundancy-row {
  cursor: pointer;
}

.redundancy-row--active {
  outline: 2px solid var(--color-accent, #2563eb);
  outline-offset: -2px;
}

.redundancy-table tbody tr.redundancy-row-sev-red {
  background: rgba(255, 107, 107, 0.06);
}

.redundancy-table tbody tr.redundancy-row-sev-orange {
  background: rgba(255, 179, 71, 0.06);
}

/* ── Bouton agrandir panneau d'analyse ──────────────────────────────────── */
.workshop-tools-head {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.workshop-tools-head .workshop-tools-title {
  margin: 0;
  flex: 1;
  min-width: 0;
}

.btn-expand-tools {
  flex-shrink: 0;
  background: none;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-sm);
  cursor: pointer;
  padding: 2px 7px;
  font-size: 1.05rem;
  line-height: 1.4;
  color: var(--color-text-muted);
  transition: border-color 0.15s, color 0.15s;
}

.btn-expand-tools:hover,
.btn-expand-tools[aria-pressed="true"] {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

/* Mode panneau étendu : l'éditeur disparaît, le panneau prend toute la largeur */
@media (min-width: 1024px) {
  .workshop.tools-expanded .workshop-editor-col,
  .workshop.tools-expanded .workshop-resizer {
    display: none;
  }

  .workshop.tools-expanded .workshop-tools-col {
    flex: none;
    width: 100%;
    max-width: 100%;
  }
}

/* ── Sélecteur de colonnes tableau sémantique ───────────────────────────── */
.filter-sep {
  flex: 1 1 auto;
}

.col-picker-details {
  position: relative;
}

.col-picker-toggle {
  cursor: pointer;
  list-style: none;
  user-select: none;
  font-size: 0.82rem;
}

.col-picker-toggle::-webkit-details-marker {
  display: none;
}

.col-picker-panel {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  z-index: 200;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-3);
  min-width: 148px;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  box-shadow: 0 4px 16px rgba(0,0,0,0.18);
}

.col-picker-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.82rem;
  cursor: pointer;
  white-space: nowrap;
  color: var(--color-text);
}

.col-picker-item input[type="checkbox"] {
  accent-color: var(--color-accent);
  cursor: pointer;
}

/* ── Masquage colonnes optionnelles — sélecteurs data-col/data-sort (V42 Brief 3)
   Remplace nth-child : robuste si réordonnancement futur. */

.semantic-table.sem-hide-context th[data-sort="context"],
.semantic-table.sem-hide-context td.col-context,
.semantic-table.sem-hide-context td[data-col="context"] { display: none; }

.semantic-table.sem-hide-occ-max th[data-sort="occ_max"],
.semantic-table.sem-hide-occ-max td[data-col="occ-max"] { display: none; }

.semantic-table.sem-hide-occ-ideal th[data-sort="occ_ideal"],
.semantic-table.sem-hide-occ-ideal td[data-col="occ-ideal"] { display: none; }

.semantic-table.sem-hide-freq-c th[data-sort="freq_c"],
.semantic-table.sem-hide-freq-c td[data-col="freq-c"] { display: none; }

.semantic-table.sem-hide-freq-title th[data-sort="freq_title"],
.semantic-table.sem-hide-freq-title td[data-col="freq-title"] { display: none; }

.semantic-table.sem-hide-freq-hn th[data-sort="freq_hn"],
.semantic-table.sem-hide-freq-hn td[data-col="freq-hn"] { display: none; }

.semantic-table.sem-hide-corpus-df th[data-sort="corpus_df"],
.semantic-table.sem-hide-corpus-df td[data-col="corpus-df"] { display: none; }

.semantic-table.sem-hide-bm25 th[data-sort="tfidf"],
.semantic-table.sem-hide-bm25 td[data-col="bm25"] { display: none; }

.semantic-table.sem-hide-interest th[data-sort="interest"],
.semantic-table.sem-hide-interest td[data-col="interest"] { display: none; }

.semantic-table.sem-hide-priority th[data-sort="priority"],
.semantic-table.sem-hide-priority td[data-col="priority"] { display: none; }

/* ── Plus ▾ dropdown ── */

.tab-plus-wrap {
  position: relative;
  display: inline-flex;
}

.tab-plus {
  cursor: pointer;
}

.tab-plus[aria-expanded="true"],
.tab-plus.tab-plus-active {
  color: var(--color-accent);
  border-color: var(--color-accent);
}

.tab-plus-menu {
  position: absolute;
  top: calc(100% + var(--space-1));
  right: 0;
  z-index: var(--z-fixed);
  display: flex;
  flex-direction: column;
  min-width: 180px;
  padding: var(--space-1);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.tab-plus-menu[hidden] {
  display: none;
}

.tab-plus-item {
  display: flex;
  align-items: center;
  padding: var(--space-2) var(--space-3);
  font: inherit;
  text-align: left;
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  cursor: pointer;
}

.tab-plus-item:hover,
.tab-plus-item:focus-visible {
  background: var(--color-accent-soft);
  color: var(--color-accent-strong);
  outline: none;
}

.tab-plus-item[aria-current="page"] {
  font-weight: var(--font-weight-semibold);
  color: var(--color-accent-strong);
}

/* ── Accordéon Assistant IA (V42 Brief 3) ── */

.ai-assist-accordion {
  margin: var(--space-3) 0;
  background: var(--color-bg-surface);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.ai-assist-summary {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  font-weight: var(--font-weight-semibold);
  cursor: pointer;
  list-style: none;
  transition: background var(--duration-fast) var(--ease-default);
}

.ai-assist-summary::-webkit-details-marker { display: none; }

.ai-assist-summary::before {
  content: "▸";
  display: inline-block;
  font-size: 0.8em;
  color: var(--color-text-secondary);
  transition: transform var(--duration-fast) var(--ease-default);
}

.ai-assist-accordion[open] .ai-assist-summary::before {
  transform: rotate(90deg);
}

.ai-assist-summary:hover {
  background: var(--color-accent-soft);
}

.ai-assist-icon { font-size: 1.2em; }
.ai-assist-title { color: var(--color-text-primary); }
.ai-assist-hint { margin-left: auto; }

.ai-assist-body {
  padding: var(--space-4);
  border-top: 1px solid var(--color-border-subtle);
}

/* ── Exporter ▾ dropdown ── */

.export-menu { position: relative; display: inline-block; }
.export-menu-toggle { cursor: pointer; }
.export-menu[open] .export-menu-toggle {
  background: var(--color-accent-soft);
  color: var(--color-accent-strong);
}

.export-menu-panel {
  position: absolute;
  top: calc(100% + var(--space-1));
  right: 0;
  z-index: var(--z-dropdown);
  display: flex;
  flex-direction: column;
  min-width: 240px;
  padding: var(--space-1);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.export-menu-item {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 2px;
  padding: var(--space-2) var(--space-3);
  font: inherit;
  text-align: left;
  background: transparent;
  border: none;
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  cursor: pointer;
  text-decoration: none;
}

.export-menu-item:hover,
.export-menu-item:focus-visible {
  background: var(--color-accent-soft);
  outline: none;
}

.export-menu-label { font-weight: var(--font-weight-medium); }
.export-menu-hint { font-size: 0.82em; color: var(--color-text-secondary); }

/* ── col-picker reset button ── */

.col-picker-reset {
  display: block;
  width: 100%;
  margin-top: var(--space-2);
  padding: var(--space-1) var(--space-2);
  font: inherit;
  font-size: 0.8em;
  color: var(--color-text-secondary);
  background: transparent;
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  cursor: pointer;
  text-align: center;
}

.col-picker-reset:hover {
  background: var(--color-accent-soft);
  color: var(--color-accent-strong);
  border-color: var(--color-accent-soft);
}

.occ-max-capped-info {
  margin-left: 4px;
  color: var(--c-muted, var(--color-text-muted));
  cursor: help;
  font-size: 0.9em;
}

/* V20 — keywords « À vérifier » */
.badge-review {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 0.35rem;
  padding: 1px;
  border-radius: var(--radius-sm);
  background: var(--color-warning-soft);
  color: var(--color-warning);
  cursor: help;
  vertical-align: middle;
}

.kw-review td {
  background: rgba(240, 173, 78, 0.09);
}

.kw-validated td {
  background: rgba(40, 167, 69, 0.07);
}

.kw-review-actions {
  display: inline-flex;
  gap: 0.15rem;
  margin-right: 0.35rem;
  vertical-align: middle;
}

.btn-validate-kw,
.btn-reject-kw {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px 4px;
  min-width: 1.5rem;
  min-height: 1.5rem;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 0.95rem;
  line-height: 1;
  padding: 0 0.2rem;
  opacity: 0.75;
  transition: opacity 0.15s ease;
}

.btn-validate-kw:hover,
.btn-reject-kw:hover {
  opacity: 1;
}

.kw-review .col-action {
  min-width: 5rem;
  white-space: normal;
  text-align: left;
  vertical-align: top;
}
/* V26-bis — avis IA groupes (ligne pleine) */
tr.kw-ia-opinion-row td.kw-ia-opinion-td {
  max-width: 0;
  overflow: hidden;
  padding: 0.2rem 0.75rem 0.4rem 2rem;
  background: var(--color-surface-alt, var(--color-bg-surface));
  font-size: 0.82rem;
  line-height: 1.5;
  border-top: 1px solid var(--color-border, var(--color-border-subtle));
  white-space: pre-line;
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
  vertical-align: top;
}
.ia-op-icon { font-size: 0.95rem; }
.ia-op-verdict { font-weight: 600; text-transform: capitalize; }
.ia-op-raison { color: var(--color-text-muted, var(--color-text-secondary)); font-style: italic; }

.btn-ia-opinion-toggle {
  margin-left: 0.3rem;
  padding: 0.1rem 0.35rem;
  font-size: 0.8rem;
  cursor: pointer;
  border: 1px solid var(--color-border, var(--color-border-subtle));
  border-radius: 4px;
  background: var(--color-surface, #fff);
  opacity: 0.7;
}
.btn-ia-opinion-toggle:hover { opacity: 1; }

.btn-ia-opinion-reset {
  margin-left: 0.5rem;
  padding: 0.1rem 0.3rem;
  font-size: 0.75rem;
  cursor: pointer;
  border: 1px solid var(--color-border, var(--color-border-subtle));
  border-radius: 4px;
  background: transparent;
  color: var(--color-text-muted, var(--color-text-secondary));
}
.btn-ia-opinion-reset:hover {
  color: #ef4444;
  border-color: #ef4444;
}

/* Avis IA en ligne (clic sur la ligne = ouvrir / refermer) */
#kw-table-body tr.kw-row[data-has-ia-opinion="1"] {
  cursor: pointer;
}

/* V14-final — Réglages provider (projet + page) */
.settings-section {
  margin: 1.5rem 0;
  padding: 1rem 1.25rem;
  border: 1px solid var(--color-border, var(--color-border-subtle));
  border-radius: 8px;
}
.settings-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 0.5rem;
}
.ai-page-provider-override {
  margin-top: 1rem;
}
.divider-light {
  border: none;
  border-top: 1px solid var(--color-border, var(--color-border-subtle));
  margin: 1rem 0 0.75rem;
}
.input-sm {
  font-size: 0.85rem;
  padding: 0.2rem 0.5rem;
}
.btn-sm {
  font-size: 0.85rem;
  padding: 0.25rem 0.6rem;
}

/* V6-bis — alternatives suggestions IA */
.ai-alternatives {
  margin: 0.5rem 0 0.25rem;
  padding: 0.4rem 0.6rem;
  background: var(--color-surface-alt, var(--color-bg-surface));
  border-radius: 6px;
  border: 1px solid var(--color-border, var(--color-border-subtle));
  font-size: 0.82rem;
}
.ai-alt-label {
  margin: 0 0 0.25rem;
  font-weight: 600;
  color: var(--color-muted, var(--color-text-secondary));
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ai-alt-option {
  display: flex;
  align-items: baseline;
  gap: 0.35rem;
  margin: 0.15rem 0;
  cursor: pointer;
}
.ai-alt-main {
  font-style: italic;
  color: var(--color-muted, var(--color-text-secondary));
}
.ai-alt-radio {
  flex-shrink: 0;
  margin-top: 0.1rem;
}
.ai-alt-text {
  line-height: 1.4;
}

/* V31 — Toponymes / Opportunités locales */
.kw-toponym {
  opacity: .85;
}
.kw-toponym td {
  background: var(--color-surface-alt, var(--color-bg-surface));
}
.badge-toponym {
  font-size: .8rem;
  margin-left: .25rem;
  opacity: .7;
  cursor: help;
}

/* A5c — Termes écartés */
.rejected-kw-details {
  margin-top: var(--space-4);
}
.rejected-kw-details > summary {
  cursor: pointer;
  user-select: none;
  font-size: 0.85rem;
  color: var(--color-text-muted, var(--color-text-muted));
  padding: var(--space-2) 0;
  list-style: disclosure-closed;
}
.rejected-kw-details[open] > summary {
  list-style: disclosure-open;
}
.rejected-kw-wrap {
  margin-top: var(--space-3);
}
.rejected-kw-notice {
  font-size: 0.82rem;
  color: var(--color-text-muted, var(--color-text-muted));
  margin-bottom: var(--space-3);
  font-style: italic;
}
.rejected-kw-table {
  font-size: 0.82rem;
  width: 100%;
}
.rejected-kw-table td,
.rejected-kw-table th {
  padding: var(--space-1) var(--space-2);
}
.forced-target-badge {
  display: inline-block;
  font-size: 0.72rem;
  background: var(--color-primary, #2563eb);
  color: #fff;
  border-radius: 3px;
  padding: 1px 5px;
  margin-left: 5px;
  vertical-align: middle;
  font-weight: 600;
  letter-spacing: .02em;
}

/* B.2 — Détail SERP (modale « Générer un cocon »), lisible clair + sombre */
.gen-serp-urls {
  box-sizing: border-box;
  padding: 0.5rem 0.65rem;
  background: var(--color-surface-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-text);
  font-size: 0.85rem;
  line-height: 1.45;
}
.gen-serp-urls__heading {
  margin: 0 0 0.4rem;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-text);
}
.gen-serp-urls__label {
  margin: 0 0 0.2rem;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--color-text-muted);
}
.gen-serp-urls ul {
  margin: 0 0 0.5rem;
  padding-left: 1.15rem;
  color: var(--color-text);
}
.gen-serp-urls li {
  margin-bottom: 0.15rem;
  word-break: break-word;
  overflow-wrap: anywhere;
  color: var(--color-text);
}
.gen-serp-urls__reason {
  color: var(--color-text-muted);
}
.gen-serp-urls__hint {
  margin: 0.35rem 0 0;
  font-size: 0.8rem;
  line-height: 1.35;
  color: var(--color-text-muted);
}

/* B.2 — Candidats liens internes (modale + fiche cocon), lisible clair + sombre */
.cocon-ilc-list {
  margin: 0.3rem 0 0 1rem;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.cocon-ilc-list li {
  font-size: 0.82rem;
  color: var(--color-text-muted);
  line-height: 1.35;
}
.cocon-ilc-link {
  color: var(--color-accent);
  text-decoration: none;
  font-family: var(--font-mono);
  font-size: 0.82rem;
  word-break: break-all;
}
.cocon-ilc-link:hover {
  text-decoration: underline;
}
.cocon-ilc-slug {
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--color-text-muted);
  word-break: break-all;
}

/* ─── B.6 — Colonne URL cocon ────────────────────────────────────────── */

.cocon-url-cell {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  min-width: 0;
}

.cocon-url-input {
  flex: 1;
  min-width: 180px;
  max-width: 320px;
  font-size: 0.82rem;
  font-family: var(--font-mono);
}

.cocon-url-status {
  font-size: 0.78rem;
  white-space: nowrap;
  color: var(--color-text-muted);
  min-width: 1.5rem;
}

/* ─── B.7 — Bouton et panneau Lien Cocon ────────────────────────────── */

.btn-editor-cocon {
  color: var(--color-accent);
}
.btn-editor-cocon[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
}

#cocon-link-backdrop {
  position: fixed;
  inset: 0;
  /* Au-dessus de .analyze-overlay (10000), tooltips (10050), pour éviter tout recouvrement sticky */
  z-index: 50000;
}

#cocon-link-panel {
  position: fixed;
  z-index: 50001;
  min-width: 280px;
  max-width: 380px;
  max-height: 320px;
  overflow-y: auto;
  background: var(--color-surface-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-soft);
  padding: 0.5rem 0;
}

.cocon-link-title {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.25rem 0.75rem 0.35rem;
  margin: 0;
}

.cocon-link-loading,
.cocon-link-error,
.cocon-link-empty {
  font-size: 0.84rem;
  color: var(--color-text-muted);
  padding: 0.5rem 0.75rem;
  margin: 0;
}

.cocon-link-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.cocon-link-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.1rem;
  width: 100%;
  padding: 0.45rem 0.75rem;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  color: var(--color-text);
  font-family: var(--font-sans);
}
.cocon-link-item:hover,
.cocon-link-item:focus {
  background: var(--color-accent-dim);
  outline: none;
}

.cocon-link-kw {
  font-size: 0.88rem;
  font-weight: 500;
}

.cocon-link-href {
  font-size: 0.74rem;
  font-family: var(--font-mono);
  color: var(--color-text-muted);
}

/* ─── Phase B.1 — Cocons ─────────────────────────────────────────────── */

.badge-vert {
  background: rgba(46, 160, 67, 0.18);
  color: var(--color-success);
}

/* B.2b — badge satellite existant dans le projet */
.badge-existante {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  background: rgba(46, 160, 67, 0.18);
  color: var(--color-success);
  flex-shrink: 0;
}

/* B.2b — ligne "pages projet utilisées" dans le debug SERP */
.gen-serp-urls__pages-signal {
  font-weight: 600;
  color: var(--color-success);
}
.badge-orange {
  background: rgba(210, 153, 34, 0.18);
  color: #e3b341;
}
.badge-orange-fonce {
  background: rgba(217, 117, 17, 0.2);
  color: #f0883e;
}
.badge-rouge {
  background: rgba(248, 81, 73, 0.18);
  color: #ff7b72;
}
.badge-pilier {
  background: rgba(88, 166, 255, 0.2);
  color: var(--color-accent);
}
.badge-satellite {
  background: var(--color-bg-elevated, rgba(255,255,255,0.06));
  color: var(--color-text-muted, var(--color-text-muted));
}

.dialog {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  padding: 0;
  max-width: 480px;
  width: calc(100% - 2rem);
}
.dialog::backdrop {
  background: rgba(0, 0, 0, 0.5);
}
.dialog-form {
  padding: 1.25rem 1.25rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.dialog-title {
  margin: 0 0 0.4rem;
  font-size: 1.05rem;
}
.dialog-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-top: 0.8rem;
}
.field-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--color-text-muted, var(--color-text-muted));
  margin-top: 0.4rem;
}
.advisor-result {
  min-height: 1.2em;
  padding: 0.4rem 0.6rem;
  background: var(--color-bg-subtle, rgba(255,255,255,0.03));
  border-radius: var(--radius-sm);
}

/* Accueil — onglets Projets / Rechercher */
.project-home-tabs {
  display: flex;
  gap: 0.35rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 0.5rem;
}
.project-home-tab {
  padding: 0.4rem 0.75rem;
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-text-muted);
  text-decoration: none;
}
.project-home-tab:hover {
  color: var(--color-text);
  background: var(--color-surface-elevated);
}
.project-home-tab--active {
  color: var(--color-accent);
  background: var(--color-accent-dim);
}

.project-home-panel--active {
  display: block;
}
.project-home-panel[hidden] {
  display: none !important;
}

.global-search-input {
  max-width: 32rem;
  width: 100%;
}
.global-search-results {
  margin-top: 0.75rem;
  max-height: 22rem;
  overflow: auto;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
}
.global-search-group-title {
  margin: 0;
  padding: 0.4rem 0.65rem;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  background: var(--color-surface-elevated);
  border-bottom: 1px solid var(--color-border);
}
.global-search-list {
  margin: 0;
  padding: 0;
  list-style: none;
}
.global-search-list li {
  border-bottom: 1px solid var(--color-border);
}
.global-search-list li:last-child {
  border-bottom: none;
}
.global-search-link {
  display: block;
  padding: 0.5rem 0.65rem;
  color: var(--color-text);
  text-decoration: none;
}
.global-search-link:hover {
  background: var(--color-surface-elevated);
}

.project-card-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}
.project-card-row .project-card-link {
  flex: 1;
  min-width: 0;
}

.table-actions {
  white-space: nowrap;
}
.col-actions {
  width: 1%;
  white-space: nowrap;
}

.btn-danger {
  background: rgba(218, 54, 51, 0.2);
  color: var(--color-danger);
  border: 1px solid rgba(248, 81, 73, 0.45);
}
.btn-danger:hover {
  background: rgba(218, 54, 51, 0.35);
}
.btn-danger-text {
  color: var(--color-danger);
}
.btn-danger-text:hover {
  color: #ffa198;
}
.btn-danger-ghost {
  color: var(--color-text-muted);
  border-color: var(--color-border);
}
.btn-danger-ghost:hover {
  color: var(--color-danger);
  border-color: rgba(248, 81, 73, 0.45);
}

/* ── Import URL → éditeur ──────────────────────────────────────────────── */
.import-status {
  font-size: .8125rem;
  margin-left: .5rem;
  color: var(--color-text-muted);
}
.import-status--success {
  color: var(--color-green, var(--color-success));
}
.import-status--error {
  color: var(--color-red, var(--color-danger));
}

/* ── Score history (B.3b) ──────────────────────────────────────────────── */
.score-history-section {
  margin: 1.25rem 0 0;
  padding-top: 0.5rem;
  border-top: 1px solid var(--color-border);
}

.score-history-wrapper {
  position: relative;
  max-width: 700px;
  height: 180px;
  margin-top: 0.35rem;
}

.score-history-wrapper canvas {
  width: 100% !important;
  height: 100% !important;
}
/* ── B.3c — Graphe cocon D3 ────────────────────────────────────────────── */
.cocon-graph-section { margin: 1.5rem 0; }

.cocon-graph-wrapper {
  width: 100%;
  max-height: min(92vh, 1200px);
  min-height: 460px;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  overflow: auto;
  background: var(--color-surface);
}

.cocon-graph-wrapper svg { display: block; }

.cocon-node--pilier circle { cursor: default; }

.cocon-node--satellite--page circle { cursor: pointer; }

.cocon-node--satellite--ia-only circle {
  stroke-dasharray: 4 2;
  cursor: default;
}

/* ── B.4 — Print (impression atelier) ──────────────────────────────────── */
@media print {
  .sidebar,
  .navbar,
  .toolbar-actions,
  .toolbar-filters,
  .btn,
  .chip,
  .no-print {
    display: none !important;
  }
  body {
    font-size: 11pt;
    color: #111;
    background: #fff;
  }
}

/* Tableau sémantique — pastel cellule Occurrence vs plage idéale */
.kw-occ--yellow {
  background-color: #fffde7;
}
.kw-occ--orange {
  background-color: #fff3e0;
}
.kw-occ--red {
  background-color: #ffebee;
}

/* ── UI Concurrence V2 — Panel Top 3 ──────────────────────────────────── */
.top3-panel {
  margin-bottom: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.top3-header {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}
.top3-title {
  font-weight: 700;
  font-size: 0.9rem;
}
.top3-subtitle {
  font-size: 0.78rem;
  color: var(--color-text-muted);
}
.top3-cards {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.top3-card {
  flex: 1;
  min-width: 140px;
  background: var(--color-surface-elevated);
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-sm);
  padding: var(--space-2) var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.top3-medal  { font-size: 1.2rem; }
.top3-domain {
  font-size: 0.82rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.top3-words { font-size: 0.8rem; color: var(--color-text-muted); }
.top3-sem   { font-size: 0.75rem; color: var(--color-text-muted); }
.top3-pr    { font-size: 0.75rem; color: var(--color-text-muted); }

.comp-sem-good { color: var(--color-success, #1a7f4b); font-weight: 600; }
.comp-sem-mid  { color: var(--color-warning, #b8860b); font-weight: 600; }
.comp-sem-low  { color: var(--color-danger, #c0392b); font-weight: 600; }
.comp-sem-pending { color: var(--color-text-muted); font-style: italic; }
.top3-flag  {
  font-size: 0.7rem;
  padding: 1px 4px;
  border-radius: 3px;
  background: var(--color-surface);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border-muted);
  align-self: flex-start;
}
.top3-flag-authority { color: var(--color-danger); }
.top3-flag-trusted   { color: var(--color-ok); }
.top3-flag-thin      { color: var(--color-warn); }

/* ── UI Concurrence V2 — Fourchette mots enrichie ─────────────────────── */

/* Intro texte lisible */
.wc-intro {
  margin-bottom: var(--space-3);
}
.wc-sentence {
  font-size: 0.88rem;
  margin: 0 0 var(--space-1);
  line-height: 1.5;
}
.wc-target-num {
  color: var(--color-ok);
}
.wc-status {
  font-size: 0.85rem;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
}
.wc-status-ok    { color: var(--color-ok);   background: color-mix(in srgb, var(--color-ok) 10%, transparent); }
.wc-status-short { color: var(--color-warn);  background: color-mix(in srgb, var(--color-warn) 10%, transparent); }
.wc-status-long  { color: var(--color-accent); background: color-mix(in srgb, var(--color-accent) 10%, transparent); }

/* Légende barre */
.wc-barre-legend {
  display: flex;
  gap: var(--space-3);
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}
.wc-barre-legend-item {
  display: flex;
  align-items: center;
  gap: 4px;
}
.wc-legend-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
}
.wc-legend-median { background: var(--color-accent); }
.wc-legend-page   { background: var(--color-text-muted); opacity: 0.7; }

.wc-barre-wrap { margin-bottom: var(--space-3); }
.wc-barre {
  position: relative;
  height: 8px;
  background: var(--color-surface-elevated);
  border-radius: 4px;
  margin-bottom: 4px;
}
.wc-barre-fill {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--color-accent) 0%, var(--color-warn) 100%);
  border-radius: 4px;
  opacity: 0.3;
}
.wc-barre-marker {
  position: absolute;
  top: -3px;
  width: 2px;
  height: 14px;
  border-radius: 1px;
  transform: translateX(-50%);
}
.wc-barre-median { background: var(--color-accent); }
.wc-barre-page   { background: var(--color-text-muted); opacity: 0.7; }
.wc-barre-target {
  background: transparent;
  font-size: 0.85rem;
  top: -5px;
  width: auto;
  height: auto;
}
.wc-barre-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-top: 3px;
}

.wc-detail-wrap {
  margin-top: var(--space-3);
  font-size: 0.8rem;
}
.wc-detail-wrap summary {
  cursor: pointer;
  color: var(--color-text-muted);
  padding: var(--space-1) 0;
  user-select: none;
}
.wc-detail-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--space-2);
}
.wc-detail-table th,
.wc-detail-table td {
  padding: 3px var(--space-2);
  border-bottom: 1px solid var(--color-border-muted);
  text-align: left;
}
.wc-detail-table th {
  color: var(--color-text-muted);
  font-weight: 600;
}
.wc-detail-excluded td {
  opacity: 0.45;
  font-style: italic;
}
.wc-detail-domain {
  max-width: 180px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wc-detail-flag {
  font-size: 0.68rem;
  margin-left: 4px;
  padding: 1px 3px;
  border-radius: 3px;
  background: var(--color-surface-elevated);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border-muted);
}

/* === Différenciation Tier 1 === */
.differentiation-header { margin-bottom: 16px; }
.differentiation-intro { margin-top: 4px; }

.differentiation-loading,
.differentiation-empty {
  padding: 16px;
  color: var(--color-text-muted, #666);
  font-style: italic;
}

.differentiation-cards {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.diff-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--color-border-muted, #e0e0e0);
  border-radius: 8px;
  background: var(--color-surface, #fafafa);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.diff-card:hover {
  border-color: var(--color-accent, #2d7be5);
  background: var(--color-surface-elevated, #f4f8ff);
}
.diff-card:has(input:checked) {
  border-color: var(--color-accent, #2d7be5);
  background: var(--color-surface-elevated, #eaf2ff);
}

.diff-card-check { margin-top: 4px; }
.diff-card-body { flex: 1; }
.diff-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
  flex-wrap: wrap;
}

.diff-badge {
  display: inline-block;
  padding: 2px 8px;
  font-size: 12px;
  font-weight: 600;
  border-radius: 12px;
}
.diff-badge.semafor-tip-anchor {
  cursor: help;
}
.diff-badge-paa_gap { background: #fff5e6; color: #b35900; }
.diff-badge-paa_gap_absent { background: #fff5e6; color: #b35900; }
.diff-badge-paa_gap_underserved { background: #fff0f5; color: #9a1d4f; }
.diff-badge-low_coverage { background: #ecf3ff; color: #1d4f9a; }
.diff-badge-lc_cluster { background: #eef8ee; color: #1f6b3a; }
.diff-badge-outlier_title { background: #f3f0ff; color: #4a2d9a; }

.opportunities-diagnostic {
  margin: 12px 0 16px;
  padding: 12px 14px;
  background: #fffbea;
  border: 1px solid #f0e0a0;
  border-radius: 8px;
  font-size: 13px;
}
.opportunities-diagnostic-title {
  margin: 0 0 6px;
  font-weight: 600;
}
.opportunities-diagnostic ul {
  margin: 0;
  padding-left: 1.2em;
}
.opportunities-outliers-section {
  margin-top: 20px;
}
.opportunities-outliers-title {
  font-size: 14px;
  margin: 0 0 10px;
}

.diff-card-title { font-weight: 600; }
.diff-card-rationale {
  margin: 0;
  color: var(--color-text-muted, #555);
  font-size: 13px;
}

.differentiation-actions {
  margin-top: 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.differentiation-save-status { font-size: 13px; }
.diff-save-info { color: var(--color-text-muted, #666); }
.diff-save-success { color: #1f7a3e; }
.diff-save-warning { color: #b35900; }

.diff-error {
  padding: 12px;
  color: #b00020;
  background: #fff0f0;
  border-radius: 6px;
}

.tab-badge.active {
  display: inline-block;
  min-width: 18px;
  padding: 0 6px;
  background: var(--color-accent, #2d7be5);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  border-radius: 9px;
  margin-left: 6px;
}

/* === Module Angles IA === */
.angles-ia-header { margin-bottom: 14px; }
.angles-ia-intro { margin-top: 4px; }

.angles-ia-level-selector {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.angles-ia-levels { display: flex; gap: 6px; flex-wrap: wrap; }
.level-btn {
  padding: 5px 12px;
  border-radius: 6px;
  border: 1px solid var(--border-soft, #dde);
  background: var(--bg-card, #fafafa);
  cursor: pointer;
  font-size: 13px;
  transition: border-color 0.15s, background 0.15s;
}
.level-btn.active,
.level-btn:hover {
  border-color: var(--color-accent, #2d7be5);
  background: #eaf2ff;
}
.level-cost {
  font-size: 11px;
  color: var(--color-text-muted, #888);
  margin-left: 4px;
}

.angles-ia-stale-warning {
  font-size: 13px;
  color: #7a4f00;
  background: #fff8e6;
  border: 1px solid #f0c060;
  padding: 8px 12px;
  border-radius: 5px;
  margin-bottom: 14px;
}

.angles-ia-cost-warning {
  font-size: 13px;
  color: var(--color-text-muted, #555);
  background: #fef9e7;
  border: 1px solid #f6e57e;
  padding: 6px 10px;
  border-radius: 5px;
  margin-bottom: 14px;
}

.angles-ia-run-meta {
  font-size: 12px;
  color: var(--color-text-muted, #888);
  margin-bottom: 12px;
}

.angles-ia-cards {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ai-angle-card {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 12px 14px;
  border: 1px solid var(--border-soft, #e0e0e0);
  border-radius: 8px;
  background: var(--bg-card, #fafafa);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}
.ai-angle-card:hover {
  border-color: var(--color-accent, #2d7be5);
  background: #f4f8ff;
}
.ai-angle-card:has(input:checked) {
  border-color: var(--color-accent, #2d7be5);
  background: #eaf2ff;
}

.ai-angle-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 12px;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
}
.badge-flash { background: #e3f2fd; color: #0d47a1; }
.badge-pro { background: #e8f5e9; color: #1b5e20; }
.badge-opus { background: #f3e5f5; color: #4a148c; }

.ai-angle-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.ai-angle-title { font-weight: 600; color: var(--color-text, #222); }
.ai-angle-rationale {
  font-size: 13px;
  color: var(--color-text-muted, #555);
  margin: 4px 0 0;
}
.ai-angle-placement {
  font-size: 12px;
  color: #6c757d;
  margin: 3px 0 0;
}
.ai-angle-source {
  font-size: 12px;
  color: var(--color-accent, #2d7be5);
  margin: 2px 0 0;
}

.angles-ia-actions {
  margin-top: 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.angles-ia-save-status { font-size: 13px; color: #1f7a3e; }
.angles-ia-error {
  padding: 10px 12px;
  background: #fff0f0;
  color: #b00020;
  border-radius: 5px;
  margin-bottom: 12px;
}
.angles-ia-loading { font-style: italic; }
.angles-ia-empty { margin-bottom: 12px; }

/* === Régime SERP (onglet Enrichissement) === */
.serp-regime-banner {
  margin-bottom: 20px;
  padding: 16px 18px;
  border-radius: 10px;
  background: var(--bg-card, #fafafa);
  border-left: 4px solid var(--accent, #2d7be5);
  transition: border-color 0.2s;
}
.serp-regime-banner.regime-saturated { border-left-color: #d97706; }
.serp-regime-banner.regime-angle-divergent { border-left-color: #2563eb; }
.serp-regime-banner.regime-multi-intent { border-left-color: #7c3aed; }
.serp-regime-banner.regime-atypical { border-left-color: #6b7280; }
.serp-regime-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.serp-regime-emoji { font-size: 22px; line-height: 1; }
.serp-regime-label {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
}
.serp-regime-confidence {
  margin-left: auto;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 10px;
  background: #f0f0f0;
}
.serp-regime-confidence.conf-high { background: #e8f5e9; color: #1b5e20; }
.serp-regime-confidence.conf-medium { background: #fff3e0; color: #b35900; }
.serp-regime-confidence.conf-low { background: #fce4ec; color: #ad1457; }
.serp-regime-explanation {
  font-size: 14px;
  color: var(--text-muted, #555);
  margin-bottom: 12px;
}
.serp-regime-suggestion-box {
  background: rgba(45, 123, 229, 0.08);
  padding: 10px 14px;
  border-radius: 6px;
  margin-bottom: 10px;
}
.serp-regime-suggestion {
  margin: 0;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-strong, #222);
}
.serp-regime-details { margin-top: 8px; }
.serp-regime-details summary {
  font-size: 13px;
  color: var(--text-muted, #666);
  cursor: pointer;
  user-select: none;
}
.serp-regime-nuance {
  font-size: 13px;
  font-style: italic;
  color: var(--text-muted, #555);
  margin: 8px 0 4px;
  padding-left: 12px;
  border-left: 2px solid #ddd;
}
.serp-regime-confidence-reason {
  font-size: 12px;
  color: var(--text-muted, #777);
  margin: 4px 0;
}
.serp-regime-debug {
  font-size: 11px;
  color: #999;
  margin-top: 6px;
}
.serp-regime-empty {
  margin-bottom: 16px;
  padding: 12px 14px;
  border-radius: 8px;
  background: var(--bg-muted, #f5f5f5);
}

.serp-regime-stale-warning {
  font-size: 13px;
  color: #7a4f00;
  background: #fff8e6;
  border: 1px solid #f0c060;
  padding: 8px 12px;
  border-radius: 5px;
  margin-bottom: 12px;
}

/* ── Guide sidebar primo-utilisateur ── */
.guide-tab-trigger {
  position: fixed;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 120;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  rotate: 180deg;
  padding: var(--space-3) var(--space-2);
  background: var(--color-accent);
  color: #fff;
  border: none;
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.04em;
  box-shadow: 2px 0 8px rgba(0, 0, 0, 0.15);
  transition: left 0.2s ease, background var(--duration-fast);
  line-height: 1;
}
.guide-tab-trigger:hover {
  background: color-mix(in srgb, var(--color-accent) 85%, #000);
}
.guide-tab-trigger--open {
  left: 260px;
}

.guide-sidebar {
  width: 0;
  min-width: 0;
  overflow: hidden;
  flex-shrink: 0;
  transition: width 0.2s ease, min-width 0.2s ease;
  background: var(--color-surface);
  border-right: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
}
.guide-sidebar.guide-sidebar--open {
  width: 260px;
  min-width: 260px;
}

.guide-sidebar-inner {
  width: 260px;
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
}

@media (min-width: 1024px) {
  .guide-sidebar {
    align-self: stretch;
    position: sticky;
    top: var(--app-header-height);
    height: calc(100vh - var(--app-header-height));
    max-height: calc(100vh - var(--app-header-height));
  }
}

.guide-sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-3) var(--space-2);
  border-bottom: 1px solid var(--color-border);
  flex-shrink: 0;
}
.guide-sidebar-title {
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--color-text);
}
.guide-sidebar-close {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--color-text-muted);
  font-size: 1rem;
  padding: 2px 4px;
  border-radius: var(--radius-md);
}
.guide-sidebar-close:hover { color: var(--color-text); }

.guide-tracks-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border);
  flex-shrink: 0;
}
.guide-track-btn {
  font-size: 0.72rem;
  padding: 2px 8px;
  border-radius: 12px;
  border: 1px solid var(--color-border);
  background: var(--color-surface-elevated);
  color: var(--color-text-muted);
  cursor: pointer;
  white-space: nowrap;
}
.guide-track-btn.active,
.guide-track-btn:hover {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}

.guide-steps-container {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-2) 0;
  min-height: 0;
}

.guide-human-callout {
  margin: var(--space-2) var(--space-3);
  padding: var(--space-2) var(--space-3);
  background: color-mix(in srgb, var(--color-ok) 10%, var(--color-surface));
  border-left: 3px solid var(--color-ok);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: 0.78rem;
  line-height: 1.5;
  color: var(--color-text);
}
.guide-human-callout strong {
  display: block;
  margin-bottom: 3px;
  color: var(--color-ok);
}

.guide-step {
  padding: var(--space-2) var(--space-3);
  cursor: pointer;
  border-left: 3px solid transparent;
  transition: background var(--duration-fast), border-color var(--duration-fast);
}
.guide-step:hover {
  background: var(--color-surface-elevated);
}
.guide-step.guide-step--active {
  border-left-color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 8%, var(--color-surface));
}
.guide-step-num {
  font-size: 0.7rem;
  color: var(--color-text-muted);
  font-weight: 600;
  margin-bottom: 2px;
}
.guide-step-title {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: 2px;
}
.guide-step-body {
  font-size: 0.78rem;
  color: var(--color-text-muted);
  line-height: 1.5;
  display: none;
  margin-top: var(--space-1);
}
.guide-step--active .guide-step-body {
  display: block;
}
.guide-step-action {
  display: block;
  margin-top: var(--space-2);
  font-size: 0.75rem;
  color: var(--color-accent);
  font-weight: 600;
}
.guide-step-action::before { content: "→ "; }

.guide-seealso {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin: var(--space-1) var(--space-3) var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-border-muted);
}
.guide-seealso a {
  color: var(--color-accent);
  text-decoration: none;
  cursor: pointer;
}
.guide-seealso a:hover { text-decoration: underline; }

@keyframes guide-pulse {
  0%   { outline-offset: 0;   outline-color: var(--color-accent); }
  50%  { outline-offset: 4px; outline-color: var(--color-accent); }
  100% { outline-offset: 0;   outline-color: transparent; }
}
.guide-highlight-pulse {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
  animation: guide-pulse 0.7s ease 3;
  border-radius: var(--radius-md);
}

@media (max-width: 900px) {
  .guide-sidebar.guide-sidebar--open {
    position: fixed;
    left: 0;
    top: var(--app-header-height, 56px);
    bottom: 0;
    z-index: 200;
    width: min(280px, 88vw);
    min-width: min(280px, 88vw);
    box-shadow: 4px 0 16px rgba(0, 0, 0, 0.2);
  }
  .guide-sidebar-inner {
    width: min(280px, 88vw);
  }
  .guide-tab-trigger--open {
    left: min(280px, 88vw);
  }
}
/* /Guide sidebar */

/* ── Social Repurposing ── */
.social-panel-overlay {
  position: fixed;
  inset: 0;
  z-index: 300;
  background: rgba(0, 0, 0, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-md);
}
.social-panel-overlay.hidden {
  display: none;
}
.social-panel {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
  width: min(740px, 96vw);
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.social-panel-header {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-md) var(--spacing-lg);
  border-bottom: 1px solid var(--color-border);
}
.social-panel-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
  flex: 1;
}
.social-panel-meta {
  font-size: 0.75rem;
  color: var(--color-text-muted);
}
.social-panel-close {
  font-size: 1.2rem;
  line-height: 1;
  padding: 0 var(--spacing-xs);
}
.social-cards {
  flex: 1;
  overflow-y: auto;
  padding: var(--spacing-md) var(--spacing-lg);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.social-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.social-card--error {
  padding: var(--spacing-sm) var(--spacing-md);
  color: var(--color-error, #c0392b);
  background: var(--color-error-bg, #fdf2f2);
}
.social-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-xs) var(--spacing-sm);
  background: var(--color-surface-alt, #f6f7f9);
  border-bottom: 1px solid var(--color-border);
}
.social-card-network-label {
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
}
.social-card-actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}
.social-char-counter {
  font-size: 0.75rem;
  font-variant-numeric: tabular-nums;
  min-width: 5ch;
  text-align: right;
}
.social-char--ok { color: var(--color-success, #27ae60); }
.social-char--short { color: var(--color-text-muted); }
.social-char--warning { color: var(--color-warning, #f39c12); }
.social-char--over { color: var(--color-error, #c0392b); font-weight: 700; }
.social-card-textarea {
  width: 100%;
  resize: vertical;
  border: none;
  border-bottom: 1px solid var(--color-border);
  border-radius: 0;
  padding: var(--spacing-sm);
  font-size: 0.875rem;
  line-height: 1.5;
  font-family: inherit;
  background: var(--color-surface);
}
.social-card-textarea:focus {
  outline: 2px solid var(--color-accent);
  outline-offset: -2px;
}
.social-card-hashtags {
  padding: var(--spacing-xs) var(--spacing-sm);
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  min-height: 28px;
}
.social-hashtag {
  font-size: 0.75rem;
  color: var(--color-accent);
  background: var(--color-accent-subtle, rgba(74, 109, 229, 0.08));
  border-radius: var(--radius-sm);
  padding: 1px 6px;
}
.social-loading {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-lg);
  color: var(--color-text-muted);
  justify-content: center;
}
.social-error {
  padding: var(--spacing-md) var(--spacing-lg);
  color: var(--color-error, #c0392b);
  background: var(--color-error-bg, #fdf2f2);
  border-radius: var(--radius-md);
  margin: var(--spacing-sm) var(--spacing-lg);
}
.social-panel-footer {
  padding: var(--spacing-sm) var(--spacing-lg);
  border-top: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}
.btn-xs {
  font-size: 0.7rem;
  padding: 1px 6px;
}
/* /Social Repurposing */
