/* ═══════════════════════════════════════════════════════════
   SD Planning — Design Tokens
   Système de variables CSS pour homogénéiser tous les modules.
   À appliquer progressivement aux composants en remplaçant les
   styles inline par var(--xxx) ou par les classes .sdp-* ci-dessous.
   ═══════════════════════════════════════════════════════════ */
:root{
  /* ── BRAND (vert — matche le logo & l'icône PWA) ── */
  --c-brand-50:#f0fdf4;
  --c-brand-100:#dcfce7;
  --c-brand-200:#bbf7d0;
  --c-brand-300:#86efac;
  --c-brand-400:#4ade80;
  --c-brand-500:#22c55e;
  --c-brand-600:#16a34a;   /* PRIMARY — couleur principale de l'app */
  --c-brand-700:#15803d;
  --c-brand-800:#166534;

  /* ── ACCENT (teal — pour secondaire / hover / focus) ── */
  --c-accent-500:#14b8a6;
  --c-accent-600:#0d9488;
  --c-accent-700:#0f766e;

  /* ── Sémantique ── */
  --c-success:#16a34a;
  --c-warning:#f59e0b;
  --c-danger:#ef4444;
  --c-info:#3b82f6;

  /* ── Neutres (gris) ── */
  --c-n-50:#f8fafc;
  --c-n-100:#f1f5f9;
  --c-n-200:#e2e8f0;
  --c-n-300:#cbd5e1;
  --c-n-400:#94a3b8;
  --c-n-500:#64748b;
  --c-n-600:#475569;
  --c-n-700:#334155;
  --c-n-800:#1e293b;
  --c-n-900:#0f172a;

  /* ── Typographie ── */
  --ff-base:'Inter',-apple-system,'Segoe UI',system-ui,Roboto,Helvetica,Arial,sans-serif;
  --fs-xs:11px;
  --fs-sm:12px;
  --fs-base:13px;
  --fs-md:14px;
  --fs-lg:16px;
  --fs-xl:18px;
  --fs-2xl:22px;
  --fw-regular:400;
  --fw-medium:500;
  --fw-semibold:600;
  --fw-bold:700;
  --fw-extrabold:800;
  --lh-tight:1.25;
  --lh-base:1.4;
  --lh-relaxed:1.6;

  /* ── Espacements (échelle 4px) ── */
  --sp-1:4px;
  --sp-2:8px;
  --sp-3:12px;
  --sp-4:16px;
  --sp-5:20px;
  --sp-6:24px;
  --sp-8:32px;
  --sp-10:40px;

  /* ── Rayons d'arrondi ── */
  --r-xs:4px;
  --r-sm:6px;
  --r-md:8px;
  --r-lg:12px;
  --r-xl:16px;
  --r-pill:9999px;

  /* ── Ombres ── */
  --sh-sm:0 1px 2px rgba(0,0,0,.05);
  --sh-md:0 2px 8px rgba(0,0,0,.08);
  --sh-lg:0 8px 24px rgba(0,0,0,.12);
  --sh-xl:0 20px 50px rgba(0,0,0,.18);

  /* ── Boutons standardisés (à appliquer via .sdp-btn) ── */
  --btn-h-sm:28px;
  --btn-h-md:36px;
  --btn-h-lg:44px;
  --btn-px:14px;
  --btn-radius:var(--r-md);
  --btn-fw:var(--fw-semibold);
  --btn-fs:var(--fs-base);
  --btn-transition:all .15s ease;

  /* ── Inputs standardisés (à appliquer via .sdp-input) ── */
  --input-h:36px;
  --input-px:12px;
  --input-radius:var(--r-md);
  --input-border:1px solid var(--c-n-300);
  --input-border-focus:1px solid var(--c-brand-600);
  --input-fs:var(--fs-base);

  /* ── Cards ── */
  --card-bg:#fff;
  --card-border:1px solid var(--c-n-200);
  --card-radius:var(--r-lg);
  --card-pad:var(--sp-4);
  --card-shadow:var(--sh-sm);

  /* ── Layout ── */
  --sidebar-w-expanded:220px;
  --sidebar-w-collapsed:58px;
  --header-h:56px;
  --content-max-w:1400px;
}
[data-sdp-theme="dark"]{
  --c-n-50:#07110d;
  --c-n-100:#0b1711;
  --c-n-200:#173327;
  --c-n-300:#285242;
  --c-n-400:#7ba898;
  --c-n-500:#a3bfb5;
  --c-n-600:#c5d8d1;
  --c-n-700:#d8e5e0;
  --c-n-800:#ecfdf5;
  --c-n-900:#f8fafc;
  --card-bg:#0f1f18;
  --card-border:1px solid rgba(134,239,172,.16);
  --card-shadow:0 12px 32px rgba(0,0,0,.28);
}

/* ═══════════════════════════════════════════════════════════
   Classes utilitaires SDP (.sdp-*) — homogénéisation progressive
   Remplacent les styles inline éparpillés. Tous les composants
   peuvent les adopter au fur et à mesure des refontes.
   ═══════════════════════════════════════════════════════════ */

