/* ============================================================
   GRAPHIC OUEST — COMPONENTS (Phase A)
   ----------------------------------------------------------
   Composants UI partagés site public / outils admin / dashboard.
   Toutes les classes sont préfixées « go- » pour ne jamais
   entrer en conflit avec WooCommerce, le thème existant ou
   d'autres plugins.

   Dépend de : design-tokens.css

   ⚠️ Ce fichier N'EST PAS chargé sur le site live.
   ============================================================ */

/* ============================================================
   BASE / RESET MINIMAL (préfixé via .go-scope)
   À appliquer à un conteneur parent <div class="go-scope">…</div>
   pour ne pas affecter le reste du site.
   ============================================================ */
.go-scope,
.go-scope * {
  box-sizing: border-box;
}
.go-scope {
  font-family: var(--go-font-sans);
  font-size: var(--go-text-base);
  line-height: var(--go-leading-relaxed);
  color: var(--go-color-text);
}

/* ============================================================
   TYPOGRAPHIE UTILITAIRE
   ============================================================ */
.go-h1 { font-size: var(--go-text-4xl); line-height: var(--go-leading-tight); font-weight: var(--go-weight-bold); color: var(--go-color-primary); margin: 0 0 var(--go-space-lg); }
.go-h2 { font-size: var(--go-text-3xl); line-height: var(--go-leading-tight); font-weight: var(--go-weight-bold); color: var(--go-color-primary); margin: 0 0 var(--go-space-md); }
.go-h3 { font-size: var(--go-text-2xl); line-height: var(--go-leading-tight); font-weight: var(--go-weight-semibold); color: var(--go-color-primary); margin: 0 0 var(--go-space-md); }
.go-h4 { font-size: var(--go-text-xl);  line-height: var(--go-leading-tight); font-weight: var(--go-weight-semibold); color: var(--go-color-primary); margin: 0 0 var(--go-space-sm); }
.go-lead { font-size: var(--go-text-lg); line-height: var(--go-leading-relaxed); color: var(--go-color-gray); margin: 0 0 var(--go-space-lg); }
.go-small { font-size: var(--go-text-sm); color: var(--go-color-gray); }
.go-mono { font-family: var(--go-font-mono); }

/* ============================================================
   CONTAINER & SECTION
   ============================================================ */
.go-container        { max-width: var(--go-container);        margin-inline: auto; padding-inline: var(--go-space-md); }
.go-container--narrow{ max-width: var(--go-container-narrow); margin-inline: auto; padding-inline: var(--go-space-md); }
.go-container--wide  { max-width: var(--go-container-wide);   margin-inline: auto; padding-inline: var(--go-space-md); }

.go-section {
  padding-block: var(--go-space-3xl);
}
.go-section--soft { background: var(--go-color-bg-soft); }
.go-section--tight { padding-block: var(--go-space-2xl); }

@media (max-width: 768px) {
  .go-section { padding-block: var(--go-space-2xl); }
}

/* ============================================================
   BOUTONS
   ============================================================ */
.go-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--go-space-sm);
  min-height: 44px;            /* cible tactile mobile */
  padding: 12px 24px;
  font-family: var(--go-font-sans);
  font-size: var(--go-text-base);
  font-weight: var(--go-weight-semibold);
  line-height: 1.2;
  border: 2px solid transparent;
  border-radius: var(--go-radius-md);
  cursor: pointer;
  text-decoration: none;
  transition: background var(--go-duration-fast) var(--go-ease-out),
              color      var(--go-duration-fast) var(--go-ease-out),
              border-color var(--go-duration-fast) var(--go-ease-out),
              box-shadow var(--go-duration-fast) var(--go-ease-out);
}
.go-btn:focus-visible { outline: none; box-shadow: var(--go-shadow-focus); }
.go-btn[disabled],
.go-btn.is-disabled {
  background: var(--go-color-gray-medium);
  color: var(--go-color-white);
  border-color: transparent;
  cursor: not-allowed;
  opacity: 0.7;
}

