/* ============================================================
   SR2 — 2052  ·  Identité « liquid glass premium »
   Apple visionOS-inspired : surfaces givrées, bordures capillaires,
   dock de navigation flottant (façon Instagram), springs, cascade.
   Graphite neutre + accent rouge raffiné. Zéro néon. Zéro grille.
   Scope : html[data-theme] → ne touche pas aux maquettes HTML
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ── 1. TOKENS ──────────────────────────────────────────────── */
:root[data-theme="dark"]{
  --bg:#0a0a0d;
  --charbon:rgba(255,255,255,.045);
  --acier:rgba(255,255,255,.07);
  --bordure:rgba(255,255,255,.085);
  --accent:#ff453a;
  --accent2:#ff6b5e;
  --texte:#d6d6dc;
  --texte-dim:#86868f;
  --blanc:#f5f5f7;
  --vert:#30d158;
  --bleu:#0a84ff;
  --jaune:#ffd60a;
  --orange:#ff9f0a;
  --card-bg:rgba(255,255,255,.052);
  --input-bg:rgba(255,255,255,.06);
  --shadow:rgba(0,0,0,.5);
  --hairline:rgba(255,255,255,.085);
  --frost:saturate(180%) blur(22px);
  --e1:0 1px 1px rgba(0,0,0,.22), 0 8px 24px rgba(0,0,0,.30);
  --e2:0 2px 4px rgba(0,0,0,.26), 0 18px 50px rgba(0,0,0,.45);
  --spring:cubic-bezier(.32,1.4,.45,1);
}
:root[data-theme="light"]{
  --bg:#f2f2f6;
  --charbon:rgba(255,255,255,.72);
  --acier:rgba(255,255,255,.9);
  --bordure:rgba(0,0,0,.075);
  --accent:#e8362b;
  --accent2:#ff5a4f;
  --texte:#3a3a40;
  --texte-dim:#85858d;
  --blanc:#1c1c21;
  --vert:#19a342;
  --bleu:#0071e3;
  --jaune:#b88a00;
  --orange:#cc7a00;
  --card-bg:rgba(255,255,255,.78);
  --input-bg:rgba(255,255,255,.92);
  --shadow:rgba(40,40,60,.14);
  --hairline:rgba(0,0,0,.07);
  --frost:saturate(180%) blur(22px);
  --e1:0 1px 1px rgba(30,30,50,.05), 0 8px 24px rgba(30,30,50,.08);
  --e2:0 2px 6px rgba(30,30,50,.07), 0 22px 60px rgba(30,30,50,.14);
  --spring:cubic-bezier(.32,1.4,.45,1);
}

/* ── 2. BASE & FOND AMBIANT ─────────────────────────────────── */
html[data-theme] body{
  font-family:'Inter','Barlow',-apple-system,sans-serif;
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.011em;
}
html[data-theme] body::before{display:none;}
html[data-theme] body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(56% 42% at 18% -6%, rgba(255,69,58,.075), transparent 70%),
    radial-gradient(48% 38% at 86% 4%, rgba(10,132,255,.055), transparent 70%),
    radial-gradient(60% 50% at 50% 112%, rgba(255,159,10,.045), transparent 72%);
  animation:sr3Ambient 26s ease-in-out infinite alternate;
}
html[data-theme="light"] body::after{
  background:
    radial-gradient(56% 42% at 18% -6%, rgba(232,54,43,.06), transparent 70%),
    radial-gradient(48% 38% at 86% 4%, rgba(0,113,227,.05), transparent 70%);
}
@keyframes sr3Ambient{from{transform:translateY(0) scale(1);}to{transform:translateY(-26px) scale(1.05);}}
html[data-theme] .main-wrap,
html[data-theme] header,
html[data-theme] .sub-header,
html[data-theme] .tabs-bar{position:relative;z-index:1;}

