/* ===== ACADÉMIE LSPD — style partagé ===== */
:root{
  --bg:#0a0e17; --panel:#111826; --panel2:#0d1420; --line:#1e2a3d;
  --blue:#2f6df6; --blue2:#4d8bff; --gold:#f6c94a; --white:#eef3fb;
  --green:#37d67a; --red:#ff5470; --muted:#8ba0bf; --shadow:0 10px 40px rgba(0,0,0,.5);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  background:radial-gradient(1200px 600px at 50% -10%,#13203a 0%,var(--bg) 55%);
  color:var(--white);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--blue2)}
.wrap{max-width:1080px;margin:0 auto;padding:24px 18px 90px}
.topbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.5px;text-decoration:none;color:var(--white)}
.topbar .brand .sh{font-size:24px}
.topbar .brand small{display:block;font-size:11px;color:var(--gold);letter-spacing:2px;text-transform:uppercase;font-weight:700}
.crumbs{margin-left:auto;font-size:13px;color:var(--muted)}
.hero{position:relative;border:1px solid var(--line);border-radius:20px;overflow:hidden;
  background:linear-gradient(135deg,#0f1d3a 0%,#0a1122 60%,#0a0e17 100%);padding:30px;box-shadow:var(--shadow)}
.hero::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent 0 38px,rgba(47,109,246,.05) 38px 40px);pointer-events:none}
.badgeLine{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.shield{font-size:32px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6))}
.kicker{letter-spacing:3px;font-size:12px;color:var(--gold);font-weight:700;text-transform:uppercase}
.hero h1{margin:8px 0 6px;font-size:34px;line-height:1.05}
.hero h1 span{color:var(--blue2)}
.hero p{color:var(--muted);max-width:660px;margin:0}
.stripe{height:6px;background:linear-gradient(90deg,var(--blue),var(--gold));border-radius:6px;margin-top:16px;width:120px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:22px}
.fcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:16px;background:var(--panel);
  padding:20px;text-decoration:none;color:var(--white);box-shadow:var(--shadow);transition:.2s}
