/* ============================================================
   Généalogie & SQL — Atelier du CG22
   ============================================================ */

:root {
  --fond: #f4f1ea;
  --carte: #ffffff;
  --encre: #2c2825;
  --encre-2: #6f6559;
  --bord: #e3dccf;
  --accent: #2f6b4f;
  --accent-fonce: #24523d;
  --accent-clair: #e9f1ec;
  --or: #c98f2d;
  --or-clair: #fdf3e0;
  --homme: #4a7aa5;
  --femme: #b2537a;
  --danger: #a23b3b;
  --rayon: 10px;
  --ombre: 0 1px 3px rgba(44, 40, 37, .08), 0 4px 14px rgba(44, 40, 37, .06);
}

* { box-sizing: border-box; }
/* overscroll-behavior : sur mobile, un glissement vers le bas ne doit pas
   recharger la page (le tirer-pour-rafraîchir viderait l'éditeur SQL). */
html, body { height: 100%; overscroll-behavior: none; }
body {
  margin: 0;
  font-family: "Segoe UI", system-ui, -apple-system, sans-serif;
  font-size: 16px;
  color: var(--encre);
  background: var(--fond);
  display: flex;
  flex-direction: column;
}
code, kbd, textarea, .mono {
  font-family: Consolas, "Cascadia Code", Menlo, monospace;
}
code { background: #f0ece3; padding: 1px 5px; border-radius: 4px; font-size: .88em; }

/* ---------- En-tête ---------- */
.entete {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 10px 18px;
  background: var(--carte);
  border-bottom: 2px solid var(--bord);
  flex-wrap: wrap;
}
.marque { display: flex; align-items: center; gap: 10px; }
.marque .logo { font-size: 28px; }
.marque strong { font-size: 18px; display: block; }
.marque .sous-titre { font-size: 12.5px; color: var(--encre-2); display: block; }
.onglets { display: flex; gap: 4px; flex: 1; justify-content: center; flex-wrap: wrap; }
.onglets a {
  padding: 8px 14px;
  border-radius: 999px;
  text-decoration: none;
  color: var(--encre-2);
  font-weight: 600;
  font-size: 15px;
}
.onglets a:hover { background: var(--accent-clair); color: var(--accent-fonce); }
.onglets a.actif { background: var(--accent); color: #fff; }
.actions-entete { display: flex; gap: 8px; }

/* ---------- Boutons ---------- */
.btn {
  border: 1px solid var(--bord);
  background: var(--carte);
  color: var(--encre);
  padding: 7px 13px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.btn:hover { border-color: var(--accent); color: var(--accent-fonce); background: var(--accent-clair); }
.btn-primaire { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-primaire:hover { background: var(--accent-fonce); color: #fff; }
.btn-mini { padding: 3px 9px; font-size: 12.5px; }
.btn kbd {
  background: rgba(255, 255, 255, .25);
  border-radius: 4px;
  padding: 1px 5px;
  font-size: 11px;
}

/* ---------- Pages ---------- */
.page { display: none; flex: 1; min-height: 0; }
.page.actif { display: flex; }
#page-arbre.actif { flex-direction: column; }

/* ---------- Barre de l'arbre ---------- */
.barre-arbre {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  flex-wrap: wrap;
}
.zone-recherche { position: relative; }
#recherche {
  width: 300px;
  padding: 8px 12px;
  border: 1px solid var(--bord);
  border-radius: 8px;
  font-size: 14.5px;
  background: var(--carte);
}
#recherche:focus { outline: 2px solid var(--accent); border-color: transparent; }
.menu-recherche {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  width: 340px;
  background: var(--carte);
  border: 1px solid var(--bord);
  border-radius: 8px;
  box-shadow: var(--ombre);
  z-index: 30;
  max-height: 320px;
  overflow: auto;
}
.menu-recherche button {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  text-align: left;
  padding: 8px 12px;
  border: 0;
  background: none;
  cursor: pointer;
  font-size: 14px;
}
.menu-recherche button:hover, .menu-recherche button.survol { background: var(--accent-clair); }
.menu-recherche .detail { color: var(--encre-2); font-size: 12.5px; white-space: nowrap; }
.astuce { color: var(--encre-2); font-size: 13px; margin-left: auto; }

/* ---------- Bandeau relation ---------- */
.bandeau-relation {
  margin: 0 16px 8px;
  padding: 10px 14px;
  background: var(--or-clair);
  border: 1px solid #e8cf9e;
  border-radius: var(--rayon);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 12px;
  font-size: 14.5px;
}
.bandeau-relation .boutons-relation { margin-left: auto; display: flex; gap: 6px; }

/* ---------- Zone de l'arbre ---------- */
.zone-arbre {
  position: relative;
  flex: 1;
  min-height: 0;
  margin: 0 16px 16px;
  border: 1px solid var(--bord);
  border-radius: var(--rayon);
  background:
    radial-gradient(circle, #e6e0d2 1px, transparent 1px) 0 0 / 26px 26px,
    #faf8f3;
  overflow: hidden;
}
/* touch-action: none — le doigt sert à déplacer/pincer l'arbre, le
   navigateur ne doit ni défiler ni zoomer la page à sa place. */
#svg-arbre {
  width: 100%;
  height: 100%;
  display: block;
  cursor: grab;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  -webkit-touch-callout: none;
}
#svg-arbre.deplacement { cursor: grabbing; }
.controles-zoom {
  position: absolute;
  left: 12px;
  bottom: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.controles-zoom button {
  width: 38px;
  height: 38px;
  font-size: 19px;
  border-radius: 8px;
  border: 1px solid var(--bord);
  background: var(--carte);
  cursor: pointer;
  box-shadow: var(--ombre);
}
.controles-zoom button:hover { background: var(--accent-clair); }

/* ---------- Nœuds SVG ---------- */
.noeud { cursor: pointer; }
.noeud .boite {
  fill: var(--carte);
  stroke: #d8d0c1;
  stroke-width: 1.2;
  rx: 9px;
}
.noeud:hover .boite { stroke: var(--accent); stroke-width: 2; }
.noeud .bande { rx: 0; }
.noeud.sexe-M .bande { fill: var(--homme); }
.noeud.sexe-F .bande { fill: var(--femme); }
.noeud text { user-select: none; }
.noeud .prenom { font-size: 13.5px; font-weight: 700; fill: var(--encre); }
.noeud .nom { font-size: 12px; fill: var(--encre-2); }
.noeud .dates { font-size: 10.5px; fill: #96897a; }
.noeud .fond-sosa { fill: var(--accent); }
.noeud .texte-sosa { fill: #fff; font-size: 10px; font-weight: 700; }
.noeud.implexe .fond-sosa { fill: var(--or); }
.noeud.focus .boite { stroke: var(--accent); stroke-width: 3; }
.noeud.selection-1 .boite { stroke: #4a7aa5; stroke-width: 3; stroke-dasharray: none; }
.noeud.selection-2 .boite { stroke: #b2537a; stroke-width: 3; }
.pastille-selection { font-size: 12px; font-weight: 700; }

/* liens */
.lien { fill: none; stroke: #bfb5a3; stroke-width: 1.6; }
.lien-mariage { fill: none; stroke: #a99e8a; stroke-width: 2.6; }
.etiquette-lien { font-size: 11px; fill: var(--encre-2); }
.bande-generation { fill: rgba(47, 107, 79, .045); }
.etiquette-generation {
  font-size: 12px;
  font-weight: 700;
  fill: #a89c89;
  letter-spacing: .06em;
  text-transform: uppercase;
}

/* chemin illuminé entre deux personnes */
svg.mode-chemin .noeud:not(.sur-chemin) { opacity: .16; }
svg.mode-chemin .lien:not(.sur-chemin), svg.mode-chemin .lien-mariage:not(.sur-chemin) { opacity: .1; }
svg.mode-chemin .noeud.sur-chemin .boite { stroke: var(--or); stroke-width: 3; filter: drop-shadow(0 0 6px rgba(201, 143, 45, .8)); }
svg.mode-chemin .noeud.ancetre-commun .boite { stroke: var(--danger); stroke-width: 3.5; filter: drop-shadow(0 0 8px rgba(162, 59, 59, .8)); }
svg.mode-chemin .lien.sur-chemin, svg.mode-chemin .lien-mariage.sur-chemin { stroke: var(--or); stroke-width: 3.5; }

/* ---------- Panneau personne ---------- */
.panneau {
  position: absolute;
  top: 12px;
  right: 12px;
  bottom: 12px;
  width: 330px;
  background: var(--carte);
  border: 1px solid var(--bord);
  border-radius: var(--rayon);
  box-shadow: var(--ombre);
  padding: 16px;
  overflow: auto;
  z-index: 20;
}
.panneau .fermer {
  position: absolute;
  top: 8px;
  right: 10px;
  border: 0;
  background: none;
  font-size: 18px;
  cursor: pointer;
  color: var(--encre-2);
}
.panneau h3 { margin: 0 34px 2px 0; font-size: 19px; }
.panneau .badges { display: flex; gap: 6px; flex-wrap: wrap; margin: 6px 0 10px; }
.badge {
  font-size: 11.5px;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 999px;
  background: var(--accent-clair);
  color: var(--accent-fonce);
}
.badge.or { background: var(--or-clair); color: #8a5f13; border: 1px solid #e8cf9e; }
.badge.bleu { background: #e8eff5; color: #33587a; }
.badge.rose { background: #f6e9ef; color: #8a3d5f; }
.panneau dl { margin: 10px 0; font-size: 14px; }
.panneau dt { color: var(--encre-2); font-size: 12px; text-transform: uppercase; letter-spacing: .05em; margin-top: 8px; }
.panneau dd { margin: 2px 0 0; }
.panneau h4 {
  margin: 14px 0 6px;
  font-size: 12.5px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--encre-2);
  border-top: 1px solid var(--bord);
  padding-top: 10px;
}
.liste-proches { display: flex; flex-direction: column; gap: 4px; }
.proche {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 6px 9px;
  border: 1px solid var(--bord);
  border-radius: 7px;
  background: #fbfaf7;
  cursor: pointer;
  font-size: 13.5px;
  text-align: left;
  width: 100%;
}
.proche:hover { border-color: var(--accent); background: var(--accent-clair); }
.proche .detail { color: var(--encre-2); font-size: 12px; white-space: nowrap; }
.panneau .actions { display: flex; flex-direction: column; gap: 6px; margin-top: 14px; }
.panneau .actions .btn { justify-content: center; }

/* ---------- Console SQL ---------- */
#page-sql.actif { display: grid; grid-template-columns: 320px 1fr; min-height: 0; }
.colonne-lecons {
  border-right: 1px solid var(--bord);
  background: #f9f7f1;
  overflow-y: auto;
  padding: 14px;
}
.colonne-lecons h2 { margin: 2px 0 6px; font-size: 17px; }
.intro-lecons { font-size: 13px; color: var(--encre-2); margin: 0 0 12px; }
.module summary {
  cursor: pointer;
  font-weight: 700;
  font-size: 14.5px;
  padding: 8px 6px;
  border-radius: 7px;
  list-style: none;
}
.module summary::-webkit-details-marker { display: none; }
.module summary:hover { background: var(--accent-clair); }
.module summary .compteur { color: var(--encre-2); font-weight: 400; font-size: 12px; }
.lecon-item {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  text-align: left;
  border: 0;
  background: none;
  padding: 6px 8px 6px 22px;
  font-size: 13.5px;
  cursor: pointer;
  border-radius: 6px;
  color: var(--encre);
}
.lecon-item:hover { background: var(--accent-clair); }
.lecon-item.actif { background: var(--accent); color: #fff; }
.lecon-item .coche { margin-left: auto; font-size: 12px; }

/* La colonne console ne défile pas : la leçon et les résultats défilent
   chacun dans leur panneau, l'éditeur reste toujours visible. */
.colonne-console {
  overflow: hidden;
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
  min-height: 0;
}
.carte-lecon {
  flex: 0 1 auto;
  max-height: 30vh;
  overflow-y: auto;
}
.carte-lecon:empty { display: none; }
.memo-schema { flex-shrink: 0; }
.memo-schema[open] { max-height: 30vh; overflow-y: auto; }
.editeur { flex-shrink: 0; }
.indicateur-selection {
  font-size: 12px;
  color: #8a5f13;
  background: var(--or-clair);
  border: 1px solid #e8cf9e;
  border-radius: 999px;
  padding: 3px 10px;
}
.carte {
  background: var(--carte);
  border: 1px solid var(--bord);
  border-radius: var(--rayon);
  padding: 14px 16px;
  box-shadow: var(--ombre);
}
.carte-lecon h3 { margin: 0 0 8px; font-size: 17px; }
.carte-lecon p { margin: 8px 0; font-size: 14.5px; line-height: 1.55; }
.carte-lecon ul { margin: 8px 0; padding-left: 22px; font-size: 14.5px; line-height: 1.55; }
.carte-lecon .exemples { display: flex; flex-direction: column; gap: 8px; margin: 10px 0; }
.exemple-sql {
  display: flex;
  align-items: stretch;
  gap: 0;
  border: 1px solid var(--bord);
  border-radius: 8px;
  overflow: hidden;
}
.exemple-sql pre {
  margin: 0;
  padding: 9px 12px;
  font-size: 12.8px;
  line-height: 1.5;
  overflow-x: auto;
  flex: 1;
  background: #f8f6f0;
}
.exemple-sql button {
  border: 0;
  border-left: 1px solid var(--bord);
  background: var(--accent-clair);
  color: var(--accent-fonce);
  font-weight: 700;
  font-size: 13px;
  padding: 0 14px;
  cursor: pointer;
  white-space: nowrap;
}
.exemple-sql button:hover { background: var(--accent); color: #fff; }
.exercice {
  border-left: 4px solid var(--or);
  background: var(--or-clair);
  padding: 10px 14px;
  border-radius: 0 8px 8px 0;
  margin-top: 10px;
  font-size: 14.5px;
}
.exercice summary { cursor: pointer; font-weight: 600; color: #8a5f13; margin-top: 6px; font-size: 13.5px; }
.navigation-lecon { display: flex; justify-content: space-between; margin-top: 12px; gap: 8px; }

.memo-schema summary { cursor: pointer; font-weight: 700; font-size: 14.5px; }
.memo-contenu { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; margin-top: 12px; }
.memo-table h4 { margin: 0 0 6px; color: var(--accent-fonce); }
.memo-table ul { margin: 0; padding-left: 18px; font-size: 13px; line-height: 1.65; }
.requetes-rapides { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-top: 12px; font-size: 13px; color: var(--encre-2); }
.puce {
  border: 1px solid var(--bord);
  background: #fbfaf7;
  border-radius: 999px;
  padding: 5px 12px;
  font-size: 13px;
  cursor: pointer;
}
.puce:hover { border-color: var(--accent); background: var(--accent-clair); }

.editeur { padding: 0; overflow: hidden; }
#editeur-sql {
  width: 100%;
  min-height: 96px;
  height: 132px;
  max-height: 42vh;
  border: 0;
  resize: vertical;
  padding: 13px 15px;
  font-size: 14px;
  line-height: 1.55;
  background: #fdfcf9;
  color: #33302b;
  display: block;
}
#editeur-sql:focus { outline: none; background: #fff; }
.barre-editeur {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-top: 1px solid var(--bord);
  background: #f8f6f0;
}
#historique { max-width: 260px; padding: 6px; border-radius: 7px; border: 1px solid var(--bord); font-size: 13px; }
.info-duree { margin-left: auto; font-size: 12.5px; color: var(--encre-2); }

.zone-resultats {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1 1 auto;
  min-height: 90px;
  overflow: auto;
}
.resultat { flex-shrink: 0; }
.placeholder-resultats { color: var(--encre-2); font-size: 14px; text-align: center; padding: 30px 10px; }
/* overflow: clip (et non hidden) : arrondit les coins sans devenir le
   conteneur de défilement — les en-têtes sticky collent au panneau. */
.resultat { background: var(--carte); border: 1px solid var(--bord); border-radius: var(--rayon); overflow: clip; }
.resultat .entete-resultat {
  padding: 7px 12px;
  font-size: 12.5px;
  color: var(--encre-2);
  background: #f8f6f0;
  border-bottom: 1px solid var(--bord);
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.resultat .entete-resultat code { background: none; padding: 0; color: var(--accent-fonce); }
/* Le tableau défile avec le panneau de résultats (un seul ascenseur) ;
   les en-têtes restent collés en haut du panneau. */
.defilement-table { overflow: visible; }
.resultat table { border-collapse: collapse; width: 100%; font-size: 13.5px; }
.resultat th {
  position: sticky;
  top: 0;
  background: var(--accent);
  color: #fff;
  text-align: left;
  padding: 7px 11px;
  font-size: 12.5px;
  white-space: nowrap;
}
.resultat td { padding: 5.5px 11px; border-top: 1px solid #efeadf; white-space: nowrap; }
.resultat tbody tr:nth-child(even) { background: #faf8f3; }
.resultat tbody tr:hover { background: var(--accent-clair); }
.resultat td.nul { color: #b3a894; font-style: italic; }
.resultat td.numero { color: #33587a; }
.resultat .pied { padding: 6px 12px; font-size: 12px; color: var(--encre-2); }
.message-modif {
  padding: 10px 14px;
  font-size: 14px;
  background: var(--accent-clair);
  border: 1px solid #cfe0d6;
  border-radius: var(--rayon);
}
.message-erreur {
  padding: 12px 14px;
  font-size: 14px;
  background: #f9ecec;
  border: 1px solid #e3c3c3;
  border-radius: var(--rayon);
  color: var(--danger);
}
.message-erreur code { background: #f2dede; }

/* ---------- Page Comprendre ---------- */
#page-concepts { overflow-y: auto; }
.colonne-concepts { max-width: 880px; margin: 0 auto; padding: 22px 18px 50px; display: flex; flex-direction: column; gap: 14px; }
.colonne-concepts h2 { margin: 0 0 10px; font-size: 20px; }
.colonne-concepts p, .colonne-concepts li { font-size: 15px; line-height: 1.65; }
.colonne-concepts ul { padding-left: 22px; }
.note { background: #f6f3ea; border-radius: 8px; padding: 9px 13px; font-size: 14px !important; }
.table-sosa { border-collapse: collapse; margin: 10px 0; font-size: 14px; }
.table-sosa th, .table-sosa td { border: 1px solid var(--bord); padding: 6px 12px; text-align: left; }
.table-sosa th { background: var(--accent-clair); color: var(--accent-fonce); }

/* ---------- Dialogue ---------- */
dialog {
  border: 1px solid var(--bord);
  border-radius: 12px;
  box-shadow: 0 10px 40px rgba(0, 0, 0, .2);
  padding: 20px;
  width: min(430px, 92vw);
}
dialog::backdrop { background: rgba(44, 40, 37, .45); }
dialog h3 { margin: 0 0 12px; }
dialog label { display: flex; flex-direction: column; gap: 4px; font-size: 13.5px; font-weight: 600; color: var(--encre-2); margin-bottom: 10px; flex: 1; }
dialog input, dialog select { padding: 8px 10px; border: 1px solid var(--bord); border-radius: 7px; font-size: 14.5px; }
dialog .rangee { display: flex; gap: 10px; }
dialog .rangee.boutons { justify-content: flex-end; margin-top: 6px; }
dialog .note { font-size: 12.5px !important; }

/* ---------- Toasts ---------- */
.toasts {
  position: fixed;
  bottom: 16px;
  right: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 100;
  max-width: 440px;
}
.toast {
  background: #33302b;
  color: #f5f2ec;
  padding: 11px 15px;
  border-radius: 10px;
  font-size: 13.5px;
  box-shadow: 0 6px 24px rgba(0, 0, 0, .3);
  animation: apparition .25s ease-out;
  line-height: 1.5;
}
.toast code { background: rgba(255, 255, 255, .13); color: #ffd9a0; display: block; margin-top: 6px; padding: 6px 8px; white-space: pre-wrap; word-break: break-word; }
.toast.erreur { background: #6e2f2f; }
@keyframes apparition { from { transform: translateY(10px); opacity: 0; } to { transform: none; opacity: 1; } }

.cache { display: none !important; }

/* ============================================================
   Écrans étroits et tactiles (tablette, téléphone)
   ============================================================ */

/* ---------- Doigt plutôt que souris : cibles plus grandes,
   pas de raccourcis clavier, pas de zoom iOS sur les champs ---------- */
@media (pointer: coarse) {
  .btn kbd { display: none; }
  .btn { padding: 9px 14px; }
  .btn-mini { padding: 6px 10px; }
  .controles-zoom button { width: 44px; height: 44px; font-size: 22px; }
  .lecon-item { padding-top: 9px; padding-bottom: 9px; }
  .proche { padding: 9px 10px; }
  .puce { padding: 8px 13px; }
  /* En dessous de 16px, iOS zoome la page à chaque focus d'un champ. */
  input, select, textarea { font-size: 16px !important; }
}

/* ---------- Tablette ---------- */
@media (max-width: 900px) {
  .astuce { display: none; }
  .panneau { width: min(330px, 86vw); }

  /* Console SQL : la liste des leçons se replie derrière son titre
     (JS : clic sur le h2 → classe .ouvert sur .colonne-lecons). */
  #page-sql.actif { grid-template-columns: 1fr; grid-template-rows: auto minmax(0, 1fr); }
  .colonne-lecons {
    max-height: none;
    border-right: 0;
    border-bottom: 1px solid var(--bord);
    padding: 10px 14px;
  }
  .colonne-lecons h2 {
    margin: 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
  }
  .colonne-lecons h2::after { content: '▾'; color: var(--encre-2); font-size: 14px; transition: transform .15s; }
  .colonne-lecons.ouvert h2::after { transform: rotate(180deg); }
  .colonne-lecons .intro-lecons, .colonne-lecons #liste-lecons { display: none; }
  .colonne-lecons.ouvert .intro-lecons { display: block; margin-top: 8px; }
  .colonne-lecons.ouvert #liste-lecons { display: block; max-height: 45vh; overflow-y: auto; }
}

/* ---------- Téléphone ---------- */
@media (max-width: 700px) {
  /* En-tête sur deux rangées : marque + actions, puis onglets pleine largeur */
  .entete { padding: 8px 10px; gap: 6px 8px; }
  .marque { flex: 1; gap: 8px; }
  .marque .logo { font-size: 24px; }
  .marque strong { font-size: 16px; }
  .marque .sous-titre { display: none; }
  .btn .libelle { display: none; }          /* 🔄 et 💾 deviennent des icônes */
  .onglets { order: 3; flex-basis: 100%; gap: 6px; }
  .onglets a { flex: 1; text-align: center; padding: 8px 4px; font-size: 14px; }

  /* Page arbre : la recherche prend toute la largeur, l'arbre colle aux bords */
  .barre-arbre { padding: 8px 10px; gap: 8px; }
  .zone-recherche { flex: 1 1 100%; }
  #recherche { width: 100%; }
  .menu-recherche { width: 100%; }
  .bandeau-relation { margin: 0 10px 8px; padding: 9px 12px; font-size: 13.5px; }
  .zone-arbre { margin: 0 10px 10px; }

  /* La fiche personne devient un panneau posé en bas de l'écran */
  .panneau {
    top: auto;
    left: 8px;
    right: 8px;
    bottom: 8px;
    width: auto;
    max-height: min(55%, 420px);
    box-shadow: 0 -6px 28px rgba(44, 40, 37, .22);
  }

  /* Console SQL : plus aérée en largeur, boutons qui passent à la ligne */
  .colonne-console { padding: 10px; gap: 10px; }
  .carte { padding: 12px; }
  #editeur-sql { height: 110px; padding: 11px 12px; }
  .barre-editeur { flex-wrap: wrap; gap: 8px; padding: 8px 10px; }
  #historique { max-width: none; flex: 1 1 120px; min-width: 0; }
  .memo-contenu { grid-template-columns: 1fr; }

  /* Page Comprendre */
  .colonne-concepts { padding: 14px 10px 40px; }
  .table-sosa { display: block; overflow-x: auto; }

  /* Dialogue et toasts */
  dialog .rangee { flex-wrap: wrap; }
  dialog .rangee label { min-width: 150px; }
  .toasts { left: 12px; right: 12px; bottom: 12px; max-width: none; }
}