html[data-theme] ::selection{background:var(--accent);color:#fff;}
html[data-theme] ::-webkit-scrollbar{width:8px;height:8px;}
html[data-theme] ::-webkit-scrollbar-track{background:transparent;}
html[data-theme] ::-webkit-scrollbar-thumb{background:rgba(128,128,140,.35);border-radius:99px;}
html[data-theme] ::-webkit-scrollbar-thumb:hover{background:rgba(128,128,140,.6);}

/* ── 3. HEADER (verre givré, capillaire) ────────────────────── */
html[data-theme] header{
  position:sticky;top:0;z-index:300;
  background:color-mix(in srgb, var(--bg) 62%, transparent);
  backdrop-filter:var(--frost);
  -webkit-backdrop-filter:var(--frost);
  border-bottom:1px solid var(--hairline);
  height:54px;
}
html[data-theme] .header-title{
  font-family:'Inter',sans-serif;font-weight:700;
  font-size:16px;letter-spacing:-.02em;
  color:var(--blanc);
}
html[data-theme] .header-title span{color:var(--accent);}
html[data-theme] .header-sub{
  font-family:'Inter',sans-serif;font-size:10px;font-weight:500;
  letter-spacing:.08em;color:var(--texte-dim);
}
html[data-theme] .header-divider{background:var(--hairline);}
html[data-theme] .hdr-btn{
  font-family:'Inter',sans-serif;font-weight:600;font-size:11px;
  letter-spacing:.01em;text-transform:none;
  color:var(--texte);
  background:var(--charbon);
  border:1px solid var(--hairline);
  border-radius:999px;
  padding:7px 14px;
  transition:all .22s var(--spring);
}
html[data-theme] .hdr-btn:hover{
  background:var(--acier);color:var(--blanc);
  border-color:var(--bordure);
  transform:translateY(-1px);
}
html[data-theme] .hdr-btn:active{transform:scale(.95);}
html[data-theme] .sub-header{
  background:transparent;border-bottom:none;height:38px;
}
html[data-theme] .sub-user-badge{
  font-family:'Inter',sans-serif;font-size:10px;font-weight:600;
  letter-spacing:.07em;color:var(--texte-dim);
  background:var(--charbon);
  border:1px solid var(--hairline);
  border-radius:999px;padding:5px 12px;
}

/* ── 4. DOCK FLOTTANT (signature — façon Instagram) ─────────── */
html[data-theme] .tabs-bar{
  position:sticky;top:62px;z-index:250;
  width:fit-content;max-width:calc(100% - 24px);
  margin:12px auto 6px;
  padding:5px;gap:2px;
  background:color-mix(in srgb, var(--bg) 55%, transparent);
  backdrop-filter:var(--frost);
  -webkit-backdrop-filter:var(--frost);
  border:1px solid var(--hairline);
  border-radius:999px;
  box-shadow:var(--e1);
  animation:sr3Dock .5s var(--spring) both;
}
@keyframes sr3Dock{from{opacity:0;transform:translateY(-10px) scale(.96);}to{opacity:1;transform:none;}}
html[data-theme] .tab-btn{
  font-family:'Inter',sans-serif;font-weight:600;font-size:12px;
  letter-spacing:0;text-transform:none;
  color:var(--texte-dim);
  border:none;border-bottom:none;border-radius:999px;
  padding:9px 16px;
  transition:all .25s var(--spring);
}
html[data-theme] .tab-btn:hover{color:var(--blanc);background:var(--charbon);}
html[data-theme] .tab-btn.actif{
  color:#fff;
  background:linear-gradient(180deg, var(--accent2), var(--accent));
  border-bottom:none;
  box-shadow:0 4px 14px color-mix(in srgb, var(--accent) 45%, transparent);
}
html[data-theme] .tab-btn:active{transform:scale(.94);}
/* onglets internes (vue gestion) */
html[data-theme] .ctab{
  font-family:'Inter',sans-serif;font-weight:600;text-transform:none;letter-spacing:0;
  border-radius:999px;border-bottom:none;
  transition:all .22s var(--spring);
}
html[data-theme] .ctab.actif{color:#fff;background:linear-gradient(180deg,var(--accent2),var(--accent));border-bottom:none;}
html[data-theme] .ctab:hover:not(.actif){color:var(--blanc);background:var(--charbon);}

/* ── 5. SURFACES GIVRÉES ────────────────────────────────────── */
html[data-theme] .card,
html[data-theme] .resume-card,
html[data-theme] .banque-card,
html[data-theme] .hist-row,
html[data-theme] .bulletin-row,
html[data-theme] .bul-row,
html[data-theme] .dest-item,
html[data-theme] .emp-item,
html[data-theme] .login-box,
html[data-theme] .cal,
html[data-theme] .env-total,
html[data-theme] .jour-total-box{
  background:var(--card-bg);
  backdrop-filter:var(--frost);
  -webkit-backdrop-filter:var(--frost);
  border:1px solid var(--hairline);
  border-radius:22px;
  box-shadow:var(--e1);
}
html[data-theme] .heures-calc-box,
html[data-theme] .shift-total{border-radius:16px;border:1px solid var(--hairline);}
html[data-theme] .resume-card{
  transition:transform .3s var(--spring), box-shadow .3s ease;
}
html[data-theme] .resume-card:hover{transform:translateY(-3px);box-shadow:var(--e2);}
html[data-theme] .resume-val{
  font-family:'Inter',sans-serif;font-weight:700;letter-spacing:-.03em;
  font-variant-numeric:tabular-nums;
}
html[data-theme] .resume-label,
html[data-theme] .banque-titre{
  font-family:'Inter',sans-serif;font-weight:600;font-size:9px;
  letter-spacing:.09em;
}
html[data-theme] .card-titre{
  font-family:'Inter',sans-serif;font-weight:700;letter-spacing:-.01em;text-transform:none;
}
html[data-theme] .banque-card::before{height:0;}
html[data-theme] .banque-card{overflow:hidden;}
html[data-theme] .banque-val{font-family:'Inter',sans-serif;font-weight:700;letter-spacing:-.03em;font-variant-numeric:tabular-nums;}
html[data-theme] .banque-card.orange{box-shadow:var(--e1), inset 0 14px 40px -28px var(--orange);}
html[data-theme] .banque-card.vert{box-shadow:var(--e1), inset 0 14px 40px -28px var(--vert);}
html[data-theme] .banque-card.bleu{box-shadow:var(--e1), inset 0 14px 40px -28px var(--bleu);}
html[data-theme] .banque-card.jaune{box-shadow:var(--e1), inset 0 14px 40px -28px var(--jaune);}
html[data-theme] .hist-row{border-left:1px solid var(--hairline);}
html[data-theme] .hist-row,
html[data-theme] .bulletin-row{transition:transform .3s var(--spring), box-shadow .3s ease;}
html[data-theme] .hist-row:hover,
html[data-theme] .bulletin-row:hover{transform:translateY(-2px);box-shadow:var(--e2);}

/* ── 6. CASCADE D'ENTRÉE (stagger Instagram) ────────────────── */
@keyframes sr3Up{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}
html[data-theme] .tab-content.actif .resume-card,
html[data-theme] .tab-content.actif .jour-card,
html[data-theme] .tab-content.actif .banque-card,
html[data-theme] .ctab-content.actif .card,
html[data-theme] .container > .cal,
html[data-theme] .container > .env-modes,
html[data-theme] .container > .env-total{
  animation:sr3Up .45s var(--spring) both;
}
html[data-theme] .tab-content.actif > * > :nth-child(2){animation-delay:.04s;}
html[data-theme] .tab-content.actif .resume-card:nth-child(2){animation-delay:.05s;}
html[data-theme] .tab-content.actif .resume-card:nth-child(3){animation-delay:.10s;}
html[data-theme] .tab-content.actif .resume-card:nth-child(4){animation-delay:.15s;}
html[data-theme] .tab-content.actif .jour-card:nth-child(1){animation-delay:.08s;}
html[data-theme] .tab-content.actif .jour-card:nth-child(2){animation-delay:.12s;}
html[data-theme] .tab-content.actif .jour-card:nth-child(3){animation-delay:.16s;}
html[data-theme] .tab-content.actif .jour-card:nth-child(4){animation-delay:.20s;}
html[data-theme] .tab-content.actif .jour-card:nth-child(5){animation-delay:.24s;}
html[data-theme] .tab-content.actif .jour-card:nth-child(6){animation-delay:.28s;}
html[data-theme] .tab-content.actif .jour-card:nth-child(7){animation-delay:.32s;}
html[data-theme] .tab-content.actif .banque-card:nth-child(2){animation-delay:.07s;}
html[data-theme] .tab-content.actif .banque-card:nth-child(3){animation-delay:.14s;}
html[data-theme] .tab-content.actif .banque-card:nth-child(4){animation-delay:.21s;}
html[data-theme] .tab-content.actif .banque-card:nth-child(5){animation-delay:.28s;}

/* ── 7. CALENDRIER SEMAINE ──────────────────────────────────── */
html[data-theme] .jour-card{
  background:var(--card-bg);
  backdrop-filter:var(--frost);
  -webkit-backdrop-filter:var(--frost);
  border:1px solid var(--hairline);
  border-radius:18px;
  transition:transform .28s var(--spring), box-shadow .28s ease, border-color .2s ease;
}
html[data-theme] .jour-card:hover{
  transform:translateY(-3px) scale(1.015);
  box-shadow:var(--e2);
  background:var(--acier);
  border-color:var(--bordure);
}
html[data-theme] .jour-card.aujourd-hui{
  border:1px solid color-mix(in srgb, var(--accent) 55%, transparent);
  background:color-mix(in srgb, var(--accent) 7%, var(--card-bg));
  box-shadow:var(--e1), 0 0 0 3px color-mix(in srgb, var(--accent) 14%, transparent);
}
html[data-theme] .jour-card.a-des-heures{border-left:1px solid var(--hairline);}
html[data-theme] .jour-card.a-des-heures::after{
  content:'';position:absolute;top:10px;right:10px;width:7px;height:7px;
  border-radius:50%;background:var(--vert);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--vert) 18%, transparent);
}
html[data-theme] .jour-card.weekend{opacity:.82;}
html[data-theme] .jour-nom{font-family:'Inter',sans-serif;font-weight:600;font-size:9px;letter-spacing:.09em;}
html[data-theme] .jour-date-num{font-family:'Inter',sans-serif;font-weight:700;letter-spacing:-.02em;}
html[data-theme] .jour-heures-val{font-family:'Inter',sans-serif;font-weight:600;font-size:13px;}
html[data-theme] .jour-horaire-txt{font-family:'Inter',sans-serif;font-size:9.5px;}
html[data-theme] .semaine-titre{font-family:'Inter',sans-serif;font-weight:700;letter-spacing:-.02em;text-transform:none;}
html[data-theme] .semaine-sous{font-family:'Inter',sans-serif;letter-spacing:.05em;}

