/* ============================================================
   ALG CLUB — Styles composants (utilisent css/tokens.css)
   Restyle de la base Beta 2 → marque luxe/sobre/élégant.
   ============================================================ */

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

body {
  background: var(--alg-bg);
  color: var(--alg-text);
  font-family: var(--alg-font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  font-weight: 400;
  min-height: 100dvh;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  /* profondeur ambiante : vignette + glow émeraude haut-gauche */
  background-image:
    radial-gradient(1200px 600px at 15% -10%, rgba(42,91,67,0.06), transparent 60%),
    radial-gradient(1000px 800px at 50% 120%, var(--alg-bg-deep), transparent 70%);
  background-attachment: fixed;
}
/* grain film très subtil */
body::after {
  content: ""; position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  opacity: 0.035; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@media (prefers-reduced-transparency: reduce) { body::after { display: none; } }
/* Grain filmique : sombre uniquement (sur fond clair il « salit » et durcit le rendu) */
:root[data-theme="light"] body::after { display: none; }

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-thumb { background: var(--alg-surface-3); border-radius: var(--r-pill); }
::-webkit-scrollbar-track { background: transparent; }

.w { max-width: var(--container); margin: 0 auto; padding: 0 var(--sp-6) var(--sp-9); }

/* ---------- HEADER ---------- */
.hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-5) var(--sp-6);
  border-bottom: 1px solid var(--alg-border);
  position: sticky; top: 0; z-index: 100;
  background: var(--header-bg); backdrop-filter: blur(20px);
}
/* Logo = wordmark « ALG CLUB » vectoriel (SVG). Variante blanche (sombre) / noire (clair) → image de fond,
   fiable partout (le masque CSS échouait sur certains navigateurs). */
.logo {
  width: 141px; height: 23px;
  background: url("../assets/logo-alg.svg") no-repeat center / contain;
}
:root[data-theme="light"] .logo { background-image: url("../assets/logo-alg-black.svg"); }
.logo-sub {
  font-size: var(--fs-micro); letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--alg-text-3); margin-top: 4px;
}
.hdr-r { display: flex; align-items: center; gap: var(--sp-3); }
.sp { font-size: var(--fs-caption); color: var(--alg-text-2); display: flex; align-items: center; gap: var(--sp-1); opacity: 0; transition: opacity var(--dur-slow); }
.sp.on { opacity: 1; }
.dot { width: 6px; height: 6px; border-radius: 50%; background: var(--alg-emerald-bright); }
.score-pill {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3); border-radius: var(--r-pill);
  border: 1px solid var(--alg-border-strong); font-size: var(--fs-caption); color: var(--alg-text-2);
}
.score-num { font-family: var(--alg-font-display); font-size: 16px; color: var(--alg-emerald-bright); font-variant-numeric: tabular-nums; }

/* ---------- TABS ---------- */
.tabs { display: flex; overflow-x: auto; gap: var(--sp-1); padding: 0 var(--sp-6); border-bottom: 1px solid var(--alg-border); scrollbar-width: none; }
.tabs::-webkit-scrollbar { display: none; }
.tab {
  position: relative; padding: var(--sp-4) var(--sp-4); font-size: var(--fs-label); font-weight: 500;
  color: var(--alg-text-2); background: none; border: none; cursor: pointer; white-space: nowrap;
  font-family: inherit; transition: color var(--dur-base);
}
.tab:hover { color: var(--alg-text); }
.tab.on { color: var(--alg-text); }
.tab.on::after {
  content: ""; position: absolute; left: var(--sp-4); right: var(--sp-4); bottom: -1px; height: 2px;
  background: var(--alg-emerald-bright); border-radius: var(--r-pill);
}

.pane { display: none; padding: var(--sp-6) var(--sp-6); animation: paneIn var(--dur-slow) var(--ease-out); }
.pane.on { display: block; }
@keyframes paneIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* ---------- KPI ---------- */
.kgrid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: var(--sp-4); margin-bottom: var(--sp-6); }
.kgrid--bud { grid-template-columns: repeat(3, minmax(0,1fr)); }   /* Budget : 3 KPI (les @media .kgrid replient en 2 puis 1) */
.k {
  position: relative; overflow: hidden;
  background: var(--card-sheen), var(--card-bg);
  border-radius: var(--r-md); padding: var(--sp-5);
  box-shadow: var(--card-shadow);
}
.klb { font-size: var(--fs-micro); letter-spacing: 0.09em; text-transform: uppercase; color: var(--alg-text-2); font-weight: 600; margin-bottom: var(--sp-2); }
.kv { font-family: var(--alg-font-display); font-size: 26px; color: var(--alg-text); font-variant-numeric: tabular-nums; }
.kv.g { color: var(--alg-emerald-bright); }
.kv.r { color: var(--alg-negative); }
.kv.debt { color: var(--alg-debt); }   /* dettes : gris neutre, jamais rouge (call 18/06) */
.kv.gold { color: var(--alg-gold); }   /* accent or léger (ex. capacité d'épargne Budget) — PAS le traitement héros */
.ks { font-size: var(--fs-caption); color: var(--alg-text-3); margin-top: var(--sp-1); }
.trend { display: inline-flex; align-items: center; gap: var(--sp-1); font-size: var(--fs-caption); padding: 2px 8px; border-radius: var(--r-xs); margin-top: var(--sp-1); }
.tup { background: var(--alg-emerald-ghost); color: var(--alg-emerald-bright); }
.tdn { background: var(--alg-negative-ghost); color: var(--alg-negative); }
.tfl { background: var(--alg-surface-2); color: var(--alg-text-2); }   /* pastille neutre theme-aware (visible en clair ET sombre) */
.tfl-dn { background: var(--alg-debt-ghost); color: var(--alg-debt); margin-top: var(--sp-1); display: inline-flex; align-items: center; gap: var(--sp-1); font-size: var(--fs-caption); padding: 2px 8px; border-radius: var(--r-xs); }   /* baisse : gris sobre, jamais rouge sur la carte or */

/* HÉROS : patrimoine net (1re carte) — le SEUL moment OR */
.k.gk {
  background: linear-gradient(160deg, var(--alg-olive), var(--alg-surface) 90%);
  box-shadow: var(--hero-shadow);
  container-type: inline-size;
}
.k.gk .klb { color: var(--alg-gold-dim); }
.k.gk .kv { color: var(--alg-gold); font-size: 34px; white-space: nowrap; }
.k.gk .kv.neg, .sy-evo-val.neg { color: var(--alg-text); }   /* patrimoine net < 0 : neutre sobre */

/* ---------- CARTES ---------- */
.r2 { display: grid; grid-template-columns: 1fr 280px; gap: var(--sp-4); }
.card {
  position: relative;
  background: var(--card-sheen), var(--card-bg);
  border-radius: var(--r-md); padding: var(--sp-5); margin-bottom: var(--sp-4);
  box-shadow: var(--card-shadow);
}
/* Bordure premium : liseré champagne dégradé (lumineux en haut → quasi nul en bas) via masque — pas de trait plat uniforme */
.card::before, .k::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none; padding: 1px;
  background: var(--card-edge);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
}
.k.gk::before { background: var(--hero-edge); }
/* Titre de carte/section : eyebrow MAJ mis en avant — texte crème + barre accent émeraude */
.ctit { font-size: var(--fs-micro); letter-spacing: 0.14em; text-transform: uppercase; color: var(--alg-text); font-weight: 600; margin-bottom: var(--sp-4); }
.ctit::before {
  content: ""; display: inline-block; width: 3px; height: 0.92em;
  margin-right: var(--sp-2); vertical-align: -1px;
  background: var(--alg-emerald-bright); border-radius: var(--r-pill);
}

