/* ==========================================================================
   Sabimmo Conciergerie — clair, minimaliste, moderne (esprit Airbnb)
   Palette crème / beige / gris · San Francisco · typo fine, beaucoup d'air
   ========================================================================== */
:root{
  --bg:#FBF9F5; --bg-2:#F3EFE8; --surface:#FFFFFF;
  --ink:#2A2A28; --text:#46433D; --muted:#8C857A;
  --line:#ECE6DC; --line-2:#E2DACD;
  --accent:#2A2A28; --sand:#A6917A; --sand-soft:#C9BBA6;
  --r:12px; --r-lg:18px; --r-sm:8px; --r-pill:999px;
  --s4:16px; --s5:24px; --s6:32px; --s7:48px; --s8:72px; --s9:104px;
  --maxw:1160px;
  --sans:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:84px}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);font-weight:400;font-size:16.5px;line-height:1.65;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}
h1,h2,h3,h4{margin:0;color:var(--ink);font-weight:700;line-height:1.14;letter-spacing:-.02em}
h1{font-size:clamp(1.95rem,3.4vw,2.85rem)}
h2{font-size:clamp(1.45rem,2.6vw,2rem);letter-spacing:-.015em}
h3{font-size:1.1rem;font-weight:600;letter-spacing:-.01em}
p{margin:0}
a{color:var(--ink);text-decoration:none}
img{display:block;max-width:100%}
ul{margin:0;padding:0;list-style:none}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-left:max(22px,env(safe-area-inset-left));padding-right:max(22px,env(safe-area-inset-right))}
@media(min-width:900px){.wrap{padding-left:max(40px,env(safe-area-inset-left));padding-right:max(40px,env(safe-area-inset-right))}}
.section{padding:56px 0}
@media(min-width:900px){.section{padding:80px 0}}
.bg-2{background:var(--bg-2)}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;color:var(--sand);display:block;margin-bottom:14px}
.lead{color:var(--muted);font-size:1.05rem;line-height:1.6}
.center{text-align:center}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-weight:600;font-size:.97rem;padding:13px 22px;border-radius:var(--r);border:1px solid transparent;cursor:pointer;transition:background .18s,border-color .18s,color .18s,transform .12s;line-height:1}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--ink);color:#fff}
.btn--primary:hover{background:#000}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--ink)}
.btn--lg{padding:15px 26px;font-size:1rem}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(251,249,245,.82);-webkit-backdrop-filter:saturate(150%) blur(12px);backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:.5rem;color:var(--ink);font-weight:800;font-size:1.18rem;letter-spacing:.01em}
.brand .mk{width:30px;height:30px;flex:none;color:var(--ink)}
.brand small{display:block;font-size:9px;font-weight:600;letter-spacing:2.5px;color:var(--muted);margin-top:-2px}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{color:var(--text);font-size:.93rem;font-weight:500}
.nav-links a:hover{color:var(--ink)}
.nav-right{display:flex;align-items:center;gap:14px}
.lang{font-size:.82rem;color:var(--muted);font-weight:600}
.lang a{color:var(--muted)} .lang a.on{color:var(--ink)}
.nav-tog{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-tog span{display:block;width:22px;height:1.5px;background:var(--ink);margin:5px 0}

/* hero */
.hero{padding-top:var(--s8);padding-bottom:var(--s8)}
.hero-grid{display:grid;grid-template-columns:1fr;gap:var(--s7);align-items:center}
@media(min-width:960px){.hero-grid{grid-template-columns:1.05fr .95fr;gap:var(--s8)}}
.hero h1{margin-bottom:16px;max-width:15ch}
.hero .lead{max-width:44ch;margin-bottom:28px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.hero-meta{margin-top:26px;display:flex;flex-wrap:wrap;gap:18px;color:var(--muted);font-size:.9rem}
.hero-meta b{color:var(--ink);font-weight:700}
.hero-photo{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:5/4;box-shadow:0 20px 50px rgba(42,42,40,.12)}
.hero-photo img{width:100%;height:100%;object-fit:cover}

/* stat strip */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s6) var(--s5)}
@media(min-width:760px){.stats{grid-template-columns:repeat(5,1fr)}}
.stat .n{font-size:1.9rem;font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1}
.stat .l{color:var(--muted);font-size:.9rem;margin-top:6px}

