/* ============================================================
   EchoFirst — Application Formation MERM
   Design system unifié (fusion carnet v1 + backlog v1)
   ============================================================ */
:root{
  --navy:#10396E; --navy-dark:#0B2A52;
  --teal:#00A2B5; --teal-dark:#008a9b; --teal-light:#CCEEF2; --teal-vif:#4FD2E0;
  --ink:#212529; --grey:#5d6b7a; --border:#D8E2EF; --bg:#EDF2F9; --white:#fff;
  --paper:#E7EEF8; --tint:#DCE7F5;
  --green:#1f9d55; --green-light:#D5F0E0;
  --orange:#e0a106; --orange-light:#FAEBBE;
  --red:#e74c3c; --red-light:#FBDED9;
  --amber-bg:#FBEFD8; --amber-ink:#9a6a16;
  /* variables sémantiques (thématisation clair/sombre) */
  --card:#fff;            /* fonds de cartes, inputs, boutons ghost */
  --heading:#10396E;      /* texte titres (navy en clair, lisible en sombre) */
  --stripe:#EAF0F8;       /* lignes paires des tableaux */
  --pill-bg:#E2E9F2;      /* fonds neutres (pills pending/draft, hover) */
  --border-2:#C9D6E7;     /* bordures secondaires / pointillés */
  --row-line:#E8EEF6;     /* séparateurs de lignes (backlog) */
  --muted:#8C99A8;        /* texte atténué */
  --teal-ink:#056574; --green-ink:#15663B; --orange-ink:#8a6400; --red-ink:#a52d20;
}

/* ---------------- MODE SOMBRE ---------------- */
html[data-theme="dark"]{
  color-scheme:dark;
  --bg:#0D1626; --white:#16213A; --card:#16213A;
  --paper:#18253E; --tint:#1B2A45;
  --border:#24344F; --border-2:#324663; --row-line:#1F2E4A;
  --ink:#E8EEF7; --grey:#9FB0C8; --muted:#5F7390; --heading:#D9E5F6;
  --stripe:#1B2A45; --pill-bg:#243450;
  --teal-light:#0E3340; --teal-ink:#58CDD8;
  --green-light:#11301F; --green-ink:#58D68D;
  --orange-light:#33270C; --orange-ink:#F2C14E;
  --red-light:#371A16; --red-ink:#F1948A;
  --amber-bg:#33270C; --amber-ink:#E0B765;
}
html[data-theme="dark"] .banner,html[data-theme="dark"] .banner.ok,html[data-theme="dark"] .banner.warn{border-color:transparent;}
html[data-theme="dark"] .mod:hover{box-shadow:0 10px 28px rgba(0,0,0,.3);}
html[data-theme="dark"] .ccard.clickable:hover{box-shadow:0 8px 22px rgba(0,0,0,.3);}
html[data-theme="dark"] .dash-card:hover{box-shadow:0 10px 26px rgba(0,0,0,.4);}
html[data-theme="dark"] .modal{box-shadow:0 14px 44px rgba(0,0,0,.45);}
html[data-theme="dark"] .team-panel,html[data-theme="dark"] .refmenu{box-shadow:0 10px 30px rgba(0,0,0,.35);}
html[data-theme="dark"] .pill.todo{background:transparent;}
html[data-theme="dark"] footer{background:transparent;}
html[data-theme="dark"] #loginScreen{background:linear-gradient(135deg,#0A1220 0%,#10213C 100%);}
html[data-theme="dark"] header.hero{background:linear-gradient(120deg,#13223C 0%,#0F2C3C 100%);border-bottom-color:var(--border);}
html[data-theme="dark"] .hero-badge{background:rgba(79,210,224,.14);color:var(--teal-ink);}
html[data-theme="dark"] .brand img{filter:brightness(0) invert(1);opacity:.95;}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Poppins',arial,tahoma,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;font-size:15px;}
.container{max-width:1140px;margin:0 auto;padding:0 24px;}
button{font-family:inherit;cursor:pointer;}
input,select,textarea{font-family:inherit;font-size:14px;}

/* ---------------- NAV ---------------- */
nav.appnav{position:sticky;top:0;background:var(--white);border-bottom:1px solid var(--border);z-index:50;}
.nav-inner{max-width:1140px;margin:0 auto;padding:10px max(24px,env(safe-area-inset-right)) 10px max(24px,env(safe-area-inset-left));display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;}
.brand img{height:26px;width:auto;display:block;}
.brand-tag{font-size:11px;color:var(--grey);font-weight:500;margin-left:4px;border-left:1px solid var(--border);padding-left:10px;white-space:nowrap;}
/* en grand écran : actions ancrées en haut à droite (les onglets restent en 2e ligne) */
.nav-right{position:absolute;top:6px;right:24px;display:flex;align-items:center;gap:12px;flex-wrap:nowrap;}

/* bouton burger (smartphone uniquement) */
.nav-burger{display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;width:40px;height:40px;padding:0;border:1px solid var(--border);background:var(--card);border-radius:10px;cursor:pointer;flex-shrink:0;}
.nav-burger span{display:block;width:20px;height:2px;background:var(--heading);border-radius:2px;transition:.2s;}
.appnav.menu-open .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.appnav.menu-open .nav-burger span:nth-child(2){opacity:0;}
.appnav.menu-open .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* tabs de modules */
.navtabs{max-width:1140px;margin:0 auto;padding:2px 24px 0;display:flex;gap:6px;overflow-x:auto;}
.navtabs a{text-decoration:none;color:var(--grey);font-size:13.5px;font-weight:500;padding:13px 18px;border-bottom:2px solid transparent;border-radius:10px 10px 0 0;white-space:nowrap;transition:.15s;}
.navtabs a:hover{color:var(--heading);background:var(--tint);}
.navtabs a.active{color:var(--heading);font-weight:600;border-bottom-color:var(--teal);background:transparent;}

.icon-btn{border:1px solid var(--border);background:var(--card);color:var(--heading);font-size:12.5px;font-weight:500;padding:8px 14px;border-radius:30px;transition:.15s;}
.icon-btn:hover{border-color:var(--teal);color:var(--teal);}

/* badge du compte connecté */
.role-badge{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--heading);background:var(--bg);border:1px solid var(--border);border-radius:30px;padding:5px 14px 5px 5px;max-width:220px;}
.role-badge span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.role-badge .avatar{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;background:var(--teal);flex-shrink:0;}

/* ---------------- ÉCRAN DE CONNEXION ---------------- */
body.login-mode{overflow:hidden;}
#loginScreen{position:fixed;inset:0;z-index:500;background:linear-gradient(135deg,#D8E4F4 0%,#C4E6EB 100%);display:flex;align-items:center;justify-content:center;padding:max(24px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(24px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));overflow:auto;}
#loginScreen[hidden]{display:none;}
.login-card{background:var(--card);border:1px solid var(--border);border-radius:20px;box-shadow:0 14px 40px rgba(16,57,110,.10);max-width:440px;width:100%;padding:34px 34px 24px;margin:auto;}
.login-logo{height:34px;display:block;margin:0 auto 18px;}
html[data-theme="dark"] .login-logo{filter:brightness(0) invert(1);opacity:.95;}
.login-card h1{font-size:20px;font-weight:800;color:var(--heading);text-align:center;letter-spacing:-.4px;line-height:1.25;}
.login-sub{font-size:13px;color:var(--grey);text-align:center;margin:6px 0 22px;}
#loginForm label{display:block;font-size:12px;font-weight:600;color:var(--heading);margin:12px 0 5px;}
#loginForm input{width:100%;border:1px solid var(--border);border-radius:10px;padding:11px 13px;font-size:14.5px;background:var(--card);color:var(--ink);outline:none;}
#loginForm input:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,162,181,.12);}
.login-error{background:var(--red-light);color:var(--red-ink);font-size:12.5px;border-radius:8px;padding:9px 12px;margin-top:12px;}
.login-submit{width:100%;margin-top:16px;}
.login-demo{margin-top:22px;border-top:1px solid var(--border);padding-top:16px;}
.login-demo-title{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--grey);margin-bottom:10px;}
.login-acc{display:flex;align-items:center;gap:11px;width:100%;border:1px solid var(--border);background:var(--card);border-radius:12px;padding:10px 12px;margin-bottom:8px;text-align:left;transition:.15s;}
.login-acc:hover{border-color:var(--teal);background:var(--teal-light);}
.login-acc .avatar{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;background:var(--navy);flex-shrink:0;}
.login-acc .la-body{flex:1;min-width:0;}
.login-acc .la-name{display:block;font-size:13.5px;font-weight:600;color:var(--heading);}
.login-acc .la-desc{display:block;font-size:11px;color:var(--grey);line-height:1.4;}
.login-acc .la-cred{font-size:11px;font-weight:600;color:var(--teal-ink);background:var(--teal-light);border-radius:20px;padding:3px 10px;white-space:nowrap;flex-shrink:0;}
.login-foot{font-size:10.5px;color:var(--muted);text-align:center;margin-top:16px;}

