:root{
  --bg:#0f1525; --panel:#fff; --ink:#1a2238; --muted:#6b7385; --line:#e6e9f0;
  --primary:#2f5bea; --primary-d:#2247c4; --ok:#1f9d6b; --no:#d9534f; --danger:#c0392b;
  --havas:#309fdf; --ailleurs:#f8601d; --supertripper:#604fd7;
  --radius:12px; --shadow:0 1px 3px rgba(16,24,40,.08),0 1px 2px rgba(16,24,40,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:#f4f6fb;color:var(--ink);line-height:1.5}
a{color:var(--primary);text-decoration:none}
h1,h2{margin:0 0 .4em}
.muted{color:var(--muted)} .small{font-size:.85rem} .mt{margin-top:.6rem}

/* Topbar */
.topbar{display:flex;align-items:center;gap:1.5rem;background:var(--bg);color:#fff;padding:.7rem 1.4rem}
.brand{display:flex;align-items:center;gap:.6rem;color:#fff;font-weight:600}
.logo{display:inline-grid;place-items:center;width:34px;height:34px;background:var(--primary);
  border-radius:9px;font-weight:800;letter-spacing:.5px}
.logo.big{width:54px;height:54px;font-size:1.3rem;margin:auto}
.brand-name{font-size:1.05rem}
.mainnav{display:flex;gap:.3rem;margin-left:1rem}
.mainnav a{color:#c4ccdd;padding:.45rem .8rem;border-radius:8px}
.mainnav a:hover{background:rgba(255,255,255,.08);color:#fff}
.mainnav a.active{background:var(--primary);color:#fff}
.userbox{margin-left:auto;display:flex;align-items:center;gap:1rem}
.who{color:#fff;display:flex;flex-direction:column;line-height:1.15;text-align:right}
.who .meta{font-size:.72rem;color:#9aa3b8;text-transform:capitalize}
/* Sélecteur "Voir en tant que" (admin) */
.viewas{display:flex;align-items:center;gap:.3rem;background:rgba(255,255,255,.1);border-radius:8px;padding:.2rem .45rem}
.viewas .eye{font-size:.9rem}
.viewas select{background:transparent;color:#fff;border:none;font-size:.82rem;padding:.2rem;cursor:pointer}
.viewas select option{color:#1a2238}
.preview-bar{background:#fff7e6;border-bottom:1px solid #f0d8a8;color:#7a5a12;font-size:.88rem;
  padding:.5rem 1.4rem;display:flex;align-items:center;gap:.6rem;justify-content:center;flex-wrap:wrap}
.linkbtn{background:none;border:none;color:var(--primary);text-decoration:underline;cursor:pointer;font:inherit;padding:0}

.container{max-width:1080px;margin:1.6rem auto;padding:0 1.2rem}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}
.page-title{font-size:1.5rem}

/* Buttons */
button,.btn-primary,.btn-secondary,.btn-ghost,.btn-ok,.btn-no,.btn-danger{
  font:inherit;cursor:pointer;border:1px solid transparent;border-radius:9px;padding:.55rem 1rem;font-weight:600}
.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-d)}
.btn-secondary{background:#eef1f8;color:var(--ink);border-color:var(--line)}
.btn-ghost{background:transparent;color:inherit;border-color:rgba(125,135,160,.4)}
.btn-ghost:hover{background:rgba(125,135,160,.12)}
.btn-ok{background:var(--ok);color:#fff}.btn-no{background:var(--no);color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.sm{padding:.3rem .6rem;font-size:.8rem}
.inline{display:inline} .inline-actions>*{margin-right:.4rem}
.actions{display:flex;gap:.6rem;justify-content:flex-end}

/* Cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:1.2rem 1.3rem;margin-bottom:1.2rem}
.card.danger{border-color:#f3c4c0}
.empty{background:#fff;border:1px dashed var(--line);border-radius:var(--radius);padding:2.5rem;text-align:center;color:var(--muted)}

/* Auth screens */
.authcard{max-width:420px;margin:5vh auto;background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow);padding:2rem;text-align:center}
.authcard.wide{max-width:680px}
.authcard h1{font-size:1.4rem}.subtitle{color:var(--muted);margin-top:-.3rem}
.authlogo{margin-bottom:.5rem}
.stack{display:flex;flex-direction:column;gap:.9rem;text-align:left;margin-top:1rem}
.stack label,.form-grid label{display:flex;flex-direction:column;gap:.3rem;font-size:.9rem;font-weight:600;color:#444c63}
input,select,textarea{font:inherit;padding:.55rem .65rem;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:2px solid #cdd9ff;border-color:var(--primary)}
.hint{color:var(--muted);font-size:.8rem;margin-top:1rem}

/* 2FA */
.steps{text-align:left;color:#444c63}
.twofa-grid{display:grid;grid-template-columns:220px 1fr;gap:1.5rem;align-items:start;text-align:left}
.qr img{border:1px solid var(--line);border-radius:10px;background:#fff;padding:6px}
.manualkey{margin-top:.6rem;font-size:.8rem;color:var(--muted)}
.manualkey code{word-break:break-all;background:#f2f4fa;padding:2px 5px;border-radius:5px}

/* Alerts */
.alert{padding:.7rem .9rem;border-radius:9px;margin:.6rem 0;font-size:.9rem}
.alert.error{background:#fdeceb;color:#a4302a;border:1px solid #f3c4c0}
.alert.success{background:#e8f7f0;color:#13654a;border:1px solid #b6e3cf}
.alert.info{background:#eef3ff;color:#23408e;border:1px solid #c4d4f7}

/* Forms grid */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-grid .full{grid-column:1/-1}
textarea{resize:vertical}

/* Tabs */
.tabs{display:flex;gap:.4rem;margin-bottom:1rem;border-bottom:1px solid var(--line)}
.tabs a{padding:.5rem .9rem;color:var(--muted);border-bottom:2px solid transparent;font-weight:600}
.tabs a.active{color:var(--primary);border-color:var(--primary)}

/* Lead list — affichage en lignes (tout visible sans clic) */
.lead-list.rows{display:flex;flex-direction:column;gap:.6rem}
.lead-row{display:flex;gap:1.2rem;align-items:flex-start;flex-wrap:wrap;background:#fff;
  border:1px solid var(--line);border-left:4px solid var(--line);border-radius:10px;
  box-shadow:var(--shadow);padding:.85rem 1.1rem;scroll-margin-top:80px}
.lead-row.status-won{border-left-color:var(--ok)}
.lead-row.status-open{border-left-color:var(--primary)}
.lead-row.status-lost{border-left-color:var(--no);opacity:.72}
.lr-ident{display:flex;flex-direction:column;gap:.35rem;min-width:115px;align-items:flex-start}
.lr-contact{flex:2 1 230px;min-width:200px}
.lr-quals{flex:1.4 1 200px;display:flex;flex-direction:column;gap:.35rem}
.lr-tools{flex:1 1 100%;display:flex;gap:1rem;flex-wrap:wrap;align-items:center;
  border-top:1px dashed var(--line);padding-top:.7rem;margin-top:.1rem}
.amount{font-weight:800;font-size:1.05rem}
.company{font-weight:700;font-size:1.05rem}
.contact-lines{display:flex;flex-direction:column;gap:.15rem;font-size:.9rem;margin-top:.25rem}
.contact-lines .ico{display:inline-block;width:1.4em;opacity:.8}
.lc-notes{font-size:.85rem;color:#444c63;background:#f6f8fc;border-radius:8px;padding:.4rem .55rem;margin-top:.3rem}
.lc-meta{margin-top:.25rem}
.qual-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}
.qual-row .qual-comment{font-size:.82rem;font-style:italic;color:#444c63}
.lc-hint{margin:0}
/* Qualification rapide */
.quickqual{flex:2 1 300px;display:flex;gap:.4rem;flex-wrap:wrap;align-items:center;background:#f6f8fc;border-radius:9px;padding:.55rem}
.qq-comment{flex:1 1 100%;padding:.4rem .55rem;font-size:.88rem}
/* Actions clôture — barre alignée à droite, sur une seule ligne */
.lc-actions{flex:1 1 auto;display:flex;gap:.45rem;flex-wrap:wrap;align-items:center;justify-content:flex-end;margin-left:auto}
.lc-actions form{display:flex;align-items:center;margin:0}
.lc-actions .sm{min-height:34px;display:inline-flex;align-items:center;justify-content:center}
.closeform{gap:.35rem}
.closeform select{padding:.3rem .45rem;min-height:34px}

/* Badges & pills */
.badge{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.75rem;font-weight:700;color:#fff}
.brand-havas{background:var(--havas)} .brand-ailleurs{background:var(--ailleurs)} .brand-supertripper{background:var(--supertripper)}
.status-pill{font-size:.75rem;font-weight:700;padding:.15rem .55rem;border-radius:999px}
.status-pill.open{background:#eef1ff;color:var(--primary)}
.status-pill.won{background:#e8f7f0;color:var(--ok)}
.status-pill.lost{background:#fdeceb;color:var(--no)}
.tag{font-size:.72rem;font-weight:700;padding:.1rem .45rem;border-radius:6px}
.tag.ok{background:#e8f7f0;color:var(--ok)} .tag.no{background:#fdeceb;color:var(--no)}
.quals .tag{margin-left:.25rem}

/* Detail */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.detail-grid .card{margin:0}
.kv{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1rem;margin:0}
.kv dt{color:var(--muted);font-size:.85rem} .kv dd{margin:0;font-weight:600}
.quallist{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.6rem}
.quallist li{display:flex;flex-direction:column;gap:.25rem;border-left:3px solid var(--line);padding-left:.6rem}
.qual-head{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.qual-comment{font-size:.85rem;color:#444c63;font-style:italic;background:#f6f8fc;border-radius:6px;padding:.35rem .55rem}
.qualform{margin-top:.8rem;border-top:1px solid var(--line);padding-top:.8rem}
.qualform .radio{flex-direction:row;align-items:flex-start;gap:.5rem;font-weight:400;font-size:.9rem}
.qualform .radio input{width:auto;margin-top:.2rem}

/* Stats */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.2rem}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:1rem;text-align:center;display:flex;flex-direction:column;gap:.2rem}
.kpi.highlight{background:#0f1525;color:#fff}
.kpi-val{font-size:1.5rem;font-weight:800}.kpi-lbl{font-size:.8rem;color:var(--muted)}
.kpi.highlight .kpi-lbl{color:#9aa3b8}
.table{width:100%;border-collapse:collapse}
.table th,.table td{text-align:left;padding:.6rem .5rem;border-bottom:1px solid var(--line)}
.table th{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.02em}
.period select{margin-left:.4rem}

/* Users table */
.rolef select{padding:.25rem .4rem}
.rowactions{display:flex;gap:.3rem;flex-wrap:wrap}
.row-off{opacity:.5}

.appfoot{text-align:center;color:var(--muted);font-size:.8rem;padding:2rem 1rem}

@media(max-width:720px){
  .form-grid,.detail-grid,.twofa-grid{grid-template-columns:1fr}
  .topbar{flex-wrap:wrap;gap:.6rem}.mainnav{margin-left:0}.userbox{margin-left:0}
}
