/* ============================================================
   Coopérative Oasis — DESIGN SYSTEM CONSOLIDÉ
   components.css · CHAQUE composant défini UNE seule fois
   ------------------------------------------------------------
   • @import "tokens.css"; en tête (un seul :root).
   • Zéro couleur/espacement en dur → var(--…) partout.
   • Variations parts/livret par [data-univers] (consomme --accent*),
     jamais .ps-kpi/.lv-kpi en double.
   • Sémantique fixe (ok/warn/danger) et chrome (sidebar) NON thémés.
   • Renommages canoniques documentés dans contrat-markup.md.
   ============================================================ */
@import "tokens.css";

/* ============================================================ */
/* 1 · BASE                                                     */
/* ============================================================ */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--font);font-weight:450;color:var(--ink);background:var(--bg);
  font-size:var(--fs-lg);line-height:var(--lh-body);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.01em;line-height:var(--lh-tight);color:var(--ink);}
p{margin:0;text-wrap:pretty;}
img{max-width:100%;display:block;}
:focus-visible{outline:3px solid color-mix(in srgb,var(--accent) 45%,transparent);outline-offset:2px;border-radius:6px;}

/* ============================================================ */
/* 2 · COQUILLE — sidebar + main (chrome NEUTRE coop)           */
/* ============================================================ */
.app{display:flex;min-height:100vh;}
.app-sidebar{width:var(--sidebar-w);flex:none;background:var(--card);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;}
.app-sidebar__brand{padding:var(--sp-xl) var(--sp-xl) var(--sp-lg);border-bottom:1px solid var(--line);}
.app-sidebar__brand img{width:190px;height:auto;}

.user-card{padding:var(--sp-lg) var(--sp-xl);border-bottom:1px solid var(--line);}
.user-card__name{font-weight:700;font-size:var(--fs-base);letter-spacing:.01em;}
.user-card__total{font-size:var(--fs-kpi);font-weight:800;color:var(--ink);margin-top:var(--sp-sm);letter-spacing:-.02em;}
.user-card__sub{font-size:var(--fs-xs);color:var(--muted);margin-top:2px;}
.user-card__pending{display:inline-flex;align-items:center;gap:5px;font-size:var(--fs-xs);color:var(--lv-strong);
  background:var(--lv-tint);padding:3px 9px;border-radius:var(--r-pill);margin-top:9px;font-weight:500;}

.nav{padding:var(--sp-md);display:flex;flex-direction:column;gap:2px;flex:1;}
.nav a{display:flex;align-items:center;gap:11px;padding:10px var(--sp-md);border-radius:10px;
  color:var(--ink-2);font-size:var(--fs-md);font-weight:500;transition:background .14s var(--ease),color .14s var(--ease);}
.nav a .ic{color:var(--faint);transition:color .14s;}
.nav a:hover{background:var(--bg);color:var(--ink);}
.nav a:hover .ic{color:var(--ink-2);}
.nav a.is-active{background:var(--coop-tint);color:var(--coop-strong);font-weight:700;}
.nav a.is-active .ic{color:var(--coop);}
.nav__sep{height:1px;background:var(--line);margin:10px var(--sp-md);}
.nav__group{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);font-weight:700;padding:var(--sp-sm) var(--sp-md) var(--sp-xs);}

.nav-foot{padding:var(--sp-md) var(--sp-lg);border-top:1px solid var(--line);}
.nav-foot a{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:var(--fs-sm);font-weight:500;}
.nav-foot a:hover{color:var(--ink);}
.nav-foot a.nav-foot__site{white-space:nowrap;color:var(--coop-strong);font-weight:600;font-size:var(--fs-sm);
  background:var(--coop-tint);padding:10px var(--sp-md);border-radius:11px;margin-bottom:9px;
  border:1px solid color-mix(in srgb,var(--coop) 22%,transparent);transition:filter .14s var(--ease),box-shadow .14s;}
.nav-foot a.nav-foot__site:hover{filter:brightness(.98);box-shadow:var(--sh-1);}
.nav-foot a.nav-foot__site .ic{color:var(--coop);}
.nav-foot a.nav-foot__site .ext{width:14px;height:14px;flex:none;margin-left:auto;opacity:.6;}

.main{flex:1;min-width:0;display:flex;flex-direction:column;}
.page{max-width:var(--page-max);width:100%;margin:0 auto;padding:var(--sp-xl) 38px 60px;}

/* tiroir mobile */
.mobile-topbar{display:none;}
.nav-overlay{display:none;}
@media(max-width:900px){
  .app{display:block;}
  .app-sidebar{position:fixed;top:0;left:0;height:100vh;width:284px;max-width:86vw;z-index:60;
    transform:translateX(-100%);transition:transform .26s var(--ease);box-shadow:0 0 60px rgba(20,22,26,.22);}
  .app.nav-open .app-sidebar{transform:none;}
  .nav-overlay{display:block;position:fixed;inset:0;background:rgba(20,22,26,.46);z-index:55;
    opacity:0;visibility:hidden;transition:opacity .26s var(--ease),visibility .26s;}
  .app.nav-open .nav-overlay{opacity:1;visibility:visible;}
  .mobile-topbar{display:flex;align-items:center;gap:13px;padding:10px 15px;background:var(--card);
    border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;}
  .mobile-topbar__burger{width:42px;height:42px;border-radius:11px;border:1px solid var(--line-2);background:var(--card);
    display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);flex:none;transition:background .14s var(--ease);}
  .mobile-topbar__burger:hover{background:var(--bg);}
  .mobile-topbar__burger svg{width:22px;height:22px;}
  .mobile-topbar__logo{height:42px;display:flex;align-items:center;}
  .mobile-topbar__logo img{height:42px;width:auto;display:block;}
  .page{padding:var(--sp-xl) var(--sp-lg) 72px;}
}
@media(max-width:560px){.page{padding:var(--sp-lg) var(--sp-md) 60px;}}

/* ============================================================ */
/* 3 · ATOMES                                                   */
/* ============================================================ */
/* icône — base canonique 18px ; contextes ci-dessous */
.ic{width:18px;height:18px;flex:none;}

.btn{
  --_bg:var(--accent);--_fg:var(--accent-on);--_bd:transparent;
  font-family:inherit;font-weight:700;font-size:var(--fs-md);letter-spacing:.005em;
  display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-sm);
  padding:11px var(--sp-xl);border-radius:var(--r-pill);border:1.5px solid var(--_bd);
  background:var(--_bg);color:var(--_fg);cursor:pointer;text-decoration:none;white-space:nowrap;
  transition:filter .15s var(--ease),transform .08s var(--ease),background .15s,box-shadow .15s;
}
.btn:hover{filter:brightness(.95);text-decoration:none;}
.btn:active{transform:scale(.985);}
.btn[hidden]{display:none;}/* sinon .btn{display:inline-flex} écrase le [hidden] UA → boutons fantômes (btn-next/btn-submit du tunnel) */
.btn .ic{width:16px;height:16px;}
.btn--lg{padding:14px var(--sp-2xl);font-size:var(--fs-lg);}
.btn--sm{padding:var(--sp-sm) 15px;font-size:var(--fs-sm);}
.btn--block{width:100%;}
/* variantes pleines : posent l'accent localement */
.btn--accent{--_bg:var(--accent);--_fg:var(--accent-on);}
.btn--coop{--_bg:var(--coop);--_fg:var(--ink-inverse);}
.btn--ps{--_bg:var(--ps);--_fg:var(--ink-inverse);}
.btn--lv{--_bg:var(--lv-bright);--_fg:var(--ink);}
/* fantômes */
.btn--ghost{--_bg:transparent;--_fg:var(--ink-2);--_bd:var(--line-2);}
.btn--ghost:hover{filter:none;border-color:var(--muted);}
.btn--ghost-accent{--_bg:transparent;--_fg:var(--accent-strong);--_bd:color-mix(in srgb,var(--accent) 40%,transparent);}
.btn--ghost-accent:hover{filter:none;background:var(--accent-tint);}
.btn--ghost-ps{--_bg:transparent;--_fg:var(--ps-strong);--_bd:color-mix(in srgb,var(--ps) 40%,transparent);}
.btn--ghost-ps:hover{filter:none;background:var(--ps-tint);}
.btn--ghost-lv{--_bg:transparent;--_fg:var(--lv-strong);--_bd:color-mix(in srgb,var(--lv) 45%,transparent);}
.btn--ghost-lv:hover{filter:none;background:var(--lv-tint);}
.btn--link{--_bg:transparent;--_fg:var(--accent-strong);padding:6px 4px;border:0;}
.btn--link:hover{filter:none;text-decoration:underline;text-underline-offset:3px;}

