/* ===== Manrope (auto-hébergée, RGPD) ===== */
@font-face{font-family:'Manrope';font-weight:500;font-style:normal;font-display:swap;src:url('../fonts/manrope-500.woff2') format('woff2');}
@font-face{font-family:'Manrope';font-weight:600;font-style:normal;font-display:swap;src:url('../fonts/manrope-600.woff2') format('woff2');}
@font-face{font-family:'Manrope';font-weight:700;font-style:normal;font-display:swap;src:url('../fonts/manrope-700.woff2') format('woff2');}

:root{
  --ink:#1A1A1A; --black:#0E0E0E; --taupe:#8A8479; --taupe-l:#A8A29A; --taupe-d:#736E63;
  --ivory:#F7F5F2; --sable:#EBE6DD; --muted:#6C685F; --line:#DED9CF; --line-2:#CFC9BD;
  --sans:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --wrap:1140px; --pad:clamp(20px,5vw,40px);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);color:var(--ink);background:var(--ivory);line-height:1.6;-webkit-font-smoothing:antialiased;font-weight:500;}
img,svg{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--wrap);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}

/* ===== type ===== */
h1,h2,h3{font-weight:700;letter-spacing:-.01em;line-height:1.12;color:var(--ink);}
h1{font-size:clamp(30px,5vw,52px);}
h2{font-size:clamp(24px,3.4vw,36px);}
h3{font-size:clamp(18px,2vw,21px);}
.kicker{font-weight:700;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--taupe);}
.lead{font-size:clamp(16px,1.5vw,19px);color:var(--muted);max-width:60ch;}
.accent-bar{width:42px;height:3px;background:var(--taupe);border:0;margin:0 0 22px;}

/* ===== header ===== */
.site-header{position:sticky;top:0;z-index:50;background:rgba(247,245,242,.9);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line);}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:72px;}
.brand{display:flex;align-items:center;gap:13px;}
.brand .mark{font-weight:700;font-size:26px;letter-spacing:-.05em;line-height:1;color:var(--ink);}
.brand .mark .pt{color:var(--taupe);display:inline-block;transform-origin:50% 80%;}
.brand.intro .mark .pt{animation:pt-in .62s cubic-bezier(.2,1.5,.4,1) both;}
.brand:hover .mark .pt{animation:pt-pop .55s ease;}
@keyframes pt-in{0%{transform:scale(0);opacity:0}55%{transform:scale(1.32);opacity:1}100%{transform:scale(1)}}
@keyframes pt-pop{0%,100%{transform:scale(1)}32%{transform:scale(.5)}66%{transform:scale(1.3)}}
@media (prefers-reduced-motion:reduce){.brand.intro .mark .pt,.brand:hover .mark .pt{animation:none;}}
.brand .bar{width:1px;height:28px;background:var(--line-2);}
.brand .name{font-weight:600;font-size:19px;letter-spacing:-.01em;color:var(--ink);}
.nav{display:flex;align-items:center;gap:30px;}
.nav a.link{font-size:14.5px;color:var(--ink);position:relative;padding:4px 0;}
.nav a.link::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;background:var(--taupe);transition:right .25s ease;}
.nav a.link:hover::after,.nav a.link.active::after{right:0;}
.nav .phone{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--ink);}
.nav .phone .ph-ico{width:16px;height:16px;stroke:var(--taupe);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transform-origin:62% 60%;animation:ring 5s ease-in-out infinite;}
.nav .phone:hover .ph-ico{stroke:var(--ink);}
@keyframes ring{0%,68%,100%{transform:rotate(0)}71%{transform:rotate(-13deg)}75%{transform:rotate(11deg)}79%{transform:rotate(-8deg)}83%{transform:rotate(6deg)}88%{transform:rotate(-3deg)}}
@media (prefers-reduced-motion:reduce){.nav .phone .ph-ico{animation:none;}}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.01em;padding:11px 20px;border-radius:2px;cursor:pointer;border:1px solid var(--ink);transition:.2s;}
.btn-dark{background:var(--ink);color:var(--ivory);}
.btn-dark:hover{background:#000;}
.btn-ghost{background:transparent;color:var(--ink);}
.btn-ghost:hover{background:var(--ink);color:var(--ivory);}
.btn-light{background:var(--ivory);color:var(--ink);border-color:var(--ivory);}
.btn-light:hover{background:transparent;color:var(--ivory);}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 22px -12px rgba(20,18,15,.5);}
.btn:active{transform:translateY(0);}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;}

