/* ============================================================
   TYPOGRAPHIE — styles de la zone Choisir (v3)

   Ajout à concaténer dans nuancier.css OU à inclure séparément
   via un <link> supplémentaire.

   Préfixe des classes : .ds-typo-* (cohérent avec le reste du
   sous-module typo).

   Les styles des zones Échelle (.ds-typo-scale, .ds-typo-row*,
   .ds-typo-preview*) et Conventions (.ds-typo-conventions*)
   préexistent dans nuancier.css et n'ont pas à changer — ce sont
   les mêmes blocs visuels, juste réorganisés.
   ============================================================ */


/* ============================================================
   STRUCTURE DES 3 ZONES
   ============================================================ */

.ds-typo-zone {
  margin-bottom: var(--space-xl);
  padding: var(--space-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}

.ds-typo-zone-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 var(--space-lg) 0;
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border);
}


/* ============================================================
   ZONE 1 — CHOISIR : RÉCAP STICKY
   ============================================================ */

.ds-typo-recap {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--color-surface);
  padding: var(--space-md);
  margin: 0 calc(var(--space-lg) * -1) var(--space-lg);
  border-bottom: 1px solid var(--color-border);
  /* Ombre subtile en bas pour décoller du contenu qui scrolle dessous */
  box-shadow: 0 4px 8px -8px rgba(0, 0, 0, 0.15);
}

.ds-typo-recap-roles {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.ds-typo-recap-role {
  padding: var(--space-sm) var(--space-md);
  background: var(--color-bg);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
}

.ds-typo-recap-role-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 4px;
}

.ds-typo-recap-role-name {
  font-size: var(--text-md);
  font-weight: 500;
  color: var(--color-text);
  word-break: break-word;
}

/* La mini-composition : titre + body + mono sur une ligne (avec wrap) */
.ds-typo-recap-composition {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--space-md);
  padding-top: var(--space-sm);
  border-top: 1px dashed var(--color-border);
  color: var(--color-text-soft);
}

.ds-typo-recap-composition-title {
  font-size: var(--text-lg);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--color-text);
}

.ds-typo-recap-composition-body {
  font-size: var(--text-sm);
}

.ds-typo-recap-composition-mono {
  font-size: var(--text-sm);
  color: var(--color-text-faint);
}


/* ============================================================
   ZONE 1 — CHOISIR : PRESETS
   ============================================================ */

.ds-typo-presets {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
  flex-wrap: wrap;
}

.ds-typo-presets-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ds-typo-presets-row {
  display: flex;
  gap: var(--space-xs);
  flex-wrap: wrap;
}

.ds-typo-preset-chip {
  padding: 4px var(--space-md);
  font-size: var(--text-sm);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  color: var(--color-text);
  cursor: pointer;
  transition: all var(--t-fast);
}
.ds-typo-preset-chip:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
  background: color-mix(in srgb, var(--color-accent) 8%, transparent);
}
.ds-typo-preset-chip.is-active {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}
[data-theme="dark"] .ds-typo-preset-chip.is-active {
  color: var(--color-bg);
}


/* ============================================================
   ZONE 1 — CHOISIR : CONTROLS (texte + taille)
   ============================================================ */

.ds-typo-chooser-controls {
  display: flex;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
  flex-wrap: wrap;
}

.ds-typo-chooser-control {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  flex: 1 1 200px;
}

.ds-typo-chooser-control--grow {
  flex: 2 1 320px;
}

.ds-typo-chooser-input {
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--text-md);
  font-family: var(--font-body);
}
.ds-typo-chooser-input:focus {
  outline: none;
  border-color: var(--color-border-strong);
}

.ds-typo-chooser-range {
  width: 100%;
}


/* ============================================================
   ZONE 1 — CHOISIR : FILTRES
   ============================================================ */

.ds-typo-chooser-filters {
  display: flex;
  gap: var(--space-xs);
  margin-bottom: var(--space-lg);
  flex-wrap: wrap;
}