.linkarrow{display:inline-flex;align-items:center;gap:5px;font-weight:600;font-size:var(--fs-sm);color:var(--accent-strong);}
.linkarrow:hover{text-decoration:underline;text-underline-offset:3px;}
.linkarrow .ic{width:15px;height:15px;}

.eyebrow{font-size:var(--fs-micro);letter-spacing:.13em;text-transform:uppercase;font-weight:700;color:var(--muted);}

.pill{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-xs);font-weight:600;padding:3px 11px;border-radius:var(--r-pill);}
.pill--accent{background:var(--accent-tint);color:var(--accent-strong);}
.pill--ps{background:var(--ps-tint);color:var(--ps-strong);}
.pill--lv{background:var(--lv-tint);color:var(--lv-strong);}
.pill--ok{background:var(--coop-tint);color:var(--coop-strong);}
.pill--pending{background:var(--lv-tint);color:var(--lv-strong);}
.pill--neutral{background:var(--bg);color:var(--ink-2);}

/* mini-icône ronde — thémée par défaut, variantes explicites */
.dot-ic{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex:none;
  background:var(--accent-tint);color:var(--accent-strong);}
.dot-ic .ic{width:20px;height:20px;}
.dot-ic--ps{background:var(--ps-tint);color:var(--ps-strong);}
.dot-ic--lv{background:var(--lv-tint);color:var(--lv-strong);}
.dot-ic--coop{background:var(--coop-tint);color:var(--coop-strong);}

.mono{font-variant-numeric:tabular-nums;}
.muted{color:var(--muted);}
.tiny{font-size:var(--fs-xs);}

/* ============================================================ */
/* 4 · FORMULAIRES (un seul .input, .field, etc.)               */
/* ============================================================ */
.field{margin-bottom:var(--sp-lg);}
.field:last-child{margin-bottom:0;}
.field__label{display:flex;align-items:center;gap:6px;font-size:var(--fs-xs);font-weight:700;
  letter-spacing:.02em;text-transform:uppercase;color:var(--muted);margin-bottom:7px;}
.field__label .req{color:var(--danger);}
.field__label .lock{width:12px;height:12px;color:var(--faint);}
.field__value{font-size:var(--fs-lead);font-weight:700;color:var(--ink);letter-spacing:-.005em;}
.field__hint{font-size:var(--fs-xs);color:var(--muted);margin-top:5px;}

.input{width:100%;border:1.5px solid var(--line-2);border-radius:var(--r-sm);
  padding:var(--sp-md) var(--sp-lg);font-size:var(--fs-base);font-family:inherit;color:var(--ink);
  background:var(--card);transition:border-color .15s var(--ease),box-shadow .15s;}
.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 16%,transparent);}
.input::placeholder{color:var(--faint);}
textarea.input{min-height:96px;resize:vertical;}

.input-wrap{position:relative;display:flex;align-items:center;}
.input-wrap .input{padding-right:42px;}
.input-wrap__ic{position:absolute;right:14px;width:18px;height:18px;color:var(--faint);pointer-events:none;}

.field-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-lg) var(--sp-xl);}
@media(max-width:560px){.field-row{grid-template-columns:1fr;}}

.select-wrap{position:relative;}
.select-wrap select{width:100%;appearance:none;border:1.5px solid var(--line-2);border-radius:var(--r-sm);
  padding:var(--sp-md) var(--sp-4xl) var(--sp-md) var(--sp-lg);font-size:var(--fs-base);font-family:inherit;
  color:var(--ink);background:var(--card);cursor:pointer;transition:border-color .15s;}
.select-wrap select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 16%,transparent);}
.select-wrap__chev{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--muted);pointer-events:none;}

/* segmenté (oui/non, défisc) */
.seg{display:inline-flex;border:1.5px solid var(--line-2);border-radius:var(--r-pill);overflow:hidden;background:var(--card);}
.seg button{font-family:inherit;font-weight:600;font-size:var(--fs-sm);padding:9px var(--sp-lg);border:0;background:transparent;color:var(--ink-2);cursor:pointer;transition:all .14s;}
.seg button.is-active{background:var(--accent);color:var(--accent-on);}

/* interrupteur */
.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:var(--fs-sm);font-weight:600;color:var(--ink);}
.switch input{position:absolute;opacity:0;width:0;height:0;}
.switch__track{width:42px;height:24px;border-radius:999px;background:var(--line-2);position:relative;transition:background .18s var(--ease);flex:none;}
.switch__track::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--card);box-shadow:0 1px 3px rgba(0,0,0,.25);transition:transform .18s var(--ease);}
.switch input:checked + .switch__track{background:var(--accent);}
.switch input:checked + .switch__track::after{transform:translateX(18px);}
.switch input:focus-visible + .switch__track{outline:3px solid color-mix(in srgb,var(--accent) 45%,transparent);outline-offset:2px;}

/* saisie de montant */
.amount-input{display:flex;align-items:center;gap:var(--sp-sm);max-width:260px;border:1.5px solid var(--line-2);
  border-radius:var(--r-md);padding:var(--sp-xs) var(--sp-lg);transition:border-color .14s;}
.amount-input:focus-within{border-color:var(--accent);}
.amount-input input{flex:1;border:0;outline:none;font-size:var(--fs-title-lg);font-weight:700;font-family:inherit;padding:var(--sp-sm) 0;color:var(--ink);width:100%;}
.amount-input .cur{font-size:var(--fs-lead);color:var(--muted);font-weight:700;}
.amount-hint{font-size:var(--fs-xs);color:var(--muted);margin-top:var(--sp-sm);}
.amount-hint b{color:var(--ink);}

/* boutons-portail Oui/Non (gate) */
.gate-btn{font-family:inherit;font-weight:600;font-size:var(--fs-sm);padding:9px var(--sp-lg);border-radius:var(--r-pill);
  border:1.5px solid var(--line-2);background:var(--card);color:var(--ink-2);cursor:pointer;transition:all .14s;}
.gate-btn:hover{border-color:var(--muted);}
.gate-btn.is-active[data-val="yes"]{background:var(--warn-tint);border-color:var(--warn);color:var(--lv-strong);}
.gate-btn.is-active[data-val="no"]{background:var(--accent-tint);border-color:var(--accent);color:var(--accent-strong);}