/* ---------------- HERO ---------------- */
header.hero{background:linear-gradient(120deg,#DFE9F6 0%,#CFE9EE 100%);color:var(--ink);padding:32px 0 28px;border-bottom:1px solid var(--border);}
.hero-badge{display:inline-block;background:rgba(0,162,181,.18);border:1px solid transparent;color:var(--teal-ink);font-size:11px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;padding:5px 13px;border-radius:30px;margin-bottom:12px;}
.hero h1{font-size:clamp(20px,3vw,28px);font-weight:700;line-height:1.18;letter-spacing:-.6px;color:var(--heading);}
.hero h1 .accent{color:var(--teal);}
.hero-sub{margin-top:8px;font-size:14px;font-weight:400;color:var(--grey);}
.hero-sub strong{color:var(--heading);font-weight:600;}

main{padding:64px 0 72px;min-height:55vh;}
.view{display:none;}
.view.active{display:block;}
/* ---- tête de page : kicker + titre + lead ---- */
.kicker{display:flex;align-items:center;gap:14px;color:var(--teal-ink);font-size:14px;font-weight:700;letter-spacing:2.6px;text-transform:uppercase;margin-bottom:18px;}
.kicker::before{content:'';width:44px;height:3px;border-radius:2px;background:var(--teal);flex-shrink:0;}
h2{font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--heading);letter-spacing:-.6px;line-height:1.18;}
h2 .h2-light{font-weight:400;color:var(--grey);font-size:.72em;letter-spacing:-.3px;}
.section-lead{margin-top:14px;margin-bottom:34px;font-size:15px;line-height:1.7;color:var(--grey);max-width:680px;}
.section-lead b{color:var(--heading);}

/* ---------------- STAT CARDS ---------------- */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:0;margin:28px 0;background:linear-gradient(180deg,var(--card),var(--paper));border:1px solid var(--border);border-top:3px solid var(--teal);border-radius:14px;padding:20px 4px;box-shadow:0 1px 3px rgba(16,57,110,.05);}
.stat{background:transparent;border:none;border-right:1px solid var(--border);border-radius:0;padding:2px 24px;}
.stat:last-child{border-right:none;}
.stat .n{font-size:24px;font-weight:700;color:var(--heading);line-height:1.1;}
.stat .n.teal{color:var(--teal);}
.stat .n.warn{color:var(--orange);}
.stat .l{font-size:11.5px;color:var(--grey);margin-top:5px;}

