/* =====================================================================
   VARIABLES GLOBALES
   Utilisées sur toutes les pages via base.html
===================================================================== */

:root{
  /* --- Couleurs Option A : Bleu nuit / Ardoise / Or --- */
  --gen-title:#3D2B8F;          /* violet profond (titres) */
  --gen-blue:#F0EAFA;           /* violet très pâle (fonds alternés) */
  --gen-black:#0D1B4B;          /* bleu nuit profond (texte principal) */
  --gen-white:#FFFFFF;

  --gen-light:#F0F2F8;          /* ardoise clair (hover, lignes) */
  --gen-mid:#C8CEDF;            /* ardoise moyen (bordures légères) */
  --gen-dark:#4A5572;           /* ardoise texte secondaire */

  --border:1px solid #E5E2FF;

  --band:#0D0630;               /* quasi noir violet (bandeau) */
  --btn:#4F3FBF;                /* violet profond (boutons) */
  --btn-hover:#4335A8;          /* violet foncé au hover */
  --tab:#E9E6FF;                /* violet lumineux (onglets) */
  --tab-activ:#5E52C9;           /* violet très pale (onglets) */
  --tab-color:#4F3FBF;           /* bleu pâle (onglets) */
  --tab-hover:#4335A8;
  --tab-blue:#F0EAFA;           /* violet pâle (lignes paires tables) */
  --muted:#4A5572;              /* ardoise (textes courants) */
  --line:#D0D5E8;               /* filets */

  /* --- Accent Or --- */
  --gold:#E2BE6A;               /* or brillant (accents, filets décoratifs) */
  --gold-light:#F5EDD6;         /* or très pâle (fond accent) */

  --h:40px;
  --ok:#1a73e8;
  --ko:#D93025;

  /* --- Espacements (toutes pages) ---
     xs =  4px  → micro-espaces : items de liste, labels, icônes
     sm =  8px  → espaces internes légers : champs, flashes, gaps
     md = 16px  → marge standard : sections, padding cards, titres
     lg = 24px  → entre blocs majeurs : grilles, tabs, analyse
     xl = 32px  → séparations de sections : footer, origin, pricing
     xxl= 48px  → réservé aux grands espacements (non utilisé actuellement)
  */
  --space-xs:  .25rem;   /*  4px */
  --space-sm:  .5rem;    /*  8px */
  --space-ms:  .75rem;    /*  12px */
  --space-md:  1rem;     /* 16px */
  --space-lg:  1.5rem;   /* 24px */
  --space-xl:  2rem;     /* 32px */
  --space-xxl: 3rem;     /* 48px */
}

/* =====================================================================
   RESET & BASE
   Toutes les pages via base.html
   → margin/padding remis à 0 globalement, réappliqués via variables
===================================================================== */

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

body{
  font:16px/1.5 "Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:linear-gradient(135deg, #6FD3FF 0%, #6A3FCF 100%);background-attachment:fixed;
  color:var(--gen-black);
}

a{color:inherit}
img{max-width:100%;height:auto}

/* Enveloppe principale — toutes pages
   padding H = --space-md (16px) gauche/droite uniforme sur toutes les pages
   padding B = --space-sm (8px) bas uniquement
   background = --gen-white : marges L/R blanches, cards internes en --gen-blue
   min-height = 100vh pour que le fond blanc couvre toute la hauteur de page */
.page-wrapper{
  padding:0 var(--space-xl) var(--space-xl) var(--space-xl);
  background:transparent;
  min-height:100vh;
}

/* Centrage du contenu — toutes pages
   margin auto gauche/droite, pas de marge fixe */
.container{width:min(90vw,1000px);margin:0 auto;position:relative}

/* Card principale — index, price, origin, import, demonstration, login
   margin T/B = --space-md (16px) pour séparer du bandeau et du footer
   ⚠️ Exception login.html : .auth-card surcharge margin-top → --space-lg
   ⚠️ Exception payment.html : n'utilise pas .card, utilise .container-pay */
.card{
  background:var(--gen-white);
  border-radius:16px;
  padding:1.25rem 1.75rem;
  margin:var(--space-md) 0;
  border:var(--border);
  box-shadow:0 8px 40px rgba(0,0,0,.22);
}

.d-none{display:none}
.muted{color:var(--muted)}
.table-scroll{overflow-x:auto}

/* =====================================================================
   HEADER BANDEAU
   Toutes les pages via base.html
   → Marges négatives L/R = compensation exacte du padding de .page-wrapper
   → padding interne = --space-md pour aligner avec le contenu de la page
===================================================================== */

.header-band{
  background:var(--band);
  border-radius:0;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  /* Compensation du padding de .page-wrapper pour affichage bord à bord */
  margin-left:calc(-1 * var(--space-xl));
  margin-right:calc(-1 * var(--space-xl));
  padding:0;
}

.logo-wrap{display:flex;align-items:center;padding-left:0;justify-self:start}

.center-wrap{
  justify-self:center;
  display:flex;
  align-items:center;
  justify-content:center;
  width:min(900px,70vw);
}

.right-spacer{
  justify-self:end;
  display:flex;
  justify-content:flex-end;
  align-items:center;
  padding-right:var(--space-md);
}

/* Logo pleine hauteur, bandeau s'adapte */
.logo-img{max-height:none;width:auto;display:block;}

/* Navigation principale — base.html
   gap entre liens = 1.25rem (valeur fixe, non tokenisée car
   dépend de la densité des liens de navigation) */