/* ---------- TABLES ---------- */
.tbl { width: 100%; border-collapse: collapse; }
.tbl th { font-size: var(--fs-micro); letter-spacing: 0.08em; text-transform: uppercase; color: var(--alg-text-2); text-align: left; padding: 0 var(--sp-2) var(--sp-2); font-weight: 600; }
.tbl td { padding: var(--sp-3) var(--sp-2); border-top: 1px solid var(--alg-border); font-size: var(--fs-label); color: var(--alg-text); vertical-align: middle; }
.tbl td.num, .tbl td .num { font-variant-numeric: tabular-nums; white-space: nowrap; }
.tbl tr { transition: background var(--dur-fast); }
.tbl tbody tr:hover td { background: var(--alg-emerald-ghost); }
/* regroupement par catégorie (total + sous-lignes) */
.tbl tr.grp td { background: var(--alg-surface-2); }
.tbl tr.grp:hover td { background: var(--alg-surface-2); }
.tbl tr.sub td { color: var(--alg-text-2); }
.tbl tr.sub td:first-child { padding-left: 34px; position: relative; }
/* sous-catégorie : connecteur en « branche » (L) + petite flèche émeraude */
.tbl tr.sub td:first-child::before {
  content: ""; position: absolute; left: 14px; top: 0; bottom: 50%; width: 9px;
  border-left: 1.5px solid var(--alg-border-strong);
  border-bottom: 1.5px solid var(--alg-border-strong);
  border-bottom-left-radius: 6px;
}
.tbl tr.sub td:first-child::after {
  content: ""; position: absolute; left: 21px; top: 50%; width: 5px; height: 5px;
  transform: translateY(-50%) rotate(45deg);
  border-top: 1.5px solid var(--alg-emerald-bright);
  border-right: 1.5px solid var(--alg-emerald-bright);
}
.tbl tr.grp { cursor: pointer; }
/* Indicateur d'ouverture : chevron (›) qui pivote vers le bas à l'ouverture */
.tbl tr.grp .chev { display: inline-flex; align-items: center; justify-content: center; width: 15px; height: 15px; color: var(--alg-text-3); vertical-align: -3px; transition: transform var(--dur-base) var(--ease-out), color var(--dur-fast); }
.tbl tr.grp .chev svg { width: 12px; height: 12px; display: block; }
.tbl tr.grp .chev.open { transform: rotate(90deg); color: var(--alg-emerald-bright); }
.tbl tr.grp:hover .chev { color: var(--alg-text); }
.tbl tr.grp:hover .chev.open { color: var(--alg-emerald-bright); }
.tbl tr.grp .chev.anim { animation: chevOpen var(--dur-base) var(--ease-out); }
@keyframes chevOpen { from { transform: rotate(0deg); } to { transform: rotate(90deg); } }
/* sous-lignes : apparition douce (fade + léger glissé), en cascade via animation-delay (JS) */
.tbl tr.sub.anim td { animation: subIn var(--dur-base) var(--ease-out) both; }
@keyframes subIn { from { opacity: 0; transform: translateY(-5px); } to { opacity: 1; transform: translateY(0); } }
.row-act { white-space: nowrap; text-align: right; }
.bedit { background: transparent; border: none; color: var(--alg-text-3); padding: var(--sp-1) var(--sp-2); cursor: pointer; border-radius: var(--r-xs); transition: color var(--dur-fast), background var(--dur-fast); }
.bedit:hover { color: var(--alg-emerald-bright); background: var(--alg-emerald-ghost); }
.bedit svg, .bdel svg { width: 15px; height: 15px; display: block; }

/* ---------- BADGES (émeraude only, plus de rainbow) ---------- */
.badge { display: inline-block; font-size: var(--fs-micro); letter-spacing: 0.04em; padding: 3px 9px; border-radius: var(--r-pill); background: var(--alg-emerald-ghost); color: var(--alg-emerald-bright); border: 1px solid var(--alg-border); white-space: nowrap; vertical-align: middle; }
/* Dans un tableau, un long badge (ex. « Revenus de la fortune (intérêts, dividendes) ») peut passer à la ligne :
   sinon il élargit la table au-delà de sa carte et pousse la colonne actions (modifier/supprimer) hors-champ. */
.tbl .badge { white-space: normal; max-width: 100%; border-radius: var(--r-md); line-height: 1.35; text-align: center; }
.tbl td.row-act { width: 1%; white-space: nowrap; }

/* ---------- BOUTONS ---------- */
.btn { display: inline-flex; align-items: center; gap: var(--sp-2); padding: var(--sp-2) var(--sp-4); border-radius: var(--r-sm); font-size: var(--fs-label); font-weight: 500; letter-spacing: 0.02em; cursor: pointer; border: 1px solid transparent; font-family: inherit; transition: transform var(--dur-fast), background var(--dur-base), border-color var(--dur-base), box-shadow var(--dur-base); }
.btn:active { transform: scale(0.985); }
/* Primaire — émeraude profond MAT (léger dégradé pour le relief), liseré fin champagne,
   texte crème (jamais blanc pur). Survol : ombre douce + liseré qui s'éclaire, AUCUN halo vert. */
.bp { background: linear-gradient(180deg, var(--alg-emerald), var(--alg-emerald-deep)); border-color: var(--alg-border-strong); color: #f4f1e8; }   /* crème FIXE : le bouton émeraude est foncé dans les 2 thèmes */
.bp:hover { background: linear-gradient(180deg, var(--alg-emerald-bright), var(--alg-emerald)); border-color: var(--alg-gold-dim); box-shadow: 0 8px 22px -12px rgba(0,0,0,0.7); }
.bg2 { background: transparent; border-color: var(--alg-border-strong); color: var(--alg-text-2); }
.bg2:hover { color: var(--alg-text); border-color: var(--alg-gold-dim); }

/* ---------- INTERRUPTEUR DE THÈME (soleil ⇄ lune) ---------- */
.theme-sw {
  position: relative; width: 54px; height: 27px; flex: 0 0 auto; padding: 0;
  border-radius: var(--r-pill); border: 1px solid var(--alg-border-strong);
  background: var(--alg-surface-2); cursor: pointer;
  transition: background var(--dur-base), border-color var(--dur-base);
}
.theme-sw:hover { border-color: var(--alg-gold-dim); }
.theme-sw svg { position: absolute; top: 50%; transform: translateY(-50%); width: 13px; height: 13px; z-index: 2; pointer-events: none; transition: color var(--dur-base), opacity var(--dur-base); }
.theme-sw-sun  { left: 7px; }
.theme-sw-moon { right: 7px; }
.theme-sw-knob {
  position: absolute; top: 2px; left: 2px; width: 21px; height: 21px; border-radius: 50%;
  background: var(--alg-emerald); box-shadow: 0 1px 3px rgba(0,0,0,0.4); z-index: 1;
  transition: transform var(--dur-base) var(--ease-out), background var(--dur-base);
}
/* SOMBRE (défaut) : knob à droite, lune éclairée (= état courant) */
.theme-sw-knob { transform: translateX(27px); }
.theme-sw-moon { color: #f4f1e8; opacity: 1; }
.theme-sw-sun  { color: var(--alg-text-3); opacity: .75; }
/* CLAIR : knob à gauche, soleil éclairé */
:root[data-theme="light"] .theme-sw-knob { transform: translateX(0); }
:root[data-theme="light"] .theme-sw-sun  { color: #fdf6e3; opacity: 1; }
:root[data-theme="light"] .theme-sw-moon { color: var(--alg-text-3); opacity: .7; }
.bdel { background: transparent; border: none; color: var(--alg-text-3); padding: var(--sp-1) var(--sp-2); cursor: pointer; border-radius: var(--r-xs); transition: color var(--dur-fast), background var(--dur-fast); }
.bdel:hover { color: var(--alg-negative); background: var(--alg-negative-ghost); }

/* ---------- FORMULAIRES ---------- */
.fw { background: var(--alg-emerald-ghost); border: 1px solid var(--alg-border-strong); border-radius: var(--r-md); padding: var(--sp-4); margin-bottom: var(--sp-4); display: none; }
.fw.on { display: block; animation: paneIn var(--dur-base) var(--ease-out); }
.fg3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-3); margin-bottom: var(--sp-3); }
.fg4 { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--sp-3); margin-bottom: var(--sp-3); }