.ds-typo-chooser-filter {
  padding: 4px var(--space-md);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  color: var(--color-text-soft);
  cursor: pointer;
  transition: all var(--t-fast);
}
.ds-typo-chooser-filter:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}
.ds-typo-chooser-filter.is-active {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}
[data-theme="dark"] .ds-typo-chooser-filter.is-active {
  color: var(--color-bg);
}

.ds-typo-chooser-filter-count {
  opacity: 0.5;
  margin-left: 4px;
}


/* ============================================================
   ZONE 1 — CHOISIR : GRILLE DE CARTES
   ============================================================ */

.ds-typo-chooser-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap: var(--space-md);
}

.ds-typo-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding: var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  position: relative;
  transition: border-color var(--t-fast);
}
.ds-typo-card:hover {
  border-color: var(--color-border-strong);
}
.ds-typo-card.is-hidden {
  display: none;
}

.ds-typo-card-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.ds-typo-card-name {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-soft);
  flex: 1 1 auto;
}

.ds-typo-card-tag {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 2px var(--space-sm);
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  color: var(--color-text-soft);
  white-space: nowrap;
}
.ds-typo-card-tag--serif   { color: var(--color-accent);  border-color: color-mix(in srgb, var(--color-accent) 40%, transparent); }
.ds-typo-card-tag--slab    { color: var(--color-text-soft); border-color: color-mix(in srgb, var(--color-text-soft) 50%, transparent); }
.ds-typo-card-tag--sans    { color: var(--color-info);    border-color: color-mix(in srgb, var(--color-info) 50%, transparent); }
.ds-typo-card-tag--display { color: var(--color-warning); border-color: color-mix(in srgb, var(--color-warning) 40%, transparent); }
.ds-typo-card-tag--mono    { color: var(--color-success); border-color: color-mix(in srgb, var(--color-success) 40%, transparent); }

/* Badges des rôles assignés (D / B / M) */
.ds-typo-card-badges {
  display: flex;
  gap: 4px;
}

.ds-typo-card-badge {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--color-accent);
  color: #fff;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
[data-theme="dark"] .ds-typo-card-badge {
  color: var(--color-bg);
}

/* Échantillon principal */
.ds-typo-card-sample {
  line-height: 1.15;
  color: var(--color-text);
  word-break: break-word;
  /* Évite les sauts pendant le chargement des polices */
  font-synthesis: none;
  font-feature-settings: "kern";
  -webkit-font-feature-settings: "kern";
  padding: var(--space-sm) 0;
}

/* Variantes : une rangée par graisse */
.ds-typo-card-variants {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--space-sm) 0;
  border-top: 1px solid var(--color-border);
}

.ds-typo-card-variant {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--space-md);
  align-items: baseline;
  font-size: var(--text-md);
  color: var(--color-text-soft);
}

.ds-typo-card-variant-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  text-transform: lowercase;
  letter-spacing: 0.04em;
}

.ds-typo-card-variant-sample {
  word-break: break-word;
}

/* Rangée des 3 boutons de rôle */
.ds-typo-card-roles {
  display: flex;
  gap: var(--space-xs);
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-border);
}

.ds-typo-card-role-btn {
  flex: 1;
  padding: 6px var(--space-sm);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-text-soft);
  cursor: pointer;
  transition: all var(--t-fast);
}
.ds-typo-card-role-btn:hover:not(.is-disabled):not(.is-on) {
  border-color: var(--color-accent);
  color: var(--color-accent);
}
.ds-typo-card-role-btn.is-on {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
  font-weight: 600;
}
[data-theme="dark"] .ds-typo-card-role-btn.is-on {
  color: var(--color-bg);
}
.ds-typo-card-role-btn.is-disabled {
  opacity: 0.3;
  cursor: not-allowed;
}