/* ===== hero ===== */
.hero{position:relative;overflow:hidden;}
.hero .wrap{padding-top:clamp(44px,7vw,84px);padding-bottom:clamp(44px,7vw,84px);}
.hero h1{max-width:18ch;}
.hero .lead{margin-top:22px;}
.hero .cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap;}
.hero-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,5vw,68px);align-items:center;}
.hero-text h1{max-width:15ch;}
.hero-portrait{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:4px;background:var(--sable);height:clamp(460px,56vw,650px);margin-top:-22px;box-shadow:0 30px 72px -30px rgba(20,18,15,.55);}
.hero .ghost{position:absolute;right:-4%;bottom:-18%;font-weight:700;font-size:min(46vw,640px);letter-spacing:-.05em;color:var(--ink);opacity:.035;line-height:1;pointer-events:none;user-select:none;}

/* ===== sections ===== */
.section{padding:clamp(54px,8vw,96px) 0;}
.section.sable{background:var(--sable);}
.section.ink{background:var(--ink);color:var(--ivory);}
.section.ink h2,.section.ink h3{color:var(--ivory);}
.section.ink .lead{color:var(--taupe-l);}
.section-head{max-width:62ch;margin-bottom:40px;}
.section-head .accent-bar{margin-top:14px;}

/* ===== cards grid ===== */
.grid{display:grid;gap:18px;}
.cols-2{grid-template-columns:repeat(2,1fr);}
.cols-3{grid-template-columns:repeat(3,1fr);}
.card{background:var(--ivory);border:1px solid var(--line);border-radius:4px;padding:26px 24px;transition:.2s;}
.section.sable .card{background:#fff;}
.card:hover{border-color:var(--taupe);transform:translateY(-2px);}
.card .num{font-weight:700;color:var(--taupe);font-size:13px;letter-spacing:.1em;}
.card h3{margin:10px 0 8px;}
.card p{color:var(--muted);font-size:14.5px;}
.card.feature{border-color:var(--taupe);background:linear-gradient(180deg,#fff, #fbf9f5);}
.card.feature .num{color:var(--taupe-d);}

/* expertise detail blocks */
.exp{border-top:1px solid var(--line-2);padding:30px 0;display:grid;grid-template-columns:230px 1fr;gap:30px;}
.exp:last-child{border-bottom:1px solid var(--line-2);}
.exp .t{font-size:13px;font-weight:700;}
.exp .t .num{color:var(--taupe);display:block;margin-bottom:8px;letter-spacing:.1em;}
.exp h3{font-size:20px;margin-bottom:10px;}
.exp ul{list-style:none;margin-top:10px;}
.exp li{position:relative;padding-left:20px;margin:8px 0;color:var(--muted);font-size:14.5px;}
.exp li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;background:var(--taupe);}
.exp.feature{background:var(--sable);margin:0 calc(-1*var(--pad));padding-left:var(--pad);padding-right:var(--pad);border:0;}

/* ===== chiffres ===== */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.stat .n{font-weight:700;font-size:clamp(34px,4vw,50px);color:var(--ink);line-height:1;}
.section.ink .stat .n{color:var(--ivory);}
.stat .l{color:var(--muted);font-size:14px;margin-top:8px;}
.section.ink .stat .l{color:var(--taupe-l);}
.stat .rule{width:46px;height:2px;background:var(--taupe);margin-bottom:16px;}

/* ===== le cabinet ===== */
.profile{display:grid;grid-template-columns:340px 1fr;gap:48px;align-items:start;}
.portrait{background:var(--sable);border:1px solid var(--line);aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px;text-align:center;border-radius:4px;}
.profile .body p{margin-bottom:16px;color:#33312c;}
.profile .body p:first-child{font-size:19px;color:var(--ink);font-weight:600;}

/* ===== CTA band ===== */
.cta-band{background:var(--taupe);color:var(--ivory);}
.cta-band .wrap{padding:clamp(40px,6vw,64px) var(--pad);display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;}
.cta-band h2{color:var(--ivory);max-width:20ch;}
.cta-band .btn-light{border-color:var(--ivory);}

/* ===== contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start;}
.coord li{list-style:none;margin-bottom:22px;}
.coord .lbl{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--taupe);}
.coord .val{font-size:17px;margin-top:4px;color:var(--ink);}
.coord a.val:hover{color:var(--taupe-d);}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--ink);}
.field input,.field textarea{width:100%;font-family:var(--sans);font-size:15px;color:var(--ink);background:#fff;border:1px solid var(--line-2);border-radius:3px;padding:12px 14px;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--taupe);box-shadow:0 0 0 3px rgba(138,132,121,.15);}
.field textarea{min-height:130px;resize:vertical;}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.consent{display:flex;gap:10px;align-items:flex-start;font-size:12.5px;color:var(--muted);margin:8px 0 18px;}
.consent input{margin-top:3px;}
.form-status{margin-top:14px;font-size:14px;line-height:1.5;}
.form-status.ok{color:#2f6b46;font-weight:600;}
.form-status.err{color:#9a3b2f;font-weight:600;}
.map{margin-top:14px;border:1px solid var(--line);border-radius:4px;overflow:hidden;}
.map iframe{display:block;width:100%;height:300px;border:0;filter:grayscale(.25) contrast(.95);}
.map-consent{height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px;background:var(--sable);padding:24px;}
.map-consent .addr{font-weight:600;color:var(--ink);font-size:15px;margin:0;}
.map-consent p{max-width:48ch;color:var(--muted);font-size:12.5px;margin:0;}

/* ===== footer ===== */
.site-footer{background:var(--ink);color:#cfc9bd;padding:56px 0 26px;}
.site-footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;}
.site-footer .mark{font-weight:700;font-size:28px;letter-spacing:-.05em;color:var(--ivory);}
.site-footer .mark .pt{color:var(--taupe);}
.site-footer p,.site-footer a,.site-footer li{font-size:13.5px;color:#bdb8ae;line-height:1.8;list-style:none;}
.site-footer a:hover{color:var(--ivory);}
.site-footer h4{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--taupe-l);margin-bottom:12px;font-weight:700;}
.site-footer .bottom{border-top:1px solid #333028;margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12px;color:#8a857c;}

/* ===== legal page ===== */
.legal{max-width:760px;}
.legal h2{font-size:20px;margin:30px 0 8px;}
.legal p{color:#3a382f;margin-bottom:10px;font-size:15px;}

/* ===== accueil : portrait + à-propos ===== */
.about-home{display:grid;grid-template-columns:360px 1fr;gap:50px;align-items:center;}
.portrait-photo{position:relative;overflow:hidden;aspect-ratio:4/5;border:1px solid var(--line);border-radius:4px;background:var(--sable);}
.about-home .stats{margin-top:30px;}
.about-home .btn{margin-top:28px;}

/* ===== icônes de cartes ===== */
.card .ico{width:30px;height:30px;stroke:var(--taupe);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;display:block;margin-bottom:16px;}
.card.feature .ico{stroke:var(--taupe-d);}
.card:hover .ico{stroke:var(--ink);transition:stroke .2s;}

/* ===== bande signature (citation) ===== */
.statement{background:var(--taupe);color:var(--ivory);position:relative;overflow:hidden;}
.statement .wrap{padding:clamp(56px,8vw,92px) var(--pad);text-align:center;position:relative;z-index:1;}
.statement p{font-weight:600;font-size:clamp(22px,3vw,34px);line-height:1.28;max-width:22ch;margin:0 auto;letter-spacing:-.01em;color:var(--ivory);}
.statement .em{color:var(--ivory);opacity:.62;}
.statement .ghost-m{position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);font-weight:700;font-size:min(42vw,440px);letter-spacing:-.05em;color:var(--ivory);opacity:.06;line-height:1;pointer-events:none;user-select:none;}

/* ===== le cabinet (texte + 2e photo) ===== */
.about-cabinet{display:grid;grid-template-columns:1fr 380px;gap:clamp(34px,5vw,56px);align-items:center;}
.photo-cabinet{position:relative;overflow:hidden;aspect-ratio:1/1;border:1px solid var(--line);border-radius:4px;background:var(--sable);}
/* effet photo : zoom doux au survol, dans un cadre détouré */
.ph{position:absolute;inset:0;background:center/cover no-repeat;transition:transform 1.1s cubic-bezier(.2,.55,.2,1), filter .5s ease;}
.portrait-photo:hover .ph,.photo-cabinet:hover .ph,.hero-portrait:hover .ph{transform:scale(1.055);filter:brightness(1.04);}
.ph-portrait{background-image:url('../img/portrait.jpg');background-position:center 20%;}
.ph-cabinet{background-image:url('../img/cabinet.jpg');}
@media (prefers-reduced-motion:reduce){.ph{transition:filter .4s;}.portrait-photo:hover .ph,.photo-cabinet:hover .ph,.hero-portrait:hover .ph{transform:none;}}
.about-cabinet .btn{margin-top:26px;}

/* ===== premier contact (étapes) ===== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;position:relative;}
.steps::before{content:"";position:absolute;top:26px;left:14%;right:14%;height:1.5px;background:var(--line-2);z-index:0;}
.step{position:relative;z-index:1;}
.step .n{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border:1.5px solid var(--taupe);border-radius:50%;color:var(--taupe);font-weight:700;font-size:15px;letter-spacing:0;background:var(--sable);}
.step h3{margin:20px 0 8px;font-size:19px;}
.step p{color:var(--muted);font-size:14.5px;}

/* ===== reveal au défilement ===== */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease;}
.reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important;}}

/* ===== consentement cookies ===== */
.consent-pop{position:fixed;left:0;right:0;bottom:0;z-index:120;background:var(--ink);color:#cfc9bd;padding:20px var(--pad);box-shadow:0 -12px 34px rgba(20,18,15,.24);transform:translateY(115%);transition:transform .45s cubic-bezier(.2,.7,.2,1);}
.consent-pop.show{transform:translateY(0);}
.consent-pop .inner{max-width:var(--wrap);margin:0 auto;display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:space-between;}
.consent-pop h4{color:var(--ivory);font-size:15px;margin:0 0 5px;font-weight:700;}
.consent-pop p{font-size:13px;line-height:1.55;max-width:64ch;margin:0;color:#bdb8ae;}
.consent-pop a{color:var(--ivory);text-decoration:underline;}
.consent-cats{display:flex;gap:22px;flex-wrap:wrap;margin-top:12px;font-size:13px;}
.consent-cats label{display:flex;align-items:center;gap:8px;color:#cfc9bd;cursor:pointer;}
.consent-cats input{width:16px;height:16px;accent-color:var(--taupe);}
.consent-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.consent-pop .btn{padding:10px 18px;font-size:13.5px;}
.consent-pop .btn-text{background:none;border:0;color:#bdb8ae;text-decoration:underline;cursor:pointer;font-family:var(--sans);font-size:13px;padding:6px 4px;}
.consent-pop .btn-text:hover{color:var(--ivory);}
.site-footer .cookie-manage{background:none;border:0;color:#8a857c;font-size:12px;cursor:pointer;text-decoration:underline;font-family:var(--sans);padding:0;}
.site-footer .cookie-manage:hover{color:var(--ivory);}
@media(max-width:760px){.consent-pop .inner{flex-direction:column;align-items:flex-start;gap:16px;}.consent-actions{width:100%;}}

/* ===== responsive ===== */
@media(max-width:880px){
  .nav{position:fixed;inset:72px 0 auto 0;background:var(--ivory);border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start;gap:0;padding:8px var(--pad) 18px;transform:translateY(-130%);transition:transform .28s ease;}
  .nav.open{transform:translateY(0);}
  .nav a.link{width:100%;padding:14px 0;border-bottom:1px solid var(--line);}
  .nav .btn{margin-top:12px;}
  .burger{display:flex;}
  .cols-3,.cols-2,.stats,.steps{grid-template-columns:1fr;}
  .steps::before{display:none;}
  .exp{grid-template-columns:1fr;gap:8px;}
  .profile,.contact-grid,.about-home,.about-cabinet{grid-template-columns:1fr;gap:28px;}
  .about-home .portrait-photo{max-width:340px;width:100%;margin:0 auto;}
  .hero-grid{grid-template-columns:1fr;gap:30px;}
  .hero-portrait{height:auto;aspect-ratio:4/5;width:100%;max-width:340px;}
  .site-footer .top{grid-template-columns:1fr;gap:24px;}
  .row-2{grid-template-columns:1fr;}
}