/* Bouton primaire — bleu marine plein + texte blanc — action principale
   (DS-003B 2026-06-21 : passé en bleu marine plein suite à décision Samy
   "l'orange est réservé aux accents ponctuels, pas aux fonds aplatis".
   Contraste WCAG : blanc sur #13235B = 14.80:1 ✅ AAA — texte normal et large.
   Hover : bleu primaire dark #0A1640 ≈ 17:1 ✅ AAA.) */
.go-btn-primary {
  background: var(--go-color-primary);
  color: var(--go-color-white);
}
.go-btn-primary:hover,
.go-btn-primary:focus-visible {
  background: var(--go-color-primary-dark);
  color: var(--go-color-white);
}

/* Bouton secondaire — fond gris très clair + texte bleu marine + bordure discrète
   (DS-003C 2026-06-21 : ancien style "outline bleu" remplacé pour éviter
   deux boutons "bleu visuel fort" côte à côte avec le primaire bleu plein.
   Contraste WCAG : #13235B sur #F2F2F3 = 13.23:1 ✅ AAA) */
.go-btn-secondary {
  background: var(--go-color-bg-muted);
  color: var(--go-color-primary);
  border-color: var(--go-color-gray-light);
}
.go-btn-secondary:hover,
.go-btn-secondary:focus-visible {
  background: var(--go-color-gray-light);
  color: var(--go-color-primary);
  border-color: var(--go-color-primary);
}

/* Bouton tertiaire — type lien texte bleu, sans gros bouton
   (DS-003C 2026-06-21 : pour actions ponctuelles non prioritaires
   — "Voir conseils", "En savoir plus", "Annuler" hors action critique.
   Padding et poids allégés ; min-height conservé pour cible tactile.) */
