@font-face{font-family:'SangBleu Empire';font-style:normal;font-weight:400;font-display:swap;src:url(../fonts/sangbleu-empire-400.woff2) format('woff2')}@font-face{font-family:'SangBleu Empire';font-style:normal;font-weight:500;font-display:swap;src:url(../fonts/sangbleu-empire-500.woff2) format('woff2')}@font-face{font-family:'Euclid Flex';font-style:normal;font-weight:400;font-display:swap;src:url(../fonts/euclid-flex-400.woff2) format('woff2')}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
:root{
 --serif:"SangBleu Empire",Georgia,serif; --sans:"Euclid Flex",system-ui,-apple-system,sans-serif;
 --rose:#C46F7C; --rose-deep:#A6485C; --gold:#E0C485; --gold-deep:#A9791F;
 --ink:#2B2A28; --text:#454239; --muted:#736E66; --paper:#fff; --line:#ECE8E3;
 --grad:linear-gradient(95deg,#C46F7C 0%,#D98E6A 28%,#DEA46A 52%,#E2935A 74%,#C46F7C 100%);
 --wrap:1540px;--hero-vh:90;--head-h:121px;
}
body{margin:0;background:var(--paper);color:var(--text);font-family:var(--sans);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0}
:focus-visible{outline:2px solid var(--rose-deep);outline-offset:3px}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(22px,4vw,64px)}
.eyebrow{font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--rose-deep)}
.ic{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:middle}
.ic--fill{fill:currentColor;stroke:currentColor}
.mark{height:auto}

