/*
Theme Name: CreditPro Paris
Theme URI: https://creditpro.paris
Description: Thème sur-mesure pour CreditPro Paris — courtage en crédit professionnel en Île-de-France. Charte bleu finance & or.
Author: CreditPro Paris
Version: 1.0
*/

:root{
  --cp-primary:#1657D0;        /* bleu confiance */
  --cp-primary-d:#0E3FA0;
  --cp-dark:#0A2540;           /* navy texte */
  --cp-ink:#13233a;            /* texte */
  --cp-mut:#5a6b80;            /* texte secondaire */
  --cp-bg:#ffffff;
  --cp-soft:#eef3fd;           /* fond bleu très clair */
  --cp-line:#e2e8f2;
  --cp-accent:#E8B53A;         /* or premium */
  --cp-radius:16px;
  --cp-shadow:0 10px 30px rgba(10,37,64,.09);
  --cp-wrap:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--cp-ink);background:var(--cp-bg);line-height:1.65;font-size:17px}
img{max-width:100%;height:auto;display:block}
a{color:var(--cp-primary-d);text-decoration:none}
h1,h2,h3{line-height:1.2;color:var(--cp-dark);margin:.2em 0 .5em;font-weight:800;letter-spacing:-.01em}
h1{font-size:clamp(2rem,4.5vw,3.4rem)}
h2{font-size:clamp(1.5rem,3vw,2.3rem)}
h3{font-size:1.2rem}
p{margin:0 0 1rem}
.cp-wrap{max-width:var(--cp-wrap);margin:0 auto;padding:0 24px}