/* ---- Relevés mensuels : formulaire « par classe » ---- */
.snapf-top { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.snap-cols { display: grid; grid-template-columns: 1fr; gap: var(--sp-4); margin-bottom: var(--sp-3); }   /* édition par actif : pleine largeur (nom + classe + montant) */
.snap-sec-h { display: flex; align-items: baseline; justify-content: space-between; gap: var(--sp-2); font-size: var(--fs-micro); letter-spacing: 0.08em; text-transform: uppercase; color: var(--alg-text-2); font-weight: 600; margin-bottom: var(--sp-2); }
.snap-sec-h b { font-family: var(--alg-font-display); font-size: var(--fs-label); color: var(--alg-text); letter-spacing: 0; }
.snap-rows { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-2); }
.snap-row { display: grid; grid-template-columns: 1.3fr 1fr 120px 26px; gap: var(--sp-2); align-items: center; }
/* sous-totaux par classe / par type (visibles dès qu'il y a ≥2 éléments) */
.snap-bd { display: flex; flex-wrap: wrap; gap: 5px 12px; margin: 0 0 8px; }
.snap-bd-it { font-size: var(--fs-micro); color: var(--alg-text-3); }
.snap-bd-it b { color: var(--alg-text-2); font-weight: 600; font-variant-numeric: tabular-nums; }
@media (max-width: 480px) { .snap-row { grid-template-columns: 1fr 1fr 90px 24px; } }
.snap-rm { background: none; border: none; color: var(--alg-text-3); font-size: 18px; line-height: 1; cursor: pointer; border-radius: var(--r-xs); transition: color var(--dur-fast); }
.snap-rm:hover { color: var(--alg-negative); }
.snapf-foot { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; margin-top: var(--sp-3); padding-top: var(--sp-3); border-top: 1px solid var(--alg-border); }
.snap-err { display: none; font-size: var(--fs-caption); color: var(--alg-negative); margin-top: var(--sp-3); }
.snap-err.on { display: block; }
@media (max-width: 760px) { .snapf-top, .snap-cols { grid-template-columns: 1fr; } }
.fl { font-size: var(--fs-micro); letter-spacing: 0.08em; text-transform: uppercase; color: var(--alg-text-2); display: block; margin-bottom: var(--sp-1); }
input:not([type]), input[type=text], input[type=number], input[type=password], input[type=email], input[type=month], select {
  width: 100%; background: var(--alg-surface-2); border: 1px solid var(--alg-border-strong);
  border-radius: var(--r-xs); color: var(--alg-text); font-size: var(--fs-label); padding: var(--sp-2) var(--sp-3);
  outline: none; font-family: inherit; transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
input:focus, select:focus { border-color: var(--alg-emerald-bright); box-shadow: 0 0 0 3px var(--alg-emerald-glow); }
input::placeholder { color: var(--alg-text-3); }
/* Sélecteur de mois (relevés rétroactifs) : icône calendrier lisible sur thème sombre */
input[type=month] { color-scheme: dark; }
input[type=month]::-webkit-calendar-picker-indicator { filter: invert(0.7); cursor: pointer; }
[data-theme="light"] input[type=month] { color-scheme: light; }
[data-theme="light"] input[type=month]::-webkit-calendar-picker-indicator { filter: none; }
/* Pas de flèches natives (stepper) sur les champs montant — saisie au clavier */
input[type=number] { -moz-appearance: textfield; appearance: textfield; }
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button { -webkit-appearance: none; appearance: none; margin: 0; }
select option { background: var(--alg-surface); color: var(--alg-text); }
:focus-visible { outline: none; }
button:focus-visible, .tab:focus-visible, a:focus-visible, .seg button:focus-visible { box-shadow: 0 0 0 2px var(--alg-emerald-bright), 0 0 0 5px var(--alg-emerald-glow); border-radius: var(--r-xs); }

.topbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--sp-4); }
.topbar > div, .topbar > span { font-size: var(--fs-label); color: var(--alg-text-2); }

/* ---------- ALLOCATION / BARRES ---------- */
.alloc-row { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-2) 0; border-bottom: 1px solid var(--alg-border); }
.alloc-row:last-child { border: none; }
.prog { height: 4px; background: var(--alg-border); border-radius: var(--r-pill); margin-top: var(--sp-2); overflow: hidden; }
.pf { height: 100%; border-radius: var(--r-pill); background: var(--alg-emerald-bright); transition: width var(--dur-hero) var(--ease-out); }
.hbar-track { height: 6px; background: var(--alg-border); border-radius: var(--r-pill); overflow: hidden; }
.hbar-fill { height: 100%; border-radius: var(--r-pill); background: var(--alg-emerald-bright); transition: width var(--dur-hero) var(--ease-out); }
.hbar-labels { display: flex; justify-content: space-between; font-size: var(--fs-micro); color: var(--alg-text-3); margin-top: var(--sp-2); }

/* ---------- DONUT centre ---------- */
.ch { position: relative; width: 100%; }
.dcwrap { position: relative; }
.dccenter { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); text-align: center; pointer-events: none; max-width: 108px; }
.dccenter .dcval { font-family: var(--alg-font-display); font-size: 18px; color: var(--alg-text); font-variant-numeric: tabular-nums; line-height: 1.1; }
/* label de classe au centre : reste DANS le trou du donut (largeur bornée, retour ligne, moins d'interlettrage) — ne colle pas à l'anneau */
.dccenter .dclb { font-size: var(--fs-micro); letter-spacing: 0.06em; text-transform: uppercase; color: var(--alg-text-2); line-height: 1.18; white-space: normal; overflow-wrap: break-word; margin-top: 3px; }

/* ---------- ÉTATS VIDES ---------- */
.empty { text-align: center; padding: var(--sp-7); color: var(--alg-text-3); font-size: var(--fs-label); }
.empty-icon { color: var(--alg-text-3); margin-bottom: var(--sp-3); opacity: 0.5; display: inline-flex; }
.empty-icon svg { width: 26px; height: 26px; }

/* minmax(0,1fr) : empêche le contenu (badges non-sécables) d'élargir une colonne au-delà de sa moitié → reste aligné avec les cartes du dessus */
.cfgrid { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1fr); gap: var(--sp-4); }