.go-btn-tertiary {
  background: transparent;
  color: var(--go-color-primary);
  border-color: transparent;
  padding: 10px 12px;
  font-weight: var(--go-weight-medium);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.go-btn-tertiary:hover,
.go-btn-tertiary:focus-visible {
  color: var(--go-color-primary-dark);
  background: var(--go-color-bg-soft);
  text-decoration: underline;
}

/* Bouton danger — rouge — action irréversible (toujours avec confirmation 2 clics) */
.go-btn-danger {
  background: var(--go-color-danger);
  color: var(--go-color-white);
}
.go-btn-danger:hover,
.go-btn-danger:focus-visible {
  background: #A11F1F;
  color: var(--go-color-white);
}

/* Taille petite (compacte, outils admin) */
.go-btn--sm { min-height: 36px; padding: 8px 16px; font-size: var(--go-text-sm); }

/* ============================================================
   CARDS
   ============================================================ */
.go-card {
  background: var(--go-color-white);
  border: 1px solid var(--go-color-gray-light);
  border-radius: var(--go-radius-lg);
  padding: var(--go-space-lg);
}
.go-card--soft { background: var(--go-color-bg-muted); border-color: transparent; }
.go-card--accent { border-left: 4px solid var(--go-color-secondary); }
.go-card__title { font-size: var(--go-text-xl); font-weight: var(--go-weight-semibold); color: var(--go-color-primary); margin: 0 0 var(--go-space-sm); }
.go-card__body  { color: var(--go-color-text); }
.go-card__footer { margin-top: var(--go-space-md); padding-top: var(--go-space-md); border-top: 1px solid var(--go-color-gray-light); }

/* Grille cards */
.go-cards-grid {
  display: grid;
  gap: var(--go-space-lg);
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

/* ============================================================
   ALERTS / BANDEAUX DE STATUT (4 niveaux)
   ============================================================ */
.go-alert {
  display: flex;
  align-items: flex-start;
  gap: var(--go-space-md);
  padding: var(--go-space-md) var(--go-space-lg);
  border-left: 4px solid transparent;
  border-radius: var(--go-radius-md);
  font-size: var(--go-text-base);
  line-height: var(--go-leading-normal);
}
.go-alert__icon { flex-shrink: 0; width: 20px; height: 20px; margin-top: 2px; }
.go-alert__body { flex: 1; }
.go-alert__title { font-weight: var(--go-weight-semibold); margin: 0 0 4px; }
.go-alert__text  { margin: 0; }

.go-alert-success { background: var(--go-color-success-bg); color: var(--go-color-success-text); border-left-color: var(--go-color-success); }
.go-alert-info    { background: var(--go-color-info-bg);    color: var(--go-color-info-text);    border-left-color: var(--go-color-info); }
.go-alert-warning { background: var(--go-color-warning-bg); color: var(--go-color-warning-text); border-left-color: var(--go-color-warning); }
.go-alert-error   { background: var(--go-color-danger-bg);  color: var(--go-color-danger-text);  border-left-color: var(--go-color-danger); }

/* ============================================================
   FORMULAIRES
   ============================================================ */
.go-form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: var(--go-space-md);
}
.go-label {
  font-size: var(--go-text-sm);
  font-weight: var(--go-weight-semibold);
  color: var(--go-color-primary);
}
.go-label__optional { color: var(--go-color-gray); font-weight: var(--go-weight-regular); }
.go-input,
.go-textarea,
.go-select {
  width: 100%;
  padding: 12px 14px;
  font-family: var(--go-font-sans);
  font-size: var(--go-text-base);          /* 16px = pas de zoom auto iOS */
  line-height: var(--go-leading-normal);
  color: var(--go-color-text);
  background: var(--go-color-white);
  border: 1px solid var(--go-color-gray-light);
  border-radius: var(--go-radius-md);
  transition: border-color var(--go-duration-fast), box-shadow var(--go-duration-fast);
}
.go-input:focus,
.go-textarea:focus,
.go-select:focus {
  outline: none;
  border-color: var(--go-color-primary);
  box-shadow: var(--go-shadow-focus);
}
.go-input::placeholder,
.go-textarea::placeholder { color: var(--go-color-gray-medium); }
.go-textarea { min-height: 120px; resize: vertical; }

.go-help {
  font-size: var(--go-text-sm);
  color: var(--go-color-gray);
}
.go-form-field.is-error .go-input,
.go-form-field.is-error .go-textarea,
.go-form-field.is-error .go-select {
  border-color: var(--go-color-danger);
}
.go-form-field.is-error .go-help { color: var(--go-color-danger); }

/* ============================================================
   STATUS PILLS
   ============================================================ */
.go-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  font-size: var(--go-text-xs);
  font-weight: var(--go-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-radius: var(--go-radius-pill);
}
.go-status--success { background: var(--go-color-success-bg); color: var(--go-color-success-text); }
.go-status--info    { background: var(--go-color-info-bg);    color: var(--go-color-info-text); }
.go-status--warning { background: var(--go-color-warning-bg); color: var(--go-color-warning-text); }
.go-status--error   { background: var(--go-color-danger-bg);  color: var(--go-color-danger-text); }
.go-status--neutral { background: var(--go-color-bg-muted);   color: var(--go-color-gray); }

/* ============================================================
   PANNEAU ADMIN
   ============================================================ */
.go-admin-panel {
  background: var(--go-color-white);
  border: 1px solid var(--go-color-gray-light);
  border-top: 4px solid var(--go-color-primary);
  border-radius: var(--go-radius-md);
  padding: var(--go-space-lg);
}
.go-admin-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--go-space-md);
  margin-bottom: var(--go-space-md);
  padding-bottom: var(--go-space-md);
  border-bottom: 1px solid var(--go-color-gray-light);
}
.go-admin-panel__title {
  font-size: var(--go-text-lg);
  font-weight: var(--go-weight-semibold);
  color: var(--go-color-primary);
  margin: 0;
}
.go-admin-panel__meta {
  font-size: var(--go-text-sm);
  color: var(--go-color-gray);
  font-family: var(--go-font-mono);
}