/* Header */
.cp-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--cp-line)}
.cp-header .cp-wrap{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.cp-brand{font-weight:900;font-size:1.45rem;color:var(--cp-dark);letter-spacing:-.02em}
.cp-brand span{color:var(--cp-primary)}
.cp-nav{display:flex;align-items:center;gap:26px}
.cp-nav ul{display:flex;gap:24px;list-style:none;margin:0;padding:0}
.cp-nav a{color:var(--cp-ink);font-weight:600;font-size:.97rem}
.cp-nav a:hover{color:var(--cp-primary)}
.cp-btn{display:inline-block;background:var(--cp-primary);color:#fff;font-weight:700;padding:13px 22px;border-radius:999px;transition:.2s;border:0;cursor:pointer;font-size:.97rem}
.cp-btn:hover{background:var(--cp-primary-d);color:#fff;transform:translateY(-1px)}
.cp-btn-ghost{background:transparent;color:var(--cp-dark);border:1.5px solid var(--cp-line)}
.cp-btn-ghost:hover{border-color:var(--cp-primary);color:var(--cp-primary);background:transparent}
.cp-btn-lg{padding:16px 30px;font-size:1.05rem}
.cp-burger{display:none;background:none;border:0;font-size:1.6rem;color:var(--cp-dark);cursor:pointer}

/* Sections */
.cp-section{padding:84px 0}
.cp-section.alt{background:var(--cp-soft)}
.cp-center{text-align:center;max-width:760px;margin:0 auto 48px}
.cp-eyebrow{display:inline-block;background:var(--cp-soft);color:var(--cp-primary-d);font-weight:700;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:999px;margin-bottom:16px;border:1px solid var(--cp-line)}
.cp-lead{font-size:1.15rem;color:var(--cp-mut)}

/* Hero */
.cp-hero{background:linear-gradient(160deg,#0A2540 0%,#1657D0 135%);color:#fff;padding:96px 0 104px;position:relative;overflow:hidden}
.cp-hero h1{color:#fff;max-width:14ch}
.cp-hero .cp-lead{color:rgba(255,255,255,.9);font-size:1.25rem;max-width:54ch}
.cp-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.cp-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.cp-hero .cp-btn-ghost{color:#fff;border-color:rgba(255,255,255,.4)}
.cp-hero .cp-btn-ghost:hover{border-color:#fff;color:#fff}
.cp-hero-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:var(--cp-radius);padding:26px;backdrop-filter:blur(6px)}
.cp-hero-card h3{color:#fff}
.cp-hero-card ul{list-style:none;margin:0;padding:0}
.cp-hero-card li{padding:10px 0;border-bottom:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.92);display:flex;gap:10px}
.cp-hero-card li:last-child{border:0}
.cp-hero-card li::before{content:"✓";color:var(--cp-accent);font-weight:900}
.cp-trust{display:flex;gap:36px;flex-wrap:wrap;justify-content:center;margin-top:8px;color:var(--cp-mut);font-weight:600;font-size:.95rem}
.cp-trust b{color:var(--cp-dark);font-size:1.6rem;display:block}

/* Grid / cards */
.cp-grid{display:grid;gap:24px}
.cp-g3{grid-template-columns:repeat(3,1fr)}
.cp-g2{grid-template-columns:repeat(2,1fr)}
.cp-card{background:#fff;border:1px solid var(--cp-line);border-radius:var(--cp-radius);padding:30px;box-shadow:var(--cp-shadow)}
.cp-card h3{margin-top:6px}
.cp-ico{width:52px;height:52px;border-radius:14px;background:var(--cp-soft);color:var(--cp-primary);display:flex;align-items:center;justify-content:center;font-size:1.6rem;font-weight:900;margin-bottom:6px}
.cp-step-n{font-size:2.4rem;font-weight:900;color:var(--cp-accent);-webkit-text-stroke:1px var(--cp-primary);line-height:1}

/* Lists */
.cp-check{list-style:none;margin:0;padding:0}
.cp-check li{position:relative;padding:8px 0 8px 32px;color:var(--cp-ink)}
.cp-check li::before{content:"✓";position:absolute;left:0;top:8px;color:var(--cp-primary);font-weight:900}

/* Pricing */
.cp-price{background:#fff;border:1px solid var(--cp-line);border-radius:var(--cp-radius);padding:32px;box-shadow:var(--cp-shadow);display:flex;flex-direction:column}
.cp-price.feat{border:2px solid var(--cp-primary);position:relative}
.cp-price.feat::after{content:"Le plus choisi";position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--cp-primary);color:#fff;font-size:.72rem;font-weight:700;padding:5px 14px;border-radius:999px;letter-spacing:.04em}
.cp-amount{font-size:2.4rem;font-weight:900;color:var(--cp-dark);margin:6px 0}
.cp-amount small{font-size:.95rem;font-weight:600;color:var(--cp-mut)}
.cp-price .cp-btn{margin-top:auto}

/* FAQ */
.cp-faq details{background:#fff;border:1px solid var(--cp-line);border-radius:12px;padding:6px 22px;margin-bottom:12px}
.cp-faq summary{cursor:pointer;font-weight:700;color:var(--cp-dark);padding:14px 0;list-style:none;position:relative}
.cp-faq summary::-webkit-details-marker{display:none}
.cp-faq summary::after{content:"+";position:absolute;right:0;color:var(--cp-primary);font-weight:900;font-size:1.3rem}
.cp-faq details[open] summary::after{content:"–"}
.cp-faq details[open] summary{border-bottom:1px solid var(--cp-line)}
.cp-faq p{padding:14px 0 6px;margin:0;color:var(--cp-mut)}

/* CTA band */
.cp-cta{background:var(--cp-dark);color:#fff;border-radius:24px;padding:56px;text-align:center}
.cp-cta h2{color:#fff}
.cp-cta .cp-lead{color:rgba(255,255,255,.85)}
.cp-cta .cp-btn{background:var(--cp-accent);color:var(--cp-dark)}
.cp-cta .cp-btn:hover{background:#fff}

/* Page header (inner) */
.cp-phead{background:var(--cp-soft);padding:64px 0;text-align:center;border-bottom:1px solid var(--cp-line)}
.cp-phead h1{margin:0}

/* Footer */
.cp-footer{background:var(--cp-dark);color:rgba(255,255,255,.8);padding:60px 0 28px}
.cp-footer a{color:rgba(255,255,255,.8)}
.cp-footer a:hover{color:#fff}
.cp-fgrid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:36px}
.cp-footer h4{color:#fff;margin:0 0 14px;font-size:1rem}
.cp-footer ul{list-style:none;margin:0;padding:0}
.cp-footer li{padding:5px 0}
.cp-fbrand{font-weight:900;font-size:1.4rem;color:#fff}
.cp-fbrand span{color:var(--cp-accent)}
.cp-copy{border-top:1px solid rgba(255,255,255,.14);padding-top:22px;font-size:.88rem;color:rgba(255,255,255,.6);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* content typography for page bodies */
.cp-body{max-width:820px;margin:0 auto}
.cp-body h2{margin-top:1.6em}
.cp-body table{width:100%;border-collapse:collapse;margin:1.2em 0}
.cp-body th,.cp-body td{border:1px solid var(--cp-line);padding:12px 14px;text-align:left}
.cp-body th{background:var(--cp-soft);color:var(--cp-dark)}

@media(max-width:900px){
  .cp-hero-grid,.cp-g3,.cp-g2,.cp-fgrid{grid-template-columns:1fr}
  .cp-nav ul,.cp-nav .cp-btn{display:none}
  .cp-nav.open ul{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:#fff;padding:18px 24px;border-bottom:1px solid var(--cp-line);box-shadow:var(--cp-shadow)}
  .cp-nav.open .cp-btn{display:inline-block;margin-top:10px}
  .cp-burger{display:block}
  .cp-section{padding:60px 0}
  .cp-cta{padding:40px 22px}
}

/* Blog */
.cp-postcard{padding:0;overflow:hidden;display:flex;flex-direction:column;transition:.2s;text-decoration:none;color:inherit}
.cp-postcard:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(8,61,43,.14)}
.cp-thumb{aspect-ratio:16/9;overflow:hidden;background:var(--cp-soft)}
.cp-thumb img{width:100%;height:100%;object-fit:cover}
.cp-cardbody{padding:24px}
.cp-cardbody h3{margin:8px 0}
.cp-readmore{color:var(--cp-primary);font-weight:700;font-size:.95rem}
.cp-singlethumb{border-radius:var(--cp-radius);overflow:hidden;margin-bottom:30px}
.cp-singlethumb img{width:100%;height:auto;display:block}
.nav-links{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.nav-links .page-numbers{display:inline-flex;min-width:42px;height:42px;align-items:center;justify-content:center;border:1px solid var(--cp-line);border-radius:10px;color:var(--cp-dark);font-weight:600;padding:0 12px}
.nav-links .page-numbers.current{background:var(--cp-primary);color:#fff;border-color:var(--cp-primary)}

/* Portail ValorPro (déplacé du plugin pour fiabilité de chargement) */
.cp-portal input,.cp-portal select,.cp-portal textarea{width:100%;padding:11px 13px;border:1px solid var(--cp-line);border-radius:10px;font:inherit;background:#fff}
.cp-contactlist{list-style:none;margin:18px 0 0;padding:0}
.cp-contactlist li{padding:9px 0;border-bottom:1px solid var(--cp-line)}
.cp-contactlist li:last-child{border:0}
.cp-portal label{font-weight:600;font-size:.92rem;color:var(--cp-dark)}
.cp-portal form p{margin:0 0 14px}
.cp-alert{padding:14px 18px;border-radius:12px;margin-bottom:22px;font-weight:600}
.cp-alert.ok{background:#e9f9f1;color:#0A7C49;border:1px solid #b8ebd2}
.cp-alert.err{background:#fdecec;color:#b42318;border:1px solid #f6c9c4}
.cp-badge{display:inline-block;background:var(--cp-soft);color:var(--cp-primary-d);border:1px solid var(--cp-line);border-radius:999px;padding:5px 14px;font-weight:700;font-size:.82rem}
.cp-dos{margin-bottom:16px}
.cp-table-wrap{overflow-x:auto}
table.cp-bodacc{width:100%;border-collapse:collapse;font-size:.92rem}
table.cp-bodacc th,table.cp-bodacc td{border:1px solid var(--cp-line);padding:10px 12px;text-align:left;vertical-align:top}
table.cp-bodacc th{background:var(--cp-soft);color:var(--cp-dark)}
table.cp-bodacc tr:nth-child(even){background:#fafdfb}
table.cp-bodacc td:last-child,table.cp-bodacc th:last-child{white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums}

/* Espace client — layout sidebar */
.cp-app{display:grid;grid-template-columns:240px 1fr;gap:30px;align-items:start}
.cp-side nav{display:flex;flex-direction:column;gap:4px;position:sticky;top:90px;background:#fff;border:1px solid var(--cp-line);border-radius:var(--cp-radius);padding:10px;box-shadow:var(--cp-shadow)}
.cp-side a{padding:12px 14px;border-radius:10px;color:var(--cp-ink);font-weight:600;font-size:.95rem;text-decoration:none;display:block}
.cp-side a:hover{background:var(--cp-soft);color:var(--cp-primary-d)}
.cp-side a.active{background:var(--cp-primary);color:#fff}
@media(max-width:900px){.cp-app{grid-template-columns:1fr}.cp-side nav{position:static;flex-direction:row;flex-wrap:wrap}.cp-side a{flex:1;text-align:center}}

/* Espace client — dossiers maître-détail */
.cp-dositem{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:12px;text-decoration:none;color:inherit;transition:.15s}
.cp-dositem:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(8,61,43,.12)}
.cp-filelist{list-style:none;margin:0;padding:0}
.cp-filelist li{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--cp-line)}
.cp-filelist li:last-child{border:0}
.cp-x{background:#fdecec;color:#b42318;border:0;border-radius:8px;width:30px;height:30px;cursor:pointer;font-weight:700}
.cp-x:hover{background:#f6c9c4}

/* Chiffres clés (bandeau) */
.cp-statsband{background:linear-gradient(135deg,var(--cp-dark),var(--cp-primary-d));color:#fff}
.cp-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center;margin-top:18px}
.cp-stat .cp-statnum{font-size:3.2rem;font-weight:900;letter-spacing:-.02em;line-height:1;color:#fff}
.cp-stat .cp-statnum span{color:var(--cp-accent)}
.cp-stat .cp-statlbl{margin-top:10px;font-weight:600;color:rgba(255,255,255,.85);font-size:1.05rem}
@media(max-width:760px){.cp-stats{grid-template-columns:1fr;gap:34px}}

/* Avis clients (masonry) */
.cp-reviews{columns:3;column-gap:24px;margin-top:18px}
.cp-review{break-inside:avoid;-webkit-column-break-inside:avoid;background:#fff;border:1px solid var(--cp-line);border-radius:var(--cp-radius);padding:24px;box-shadow:var(--cp-shadow);margin:0 0 24px}
.cp-stars{color:#f5b301;letter-spacing:2px;font-size:1.05rem}
.cp-review p{margin:12px 0 16px;color:var(--cp-ink);font-size:.97rem}
.cp-reviewer{display:flex;align-items:center;gap:12px}
.cp-avatar{width:44px;height:44px;border-radius:50%;background:var(--cp-soft);color:var(--cp-primary-d);display:flex;align-items:center;justify-content:center;font-weight:800;flex:0 0 44px}
.cp-reviewer b{display:block;color:var(--cp-dark);font-size:.95rem}
.cp-reviewer span{color:var(--cp-mut);font-size:.85rem}
@media(max-width:980px){.cp-reviews{columns:2}}
@media(max-width:640px){.cp-reviews{columns:1}}