.fcard:hover{transform:translateY(-3px);border-color:var(--blue)}
.fcard .ic{font-size:34px}
.fcard h3{margin:12px 0 4px;font-size:18px}
.fcard p{margin:0;font-size:12.5px;color:var(--muted);flex:1}
.fcard .tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:14px}
.tag{font-size:10.5px;font-weight:800;padding:4px 9px;border-radius:20px;letter-spacing:.4px}
.tag.ready{background:rgba(55,214,122,.14);color:#8ef0bd;border:1px solid rgba(55,214,122,.4)}
.tag.soon{background:rgba(246,201,74,.12);color:var(--gold);border:1px solid rgba(246,201,74,.35)}
.tag.cat{background:#0b1322;color:var(--muted);border:1px solid var(--line)}
.sectionTitle{margin:28px 0 6px;font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:2px}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:20px 0 6px}
.tab{flex:1;min-width:150px;text-align:center;font-weight:800;font-size:14px;padding:14px 10px;border-radius:14px;
  border:1px solid var(--line);background:var(--panel2);color:var(--muted);cursor:pointer;transition:.2s;font-family:inherit}
.tab .sub{display:block;font-size:11px;font-weight:600;color:var(--muted);margin-top:3px}
.tab:hover{border-color:var(--blue);color:var(--white)}
.tab.active{background:linear-gradient(135deg,#16294d,#0d1626);border-color:var(--gold);color:var(--white);box-shadow:0 0 0 1px rgba(246,201,74,.2)}
.tab.active .sub{color:var(--gold)}
.view{display:none;margin-top:18px}
.view.on{display:block;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.dock{position:sticky;top:0;z-index:40;margin:0 0 22px;background:rgba(13,20,32,.92);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:16px;padding:14px 18px;box-shadow:var(--shadow)}
.dockTop{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.rankBox{display:flex;align-items:center;gap:12px}
.rankMedal{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:23px;background:linear-gradient(135deg,#1b2b4d,#0d1729);border:1px solid var(--line)}
.rankName{font-weight:800;font-size:16px}.rankSub{font-size:12px;color:var(--muted)}
.xpNums{font-size:13px;color:var(--muted)}.xpNums b{color:var(--gold)}
.bar{height:11px;background:#0a1120;border:1px solid var(--line);border-radius:20px;margin-top:12px;overflow:hidden}
.fill{height:100%;width:0;border-radius:20px;background:linear-gradient(90deg,var(--blue),var(--blue2),var(--gold));transition:width .6s cubic-bezier(.3,1,.4,1)}
.module{border:1px solid var(--line);border-radius:18px;background:var(--panel);margin:0 0 18px;overflow:hidden;box-shadow:var(--shadow)}
.mHead{display:flex;align-items:center;gap:16px;padding:18px 22px;cursor:pointer;user-select:none}
.mHead:hover{background:#131c2d}
.mIcon{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:25px;flex:none;background:linear-gradient(135deg,#16294d,#0d1626);border:1px solid var(--line)}
.mTitle{flex:1}.mTitle h2{margin:0;font-size:19px}.mTitle .mMeta{font-size:12px;color:var(--muted);margin-top:3px}
.chev{font-size:20px;color:var(--muted);transition:.3s}.module.open .chev{transform:rotate(180deg)}
.mBody{max-height:0;overflow:hidden;transition:max-height .5s ease}.mInner{padding:4px 22px 24px}
h3.blk{margin:20px 0 8px;font-size:16px;color:var(--blue2)}
h4{margin:16px 0 6px;font-size:14px;color:var(--gold)}
p.lead{color:#cdd8ea}
ul.clean{list-style:none;padding:0;margin:8px 0}
ul.clean li{padding:7px 12px 7px 34px;position:relative;border-left:2px solid var(--line);margin-left:6px}
ul.clean li::before{content:"▸";position:absolute;left:12px;color:var(--blue2)}
.callout{border-radius:12px;padding:13px 16px;margin:14px 0;font-size:14px;border:1px solid var(--line)}
.callout.warn{background:rgba(255,84,112,.08);border-color:rgba(255,84,112,.4)}
.callout.tip{background:rgba(55,214,122,.07);border-color:rgba(55,214,122,.35)}
.callout.radio{background:rgba(47,109,246,.09);border-color:rgba(47,109,246,.4);font-family:'Courier New',monospace}
.callout.todo{background:rgba(246,201,74,.08);border-color:rgba(246,201,74,.4)}
.callout b{color:var(--white)}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin:12px 0}
.card{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:14px}
.card .dot{width:22px;height:22px;border-radius:6px;display:inline-block;margin-bottom:8px;border:1px solid rgba(255,255,255,.2)}
.card h5{margin:0 0 4px;font-size:14px}.card p{margin:0;font-size:12.5px;color:var(--muted)}
.dot.white{background:#f3f6fb}.dot.black{background:#1a2230}.dot.blue{background:var(--blue)}
.step{display:flex;gap:14px;margin:12px 0;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.stepNo{width:38px;height:38px;flex:none;border-radius:10px;display:grid;place-items:center;font-weight:900;background:linear-gradient(135deg,var(--blue),#1a49b8);color:#fff}
.goal{display:inline-block;font-size:11px;font-weight:800;color:var(--green);background:rgba(55,214,122,.1);border:1px solid rgba(55,214,122,.3);border-radius:20px;padding:3px 10px;margin-top:6px}
.diagram{background:#0a1120;border:1px solid var(--line);border-radius:14px;padding:16px;margin:14px 0;text-align:center}
.diagram svg{max-width:100%;height:auto}
.legend{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:10px;font-size:12px;color:var(--muted)}
.lg{width:12px;height:12px;border-radius:3px;display:inline-block;margin-right:5px;vertical-align:middle}
.quiz{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:18px;margin:14px 0}
.q{margin:0 0 6px;font-weight:700;font-size:15px}
.qtag{font-size:11px;font-weight:800;color:var(--gold);letter-spacing:1px}
.opts{display:grid;gap:9px;margin:12px 0 4px}
.opt{text-align:left;font-size:14px;padding:12px 14px;border-radius:10px;border:1px solid var(--line);background:#0b1322;color:var(--white);cursor:pointer;transition:.15s;font-family:inherit}
.opt:hover{border-color:var(--blue);background:#101c30}
.opt.sel{border-color:var(--gold);background:#141d10}
.opt.correct{border-color:var(--green);background:rgba(55,214,122,.14)}
.opt.wrong{border-color:var(--red);background:rgba(255,84,112,.14)}
.opt:disabled{cursor:default}
.feedback{font-size:13px;margin-top:10px;padding:10px 12px;border-radius:9px;display:none}
.feedback.show{display:block}.feedback.ok{background:rgba(55,214,122,.1);color:#a7f3cf}.feedback.no{background:rgba(255,84,112,.1);color:#ffc2cd}
.panel{border:1px solid var(--line);border-radius:18px;background:var(--panel);padding:26px;box-shadow:var(--shadow)}
.panel.locked{text-align:center}
.lockIcon{font-size:44px}
label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin:14px 0 6px;letter-spacing:.5px;text-transform:uppercase}
input.fld{width:100%;padding:13px 15px;font-size:15px;border-radius:12px;border:1px solid var(--line);background:#0b1322;color:var(--white);font-family:inherit}
input.fld:focus{outline:none;border-color:var(--blue)}
.btn{display:inline-block;margin-top:16px;font-weight:800;font-size:14px;padding:13px 24px;border-radius:12px;border:none;cursor:pointer;color:#08111f;background:linear-gradient(135deg,var(--gold),#ffdd7a);font-family:inherit}
.btn:hover{filter:brightness(1.05)}
.btn.blue{color:#fff;background:linear-gradient(135deg,var(--blue),#1a49b8)}
.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}
.btn:disabled{opacity:.5;cursor:default}
.who{display:flex;align-items:center;gap:12px;background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:12px 16px;margin-bottom:16px}
.who .av{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-size:18px;background:linear-gradient(135deg,#16294d,#0d1626);border:1px solid var(--line)}
.who b{font-size:15px}.who small{color:var(--muted)}
.progress-exam{font-size:12px;color:var(--muted);margin-bottom:8px}
.minibar{height:8px;background:#0a1120;border:1px solid var(--line);border-radius:20px;overflow:hidden;margin:6px 0 18px}
.minibar>div{height:100%;background:linear-gradient(90deg,var(--blue),var(--gold));width:0;transition:.4s}
.cert{border:2px solid var(--gold);border-radius:18px;padding:28px;text-align:center;background:radial-gradient(600px 200px at 50% 0%,rgba(246,201,74,.12),transparent),linear-gradient(135deg,#1a1608,#0d1420);box-shadow:var(--shadow)}
.cert .seal{font-size:46px}.cert h2{margin:6px 0;font-size:24px}
.cert .name{font-size:24px;font-weight:900;color:var(--gold);margin:8px 0}
.cert .score{font-size:40px;font-weight:900;margin:6px 0}.cert .meta{color:var(--muted);font-size:13px}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin:16px 0}
.stat{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:16px;text-align:center}
.stat .n{font-size:28px;font-weight:900;color:var(--gold)}.stat .l{font-size:12px;color:var(--muted)}
table{width:100%;border-collapse:collapse;margin-top:8px;font-size:13.5px}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px}
tr:hover td{background:#111c2d}
.pill{font-size:11px;font-weight:800;padding:3px 10px;border-radius:20px}
.pill.ok{background:rgba(55,214,122,.14);color:#8ef0bd;border:1px solid rgba(55,214,122,.4)}
.pill.no{background:rgba(255,84,112,.14);color:#ffc2cd;border:1px solid rgba(255,84,112,.4)}
.tableWrap{overflow-x:auto}
.notice{font-size:12.5px;color:var(--muted);background:var(--panel2);border:1px dashed var(--line);border-radius:12px;padding:12px 14px;margin:14px 0}
.foot{text-align:center;color:var(--muted);font-size:12px;margin-top:28px}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(140px);background:linear-gradient(135deg,#1b2b4d,#0d1729);border:1px solid var(--gold);color:var(--white);padding:14px 20px;border-radius:14px;font-weight:700;box-shadow:var(--shadow);transition:.5s;z-index:99;display:flex;gap:10px;align-items:center}
.toast.show{transform:translateX(-50%) translateY(0)}