/* ============================================================
   DASHBOARD CARD (KPI tableau de bord GO Pilotage)
   ============================================================ */
.go-dashboard-card {
  background: var(--go-color-white);
  border: 1px solid var(--go-color-gray-light);
  border-radius: var(--go-radius-lg);
  padding: var(--go-space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--go-space-xs);
}
.go-dashboard-card__label {
  font-size: var(--go-text-sm);
  font-weight: var(--go-weight-medium);
  color: var(--go-color-gray);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.go-dashboard-card__value {
  font-size: var(--go-text-3xl);
  font-weight: var(--go-weight-bold);
  color: var(--go-color-primary);
  font-family: var(--go-font-sans);
  line-height: 1;
}
.go-dashboard-card__delta {
  font-size: var(--go-text-sm);
  color: var(--go-color-gray);
}
.go-dashboard-card__delta--up   { color: var(--go-color-success-text); }
.go-dashboard-card__delta--down { color: var(--go-color-danger-text); }

/* ============================================================
   HERO (site public)
   ============================================================ */
.go-hero {
  background: var(--go-color-white);
  padding-block: var(--go-space-3xl);
  border-bottom: 1px solid var(--go-color-gray-light);
}
.go-hero__eyebrow {
  display: inline-block;
  padding: 6px 12px;
  background: var(--go-color-primary-soft);
  color: var(--go-color-primary);
  font-size: var(--go-text-xs);
  font-weight: var(--go-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-radius: var(--go-radius-pill);
  margin-bottom: var(--go-space-md);
}
.go-hero__title {
  font-size: clamp(28px, 4vw, var(--go-text-4xl));
  font-weight: var(--go-weight-bold);
  color: var(--go-color-primary);
  line-height: var(--go-leading-tight);
  margin: 0 0 var(--go-space-md);
  max-width: 24ch;
}
.go-hero__subtitle {
  font-size: var(--go-text-lg);
  color: var(--go-color-gray);
  line-height: var(--go-leading-relaxed);
  margin: 0 0 var(--go-space-lg);
  max-width: 60ch;
}
.go-hero__actions {
  display: flex;
  gap: var(--go-space-md);
  flex-wrap: wrap;
  margin-bottom: var(--go-space-md);
}
.go-hero__reassurance {
  font-size: var(--go-text-sm);
  color: var(--go-color-gray);
}

/* ============================================================
   UTILITAIRES BAS NIVEAU
   ============================================================ */
.go-stack > * + * { margin-top: var(--go-space-md); }
.go-stack--lg > * + * { margin-top: var(--go-space-lg); }
.go-row {
  display: flex;
  gap: var(--go-space-md);
  flex-wrap: wrap;
  align-items: center;
}
.go-divider {
  height: 1px;
  background: var(--go-color-gray-light);
  border: none;
  margin-block: var(--go-space-lg);
}
.go-sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* ============================================================
   ============================================================
   DS-002 — EXTENSION COMPOSANTS (2026-06-21)
   Composants additionnels pour Home V1, page fichiers, tunnel
   devis, outil tarif v2, prévisualisateur, GO Pilotage.
   Toutes les classes restent préfixées .go-* et utilisent les
   variables --go-* existantes (aucun nouveau token ajouté).
   ============================================================
   ============================================================ */

/* ============================================================
   1. NAVIGATION simple (header public + admin)
   ============================================================ */
.go-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--go-space-lg);
  padding: var(--go-space-md) var(--go-space-lg);
  background: var(--go-color-white);
  border-bottom: 1px solid var(--go-color-gray-light);
}
.go-nav--admin {
  background: var(--go-color-primary);
  border-bottom-color: var(--go-color-secondary);
  border-bottom-width: 3px;
  color: var(--go-color-white);
}
.go-nav__brand {
  font-weight: var(--go-weight-bold);
  font-size: var(--go-text-lg);
  color: var(--go-color-primary);
  text-decoration: none;
}
.go-nav--admin .go-nav__brand { color: var(--go-color-white); }
.go-nav__list {
  display: flex;
  align-items: center;
  gap: var(--go-space-lg);
  list-style: none;
  margin: 0; padding: 0;
}
.go-nav__link {
  color: var(--go-color-text);
  text-decoration: none;
  font-weight: var(--go-weight-medium);
  padding: var(--go-space-sm) 0;
  border-bottom: 2px solid transparent;
  transition: color var(--go-duration-fast), border-color var(--go-duration-fast);
}
.go-nav__link:hover,
.go-nav__link:focus-visible {
  color: var(--go-color-primary);
  border-bottom-color: var(--go-color-secondary);
}
.go-nav--admin .go-nav__link { color: var(--go-color-white); }
.go-nav--admin .go-nav__link:hover,
.go-nav--admin .go-nav__link:focus-visible { color: var(--go-color-secondary); border-bottom-color: var(--go-color-secondary); }
.go-nav__actions { display: flex; gap: var(--go-space-sm); }