/* ── 8. PICKER DE PÉRIODE (envoi) ───────────────────────────── */
html[data-theme] .env-modes{
  background:var(--charbon);
  backdrop-filter:var(--frost);
  -webkit-backdrop-filter:var(--frost);
  border:1px solid var(--hairline);
  border-radius:999px;padding:4px;
}
html[data-theme] .env-mode{
  font-family:'Inter',sans-serif;font-weight:600;text-transform:none;letter-spacing:0;
  border-radius:999px;
  transition:all .25s var(--spring);
}
html[data-theme] .env-mode.actif{
  background:linear-gradient(180deg,var(--accent2),var(--accent));
  box-shadow:0 4px 14px color-mix(in srgb, var(--accent) 40%, transparent);
}
html[data-theme] .env-mode:active{transform:scale(.95);}
html[data-theme] .cal{border-radius:24px;padding:20px 16px;}
html[data-theme] .cal-titre{font-family:'Inter',sans-serif;font-weight:700;text-transform:none;letter-spacing:-.01em;}
html[data-theme] .cal-nav{
  background:var(--charbon);border:1px solid var(--hairline);
  color:var(--texte);
  transition:all .25s var(--spring);
}
html[data-theme] .cal-nav:hover{
  background:linear-gradient(180deg,var(--accent2),var(--accent));
  border-color:transparent;color:#fff;transform:scale(1.08);
  box-shadow:0 4px 14px color-mix(in srgb, var(--accent) 40%, transparent);
}
html[data-theme] .cal-nav:active{transform:scale(.9);}
html[data-theme] .cal-dows span{font-family:'Inter',sans-serif;font-weight:600;font-size:10px;letter-spacing:.06em;}
html[data-theme] .cal-cell .num{
  font-family:'Inter',sans-serif;font-weight:500;font-size:14px;
  transition:all .22s var(--spring);
}
html[data-theme] .cal-cell.hover-wk{background:var(--charbon);}
html[data-theme] .cal-cell.in-range{background:color-mix(in srgb, var(--accent) 13%, transparent);}
html[data-theme] .cal-cell.sel .num{
  background:linear-gradient(180deg,var(--accent2),var(--accent));
  box-shadow:0 5px 16px color-mix(in srgb, var(--accent) 50%, transparent);
  font-weight:700;
}
html[data-theme] .cal-cell.auj:not(.sel) .num{
  box-shadow:inset 0 0 0 1.5px var(--accent);
}
html[data-theme] .cal-preset{
  font-family:'Inter',sans-serif;font-weight:600;text-transform:none;letter-spacing:0;
  background:var(--charbon);border:1px solid var(--hairline);color:var(--texte);
  transition:all .25s var(--spring);
}
html[data-theme] .cal-preset:hover{
  background:var(--acier);color:var(--blanc);border-color:var(--bordure);
  transform:translateY(-1px);box-shadow:var(--e1);
}
html[data-theme] .cal-preset:active{transform:scale(.95);}

