:root{
  --navy:#1B2D3F; --navy-2:#243448; --navy-3:#2E4255;
  --gold:#E8BF19; --gold-deep:#B89610;
  --ink:#1C1C1C; --gray:#4A5568; --gray-soft:#94A3B8;
  --light:#F4F6F9; --paper:#FFFFFF; --line:#DDE2EA;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Inter',-apple-system,Segoe UI,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.65;font-size:16px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
section{padding:88px 0}
.label{display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:14px}
h1,h2,h3{font-family:var(--serif);color:var(--navy);line-height:1.18}
h2{font-size:clamp(28px,4vw,40px);margin-bottom:18px}
.lead{color:var(--gray);max-width:680px;font-size:17.5px}
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:15.5px;padding:15px 30px;border-radius:6px;transition:.25s;cursor:pointer;border:none}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:#f2cf3d;transform:translateY(-2px);box-shadow:0 10px 24px rgba(232,191,25,.28)}
.btn-ghost{border:1.5px solid rgba(255,255,255,.35);color:#fff}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-3);transform:translateY(-2px)}

/* ---------- Header ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(27,45,63,.92);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;flex-direction:column;line-height:1.2}
.brand .name{font-family:var(--serif);font-weight:600;font-size:19px;color:#fff}
.brand .name b{color:var(--gold);font-weight:600}
.brand .tag{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-soft)}
nav.menu{display:flex;align-items:center;gap:30px}
nav.menu a{color:#E6EBF2;font-size:14.5px;font-weight:500;transition:.2s}
nav.menu a:hover{color:var(--gold)}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav-cta .btn{padding:11px 20px;font-size:14px}
.icon-link svg{width:20px;height:20px;fill:#E6EBF2;transition:.2s}
.icon-link:hover svg{fill:var(--gold)}
.lang{color:#E6EBF2;font-weight:700;font-size:13px;letter-spacing:.06em;border:1px solid rgba(255,255,255,.3);padding:6px 11px;border-radius:6px;transition:.2s}
.lang:hover{border-color:var(--gold);color:var(--gold)}
.burger{display:none;background:none;border:none;cursor:pointer;padding:6px}
.burger span{display:block;width:24px;height:2px;background:#fff;margin:5px 0;transition:.3s}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-2) 55%,var(--navy-3) 100%);color:#fff;padding:170px 0 110px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-180px;top:-180px;width:560px;height:560px;border-radius:50%;border:1px solid rgba(232,191,25,.18)}
.hero::before{content:"";position:absolute;right:-120px;top:-120px;width:440px;height:440px;border-radius:50%;border:1px solid rgba(232,191,25,.10)}
.hero .wrap{display:grid;grid-template-columns:1.25fr .75fr;gap:60px;align-items:center;position:relative;z-index:2}
.hero h1{color:#fff;font-size:clamp(34px,5vw,54px);margin:18px 0 22px}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero p.sub{color:#C6D2DE;font-size:18px;max-width:560px;margin-bottom:36px}
.hero .label{color:var(--gold)}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-photo{justify-self:center;position:relative}
.hero-photo img{width:340px;height:410px;border-radius:18px;object-fit:cover;object-position:50% 18%;box-shadow:0 30px 60px rgba(0,0,0,.35)}
.hero-photo::after{content:"";position:absolute;inset:-14px;border:2px solid rgba(232,191,25,.55);border-radius:26px;pointer-events:none}
.hero-photo .badge{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);background:#fff;color:var(--navy);font-weight:700;font-size:13.5px;padding:9px 20px;border-radius:30px;white-space:nowrap;box-shadow:0 8px 22px rgba(0,0,0,.25)}
.cred-bar{background:var(--navy-2);border-top:1px solid rgba(255,255,255,.07);padding:26px 0}
.cred-bar .wrap{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cred{display:flex;align-items:center;gap:12px;color:#D9E1EA;font-size:14.5px;font-weight:500}
.cred svg{width:22px;height:22px;fill:var(--gold);flex-shrink:0}

/* ---------- Services ---------- */
.services{background:var(--light)}
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:50px}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:38px 32px;transition:.3s}
.card:hover{transform:translateY(-6px);box-shadow:0 22px 44px rgba(27,45,63,.10);border-color:transparent}
.card .ico{width:56px;height:56px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.card .ico svg{width:26px;height:26px;fill:var(--gold)}
.card h3{font-size:22px;margin-bottom:12px}
.card p{color:var(--gray);font-size:15.5px}
.card ul{list-style:none;margin-top:16px}
.card ul li{color:var(--gray);font-size:14.5px;padding:7px 0 7px 24px;position:relative;border-top:1px solid var(--light)}
.card ul li::before{content:"▸";color:var(--gold-deep);position:absolute;left:4px}

/* ---------- Approche ---------- */
.approche .wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.steps{display:flex;flex-direction:column;gap:0;margin-top:8px}
.step{display:flex;gap:22px;padding:22px 0;border-bottom:1px solid var(--line)}
.step:last-child{border-bottom:none}
.step .num{font-family:var(--serif);font-size:30px;font-weight:700;color:var(--gold-deep);line-height:1;min-width:46px}
.step h3{font-size:18.5px;margin-bottom:6px;font-family:var(--sans);font-weight:700;color:var(--navy)}
.step p{color:var(--gray);font-size:15px}
.network{background:var(--navy);border-radius:16px;padding:44px 38px;color:#fff}
.network h3{color:#fff;font-size:24px;margin-bottom:10px}
.network p{color:#C6D2DE;font-size:15px;margin-bottom:26px}
.net-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.net-item{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);border-radius:8px;padding:14px 10px;text-align:center;font-size:13.5px;font-weight:500;color:#E6EBF2;display:flex;align-items:center;justify-content:center}
.net-item.me{background:var(--gold);color:var(--navy);font-weight:700;border-color:var(--gold)}

/* ---------- À propos ---------- */
.apropos{background:var(--light)}
.apropos .wrap{display:grid;grid-template-columns:.8fr 1.2fr;gap:64px;align-items:center}
.apropos-photo{position:relative;justify-self:center}
.apropos-photo img{width:320px;height:385px;border-radius:18px;object-fit:cover;object-position:50% 18%;border:5px solid #fff;box-shadow:0 24px 48px rgba(27,45,63,.18)}
.titres{display:flex;flex-wrap:wrap;gap:10px;margin:24px 0}
.pill{background:#fff;border:1px solid var(--line);border-radius:30px;padding:8px 18px;font-size:13.5px;font-weight:600;color:var(--navy)}
.pill b{color:var(--gold-deep)}
.apropos p{color:var(--gray);margin-bottom:14px}

.diplome{display:inline-flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 22px;margin-top:22px;transition:.25s}
.diplome:hover{box-shadow:0 12px 28px rgba(27,45,63,.12);transform:translateY(-2px);border-color:var(--gold)}
.diplome img,.diplome .badge-svg{width:46px;height:46px;flex-shrink:0}
.diplome .badge-svg svg{width:46px;height:46px;fill:var(--gold-deep)}
.diplome .dt{font-weight:700;color:var(--navy);font-size:15px;line-height:1.3}
.diplome .ds{font-size:13px;color:var(--gray)}

/* ---------- Partenaires ---------- */
.partners{text-align:center}
.partner-row{display:flex;justify-content:center;align-items:center;gap:64px;flex-wrap:wrap;margin-top:46px}
.partner{display:flex;flex-direction:column;align-items:center;gap:12px}
.partner img{height:64px;width:auto;object-fit:contain;filter:grayscale(35%);opacity:.9;transition:.25s}
.partner img:hover{filter:none;opacity:1}
.partner span{font-size:13px;color:var(--gray-soft)}
.partner .alt{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--navy)}

/* ---------- Rendez-vous ---------- */
.rdv{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-3) 100%);color:#fff;text-align:center;position:relative;overflow:hidden}
.rdv::before{content:"";position:absolute;left:-160px;bottom:-160px;width:480px;height:480px;border-radius:50%;border:1px solid rgba(232,191,25,.15)}
.rdv h2{color:#fff}
.rdv .label{color:var(--gold)}
.rdv p{color:#C6D2DE;max-width:640px;margin:0 auto 38px}
.rdv-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:16px;max-width:720px;margin:0 auto;padding:46px 40px;position:relative;z-index:2}
.rdv-points{display:flex;justify-content:center;gap:36px;flex-wrap:wrap;margin-bottom:34px}
.rdv-points div{display:flex;align-items:center;gap:9px;font-size:14.5px;color:#E6EBF2}
.rdv-points svg{width:18px;height:18px;fill:var(--gold)}

/* ---------- Contact ---------- */
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.c-item{display:flex;gap:16px;padding:17px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.c-item svg{width:21px;height:21px;fill:var(--gold-deep);flex-shrink:0;margin-top:3px}
.c-item .t{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-soft);font-weight:700}
.c-item .v{font-size:15.5px;color:var(--ink);font-weight:500}
.c-item a:hover{color:var(--gold-deep)}
.c-side{background:var(--light);border-radius:16px;padding:44px 40px;align-self:start}
.c-side h3{font-size:22px;margin-bottom:12px}
.c-side p{color:var(--gray);font-size:15px;margin-bottom:24px}
.c-side .btn{width:100%;justify-content:center;margin-bottom:12px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--navy);margin-bottom:7px}
.field input,.field textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;padding:13px 15px;font-family:var(--sans);font-size:15px;color:var(--ink);transition:.2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold-deep);box-shadow:0 0 0 3px rgba(232,191,25,.18)}
.field textarea{resize:vertical;min-height:130px}
.checks{margin:6px 0 18px}
.checks .ct{font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--navy);margin-bottom:10px}
.check{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px;font-size:14.5px;color:var(--gray);cursor:pointer}
.check input{accent-color:var(--gold-deep);width:17px;height:17px;margin-top:2px;flex-shrink:0;cursor:pointer}
.consent{font-size:12.5px;color:var(--gray-soft);line-height:1.55}
.map{margin:18px 0 4px;border-radius:12px;overflow:hidden;box-shadow:0 12px 28px rgba(27,45,63,.10);border:1px solid var(--line)}
.map iframe{display:block;width:100%;height:250px;border:0;filter:saturate(.85)}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
footer{background:var(--navy);color:#9FB0C0;padding:54px 0 34px;font-size:13px}
footer .top{display:flex;justify-content:space-between;gap:32px;flex-wrap:wrap;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:26px}
footer .fbrand{font-family:var(--serif);font-size:19px;color:#fff}
footer .fbrand b{color:var(--gold)}
footer .flinks{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
footer .flinks a:hover{color:var(--gold)}
footer .disclaimer{max-width:980px;line-height:1.7;color:#7E91A4}
footer .copy{margin-top:18px;color:#62788D}

/* ---------- Responsive ---------- */
@media(max-width:960px){
  .hero .wrap,.approche .wrap,.apropos .wrap,.contact .wrap{grid-template-columns:1fr}
  .hero{padding:140px 0 80px}
  .hero-photo{order:-1}
  .hero-photo img{width:250px;height:300px}
  .apropos-photo img{width:260px;height:312px}
  .cards3{grid-template-columns:1fr}
  .apropos-photo{order:-1}
  .net-grid{grid-template-columns:repeat(2,1fr)}
  .network{padding:32px 24px}
  .rdv-card{padding:34px 22px}
  .partner-row{gap:36px}
  .map iframe{height:280px}
  .c-side{padding:34px 24px}
  nav.menu{position:fixed;top:72px;right:0;background:var(--navy);flex-direction:column;width:100%;padding:28px 24px;gap:22px;transform:translateY(-130%);transition:.35s;opacity:0;border-bottom:1px solid rgba(255,255,255,.1)}
  nav.menu.open{transform:translateY(0);opacity:1}
  .burger{display:block}
  .nav-cta .btn{display:none}
  section{padding:64px 0}
}
