/* ═══════════════════════════════════════════════════════
   EPPRIDAD — Espace Étudiant v5 — Design App Premium
   Dynamique · Animé · Mobile-first · Professionnel
════════════════════════════════════════════════════════ */

/* ═══ Ancien bloc auth supprimé — voir section LOGIN PREMIUM V27 en bas ═══ */

/* ══════════════════════════════
   STUDENT PAGE — APP DESIGN
══════════════════════════════ */
#student-page{background:var(--surface2);min-height:100vh;flex-direction:row}

/* SIDEBAR */
.student-sidebar{
  width:var(--sidebar-w);background:var(--dark2);
  display:flex;flex-direction:column;align-items:center;
  padding:16px 0;position:fixed;left:0;top:0;bottom:0;z-index:200;
  transition:width var(--tr);overflow:hidden;
  box-shadow:4px 0 24px rgba(0,0,0,.2);
}
.student-sidebar.expanded{width:var(--sidebar-expanded);align-items:flex-start}
.sidebar-logo{width:44px;height:44px;border-radius:12px;border:2px solid rgba(201,168,76,.4);background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:20px;flex-shrink:0}
.student-sidebar.expanded .sidebar-logo{margin-left:14px}
.sidebar-logo img{width:32px;height:32px;object-fit:contain}
.sidebar-nav{width:100%;padding:0 8px;flex:1}
.nav-item{width:100%;padding:0;height:48px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);border-radius:12px;transition:all .2s;position:relative;font-size:12.5px;font-weight:600;white-space:nowrap;margin-bottom:4px}
.student-sidebar.expanded .nav-item{justify-content:flex-start;padding:0 14px;gap:12px}
.nav-item:hover{color:rgba(255,255,255,.85);background:rgba(255,255,255,.07)}
.nav-item.active{background:rgba(201,168,76,.15);color:var(--accent)}
.nav-item.active::before{content:'';position:absolute;left:0;top:10px;bottom:10px;width:3px;background:var(--accent);border-radius:0 3px 3px 0}
.student-sidebar.expanded .nav-item.active::before{left:0}
.nav-icon{font-size:20px;flex-shrink:0}
.nav-label{display:none}
.student-sidebar.expanded .nav-label{display:block}
.sidebar-toggle{margin-top:auto;margin-bottom:8px;color:rgba(255,255,255,.3);font-size:18px;padding:10px;transition:color .2s;border-radius:10px}
.sidebar-toggle:hover{color:#fff;background:rgba(255,255,255,.06)}
.student-sidebar.expanded .sidebar-toggle{align-self:flex-end;margin-right:8px}
.notif-dot{width:7px;height:7px;background:var(--danger);border-radius:50%;position:absolute;top:9px;right:9px;border:1.5px solid var(--dark2)}
.student-sidebar.expanded .notif-dot{position:static;margin-left:auto;margin-right:0;border:none}

/* MAIN */
.student-main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;height:100vh;overflow-y:auto;transition:margin-left var(--tr)}
.student-main.shifted{margin-left:var(--sidebar-expanded)}

/* TOPBAR */
.student-topbar{height:58px;background:var(--surface);border-bottom:1px solid var(--border);padding:0 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 8px rgba(0,0,0,.05)}
.topbar-title{font-size:16px;font-weight:700;color:var(--text)}
.topbar-right{display:flex;align-items:center;gap:10px}
.topbar-notif{width:36px;height:36px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;position:relative;font-size:16px;cursor:pointer;transition:all .2s}
.topbar-notif:hover{background:var(--surface3)}
.topbar-ava{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-l) 100%);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px rgba(22,80,63,.3)}
.student-body{flex:1;padding:20px 20px 100px;overflow-x:hidden;max-width:1100px;overflow-y:auto;}

/* PANELS */
.s-panel{display:none;animation:fadeUp .28s ease}
.s-panel.active{display:block}