.band-nav{display:flex;gap:1.25rem;flex-wrap:wrap;justify-content:center;width:100%}
.band-link{
  font-weight:600;
  text-decoration:none;
  color:rgba(255,255,255,.9);
  border-bottom:2px solid transparent;
  transition:border-color .2s, color .2s;
}
.band-link:hover{color:#fff;border-bottom-color:rgba(255,255,255,.6)}

/* Drapeaux de langue — base.html
   padding = valeurs fixes 2px/3px (micro-ajustements visuels uniquement) */
.lang-flags{display:flex;gap:10px;align-items:center}
.lang-flag{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  border-bottom:none;
  border-radius:6px;
  padding:2px;
}
.lang-flag img{display:block;border:0}
.lang-flag:not(.active){opacity:.55}
.lang-flag.active{opacity:1;background:var(--gen-white);border-radius:6px;padding:3px}

/* =====================================================================
   ACCROCHE PERMANENTE
   index.html uniquement — placée au-dessus des tabs, visible sur tous les onglets
   → margin-bottom + padding-bottom = --space-md (16px)
   → filet bas pour délimiter visuellement l'accroche des tabs
===================================================================== */

.page-intro{
  margin-bottom:0;
  padding-bottom:var(--space-md);
  border-bottom:var(--border);
}

/* Bloc intro encadré dans l'onglet Présentation — index.html
   Fond --gen-blue pour le distinguer des blocs thématiques qui suivent
   margin-bottom = --space-lg (24px) pour marquer la rupture avec le premier bloc */
.tab-intro{
  background:var(--gen-blue);
  border:none;
  margin-bottom:var(--space-lg);
}
.tab-intro .section-text + .section-text{
  margin-top:var(--space-sm);
}

/* =====================================================================
   TABS
   Utilisé uniquement sur : index.html (7 onglets)
   → padding-bottom = --space-sm (8px) sous la barre de séparation
   → margin-bottom  = --space-lg (24px) entre les tabs et le contenu
===================================================================== */

.tabs{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:.75rem;
  border-bottom:var(--border);
  padding-top:0;
  padding-bottom:var(--space-md);
  margin-top:var(--space-md);
  margin-bottom:var(--space-md);
}
.tab-btn{
  height:var(--h);
  border-radius:999px;
  border:var(--border);
  background:var(--tab);
  color:var(--tab-color);
  font-weight:700;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  white-space:nowrap;
}
.tab-btn:hover {background: var(--tab-hover);color:var(--gen-white)}
.tab-btn.active{background:var(--tab-activ);color:var(--gen-white);border:var(--border)}
.tab-content{display:none}
.tab-content.active{display:block}

/* =====================================================================
   TYPOGRAPHIE
   Toutes les pages — hiérarchie uniforme
   → Règle de base : 0 en haut, --space-md (16px) en bas
   ⚠️ Exceptions documentées inline pour chaque composant
===================================================================== */

/* H1/H2 de section — toutes pages
   ⚠️ import_pro_history.html : .history-header .section-title → margin:0
   ⚠️ origin.html : .origin-block .section-title → margin T=xs, B=sm */
.section-title{
  font-size:clamp(1.3rem,1.2vw + 1rem,1.6rem);
  font-weight:900;
  color:var(--gen-title);
  margin:0 0 var(--space-md);
}

/* Sous-titres de section — index.html, price.html, origin.html
   margin T = --space-lg (24px) pour respiration avant le sous-titre
   margin B = --space-sm (8px) pour rapprocher le contenu qui suit
   ⚠️ origin.html : .origin-block .section-subtitle → margin T=xs, B=sm
   ⚠️ index.html  : premier .section-subtitle dans un .instr → margin-top:0
      car le padding du .instr suffit, la double marge crée un espace excessif */
.section-subtitle{
  font-size:clamp(1.1rem,1vw + .9rem,1.35rem);
  font-weight:900;
  margin:var(--space-lg) 0 var(--space-sm);
  color:var(--gen-title);
  border-left:5px solid var(--gold);
  padding-left:15px;
}
.instr > .section-subtitle:first-child,
.instr > h3.section-subtitle:first-child,
.instr > h3:first-of-type.section-subtitle,
#tab-presentation .instr .section-subtitle{
  margin-top:0;
  padding-top:0;
}

/* Sous-titres niveau 3 — index.html, price.html
   margin T = --space-md (16px), margin B = --space-xs (4px)
   Filet gauche plus fin (3px) et couleur neutre pour hiérarchie visuelle */
.section-subtitle-small{
  font-size:1rem;
  font-weight:800;
  margin:var(--space-md) 0 var(--space-xs);
  color:var(--gen-title);
  padding-left:10px;
  border-left:3px solid var(--gen-dark);
}

/* Paragraphes courants — toutes pages
   Pas de marge propre, portée par le conteneur parent */
.section-text{line-height:1.7;color:var(--muted)}

/* Intro sous le titre — index.html uniquement
   margin B = --space-md (16px) */
.section-lead{
  font-size:1.05rem;
  color:var(--muted);
  line-height:1.7;
  margin:0 0 var(--space-md);
}

/* Intro sous le titre — price.html uniquement
   même logique que .section-lead, classe distincte pour lisibilité HTML */
.lead{
  color:var(--muted);
  line-height:1.7;
  margin:0 0 var(--space-md);
}

/* =====================================================================
   PANELS / INSTRUCTIONS
   index.html, price.html, import_pro.html, demonstration.html, origin.html
   → margin T/B = --space-md (16px) uniforme entre chaque panneau
   → padding interne = --space-md (16px) sur tous les côtés
===================================================================== */

.instr{
  background:var(--gen-white);
  border:var(--border);
  border-radius:12px;
  padding:var(--space-md);
  margin:var(--space-md) 0;
  font-size:.95rem;
  line-height:1.55;
  font-weight:600;
}

/* Alternance blocs : impairs = ardoise pâle (premier), pairs = blanc */
.instr:nth-child(odd){
  background:var(--gen-blue);
}
.instr:nth-child(even){
  background:var(--gen-white);
}

/* Mise en avant inline — import_pro.html, demonstration.html */
.hl{
  font-weight:900;
  background:var(--gen-blue);
  color:var(--gen-title);
  border:1px solid #D6D1FF;
  padding:4px 10px;
  border-radius:6px;
  display:inline-block;
  text-decoration:none;
}

/* Espacement entre divs enfants d'un .instr — import_pro.html */
.instr > div + div{padding-left:10px}

/* =====================================================================
   LISTES
   index.html (.section-list), price.html, import_pro.html,
   demonstration.html (toutes via .instr-list)
   → margin T = --space-sm (8px) entre le texte précédent et la liste
   → margin entre items = --space-xs (4px)
===================================================================== */

.instr-list,
.section-list{
  list-style:disc;
  margin:var(--space-sm) 0 0;
  padding-left:1.6rem;
}
.instr-list li,
.section-list li{
  margin:0 0 var(--space-xs) 0;
  color:var(--gen-title);
  font-weight:600;
  padding-left:.4rem;
}

