:root{
  /* Brand */
  --navy:#013861;--navy-d:#012850;--navy-dd:#011d3d;--navy-l:#024a80;
  --blue:#0a84d0;--blue-l:#4db8ff;--blue-pale:#e8f4fd;
  /* Neutrals (corporate-grade) */
  --white:#ffffff;--off:#f6f8fb;
  --gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e4ebf2;--gray-300:#cdd9e5;
  --bd:#dbe4ef;--bd-dark:rgba(255,255,255,0.09);
  /* Text */
  --tx:#0d2340;--tx-mid:#4a6080;--tx-soft:#8aa4bf;
  /* Status */
  --ok:#10b981;--err:#ef4444;--warn:#f59e0b;
  /* Elevation (layered shadows for depth without flashiness) */
  --sh1:0 1px 2px rgba(15,38,68,0.06),0 1px 3px rgba(15,38,68,0.04);
  --sh2:0 2px 4px rgba(15,38,68,0.06),0 4px 12px rgba(15,38,68,0.06);
  --sh3:0 6px 16px rgba(15,38,68,0.08),0 12px 32px rgba(15,38,68,0.10);
  /* Radii (consistent scale) */
  --r-xs:4px;--r-sm:6px;--r:10px;--r-md:12px;--r-lg:16px;--r-pill:999px;
  /* Motion (consistent easing) */
  --ease:cubic-bezier(.4,0,.2,1);--ease-out:cubic-bezier(.16,1,.3,1);
  /* Type */
  --font:'Plus Jakarta Sans','Segoe UI',-apple-system,system-ui,sans-serif;
  --mono:'IBM Plex Mono','SF Mono',Consolas,monospace;
  /* Layout */
  --sw:300px;
  /* Focus ring (a11y) */
  --ring:0 0 0 3px rgba(10,132,208,0.35);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
*:focus{outline:none}
*:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--r-sm)}
/* Le focus est géré par le parent .input-box (focus-within) */
#user-input:focus-visible{box-shadow:none}
html,body{height:100%;height:100dvh;overflow:hidden}

/* ── Onboarding (1ʳᵉ connexion, style Microsoft OOBE) ─────────────────── */
.ob-overlay{
  position:fixed;inset:0;z-index:9998;
  background:linear-gradient(135deg,var(--navy-dd) 0%,var(--navy) 55%,var(--navy-l) 100%);
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  animation:obFadeIn .4s ease;
  padding:24px;
}
@keyframes obFadeIn{from{opacity:0}to{opacity:1}}
.ob-overlay.ob-leaving{animation:obFadeOut .6s ease forwards}
@keyframes obFadeOut{to{opacity:0;visibility:hidden}}

/* Auroras bleues qui dérivent en fond — dérivés du bleu Dukiwi */
.ob-aurora{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;pointer-events:none}
.ob-aurora-1{
  width:60vw;height:60vw;top:-15vw;left:-10vw;
  background:radial-gradient(circle,var(--blue-l) 0%,var(--blue) 50%,transparent 80%);
  animation:obDrift1 16s ease-in-out infinite alternate
}
.ob-aurora-2{
  width:55vw;height:55vw;bottom:-20vw;right:-15vw;
  background:radial-gradient(circle,#5eb8ff 0%,var(--blue) 60%,transparent 85%);
  animation:obDrift2 22s ease-in-out infinite alternate
}
.ob-aurora-3{
  width:45vw;height:45vw;top:30%;left:35%;
  background:radial-gradient(circle,#87cefa 0%,var(--blue-l) 50%,transparent 80%);
  animation:obDrift3 18s ease-in-out infinite alternate;
  opacity:.35
}
@keyframes obDrift1{0%{transform:translate(0,0) scale(1)}100%{transform:translate(15vw,10vh) scale(1.15)}}
@keyframes obDrift2{0%{transform:translate(0,0) scale(.95)}100%{transform:translate(-12vw,-8vh) scale(1.10)}}
@keyframes obDrift3{0%{transform:translate(-10%,-10%) scale(1)}100%{transform:translate(10%,15%) scale(.92)}}

/* Contenu principal — positionnement absolu pour ancrer la DERNIÈRE ligne
   exactement au centre vertical, et l'input juste en-dessous. */
.ob-content{
  position:absolute;inset:0;
  z-index:2;color:#fff;
}
.ob-text{
  position:absolute;
  left:50%;bottom:50%;
  transform:translateX(-50%);
  width:100%;max-width:680px;
  padding:0 24px;
  min-height:260px;
  font-family:var(--font);
  font-size:clamp(22px,4vw,38px);
  font-weight:300;
  line-height:1.35;letter-spacing:-.4px;
  text-align:center;
  text-shadow:0 2px 30px rgba(0,0,0,0.25);
}
/* Chaque ligne est positionnée en absolu au "bas virtuel" du conteneur.
   Quand une nouvelle ligne arrive, on incrémente data-age des précédentes —
   la transition CSS sur transform fait l'animation smooth (rien ne saute). */
.ob-line{
  position:absolute;left:0;right:0;bottom:0;
  text-align:center;
  transform:translateY(28px);
  opacity:0;
  /* Glide doux et continu (cubic-bezier symétrique) — pas de front-load
     comme avec var(--ease-out) qui faisait sauter la ligne en 200ms */
  transition:transform 1.4s cubic-bezier(0.4,0,0.2,1),opacity 1.1s ease-in-out;
  will-change:transform,opacity
}
.ob-line[data-age="0"]{transform:translateY(0);opacity:1}
.ob-line[data-age="1"]{transform:translateY(-3em);opacity:.45}
.ob-line[data-age="2"]{transform:translateY(-5.5em);opacity:.18}
.ob-line[data-age="3"]{transform:translateY(-8em);opacity:0}
/* Mots individuels — apparition décalée pour effet "stream" */
.ob-word{display:inline-block;opacity:0;transform:translateY(8px);animation:obWord .55s var(--ease-out) forwards}
@keyframes obWord{to{opacity:1;transform:translateY(0)}}

/* 3 points qui pulsent — indique que Dukiwi réfléchit avant de répondre */
.ob-thinking{
  position:absolute;left:50%;top:50%;
  transform:translateX(-50%);
  margin-top:24px;
  display:flex;gap:8px;
  opacity:0;transition:opacity .25s ease;
  pointer-events:none
}
.ob-thinking[hidden]{display:none!important}
.ob-thinking.visible{opacity:.75;display:flex}
.ob-thinking-dot{
  width:9px;height:9px;border-radius:50%;background:#fff;
  animation:obDot 1.2s ease-in-out infinite
}
.ob-thinking-dot:nth-child(2){animation-delay:.15s}
.ob-thinking-dot:nth-child(3){animation-delay:.30s}
@keyframes obDot{
  0%,80%,100%{transform:scale(.55);opacity:.35}
  40%{transform:scale(1);opacity:1}
}

/* Input ultra-discret — positionné juste sous le centre vertical (où s'arrête le texte) */
.ob-input-wrap{
  position:absolute;
  left:50%;top:50%;
  transform:translateX(-50%);
  margin-top:32px;
  display:flex;align-items:center;gap:8px;
  width:100%;max-width:520px;
  border-bottom:1.5px solid rgba(255,255,255,0.55);
  box-shadow:0 1px 0 0 rgba(255,255,255,0.10);
  transition:border-color .2s
  padding:6px 24px 8px;
}
/* Override pour que [hidden] gagne sur display:flex (sinon le form
   reste visible après submit alors qu'on a posé form.hidden = true) */
.ob-input-wrap[hidden]{display:none!important}
.ob-input-wrap:focus-within{border-bottom-color:rgba(255,255,255,0.85)}

/* Compteur de progression du profil — en haut à droite de l'overlay onboarding */
.ob-counter{
  position:absolute;
  top:max(20px, env(safe-area-inset-top, 0px));
  right:24px;
  z-index:10;
  display:inline-flex;align-items:baseline;gap:2px;
  font-family:var(--mono, 'IBM Plex Mono', monospace);
  font-size:13px;font-weight:600;letter-spacing:.4px;
  color:rgba(255,255,255,0.92);
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.22);
  border-radius:999px;
  padding:6px 14px;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  transition:transform .25s var(--ease, ease-out);
}
.ob-counter[hidden]{display:none!important}
.ob-counter-sep{margin:0 1px;opacity:.55}
.ob-counter-label{font-family:var(--font, system-ui, sans-serif);font-size:10.5px;font-weight:500;text-transform:uppercase;letter-spacing:.6px;margin-left:7px;padding-left:8px;border-left:1px solid rgba(255,255,255,0.20);opacity:.78}
.ob-counter.is-bumped{animation:obCounterBump .35s ease-out}

/* ── Carte Profil (desktop only) ─────────────────────────────────── */
.ob-profile-card{
  position:absolute;
  top:50%;left:32px;
  transform:translateY(-50%);
  width:280px;max-width:32vw;
  padding:22px 24px 20px;
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.16);
  border-radius:18px;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:0 8px 32px rgba(0,0,0,0.20);
  color:#fff;z-index:5;
  transition:opacity .35s, transform .35s;
}
.ob-profile-card[hidden]{display:none!important}
.ob-pc-head{
  font-size:10.5px;font-weight:700;letter-spacing:1.6px;
  text-transform:uppercase;color:rgba(255,255,255,0.55);
  border-bottom:1px solid rgba(255,255,255,0.12);
  padding-bottom:10px;margin-bottom:14px;
}
.ob-pc-body{display:flex;flex-direction:column;gap:7px}
.ob-pc-name{
  font-size:18px;font-weight:700;letter-spacing:-.3px;line-height:1.3;
  color:#fff;margin-bottom:4px;
}
.ob-pc-name:empty{display:none}
.ob-pc-line{
  font-size:13.5px;font-weight:400;line-height:1.45;
  color:rgba(255,255,255,0.82);
  opacity:0;transform:translateY(4px);
  animation:obPcLineIn .4s ease-out forwards;
}
.ob-pc-line:empty{display:none;animation:none}
@keyframes obPcLineIn{
  to{opacity:1;transform:translateY(0)}
}

/* Masque en mobile / tablette */
@media (max-width:1063px){
  .ob-profile-card{display:none!important}
}

/* ── Grille « Centres d'intérêt » — sous le texte, petits carrés ─── */
.ob-interests{
  position:absolute;
  left:50%;
  top:calc(50% + 60px);                /* sous le texte centré du dessus */
  transform:translateX(-50%);
  width:min(720px, calc(100vw - 32px));
  display:flex;flex-direction:column;gap:12px;
  z-index:4;
}
.ob-interests[hidden]{display:none!important}
.ob-int-grid{
  display:grid;
  grid-template-columns:repeat(6, 1fr); /* 6 colonnes × 2 rangées = 12 */
  gap:8px;
}
.ob-int-card{
  position:relative;aspect-ratio:1/1;
  border:1.5px solid rgba(255,255,255,0.20);
  border-radius:10px;overflow:hidden;
  background:#013861;                  /* fond bleu dukiwi de secours */
  cursor:pointer;padding:0;
  transition:border-color .18s, transform .18s, box-shadow .18s;
}
.ob-int-card img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;
  transition:transform .35s, filter .25s;
}
/* Filigrane bleu dukiwi par-dessus l'image */
.ob-int-card::after{
  content:'';position:absolute;inset:0;
  background:rgba(1, 29, 61, 0.55);
  mix-blend-mode:multiply;
  pointer-events:none;
  transition:background .2s;
}
.ob-int-card:hover{border-color:rgba(255,255,255,0.55);transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,0.30)}
.ob-int-card:hover img{transform:scale(1.06)}
.ob-int-card:hover::after{background:rgba(1, 29, 61, 0.35)}
.ob-int-label{
  position:absolute;inset:0;
  display:grid;place-items:center;
  padding:4px 6px;text-align:center;
  color:#fff;font-weight:700;font-size:12px;letter-spacing:-.1px;line-height:1.15;
  text-shadow:0 1px 4px rgba(0,0,0,0.55);
  z-index:1;pointer-events:none;
}
.ob-int-tick{
  position:absolute;top:4px;right:4px;
  width:20px;height:20px;border-radius:50%;
  background:#10b981;color:#fff;
  display:grid;place-items:center;font-size:11px;font-weight:700;
  opacity:0;transform:scale(.6);
  transition:opacity .18s, transform .18s;
  z-index:2;
  box-shadow:0 2px 6px rgba(0,0,0,0.45);
}
.ob-int-card.is-picked{
  border-color:#10b981;
  box-shadow:0 0 0 2px rgba(16,185,129,0.45), 0 6px 18px rgba(0,0,0,0.35);
}
.ob-int-card.is-picked::after{background:rgba(16, 185, 129, 0.30)}
.ob-int-card.is-picked .ob-int-tick{opacity:1;transform:scale(1)}