/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 600px) {
  .ds-typo-recap-roles {
    grid-template-columns: 1fr;
  }
  .ds-typo-chooser-grid {
    grid-template-columns: 1fr;
  }
  .ds-typo-recap {
    /* Sticky retiré en mobile : trop d'espace utilisé */
    position: static;
  }
}


/* ============================================================
   ZONE 3 — CONVENTIONS (refonte v3.1, compact)
   ============================================================ */

.ds-typo-conventions-intro {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  margin: 0 0 var(--space-lg) 0;
  max-width: 60ch;
}

/* Rangées compactes : label / segmented / hint */
.ds-typo-conv-rows {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.ds-typo-conv-row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.ds-typo-conv-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-soft);
  /* Largeur fixe pour aligner les segmented entre eux verticalement */
  min-width: 110px;
}

.ds-typo-conv-hint {
  font-size: var(--text-xs);
  color: var(--color-text-faint);
  flex: 1 1 auto;
}

/* Toggle compact (case à cocher Insécables) */
.ds-typo-conv-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  cursor: pointer;
  /* Aligne visuellement avec un segmented-control compact */
  padding: 4px var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
}
.ds-typo-conv-toggle input[type="checkbox"] {
  margin: 0;
}

/* Variante compacte du segmented-control natif du nuancier.
   N'élargit pas pour remplir la largeur disponible : reste à sa
   taille naturelle, alignée à gauche. Pour la coloration accent,
   utiliser en plus la classe --accent. */
.segmented-control--compact {
  display: inline-flex !important;
  width: auto !important;
  flex: 0 0 auto !important;
}
.segmented-control--compact label {
  padding: 4px var(--space-md) !important;
  font-size: var(--text-sm) !important;
}

/* Variante "accent" du segmented-control : applique la couleur accent
   Nogegon (brique #b8412a) sur le hover et l'état sélectionné.
   Indépendante de --compact (peut être combinée OU utilisée seule
   sur un segmented control pleine largeur). */
.segmented-control--accent label {
  transition: color var(--t-fast), background-color var(--t-fast), border-color var(--t-fast) !important;
}

/* Hover : bordure et fond avec un soupçon d'accent (8% d'opacité).
   Ne s'applique pas au label déjà sélectionné, sinon on perd l'état actif. */
.segmented-control--accent label:hover {
  color: var(--color-accent) !important;
  background: color-mix(in srgb, var(--color-accent) 8%, transparent) !important;
}
.segmented-control--accent input:checked + label:hover {
  color: #fff !important;  /* override pour ne pas reperdre le fond accent */
}

/* État sélectionné : fond accent plein, texte sur fond contrasté.
   Le sélecteur cible le label adjacent à un input:checked (mécanique
   standard du segmented-control HTML/CSS pur). */
.segmented-control--accent input:checked + label {
  background: var(--color-accent) !important;
  color: #fff !important;
  border-color: var(--color-accent) !important;
  font-weight: 500 !important;
}

/* En mode sombre, l'accent est plus violet/mauve (#726791) — moins
   contrasté que la brique. On garde la même logique mais on s'assure
   que le texte blanc reste lisible. */
[data-theme="dark"] .segmented-control--accent input:checked + label {
  background: var(--color-accent) !important;
  color: var(--color-bg) !important;
  border-color: var(--color-accent) !important;
}

/* Toggle "Insécables" : même traitement que le segmented quand coché.
   On utilise :has() pour réagir à la case interne. Fallback gracieux
   pour les navigateurs sans :has() (Safari < 15.4) : la case reste
   en bordure neutre, c'est OK. */
.ds-typo-conv-toggle:has(input:checked) {
  background: var(--color-accent);
  color: #fff;
  border-color: var(--color-accent);
}
.ds-typo-conv-toggle:has(input:checked) input[type="checkbox"] {
  /* Inverser le contraste de la case pour qu'elle reste visible sur fond accent */
  accent-color: #fff;
}
[data-theme="dark"] .ds-typo-conv-toggle:has(input:checked) {
  color: var(--color-bg);
}
.ds-typo-conv-toggle:hover {
  border-color: var(--color-accent);
}