/* ============================================================ */
/* 5 · EN-TÊTE DE PAGE + KPI (unifié, thémé)                    */
/* ============================================================ */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--sp-xl);flex-wrap:wrap;}
@media(max-width:900px){.page-head{align-items:flex-start;}}
.page-head__title{font-size:var(--fs-kpi);font-weight:800;letter-spacing:-.02em;}
@media(max-width:560px){.page-head__title{font-size:var(--fs-title-lg);}}
.page-head__kpis{display:flex;gap:var(--sp-2xl);}
.page-head__kpi .n{font-size:var(--fs-title-lg);font-weight:800;color:var(--ink);letter-spacing:-.01em;}
.page-head__kpi .n.pending{color:var(--lv-strong);}
.page-head__kpi .l{font-size:var(--fs-xs);color:var(--muted);}
.page-head__status{display:flex;align-items:center;gap:var(--sp-sm);font-size:var(--fs-sm);font-weight:600;
  color:var(--coop-strong);background:var(--coop-tint);padding:7px var(--sp-lg);border-radius:var(--r-pill);}
.page-head__status .ic{width:16px;height:16px;}

/* KPI en cartes — UN SEUL composant, accent par [data-univers] */
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-lg);}
@media(max-width:720px){.kpis{grid-template-columns:1fr;}}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:var(--sp-lg) var(--sp-xl);}
.kpi__val{font-size:var(--fs-kpi);font-weight:800;letter-spacing:-.02em;color:var(--ink);}
.kpi__label{font-size:var(--fs-sm);color:var(--ink-2);font-weight:600;margin-top:2px;}
.kpi__sub{font-size:var(--fs-xs);color:var(--muted);margin-top:5px;display:flex;align-items:center;gap:6px;}
.kpi__sub a{color:var(--accent-strong);font-weight:600;}
.kpi__sub .pending{color:var(--lv-strong);font-weight:600;}
.kpi--accent{border-top:3px solid var(--accent-bright);}

/* badge « membre depuis » — accent, thémé (ex .lv-open-badge ambigu) */
.open-badge{display:inline-flex;align-items:center;gap:var(--sp-sm);font-size:var(--fs-sm);font-weight:700;
  color:var(--accent-strong);background:var(--accent-tint);padding:6px 14px;border-radius:var(--r-pill);}

/* ============================================================ */
/* 6 · CARTES & CONTENEURS                                      */
/* ============================================================ */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);}
.card-pad{padding:var(--sp-2xl) var(--sp-2xl);}
@media(max-width:560px){.card-pad{padding:var(--sp-xl) var(--sp-lg);}}
.section{margin-top:var(--sp-md);}
.section__head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--sp-lg);margin-bottom:10px;}
.section__title{font-size:var(--fs-title);font-weight:700;}
.section__title .em{color:var(--accent-strong);}

/* dépliable générique */
.collapse{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden;}
.collapse>summary{list-style:none;cursor:pointer;padding:var(--sp-lg) var(--sp-xl);display:flex;align-items:center;justify-content:space-between;gap:14px;}
.collapse>summary::-webkit-details-marker{display:none;}
.collapse>summary:hover{background:var(--card-2);}
.collapse__t{font-size:var(--fs-lg);font-weight:700;display:flex;align-items:center;gap:10px;}
.collapse__meta{font-size:var(--fs-sm);color:var(--muted);margin-left:auto;margin-right:6px;font-weight:500;}
.collapse__chev{width:20px;height:20px;color:var(--muted);transition:transform .2s var(--ease);flex:none;}
.collapse[open]>summary .collapse__chev{transform:rotate(180deg);}
.collapse__body{padding:var(--sp-xs) var(--sp-xl) var(--sp-xl);border-top:1px solid var(--line);}

/* accordéon « comment ça marche » */
.howto{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden;}
.howto__row{border-top:1px solid var(--line);}
.howto__row:first-child{border-top:0;}
.howto__row>summary{list-style:none;cursor:pointer;padding:15px var(--sp-xl);display:flex;align-items:center;gap:var(--sp-md);}
.howto__row>summary::-webkit-details-marker{display:none;}
.howto__row>summary:hover{background:var(--card-2);}
.howto__ic{width:30px;height:30px;border-radius:9px;background:var(--accent-tint);color:var(--accent-strong);display:flex;align-items:center;justify-content:center;flex:none;}
.howto__ic .ic{width:17px;height:17px;}
.howto__title{font-size:var(--fs-base);font-weight:700;}
.howto__chev{width:18px;height:18px;color:var(--muted);margin-left:auto;transition:transform .2s var(--ease);}
.howto__row[open] .howto__chev{transform:rotate(180deg);}
.howto__detail{padding:0 var(--sp-xl) var(--sp-lg) 64px;font-size:var(--fs-md);color:var(--ink-2);line-height:var(--lh-body);}
.howto__foot{padding:var(--sp-lg) var(--sp-xl);border-top:1px solid var(--line);background:var(--card-2);display:flex;justify-content:flex-end;}

/* ============================================================ */
/* 7 · TABLES & STATUTS                                         */
/* ============================================================ */
.data-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm);}
.data-table th{text-align:left;font-size:var(--fs-micro);letter-spacing:.03em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:10px 14px;border-bottom:1px solid var(--line-2);}
.data-table td{padding:var(--sp-md) 14px;border-bottom:1px solid var(--line);color:var(--ink);}
.data-table tbody tr:last-child td{border-bottom:0;}
.data-table tbody tr:hover td{background:var(--card-2);}
.data-table .doc-link{display:inline-flex;align-items:center;gap:6px;color:var(--accent-strong);font-weight:600;font-size:var(--fs-xs);}
.table-scroll{overflow-x:auto;}

/* puce statut — un composant, modificateurs sémantiques */
.statut{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-xs);font-weight:700;padding:3px 11px;border-radius:var(--r-pill);}
.statut--ok{background:var(--coop-tint);color:var(--coop-strong);}
.statut--wait{background:var(--lv-tint);color:var(--lv-strong);}
.statut--err{background:var(--danger-tint);color:var(--danger);}

/* badge don/rendement (historique) */
.tag-don{display:inline-flex;align-items:center;gap:5px;font-size:var(--fs-micro);font-weight:700;color:var(--lv-strong);background:var(--lv-tint);padding:2px 9px;border-radius:var(--r-pill);}

/* ============================================================ */
/* 8 · TUNNEL — flow / step / panneaux (thémé par --accent)     */
/* ============================================================ */
.flow{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-2);overflow:hidden;}
.flow__intro{padding:var(--sp-xl) var(--sp-2xl);border-bottom:1px solid var(--line);
  background:radial-gradient(120% 160% at 100% 0%, color-mix(in srgb,var(--accent-bright) 12%,transparent), transparent 55%),var(--card);}
.flow__intro .t{font-size:var(--fs-title);font-weight:800;letter-spacing:-.01em;}
.flow__intro .d{font-size:var(--fs-md);color:var(--ink-2);margin-top:5px;max-width:64ch;}

.steps{display:flex;align-items:center;padding:var(--sp-xl) var(--sp-2xl);border-bottom:1px solid var(--line);background:var(--card-2);}
.step{display:flex;align-items:center;gap:11px;flex:none;}
.step__num{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:var(--fs-sm);font-weight:800;flex:none;border:2px solid var(--line-2);color:var(--muted);background:var(--card);transition:all .2s var(--ease);}
.step__txt{display:flex;flex-direction:column;line-height:1.2;}
.step__k{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);font-weight:700;}
.step__l{font-size:var(--fs-sm);font-weight:700;color:var(--muted);transition:color .2s;}
.step__bar{flex:1;height:2px;background:var(--line-2);margin:0 14px;min-width:18px;border-radius:2px;transition:background .2s;}
.step.is-active .step__num{border-color:var(--accent);background:var(--accent);color:var(--accent-on);}
.step.is-active .step__l{color:var(--ink);}
.step.is-done .step__num{border-color:var(--accent);background:var(--accent-tint);color:var(--accent-strong);}
.step.is-done .step__l{color:var(--ink-2);}
.step__bar.is-filled{background:var(--accent);}
@media(max-width:760px){.step__txt{display:none;}.steps{justify-content:center;}}