/* index.html — blocs .instr contenant des listes dans l'onglet présentation
   fond --gen-blue pour rompre la dominance du blanc et distinguer
   visuellement les blocs de contenu énumératif des blocs textuels */
/* index.html — listes dans l'onglet présentation
   Le .instr reste blanc (fond de base), la .section-list reçoit un fond bleu
   pour contraster avec le blanc du .instr parent */
#tab-presentation .section-list{
  background:var(--gen-white);
  border:var(--border);
  border-radius:10px;
  padding:var(--space-md) 22px;
  margin:var(--space-md) 0;
  font-weight:600;
}
#tab-presentation .section-list li{margin-left:1.2rem;margin-bottom:0}

/* index.html, price.html — listes en 2 colonnes
   Responsive : colonne unique sous 900px */
.instr-list.is-2col,
.section-list.is-2col{columns:2;column-gap:2rem}
.instr-list.is-2col li,
.section-list.is-2col li{break-inside:avoid}
@media (max-width:900px){
  .instr-list.is-2col,
  .section-list.is-2col{columns:1}
}

/* =====================================================================
   BOUTONS
   Toutes les pages
   → padding interne fixe (.6rem .95rem) pour hauteur uniforme
   → gap interne = --space-sm (8px)
===================================================================== */

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--space-sm);
  border-radius:999px;
  padding:.6rem .95rem;
  border:1px solid #4F3FBF;
  background:#4F3FBF;
  color:#fff;
  cursor:pointer;
  text-decoration:none;
  transition:all 0.2s ease;
  font-family:"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:16px;
  font-weight:600;
  line-height:1;
}
.btn:hover{background:#4335A8;border-color:#4335A8}
.btn.primary{background:#4F3FBF;border-color:#4F3FBF}

/* Bouton Démonstration — bleu clair */
.btn-demo{background:#4FB3E8 !important;border-color:#4FB3E8 !important;color:#fff !important}
.btn-demo:hover{background:#3AA0D8 !important;border-color:#3AA0D8 !important}

/* Boutons secondaires */
.btn-outline,
.btn-secondary{background:#F6F4FF !important;border:1px solid #D6D1FF !important;color:#4F3FBF !important}
.btn-outline:hover,
.btn-secondary:hover{background:#EDE9FF !important;border-color:#C0AEE8 !important}

.is-disabled,[aria-disabled="true"]{opacity:.55;pointer-events:none}

/* =====================================================================
   TABLES KEYVALUE
   index.html uniquement (7 onglets de contenu)
   → margin-top = --space-md (16px) sous le titre ou le texte intro
===================================================================== */

.keyvalue-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  table-layout:fixed;
  border:var(--border);
  border-radius:10px;
  overflow:hidden;
  background:var(--gen-white);
  margin-top:var(--space-md);
}
.table-rounded{border-radius:10px;overflow:hidden}
.keyvalue-table th,.keyvalue-table td{
  padding:.8rem var(--space-md);
  border:0;
  vertical-align:middle;
  text-align:left;
  overflow-wrap:anywhere;
}
.keyvalue-table tr > *{border-right:var(--border);border-bottom:var(--border)}
.keyvalue-table tr > *:last-child{border-right:0}
.keyvalue-table tbody tr:last-child > *{border-bottom:0}
.keyvalue-table th{
  background:var(--tab);
  color:var(--gen-black);
  font-weight:600;
  text-transform:uppercase;
  font-size:.85rem;
}
.keyvalue-table tbody tr:nth-child(even){background:var(--tab-blue)}

/* Largeurs colonnes par onglet — index.html */
#tab-postures .keyvalue-table th:nth-child(1){width:6%}
#tab-postures .keyvalue-table th:nth-child(2){width:24%}
#tab-postures .keyvalue-table th:nth-child(3){width:70%}

#tab-keyvalues .keyvalue-table th:nth-child(1){width:6%}
#tab-keyvalues .keyvalue-table th:nth-child(2){width:31%}
#tab-keyvalues .keyvalue-table th:nth-child(3){width:63%}

#tab-personnalite .keyvalue-table th:nth-child(1){width:6%}
#tab-personnalite .keyvalue-table th:nth-child(2){width:21%}
#tab-personnalite .keyvalue-table th:nth-child(3){width:73%}

#tab-dynamic .keyvalue-table th:nth-child(1){width:6%}
#tab-dynamic .keyvalue-table th:nth-child(2){width:30%}
#tab-dynamic .keyvalue-table th:nth-child(3){width:64%}

#tab-source .keyvalue-table th:nth-child(1){width:22%}
#tab-source .keyvalue-table th:nth-child(2){width:78%}

#tab-intelligences .keyvalue-table th:nth-child(1){width:25%}
#tab-intelligences .keyvalue-table th:nth-child(2){width:15%}
#tab-intelligences .keyvalue-table th:nth-child(3){width:60%}

#tab-postures .keyvalue-table td:nth-child(3),
#tab-intelligences .keyvalue-table td:nth-child(3){white-space:pre-line}

#tab-postures .keyvalue-table td:nth-child(2),
#tab-keyvalues .keyvalue-table td:nth-child(2),
#tab-personnalite .keyvalue-table td:nth-child(2),
#tab-dynamic .keyvalue-table td:nth-child(2){font-weight:600}

#tab-source .keyvalue-table td:nth-child(1),
#tab-intelligences .keyvalue-table td:nth-child(1){font-weight:600}

/* =====================================================================
   FOOTER
   Toutes les pages via base.html
   → margin-top = --space-xl (32px) pour bien séparer du contenu
   → padding-top = --space-md (16px) au-dessus du filet
===================================================================== */

.footer{
  margin-top:var(--space-xl);
  padding-top:var(--space-md);
  border-top:1px solid var(--line);
  font-size:.85rem;
  color:var(--gen-dark);
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
}
.footer a{text-decoration:underline}

/* =====================================================================
   AUTH — LOGIN
   Utilisé uniquement sur : login.html
   ⚠️ Spécifique login.html — page mono-colonne centrée sans sidebar ni tabs
      .auth-card surcharge intentionnellement la margin-top standard de .card :
      --space-lg (24px) au lieu de --space-md (16px) pour aérer la page de login
      qui n'a pas de titre de page au-dessus
===================================================================== */

.auth-honeypot{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;opacity:0}

/* Conteneur des messages flash centré — login.html
   gap = --space-sm (8px), margin T=sm B=md */
.auth-flashes{margin:var(--space-sm) 0 var(--space-md)}
.auth-flashes-centered{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}
.auth-flashes-centered .flash{width:100%;max-width:360px}

/* Carte de connexion — login.html
   ⚠️ margin-top = --space-lg (24px) intentionnellement plus grand que .card
      standard (--space-md) pour aérer la page login */
.auth-wrap{max-width:420px;margin:0 auto}
.auth-card{margin-top:var(--space-lg)}
.auth-title{text-align:center}

/* Labels et champs — login.html
   label margin-bottom = --space-xs (4px) collé au champ
   field margin-bottom = --space-sm (8px) entre les champs */
.auth-label{font-weight:700;display:block;margin-bottom:var(--space-xs)}
.auth-form .field{margin-bottom:var(--space-sm)}
.auth-form label{display:block;margin-bottom:6px;font-weight:700}
.auth-form input{
  width:100%;
  min-height:45px;
  padding:0 var(--space-md);
  border-radius:12px;
  border:1px solid var(--gen-mid);
  background:var(--gen-white);
  color:var(--gen-black);
  outline:none;
  text-align:center;
}
.auth-form input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.18)}

/* Bouton de soumission — login.html
   margin-top = --space-lg (24px) pour séparer clairement des champs */
.auth-submit{
  width:100%;
  margin:var(--space-lg) 0 0;
  display:block;
  background:var(--band);
  color:var(--gen-white);
  border-color:var(--band);
  border-radius:12px;
  height:45px;
  font-weight:800;
}

/* =====================================================================
   AUTH — MOT DE PASSE (login.html + signup.html)
   Bouton œil, barre de force, critères, correspondance
===================================================================== */

/* Wrapper input + bouton œil */
.pw-input-wrap{position:relative;display:flex;align-items:center}
.pw-input-wrap input{width:100%;padding-right:2.8rem}
.pw-toggle{
  position:absolute;right:.7rem;
  background:none;border:none;cursor:pointer;
  padding:0;color:#888;display:flex;align-items:center;
  line-height:1;
}
.pw-toggle:hover{color:var(--gen-black)}
.eye-icon{width:20px;height:20px;flex-shrink:0}

/* Barre de force — signup.html */
.pw-strength-bar{
  height:4px;background:var(--gen-mid);
  border-radius:2px;margin-top:6px;overflow:hidden;
}
.pw-strength-fill{
  height:100%;width:0%;border-radius:2px;
  transition:width .3s ease,background .3s ease;
}
.pw-strength-label{
  font-size:11px;margin-top:4px;font-weight:700;
  min-height:15px;letter-spacing:.02em;
}

/* Critères mot de passe — signup.html */
.pw-criteria{list-style:none;padding:6px 0 0;margin:0}
.criterion{
  font-size:12px;color:var(--ko);
  margin-bottom:2px;transition:color .2s;
  display:flex;align-items:center;gap:4px;
}
.criterion.ok{color:var(--ok)}
.crit-icon{font-style:normal;width:14px;text-align:center;flex-shrink:0}

/* Message correspondance — signup.html */
.pw-match-msg{font-size:12px;margin-top:4px;min-height:16px;font-weight:600}

/* Champs côte à côte prénom / nom — signup.html */
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}
@media(max-width:480px){.field-row{grid-template-columns:1fr}}

/* Séparateur liens auth */
.auth-sep{color:var(--gen-mid);margin:0 4px}

/* Turnstile — centrage */
.cf-turnstile{margin:var(--space-sm) 0}

/* =====================================================================
   FLASHES / MESSAGES
   login.html, demonstration.html, import_pro.html
   → margin T/B = --space-sm (8px) entre chaque message
===================================================================== */

.flash{
  padding:.75rem var(--space-md);
  border-radius:12px;
  border:1px solid var(--line);
  background:var(--gen-white);
  margin:var(--space-sm) 0;
}
.flash-error{border-color:rgba(217,48,37,.35)}
.flash-success{border-color:rgba(26,115,232,.35)}

/* =====================================================================
   IMPORT PRO
   import_pro.html, import_pro_history.html
   ⚠️ Spécifique import — marges internes plus généreuses que les pages
      informatives : la zone d'action (dépôt fichier) doit être bien visible
      → filewrap margin T/B = --space-lg (24px) au lieu de --space-md
===================================================================== */

/* Conteneur import — margin-top = --space-md (16px) sous le bandeau */
.container-import{margin-top:var(--space-md)}

/* Zone de sélection de fichier — import_pro.html
   ⚠️ margin T/B = --space-lg (24px) — plus grand que standard
      pour mettre en valeur l'action principale de la page */
.filewrap{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:1.2rem;
  align-items:center;
  width:100%;
  margin:var(--space-lg) 0;
}
.filewrap input[type=file]{display:none}
.filewrap .file-path{
  height:var(--h);
  border-radius:6px;
  border:1px solid var(--gen-mid);
  background:var(--gen-blue);
  color:var(--gen-black);
  display:flex;
  align-items:center;
  padding:0 12px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* Barre de progression — import_pro.html
   margin-top = --space-md (16px) standard */
.progress-section{margin-top:var(--space-md)}
.progress-title{margin:var(--space-xs) 0 var(--space-sm);font-weight:900}
.progress-outer{
  background:var(--gen-white);
  border-radius:12px;
  height:25px;
  width:100%;
  margin:var(--space-sm) 0;
  overflow:hidden;
  border:var(--border);
}
.progress-bar{
  background:#4F3FBF;
  height:100%;
  width:0%;
  transition:width .4s ease;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:.85rem;
  color:#fff;
}
.records-count{margin-top:var(--space-xs);font-size:.9rem}

/* Guide et séparateurs — import_pro.html */
.import-guide{margin-bottom:var(--space-md)}
.instr.import-guide{background:var(--gen-white)}
.demo-analysis-wrapper ~ * , .demo-section + .instr.import-guide{margin-bottom:0!important}
.import-separators{
  margin-top:var(--space-sm);
  display:inline-block;
}

/* Historique — import_pro.html, import_pro_history.html
   margin-top = --space-md, padding-top = --space-md */
.history-container{
  margin-top:var(--space-md);
  border-top:1px solid var(--line);
  padding-top:var(--space-md);
}
.history-title{font-size:1.2rem;font-weight:900;margin:0 0 var(--space-md)}

/* Liste des imports — gap = --space-sm (8px) entre lignes */
.import-list{display:flex;flex-direction:column;gap:var(--space-sm)}
.import-header,.import-item{
  display:grid;
  grid-template-columns:60px 120px 80px 200px 60px 60px 60px 1fr;
  gap:var(--space-sm);
  align-items:center;
}
.import-item{
  background:var(--gen-white);
  padding:.8rem 1.25rem;
  border-radius:10px;
  border:1px solid var(--gen-light);
  border-left:5px solid var(--gold);
  font-size:.85rem;
  transition:all .2s ease;
}
.header-item{
  background:var(--gen-blue);
  font-weight:900;
  text-transform:uppercase;
  font-size:.75rem;
  letter-spacing:.05em;
  border-left-color:transparent;
}
.import-item:not(.header-item):hover{
  transform:translateX(5px);
  background:var(--gen-blue);
  box-shadow:0 4px 6px -1px rgba(10,14,42,.12);
}
.import-item .date{color:var(--gen-dark);font-family:monospace;white-space:nowrap}
.import-item .username{font-weight:800}
.import-item .count{font-weight:900;text-align:center;color:var(--ok)}
.import-item .count.rejected-error{color:var(--ko)}
.import-item .fname{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--gen-dark);font-weight:600;padding-right:15px}
.no-imports{padding:var(--space-md);text-align:center}

/* Pied de liste — import_pro.html, margin-top = --space-md */
.history-footer{display:flex;justify-content:center;margin-top:var(--space-md)}
.view-all-btn{height:var(--h);border-radius:12px;padding:0 1.2rem}

@media (max-width:900px){
  .import-header,.import-item{grid-template-columns:1fr 1fr;gap:10px}
  .header-item{display:none}
  .import-item .fname{grid-column:span 2;border-top:1px solid var(--gen-light);padding-top:var(--space-xs)}
  .filewrap{grid-template-columns:1fr;gap:.75rem}
}

/* En-tête historique — import_pro_history.html uniquement
   ⚠️ .section-title sans marge verticale car dans un flex row avec le bouton retour
      margin-bottom = --space-sm (8px) sur le conteneur */
.history-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:var(--space-sm);
}
.history-header .section-title{margin:0}
.history-back{margin-left:auto;text-decoration:none;font-weight:800}

/* =====================================================================
   BANDEAU QUOTA DUAL — import_pro.html
   Grille 2 colonnes (Abonnement | Achats Ponctuels) séparées par un
   filet vertical. Les classes utilitaires (.muted, .hl, .instr) sont
   réutilisées depuis le tronc commun.
   ⚠️ Pas de styles dans les templates — tout est centralisé ici.
===================================================================== */

/* Grille principale : col-sub | divider | col-pct
   margin-top = --space-sm (8px) pour respirer après le titre .hl */
.quota-dual-columns{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:0 var(--space-lg);
  align-items:start;
  margin-top:var(--space-sm);
}

/* ── Colonne individuelle ── */
.quota-col{
  display:flex;
  flex-direction:column;
  gap:var(--space-xs);
}
/* Plan absent : contenu grisé */
.quota-col--empty{
  opacity:.55;
}

/* Titre de colonne : reprend la logique .hl mais avec soulignement coloré
   border-bottom remplace le fond encadré pour rester dans l'espace du .instr */
.quota-col-title{
  font-weight:800;
  font-size:.95rem;
  color:var(--gen-dark);
  border-bottom:2px solid var(--gen-mid);
  padding-bottom:var(--space-xs);
  margin-bottom:var(--space-xs);
}
.quota-col-title--subscription{
  border-color:var(--btn);
  color:var(--btn);
}
.quota-col-title--punctual{
  border-color:#2C8FD4;
  color:#2C8FD4;
}

/* Ligne de donnée label + valeur sur la même ligne */
.quota-col-row{
  display:flex;
  align-items:baseline;
  flex-wrap:wrap;
  gap:4px;
  font-size:.9rem;
}
/* Ligne Consommé / Restant : séparée du bloc infos par un filet tirets */
.quota-col-row--usage{
  margin-top:var(--space-xs);
  padding-top:var(--space-xs);
  border-top:1px dashed var(--gen-mid);
}

/* Label court — .muted du tronc est appliqué en HTML, ici on fixe la taille */
.quota-label{
  font-size:.85rem;
  white-space:nowrap;
}

/* Valeur Restant colorée --ok (bleu) */
.quota-remaining{
  color:var(--ok);
}

/* Message affiché quand le plan est absent (—) */
.quota-empty-msg{
  font-size:1.1rem;
  font-weight:600;
  padding:var(--space-sm) 0;
}

/* ── Séparateur vertical entre les deux colonnes ── */
.quota-divider{
  width:1px;
  align-self:stretch;
  background:var(--line);
}

/* ── Sélecteur de plan actif (visible seulement si les 2 plans sont dispo) ──
   margin-top + padding-top = --space-sm (8px), filet haut pour délimiter */
.quota-plan-selector{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:var(--space-md);
  margin-top:var(--space-md);
  padding-top:var(--space-sm);
  border-top:1px solid var(--line);
}
.quota-plan-option{
  display:flex;
  align-items:center;
  gap:6px;
  cursor:pointer;
  font-weight:600;
  font-size:.9rem;
  color:var(--gen-dark);
  user-select:none;
}
.quota-plan-option input[type="radio"]{
  accent-color:var(--btn);
  width:16px;
  height:16px;
  cursor:pointer;
}
.quota-plan-option--disabled{
  opacity:.4;
  cursor:not-allowed;
}
.quota-plan-option--disabled input[type="radio"]{
  cursor:not-allowed;
}

/* Responsive — les 2 colonnes passent en colonne unique sous 640px,
   le séparateur vertical devient un filet horizontal */
@media(max-width:640px){
  .quota-dual-columns{
    grid-template-columns:1fr;
  }
  .quota-divider{
    height:1px;
    width:100%;
    align-self:auto;
    margin:var(--space-sm) 0;
  }
}

/* =====================================================================
   HISTORIQUE IMPORTS — 2eme ligne detail + filtres de periode
   La 2eme ligne est sur une seule ligne horizontale avec 3 zones :
   gauche (Type), centre (Telecharger), droite (Validite du lien)
===================================================================== */

/* 1ere ligne : coins hauts arrondis, pas de bordure basse */
.import-item--main{
  border-radius:10px 10px 0 0;
  border-bottom:none;
}
/* 2eme ligne : coins bas arrondis, fond pale, disposition gauche/centre/droite */
.import-item--detail{
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:var(--gen-blue);
  padding:.45rem 1.25rem .55rem 1.5rem;
  border-radius:0 0 10px 10px;
  border:1px solid var(--gen-light);
  border-top:none;
  border-left:5px solid var(--gold-light);
  font-size:.82rem;
  margin-top:-8px;
}
/* Cellule individuelle : label + valeur cote a cote */
.import-detail-cell{
  display:flex;
  align-items:baseline;
  gap:4px;
  white-space:nowrap;
}
/* Lien telechargement actif */
.import-download-link{
  color:var(--ok);
  font-weight:700;
  text-decoration:underline;
}
/* Lien expire */
.import-link-expired{
  opacity:.45;
  font-style:italic;
  color:var(--muted);
}

/* Filtres de periode — import_pro_history.html */
.history-filters{margin-bottom:var(--space-md)}
.history-filter-form{display:flex;flex-direction:column;gap:var(--space-sm)}
.history-filter-row{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:var(--space-sm);
}
.history-filter-label{
  font-weight:700;
  font-size:.9rem;
  color:var(--gen-dark);
  white-space:nowrap;
}
.history-filter-input{
  height:var(--h);
  border-radius:8px;
  border:1px solid var(--gen-mid);
  padding:0 var(--space-sm);
  background:var(--gen-white);
  color:var(--gen-black);
  font-size:.9rem;
  outline:none;
}
.history-filter-input:focus{
  border-color:var(--btn);
  box-shadow:0 0 0 3px rgba(79,63,191,.15);
}
@media(max-width:700px){
  .import-item--detail{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}
  .history-filter-row{flex-direction:column;align-items:flex-start}
}

/* =====================================================================
   DEMO / DEMONSTRATION
   demonstration.html uniquement
   → demo-flashes margin B = --space-lg (24px), plus grand que .flash standard
     car séparation visuelle forte entre les messages et le formulaire
   → demo-section/form : margin-top = --space-sm (8px) compact
===================================================================== */

.demo-flashes{margin:var(--space-sm) 0 var(--space-lg)}
.demo-section{margin-top:var(--space-sm)}
.demo-form{margin-top:var(--space-sm)}

/* Formulaire demo — grille 3 champs + bouton
   gap fixe 12px intentionnel pour densité visuelle du formulaire */
.demo-grid{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:12px;align-items:end}
.demo-grid--analysis{grid-template-columns:1fr 1fr 1fr auto}

.demo-field{display:flex;flex-direction:column}
.demo-field--action{justify-content:flex-end}
.demo-field--small{flex:1}
.demo-field--date{flex:1.5}

/* Labels demo — margin-bottom = --space-xs (4px) collé au champ */
.demo-label{display:block;font-weight:800;margin-bottom:var(--space-xs);text-align:center}

.demo-input,
.demo-select{
  width:100%;
  height:var(--h);
  border-radius:6px;
  border:1.5px solid #4F3FBF;
  padding:0 12px;
  background:var(--gen-blue);
  color:var(--gen-title);
  outline:none;
  text-align:center;
  font-weight:800;
}
.demo-select{text-align-last:center}

/* Labels de date — margin-bottom = --space-xs, padding-top = --space-xs */
.demo-date-labels{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:10px;
  margin-bottom:var(--space-xs);
  padding-top:var(--space-xs);
}
.demo-date-labels span{text-align:center}
.demo-date--equal{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}

/* Pied de formulaire — margin-top = --space-sm (8px) compact */
.demo-form-footer-center{display:flex;justify-content:center;margin-top:var(--space-ms)}

/* Quota inline — padding = --space-xs --space-sm (élément compact inline) */
.demo-quota-inline{
  background:var(--gen-white);
  border:var(--border);
  border-radius:10px;
  padding:var(--space-xs) var(--space-sm);
  margin-top:var(--space-xs);
  color:#4F3FBF;
  font-weight:600;
}

/* Bloc info — margin-top = --space-md (16px) standard */
.demo-info-block{margin-top:var(--space-md);margin-bottom:0!important;padding-bottom:var(--space-xs)}

/* --- Blocs d'analyse --- */

/* Wrapper — pas de marge en haut (suit directement le formulaire) */
.demo-analysis-wrapper{margin-top:0}

/* Titre externe des blocs — margin B = --space-xs (4px) très collé */
.demo-analysis-title-out{
  font-weight:900;
  margin:0 0 var(--space-xs);
  padding-left:var(--space-xs);
}

/* Bloc d'analyse — margin-bottom = --space-lg (24px)
   ⚠️ Dernier bloc : margin-bottom = 0 via :last-of-type */
.demo-analysis-block{
  background:var(--gen-blue);
  border:var(--border);
  border-radius:8px;
  padding:var(--space-xs) var(--space-md) 0 var(--space-md);
  margin-bottom:var(--space-lg);
}
.demo-analysis-block:last-of-type{margin-bottom:0}

/* Lignes d'analyse — min-height fixe 40px pour uniformité */
.demo-analysis-block .demo-analysis-row{
  display:grid;
  grid-template-columns:260px 1fr 32px;
  gap:12px;
  align-items:center;
  min-height:40px;
  padding-bottom:3px;
  border-bottom:var(--border);
}
.demo-analysis-row:last-child{border-bottom:none}

.demo-analysis-block .demo-analysis-k{
  font-weight:800;color:var(--btn);white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;line-height:1.2;min-width:180px;
}
.demo-analysis-block .demo-analysis-v,
.demo-analysis-block .demo-analysis-v.demo-analysis-wrap{
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;
}
.demo-analysis-block .demo-analysis-i{justify-self:end}

/* Tooltip */
.demo-tip{
  width:28px;height:28px;border-radius:999px;
  border:1px solid rgba(26,58,143,.2);background:var(--gen-blue);
  cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  position:relative;z-index:10;font-weight:600;
}
.demo-tip::after{
  content:attr(data-tip);position:absolute;right:0;top:36px;z-index:9999;
  width:min(420px,75vw);padding:12px 14px;border-radius:12px;
  background:var(--gen-blue);border:1px solid var(--gen-mid);color:var(--gen-black);
  font-size:.88rem;line-height:1.35;font-weight:900;
  box-shadow:0 12px 28px rgba(10,14,42,.18);
  opacity:0;transform:translateY(-6px);pointer-events:none;
  white-space:pre-wrap;transition:all .2s;
}
.demo-tip:hover::after,
.demo-tip:focus::after{opacity:1;transform:translateY(8px)}

.demo-analysis-row:hover,
.demo-analysis-row:focus-within{
  background:#F3F4F6;border-radius:8px;transition:background .15s ease;
}

@media (max-width:900px){.demo-grid{grid-template-columns:1fr}}
@media (max-width:700px){
  .demo-analysis-block .demo-analysis-row{grid-template-columns:1fr auto}
}

/* =====================================================================
   PRICING / TARIFS
   price.html uniquement
   ⚠️ Spécifique price.html — seule page avec des grilles de plans en colonnes
      et une table de tarification ; marges plus généreuses que les pages
      de contenu pour aérer les plans tarifaires
   → Entre grilles et sections : --space-lg (24px)
   → pricing-page margin-top : --space-lg (24px) sous la card
===================================================================== */

/* Rangée de boutons CTA — gap = --space-md (16px) */
.btn-row{display:flex;justify-content:center;align-items:center;width:100%;gap:var(--space-md)}

/* Textes spécifiques price.html */
.title{text-align:center;font-weight:900;margin:0 0 var(--space-xs)}
.text{color:var(--muted);line-height:1.7;margin:var(--space-sm) 0 var(--space-md)}
.punctual-title{text-align:center;font-weight:800;margin:var(--space-xs) 0 var(--space-sm);font-size:1.3rem}

/* Conteneur — margin-top = --space-lg (24px) */
.pricing-page{margin-top:var(--space-lg)}

/* Grilles de plans — gap = --space-lg (24px) entre plans */
.pricing-grid{display:grid;gap:var(--space-lg);margin-top:var(--space-md)}
.pricing-grid-plans{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.pricing-grid-punctual{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));align-items:start}
.pricing-grid-demo{display:flex;justify-content:center;width:100%;margin:var(--space-lg) 0}