/* ============================================================
   2. STEPPER (tunnel devis, configurateur multi-étapes)
   ============================================================ */
.go-stepper {
  display: flex;
  align-items: center;
  gap: var(--go-space-md);
  list-style: none;
  margin: 0 0 var(--go-space-lg);
  padding: 0;
  flex-wrap: wrap;
}
.go-stepper__item {
  display: flex;
  align-items: center;
  gap: var(--go-space-sm);
  color: var(--go-color-gray);
  font-size: var(--go-text-sm);
  font-weight: var(--go-weight-medium);
}
.go-stepper__item + .go-stepper__item::before {
  content: "";
  width: 24px; height: 2px;
  background: var(--go-color-gray-light);
  margin-right: var(--go-space-sm);
}
.go-stepper__index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: var(--go-radius-pill);
  background: var(--go-color-bg-muted);
  color: var(--go-color-gray);
  font-weight: var(--go-weight-semibold);
  font-size: var(--go-text-sm);
}
.go-stepper__item--current .go-stepper__index { background: var(--go-color-primary); color: var(--go-color-white); }
.go-stepper__item--current { color: var(--go-color-primary); font-weight: var(--go-weight-semibold); }
.go-stepper__item--done .go-stepper__index { background: var(--go-color-success); color: var(--go-color-white); }
.go-stepper__item--done { color: var(--go-color-success-text); }
.go-stepper__item--done .go-stepper__index::before { content: "\2713"; } /* unicode checkmark, sobre */

/* ============================================================
   3. CONFIRMATION 2 CLICS (action critique réversible)
   ============================================================ */
.go-confirm {
  background: var(--go-color-white);
  border: 2px solid var(--go-color-warning);
  border-radius: var(--go-radius-lg);
  padding: var(--go-space-lg);
  box-shadow: var(--go-shadow-md);
  max-width: 560px;
}
.go-confirm__title {
  font-size: var(--go-text-xl);
  font-weight: var(--go-weight-semibold);
  color: var(--go-color-primary);
  margin: 0 0 var(--go-space-sm);
}
.go-confirm__body {
  color: var(--go-color-text);
  margin: 0 0 var(--go-space-md);
}
.go-confirm__summary {
  background: var(--go-color-warning-bg);
  border-radius: var(--go-radius-md);
  padding: var(--go-space-md);
  font-family: var(--go-font-mono);
  font-size: var(--go-text-sm);
  color: var(--go-color-warning-text);
  margin: 0 0 var(--go-space-md);
}
.go-confirm__actions {
  display: flex;
  gap: var(--go-space-md);
  justify-content: flex-end;
  flex-wrap: wrap;
}