/* segmented control (temporalité dépenses) */
.seg { display: inline-flex; background: var(--alg-surface-2); border: 1px solid var(--alg-border); border-radius: var(--r-pill); padding: 2px; gap: 2px; flex-shrink: 0; }
.seg button { background: none; border: none; color: var(--alg-text-2); font-family: inherit; font-size: var(--fs-caption); padding: 5px 13px; border-radius: var(--r-pill); cursor: pointer; transition: color var(--dur-fast), background var(--dur-fast); white-space: nowrap; }
.seg button:hover { color: var(--alg-text); }
.seg button.on { background: var(--alg-emerald); color: #fff; }
.diff { font-size: var(--fs-caption); font-variant-numeric: tabular-nums; }
.diff.up { color: var(--alg-emerald-bright); } .diff.dn { color: var(--alg-negative); }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 760px) {
  .w { padding: 0 var(--sp-4) var(--sp-8); }
  .hdr, .tabs, .pane { padding-left: var(--sp-4); padding-right: var(--sp-4); }
  .hdr { flex-wrap: wrap; row-gap: var(--sp-2); }
  .hdr-r { gap: var(--sp-2); flex-wrap: wrap; justify-content: flex-end; }
  .pane .card { overflow-x: auto; }   /* filet : un tableau trop large scrolle dans sa carte au lieu de casser la page */
  .kgrid { grid-template-columns: 1fr 1fr; }
  .r2 { grid-template-columns: 1fr; }
  .fg4, .fg3 { grid-template-columns: 1fr 1fr; }
  .k.gk .kv { font-size: 30px; }
}
/* Budget : Revenus | Dépenses = 2 tableaux à 4 colonnes → empilés plus tôt pour leur laisser de la largeur (sinon le tableau Dépenses déborde de sa carte) */
@media (max-width: 1080px) { .cfgrid { grid-template-columns: minmax(0,1fr); } .cfgrid > * { min-width: 0; } }   /* minmax(0,..) + min-width:0 : la piste peut rétrécir sous le contenu (sinon le tableau Dépenses pousse la page) */
@media (max-width: 420px) { .kgrid { grid-template-columns: 1fr; } }

/* ---------- AUTH (écran de connexion) ---------- */
body:not(.authed) .w { display: none; }            /* app cachée tant qu'on n'est pas connecté */
.auth-overlay {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center; padding: var(--sp-5);
}
body.authed .auth-overlay { display: none; }
/* Écran de changement de mot de passe forcé (1re connexion) : masqué sauf en mode pw-change */
#pwchange-overlay { display: none; }
body.pw-change #auth-overlay { display: none; }
body.pw-change #pwchange-overlay { display: flex; }
body.authed #pwchange-overlay { display: none; }
.auth-hint { text-align: center; color: var(--alg-text-2); font-size: var(--fs-caption); line-height: 1.55; margin: 0 0 var(--sp-5); }
.pw-rules { list-style: none; margin: -6px 0 var(--sp-4); padding: 0; display: flex; flex-wrap: wrap; gap: 4px var(--sp-4); }
.pw-rules li { font-size: var(--fs-caption); color: var(--alg-text-3); display: inline-flex; align-items: center; gap: 6px; transition: color var(--dur-fast); }
.pw-rules li::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--alg-text-3); flex: 0 0 auto; transition: background var(--dur-fast), transform var(--dur-fast); }
.pw-rules li.ok { color: var(--alg-emerald-bright); }
.pw-rules li.ok::before { background: var(--alg-emerald-bright); transform: scale(1.25); }
.auth-card {
  width: 100%; max-width: 380px;
  background: linear-gradient(160deg, var(--alg-olive), var(--alg-surface) 80%);
  border: 1px solid var(--alg-border-strong); border-radius: var(--r-lg);
  padding: var(--sp-7) var(--sp-6); box-shadow: var(--shadow-3);
  animation: paneIn var(--dur-slow) var(--ease-out);
}
/* Logo (login) = même SVG que le header, hauteur ≈ ancienne taille de police (26px), centré, theme-aware */
.auth-brand { height: 26px; background: url("../assets/logo-alg.svg") no-repeat center / contain; }
:root[data-theme="light"] .auth-brand { background-image: url("../assets/logo-alg-black.svg"); }
.auth-sub { text-align: center; color: var(--alg-text-2); font-size: var(--fs-label); margin: var(--sp-2) 0 var(--sp-6); }
.auth-field { margin-bottom: var(--sp-4); }
.auth-msg { font-size: var(--fs-caption); min-height: 18px; margin-bottom: var(--sp-3); }
.auth-msg.error { color: var(--alg-negative); }
.auth-msg.ok { color: var(--alg-emerald-bright); }
#au-submit { width: 100%; justify-content: center; }
.auth-foot { display: flex; flex-direction: column; gap: var(--sp-2); text-align: center; margin-top: var(--sp-5); font-size: var(--fs-caption); color: var(--alg-text-3); }
.auth-foot a { color: var(--alg-emerald-bright); text-decoration: none; }
.auth-foot a:hover { text-decoration: underline; }

/* ---------- ONBOARDING (coach-marks) ---------- */
.tour-back { position: fixed; inset: 0; z-index: 300; background: var(--alg-scrim); opacity: 0; transition: opacity var(--dur-base); backdrop-filter: blur(2px); }
.tour-spot {
  position: fixed; z-index: 301; border-radius: var(--r-md); opacity: 0; pointer-events: none;
  box-shadow: 0 0 0 9999px var(--alg-scrim), inset 0 0 0 1px var(--alg-gold-dim), 0 0 0 4px var(--alg-emerald-glow);
  transition: left var(--dur-slow) var(--ease-emphasis), top var(--dur-slow) var(--ease-emphasis),
              width var(--dur-slow) var(--ease-emphasis), height var(--dur-slow) var(--ease-emphasis), opacity var(--dur-base);
}
.tour-capsule {
  position: fixed; z-index: 302; max-width: 360px;
  background: linear-gradient(160deg, var(--alg-olive), var(--alg-surface) 85%);
  border: 1px solid var(--alg-border-strong); border-radius: var(--r-lg);
  padding: var(--sp-5); box-shadow: var(--shadow-3);
  transition: left var(--dur-slow) var(--ease-out), top var(--dur-slow) var(--ease-out);
}
.tour-dots { display: flex; gap: 6px; margin-bottom: var(--sp-4); }
.tour-dots span { width: 6px; height: 6px; border-radius: var(--r-pill); background: var(--alg-border-strong); transition: all var(--dur-base); }
.tour-dots span.on { background: var(--alg-gold); width: 18px; }
.tour-title { font-family: var(--alg-font-display); font-size: 20px; color: var(--alg-text); margin-bottom: var(--sp-2); line-height: 1.2; }
.tour-text { font-size: var(--fs-label); color: var(--alg-text-2); line-height: 1.6; }
.tour-actions { display: flex; align-items: center; margin-top: var(--sp-5); }
.tour-skip { background: none; border: none; color: var(--alg-text-3); font-family: inherit; font-size: var(--fs-caption); cursor: pointer; padding: var(--sp-2); }
.tour-skip:hover { color: var(--alg-text-2); }
.tour-next { margin-left: auto; }
.tour-capsule::before { content: ""; position: absolute; left: 50%; transform: translateX(-50%) rotate(45deg); width: 12px; height: 12px; background: var(--alg-olive); border: 1px solid var(--alg-border-strong); opacity: 0; }
.tour-capsule.arrow-up::before { top: -7px; border-right: none; border-bottom: none; opacity: 1; }
.tour-capsule.arrow-down::before { bottom: -7px; border-left: none; border-top: none; opacity: 1; }

/* ============================================================
   SYNTHÈSE — Finary complet (héros calme + dense, marque ALG)
   Tous les --fs-* portent déjà l'unité px → usage direct.
   ============================================================ */