/* Carte de plan — padding T = .75rem (intentionnellement plus serré en haut) */
.plan{
  border:1px solid #E5E2FF;border-radius:16px;background:var(--gen-white);
  box-shadow:0 1px 4px rgba(10,14,42,.06);
  padding:.75rem var(--space-lg) var(--space-lg);
  display:flex;flex-direction:column;
}
.featured-plan{box-shadow:0 12px 30px rgba(26,58,143,.14);transform:scale(1.02);border:2px solid #4F3FBF}
.demo-plan{box-shadow:none;transform:none}
.plan-punctual{gap:var(--space-sm)}
.plan h3{text-align:center;font-weight:950;margin:0}
.plan .price{text-align:center;font-size:1.8rem;font-weight:950;margin:0}
.plan .meta{text-align:center}

/* Liste de fonctionnalités — margin T/B = --space-md (16px) */
.features{flex-grow:1;margin:var(--space-md) 0;list-style:none;padding:0}
.features li{margin-bottom:var(--space-xs);padding-left:1.2rem;position:relative}
.features li::before{content:"•";position:absolute;left:0;color:var(--gen-black)}

/* Table de tarification */
.btn-pricing{min-width:150px}


.pricing-table{width:100%;border-collapse:collapse}
.pricing-table th,.pricing-table td{padding:10px 12px;border-bottom:1px solid var(--line)}
.pricing-table thead th{background:var(--gen-blue);text-align:left}
.pricing-table tbody td:nth-child(1),.pricing-table tbody td:nth-child(2){text-align:right}

@media (max-width:768px){
  .featured-plan{transform:scale(1)}
  .btn-pricing{width:100%}
}

/* =====================================================================
   PRICE — SÉLECTEURS ACHATS PONCTUELS
   price.html — zones profil et fichier
===================================================================== */

/* En-tête de zone avec fond bleu titre */
.punctual-header{
  text-align:center;
  font-weight:800;
  font-size:1.1rem;
  color:var(--gen-title);
  background:var(--gen-blue);
  border-radius:10px;
  padding:var(--space-xs) var(--space-md);
  margin:var(--space-xs) 0 var(--space-sm);
  letter-spacing:.02em;
  border:1px solid #D6D1FF;
}

/* Bloc sélecteur centré avec fond doux */
.punctual-selector{
  background:var(--gen-blue);
  border:1px solid var(--gen-mid);
  border-radius:12px;
  padding:var(--space-md);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:var(--space-sm);
  margin:var(--space-sm) 0;
}

/* Grille 2 colonnes : Tranche | Quantité sur la même ligne */
.selector-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-md);
  width:100%;
}