/* tableau de bord étudiant : bloc dédié « Durée de mon parcours » */
.parcours-card{display:flex;align-items:center;gap:22px;margin:8px 0 28px;padding:22px 26px;border-radius:18px;background:linear-gradient(120deg,var(--navy) 0%,var(--teal-dark) 100%);color:#fff;box-shadow:0 10px 30px rgba(16,57,110,.18);}
.parcours-card .pc-ico{font-size:36px;line-height:1;flex-shrink:0;opacity:.92;}
.parcours-card .pc-kicker{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;opacity:.85;}
.parcours-card .pc-figure{font-size:34px;font-weight:700;line-height:1.1;margin:4px 0 2px;}
.parcours-card .pc-figure span{font-size:18px;font-weight:500;opacity:.9;}
.parcours-card .pc-sub{font-size:13.5px;opacity:.94;}
.parcours-card .pc-sub b{font-weight:700;}
.parcours-card .pc-opt{margin-top:8px;display:inline-block;font-size:12px;font-weight:600;background:rgba(255,255,255,.16);border-radius:20px;padding:4px 12px;}

/* ---------------- BANNER ---------------- */
.banner{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:space-between;background:var(--teal-light);border:1px solid transparent;border-radius:14px;padding:18px 22px;margin:22px 0;}
.banner.ok{background:var(--green-light);border-color:transparent;}
.banner.warn{background:var(--orange-light);border-color:transparent;}
.banner-txt{font-size:14px;color:var(--teal-ink);}
.banner.ok .banner-txt{color:var(--green-ink);}
.banner.warn .banner-txt{color:var(--orange-ink);}
.banner-txt strong{color:var(--heading);}

/* ---------------- CARNET : blocs & vacations ---------------- */
.block{background:var(--card);border:1px solid var(--border);border-radius:16px;margin-top:24px;padding:26px 28px;}
.block-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.block-tag{flex-shrink:0;background:var(--tint);color:var(--heading);font-size:10.5px;font-weight:700;letter-spacing:.8px;border-radius:6px;padding:5px 9px;text-transform:uppercase;}
.block.opt .block-tag,.block-tag[data-opt]{background:var(--teal-light);color:var(--teal-ink);}
.block-title{font-weight:600;color:var(--heading);font-size:16px;flex:1;min-width:160px;}
.block-title .sub{display:block;font-weight:400;color:var(--grey);font-size:12.5px;}
.block-count{font-size:13px;color:var(--grey);font-weight:600;white-space:nowrap;}
.block-count b{color:var(--heading);font-size:15px;}
.bar{height:6px;background:var(--tint);border:none;border-radius:8px;overflow:hidden;margin:14px 0 16px;}
.bar-fill{height:100%;background:var(--teal);border-radius:8px;transition:width .25s;}
.vac-grid{display:flex;flex-wrap:wrap;gap:7px;}
.vac-pack{display:flex;gap:7px;padding-right:8px;margin-right:2px;border-right:1px dashed var(--border-2);}
.vac-pack:last-child{border-right:none;}
.vac{width:34px;height:34px;border-radius:8px;border:1px solid var(--border-2);background:var(--card);color:var(--grey);font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;transition:.12s;position:relative;}
.vac:hover{border-color:var(--teal);color:var(--teal);}
.vac.checked{background:var(--teal);border-color:var(--teal);color:#fff;}
.vac.milestone::after{content:'';position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--teal-vif);}
.vac.checked.milestone::after{background:var(--card);}
.vac.noenc.checked{box-shadow:inset 0 0 0 2px #fff, inset 0 0 0 3px var(--orange);}
/* états d'échantillon par vacation (1 image tirée au sort par vacation cochée) */
.vac.a_deposer{background:var(--orange-light);border-color:var(--orange);color:var(--orange-ink);}
.vac.pending{background:var(--pill-bg);border-color:var(--border-2);color:var(--grey);}
.vac.valide{background:var(--green);border-color:var(--green);color:#fff;}
.vac.a_refaire{background:var(--red);border-color:var(--red);color:#fff;}
.block-count .bc-sub{font-weight:500;color:var(--grey);}
/* lignes d'action sous un bloc : image à déposer / vacation à refaire */
.vac-actions{margin-top:14px;display:flex;flex-direction:column;gap:8px;}
.vac-action{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:space-between;background:var(--orange-light);border-radius:12px;padding:10px 14px;}
.vac-action.refaire{background:var(--red-light);}
.vac-action .va-txt{font-size:13px;color:var(--orange-ink);}
.vac-action.refaire .va-txt{color:var(--red-ink);}
.vac-action .va-txt i{font-style:normal;font-weight:600;}
.vac-action .va-cmt{display:block;font-style:italic;font-weight:400;margin-top:2px;opacity:.9;}
/* panneau de référence : listing des images attendues du module */
.img-listing{margin-top:14px;border-top:1px dashed var(--border-2);padding-top:10px;}
.img-listing summary{cursor:pointer;font-size:12.5px;font-weight:600;color:var(--teal-ink);list-style:none;}
.img-listing summary::-webkit-details-marker{display:none;}
.img-listing ul{margin:10px 0 2px;padding-left:18px;display:flex;flex-direction:column;gap:7px;}
.img-listing li{font-size:13px;color:var(--ink);}
.img-listing li b{color:var(--heading);}
.img-listing li span{display:block;font-size:12px;color:var(--grey);margin-top:1px;}

/* ---------------- CARNET : échantillons ---------------- */
.samples-wrap{margin-top:14px;display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px;}
.sample{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--card);}
.sample .thumb{height:130px;background:#0b2a52;display:flex;align-items:center;justify-content:center;color:#9fb3d1;font-size:12px;overflow:hidden;cursor:pointer;}
.sample .thumb img{width:100%;height:100%;object-fit:cover;}
.sample .s-body{padding:12px 14px;}
.sample .s-meta{font-size:12px;color:var(--grey);}
.sample .s-meta b{color:var(--heading);}
.sample .s-comment{margin-top:8px;font-size:12.5px;color:var(--ink);background:var(--bg);border-radius:8px;padding:8px 10px;}

.pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;border-radius:20px;padding:4px 11px;}
.pill::before{content:'';width:6px;height:6px;border-radius:50%;}
.pill.pending{background:var(--pill-bg);color:var(--grey);}.pill.pending::before{background:var(--muted);}
.pill.valide,.pill.passed{background:var(--green-light);color:var(--green-ink);}.pill.valide::before,.pill.passed::before{background:var(--green);}
.pill.a_ameliorer{background:var(--orange-light);color:var(--orange-ink);}.pill.a_ameliorer::before{background:var(--orange);}
.pill.a_refaire,.pill.failed{background:var(--red-light);color:var(--red-ink);}.pill.a_refaire::before,.pill.failed::before{background:var(--red);}
.pill.draft{background:var(--pill-bg);color:var(--grey);}.pill.draft::before{background:var(--muted);}
.pill.published{background:var(--teal-light);color:var(--teal-ink);}.pill.published::before{background:var(--teal);}
.pill.todo{background:var(--card);color:var(--muted);border:1px dashed var(--border-2);}.pill.todo::before{background:var(--border-2);}

/* ---------------- BUTTONS ---------------- */
.btn{display:inline-block;background:var(--teal);color:#fff;border:none;text-decoration:none;font-weight:600;font-size:13.5px;padding:10px 20px;border-radius:30px;transition:background .2s;text-align:center;}
.btn:hover{background:var(--teal-dark);}
.btn.small{padding:7px 15px;font-size:12.5px;}
.btn.ghost{background:var(--card);color:var(--heading);border:1px solid var(--border);}
.btn.ghost:hover{border-color:var(--teal);color:var(--teal);background:var(--card);}
.btn.navy{background:var(--navy);}.btn.navy:hover{background:var(--navy-dark);}
.btn:disabled{opacity:.5;cursor:not-allowed;}
.btn.valide{background:var(--green);}.btn.valide:hover{background:#178246;}
.btn.ameliorer{background:var(--orange);}.btn.ameliorer:hover{background:#c08c00;}
.btn.refaire,.btn.danger{background:var(--red);}.btn.refaire:hover,.btn.danger:hover{background:#cf3f30;}

/* ---------------- REVUE (équipe) ---------------- */
.toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:18px 0;}
.toolbar select,.toolbar input{border:1px solid var(--border);border-radius:8px;padding:8px 10px;background:var(--card);}
.toolbar label{font-size:12.5px;font-weight:600;color:var(--heading);}
.review-card{display:grid;grid-template-columns:160px 1fr;gap:18px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px;margin-top:14px;}
.rc-thumb{height:130px;border-radius:10px;background:#0b2a52;overflow:hidden;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#9fb3d1;font-size:12px;}
.rc-thumb img{width:100%;height:100%;object-fit:cover;}
.rc-meta{font-size:12.5px;color:var(--grey);margin-bottom:4px;}
.rc-meta b{color:var(--heading);}
.lat-badge{display:inline-block;font-size:11px;font-weight:700;background:var(--teal-light);color:var(--teal-ink);border-radius:20px;padding:2px 9px;}
.rc-img{font-size:13px;color:var(--teal-ink);background:var(--teal-light);border-radius:10px;padding:8px 12px;margin:2px 0 8px;}
.rc-img b{color:var(--heading);}
.rc-img .rc-img-desc{display:block;font-size:12px;color:var(--grey);margin-top:2px;}
.anon-badge{display:inline-block;font-size:11px;background:var(--teal-light);color:var(--teal-ink);border-radius:20px;padding:3px 10px;margin-top:4px;}
.anon-badge.warn{background:var(--orange-light);color:var(--orange-ink);}
.rc-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;}
.rc-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:10px;}
.rc-controls select{border:1px solid var(--border);border-radius:8px;padding:8px 10px;background:var(--card);}
.rc-comment{width:100%;border:1px solid var(--border);border-radius:8px;padding:9px 11px;margin-top:8px;resize:vertical;min-height:48px;}
.empty{background:var(--card);border:1px dashed var(--border-2);border-left:3px solid var(--teal);border-radius:14px;padding:34px 30px;text-align:center;color:var(--grey);font-size:14px;margin-top:18px;}

/* ---------------- ADMIN ---------------- */
.adm-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px 26px;margin-top:18px;box-shadow:0 1px 3px rgba(16,57,110,.05);}
.adm-card:nth-of-type(even){background:linear-gradient(180deg,var(--card),var(--tint));}
.adm-card h3{color:var(--heading);font-size:16px;margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.adm-card h3::before{content:'';width:4px;height:18px;border-radius:3px;background:linear-gradient(180deg,var(--teal),var(--teal-vif));flex-shrink:0;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--heading);margin-bottom:6px;}
.field input,.field select{width:100%;max-width:420px;border:1px solid var(--border);border-radius:8px;padding:10px 12px;background:var(--card);}
.field .hint{font-size:11.5px;color:var(--grey);margin-top:4px;}
.adm-row{display:grid;grid-template-columns:1fr 1.6fr 90px 100px 44px;gap:10px;align-items:center;margin-bottom:8px;}
.adm-row input{border:1px solid var(--border);border-radius:8px;padding:8px 10px;width:100%;}
.adm-row .rm{border:1px solid var(--border);background:var(--card);color:var(--red);border-radius:8px;padding:8px;font-weight:700;}
.adm-head{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--grey);font-weight:700;}
.adm-total{margin-top:12px;font-size:13px;color:var(--heading);font-weight:600;}
.enc-row{display:grid;grid-template-columns:1fr 1fr 40px;gap:10px;align-items:center;margin-bottom:8px;}
.enc-row input{border:1px solid var(--border);border-radius:8px;padding:9px 11px;width:100%;}
.enc-row .rm{border:1px solid var(--border);background:var(--card);color:var(--red);border-radius:8px;padding:8px;font-weight:700;}
/* éditeur admin du listing des images attendues par module */
.eimg-block{border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:12px;background:var(--card);}
.eimg-block-head{font-size:13.5px;margin-bottom:10px;}
.eimg-block-head b{color:var(--heading);}
.eimg-block-head .eimg-count{float:right;font-size:11px;color:var(--grey);font-weight:600;}
.eimg-rows{display:flex;flex-direction:column;gap:8px;}
.eimg-row{display:grid;grid-template-columns:1fr 1.6fr 40px;gap:10px;align-items:center;}
.eimg-row input{border:1px solid var(--border);border-radius:8px;padding:9px 11px;width:100%;}
.eimg-row .rm{border:1px solid var(--border);background:var(--card);color:var(--red);border-radius:8px;padding:8px;font-weight:700;}
.stu-row{display:grid;grid-template-columns:1fr 1fr 1.1fr 1.2fr .8fr 1.3fr 1fr .9fr 40px;gap:8px;align-items:center;margin-bottom:8px;}
.stu-row input,.stu-row select{border:1px solid var(--border);border-radius:8px;padding:9px 10px;width:100%;background:var(--card);}
.stu-row input[type=checkbox]{width:auto;}
.stu-row .rm{border:1px solid var(--border);background:var(--card);color:var(--red);border-radius:8px;padding:8px;font-weight:700;}
.stu-opts{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.stu-opts label{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;color:var(--teal-dark);white-space:nowrap;cursor:pointer;}
.stu-opts-none{color:var(--grey);}

/* ---------------- COMPTES & ACCÈS (admin) ---------------- */
.cpt-row{display:grid;grid-template-columns:1.6fr .9fr 1.2fr auto;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);}
.cpt-row.cpt-head{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--grey);font-weight:700;border-bottom:2px solid var(--border);}
.cpt-user{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.cpt-actions{display:flex;gap:6px;justify-content:flex-end;align-items:center;flex-wrap:wrap;}
.cpt-actions .rm{border:1px solid var(--border);background:var(--card);color:var(--red);border-radius:8px;padding:6px 10px;font-weight:700;}
.cpt-pw-list{display:flex;flex-direction:column;gap:8px;margin-bottom:6px;}
.cpt-pw{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 12px;background:var(--tint);border:1px solid var(--border);border-radius:8px;}
.cpt-pw code{font-family:ui-monospace,Menlo,Consolas,monospace;font-weight:700;color:var(--heading);background:var(--card);padding:3px 8px;border-radius:6px;border:1px solid var(--border);user-select:all;}
.cpt-pw.err{color:var(--red);}
@media (max-width:760px){ .cpt-row{grid-template-columns:1fr;gap:4px;} .cpt-row.cpt-head{display:none;} .cpt-actions{justify-content:flex-start;} }

/* ---------------- CONSENTEMENT & LIENS LÉGAUX ---------------- */
.consent-row{display:flex;gap:10px;align-items:flex-start;font-size:14px;line-height:1.5;}
.consent-row input{width:auto;margin-top:3px;flex-shrink:0;}
.legal-links{margin-top:8px;font-size:12.5px;opacity:.9;}
.login-legal{margin-top:8px;font-size:12px;text-align:center;color:var(--grey);}

/* ---------------- COHORTES (admin) ---------------- */
.coh-item{border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px;background:var(--tint);}
.coh-grid{display:grid;grid-template-columns:1.4fr .9fr .9fr .9fr 1.4fr;gap:12px;align-items:end;}
.coh-grid .field{margin-bottom:0;}
.coh-grid .field input,.coh-grid .field select{max-width:none;}
.coh-name-row{display:flex;gap:8px;align-items:center;}
.coh-name-row input[type=color]{width:34px;min-width:34px;height:38px;padding:2px;border:1px solid var(--border);border-radius:8px;background:var(--card);cursor:pointer;flex-shrink:0;}
.coh-name-row input[data-cf="nom"]{flex:1;}
.coh-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px;vertical-align:middle;}
.coh-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:14px;}
.coh-temporal{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:12.5px;color:var(--heading);flex:1;min-width:240px;}
.coh-temporal .coh-fin,.coh-temporal .coh-week{color:var(--grey);}
.coh-temporal .coh-pct{font-weight:700;min-width:38px;text-align:right;}
.coh-meta{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--grey);}
.coh-meta .rm{border:1px solid var(--border);background:var(--card);color:var(--red);border-radius:8px;padding:6px 10px;font-weight:700;}