.animgrad{background:var(--grad);background-size:300% 100%;animation:gradmove 16s ease infinite}
@keyframes gradmove{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.grad-bar{height:7px;width:100%}

.btn{font-weight:600;font-size:.95rem;display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.4rem;border-radius:0;border:1.5px solid transparent;cursor:pointer;transition:background .2s,border-color .2s,color .2s,transform .15s}
.btn .ic{width:17px;height:17px}
.btn--rose{background:var(--rose-deep);color:#fff}
.btn--rose:hover{background:#8f3a4c;color:#fff;transform:translateY(-1px)}
.btn--rose .arr{transition:transform .22s}.btn--rose:hover .arr{transform:translateX(3px)}
.btn--out{background:transparent;color:var(--ink);border-color:rgba(43,42,40,.28)}
.btn--out:hover{border-color:var(--ink)}
.btn--out.on-photo{color:#fff;border-color:rgba(255,255,255,.6)}
.btn--out.on-photo:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn--ghost{padding:.4rem 0;border-bottom:1.5px solid var(--rose);border-radius:0;color:var(--rose-deep);font-size:.9rem}

.strip{background:#211F1D;color:#fff}
.strip-in{max-width:var(--wrap);margin:0 auto;padding:0 clamp(22px,4vw,64px);height:44px;display:flex;align-items:center;justify-content:center;gap:0;font-size:12px;overflow-x:auto;white-space:nowrap}
.strip-in span,.strip-in a{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.9);flex:0 0 auto;padding:0 24px;border-left:1px solid rgba(255,255,255,.16)}.strip-in>:first-child{border-left:0;padding-left:0}.strip-in a{text-decoration:none;transition:color .2s ease}.strip-in a:hover{color:#fff}
.strip-in .ic{width:14px;height:14px;color:var(--gold)}

.head{position:sticky;top:0;z-index:40;background:rgba(33,31,29,.97);-webkit-backdrop-filter:saturate(1.1) blur(7px);backdrop-filter:saturate(1.1) blur(7px);border-top:1px solid rgba(255,255,255,.07)}.head::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,var(--rose),var(--gold-deep) 55%,var(--gold))}
.head-in{max-width:var(--wrap);margin:0 auto;padding:12px clamp(22px,4vw,64px);display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:12px}
.brand .mark{width:24px}.head .brand .mark{width:38px}.head .brand .mark line,.head .brand .mark path{stroke:#E0C485}.head .brand .logo-wm{height:27px;width:auto;display:block}
.brand b{font-family:var(--serif);font-weight:600;font-size:1.3rem;color:var(--ink);letter-spacing:-.01em}
.nav{display:none;gap:30px;font-size:1.06rem;color:#EBE4DD}
.nav-list{list-style:none;display:flex;gap:30px;align-items:center;margin:0;padding:0}
.nav li{margin:0}
.nav .current-menu-item>a::after,.nav .current_page_item>a::after{right:0}
.nav a{padding:.3rem 0;position:relative;color:#EBE4DD}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:2px;background:var(--gold);transition:right .28s}
.nav a:hover::after{right:0}
.head-r{display:flex;align-items:center;gap:14px}
.lang{font-size:.88rem;display:inline-flex;align-items:center;gap:12px}.lang .on{color:#fff;font-weight:700;position:relative}.lang .on::after{content:"";position:absolute;left:0;right:0;bottom:-5px;height:2px;background:var(--gold)}.lang .alt{color:rgba(255,255,255,.5);text-decoration:none;transition:color .2s}.lang .alt:hover{color:#fff}

.hero{position:relative;min-height:max(calc(var(--hero-vh) * 1vh - var(--head-h)),420px);display:flex;align-items:center;color:#fff;background:#2b2a28;overflow:hidden}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center 28%}
.hero .scrim{position:absolute;inset:0;opacity:.72;animation:heroWash 18s ease infinite;background:linear-gradient(90deg,rgba(70,26,36,.50),rgba(70,26,36,.14) 48%,rgba(70,26,36,.02) 74%),linear-gradient(95deg,#C46F7C 0%,#D98E6A 28%,#DEA46A 52%,#E2935A 74%,#C46F7C 100%);background-size:100% 100%,300% 100%}@keyframes heroWash{0%{background-position:0% 50%,0% 50%}50%{background-position:0% 50%,100% 50%}100%{background-position:0% 50%,0% 50%}}.hero .btn--rose{background:var(--rose-deep)}.hero .btn--rose:hover{background:#8f3a4c}
.hero-in{position:relative;z-index:2;max-width:var(--wrap);margin:0 auto;padding:clamp(44px,6vw,76px) clamp(22px,4vw,64px);width:100%}
.hero .eyebrow{color:#fff;opacity:.9}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,6vw,4.4rem);line-height:1.1;letter-spacing:.01em;margin:.4rem 0 1rem;max-width:15ch}
.hero .lead{font-size:clamp(1rem,1.6vw,1.18rem);line-height:1.6;color:rgba(255,255,255,.92);max-width:46ch;margin-bottom:1.6rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.65rem;align-items:center}

.sec{padding:74px 0}
.sec-head{margin-bottom:38px}
.h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,3.4vw,2.7rem);color:var(--ink);line-height:1.06;margin:.5rem 0 0}
.sec-head .lead{color:var(--muted);max-width:54ch;margin:.7rem 0 0}

.chan{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.chan a{position:relative;overflow:hidden;background:#FAF6F4;border-radius:14px;padding:26px 22px 28px;display:flex;flex-direction:column;gap:11px;color:var(--text);transition:background .2s,transform .18s,box-shadow .2s}
.chan a:hover{background:#fff;transform:translateY(-3px);box-shadow:0 14px 34px -22px rgba(70,26,36,.5)}
.chan .ic{width:38px;height:38px;color:var(--rose)}
.chan .t{font-family:var(--serif);font-size:1.34rem;color:var(--rose-deep)}
.chan .d{font-size:.88rem;color:var(--muted);line-height:1.45}
.chan .bar{position:absolute;left:0;right:0;bottom:0;height:3px}











.badge{position:absolute;top:16px;right:16px;font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep);border:1px solid var(--gold-deep);border-radius:999px;padding:3px 9px}

.appro{display:grid;grid-template-columns:1fr;gap:28px;align-items:center}
.appro-text p{font-size:1.05rem;line-height:1.75;color:var(--text);max-width:54ch}
.appro-text p + p{margin-top:1rem}
.appro-text .tech{font-size:.9rem;color:var(--muted);margin-top:1.1rem;padding-top:1.1rem;border-top:1px solid var(--line)}



.tests{color:#fff;position:relative}
.tests .h2{color:#fff;text-shadow:0 1px 14px rgba(70,25,25,.28)}
.tests .eyebrow{color:#fff;opacity:.95}
.tests .lead{color:#fff;opacity:.96;text-shadow:0 1px 10px rgba(70,25,25,.22)}
.tcards{display:grid;grid-template-columns:1fr;gap:16px;margin-top:30px}
.tcard{background:#fff;border-radius:14px;padding:24px 22px;display:flex;flex-direction:column;gap:12px}
.tcard .ic{width:28px;height:28px;color:var(--rose)}
.tcard .tt{font-family:var(--serif);font-size:1.22rem;color:var(--rose-deep);line-height:1.2}
.tcard .sub{font-size:.88rem;color:var(--muted)}
.tcard .btn{align-self:flex-start;margin-top:2px}

.team{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.m-photo{aspect-ratio:4/5;border-radius:3px;overflow:hidden;background:#ECEAE6;position:relative}
.m-photo img{width:100%;height:100%;object-fit:cover;display:block}

.m-nm{font-family:var(--serif);font-size:1.34rem;color:var(--ink);margin-top:13px;line-height:1.2}
.m-ro{font-size:.88rem;color:var(--muted);margin-top:5px}
.m-lg{font-size:.74rem;letter-spacing:.05em;color:var(--rose-deep);margin-top:6px}
.team-cta{display:flex;flex-wrap:wrap;gap:.65rem;justify-content:center;margin-top:40px}
.team .member{display:block;text-decoration:none;color:inherit}
.team .member .m-photo img{transition:transform .45s ease}
.team .member:hover .m-nm{color:var(--rose-deep)}
.team .member:hover .m-photo img{transform:scale(1.04)}

.rev-head{display:flex;align-items:center;gap:16px;margin-bottom:6px}
.rev-head .big{font-family:var(--serif);font-size:3rem;color:var(--ink);line-height:1}
.stars{color:var(--gold-deep);display:inline-flex;gap:1px}.stars .ic{width:15px;height:15px;fill:currentColor;stroke:currentColor}
.rev-sub{display:inline-flex;align-items:center;gap:7px;font-size:.88rem;color:var(--muted)}
.rev-g{width:22px;height:22px;flex:0 0 auto}
.rev-list{margin-top:18px}
.rev-row{display:grid;grid-template-columns:130px 1fr;gap:24px;padding:20px 0;border-top:1px solid var(--line);align-items:start}
.rev-row .nm{font-weight:600;color:var(--ink);font-size:.82rem}
.rev-row .dt{font-size:.74rem;color:var(--muted);margin-top:3px}
.rev-row .q{font-family:var(--serif);font-size:1.04rem;line-height:1.55;color:var(--text)}

.faq{display:grid;grid-template-columns:1fr;gap:28px;align-items:start}
.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:18px;font-family:var(--serif);font-size:1.34rem;color:var(--ink)}
.faq-q .ic{color:var(--rose);transition:transform .25s;flex:0 0 auto}
.faq-item[open] .faq-q .ic{transform:rotate(45deg)}
.faq-q::-webkit-details-marker{display:none}
.faq-a{padding:0 0 20px;font-size:.95rem;line-height:1.7;color:var(--muted);max-width:70ch}


.split{display:grid;grid-template-columns:1fr;gap:26px;align-items:start}
.tile{background:#FAF6F4;border-radius:14px;padding:30px}
.split .h2{font-size:1.55rem}
.access-img{margin:14px 0 0;border-radius:3px;overflow:hidden}
.access-img img{width:100%;object-fit:cover;display:block;min-height:240px}
.facts{list-style:none;margin:14px 0 0;padding:0}
.facts li{display:flex;gap:11px;padding:9px 0;border-top:1px solid var(--line);font-size:.95rem}
.facts .ic{color:var(--rose);width:18px;height:18px;flex:0 0 auto;margin-top:2px}

.final{text-align:center}
.final .h2{margin:.4rem 0 .6rem}
.final .lead{color:var(--muted);max-width:520px;margin:0 auto 26px}
.final .cta-actions{display:flex;flex-wrap:wrap;gap:.65rem;justify-content:center}
.final .trust{margin-top:30px;display:flex;flex-wrap:wrap;gap:10px 24px;justify-content:center;font-size:.88rem;color:var(--muted)}
.final .trust span{display:inline-flex;align-items:center;gap:7px}.final .trust .ic{width:15px;height:15px;color:var(--rose)}

.foot{position:relative;color:#fff;padding:54px 0 28px}
.foot .ovl{position:absolute;inset:0;background:rgba(38,16,16,.18)}
.foot .wrap{position:relative;z-index:2}
.foot-top{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;margin-bottom:28px}
.foot-top b{font-family:var(--serif);font-size:1.3rem;color:#fff}
.foot-cols{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.foot-cols h4{font-family:var(--serif);font-weight:500;font-size:1rem;color:#fff;margin:0 0 11px}
.foot-cols a,.foot-cols .li{display:block;font-size:.85rem;line-height:1.9;color:rgba(255,255,255,.92)}
.foot-cols .foot-menu{list-style:none;margin:0;padding:0}
.foot-cols .foot-menu li{margin:0}
.foot-bottom{margin-top:30px;padding-top:16px;border-top:1px solid rgba(255,255,255,.28);font-size:.78rem;color:rgba(255,255,255,.85);display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between}

.mcta{position:fixed;bottom:0;left:0;right:0;z-index:50;display:grid;grid-template-columns:1fr 1fr 1fr;background:var(--rose-deep);border-radius:16px 16px 0 0;box-shadow:0 -3px 18px rgba(43,42,40,.10);overflow:hidden}
.mcta a{display:flex;align-items:center;justify-content:center;padding:15.5px 4px;color:#fff}
.mcta .ic{width:30px;height:30px}

.note{max-width:var(--wrap);margin:0 auto;padding:22px 28px 88px;font-size:.76rem;line-height:1.6;color:var(--muted)}
.note b{color:var(--text)}

@media(prefers-reduced-motion:reduce){.animgrad,.hero .scrim{animation:none}}
@media(min-width:1250px){ .nav{display:flex} .mcta{display:none} }
@media(min-width:900px){
 .chan{grid-template-columns:repeat(5,1fr)}
 
 .appro{grid-template-columns:1.05fr .95fr;gap:clamp(56px,6vw,90px)}
 .tcards{grid-template-columns:repeat(3,1fr)}
 .team{grid-template-columns:repeat(4,1fr)}
 .faq{grid-template-columns:330px 1fr;gap:56px}
 .split{grid-template-columns:1fr 1fr;gap:38px}
 .foot-cols{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:1249px){body{padding-bottom:60px}}
.btn--white{background:#fff;color:var(--rose-deep)}.btn--white:hover{background:#f4ece9;transform:translateY(-1px)}.hero-review{position:absolute;bottom:clamp(26px,5vh,60px);right:calc(max((100% - var(--wrap))/2, 0px) + clamp(22px,4vw,64px));z-index:4;width:min(322px,34vw);background:rgba(26,15,17,.42);-webkit-backdrop-filter:blur(12px) saturate(1.05);backdrop-filter:blur(12px) saturate(1.05);padding:18px 20px;color:#fff}.hr-stars{display:flex;gap:2px;margin:0;color:#F0C969}.hr-head{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.hr-g{width:18px;height:18px;flex:0 0 auto}.hr-score{font-weight:700;font-size:1.05rem;color:#fff;line-height:1}.hr-count{font-size:.72rem;color:rgba(255,255,255,.7)}.hr-stars .ic{width:15px;height:15px}.hr-q{font-family:var(--serif);font-size:1.02rem;line-height:1.45;margin:0 0 9px}.hr-by{font-size:.76rem;color:rgba(255,255,255,.78)}@media(max-width:899px){.hero-review{display:none}}.appro .eyebrow-row{display:flex;align-items:center;gap:13px;margin-bottom:14px}

.appro .appro-lead{font-family:var(--serif);font-weight:500;font-size:clamp(1.18rem,1.7vw,1.34rem);line-height:1.5;color:var(--ink);margin:0 0 20px;max-width:36ch}
.appro .sign{display:flex;align-items:center;gap:14px;margin-top:30px;padding-top:24px;position:relative}
.appro .sign::before{content:"";position:absolute;top:0;left:0;width:54px;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold-deep))}
.appro .sign .seal{height:54px;flex:0 0 auto;display:block}
.appro .sign .seal svg{height:54px;width:auto;display:block}
.appro .sign .who{display:flex;flex-direction:column;gap:3px}
.appro .sign .nm{font-family:var(--serif);font-size:1.1rem;color:var(--ink);line-height:1.1}
.appro .sign .ro{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.head .btn--rose{background:var(--rose-deep)}.head .btn--rose:hover{background:#8f3a4c}@supports (height:1svh){.hero{min-height:max(calc(var(--hero-vh) * 1svh - var(--head-h)),420px)}}.hero-trust{display:inline-flex;align-items:center;gap:10px;margin-top:22px;text-decoration:none;width:fit-content}.hero-trust .hr-g{width:20px;height:20px;flex:0 0 auto}.hero-trust .ht-score{font-weight:700;font-size:1.05rem;color:#fff;line-height:1}.hero-trust .hr-stars{display:flex;gap:2px;color:#F0C969;margin:0}.hero-trust .hr-stars .ic{width:16px;height:16px}.hero-trust .ht-count{font-size:.84rem;color:rgba(255,255,255,.82);transition:color .2s}.hero-trust:hover .ht-count{color:#fff}.tA .tcard{padding:30px 26px;gap:14px;align-items:flex-start;transition:transform .25s,box-shadow .25s;position:relative;overflow:hidden}.tA .tcard:hover{transform:translateY(-5px);box-shadow:0 20px 44px rgba(43,42,40,.22)}.tA .tc-ic{width:76px;height:76px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(140deg,#F6E4DD,#F1D6C8)}.tA .tc-ic .ic{width:38px;height:38px;color:var(--rose-deep)}.tA .tcard .tt{font-size:1.34rem}.tA .tcard .sub{display:flex;align-items:center;gap:7px}.tA .tcard .sub .ic{width:15px;height:15px;color:var(--muted)}.tA .tcard .btn{width:100%;justify-content:center;align-self:stretch;margin-top:8px}
/* Vos besoins : index editorial + pastilles (option B) */
.besoins .b2-grid{display:block}
@media(min-width:900px){.besoins .b2-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(30px,4vw,56px);align-items:stretch}}
.b2-img{position:relative;margin:0;background-size:cover;background-position:50% 35%;filter:saturate(.97) contrast(1.02);min-height:360px;border-radius:3px;overflow:hidden}
@media(min-width:900px){.b2-img{min-height:100%}}
.b2-imgveil{position:absolute;inset:0;background:linear-gradient(165deg,rgba(196,111,124,.08) 0%,rgba(43,42,40,0) 36%,rgba(43,42,40,0) 66%,rgba(43,42,40,.22) 100%)}
.b2-list{display:flex;flex-direction:column;border-bottom:1px solid var(--line)}
.b2-row{position:relative;display:grid;grid-template-columns:76px 1fr auto;align-items:center;column-gap:22px;padding:20px 2px;border-top:1px solid var(--line);color:var(--text);text-decoration:none;transition:padding-left .35s cubic-bezier(.2,.7,.2,1)}
.b2-row::before{content:"";position:absolute;top:-1px;left:0;width:100%;height:2px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .45s ease}
.b2-row:hover::before{transform:scaleX(1)}
.b2-row:hover{padding-left:14px}
.b2-ic-wrap{width:76px;height:76px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(140deg,#F6E4DD,#F1D6C8)}
.b2-ic-wrap .ic{width:38px;height:38px;color:var(--rose-deep);stroke-width:1.3}
.b2-txt{display:flex;flex-direction:column;gap:4px;min-width:0}
.b2-t{font-family:var(--serif);font-weight:500;font-size:1.34rem;line-height:1.2;color:var(--rose-deep);display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.b2-d{font-size:.88rem;color:var(--muted);margin:0;line-height:1.5;max-width:52ch}
.b2-arr{width:24px;height:24px;color:var(--rose);opacity:.32;transition:transform .35s cubic-bezier(.2,.7,.2,1),opacity .25s,color .25s}
.b2-row:hover .b2-arr{opacity:1;transform:translateX(7px);color:var(--rose-deep)}
.b2-spec{font-family:var(--sans);font-size:.6rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);white-space:nowrap;position:relative;padding-left:14px}
.b2-spec::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-deep))}
@media(max-width:899px){.b2-img{margin-bottom:30px;min-height:300px}}

/* Notre approche : photos qui se chevauchent (sans liseré) */
.appro-media{position:relative;width:100%;height:clamp(470px,40vw,580px)}
.am-back{position:absolute;top:0;right:0;width:67%;height:60%;object-fit:cover;object-position:50% 55%;border-radius:3px;display:block}
.am-front{position:absolute;left:0;bottom:0;width:50%;height:82%;object-fit:cover;object-position:50% 20%;border-radius:3px;display:block;box-shadow:0 3px 12px -4px rgba(43,42,40,.30),0 34px 70px -26px rgba(43,42,40,.62)}
@media(max-width:899px){.appro-media{height:clamp(400px,92vw,470px)}.am-back{width:70%}.am-front{width:54%}}
.facts a{color:inherit;text-decoration:none;transition:color .2s}.facts a:hover{color:var(--rose-deep)}.foot .brand .logo-wm{height:30px;width:auto;display:block}.foot .logo-wm path{fill:#fff}.foot-cols a:hover{color:#fff}.foot-bottom a{color:inherit;text-decoration:none;transition:color .2s}.foot-bottom a:hover{color:#fff}


/* ===== Sous-menus desktop (dropdown) ============================================ */
.nav-list .menu-item-has-children{position:relative}
.nav .sub-menu{position:absolute;top:calc(100% + 16px);left:0;min-width:238px;margin:0;padding:8px;list-style:none;background:#fff;border-radius:12px;box-shadow:0 22px 48px -20px rgba(70,26,36,.55),0 2px 10px rgba(43,42,40,.10);opacity:0;visibility:hidden;transform:translateY(10px);pointer-events:none;transition:opacity .22s ease,transform .22s ease;z-index:60}
.nav .sub-menu::before{content:"";position:absolute;left:0;right:0;top:-22px;height:22px}
.nav-list .menu-item-has-children:hover>.sub-menu,.nav-list .menu-item-has-children:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
.nav .sub-menu li{margin:0}
.nav .sub-menu a{display:block;padding:10px 14px;border-radius:8px;font-size:.95rem;line-height:1.35;color:var(--text);white-space:nowrap}
.nav .sub-menu a::after{display:none}
.nav .sub-menu a:hover{background:#F7EFEC;color:var(--rose-deep)}
.nav .sub-menu .current-menu-item>a{color:var(--rose-deep)}
/* niveau 3+ : flyout a droite */
.nav .sub-menu .sub-menu{top:-8px;left:100%;margin-left:9px;transform:translateX(10px)}
.nav .sub-menu .sub-menu::before{top:0;left:-18px;right:auto;width:18px;height:100%}
.nav .sub-menu .sub-menu::after{display:none}
.nav .sub-menu .menu-item-has-children:hover>.sub-menu,.nav .sub-menu .menu-item-has-children:focus-within>.sub-menu{transform:translateX(0)}

/* ===== Menu mobile : burger + drawer ============================================ */
.burger{display:none}
.drawer-scrim,.drawer{display:none}
@media(max-width:1249px){
  .head-r .lang,.head-r .btn--rose{display:none}
  .burger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;padding:9px;background:transparent;border:0;cursor:pointer}
  .burger span{display:block;height:2px;width:100%;background:#fff;border-radius:2px;transition:transform .26s ease,opacity .2s ease}
  .burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger[aria-expanded="true"] span:nth-child(2){opacity:0}
  .burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  .drawer-scrim{display:block;position:fixed;inset:0;background:rgba(15,8,9,.55);opacity:0;visibility:hidden;transition:opacity .3s ease;z-index:79}
  .drawer-scrim.open{opacity:1;visibility:visible}
  .drawer{display:flex;flex-direction:column;position:fixed;top:0;right:0;bottom:0;width:min(360px,87vw);background:#211F1D;color:#fff;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);z-index:80;overflow-y:auto;padding:18px 22px 28px}
  .drawer.open{transform:translateX(0)}
  body.drawer-on{overflow:hidden}
}
.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.drawer-head .logo-wm{height:24px;width:auto;display:block}
.drawer-head .drawer-logo{display:inline-flex}
.drawer-head .logo-wm path{fill:#fff}
.drawer-close{position:relative;width:40px;height:40px;background:transparent;border:0;cursor:pointer;flex:0 0 auto}
.drawer-close::before,.drawer-close::after{content:"";position:absolute;left:50%;top:50%;width:20px;height:2px;background:#fff;border-radius:2px}
.drawer-close::before{transform:translate(-50%,-50%) rotate(45deg)}
.drawer-close::after{transform:translate(-50%,-50%) rotate(-45deg)}
.m-menu{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.m-menu .menu-item{display:flex;flex-wrap:wrap;align-items:center;border-bottom:1px solid rgba(255,255,255,.09)}
.m-menu>.menu-item>a{flex:1;min-width:0;padding:15px 2px;color:#EBE4DD;font-size:1.06rem}
.m-menu>.menu-item>a:hover{color:#fff}
.m-menu .current-menu-item>a{color:#fff}
.m-acc{flex:0 0 auto;width:44px;height:44px;background:transparent;border:0;cursor:pointer;position:relative}
.m-acc::before{content:"";position:absolute;left:50%;top:50%;width:8px;height:8px;margin:-6px 0 0 -4px;border-right:2px solid rgba(255,255,255,.7);border-bottom:2px solid rgba(255,255,255,.7);transform:rotate(45deg);transition:transform .25s ease}
.m-menu .menu-item.open>.m-acc::before{transform:rotate(-135deg)}
.m-menu .sub-menu{flex:0 0 100%;list-style:none;margin:0;padding:2px 0 10px 12px;display:none}
.m-menu .menu-item.open>.sub-menu{display:block}
.m-menu .sub-menu .menu-item{border-bottom:0}
.m-menu .sub-menu a{display:block;padding:11px 2px;font-size:.98rem;color:rgba(235,228,221,.82)}
.m-menu .sub-menu a:hover{color:#fff}
.drawer-foot{margin-top:auto;padding-top:24px}
.drawer-foot .lang{font-size:1rem;display:inline-flex;margin-bottom:16px}
.drawer-foot .btn{width:100%;justify-content:center}

/* ===== Footer : badge prix + reseaux sociaux ===================================== */
.foot-award{display:inline-flex;flex:0 0 auto}
.foot-award-img{display:block;height:88px;width:auto}
.foot-social{display:flex;align-items:center;gap:15px;margin-top:16px}
.foot-social a{display:inline-flex;color:rgba(255,255,255,.9);transition:color .2s ease,transform .2s ease}
.foot-social a:hover{color:#fff;transform:translateY(-1px)}
.foot-social .ic{width:23px;height:23px}

/* ============ FICHE PRATICIEN (single-praticien.php) ============ */
.prat-head{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:48px;align-items:center}
.prat-photo{margin:0}
.prat-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:3px;display:block}
.prat-back{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;color:var(--muted);text-decoration:none;margin-bottom:16px;transition:color .15s ease}
.prat-back:hover{color:var(--rose-deep)}
.prat-back .ic{width:15px;height:15px;transform:rotate(180deg)}
.prat-name{font-family:var(--serif);font-size:clamp(1.9rem,3.4vw,2.7rem);line-height:1.08;color:var(--ink);margin:0 0 12px}
.prat-role{font-size:1.05rem;color:var(--text);margin:0 0 16px}
.prat-fonction{display:inline-block;font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:var(--rose-deep);background:#F7EBEE;border-radius:999px;padding:5px 14px;margin-bottom:18px}
.prat-langs{display:flex;align-items:center;gap:9px;font-size:.92rem;color:var(--muted);margin:0 0 26px}
.prat-langs .ic{width:18px;height:18px;color:var(--rose-deep);flex:none}
.prat-cta{display:flex;flex-wrap:wrap;gap:12px}
.prat-body{display:grid;grid-template-columns:1.6fr 1fr;gap:56px;align-items:start}
.prat-body--solo{grid-template-columns:1fr;max-width:780px}
.prat-bio .eyebrow,.prat-formation .eyebrow{display:block;margin-bottom:16px}
.prat-bio .prose{font-size:1.05rem;line-height:1.78;color:var(--text)}
.prat-bio .prose p{margin:0 0 1.05em}
.prat-bio .prose p:last-child{margin-bottom:0}
.prat-formation{background:#FBF8F5;border:1px solid var(--line);border-radius:14px;padding:28px 30px}
.prat-form-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.prat-form-list li{display:flex;gap:13px;font-size:.95rem;line-height:1.55;color:var(--text)}
.prat-form-list li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--rose-deep);flex:none;margin-top:8px}
@media(max-width:900px){
	.prat-head{grid-template-columns:1fr;gap:26px}
	.prat-photo{max-width:330px}
	.prat-body{grid-template-columns:1fr;gap:34px}
}

/* ============ MODAL (popup formulaire, ex. rappel) ============ */
body.modal-on{overflow:hidden}
.modal{position:fixed;inset:0;z-index:120;display:none;overflow-y:auto}
.modal.open{display:flex;align-items:flex-start;justify-content:center;padding:24px 16px}
.modal-scrim{position:fixed;inset:0;background:rgba(15,8,9,.55)}
.modal-box{position:relative;background:#fff;border-radius:16px;width:100%;max-width:430px;margin:auto;padding:34px 30px 30px;box-shadow:0 30px 80px -22px rgba(43,42,40,.5)}
.modal-close{position:absolute;top:13px;right:13px;width:38px;height:38px;background:transparent;border:0;cursor:pointer}
.modal-close::before,.modal-close::after{content:"";position:absolute;left:50%;top:50%;width:17px;height:2px;background:var(--muted);border-radius:2px}
.modal-close::before{transform:translate(-50%,-50%) rotate(45deg)}
.modal-close::after{transform:translate(-50%,-50%) rotate(-45deg)}
.modal-title{font-family:var(--serif);font-size:1.55rem;color:var(--ink);margin:0 0 6px;padding-right:26px}
.modal-sub{font-size:.92rem;color:var(--muted);margin:0 0 22px;line-height:1.5}
/* Formulaire de rappel Gravity (classe dg-form-rappel, theme Orbital) : skin de marque par surcharge des variables natives --gf-*. Remplace l'ancien placeholder. Valide sur le rendu live (form 7). */
.gform_wrapper.dg-form-rappel_wrapper{--gf-ctrl-border-color:#D9D3CC;--gf-ctrl-border-color-hover:#C7BCB0;--gf-ctrl-border-color-focus:var(--rose-deep);--gf-ctrl-color:var(--text);--gf-ctrl-label-color-primary:var(--ink);--gf-ctrl-label-color-secondary:var(--muted);--gf-ctrl-font-size:0.95rem;--gf-color-primary:var(--rose-deep)!important;--gf-color-primary-rgb:166,72,92!important;--gf-color-primary-contrast:#fff!important;--gf-color-primary-darker:#8E3C4E!important;--gf-ctrl-btn-bg-color-primary:var(--rose-deep);--gf-ctrl-btn-bg-color-hover-primary:#8E3C4E;--gf-ctrl-btn-bg-color-active-primary:#8E3C4E;--gf-ctrl-btn-color-primary:#fff;--gf-ctrl-btn-border-color-primary:transparent;--gf-ctrl-btn-radius:0px;--gf-ctrl-btn-size:48px;--gf-ctrl-btn-font-size:0.92rem;--gf-ctrl-btn-font-weight:600;--gf-ctrl-btn-padding-x:30px}
.dg-form-rappel_wrapper .gform_fields input,.dg-form-rappel_wrapper .gform_fields textarea,.dg-form-rappel_wrapper .gform_footer input[type=submit]{font-family:var(--sans)}
.dg-form-rappel_wrapper .gfield_checkbox input[type=checkbox],.dg-form-rappel_wrapper .gfield_radio input[type=radio]{accent-color:var(--rose-deep)!important}
.dg-form-rappel_wrapper .gform_fields input::placeholder{color:var(--muted);opacity:1}
.dg-form-rappel_wrapper .gfield_label{font-weight:600;font-size:.82rem;color:var(--ink);letter-spacing:.01em}
.dg-form-rappel_wrapper .gfield_required{color:var(--rose-deep)}
.dg-form-rappel_wrapper .gform_required_legend{font-size:.76rem;color:var(--muted);font-weight:400}
.dg-form-rappel_wrapper .gchoice{margin:.16rem 0}
.dg-form-rappel_wrapper .gchoice label{color:var(--text);font-size:.9rem}
.dg-form-rappel_wrapper .gform_footer input[type=submit]{cursor:pointer;letter-spacing:.02em;transition:background-color .18s ease,transform .18s ease}
.dg-form-rappel_wrapper .gform_footer input[type=submit]:hover{transform:translateY(-1px)}
/* Mise en page popup : une seule colonne, bouton pleine largeur */
.modal-form .gform_fields{grid-template-columns:1fr!important;gap:.85rem!important}
.modal-form .gform_fields .gfield{grid-column:1/-1!important}
.modal-form .gform_footer{margin-top:.5rem}
.modal-form .gform_footer input[type=submit]{width:100%}