/* Cellule : label au-dessus, select en dessous */
.selector-row{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  width:100%;
}

/* Label */
.selector-label{
  font-weight:700;
  color:var(--gen-black);
  min-width:90px;
  text-align:center;
}

/* Select commun — valeur sélectionnée centrée */
.selector-select{
  width:100%;
  max-width:180px;
  height:40px;
  padding:0 var(--space-sm);
  border-radius:8px;
  border:1px solid var(--gen-mid);
  background:var(--gen-white);
  color:var(--gen-black);
  font-size:.95rem;
  cursor:pointer;
  outline:none;
  text-align:center;
  text-align-last:center;
}
.selector-select:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,168,76,.18);
}

/* Total en gras centré */
.selector-total{
  font-weight:800;
  font-size:1.1rem;
  color:var(--gen-title);
  text-align:center;
  margin-top:var(--space-xs);
}

/* Hint minimum */
.selector-hint{
  color:var(--gen-dark);
  font-size:.8rem;
  text-align:center;
  min-height:14px;
}

/* =====================================================================
   PAYMENT / PAIEMENT
   payment.html uniquement
   ⚠️ Spécifique payment.html — seule page avec grille 2 colonnes
      récapitulatif/formulaire ; n'utilise pas .card standard
      mais .container-pay + .pay-block
   → pay-grid gap = --space-lg (24px)
   → pay-block padding = --space-md (16px)
===================================================================== */