.flow__panel{padding:var(--sp-2xl);}
.flow__panel[hidden]{display:none;}
.flow__step-title{font-size:var(--fs-title);font-weight:700;margin-bottom:var(--sp-xs);}
.flow__step-sub{font-size:var(--fs-sm);color:var(--muted);margin-bottom:var(--sp-xl);}
.flow__nav{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-md);padding:var(--sp-lg) var(--sp-2xl);border-top:1px solid var(--line);background:var(--card-2);}
.flow__nav .spacer{flex:1;}

/* récap d'infos (grille clé/valeur) */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;}
@media(max-width:560px){.info-grid{grid-template-columns:1fr;}}
.info-cell{background:var(--card);padding:14px var(--sp-lg);}
.info-cell .k{font-size:var(--fs-micro);letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:700;}
.info-cell .v{font-size:var(--fs-base);font-weight:600;color:var(--ink);margin-top:3px;}
.info-edit{margin-top:var(--sp-lg);display:flex;align-items:center;gap:var(--sp-sm);font-size:var(--fs-sm);color:var(--muted);}
.info-edit a{color:var(--accent-strong);font-weight:600;}

/* presets de montant */
.presets{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
@media(max-width:560px){.presets{grid-template-columns:1fr 1fr;}}
.preset{border:1.5px solid var(--line-2);background:var(--card);border-radius:var(--r-md);padding:var(--sp-md) 10px;cursor:pointer;text-align:center;font-weight:700;font-size:var(--fs-lg);color:var(--ink);transition:all .14s var(--ease);display:flex;flex-direction:column;gap:2px;font-family:inherit;}
.preset small{font-weight:500;font-size:var(--fs-micro);color:var(--muted);}
.preset:hover{border-color:var(--accent);}
.preset.is-active{border-color:var(--accent);background:var(--accent-tint);color:var(--accent-strong);box-shadow:inset 0 0 0 1px var(--accent);}
.preset.is-active small{color:var(--accent-strong);}
.custom-row{display:flex;align-items:center;justify-content:center;gap:var(--sp-sm);margin:var(--sp-md) auto 0;max-width:240px;}
.custom-row[hidden]{display:none;}

/* fiscalité */
.fiscal{margin-top:var(--sp-lg);background:var(--accent-tint);border:1px solid var(--accent-tint-2);border-radius:var(--r-md);padding:13px var(--sp-lg);}
.fiscal__eco{font-size:var(--fs-base);font-weight:700;color:var(--accent-strong);}
.fiscal__eng{font-size:var(--fs-sm);color:var(--ink-2);margin-top:3px;}
.fiscal__more{margin-top:var(--sp-sm);}
.fiscal__more summary{list-style:none;cursor:pointer;font-size:var(--fs-xs);font-weight:600;color:var(--accent-strong);}
.fiscal__more summary::-webkit-details-marker{display:none;}
.fiscal__legal{font-size:var(--fs-xs);color:var(--ink-2);line-height:var(--lh-body);margin-top:var(--sp-sm);}

/* cartes radio (règlement) */
.radio-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
@media(max-width:620px){.radio-cards{grid-template-columns:1fr;}}
.radio-card{border:1.5px solid var(--line-2);border-radius:var(--r-md);padding:14px var(--sp-lg);cursor:pointer;transition:all .14s var(--ease);background:var(--card);display:flex;gap:11px;align-items:flex-start;}
.radio-card:hover{border-color:var(--accent);}
.radio-card.is-active{border-color:var(--accent);background:var(--accent-tint);box-shadow:inset 0 0 0 1px var(--accent);}
.radio-card__dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--line-2);flex:none;margin-top:1px;position:relative;transition:border-color .14s;}
.radio-card.is-active .radio-card__dot{border-color:var(--accent);}
.radio-card.is-active .radio-card__dot::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--accent);}
.radio-card__t{font-size:var(--fs-md);font-weight:700;}
.radio-card__d{font-size:var(--fs-xs);color:var(--muted);margin-top:2px;line-height:var(--lh-snug);}
/* radio-card avec input radio réel (formulaires WP) : input masqué, état piloté par :checked */
.radio-card input[type="radio"]{position:absolute;opacity:0;width:1px;height:1px;margin:0;}
.radio-card:has(input[type="radio"]:checked){border-color:var(--accent);background:var(--accent-tint);box-shadow:inset 0 0 0 1px var(--accent);}
.radio-card:has(input[type="radio"]:checked) .radio-card__dot{border-color:var(--accent);}
.radio-card:has(input[type="radio"]:checked) .radio-card__dot::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--accent);}
.radio-card input[type="radio"]:focus-visible + .radio-card__dot{outline:2px solid var(--accent);outline-offset:2px;}

/* IBAN à prélever */
.iban-box{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-md);background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-md);padding:13px var(--sp-lg);flex-wrap:wrap;}
.iban-box__num{font-weight:700;letter-spacing:.06em;font-variant-numeric:tabular-nums;}
.iban-box__edit{font-size:var(--fs-sm);color:var(--accent-strong);font-weight:600;}
.iban-edit[hidden]{display:none;}
.iban-feedback{font-size:var(--fs-sm);margin-top:var(--sp-sm);min-height:1.1em;}
.iban-feedback.is-ok{color:var(--coop-strong);font-weight:600;}
.iban-feedback.is-err{color:var(--danger);font-weight:600;}

/* portail Oui/Non + DOF/Impact */
.gate__q{font-size:var(--fs-md);color:var(--ink);margin-bottom:10px;}
.gate__legal{font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-body);margin-bottom:var(--sp-md);}
.gate__btns{display:flex;gap:10px;flex-wrap:wrap;}
.gate__summary{font-size:var(--fs-xs);color:var(--muted);line-height:var(--lh-body);margin:0 0 var(--sp-md);}
.gate__none{font-size:var(--fs-sm);color:var(--accent-strong);font-weight:600;margin-top:var(--sp-md);display:none;}
.dof-list{margin-top:var(--sp-lg);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;display:none;}
.dof-list__head{padding:11px var(--sp-lg);background:var(--card-2);border-bottom:1px solid var(--line);font-size:var(--fs-xs);font-weight:700;color:var(--ink-2);display:flex;align-items:center;gap:var(--sp-sm);}
.dof-opt{display:flex;gap:var(--sp-md);align-items:flex-start;padding:var(--sp-md) var(--sp-lg);border-top:1px solid var(--line);cursor:pointer;}
.dof-opt:first-child{border-top:0;}
.dof-opt:hover{background:var(--card-2);}
.dof-opt input{margin-top:3px;width:17px;height:17px;accent-color:var(--accent);flex:none;}
.dof-opt__t{font-size:var(--fs-sm);color:var(--ink);line-height:var(--lh-snug);}