/* ---- ROW 1 : bande KPI ---- */
.sy-kpis { margin-bottom: var(--sp-6); }
.sy-kpi  { display: flex; flex-direction: column; }   /* .k a déjà position:relative + overflow:hidden */
.sy-kpi .kv { margin-top: var(--sp-1); }
.sy-kpis .k.gk .kv { font-size: clamp(19px, 8.4cqi, 30px); white-space: nowrap; }   /* héros : s'ajuste si très grand nombre, jamais de retour ligne */


/* bloc méta (pastille + sous-texte) poussé en bas de carte → bases alignées */
.sy-meta { display: flex; flex-direction: column; gap: var(--sp-1); margin-top: auto; padding-top: var(--sp-3); }
.sy-meta .trend { align-self: flex-start; margin-top: 0; }
.sy-meta .ks { margin-top: 0; font-variant-numeric: tabular-nums; }

/* ---- ROW 2 / ROW 3 : grilles ---- */
/* colonnes de MÊME hauteur : la liste d'allocation (souvent plus haute) fixe la
   hauteur, le graphe héros grandit pour remplir → plus de vide ni de cartes collées */
.sy-r2 { grid-template-columns: 1fr minmax(280px, 340px); gap: var(--sp-5); align-items: stretch; margin-bottom: var(--sp-6); }
.sy-r3 { gap: var(--sp-5); }

/* ---- Évolution (panneau héros) ---- */
.sy-evo { margin-bottom: 0; display: flex; flex-direction: column; }
.sy-evo-head { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--sp-4); margin-bottom: var(--sp-3); }
.sy-evo-lead { display: flex; flex-direction: column; min-width: 0; }
.sy-evo-figure { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.sy-evo-val {
  font-family: var(--alg-font-display); font-size: var(--fs-display); line-height: 1;
  color: var(--alg-gold); font-variant-numeric: tabular-nums;   /* figure focale or, miroir de la carte héros */
}
.sy-evo-seg { flex: 0 0 auto; }
.sy-evo-trend { margin-top: 0; }

/* légende custom (la légende Chart.js est désactivée) */
.sy-legend { display: flex; flex-wrap: wrap; gap: var(--sp-4); margin-bottom: var(--sp-3); }
.sy-leg { display: inline-flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-caption); color: var(--alg-text-2); }
.sy-dot { width: 8px; height: 8px; border-radius: var(--r-pill); display: inline-block; flex: 0 0 auto; }
.sy-dot-net { background: var(--alg-gold); }
.sy-dot-as  { background: var(--alg-emerald-bright); }
.sy-dot-de  { background: var(--alg-debt); }   /* « Dépenses » : gris neutre */
.sy-dot-debt { background: var(--alg-debt); }   /* courbe « Dettes » : gris neutre */
.sy-area-wrap { width: 100%; flex: 1 1 auto; min-height: 300px; }
.sy-evo-empty { padding: var(--sp-6) var(--sp-5); }
/* :not([hidden]) : ne pas écraser le display:none de l'attribut hidden quand le graphe est affiché */
.sy-evo-empty:not([hidden]) { flex: 1 1 auto; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.sy-empty-t { font-family: var(--alg-font-display); font-size: var(--fs-h3); color: var(--alg-text); margin: var(--sp-2) 0 var(--sp-1); }

/* ---- Allocation ---- */
.sy-alloc { margin-bottom: 0; }
.sy-alloc-figure { display: flex; flex-direction: column; gap: 2px; margin: var(--sp-2) 0 var(--sp-4); }
.sy-alloc-val { font-family: var(--alg-font-display); font-size: var(--fs-h2); color: var(--alg-text); font-variant-numeric: tabular-nums; line-height: 1.1; }
.sy-donut { margin-bottom: var(--sp-4); }

/* lignes d'allocation denses : ligne label + valeur, puis mini-barre de part */
.sy-alloc .alloc-row { display: block; padding: var(--sp-3) 0; border-top: 1px solid var(--alg-border); border-bottom: 0; }
.sy-alloc .alloc-row:first-child { border-top: 0; }
.alloc-top { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); }
.alloc-name { display: inline-flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-label); color: var(--alg-text); min-width: 0; }
.alloc-name span { white-space: normal; line-height: 1.25; }
.alloc-vals { display: flex; align-items: baseline; gap: var(--sp-2); flex: 0 0 auto; }
.alloc-val { color: var(--alg-text); font-size: var(--fs-label); font-variant-numeric: tabular-nums; }
.alloc-pct { color: var(--alg-text-3); font-size: var(--fs-caption); font-variant-numeric: tabular-nums; min-width: 36px; text-align: right; }

/* ---- Flux mensuel ---- */
.sy-flux { display: flex; flex-direction: column; }
.flux-rows { display: flex; flex-direction: column; }
.flux-row { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-2) 0; }
.flux-lb { display: inline-flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-label); color: var(--alg-text-2); }
.flux-v { font-variant-numeric: tabular-nums; font-size: var(--fs-body); color: var(--alg-text); }
.flux-v.g { color: var(--alg-emerald-bright); }
.flux-v.r { color: var(--alg-negative); }
.flux-v.debt { color: var(--alg-debt); }   /* dépenses : gris neutre (call 18/06) */
.flux-row-total { border-top: 1px solid var(--alg-border-strong); margin-top: var(--sp-1); padding-top: var(--sp-3); }
.flux-row-total .flux-lb { color: var(--alg-text); }
.flux-row-total .flux-v { font-family: var(--alg-font-display); font-size: var(--fs-h3); }
.flux-bar { display: flex; height: 10px; border-radius: var(--r-pill); overflow: hidden; background: var(--alg-surface-2); margin-top: var(--sp-4); }
.flux-bar-rev { background: var(--alg-emerald-bright); height: 100%; transition: width var(--dur-hero) var(--ease-out); }
.flux-bar-exp { background: var(--alg-debt); height: 100%; opacity: .9; transition: width var(--dur-hero) var(--ease-out); }
.flux-foot { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); margin-top: var(--sp-2); }
.flux-foot .diff { font-weight: 600; }

/* ---- Top actifs ---- */
.sy-top-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-4); }
.sy-top-tbl { width: 100%; }
.sy-top-tbl .ta-r { text-align: right; font-variant-numeric: tabular-nums; }
.sy-top-tbl td.ta-r { text-align: right; }
.sy-top-pct { color: var(--alg-text-3); }
.sy-top-empty { padding: var(--sp-6) var(--sp-5); }
.sy-top-sub { display: none; }   /* classe inline : visible seulement quand la colonne Classe est masquée (mobile) */

/* ---- Responsive <=760px ---- */
@media (max-width: 760px) {
  .sy-r2 { grid-template-columns: 1fr; }
  .sy-evo-head { flex-direction: column; gap: var(--sp-3); }
  .sy-evo-seg { width: 100%; }
  .sy-evo-seg button { flex: 1; text-align: center; }
  .sy-evo-val { font-size: var(--fs-h1); }
  .sy-legend { gap: var(--sp-3); }
  .sy-kpis .k.gk .kv { font-size: clamp(17px, 7.4cqi, 26px); }   /* cartes 2-col plus étroites : héros sur une ligne */
}
@media (max-width: 480px) {
  .sy-top-tbl th:nth-child(2), .sy-top-tbl td:nth-child(2) { display: none; }
  .sy-top-sub { display: block; font-size: var(--fs-micro); color: var(--alg-text-3); margin-top: 2px; }
  /* Actifs : masquer Classe + Note → Nom / Valeur / % / actions */
  .tbl-as th:nth-child(2), .tbl-as td:nth-child(2), .tbl-as th:nth-child(5), .tbl-as td:nth-child(5) { display: none; }
  /* Historique : masquer vs / Actifs / Dettes → Mois / Net / Épargne / actions */
  .tbl-hi th:nth-child(3), .tbl-hi td:nth-child(3), .tbl-hi th:nth-child(4), .tbl-hi td:nth-child(4), .tbl-hi th:nth-child(5), .tbl-hi td:nth-child(5) { display: none; }
}

