*{box-sizing:border-box;margin:0;padding:0}
:root{--navy:#0d1b4b;--coral:#e8604a;--navy-light:#1a2d6b;--bg:#f8f9fc;--text:#1a1a2e;--text-muted:#6b7280;--border:#e5e7eb;--card-bg:#ffffff;--surface:#f3f4f6}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}
a{color:inherit;text-decoration:none}

nav{background:var(--navy);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:64px;position:sticky;top:0;z-index:100}
.logo{display:flex;align-items:center;gap:2px;text-decoration:none}
.logo-doc{color:#fff;font-size:22px;font-weight:600;letter-spacing:-0.5px}
.logo-formed{color:var(--coral);font-size:22px;font-weight:600;letter-spacing:-0.5px}
.nav-links{display:flex;gap:4px}
.nav-btn{background:none;border:none;color:rgba(255,255,255,0.8);font-size:13px;padding:8px 14px;border-radius:6px;cursor:pointer;font-family:inherit;transition:background 0.15s;text-decoration:none;display:inline-block}
.nav-btn:hover,.nav-btn.active{background:rgba(255,255,255,0.12);color:#fff}
.nav-contact{background:var(--coral);color:#fff;font-size:13px;padding:9px 18px;border-radius:6px;font-family:inherit;font-weight:500;text-decoration:none;display:inline-block}
.nav-contact:hover{opacity:0.9}

.hero{background:var(--navy);padding:6rem 2rem 5rem;text-align:center}
.hero-badge{display:inline-block;background:rgba(232,96,74,0.2);color:#f0a090;font-size:12px;padding:5px 16px;border-radius:20px;margin-bottom:1.5rem;letter-spacing:0.5px;font-weight:500}
.hero h1{color:#fff;font-size:46px;font-weight:700;line-height:1.15;max-width:700px;margin:0 auto 1rem;letter-spacing:-1.5px}
.hero h1 span{color:var(--coral)}
.hero-sub{color:rgba(255,255,255,0.65);font-size:18px;max-width:540px;margin:0 auto 2.5rem;line-height:1.65}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-primary{background:var(--coral);color:#fff;padding:14px 30px;border-radius:8px;font-size:15px;font-weight:600;font-family:inherit;text-decoration:none;display:inline-block}
.btn-primary:hover{opacity:0.9}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,0.4);padding:14px 30px;border-radius:8px;font-size:15px;font-family:inherit;text-decoration:none;display:inline-block}
.btn-outline:hover{background:rgba(255,255,255,0.08)}
.badges-row{display:flex;justify-content:center;gap:10px;margin-top:3rem;flex-wrap:wrap}
.trust-badge{background:rgba(255,255,255,0.08);border:0.5px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.75);font-size:12px;padding:6px 14px;border-radius:20px}

.stats-section{background:var(--navy);padding:3rem 2rem;border-top:1px solid rgba(255,255,255,0.08)}
.stats-inner{max-width:960px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2rem;text-align:center}
.stat-number{color:var(--coral);font-size:42px;font-weight:700;letter-spacing:-1px;line-height:1}
.stat-label{color:rgba(255,255,255,0.6);font-size:13px;margin-top:6px;line-height:1.4}

.why-section{background:#fff;padding:5rem 2rem;border-bottom:1px solid var(--border)}
.why-inner{max-width:960px;margin:0 auto;text-align:center}
.section-label{font-size:11px;letter-spacing:1px;color:var(--coral);font-weight:600;margin-bottom:0.5rem}
.section-title{font-size:30px;font-weight:700;letter-spacing:-0.5px;margin-bottom:0.75rem}
.section-sub{color:var(--text-muted);font-size:16px;margin-bottom:3rem;max-width:540px;margin-left:auto;margin-right:auto}
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-top:3rem}
.why-card{background:var(--surface);border-radius:12px;padding:1.75rem 1.5rem;text-align:left}
.why-icon{width:44px;height:44px;border-radius:10px;background:var(--navy);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;font-size:20px}
.why-card h3{font-size:15px;font-weight:600;margin-bottom:6px}
.why-card p{font-size:13px;color:var(--text-muted);line-height:1.6}

.section{padding:5rem 2rem}
.section-inner{max-width:960px;margin:0 auto}
.profs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:20px;max-width:960px;margin:0 auto}
.prof-card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:1.75rem 1.5rem;text-decoration:none;display:block;transition:border-color 0.2s,transform 0.2s;text-align:center;color:var(--text)}
.prof-card:hover{border-color:var(--navy);transform:translateY(-3px)}
.prof-icon{width:52px;height:52px;border-radius:14px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-size:24px}
.prof-icon.blue{background:#E6F1FB}
.prof-icon.teal{background:#E1F5EE}
.prof-icon.coral{background:#FAECE7}
.prof-icon.purple{background:#EEEDFE}
.prof-card h3{font-size:17px;font-weight:600;margin-bottom:8px}
.prof-card p{font-size:13px;color:var(--text-muted);line-height:1.55}
.prof-count{display:inline-block;background:#E6F1FB;color:#0C447C;font-size:11px;padding:4px 12px;border-radius:20px;margin-top:12px;font-weight:600}

.page-hero{background:var(--navy);padding:3.5rem 2rem}
.page-hero-inner{max-width:960px;margin:0 auto}
.back-btn{color:rgba(255,255,255,0.55);font-size:13px;margin-bottom:1rem;display:inline-flex;align-items:center;gap:6px;text-decoration:none}
.back-btn:hover{color:#fff}
.page-hero h1{color:#fff;font-size:34px;font-weight:700;letter-spacing:-1px;margin-bottom:6px}
.page-hero p{color:rgba(255,255,255,0.6);font-size:15px}

.formations-section{padding:3rem 2rem;max-width:960px;margin:0 auto}
.highlight-bar{background:#EFF6FF;border-left:3px solid #185FA5;padding:14px 18px;border-radius:0 10px 10px 0;margin-bottom:2rem;font-size:14px;color:#1e3a8a;line-height:1.6}

/* ACCORDION CARDS */
.formation-card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;margin-bottom:12px;overflow:hidden;transition:border-color 0.15s}
.formation-card:hover{border-color:#b0bbdd}
.formation-summary{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;gap:16px;flex-wrap:wrap;cursor:pointer;list-style:none}
.formation-summary::-webkit-details-marker{display:none}
.formation-left{flex:1;min-width:0}
.formation-title{font-size:16px;font-weight:600;margin-bottom:8px;line-height:1.4;color:var(--text)}
.formation-accroche{font-size:13px;color:var(--text-muted);line-height:1.5;margin-top:4px}
.formation-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.tag{font-size:11px;padding:4px 11px;border-radius:20px;font-weight:600}
.tag-dpc{background:#DCFCE7;color:#166534}
.tag-opco{background:#DBEAFE;color:#1e40af}
.tag-duree{background:#F3F4F6;color:#374151}
.tag-mode{background:#EDE9FE;color:#4C1D95}
.tag-date{background:#FEF3C7;color:#92400E}
.tag-region{background:#FEE2E2;color:#991B1B}
.formation-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.cta-info{background:var(--navy);color:#fff;padding:10px 18px;border-radius:8px;font-size:13px;font-weight:600;white-space:nowrap;text-decoration:none;display:inline-block}
.cta-info:hover{background:var(--navy-light)}
.accordion-arrow{color:var(--text-muted);font-size:18px;transition:transform 0.2s;user-select:none}
details[open] .accordion-arrow{transform:rotate(180deg)}
details[open] .formation-summary{border-bottom:1px solid var(--border)}
.formation-body{padding:1.25rem 1.5rem;background:var(--surface)}
.formation-body p{font-size:14px;color:var(--text-muted);line-height:1.75;margin-bottom:0.75rem}
.formation-body p:last-child{margin-bottom:0}
.formation-body strong{color:var(--text);font-weight:600}

.contact-section{background:var(--navy);padding:4rem 2rem;text-align:center}
.contact-section h2{color:#fff;font-size:28px;font-weight:700;margin-bottom:0.5rem;letter-spacing:-0.5px}
.contact-section p{color:rgba(255,255,255,0.6);font-size:15px;margin-bottom:2.5rem}
.contact-cards{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.contact-card{background:rgba(255,255,255,0.08);border:0.5px solid rgba(255,255,255,0.15);border-radius:12px;padding:1.5rem 2.5rem;text-align:center}
.contact-card-label{font-size:11px;color:rgba(255,255,255,0.45);margin-bottom:8px;letter-spacing:0.8px;font-weight:600}
.contact-card-value{color:#fff;font-size:18px;font-weight:600}

.partners-strip{background:#fff;padding:2.5rem 2rem;border-top:1px solid var(--border);text-align:center}
.partners-label{font-size:11px;color:var(--text-muted);letter-spacing:1px;margin-bottom:1.25rem;font-weight:600}
.partners-logos{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;align-items:center}
.partner-pill{font-size:12px;font-weight:600;color:var(--text-muted);border:1px solid var(--border);padding:6px 16px;border-radius:20px}

.contact-form-wrap{padding:3rem 2rem;max-width:640px;margin:0 auto}
.contact-info-cards{display:flex;gap:14px;margin-bottom:2rem;flex-wrap:wrap}
.contact-info-card{flex:1;min-width:200px;background:var(--surface);border-radius:12px;padding:1.25rem;text-align:center}
.contact-info-card .label{font-size:11px;color:var(--text-muted);margin-bottom:6px;font-weight:600;letter-spacing:0.5px}
.contact-info-card .value{font-size:17px;font-weight:700;color:var(--navy)}
.form-card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:2rem}
.form-card h2{font-size:20px;font-weight:700;margin-bottom:1.5rem}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:13px;font-weight:500;margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:14px;color:var(--text);background:#fff;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--navy)}
.form-group textarea{height:110px;resize:vertical}
.form-submit{background:var(--navy);color:#fff;border:none;padding:13px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;width:100%;margin-top:6px}
.form-submit:hover{background:var(--navy-light)}

footer{background:#070f2b;padding:2rem;text-align:center}
footer p{color:rgba(255,255,255,0.35);font-size:12px}

@media(max-width:680px){
  .hero h1{font-size:32px}
  .nav-links{display:none}
  .formations-section{padding:2rem 1rem}
  .formation-summary{flex-direction:column;align-items:flex-start}
  .formation-right{width:100%}
  .cta-info{width:100%;text-align:center}
  .stat-number{font-size:32px}
}