/* ============================================================
   ZONE 4 — MISE EN CONTEXTE
   ============================================================
   Préfixe .dsx-* pour les éléments scopés à cette zone uniquement.
   Variables CSS scopées sur .ds-typo-context (injectées par le JS) :
     --dsx-display, --dsx-body, --dsx-mono
     --dsx-size-{xs..4xl}, --dsx-lh-{...}, --dsx-tracking-{...}
     --dsx-heading-transform, --dsx-heading-extra-tracking
   ============================================================ */

.ds-typo-context-intro {
  font-size: var(--text-sm);
  color: var(--color-text-soft);
  margin: 0 0 var(--space-lg) 0;
  max-width: 60ch;
}

/* "Page" reconstituée : conteneur visuellement distinct, à fond doux */
.ds-typo-context-page {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
  /* Tous les enfants héritent de la body par défaut */
  font-family: var(--dsx-body);
  color: var(--color-text);
}

/* ----- Site header ----- */
.dsx-site-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-md);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--color-border);
  flex-wrap: wrap;
}
.dsx-site-brand {
  font-family: var(--dsx-display);
  font-size: var(--dsx-size-lg);
  line-height: var(--dsx-lh-lg);
  letter-spacing: var(--dsx-tracking-lg);
  font-weight: 700;
}
.dsx-site-tagline {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-sm);
  line-height: var(--dsx-lh-sm);
  color: var(--color-text-soft);
}

/* ----- Hero ----- */
.dsx-hero {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  padding: var(--space-lg) 0;
}
.dsx-eyebrow {
  font-family: var(--dsx-mono);
  font-size: var(--dsx-size-xs);
  line-height: var(--dsx-lh-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-faint);
}
.dsx-h1 {
  font-family: var(--dsx-display);
  font-size: var(--dsx-size-4xl);
  line-height: var(--dsx-lh-4xl);
  letter-spacing: calc(var(--dsx-tracking-4xl) + var(--dsx-heading-extra-tracking, 0em));
  text-transform: var(--dsx-heading-transform, none);
  font-weight: 700;
  margin: 0;
}
.dsx-lead {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-lg);
  line-height: var(--dsx-lh-lg);
  letter-spacing: var(--dsx-tracking-lg);
  color: var(--color-text);
  margin: 0;
  max-width: 60ch;
}

/* ----- Grille article + UI ----- */
.dsx-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-xl);
}

.dsx-article {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.dsx-h2 {
  font-family: var(--dsx-display);
  font-size: var(--dsx-size-3xl);
  line-height: var(--dsx-lh-3xl);
  letter-spacing: calc(var(--dsx-tracking-3xl) + var(--dsx-heading-extra-tracking, 0em));
  text-transform: var(--dsx-heading-transform, none);
  font-weight: 700;
  margin: 0;
}
.dsx-h3 {
  font-family: var(--dsx-display);
  font-size: var(--dsx-size-xl);
  line-height: var(--dsx-lh-xl);
  letter-spacing: calc(var(--dsx-tracking-xl) + var(--dsx-heading-extra-tracking, 0em));
  text-transform: var(--dsx-heading-transform, none);
  font-weight: 600;
  margin: var(--space-md) 0 0 0;
}
.dsx-lead-sm {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-lg);
  line-height: var(--dsx-lh-lg);
  letter-spacing: var(--dsx-tracking-lg);
  color: var(--color-text-soft);
  margin: 0;
  font-style: italic;
}
.dsx-body {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-base);
  line-height: var(--dsx-lh-base);
  letter-spacing: var(--dsx-tracking-base);
  margin: 0;
}
.dsx-caption {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-xs);
  line-height: var(--dsx-lh-xs);
  letter-spacing: var(--dsx-tracking-xs);
  color: var(--color-text-faint);
  margin: 0;
  padding-top: var(--space-sm);
  border-top: 1px solid var(--color-border);
}
.dsx-link {
  color: var(--color-accent, var(--color-info));
  text-decoration: underline;
  text-underline-offset: 0.15em;
  text-decoration-thickness: 0.08em;
}