/* ── 9. SHEETS (modals iOS) ─────────────────────────────────── */
html[data-theme] .modal-overlay{
  background:rgba(0,0,0,.44);
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
}
html[data-theme] .modal{
  background:color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter:var(--frost);
  -webkit-backdrop-filter:var(--frost);
  border:1px solid var(--bordure);
  border-top:1px solid var(--bordure);
  border-radius:26px;
  box-shadow:var(--e2);
  animation:sr3Sheet .4s var(--spring) both;
}
@keyframes sr3Sheet{from{opacity:0;transform:translateY(26px) scale(.96);}to{opacity:1;transform:none;}}
html[data-theme] .modal-titre{
  font-family:'Inter',sans-serif;font-weight:700;font-size:17px;
  letter-spacing:-.02em;text-transform:none;
}

/* ── 10. BOUTONS ────────────────────────────────────────────── */
html[data-theme] .btn-prim{
  font-family:'Inter',sans-serif;font-weight:600;font-size:13px;
  letter-spacing:0;text-transform:none;
  background:linear-gradient(180deg, var(--accent2), var(--accent));
  border:none;border-radius:14px;
  box-shadow:0 6px 18px color-mix(in srgb, var(--accent) 38%, transparent), inset 0 1px 0 rgba(255,255,255,.18);
  transition:all .25s var(--spring);
}
html[data-theme] .btn-prim:hover{
  filter:brightness(1.07);transform:translateY(-1px);
  box-shadow:0 10px 26px color-mix(in srgb, var(--accent) 48%, transparent), inset 0 1px 0 rgba(255,255,255,.18);
}
html[data-theme] .btn-prim:active{transform:scale(.96);}
html[data-theme] .btn-sec,
html[data-theme] .btn-nav,
html[data-theme] .btn-add-shift{
  font-family:'Inter',sans-serif;font-weight:600;font-size:12px;
  letter-spacing:0;text-transform:none;
  background:var(--charbon);color:var(--texte);
  border:1px solid var(--hairline);border-radius:14px;
  transition:all .25s var(--spring);
}
html[data-theme] .btn-sec:hover,
html[data-theme] .btn-nav:hover,
html[data-theme] .btn-add-shift:hover{
  background:var(--acier);color:var(--blanc);border-color:var(--bordure);
  transform:translateY(-1px);
}
html[data-theme] .btn-sec:active,
html[data-theme] .btn-nav:active{transform:scale(.96);}
html[data-theme] .btn-nav.accent{
  background:linear-gradient(180deg,var(--accent2),var(--accent));
  border:none;color:#fff;
  box-shadow:0 5px 16px color-mix(in srgb, var(--accent) 38%, transparent);
}
html[data-theme] .btn-danger{
  font-family:'Inter',sans-serif;font-weight:600;text-transform:none;letter-spacing:0;
  background:color-mix(in srgb, #e03c31 12%, transparent);
  border:1px solid color-mix(in srgb, #e03c31 35%, transparent);
  border-radius:14px;
  transition:all .22s var(--spring);
}
html[data-theme] .btn-danger:hover{background:color-mix(in srgb, #e03c31 22%, transparent);}
html[data-theme] .btn-vert,
html[data-theme] .btn-dl{
  font-family:'Inter',sans-serif;font-weight:600;text-transform:none;letter-spacing:0;
  border-radius:12px;border:none;
  box-shadow:0 4px 14px color-mix(in srgb, var(--vert) 30%, transparent);
  transition:all .22s var(--spring);
}
html[data-theme] .btn-dl:hover{opacity:1;transform:translateY(-1px);}
html[data-theme] .btn-dl:active{transform:scale(.95);}

/* ── 11. CHAMPS ─────────────────────────────────────────────── */
html[data-theme] .field label,
html[data-theme] .fi label{
  font-family:'Inter',sans-serif;font-weight:600;font-size:10px;
  letter-spacing:.06em;color:var(--texte-dim);
}
html[data-theme] .field input,
html[data-theme] .field textarea,
html[data-theme] .field select,
html[data-theme] .fi input,
html[data-theme] .fi select,
html[data-theme] .fi textarea,
html[data-theme] .shift-block input[type="time"],
html[data-theme] input[type="date"],
html[data-theme] input[type="time"],
html[data-theme] input[type="number"],
html[data-theme] input[type="text"],
html[data-theme] input[type="password"],
html[data-theme] select,
html[data-theme] textarea{
  font-family:'Inter',sans-serif;
  background:var(--input-bg);
  border:1px solid var(--hairline);
  border-radius:14px;
  transition:all .22s ease;
}
html[data-theme] input:focus,
html[data-theme] select:focus,
html[data-theme] textarea:focus{
  border-color:color-mix(in srgb, var(--accent) 60%, transparent);
  box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent);
  outline:none;
}
html[data-theme] .shift-block{border-radius:18px;}
html[data-theme] #shiftsContainer.multi .shift-block{
  background:var(--charbon);
  border:1px solid var(--hairline);
  border-radius:18px;
}
html[data-theme] .shift-label{font-family:'Inter',sans-serif;font-weight:600;letter-spacing:.05em;}

/* ── 12. LISTES & SÉLECTIONS ────────────────────────────────── */
html[data-theme] .dest-item{
  border-radius:18px;
  transition:all .25s var(--spring);
}
html[data-theme] .dest-item:hover{transform:translateY(-1px);background:var(--acier);border-color:var(--bordure);}
html[data-theme] .dest-item.sel{
  border-color:color-mix(in srgb, var(--accent) 55%, transparent);
  background:color-mix(in srgb, var(--accent) 8%, var(--card-bg));
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 13%, transparent);
}
html[data-theme] .dest-nom{font-family:'Inter',sans-serif;font-weight:600;text-transform:none;}
html[data-theme] .dest-role{
  font-family:'Inter',sans-serif;font-weight:600;font-size:8.5px;
  border:1px solid var(--hairline);border-radius:999px;padding:3px 8px;
}
html[data-theme] .badge{border-radius:999px;font-family:'Inter',sans-serif;font-weight:600;letter-spacing:.02em;}

/* ── 13. TOAST (pilule flottante) ───────────────────────────── */
html[data-theme] #toast{
  background:color-mix(in srgb, var(--bg) 70%, transparent);
  backdrop-filter:var(--frost);
  -webkit-backdrop-filter:var(--frost);
  border:1px solid var(--bordure);
  border-left:1px solid var(--bordure);
  border-radius:999px;
  padding:12px 22px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:13px;letter-spacing:0;
  box-shadow:var(--e2);
}
html[data-theme] #toast::before{
  content:'';display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--vert);margin-right:9px;
  box-shadow:0 0 0 3px color-mix(in srgb, var(--vert) 20%, transparent);
}
html[data-theme] #toast.error::before{
  background:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);
}