/* about (story) */
.about{display:grid;grid-template-columns:1fr;gap:var(--s7);align-items:center}
@media(min-width:900px){.about{grid-template-columns:.9fr 1.1fr;gap:var(--s8)}}
.about-photo{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:0 18px 44px rgba(42,42,40,.12)}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about p+p{margin-top:14px}
.sign{margin-top:20px;font-weight:700;color:var(--ink)}
.sign span{display:block;font-weight:500;color:var(--muted);font-size:.9rem}

/* feature list / services */
.cols{display:grid;grid-template-columns:1fr;gap:0;margin-top:var(--s6)}
@media(min-width:740px){.cols{grid-template-columns:1fr 1fr;column-gap:var(--s8)}}
.li{padding:18px 0;border-top:1px solid var(--line)}
.li b{display:block;font-weight:600;color:var(--ink);margin-bottom:2px}
.li span{color:var(--muted);font-size:.95rem}

/* why — points */
.points{display:grid;grid-template-columns:1fr;gap:20px;margin-top:var(--s6)}
@media(min-width:760px){.points{grid-template-columns:repeat(3,1fr);gap:24px}}
.point{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px}
.point h3{margin-bottom:8px}
.point p{color:var(--muted);font-size:.95rem}

/* testimonials */
.quotes{display:grid;grid-template-columns:1fr;gap:20px;margin-top:var(--s6)}
@media(min-width:760px){.quotes{grid-template-columns:repeat(3,1fr)}}
.quote{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px}
.quote .stars{color:var(--sand);letter-spacing:2px;font-size:.85rem}
.quote blockquote{margin:12px 0 14px;color:var(--ink);font-size:1.02rem;line-height:1.5}
.quote .who{color:var(--muted);font-size:.88rem;font-weight:600}

/* zones */
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.chip{border:1px solid var(--line-2);border-radius:var(--r-pill);padding:7px 15px;font-size:.9rem;color:var(--text);background:var(--surface)}

/* pricing */
.price{display:flex;flex-wrap:wrap;align-items:baseline;gap:14px}
.price .big{font-size:3rem;font-weight:800;color:var(--ink);letter-spacing:-.03em;line-height:1}
.price .by{color:var(--muted)}