/* ── Boutons ── */
.sdp-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  height:var(--btn-h-md);padding:0 var(--btn-px);
  border-radius:var(--btn-radius);border:none;cursor:pointer;
  font-family:inherit;font-size:var(--btn-fs);font-weight:var(--btn-fw);
  letter-spacing:0;white-space:nowrap;transition:var(--btn-transition);
  user-select:none;
}
.sdp-btn:disabled{opacity:.5;cursor:not-allowed}
.sdp-btn--sm{height:var(--btn-h-sm);padding:0 10px;font-size:var(--fs-sm)}
.sdp-btn--lg{height:var(--btn-h-lg);padding:0 20px;font-size:var(--fs-md)}
.sdp-btn--primary{background:var(--c-brand-600);color:#fff}
.sdp-btn--primary:hover:not(:disabled){background:var(--c-brand-700)}
.sdp-btn--secondary{background:var(--c-n-100);color:var(--c-n-800)}
.sdp-btn--secondary:hover:not(:disabled){background:var(--c-n-200)}
.sdp-btn--ghost{background:transparent;color:var(--c-n-600);border:1px solid var(--c-n-200)}
.sdp-btn--ghost:hover:not(:disabled){background:var(--c-n-100);border-color:var(--c-n-300)}
.sdp-btn--danger{background:var(--c-danger);color:#fff}
.sdp-btn--danger:hover:not(:disabled){background:#dc2626}
.sdp-btn--success{background:var(--c-success);color:#fff}
.sdp-btn--warn{background:var(--c-warning);color:var(--c-n-900)}

/* ── Inputs ── */
.sdp-input,.sdp-select,.sdp-textarea{
  display:block;width:100%;
  height:var(--input-h);padding:0 var(--input-px);
  border:var(--input-border);border-radius:var(--input-radius);
  background:#fff;color:var(--c-n-800);
  font-family:inherit;font-size:var(--input-fs);
  outline:none;transition:border-color .12s,box-shadow .12s;
}
.sdp-textarea{height:auto;min-height:80px;padding:10px var(--input-px);line-height:var(--lh-base)}
.sdp-input:focus,.sdp-select:focus,.sdp-textarea:focus{
  border-color:var(--c-brand-600);
  box-shadow:0 0 0 3px var(--c-brand-100);
}
.sdp-label{
  display:block;margin-bottom:var(--sp-1);
  font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--c-n-600);
  letter-spacing:0;
}

/* ── Cards ── */
.sdp-card{
  background:var(--card-bg);border:var(--card-border);
  border-radius:var(--card-radius);padding:var(--card-pad);
  box-shadow:var(--card-shadow);
}
.sdp-card__header{
  display:flex;justify-content:space-between;align-items:center;
  padding-bottom:var(--sp-3);margin-bottom:var(--sp-3);
  border-bottom:1px solid var(--c-n-100);
}
.sdp-card__title{font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--c-n-900)}
.sdp-card__sub{font-size:var(--fs-xs);color:var(--c-n-500);margin-top:2px}

/* ── Badges & chips ── */
.sdp-badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:var(--r-pill);
  font-size:var(--fs-xs);font-weight:var(--fw-semibold);
  background:var(--c-brand-100);color:var(--c-brand-800);
}
.sdp-badge--warn{background:#fef3c7;color:#92400e}
.sdp-badge--danger{background:#fee2e2;color:#991b1b}
.sdp-badge--info{background:#dbeafe;color:#1e40af}

/* ── Layout helpers ── */
.sdp-stack{display:flex;flex-direction:column;gap:var(--sp-3)}
.sdp-row{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}
.sdp-row--end{justify-content:flex-end}
.sdp-row--between{justify-content:space-between}

/* ── Section labels (petit titre uppercase au-dessus d'une liste) ── */
.sdp-section-label{
  font-size:var(--fs-xs);
  font-weight:var(--fw-bold);
  color:var(--c-n-500);
  letter-spacing:.5px;
  text-transform:uppercase;
  line-height:1.4;
}

/* ── Hiérarchie typographique unifiée (h1 → h4) ── */
.sdp-h1,h1.sdp{font-size:var(--fs-2xl);font-weight:var(--fw-extrabold);color:var(--c-n-900);letter-spacing:-.5px;line-height:var(--lh-tight)}
.sdp-h2,h2.sdp{font-size:var(--fs-xl);font-weight:var(--fw-extrabold);color:var(--c-n-900);letter-spacing:-.3px;line-height:var(--lh-tight)}
.sdp-h3,h3.sdp{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--c-n-900);letter-spacing:-.2px;line-height:var(--lh-tight)}
.sdp-h4,h4.sdp{font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--c-n-800);line-height:var(--lh-tight)}
.sdp-text-muted{color:var(--c-n-500);font-size:var(--fs-sm)}

/* ═══════════════════════════════════════════════════════════
   HOMOGÉNÉISATION GLOBALE — règles qui s'appliquent à TOUS
   les éléments natifs (button, input, select, textarea), même
   ceux qui utilisent des styles inline. Ajoute hover/focus/
   active states cohérents partout, sans toucher au JSX.
   ═══════════════════════════════════════════════════════════ */

/* ── Boutons natifs : hover/active/focus uniformes partout ── */
button{
  cursor:pointer;
  font-family:inherit;
  transition:filter .12s ease, transform .08s ease, box-shadow .12s ease, background-color .12s ease, border-color .12s ease;
  -webkit-tap-highlight-color:transparent;
}
button:disabled{cursor:not-allowed;opacity:.55}
button:not(:disabled):hover{filter:brightness(.94)}
button:not(:disabled):active{transform:translateY(1px)}
button:focus{outline:none}
button:focus-visible{
  outline:2px solid var(--c-brand-600);
  outline-offset:2px;
  border-radius:var(--r-sm);
}

/* ── Inputs natifs : focus ring vert cohérent partout ── */
input:not([type=checkbox]):not([type=radio]),
select,
textarea{
  font-family:inherit;
  transition:border-color .12s ease, box-shadow .12s ease;
  -webkit-tap-highlight-color:transparent;
}
input:not([type=checkbox]):not([type=radio]):focus,
select:focus,
textarea:focus{
  outline:none !important;
  border-color:var(--c-brand-600) !important;
  box-shadow:0 0 0 3px var(--c-brand-100) !important;
}
input::placeholder,textarea::placeholder{color:var(--c-n-400);opacity:1}

/* ── Liens cohérents ── */
a{color:var(--c-brand-700);text-decoration:none;transition:color .12s ease}
a:hover{color:var(--c-brand-800);text-decoration:underline}

/* ── Sélection de texte aux couleurs de la marque ── */
::selection{background:var(--c-brand-200);color:var(--c-n-900)}
::-moz-selection{background:var(--c-brand-200);color:var(--c-n-900)}

/* ── Scrollbars personnalisées (déjà partiellement présentes plus bas, on consolide) ── */
*::-webkit-scrollbar{width:8px;height:8px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:var(--c-n-300);border-radius:var(--r-pill);border:2px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:var(--c-n-400);background-clip:content-box;border:2px solid transparent}
*{scrollbar-width:thin;scrollbar-color:var(--c-n-300) transparent}

/* ── Polish global du rendu ── */
body{
  font-feature-settings:"cv11","ss01","ss03";  /* Inter : meilleur rendu chiffres + l/I distincts */
  text-rendering:optimizeLegibility;
}

/* ── Composants Bt/In/Sl/Lb/Cd : amélioration ciblée via className ── */
/* (les composants ajoutent ces classes — voir ui-primitives.jsx) */
.sdp-bt-x{
  border-radius:var(--r-sm) !important;  /* uniformise les boutons Bt */
  font-weight:var(--fw-semibold);
}
.sdp-bt-x:not(:disabled):hover{filter:brightness(.92);box-shadow:var(--sh-sm)}
.sdp-bt-x:not(:disabled):active{transform:translateY(1px) scale(.98);filter:brightness(.88)}

.sdp-in-x,.sdp-sl-x{
  border-radius:var(--r-sm) !important;
  transition:border-color .12s ease, box-shadow .12s ease !important;
}
.sdp-in-x:hover:not(:focus),.sdp-sl-x:hover:not(:focus){border-color:var(--c-n-400) !important}

.sdp-cd-x{
  transition:box-shadow .2s ease, transform .2s ease;
}
.sdp-cd-x:hover{box-shadow:var(--sh-md)}

/* ── Modals : backdrop avec un peu plus de classe ── */
.sdp-md-x{animation:sdp-md-enter .2s cubic-bezier(.16,1,.3,1)}
@keyframes sdp-md-enter{
  from{opacity:0;transform:translateY(8px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

/* ── Cartes "fade-in" déjà existantes : transition de hover ── */
.fade-in:hover{transition:box-shadow .2s ease}

/* ── Détails d'accessibilité ── */
[role=button],[role=link],[tabindex]{cursor:pointer}
[disabled]{user-select:none}

/* ═══════════════════════════════════════════════════════════
   Fin du bloc d'homogénéisation globale
   ═══════════════════════════════════════════════════════════ */

*{box-sizing:border-box;margin:0}
body{
  font-family:'Inter',-apple-system,'Segoe UI',system-ui,Roboto,Helvetica,Arial,sans-serif;
  background:#f1f5f9;-webkit-text-size-adjust:100%;overflow-x:hidden;
  font-size:12.5px;line-height:1.4;color:#1e293b;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  letter-spacing:-.01em;
}
/* ── Typography scale ── */
h1,h2,h3,h4{font-weight:700;line-height:1.25;color:#0f172a;letter-spacing:-.02em}
h2{font-size:1rem} /* 22px */
h3{font-size:.9rem}     /* 16px */
p{font-size:.875rem;color:#475569}
/* ── Label & input consistency ── */
label{font-size:.8125rem;font-weight:500;color:#475569}
input,select,textarea,button{font-family:inherit;font-size:.875rem}
/* ── Sidebar compact ── */
.sb-label{font-size:.8125rem;font-weight:500;letter-spacing:-.01em}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}
/* ── Global readability improvements ── */
.fade-in *{letter-spacing:inherit}
/* Cards uniform padding */
.cd-body{padding:18px 20px}
/* Improve contrast on muted text */
:root{
  --text-primary:#0f172a;
  --text-secondary:#475569;
  --text-muted:#64748b;
  --text-faint:#94a3b8;
  --border:#e2e8f0;
  --bg-card:#fff;
  --bg-page:#f1f5f9;
}
select,input,button{font-family:inherit}
.xcell{width:100%;height:34px;border:none;outline:none;text-align:center;font-weight:700;font-size:12px;background:transparent;text-transform:uppercase;caret-color:#16a34a}
.fade-in{animation:fadeIn .3s ease}@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{from{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes sdp-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.pulse{animation:pulse 2s infinite}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.past-overlay{position:relative}.past-overlay::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(135deg,transparent,transparent 10px,rgba(148,163,184,.06) 10px,rgba(148,163,184,.06) 20px);pointer-events:none;border-radius:inherit}
.tt-border{box-shadow:inset 0 0 0 2px #f59e0b40!important;border-radius:4px}

/* ═══ Disable iOS/Android callout menu (copy/paste) on planning cells ═══ */
.plan-table-wrap,.plan-table-wrap *{-webkit-touch-callout:none!important;-webkit-user-select:none!important;-khtml-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important;user-select:none!important;-webkit-tap-highlight-color:transparent!important}
.plan-table-wrap input,.plan-table-wrap textarea{-webkit-user-select:auto!important;user-select:auto!important}

/* ═══════════════════════════════════════════════
   RESPONSIVE v20 — 3 breakpoints
   Desktop ≥1025 | Tablet 601–1024 | Mobile ≤600
═══════════════════════════════════════════════ */

.mob-btn{display:none}
.mob-topbar{display:none}

/* ═══ Padding fluide global selon viewport ═══ */
.mc>div{padding:clamp(12px,2.2vw,28px)}

/* ── DESKTOP ≥1025px ── */
@media(min-width:1025px){
  .mc{margin-left:220px;transition:margin .25s}
  .mc.collapsed{margin-left:58px}
  .sb{display:flex!important}
  .sb-overlay{display:none!important}
}

/* ── GRAND ÉCRAN ≥1400px : padding plus généreux ── */
@media(min-width:1400px){
  .mc>div{padding:24px clamp(28px,3vw,48px)!important}
  .gf4{gap:14px!important}
}

/* ── ULTRA WIDE ≥1800px : limiter pour ne pas étirer trop ── */
@media(min-width:1800px){
  .mc>div{max-width:1720px;margin:0 auto!important}
}

/* ── TABLET 601–1024px ── */
@media(min-width:601px) and (max-width:1024px){
  .mc,.mc.collapsed{margin-left:0!important;padding-top:62px!important}
  .mc>div{padding:12px clamp(14px,2vw,22px)!important}
  /* Grids tablette : 2 cols pour les grilles standard, auto-fit pour les listes */
  .g3{grid-template-columns:repeat(2,1fr)!important}
  .g4{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))!important}
  .g5{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))!important}
  /* Cartes : pleine largeur */
  .card,.cd{width:100%!important;max-width:100%!important;box-sizing:border-box}
  .sb{
    position:fixed!important;top:0;left:0;bottom:0;right:0;
    width:320px!important;max-width:85vw!important;
    transform:translateX(-105%);transition:transform .25s ease-out;
    display:flex!important;z-index:9600!important;
  }
  .sb.open{transform:translateX(0)!important}
  .sb .sb-close-mobile{display:flex!important;position:absolute;top:14px;right:14px;width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.1);color:#fff;border:none;font-size:20px;cursor:pointer;align-items:center;justify-content:center;z-index:10}
  .sb-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.8)!important;z-index:9500!important;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
  .sb-overlay.open{display:block!important}
  .mob-btn{display:none!important}
  .mob-topbar{
    display:flex!important;position:fixed!important;top:0!important;left:0!important;right:0!important;
    height:52px!important;z-index:8000!important;
    background:linear-gradient(135deg,#0f172a,#1e293b)!important;
    align-items:center!important;justify-content:space-between!important;
    padding:0 10px!important;gap:8px!important;
    box-shadow:0 2px 12px rgba(0,0,0,.3)!important;
    border-bottom:2px solid rgba(22,163,74,.4)!important;
  }
  .mob-topbar-btn{
    width:38px!important;height:38px!important;border-radius:10px!important;
    background:rgba(255,255,255,.1)!important;color:#fff!important;border:none!important;
    font-size:18px!important;cursor:pointer!important;display:flex!important;
    align-items:center!important;justify-content:center!important;flex-shrink:0!important;
  }
  .mob-topbar-btn:active{transform:scale(.92)}
  .mob-topbar-title{display:flex!important;align-items:center!important;gap:8px!important;flex:1!important;justify-content:center!important}
  h2{font-size:17px!important}
  .gf4{grid-template-columns:1fr 1fr!important;gap:10px!important}
  .plan-table-wrap{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important}
  button{min-height:38px}
  input,select,textarea{min-height:38px}
}

/* ── MOBILE ≤600px ── */
@media(max-width:600px){
  body{overflow-x:hidden}
  body.sb-locked{overflow:hidden!important}
  .mc,.mc.collapsed{margin-left:0!important;padding-top:58px!important;width:100%!important}
  .mc>div{padding:12px 10px 24px!important;max-width:100%!important}
  .sb{
    position:fixed!important;top:0;left:0;bottom:0;right:0;
    width:100%!important;max-width:100%!important;
    transform:translateX(-105%);transition:transform .25s ease-out;
    display:flex!important;z-index:9600!important;
    box-shadow:0 0 60px rgba(0,0,0,.5);
  }
  .sb.open{transform:translateX(0)!important}
  .sb .sb-close-mobile{display:flex!important;position:absolute;top:14px;right:14px;width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.1);color:#fff;border:none;font-size:20px;cursor:pointer;align-items:center;justify-content:center;z-index:10}
  .sb-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.65);z-index:8500!important;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
  .sb-overlay.open{display:block!important}
  .mob-btn{display:none!important}
  .mob-topbar{
    display:flex!important;position:fixed!important;top:0!important;left:0!important;right:0!important;
    height:48px!important;z-index:8000!important;
    background:linear-gradient(135deg,#0f172a,#1e293b)!important;
    align-items:center!important;justify-content:space-between!important;
    padding:0 8px!important;gap:6px!important;
    box-shadow:0 2px 12px rgba(0,0,0,.3)!important;
    border-bottom:2px solid rgba(22,163,74,.4)!important;
  }
  .mob-topbar-btn{
    width:36px!important;height:36px!important;border-radius:9px!important;
    background:rgba(255,255,255,.1)!important;color:#fff!important;border:none!important;
    font-size:17px!important;cursor:pointer!important;display:flex!important;
    align-items:center!important;justify-content:center!important;flex-shrink:0!important;
  }
  .mob-topbar-btn:active{transform:scale(.92)}
  .mob-topbar-title{display:flex!important;align-items:center!important;gap:7px!important;flex:1!important;justify-content:center!important}
  /* Typography — bigger for readability */
  h1{font-size:18px!important}
  h2{font-size:16px!important;margin-bottom:8px!important}
  h3{font-size:14px!important}
  /* Cards */
  .card,.cd{padding:14px!important;margin-bottom:8px!important;border-radius:10px!important}
  /* Grids collapse */
  .g2,.g3,.g4,.g5,.gf4{grid-template-columns:1fr!important;gap:8px!important}
  .g7{grid-template-columns:repeat(2,1fr)!important;gap:6px!important}
  /* Tables */
  table{font-size:12px!important}
  th,td{padding:6px 4px!important}
  /* Inputs (prevent iOS zoom = must be ≥16px) — exclut les inputs login qui ont leur propre padding */
  input:not(.sdp-login-input),select,textarea{font-size:16px!important;padding:10px 12px!important;min-height:42px!important}
  /* Buttons touch-friendly — exclut les boutons login */
  button:not(.login-cta):not(.login-link):not(.login-input-toggle){min-height:40px;font-size:13px!important}
  /* Modals */
  .modal-content{max-width:100%!important;width:calc(100% - 12px)!important;max-height:90vh!important;margin:6px!important}
  /* Planning tables */
  .plan-table-wrap{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;max-width:100%!important;margin:0!important;padding:0!important;border-radius:10px}
  /* More menu fullscreen on mobile */
  .more-menu-panel{
    position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;
    margin:0!important;border-radius:0!important;max-width:100vw!important;
    padding:60px 20px 20px!important;overflow-y:auto!important;
    box-shadow:none!important;border:none!important;
  }
  .more-menu-backdrop{background:rgba(15,23,42,.65)!important;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
  .more-menu-close{display:flex!important}
  .more-menu-panel button{padding:14px 16px!important;font-size:14px!important}
}

/* ═══ Typography harmonization ═══ */
/* Uniform font sizes across all views */
body{font-size:13px;color:#1e293b}
h1{font-size:18px;font-weight:700;letter-spacing:-.2px;margin:0}
h2{font-size:15px;font-weight:700;letter-spacing:-.1px;margin:0 0 12px 0;color:#0f172a}
h3{font-size:13px;font-weight:700;letter-spacing:-.05px;margin:0;color:#0f172a}
h4{font-size:12px;font-weight:700;margin:0;color:#475569}
p{font-size:13px;line-height:1.5;margin:0}
small,.small{font-size:11px;color:#64748b}
label{font-size:11px;font-weight:600;color:#475569;letter-spacing:0}
button{font-family:inherit}
input,select,textarea{font-family:inherit;font-size:13px}
/* 👁 Mode impersonation lecture seule : signale visuellement l'inactivité des éléments modifiants */
.impersonate-readonly button:not([data-allow-ro]):not([data-nav]),
.impersonate-readonly input[type="checkbox"],
.impersonate-readonly input[type="radio"]{cursor:not-allowed !important}
.impersonate-readonly button:not([data-allow-ro]):not([data-nav]):hover{opacity:.7;filter:saturate(.7)}

/* ═══════════════════════════════════════════════════════════
   AMÉLIORATIONS RESPONSIVE GLOBALES (post-rebrand)
   Règles ajoutées pour homogénéiser le comportement mobile/tablette
   sans toucher au JSX. Cible les patterns CSS/inline déjà présents.
   ═══════════════════════════════════════════════════════════ */

/* ── Tablette : ≤ 1024px ── */
@media (max-width: 1024px) {
  /* Grilles 4 colonnes des stats → 2 colonnes */
  .g4{grid-template-columns:repeat(2,1fr) !important}
  /* Layout 2 colonnes principal (left + right sidebar 320px) → 1 colonne */
  .gf4{grid-template-columns:1fr !important}
  /* Marges plus serrées */
  .mc>div{padding:clamp(10px,1.8vw,20px) !important}
  /* Cards : moins de padding interne */
  .sdp-card{padding:var(--sp-3)}
}

/* ── Mobile : ≤ 600px ── */
@media (max-width: 600px) {
  body{font-size:14px}
  /* Grilles 4 → 2 → 1 colonne */
  .g4{grid-template-columns:1fr 1fr !important;gap:8px !important}
  .gf4{grid-template-columns:1fr !important;gap:12px !important}
  /* Stats cards plus compactes */
  .g4 > div{padding:12px !important}
  /* Headers : title + clock empilés */
  .mc h2{font-size:15px}
  /* Tables responsive */
  table{font-size:12px}
  th,td{padding:6px 4px !important;word-break:break-word}
  /* Modals : prendre tout l'écran sur mobile */
  .sdp-md-x{
    width:100% !important;max-width:100% !important;
    border-radius:var(--r-lg) var(--r-lg) 0 0 !important;
    margin-top:auto !important;
    max-height:92vh !important;
  }
  /* Boutons : touch target 40px minimum */
  button:not(.sdp-bt-x):not([role=tab]):not(.no-touch-fix){min-height:40px;font-size:13px}
  /* Sidebar du Dashboard : pas de width fixée */
  .gf4 > div:last-child{width:100% !important}
  /* Labels et petits textes plus lisibles */
  label{font-size:12px}
  small,.small{font-size:12px}
  p{font-size:14px}
  /* Select/input : éviter le zoom iOS + meilleurs touch targets */
  select{min-height:40px}
  /* Planning tables : meilleur scroll horizontal */
  .plan-table-wrap table{min-width:600px}
  /* Admin grids with fixed widths → fluid */
  [style*="minWidth:800"],[style*="min-width:800"]{min-width:0 !important;width:100% !important}
  [style*="minWidth:700"],[style*="min-width:700"]{min-width:0 !important;width:100% !important}
  [style*="minWidth:600"],[style*="min-width:600"]{min-width:0 !important;width:100% !important}
}

/* ── Très petit mobile : ≤ 380px ── */
@media (max-width: 380px) {
  .g4{grid-template-columns:1fr !important}
  /* Réduction du padding des cards */
  .sdp-card,[class*="cd-"]{padding:var(--sp-3) !important}
}

/* ── Préfèrent réduire les animations (a11y) ── */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
}

/* ── Dark scrollbar pour zones sombres (sidebar) ── */
.sb ::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12)}
.sb ::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.22)}

/* ═══════════════════════════════════════════════════════════
   Fin amélioration responsive
   ═══════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════
   ✨ BOOT — Écran de chargement initial animé
   ═══════════════════════════════════════════════════════════ */
.sdp-boot{
  position:relative;
  min-height:100vh;min-height:100dvh;
  display:flex;align-items:center;justify-content:center;
  background:#070b14;
  font-family:var(--ff-base);
  overflow:hidden;
  color:#fff;
}
.sdp-boot-aurora{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.sdp-boot-orb{
  position:absolute;border-radius:50%;
  filter:blur(90px);
  animation:sdp-boot-float 8s ease-in-out infinite;
}
.sdp-boot-orb--1{
  width:420px;height:420px;
  background:radial-gradient(circle, #22c55e 0%, transparent 70%);
  opacity:.45;
  top:-100px;left:-80px;
}
.sdp-boot-orb--2{
  width:360px;height:360px;
  background:radial-gradient(circle, #14b8a6 0%, transparent 70%);
  opacity:.4;
  bottom:-80px;right:-80px;
  animation-delay:-4s;
}
@keyframes sdp-boot-float{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(30px,-20px) scale(1.05)}
}
.sdp-boot-stack{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:18px;
  animation:sdp-boot-in .5s cubic-bezier(.16,1,.3,1) both;
}
@keyframes sdp-boot-in{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}
.sdp-boot-logo-ring{
  position:relative;
  width:84px;height:84px;
  display:flex;align-items:center;justify-content:center;
  border-radius:22px;
}
.sdp-boot-logo-ring::before{
  content:'';position:absolute;inset:-6px;
  border-radius:26px;
  background:conic-gradient(from 0deg, transparent 0%, #22c55e 30%, #14b8a6 60%, transparent 100%);
  animation:sdp-spin 2s linear infinite;
  z-index:-1;
}
.sdp-boot-logo-ring::after{
  content:'';position:absolute;inset:0;
  border-radius:22px;
  background:#070b14;
  z-index:-1;
}
.sdp-boot-logo{
  width:64px;height:64px;border-radius:16px;
  object-fit:cover;
  box-shadow:0 10px 30px -8px rgba(34,197,94,.5);
  animation:sdp-boot-logo-pulse 2.4s ease-in-out infinite;
}
@keyframes sdp-boot-logo-pulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.04)}
}
.sdp-boot-brand{
  font-size:18px;font-weight:800;
  letter-spacing:-.4px;
  color:#f1f5f9;
  background:linear-gradient(180deg,#fff 0%,#94a3b8 110%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.sdp-boot-dots{display:flex;gap:6px;margin-top:4px}
.sdp-boot-dots span{
  width:7px;height:7px;border-radius:50%;
  background:#22c55e;
  animation:sdp-boot-dot 1.2s ease-in-out infinite;
}
.sdp-boot-dots span:nth-child(2){animation-delay:.15s;background:#14b8a6}
.sdp-boot-dots span:nth-child(3){animation-delay:.3s;background:#0ea5e9}
@keyframes sdp-boot-dot{
  0%,80%,100%{transform:scale(.6);opacity:.5}
  40%{transform:scale(1);opacity:1}
}

/* ═══════════════════════════════════════════════════════════
   ✨ LOGIN — Design 2026 : split layout, glassmorphism, aurora
   Hero brand à gauche (desktop) + formulaire à droite, fond
   sombre avec orbes animées et grille subtile, micro-animations.
   ═══════════════════════════════════════════════════════════ */

/* ── Stage plein écran ── */
.login-stage{
  position:relative;
  min-height:100vh;min-height:100dvh;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  background:#070b14;
  font-family:var(--ff-base);
  overflow:hidden;
}

/* ── Aurora animée (orbes + grille) ── */
.login-aurora{
  position:absolute;inset:0;
  pointer-events:none;
  z-index:0;
  overflow:hidden;
}
.login-orb{
  position:absolute;
  border-radius:50%;
  filter:blur(90px);
  will-change:transform;
  animation:login-orb-float 22s ease-in-out infinite;
}
.login-orb--1{
  width:520px;height:520px;
  background:radial-gradient(circle, #22c55e 0%, transparent 70%);
  opacity:.55;
  top:-160px;left:-120px;
}
.login-orb--2{
  width:460px;height:460px;
  background:radial-gradient(circle, #14b8a6 0%, transparent 70%);
  opacity:.45;
  bottom:-180px;right:-120px;
  animation-delay:-7s;
}
.login-orb--3{
  width:340px;height:340px;
  background:radial-gradient(circle, #0ea5e9 0%, transparent 70%);
  opacity:.25;
  top:50%;left:45%;
  animation-delay:-14s;
}
@keyframes login-orb-float{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(40px,-30px) scale(1.06)}
  66%{transform:translate(-30px,40px) scale(.94)}
}
.login-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:40px 40px;
  -webkit-mask-image:radial-gradient(ellipse at center, #000 35%, transparent 75%);
  mask-image:radial-gradient(ellipse at center, #000 35%, transparent 75%);
}

/* ── Shell : carte glassmorphism contenant les 2 panneaux ── */
.login-shell{
  position:relative;z-index:1;
  width:100%;max-width:1040px;
  display:grid;
  grid-template-columns:1.05fr 440px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  overflow:hidden;
  backdrop-filter:blur(20px) saturate(140%);
  -webkit-backdrop-filter:blur(20px) saturate(140%);
  box-shadow:
    0 40px 100px -20px rgba(0,0,0,.7),
    0 0 0 1px rgba(255,255,255,.04) inset;
  animation:login-card-enter .55s cubic-bezier(.16,1,.3,1) both;
}
@keyframes login-card-enter{
  from{opacity:0;transform:translateY(20px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

/* ── Hero (gauche, desktop) ── */
.login-hero{
  position:relative;
  padding:36px 40px 30px;
  display:flex;flex-direction:column;
  color:#fff;
  background:
    radial-gradient(circle at 85% 15%, rgba(34,197,94,.22) 0%, transparent 55%),
    radial-gradient(circle at 15% 90%, rgba(20,184,166,.18) 0%, transparent 55%),
    linear-gradient(135deg, #0f1d17 0%, #0a1119 100%);
  border-right:1px solid rgba(255,255,255,.05);
  overflow:hidden;
}
.login-hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:36px 36px;
  -webkit-mask-image:radial-gradient(ellipse at 30% 30%, #000 30%, transparent 75%);
  mask-image:radial-gradient(ellipse at 30% 30%, #000 30%, transparent 75%);
}

.login-hero-brand{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:11px;
  margin-bottom:auto;
}
.login-hero-logo{
  width:38px;height:38px;border-radius:10px;object-fit:cover;
  box-shadow:0 6px 20px -4px rgba(34,197,94,.55), 0 0 0 1px rgba(255,255,255,.08);
}
.login-hero-name{
  font-size:15px;font-weight:700;letter-spacing:-.2px;
  color:#f8fafc;
}

.login-hero-body{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;justify-content:center;padding:24px 0}
.login-hero-title{
  font-size:38px;font-weight:800;letter-spacing:-1.4px;line-height:1.05;
  margin:0 0 16px;
  background:linear-gradient(180deg,#fff 0%,#cbd5e1 110%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  color:#fff; /* fallback */
}
.login-hero-lede{
  font-size:15px;line-height:1.55;
  color:#94a3b8;
  margin:0;max-width:34ch;
}

.login-hero-foot{
  position:relative;z-index:1;
  display:flex;align-items:center;gap:8px;
  font-size:12px;color:rgba(148,163,184,.8);
  letter-spacing:.2px;
  font-weight:500;
}
.login-hero-dot{
  width:8px;height:8px;border-radius:50%;
  background:#22c55e;
  box-shadow:0 0 0 0 rgba(34,197,94,.6);
  animation:login-pulse 2.4s ease-in-out infinite;
}
@keyframes login-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.55)}
  50%{box-shadow:0 0 0 7px rgba(34,197,94,0)}
}

/* ── Panneau formulaire (droite) ── */
.login-panel{
  padding:48px 44px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.login-card{
  width:100%;
  max-width:360px;
  padding:0;
  background:transparent;
  box-shadow:none;
  border-radius:0;
}
.login-card-brand-mobile{display:none}

.login-head{margin-bottom:22px}
.login-card-title{
  font-size:24px;font-weight:800;letter-spacing:-.6px;line-height:1.15;
  color:var(--c-n-900);margin:0 0 7px;
}
.login-subtitle{
  font-size:13.5px;font-weight:500;
  color:var(--c-n-500);
  line-height:1.5;
  margin:0;
}

/* ── Alertes ── */
.login-alert{
  padding:11px 14px;border-radius:11px;
  font-size:12.5px;line-height:1.4;
  margin-bottom:14px;
  display:flex;align-items:center;gap:9px;
}
.login-alert--ok{background:#f0fdf4;border:1px solid #bbf7d0;color:var(--c-brand-800)}
.login-alert--err{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}

/* ── Formulaire ── */
.login-form{display:flex;flex-direction:column;gap:14px}

.login-field{display:flex;flex-direction:column;gap:6px}
.login-label{
  font-size:12px;font-weight:600;
  color:var(--c-n-700);
  letter-spacing:0;
  padding-left:2px;
}

/* ── Inputs avec icône ── */
.login-input-wrap{position:relative;display:flex;align-items:center}
.login-input-icon{
  position:absolute;left:12px;
  width:20px;height:20px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:14px;line-height:1;
  color:var(--c-n-400);
  pointer-events:none;
  transition:opacity .15s, transform .15s;
  z-index:1;
  opacity:.7;
}
.login-input-wrap:focus-within .login-input-icon{opacity:1;transform:scale(1.08)}

.sdp-login-input{
  display:block;width:100%;
  height:46px;padding:0 14px;
  background:#f8fafc;
  border:1px solid var(--c-n-200);
  border-radius:12px;
  font-size:14px;font-weight:500;
  color:var(--c-n-900);
  font-family:inherit;
  outline:none;
  transition:background .15s, border-color .15s, box-shadow .15s;
  -webkit-appearance:none;appearance:none;
}
.sdp-login-input--icon{padding-left:40px}
.sdp-login-input--toggle{padding-right:44px}
.sdp-login-input:hover:not(:focus){
  background:#fff;border-color:var(--c-n-300);
}
.sdp-login-input:focus{
  background:#fff !important;
  border-color:var(--c-brand-500) !important;
  box-shadow:0 0 0 4px rgba(34,197,94,.13) !important;
}
.sdp-login-input::placeholder{
  color:var(--c-n-400);font-weight:400;
}
.sdp-login-input:-webkit-autofill,
.sdp-login-input:-webkit-autofill:hover,
.sdp-login-input:-webkit-autofill:focus{
  -webkit-box-shadow:0 0 0 100px #f8fafc inset !important;
  -webkit-text-fill-color:var(--c-n-900) !important;
  caret-color:var(--c-n-900);
  border-radius:12px;
}

/* Toggle œil mot de passe */
.login-input-toggle{
  position:absolute;right:6px;
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  background:transparent;border:none;cursor:pointer;
  color:var(--c-n-400);
  border-radius:8px;
  font-family:inherit;
  transition:color .15s, background .15s;
}
.login-input-toggle:hover{color:var(--c-n-700);background:var(--c-n-100)}
.login-input-toggle:focus-visible{outline:2px solid var(--c-brand-500);outline-offset:1px}

/* Row remember + forgot */
.login-row{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;margin-top:-2px;
}
.login-remember{
  display:inline-flex;align-items:center;
  gap:8px;
  font-size:12.5px;font-weight:500;
  color:var(--c-n-600);
  cursor:pointer;user-select:none;
}
.login-remember input[type=checkbox]{
  width:16px;height:16px;cursor:pointer;
  accent-color:var(--c-brand-600);margin:0;
  border-radius:4px;
}
.login-link--inline{padding:0;margin:0;font-size:12.5px}

/* ── CTA principal avec effet shine ── */
.login-cta{
  position:relative;overflow:hidden;
  width:100%;height:48px;
  margin-top:6px;
  border:none;
  border-radius:12px;
  background:linear-gradient(135deg, #16a34a 0%, #15803d 100%);
  color:#fff;
  font-family:inherit;
  font-size:14px;font-weight:700;
  letter-spacing:.2px;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:transform .15s, box-shadow .2s, filter .15s;
  box-shadow:0 8px 24px -6px rgba(22,163,74,.55), 0 0 0 1px rgba(22,163,74,.2);
}
.login-cta::before{
  content:'';position:absolute;top:0;left:-150%;
  width:60%;height:100%;
  background:linear-gradient(90deg, transparent 0%, rgba(255,255,255,.28) 50%, transparent 100%);
  transform:skewX(-20deg);
  transition:left .7s ease;
}
.login-cta:hover:not(:disabled)::before{left:150%}
.login-cta:hover:not(:disabled){
  transform:translateY(-1px);
  box-shadow:0 12px 28px -6px rgba(22,163,74,.65), 0 0 0 1px rgba(22,163,74,.3);
  filter:brightness(1.04);
}
.login-cta:active:not(:disabled){transform:translateY(0);filter:brightness(.96)}
.login-cta:disabled{
  background:var(--c-n-200);
  color:var(--c-n-400);
  cursor:not-allowed;
  box-shadow:none;
}
.login-cta-arrow{
  display:inline-block;font-size:16px;line-height:1;
  transition:transform .2s ease;
}
.login-cta:hover:not(:disabled) .login-cta-arrow{transform:translateX(3px)}

.login-spinner{
  position:relative;
  display:inline-block;width:16px;height:16px;
  border-radius:50%;
  background:conic-gradient(from 0deg, transparent 0%, rgba(255,255,255,.95) 80%, #fff 100%);
  -webkit-mask:radial-gradient(farthest-side, transparent 56%, #000 58%);
          mask:radial-gradient(farthest-side, transparent 56%, #000 58%);
  animation:sdp-spin .8s linear infinite;
}
.login-spinner--dark{
  background:conic-gradient(from 0deg, transparent 0%, rgba(15,23,42,.7) 80%, var(--c-n-800) 100%);
}

/* CTA biométrique : variante secondaire */
.login-cta--bio{
  background:#fff;
  color:var(--c-n-800);
  border:1px solid var(--c-n-200);
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.login-cta--bio::before{display:none}
.login-cta--bio:hover:not(:disabled){
  background:#fafbfc;
  border-color:var(--c-n-300);
  box-shadow:0 6px 16px -4px rgba(15,23,42,.08);
  transform:translateY(-1px);
  filter:none;
}
.login-cta--bio:disabled{background:var(--c-n-100);border-color:var(--c-n-200);color:var(--c-n-400)}

/* Divider "ou" */
.login-divider{
  display:flex;align-items:center;gap:12px;
  margin:6px 0 -2px;
  font-size:11px;
  color:var(--c-n-400);
  text-transform:uppercase;
  letter-spacing:1.4px;
  font-weight:600;
}
.login-divider::before,
.login-divider::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg, transparent, var(--c-n-200), transparent);
}

/* Liens */
.login-link{
  background:none;border:none;
  color:var(--c-brand-700);
  cursor:pointer;
  font-family:inherit;font-size:12.5px;font-weight:600;
  padding:6px 0;
  text-align:center;
  margin-top:2px;
  letter-spacing:0;
  transition:color .12s;
}
.login-link:hover{color:var(--c-brand-800);text-decoration:underline}
.login-link--ghost{color:var(--c-n-500)}
.login-link--ghost:hover{color:var(--c-n-700)}

/* ── Brand condensée mobile ── */
.login-brand-mobile-name{
  font-size:16px;font-weight:800;color:var(--c-n-900);letter-spacing:-.3px;
}

/* Staggered entry pour les champs du formulaire */
.login-form > *{
  opacity:0;
  animation:login-field-in .45s cubic-bezier(.16,1,.3,1) forwards;
}
.login-form > *:nth-child(1){animation-delay:.08s}
.login-form > *:nth-child(2){animation-delay:.14s}
.login-form > *:nth-child(3){animation-delay:.2s}
.login-form > *:nth-child(4){animation-delay:.26s}
.login-form > *:nth-child(5){animation-delay:.32s}
.login-form > *:nth-child(6){animation-delay:.38s}
.login-form > *:nth-child(7){animation-delay:.44s}
@keyframes login-field-in{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
@media (prefers-reduced-motion:reduce){
  .login-form > *{opacity:1;animation:none}
  .login-orb,.sdp-boot-orb,.sdp-boot-logo,.login-hero-dot{animation:none !important}
}

/* ═══ Responsive : tablette (portrait) ═══ */
@media (max-width:1100px) and (min-width:861px){
  .login-shell{
    max-width:920px;
    grid-template-columns:1fr 400px;
  }
  .login-hero{padding:32px 32px 26px}
  .login-hero-title{font-size:28px}
  .login-panel{padding:40px 36px}
}

/* ═══ Responsive : tablette portrait + mobile ═══ */
@media (max-width:860px){
  .login-stage{
    padding:max(24px, env(safe-area-inset-top, 24px)) 18px max(24px, env(safe-area-inset-bottom, 24px));
    align-items:center;justify-content:center;
  }
  .login-shell{
    grid-template-columns:1fr;
    max-width:460px;
    min-height:0;
    border-radius:24px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.04);
    backdrop-filter:blur(20px) saturate(140%);
    -webkit-backdrop-filter:blur(20px) saturate(140%);
    box-shadow:0 30px 80px -20px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.04) inset;
  }
  .login-hero{display:none}
  .login-panel{
    padding:0;
    background:#fff;
    border-radius:24px;
    overflow:hidden;
  }
  .login-card{
    max-width:none;
    padding:30px 26px 28px;
    position:relative;
  }
  /* Bande gradient en haut de la carte mobile */
  .login-card::before{
    content:'';position:absolute;left:0;right:0;top:0;height:3px;
    background:linear-gradient(90deg, transparent 0%, #22c55e 30%, #14b8a6 70%, transparent 100%);
  }
  .login-card-brand-mobile{
    display:flex;flex-direction:column;align-items:center;gap:10px;
    margin-bottom:22px;
    animation:login-brand-in .55s cubic-bezier(.16,1,.3,1) both;
  }
  .login-card-brand-mobile .login-logo{
    width:62px;height:62px;border-radius:17px;object-fit:cover;
    box-shadow:0 14px 30px -6px rgba(22,163,74,.5), 0 0 0 1px rgba(22,163,74,.15);
    animation:login-logo-float 3.2s ease-in-out infinite;
  }
  .login-brand-mobile-name{font-size:17px;letter-spacing:-.4px}
  /* Force le padding correct pour les inputs login en surclassant la règle globale */
  .sdp-login-input{height:50px!important;padding:0 14px!important;font-size:16px!important;border-radius:13px!important;min-height:50px!important}
  .sdp-login-input--icon{padding-left:42px!important}
  .sdp-login-input--toggle{padding-right:46px!important}
  .login-input-icon{left:13px;width:22px;height:22px;font-size:15px}
  .login-input-toggle{width:36px;height:36px;right:7px;font-size:16px}
  .login-cta{height:52px;font-size:14.5px;border-radius:13px}
}
@keyframes login-logo-float{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-4px) rotate(-1.5deg)}
}
@keyframes login-brand-in{
  from{opacity:0;transform:translateY(-8px) scale(.95)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

.sdp-iconified{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:1.08em;
  height:1.08em;
  margin:0 .12em;
  vertical-align:-.17em;
  color:currentColor;
  line-height:1;
  flex-shrink:0;
}
.sdp-iconified:first-child{margin-left:0}
.sdp-iconified:last-child{margin-right:0}
.sdp-iconified svg,
.sdp-lucide-icon{
  width:1em;
  height:1em;
  stroke:currentColor;
  stroke-width:2.15;
}
.sb-nav-icon .sdp-iconified,
.login-input-icon .sdp-iconified,
.login-input-toggle .sdp-iconified,
.mob-topbar-btn .sdp-iconified{
  margin:0;
}
.sdp-view-shell{
  animation:sdp-view-enter .24s cubic-bezier(.2,.85,.2,1) both;
  will-change:opacity, transform, filter;
}
@keyframes sdp-view-enter{
  from{opacity:0;transform:translateY(8px) scale(.996);filter:blur(3px)}
  to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}
.sb button{
  transition:background .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.sb button:not(:disabled):hover{
  transform:translateX(2px);
}
@media (prefers-reduced-motion: reduce){
  .sdp-view-shell,
  .login-card-brand-mobile,
  .login-card-brand-mobile .login-logo{
    animation:none!important;
  }
  .sb button{transition:none!important}
}

/* ═══ Responsive : tablette paysage / petit écran ═══ */
@media (max-height:720px) and (min-width:861px){
  .login-stage{padding:16px}
  .login-hero{padding:28px 36px 22px}
  .login-hero-body{padding:18px 0 14px}
  .login-hero-title{font-size:26px;margin-bottom:10px}
  .login-hero-lede{margin-bottom:0}
  .login-panel{padding:32px 36px}
  .login-head{margin-bottom:18px}
}

/* ═══ Mobile compact ═══ */
@media (max-width:520px){
  .login-stage{padding:max(20px, env(safe-area-inset-top, 20px)) 14px max(20px, env(safe-area-inset-bottom, 20px))}
  .login-card{padding:28px 22px 26px}
  .login-card-title{font-size:23px}
  .login-subtitle{font-size:13px}
  .login-row{flex-wrap:wrap;gap:10px}
  .login-card-brand-mobile{margin-bottom:20px}
  .login-card-brand-mobile .login-logo{width:58px;height:58px}
}

/* ═══ Très petit (paysage téléphone) ═══ */
@media (max-height:560px) and (max-width:860px){
  .login-stage{padding:14px;align-items:flex-start}
  .login-shell{max-width:520px;width:100%}
  .login-card{padding:22px 22px 20px}
  .login-card-brand-mobile{margin-bottom:14px;flex-direction:row;gap:10px;justify-content:flex-start}
  .login-card-brand-mobile .login-logo{width:42px;height:42px;border-radius:12px;animation:none}
  .login-head{margin-bottom:12px}
  .login-card-title{font-size:18px;margin-bottom:3px}
  .login-subtitle{font-size:12px}
  .login-form{gap:10px}
  .sdp-login-input{height:42px!important;min-height:42px!important}
  .login-cta{height:44px}
}

/* Login premium refresh */
.login-shell{
  grid-template-columns:1.08fr 440px;
  border-color:rgba(255,255,255,.72);
}
.login-hero{padding:36px 38px 30px}
.login-hero-brand{gap:16px}
.login-hero-logo-wrap{
  position:relative;
  width:56px;height:56px;
  display:grid;place-items:center;
  border-radius:18px;
  flex-shrink:0;
}
.login-hero-logo-wrap::before,
.login-hero-logo-wrap::after{
  content:"";
  position:absolute;inset:-8px;
  border-radius:24px;
  background:radial-gradient(circle, rgba(34,197,94,.48), rgba(34,197,94,0) 64%);
  animation:login-logo-aura 3.1s ease-in-out infinite;
}
.login-hero-logo-wrap::after{
  inset:-14px;
  background:radial-gradient(circle, rgba(20,184,166,.28), rgba(20,184,166,0) 70%);
  animation-delay:.45s;
}
.login-hero-logo{
  position:relative;z-index:1;
  width:56px;height:56px;border-radius:15px;
  box-shadow:0 14px 34px -8px rgba(34,197,94,.75),0 0 0 1px rgba(255,255,255,.18);
  animation:login-logo-float 3.4s ease-in-out infinite;
}
.login-hero-name{font-size:28px;font-weight:700;letter-spacing:-.8px}
.login-hero-foot--checking .login-hero-dot{background:#f59e0b;box-shadow:0 0 0 0 rgba(245,158,11,.5)}
.login-hero-foot--ok .login-hero-dot{background:#22c55e;box-shadow:0 0 0 0 rgba(34,197,94,.6)}
.login-hero-foot--bad .login-hero-dot{background:#ef4444;box-shadow:0 0 0 0 rgba(239,68,68,.55)}
.login-hero-foot--ok{color:rgba(203,213,225,.88)}
.login-hero-foot--bad{color:#fecaca}
.login-card-title--icon{
  display:flex;align-items:center;gap:10px;
  color:#047857;
  font-weight:700;
  letter-spacing:-.35px;
}
.login-title-icon{
  width:25px;height:25px;
  display:inline-flex;align-items:center;justify-content:center;
  color:#047857;
}
.login-title-icon .sdp-iconified{width:1.12em;height:1.12em;margin:0}
.login-title-icon svg{stroke-width:2.25}
.login-input-icon{
  width:22px;height:22px;
  color:#6d28d9;
}
.login-input-icon .sdp-iconified,
.login-input-toggle .sdp-iconified{
  width:1.05em;height:1.05em;margin:0;
}
.login-input-icon--lock{color:#f59e0b}
.login-input-icon--mail{color:#0ea5e9}
.sdp-login-input{
  height:48px;
  background:#fff;
  border-radius:9px;
  font-size:15px;
  box-shadow:0 2px 5px rgba(15,23,42,.08);
  transition:background .15s,border-color .15s,box-shadow .15s,transform .15s;
}
.sdp-login-input:hover:not(:focus){
  box-shadow:0 3px 9px rgba(15,23,42,.1);
}
.sdp-login-input:focus{
  box-shadow:0 0 0 3px rgba(34,197,94,.12),0 6px 18px rgba(15,23,42,.12)!important;
}
.login-input-toggle{color:#94a3b8}
.login-remember input[type=checkbox]{
  width:18px;height:18px;border-radius:5px;
}
.login-cta{border-radius:8px}
.login-link{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
}
@keyframes login-logo-aura{
  0%,100%{opacity:.58;transform:scale(.92)}
  50%{opacity:1;transform:scale(1.08)}
}
@media (max-width:860px){
  .login-hero-logo-wrap{width:62px;height:62px}
}
@media (prefers-reduced-motion:reduce){
  .login-hero-logo,
  .login-hero-logo-wrap::before,
  .login-hero-logo-wrap::after{animation:none!important}
}

/* Connected app shell */
.sdp-connected-header{
  margin:16px 18px 18px;
  min-height:102px;
  padding:22px;
  border-radius:24px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(226,232,240,.9);
  box-shadow:0 18px 45px rgba(15,23,42,.08);
  display:flex;
  align-items:center;
  gap:16px;
}
.sdp-connected-title-icon{
  width:56px;height:56px;
  border-radius:17px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  background:linear-gradient(135deg,#16a34a,#06b6d4);
  box-shadow:0 18px 32px -12px rgba(22,163,74,.55);
  flex-shrink:0;
}
.sdp-connected-title-icon .sdp-iconified{margin:0;width:1.35em;height:1.35em}
.sdp-connected-title-icon svg{stroke-width:2.1}
.sdp-connected-header h1{
  margin:0 0 5px;
  color:#020617;
  font-size:30px;
  line-height:1.05;
  font-weight:800;
  letter-spacing:-.7px;
}
.sdp-connected-header p{
  margin:0;
  color:#64748b;
  font-size:14px;
  font-weight:500;
}
.sdp-head-btn{
  width:50px;height:50px;
  border-radius:16px;
  border:1px solid #e2e8f0;
  background:#fff;
  color:#0f172a;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(15,23,42,.08);
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.sdp-head-btn:hover{
  transform:translateY(-1px);
  border-color:#bbf7d0;
  box-shadow:0 12px 24px rgba(15,23,42,.11);
}
.sdp-head-btn .sdp-iconified{margin:0;width:1.1em;height:1.1em}
.sdp-head-user{
  position:relative;
  min-width:220px;
  padding:10px 14px;
  border-radius:16px;
  border:1px solid #e2e8f0;
  background:#fff;
  display:flex;
  align-items:center;
  gap:12px;
  box-shadow:0 8px 18px rgba(15,23,42,.08);
  cursor:pointer;
  font-family:inherit;
  text-align:left;
}
.sdp-head-user.open{border-color:#bbf7d0}
.sdp-head-chevron{margin-left:auto;color:#94a3b8;display:flex}
.sdp-head-user .sdp-head-chevron{
  background:transparent;
  padding:0;
  margin-top:0;
  border-radius:0;
  color:#94a3b8;
  flex-shrink:0;
}
.sdp-head-user .sdp-head-chevron .sdp-iconified{width:1em;height:1em;margin:0}
.sdp-head-avatar{
  width:42px;height:42px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#065f46;
  background:linear-gradient(135deg,#bbf7d0,#86efac);
  font-size:12px;
  font-weight:900;
  flex-shrink:0;
}
.sdp-head-user strong{
  display:block;
  max-width:145px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#020617;
  font-size:13px;
}
.sdp-head-user span{
  display:inline-flex;
  margin-top:3px;
  color:#047857;
  background:#dcfce7;
  border-radius:6px;
  padding:2px 7px;
  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
}
.sdp-profile-wrap{position:relative}
.sdp-profile-menu{position:absolute;right:0;top:calc(100% + 10px);width:260px;padding:12px;border-radius:16px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 24px 60px rgba(15,23,42,.18);z-index:10020;animation:sdp-menu-in .16s ease both}
.sdp-profile-menu-head{display:flex;align-items:center;gap:12px;padding:4px 4px 12px;border-bottom:1px solid #f1f5f9;margin-bottom:8px}
.sdp-profile-menu-head strong{display:block;font-size:13px;color:#0f172a}
.sdp-profile-menu-head span{display:block;font-size:12px;color:#64748b;margin-top:2px}
.sdp-profile-menu button{width:100%;display:flex;align-items:center;gap:11px;padding:11px 10px;border:none;background:transparent;border-radius:10px;color:#475569;font-size:13px;font-weight:750;font-family:inherit;cursor:pointer;text-align:left}
.sdp-profile-menu button:hover{background:#f1f5f9;color:#0f172a}
.sdp-profile-menu button.danger{color:#ef4444}
.sdp-profile-menu button.danger:hover{background:#fef2f2}
@keyframes sdp-menu-in{from{opacity:0;transform:translateY(-5px) scale(.98)}to{opacity:1;transform:none}}
.sdp-sidebar-clock{position:relative;margin:4px 18px 16px;display:flex;align-items:center;gap:14px;color:#fff}
.sdp-sidebar-clock::after{content:"";position:absolute;left:96px;bottom:-12px;width:70px;height:6px;border-radius:10px;background:linear-gradient(90deg,#bbf7d0,#22c55e,#14b8a6);box-shadow:0 0 18px rgba(34,197,94,.65);animation:sdp-clock-glow 2.8s ease-in-out infinite}
.sdp-sidebar-clock-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#dcfce7;border:1px solid rgba(187,247,208,.52);background:radial-gradient(circle at 35% 25%,rgba(255,255,255,.12),rgba(255,255,255,.04));box-shadow:0 0 0 7px rgba(34,197,94,.08),0 0 24px rgba(34,197,94,.26)}
.sdp-sidebar-clock strong{display:block;font-size:25px;line-height:1;letter-spacing:-.5px}
.sdp-sidebar-clock span{display:block;margin-top:7px;font-size:11px;color:#d1d5db;font-weight:750;text-transform:capitalize}
@keyframes sdp-clock-glow{0%,100%{opacity:.7;transform:scaleX(.82)}50%{opacity:1;transform:scaleX(1)}}
.sdp-sidebar-collapse{width:100%;margin:0 0 8px;min-height:40px;display:flex;align-items:center;justify-content:center;gap:9px;border-radius:14px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.08);color:#d1fae5;font-size:12px;font-weight:800;font-family:inherit;cursor:pointer}
.sdp-sidebar-collapse:hover{background:rgba(255,255,255,.14)}
.sdp-sidebar-item.is-collapsed::after{content:attr(data-tip);position:absolute;left:calc(100% + 14px);top:50%;transform:translateY(-50%) translateX(-4px);opacity:0;pointer-events:none;background:#3b070d;color:#fff;padding:10px 13px;border-radius:10px;font-size:12px;font-weight:800;white-space:nowrap;box-shadow:0 14px 35px rgba(15,23,42,.22);transition:opacity .14s ease,transform .14s ease;z-index:10050}
.sdp-sidebar-item.is-collapsed::before{content:"";position:absolute;left:calc(100% + 7px);top:50%;transform:translateY(-50%);border:7px solid transparent;border-right-color:#3b070d;opacity:0;transition:opacity .14s ease}
.sdp-sidebar-item.is-collapsed:hover::after{opacity:1;transform:translateY(-50%) translateX(0)}
.sdp-sidebar-item.is-collapsed:hover::before{opacity:1}
[data-sdp-theme="dark"] body{background:#07110d}
[data-sdp-theme="dark"] .mc{background:#07110d!important}
[data-sdp-theme="dark"] .sdp-connected-header,[data-sdp-theme="dark"] .sdp-head-btn,[data-sdp-theme="dark"] .sdp-head-user,[data-sdp-theme="dark"] .sdp-profile-menu{background:#0f1f18;border-color:rgba(134,239,172,.18);color:#e2e8f0}
[data-sdp-theme="dark"] .sdp-connected-header h1,[data-sdp-theme="dark"] .sdp-head-user strong,[data-sdp-theme="dark"] .sdp-profile-menu-head strong{color:#f8fafc}
[data-sdp-theme="dark"] .sdp-connected-header p,[data-sdp-theme="dark"] .sdp-profile-menu-head span{color:#94a3b8}
[data-sdp-theme="dark"] .sdp-profile-menu button{color:#cbd5e1}
[data-sdp-theme="dark"] .sdp-profile-menu button:hover{background:rgba(255,255,255,.08);color:#fff}
.sb>div:last-child>div:first-child{display:none!important}
.sb>div:last-child>button:last-child{display:none!important}
.sb>div:last-child>div:nth-of-type(2) button{font-size:0!important}
.sb>div:last-child>div:nth-of-type(2) button:first-child::after{content:"Vue admin";font-size:10px}
.sb>div:last-child>div:nth-of-type(2) button:nth-child(2)::after{content:"Vue utilisateur";font-size:10px}
.sb>div:nth-child(3)>div>div:nth-child(2){
  font-size:0!important;
}
.sb>div:nth-child(3)>div>div:nth-child(2)::after{
  content:"ADMINISTRATEUR";
  font-size:9px;
}
[data-sdp-theme="dark"] .mc div[style*="background:#fff"],
[data-sdp-theme="dark"] .mc div[style*="background: rgb(255, 255, 255)"]{
  background:#0f1f18!important;
  border-color:rgba(134,239,172,.16)!important;
}
.sb-nav-icon .sdp-iconified{width:1.1em;height:1.1em}
@media (min-width:861px){
  .mc>div.sdp-connected-header{max-width:none!important}
}
@media (max-width:860px){
  .sdp-connected-header{
    margin:10px 10px 12px;
    min-height:0;
    padding:14px;
    border-radius:18px;
    gap:10px;
    flex-wrap:wrap;
  }
  .sdp-connected-title-icon{width:44px;height:44px;border-radius:14px}
  .sdp-connected-header h1{font-size:21px}
  .sdp-connected-header p{font-size:12px}
  .sdp-head-btn{width:40px;height:40px;border-radius:12px}
  .sdp-head-user{min-width:0;flex:1;padding:8px 10px}
  .sdp-head-user strong{max-width:120px}
}
