
:root{
  --tl:#0B8B9F;--tl-dk:#054D5C;--tl-md:#076D82;--tl-lt:#0FA4D1;
  --gr:#0C8E69;--gr-dk:#076D5A;--lm:#7A9020;--lm-lt:#B3CD36;
  --ink:#0A1C1F;--ink80:rgba(10,28,31,.8);--ink60:rgba(10,28,31,.6);
  --ink40:rgba(10,28,31,.4);--ink15:rgba(10,28,31,.15);--ink08:rgba(10,28,31,.08);
  --wh:#FAFCFC;--off:#F2F7F8;--paper:#E6EFF1;--bdr:#C5DCE0;
  --rf:'Cormorant Garamond',Georgia,serif;--sf:'DM Sans',system-ui,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--sf);background:var(--wh);color:var(--ink);line-height:1.7;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.wrap{max-width:1320px;margin:0 auto;padding:0 clamp(24px,5%,80px)}
.rv{opacity:0;transform:translateY(28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.rvl{opacity:0;transform:translateX(-28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.rvr{opacity:0;transform:translateX(28px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.rv.in,.rvl.in,.rvr.in{opacity:1;transform:none}
.ey{display:inline-flex;align-items:center;gap:10px;font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;font-weight:600;color:var(--tl)}
.ey::before{content:'';width:22px;height:1.5px;background:currentColor}
.ey-w{color:rgba(255,255,255,.5)}
.ey-w::before{background:rgba(255,255,255,.4)}
h2{font-family:var(--rf);font-size:clamp(1.9rem,3.5vw,2.9rem);font-weight:400;line-height:1.12;color:var(--ink)}
h2 em{font-style:italic;color:var(--tl)}
h2.w{color:#fff}h2.w em{color:rgba(255,255,255,.65)}
.lede{margin-top:14px;font-size:.95rem;color:var(--ink60);line-height:1.82;max-width:540px}
.lede.w{color:rgba(255,255,255,.58)}
.btn{display:inline-flex;align-items:center;gap:9px;padding:13px 28px;border-radius:3px;font-family:var(--sf);font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:none;transition:all .25s var(--ease)}
.btn svg{flex-shrink:0}
.bP{background:var(--tl);color:#fff;box-shadow:0 4px 18px rgba(11,139,159,.22)}
.bP:hover{background:var(--tl-dk);transform:translateY(-2px);box-shadow:0 10px 28px rgba(11,139,159,.3)}
.bG{background:transparent;color:var(--tl);border:1.5px solid var(--tl)}
.bE{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.45)}
.bE:hover{background:rgba(255,255,255,.1);border-color:#fff;transform:translateY(-2px)}
.bG:hover{background:var(--tl);color:#fff;transform:translateY(-2px)}
.sec{padding:96px 0}
.sec-alt{background:var(--off)}
.sec-dk{background:linear-gradient(150deg,var(--tl-dk) 0%,#021E26 100%);color:#fff}

/* NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:999;padding:0 5%;height:68px;display:flex;align-items:center;justify-content:space-between;transition:background .35s,box-shadow .35s}
#nav.s{background:rgba(250,252,252,.96);backdrop-filter:blur(22px);box-shadow:0 1px 0 var(--bdr)}
.nbrand{display:flex;align-items:center;gap:12px}
.nbrand svg{width:36px;height:36px;flex-shrink:0}
.nbrand-t{line-height:1.15}
.nbrand-n{font-family:var(--rf);font-size:1.05rem;font-weight:500;color:var(--tl-dk)}
.nbrand-s{font-size:.57rem;letter-spacing:.14em;text-transform:uppercase;color:var(--tl);font-weight:500}
.nm{display:flex;align-items:center;gap:28px;list-style:none}
.nm a{font-size:.73rem;letter-spacing:.07em;text-transform:uppercase;font-weight:500;color:var(--ink60);transition:color .2s}
.nm a:hover{color:var(--tl)}
.nrdv{background:var(--tl)!important;color:#fff!important;padding:9px 22px;border-radius:3px}
.nrdv:hover{background:var(--tl-dk)!important}
/* Nav sub — 3 services */
.nsub{display:flex;align-items:center;gap:7px}
.nbar{color:var(--ink15);font-size:.8rem;line-height:1;font-weight:300;user-select:none}

/* HERO */
#hero{min-height:100vh;display:grid;grid-template-columns:55% 45%;align-items:center;padding:110px 5% 70px;position:relative;overflow:hidden}
.hgrid{position:absolute;inset:0;background-image:linear-gradient(rgba(11,139,159,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(11,139,159,.05) 1px,transparent 1px);background-size:52px 52px;mask-image:radial-gradient(ellipse 85% 85% at 50% 50%,black,transparent 80%);pointer-events:none}
#hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 70% at 80% 35%,rgba(11,139,159,.05) 0%,transparent 65%);pointer-events:none}
.hcon{position:relative;z-index:1;padding-right:56px}
.hey{margin-bottom:22px}
h1{font-family:var(--rf);font-size:clamp(2.8rem,5.2vw,4.3rem);font-weight:300;line-height:1.08;color:var(--ink);margin-bottom:20px}
h1 em{font-style:italic;color:var(--tl)}h1 strong{font-weight:500}
.hlead{font-size:1.02rem;color:var(--ink60);max-width:490px;margin-bottom:40px;line-height:1.88}
.hbtns{display:flex;flex-wrap:wrap;gap:12px}

/* PHOTO */
.hphoto{position:relative;z-index:1;display:flex;justify-content:center;align-items:flex-end}
.pframe{position:relative;width:390px;height:470px}
.pbg{position:absolute;inset:20px 0 0 20px;background:linear-gradient(135deg,rgba(11,139,159,.11),rgba(12,142,105,.06));border-radius:4px}
.pimg{position:absolute;inset:0 20px 20px 0;border-radius:4px;overflow:hidden;box-shadow:0 20px 55px rgba(10,28,31,.2)}
.pimg img{width:100%;height:100%;object-fit:cover;object-position:center top}
.pbadge{position:absolute;bottom:42px;left:-16px;background:#fff;border:1px solid var(--bdr);border-radius:4px;padding:12px 16px;box-shadow:0 8px 24px rgba(10,28,31,.1)}
.pbadge strong{display:block;font-size:.77rem;font-weight:600;color:var(--ink);margin-bottom:1px}
.pbadge span{font-size:.68rem;color:var(--tl);font-weight:500}
.plogo{position:absolute;top:-18px;right:-18px;width:68px;height:68px;background:#fff;border-radius:50%;padding:8px;box-shadow:0 4px 18px rgba(11,139,159,.15);display:flex;align-items:center;justify-content:center}
.plogo svg{width:48px;height:48px}
.plogo::before{content:'';position:absolute;inset:-6px;border-radius:50%;border:1.5px dashed rgba(11,139,159,.28);animation:tspin 22s linear infinite}
@keyframes tspin{to{transform:rotate(360deg)}}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bdr);border:1px solid var(--bdr);border-radius:4px;overflow:hidden}
.stat{background:var(--wh);padding:26px 20px;text-align:center}
.stat-n{font-family:var(--rf);font-size:2.5rem;font-weight:300;color:var(--tl);line-height:1}
.stat-u{font-family:var(--rf);font-size:1.3rem;color:var(--tl);font-style:italic}
.stat-l{font-size:.73rem;color:var(--ink60);margin-top:5px;letter-spacing:.03em}

/* ORIENTATION */
.ogrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.ocard{display:flex;flex-direction:column;padding:36px 28px 32px;border-radius:4px;border:1px solid var(--bdr);background:var(--wh);text-decoration:none;color:inherit;transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s;position:relative;overflow:hidden}
.ocard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:4px 4px 0 0}
.oc1::before{background:linear-gradient(90deg,var(--tl),var(--tl-lt))}
.oc2::before{background:linear-gradient(90deg,var(--gr-dk),var(--gr))}
.oc3::before{background:linear-gradient(90deg,#3E4A0A,var(--lm))}
.ocard:hover{transform:translateY(-5px)}
.oc1:hover{box-shadow:0 14px 36px rgba(11,139,159,.12);border-color:rgba(11,139,159,.3)}
.oc2:hover{box-shadow:0 14px 36px rgba(12,142,105,.12);border-color:rgba(12,142,105,.3)}
.oc3:hover{box-shadow:0 14px 36px rgba(122,144,32,.12);border-color:rgba(122,144,32,.3)}
.oc4::before{background:linear-gradient(90deg,#054D5C,#0B8B9F)}
.oc4:hover{box-shadow:0 14px 36px rgba(5,77,92,.14);border-color:rgba(11,139,159,.35)}
.oc4 .olink{color:var(--tl-dk)}
.onum{font-family:var(--rf);font-size:2.1rem;font-weight:300;color:var(--bdr);line-height:1;margin-bottom:12px}
.ocard h3{font-family:var(--rf);font-size:1.45rem;font-weight:400;color:var(--ink);margin-bottom:10px}
.ocard p{font-size:.87rem;color:var(--ink60);line-height:1.78;margin-bottom:18px;flex:1}
.otags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:20px}
.otags span{font-size:.63rem;padding:2px 9px;border-radius:2px;background:var(--off);color:var(--ink60);border:1px solid var(--bdr)}
.olink{font-size:.72rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--tl);transition:opacity .2s}
.oc2 .olink{color:var(--gr)}
.oc3 .olink{color:var(--lm)}
.ocard:hover .olink{opacity:.75}

/* COMPARATIF COACHING / THÉRAPIE */
.cmp-wrap{margin-top:52px;padding:36px 40px;background:linear-gradient(135deg,rgba(11,139,159,.05),rgba(12,142,105,.03));border:1px solid var(--bdr);border-radius:6px}
.cmp-title{text-align:center;font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ink60);margin-bottom:28px}
.cmp-grid{display:grid;grid-template-columns:1fr 40px 1fr;align-items:start;gap:0}
.cmp-sep{display:flex;justify-content:center;padding-top:14px}
.cmp-sep::before{content:'ou';font-family:var(--rf);font-size:1.1rem;font-style:italic;color:var(--ink40)}
.cmp-col{padding:0 12px}
.cmp-head{display:flex;align-items:center;gap:9px;font-family:var(--rf);font-size:1.15rem;font-weight:500;color:var(--ink);margin-bottom:14px}
.cmp-co .cmp-head{color:var(--tl-dk)}
.cmp-co .cmp-head svg{stroke:var(--tl)}
.cmp-th .cmp-head{color:var(--gr-dk)}
.cmp-th .cmp-head svg{stroke:var(--gr)}
.cmp-list{list-style:none;padding:0;margin:0}
.cmp-list li{font-size:.86rem;color:var(--ink60);line-height:1.6;padding:5px 0 5px 16px;position:relative;border-bottom:1px solid var(--paper)}
.cmp-list li:last-child{border-bottom:none}
.cmp-list li::before{content:'·';position:absolute;left:0;color:var(--tl);font-weight:700}
.cmp-th .cmp-list li::before{color:var(--gr)}
.cmp-note{text-align:center;margin-top:22px;font-size:.82rem;color:var(--ink60);font-style:italic;border-top:1px solid var(--bdr);padding-top:18px}
@media(max-width:640px){.cmp-grid{grid-template-columns:1fr}.cmp-sep{padding:12px 0;text-align:center}.cmp-wrap{padding:24px 20px}}

/* SÉPARATEUR FAQ GLOSSAIRE */
.faq-sep{margin:28px 0 20px;display:flex;align-items:center;gap:14px}
.faq-sep::before,.faq-sep::after{content:'';flex:1;height:1px;background:var(--bdr)}
.faq-sep span{font-size:.65rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink40);white-space:nowrap}

/* ABOUT */
.agrid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.aquote{position:relative;font-family:var(--rf);font-size:1.2rem;font-style:italic;line-height:1.72;color:var(--tl-dk);padding:24px 32px;border-left:3px solid var(--tl);background:linear-gradient(90deg,rgba(11,139,159,.045),transparent);margin:24px 0;border-radius:0 4px 4px 0}
.aquote::before{content:'\201C';position:absolute;top:-12px;left:18px;font-size:5.5rem;line-height:1;color:var(--tl);opacity:.12;font-family:var(--rf);pointer-events:none}
.abody{font-size:.93rem;color:var(--ink60);line-height:1.88}
.abody p+p{margin-top:14px}
.abody strong{color:var(--tl-dk);font-weight:600}
.deon{margin-top:24px;padding:18px 20px;background:var(--wh);border:1px solid var(--bdr);border-radius:4px}
.deon h4{font-family:var(--rf);font-size:.92rem;font-weight:500;margin-bottom:9px}
.dbadges{display:flex;flex-wrap:wrap;gap:6px}
.dbadge{font-size:.68rem;letter-spacing:.06em;padding:3px 11px;border-radius:20px;border:1px solid var(--bdr);background:var(--off);color:var(--tl-dk);font-weight:500}
.cgrid{display:flex;flex-direction:column;gap:9px}
.cred{display:flex;gap:13px;align-items:flex-start;padding:14px 16px;background:var(--wh);border:1px solid var(--bdr);border-radius:4px;border-left:3px solid var(--tl);transition:box-shadow .2s,transform .2s}
.cred:hover{box-shadow:0 5px 18px rgba(11,139,159,.09);transform:translateX(3px)}
.cred.gr{border-left-color:var(--gr)}
.cred.li{border-left-color:var(--lm)}
.cico{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--tl),var(--tl-lt));display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:.6rem;font-weight:700;text-align:center;line-height:1.2}
.cred.gr .cico{background:linear-gradient(135deg,var(--gr-dk),var(--gr))}
.cred.li .cico{background:linear-gradient(135deg,#3E4A0A,var(--lm))}
.cbody strong{display:block;font-size:.83rem;font-weight:600;color:var(--ink);margin-bottom:1px}
.cbody span{font-size:.73rem;color:var(--ink60)}

/* TROUBLES TRAITÉS */
.trtgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.trt{padding:22px 22px 20px;border:1px solid var(--bdr);border-radius:4px;background:var(--wh);position:relative;transition:transform .25s,box-shadow .25s}
.trt:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(11,139,159,.08)}
.trt::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;border-radius:4px 4px 0 0}
.tt1::before{background:linear-gradient(90deg,var(--tl),var(--tl-lt))}
.tt2::before{background:linear-gradient(90deg,var(--gr-dk),var(--gr))}
.tt3::before{background:linear-gradient(90deg,#3E4A0A,var(--lm))}
.tt4::before{background:linear-gradient(90deg,var(--tl-md),var(--tl))}
.tt5::before{background:linear-gradient(90deg,var(--gr),#56D9A0)}
.tt6::before{background:linear-gradient(90deg,var(--tl-dk),var(--tl-md))}
.trt-icon{width:40px;height:40px;margin-bottom:14px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:linear-gradient(135deg,rgba(11,139,159,.08),rgba(11,139,159,.04))}
.trt-icon svg{width:22px;height:22px;stroke:var(--tl);flex-shrink:0}
.trt h3{font-family:var(--rf);font-size:1.08rem;font-weight:500;color:var(--ink);margin-bottom:5px}
.trt p{font-size:.8rem;color:var(--ink60);line-height:1.65}
.trt-tags{margin-top:10px;display:flex;flex-wrap:wrap;gap:5px}
.trt-tag{font-size:.63rem;padding:2px 8px;border-radius:2px;background:var(--off);color:var(--ink60);border:1px solid var(--bdr)}

/* APPROCHE */
.apcols{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.apitems{display:flex;flex-direction:column;gap:14px}
.apitem{display:flex;gap:18px;padding:22px 24px;border-radius:4px;border:1px solid var(--bdr);background:var(--wh);transition:transform .25s,box-shadow .25s}
.apitem:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(11,139,159,.08)}
.apn{font-family:var(--rf);font-size:2.3rem;font-weight:300;color:var(--bdr);line-height:1;flex-shrink:0;width:48px;transition:color .3s}
.apitem:hover .apn{color:rgba(11,139,159,.22)}
.apbody h3{font-family:var(--rf);font-size:1.08rem;font-weight:500;color:var(--ink);margin-bottom:5px}
.apbody p{font-size:.81rem;color:var(--ink60);line-height:1.68}
.apbadge{display:inline-flex;margin-top:8px;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;padding:2px 9px;border-radius:2px;color:#fff}
.ap1 .apbadge{background:var(--tl)}
.ap2 .apbadge{background:var(--gr)}
.ap3 .apbadge{background:var(--lm)}
.aptext h3{font-family:var(--rf);font-size:clamp(1.6rem,2.8vw,2.2rem);font-weight:400;color:var(--ink);margin-bottom:15px;line-height:1.22}
.aptext h3 em{font-style:italic;color:var(--tl)}
.aptext p{font-size:.91rem;color:var(--ink60);line-height:1.86;margin-bottom:13px}
.aptext strong{color:var(--tl-dk)}
/* KEY CONCEPTS */
.kc-row{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0}
.kc{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border:1px solid var(--bdr);border-radius:3px;background:var(--wh);font-size:.75rem;color:var(--ink60)}
.kc::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--tl);flex-shrink:0}
.kc.g::before{background:var(--gr)}

/* STEPS */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;overflow:visible}
.steps::before{content:'';position:absolute;top:27px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--bdr),var(--bdr),var(--bdr),transparent)}
.step{text-align:center;padding:0 12px;position:relative}
.step-n{width:54px;height:54px;border-radius:50%;background:var(--wh);border:2px solid var(--tl);display:flex;align-items:center;justify-content:center;font-family:var(--rf);font-size:1.35rem;font-weight:400;color:var(--tl);margin:0 auto 18px;position:relative;z-index:1;transition:background .3s,color .3s,box-shadow .3s}
.step:hover .step-n{background:var(--tl);color:#fff;box-shadow:0 4px 18px rgba(11,139,159,.3)}
.step h4{font-family:var(--rf);font-size:1.02rem;font-weight:500;color:var(--ink);margin-bottom:6px}
.step p{font-size:.78rem;color:var(--ink60);line-height:1.6}

/* SERVICES — ROW LAYOUT */
.svrow{display:grid;grid-template-columns:220px 1fr;gap:48px;align-items:start}
.svrow-meta{display:flex;flex-direction:column;gap:10px;padding-top:4px}
.svrow-num{font-family:var(--rf);font-size:3.5rem;font-weight:300;color:rgba(255,255,255,.08);line-height:1}
.svrow-title{font-family:var(--rf);font-size:1.75rem;font-weight:400;color:#fff;line-height:1.15}
.svrow-badge{display:inline-flex;padding:4px 10px;border-radius:2px;font-size:.63rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;margin-top:4px}
.co1{background:rgba(15,164,209,.2);color:rgba(15,164,209,.9)}
.co2{background:rgba(12,142,105,.2);color:rgba(12,142,105,.9)}
.co3{background:rgba(122,144,32,.2);color:rgba(183,205,54,.9)}
.svrow-body{}
.svrow-lead{font-family:var(--rf);font-size:1.22rem;font-style:italic;color:rgba(255,255,255,.82);line-height:1.72;margin-bottom:14px}
.svrow-sub{font-size:.86rem;color:rgba(255,255,255,.52);line-height:1.82;margin-bottom:18px}
.svrow-info{display:flex;align-items:center;gap:7px;font-size:.72rem;color:rgba(255,255,255,.35);margin-bottom:18px;flex-wrap:wrap}
.svrow-info::before{content:'';width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.2);flex-shrink:0}
.sinfo-badge{background:rgba(11,139,159,.35);color:rgba(11,220,255,.9);border:1px solid rgba(11,139,159,.5);border-radius:2px;padding:1px 8px;font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.svrow-divider{border:none;border-top:1px solid rgba(255,255,255,.08);margin:0}
/* Keep service tags + btns for dark section */
.stags{display:flex;flex-wrap:wrap;gap:6px}
.stag{font-size:.64rem;letter-spacing:.04em;padding:3px 9px;border-radius:20px;border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.55)}
.sbtn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:3px;font-size:.74rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;transition:all .25s}
.sbtn svg{width:12px;height:12px;transition:transform .2s}
.sbtn:hover svg{transform:translateX(4px)}
.s1 .sbtn,.sbtn.s1{background:var(--tl-lt);color:#fff}
.s1 .sbtn:hover,.sbtn.s1:hover{background:#0C85B0}
.s2 .sbtn,.sbtn.s2{background:var(--gr);color:#fff}
.s2 .sbtn:hover,.sbtn.s2:hover{background:var(--gr-dk)}
.s3 .sbtn,.sbtn.s3{background:rgba(100,116,26,.9);color:#fff}
.s3 .sbtn:hover,.sbtn.s3:hover{background:#3E4A0A}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--bdr);border-radius:4px;overflow:hidden}
.faq-item{border-bottom:1px solid var(--bdr)}
.faq-item:last-child{border-bottom:none}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;background:var(--wh);cursor:pointer;text-align:left;border:none;font-family:var(--rf);font-size:1.05rem;font-weight:500;color:var(--ink);transition:background .2s}
.faq-q:hover{background:var(--off)}
.faq-q svg{flex-shrink:0;transition:transform .3s var(--ease);color:var(--tl)}
.faq-item.open .faq-q svg{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a-in{padding:0 24px 20px;font-size:.88rem;color:var(--ink60);line-height:1.82}
.faq-a-in strong{color:var(--tl-dk)}

/* FORMATIONS TIMELINE */
.flayout{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.tl{position:relative;padding-left:24px}
.tl::before{content:'';position:absolute;left:0;top:8px;bottom:0;width:1px;background:linear-gradient(to bottom,var(--tl),var(--bdr))}
.tli{position:relative;margin-bottom:26px}
.tli::before{content:'';position:absolute;left:-28px;top:7px;width:8px;height:8px;border-radius:50%;background:var(--tl);border:2px solid var(--off);box-shadow:0 0 0 2px var(--tl);transition:transform .2s}
.tli:hover::before{transform:scale(1.5)}
.tdate{font-size:.65rem;letter-spacing:.13em;text-transform:uppercase;font-weight:600;color:var(--tl);margin-bottom:2px}
.ttitle{font-family:var(--rf);font-size:.98rem;font-weight:500;color:var(--ink);margin-bottom:1px}
.torg{font-size:.74rem;color:var(--ink40);font-weight:500}
.tdesc{margin-top:4px;font-size:.79rem;color:var(--ink60);line-height:1.6}
.fcta{padding:32px;background:linear-gradient(135deg,rgba(11,139,159,.07),rgba(12,142,105,.04));border:1px solid var(--bdr);border-radius:4px}
.fcta h3{font-family:var(--rf);font-size:1.4rem;font-weight:400;color:var(--ink);margin-bottom:10px}
.fcta>p{font-size:.86rem;color:var(--ink60);margin-bottom:20px;line-height:1.75}
.sk-h{font-size:.67rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--tl);margin-bottom:10px}
.sktags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.sktag{font-size:.71rem;padding:4px 11px;background:var(--wh);border:1px solid var(--bdr);border-radius:2px;color:var(--ink60)}

/* RDV */
.rgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.rcard{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:4px;padding:34px 26px;display:flex;flex-direction:column;transition:background .3s,transform .3s}
.rcard:hover{background:rgba(255,255,255,.1);transform:translateY(-3px)}
.rico{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.rc1{background:rgba(15,164,209,.18)}
.rc2{background:rgba(12,142,105,.18)}
.rc3{background:rgba(122,144,32,.18)}
.rc4{background:rgba(11,139,159,.18)}
.rcard h4{font-family:var(--rf);font-size:1.4rem;font-weight:400;color:#fff;margin-bottom:7px}
.rsub{font-size:.78rem;color:rgba(255,255,255,.5);margin-bottom:20px;line-height:1.68;flex:1}
.rcta{display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:3px;font-size:.74rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;transition:all .25s}
.rcta svg{width:12px;height:12px;transition:transform .2s}
.rcta:hover svg{transform:translateX(4px)}
.cco{background:var(--tl-lt);color:#fff}.cco:hover{background:#0C85B0}
.cth{background:var(--gr);color:#fff}.cth:hover{background:var(--gr-dk)}
.cfo{background:rgba(100,116,26,.85);color:#fff}.cfo:hover{background:#3E4A0A}
.cent{background:var(--tl-dk);color:#fff}.cent:hover{background:#021E26}

/* CONTACT */
.cinn{max-width:620px;margin:0 auto;text-align:center}
.cemail{display:inline-flex;align-items:center;gap:11px;margin:28px 0;font-family:var(--rf);font-size:1.45rem;font-style:italic;color:var(--tl);border-bottom:1px solid var(--bdr);padding-bottom:5px;transition:color .2s,border-color .2s}
.cemail:hover{color:var(--tl-dk);border-color:var(--tl)}
.cnote{font-size:.8rem;color:var(--ink40)}

/* FORMULAIRE DE CONTACT */
.cform{width:100%;max-width:560px;margin:28px auto 8px;text-align:left}
.cform-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cform-field{display:flex;flex-direction:column;margin-bottom:16px}
.cform-field label{font-size:.72rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink60);margin-bottom:6px}
.cform-field input,.cform-field select,.cform-field textarea{border:1px solid var(--bdr);border-radius:3px;padding:11px 14px;font-family:var(--sf);font-size:.875rem;color:var(--ink);background:var(--wh);transition:border-color .2s,box-shadow .2s;outline:none;resize:vertical;-webkit-appearance:none}
.cform-field input:focus,.cform-field select:focus,.cform-field textarea:focus{border-color:var(--tl);box-shadow:0 0 0 3px rgba(11,139,159,.1)}
.cform-field select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.cform-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--tl);color:#fff;border:none;border-radius:3px;padding:14px 28px;font-family:var(--sf);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background .22s,transform .22s;width:100%}
.cform-btn:hover{background:var(--tl-dk);transform:translateY(-1px)}
.cform-btn svg{width:18px;height:18px;flex-shrink:0}
.cf-notice{display:flex;align-items:center;gap:10px;padding:13px 18px;border-radius:3px;font-size:.85rem;margin:20px auto 8px;max-width:560px;text-align:left}
.cf-ok{background:rgba(12,142,105,.08);border:1px solid rgba(12,142,105,.25);color:rgba(12,142,105,1)}
.cf-err{background:rgba(200,60,50,.07);border:1px solid rgba(200,60,50,.22);color:rgba(180,40,30,1)}
.cf-err a{color:inherit;font-weight:600}

/* SOCIAL BUTTONS — contact */
.csocial{display:flex;gap:12px;margin:20px 0 4px;justify-content:center;flex-wrap:wrap}
.csoc-btn{display:inline-flex;align-items:center;gap:9px;padding:11px 22px;border-radius:3px;font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;transition:all .25s var(--ease);text-decoration:none}
.csoc-li{background:#0A66C2;color:#fff}
.csoc-li:hover{background:#004182;transform:translateY(-2px);box-shadow:0 8px 22px rgba(10,102,194,.3)}
.csoc-wa{background:#25D366;color:#fff}
.csoc-wa:hover{background:#1ebe57;transform:translateY(-2px);box-shadow:0 8px 22px rgba(37,211,102,.3)}

/* SECTION ENTREPRISE */
.entgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:52px}
.entcard{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:28px 28px 24px;transition:background .25s,border-color .25s}
.entcard:hover{background:rgba(255,255,255,.1);border-color:rgba(11,139,159,.5)}
.entcard-ico{width:44px;height:44px;background:rgba(11,139,159,.15);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.entcard h4{font-family:var(--rf);font-size:1.18rem;font-weight:500;color:#fff;margin-bottom:10px}
.entcard-sub{font-size:.84rem;color:rgba(255,255,255,.62);line-height:1.75;margin-bottom:14px}
.entlist{list-style:none;margin-bottom:18px}
.entlist li{font-size:.8rem;color:rgba(255,255,255,.55);padding:5px 0;padding-left:16px;position:relative;border-bottom:1px solid rgba(255,255,255,.06)}
.entlist li::before{content:'→';position:absolute;left:0;color:var(--tl);font-size:.72rem}
.entlist li:last-child{border-bottom:none}
.entcard-tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tl);background:rgba(11,139,159,.15);padding:4px 10px;border-radius:2px}
.entpourquoi{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:36px 40px;margin-top:20px}
.entpq-right{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.entstat{text-align:center;padding:20px;background:rgba(11,139,159,.12);border-radius:4px}
.entstat-n{display:block;font-family:var(--rf);font-size:1.6rem;color:#fff;font-weight:400;margin-bottom:4px}
.entstat-l{font-size:.72rem;color:rgba(255,255,255,.5);letter-spacing:.05em;text-transform:uppercase}
@media(max-width:768px){.entgrid{grid-template-columns:1fr}.entpourquoi{grid-template-columns:1fr}.entpq-right{grid-template-columns:1fr 1fr}}

/* FOOTER */
footer{background:var(--ink);padding:28px 5%;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.fbrand{display:flex;align-items:center;gap:9px}
.fbrand svg{width:26px;height:26px;opacity:.6}
.fbrand span{font-family:var(--rf);font-size:.92rem;color:rgba(255,255,255,.42)}
.fsocial{display:flex;gap:10px}
.fsoc{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);color:rgba(255,255,255,.4);transition:all .2s}
.fsoc:hover{background:rgba(255,255,255,.18);color:#fff;transform:translateY(-2px)}
.fcopy{font-size:.73rem;color:rgba(255,255,255,.26)}
.fcopy a{color:rgba(255,255,255,.36)}
.fcopy a:hover{color:rgba(255,255,255,.62)}

/* Logos de crédibilité dans les sections services */
.svrow-logos{display:flex;gap:16px;margin:18px 0 20px;flex-wrap:wrap;align-items:center}
.svrow-logo-pill{background:rgba(255,255,255,.97);border-radius:6px;padding:10px 18px;display:inline-flex;align-items:center;justify-content:center;transition:transform .28s var(--ease),box-shadow .28s var(--ease);box-shadow:0 2px 12px rgba(0,0,0,.18)}
.svrow-logo-pill:hover{transform:scale(1.4);box-shadow:0 8px 32px rgba(0,0,0,.28);z-index:10;position:relative}
.svrow-logo-pill img{height:48px;width:auto;display:block;max-width:140px}
.flinks{display:flex;gap:20px;list-style:none}
.flinks a{font-size:.7rem;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.3);transition:color .2s}
.flinks a:hover{color:rgba(255,255,255,.6)}

/* GRAND ÉCRAN */
@media(min-width:1440px){
  .wrap{max-width:1440px}
  #hero{padding:120px 6% 80px;grid-template-columns:52% 48%}
  .pframe{width:440px;height:520px}
  h1{font-size:clamp(3.2rem,4.2vw,5rem)}
  .sec{padding:112px 0}
}
@media(min-width:1700px){
  .wrap{max-width:1600px}
  #hero{grid-template-columns:50% 50%}
  .pframe{width:480px;height:560px}
}

/* RESPONSIVE */
@media(max-width:1024px){
  #hero{grid-template-columns:1fr}.hphoto{display:none}
  .agrid,.apcols,.flayout{grid-template-columns:1fr;gap:44px}
  .hcon{padding-right:0}
  .svrow{grid-template-columns:1fr;gap:24px}
  .svrow-meta{flex-direction:row;align-items:center;gap:16px}
  .svrow-num{font-size:2.5rem}
}
@media(max-width:860px){
  .trtgrid,.rgrid,.ogrid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:28px}.steps::before{display:none}
  .stats{grid-template-columns:1fr 1fr}
  .nm{display:none}
  footer{flex-direction:column;text-align:center}
}
@media(max-width:560px){
  .trtgrid,.rgrid,.ogrid,.stats{grid-template-columns:1fr}
  #faq .wrap > div{grid-template-columns:1fr!important}
}