/* ----- Aside (colonne droite) ----- */
.dsx-aside {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

/* Stat tabulaire : exerce la mono pour les chiffres */
.dsx-stat {
  padding: var(--space-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}
.dsx-stat-value {
  font-family: var(--dsx-mono);
  font-size: var(--dsx-size-3xl);
  line-height: var(--dsx-lh-3xl);
  letter-spacing: var(--dsx-tracking-3xl);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}
.dsx-stat-label {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-xs);
  line-height: var(--dsx-lh-xs);
  letter-spacing: var(--dsx-tracking-xs);
  color: var(--color-text-soft);
  margin-top: 4px;
}
.dsx-stat-delta {
  font-family: var(--dsx-mono);
  font-size: var(--dsx-size-sm);
  color: var(--color-success);
  font-variant-numeric: tabular-nums;
  margin-top: var(--space-sm);
}

/* Carte UI */
.dsx-card {
  padding: var(--space-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.dsx-card-title {
  font-family: var(--dsx-display);
  font-size: var(--dsx-size-lg);
  line-height: var(--dsx-lh-lg);
  letter-spacing: calc(var(--dsx-tracking-lg) + var(--dsx-heading-extra-tracking, 0em));
  text-transform: var(--dsx-heading-transform, none);
  font-weight: 600;
  margin: 0;
}
.dsx-card-body {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-sm);
  line-height: var(--dsx-lh-sm);
  letter-spacing: var(--dsx-tracking-sm);
  color: var(--color-text-soft);
  margin: 0;
}
.dsx-card-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-sm);
  padding-top: var(--space-sm);
}

/* Boutons */
.dsx-btn-primary,
.dsx-btn-primary-sm {
  font-family: var(--dsx-body);
  font-weight: 500;
  background: var(--color-text);
  color: var(--color-bg);
  border: 1px solid var(--color-text);
  border-radius: var(--radius-sm);
  cursor: pointer;
}
.dsx-btn-primary {
  font-size: var(--dsx-size-sm);
  padding: var(--space-sm) var(--space-lg);
  /* Affirme sa présence sur le hero */
  align-self: flex-start;
  margin-top: var(--space-sm);
}
.dsx-btn-primary-sm {
  font-size: var(--dsx-size-xs);
  padding: 4px var(--space-md);
}
.dsx-btn-ghost {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-xs);
  font-weight: 500;
  padding: 4px var(--space-md);
  background: transparent;
  color: var(--color-text-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
}

/* Champ de formulaire avec valeur mono */
.dsx-form-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.dsx-form-label {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-xs);
  line-height: var(--dsx-lh-xs);
  letter-spacing: var(--dsx-tracking-xs);
  color: var(--color-text-soft);
}
.dsx-form-input {
  font-family: var(--dsx-mono);
  font-size: var(--dsx-size-sm);
  padding: var(--space-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text);
}
.dsx-form-hint {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-xs);
  color: var(--color-text-faint);
}

/* ----- Footer ----- */
.dsx-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
  flex-wrap: wrap;
}
.dsx-footer-colophon,
.dsx-footer-legal {
  font-family: var(--dsx-body);
  font-size: var(--dsx-size-xs);
  line-height: var(--dsx-lh-xs);
  color: var(--color-text-faint);
}
.dsx-footer-colophon {
  font-style: italic;
}

/* ----- Responsive ----- */
@media (max-width: 800px) {
  .dsx-grid {
    grid-template-columns: 1fr;
  }
  .ds-typo-conv-label {
    /* Sur petit écran, label sur sa propre ligne */
    min-width: 100%;
  }
}


