/* =========================================================
   ESPACE CLIENT — Crédit Pro (éditorial ivoire)
   ========================================================= */
:root{
  --bg:#F3F0E8; --card:#FFFFFF; --ink:#16241E; --muted:#5C6A60; --line:#E3DDCD;
  --gold:#B8924A; --gold-l:#D0B074; --navy:#0F3D2E;
  --ok:#15803D; --ok-bg:#DCFCE7; --ko:#C13338; --ko-bg:#FEF2F2; --wait:#B45309; --wait-bg:#FEF7EC;
  --serif:'Fraunces',Georgia,serif; --sans:'Inter',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
body.cp{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased}
h1,h2{font-family:var(--serif);font-weight:500;letter-spacing:-.01em}
a{color:var(--gold)}

/* ---- Auth ---- */
.cp-auth{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.cp-auth-card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 24px 60px rgba(20,27,46,.12);max-width:400px;width:100%;padding:38px 34px;text-align:center}
.cp-mark{border-radius:12px;margin:0 auto 16px;display:block}
.cp-auth-card h1{font-size:1.6rem;margin:0 0 6px}
.cp-sub{color:var(--muted);font-size:.95rem;margin:0 0 22px;line-height:1.5}
.cp-auth-card form{display:flex;flex-direction:column;gap:14px;text-align:left}
.cp-auth-card label{font-size:.82rem;font-weight:600;color:var(--ink);display:flex;flex-direction:column;gap:6px}
.cp-auth-card input{padding:12px 14px;border:1px solid var(--line);border-radius:9px;font-size:1rem;font-family:inherit;background:#fff}
.cp-auth-card input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(169,132,76,.15)}
.cp-btn{display:inline-block;background:var(--navy);color:#fff;text-decoration:none;text-align:center;padding:13px 22px;border:0;border-radius:9px;font-size:.97rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s}
.cp-btn:hover{background:#0A2D22;color:#fff}
.cp-btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.cp-btn-sm{padding:8px 14px;font-size:.85rem}
.cp-mini{color:#9A9488;font-size:.78rem;margin:18px 0 0}
.cp-info-msg{background:#EBF2EC;color:#15803D;border:1px solid #b9e0c5;border-radius:8px;padding:10px 14px;font-size:.86rem;font-weight:600;margin:0 0 16px}
.cp-forgot{margin-top:16px;text-align:left}
.cp-forgot summary{cursor:pointer;color:var(--gold);font-size:.85rem;font-weight:600;list-style:none}
.cp-forgot summary::-webkit-details-marker{display:none}
.cp-forgot form{margin-top:12px}
.cp-err{background:var(--ko-bg);color:var(--ko);border:1px solid #f5c6c7;border-radius:8px;padding:10px 14px;font-size:.88rem;font-weight:600;margin:0 0 16px}
.cp-ok{color:var(--ok);font-weight:700;font-size:1.05rem;margin:0 0 6px}

/* ---- Header ---- */
.cp-header{background:var(--navy)}
.cp-header-in{max-width:920px;margin:0 auto;padding:16px 20px;display:flex;align-items:center;justify-content:space-between}
.cp-brand{display:inline-flex;align-items:center;gap:10px;color:#fff;font-family:var(--serif);font-size:1.15rem;font-weight:600}
.cp-brand b{color:var(--gold-l);font-weight:600}
.cp-logout{color:rgba(255,255,255,.8);text-decoration:none;font-size:.88rem;font-weight:600;margin-left:auto}
.cp-logout:hover{color:#fff}

/* ---- Portal ---- */
.cp-portal{max-width:920px;margin:0 auto;padding:32px 20px 60px}
.cp-h1{font-size:clamp(1.6rem,3.5vw,2.2rem);margin:0 0 24px}
.cp-panel{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px 28px;margin-bottom:22px}
.cp-panel h2{font-size:1.3rem;margin:0 0 16px}
.cp-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.cp-panel-head h2{margin:0}
.cp-muted{color:var(--muted)}

/* ---- État + progression ---- */
.cp-state{font-size:.82rem;font-weight:700;color:var(--gold);background:#fff;border:1px solid var(--line);padding:6px 12px;border-radius:999px}
.cp-state-ok{color:var(--ok);background:var(--ok-bg);border-color:#a7e3bf}
.cp-state-ko{color:var(--ko);background:var(--ko-bg);border-color:#f5c6c7}
.cp-progress{height:8px;background:#EDE7D9;border-radius:999px;overflow:hidden}
.cp-progress-bar{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-l));border-radius:999px;transition:width .4s}
.cp-progress-pct{margin:8px 0 18px;font-size:.82rem;color:var(--muted);font-weight:600}
.cp-timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.cp-step{display:flex;align-items:center;gap:14px;padding:11px 0;color:var(--muted);font-size:.95rem;position:relative}
.cp-step .cp-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--line);background:#fff;flex-shrink:0}
.cp-step + .cp-step::before{content:'';position:absolute;left:7px;top:-9px;height:9px;width:2px;background:var(--line)}
.cp-step-done{color:var(--ink)}
.cp-step-done .cp-dot{background:var(--gold);border-color:var(--gold)}
.cp-step-current{color:var(--ink);font-weight:700}
.cp-step-current .cp-dot{background:#fff;border-color:var(--gold);box-shadow:0 0 0 4px rgba(169,132,76,.22)}

/* ---- Documents ---- */
.cp-docs{list-style:none;margin:0;padding:0}
.cp-doc{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.cp-doc:last-child{border-bottom:0}
.cp-doc-name{font-weight:600;font-size:.95rem}
.cp-doc-actions{display:flex;align-items:center;gap:12px}
.cp-doc-actions a{font-weight:600;font-size:.85rem;text-decoration:none}
.cp-badge{font-size:.74rem;font-weight:700;padding:5px 10px;border-radius:999px}
.cp-badge-valide{color:var(--ok);background:var(--ok-bg)}
.cp-badge-refuse{color:var(--ko);background:var(--ko-bg)}
.cp-badge-attente{color:var(--wait);background:var(--wait-bg)}
.cp-badge-todo{color:#8A6B3A;background:#F1E7D3}
.cp-missing{margin-top:16px;background:#fff;border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:0 8px 8px 0;padding:12px 14px;font-size:.86rem;color:var(--muted);line-height:1.5}
.cp-missing strong{color:var(--ink);display:block;margin-bottom:3px}

/* ---- Infos ---- */
.cp-info{display:grid;grid-template-columns:1fr 1fr;gap:0 28px}
.cp-info-row{display:flex;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.cp-info-row span{color:var(--muted)}
.cp-info-row strong{color:var(--ink);font-weight:600;text-align:right}

@media (max-width:640px){
  .cp-info{grid-template-columns:1fr}
  .cp-panel{padding:22px 18px}
}

/* ---- En-tête : titre à gauche, conseiller en haut à droite ---- */
.cp-top{display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:24px}
.cp-top .cp-h1{margin:0;flex:1 1 320px}

/* ---- Carte conseiller dédié ---- */
.cp-advisor-card{flex:0 0 auto;width:280px;max-width:100%;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:0 14px 34px rgba(20,27,46,.08)}
.cp-advisor-head{display:flex;align-items:center;gap:13px;margin-bottom:15px}
.cp-advisor-pic{width:52px;height:52px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--gold),var(--gold-l));color:#fff;font-family:var(--serif);font-size:1.15rem;font-weight:700;letter-spacing:.02em}
.cp-advisor-label{display:block;font-size:.72rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.cp-advisor-name{display:block;font-size:1.08rem;color:var(--ink);font-weight:700;line-height:1.2;margin-top:2px}
.cp-advisor-contact{display:flex;flex-direction:column;gap:8px}
.cp-advisor-btn{display:flex;align-items:center;gap:9px;padding:11px 14px;border-radius:9px;font-size:.92rem;font-weight:700;text-decoration:none;transition:filter .15s,background .15s}
.cp-advisor-ico{flex-shrink:0;display:inline-flex;line-height:1}
.cp-advisor-call{background:var(--navy);color:#fff}
.cp-advisor-call:hover{filter:brightness(1.15)}
.cp-advisor-wa{background:#25D366;color:#fff}
.cp-advisor-wa:hover{filter:brightness(.93)}
@media (max-width:640px){
  .cp-advisor-card{width:100%}
}

/* ---- Navbar identique au site (cp-topbar) ---- */
.cp-topbar{background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.cp-topbar-in{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0}
.cp-logo{display:inline-flex;align-items:center;gap:9px;text-decoration:none;min-width:0}
.cp-logo img{height:36px;width:auto;display:block;flex-shrink:0;border-radius:9px}
.cp-logo .cp-wordmark{font-family:var(--serif);font-weight:700;font-size:1.02rem;letter-spacing:.04em;color:var(--ink);line-height:1;white-space:nowrap}
.cp-logo .cp-wordmark span{color:var(--gold)}
.cp-nav{display:flex;align-items:center;gap:20px;min-width:0}
.cp-nav a{text-decoration:none;color:var(--ink);font-size:.9rem;font-weight:600;transition:color .2s;white-space:nowrap}
.cp-nav a:hover{color:var(--gold)}
@media (max-width:900px){
  .cp-nav a:not(.btn){display:none}
  .cp-logo img{height:32px}
}
@media (max-width:360px){.cp-logo .cp-wordmark{display:none}}

/* ---- Mon compte (bouton pill sur barre claire) ---- */
.cp-account{position:relative;flex-shrink:0}
.cp-account-btn{display:inline-flex;align-items:center;gap:9px;background:var(--navy);border:1px solid var(--navy);color:#fff;padding:6px 14px 6px 6px;border-radius:999px;font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;transition:filter .15s}
.cp-account-btn:hover{filter:brightness(1.18)}
.cp-account-ava{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-l));color:#fff;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700}
.cp-account-caret{font-size:.7rem;opacity:.85}
.cp-account-menu{position:absolute;top:calc(100% + 10px);right:0;width:250px;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 44px rgba(20,27,46,.22);padding:8px;z-index:50}
.cp-account-card{display:flex;flex-direction:column;gap:2px;padding:12px 12px 14px;border-bottom:1px solid var(--line)}
.cp-account-cname{font-size:1rem;color:var(--ink);font-weight:700}
.cp-account-card span{font-size:.85rem;color:var(--muted)}
.cp-account-mail{word-break:break-all}
.cp-account-logout{display:block;text-align:center;margin-top:6px;padding:11px;border-radius:9px;background:var(--navy);color:#fff;text-decoration:none;font-size:.9rem;font-weight:600;transition:filter .15s}
.cp-account-logout:hover{filter:brightness(1.15);color:#fff}
@media (max-width:480px){.cp-account-txt{display:none}}

/* ---- Onglets espace ---- */
.cp-tabs{display:flex;gap:6px;margin:0 0 22px;border-bottom:1px solid var(--line)}
.cp-tab{appearance:none;background:none;border:0;border-bottom:2px solid transparent;margin-bottom:-1px;padding:11px 16px;font-family:inherit;font-size:.96rem;font-weight:600;color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s}
.cp-tab:hover{color:var(--ink)}
.cp-tab.active{color:var(--gold);border-bottom-color:var(--gold)}

/* ---- Logo navbar ---- */
.cp-brand-mark{width:36px;height:36px;border-radius:9px;display:block;box-shadow:0 6px 16px rgba(14,35,80,.35)}

/* ---- Footer (identique au site vitrine) ---- */
.container{width:min(100% - 40px, 1180px);margin:0 auto}
.footer{background:var(--navy);color:rgba(226,233,247,.6);padding:70px 0 28px;font-size:.92rem}
.footer a{color:rgba(226,233,247,.62);text-decoration:none}
.footer a:hover{color:#fff}
.footer .brand{display:inline-flex;align-items:center;gap:11px;text-decoration:none}
.footer .brand-mark{width:40px;height:40px;border-radius:11px;display:block;box-shadow:0 6px 16px rgba(14,35,80,.35)}
.footer .brand-text{font-family:var(--serif);font-weight:700;font-size:1.2rem;color:#fff;letter-spacing:-.02em}
.footer .brand-text span{color:var(--gold-l)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:56px;margin-bottom:48px}
.footer-tag{color:rgba(226,233,247,.5);line-height:1.6;max-width:320px;margin:18px 0 0;font-size:.9rem}
.footer-grid h4{font-family:var(--sans);color:#fff;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;margin:0 0 18px}
.footer-grid ul{list-style:none;margin:0;padding:0}
.footer-grid li{margin-bottom:11px}
.footer-bottom{padding-top:28px;border-top:1px solid rgba(255,255,255,.08);font-size:.8rem;color:rgba(226,233,247,.4);text-align:center;line-height:1.7}
@media (max-width:760px){.footer-grid{grid-template-columns:1fr;gap:34px}}

/* ---- Dossier complet (plus de pièces à importer) ---- */
.cp-complete{display:flex;flex-direction:column;gap:4px;background:var(--ok-bg);border:1px solid #a7e3bf;border-radius:10px;padding:14px 16px;margin-bottom:14px}
.cp-complete strong{color:var(--ok);font-size:1rem}
.cp-complete span{color:#3f6e50;font-size:.9rem;line-height:1.5}