/* ============================================================
   ONBOARDING — wizard de saisie premium
   ============================================================ */
.wz-overlay {
  position: fixed; inset: 0; z-index: 400; display: none;
  align-items: flex-start; justify-content: center; overflow-y: auto;
  padding: clamp(28px, 9vh, 88px) var(--sp-5) var(--sp-7);
  background:
    radial-gradient(900px 500px at 50% -5%, rgba(42,91,67,0.10), transparent 60%),
    radial-gradient(700px 600px at 50% 112%, rgba(227,214,177,0.05), transparent 60%),
    var(--alg-bg);
}
.wz { width: 100%; max-width: 560px; margin: 0 auto; animation: paneIn var(--dur-slow) var(--ease-out); }
.wz-prog { display: flex; gap: 6px; margin-bottom: var(--sp-2); }
.wz-prog span { flex: 1; height: 3px; border-radius: var(--r-pill); background: var(--alg-border-strong); transition: background var(--dur-base); }
.wz-prog span.on { background: var(--alg-gold); }
.wz-prog span.done { background: var(--alg-emerald-bright); }
.wz-step { font-size: var(--fs-micro); letter-spacing: 0.14em; text-transform: uppercase; color: var(--alg-text-3); margin-bottom: var(--sp-6); }
/* Logo (onboarding) = même SVG, hauteur ≈ ancienne taille (22px), centré, theme-aware */
.wz-brand { height: 22px; background: url("../assets/logo-alg.svg") no-repeat center / contain; margin-bottom: var(--sp-5); }
:root[data-theme="light"] .wz-brand { background-image: url("../assets/logo-alg-black.svg"); }
.wz-title { font-family: var(--alg-font-display); font-size: 30px; line-height: 1.12; color: var(--alg-text); margin-bottom: var(--sp-3); }
.wz-intro { font-size: var(--fs-body); color: var(--alg-text-2); line-height: 1.6; margin-bottom: var(--sp-6); }
.wz-intro b { color: var(--alg-text); }
.wz-list { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-3); }
.wz-row { display: grid; gap: var(--sp-2); align-items: center; }
.wz-inc { grid-template-columns: 1fr 110px 128px 30px; }
.wz-exp { grid-template-columns: 1fr 96px 128px 30px; }
.wz-ass { grid-template-columns: 1fr 1fr 120px 30px; }
/* Dette = 6 champs → 2 lignes : [Nom | Type | ×] puis [Restant | Mensualité | Taux | Initial] */
.wz-deb { grid-template-columns: 1fr 1fr 1fr 1fr 28px; }
.wz-deb .wz-name { grid-column: 1 / 3; }
.wz-deb .wz-dt   { grid-column: 3 / 5; }
.wz-deb .wz-rm   { grid-column: 5; grid-row: 1 / 3; align-self: center; }
.wz-fixed { font-size: var(--fs-label); color: var(--alg-text); padding: 0 var(--sp-1); }
.wz-rm { background: none; border: none; color: var(--alg-text-3); font-size: 18px; line-height: 1; cursor: pointer; border-radius: var(--r-xs); transition: color var(--dur-fast), background var(--dur-fast); }
.wz-rm:hover { color: var(--alg-negative); background: var(--alg-negative-ghost); }
.wz-add { background: transparent; border: 1px dashed var(--alg-border-strong); color: var(--alg-emerald-bright); border-radius: var(--r-sm); padding: var(--sp-3); width: 100%; font-family: inherit; font-size: var(--fs-label); cursor: pointer; transition: border-color var(--dur-fast), background var(--dur-fast); }
.wz-add:hover { border-color: var(--alg-emerald-bright); background: var(--alg-emerald-ghost); }
.wz-actions { display: flex; align-items: center; gap: var(--sp-3); margin-top: var(--sp-7); }
.wz-skip { background: none; border: none; color: var(--alg-text-3); font-family: inherit; font-size: var(--fs-caption); cursor: pointer; }
.wz-skip:hover { color: var(--alg-text-2); }
.wz-actions .wz-next { margin-left: auto; }
.wz-center { text-align: center; padding-top: var(--sp-2); }
.wz-center .wz-intro { max-width: 420px; margin: 0 auto var(--sp-6); }
.wz-cta { width: 100%; max-width: 320px; margin: var(--sp-4) auto 0; justify-content: center; }
.wz-back-min { display: flex; align-items: center; justify-content: center; gap: 6px; margin: var(--sp-4) auto 0; background: none; border: none; color: var(--alg-text-3); font-family: inherit; font-size: var(--fs-caption); cursor: pointer; transition: color var(--dur-fast); }
.wz-back-min:hover { color: var(--alg-text); }
.wz-back-min svg { width: 15px; height: 15px; }

/* ---- Onboarding : écran final (photo héros + flèche animée + CTA shiny) ---- */
.wz-hero-photo { position: relative; width: 100%; max-width: 430px; margin: 0 auto var(--sp-6); border-radius: 18px; overflow: hidden; border: 1px solid var(--alg-border-strong); box-shadow: var(--shadow-3); }
.wz-hero-photo img { display: block; width: 100%; max-height: 380px; object-fit: cover; object-position: center top; }
.wz-hero-scrim { position: absolute; inset: 0; pointer-events: none; background: linear-gradient(180deg, transparent 55%, var(--alg-scrim) 100%); }
.wz-arrow { margin: 10px 0 6px; display: flex; justify-content: center; animation: wzArrowBob 1.7s var(--ease-in-out) infinite; }
.wz-arrow svg { width: 28px; height: 28px; }
@keyframes wzArrowBob { 0%,100% { transform: translateY(0); opacity: .55; } 50% { transform: translateY(6px); opacity: 1; } }

/* CTA « shiny » — liseré dégradé or↔émeraude, fond émeraude-noir, texte or lumineux, reflet au survol.
   Fond sombre fixe dans les 2 thèmes (CTA premium qui ressort). Inspiré du style demandé, en couleurs ALG. */