.ob-int-foot{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding:0 2px;
}
.ob-int-count{
  font-size:12px;font-weight:500;letter-spacing:.2px;
  color:rgba(255,255,255,0.7);
  font-family:var(--mono, 'IBM Plex Mono', monospace);
}
.ob-int-count.is-ok{color:#34d399}
.ob-int-submit{
  padding:8px 22px;
  background:rgba(255,255,255,0.15);
  border:1px solid rgba(255,255,255,0.40);
  color:#fff;border-radius:999px;
  font-family:inherit;font-size:13px;font-weight:600;letter-spacing:.2px;
  cursor:pointer;transition:all .18s;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.ob-int-submit:hover:not(:disabled){background:rgba(255,255,255,0.28);transform:translateY(-1px)}
.ob-int-submit:disabled{opacity:.4;cursor:not-allowed}

@media (max-width:680px){
  .ob-int-grid{grid-template-columns:repeat(4, 1fr)}  /* 4 × 3 sur mobile */
  .ob-int-label{font-size:11px}
}

/* ── Overlay "Syndrome de la page blanche" — 30s d'inactivité ───── */
.cs-overlay{
  position:absolute;inset:0;z-index:50;
  background:linear-gradient(135deg,var(--navy-dd) 0%,var(--navy) 55%,var(--navy-l) 100%);
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  animation:csFadeIn .45s ease;
  border-radius:0;
}
/* Variante "full-page" — couvre toute la fenêtre, pas juste #messages */
.cs-overlay.cs-full{
  position:fixed;inset:0;z-index:9990;padding:0;
}
@keyframes csFadeIn{from{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}
.cs-overlay.cs-leaving{animation:csFadeOut .35s ease forwards}
@keyframes csFadeOut{to{opacity:0;transform:scale(.98)}}

/* Auroras (mêmes que l'onboarding) */
.cs-aurora{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5;pointer-events:none}
.cs-aurora-1{
  width:55vw;height:55vw;top:-15vw;left:-12vw;
  background:radial-gradient(circle,var(--blue-l) 0%,var(--blue) 50%,transparent 80%);
  animation:csDrift1 18s ease-in-out infinite alternate;
}
.cs-aurora-2{
  width:50vw;height:50vw;bottom:-15vw;right:-10vw;
  background:radial-gradient(circle,var(--blue) 0%,var(--navy-l) 60%,transparent 85%);
  animation:csDrift2 22s ease-in-out infinite alternate;
}
.cs-aurora-3{
  width:38vw;height:38vw;top:35%;left:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,var(--blue-l) 0%,transparent 70%);
  opacity:.35;animation:csDrift3 14s ease-in-out infinite alternate;
}
@keyframes csDrift1{to{transform:translate(8vw, 6vw) scale(1.1)}}
@keyframes csDrift2{to{transform:translate(-6vw,-5vw) scale(1.08)}}
@keyframes csDrift3{to{transform:translate(-50%,-50%) scale(1.18)}}

.cs-close{
  position:fixed;
  top:max(14px, env(safe-area-inset-top, 0px));
  right:max(18px, env(safe-area-inset-right, 0px));
  z-index:10;
  background:transparent;border:0;padding:4px;
  color:rgba(255,255,255,0.85);
  font-size:26px;line-height:1;font-family:inherit;font-weight:300;
  cursor:pointer;
  transition:color .15s, transform .15s;
}
.cs-close:hover{color:#fff;transform:scale(1.12)}

.cs-content{
  position:relative;z-index:1;
  max-width:760px;width:100%;
  text-align:center;color:#fff;
  display:flex;flex-direction:column;align-items:center;gap:18px;
}
.cs-title{
  font-size:clamp(22px, 3.4vw, 32px);font-weight:700;letter-spacing:-.4px;
  margin:0;line-height:1.15;
}
.cs-subtitle{
  font-size:clamp(13.5px, 1.6vw, 16px);font-weight:400;
  color:rgba(255,255,255,0.78);line-height:1.5;
  margin:0;max-width:560px;
}
.cs-items{
  display:grid;grid-template-columns:repeat(2, minmax(0,1fr));
  gap:12px;width:100%;margin-top:6px;
}
.cs-item{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;text-align:left;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.22);
  border-radius:14px;color:#fff;
  font-family:inherit;font-size:14px;font-weight:500;letter-spacing:-.1px;
  cursor:pointer;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:all .18s var(--ease-out, ease-out);
}
.cs-item:hover{
  background:rgba(255,255,255,0.18);
  border-color:rgba(255,255,255,0.55);
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(0,0,0,0.30);
}
.cs-icon{
  font-size:22px;line-height:1;flex-shrink:0;
  display:grid;place-items:center;
  width:38px;height:38px;border-radius:10px;
  background:rgba(255,255,255,0.12);
}
.cs-label{flex:1;font-size:13.5px;line-height:1.35}
.cs-or{
  margin:8px 0 0;font-size:12.5px;font-style:italic;
  color:rgba(255,255,255,0.55);letter-spacing:.2px;
}

@media (max-width:680px){
  .cs-items{grid-template-columns:1fr}
  .cs-content{gap:14px}
  .cs-item{padding:12px 14px}
  .cs-icon{width:32px;height:32px;font-size:18px}
}

/* ── Dashboard full-page : météo + horloge + speech + news ──────── */
.cs-topbar{
  position:absolute;top:0;left:0;right:0;
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:24px;z-index:3;pointer-events:none;
  color:#fff;gap:24px;
}
.cs-weather{
  display:flex;flex-direction:column;gap:10px;
  pointer-events:auto;
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.16);
  border-radius:14px;padding:14px 16px;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  width:280px;box-sizing:border-box;
}
.cs-weather:empty{display:none}
.cs-weather-now{display:flex;align-items:center;gap:14px}
.cs-w-icon{font-size:36px;line-height:1}
.cs-w-temp{font-size:26px;font-weight:700;letter-spacing:-.5px;line-height:1.05}
.cs-w-label{font-size:11.5px;color:rgba(255,255,255,0.72);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}
.cs-weather-hourly{
  display:grid;grid-template-columns:repeat(4, 1fr);gap:8px;
  padding-top:10px;border-top:1px solid rgba(255,255,255,0.10);
}
.cs-w-hour{
  text-align:center;color:#fff;
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.cs-wh-time{font-size:10.5px;color:rgba(255,255,255,0.58);font-family:var(--mono, 'IBM Plex Mono', monospace);letter-spacing:.4px}
.cs-wh-icon{font-size:18px;line-height:1}
.cs-wh-temp{font-size:13px;font-weight:600}

.cs-clock{
  font-family:var(--mono, 'IBM Plex Mono', monospace);
  font-size:clamp(38px, 5.5vw, 64px);
  font-weight:300;letter-spacing:-1px;line-height:1;
  color:rgba(255,255,255,0.92);
  text-shadow:0 2px 16px rgba(0,0,0,0.25);
  position:absolute;left:50%;top:32px;transform:translateX(-50%);
}
.cs-cl-sep{opacity:.45;animation:csBlink 1.05s steps(2,end) infinite}
@keyframes csBlink{50%{opacity:.1}}

/* Speech scrollable au centre — top padding réserve la place de la topbar/horloge */
.cs-scroll{
  position:relative;z-index:2;
  width:min(720px, calc(100vw - 48px));
  height:100vh;max-height:100vh;
  overflow-y:auto;
  padding:160px 16px 160px;        /* top: clock+weather, bottom: news + marge */
  scroll-padding-top:160px;        /* scrollIntoView laisse 160px de marge en haut */
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.20) transparent;
  scroll-behavior:smooth;
  mask-image:linear-gradient(to bottom, transparent 0, transparent 130px, #000 170px, #000 calc(100% - 170px), transparent calc(100% - 130px), transparent 100%);
  -webkit-mask-image:linear-gradient(to bottom, transparent 0, transparent 130px, #000 170px, #000 calc(100% - 170px), transparent calc(100% - 130px), transparent 100%);
}
.cs-scroll::-webkit-scrollbar{width:5px}
.cs-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.20);border-radius:3px}
.cs-spacer{display:none}  /* remplacé par le padding-top/bottom du .cs-scroll */

.cs-fade{
  opacity:0;transform:translateY(18px);
  transition:opacity .55s ease, transform .55s ease;
  color:#fff;
}
.cs-fade.is-in{opacity:1;transform:translateY(0)}

.cs-intro{
  font-size:clamp(13px, 1.5vw, 15px);
  text-transform:uppercase;letter-spacing:3.5px;
  color:rgba(255,255,255,0.55);
  margin:0 0 14px;font-weight:600;
  text-align:center;
}
.cs-topic{
  font-size:clamp(24px, 3.5vw, 34px);
  font-weight:700;letter-spacing:-.5px;line-height:1.2;
  margin:0 0 24px;color:#fff;
  text-align:left;
}
.cs-para{
  font-size:clamp(16px, 1.7vw, 18.5px);
  font-weight:300;line-height:1.7;
  color:rgba(255,255,255,0.92);
  margin:0 0 22px;max-width:68ch;
  text-align:justify;
  text-align-last:left;
  hyphens:auto;
}

/* Apparition mot par mot — chaque .cs-word a transition-delay inline */
.cs-word{
  display:inline-block;
  opacity:0;transform:translateY(8px);
  transition:opacity .45s ease-out, transform .45s ease-out;
  will-change:opacity, transform;
}
.cs-fade.is-in .cs-word{opacity:1;transform:translateY(0)}

/* Markdown inline dans les paragraphes (rendu par applyInlineMd côté JS) */
.cs-para strong, .cs-topic strong{font-weight:700;color:#fff}
.cs-para em{font-style:italic;color:rgba(255,255,255,0.95)}
.cs-code{
  font-family:var(--mono, 'IBM Plex Mono', monospace);
  font-size:.9em;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:4px;
  padding:1px 6px;
  color:#fff;
}
.cs-questions{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start;
  margin:32px 0 0;max-width:680px;
}
.cs-qbtn{
  padding:9px 18px;
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.30);
  color:#fff;border-radius:999px;
  font-family:inherit;font-size:13px;font-weight:500;letter-spacing:-.1px;
  cursor:pointer;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:all .18s var(--ease-out, ease-out);
}
.cs-qbtn:hover{background:rgba(255,255,255,0.20);border-color:rgba(255,255,255,0.55);transform:translateY(-2px)}

/* Badge modèle LLM — bas centre, discret */
.cs-modelbadge{
  position:fixed;
  bottom:max(12px, env(safe-area-inset-bottom, 0px));
  left:50%;transform:translateX(-50%);
  z-index:5;pointer-events:none;
  font-family:var(--mono, 'IBM Plex Mono', monospace);
  font-size:10.5px;letter-spacing:.4px;
  color:rgba(255,255,255,0.45);
  padding:4px 12px;border-radius:999px;
  background:rgba(0,0,0,0.20);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}

/* Bouton Pause : flotte en haut à droite, à côté de la croix */
.cs-pause{
  position:fixed;top:max(14px, env(safe-area-inset-top, 0px));right:60px;z-index:10;
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 14px;border-radius:999px;
  background:rgba(255,255,255,0.10);color:#fff;
  border:1px solid rgba(255,255,255,0.22);
  font-family:inherit;font-size:12.5px;font-weight:500;letter-spacing:.2px;
  cursor:pointer;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:background .15s, transform .15s;
}
.cs-pause:hover{background:rgba(255,255,255,0.20);transform:translateY(-1px)}
.cs-pause-icon{font-size:13px;line-height:1}
.cs-pause.is-paused{background:rgba(16,185,129,0.25);border-color:rgba(16,185,129,0.55)}

/* Sections de step empilées : séparation douce + animation d'apparition */
.cs-step{
  display:flex;flex-direction:column;
  padding:32px 0;
  border-bottom:1px solid rgba(255,255,255,0.08);
  animation:csStepIn .55s ease-out;
}
.cs-step:last-of-type{border-bottom:none}
@keyframes csStepIn{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

/* Indicateur de chargement (3 dots animés) */
.cs-status{
  display:flex;justify-content:center;align-items:center;
  gap:8px;height:32px;margin:24px 0;
  opacity:0;transition:opacity .25s;
}
.cs-status.is-in{opacity:0}
.cs-status.is-loading{opacity:1}
.cs-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,0.55);
  animation:csDotPulse 1.2s ease-in-out infinite;
}
.cs-dot:nth-child(2){animation-delay:.15s}
.cs-dot:nth-child(3){animation-delay:.30s}
@keyframes csDotPulse{
  0%,100%{transform:scale(.6);opacity:.3}
  50%{transform:scale(1.1);opacity:1}
}
.cs-end{
  color:rgba(255,255,255,0.55);font-size:12.5px;font-style:italic;letter-spacing:.2px;
}