/* ============================================================
   4. MODAL sobre (dialog overlay)
   ============================================================ */
.go-modal {
  position: fixed;
  inset: 0;
  z-index: var(--go-z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--go-space-md);
}
.go-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(19, 35, 91, 0.55);
}
.go-modal__panel {
  position: relative;
  background: var(--go-color-white);
  border-radius: var(--go-radius-lg);
  box-shadow: var(--go-shadow-lg);
  max-width: 600px;
  width: 100%;
  max-height: 90vh;
  overflow: auto;
}
.go-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--go-space-md) var(--go-space-lg);
  border-bottom: 1px solid var(--go-color-gray-light);
}
.go-modal__title {
  font-size: var(--go-text-xl);
  font-weight: var(--go-weight-semibold);
  color: var(--go-color-primary);
  margin: 0;
}
.go-modal__close {
  background: transparent;
  border: none;
  font-size: var(--go-text-xl);
  color: var(--go-color-gray);
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
  border-radius: var(--go-radius-sm);
}
.go-modal__close:hover,
.go-modal__close:focus-visible { color: var(--go-color-primary); background: var(--go-color-bg-muted); outline: none; }
.go-modal__body { padding: var(--go-space-lg); }
.go-modal__footer {
  display: flex;
  justify-content: flex-end;
  gap: var(--go-space-md);
  padding: var(--go-space-md) var(--go-space-lg);
  border-top: 1px solid var(--go-color-gray-light);
  background: var(--go-color-bg-soft);
}

/* ============================================================
   5. TOAST / NOTIFICATION (4 niveaux, position fixed)
   ============================================================ */
.go-toast-stack {
  position: fixed;
  top: var(--go-space-lg);
  right: var(--go-space-lg);
  z-index: var(--go-z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--go-space-sm);
  max-width: 380px;
}
.go-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--go-space-sm);
  padding: var(--go-space-md);
  border-radius: var(--go-radius-md);
  background: var(--go-color-white);
  box-shadow: var(--go-shadow-md);
  border-left: 4px solid var(--go-color-info);
}
.go-toast--success { border-left-color: var(--go-color-success); }
.go-toast--info    { border-left-color: var(--go-color-info); }
.go-toast--warning { border-left-color: var(--go-color-warning); }
.go-toast--error   { border-left-color: var(--go-color-danger); }
.go-toast__title { font-weight: var(--go-weight-semibold); color: var(--go-color-primary); margin: 0 0 4px; font-size: var(--go-text-sm); }
.go-toast__msg   { margin: 0; font-size: var(--go-text-sm); color: var(--go-color-text); }

/* ============================================================
   6. LOADER discret (spinner sobre)
   ============================================================ */
.go-loader {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--go-color-gray-light);
  border-top-color: var(--go-color-primary);
  border-radius: 50%;
  animation: go-spin 800ms linear infinite;
}
.go-loader--lg { width: 32px; height: 32px; border-width: 3px; }
.go-loader--on-dark { border-color: rgba(255,255,255,0.3); border-top-color: var(--go-color-secondary); }
@keyframes go-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) {
  .go-loader { animation-duration: 2s; }
}

/* ============================================================
   7. TABS / ONGLETS
   ============================================================ */
.go-tabs__list {
  display: flex;
  border-bottom: 1px solid var(--go-color-gray-light);
  gap: var(--go-space-xs);
  margin: 0 0 var(--go-space-lg);
  padding: 0;
  list-style: none;
  flex-wrap: wrap;
}
.go-tabs__tab {
  background: transparent;
  border: none;
  padding: var(--go-space-sm) var(--go-space-md);
  font-family: var(--go-font-sans);
  font-size: var(--go-text-base);
  font-weight: var(--go-weight-semibold);
  color: var(--go-color-gray);
  cursor: pointer;
  border-bottom: 3px solid transparent;
  margin-bottom: -1px;
  transition: color var(--go-duration-fast), border-color var(--go-duration-fast);
}
.go-tabs__tab:hover { color: var(--go-color-primary); }
.go-tabs__tab:focus-visible { outline: none; box-shadow: var(--go-shadow-focus); border-radius: var(--go-radius-sm); }
.go-tabs__tab--active { color: var(--go-color-primary); border-bottom-color: var(--go-color-secondary); }
.go-tabs__panel { display: none; }
.go-tabs__panel--active { display: block; }