/* Conteneur dédié — identique à .container mais isolé pour la page payment */
.container-pay{width:min(90vw,1000px);margin:0 auto}

/* Grille 2 colonnes récap / formulaire — gap = --space-lg (24px) */
.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}
.pay-info{display:flex;flex-direction:column;gap:var(--space-sm)}
.pay-form-container{display:flex;flex-direction:column;gap:var(--space-sm)}

/* Blocs internes — padding = --space-md (16px) uniforme */
.pay-block{background:var(--gen-white);border:var(--border);border-radius:12px;padding:var(--space-md)}

/* Titre page — margin B = --space-xs (4px) très serré car suivi du .pay-lead */
.pay-title{
  font-size:clamp(1.3rem,1.2vw + 1rem,1.6rem);
  font-weight:900;color:var(--gen-title);
  margin:0 0 var(--space-xs);
}

/* Titres de sections internes — margin B = --space-sm (8px) */
.pay-section{font-weight:900;margin:0 0 var(--space-sm)}

/* Labels — margin-bottom = 6px (valeur fixe pour coller au champ) */
.pay-label{font-weight:800;display:block;margin-bottom:6px}

/* Texte récapitulatif compact — margin T/B = --space-sm (8px) */
.pay-mini{font-size:.9rem;color:var(--muted);margin:var(--space-sm) 0}