/* ══ ACCUEIL — HERO DYNAMIQUE ══ */
.student-hero{
  background:linear-gradient(135deg,var(--primary-d) 0%,var(--primary) 55%,#1e8055 100%);
  border-radius:var(--r-xl);padding:28px 28px 24px;color:#fff;
  margin-bottom:18px;position:relative;overflow:hidden;
}
.student-hero::before{content:'';position:absolute;right:-60px;top:-60px;width:220px;height:220px;border-radius:50%;background:rgba(201,168,76,.1)}
.student-hero::after{content:'';position:absolute;right:80px;bottom:-50px;width:130px;height:130px;border-radius:50%;background:rgba(255,255,255,.05)}
.sh-row1{display:flex;align-items:flex-start;justify-content:space-between;position:relative;z-index:1}
.sh-left{}
.sh-greeting{font-size:13px;color:rgba(255,255,255,.55);margin-bottom:3px}
.sh-name{font-family:'Playfair Display',serif;font-size:clamp(22px,3vw,30px);font-weight:700;color:#fff;line-height:1.1;margin-bottom:6px}
.sh-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.sh-chip{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:4px 10px;font-size:11px;color:rgba(255,255,255,.75)}
.sh-score{background:rgba(255,255,255,.1);border:1px solid rgba(201,168,76,.35);border-radius:16px;padding:14px 20px;text-align:center;flex-shrink:0;min-width:90px}
.sh-score-n{font-family:'Playfair Display',serif;font-size:36px;font-weight:700;color:var(--accent);line-height:1;animation:countUp .5s ease}
.sh-score-l{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.sh-score-m{font-size:12px;color:rgba(255,255,255,.65);margin-top:4px;font-weight:600}
.sh-score-d{font-size:11px;margin-top:3px;font-weight:700}

/* Stats rapides en ligne */
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:18px;position:relative;z-index:1}
.hs{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 10px;text-align:center;transition:background .2s;cursor:pointer}
.hs:hover{background:rgba(255,255,255,.14)}
.hs-val{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:#fff}
.hs-lbl{font-size:10px;color:rgba(255,255,255,.45);margin-top:3px;text-transform:uppercase;letter-spacing:.5px}

/* Accès rapide — cards carrées */
.quick-access{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
@media(max-width:600px){.quick-access{grid-template-columns:repeat(4,1fr);gap:8px}}
.qa-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px 10px;text-align:center;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:8px}
.qa-card:hover{border-color:var(--primary);box-shadow:var(--sh);transform:translateY(-2px)}
.qa-card:active{transform:translateY(0)}
.qa-icon{font-size:26px;line-height:1}
.qa-label{font-size:11.5px;font-weight:700;color:var(--text2)}

/* Cards accueil */
.accueil-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:640px){.accueil-grid{grid-template-columns:1fr}}
.ac-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;animation:fadeUp .3s ease}
.ac-card-title{font-weight:700;font-size:14px;color:var(--text);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.ac-row{font-size:13px;color:var(--text2);padding:7px 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.ac-row:last-child{border-bottom:none}
.ac-note{font-family:'Playfair Display',serif;font-size:15px;font-weight:700;min-width:36px}
.tip-box{background:linear-gradient(135deg,rgba(201,168,76,.08),rgba(201,168,76,.04));border:1px solid rgba(201,168,76,.2);border-radius:var(--r);padding:14px 16px;font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:16px;display:flex;gap:10px}
.tip-icon{font-size:18px;flex-shrink:0;margin-top:1px}

/* ══ NOTES ══ */
.notes-header{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.nh-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;text-align:center;animation:countUp .4s ease}
.nh-val{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;color:var(--text)}
.nh-lbl{font-size:10.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}
.table-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--border);background:var(--surface)}
.notes-table{width:100%;border-collapse:collapse;font-size:13.5px}
.notes-table th{background:linear-gradient(135deg,var(--primary-d),var(--primary));color:#fff;padding:11px 12px;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.notes-table td{padding:10px 12px;border-bottom:1px solid var(--border)}
.notes-table tr:last-child td{border-bottom:none}
.notes-table tr:hover td{background:var(--surface2)}
.notes-table tbody tr{animation:fadeUp .2s ease}
.note-pill{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700}
.notes-num{color:var(--text3);font-size:12px;width:28px}
.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:10.5px;font-weight:700}
.badge-green{background:#e8f5e9;color:#1b5e20}
.badge-blue{background:#e3f2fd;color:#0d47a1}
.badge-amber{background:var(--accent-pale);color:#7d5a00}
.badge-gray{background:var(--surface3);color:var(--text2)}

/* ══ BULLETIN ══ */
.bulletin-header{background:linear-gradient(135deg,var(--primary-d),var(--primary));border-radius:var(--r) var(--r) 0 0;padding:22px 26px;color:#fff;display:flex;align-items:center;gap:18px}
.bh-logo img{height:50px}
.bh-title{}
.bulletin-info{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:16px 0;font-size:13px;border-bottom:1px solid var(--border);margin-bottom:14px}
.bi-lbl{color:var(--text3);margin-right:6px}
.bulletin-footer{margin-top:16px;padding:16px;background:var(--surface2);border-radius:var(--r);text-align:center}
.bf-avg{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}
.bf-decision{font-size:14px;font-weight:700;margin-bottom:10px}

/* ══ EDT ══ */
.edt-table{width:100%;border-collapse:collapse;font-size:12px;min-width:700px}
.edt-table th{background:linear-gradient(135deg,var(--primary-d),var(--primary));color:#fff;padding:10px 8px;text-align:center;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.edt-table td{padding:4px;border:1px solid var(--border);vertical-align:top;min-width:110px}
.edt-h{background:var(--surface2);font-weight:700;font-size:11px;color:var(--text2);text-align:center;white-space:nowrap;padding:8px 6px}
.edt-cell{padding:7px 8px;border-radius:8px;min-height:52px}
.edt-mat{font-size:11.5px;font-weight:600;color:var(--text);line-height:1.3}
.edt-type{font-size:10px;padding:2px 7px;border-radius:4px;font-weight:700;margin-top:3px;display:inline-block}
.edt-c{background:rgba(22,80,63,.1);color:var(--primary)}
.edt-td{background:rgba(13,110,253,.08);color:#0a70d6}
.edt-tp{background:rgba(201,168,76,.12);color:#7d5a00}
.edt-pause{text-align:center;padding:8px;color:var(--text3);font-size:12px;background:var(--surface2)}
.edt-vide{text-align:center;color:var(--surface3);font-size:18px}
.edt-legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px;font-size:12px;font-weight:600;padding:10px}
.edt-legend .edt-c,.edt-legend .edt-td,.edt-legend .edt-tp{padding:4px 12px;border-radius:6px}

/* ══ PROGRESSION ══ */
.prog-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:20px}
.prog-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;text-align:center;animation:fadeUp .3s ease}
.prog-icon{font-size:26px;margin-bottom:8px}
.prog-val{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;color:var(--text)}
.prog-lbl{font-size:10.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin:4px 0}
.prog-badge{font-size:10.5px;font-weight:700;padding:3px 10px;border-radius:20px;display:inline-block}
.pb-up{background:#e8f5e9;color:#1b5e20}
.pb-flat{background:var(--accent-pale);color:#7d5a00}
.pb-down{background:#ffebee;color:var(--danger)}
.sb-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}
.sb-row:last-child{border-bottom:none}
.sb-lbl{width:160px;font-size:12px;color:var(--text2);flex-shrink:0}
.sb-track{flex:1;height:8px;background:var(--surface3);border-radius:4px;overflow:hidden}
.sb-fill{height:100%;border-radius:4px;transition:width 1.2s ease}
.sb-num{width:32px;text-align:right;font-size:12px;font-weight:700;flex-shrink:0}
.advice-box{background:var(--primary-pale);border:1px solid rgba(22,80,63,.15);border-radius:var(--r);padding:18px;font-size:14px;color:var(--text);line-height:1.8;margin-top:16px}

/* ══ CONSEILS IA ══ */
.ai-loading{display:flex;align-items:center;gap:14px;padding:30px;color:var(--text2);font-size:14px}
.spinner{width:22px;height:22px;border:2.5px solid var(--border2);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
.global-insight{background:linear-gradient(135deg,var(--primary-pale),rgba(201,168,76,.05));border:1px solid rgba(22,80,63,.15);border-radius:var(--r);padding:18px;margin-bottom:20px;display:flex;gap:14px}
.gi{font-size:28px;flex-shrink:0}
.conseils-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.conseil-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;animation:fadeUp .3s ease;transition:box-shadow .2s}
.conseil-card:hover{box-shadow:var(--sh)}
.cc-head{padding:14px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}
.cc-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.cc-name{font-weight:700;font-size:13.5px;color:var(--text)}
.cc-note{font-family:'Playfair Display',serif;font-size:18px;font-weight:700}
.cc-body{padding:14px 16px}
.cc-status{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;display:inline-block;margin-bottom:10px}
.s-force{background:#e8f5e9;color:#1b5e20}
.s-moyen{background:var(--accent-pale);color:#7d5a00}
.s-faible{background:#ffebee;color:var(--danger)}
.cc-tips{list-style:none;padding:0;margin-bottom:10px}
.cc-tips li{font-size:12.5px;color:var(--text2);padding:4px 0;padding-left:16px;position:relative;line-height:1.5}
.cc-tips li::before{content:'→';position:absolute;left:0;color:var(--primary);font-weight:700}
.cc-guide{background:var(--surface2);border-radius:8px;padding:10px 12px;margin-top:8px}
.cc-guide-title{font-size:11px;font-weight:700;color:var(--text2);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.cc-guide-text{font-size:12px;color:var(--text3);line-height:1.5}
.cc-bar{height:4px;background:var(--surface3);border-radius:2px;margin-top:12px;overflow:hidden}
.cc-bar-fill{height:100%;border-radius:2px;transition:width 1s ease}

/* ══ SCOLARITE ══ */
.scol-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:16px}
.scol-bloc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;text-align:center;transition:transform .2s}
.scol-bloc:hover{transform:translateY(-2px)}
.scol-bloc-n{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;line-height:1.1}
.scol-bloc-l{font-size:10.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-top:4px}
.scol-prog-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-bottom:14px}
.scol-bar-bg{height:18px;background:var(--surface3);border-radius:9px;overflow:hidden;margin:10px 0 6px}
.scol-bar-fill{height:100%;border-radius:9px;background:linear-gradient(to right,var(--primary),#22865a);display:flex;align-items:center;justify-content:flex-end;padding-right:8px;transition:width 1.2s ease}
.scol-bar-fill span{font-size:10.5px;font-weight:700;color:#fff}
.scol-sit{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:30px;font-size:12.5px;font-weight:700}
.scol-sit-ok{background:#e8f5e9;color:#1b5e20}
.scol-sit-red{background:#ffebee;color:var(--danger)}
.scol-sit-blue{background:#e3f2fd;color:#0d47a1}
.scol-sit-warn{background:var(--accent-pale);color:#7d5a00}
.scol-sit-none{background:var(--surface3);color:var(--text2)}
.scol-msg{border-radius:var(--r);padding:16px 18px;font-size:13.5px;line-height:1.8;margin-bottom:14px;border-left:4px solid}
.scol-msg-ok{background:#f0fff4;border-color:#1b5e20;color:#1b5e20}
.scol-msg-red{background:#fff5f5;border-color:var(--danger);color:#7d2020}
.scol-msg-warn{background:#fffbeb;border-color:#f59e0b;color:#7a5500}
.scol-cta{border-radius:var(--r-lg);padding:20px 22px;margin-bottom:14px;display:flex;align-items:center;gap:16px;color:#fff}
.scol-cta-red{background:linear-gradient(135deg,var(--danger),#b71c1c)}
.scol-cta-green{background:linear-gradient(135deg,var(--primary),#22865a)}
.scol-cta-ico{font-size:38px;flex-shrink:0}
.scol-cta-btn{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.9);padding:9px 18px;border-radius:30px;font-size:12.5px;font-weight:700;border:none;cursor:pointer;margin-top:10px;transition:all .2s;color:var(--primary)}
.scol-cta-btn-red{color:var(--danger)}
.scol-cta-btn:hover{background:#fff;transform:translateY(-1px)}
.scol-wa{background:#25d366;color:#fff;border:none;border-radius:10px;padding:13px;font-size:14px;font-weight:700;display:flex;align-items:center;gap:10px;cursor:pointer;width:100%;justify-content:center;transition:all .2s}
.scol-wa:hover{background:#20b857;transform:translateY(-1px)}

/* ══ BIBLIOTHÈQUE ══ */
.lib-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.lib-filter{padding:7px 16px;border-radius:20px;border:1px solid var(--border);font-size:12.5px;font-weight:600;color:var(--text2);transition:all .2s;cursor:pointer}
.lib-filter.active,.lib-filter:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.lib-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:transform .2s,box-shadow .2s;animation:fadeUp .3s ease}
.lib-card:hover{transform:translateY(-2px);box-shadow:var(--sh)}
.lib-thumb{height:88px;display:flex;align-items:center;justify-content:center;font-size:40px;background:linear-gradient(135deg,var(--surface2),var(--surface3));position:relative}
.lib-card-body{padding:14px 16px}
.lib-card-title{font-weight:700;font-size:14px;color:var(--text);margin-bottom:4px}
.lib-card-meta{font-size:11px;color:var(--text3);margin-bottom:8px}
.lib-card-desc{font-size:12px;color:var(--text2);line-height:1.5;margin-bottom:12px}
.lib-card-actions{display:flex;gap:8px}

/* ══ NOTIFICATIONS ══ */
.notif-item{display:flex;gap:14px;padding:14px;border-radius:var(--r);margin-bottom:10px;border:1px solid var(--border);background:var(--surface);animation:fadeUp .3s ease;transition:border-color .2s}
.notif-item:hover{border-color:var(--border2)}
.notif-item.unread{border-color:rgba(22,80,63,.25);background:var(--primary-pale)}
.notif-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.notif-title{font-weight:700;font-size:14px;color:var(--text);margin-bottom:3px}
.notif-body{font-size:13px;color:var(--text2);line-height:1.5}
.notif-time{font-size:11px;color:var(--text3);margin-top:4px}

/* ══ SECTIONS COMMUNES ══ */
.s-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--text);margin-bottom:14px}
.s-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-bottom:14px}
.btn-sm{padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;border:1px solid var(--border);color:var(--text2);background:var(--surface);transition:all .2s;cursor:pointer}
.btn-sm:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-danger-sm{border-color:rgba(229,57,53,.3);color:var(--danger)}
.btn-danger-sm:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.prog-bar-wrap{height:6px;background:var(--surface3);border-radius:3px;overflow:hidden;min-width:60px}
.prog-bar-fill{height:100%;border-radius:3px;transition:width 1s ease}

/* ══════════════════════════════════════════════════════
   ADMIN — CENTRE DE CONTRÔLE PREMIUM
══════════════════════════════════════════════════════ */
#admin-page{background:#f0f4f2;min-height:100vh;flex-direction:row}

/* ── SIDEBAR ── */
.admin-sidebar{
  width:260px;
  background:linear-gradient(180deg,#0b2f25 0%,#0d3d2c 60%,#071a12 100%);
  display:flex;flex-direction:column;
  position:fixed;left:0;top:0;bottom:0;z-index:200;
  box-shadow:4px 0 32px rgba(0,0,0,.25);
  transition:width .3s;
}
.admin-sidebar-logo{
  padding:22px 20px 18px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.admin-logo-row{display:flex;align-items:center;gap:12px;margin-bottom:4px}
.admin-logo-circle{
  width:40px;height:40px;border-radius:10px;
  background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.3);
  display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;
}
.admin-logo-circle img{width:30px;height:30px;object-fit:contain}
.admin-sidebar-name{font-family:'Playfair Display',serif;font-size:17px;color:var(--accent);font-weight:700;letter-spacing:.5px}
.admin-sidebar-sub{font-size:9px;color:rgba(255,255,255,.25);letter-spacing:2.5px;text-transform:uppercase;margin-top:1px}
.admin-user-badge{
  display:flex;align-items:center;gap:8px;margin-top:12px;
  background:rgba(255,255,255,.05);border-radius:8px;padding:8px 10px;
}
.admin-user-dot{width:8px;height:8px;background:#4caf50;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px rgba(76,175,80,.6)}
.admin-user-text{font-size:11.5px;color:rgba(255,255,255,.55)}
.admin-user-text strong{color:rgba(255,255,255,.85);display:block;font-size:12.5px}

/* ── NAV GROUPS ── */
.admin-nav{padding:12px 10px;flex:1;overflow-y:auto}
.admin-nav-section{
  font-size:9.5px;color:rgba(255,255,255,.2);
  letter-spacing:2px;text-transform:uppercase;
  padding:12px 10px 6px;font-weight:700;
}
.admin-nav-item{
  display:flex;align-items:center;gap:11px;
  padding:10px 14px;border-radius:10px;
  color:rgba(255,255,255,.48);font-size:13px;font-weight:500;
  transition:all .18s;margin-bottom:2px;position:relative;cursor:pointer;
  -webkit-tap-highlight-color:transparent;
}
.admin-nav-item:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.85)}
.admin-nav-item.active{
  background:rgba(201,168,76,.12);color:var(--accent);
  font-weight:700;
}
.admin-nav-item.active::before{
  content:'';position:absolute;left:0;top:8px;bottom:8px;
  width:3px;background:var(--accent);border-radius:0 3px 3px 0;
}
.admin-badge{
  margin-left:auto;background:var(--danger);color:#fff;
  font-size:10px;font-weight:800;min-width:20px;height:20px;
  padding:0 5px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
}
.admin-footer{
  padding:14px 16px;border-top:1px solid rgba(255,255,255,.06);
}
.admin-footer button{
  color:rgba(255,255,255,.35);font-size:12.5px;
  display:flex;align-items:center;gap:8px;
  transition:color .2s;cursor:pointer;
  background:none;border:none;font-family:inherit;
}
.admin-footer button:hover{color:#fff}

/* ── MAIN ── */
.admin-main{margin-left:260px;flex:1;display:flex;flex-direction:column;min-height:100vh}

/* ── TOPBAR ── */
.admin-topbar{
  background:#fff;border-bottom:1px solid #e8ede9;
  padding:0 28px;height:62px;
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:100;
  box-shadow:0 1px 8px rgba(0,0,0,.05);
}
.admin-topbar-title{font-size:17px;font-weight:700;color:var(--text)}
.admin-topbar-right{display:flex;align-items:center;gap:12px}
.admin-topbar-btn{
  width:36px;height:36px;border-radius:9px;
  background:#f4f8f6;border:1px solid #e0e8e3;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;cursor:pointer;transition:all .2s;
}
.admin-topbar-btn:hover{background:#e4f0e8}

/* ── BODY ── */
.admin-body{flex:1;padding:24px 28px;overflow-y:auto;height:calc(100vh - 62px)}

/* ── PANELS ── */
.ap{display:none;animation:fadeUp .28s ease}
.ap.active{display:block}

/* ── STAT CARDS ── */
.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:14px;margin-bottom:24px}
.admin-stat-card{
  background:#fff;border:1px solid #e8ede9;border-radius:14px;
  padding:18px;display:flex;align-items:center;gap:14px;
  transition:all .2s;cursor:pointer;
}
.admin-stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.09);border-color:var(--primary)}
.admin-stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.admin-stat-n{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;color:var(--text)}
.admin-stat-l{font-size:11.5px;color:var(--text3);margin-top:2px}

/* ── SECTION CARDS ── */
.s-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;color:var(--text);margin-bottom:14px}
.s-card{background:#fff;border:1px solid #e8ede9;border-radius:14px;padding:20px;margin-bottom:14px}
.s-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}

/* ── TABLES ── */
.students-table-wrap{overflow-x:auto;background:#fff;border:1px solid #e8ede9;border-radius:14px}
.students-table{width:100%;border-collapse:collapse;font-size:13px}
.students-table th{
  background:#f4f8f6;border-bottom:1px solid #e8ede9;
  padding:11px 14px;text-align:left;font-size:11px;
  text-transform:uppercase;letter-spacing:.5px;color:var(--text2);font-weight:700;
}
.students-table td{padding:12px 14px;border-bottom:1px solid #f0f4f2;vertical-align:middle}
.students-table tr:last-child td{border-bottom:none}
.students-table tr:hover td{background:#f8fbf9}
.st-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;white-space:nowrap}
.st-active{background:#e8f5e9;color:#1b5e20}
.st-pending{background:#fff3e0;color:#e65100}
.st-none{background:#f5f5f5;color:#666}
.st-expired{background:#ffebee;color:#c62828}

/* ── FORM ELEMENTS ── */
.admin-search{
  padding:9px 14px;border:1.5px solid #d4ddd7;border-radius:10px;
  font-size:13.5px;width:240px;outline:none;transition:all .2s;
  background:#fff;font-family:inherit;
}
.admin-search:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(22,80,63,.1)}
.admin-form-group{margin-bottom:15px}
.admin-form-label{
  display:block;font-size:11.5px;font-weight:700;
  letter-spacing:.5px;text-transform:uppercase;
  color:var(--text2);margin-bottom:6px;
}
.admin-form-input,.admin-form-textarea,.admin-form-select{
  width:100%;padding:10px 14px;
  border:1.5px solid #d4ddd7;border-radius:10px;
  font-size:14px;color:var(--text);background:#fff;
  outline:none;font-family:inherit;transition:all .2s;
}
.admin-form-input:focus,.admin-form-textarea:focus,.admin-form-select:focus{
  border-color:var(--primary);box-shadow:0 0 0 3px rgba(22,80,63,.1);
}
.admin-form-textarea{resize:vertical;min-height:80px}
.btn-sm{
  padding:7px 14px;border-radius:8px;font-size:12.5px;font-weight:600;
  border:1px solid #d4ddd7;color:var(--text2);background:#fff;
  transition:all .2s;cursor:pointer;font-family:inherit;
}
.btn-sm:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-danger-sm{border-color:rgba(220,53,69,.3);color:var(--danger)}
.btn-danger-sm:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-block{
  display:block;width:100%;padding:12px;border-radius:10px;
  font-size:14px;font-weight:700;transition:all .2s;border:none;cursor:pointer;font-family:inherit;
}
.btn-green-block{background:linear-gradient(135deg,var(--primary),var(--primary-l));color:#fff}
.btn-green-block:hover{opacity:.92;transform:translateY(-1px)}

/* ── PUBLISH TYPES ── */
.post-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
.ptype-btn{
  padding:12px 6px;border-radius:10px;border:1.5px solid #d4ddd7;
  background:#f8fbf9;font-size:12px;font-weight:700;cursor:pointer;
  text-align:center;transition:all .18s;color:var(--text2);line-height:1.4;
}
.ptype-btn:hover{border-color:var(--primary);background:var(--primary-pale);color:var(--primary)}
.ptype-btn.sel{border-color:var(--primary);background:var(--primary);color:#fff}

/* ── UPLOAD ZONES ── */
.drop-zone{
  border:2px dashed #c4d4c8;border-radius:10px;padding:22px;
  text-align:center;cursor:pointer;transition:all .2s;background:#f8fbf9;
}
.drop-zone:hover,.drop-zone.drag{border-color:var(--primary);background:var(--primary-pale)}
.doc-src-tabs{display:flex;gap:8px;margin-bottom:10px}
.doc-src-tab{
  flex:1;padding:9px;border-radius:8px;border:1.5px solid #d4ddd7;
  font-size:12.5px;font-weight:600;cursor:pointer;text-align:center;
  transition:all .2s;color:var(--text2);background:#f8fbf9;
}
.doc-src-tab.sel{border-color:var(--primary);background:var(--primary-pale);color:var(--primary)}

/* ── MODALS ── */
.vmodal-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px}
.vmodal-box{background:#fff;border-radius:20px;padding:24px;max-width:440px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.25);max-height:90vh;overflow-y:auto}
.vmodal-box h3{font-family:'Playfair Display',serif;font-size:19px;font-weight:700;margin-bottom:16px;color:var(--text)}
.dur-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.dur-btn{padding:10px 6px;border-radius:8px;border:1.5px solid #d4ddd7;background:#f8fbf9;font-size:12px;font-weight:600;cursor:pointer;text-align:center;transition:all .2s;color:var(--text2);line-height:1.3}
.dur-btn:hover,.dur-btn.sel{border-color:var(--primary);background:var(--primary-pale);color:var(--primary)}

/* ── MOBILE BOTTOM NAV (admin) ── */
.admin-bottom-nav{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:300;
  background:#0b2f25;border-top:1px solid rgba(255,255,255,.08);
  flex-direction:row;padding:6px 0 max(6px,env(safe-area-inset-bottom));
}
.admin-bnav-item{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;color:rgba(255,255,255,.35);font-size:10px;font-weight:600;
  padding:5px 2px;position:relative;transition:color .2s;cursor:pointer;
}
.admin-bnav-item.active,.admin-bnav-item:hover{color:var(--accent)}
.admin-bnav-ico{font-size:19px;line-height:1}
.bnav-badge{
  position:absolute;top:2px;right:calc(50% - 22px);
  background:var(--danger);color:#fff;font-size:9px;font-weight:800;
  padding:1px 4px;border-radius:8px;
}

/* ── EXPIRY BADGES ── */
.expiry-ok{background:#e8f5e9;color:#1b5e20;font-size:11px;font-weight:700;padding:2px 8px;border-radius:12px}
.expiry-warn{background:#fff3e0;color:#e65100;font-size:11px;font-weight:700;padding:2px 8px;border-radius:12px}
.expiry-exp{background:#ffebee;color:#c62828;font-size:11px;font-weight:700;padding:2px 8px;border-radius:12px}

/* ── IMPERSONATE ── */
.impersonate-bar{
  background:#ffc107;color:#1a1a1a;padding:8px 16px;
  font-size:12.5px;font-weight:700;
  display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0;
}
.impersonate-bar button{background:#1a1a1a;color:#fff;border:none;border-radius:6px;padding:5px 14px;font-size:12px;font-weight:700;cursor:pointer}

/* ── PDF MODAL ── */
.pdf-modal-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;padding:10px}
.pdf-modal-box{background:#fff;border-radius:14px;width:96vw;max-width:920px;height:92vh;display:flex;flex-direction:column;overflow:hidden}
.pdf-modal-header{padding:12px 18px;border-bottom:1px solid #ddd;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.pdf-modal-body{flex:1;overflow:hidden}
.pdf-modal-body iframe{width:100%;height:100%;border:none}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .admin-sidebar{width:220px}
  .admin-main{margin-left:220px}
}
@media(max-width:768px){
  .admin-sidebar{display:none!important}
  .admin-main{margin-left:0!important}
  .admin-bottom-nav{display:flex}
  .admin-body{padding:14px;padding-bottom:80px!important;height:calc(100vh - 62px - 60px)}
  .admin-stats-grid{grid-template-columns:1fr 1fr}
  .s-title-row{flex-direction:column;align-items:flex-start}
  .admin-search{width:100%!important}
  .dur-grid{grid-template-columns:repeat(2,1fr)}
  .post-type-grid{grid-template-columns:repeat(2,1fr)}
  .students-table th:nth-child(3),.students-table td:nth-child(3){display:none}
  .students-table th:nth-child(5),.students-table td:nth-child(5){display:none}
}
@media(max-width:480px){
  .admin-stats-grid{grid-template-columns:1fr 1fr}
}

/* Fix autocomplete browser override */
.form-input:-webkit-autofill,
.form-input:-webkit-autofill:focus {
  -webkit-text-fill-color: #091f17 !important;
  -webkit-box-shadow: 0 0 0 1000px #fff inset !important;
  background-color: #fff !important;
}

/* ══════════════════════════════════════════════════════════
   EPPRIDAD V18 — OPTIMISATION MOBILE COMPLÈTE
   ══════════════════════════════════════════════════════════ */

/* ── Grille 2 colonnes → 1 colonne sur mobile ── */
@media(max-width:600px){
  [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr!important;
  }
  [style*="grid-template-columns:repeat(2"]{
    grid-template-columns:1fr!important;
  }
}

/* ── Panels admin : padding réduit, cartes pleine largeur ── */
@media(max-width:768px){
  .s-card{padding:14px!important;border-radius:12px!important}
  .s-title{font-size:16px!important}
  .admin-form-input,.admin-form-select,.admin-form-textarea{
    font-size:16px!important; /* évite le zoom iOS */
    padding:11px 13px!important;
  }
  .btn-block{padding:13px 14px!important;font-size:14px!important}
  .btn-sm{padding:7px 12px!important;font-size:12px!important}

  /* Stats : 2 par ligne */
  .admin-stats-grid{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}
  .stat-card{padding:14px 10px!important}
  .stat-value{font-size:22px!important}
  .stat-label{font-size:11px!important}

  /* Tableau étudiants : masquer colonnes non essentielles */
  .students-table th:nth-child(4),.students-table td:nth-child(4){display:none}

  /* Actions rapides en grille 2×2 */
  .quick-actions-grid{grid-template-columns:repeat(2,1fr)!important}

  /* Correction exercice : textarea pleine largeur */
  textarea[id^="note-"]{width:100%!important;box-sizing:border-box}

  /* Formation cards : actions empilées */
  .s-card [style*="display:flex;flex-direction:column;gap:6px;flex-shrink:0"]{
    flex-direction:row!important;flex-wrap:wrap!important;
  }
}

@media(max-width:480px){
  .admin-stats-grid{grid-template-columns:repeat(2,1fr)!important}
  .admin-body{padding:10px!important;padding-bottom:80px!important}

  /* Header admin */
  .admin-header{padding:0 12px!important}
  .admin-header-title{font-size:15px!important}

  /* Formulaires : champs pleine largeur */
  .admin-form-group{margin-bottom:12px!important}

  /* Give acces form */
  #giveAccesForm .s-card{padding:12px!important}

  /* Boutons paires côte à côte */
  [style*="display:flex;gap:10px"]{gap:8px!important}
  [style*="display:flex;gap:6px"]{gap:6px!important}
}

/* ── Espace étudiant (cours) : login deux colonnes → une ── */
@media(max-width:768px){
  .lp-left{display:none}
  #login-page{flex-direction:column}
  .lp-right{padding:24px 20px!important;min-height:100vh}
  .lp-box-logo{display:block!important}
  
}

/* ── Sidebar cours étudiant sur mobile ── */
@media(max-width:768px){
  .student-sidebar{
    position:fixed!important;
    left:-100%!important;
    z-index:1000;
    transition:left .25s ease;
    width:260px!important;
    box-shadow:4px 0 24px rgba(0,0,0,.5);
  }
  .student-sidebar.mobile-open{left:0!important}
  .student-main{margin-left:0!important}
  .student-main.shifted{margin-left:0!important}

  /* Overlay pour fermer la sidebar */
  .sidebar-overlay{
    display:none;position:fixed;inset:0;
    background:rgba(0,0,0,.5);z-index:999;
  }
  .sidebar-overlay.show{display:block}

  /* Topbar cours */
  .course-topbar{padding:0 12px!important}
  .topbar-title{font-size:14px!important;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

  /* Panel contenu cours */
  .course-content{padding:16px!important}
  .module-card{padding:14px!important}
}

/* ── Bottom nav admin : labels visibles ── */
@media(max-width:360px){
  .admin-bottom-nav .nav-label{display:none}
  .admin-bottom-nav .nav-item{padding:8px 6px}
}

/* ── Formations en ligne page publique ── */
@media(max-width:600px){
  .formation-card-grid{grid-template-columns:1fr!important}
  .formation-hero{padding:40px 16px!important}
  .formation-hero h1{font-size:clamp(24px,6vw,36px)!important}
}

/* ── Général : éviter overflow horizontal ── */
*{max-width:100%;box-sizing:border-box}
img,video,iframe{max-width:100%;height:auto}
table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}

/* ── Touch targets minimaux (accessibilité mobile) ── */
button,a,[onclick]{min-height:36px;min-width:36px}

/* ── Amélioration focus pour clavier et accessibilité ── */
button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--primary,#16503f);
  outline-offset:2px;
}

/* ── Hamburger mobile pour admin (déjà géré en JS, renforcement CSS) ── */
.admin-mobile-menu-btn{
  display:none;
  background:none;border:none;
  color:var(--text,#1a1a1a);
  font-size:22px;padding:8px;cursor:pointer;
  border-radius:8px;
}
@media(max-width:768px){
  .admin-mobile-menu-btn{display:flex;align-items:center;justify-content:center}
}

/* ── Drawer sidebar admin mobile ── */
@media(max-width:768px){
  .admin-sidebar.mobile-open{
    display:flex!important;
    position:fixed!important;
    left:0!important;top:0!important;bottom:0!important;
    z-index:9999;
    width:260px!important;
    box-shadow:4px 0 30px rgba(0,0,0,.4);
  }
  .admin-overlay{
    display:none;position:fixed;inset:0;
    background:rgba(0,0,0,.45);z-index:9998;
  }
  .admin-overlay.show{display:block}
}

/* ── Accueil adaptatif (apprenant en ligne + étudiant diplômant) ── */
.qa-card{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:14px;padding:16px 12px;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  transition:all .2s;text-align:center;
  box-shadow:0 1px 6px rgba(22,80,63,.05);
}
.qa-card:hover,.qa-card:active{
  border-color:var(--primary);background:var(--primary-pale);
  transform:translateY(-2px);box-shadow:0 4px 16px rgba(22,80,63,.12);
}
.qa-icon{font-size:26px;line-height:1}
.qa-label{font-size:11.5px;font-weight:700;color:var(--text2)}
.quick-access{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:10px;margin-bottom:4px;
}
@media(max-width:480px){
  .quick-access{grid-template-columns:repeat(2,1fr);gap:8px}
  .qa-icon{font-size:22px}
}
/* Hero stats */
.hs-v{font-size:18px;font-weight:800;color:var(--accent);line-height:1}
.hs-l{font-size:10px;color:rgba(255,255,255,.55);margin-top:2px;text-align:center}
/* Topbar site button */
.topbar-site-btn{
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  border-radius:8px;padding:5px 11px;font-size:12px;font-weight:600;
  color:rgba(255,255,255,.6);text-decoration:none;transition:all .2s;
  white-space:nowrap;
}
.topbar-site-btn:hover{background:rgba(201,168,76,.15);color:var(--accent);border-color:rgba(201,168,76,.3)}
/* Admin msg banner */
#adminMsgBanner{animation:slideDown .3s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* ── Boutons flottants mobile (site + logout) ──────────────── */
.mobile-nav-logout{
  display:none; /* Caché par défaut, affiché en CSS mobile */
  position:fixed;bottom:72px;right:14px;
  flex-direction:column;gap:8px;z-index:300;
}
.mbl-btn{
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;cursor:pointer;border:none;
  box-shadow:0 4px 14px rgba(0,0,0,.25);transition:all .2s;
  text-decoration:none;
}
.mbl-site{background:var(--primary);color:#fff;}
.mbl-site:hover{background:var(--primary-l);transform:scale(1.08);}
.mbl-logout{background:#e53935;color:#fff;}
.mbl-logout:hover{background:#c62828;transform:scale(1.08);}

@media(max-width:767px){
  .mobile-nav-logout{display:flex;}
  .hide-mobile{display:none!important;}
}
@media(min-width:768px){
  .mobile-nav-logout{display:none!important;}
  .hide-mobile{display:inline!important;}
}

/* ═══════════════════════════════════════════════
   PHASE 1 — Dashboard V2 & Inscriptions premium
═══════════════════════════════════════════════ */

/* KPI cards sombres — override pour le nouveau style */
.admin-stat-card{
  background:linear-gradient(135deg,#0b2f25,#16503f);
  border-radius:16px;
  padding:18px 20px;
  border:1px solid rgba(255,255,255,.07);
  transition:all var(--tr);
  cursor:pointer;
  position:relative;
  overflow:hidden;
}
.admin-stat-card:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(0,0,0,.3);
}
.admin-stat-n{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;color:#fff;line-height:1}
.admin-stat-l{font-size:11.5px;color:rgba(255,255,255,.5);margin-top:4px}

/* Inscription cards */
.insc-card{transition:box-shadow var(--tr)}
.insc-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.09)!important}
.insc-card--new{animation:inscPulse 2s ease-in-out}
@keyframes inscPulse{0%,100%{box-shadow:0 0 0 2px rgba(198,40,40,.08)}50%{box-shadow:0 0 0 4px rgba(198,40,40,.15)}}

/* Stats bar inscriptions */
#inscStatsBar{gap:6px;display:flex;flex-wrap:wrap}

/* Charts zones */
#revenusChartZone,#formationsChartZone{min-height:60px}

/* Responsive dashboard grids */
@media(max-width:900px){
  #ap-dashboard>[style*="1.6fr"]{grid-template-columns:1fr!important}
}
@media(max-width:640px){
  .admin-stats-grid{grid-template-columns:1fr 1fr!important;gap:10px!important}
  #ap-dashboard>[style*="1.6fr"]{grid-template-columns:1fr!important}
}

/* ══ PAGE LOGIN — PREMIUM V27 ══════════════════════════════ */

/* Grille login */
/* #auth-page : display géré par .page / .page.active (voir haut du fichier) */

/* Gauche dark */
.auth-left{
  flex:0 0 52%;
  background:linear-gradient(148deg,#040b08 0%,#0b2f25 38%,#16503f 68%,#0b3526 100%);
  display:flex;align-items:center;justify-content:center;
  padding:52px 56px;position:relative;overflow:hidden;
}
@media(max-width:860px){.auth-left{display:none}}
.auth-left-bg{position:absolute;inset:0;
  background:radial-gradient(ellipse at 20% 80%,rgba(201,168,76,.07),transparent 55%),
             radial-gradient(ellipse at 80% 20%,rgba(22,80,63,.35),transparent 50%)}
.auth-left-orb{position:absolute;width:550px;height:550px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,168,76,.05),transparent 60%);
  top:-180px;right:-180px;pointer-events:none}
.auth-left-orb2{position:absolute;width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.03),transparent 65%);
  bottom:-120px;left:-80px;pointer-events:none}
.auth-left-content{position:relative;z-index:1;max-width:440px}

/* Logo */
.auth-logo-wrap{display:flex;align-items:center;gap:16px;margin-bottom:48px}
.auth-logo-circle{width:64px;height:64px;border-radius:50%;
  background:rgba(255,255,255,.06);border:2px solid rgba(201,168,76,.4);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
  box-shadow:0 0 0 6px rgba(201,168,76,.06)}
.auth-logo-circle img{width:46px;height:46px;object-fit:contain}
.auth-logo-name{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;
  letter-spacing:1.5px;color:var(--accent)}
.auth-logo-sub{font-size:9.5px;color:rgba(255,255,255,.3);letter-spacing:2.5px;
  text-transform:uppercase;margin-top:3px}

/* Titre */
.auth-left h1{font-family:'Playfair Display',serif;font-size:clamp(28px,3vw,42px);
  font-weight:800;color:#fff;line-height:1.1;margin-bottom:16px}
.auth-left h1 em{color:var(--accent);font-style:normal}
.auth-left p{font-size:13.5px;color:rgba(255,255,255,.48);line-height:1.85;margin-bottom:28px}

/* Badges type formation */
.auth-badge{background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.22);
  border-radius:20px;padding:5px 13px;font-size:11.5px;font-weight:700;color:#d4af37}

/* Fonctionnalités */
.auth-features{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.auth-feature{display:flex;align-items:flex-start;gap:14px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:14px;padding:14px 16px;transition:border-color .2s}
.auth-feature:hover{border-color:rgba(201,168,76,.2)}
.auth-feature-icon{font-size:22px;flex-shrink:0;width:36px;text-align:center;margin-top:1px}
.auth-feature-title{color:#fff;font-size:13.5px;font-weight:700;margin-bottom:3px}
.auth-feature-sub{color:rgba(255,255,255,.42);font-size:12px;line-height:1.55}

/* Stats */
.auth-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.auth-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:14px;padding:18px 12px;text-align:center;transition:border-color .2s}
.auth-stat:hover{border-color:rgba(201,168,76,.25)}
.auth-stat-n{font-family:'Playfair Display',serif;font-size:30px;font-weight:700;
  color:var(--accent);line-height:1}
.auth-stat-l{font-size:9.5px;color:rgba(255,255,255,.3);letter-spacing:1.5px;
  text-transform:uppercase;margin-top:5px}

/* Droite claire */
.auth-right{flex:1;background:#f8fdf9;display:flex;align-items:center;
  justify-content:center;padding:40px 32px;position:relative}
.auth-right::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(22,80,63,.06),transparent 55%);
  pointer-events:none}
.auth-box{width:100%;max-width:400px;position:relative;z-index:1}
.auth-box-logo{display:none;text-align:center;margin-bottom:28px}
@media(max-width:860px){.auth-box-logo{display:block}}
.auth-box-logo img{height:52px;object-fit:contain}

/* Tabs */
.auth-tabs{display:flex;background:rgba(22,80,63,.06);border:1px solid rgba(22,80,63,.1);
  border-radius:14px;padding:4px;margin-bottom:24px}
.auth-tab{flex:1;padding:11px;border-radius:11px;font-size:13px;font-weight:600;
  color:rgba(22,80,63,.5);transition:all .2s;text-align:center;cursor:pointer;
  background:none;border:none;font-family:inherit}
.auth-tab.active{background:#fff;color:#16503f;box-shadow:0 2px 10px rgba(22,80,63,.12)}
.auth-tab:not(.active):hover{color:#16503f}

/* Form */
.form-heading{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;
  color:#091f17;margin-bottom:5px}
.form-sub{font-size:13px;color:#5a8a72;margin-bottom:22px;line-height:1.6}
.form-label{display:block;font-size:11px;font-weight:700;letter-spacing:.6px;
  text-transform:uppercase;color:#5a8a72;margin-bottom:7px}
.form-input{width:100%;padding:13px 15px;border:1.5px solid rgba(22,80,63,.15);
  border-radius:12px;font-size:14.5px;font-weight:500;color:#091f17;
  background:#fff;transition:all .2s;outline:none;font-family:inherit}
.form-input::placeholder{color:rgba(22,80,63,.3);font-weight:400}
.form-input:focus{border-color:#16503f;box-shadow:0 0 0 3px rgba(22,80,63,.08)}
.form-group{margin-bottom:16px}
.form-err{display:none;background:#fdf0f0;border:1px solid rgba(229,57,53,.25);
  color:#c62828;font-size:13px;padding:10px 14px;border-radius:10px;margin-bottom:14px}
.form-err:not(:empty){display:block}
.form-success{display:none;background:#e8f5e9;border:1px solid rgba(46,125,82,.25);
  color:#2e7d32;font-size:13px;padding:10px 14px;border-radius:10px;margin-bottom:14px}
.form-success:not(:empty){display:block}
.form-link{text-align:center;font-size:12.5px;color:#5a8a72;margin-top:14px}
.form-link a{color:#16503f;font-weight:700;text-decoration:none}
.form-link a:hover{text-decoration:underline}

/* Bouton principal */
.btn-primary{display:block;width:100%;padding:14px;
  background:linear-gradient(135deg,#16503f,#1e6b54);color:#fff;
  border:none;border-radius:13px;font-size:15px;font-weight:700;
  cursor:pointer;transition:all .2s;font-family:inherit;
  box-shadow:0 4px 16px rgba(22,80,63,.25);letter-spacing:.2px;margin-top:4px}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(22,80,63,.35)}
.btn-primary:active{transform:none;box-shadow:none}
.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* Pending card */
.pending-card{background:#fff;border:1px solid rgba(22,80,63,.1);border-radius:18px;
  padding:28px 24px;text-align:center}
.pending-card .p-icon{font-size:52px;margin-bottom:16px}
.pending-card h3{font-family:'Playfair Display',serif;font-size:20px;color:#091f17;margin-bottom:8px}
.pending-card p{font-size:13.5px;color:#5a8a72;line-height:1.7;margin-bottom:8px}
.pending-id{background:#e8f5f0;border:1px solid rgba(22,80,63,.15);border-radius:10px;
  padding:10px 16px;font-family:monospace;font-size:15px;font-weight:700;
  color:#16503f;margin:10px 0;letter-spacing:.5px}

/* Divider */
.divider{display:flex;align-items:center;gap:10px;color:rgba(22,80,63,.35);
  font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;
  margin:14px 0}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:rgba(22,80,63,.12)}