/* ============================================================
   8. TABLEAU simple (lecture admin / dashboard)
   ============================================================ */
.go-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--go-text-sm);
}
.go-table th,
.go-table td {
  padding: var(--go-space-sm) var(--go-space-md);
  text-align: left;
  border-bottom: 1px solid var(--go-color-gray-light);
}
.go-table thead th {
  background: var(--go-color-bg-muted);
  color: var(--go-color-primary);
  font-weight: var(--go-weight-semibold);
  font-size: var(--go-text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  position: sticky;
  top: 0;
  border-bottom: 2px solid var(--go-color-gray-light);
}
.go-table tbody tr:hover { background: var(--go-color-bg-soft); }
.go-table__cell--num {
  font-family: var(--go-font-mono);
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.go-table__cell--right { text-align: right; }

/* ============================================================
   9. DIFF / Bloc avant-après (changements tarif)
   ============================================================ */
.go-diff {
  border: 1px solid var(--go-color-gray-light);
  border-radius: var(--go-radius-md);
  overflow: hidden;
}
.go-diff__row {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: var(--go-space-md);
  padding: var(--go-space-sm) var(--go-space-md);
  align-items: center;
  border-bottom: 1px solid var(--go-color-gray-light);
}
.go-diff__row:last-child { border-bottom: none; }
.go-diff__label { color: var(--go-color-text); font-size: var(--go-text-sm); }
.go-diff__old, .go-diff__new {
  font-family: var(--go-font-mono);
  font-size: var(--go-text-sm);
  font-variant-numeric: tabular-nums;
  padding: 2px 8px;
  border-radius: var(--go-radius-sm);
}
.go-diff__old { background: var(--go-color-bg-muted); color: var(--go-color-gray); text-decoration: line-through; }
.go-diff__new { background: var(--go-color-success-bg); color: var(--go-color-success-text); }
.go-diff__delta { font-size: var(--go-text-xs); font-weight: var(--go-weight-semibold); padding: 2px 8px; border-radius: var(--go-radius-pill); }
.go-diff__delta--up   { background: var(--go-color-warning-bg); color: var(--go-color-warning-text); }
.go-diff__delta--down { background: var(--go-color-info-bg);    color: var(--go-color-info-text); }
.go-diff__delta--same { background: var(--go-color-bg-muted);   color: var(--go-color-gray); }

/* ============================================================
   10. ADMIN PANEL — extension (toolbar)
   ============================================================ */
.go-admin-panel__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--go-space-md);
  background: var(--go-color-bg-soft);
  padding: var(--go-space-sm) var(--go-space-md);
  margin: -1px -1px var(--go-space-md);
  border-radius: var(--go-radius-md) var(--go-radius-md) 0 0;
  border-bottom: 1px solid var(--go-color-gray-light);
  font-size: var(--go-text-sm);
}

/* ============================================================
   11. DASHBOARD ROW (grille de KPIs)
   ============================================================ */