/* Montant total — margin-top = --space-sm (8px) après le filet hr */
.pay-total{font-weight:900;font-size:1.1rem;margin-top:var(--space-sm)}

/* Champs — margin-bottom = --space-sm (8px) entre champs */
.pay-field{margin-bottom:var(--space-sm)}

.pay-input{
  width:100%;height:45px;border-radius:12px;
  border:1px solid var(--gen-mid);padding:0 12px;background:var(--gen-white);
}
.pay-lead,.pay-hint{color:var(--muted)}

@media (max-width:900px){.pay-grid{grid-template-columns:1fr}}

/* =====================================================================
   ORIGIN / ORIGINE
   origin.html uniquement
   ⚠️ Spécifique origin.html — seule page avec des blocs icon+texte empilés
      Marges entre blocs = --space-xs/sm (plus serrées que .instr standard)
      car l'effet recherché est une page narrative continue
   → .origin-block padding interne = --space-xl (32px) pour aérer le contenu
   → Titres dans les blocs : marges réduites vs standard (dans un bloc déjà padé)
===================================================================== */

/* Bloc origin — margin T/L/R = --space-xs (4px), margin B = --space-sm (8px)
   ⚠️ padding = --space-xl (32px) intentionnellement plus grand que .instr
      standard (--space-md) pour donner de l'air à chaque bloc narratif */