/* édition inline */
.inline-edit{margin-top:var(--sp-md);padding:14px var(--sp-lg);background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-md);}
.inline-edit[hidden]{display:none;}
.inline-edit__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-md);}
@media(max-width:560px){.inline-edit__row{grid-template-columns:1fr;}}
.inline-edit label{display:block;font-size:var(--fs-xs);font-weight:700;text-transform:uppercase;letter-spacing:.02em;color:var(--muted);margin-bottom:5px;}
.inline-edit__actions{display:flex;gap:10px;margin-top:var(--sp-md);}

/* récap + soumission */
.recap{padding:var(--sp-xl) var(--sp-2xl);background:var(--card-2);}
.recap__who{display:flex;flex-direction:column;gap:3px;padding-bottom:var(--sp-lg);border-bottom:1px solid var(--line);margin-bottom:var(--sp-lg);}
.recap__name{font-size:var(--fs-base);font-weight:700;}
.recap__name .lbl{font-size:var(--fs-micro);text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;display:block;margin-bottom:2px;}
.recap__details{font-size:var(--fs-sm);color:var(--ink-2);display:flex;gap:6px;flex-wrap:wrap;}
.recap__details span:not(:last-child)::after{content:"·";margin-left:6px;color:var(--faint);}
.recap__edit{font-size:var(--fs-sm);color:var(--accent-strong);font-weight:600;margin-top:6px;}
.recap__summary{text-align:center;margin-bottom:var(--sp-lg);}
.recap__amount{font-size:var(--fs-display);font-weight:800;letter-spacing:-.02em;color:var(--ink);}
.recap__line{font-size:var(--fs-sm);color:var(--ink-2);margin-top:3px;}
.recap__fiscal{font-size:var(--fs-sm);color:var(--accent-strong);font-weight:700;margin-top:var(--sp-xs);}
.recap__action{display:flex;justify-content:center;}

/* ============================================================ */
/* 9 · BANDEAU SOUSCRIRE + MODALES + REMBOURSEMENT (tunnel)     */
/* ============================================================ */
.ssc-collapse{border:1.5px solid var(--accent);border-radius:var(--r-lg);background:var(--accent-tint);overflow:hidden;box-shadow:var(--sh-1);}
.ssc-collapse>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:15px;padding:var(--sp-lg) var(--sp-xl);}
.ssc-collapse>summary::-webkit-details-marker{display:none;}
.ssc-collapse__ic{width:42px;height:42px;border-radius:var(--r-md);background:var(--accent);color:var(--accent-on);display:flex;align-items:center;justify-content:center;flex:none;}
.ssc-collapse__ic .ic{width:22px;height:22px;}
.ssc-collapse__txt{flex:1;min-width:0;}
.ssc-collapse__txt .t{display:block;font-size:var(--fs-lead);font-weight:800;color:var(--accent-strong);letter-spacing:-.01em;}
.ssc-collapse__txt .d{display:block;font-size:var(--fs-sm);color:var(--ink-2);margin-top:2px;}
.ssc-collapse__chev{flex:none;color:var(--accent-strong);transition:transform .2s var(--ease);}
.ssc-collapse__chev .ic{width:22px;height:22px;}
.ssc-collapse[open]>summary .ssc-collapse__chev{transform:rotate(180deg);}

.ssc{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden;}
.ssc-collapse .ssc{border:0;border-top:1px solid var(--accent-tint-2);border-radius:0;box-shadow:none;}
.ssc__head{padding:var(--sp-xl) var(--sp-2xl);border-bottom:1px solid var(--line);}
.ssc__head .t{font-size:var(--fs-title);font-weight:700;}
.ssc__head .s{font-size:var(--fs-sm);color:var(--muted);margin-top:2px;}
.ssc__group{padding:var(--sp-xl) var(--sp-2xl);border-bottom:1px solid var(--line);}
.ssc__group:last-child{border-bottom:0;}
.ssc__label{font-size:var(--fs-sm);font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--ink-2);margin-bottom:13px;display:flex;align-items:center;gap:var(--sp-sm);}
.ssc__label .num{width:22px;height:22px;border-radius:50%;background:var(--accent-tint);color:var(--accent-strong);font-size:var(--fs-xs);display:inline-flex;align-items:center;justify-content:center;font-weight:800;}

.ssc-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:3vh 2vw;}
.ssc-modal[hidden]{display:none;}
.ssc-modal__backdrop{position:absolute;inset:0;background:rgba(20,22,26,.55);}
.ssc-modal__dialog{position:relative;background:var(--card);border-radius:var(--r-xl);box-shadow:var(--sh-3);width:min(960px,96vw);height:min(90vh,920px);display:flex;flex-direction:column;overflow:hidden;animation:sscModalIn .22s var(--ease);}
.ssc-modal__dialog--auto{width:min(460px,96vw);height:auto;max-height:90vh;}/* notices courts (ex. profil incomplet) */
@keyframes sscModalIn{from{opacity:0;transform:translateY(10px) scale(.99);}to{opacity:1;transform:none;}}
.ssc-modal__x{position:absolute;top:13px;right:13px;z-index:3;width:34px;height:34px;border-radius:50%;border:0;background:var(--card-2);color:var(--ink-2);cursor:pointer;display:flex;align-items:center;justify-content:center;}
.ssc-modal__x:hover{background:var(--line);}
.ssc-modal__head{padding:var(--sp-xl) 54px 14px var(--sp-2xl);border-bottom:1px solid var(--line);}
.ssc-modal__title{font-size:var(--fs-title-lg);font-weight:800;letter-spacing:-.01em;color:var(--ink);}
.ssc-modal__sub{font-size:var(--fs-sm);color:var(--muted);margin-top:var(--sp-xs);}
.ssc-modal__body{flex:1;min-height:0;padding:var(--sp-lg) var(--sp-2xl);background:var(--bg);}
.ssc-modal__frame{width:100%;height:100%;border:1px solid var(--line);border-radius:var(--r-md);background:var(--card);}
.ssc-modal__scroll{flex:1;min-height:0;overflow:auto;padding:var(--sp-xl) var(--sp-2xl);}
.ssc-modal__foot{display:flex;align-items:center;gap:var(--sp-md);padding:15px var(--sp-2xl);border-top:1px solid var(--line);flex-wrap:wrap;}
.ssc-modal__foot .spacer{flex:1;}
.ssc-modal__foot-note{font-size:var(--fs-xs);color:var(--muted);max-width:44ch;}
.ssc-modal__success{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;align-items:center;text-align:center;justify-content:center;padding:30px var(--sp-2xl);}
.ssc-modal__check{width:62px;height:62px;border-radius:50%;background:var(--coop-tint);color:var(--coop-strong);display:flex;align-items:center;justify-content:center;margin-bottom:14px;}
.ssc-modal__check svg{width:30px;height:30px;}
.ssc-modal__msg{font-size:var(--fs-base);color:var(--ink-2);max-width:54ch;margin-top:6px;line-height:var(--lh-body);}
.ssc-modal__after{font-size:var(--fs-sm);color:var(--muted);margin-top:14px;max-width:54ch;}
.ssc-modal__pay{margin-top:var(--sp-lg);background:var(--accent-tint);border:1px solid var(--accent-tint-2);border-radius:var(--r-md);padding:15px var(--sp-xl);font-size:var(--fs-md);color:var(--ink);max-width:62ch;line-height:var(--lh-body);text-align:left;}
.ssc-modal__pay b{color:var(--accent-strong);}