.btn-shiny {
  position: relative; display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  padding: 13px var(--sp-5); cursor: pointer; font-family: inherit; font-size: var(--fs-label); letter-spacing: 0.04em;
  border: 1.5px solid transparent; border-radius: var(--r-md); overflow: hidden; isolation: isolate;
  background: linear-gradient(180deg, #15251b, #0b130d) padding-box,
              linear-gradient(145deg, var(--alg-gold), var(--alg-emerald-bright) 48%, var(--alg-gold-dim)) border-box;
  box-shadow: 0 10px 28px -12px rgba(0,0,0,0.7), inset 0 0 18px rgba(227,214,177,0.06);
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base);
}
.btn-shiny > span { position: relative; z-index: 2; background: linear-gradient(180deg, #f4ecd2, #d6c393); -webkit-background-clip: text; background-clip: text; color: transparent; text-shadow: 0 0 16px rgba(227,214,177,0.22); }
.btn-shiny::before { content: ""; position: absolute; inset: 0; z-index: 1; border-radius: inherit; pointer-events: none; background: radial-gradient(120% 90% at 50% -10%, rgba(227,214,177,0.16), transparent 62%); }
.btn-shiny::after { content: ""; position: absolute; top: 0; bottom: 0; left: 0; width: 45%; z-index: 1; pointer-events: none; background: linear-gradient(100deg, transparent, rgba(255,255,255,0.1), transparent); transform: translateX(-220%) skewX(-16deg); }
.btn-shiny:hover { transform: translateY(-1px); box-shadow: 0 14px 34px -12px rgba(0,0,0,0.78), inset 0 0 24px rgba(227,214,177,0.12); }
.btn-shiny:hover::after { animation: shinySweep 1.1s var(--ease-out); }
.btn-shiny:active { transform: translateY(0); }
@keyframes shinySweep { from { transform: translateX(-220%) skewX(-16deg); } to { transform: translateX(360%) skewX(-16deg); } }
@media (prefers-reduced-motion: reduce) { .wz-arrow { animation: none; } .btn-shiny:hover::after { animation: none; } }

/* ---------- Tour guidé (spotlight) ---------- */
#tour-layer { position: fixed; inset: 0; z-index: 500; display: none; }
body.tour-on #tour-layer { display: block; }
#tour-hole { position: absolute; border-radius: var(--r-md); box-shadow: 0 0 0 9999px var(--alg-scrim); transition: top var(--dur-base) var(--ease-out), left var(--dur-base) var(--ease-out), width var(--dur-base) var(--ease-out), height var(--dur-base) var(--ease-out); }
#tour-card { position: fixed; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 340px; max-width: calc(100vw - 32px); background: var(--card-sheen), var(--card-bg); border: 1px solid var(--alg-border-strong); border-radius: var(--r-md); padding: var(--sp-5); box-shadow: var(--shadow-3); }
#tour-step { font-size: var(--fs-micro); letter-spacing: 0.12em; text-transform: uppercase; color: var(--alg-text-3); font-weight: 600; margin-bottom: var(--sp-2); }
#tour-title { font-family: var(--alg-font-display); font-size: var(--fs-h3); color: var(--alg-text); margin-bottom: var(--sp-2); line-height: 1.2; }
#tour-text { font-size: var(--fs-label); color: var(--alg-text-2); line-height: 1.55; margin-bottom: var(--sp-4); }
#tour-nav { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); }
.tour-skip { background: none; border: none; color: var(--alg-text-3); font-family: inherit; font-size: var(--fs-caption); cursor: pointer; transition: color var(--dur-fast); }
.tour-skip:hover { color: var(--alg-text); }
#tour-next { min-width: 118px; }
/* Proposition du tour : carte CENTRÉE au milieu de l'écran, avec fond voilé (choix démarrer / plus tard) */
#tour-offer { position: fixed; inset: 0; z-index: 450; display: flex; align-items: center; justify-content: center; padding: 24px; background: rgba(4,7,10,0.62); -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px); opacity: 0; transition: opacity var(--dur-base); }
#tour-offer.on { opacity: 1; }
.tour-offer-card { width: min(420px, 100%); text-align: center; padding: var(--sp-6) var(--sp-6) var(--sp-5); background: var(--card-sheen), var(--card-bg); border: 1px solid var(--alg-border-strong); border-radius: var(--r-md); box-shadow: var(--shadow-3); transform: translateY(10px) scale(0.98); transition: transform var(--dur-base) var(--ease-out); }
#tour-offer.on .tour-offer-card { transform: none; }
.tour-offer-t { font-family: var(--alg-font-display); font-size: 22px; color: var(--alg-text); margin-bottom: var(--sp-3); }
.tour-offer-d { font-size: var(--fs-label); color: var(--alg-text-2); line-height: 1.6; margin-bottom: var(--sp-5); }
.tour-offer-dur { color: var(--alg-text-3); white-space: nowrap; }
.tour-offer-actions { display: flex; flex-direction: column; align-items: center; gap: var(--sp-2); }
.tour-offer-actions .btn-shiny { width: 100%; max-width: 260px; padding: 11px var(--sp-4); }
@media (prefers-reduced-motion: reduce) { .tour-offer-card { transition: none; transform: none; } }

.wz-skipall { display: block; margin: var(--sp-4) auto 0; background: none; border: none; color: var(--alg-text-3); font-family: inherit; font-size: var(--fs-caption); cursor: pointer; }
.wz-skipall:hover { color: var(--alg-text-2); }
.wz-check { width: 52px; height: 52px; margin: 0 auto var(--sp-4); border-radius: var(--r-pill); display: grid; place-items: center; color: var(--alg-emerald-bright); background: var(--alg-emerald-ghost); border: 1px solid var(--alg-emerald); }
.wz-check svg { width: 26px; height: 26px; }

/* ── Onboarding → dashboard : dissolution de l'overlay + révélation feutrée ── */
.wz-overlay { transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out); }
.wz-overlay.wz-closing { opacity: 0; transform: scale(1.015); pointer-events: none; }
/* le contenu du dashboard monte en place une fois l'overlay dissous (joué une seule fois) */
/* Cascade d'arrivée : chaque cellule (KPI + cartes) apparaît l'une après l'autre (connexion/démo).
   Délais posés en inline par playEnterAnimation() pour un enchaînement séquentiel régulier. */
@keyframes cellIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
@keyframes dashReveal { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
body.dash-enter main .pane.on > * { animation: dashReveal var(--dur-hero) var(--ease-out) both; }
body.dash-enter main .pane.on > *:nth-child(1) { animation-delay: 260ms; }
body.dash-enter main .pane.on > *:nth-child(2) { animation-delay: 360ms; }
body.dash-enter main .pane.on > *:nth-child(3) { animation-delay: 460ms; }
body.dash-enter main .pane.on > *:nth-child(n+4) { animation-delay: 540ms; }
@media (prefers-reduced-motion: reduce) {
  .wz-overlay { transition: none; }
  body.dash-enter main .pane.on > * { animation: none; }
}
@media (max-width: 560px) {
  .wz-overlay { padding: clamp(20px, 6vh, 52px) var(--sp-4) var(--sp-6); }
  .wz-title { font-size: 25px; }
  .wz-row { display: flex; flex-wrap: wrap; }
  .wz-row > * { flex: 1 1 38%; }
  .wz-row .wz-name, .wz-row .wz-fixed, .wz-row .wz-type, .wz-row .wz-catsel, .wz-row .wz-dt { flex-basis: 100%; }
  .wz-row .wz-rm { flex: 0 0 auto; }
}

/* ---------- Audit 18.06 : feedback de saisie invalide + bandeau démo ---------- */
input.invalid, select.invalid { border-color: var(--alg-negative) !important; box-shadow: 0 0 0 3px var(--alg-negative-ghost) !important; }
.sp.st-err { color: var(--alg-negative); }
.demo-banner { display: none; }
body.demo-on .demo-banner {
  display: flex; align-items: center; gap: 7px;
  position: fixed; left: 50%; bottom: 16px; transform: translateX(-50%); z-index: 9998;
  padding: 8px 16px; border-radius: var(--r-pill);
  background: var(--alg-scrim-pill); border: 1px solid var(--alg-border-strong);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  color: var(--alg-text-2); font-size: var(--fs-caption); box-shadow: var(--shadow-2);
  pointer-events: none; max-width: calc(100vw - 32px); white-space: nowrap;
}
body.demo-on .demo-banner b { color: var(--alg-gold); font-weight: 600; }
body.demo-on .w { padding-bottom: 76px; } /* la pastille démo flotte en bas → laisser de l'air sous le contenu */

/* Bouton « Simuler l'onboarding » — visible UNIQUEMENT en mode démo (jamais pour un vrai client) */
#sim-onb { display: none; }
body.demo-on #sim-onb {
  display: inline-flex; align-items: center; gap: 6px;
  position: fixed; left: 16px; bottom: 16px; z-index: 9998;
  padding: 8px 14px; border-radius: var(--r-pill);
  background: var(--alg-scrim-pill); border: 1px solid var(--alg-border-strong);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  color: var(--alg-text-2); font-family: inherit; font-size: var(--fs-caption); letter-spacing: 0.02em;
  cursor: pointer; box-shadow: var(--shadow-2);
  transition: color var(--dur-fast), border-color var(--dur-fast), transform var(--dur-fast);
}
body.demo-on #sim-onb:hover { color: var(--alg-text); border-color: var(--alg-emerald-bright); transform: translateY(-1px); }

/* Légende du treemap actifs (les petites cases sont muettes → on liste tout dessous) */
.tree-legend { display: flex; flex-wrap: wrap; gap: var(--sp-2) var(--sp-4); margin-top: var(--sp-4); }
.tl-item { display: inline-flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-caption); color: var(--alg-text-2); }
.tl-item b { color: var(--alg-text); font-weight: 600; font-variant-numeric: tabular-nums; }
.tl-dot { width: 9px; height: 9px; border-radius: 2px; display: inline-block; flex: 0 0 auto; }