/* ---------------- ENVOI FINAL DU CARNET (étudiant) ---------------- */
.final-cta{display:flex;align-items:center;gap:22px;flex-wrap:wrap;justify-content:space-between;margin-top:30px;
  background:linear-gradient(120deg,var(--tint),var(--teal-light));border:1px solid var(--border);border-left:4px solid var(--teal);border-radius:16px;padding:22px 26px;}
.final-cta.ready{border-left-color:var(--green-ink);background:linear-gradient(120deg,var(--tint),var(--green-light));}
.final-cta .fc-title{font-size:16px;font-weight:700;color:var(--heading);}
.final-cta .fc-sub{font-size:13px;color:var(--grey);margin-top:6px;max-width:560px;line-height:1.55;}
.final-cta .fc-check{list-style:none;margin:10px 0 0;padding:0;font-size:13px;color:var(--grey);}
.final-cta .fc-check li{padding:3px 0;}
.final-cta .fc-check li.ok{color:var(--green-ink);font-weight:600;}
.final-cta .btn[disabled]{opacity:.5;cursor:not-allowed;}
/* carnet verrouillé : la grille de vacations n'est plus cliquable */
.carnet-locked .vac{cursor:default;opacity:.85;}
.carnet-locked .block .banner{display:none;}

/* ---------------- EXAMEN PRATIQUE FINAL (module) ---------------- */
.ep-panel-row td{background:var(--tint) !important;padding:0 !important;}
.ep-panel{padding:20px 22px;}
.ep-note{font-size:13px;color:var(--grey);line-height:1.6;}
.ep-form{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-bottom:12px;}
.ep-form.ep-result{border-left:3px solid var(--teal);}
.ep-subtitle{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--teal-ink);margin-bottom:12px;}
.ep-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;}
.ep-grid .field{margin-bottom:6px;}
.ep-grid .field input,.ep-grid .field select{max-width:none;}
.ep-examinateurs{display:flex;flex-wrap:wrap;gap:8px 18px;}
.ep-chk{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink);background:var(--tint);border-radius:8px;padding:7px 12px;cursor:pointer;}
.ep-chk input{accent-color:var(--teal);width:15px;height:15px;}
.ep-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px;}
.ep-card{background:var(--card);border:1px solid var(--border);border-top:3px solid var(--teal);border-radius:16px;padding:22px 26px;margin-top:22px;box-shadow:0 1px 3px rgba(16,57,110,.05);}
.ep-card-h{display:flex;align-items:center;gap:10px;font-size:18px;color:var(--heading);margin-bottom:14px;}

/* ---------------- ENCADRANT BAR ---------------- */
.enc-bar{display:flex;align-items:center;gap:18px;flex-wrap:wrap;background:var(--tint);border:none;border-radius:14px;padding:14px 20px;margin:18px 0 28px;}
.enc-field{display:flex;flex-direction:column;gap:4px;}
.enc-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.enc-field label{font-size:10.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--teal-ink);}
.enc-bar label{font-size:12.5px;font-weight:600;color:var(--heading);}
.enc-select{position:relative;display:inline-flex;align-items:center;min-width:300px;background:var(--card);border:1px solid var(--border-2);border-radius:10px;box-shadow:0 1px 2px rgba(16,57,110,.05);transition:border-color .15s,box-shadow .15s;}
.enc-select:hover{border-color:var(--teal);}
.enc-select:focus-within{border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,162,181,.18);}
.enc-avatar{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;margin-left:7px;border-radius:50%;background:var(--teal);color:#fff;font-size:11px;font-weight:700;letter-spacing:.3px;flex-shrink:0;}
.enc-bar .enc-select select{appearance:none;-webkit-appearance:none;-moz-appearance:none;border:none;background:transparent;box-shadow:none;outline:none;flex:1;min-width:0;padding:9px 34px 9px 10px;font-weight:600;font-size:13.5px;color:var(--heading);cursor:pointer;}
.enc-chevron{position:absolute;right:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--grey);pointer-events:none;transition:color .15s;}
.enc-select:hover .enc-chevron,.enc-select:focus-within .enc-chevron{color:var(--teal);}
.enc-switch{display:inline-flex;align-items:center;gap:10px;font-size:12.5px;font-weight:500;color:var(--heading);margin-left:auto;cursor:pointer;}
.enc-switch input{appearance:none;-webkit-appearance:none;width:36px;height:20px;border-radius:20px;background:var(--border-2);position:relative;transition:background .2s;cursor:pointer;margin:0;flex-shrink:0;}
.enc-switch input::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--card);box-shadow:0 1px 3px rgba(0,0,0,.2);transition:left .2s;}
.enc-switch input:checked{background:var(--teal);}
.enc-switch input:checked::after{left:18px;}
.suivi-tbl{width:100%;border-collapse:collapse;margin-top:14px;background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.suivi-tbl th{background:var(--paper);color:var(--heading);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;text-align:left;padding:12px 14px;border-bottom:1px solid var(--border-2);}
.suivi-tbl td{font-size:13px;padding:11px 14px;border-top:1px solid var(--border);}
.suivi-tbl tr:nth-child(even) td{background:var(--stripe);}

/* ---------------- OVERLAY / MODAL ---------------- */
.overlay{position:fixed;inset:0;background:rgba(11,42,82,.55);z-index:200;display:none;align-items:flex-start;justify-content:center;padding:30px 16px;overflow:auto;}
.overlay.active{display:flex;}
.modal{background:var(--card);border:1px solid var(--border);border-radius:18px;max-width:680px;width:100%;padding:28px 30px;box-shadow:0 14px 44px rgba(11,42,82,.10);}
.modal.wide{max-width:860px;}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.modal-head h3{color:var(--heading);font-size:18px;}
.modal-close{border:none;background:var(--bg);width:34px;height:34px;border-radius:50%;color:var(--grey);font-size:18px;}
.modal-close:hover{background:var(--pill-bg);color:var(--ink);}
.modal-sub{font-size:13px;color:var(--grey);margin-bottom:18px;}
.drop{border:1.5px dashed var(--border-2);border-radius:14px;padding:36px 30px;text-align:center;color:var(--grey);font-size:14px;display:block;cursor:pointer;}
.drop input{display:none;}
.preview-wrap{position:relative;margin:16px 0;background:#0b2a52;border-radius:12px;overflow:hidden;display:flex;justify-content:center;}
.preview-wrap canvas{max-width:100%;display:block;}
.crop-overlay{position:absolute;left:0;top:0;width:100%;background:rgba(231,76,60,.45);border-bottom:2px solid #e74c3c;pointer-events:none;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.4);}
.slider-row{display:flex;align-items:center;gap:14px;margin:8px 0 4px;}
.slider-row label{font-size:12.5px;font-weight:600;color:var(--heading);white-space:nowrap;}
.slider-row input[type=range]{flex:1;accent-color:var(--teal);}
.slider-val{font-size:12.5px;color:var(--grey);width:74px;text-align:right;}
.meta-list{font-size:12.5px;color:var(--grey);background:var(--bg);border-radius:10px;padding:12px 14px;margin:8px 0;}
.meta-list div{padding:2px 0;}
.meta-list b{color:var(--heading);}
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:12px 0;}
.ba-grid .cell{text-align:center;}
.ba-grid .cell h4{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--grey);margin-bottom:6px;}
.ba-grid .media-box{background:#0b2a52;border-radius:10px;overflow:hidden;min-height:120px;display:flex;align-items:center;justify-content:center;}
.ba-grid img,.ba-grid video{max-width:100%;max-height:240px;display:block;}
.warnbox{background:var(--orange-light);border-radius:10px;padding:12px 14px;font-size:12.5px;color:var(--orange-ink);margin:10px 0;}
.warnbox.info{background:var(--teal-light);color:var(--teal-ink);}
.confirm-row{display:flex;align-items:flex-start;gap:10px;margin:14px 0;font-size:13.5px;color:var(--ink);}
.confirm-row input{margin-top:3px;width:17px;height:17px;accent-color:var(--teal);}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;margin-top:8px;}
.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:8px;}
@keyframes spin{to{transform:rotate(360deg);}}
.exp-list{display:flex;flex-direction:column;gap:10px;margin:8px 0 4px;}
.exp-item{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--border);border-radius:12px;padding:13px 16px;}
.exp-item .d{font-size:12px;color:var(--grey);line-height:1.45;}
.exp-item .d b:first-child{color:var(--heading);font-weight:600;display:block;font-size:13.5px;margin-bottom:2px;}
.exp-item .d b{color:var(--heading);font-weight:600;}
.exp-item .btn{flex-shrink:0;}