/* remboursement */
.remb{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-lg);flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line);border-left:3px solid var(--line-2);border-radius:var(--r-md);padding:var(--sp-lg) var(--sp-xl);box-shadow:var(--sh-1);}
.remb__t{font-size:var(--fs-base);font-weight:700;}
.remb__d{font-size:var(--fs-sm);color:var(--muted);margin-top:2px;max-width:60ch;}
.remb-warn{display:flex;gap:11px;align-items:flex-start;background:var(--warn-tint);border:1px solid color-mix(in srgb,var(--warn) 30%,transparent);border-radius:var(--r-md);padding:13px 15px;margin:var(--sp-xs) 0 var(--sp-lg);}
.remb-warn .ic{width:20px;height:20px;color:var(--lv-strong);margin-top:1px;}
.remb-warn span{font-size:var(--fs-sm);color:var(--ink-2);line-height:var(--lh-snug);}

/* ============================================================ */
/* 10 · TABLEAU DE BORD                                         */
/* ============================================================ */
.welcome{position:relative;overflow:hidden;border-radius:var(--r-lg);
  background:radial-gradient(120% 140% at 100% 0%, rgba(0,190,205,.13), transparent 55%),
    radial-gradient(120% 160% at 0% 100%, rgba(43,175,122,.10), transparent 50%),var(--card);
  border:1px solid var(--line);box-shadow:var(--sh-1);padding:10px var(--sp-xl);display:flex;gap:var(--sp-2xl);align-items:center;}
.welcome__body{flex:1;min-width:0;}
.welcome__hi{font-size:var(--fs-lead);font-weight:800;letter-spacing:-.02em;}
.welcome__hi .wave{font-weight:450;}
.welcome__impact{font-size:var(--fs-sm);color:var(--ink-2);margin-top:var(--sp-xs);max-width:70ch;line-height:var(--lh-snug);}
.welcome__impact b{color:var(--ps-strong);font-weight:700;}
.welcome__do{font-size:var(--fs-xs);color:var(--muted);margin-top:3px;line-height:1.35;}
.welcome__stats{display:flex;flex-direction:column;gap:6px;flex:none;padding-left:var(--sp-2xl);border-left:1px solid var(--line);}
.welcome__stat .n{font-size:var(--fs-title);font-weight:800;color:var(--ink);letter-spacing:-.01em;line-height:1.05;}
.welcome__stat .l{font-size:var(--fs-xs);color:var(--muted);line-height:1.15;}
@media(max-width:720px){.welcome{flex-direction:column;align-items:stretch;gap:var(--sp-lg);padding:var(--sp-lg) var(--sp-xl);}
  .welcome__stats{flex-direction:row;flex-wrap:wrap;gap:var(--sp-xl) 28px;padding-left:0;border-left:0;padding-top:15px;border-top:1px solid var(--line);}}

.actu{display:flex;gap:var(--sp-lg);align-items:stretch;border-radius:var(--r-lg);overflow:hidden;background:var(--card);border:1px solid var(--line);box-shadow:var(--sh-1);}
.actu__media{width:150px;flex:none;background:var(--accent-tint);position:relative;}
.actu__media .ph{position:absolute;inset:0;}
.actu__body{padding:11px var(--sp-xl);display:flex;flex-direction:column;justify-content:center;gap:var(--sp-xs);}
.actu__kicker{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-micro);letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--m-coral);}
.actu__title{font-size:var(--fs-lg);font-weight:700;}
.actu__desc{font-size:var(--fs-sm);color:var(--ink-2);max-width:74ch;line-height:var(--lh-snug);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
@media(max-width:640px){.actu{flex-direction:column;}.actu__media{width:auto;height:130px;}}

/* carte produit — UN composant, accent par [data-univers] sur la carte */
.placements{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-lg);}
@media(max-width:860px){.placements{grid-template-columns:1fr;}}
.pcard{position:relative;overflow:hidden;border-radius:var(--r-lg);background:var(--card);border:1px solid var(--line);box-shadow:var(--sh-1);display:flex;flex-direction:column;transition:box-shadow .15s var(--ease);}
.pcard:hover{box-shadow:var(--sh-2);}
.pcard__accent{height:4px;width:100%;background:var(--accent-bright);}
.pcard__top{padding:var(--sp-xl) var(--sp-xl) var(--sp-xs);display:flex;justify-content:space-between;align-items:flex-start;gap:14px;}
.pcard__eyebrow{display:flex;align-items:center;gap:9px;}
.pcard__eyebrow .name{font-size:var(--fs-xs);letter-spacing:.04em;text-transform:uppercase;font-weight:700;color:var(--ink);}
.pcard__solde-wrap{padding:var(--sp-xs) var(--sp-xl) 0;}
.pcard__solde{font-size:var(--fs-display);font-weight:800;letter-spacing:-.025em;line-height:1.05;color:var(--ink);}
.pcard__solde-sub{font-size:var(--fs-sm);color:var(--muted);margin-top:3px;min-height:2.6em;}
.pcard__facts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;margin-top:var(--sp-lg);background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.pcard__fact{background:var(--card-2);padding:var(--sp-md) 14px;min-width:0;}
.pcard__fact .l{font-size:var(--fs-micro);color:var(--muted);display:flex;align-items:center;gap:5px;min-width:0;overflow-wrap:anywhere;}
.pcard__fact .v{font-size:var(--fs-sm);font-weight:700;color:var(--ink);margin-top:3px;overflow-wrap:anywhere;}
.pcard__fact .ic{width:13px;height:13px;color:var(--faint);}
.pcard__foot{padding:var(--sp-lg) var(--sp-xl) var(--sp-sm);display:flex;flex-direction:column;gap:var(--sp-md);margin-top:auto;}
.pcard__btns{display:flex;justify-content:center;gap:var(--sp-md);}
.pcard__btns .btn{flex:1;max-width:190px;justify-content:center;}
.pcard .rate-note:last-child{margin-bottom:var(--sp-lg);}

.rate-note{font-size:var(--fs-xs);color:var(--ink-2);background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:7px 11px;margin:var(--sp-md) var(--sp-xl) 0;display:flex;gap:7px;align-items:flex-start;}
.rate-note b{color:var(--ink);}
.rate-note .ic{width:14px;height:14px;margin-top:2px;color:var(--muted);}

.reasons{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:var(--sp-xl) var(--sp-2xl);}
.reasons__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-xl) var(--sp-2xl);}
@media(max-width:760px){.reasons__grid{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.reasons__grid{grid-template-columns:1fr;}}
.reason{display:flex;gap:13px;align-items:flex-start;}
.reason__t{font-size:var(--fs-md);font-weight:700;}
.reason__d{font-size:var(--fs-sm);color:var(--ink-2);margin-top:2px;line-height:var(--lh-body);}
.reasons__foot{margin-top:var(--sp-xl);padding-top:var(--sp-lg);border-top:1px solid var(--line);}
.reasons__labels{display:flex;flex-wrap:wrap;align-items:center;gap:10px;}
.reasons__labels .lead{font-size:var(--fs-xs);color:var(--muted);font-weight:600;margin-right:var(--sp-xs);}
.lblchip{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-xs);font-weight:700;color:var(--ink);background:var(--bg);border:1px solid var(--line-2);border-radius:var(--r-pill);padding:6px 13px;}
.lblchip .gem{width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,var(--m-teal),var(--m-yellow));flex:none;}