/* TOC sidebar gauche — desktop uniquement, alignée avec weather/news.
   Weather ≈ 170px de haut (24px padding + ~140px). News ≈ 145px de haut.
   Marge 15px entre chaque bloc. */
.cs-toc{
  position:absolute;left:24px;
  top:calc(24px + 170px + 15px);       /* sous weather + gap 15px */
  bottom:calc(24px + 145px + 125px);   /* au-dessus de news + marge réelle */
  width:280px;box-sizing:border-box;z-index:3;
  display:flex;flex-direction:column;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:14px;padding:14px 16px 10px;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  color:#fff;pointer-events:auto;
  overflow:hidden;
}
.cs-toc-head{
  font-size:10.5px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;
  color:rgba(255,255,255,0.55);margin-bottom:10px;
  border-bottom:1px solid rgba(255,255,255,0.10);padding-bottom:8px;
}
.cs-toc-list{
  list-style:none;margin:0;padding:2px 0;
  display:flex;flex-direction:column;gap:4px;
  overflow-y:auto;flex:1;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.20) transparent;
}
.cs-toc-list::-webkit-scrollbar{width:4px}
.cs-toc-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.20);border-radius:2px}
.cs-toc-link{
  display:flex;align-items:flex-start;gap:8px;
  padding:6px 8px;border-radius:8px;
  text-decoration:none;color:rgba(255,255,255,0.78);
  font-size:12px;line-height:1.35;font-weight:400;
  transition:background .12s, color .12s;
  border-left:2px solid transparent;
}
.cs-toc-link:hover{background:rgba(255,255,255,0.10);color:#fff;border-left-color:var(--blue-l, #5db9f6)}
.cs-toc-idx{
  font-family:var(--mono, 'IBM Plex Mono', monospace);
  font-size:10px;font-weight:600;color:rgba(255,255,255,0.40);
  flex-shrink:0;margin-top:1px;
}

/* Masque la TOC sur mobile */
@media (max-width:1100px){
  .cs-toc{display:none}
}

/* Décale le scroll principal pour ne pas chevaucher la TOC (280px + 24px + 40px gap) */
@media (min-width:1101px){
  .cs-scroll{margin-left:170px}
}

/* Bouton "Inspire-moi" — topbar + welcome screen */
.tb-inspire{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:50%;
  background:rgba(10,132,208,0.12);color:var(--blue, #0a84d0);
  border:1px solid rgba(10,132,208,0.25);
  cursor:pointer;flex-shrink:0;margin-right:8px;
  transition:background .15s, transform .15s, color .15s;
}
.tb-inspire:hover{background:rgba(10,132,208,0.22);color:var(--navy, #013861);transform:scale(1.06)}

.wlc-inspire{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 18px;margin:12px auto 0;
  background:rgba(10,132,208,0.10);color:var(--navy, #013861);
  border:1px solid rgba(10,132,208,0.25);border-radius:999px;
  font-family:inherit;font-size:13px;font-weight:600;letter-spacing:.1px;
  cursor:pointer;
  transition:all .15s;
}
.wlc-inspire:hover{background:rgba(10,132,208,0.20);transform:translateY(-1px);box-shadow:0 4px 12px rgba(10,132,208,0.18)}
.wlc-inspire svg{flex-shrink:0}

/* News 20min : bas gauche — même largeur que weather et TOC */
.cs-news{
  position:absolute;left:24px;bottom:24px;z-index:3;
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.16);
  border-radius:14px;padding:12px 16px;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  width:280px;box-sizing:border-box;color:#fff;
  pointer-events:auto;
}
.cs-news-head{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.65);margin-bottom:8px}
.cs-news-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.cs-news-list li{font-size:12.5px;line-height:1.4}
.cs-news-list a{
  color:rgba(255,255,255,0.85);text-decoration:none;
  display:block;padding:3px 0;
  border-left:2px solid transparent;padding-left:8px;margin-left:-2px;
  transition:color .15s, border-color .15s;
}
.cs-news-list a:hover{color:#fff;border-left-color:var(--blue-l, #5db9f6)}

/* ── Mobile : weather & news en pills collapsées, expand au clic ── */
@media (max-width:1100px){
  /* Topbar row compacte, alignée verticalement */
  .cs-topbar{padding:14px 70px 14px 14px;gap:10px;align-items:center}  /* padding-right pour laisser la croix */
  .cs-clock{
    position:static;transform:none;
    font-size:clamp(22px, 4.5vw, 30px);
    order:2;flex:1;text-align:center;
    color:rgba(255,255,255,0.85);
  }

  /* Pause descend en bas (au-dessus du badge modèle) */
  .cs-pause{
    top:auto;right:auto;
    bottom:calc(max(12px, env(safe-area-inset-bottom, 0px)) + 36px);
    left:50%;transform:translateX(-50%);
  }

  /* Badge modèle reste en bas mais plus haut sur mobile pour ne pas chevaucher news */
  .cs-modelbadge{bottom:max(8px, env(safe-area-inset-bottom, 0px))}

  /* Weather : par défaut collapsée = petite pastille icon + temp */
  .cs-weather{
    cursor:pointer;
    width:auto;padding:6px 12px;border-radius:999px;
    transition:padding .2s, border-radius .2s, width .2s;
  }
  .cs-weather.is-collapsed{padding:6px 12px;border-radius:999px;width:auto}
  .cs-weather.is-collapsed .cs-w-label{display:none}
  .cs-weather.is-collapsed .cs-weather-hourly{display:none}
  .cs-weather.is-collapsed .cs-weather-now{gap:6px}
  .cs-weather.is-collapsed .cs-w-icon{font-size:22px}
  .cs-weather.is-collapsed .cs-w-temp{font-size:16px}
  .cs-weather.is-collapsed .cs-w-text{display:inline}
  /* Quand on l'expand : carte normale, posée par-dessus le contenu */
  .cs-weather:not(.is-collapsed){
    position:absolute;top:14px;left:14px;z-index:6;
    width:min(280px, calc(100vw - 28px));padding:14px 16px;
    border-radius:14px;
  }

  /* News : par défaut collapsée = "📰 News" */
  .cs-news{
    cursor:pointer;left:14px;bottom:14px;right:auto;
    width:auto;padding:6px 14px;border-radius:999px;
    transition:padding .2s, border-radius .2s, width .2s;
  }
  .cs-news.is-collapsed{padding:6px 14px;border-radius:999px;width:auto}
  .cs-news.is-collapsed .cs-news-list{display:none}
  .cs-news.is-collapsed .cs-news-head{
    margin:0;font-size:12px;letter-spacing:.8px;color:rgba(255,255,255,0.95);
    border:0;padding:0;
  }
  /* Expand : redevient carte */
  .cs-news:not(.is-collapsed){
    width:min(280px, calc(100vw - 28px));
    padding:12px 16px;border-radius:14px;
    z-index:6;
  }

  .cs-scroll{padding:90px 12px 80px}
}

/* ── Debug panel (π) — toujours accessible, log live ────────────── */
.dbg-toggle{
  position:fixed;right:14px;bottom:14px;z-index:9999;
  background:rgb(255 255 255 / 0%);color:#3966ad;border:0 solid rgba(255,255,255,0.18);
  font-family:'IBM Plex Mono', monospace;font-size:17px;
  cursor:pointer;place-items:center;
  -webkit-backdrop-filter:blur(8px);
}
.dbg-panel{
  position:fixed;right:14px;bottom:58px;z-index:9999;
  width:min(540px, calc(100vw - 28px));
  max-height:min(70vh, 600px);
  background:rgba(15,18,24,0.92);color:#eaeef5;
  border:1px solid rgba(255,255,255,0.12);border-radius:10px;
  box-shadow:0 12px 40px rgba(0,0,0,0.5);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  display:flex;flex-direction:column;overflow:hidden;
  font-family:'IBM Plex Mono', monospace;
}
.dbg-panel[hidden]{display:none}
.dbg-head{
  display:flex;align-items:center;gap:8px;
  padding:8px 10px;background:rgba(0,0,0,0.35);
  border-bottom:1px solid rgba(255,255,255,0.10);
}
.dbg-title{flex:1;font-size:12px;font-weight:600;letter-spacing:.4px;color:#a8c5ff}
.dbg-btn{
  background:rgba(255,255,255,0.06);color:#eaeef5;
  border:1px solid rgba(255,255,255,0.14);border-radius:6px;
  padding:3px 9px;font-family:inherit;font-size:11px;cursor:pointer;
}
.dbg-btn:hover{background:rgba(255,255,255,0.12)}
.dbg-body{
  flex:1;overflow-y:auto;overflow-x:hidden;
  padding:6px 8px 10px;font-size:11px;line-height:1.45;
}
.dbg-body::-webkit-scrollbar{width:6px}
.dbg-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.15);border-radius:3px}
.dbg-row{display:grid;grid-template-columns:88px 60px 1fr;gap:6px;padding:4px 0;border-bottom:1px solid rgba(255,255,255,0.05)}
.dbg-ts{color:#7a8aa3;font-size:10px}
.dbg-kind{font-size:10px;font-weight:700;letter-spacing:.5px;text-align:center;border-radius:3px;padding:1px 4px;align-self:start}
.dbg-REQ   .dbg-kind{background:rgba(59,130,246,0.20);color:#93c5fd}
.dbg-RES   .dbg-kind{background:rgba(16,185,129,0.20);color:#86efac}
.dbg-ERR   .dbg-kind{background:rgba(239,68,68,0.25);color:#fca5a5}
.dbg-THINK .dbg-kind{background:rgba(250,204,21,0.18);color:#fde68a}
.dbg-STATE .dbg-kind{background:rgba(168,85,247,0.20);color:#d8b4fe}
.dbg-USER  .dbg-kind{background:rgba(244,114,182,0.22);color:#fbcfe8}
.dbg-data{margin:0;white-space:pre-wrap;word-break:break-word;font-family:inherit;color:#dfe6f0;font-size:10.5px}
@keyframes obCounterBump{
  0%   {transform:scale(1)}
  50%  {transform:scale(1.10)}
  100% {transform:scale(1)}
}
.ob-input{
  flex:1;background:transparent;border:none;outline:none!important;
  box-shadow:none!important;
  font-family:var(--font);font-size:clamp(18px,3vw,26px);font-weight:300;
  color:#fff;text-align:left;letter-spacing:-.2px;
  padding:8px 4px;
  caret-color:#fff
}
/* Neutralise le focus-ring global (a11y) sur ce champ spécifiquement */
.ob-input:focus,.ob-input:focus-visible{outline:none!important;box-shadow:none!important}
.ob-input::placeholder{color:rgba(255,255,255,0.4);font-style:italic}
.ob-send{
  width:42px;height:42px;flex-shrink:0;
  background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.30);
  border-radius:50%;color:#fff;cursor:pointer;
  display:grid;place-items:center;
  transition:all .18s var(--ease);
  opacity:0;transform:scale(.8)
}
.ob-send.visible{opacity:1;transform:scale(1)}
.ob-send:hover{background:rgba(255,255,255,0.28);transform:scale(1.05)}
.ob-send:active{transform:scale(.95)}
.ob-send:disabled{opacity:.3;cursor:not-allowed;transform:scale(.85)}

/* ── Easter Egg overlay (clé Windows XP → code d'invitation) ──────────── */
.egg-overlay{
  position:fixed;inset:0;z-index:9999;
  background:linear-gradient(135deg,var(--navy-dd) 0%,var(--navy) 55%,var(--navy-l) 100%);
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  animation:obFadeIn .5s ease;
}
.egg-overlay[hidden]{display:none!important}
.egg-overlay.egg-leaving{animation:obFadeOut .6s ease forwards}

.egg-content{
  position:relative;z-index:2;
  text-align:center;color:#fff;
  max-width:640px;width:100%;
  text-shadow:0 2px 30px rgba(0,0,0,0.25);
}

/* La clé Windows XP en monospace, ambiance "DOS" */
.egg-key{
  font-family:var(--mono);
  font-size:clamp(11px,1.6vw,15px);
  color:rgba(255,255,255,0.45);
  letter-spacing:2px;
  margin-bottom:24px;
  opacity:0;
  animation:eggFade .7s ease .15s forwards;
}

.egg-title{
  font-family:var(--font);
  font-size:clamp(28px,5vw,46px);
  font-weight:300;letter-spacing:-.5px;
  line-height:1.2;
  margin-bottom:14px;
  opacity:0;
  animation:eggFadeUp .7s var(--ease-out) .4s forwards;
}

.egg-subtitle{
  font-size:clamp(14px,2vw,18px);
  font-weight:300;
  color:rgba(255,255,255,0.70);
  line-height:1.6;
  margin-bottom:40px;
  opacity:0;
  animation:eggFadeUp .7s var(--ease-out) .7s forwards;
}

.egg-code-label{
  font-size:11px;font-weight:600;letter-spacing:.8px;
  color:rgba(255,255,255,0.50);
  text-transform:uppercase;
  margin-bottom:14px;
  opacity:0;
  animation:eggFadeUp .6s var(--ease-out) 1.0s forwards;
}

/* Le code généré : grosse police monospace, "carte tirée" */
.egg-code{
  display:inline-block;
  font-family:var(--mono);
  font-size:clamp(40px,8vw,76px);
  font-weight:700;letter-spacing:8px;
  color:#fff;
  padding:24px 40px;
  background:rgba(255,255,255,0.08);
  border:2px dashed rgba(255,255,255,0.40);
  border-radius:14px;
  backdrop-filter:blur(10px);
  text-shadow:0 4px 24px rgba(255,255,255,0.30);
  margin-bottom:40px;
  opacity:0;transform:scale(.88);
  animation:eggCodeIn 1s var(--ease-out) 1.2s forwards;
}

.egg-actions{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
  opacity:0;
  animation:eggFadeUp .7s var(--ease-out) 1.7s forwards;
}
.egg-btn{
  padding:12px 26px;
  background:rgba(255,255,255,0.10);
  border:1.5px solid rgba(255,255,255,0.40);
  border-radius:26px;
  color:#fff;
  font-family:var(--font);font-size:14px;font-weight:600;
  cursor:pointer;text-decoration:none;
  letter-spacing:.3px;
  transition:all .2s var(--ease);
  backdrop-filter:blur(8px);
}
.egg-btn:hover{
  background:rgba(255,255,255,0.22);
  border-color:rgba(255,255,255,0.65);
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(255,255,255,0.18);
}
.egg-btn-primary{
  background:#fff;color:var(--navy);border-color:#fff;
  box-shadow:0 6px 22px rgba(255,255,255,0.22);
}
.egg-btn-primary:hover{background:rgba(255,255,255,0.92)}
.egg-btn-ghost{background:transparent;border-color:rgba(255,255,255,0.25);color:rgba(255,255,255,0.70)}
.egg-btn-ghost:hover{background:rgba(255,255,255,0.10);color:#fff}

@keyframes eggFade   {to{opacity:1}}
@keyframes eggFadeUp {from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)}}
@keyframes eggCodeIn {to{opacity:1;transform:scale(1)}}

/* Bouton final "Démarrer" — apparait après le message [DONE] de bienvenue */
.ob-start{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,0);
  margin-top:40px;
  padding:14px 40px;
  background:#fff;color:var(--navy);
  border:none;border-radius:30px;
  font-family:var(--font);font-size:16px;font-weight:600;
  cursor:pointer;
  letter-spacing:.3px;
  box-shadow:0 8px 28px rgba(255,255,255,0.22),0 2px 8px rgba(0,0,0,0.18);
  transition:transform .18s var(--ease),box-shadow .25s var(--ease);
  animation:obStartIn .55s var(--ease-out) both;
  z-index:3;
}
.ob-start[hidden]{display:none!important}
.ob-start:hover{
  transform:translate(-50%,-2px);
  box-shadow:0 12px 36px rgba(255,255,255,0.32),0 4px 14px rgba(0,0,0,0.22);
}
.ob-start:active{transform:translate(-50%,0)}
@keyframes obStartIn{
  from{opacity:0;transform:translate(-50%,16px)}
  to{opacity:1;transform:translate(-50%,0)}
}

/* Boutons de choix (Tu/Vous/Neutre, Homme/Femme/Neutre, etc.) */
.ob-choices{
  position:absolute;left:50%;top:50%;
  transform:translateX(-50%);
  margin-top:32px;
  display:flex;flex-wrap:wrap;gap:12px;justify-content:center;
  width:100%;max-width:520px;padding:0 24px;
}
.ob-choices[hidden]{display:none!important}
.ob-choice{
  padding:10px 22px;
  background:rgba(255,255,255,0.08);
  border:1.5px solid rgba(255,255,255,0.30);
  border-radius:24px;
  color:#fff;
  font-family:var(--font);font-size:15px;font-weight:500;
  cursor:pointer;
  transition:all .2s var(--ease);
  letter-spacing:.3px;
  backdrop-filter:blur(8px);
}
.ob-choice:hover{
  background:rgba(255,255,255,0.20);
  border-color:rgba(255,255,255,0.55);
  transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(0,0,0,0.18);
}
.ob-choice:active{transform:translateY(0)}
.ob-choice.is-confirmed{
  background:rgba(16,185,129,0.45);
  border-color:rgba(16,185,129,0.9);
  color:#fff;
  box-shadow:0 0 0 0 rgba(16,185,129,0.6);
  animation:obChoicePulse .55s ease-out;
}
.ob-choice.is-dimmed{opacity:.35;filter:saturate(.4);transition:opacity .25s, filter .25s}
.ob-choice:disabled{cursor:default}
@keyframes obChoicePulse{
  0%   {transform:translateY(0)   scale(1);    box-shadow:0 0 0 0   rgba(16,185,129,0.55)}
  40%  {transform:translateY(-2px) scale(1.04); box-shadow:0 0 0 12px rgba(16,185,129,0.0)}
  100% {transform:translateY(0)   scale(1);    box-shadow:0 0 0 0   rgba(16,185,129,0)}
}

/* Icône rouage — ouvre le panneau d'édition pendant l'onboarding */
.ob-gear{
  position:absolute;right:max(20px,env(safe-area-inset-right));
  bottom:max(80px,calc(env(safe-area-inset-bottom) + 70px));
  z-index:3;
  width:42px;height:42px;
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.25);
  border-radius:50%;
  display:grid;place-items:center;
  color:rgba(255,255,255,0.75);
  cursor:pointer;
  transition:all .2s var(--ease);
  backdrop-filter:blur(8px);
}
.ob-gear[hidden]{display:none!important}
.ob-gear:hover{
  background:rgba(255,255,255,0.20);
  color:#fff;
  transform:rotate(45deg);
}

/* Panneau d'édition — même esthétique que l'onboarding (fond bleu, texte blanc) */
.ob-edit-panel{
  position:fixed;inset:0;z-index:10000;
  background:linear-gradient(135deg,var(--navy-dd) 0%,var(--navy) 55%,var(--navy-l) 100%);
  display:flex;align-items:center;justify-content:center;
  padding:24px;overflow-y:auto;
  animation:obFadeIn .3s ease;
}
.ob-edit-panel[hidden]{display:none!important}
.ob-edit-card{
  width:100%;max-width:520px;
  padding:32px 24px;
  color:#fff;
  text-shadow:0 2px 30px rgba(0,0,0,0.25);
}
.ob-edit-head{
  font-family:var(--font);
  font-size:clamp(22px,4vw,32px);
  font-weight:300;letter-spacing:-.3px;
  text-align:center;
  margin-bottom:32px;
}
.ob-edit-row{margin-bottom:26px}
.ob-edit-label{
  display:block;
  font-size:11px;font-weight:600;
  color:rgba(255,255,255,0.55);
  margin-bottom:10px;
  text-transform:uppercase;letter-spacing:.8px;
  text-align:center;
}
/* Input texte : transparent, blanc, ligne en dessous (style onboarding) */
.ob-edit-input{
  width:100%;
  background:transparent;border:none;
  border-bottom:1px solid rgba(255,255,255,0.35);
  color:#fff;
  font-family:var(--font);
  font-size:clamp(17px,2.5vw,22px);font-weight:300;
  padding:6px 4px 10px;
  text-align:center;
  outline:none;
  transition:border-color .2s;
  caret-color:#fff;
}
.ob-edit-input:focus,.ob-edit-input:focus-visible{
  outline:none!important;box-shadow:none!important;
  border-bottom-color:#fff;
}

/* Boutons de choix dans le panneau — même style que ob-choice, état "selected" en surbrillance */
.ob-edit-choices{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;
}
.ob-edit-choice{
  padding:8px 20px;
  background:rgba(255,255,255,0.08);
  border:1.5px solid rgba(255,255,255,0.30);
  border-radius:24px;
  color:#fff;
  font-family:var(--font);font-size:14px;font-weight:500;
  cursor:pointer;
  transition:all .18s var(--ease);
  backdrop-filter:blur(8px);
  letter-spacing:.2px;
}
.ob-edit-choice:hover{
  background:rgba(255,255,255,0.18);
  border-color:rgba(255,255,255,0.50);
}
.ob-edit-choice.selected{
  background:#fff;
  border-color:#fff;
  color:var(--navy);
  font-weight:600;
  box-shadow:0 4px 16px rgba(255,255,255,0.18);
}

/* Actions — même look que les choix mais en pleine largeur */
.ob-edit-actions{
  display:flex;gap:12px;justify-content:center;
  margin-top:36px;padding-top:0;
}
.ob-edit-btn{
  padding:10px 24px;
  background:transparent;
  border:1.5px solid rgba(255,255,255,0.40);
  border-radius:24px;
  color:#fff;
  font-family:var(--font);font-size:14px;font-weight:600;
  cursor:pointer;
  transition:all .18s var(--ease);
  letter-spacing:.2px;
}
.ob-edit-cancel:hover{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.60)}
.ob-edit-save{background:#fff;color:var(--navy);border-color:#fff}
.ob-edit-save:hover{background:rgba(255,255,255,0.90);box-shadow:0 6px 20px rgba(255,255,255,0.18);transform:translateY(-1px)}

/* Badge Swiss made (au-dessus du logo) — style sweever.com adapté fond sombre */
.ob-swiss-made{
  position:absolute;left:50%;
  bottom:max(72px,calc(env(safe-area-inset-bottom) + 64px));
  transform:translateX(-50%);
  display:flex;align-items:center;gap:.5rem;
  font-family:var(--font);font-weight:600;font-size:13px;
  color:rgba(255,255,255,0.70);
  letter-spacing:.1px;white-space:nowrap;
  z-index:2;pointer-events:none;
  text-shadow:0 1px 8px rgba(0,0,0,0.30);
  animation:obLogoIn 1.2s ease 0.5s both;
}
.ob-swiss-made svg{
  width:18px;height:18px;flex-shrink:0;
  border-radius:2px;
  box-shadow:0 1px 4px rgba(0,0,0,0.25);
}
@media(max-width:1063px){
  .ob-swiss-made{font-size:12px;bottom:max(64px,calc(env(safe-area-inset-bottom) + 56px))}
  .ob-swiss-made svg{width:16px;height:16px}
}

/* Logo Dukiwi en bas de l'écran d'onboarding */
.ob-logo{
  position:absolute;left:50%;
  bottom:max(28px,env(safe-area-inset-bottom));
  transform:translateX(-50%);
  height:28px;width:auto;
  opacity:.65;
  z-index:2;pointer-events:none;
  filter:drop-shadow(0 2px 12px rgba(0,0,0,0.25));
  animation:obLogoIn 1.2s ease 0.4s both
}
@keyframes obLogoIn{from{opacity:0;transform:translate(-50%,8px)}to{opacity:.65;transform:translate(-50%,0)}}
@media(max-width:1063px){.ob-logo{height:24px;bottom:max(22px,env(safe-area-inset-bottom))}}

/* ── Bannière d'installation PWA ──────────────────────────────────────── */
.pwa-banner{
  position:fixed;top:0;left:0;right:0;z-index:10000;
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;
  padding-top:max(10px,env(safe-area-inset-top));
  background:linear-gradient(90deg,var(--navy) 0%,var(--blue) 100%);
  color:#fff;font-size:13px;font-weight:500;
  box-shadow:0 2px 12px rgba(0,0,0,0.18);
  animation:pwaSlideDown .35s var(--ease-out)
}
/* IMPORTANT : la règle .pwa-banner ci-dessus définit display:flex et écraserait
   le default [hidden]{display:none}. On force la priorité ici. Idem pour la modale. */
.pwa-banner[hidden],.pwa-ios-tip[hidden]{display:none!important}
@keyframes pwaSlideDown{from{transform:translateY(-100%)}to{transform:translateY(0)}}
.pwa-banner-icon{flex-shrink:0;width:22px;height:22px;color:#fff;opacity:.95}
.pwa-banner-text{flex:1;min-width:0;line-height:1.3}
.pwa-banner-cta{
  padding:7px 14px;background:#fff;color:var(--navy);
  border:none;border-radius:6px;font-family:var(--font);
  font-size:12.5px;font-weight:700;cursor:pointer;
  transition:transform .15s,box-shadow .15s;flex-shrink:0
}
.pwa-banner-cta:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,0.20)}
.pwa-banner-close{
  background:transparent;border:none;color:rgba(255,255,255,0.8);
  font-size:24px;line-height:1;cursor:pointer;padding:0 4px;flex-shrink:0;
  transition:color .15s
}
.pwa-banner-close:hover{color:#fff}

/* Modale instructions iOS */
.pwa-ios-tip{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:10001;
  background:#fff;border-radius:var(--r-md);box-shadow:var(--sh3);
  padding:22px 24px;max-width:340px;width:calc(100vw - 32px);
  animation:pwaPopIn .25s var(--ease-out)
}
@keyframes pwaPopIn{from{opacity:0;transform:translate(-50%,-48%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.pwa-ios-tip-head{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:14px}
.pwa-ios-tip ol{padding-left:22px;margin:0 0 18px;font-size:13.5px;line-height:1.7;color:var(--tx)}
.pwa-ios-tip li{margin-bottom:6px}
.pwa-ios-tip strong{color:var(--navy)}
.pwa-ios-close{
  width:100%;padding:10px;background:var(--navy);color:#fff;
  border:none;border-radius:var(--r-sm);
  font-family:var(--font);font-size:13.5px;font-weight:600;cursor:pointer;
  transition:background .15s
}
.pwa-ios-close:hover{background:var(--blue)}

/* Quand la bannière est visible, on pousse le contenu en-dessous */
body:has(.pwa-banner:not([hidden])) .app{margin-top:46px;height:calc(100dvh - 46px)}
@media(max-width:1063px){
  body:has(.pwa-banner:not([hidden])) .app{margin-top:54px;height:calc(100dvh - 54px)}
}
body{font-family:var(--font);font-size:14px;color:var(--tx);background:var(--off);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
optgroup{color:var(--navy);background:#81bef4}

/* LAYOUT */
.app{display:grid;grid-template-columns:var(--sw) 1fr;height:100vh;height:100dvh}

/* SIDEBAR */
.sidebar{background:var(--navy);display:flex;flex-direction:column;overflow:hidden;position:relative}
.sidebar::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 160% 80% at 50% -10%,rgba(10,132,208,0.18) 0%,transparent 70%)}
.sb-inner{position:relative;z-index:2;display:flex;flex-direction:column;height:100%}

/* Logo */
.logo-area{padding:16px 18px 14px;border-bottom:1px solid var(--bd-dark);flex-shrink:0;display:flex;align-items:center;justify-content:space-between}
.logo-area img{height:26px;width:auto;display:block}
.logo-link{display:inline-flex;margin: 0 auto;align-items:center;text-decoration:none;cursor:pointer;transition:opacity .15s}
.logo-link:hover{opacity:.75}
.logo-fallback{display:none;color:#fff;font-size:16px;font-weight:700}
.logo-admin-btn{padding:4px 10px;border-radius:6px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.14);color:rgba(255,255,255,0.60);font-size:11px;font-weight:600;text-decoration:none;transition:all .2s;white-space:nowrap}
.logo-admin-btn:hover{background:rgba(255,255,255,0.15);color:#fff}

/* New chat */
.btn-new{margin:14px 12px 0;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;background:rgba(10,132,208,0.16);border:1px solid rgba(10,132,208,0.32);border-radius:var(--r-sm);color:rgba(255,255,255,0.92);font-family:var(--font);font-size:12.5px;font-weight:600;cursor:pointer;transition:background .18s var(--ease),border-color .18s var(--ease),transform .15s var(--ease);flex-shrink:0;width:calc(100% - 24px);letter-spacing:.1px}
.btn-new:hover{background:rgba(10,132,208,0.30);border-color:rgba(10,132,208,0.55);transform:translateY(-1px)}
.btn-new:active{transform:translateY(0)}

/* Conversation list */
.conv-section{display:flex;flex-direction:column;flex:1;min-height:0;margin-top:12px}
.conv-lbl{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.28);padding:0 16px 8px;flex-shrink:0;display:flex;align-items:center;gap:8px}
.conv-lbl::after{content:'';flex:1;height:1px;background:rgba(255,255,255,0.07)}
.conv-list{flex:1;overflow-y:auto;padding:0 8px 8px}
.conv-list::-webkit-scrollbar{width:3px}
.conv-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.12);border-radius:2px}
.conv-item{display:flex;align-items:stretch;border-radius:8px;cursor:pointer;transition:background .15s;margin-bottom:2px;overflow:hidden;border:1px solid transparent}
.conv-item:hover{background:rgba(255,255,255,0.07)}
.conv-item.active{background:rgba(10,132,208,0.20);border-color:rgba(10,132,208,0.28)}
.conv-body{flex:1;padding:9px 10px;overflow:hidden;min-width:0}
.conv-title{font-size:12.5px;color:rgba(255,255,255,0.78);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}
.conv-item.active .conv-title{color:#fff;font-weight:600}
.conv-meta{font-size:10px;color:rgba(255,255,255,0.30);font-family:var(--mono);margin-top:2px}
.conv-del{flex-shrink:0;width:30px;display:grid;place-items:center;background:transparent;border:none;color:rgba(255,255,255,0.18);cursor:pointer;border-radius:0 7px 7px 0;transition:all .15s;opacity:0}
.conv-item:hover .conv-del{opacity:1}
.conv-del:hover{background:rgba(232,64,64,0.18);color:#ff8080}
.conv-empty{padding:10px 14px;font-size:12px;color:rgba(255,255,255,0.28);font-style:italic}

/* Auth zone (bas sidebar) */
.sb-auth{flex-shrink:0;border-top:1px solid var(--bd-dark);padding:12px}
.sb-auth-user{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:8px;background:rgba(255,255,255,0.06);margin-bottom:8px}
.sb-settings-link{flex-shrink:0;display:grid;place-items:center;width:30px;height:30px;border-radius:7px;color:rgba(255,255,255,0.45);text-decoration:none;transition:all .18s var(--ease);background:transparent}
.sb-settings-link:hover{background:rgba(255,255,255,0.10);color:#fff;transform:rotate(45deg)}
.sb-avatar{width:30px;height:30px;border-radius:7px;background:rgba(10,132,208,0.25);border:1px solid rgba(10,132,208,0.4);display:grid;place-items:center;font-size:11px;font-weight:700;color:rgba(255,255,255,0.9);flex-shrink:0}
.sb-username{font-size:12.5px;color:rgba(255,255,255,0.80);font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-user-role{font-size:10px;color:rgba(255,255,255,0.35);font-family:var(--mono)}
.sb-auth-links{display:flex;gap:8px}
.sb-link{flex:1;text-align:center;padding:7px 6px;border-radius:7px;font-size:12px;font-weight:600;text-decoration:none;transition:all .2s}
.sb-link-login{background:rgba(10,132,208,0.20);border:1px solid rgba(10,132,208,0.35);color:rgba(255,255,255,0.85)}
.sb-link-login:hover{background:rgba(10,132,208,0.35);color:#fff}
.sb-link-register{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.55)}
.sb-link-register:hover{background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.85)}
.sb-link-logout{background:rgba(232,64,64,0.12);border:1px solid rgba(232,64,64,0.22);color:rgba(255,100,100,0.85);padding:7px 10px;border-radius:7px;font-size:12px;font-weight:600;text-decoration:none;transition:all .2s}
.sb-link-logout:hover{background:rgba(232,64,64,0.22);color:#ff8080}

/* Settings panel */
.sb-settings{flex-shrink:0;border-top:1px solid var(--bd-dark);padding:13px 12px 14px}
.sb-lbl{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.28);margin-bottom:7px;display:flex;align-items:center;gap:7px}
.sb-lbl::after{content:'';flex:1;height:1px;background:rgba(255,255,255,0.07)}
.sb-row{margin-bottom:9px}
.sb-select{width:100%;appearance:none;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);border-radius:7px;color:rgba(255,255,255,0.90);font-family:var(--mono);font-size:12px;padding:8px 30px 8px 11px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.40)' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;transition:border-color .2s}
.sb-select:focus{outline:none;border-color:var(--blue-l)}
.sb-select option{background:var(--navy-d);color:#fff}
.sb-ta{width:100%;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);border-radius:7px;color:rgba(255,255,255,0.85);font-family:var(--mono);font-size:11px;line-height:1.6;padding:8px 11px;resize:none;height:66px;transition:border-color .2s}
.sb-ta:focus{outline:none;border-color:var(--blue-l)}
.sb-ta::placeholder{color:rgba(255,255,255,0.22)}
.sb-model-locked{padding:9px 11px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.10);border-radius:7px;font-size:12px;color:rgba(255,255,255,0.60);display:flex;align-items:center;gap:7px;font-family:var(--mono)}
.sb-model-locked svg{flex-shrink:0;fill:rgba(255,255,255,0.30);width:13px;height:13px}
.sb-model-locked-hint{font-size:10.5px;color:rgba(255,255,255,0.28);margin-top:5px}
.sb-model-locked-hint a{color:rgba(77,184,255,0.70);text-decoration:none}
.sb-model-locked-hint a:hover{color:var(--blue-l)}
.status-pill{display:flex;align-items:center;gap:8px;padding:7px 11px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);border-radius:7px;font-size:11px;color:rgba(255,255,255,0.50);font-weight:500}
.dot{width:6px;height:6px;border-radius:50%;background:var(--err);flex-shrink:0}
.dot.on{background:var(--ok);box-shadow:0 0 0 3px rgba(0,196,140,0.18);animation:blink 2.5s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
.sb-ver{text-align:center;font-size:10px;color:rgba(255,255,255,0.15);margin-top:9px;font-family:var(--mono)}

/* Provider pill */
.provider-pill{display:flex;align-items:center;gap:7px;padding:6px 11px;border-radius:7px;font-size:11px;font-weight:600;margin-bottom:2px;transition:all .3s}
.provider-local{background:rgba(0,196,140,0.12);border:1px solid rgba(0,196,140,0.22);color:rgba(255,255,255,0.70)}
.provider-claude{background:rgba(232,168,64,0.14);border:1px solid rgba(232,168,64,0.30);color:#f0c060}
.provider-pill span:first-child{font-size:13px}

/* MAIN */
.main{display:flex;flex-direction:column;overflow:hidden;background:var(--off);position:relative;min-height:0}
/* ── Filigrane logo — une seule instance centrée (desktop) ── */
.main::after{
  content:'';position:absolute;
  top:54px;bottom:70px;left:0;right:0;
  background-image:url('/imgs/logo-dukiwi.png');
  background-size:200px auto;
  background-position:center center;
  background-repeat:no-repeat;
  opacity:0.07;pointer-events:none;z-index:0;
}
/* Le contenu de messages passe au-dessus */
.messages,.input-area,.topbar,.banner{position:relative;z-index:1}
.topbar{background:var(--white);border-bottom:1px solid var(--bd);padding:0 26px;height:56px;display:flex;align-items:center;gap:14px;flex-shrink:0;box-shadow:var(--sh1);backdrop-filter:saturate(180%) blur(8px)}
.tb-icon{width:32px;height:32px;background:var(--navy);border-radius:8px;display:grid;place-items:center;flex-shrink:0}
.tb-icon svg{fill:white;width:16px;height:16px}
.tb-info{flex:1;min-width:0}
.tb-title{font-size:14px;font-weight:700;color:var(--tx);letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tb-sub{font-size:11px;color:var(--tx-soft);font-weight:500}
.model-badge{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;color:var(--navy);background:var(--blue-pale);border:1px solid #b8d8f5;padding:4px 11px;border-radius:20px;font-weight:500;white-space:nowrap;flex-shrink:0;transition:background .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease)}
.model-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0;transition:background .25s var(--ease)}

/* État "chargement en mémoire" — pulsation orange tant que Ollama warm-up */
.model-badge.loading{background:rgba(245,158,11,0.10);border-color:rgba(245,158,11,0.35);color:#b07000;animation:badgeBreathe 1.4s ease-in-out infinite}
.model-badge.loading::before{
  width:8px;height:8px;background:transparent;border:2px solid rgba(245,158,11,0.30);
  border-top-color:#f59e0b;border-radius:50%;
  animation:badgeSpin .8s linear infinite;
}
@keyframes badgeSpin{to{transform:rotate(360deg)}}
@keyframes badgeBreathe{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,0)}50%{box-shadow:0 0 0 4px rgba(245,158,11,0.10)}}
/* Compteur tokens/s sous la bulle (gris clair, vide tant que pas activé) */
.tok-counter{font-family:var(--mono);font-size:10.5px;color:var(--tx-soft);font-weight:500;letter-spacing:.2px;padding:0 4px;margin-top:4px;opacity:0;transition:opacity .25s var(--ease);min-height:14px;line-height:14px}
.tok-counter.active{opacity:1}
/* Sleep pill topbar */
.tb-sleep-pill{display:flex;align-items:center;gap:5px;background:rgba(245,158,11,0.10);border:1px solid rgba(245,158,11,0.28);border-radius:20px;padding:4px 11px;font-family:var(--mono);font-size:11px;color:#b07000;font-weight:600;flex-shrink:0;white-space:nowrap}
.tb-sleep-pill.sleeping{background:rgba(10,132,208,0.08);border-color:rgba(10,132,208,0.22);color:var(--blue)}
@media(max-width:1063px){.tb-sleep-pill{display:none!important}}
.tb-user-menu{display:flex;align-items:center;gap:8px;flex-shrink:0}
.tb-avatar{width:30px;height:30px;border-radius:7px;background:var(--blue-pale);border:1px solid #b8d8f5;display:grid;place-items:center;font-size:11px;font-weight:700;color:var(--navy)}
.tb-username{font-size:12.5px;font-weight:600;color:var(--tx-mid)}
.tb-auth-btn{padding:7px 14px;border-radius:var(--r-sm);font-family:var(--font);font-size:12.5px;font-weight:600;text-decoration:none;transition:all .18s var(--ease);letter-spacing:.1px}
.tb-btn-login{background:var(--navy);color:#fff;border:1px solid var(--navy);box-shadow:0 1px 2px rgba(1,56,97,0.18)}
.tb-btn-login:hover{background:var(--blue);border-color:var(--blue);box-shadow:0 2px 6px rgba(10,132,208,0.28);transform:translateY(-1px)}
.tb-btn-register{background:transparent;border:1px solid var(--bd);color:var(--tx-mid)}
.tb-btn-register:hover{border-color:var(--navy);color:var(--navy);background:var(--gray-50)}

/* Banners */
.banner{padding:9px 26px;display:flex;align-items:center;gap:10px;font-size:12.5px;font-weight:500;flex-shrink:0}
.banner.offline{background:#fff5f5;border-bottom:1px solid #fecdcd;color:#c0392b}
.banner.db-err{background:#fffbf0;border-bottom:1px solid #f5dfa0;color:#8a6000}
.banner code{font-family:var(--mono);padding:1px 5px;border-radius:4px;background:rgba(0,0,0,0.06)}

/* MESSAGES */
.messages{flex:1;overflow-y:auto;padding:26px 30px;display:flex;flex-direction:column;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--bd) transparent;position:relative}
.messages::-webkit-scrollbar{width:6px}
.messages::-webkit-scrollbar-track{background:transparent}
.messages::-webkit-scrollbar-thumb{background:var(--bd);border-radius:3px;border:1px solid transparent;background-clip:padding-box}
.messages::-webkit-scrollbar-thumb:hover{background:var(--gray-300)}

/* Welcome */
.welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:60px 40px;animation:fadeUp .4s var(--ease-out)}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
/* Welcome loader : style original — points rotatifs + aura bleue pulsante + auroras gradient */
.wlc-loader{position:relative;width:90px;height:90px;flex-shrink:0;margin-bottom:16px}
.wlc-loader::before{content:'';position:absolute;inset:-28px;border-radius:50%;background:radial-gradient(circle,rgba(10,132,208,0.18) 0%,rgba(94,184,255,0.08) 50%,transparent 72%);animation:wlcAura 4s ease-in-out infinite;pointer-events:none}
.wlc-loader span{position:absolute;display:block;width:90px;height:90px;border-radius:50%;filter:blur(0px)}
.wlc-loader span:nth-of-type(1){animation:wlcRotate 7s linear infinite;box-shadow:0 -17px 0 3px rgba(135,202,250,.95),0 -17px 16px 8px rgba(135,202,250,.30),-12px 8px 0 3px rgba(10,132,208,.80),-12px 8px 14px 6px rgba(10,132,208,.25),12px 8px 0 3px rgba(77,184,255,.70),12px 8px 14px 6px rgba(77,184,255,.20)}
.wlc-loader span:nth-of-type(2){animation:wlcRotateOther 7s linear infinite;box-shadow:12px -8px 0 3px rgba(94,184,255,.75),12px -8px 14px 6px rgba(94,184,255,.22),-12px -8px 0 3px rgba(10,132,208,.75),-12px -8px 14px 6px rgba(10,132,208,.22),0 17px 0 3px rgba(135,202,250,.60),0 17px 14px 6px rgba(135,202,250,.18)}
.wlc-aurora{position:absolute;border-radius:50%;mix-blend-mode:multiply;pointer-events:none;transform-origin:center}
.wlc-aurora:nth-of-type(1){width:220px;height:220px;top:-65px;left:-65px;background:conic-gradient(from 0deg,rgba(10,132,208,.55),rgba(94,184,255,.30),rgba(135,202,250,.45),rgba(10,132,208,.55));filter:blur(22px);animation:wlcBreathe1 7s ease-in-out infinite}
.wlc-aurora:nth-of-type(2){width:170px;height:170px;top:-40px;left:-40px;background:conic-gradient(from 120deg,rgba(77,184,255,.50),rgba(10,132,208,.25),rgba(135,202,250,.40),rgba(77,184,255,.50));filter:blur(16px);animation:wlcBreathe2 9s ease-in-out infinite}
.wlc-aurora:nth-of-type(3){width:130px;height:130px;top:-20px;left:-20px;background:conic-gradient(from 240deg,rgba(135,202,250,.45),rgba(10,132,208,.55),rgba(77,184,255,.35),rgba(135,202,250,.45));filter:blur(12px);animation:wlcBreathe3 5.5s ease-in-out infinite}
@keyframes wlcAura{0%,100%{transform:scale(1);opacity:.55}50%{transform:scale(1.18);opacity:1}}
@keyframes wlcBreathe1{0%,100%{transform:scale(1);opacity:.7}40%{transform:scale(1.18);opacity:1}70%{transform:scale(.93);opacity:.8}}
@keyframes wlcBreathe2{0%,100%{transform:scale(.95);opacity:.65}35%{transform:scale(1.12);opacity:.9}65%{transform:scale(1.02);opacity:.75}}
@keyframes wlcBreathe3{0%,100%{transform:scale(1.05);opacity:.8}50%{transform:scale(.88);opacity:.6}}
@keyframes wlcRotate{to{transform:rotate(360deg)}}
@keyframes wlcRotateOther{to{transform:rotate(-360deg)}}
.welcome h2{font-size:22px;font-weight:700;color:var(--tx);letter-spacing:-.4px;line-height:1.3}
.welcome p{color:var(--tx-mid);max-width:380px;font-size:13.5px;line-height:1.7}
.chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:10px;max-width:1063px}
.chip{padding:9px 16px;background:var(--white);border:1px solid var(--bd);border-radius:var(--r);font-size:12.5px;color:var(--tx-mid);cursor:pointer;transition:all .18s var(--ease);font-weight:500;line-height:1.4;box-shadow:var(--sh1)}
.chip:hover{background:var(--blue-pale);border-color:#90c8f0;color:var(--navy);transform:translateY(-1px);box-shadow:var(--sh2)}
.chip:active{transform:translateY(0)}

/* Msg group */
.msg-group{margin-bottom:20px;animation:slideUp .22s ease both}
@keyframes slideUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.msg-row{display:flex;align-items:flex-start;gap:10px}
.msg-row.user{flex-direction:row-reverse}
.avatar{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;margin-top:2px}
.avatar.ai{background:var(--navy);box-shadow:0 2px 8px rgba(1,56,97,0.22)}
.avatar.ai svg{fill:white;width:15px;height:15px}
.avatar.user{background:var(--blue-pale);border:1.5px solid #90c8f0;color:var(--navy);font-size:10px;font-weight:700}
.bwrap{display:flex;flex-direction:column;gap:4px;max-width:76%}
.msg-row.user .bwrap{align-items:flex-end}
.bmeta{font-size:10.5px;color:var(--tx-soft);font-weight:600;letter-spacing:.2px;padding:0 4px}
.bmeta-model{display:inline-flex;align-items:center;gap:5px;background:var(--blue-pale);border:1px solid #b8d8f5;color:var(--navy);padding:2px 8px;border-radius:10px;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.3px}
.bubble{padding:14px 16px;border-radius:var(--r-md);line-height:1.7;word-break:break-word;font-size:13.5px;box-shadow:var(--sh1)}
.bubble.ai{background:var(--white);border:1px solid var(--bd);border-top-left-radius:var(--r-xs);color:var(--tx)}
.bubble.user{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-l) 100%);color:rgba(255,255,255,0.96);border-top-right-radius:var(--r-xs);white-space:pre-wrap;box-shadow:0 2px 8px rgba(1,56,97,0.18),0 1px 2px rgba(1,56,97,0.10)}

/* Markdown */
.bubble.ai h1,.bubble.ai h2,.bubble.ai h3{font-family:var(--font);font-weight:700;color:var(--navy);margin:14px 0 7px;line-height:1.35}
.bubble.ai h1{font-size:16px;border-bottom:2px solid var(--blue-pale);padding-bottom:5px}
.bubble.ai h2{font-size:14.5px}.bubble.ai h3{font-size:13.5px;color:var(--navy-l)}
.bubble.ai p{margin:0 0 9px}.bubble.ai p:last-child{margin-bottom:0}
.bubble.ai ul,.bubble.ai ol{padding-left:20px;margin:7px 0 9px}.bubble.ai li{margin-bottom:3px}
.bubble.ai strong{font-weight:700;color:var(--navy)}.bubble.ai em{font-style:italic;color:var(--tx-mid)}
.bubble.ai blockquote{border-left:3px solid var(--blue);background:var(--blue-pale);margin:9px 0;padding:7px 13px;border-radius:0 6px 6px 0;color:var(--tx-mid);font-style:italic}
.bubble.ai hr{border:none;border-top:1px solid var(--bd);margin:12px 0}
.bubble.ai a{color:var(--blue);text-decoration:underline}
.bubble code{font-family:var(--mono);font-size:12px;padding:2px 6px;border-radius:4px}
.bubble.ai code{background:var(--blue-pale);color:var(--navy)}
.bubble.user code{background:rgba(255,255,255,0.15);color:rgba(255,255,255,0.9)}
.bubble.ai code:not(.dkwcode){cursor:pointer;transition:background .15s,outline .15s}
.bubble.ai code:not(.dkwcode):hover{background:#c5dff5;outline:1px solid #90c8f0}
.bubble.ai code:not(.dkwcode).inline-copied{background:#c8f0e0!important;color:#006040!important}

/* Code blocks */
.code-block{margin:11px 0;border-radius:10px;overflow:hidden;border:1px solid #2a2f3a;box-shadow:0 2px 10px rgba(0,0,0,0.18)}
.code-header{display:flex;align-items:center;justify-content:space-between;padding:7px 13px;background:var(--navy);border-bottom:1px solid #2a2f3a}
.code-lang{font-family:var(--mono);font-size:11px;font-weight:500;color:#7c8fa8;letter-spacing:.5px}
.code-copy{display:flex;align-items:center;gap:5px;background:transparent;border:1px solid #2f3848;border-radius:5px;color:#7c8fa8;font-family:var(--mono);font-size:11px;padding:3px 9px;cursor:pointer;transition:all .2s}
.code-copy:hover{background:#2a3040;color:#b0c4d8;border-color:#3d4f65}
.code-copy.copied{color:var(--ok);border-color:var(--ok)}
.code-block pre{margin:0!important;border-radius:0!important}
.code-block pre code{font-family:var(--mono)!important;font-size:12.5px!important;line-height:1.65!important;padding:13px 15px!important;border-radius:0!important}

/* Bouton "Régénérer" pour les réponses interrompues */
.regen-row{display:flex;flex-direction:column;align-items:center;gap:10px;padding:14px 16px;margin:6px 0 18px;background:linear-gradient(180deg,rgba(245,158,11,0.04),rgba(245,158,11,0.08));border:1px dashed rgba(245,158,11,0.40);border-radius:var(--r-md);animation:fadeUp .3s var(--ease-out)}
.regen-msg{font-size:12.5px;color:var(--tx-mid);text-align:center;line-height:1.5;font-weight:500}
.regen-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:var(--white);border:1px solid var(--bd);border-radius:var(--r-sm);color:var(--navy);font-family:var(--font);font-size:12.5px;font-weight:600;cursor:pointer;transition:all .18s var(--ease);box-shadow:var(--sh1)}
.regen-btn:hover{background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-1px);box-shadow:var(--sh2)}
.regen-btn:active{transform:translateY(0)}
.regen-btn svg{flex-shrink:0}

/* Streaming cursor */
.bubble.streaming:not(:empty)::after{content:'▍';display:inline-block;color:var(--blue);animation:cur .7s step-end infinite;margin-left:2px;font-size:13px;vertical-align:baseline}
@keyframes cur{0%,100%{opacity:1}50%{opacity:0}}
/* Memory toast */
.mem-toast{position:fixed;bottom:24px;right:24px;background:rgba(1,56,97,0.92);border:1px solid rgba(10,132,208,0.45);color:rgba(255,255,255,0.88);font-size:12px;font-family:var(--mono);padding:8px 14px;border-radius:8px;backdrop-filter:blur(6px);z-index:9999;animation:memIn .25s ease;pointer-events:none}
.mem-toast.out{animation:memOut .3s ease forwards}
@keyframes memIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes memOut{to{opacity:0;transform:translateY(4px)}}

/* Thinking status */
.think-status{display:flex;flex-direction:column;align-items:center;gap:14px;padding:10px 0 4px;animation:fadeIn .35s ease both}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.ai-loader{position:relative;width:54px;height:54px;flex-shrink:0}
.ai-loader__inner{position:absolute;display:block;width:54px;height:54px;border-radius:50%;animation:aiRotate 2s linear infinite}
.ai-loader__inner:nth-child(1){box-shadow:0 -10px 0 0 rgba(135,202,250,.9),-7.5px 5px 0 0 rgba(10,132,208,.6),7.5px 5px 0 0 rgba(1,56,97,.9)}
.ai-loader__inner:nth-child(2){box-shadow:7.5px -5px 0 0 rgba(94,184,255,.6),-7.5px -5px 0 0 rgba(10,132,208,.6),0 10px 0 0 rgba(1,56,97,.6);animation:aiRotateOther 2s linear infinite}
@keyframes aiRotate{50%{transform:scale(1.1) rotate(360deg)}100%{transform:scale(1) rotate(720deg)}}
@keyframes aiRotateOther{50%{transform:scale(1.2) rotate(-360deg)}100%{transform:scale(1) rotate(-720deg)}}
.think-label{font-size:12px;color:var(--tx-mid);font-style:italic;text-align:center;letter-spacing:.01em}

/* INPUT */
.input-area{background:var(--white);border-top:1px solid var(--bd);padding:14px 26px 18px;flex-shrink:0;box-shadow:0 -1px 0 var(--bd),0 -8px 24px rgba(15,38,68,0.04)}

/* Suggest bar — autocomplétion (liste verticale façon Google) */
.suggest-bar{display:none;flex-direction:column;margin-bottom:8px;background:var(--white);border:1px solid var(--bd);border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--sh1);user-select:none}
.suggest-bar.visible{display:flex;animation:fadeUp .18s var(--ease-out)}
.suggest-item{display:flex;align-items:center;gap:10px;padding:9px 14px;font-size:13px;color:var(--tx-mid);cursor:pointer;transition:background .12s var(--ease);border-bottom:1px solid var(--bd)}
.suggest-item:last-child{border-bottom:none}
.suggest-item:hover,.suggest-item.selected{background:var(--blue-pale)}
.suggest-item .suggest-typed{color:var(--tx);font-weight:600;white-space:pre}
.suggest-item .suggest-rest{color:var(--tx-soft);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.suggest-item .suggest-kbd{font-family:var(--mono);font-size:10px;background:var(--gray-50);border:1px solid var(--bd);border-radius:4px;padding:2px 7px;color:var(--tx-mid);flex-shrink:0;font-weight:600}
@media(max-width:1063px){.suggest-item{padding:8px 12px;font-size:12px}.suggest-item .suggest-kbd{display:none}}
.input-box{display:flex;align-items:flex-end;gap:10px;background:var(--gray-50);border:1px solid var(--bd);border-radius:var(--r-md);padding:6px 6px 6px 15px;transition:border-color .18s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease)}
.input-box:hover{border-color:#bccddc}
.input-box:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(10,132,208,0.10);background:var(--white)}
#user-input{flex:1;background:transparent;border:none;outline:none;resize:none;color:var(--tx);font-family:var(--font);font-size:14px;line-height:1.6;max-height:150px;min-height:38px;padding:8px 0;overflow-y:auto}
#user-input::placeholder{color:var(--tx-soft)}
#send-btn{position:relative;width:38px;height:38px;background:var(--navy);border:none;border-radius:var(--r-md);display:grid;place-items:center;cursor:pointer;flex-shrink:0;transition:background .18s var(--ease),transform .15s var(--ease),box-shadow .2s var(--ease);box-shadow:0 2px 6px rgba(1,56,97,0.18)}
#send-btn svg{fill:white;width:15px;height:15px}
#send-btn:hover{background:var(--blue);transform:translateY(-1px);box-shadow:0 4px 12px rgba(10,132,208,0.32)}
#send-btn:active{transform:translateY(0);box-shadow:0 2px 4px rgba(1,56,97,0.18)}
#send-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}
.input-hint{text-align:right;font-size:10.5px;color:var(--tx-soft);margin-top:5px;font-family:var(--mono)}

/* Search */
.search-results-card{background:var(--white);border:1px solid var(--bd);border-left:3px solid var(--blue);border-radius:var(--r);padding:11px 14px;box-shadow:var(--sh1);max-width:82%;animation:slideUp .22s ease both;font-size:12px}
.search-results-header{font-weight:600;color:var(--navy);margin-bottom:8px}
.search-results-list{margin:0;padding:0 0 0 14px;color:var(--tx-mid);display:flex;flex-direction:column;gap:5px}
.search-results-list li{line-height:1.45}
.search-results-list a{color:var(--blue);text-decoration:none;font-weight:500}
.search-results-list a:hover{text-decoration:underline}
.search-result-snippet{color:var(--tx-mid);font-size:11px}
.search-pages-read{font-size:11px;color:var(--tx-mid);margin-bottom:5px;font-style:italic}
.search-in-progress{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 0 6px}
.search-spinner-ring{position:relative;width:38px;height:38px;flex-shrink:0}
.search-spinner-ring::before,.search-spinner-ring::after{content:'';position:absolute;inset:0;border-radius:50%}
.search-spinner-ring::before{border:3px solid var(--blue-pale)}
.search-spinner-ring::after{border:3px solid transparent;border-top-color:var(--blue);border-right-color:var(--blue-l);animation:spin .8s cubic-bezier(.4,0,.2,1) infinite;box-shadow:0 0 12px rgba(10,132,208,0.20)}
.search-done-ring{width:38px;height:38px;flex-shrink:0;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;animation:popIn .3s cubic-bezier(.34,1.56,.64,1) both;box-shadow:0 0 14px rgba(10,132,208,0.35)}
.search-done-ring svg{width:20px;height:20px;stroke:#fff;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;fill:none}
@keyframes popIn{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
.search-in-progress-label{font-size:12px;color:var(--tx-mid);font-style:italic;text-align:center;line-height:1.4}
.search-in-progress-label em{display:block;font-family:var(--mono);font-size:11px;color:var(--blue);font-style:normal;margin-top:2px;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.search-in-progress.done .search-in-progress-label{color:var(--blue);font-weight:600;font-style:normal}
.search-in-progress.done .search-in-progress-label em{display:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Bouton menu mobile (caché par défaut) ── */
.tb-menu-btn{
  display:none;flex-shrink:0;
  width:36px;height:36px;background:none;border:none;
  border-radius:8px;cursor:pointer;padding:6px;
  color:var(--tx-mid);transition:background .15s;
}
.tb-menu-btn:hover{background:var(--blue-pale);color:var(--navy)}
.tb-menu-btn svg{display:block;width:100%;height:100%}

/* ── Overlay sidebar mobile ── */
.sb-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,10,25,0.55);z-index:999;
  animation:fadeIn .2s ease;
}
.sb-overlay.visible{display:block}

/* ── RESPONSIVE ─────────────────────────────────────────────────────────── */

/* Laptop standard (≤1200px) — sidebar légèrement réduite, lecture confortable */
@media(max-width:1200px){
  :root{--sw:280px}
  .messages{padding:24px 28px}
  .bwrap{max-width:80%}
}

/* Tablette étroite (≤900px) */
@media(max-width:900px){
  :root{--sw:260px}
  .topbar{padding:0 18px;gap:10px}
  .messages{padding:20px 20px}
  .input-area{padding:12px 18px 16px}
  .tb-username{display:none}
  .bwrap{max-width:84%}
  .welcome{padding:40px 24px}
  .welcome h2{font-size:20px}
}

/* Tablette/grand mobile (≤680px) : drawer */
@media(max-width:1063px){
  .app{grid-template-columns:1fr}

  /* Sidebar comme drawer */
  .sidebar{
    position:fixed;top:0;left:0;bottom:0;width:280px;
    transform:translateX(-100%);
    transition:transform .28s cubic-bezier(.4,0,.2,1);
    z-index:1000;
    box-shadow:6px 0 28px rgba(0,0,0,0.28);
  }
  .sidebar.sb-open{transform:translateX(0)}

  /* Bouton hamburger visible */
  .tb-menu-btn{display:flex;align-items:center;justify-content:center}

  /* Topbar : garder seulement hamburger + titre */
  .topbar{padding:0 14px;gap:10px;height:52px}
  .tb-sub{display:none}
  .model-badge{display:none}
  .tb-user-menu{display:none}   /* login/avatar → déjà dans la sidebar */
  .tb-icon{display:none}        /* icône redondante sur mobile */

  /* Messages */
  .messages{padding:16px 14px}
  .bwrap{max-width:88%}

  /* Input : safe-area iOS + clavier virtuel */
  .input-area{
    padding:10px 12px max(14px, env(safe-area-inset-bottom));
    flex-shrink:0;
  }

  /* Filigrane mobile : motif répété en diagonale */
  .main::after{
    top:-120%;bottom:-120%;left:-120%;right:-120%;
    background-image:url('/imgs/logo-dukiwi-tile.png');
    background-size:auto;background-repeat:repeat;
    background-position:0 0;
    transform:rotate(55deg);transform-origin:center center;
    opacity:0.10;
  }

  /* Welcome */
  .welcome{padding:24px 16px}
  .welcome h2{font-size:16px}
  .chips{gap:6px}
  .chip{font-size:11px;padding:6px 11px}
}

/* Petit mobile (≤420px) */
@media(max-width:420px){
  .sidebar{width:260px}
  .topbar{padding:0 10px;gap:8px}
  .messages{padding:12px 10px}
  .input-area{padding:8px 10px max(12px, env(safe-area-inset-bottom))}
  .bubble{padding:11px 13px;font-size:13px}
  .bwrap{max-width:92%}
  .main::after{background-size:60%}
  .welcome h2{font-size:17px}
  .welcome p{font-size:12.5px}
}

/* Accessibilité : respect du prefers-reduced-motion
   On désactive uniquement les animations d'entrée et transitions cosmétiques.
   Les loaders/spinners + l'onboarding sont préservés (scriptés, pas décoratifs). */
@media(prefers-reduced-motion:reduce){
  .msg-group,.welcome,.think-status,.regen-row,.search-results-card{animation:none!important}
  *,*::before,*::after{transition-duration:.01ms!important;scroll-behavior:auto!important}
  /* L'onboarding repose entièrement sur les transitions — on les conserve */
  .ob-line{transition:transform 1.4s cubic-bezier(0.4,0,0.2,1),opacity 1.1s ease-in-out!important}
  .ob-word{animation:obWord .55s cubic-bezier(.16,1,.3,1) forwards!important}
  .ob-overlay,.ob-aurora-1,.ob-aurora-2,.ob-aurora-3,.ob-logo{animation-duration:revert!important}
}

/* ── QUOTA PUBLIC ───────────────────────────────────────────────────────── */
.pub-quota{margin-top:9px;padding:9px 11px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.10);border-radius:8px;font-size:11px}
.pub-quota-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:6px}
.pub-quota-msgs{font-weight:600;color:rgba(255,255,255,0.72);white-space:nowrap}
.pub-quota-time{font-family:var(--mono);font-size:11px;color:rgba(255,255,255,0.45);white-space:nowrap;flex-shrink:0}
.pub-quota-bar{height:3px;background:rgba(255,255,255,0.10);border-radius:2px;overflow:hidden}
.pub-quota-fill{height:100%;background:var(--blue);border-radius:2px;transition:width .4s,background .4s}
.pub-quota.warn .pub-quota-fill{background:#f59e0b}
.pub-quota.warn .pub-quota-time{color:#f59e0b}
.pub-quota.urgent .pub-quota-fill{background:var(--err)}
.pub-quota.urgent .pub-quota-msgs,.pub-quota.urgent .pub-quota-time{color:#ff8080}

/* ── BANNIÈRE EXTINCTION ─────────────────────────────────────────────────── */
#shutdown-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9000;
  display:flex;align-items:center;gap:10px;
  background:linear-gradient(90deg,#011e3a,#01285a);
  border-top:1px solid rgba(135,198,255,0.18);
  padding:11px 20px;
  font-size:13px;font-family:var(--font);color:rgba(255,255,255,0.80);
  animation:bannerSlide .4s ease;
}
@keyframes bannerSlide{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
#shutdown-banner strong{color:#87c6ff;font-weight:700}
#shutdown-icon{font-size:16px;flex-shrink:0}
#shutdown-msg{flex:1}
#shutdown-close{
  flex-shrink:0;background:none;border:none;color:rgba(255,255,255,0.45);
  font-size:20px;line-height:1;cursor:pointer;padding:0 4px;
  transition:color .2s;
}
#shutdown-close:hover{color:#fff}
@media(max-width:480px){
  #shutdown-banner{flex-wrap:wrap;font-size:12px;padding:10px 14px}
}

/* ── FILE D'ATTENTE ─────────────────────────────────────────────────────── */
.queue-overlay{
  position:fixed;inset:0;z-index:9999;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  font-family:'Plus Jakarta Sans','Segoe UI',sans-serif;
}
/* Deux calques image pour crossfade */
.q-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:opacity 1.8s ease;
}
.q-img.active{opacity:1}
.q-img.inactive{opacity:0}
/* Gradient : assombrir haut et bas */
.q-gradient{
  position:absolute;inset:0;
  background:
    linear-gradient(to bottom,rgba(0,10,25,0.72) 0%,transparent 38%),
    linear-gradient(to top,   rgba(0,10,25,0.85) 0%,transparent 50%);
  pointer-events:none;
}
/* Contenu centré */
.q-content{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;
  width:100%;padding:40px 24px;
  text-align:center;
}
/* Spinner */
.q-ring-wrap{position:relative;width:64px;height:64px;margin-bottom:24px}
.q-ring{
  width:64px;height:64px;border-radius:50%;
  border:4px solid rgba(255,255,255,0.15);border-top-color:rgba(255,255,255,0.9);
  animation:spin .9s linear infinite;
}
.q-ring-inner{
  position:absolute;top:50%;left:50%;
  margin-top:-20px;margin-left:-20px;
  width:40px;height:40px;border-radius:50%;
  border:3px solid rgba(255,255,255,0.08);border-bottom-color:rgba(255,255,255,0.5);
  animation:spin 1.5s linear infinite reverse;
}
/* Position dans la file */
.q-pos{
  font-size:14px;font-weight:600;letter-spacing:.5px;
  color:rgba(255,255,255,0.65);text-transform:uppercase;margin-bottom:6px;
}
.q-pos-num{
  font-size:52px;font-weight:800;color:#fff;line-height:1;
  text-shadow:0 2px 16px rgba(0,0,0,0.5);letter-spacing:-1px;
}
.q-pos-label{
  font-size:13px;font-weight:500;color:rgba(255,255,255,0.92);margin-bottom:36px;
  text-shadow:0 1px 6px rgba(0,0,0,0.7),0 0 16px rgba(0,0,0,0.5);
}
/* Citation */
.q-quote{
  max-width:620px;margin-bottom:40px;min-height:72px;
  transition:opacity .7s ease;
}
.q-quote.hidden{opacity:0}
.q-quote.visible{opacity:1}
.q-quote-text{
  font-size:18px;font-weight:500;font-style:italic;color:#fff;
  line-height:1.6;margin-bottom:10px;
  text-shadow:0 1px 8px rgba(0,0,0,0.65);
}
.q-quote-author{
  font-size:13px;font-weight:600;color:rgba(255,255,255,0.55);letter-spacing:.5px;
}
/* Message principal */
.q-message{
  font-size:clamp(16px,3vw,22px);font-weight:800;
  color:#fff;letter-spacing:-.2px;line-height:1.4;max-width:660px;
  text-shadow:0 2px 6px rgba(0,0,0,0.8),0 0 20px rgba(0,0,0,0.5);
  margin-bottom:20px;
}
/* Bouton connexion queue */
.q-login-hint{margin-top:28px}
.q-login-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 24px;border-radius:30px;
  background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.35);
  color:#fff;font-size:13.5px;font-weight:600;text-decoration:none;
  backdrop-filter:blur(6px);
  transition:background .2s,border-color .2s,transform .15s;
}
.q-login-btn:hover{background:rgba(255,255,255,0.25);border-color:rgba(255,255,255,0.6);transform:translateY(-1px)}

/* Points animés */
.q-dots{display:flex;justify-content:center;gap:8px}
.q-dots span{
  width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.4);
  animation:qdot 1.1s ease-in-out infinite;
}
.q-dots span:nth-child(2){animation-delay:.2s}
.q-dots span:nth-child(3){animation-delay:.4s}
@keyframes qdot{0%,80%,100%{transform:scale(.65);opacity:.35}40%{transform:scale(1.15);opacity:1;background:#fff}}

/* ── Overlay ban fraude file d'attente ─────────────────────────────────────── */
#queue-ban-overlay{
  position:fixed;inset:0;z-index:10000;
  display:flex;align-items:center;justify-content:center;
  background:rgba(10,4,4,0.92);backdrop-filter:blur(12px);
  font-family:'Plus Jakarta Sans','Segoe UI',sans-serif;
}
.q-ban-card{
  max-width:520px;width:90%;
  background:linear-gradient(145deg,#1a0a0a,#2a0f0f);
  border:1px solid rgba(239,68,68,0.35);border-radius:20px;
  padding:48px 40px;text-align:center;
  box-shadow:0 0 60px rgba(239,68,68,0.12),0 24px 48px rgba(0,0,0,0.5);
}
.q-ban-icon{font-size:52px;margin-bottom:20px;display:block}
.q-ban-title{
  font-size:clamp(18px,3vw,24px);font-weight:800;
  color:#fff;margin:0 0 20px;letter-spacing:-.3px;
}
.q-ban-msg{
  font-size:14.5px;line-height:1.7;color:rgba(255,255,255,0.65);
  margin:0 0 28px;
}
.q-ban-msg strong{color:rgba(255,200,180,0.9)}
.q-ban-timer{
  display:inline-block;
  padding:10px 22px;border-radius:30px;
  background:rgba(239,68,68,0.15);border:1px solid rgba(239,68,68,0.3);
  font-size:13px;font-weight:600;color:rgba(255,160,140,0.9);
  letter-spacing:.2px;
}