/* ============================================================
   BARRE D'ACTIONS DE L'ONGLET (en haut, hors des 4 zones)
   ============================================================ */

.ds-typo-actions {
  display: flex;
  justify-content: flex-end;
  margin-bottom: var(--space-md);
}

.ds-typo-rules-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-text-soft);
  cursor: pointer;
  transition: all var(--t-fast);
}
.ds-typo-rules-btn:hover {
  border-color: var(--color-border-strong);
  color: var(--color-text);
}
.ds-typo-rules-btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--color-text-faint);
  color: var(--color-bg);
  font-size: 11px;
  font-weight: 700;
  font-family: var(--font-body);
}


/* ============================================================
   MODALE "REPÈRES TYPOGRAPHIQUES"
   ============================================================ */

.ds-typo-rules-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
}

.ds-typo-rules-modal[hidden] {
  display: none;
}

.ds-typo-rules-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  /* Click pour fermer (le data-rules-close est sur cet élément) */
}

.ds-typo-rules-dialog {
  position: relative;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  max-width: 760px;
  width: 100%;
  max-height: calc(100vh - var(--space-xl) * 2);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  /* Ombre douce pour décoller du backdrop */
  box-shadow: 0 24px 48px -12px rgba(0, 0, 0, 0.3);
}

/* Header sticky en haut de la modale */
.ds-typo-rules-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg);
  flex-shrink: 0;
}

.ds-typo-rules-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--color-text);
}

.ds-typo-rules-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-text-soft);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  transition: all var(--t-fast);
}
.ds-typo-rules-close:hover {
  border-color: var(--color-border-strong);
  color: var(--color-text);
}

/* Corps scrollable */
.ds-typo-rules-body {
  padding: var(--space-lg) var(--space-xl);
  overflow-y: auto;
  flex: 1 1 auto;
  color: var(--color-text);
  line-height: 1.6;
}

.ds-typo-rules-lede {
  font-size: var(--text-md);
  color: var(--color-text-soft);
  margin: 0 0 var(--space-xl) 0;
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--color-border);
}

.ds-typo-rules-section {
  margin-bottom: var(--space-xl);
}
.ds-typo-rules-section:last-child {
  margin-bottom: 0;
}

.ds-typo-rules-h3 {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 var(--space-md) 0;
  color: var(--color-text);
}

.ds-typo-rules-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-text);
  color: var(--color-bg);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: 600;
  flex-shrink: 0;
}

.ds-typo-rules-h4 {
  margin: var(--space-md) 0 4px 0;
  font-weight: 600;
  font-size: var(--text-md);
}

.ds-typo-rules-example {
  font-size: 1.8em;
  letter-spacing: -0.01em;
}

.ds-typo-rules-body p {
  margin: 0 0 var(--space-sm) 0;
  font-size: var(--text-sm);
  color: var(--color-text);
}

.ds-typo-rules-list {
  margin: 0 0 var(--space-md) 0;
  padding-left: var(--space-lg);
}
.ds-typo-rules-list li {
  margin-bottom: 6px;
  font-size: var(--text-sm);
  color: var(--color-text);
}

.ds-typo-rules-body code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  padding: 1px 6px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 3px;
  color: var(--color-text);
}

/* Associations recommandées (section 5) */
.ds-typo-rules-pairings {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin: var(--space-md) 0;
}

.ds-typo-rules-pairing {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}

.ds-typo-rules-pair-name {
  font-size: var(--text-md);
  color: var(--color-text);
}

.ds-typo-rules-pair-sep {
  color: var(--color-text-faint);
  font-family: var(--font-mono);
}

/* Responsive : modale prend toute la place sur petit écran */
@media (max-width: 700px) {
  .ds-typo-rules-modal {
    padding: 0;
  }
  .ds-typo-rules-dialog {
    max-height: 100vh;
    border-radius: 0;
    border: none;
  }
  .ds-typo-rules-body {
    padding: var(--space-md);
  }
}