.compare{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden;}
.compare__head{padding:var(--sp-lg) var(--sp-2xl) var(--sp-xs);}
.compare table{width:100%;border-collapse:collapse;font-size:var(--fs-md);}
.compare th,.compare td{padding:13px var(--sp-lg);text-align:left;border-bottom:1px solid var(--line);}
.compare thead th{font-size:var(--fs-xs);color:var(--muted);font-weight:700;border-bottom:1px solid var(--line-2);}
.compare thead th:first-child{color:transparent;}
.compare .col-ps{color:var(--ps-strong);}
.compare .col-lv{color:var(--lv-strong);}
.compare tbody td:first-child{color:var(--ink-2);font-size:var(--fs-sm);}
.compare tbody tr:last-child td{border-bottom:0;}
.compare tbody tr:hover td{background:var(--card-2);}
.compare td .yes{color:var(--coop-strong);font-weight:700;}
.compare td .no{color:var(--muted);}
.compare__th{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:var(--fs-sm);}

.news{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:var(--sp-sm) 6px;}
.news__item{display:flex;gap:14px;padding:13px var(--sp-lg);border-radius:var(--r-md);align-items:center;transition:background .14s;}
.news__item:hover{background:var(--bg);}
.news__item + .news__item{border-top:1px solid var(--line);border-radius:0;}
.news__thumb{width:62px;height:62px;border-radius:10px;flex:none;overflow:hidden;background:var(--coop-tint);position:relative;}
.news__body{flex:1;min-width:0;}
.news__tag{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 9px;border-radius:var(--r-pill);margin-bottom:var(--sp-xs);}
.news__tag--finance{background:var(--coop-tint);color:var(--coop-strong);}
.news__tag--webinar{background:var(--ps-tint);color:var(--ps-strong);}
.news__tag--event{background:var(--lv-tint);color:var(--lv-strong);}
.news__t{font-size:var(--fs-md);font-weight:700;}
.news__m{font-size:var(--fs-xs);color:var(--muted);margin-top:1px;}
.news__d{font-size:var(--fs-sm);color:var(--ink-2);margin-top:3px;}

/* accès discret au don (vers page Livret) */
.don-link{display:flex;align-items:center;gap:13px;padding:13px var(--sp-lg);background:var(--lv-tint);border:1px solid var(--lv-tint-2);border-radius:var(--r-md);text-decoration:none;transition:filter .14s var(--ease);}
.don-link:hover{filter:brightness(.98);}
.don-link__ic{width:34px;height:34px;border-radius:10px;background:var(--card);color:var(--lv-strong);display:flex;align-items:center;justify-content:center;flex:none;}
.don-link__ic .ic{width:19px;height:19px;}
.don-link__txt{flex:1;font-size:var(--fs-sm);color:var(--ink-2);line-height:var(--lh-body);}
.don-link__txt b{color:var(--ink);font-weight:700;}
.don-link__cta{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-sm);font-weight:700;color:var(--lv-strong);white-space:nowrap;flex:none;}
.don-link__cta svg{width:15px;height:15px;}
@media(max-width:560px){.don-link{flex-wrap:wrap;}.don-link__txt{flex:1 1 100%;order:2;}}

/* puce statut don (carte Livret) */
.don-chip{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-micro);font-weight:700;padding:var(--sp-xs) 10px;border-radius:var(--r-pill);text-decoration:none;border:1px solid;flex:none;white-space:nowrap;}
.don-chip__dot{width:7px;height:7px;border-radius:50%;background:currentColor;}
.don-chip.is-on{color:var(--ok);background:color-mix(in srgb,var(--ok) 12%,var(--card));border-color:color-mix(in srgb,var(--ok) 35%,var(--card));}
.don-chip.is-off{color:var(--danger);background:var(--danger-tint);border-color:color-mix(in srgb,var(--danger) 32%,var(--card));}

/* don d'intérêts (encadré page Livret) */
.don{margin-top:var(--sp-lg);background:var(--card);border:1px dashed var(--lv);border-radius:var(--r-md);padding:14px var(--sp-lg);display:flex;gap:13px;align-items:flex-start;}
.don[hidden]{display:none;}
.don__ic{width:34px;height:34px;border-radius:10px;background:var(--lv-tint);color:var(--lv-strong);display:flex;align-items:center;justify-content:center;flex:none;}
.don__t{font-size:var(--fs-md);font-weight:700;}
.don__d{font-size:var(--fs-sm);color:var(--ink-2);margin-top:2px;line-height:var(--lh-body);}
.don__rev{font-size:var(--fs-xs);color:var(--muted);margin-top:var(--sp-sm);}

/* placeholder image (rayé) */
.ph{background-image:repeating-linear-gradient(135deg,rgba(43,45,51,.05) 0 9px,transparent 9px 18px);background-color:var(--card-2);display:flex;align-items:center;justify-content:center;text-align:center;}
.ph__label{font-family:var(--mono);font-size:10px;color:var(--faint);padding:6px;line-height:1.35;}

/* ============================================================ */
/* 11 · PROFIL                                                  */
/* ============================================================ */
.tabs{display:flex;gap:var(--sp-xs);border-bottom:1.5px solid var(--line);margin-bottom:var(--sp-2xl);flex-wrap:wrap;}
.tab{position:relative;display:inline-flex;align-items:center;gap:9px;padding:13px var(--sp-lg) 15px;margin-bottom:-1.5px;
  background:none;border:0;border-bottom:2.5px solid transparent;font-family:inherit;font-size:var(--fs-md);font-weight:600;color:var(--ink-2);cursor:pointer;transition:color .14s var(--ease),border-color .14s var(--ease);}
.tab:hover{color:var(--ink);}
.tab.is-active{color:var(--coop-strong);border-bottom-color:var(--coop);font-weight:700;}
.tab__ic{width:18px;height:18px;flex:none;color:currentColor;opacity:.85;}
.tab__check{width:16px;height:16px;border-radius:50%;background:var(--ok);display:inline-flex;align-items:center;justify-content:center;flex:none;}
.tab__check svg{width:9px;height:9px;color:var(--ink-inverse);}
@media(max-width:680px){.tabs{gap:0;}.tab{padding:11px 13px 13px;font-size:var(--fs-sm);}.tab__lbl{display:none;}.tab__ic{width:20px;height:20px;}}

.panel{display:none;}
.panel.is-active{display:block;}
@media (prefers-reduced-motion: no-preference){.panel.is-active.just-opened{animation:panelIn .25s var(--ease);}}
@keyframes panelIn{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:none;}}
.panel__intro{font-size:var(--fs-md);color:var(--ink-2);line-height:var(--lh-body);margin-bottom:var(--sp-xl);max-width:64ch;}

/* ============================================================
   ALERTES — famille ambre unique « oasis-alert »
   .alert-bar = bandeau (titre + liens d'action dessous)
   .lock-note = encart compact centré
   Pastille d'icône commune (.oasis-alert__icon / .lock-note__ic).
   ============================================================ */
.alert-bar,
.lock-note{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--orange-90);border:1px solid var(--orange-80);border-radius:10px;
  padding:16px 18px;color:var(--orange-dark);font-size:14px;line-height:1.5;
}
.alert-bar{margin-top:16px;}
.lock-note{align-items:center;margin-bottom:20px;font-weight:600;}

/* pastille d'icône commune aux deux blocs (carré ambre 34×34) */
.oasis-alert__icon,
.lock-note__ic{
  flex:none;width:34px;height:34px;border-radius:8px;
  background:var(--orange-80);color:var(--orange-dark);
  display:grid;place-items:center;
}
.oasis-alert__icon svg,.oasis-alert__icon .ic,
.lock-note__ic svg,.lock-note__ic .ic{width:19px;height:19px;}