/* ============================================================
   MOBILE & CROSS-NAVIGATEUR — durcissement (audit responsive 21.06)
   Cible : iPhone/Android, Safari/iOS, Firefox/Zen, Chrome. Sans bug.
   ============================================================ */

/* Pas de flash gris au tap (iOS/Android) */
* { -webkit-tap-highlight-color: transparent; }

/* Safari ancien : fallback vh AVANT dvh */
body { min-height: 100vh; min-height: 100dvh; }

/* backdrop-filter : Safari/iOS exige le préfixe -webkit (sinon aucun flou) */
.hdr { -webkit-backdrop-filter: blur(20px); }
.tour-back { -webkit-backdrop-filter: blur(2px); }

/* Scroll tactile fluide (momentum iOS) sur les zones qui défilent */
.tabs, .pane .card, .wz-overlay { -webkit-overflow-scrolling: touch; }

/* iOS zoome au focus si la police d'un champ < 16px → on force 16px sur tactile/mobile */
@media (max-width: 768px) {
  input:not([type=checkbox]):not([type=radio]), select, textarea { font-size: 16px; }
}

/* Cibles tactiles confortables (écrans tactiles uniquement → ne change rien au desktop) */
@media (pointer: coarse) {
  .bedit, .bdel, .wz-rm { min-width: 40px; min-height: 38px; }
  .seg button, .tab { min-height: 40px; }
}

/* ---- Téléphone (≤ 480px) ---- */
@media (max-width: 480px) {
  /* Formulaires d'ajout/édition : 1 colonne (saisie au doigt) */
  .fg4, .fg3 { grid-template-columns: 1fr; }
  /* Budget Revenus/Dépenses : masquer la colonne Type/Catégorie (texte long → débordait la page) */
  #p-bu .tbl th:nth-child(2), #p-bu .tbl td:nth-child(2) { display: none; }
  /* En-tête compact (MOBILE uniquement) : boutons plus petits → tiennent sur une ligne */
  .hdr { padding: var(--sp-3) var(--sp-4); }
  .hdr-r { gap: 4px; }
  .hdr-r .btn { padding: 4px 7px; font-size: var(--fs-micro); }
  .hdr-r .btn.bp { padding: 4px 9px; }                  /* Snapshot : un poil plus large car action principale */
  .hdr-r .btn[aria-label="Revoir le guide"] { padding: 4px 7px !important; }   /* neutralise le padding inline du « ? » sur mobile */
  .hdr .theme-sw { transform: scale(0.8); transform-origin: right center; }   /* bascule thème réduite */
  .logo { width: 122px; height: 20px; }
  /* Tableaux : padding cellules resserré pour que la colonne d'actions ne soit pas rognée */
  .tbl th, .tbl td { padding-left: 6px; padding-right: 6px; }
  .tbl td.row-act, .tbl th:last-child { padding-right: 2px; }
  /* Bouton démo : repositionné pour ne plus chevaucher le contenu ni le bandeau */
  body.demo-on #sim-onb { left: 8px; bottom: 60px; font-size: 11px; padding: 6px 9px; }
  body.demo-on .w { padding-bottom: 96px; }
  /* Carte de proposition du tour : marge de sécurité sur petit écran */
  .tour-offer-card { padding: var(--sp-5) var(--sp-4) var(--sp-4); }
  .tour-offer-t { font-size: 20px; }
}

/* Très petits écrans (≤ 360px) : héros encore plus souple, pas de débordement */
@media (max-width: 360px) {
  .logo { width: 110px; height: 18px; }
  .k.gk .kv { font-size: 27px; }
  .pane, .hdr, .tabs { padding-left: var(--sp-3); padding-right: var(--sp-3); }
}

/* [SEC mobile] Flou de l'app en arrière-plan (anti-fuite via la vignette du sélecteur d'apps) */
body.app-hidden .w { filter: blur(22px); transition: filter 0.12s ease; pointer-events: none; }
@media (prefers-reduced-motion: reduce) { body.app-hidden .w { transition: none; } }

/* ============================================================
   MOBILE — en-tête auto-masquant + onglets (correctifs 21.06)
   ============================================================ */
/* En-tête : se cache au scroll vers le bas, réapparaît au scroll vers le haut / tout en haut (mobile) */
@media (max-width: 768px) {
  .hdr { transition: transform 0.28s var(--ease-out); will-change: transform; }
  body.hdr-hidden .hdr { transform: translateY(-100%); }
}
/* Onglets : les 4 TIENNENT à l'écran, scroll horizontal SEULEMENT, aucun déplacement vertical */
@media (max-width: 480px) {
  .tabs { overflow-y: hidden; touch-action: pan-x; padding-left: var(--sp-2); padding-right: var(--sp-2); gap: 0; }
  .tab { flex: 1 1 0; min-width: 0; text-align: center; padding: var(--sp-3) 4px; font-size: var(--fs-caption); }
  .tab.on::after { left: 8px; right: 8px; }
}

/* ============================================================
   DETTES — en-tête de groupe (sous-total par type) + sous-cartes (parité actifs, 21.06)
   ============================================================ */
.de-grp { display: flex; align-items: center; gap: var(--sp-2); cursor: pointer; padding: 10px 14px; margin-bottom: 10px; background: var(--card-sheen), var(--card-bg); border-radius: var(--r-md); box-shadow: var(--card-shadow); transition: background var(--dur-fast); }
.de-grp:hover { background: var(--alg-surface-2); }
.de-grp .chev { display: inline-flex; align-items: center; justify-content: center; width: 15px; height: 15px; color: var(--alg-text-3); transition: transform var(--dur-base) var(--ease-out), color var(--dur-fast); flex: 0 0 auto; }
.de-grp .chev svg { width: 12px; height: 12px; display: block; }
.de-grp .chev.open { transform: rotate(90deg); color: var(--alg-debt); }
.de-grp .chev.anim { animation: chevOpen var(--dur-base) var(--ease-out); }
.de-grp-n { font-size: var(--fs-micro); color: var(--alg-text-3); }
.de-grp-tot { margin-left: auto; color: var(--alg-debt); font-weight: 600; font-variant-numeric: tabular-nums; }
.de-sub { margin-left: 14px; }
.de-sub.anim { animation: subIn var(--dur-base) var(--ease-out) both; }

/* Onboarding — étape identité (prénom + nom) */
.wz-id { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); margin-bottom: var(--sp-4); }
@media (max-width: 480px) { .wz-id { grid-template-columns: 1fr; } }