/* ── 14. FOOTER & DIVERS ────────────────────────────────────── */
html[data-theme] .site-footer{
  background:transparent;border-top:1px solid var(--hairline);
}
html[data-theme] .site-footer p{font-family:'Inter',sans-serif;font-weight:500;letter-spacing:.18em;}
html[data-theme] table td,
html[data-theme] table th{border-color:var(--hairline) !important;}
html[data-theme] .pdf-preview-wrap{border-radius:18px;overflow:hidden;border:1px solid var(--bordure);box-shadow:var(--e1);}
html[data-theme] .spinner{
  width:20px;height:20px;border-width:2px;
  border-color:var(--hairline);
  border-top-color:var(--accent);
}
html[data-theme] .banque-bar{border-radius:99px;height:5px;background:var(--charbon);}
html[data-theme] .banque-bar-fill{border-radius:99px;}
html[data-theme] .supp-badge{border-radius:999px;font-family:'Inter',sans-serif;}
html[data-theme] .vide-box,
html[data-theme] .vide{font-family:'Inter',sans-serif;letter-spacing:0;text-transform:none;}

/* ── 15. ACCESSIBILITÉ ──────────────────────────────────────── */
html[data-theme] :focus-visible{
  outline:2px solid var(--accent);outline-offset:2px;border-radius:6px;
}
@media (prefers-reduced-motion: reduce){
  html[data-theme] *{transition:none !important;animation:none !important;}
  html[data-theme] body::after{animation:none !important;}
}