/* faq */
.faq{max-width:760px}
.faq details{border-top:1px solid var(--line)}
.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;gap:16px;align-items:center;padding:20px 0;font-weight:600;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--sand);font-size:1.4rem;line-height:1;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .a{color:var(--muted);padding-bottom:20px;max-width:62ch}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr;gap:var(--s7);align-items:start;max-width:640px;margin:0 auto}
@media(min-width:860px){.contact-grid{grid-template-columns:1fr}}
.book{background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:34px}
.book h2{color:#fff}
.book p{color:#cfc8bd;margin:12px 0 24px}
.book .btn--primary{background:#fff;color:var(--ink)}
.book .btn--primary:hover{background:#f1ece3}
.book .mini{margin-top:18px;color:#b7afa2;font-size:.85rem}
.book .mini a{color:#fff}
.form{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px}
.form .row{margin-bottom:14px}
.form .two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.form .two{grid-template-columns:1fr}}
.form label{display:block;font-size:.85rem;font-weight:600;color:var(--ink);margin-bottom:6px}
.form input,.form select,.form textarea{width:100%;-webkit-appearance:none;appearance:none;background:var(--bg);border:1px solid var(--line-2);border-radius:var(--r);color:var(--ink);font:inherit;padding:12px 14px}
.form input::placeholder,.form textarea::placeholder{color:var(--muted)}
.form select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' stroke='%238C857A' stroke-width='1.6'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(42,42,40,.08)}
.form textarea{min-height:104px;resize:vertical}
.form-note{font-size:.8rem;color:var(--muted);margin-top:8px}
.form-status{margin-top:12px;font-weight:600;min-height:1.2em}
.form-status.ok{color:#2e7d32}.form-status.err{color:#b3402a}

/* footer */
.footer{border-top:1px solid var(--line);padding:44px 0 30px;color:var(--muted)}
.footer-in{display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center}
.footer .brand{color:var(--ink)}
.footer a{color:var(--muted)}.footer a:hover{color:var(--ink)}
.footer .seo{font-size:.85rem;max-width:44ch}

/* reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s,transform .6s}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* mobile nav */
@media(max-width:860px){
  .nav-links,.nav-right .btn{display:none}
  .nav-tog{display:block}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:70px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--line);padding:18px 22px;gap:16px}
}

/* --- remplissage : cartes, pills, étapes, tarif --- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(225px,1fr));gap:16px;margin-top:var(--s6)}
.card2{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;transition:border-color .18s,transform .12s}
.card2:hover{border-color:var(--line-2);transform:translateY(-2px)}
.card2 b{display:block;font-weight:600;font-size:1rem;color:var(--ink);margin-bottom:6px}
.card2 span{color:var(--muted);font-size:.92rem;line-height:1.5}
.hero-pills{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px}
.pill{border:1px solid var(--line-2);border-radius:var(--r-pill);padding:7px 14px;font-size:.85rem;color:var(--text);background:var(--surface);font-weight:500}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-top:var(--s6)}
.step{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px}
.step .no{font-size:.82rem;font-weight:700;letter-spacing:1px;color:var(--sand)}
.step h3{margin:10px 0 6px;font-size:1.02rem}
.step p{color:var(--muted);font-size:.92rem;line-height:1.5}
.price-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;max-width:520px;margin-top:var(--s5)}
.incl{margin:20px 0 24px}
.incl li{padding:9px 0 9px 26px;position:relative;border-top:1px solid var(--line);color:var(--text);font-size:.95rem}
.incl li::before{content:"\2713";position:absolute;left:0;color:var(--sand);font-weight:700}

/* galerie défilante (biens) */
.marquee{overflow:hidden;width:100%;margin-top:var(--s6);-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.marquee-track{display:flex;gap:16px;width:max-content;animation:marq 70s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track img{height:280px;width:auto;border-radius:var(--r-lg);object-fit:cover;flex:none;background:var(--bg-2)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:600px){.marquee-track img{height:200px}}
@media(prefers-reduced-motion:reduce){.marquee-track,.r-track{animation:none}}

/* ===== HERO plein écran : grande photo + dégradé ===== */
.hero{position:relative;min-height:86vh;min-height:86dvh;display:flex;align-items:center;padding:0;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:url(/assets/img/hero-bg.jpg) center/cover no-repeat;z-index:0}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(22,17,11,.86) 0%,rgba(22,17,11,.56) 42%,rgba(22,17,11,.18) 78%,rgba(22,17,11,.36) 100%);z-index:1}
.hero .wrap{position:relative;z-index:2}
.hero-inner{max-width:640px;padding:124px 0 92px}
.hero .eyebrow{color:#E9D5A8}
.hero h1{color:#fff;max-width:16ch}
.hero .lead{color:rgba(255,255,255,.9);max-width:44ch}
.hero .btn--primary{background:#fff;color:var(--ink)}
.hero .btn--primary:hover{background:#efe9df}
.hero .btn--ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.hero .btn--ghost:hover{border-color:#fff;color:#fff}
.hero .pill{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.34);color:#fff;backdrop-filter:blur(4px)}
@media(max-width:600px){.hero{min-height:78vh;min-height:78dvh}.hero-inner{padding:96px 0 60px}}

/* ===== dégradé de fond du site (fini le beige plat) ===== */
body{background:linear-gradient(165deg,#FCFAF6 0%,#F4EDE2 55%,#ECE3D5 100%);background-attachment:fixed}
.bg-2{background:rgba(214,202,183,.32)}

/* avis : nom voyageur + badge plateforme + date */
.quote .who{display:flex;flex-wrap:wrap;align-items:center;gap:7px;color:var(--muted);font-size:.86rem;font-weight:500;margin-top:2px}
.quote .who b{color:var(--ink);font-weight:700}
.quote .src{font-size:.66rem;font-weight:700;letter-spacing:.4px;text-transform:uppercase;padding:3px 8px;border-radius:6px;line-height:1}
.quote .src.ab{background:#FDEAEE;color:#C2415A}
.quote .src.bk{background:#E8EFFB;color:#2C5BB0}
.quote .who .date{color:var(--muted)}

/* zones + tarif côte à côte (page plus courte) */
.zt-grid{display:grid;grid-template-columns:1fr;gap:var(--s7)}
@media(min-width:880px){.zt-grid{grid-template-columns:1fr 1fr;gap:var(--s8);align-items:start}}

/* avis en défilement (même esprit que les photos) */
.r-marquee{position:relative;overflow:hidden;margin-top:28px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.r-track{display:flex;gap:16px;width:max-content;padding:8px 16px;animation:marq 60s linear infinite}
.r-marquee:hover .r-track{animation-play-state:paused}
.r-track .quote{flex:0 0 220px;width:220px;height:220px;margin:0;padding:18px;display:flex;flex-direction:column;overflow:hidden}
.r-track .quote .stars{font-size:.82rem;margin-bottom:8px}
.r-track .quote blockquote{font-size:.82rem;line-height:1.42;margin:0;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}
.r-track .quote .who{margin-top:auto;padding-top:10px;font-size:.76rem;gap:5px}
.r-track .quote .who b{font-size:.82rem}
.r-track .quote .src{font-size:.58rem;padding:2px 6px}
@media(max-width:600px){.r-track .quote{flex:0 0 200px;width:200px;height:200px}}

/* prestations : liste légère (moins « grosses cartes ») */
.svc{display:grid;grid-template-columns:1fr;margin-top:10px;border-top:1px solid var(--line)}
@media(min-width:680px){.svc{grid-template-columns:1fr 1fr;column-gap:32px}}
@media(min-width:1000px){.svc{grid-template-columns:1fr 1fr 1fr;column-gap:40px}}
.svc-item{display:flex;gap:12px;align-items:flex-start;padding:15px 0;border-bottom:1px solid var(--line)}
.svc-item .ic{flex:0 0 auto;color:var(--sand);font-weight:800;font-size:.85rem;margin-top:3px}
.svc-item .svc-t b{display:block;font-weight:600;font-size:.96rem;color:var(--ink)}
.svc-item .svc-t span{display:block;color:var(--muted);font-size:.84rem;margin-top:2px;line-height:1.4}

/* avis : lecture complète + relief au survol (la marquee est en pause au survol) */
.r-track .quote{transition:box-shadow .18s ease, transform .18s ease}
.r-track .quote:hover{box-shadow:0 18px 42px rgba(42,42,40,.17);transform:translateY(-3px);z-index:3}

/* tarif : 3 formules */
.plans{display:grid;grid-template-columns:1fr;gap:18px;margin-top:26px}
@media(min-width:820px){.plans{grid-template-columns:repeat(3,1fr);align-items:stretch}}
.plan{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 24px;display:flex;flex-direction:column}
.plan-name{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700}
.plan-price{margin:8px 0 18px;display:flex;align-items:baseline;gap:8px}
.plan-price .big{font-size:2.5rem;font-weight:800;letter-spacing:-.02em;line-height:1;color:var(--ink)}
.plan-price .by{color:var(--muted);font-size:.88rem}
.plan .incl{list-style:none;margin:0;padding:0;display:grid;gap:11px;flex:1}
.plan .incl li{position:relative;padding-left:24px;font-size:.92rem;line-height:1.4;color:var(--text)}
.plan .incl li::before{content:"✓";position:absolute;left:0;top:0;color:var(--sand);font-weight:800}
.plan-note{margin-top:16px;color:var(--muted);font-size:.82rem}
.plan--featured{background:var(--ink);border-color:var(--ink);box-shadow:0 26px 64px rgba(42,42,40,.24)}
@media(min-width:820px){.plan--featured{transform:translateY(-10px)}}
.plan--featured .plan-name{color:var(--sand-soft)}
.plan--featured .plan-price .big{color:#fff}
.plan--featured .plan-price .by{color:rgba(255,255,255,.7)}
.plan--featured .incl li{color:rgba(255,255,255,.92)}
.plan--featured .incl li::before{color:var(--sand-soft)}
.plan-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--sand);color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:6px 14px;border-radius:999px;white-space:nowrap}
.plan .btn{margin-top:20px;width:100%;justify-content:center}
.plan--featured .btn--primary{background:#fff;color:var(--ink)}
.plan--featured .btn--primary:hover{background:#efe9df}

/* prestations : catégories inclus / supplément */
.svc-cat{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--ink);margin:30px 0 2px}
.svc-cat--opt{color:var(--sand)}
.svc-item .ic--opt{color:var(--sand);font-weight:800}

/* avis : encart complet au survol (popover) */
.review-pop{position:fixed;z-index:60;width:340px;max-width:88vw;height:auto;margin:0;box-shadow:0 30px 72px rgba(42,42,40,.30);opacity:0;transform:scale(.97);transition:opacity .15s ease, transform .15s ease;pointer-events:none;overflow:visible}
.review-pop.on{opacity:1;transform:scale(1)}
.review-pop blockquote{-webkit-line-clamp:unset;display:block;overflow:visible;font-size:.98rem;line-height:1.5;margin:0}
.review-pop .who{margin-top:14px}

/* étape Diffusion : logos des plateformes */
.platforms{display:flex;flex-wrap:wrap;align-items:center;gap:10px 18px;margin-top:16px}
.pf{font-weight:800;font-size:1rem;letter-spacing:-.02em;line-height:1;white-space:nowrap}
.pf-airbnb{color:#FF385C}
.pf-booking{color:#003B95}
.pf-agoda{color:#2E2C9A}
.pf-vrbo{color:#1B2A4A}

/* étape Diffusion : vraies icônes plateformes sur tuiles */
.platforms{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:18px}
.pf-tile{width:46px;height:46px;border-radius:12px;background:#fff;border:1px solid var(--line);box-shadow:0 4px 12px rgba(42,42,40,.09);display:flex;align-items:center;justify-content:center}
.pf-tile img{width:34px;height:34px;border-radius:8px;display:block}

/* autocomplétion adresse du bien */
.addr-wrap{position:relative}
.addr-list{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;background:#fff;border:1px solid var(--line-2);border-radius:12px;box-shadow:0 18px 44px rgba(42,42,40,.16);overflow:hidden;display:none}
.addr-list.on{display:block}
.addr-item{padding:11px 14px;font-size:.92rem;color:var(--text);cursor:pointer;border-bottom:1px solid var(--line)}
.addr-item:last-child{border-bottom:0}
.addr-item:hover,.addr-item.on{background:var(--bg-2);color:var(--ink)}
.addr-hint{font-size:.78rem;color:var(--muted);margin-top:5px}

/* bande partenaires tout en haut */
.topbar{background:var(--bg-2);border-bottom:1px solid var(--line)}
.topbar-in{display:flex;align-items:center;justify-content:center;gap:12px;padding:7px 0;flex-wrap:wrap}
.topbar-txt{font-size:.7rem;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);font-weight:700}
.topbar-logos{display:inline-flex;align-items:center;gap:9px}
.topbar-logos img{height:20px;width:20px;border-radius:5px;display:block}
/* logos étape Diffusion : plus petits & discrets */
.platforms{gap:12px;margin-top:14px}
.platforms .pf-tile{width:auto;height:auto;background:none;border:0;box-shadow:none;border-radius:0}
.platforms .pf-tile img{width:22px;height:22px;border-radius:5px;opacity:.9}

/* ============ REFONTE CONVERSION ============ */
/* CTA accent qui tranche (bronze chaud) */
.btn--primary{background:#8a6f52;color:#fff}
.btn--primary:hover{background:#715840}
.hero .btn--primary{background:#8a6f52;color:#fff}
.hero .btn--primary:hover{background:#715840}

/* hero : ligne de preuve */
.hero-proof{display:flex;flex-wrap:wrap;align-items:center;gap:7px 14px;margin-top:18px;color:rgba(255,255,255,.92);font-size:.92rem;font-weight:600}
.hero-proof .sep{opacity:.45}
.hero-proof .star{color:#E9D5A8}

/* CTA de relance en fin de section */
.relance{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px;margin-top:38px;text-align:center}
.relance p{margin:0;font-weight:600;color:var(--ink);font-size:1.02rem}

/* tarif : ancrage valeur */
.tarif-anchor{margin-top:10px;font-size:.92rem;color:var(--text)}
.tarif-anchor b{color:var(--ink)}

/* mobile : CTA header restauré + barre collante */
@media(max-width:860px){
  .nav-right .btn{display:inline-flex;padding:9px 13px;font-size:.85rem}
  .nav-right .lang{display:none}
}
.mobile-cta{display:none}
@media(max-width:860px){
  .mobile-cta{display:flex;position:fixed;left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom));z-index:55;justify-content:center;box-shadow:0 12px 32px rgba(42,42,40,.32)}
  body{padding-bottom:calc(84px + env(safe-area-inset-bottom))}
}

/* avis : lisibles + swipe sur mobile (plus de marquee animée) */
@media(max-width:760px){
  .r-marquee{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .r-track{animation:none;gap:12px;padding:8px 12px}
  .r-track .quote[aria-hidden]{display:none}
  .r-track .quote{flex:0 0 80vw;width:80vw;height:auto}
  .r-track .quote blockquote{-webkit-line-clamp:unset;overflow:visible}
}


/* upload de photos */
.form input[type=file]{width:100%;font-size:.9rem;color:var(--text);padding:11px 12px;border:1px dashed var(--line-2);border-radius:var(--r);background:#fff;cursor:pointer}
.form input[type=file]::file-selector-button{font:inherit;font-weight:600;color:var(--ink);background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:7px 12px;margin-right:12px;cursor:pointer}

/* logos plateformes dans les avis */
.src-logo{width:18px;height:18px;border-radius:4px;vertical-align:middle;display:inline-block;flex:0 0 auto}

/* galerie : agrandir au survol (même effet que les avis) */
.photo-pop{position:fixed;z-index:200;margin:0;opacity:0;transform:scale(.96);transition:opacity .16s ease, transform .16s ease;pointer-events:none;border-radius:12px;box-shadow:0 30px 72px rgba(20,16,12,.5)}
.photo-pop.on{opacity:1;transform:scale(1)}
.photo-pop img{display:block;width:520px;max-width:90vw;height:auto;border-radius:12px}

/* tarif : animation au survol des cartes */
.plan{transition:transform .2s ease, box-shadow .2s ease}
.plan:hover{transform:translateY(-8px);box-shadow:0 26px 60px rgba(42,42,40,.18)}
.plan--featured:hover{box-shadow:0 34px 74px rgba(42,42,40,.30)}
@media(min-width:820px){.plan--featured:hover{transform:translateY(-18px)}}

/* ils nous recommandent */
.reco{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:20px 44px;margin-top:30px}
.reco-item{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit;transition:opacity .2s ease,transform .2s ease}
a.reco-item{cursor:pointer}
a.reco-item:hover{opacity:.6;transform:translateY(-2px)}
.reco-item img{height:46px;width:auto;max-width:80px;object-fit:contain;flex:0 0 auto}
.reco-item span{font-weight:600;color:var(--ink);font-size:1.02rem;white-space:nowrap}
@media(max-width:600px){.reco{gap:14px 22px}.reco-item span{font-size:.9rem}.reco-item img{height:38px;width:auto}}

/* FAQ + Contact côte à côte */
.qc-grid{display:grid;grid-template-columns:1fr;gap:var(--s7)}
@media(min-width:900px){.qc-grid{grid-template-columns:1fr 1fr;gap:var(--s8);align-items:start}}
.qc-grid .contact-grid{max-width:none;margin:0}

/* pages communes (SEO local) */
.crumb{font-size:.86rem;color:var(--muted);margin:0 0 14px}
.crumb a{color:var(--muted);text-decoration:none}
.crumb a:hover{color:var(--sand)}
.ticks{list-style:none;padding:0;margin:24px 0 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px 28px}
.ticks li{position:relative;padding-left:28px;line-height:1.5;color:var(--text)}
.ticks li::before{content:"✓";position:absolute;left:0;top:0;color:var(--sand);font-weight:700}
.commune-links{display:flex;flex-wrap:wrap;gap:10px 12px;margin-top:24px}
.commune-links a{display:inline-block;padding:8px 15px;border:1px solid var(--line-2);border-radius:var(--r-pill);text-decoration:none;color:var(--ink);font-weight:600;font-size:.95rem;transition:background .15s ease,border-color .15s ease,color .15s ease}
.commune-links a:hover{background:var(--sand);border-color:var(--sand);color:#fff}
.commune-links a strong{font-weight:700}
.footer-communes{font-size:.84rem;color:var(--muted);padding-bottom:18px;line-height:1.9;border-bottom:1px solid var(--line);margin-bottom:22px}
.footer-communes a{color:var(--muted);text-decoration:none}
.footer-communes a:hover{color:var(--sand)}

/* blog / articles */
.article{max-width:760px;margin:0 auto}
.article-head{margin-bottom:30px}
.article-head h1{margin-top:6px}
.article-meta{color:var(--muted);font-size:.9rem;margin-top:14px;display:flex;gap:8px 16px;flex-wrap:wrap}
.prose{color:var(--text);font-size:1.06rem;line-height:1.75}
.prose .lead{font-size:1.18rem;color:var(--ink);margin-bottom:8px}
.prose h2{margin:38px 0 12px;font-size:1.5rem}
.prose h3{margin:26px 0 8px}
.prose p{margin:0 0 16px}
.prose ul{margin:0 0 18px;padding:0;list-style:none}
.prose ul li{position:relative;padding-left:24px;margin-bottom:10px}
.prose ul li::before{content:"—";position:absolute;left:0;color:var(--sand)}
.prose a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--sand-soft);text-underline-offset:3px}
.note{background:var(--bg-2);border-left:3px solid var(--sand);border-radius:8px;padding:16px 18px;margin:0 0 18px;font-size:.98rem;color:var(--text)}
.cta-band{text-align:center;background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:38px 28px;margin-top:42px}
.cta-band h2{color:#fff}.cta-band p{color:#cfc8bd;margin:12px auto 22px;max-width:46ch}
.cta-band .btn--primary{background:#fff;color:var(--ink)}.cta-band .btn--primary:hover{background:#f1ece3}
.blog-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-top:30px}
@media(min-width:760px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.blog-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease}
.blog-card:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(42,42,40,.1)}
.blog-card .cat{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--sand)}
.blog-card h3{margin:10px 0;color:var(--ink);font-size:1.14rem;line-height:1.25}
.blog-card p{color:var(--muted);font-size:.94rem;flex:1;margin:0}
.blog-card .more{margin-top:14px;color:var(--ink);font-weight:600;font-size:.9rem}

/* logos partenaires cliquables (topbar) */
.topbar-logos a{display:inline-flex;text-decoration:none;transition:opacity .15s ease}
.topbar-logos a:hover{opacity:.55}

/* ===== optimisations iOS / iPhone ===== */
@media(max-width:860px){
  body{background-attachment:scroll}            /* background:fixed bugue sur iOS Safari */
  .nav-links.open a{display:block;padding:6px 0;font-size:1.02rem}  /* cibles tactiles */
}

/* galerie : swipe au doigt sur mobile (meme comportement que les avis) */
@media(max-width:760px){
  .marquee{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;-webkit-mask-image:none;mask-image:none;scroll-snap-type:x proximity;scrollbar-width:none}
  .marquee::-webkit-scrollbar{display:none}
  .marquee-track{animation:none}
  .marquee-track img{scroll-snap-align:center}
  .marquee-track img:nth-child(n+16){display:none}   /* masque le 2e set duplique (15 photos uniques) */
}

/* ===== micro-interactions ===== */
.nav{transition:box-shadow .25s ease,background .25s ease}
.nav.scrolled{box-shadow:0 6px 22px rgba(42,42,40,.07)}
.nav-links a{position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;height:1.5px;width:0;background:var(--sand);transition:width .22s ease}
.nav-links a:hover::after{width:100%}
.btn{transition:background .18s ease,border-color .18s ease,color .18s ease,transform .15s ease,box-shadow .2s ease}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(42,42,40,.20)}
.hero .btn--primary:hover{box-shadow:0 12px 28px rgba(0,0,0,.28)}
.btn--ghost:hover{transform:translateY(-2px)}
.point{transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.point:hover{transform:translateY(-3px);box-shadow:0 16px 38px rgba(42,42,40,.10);border-color:var(--line-2)}
.blog-card .more{transition:transform .2s ease}
.blog-card:hover .more{transform:translateX(5px)}
.stat .n{font-variant-numeric:tabular-nums}
a:focus-visible,.btn:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--sand);outline-offset:3px;border-radius:5px}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}
  .btn--primary:hover,.btn--ghost:hover,.point:hover{transform:none}
}