/* bandeau : titre + liens d'action dessous */
.alert-bar__body{flex:1;min-width:0;}
.alert-bar strong{display:block;font-weight:600;color:var(--orange-dark);}
.alert-bar__links{margin-top:8px;}
.alert-bar a{
  display:inline-block;margin-right:12px;
  color:var(--orange-20);font-weight:600;text-decoration:none;border-bottom:1px solid currentColor;
}
.alert-bar a:hover{color:var(--orange-dark);}

/* encart compact : texte */
.lock-note__tx{font-size:14px;color:var(--orange-dark);line-height:1.5;}
.lock-note__tx b{color:var(--orange-dark);font-weight:600;}

.idgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--sp-lg) var(--sp-2xl);background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--sp-xl) var(--sp-xl);margin-bottom:var(--sp-2xl);}
@media(max-width:640px){.idgrid{grid-template-columns:1fr 1fr;}}
@media(max-width:420px){.idgrid{grid-template-columns:1fr;}}
.idgrid .field{margin-bottom:0;}

.save-bar{margin-top:var(--sp-2xl);display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.save-bar__note{font-size:var(--fs-xs);color:var(--muted);}
.save-toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,16px);z-index:300;display:flex;align-items:center;gap:9px;background:var(--coop-strong);color:var(--ink-inverse);font-size:var(--fs-md);font-weight:600;padding:var(--sp-md) var(--sp-xl);border-radius:var(--r-pill);box-shadow:var(--sh-3);opacity:0;transition:opacity .25s var(--ease),transform .25s var(--ease);pointer-events:none;}
.save-toast.is-on{opacity:1;transform:translate(-50%,0);}
.save-toast svg{width:16px;height:16px;}

.docblock{margin-top:var(--sp-2xl);background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--sp-lg) var(--sp-xl);}
.docblock__head{display:flex;align-items:center;gap:9px;font-size:var(--fs-md);font-weight:700;color:var(--ink);margin-bottom:var(--sp-md);}
.docblock__head .ic{width:17px;height:17px;color:var(--muted);}
.doc-status{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-sm);font-weight:700;padding:9px 14px;border-radius:var(--r-sm);width:100%;}
.doc-status--ok{background:var(--coop-tint);color:var(--coop-strong);border:1px solid color-mix(in srgb,var(--coop) 25%,transparent);}
.doc-status--wait{background:var(--lv-tint);color:var(--lv-strong);border:1px solid color-mix(in srgb,var(--lv) 30%,transparent);}
.doc-status .ic{width:15px;height:15px;}
.doc-files{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-direction:column;gap:var(--sp-sm);}
.doc-files li{display:flex;align-items:center;gap:9px;font-size:var(--fs-sm);}
.doc-files .ic-file{width:15px;height:15px;flex:none;color:var(--faint);}
.doc-files a{color:var(--coop-strong);font-weight:600;text-decoration:underline;text-underline-offset:2px;}
.doc-files .meta{color:var(--muted);font-weight:500;}
.doc-files .rm{margin-left:auto;width:24px;height:24px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;color:var(--faint);cursor:pointer;border:0;background:none;}
.doc-files .rm:hover{background:var(--danger-tint);color:var(--danger);}

.iban-display{display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--sp-lg) var(--sp-lg);margin-bottom:14px;}
.iban-display__num{font-size:var(--fs-lead);font-weight:700;letter-spacing:.08em;font-variant-numeric:tabular-nums;color:var(--ink);}
.iban-display__num .stars{color:var(--faint);letter-spacing:.12em;}

.conn-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-lg);flex-wrap:wrap;padding:var(--sp-lg) 0;border-top:1px solid var(--line);}
.conn-row:first-of-type{border-top:0;padding-top:0;}
.conn-row__main .lbl{font-size:var(--fs-xs);font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--muted);margin-bottom:5px;}
.conn-row__main .val{font-size:var(--fs-lead);font-weight:700;color:var(--ink);}
.conn-row__main .hint{font-size:var(--fs-xs);color:var(--muted);margin-top:3px;}

/* ============================================================ */
/* 12 · CONNEXION (split visuel + formulaire) — niveau compte   */
/* ============================================================ */
/* Aligné sur docs/maquettes-reference/connexion.css (fond photo login-aside.jpg). */
.login{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);}
.login__main{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 22px 90px;}
.login__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:0;max-width:940px;width:100%;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-2);overflow:hidden;}
@media(max-width:760px){.login__grid{grid-template-columns:1fr;}}
.login__aside{background:linear-gradient(160deg,color-mix(in srgb,var(--ps-strong) 80%,transparent),color-mix(in srgb,#0a3940 88%,transparent)),url("../img/login-aside.jpg") center/cover no-repeat;color:#fff;padding:40px 38px;display:flex;flex-direction:column;}
.login__aside-logo img{height:62px;width:auto;filter:brightness(0) invert(1);opacity:.96;}
.login__aside-t{font-size:25px;font-weight:800;letter-spacing:-.02em;line-height:1.18;margin-top:auto;}
.login__aside-d{font-size:14.5px;line-height:1.6;color:rgba(255,255,255,.82);margin-top:13px;}
.login__aside-stats{display:flex;gap:26px;margin-top:26px;padding-top:22px;border-top:1px solid rgba(255,255,255,.18);}
.login__aside-stat .n{font-size:22px;font-weight:800;letter-spacing:-.01em;}
.login__aside-stat .l{font-size:11.5px;color:rgba(255,255,255,.7);margin-top:2px;}
.login__form{padding:40px 40px 36px;display:flex;flex-direction:column;}
.login__eyebrow{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--ps-strong);}
.login__title{font-size:24px;font-weight:800;letter-spacing:-.02em;margin-top:7px;}
.login__sub{font-size:14px;color:var(--muted);margin-top:6px;line-height:1.5;}
.login__form .fld{margin-top:18px;}
.login__row{display:flex;align-items:center;justify-content:space-between;margin-top:10px;}
.login__remember{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2);cursor:pointer;}
.login__remember input{width:17px;height:17px;accent-color:var(--ps);}
.login__forgot{font-size:13px;font-weight:600;color:var(--ps-strong);}
.login__submit{margin-top:22px;width:100%;justify-content:center;}
.login__divider{display:flex;align-items:center;gap:14px;margin:24px 0 18px;color:var(--faint);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;}
.login__divider::before,.login__divider::after{content:"";flex:1;height:1px;background:var(--line);}
.login__cta{background:var(--ps-tint);border:1px solid var(--ps-tint-2);border-radius:var(--r-md);padding:16px 18px;display:flex;align-items:center;gap:14px;}
.login__cta-txt{flex:1;}
.login__cta-t{font-size:14.5px;font-weight:800;color:var(--ink);}
.login__cta-d{font-size:12.5px;color:var(--ink-2);margin-top:2px;line-height:1.45;}
.login__cta .btn{flex:none;}

/* pré-coquille (top-bar + footer du tunnel public) */
.pre-topbar{position:sticky;top:0;z-index:30;background:var(--card);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-lg);padding:14px 30px;}
.pre-topbar__logo img{height:42px;width:auto;display:block;}
.pre-topbar__right{display:flex;align-items:center;gap:var(--sp-lg);}
.sub-foot{border-top:1px solid var(--line);background:var(--card);padding:var(--sp-xl) 30px;}
.sub-foot__in{max-width:880px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-lg);flex-wrap:wrap;font-size:var(--fs-xs);color:var(--muted);}
.sub-foot__links{display:flex;gap:var(--sp-lg);flex-wrap:wrap;}
.sub-foot__links a{color:var(--ink-2);font-weight:500;}
.sub-foot__links a:hover{color:var(--accent-strong);}
