/* ══════════════════════════════════════════════════════════
   École 241 Kids — Design System partagé
   Basé sur parent.html · v1.0
   Chaque page peut surcharger :root pour adapter l'accent
   ══════════════════════════════════════════════════════════ */

/* ── IMPORT FONT ── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ── TOKENS ── */
:root{
  --green:#059669;--green-l:#10B981;--green-pale:#ECFDF5;
  --orange:#D97706;--blue:#2563EB;--red:#DC2626;--red-pale:#FEF2F2;
  --dark:#111827;--mid:#374151;--muted:#6B7280;
  --border:#E5E7EB;--border-strong:#D1D5DB;--bg:#F9FAFB;--white:#FFFFFF;
  --sidebar-bg:#111827;--sidebar-w:240px;
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--dark);min-height:100vh;font-size:14px;-webkit-font-smoothing:antialiased}

/* ── LOGIN ── */
#screen-login{display:none;align-items:center;justify-content:center;min-height:100vh;background:#111827;padding:1rem}
.login-card{background:var(--white);border-radius:12px;border:1px solid var(--border);padding:2.5rem 2rem;width:100%;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.login-logo{text-align:center;margin-bottom:2rem}
.login-logo .brand{font-size:1.4rem;font-weight:800;color:var(--dark);letter-spacing:-.03em}
.login-logo .brand span{color:var(--green)}
.login-logo .sub{font-size:.75rem;color:var(--muted);margin-top:.3rem;text-transform:uppercase;letter-spacing:.06em}
.login-tabs{display:flex;margin-bottom:1.5rem;background:var(--bg);border-radius:8px;padding:3px;gap:2px}
.login-tab-btn{flex:1;padding:.45rem .3rem;background:none;border:none;font-family:inherit;font-size:.78rem;font-weight:600;color:var(--muted);border-radius:6px;cursor:pointer;transition:all .15s}
.login-tab-btn.active{background:var(--white);color:var(--dark);box-shadow:0 1px 3px rgba(0,0,0,.1)}
.fg{margin-bottom:.9rem}
.fg label{display:block;font-size:.72rem;font-weight:600;color:var(--mid);margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.05em}
.fg input,.fg select,.fg textarea{width:100%;background:var(--white);border:1.5px solid var(--border);border-radius:6px;padding:.6rem .8rem;font-family:inherit;font-size:.875rem;color:var(--dark);outline:none;transition:border-color .15s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(5,150,105,.08)}
.fg textarea{resize:vertical;min-height:80px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.login-error,.login-err{background:var(--red-pale);color:var(--red);border:1px solid #FECACA;border-radius:6px;padding:.5rem .75rem;font-size:.8rem;margin-bottom:.9rem;display:none}
.login-info{background:var(--green-pale);color:var(--green);border:1px solid #A7F3D0;border-radius:6px;padding:.5rem .75rem;font-size:.8rem;margin-bottom:.9rem;display:none}
.login-title{font-size:1rem;font-weight:700;color:var(--dark);margin-bottom:1.2rem;text-align:center}
.step-indicator{display:flex;align-items:center;justify-content:center;gap:.4rem;margin-bottom:1.2rem}
.step-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;border:1.5px solid var(--border);color:var(--muted);background:var(--white);transition:all .2s;flex-shrink:0}
.step-dot.active{border-color:var(--green);color:var(--green);background:var(--green-pale)}
.step-dot.done{border-color:var(--green);color:#fff;background:var(--green)}
.step-line{flex:1;height:1.5px;background:var(--border);max-width:36px;border-radius:2px;transition:background .2s}
.step-line.done{background:var(--green)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.5rem 1rem;border-radius:6px;font-family:inherit;font-size:.8rem;font-weight:600;border:1.5px solid transparent;cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none}
.btn-primary{background:var(--green);color:#fff;border-color:var(--green)}
.btn-primary:hover{background:#047857;border-color:#047857}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-secondary{background:var(--white);color:var(--mid);border-color:var(--border-strong)}
.btn-secondary:hover{border-color:var(--dark);color:var(--dark)}
.btn-block,.btn-full{width:100%}
.btn-sm{padding:.35rem .7rem;font-size:.75rem}
.btn-danger{background:var(--red-pale);color:var(--red);border-color:#FECACA}
.btn-danger:hover{background:var(--red);color:#fff;border-color:var(--red)}
.btn-icon{width:32px;height:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1rem;border-radius:6px;flex-shrink:0;line-height:1}

/* ── APP LAYOUT ── */
#app,#screen-app{display:none;min-height:100vh}
#app.visible,#screen-app.visible{display:block}
#screen-app{display:flex}
.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;background:var(--sidebar-bg);display:flex;flex-direction:column;z-index:100;overflow-y:auto}
.sidebar-logo{padding:1.2rem 1rem .9rem;border-bottom:1px solid rgba(255,255,255,.07)}
.sidebar-logo .brand{font-size:.95rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.sidebar-logo .brand span{color:var(--green)}
.sidebar-logo .sub{font-size:.68rem;color:rgba(255,255,255,.35);margin-top:.1rem;text-transform:uppercase;letter-spacing:.06em}
.sidebar-logo .role-badge{margin-top:.5rem;display:inline-block;background:rgba(5,150,105,.2);color:#6EE7B7;font-size:.65rem;font-weight:600;border-radius:4px;padding:.15rem .5rem;text-transform:uppercase;letter-spacing:.05em}
.sidebar-nav{flex:1;padding:.5rem 0;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:.6rem;padding:.55rem 1rem;font-size:.8rem;font-weight:500;color:rgba(255,255,255,.5);cursor:pointer;border-left:2px solid transparent;transition:all .15s;margin:1px 0}
.nav-item:hover{background:rgba(255,255,255,.05);color:rgba(255,255,255,.85)}
.nav-item.active{background:rgba(5,150,105,.15);color:#6EE7B7;border-left-color:var(--green)}
.nav-icon{flex-shrink:0;width:16px;height:16px;opacity:.7}
.nav-item.active .nav-icon{opacity:1}
.nav-item:hover .nav-icon{opacity:.9}
.nav-sep{height:1px;background:rgba(255,255,255,.07);margin:.4rem .75rem}
.nav-badge{background:var(--orange);color:#fff;border-radius:10px;padding:.1rem .42rem;font-size:.66rem;font-weight:800;margin-left:auto}
.sidebar-user{padding:.75rem 1rem;border-top:1px solid rgba(255,255,255,.07)}
.user-name,.user-info,.su-org{font-size:.8rem;font-weight:600;color:rgba(255,255,255,.85);margin-bottom:.05rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-email,.su-name{font-size:.7rem;color:rgba(255,255,255,.35);margin-bottom:.6rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-footer{padding:.75rem 1rem;border-top:1px solid rgba(255,255,255,.07)}
.sidebar-footer button,.btn-logout{background:none;border:none;color:rgba(255,255,255,.4);font-size:.78rem;cursor:pointer;font-family:inherit;width:100%;text-align:left;padding:.35rem 0;transition:color .15s}
.sidebar-footer button:hover,.btn-logout:hover{color:#fff}
.main,#main-content{margin-left:var(--sidebar-w);min-height:100vh;padding:1.75rem 2rem}

/* ── VIEWS ── */
.view{display:none}
.view.active{display:block}
.page-header{margin-bottom:1.5rem;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.page-header-left h1,.page-header h1{font-size:1.2rem;font-weight:700;color:var(--dark);letter-spacing:-.02em}
.page-header-left p,.page-header p{color:var(--muted);font-size:.8rem;margin-top:.15rem}
.section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:.6rem;margin-top:1.25rem}

/* ── DASHBOARD KPI ── */
.dash-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem}
@media(max-width:900px){.dash-kpi-row{grid-template-columns:repeat(2,1fr)}}
.dash-kpi{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:1rem 1.1rem;display:flex;align-items:flex-start;gap:.75rem}
.dash-kpi-ic{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dash-kpi-ic.green{background:#D1FAE5}
.dash-kpi-ic.blue{background:#DBEAFE}
.dash-kpi-ic.orange{background:#FEF3C7}
.dash-kpi-ic.red{background:#FEE2E2}
.dash-kpi-ic svg{width:18px;height:18px}
.dash-kpi-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.25rem}
.dash-kpi-val{font-size:1.2rem;font-weight:700;color:var(--dark);letter-spacing:-.02em;line-height:1.1}
.dash-kpi-val.green{color:var(--green)}
.dash-kpi-val.red{color:var(--red)}
.dash-kpi-val.orange{color:var(--orange)}
.dash-kpi-sub{font-size:.68rem;color:var(--muted);margin-top:.18rem}
.dash-layout{display:grid;grid-template-columns:1fr 300px;gap:1.25rem;align-items:start}
@media(max-width:960px){.dash-layout{grid-template-columns:1fr}}
.dash-panel{background:var(--white);border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:.9rem}
.dash-panel:last-child{margin-bottom:0}
.dash-panel-head{padding:.65rem 1rem;border-bottom:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:space-between}
.dash-panel-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
.dash-panel-action{font-size:.72rem;font-weight:600;color:var(--green);cursor:pointer;background:none;border:none;font-family:inherit;padding:0}
.dash-panel-action:hover{text-decoration:underline}
.dash-panel-body{padding:.5rem 0}
.dash-child-row{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;border-bottom:1px solid var(--border);transition:background .12s;cursor:pointer}
.dash-child-row:last-child{border-bottom:none}
.dash-child-row:hover{background:var(--bg)}
.dash-child-av{width:32px;height:32px;border-radius:50%;background:var(--green-pale);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--green);flex-shrink:0;border:1.5px solid #A7F3D0;overflow:hidden}
.dash-child-info{flex:1;min-width:0}
.dash-child-name{font-size:.82rem;font-weight:600;color:var(--dark)}
.dash-child-meta{font-size:.7rem;color:var(--muted);margin-top:.08rem}
.dash-alert{display:flex;align-items:flex-start;gap:.6rem;padding:.65rem 1rem;border-bottom:1px solid var(--border)}
.dash-alert:last-child{border-bottom:none}
.dash-alert-bar{width:3px;flex-shrink:0;border-radius:2px;align-self:stretch;min-height:20px}
.dash-alert-bar.red{background:var(--red)}
.dash-alert-bar.orange{background:var(--orange)}
.dash-alert-bar.green{background:var(--green)}
.dash-alert-bar.blue{background:var(--blue)}
.dash-alert-text{font-size:.78rem;color:var(--mid);line-height:1.5}
.dash-alert-text strong{font-weight:600;color:var(--dark);display:block;margin-bottom:.1rem}
.dash-act-row{display:flex;align-items:center;gap:.7rem;padding:.55rem 1rem;border-bottom:1px solid var(--border)}
.dash-act-row:last-child{border-bottom:none}
.dash-act-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dash-act-info{flex:1;min-width:0}
.dash-act-label{font-size:.78rem;font-weight:500;color:var(--dark)}
.dash-act-sub{font-size:.68rem;color:var(--muted);margin-top:.05rem}
.dash-act-amt{font-size:.78rem;font-weight:700;color:var(--green);white-space:nowrap}

/* ── STATS GRID (commercial / admin) ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-card{background:var(--white);border:1.5px solid var(--border);border-radius:8px;padding:1.1rem 1.2rem}
.stat-card.green{border-top:3px solid var(--green)}
.stat-card.blue{border-top:3px solid var(--blue)}
.stat-card.orange{border-top:3px solid var(--orange)}
.stat-card.purple{border-top:3px solid #7B2D8B}
.stat-card.red{border-top:3px solid var(--red)}
.stat-card .label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.4rem}
.stat-card .value{font-size:1.8rem;font-weight:800;color:var(--dark);line-height:1}
.stat-card .sub{font-size:.75rem;color:var(--muted);margin-top:.35rem}
.stat-card.green .value{color:var(--green)}
.stat-card.orange .value{color:var(--orange)}
.stat-card.blue .value{color:var(--blue)}
.stat-card.red .value{color:var(--red)}

/* ── TABLE ── */
.table-wrap{background:var(--white);border-radius:8px;border:1px solid var(--border);overflow:hidden;overflow-x:auto;margin-bottom:1.5rem}
table{width:100%;border-collapse:collapse}
thead{background:var(--bg)}
th{padding:.7rem 1rem;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);white-space:nowrap}
td{padding:.7rem 1rem;border-top:1px solid var(--border);vertical-align:middle;font-size:.85rem}
tr:hover td{background:rgba(5,150,105,.02)}
.td-actions{display:flex;gap:.3rem;align-items:center;flex-wrap:wrap}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--muted)}
.empty-state p{font-size:.9rem;margin-top:.5rem}

/* ── TOOLBAR / SEARCH ── */
.toolbar{display:flex;align-items:center;gap:.75rem;margin-bottom:1.2rem;flex-wrap:wrap}
.search-box{position:relative;flex:1;min-width:200px}
.search-box svg{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);color:var(--muted)}
.search-box input{width:100%;background:var(--white);border:1.5px solid var(--border);border-radius:6px;padding:.55rem .9rem .55rem 2.2rem;font-family:inherit;font-size:.85rem;outline:none;transition:border-color .15s;color:var(--dark)}
.search-box input:focus{border-color:var(--green)}
.filter-select{background:var(--white);border:1.5px solid var(--border);border-radius:6px;padding:.55rem .9rem;font-family:inherit;font-size:.85rem;color:var(--mid);outline:none;cursor:pointer}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:500;display:flex;align-items:center;justify-content:center;padding:1rem}
.modal,.modal-box{background:var(--white);border-radius:10px;width:100%;max-width:580px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.15)}
.modal-box-lg,.modal-box.modal-box-lg{max-width:760px}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--white);z-index:1}
.modal-header h2,.modal-header h3{font-size:.95rem;font-weight:700;color:var(--dark)}
.modal-header .sub{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.modal-close{background:var(--bg);border:none;border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:1rem;color:var(--mid);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.modal-close:hover{background:var(--border);color:var(--dark)}
.modal-body{padding:1.2rem 1.4rem}
.modal-footer{display:flex;gap:.65rem;justify-content:flex-end;padding:.9rem 1.4rem;border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--white)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.form-full{grid-column:1/-1}

/* ── PAGINATION ── */
.pagination{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.2rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--muted)}
.page-btns{display:flex;gap:.4rem}
.page-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid var(--border);background:var(--white);cursor:pointer;font-size:.8rem;font-weight:600;color:var(--mid);transition:all .15s}
.page-btn:hover{border-color:var(--green);color:var(--green)}
.page-btn.active{background:var(--green);color:#fff;border-color:var(--green)}
.page-btn:disabled{opacity:.4;cursor:default}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:4px;font-size:.67rem;font-weight:600;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em}
.badge-paye{background:#D1FAE5;color:#065F46}
.badge-attente{background:#F3F4F6;color:#6B7280}
.badge-payable{background:#FEF3C7;color:#92400E}
.badge-verif{background:#DBEAFE;color:#1E40AF;cursor:pointer}
.badge-nouveau,.badge-s-nouveau{background:#DBEAFE;color:#1E40AF}
.badge-en_traitement,.badge-s-en_traitement{background:#FEF3C7;color:#92400E}
.badge-accepte,.badge-s-accepte{background:#D1FAE5;color:#065F46}
.badge-refuse,.badge-s-refuse{background:var(--red-pale);color:#991B1B}
.badge-archive{background:#F3F4F6;color:#9CA3AF}
.badge-actif{background:#D1FAE5;color:#065F46}
.badge-inactif{background:#FEE2E2;color:#991B1B}
.badge-super_admin{background:rgba(123,45,139,.1);color:#7B2D8B}
.badge-admin{background:rgba(5,150,105,.1);color:var(--green)}
.badge-gestionnaire{background:#F3F4F6;color:var(--muted)}

/* ── TOAST ── */
#toast{position:fixed;bottom:1.25rem;right:1.25rem;background:var(--dark);color:#fff;padding:.6rem 1.1rem;border-radius:6px;font-size:.8rem;font-weight:500;opacity:0;transform:translateY(8px);transition:all .2s;z-index:999;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.2)}
#toast.show{opacity:1;transform:translateY(0)}
#toast.success{background:var(--green)}
#toast.error{background:var(--red)}
/* Multi-toast (partenaire) */
#toast-container{position:fixed;bottom:1.25rem;right:1.25rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}
.toast-item{background:var(--dark);color:#fff;padding:.65rem 1rem;border-radius:6px;font-size:.8rem;font-weight:600;box-shadow:0 4px 20px rgba(0,0,0,.2);animation:slideIn .25s ease;pointer-events:auto;max-width:320px}
.toast-item.success{background:var(--green)}.toast-item.error{background:var(--red)}.toast-item.info{background:var(--blue)}
@keyframes slideIn{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}
/* Admin multi-toast */
#toast-container .toast{display:flex;align-items:center;gap:.75rem;background:var(--dark);color:#fff;padding:.75rem 1.1rem;border-radius:6px;font-size:.85rem;font-weight:600;box-shadow:0 8px 24px rgba(0,0,0,.2);animation:toastin .25s ease;min-width:250px}
#toast-container .toast.success{border-left:4px solid var(--green)}
#toast-container .toast.error{border-left:4px solid var(--red)}
#toast-container .toast.info{border-left:4px solid var(--blue)}
@keyframes toastin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── LOADER ── */
.loader{width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
#loading-overlay{position:fixed;inset:0;background:rgba(255,255,255,.75);display:none;align-items:center;justify-content:center;flex-direction:column;gap:.6rem;z-index:500}
#loading-overlay.show{display:flex}
.spinner{width:28px;height:28px;border:2.5px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .6s linear infinite}
.empty{text-align:center;padding:2.5rem 1rem;color:var(--muted);background:var(--white);border:1px solid var(--border);border-radius:8px}
.empty .e-icon{font-size:1.8rem;margin-bottom:.6rem;opacity:.6}

/* ── REFS TABS (commercial / admin) ── */
.ref-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border)}
.ref-tab{padding:.55rem 1rem;font-size:.84rem;font-weight:700;color:var(--muted);cursor:pointer;border-radius:6px 6px 0 0;border:none;background:none;font-family:inherit;margin-bottom:-2px;border-bottom:2px solid transparent;transition:all .15s}
.ref-tab.active{color:var(--dark);border-bottom-color:var(--green);background:rgba(5,150,105,.05)}
.ref-tab:hover:not(.active){color:var(--dark);background:var(--bg)}
.ref-item-list{display:flex;flex-direction:column;gap:.5rem}
.ref-item{display:flex;align-items:center;justify-content:space-between;background:var(--white);border:1.5px solid var(--border);border-radius:8px;padding:.65rem 1rem;gap:1rem}
.ref-item-info{flex:1;min-width:0}
.ref-item-nom{font-weight:700;font-size:.88rem;color:var(--dark)}
.ref-item-sub{font-size:.75rem;color:var(--muted);margin-top:.1rem}
.ref-add-form{background:var(--white);border:1.5px solid var(--green);border-radius:8px;padding:1.2rem;margin-bottom:1.2rem}

/* ── DRAWER TÂCHES ── */
#drawer-overlay{position:fixed;inset:0;z-index:900;pointer-events:none}
#drawer-overlay.open{pointer-events:all;background:rgba(0,0,0,.4)}
#drawer-panel{position:fixed;top:0;right:-430px;width:410px;height:100vh;background:var(--white);border-left:1px solid var(--border);display:flex;flex-direction:column;transition:right .28s cubic-bezier(.4,0,.2,1);z-index:901;box-shadow:-8px 0 32px rgba(0,0,0,.12)}
#drawer-overlay.open #drawer-panel{right:0}
.drawer-header{padding:1.1rem 1.3rem;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.drawer-type{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.drawer-header-info .drawer-type{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.drawer-name,.drawer-header-info .drawer-name{font-size:.98rem;font-weight:800;color:var(--dark);margin-top:.15rem}
.drawer-close{background:var(--bg);border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0;font-size:.95rem;transition:all .15s}
.drawer-close:hover{background:var(--border);color:var(--dark)}
.drawer-body{flex:1;overflow-y:auto;padding:1.1rem 1.3rem}
.drawer-section-title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:.75rem;display:flex;align-items:center;justify-content:space-between}
.tache-item{display:flex;gap:.7rem;align-items:flex-start;padding:.7rem;border-radius:8px;border:1px solid var(--border);margin-bottom:.5rem;background:var(--bg);transition:border-color .15s}
.tache-item:hover{border-color:var(--green)}
.tache-item.faite{opacity:.65}
.tache-item.faite .tache-titre{text-decoration:line-through;color:var(--muted)}
.tache-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);cursor:pointer;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:all .15s;background:var(--white)}
.tache-item.faite .tache-check{background:var(--green);border-color:var(--green);color:#fff}
.tache-titre{font-size:.85rem;font-weight:600;color:var(--dark);line-height:1.35}
.tache-meta{font-size:.72rem;color:var(--muted);margin-top:.15rem;display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.tache-form{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-top:.75rem}
.tache-form .fg{margin-bottom:.65rem}
.tache-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.65rem}
.empty-tasks{text-align:center;padding:1.5rem;color:var(--muted);font-size:.85rem}

/* ── MOBILE HEADER ── */
.mob-header{display:none;position:fixed;top:0;left:0;right:0;height:52px;background:var(--white);border-bottom:1px solid var(--border);z-index:200;align-items:center;padding:0 1rem;gap:.75rem}
.mob-hamburger{background:none;border:none;cursor:pointer;padding:.35rem;border-radius:5px;display:flex;flex-direction:column;gap:4px;flex-shrink:0}
.mob-hamburger span{display:block;width:20px;height:1.5px;background:var(--dark);border-radius:2px;transition:all .2s}
.mob-title{font-size:.88rem;font-weight:700;color:var(--dark);flex:1}
.mob-title span{color:var(--green)}
.mob-avatar{width:30px;height:30px;border-radius:50%;background:var(--green);color:#fff;font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif-badge-hidden{display:none!important}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:150}
.sidebar-overlay.open{display:block}
.nav-logout{display:none}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .mob-header{display:flex}
  .sidebar{position:fixed;top:52px;left:0;width:260px;height:calc(100vh - 52px);transform:translateX(-100%);transition:transform .25s ease;z-index:160}
  .sidebar.open{transform:translateX(0)}
  .sidebar-logo{display:none}
  .sidebar-user{display:none}
  .nav-logout{display:flex!important}
  .main,#main-content{margin-left:0;padding:.9rem;padding-top:calc(52px + .9rem)}
  #screen-login{padding:.75rem;align-items:flex-start;padding-top:2.5rem}
  .login-card{padding:1.5rem 1.2rem;border-radius:10px}
  .fg-row,.form-grid{grid-template-columns:1fr}
  .page-header{margin-bottom:.9rem}
  .page-header-left h1,.page-header h1{font-size:1.05rem}
  .dash-kpi-row{grid-template-columns:repeat(2,1fr)}
  .dash-layout{grid-template-columns:1fr}
  #toast{bottom:.75rem;right:.75rem;left:.75rem;text-align:center;border-radius:6px}
  #drawer-panel{width:100vw;right:-100vw}
  .revenue-card{grid-template-columns:1fr}
}
@media(max-width:380px){
  .dash-kpi-row{grid-template-columns:repeat(2,1fr);gap:.5rem}
}