/* ---------------- BACKLOG ---------------- */
.bl-toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin:24px 0 14px;}
.bl-right{display:flex;align-items:center;gap:14px;}
.filters{display:flex;gap:8px;flex-wrap:wrap;}
.filters button{border:1px solid var(--border);background:var(--card);border-radius:30px;padding:9px 17px;font-size:12.5px;font-weight:600;color:var(--grey);transition:.15s;}
.filters button .n{opacity:.6;font-weight:500;}
.filters button:hover{border-color:var(--teal);color:var(--heading);}
.filters button.active{background:var(--teal-light);color:var(--teal-ink);border-color:var(--teal);}
.filters button.active .n{opacity:.75;}
.reset{border:none;background:none;color:var(--grey);font-size:12.5px;cursor:pointer;text-decoration:underline;}
.reset:hover{color:var(--heading);}
.btn-team{border:1px solid var(--border);background:var(--card);border-radius:30px;padding:9px 17px;font-size:12.5px;font-weight:600;color:var(--heading);display:inline-flex;align-items:center;gap:7px;transition:.15s;}
.btn-team:hover{border-color:var(--teal);}
.btn-team.open{background:var(--teal-light);color:var(--teal-ink);border-color:var(--teal);}
.refrow{margin:0 0 18px;}
.refrow .fdot{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;color:#fff;font-size:8px;font-weight:700;margin-right:6px;vertical-align:-4px;}
.team-panel{display:none;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:22px 24px;margin:0 0 18px;box-shadow:0 8px 24px rgba(16,57,110,.06);}
.team-panel.open{display:block;}
.team-panel h3{font-size:12.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--teal);font-weight:700;margin-bottom:14px;}
.team-list{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px;}
.team-member{display:inline-flex;align-items:center;gap:9px;background:var(--bg);border:1px solid var(--border);border-radius:30px;padding:6px 10px 6px 6px;font-size:13.5px;font-weight:500;color:var(--ink);}
.team-member .dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;}
.team-member .nass{font-size:11.5px;color:var(--grey);}
.team-member .rm{border:none;background:none;cursor:pointer;color:var(--muted);font-size:16px;line-height:1;padding:2px 4px;}
.team-member .rm:hover{color:#c0392b;}
.team-empty{font-size:13px;color:var(--grey);}
.team-add{display:flex;gap:10px;flex-wrap:wrap;}
.team-add input{flex:1;min-width:180px;max-width:320px;font-size:14px;padding:10px 14px;border:1px solid var(--border);border-radius:12px;outline:none;color:var(--ink);}
.team-add input:focus{border-color:var(--teal);}
.team-add button{font-size:13.5px;font-weight:600;background:var(--navy);color:#fff;border:none;border-radius:12px;padding:10px 22px;transition:background .15s;}
.team-add button:hover{background:var(--navy-dark);}
.rwrap{flex-shrink:0;}
.rchip{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;cursor:pointer;border:none;transition:transform .15s,box-shadow .15s;}
.rchip:hover{transform:scale(1.08);box-shadow:0 4px 12px rgba(16,57,110,.25);}
.rchip.empty{background:var(--card);border:1px dashed var(--border-2);color:var(--muted);font-size:15px;font-weight:500;}
.rchip.empty:hover{border-color:var(--teal);color:var(--teal);}
.refmenu{position:absolute;z-index:300;min-width:220px;background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 14px 40px rgba(16,57,110,.12);padding:8px;display:none;}
.refmenu.open{display:block;}
.refmenu .rm-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey);padding:8px 10px 6px;}
.refmenu button{display:flex;align-items:center;gap:10px;width:100%;border:none;background:none;font-size:13.5px;color:var(--ink);padding:8px 10px;border-radius:10px;text-align:left;}
.refmenu button:hover{background:var(--teal-light);}
.refmenu button.on{background:var(--tint);font-weight:600;}
.refmenu .dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9.5px;font-weight:700;color:#fff;flex-shrink:0;}
.refmenu .sep{height:1px;background:var(--border);margin:6px 4px;}
.refmenu .muted{color:var(--grey);}
.mod{background:var(--card);border:1px solid var(--border);border-radius:18px;margin-bottom:22px;overflow:hidden;transition:box-shadow .22s,border-color .22s;}
.mod:hover{border-color:var(--teal);box-shadow:0 10px 28px rgba(16,57,110,.06);}
.mod-head{display:flex;align-items:center;gap:14px;padding:20px 24px;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.mod-tag{flex-shrink:0;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;background:var(--tint);color:var(--heading);border-radius:6px;padding:5px 11px;}
.mod-title{font-weight:700;color:var(--heading);font-size:16.5px;flex:1;min-width:200px;letter-spacing:-.2px;}
.mod-meta{font-size:12.5px;color:var(--grey);white-space:nowrap;}
.mod-meta b{color:var(--heading);}
.mod-meta .dm{color:var(--teal-dark);font-weight:600;}
.course{display:flex;align-items:center;gap:14px;padding:12px 24px;border-bottom:1px solid var(--row-line);cursor:pointer;transition:background .12s;}
.course:last-child{border-bottom:none;}
.course:hover{background:var(--paper);}
.course:focus-visible{outline:2px solid var(--teal);outline-offset:-2px;background:var(--paper);}
.cbox{flex-shrink:0;width:22px;height:22px;border:1.5px solid var(--border-2);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:.15s;background:var(--card);}
.cbox svg{width:13px;height:13px;opacity:0;transform:scale(.5);transition:.15s;}
.course.done .cbox{background:var(--green);border-color:var(--green);}
.course.done .cbox svg{opacity:1;transform:scale(1);}
.cnum{flex-shrink:0;width:30px;font-size:12px;font-weight:600;color:var(--muted);font-variant-numeric:tabular-nums;}
.cname{flex:1;font-size:14px;color:var(--ink);min-width:0;}
.course.done .cname{color:var(--grey);text-decoration:line-through;text-decoration-color:var(--border-2);}
.cbadges{flex-shrink:0;display:flex;gap:7px;align-items:center;}
.cdur{font-size:12.5px;font-weight:600;color:var(--teal-dark);background:var(--teal-light);border-radius:20px;padding:3px 11px;white-space:nowrap;}
.cdiu{font-size:11.5px;font-weight:600;color:var(--heading);border:1px solid var(--border-2);background:var(--card);border-radius:20px;padding:3px 10px;white-space:nowrap;cursor:help;}
.cdiu.none{color:var(--muted);border-style:dashed;}
.cdiu.el{color:var(--teal-ink);border-color:var(--teal);background:var(--teal-light);}
.cdiu.hors{color:var(--amber-ink);background:var(--amber-bg);border-color:transparent;}
.cpub{font-size:11px;font-weight:600;color:var(--teal-ink);background:var(--teal-light);border-radius:20px;padding:3px 10px;white-space:nowrap;cursor:pointer;border:none;}
.cpub:hover{background:#cdeef2;}
.cpub.draft{color:var(--grey);background:var(--pill-bg);}
.legend{margin-top:26px;display:flex;flex-wrap:wrap;gap:10px 22px;font-size:12.5px;color:var(--grey);align-items:center;}
.legend .it{display:inline-flex;align-items:center;gap:8px;}

/* ---------------- EXAMENS : hub certificats + épreuves ---------------- */
.cert-hub{display:flex;align-items:center;gap:18px;max-width:620px;margin:30px auto 38px;background:linear-gradient(120deg,var(--navy-dark) 0%,var(--navy) 100%);color:#fff;border-radius:16px;padding:22px 26px;text-decoration:none;box-shadow:0 10px 28px rgba(11,42,82,.18);transition:transform .18s,box-shadow .18s;}
.cert-hub:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(11,42,82,.26);}
.cert-hub .ch-ico{width:48px;height:48px;border-radius:12px;background:rgba(255,255,255,.12);display:inline-flex;align-items:center;justify-content:center;font-size:23px;flex-shrink:0;}
.cert-hub .ch-txt{display:flex;flex-direction:column;gap:3px;flex:1;}
.cert-hub .ch-t{font-size:16.5px;font-weight:700;letter-spacing:-.2px;}
.cert-hub .ch-d{font-size:12.5px;color:#C9D8EC;}
.cert-hub .ch-arrow{font-size:22px;color:rgba(255,255,255,.6);transition:.18s;}
.cert-hub:hover .ch-arrow{color:var(--teal-vif);transform:translateX(3px);}

.xam{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:var(--card);border:1px solid var(--border-2);border-top:3px solid var(--navy);border-radius:12px;padding:18px 22px;margin-top:12px;box-shadow:0 4px 14px rgba(11,42,82,.06);}
html[data-theme="dark"] .xam{border-top-color:var(--teal);}
.xam .xofficial{font-size:10px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:var(--navy);margin-bottom:5px;}
html[data-theme="dark"] .xam .xofficial{color:var(--teal-ink);}
.xam .xt{font-weight:700;color:var(--heading);font-size:15.5px;letter-spacing:-.2px;}
.xam .xmeta{font-size:12.5px;color:var(--grey);margin-top:4px;}

/* ---------------- E-LEARNING ---------------- */.eblock{margin-top:40px;}
.eblock-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px;}
.eblock-head .block-tag{font-size:10.5px;}
.eblock-head h3{color:var(--heading);font-size:17px;flex:1;min-width:180px;}
.eblock-head .epct{font-size:12.5px;color:var(--grey);font-weight:600;}
.eblock-head .epct b{color:var(--teal-dark);}
.eblock.locked{opacity:.62;}
.lock-note{font-size:12.5px;color:var(--orange-ink);background:var(--orange-light);border-radius:20px;padding:3px 12px;font-weight:600;}
.ccards{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:14px;margin-top:14px;}
.ccard{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;display:flex;flex-direction:column;gap:10px;transition:box-shadow .2s,border-color .2s;position:relative;}
.ccard.clickable{cursor:pointer;}
.ccard.clickable:hover{border-color:var(--teal);box-shadow:0 8px 22px rgba(16,57,110,.06);}
.ccard.coming{background:var(--bg);}
.ccard .ct{font-size:13.5px;font-weight:600;color:var(--heading);line-height:1.4;min-height:38px;}
.ccard.coming .ct{color:var(--grey);}
.ccard .cmeta{display:flex;gap:7px;align-items:center;flex-wrap:wrap;font-size:11.5px;color:var(--grey);}
.ccard .cbarw{height:6px;background:var(--tint);border:none;border-radius:6px;overflow:hidden;}
.ccard .cbarf{height:100%;background:var(--teal);border-radius:6px;}
.ccard .cact{display:flex;gap:8px;align-items:center;margin-top:auto;}

/* page cours */
.crumb{font-size:12.5px;color:var(--grey);margin-bottom:14px;}
.crumb a{color:var(--teal-dark);text-decoration:none;font-weight:600;}
.crumb a:hover{text-decoration:underline;}
.lesson-grid{display:grid;grid-template-columns:280px 1fr;gap:20px;margin-top:18px;align-items:start;}
@media(max-width:840px){.lesson-grid{grid-template-columns:1fr;}}
.lesson-side{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px;position:sticky;top:104px;}
.lesson-side h4{font-size:11.5px;text-transform:uppercase;letter-spacing:1px;color:var(--grey);margin:6px 8px 10px;}
.litem{display:flex;align-items:center;gap:10px;width:100%;border:none;background:none;text-align:left;font-size:13px;color:var(--ink);padding:9px 10px;border-radius:10px;transition:.12s;}
.litem:hover{background:var(--teal-light);}
.litem.active{background:var(--tint);font-weight:600;color:var(--heading);}
.litem .lico{flex-shrink:0;width:22px;height:22px;border-radius:50%;border:1px solid var(--border-2);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--muted);background:var(--card);}
.litem.done .lico{background:var(--green);border-color:var(--green);color:#fff;}
.litem.quiz .lico{border-style:dashed;}
.lesson-main{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:30px 34px;min-height:300px;}
.lesson-main h3{color:var(--heading);font-size:19px;margin-bottom:14px;}
.rich{font-size:14.5px;color:var(--ink);line-height:1.8;}
.rich h3{font-size:16px;margin:18px 0 8px;color:var(--heading);}
.rich h4{font-size:14.5px;margin:14px 0 6px;color:var(--heading);}
.rich p{margin:0 0 12px;}
.rich ul,.rich ol{margin:0 0 12px 22px;}
.rich li{margin-bottom:4px;}
.rich a{color:var(--teal-dark);}
.video-ph{background:#0b2a52;border-radius:12px;min-height:240px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9fb3d1;font-size:13px;gap:8px;margin:10px 0;}
.video-ph .vico{font-size:34px;}
video.lesson-video{width:100%;max-height:420px;border-radius:12px;background:#000;display:block;margin:10px 0;}
.res-list{display:flex;flex-direction:column;gap:8px;margin:10px 0;}
.res-item{display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:10px;padding:10px 14px;font-size:13.5px;color:var(--heading);text-decoration:none;font-weight:500;}
.res-item:hover{border-color:var(--teal);}
.lesson-foot{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:22px;padding-top:16px;border-top:1px solid var(--border);}

/* quiz & examens */
.qz-q{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px 24px;margin-top:16px;}
.qz-q .qhead{display:flex;justify-content:space-between;gap:10px;align-items:baseline;margin-bottom:10px;}
.qz-q .qnum{font-size:11.5px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:1px;}
.qz-q .qpts{font-size:11.5px;color:var(--grey);}
.qz-q .qtext{font-size:14.5px;font-weight:600;color:var(--ink);margin-bottom:12px;}
.qz-media{margin:10px 0;border-radius:10px;overflow:hidden;background:#0b2a52;display:flex;justify-content:center;}
.qz-media img,.qz-media video{max-width:100%;max-height:340px;display:block;}
.choice{display:flex;align-items:flex-start;gap:10px;border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:10px;font-size:13.5px;cursor:pointer;transition:.12s;background:var(--card);}
.choice:hover{border-color:var(--teal);}
.choice input{margin-top:3px;width:16px;height:16px;accent-color:var(--teal);flex-shrink:0;}
.choice.sel{border-color:var(--teal);background:var(--teal-light);}
.choice.ok{border-color:var(--green);background:var(--green-light);}
.choice.ko{border-color:var(--red);background:var(--red-light);}
.choice.missed{border-color:var(--orange);background:var(--orange-light);}
.qz-result{text-align:center;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:30px;margin-top:18px;}
.qz-result .score{font-size:44px;font-weight:800;line-height:1;}
.qz-result .score.pass{color:var(--green);}
.qz-result .score.fail{color:var(--red);}
.qz-result .verdict{font-size:14px;color:var(--grey);margin-top:8px;}

/* runner */
.run-top{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 20px;margin:18px 0;position:sticky;top:96px;z-index:40;}
.run-timer{font-size:18px;font-weight:700;color:var(--heading);font-variant-numeric:tabular-nums;}
.run-timer.low{color:var(--red);}
.run-nav{display:flex;gap:6px;flex-wrap:wrap;}
.run-dot{width:30px;height:30px;border-radius:8px;border:1px solid var(--border-2);background:var(--card);color:var(--grey);font-size:11px;font-weight:600;}
.run-dot.answered{background:var(--teal);border-color:var(--teal);color:#fff;}
.run-dot.current{box-shadow:0 0 0 2px var(--teal);}

/* éditeurs */
.ed-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px 24px;margin-top:14px;}
.ed-card h4{color:var(--heading);font-size:14px;margin-bottom:10px;}
.ed-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px;}
.ed-row input[type=text],.ed-row input[type=url],.ed-row input[type=number],.ed-row select{border:1px solid var(--border);border-radius:8px;padding:9px 11px;background:var(--card);}
.ed-row input.grow{flex:1;min-width:160px;}
.ed-row label{font-size:12.5px;font-weight:600;color:var(--heading);}
.ed-toolbar{display:flex;gap:6px;margin-bottom:8px;flex-wrap:wrap;}
.ed-toolbar button{border:1px solid var(--border);background:var(--card);border-radius:8px;padding:6px 12px;font-size:12.5px;font-weight:600;color:var(--heading);}
.ed-toolbar button:hover{border-color:var(--teal);color:var(--teal);}
.ed-content{border:1px solid var(--border);border-radius:10px;padding:14px 16px;min-height:140px;font-size:14px;line-height:1.7;background:var(--card);outline:none;}
.ed-content:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,162,181,.12);}
.ed-choice{display:grid;grid-template-columns:24px 1fr 40px;gap:10px;align-items:center;margin-bottom:8px;}
.ed-choice input[type=checkbox]{width:17px;height:17px;accent-color:var(--green);}
.ed-choice input[type=text]{border:1px solid var(--border);border-radius:8px;padding:8px 10px;width:100%;}
.ed-choice .rm{border:1px solid var(--border);background:var(--card);color:var(--red);border-radius:8px;padding:7px;font-weight:700;}
.ed-media-slot{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:8px 0;}
.ed-media-slot .mthumb{width:110px;height:74px;border-radius:8px;background:#0b2a52;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#9fb3d1;font-size:11px;flex-shrink:0;cursor:pointer;}
.ed-media-slot .mthumb img{width:100%;height:100%;object-fit:cover;}
.drag-handle{cursor:grab;color:var(--border-2);font-size:15px;user-select:none;}
.xq{border-left:3px solid var(--teal-light);}

/* dashboard */
.dash-tbl{width:100%;border-collapse:collapse;margin-top:16px;background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;font-size:13px;box-shadow:0 1px 3px rgba(16,57,110,.05);}
.dash-tbl th{background:var(--paper);color:var(--heading);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;text-align:left;padding:12px 12px;white-space:nowrap;border-bottom:1px solid var(--border-2);}
.dash-tbl td{padding:13px 14px;border-top:1px solid var(--border);vertical-align:middle;}
.dash-tbl tr:nth-child(even) td{background:var(--stripe);}
.dash-tbl .mini-bar{width:90px;height:6px;background:var(--tint);border:none;border-radius:6px;overflow:hidden;display:inline-block;vertical-align:middle;margin-right:7px;}
.dash-tbl .mini-fill{height:100%;background:var(--teal);}
/* cartes d'action — claires, contour fin, accent teal */
.dash-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-top:14px;}
.dash-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px 48px 22px 24px;text-decoration:none;color:var(--ink);display:block;transition:border-color .18s,box-shadow .18s,transform .18s;overflow:hidden;}
.dash-card::before{content:'';position:absolute;width:140px;height:140px;border-radius:50%;background:rgba(0,162,181,.12);top:-60px;right:-40px;}
.dash-card:hover{transform:translateY(-2px);border-color:var(--teal);box-shadow:0 8px 24px rgba(16,57,110,.08);}
.dash-card .dico{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;background:var(--teal-light);font-size:18px;margin-bottom:12px;}
.dash-card .dt{font-size:15px;font-weight:700;color:var(--heading);margin-bottom:5px;letter-spacing:-.2px;}
.dash-card .dd{font-size:12.5px;color:var(--grey);line-height:1.55;}
.dash-card .dd b{color:var(--orange-ink);}
.dash-card .arrow{position:absolute;right:18px;top:50%;transform:translateY(-50%);font-size:20px;color:var(--muted);transition:.18s;}
.dash-card:hover .arrow{color:var(--teal);right:14px;}

/* progression par bloc — rangées-cartes aérées */
.bp-row{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr auto;gap:18px;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px 24px;margin-top:14px;}
.bp-row.locked{background:var(--bg);}
.bp-name .bp-key{font-size:14.5px;font-weight:700;color:var(--heading);}
.bp-name .bp-label{font-size:12.5px;color:var(--grey);margin-top:2px;}
.bp-col .bp-lbl{font-size:10.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--grey);margin-bottom:7px;}
.bp-col .bp-val{font-size:13px;font-weight:600;color:var(--heading);margin-top:6px;}
.bp-col .bp-val .pct{color:var(--teal-dark);}
.bp-bar{height:8px;background:var(--tint);border:none;border-radius:8px;overflow:hidden;}
.bp-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--teal-vif));border-radius:8px;}
.bp-muted{font-size:12.5px;color:var(--muted);}
.bp-access{text-align:right;min-width:110px;}
.bp-access .chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;border-radius:20px;padding:5px 13px;}
.bp-access .chip.open{background:var(--green-light);color:var(--green-ink);}
.bp-access .chip.lock{background:var(--orange-light);color:var(--orange-ink);}
.bp-access .why{display:block;font-size:10.5px;color:var(--grey);margin-top:6px;max-width:170px;margin-left:auto;}
@media(max-width:840px){
  .bp-row{grid-template-columns:1fr 1fr;}
  .bp-name{grid-column:1 / -1;}
  .bp-access{grid-column:1 / -1;text-align:left;}
  .bp-access .why{margin-left:0;}
}

