@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:wght@300;400;500&display=swap');
:root{--bg:#07090f;--bg2:#0d1117;--bg3:#141b27;--card:#0f1520;--border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.1);--accent:#4f8aff;--a2:#00d4aa;--a3:#ff5f5f;--a4:#f59e0b;--a5:#a78bfa;--text:#dde4f0;--text2:#7a8ca8;--text3:#3d4f66;--r:10px}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;line-height:1.5}
a{text-decoration:none;color:inherit}

/* ── LAYOUT ── */
.app{display:flex;min-height:100vh}
.sidebar{width:230px;min-height:100vh;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}
.s-logo{padding:22px 18px;border-bottom:1px solid var(--border)}
.logo-t{font-family:'Syne',sans-serif;font-weight:800;font-size:20px;letter-spacing:-.5px}
.logo-t span{color:var(--accent)}
.logo-s{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.s-nav{padding:14px 10px;flex:1;overflow-y:auto}
.nav-sec{font-size:9px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text3);padding:10px 8px 5px}
.nav-a{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:7px;cursor:pointer;font-size:13px;color:var(--text2);transition:all .15s;margin-bottom:2px;text-decoration:none}
.nav-a:hover{background:var(--bg3);color:var(--text)}
.nav-a.on{background:rgba(79,138,255,.1);color:var(--accent);font-weight:500}
.nav-a.danger{color:var(--a3)}
.nav-a.danger:hover{background:rgba(255,95,95,.08)}
.nbadge{margin-left:auto;background:var(--a3);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:20px}
.s-cab{padding:10px;border-top:1px solid var(--border)}
.cab-pill{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:10px}
.cab-av{width:28px;height:28px;background:linear-gradient(135deg,var(--accent),var(--a2));border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;font-family:'Syne',sans-serif;flex-shrink:0}
.main{margin-left:230px;flex:1;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:50;backdrop-filter:blur(10px)}
.pg{padding:28px 32px;flex:1}
.ph{margin-bottom:24px}
.ph-row{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}
.pt{font-family:'Syne',sans-serif;font-size:24px;font-weight:700;letter-spacing:-.5px}
.ps{font-size:13px;color:var(--text2);margin-top:4px}

/* ── BUTTONS ── */
.btn{padding:8px 16px;border-radius:8px;font-size:13px;cursor:pointer;font-weight:500;border:none;font-family:'DM Sans',sans-serif;transition:all .15s;display:inline-flex;align-items:center;gap:6px;text-decoration:none}
.btn-p{background:var(--accent);color:#fff}.btn-p:hover{background:#3a7aff}
.btn-s{background:var(--a2);color:#fff}.btn-s:hover{opacity:.9}
.btn-d{background:var(--a3);color:#fff}.btn-d:hover{opacity:.9}
.btn-g{background:var(--card);color:var(--text2);border:1px solid var(--border)}.btn-g:hover{color:var(--text);border-color:var(--text3)}
.btn-sm{padding:5px 12px;font-size:12px}
.btn-full{width:100%;justify-content:center;padding:11px}

/* ── CARDS ── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:18px}
.ch{padding:16px 20px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.ct{font-family:'Syne',sans-serif;font-size:14px;font-weight:600}
.cb{padding:20px}

/* ── KPI ── */
.kgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:24px}
.kcard{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px;position:relative;overflow:hidden;transition:border-color .2s}
.kcard:hover{border-color:var(--border2)}
.kcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.kc-b::before{background:var(--accent)}.kc-g::before{background:var(--a2)}.kc-r::before{background:var(--a3)}.kc-y::before{background:var(--a4)}.kc-v::before{background:var(--a5)}
.kl{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}
.kv{font-family:'Syne',sans-serif;font-size:22px;font-weight:700;letter-spacing:-.5px;line-height:1}
.kg{font-size:11px;margin-top:6px}.kg.up{color:var(--a2)}.kg.dn{color:var(--a3)}.kg.nt{color:var(--text3)}

/* ── GRIDS ── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.g31{display:grid;grid-template-columns:3fr 2fr;gap:18px}
.g21{display:grid;grid-template-columns:2fr 1fr;gap:18px}

/* ── TABLES ── */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl thead tr{border-bottom:1px solid var(--border)}
.tbl th{padding:11px 16px;text-align:left;color:var(--text3);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.tbl tbody tr{border-bottom:1px solid var(--border);transition:background .1s;cursor:pointer}
.tbl tbody tr:last-child{border-bottom:none}
.tbl tbody tr:hover{background:rgba(255,255,255,.015)}
.tbl td{padding:13px 16px}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;font-size:11px;padding:2px 8px;border-radius:20px;font-weight:500}
.b-r{background:rgba(255,95,95,.12);color:var(--a3)}.b-g{background:rgba(0,212,170,.12);color:var(--a2)}
.b-b{background:rgba(79,138,255,.12);color:var(--accent)}.b-y{background:rgba(245,158,11,.12);color:var(--a4)}
.b-n{background:var(--bg3);color:var(--text2)}

/* ── FORMS ── */
.fg{margin-bottom:16px}
.fl{display:block;font-size:12px;color:var(--text2);margin-bottom:5px}
.fi{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:9px 13px;color:var(--text);font-size:13px;font-family:'DM Sans',sans-serif;outline:none;transition:border-color .15s}
.fi:focus{border-color:var(--accent)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ── ALERTS ── */
.abox{border-radius:var(--r);padding:14px 16px;display:flex;gap:12px;margin-bottom:18px}
.abox .at{font-size:13px;color:var(--text2);line-height:1.5}
.abox .at strong{font-weight:600}
.a-d{background:rgba(255,95,95,.07);border:1px solid rgba(255,95,95,.18)}.a-d .at strong{color:var(--a3)}
.a-w{background:rgba(245,158,11,.07);border:1px solid rgba(245,158,11,.18)}.a-w .at strong{color:var(--a4)}
.a-s{background:rgba(0,212,170,.07);border:1px solid rgba(0,212,170,.18)}.a-s .at strong{color:var(--a2)}
.a-i{background:rgba(79,138,255,.07);border:1px solid rgba(79,138,255,.18)}.a-i .at strong{color:var(--accent)}

/* ── AI OUTPUT ── */
.aibox{background:linear-gradient(135deg,rgba(79,138,255,.05),rgba(0,212,170,.03));border:1px solid rgba(79,138,255,.15);border-radius:var(--r);overflow:hidden}
.ai-h{padding:14px 18px;border-bottom:1px solid rgba(79,138,255,.12);display:flex;align-items:center;gap:10px}
.ai-dot{width:8px;height:8px;background:var(--a2);border-radius:50%;animation:pulse 2s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.ai-t{font-family:'Syne',sans-serif;font-size:13px;font-weight:600;color:var(--accent)}
.ai-m{margin-left:auto;font-size:11px;color:var(--text3)}
.ai-c{padding:18px;font-size:13.5px;line-height:1.8;color:var(--text2)}
.ai-c strong{color:var(--text)}

/* ── MODULE TABS ── */
.mtabs{display:flex;gap:4px;padding:4px;background:var(--bg3);border-radius:var(--r);margin-bottom:18px;overflow-x:auto}
.mtab{flex:1;min-width:90px;padding:8px 12px;border-radius:7px;cursor:pointer;font-size:12px;font-weight:500;color:var(--text2);border:none;background:none;font-family:'DM Sans',sans-serif;transition:all .15s;text-align:center;white-space:nowrap}
.mtab:hover{color:var(--text)}.mtab.on{background:var(--card);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.3)}

/* ── UPLOAD ── */
.upz{border:2px dashed var(--border2);border-radius:var(--r);padding:28px 20px;text-align:center;cursor:pointer;transition:all .2s}
.upz:hover,.upz.drag{border-color:var(--accent);background:rgba(79,138,255,.04)}

/* ── PROGRESS ── */
.pbar{height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.pfill{height:100%;border-radius:2px;transition:width .4s ease;background:var(--accent)}

/* ── LOADING ── */
.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;gap:16px}
.spin{width:32px;height:32px;border:3px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── SCORE RING ── */
.sring-wrap{display:flex;align-items:center;gap:24px;padding:20px}
.sring{position:relative;width:110px;height:110px;flex-shrink:0}
.sring svg{transform:rotate(-90deg)}
.sring-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.sring-n{font-family:'Syne',sans-serif;font-size:26px;font-weight:800;line-height:1}

/* ── RDV ── */
.rdv-i{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.rdv-i:last-child{border-bottom:none}
.rdv-dt{background:var(--bg3);border-radius:8px;padding:8px 10px;text-align:center;min-width:44px}
.rdv-d{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;line-height:1}
.rdv-m{font-size:10px;color:var(--text3);text-transform:uppercase}

/* ── LOGIN PAGE ── */
.login-pg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:40px;width:420px;max-width:95vw}
.login-logo{font-family:'Syne',sans-serif;font-weight:800;font-size:26px;text-align:center;margin-bottom:6px}
.login-logo span{color:var(--accent)}
.login-sub{text-align:center;color:var(--text2);font-size:13px;margin-bottom:28px}
.login-err{background:rgba(255,95,95,.1);border:1px solid rgba(255,95,95,.2);color:var(--a3);font-size:13px;padding:10px 14px;border-radius:8px;margin-bottom:16px}

/* ── CHART CONTAINERS ── */
.chart-wrap{position:relative;height:220px;margin-top:10px}
.chart-wrap-lg{position:relative;height:280px;margin-top:10px}

/* ── INSCRIPTION STEPS ── */
.steps{display:flex;gap:0;margin-bottom:36px}
.step-i{flex:1;display:flex;align-items:center}
.step-n{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;font-family:'Syne',sans-serif;flex-shrink:0;transition:all .3s}
.step-n.done{background:var(--a2);color:#fff}.step-n.on{background:var(--accent);color:#fff}.step-n.pend{background:var(--bg3);color:var(--text3);border:1px solid var(--border)}
.step-lb{font-size:12px;margin-left:8px}.step-lb.on{color:var(--text);font-weight:500}.step-lb.pend{color:var(--text3)}
.step-line{flex:1;height:1px;background:var(--border);margin:0 12px}.step-line.done{background:var(--a2)}

/* ── PLAN CARDS ── */
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}
.plan-card{background:var(--bg3);border:2px solid var(--border);border-radius:12px;padding:20px;cursor:pointer;transition:all .2s;position:relative}
.plan-card:hover{border-color:var(--text3)}.plan-card.sel{border-color:var(--accent);background:rgba(79,138,255,.06)}
.plan-card.pop::before{content:'Populaire';position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:0 0 6px 6px}
.plan-prix{font-family:'Syne',sans-serif;font-size:28px;font-weight:800;color:var(--accent)}
.plan-prix span{font-size:13px;color:var(--text2);font-weight:400;font-family:'DM Sans',sans-serif}

/* ── DOC UPLOAD ── */
.doc-upz{border:2px dashed var(--border2);border-radius:10px;padding:16px;text-align:center;cursor:pointer;transition:all .2s}
.doc-upz:hover{border-color:var(--accent);background:rgba(79,138,255,.03)}.doc-upz.ok{border-color:var(--a2);background:rgba(0,212,170,.04)}
.doc-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}

/* ── ADMIN SPECIFIC ── */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.admin-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:20px}

/* ── CLIENT DASHBOARD ── */
.client-score{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;margin:0 auto 16px}
.cs-in{width:88px;height:88px;background:var(--card);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-direction:column}
.cs-val{font-family:'Syne',sans-serif;font-size:28px;font-weight:800;color:var(--a2);line-height:1}
.cs-lbl{font-size:10px;color:var(--text3)}
.kpi-bar-row{display:flex;align-items:center;gap:10px;font-size:12px;margin-bottom:8px}
.kpi-bar-lbl{width:130px;color:var(--text2);flex-shrink:0}
.kpi-bar-track{flex:1;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}
.kpi-bar-fill{height:100%;border-radius:3px;transition:width 1.2s ease}
.kpi-bar-val{width:60px;text-align:right;font-family:'Syne',sans-serif;font-size:12px;font-weight:600}

/* ── MISC ── */
.fade{animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:2px}
.sep{border:none;border-top:1px solid var(--border);margin:16px 0}
.txt2{color:var(--text2)}.txt3{color:var(--text3)}.fam{font-family:'Syne',sans-serif;font-weight:700}
@media(max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .3s}.sidebar.open{transform:translateX(0)}.main{margin-left:0}.g2,.g3,.g31,.g21{grid-template-columns:1fr}.kgrid{grid-template-columns:repeat(2,1fr)}.pg{padding:18px}.plan-grid{grid-template-columns:1fr}}