.origin-block{
  display:flex;
  gap:14px;
  align-items:flex-start;
  background:var(--gen-white);
  border:var(--border);
  border-radius:12px;
  font-size:.95rem;
  line-height:1.55;
  font-weight:600;
  margin:var(--space-md) 0;
  padding:var(--space-md) var(--space-xl);
}
.origin-block:nth-child(odd){
  background:var(--gen-blue);
}
.origin-block:nth-child(even){
  background:var(--gen-white);
}
.origin-block.instr{
  margin:var(--space-sm) 0 var(--space-md) 0;
  padding:var(--space-md) var(--space-xl);
}

.origin-ico{
  width:44px;height:44px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;flex:0 0 44px;
  background:var(--gold-light);border:1px solid var(--gold);
}
.origin-body{flex:1}

/* Titres dans origin — marges réduites car dans un bloc déjà padé */
.origin-block .section-title{margin:var(--space-xs) 0 var(--space-sm)}
.origin-block .section-subtitle{margin:var(--space-xs) 0 var(--space-sm)}

.origin-block--warn{border-left:6px solid rgba(201,168,76,.9)}
.origin-block--resp{border-left:6px solid var(--gen-title)}

@media (max-width:700px){
  .origin-block{flex-direction:column}
  .origin-ico{width:40px;height:40px;flex-basis:40px}
}

/* =====================================================================
   LOGOUT
   Toutes les pages via base.html (lien de déconnexion dans la nav)
===================================================================== */

.logout-link{color:var(--ko)}
.logout-link:hover{border-bottom-color:var(--ko)}

/* =====================================================================
   RESPONSIVE GLOBAL
   Toutes les pages — réduit les grands espacements sur mobile
   → --space-xl : 32px → 24px (= --space-lg)
   → --space-xxl : 48px → 32px (= --space-xl)
   Les sections et blocs s'adaptent automatiquement sans toucher chaque règle
===================================================================== */

@media (max-width:768px){
  :root{
    --space-xl:var(--space-lg);
    --space-xxl:var(--space-xl);
  }
}

/* =====================================================================
   FEATURE GRID
   index.html — onglet Présentation uniquement
   Utilisé dans : bloc Comparatif (4 items) et bloc Périmètre (3 items)
   → Remplace des séries de <p class="section-text"> sans hiérarchie visuelle
   → Chaque item = icône + label titré + paragraphe descriptif
   → Fond --gen-blue pour contraster avec le .instr blanc parent
   → Filet gauche coloré --gen-title pour ancrer visuellement chaque entrée
   → margin-top = --space-md (16px) pour séparer du contenu précédent
===================================================================== */

.feature-grid{
  display:grid;
  gap:var(--space-sm);
  margin-top:var(--space-md);
}

.feature-item{
  display:flex;
  gap:var(--space-md);
  align-items:flex-start;
  padding:var(--space-sm) var(--space-md);
  background:var(--gen-blue);
  border-radius:10px;
  border-left:3px solid var(--gold);
}

/* Paragraphe dans feature-item — réinitialise la marge héritée de .section-text */
.feature-item .section-text{
  margin:0;
  font-weight:600;
}

/* Responsive — pas de changement de layout nécessaire,
   le flex wrap naturel gère le mobile */
@media (max-width:600px){
  .feature-item{
    gap:var(--space-sm);
    padding:var(--space-sm);
  }
}