/* ---------------- TOAST / FOOTER ---------------- */
#toast{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%) translateY(20px);background:var(--navy);color:#fff;padding:12px 22px;border-radius:30px;font-size:13.5px;z-index:400;opacity:0;transition:.25s;pointer-events:none;max-width:90%;text-align:center;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
#toast.err{background:var(--red);}
footer{background:transparent;border-top:1px solid var(--border);color:var(--grey);padding:32px 0;font-size:12px;margin-top:48px;}
footer .container{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;}
footer .deferred{max-width:760px;line-height:1.7;}
footer b{color:var(--heading);}

#storageWarn{display:none;background:var(--orange-light);color:var(--orange-ink);font-size:12.5px;padding:9px 0;text-align:center;}
#storageWarn.show{display:block;}

/* ---------------- SURVEILLANCE D'ÉPREUVE ---------------- */
.pf-wrap{max-width:900px;margin:0 auto;text-align:center;}
.pf-wrap .section-lead{margin-left:auto;margin-right:auto;margin-bottom:0;}
.pf-card{background:var(--card);border:1px solid var(--border-2);border-top:4px solid var(--navy);border-radius:18px;padding:36px 40px 32px;margin-top:32px;box-shadow:0 12px 34px rgba(11,42,82,.08);text-align:left;}
html[data-theme="dark"] .pf-card{border-top-color:var(--teal);}
.pf-kicker{text-align:center;font-size:11px;font-weight:700;letter-spacing:2.2px;text-transform:uppercase;color:var(--navy);margin-bottom:6px;}
html[data-theme="dark"] .pf-kicker{color:var(--teal-ink);}
.pf-card h4{text-align:center;color:var(--heading);font-size:20px;letter-spacing:-.3px;margin-bottom:24px;}
.pf-list{list-style:none;margin:4px 0 18px;display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.pf-list li{font-size:14px;color:var(--ink);background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:16px 18px;line-height:1.6;}
.pf-list li:last-child{grid-column:1 / -1;}
.pf-list li b{color:var(--heading);}
.pf-cam{position:relative;width:240px;margin:6px auto 12px;border-radius:12px;overflow:hidden;border:2px solid var(--teal);background:#0b2a52;}
.pf-cam video{display:block;width:100%;}
.pf-cam .pf-cam-ok{position:absolute;left:8px;bottom:8px;background:var(--green);color:#fff;font-size:10.5px;font-weight:700;border-radius:20px;padding:2px 10px;}
#proctorCam{position:fixed;right:calc(16px + env(safe-area-inset-right));bottom:calc(16px + env(safe-area-inset-bottom));z-index:390;width:150px;border-radius:12px;overflow:hidden;border:2px solid var(--teal);box-shadow:0 8px 24px rgba(11,42,82,.25);background:#0b2a52;}
#proctorCam video{display:block;width:100%;}
#proctorCam .pc-label{position:absolute;left:0;right:0;bottom:0;background:rgba(11,42,82,.78);color:#fff;font-size:9.5px;font-weight:700;letter-spacing:.5px;text-align:center;padding:3px 0;}
.proc-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;margin-top:14px;}
.proc-shot{margin:0;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card);}
.proc-shot .ps-img{aspect-ratio:4/3;background:#0b2a52;display:flex;align-items:center;justify-content:center;color:#9fb3d1;font-size:12px;overflow:hidden;}
.proc-shot .ps-img img{width:100%;height:100%;object-fit:cover;display:block;}
.proc-shot figcaption{font-size:11px;color:var(--grey);text-align:center;padding:5px 8px;font-variant-numeric:tabular-nums;}

@media(max-width:680px){
  .review-card{grid-template-columns:1fr;}
  .adm-row{grid-template-columns:1fr 1fr;}
  .adm-head{display:none;}
  .ba-grid{grid-template-columns:1fr;}
  .course{flex-wrap:wrap;}
  .cname{flex:1 1 calc(100% - 110px);}
  .cbadges{margin-left:66px;}
  .rwrap{margin-left:auto;}
}

/* ---------------- MOBILE (smartphone — hors examens) ---------------- */
@media(max-width:760px){
  .container{padding:0 14px;}
  /* barre du haut sur une seule ligne : logo à gauche, burger à droite */
  .nav-inner{padding:8px 14px;gap:8px;flex-wrap:nowrap;}
  .brand img{height:22px;}
  .brand-tag{display:none;}
  .nav-burger{display:flex;}
  /* le menu (onglets + actions) devient un panneau déroulant sous la barre */
  .nav-menu{position:absolute;top:100%;left:0;right:0;display:none;background:var(--white);border-bottom:1px solid var(--border);box-shadow:0 14px 28px rgba(11,42,82,.14);max-height:calc(100vh - 56px);max-height:calc(100dvh - 56px);overflow-y:auto;}
  .appnav.menu-open .nav-menu{display:block;}
  .navtabs{flex-direction:column;gap:2px;padding:8px 12px;max-width:none;overflow:visible;}
  .navtabs a{padding:13px 14px;font-size:14px;border-bottom:none;border-radius:10px;}
  .navtabs a.active{background:var(--tint);border-bottom-color:transparent;}
  .nav-right{position:static;flex-wrap:wrap;gap:10px;padding:12px;border-top:1px solid var(--border);}
  .role-badge{max-width:none;}
  header.hero{padding:22px 0 20px;}
  .hero-badge{display:none;}
  .hero h1{font-size:19px;}
  .hero-sub{font-size:12.5px;}
  main{padding:48px 0 44px;}
  .kicker{font-size:12px;letter-spacing:1.8px;}
  h2{font-size:21px;}
  .section-lead{font-size:13.5px;margin-bottom:24px;}
  /* tableaux larges (matrice cohorte, suivis) : défilement horizontal */
  .dash-tbl,.suivi-tbl{display:block;overflow-x:auto;white-space:nowrap;border-radius:10px;-webkit-overflow-scrolling:touch;}
  /* 1re colonne (nom de l'étudiant) figée : sinon la clé de ligne défile hors écran */
  .dash-tbl th:first-child{position:sticky;left:0;z-index:2;background:var(--paper);}
  .dash-tbl td:first-child{position:sticky;left:0;z-index:1;background:var(--card);}
  .dash-tbl tr:nth-child(even) td:first-child{background:var(--stripe);}
  .overlay{padding:12px 8px;align-items:flex-start;}
  .modal{padding:18px 16px;border-radius:14px;}
  .lesson-main{padding:18px 16px;}
  .pf-list{grid-template-columns:1fr;}
  .pf-card{padding:22px 18px;}
  .lesson-side{position:static;}
  .run-top{position:static;}
  .enc-row{grid-template-columns:1fr 1fr 40px;}
  .stu-row{grid-template-columns:1fr 1fr;}
  .stu-row .rm{grid-column:1/-1;justify-self:end;}
  .coh-grid{grid-template-columns:1fr 1fr;}
  .stat .n{font-size:20px;}
  .stat{border-right:none;border-bottom:1px solid var(--border);padding:12px 18px;}
  .stat:last-child{border-bottom:none;}
  .enc-switch{margin-left:0;}
  .enc-line{width:100%;}
  .enc-select{min-width:0;flex:1;}
  .bp-row{padding:14px 16px;gap:12px;}
  .dash-card{padding:18px 42px 16px 18px;}
  .exp-item{flex-wrap:wrap;}
  .toolbar{gap:8px;}
  .login-card{padding:26px 20px 18px;}
  .vac{width:40px;height:40px;font-size:12px;}
  .btn.small{padding:10px 16px;}
  .run-dot{width:36px;height:36px;}
  footer .container{flex-direction:column;}
}
/* cibles tactiles plus généreuses sur écrans tactiles */
@media(pointer:coarse){
  .choice{padding:13px 15px;}
  .litem{padding:12px 10px;}
  .icon-btn{padding:9px 14px;}
  .navtabs a{padding:13px 14px;}
  /* cibles ≥44px : fermeture de modale et boutons de suppression (flux atteignables
     en mobile : dépôt carnet, encadrants, admin) */
  .modal-close{width:44px;height:44px;}
  .rm{min-width:44px;min-height:44px;}
}
@media print{nav.appnav,header.hero,footer,.navtabs,#proctorCam,#loginScreen{display:none;}}

/* ===== bibliothèque PDF (espace perso & banque de questions) ===== */
.pdf-list{display:flex;flex-direction:column;gap:8px;margin:10px 0;}
.pdf-item{display:flex;align-items:center;gap:12px;border:1px solid var(--border);border-radius:10px;padding:10px 14px;background:var(--card);text-decoration:none;color:var(--heading);}
a.pdf-item:hover{border-color:var(--teal);}
.pdf-ico{flex:0 0 auto;font-size:10px;font-weight:800;letter-spacing:.5px;color:#fff;background:var(--red);border-radius:6px;padding:5px 7px;}
.pdf-body{flex:1;min-width:0;display:flex;flex-direction:column;}
.pdf-title{font-weight:600;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.pdf-sub{font-size:11.5px;color:var(--grey);}
.pdf-open{flex:0 0 auto;font-size:12px;font-weight:600;color:var(--teal-ink);}

/* ===== progression (espace perso) ===== */
.esp-courses{display:flex;flex-direction:column;gap:14px;margin-top:10px;}
.esp-block-h{font-size:12px;font-weight:700;color:var(--teal-ink);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;}
.esp-course{display:flex;align-items:center;gap:10px;padding:8px 12px;border:1px solid var(--border);border-radius:10px;background:var(--card);text-decoration:none;color:var(--heading);margin-bottom:6px;}
.esp-course:hover{border-color:var(--teal);}
.esp-course-t{flex:1;min-width:0;font-size:13.5px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.esp-course-pct{font-size:12.5px;font-weight:700;color:var(--grey);min-width:42px;text-align:right;}

/* ============================================================
   VISITE GUIDÉE (EF.demo) — projecteur + bulle d'explication
   ============================================================ */
/* bouton de lancement dans la barre de navigation */
.demo-btn{border:1px solid var(--teal);background:var(--teal-light);color:var(--teal-ink);font-size:12.5px;font-weight:600;padding:8px 14px;border-radius:30px;transition:.15s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;}
.demo-btn:hover{background:var(--teal);color:#fff;}

/* capteur de clics : neutralise l'application pendant la visite (met en pause) */
.ef-tour-catch{position:fixed;inset:0;z-index:9000;background:transparent;}
/* projecteur : trou lumineux sur la cible, le reste assombri via box-shadow */
.ef-tour-dim{position:fixed;z-index:9001;border-radius:12px;pointer-events:none;
  box-shadow:0 0 0 9999px rgba(8,26,52,.62), 0 0 0 2px var(--teal-vif), 0 0 22px 4px rgba(79,210,224,.55);
  transition:left .32s ease,top .32s ease,width .32s ease,height .32s ease;}
.ef-tour-dim.full{left:0!important;top:0!important;width:100vw!important;height:100vh!important;height:100dvh!important;border-radius:0;
  box-shadow:inset 0 0 0 9999px rgba(8,26,52,.62);}

/* bulle d'explication */
.ef-tour-card{position:fixed;z-index:9003;width:min(380px,calc(100vw - 28px));background:var(--card);
  border:1px solid var(--border);border-radius:16px;box-shadow:0 18px 50px rgba(8,26,52,.45);
  padding:18px 18px 14px;overflow:hidden;transition:left .28s ease,top .28s ease;}
.ef-tour-prog{position:absolute;top:0;left:0;right:0;height:4px;background:var(--pill-bg);}
.ef-tour-prog span{display:block;height:100%;background:var(--teal);transition:width .35s ease;}
.ef-tour-kick{font-size:10.5px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--teal-ink);margin:6px 0 8px;}
.ef-tour-title{font-size:17px;font-weight:700;color:var(--heading);line-height:1.3;margin-bottom:8px;letter-spacing:-.2px;}
.ef-tour-text{font-size:13.5px;line-height:1.6;color:var(--grey);}
.ef-tour-text b{color:var(--heading);font-weight:600;}
.ef-tour-text i{font-size:12.5px;color:var(--muted);}
/* barre de décompte de l'auto-avance */
.ef-tour-count{height:3px;border-radius:2px;background:var(--pill-bg);margin-top:14px;overflow:hidden;}
.ef-tour-count span{display:block;height:100%;width:0;background:var(--teal-vif);}
.ef-tour-ctrl{display:flex;align-items:center;gap:8px;margin-top:12px;}
.ef-tour-btn{border:none;background:var(--teal);color:#fff;font-weight:600;font-size:12.5px;padding:9px 14px;border-radius:30px;transition:.15s;}
.ef-tour-btn:hover{background:var(--teal-dark);}
.ef-tour-btn.ghost{background:var(--card);color:var(--heading);border:1px solid var(--border);}
.ef-tour-btn.ghost:hover{border-color:var(--teal);color:var(--teal);}
.ef-tour-btn.play{background:var(--navy);} .ef-tour-btn.play:hover{background:var(--navy-dark);}
.ef-tour-btn.quit{margin-left:auto;background:var(--card);color:var(--grey);border:1px solid var(--border);padding:9px 12px;}
.ef-tour-btn.quit:hover{border-color:var(--red);color:var(--red);}
.ef-tour-btn:disabled{opacity:.4;cursor:not-allowed;}
@media (max-width:760px){
  .ef-tour-card{width:calc(100vw - 20px);left:10px!important;}
  .ef-tour-ctrl{flex-wrap:wrap;}
}

/* ===== file de validation (banque de questions) ===== */
.qb-item{border-left:3px solid var(--teal);}
.qb-source{margin-top:12px;background:var(--bg);border-radius:10px;padding:10px 14px;}
.qb-source-h{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--grey);margin-bottom:6px;}
.qb-quote{margin:0;padding:6px 12px;border-left:3px solid var(--border-2,var(--border));font-style:italic;font-size:13px;color:var(--ink);white-space:pre-wrap;}

/* ===== mini-graphe de tendance (scores d'épreuves) ===== */
.spark{display:flex;align-items:flex-end;gap:14px;padding:18px 16px 10px;background:var(--card);border:1px solid var(--border);border-radius:14px;overflow-x:auto;}
.spark-col{flex:0 0 auto;width:46px;display:flex;flex-direction:column;align-items:center;gap:6px;}
.spark-val{font-size:11px;font-weight:700;color:var(--heading);}
.spark-track{position:relative;height:120px;width:26px;display:flex;align-items:flex-end;background:var(--stripe);border-radius:6px;overflow:hidden;}
/* ligne du seuil de réussite (70 %) tracée en travers de chaque piste */
.spark-track::after{content:'';position:absolute;left:0;right:0;bottom:70%;border-top:1px dashed var(--orange);}
.spark-bar{width:100%;border-radius:6px 6px 0 0;transition:height .4s ease;}
.spark-bar.pass{background:var(--green);} .spark-bar.fail{background:var(--red);}
.spark-x{font-size:10.5px;font-weight:600;color:var(--grey);max-width:46px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;}
.spark-cap{font-size:11.5px;color:var(--grey);margin-top:8px;}

/* ===== analytics (cohorte & surveillance) ===== */
.an-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:6px;}
.an-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px 20px;}
.an-card h3{font-size:14px;font-weight:700;color:var(--heading);margin-bottom:4px;}
.an-card .an-sub{font-size:12px;color:var(--grey);margin-bottom:14px;}
.an-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:9px;font-size:12.5px;}
.an-bar-lbl{flex:0 0 38%;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--heading);font-weight:500;}
.an-bar-track{flex:1;height:14px;background:var(--stripe);border-radius:8px;overflow:hidden;}
.an-bar-fill{height:100%;border-radius:8px;background:var(--teal);transition:width .4s ease;}
.an-bar-fill.warn{background:var(--orange);} .an-bar-fill.bad{background:var(--red);} .an-bar-fill.good{background:var(--green);}
.an-bar-val{flex:0 0 auto;font-weight:700;color:var(--heading);min-width:54px;text-align:right;}
.an-empty{font-size:13px;color:var(--grey);padding:8px 0;}