.go-dashboard-row {
  display: grid;
  gap: var(--go-space-lg);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

/* ============================================================
   12. AIDE CLIENT / GLOSSAIRE (vocabulaire impression -> client)
   ============================================================ */
.go-glossary {
  display: grid;
  gap: var(--go-space-md);
}
.go-glossary__item {
  background: var(--go-color-bg-soft);
  border-left: 3px solid var(--go-color-primary);
  border-radius: var(--go-radius-sm);
  padding: var(--go-space-md);
}
.go-glossary__term {
  font-weight: var(--go-weight-semibold);
  color: var(--go-color-primary);
  margin: 0 0 4px;
}
.go-glossary__def {
  font-size: var(--go-text-sm);
  color: var(--go-color-text);
  margin: 0;
}
.go-tooltip {
  border-bottom: 1px dotted var(--go-color-primary);
  cursor: help;
  position: relative;
}

/* ============================================================
   13. UPLOAD fichier (dropzone)
   ============================================================ */
.go-upload {
  display: block;
}
.go-upload__dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--go-space-sm);
  padding: var(--go-space-xl);
  background: var(--go-color-bg-soft);
  border: 2px dashed var(--go-color-gray-light);
  border-radius: var(--go-radius-lg);
  color: var(--go-color-gray);
  text-align: center;
  cursor: pointer;
  transition: background var(--go-duration-fast), border-color var(--go-duration-fast);
}
.go-upload__dropzone:hover,
.go-upload__dropzone.is-dragover {
  background: var(--go-color-primary-soft);
  border-color: var(--go-color-primary);
  color: var(--go-color-primary);
}
.go-upload__title { font-weight: var(--go-weight-semibold); color: var(--go-color-primary); font-size: var(--go-text-base); margin: 0; }
.go-upload__hint  { font-size: var(--go-text-sm); color: var(--go-color-gray); margin: 0; }
.go-upload__formats { font-size: var(--go-text-xs); color: var(--go-color-gray); margin: var(--go-space-sm) 0 0; font-family: var(--go-font-mono); }
.go-upload__list { list-style: none; margin: var(--go-space-md) 0 0; padding: 0; }
.go-upload__file {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--go-space-md);
  padding: var(--go-space-sm) var(--go-space-md);
  background: var(--go-color-white);
  border: 1px solid var(--go-color-gray-light);
  border-radius: var(--go-radius-md);
  font-size: var(--go-text-sm);
  margin-bottom: var(--go-space-xs);
}

/* ============================================================
   14. RÉASSURANCE (3 engagements home : fichier vérifié, etc.)
   ============================================================ */
.go-trust {
  display: grid;
  gap: var(--go-space-lg);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.go-trust__item {
  background: var(--go-color-white);
  border: 1px solid var(--go-color-gray-light);
  border-radius: var(--go-radius-lg);
  padding: var(--go-space-lg);
  text-align: left;
}
.go-trust__pictogram {
  width: 36px;
  height: 36px;
  background: var(--go-color-primary-soft);
  color: var(--go-color-primary);
  border-radius: var(--go-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--go-space-sm);
}
.go-trust__pictogram svg { width: 20px; height: 20px; display: block; }
.go-trust__title { font-size: var(--go-text-lg); font-weight: var(--go-weight-semibold); color: var(--go-color-primary); margin: 0 0 4px; }
.go-trust__text  { font-size: var(--go-text-sm); color: var(--go-color-gray); margin: 0; line-height: var(--go-leading-relaxed); }

/* ============================================================
   15. ACTION CRITIQUE (encart d'alerte avant suppression /
       écrasement, plus visuellement marqué qu'un simple alert)
   ============================================================ */
.go-critical {
  background: var(--go-color-danger-bg);
  border: 2px solid var(--go-color-danger);
  border-radius: var(--go-radius-lg);
  padding: var(--go-space-lg);
}
.go-critical__title {
  display: flex;
  align-items: center;
  gap: var(--go-space-sm);
  font-size: var(--go-text-lg);
  font-weight: var(--go-weight-semibold);
  color: var(--go-color-danger-text);
  margin: 0 0 var(--go-space-sm);
}
.go-critical__body { color: var(--go-color-danger-text); margin: 0 0 var(--go-space-md); }
.go-critical__actions { display: flex; gap: var(--go-space-md); justify-content: flex-end; flex-wrap: wrap; }

