:root{
  --bg: #eef0f4;
  --bg-2: #e3e7ee;
  --bg-3: #d6dbe5;
  --paper: #f7f8fb;
  --line: #c9cfdb;
  --line-2: #b1b8c7;
  --ink: #131826;
  --ink-2: #3d4759;
  --ink-3: #6d7589;
  --accent: #1f3aa8;
  --accent-2: #e07a5f;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:"Manrope",Helvetica,Arial,sans-serif;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
img{display:block;max-width:100%}
.serif{font-family:"Newsreader",Georgia,serif;font-weight:400;letter-spacing:-.005em}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.narrow{max-width:920px;margin:0 auto;padding:0 28px}

h1,h2,h3,h4{margin:0;font-weight:500;letter-spacing:-.015em}
.display{font-family:"Newsreader",Georgia,serif;font-weight:400;font-size:clamp(44px,5.6vw,80px);line-height:1.04;letter-spacing:-.02em}
.display em{font-style:italic;color:var(--accent)}
.h2{font-family:"Newsreader",Georgia,serif;font-weight:400;font-size:clamp(32px,3.6vw,48px);line-height:1.18;letter-spacing:-.015em}
.h2 em{font-style:italic;color:var(--accent)}
.eyebrow{font-size:11.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}
.micro{font-size:12px;color:var(--ink-3);letter-spacing:.02em}
hr.rule{border:0;border-top:1px solid var(--line);margin:0}

.util{font-size:13px;color:var(--ink-2);border-bottom:1px solid var(--line)}
.util .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.util .left{display:flex;gap:24px}
.util .left span{display:inline-flex;gap:8px;align-items:center}
.util .left svg{color:var(--accent)}
.util .right{display:flex;gap:18px;align-items:center}
.util .right a:hover{color:var(--ink)}

header.nav{position:sticky;top:0;z-index:50;background:rgba(246,243,236,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
header.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:12px;font-weight:600;font-size:18px;letter-spacing:-.01em}
.logo .mk{width:34px;height:34px;border-radius:50%;background:var(--accent);position:relative;display:grid;place-items:center;color:#f6f3ec;font-family:"Newsreader",serif;font-style:italic;font-size:18px}
.logo .mk::after{content:"";position:absolute;inset:-4px;border:1px solid var(--line-2);border-radius:50%}
nav ul{list-style:none;display:flex;gap:32px;margin:0;padding:0;font-size:14px;color:var(--ink-2)}
nav ul a:hover{color:var(--ink)}
.nav-right{display:flex;gap:10px;align-items:center}

.btn{display:inline-flex;align-items:center;gap:10px;padding:11px 18px;border-radius:6px;font-weight:500;font-size:14px;border:1px solid transparent;transition:transform .08s ease, background .15s ease, border-color .15s ease;cursor:pointer}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:#000}
.btn-line{border-color:var(--line-2);color:var(--ink);background:transparent}
.btn-line:hover{background:var(--bg-2)}
.btn-ghost{color:var(--ink-2)}
.btn-ghost:hover{color:var(--ink)}
.btn-lg{padding:14px 22px;font-size:15px;border-radius:8px}

.breadcrumb{font-size:13px;color:var(--ink-3);padding:16px 0;border-bottom:1px solid var(--line);background:var(--bg)}
.breadcrumb a{color:var(--ink-2)}
.breadcrumb a:hover{color:var(--ink);text-decoration:underline}
.breadcrumb .sep{margin:0 8px;color:var(--line-2)}
.breadcrumb .cur{color:var(--ink);font-weight:500}

.hero{padding:80px 0 64px;position:relative}
.hero .grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:start}
.hero .lede{font-size:18px;color:var(--ink-2);max-width:48ch;margin:24px 0 32px;line-height:1.55}
.hero .meta{display:flex;align-items:center;gap:16px;margin-bottom:32px}
.hero .meta .ln{flex:1;height:1px;background:var(--line)}
.hero .ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero .trust{margin-top:48px;border-top:1px solid var(--line);padding-top:32px;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.hero .trust .item{padding:0 24px;border-left:1px solid var(--line)}
.hero .trust .item:first-child{border-left:0;padding-left:0}
.hero .trust .v{font-family:"Newsreader",serif;font-size:32px;letter-spacing:-.02em;line-height:1}
.hero .trust .l{font-size:12.5px;color:var(--ink-3);margin-top:8px;letter-spacing:.04em}

.hero-cta{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:32px;box-shadow:0 1px 0 rgba(0,0,0,.02),0 28px 50px -32px rgba(28,31,36,.12);text-align:center}
.hero-cta .badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--accent);background:color-mix(in oklab,var(--accent) 8%,var(--paper));padding:6px 12px;border-radius:999px;letter-spacing:.04em;margin-bottom:24px}
.hero-cta .badge .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.hero-cta h3{font-family:"Newsreader",serif;font-weight:400;font-size:30px;line-height:1.1;margin:0 0 12px;color:var(--ink)}
.hero-cta p{color:var(--ink-2);font-size:15px;margin:0 0 24px}
.hero-cta .btn-cta{display:flex;width:100%;justify-content:center;align-items:center;gap:10px;background:var(--ink);color:var(--paper);padding:16px 24px;border-radius:8px;font-weight:500;font-size:15px;transition:background .15s ease}
.hero-cta .btn-cta:hover{background:#000}
.hero-cta .trustline{display:flex;justify-content:center;gap:18px;margin-top:18px;font-size:11.5px;color:var(--ink-3);flex-wrap:wrap}
.hero-cta .legal{font-size:11px;color:var(--ink-3);margin-top:14px}

section{padding:96px 0}
.sec-head{margin-bottom:56px}
.sec-head.center{text-align:center}
.sec-head h2{margin:14px 0 0;max-width:22ch}
.sec-head.center h2{margin-left:auto;margin-right:auto}
.sec-head p{color:var(--ink-2);max-width:54ch;margin:18px 0 0;font-size:16px}
.sec-head.center p{margin-left:auto;margin-right:auto}

.types{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.type{background:var(--bg);padding:32px 28px;display:flex;flex-direction:column;gap:14px;min-height:300px;position:relative}
.type:hover{background:var(--paper)}
.type .num{font-family:"Newsreader",serif;font-style:italic;font-size:13px;color:var(--ink-3)}
.type h3{font-family:"Newsreader",serif;font-size:24px;font-weight:400;line-height:1.1;letter-spacing:-.01em}
.type p{color:var(--ink-2);font-size:14px;margin:0;max-width:30ch}
.type .specs{margin-top:auto;border-top:1px solid var(--line);padding-top:14px;display:flex;justify-content:space-between;font-size:12px;color:var(--ink-3)}
.type .specs b{display:block;color:var(--ink);font-weight:600;font-size:14.5px;margin-top:3px;letter-spacing:-.01em}
.type .tag{position:absolute;top:24px;right:24px;font-size:11px;color:var(--accent);background:color-mix(in oklab, var(--accent) 8%, var(--paper));padding:4px 8px;border-radius:999px;font-weight:500;letter-spacing:.04em}

.aides-wrap{padding:0 0 96px}
.aides{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:56px;position:relative;overflow:hidden}
.aides::before{content:"";position:absolute;top:-60%;right:-10%;width:60%;height:200%;background:radial-gradient(closest-side, color-mix(in oklab, var(--accent) 6%, transparent), transparent 70%);pointer-events:none}
.aides .head{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:end;margin-bottom:48px;position:relative}
.aides .head h2{max-width:18ch}
.aides .head .right{color:var(--ink-2);max-width:46ch;font-size:15.5px}
.aides .quad{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);position:relative}
.aides .a{padding:32px 24px 0;border-left:1px solid var(--line)}
.aides .a:first-child{border-left:0;padding-left:0}
.aides .a .lbl{font-size:12.5px;color:var(--ink-3);letter-spacing:.04em;margin-bottom:14px}
.aides .a .v{font-family:"Newsreader",serif;font-weight:400;font-size:48px;letter-spacing:-.025em;line-height:1}
.aides .a .v small{font-size:24px;color:var(--ink-2);margin-left:2px}
.aides .a .d{font-size:13.5px;color:var(--ink-2);margin-top:14px;max-width:24ch}

.proc{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.proc .right{display:grid;gap:0}
.proc .stp{padding:24px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:80px 1fr;gap:24px;align-items:start}
.proc .stp:last-child{border-bottom:1px solid var(--line)}
.proc .stp .n{font-family:"Newsreader",serif;font-style:italic;font-size:22px;color:var(--ink-3);padding-top:2px}
.proc .stp h3{font-family:"Newsreader",serif;font-size:22px;font-weight:400;line-height:1.15;margin:0 0 6px}
.proc .stp p{color:var(--ink-2);font-size:14.5px;margin:0;max-width:42ch}
.proc .stp .when{font-size:12px;color:var(--ink-3);margin-top:10px;letter-spacing:.04em}

.tests{background:var(--bg-2)}
.testgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px}
.test{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:28px;display:flex;flex-direction:column;gap:18px;min-height:280px}
.test .stars{color:var(--accent-2);letter-spacing:2px;font-size:14px}
.test .q{font-size:16px;line-height:1.5;color:var(--ink)}
.test .q.large{font-family:"Newsreader",serif;font-size:22px;line-height:1.3;letter-spacing:-.01em;font-weight:400}
.test .who{margin-top:auto;display:flex;gap:12px;align-items:center;padding-top:14px;border-top:1px solid var(--line)}
.test .who .av{width:36px;height:36px;border-radius:50%;background:var(--bg-3);display:grid;place-items:center;font-size:12.5px;font-weight:600;color:var(--ink-2)}
.test .who b{display:block;font-size:13.5px;font-weight:600}
.test .who span{display:block;font-size:12px;color:var(--ink-3);margin-top:1px}

.faq-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start}
.faq-list{border-top:1px solid var(--line)}
.qa{border-bottom:1px solid var(--line)}
.qa summary{list-style:none;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;gap:18px;align-items:center;font-weight:500;font-size:16px;color:var(--ink)}
.qa summary::-webkit-details-marker{display:none}
.qa .pls{flex:0 0 22px;width:22px;height:22px;display:grid;place-items:center;color:var(--ink-2);transition:transform .2s ease}
.qa[open] .pls{transform:rotate(45deg);color:var(--ink)}
.qa .ans{padding:0 32px 22px 0;color:var(--ink-2);font-size:14.5px;max-width:62ch;line-height:1.6}

.final{background:var(--bg-2);text-align:center;padding:112px 0}
.final h2{margin:14px 0 18px}
.final p{color:var(--ink-2);max-width:46ch;margin:0 auto 28px;font-size:16px}
.final .ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

footer{padding:56px 0 32px;border-top:1px solid var(--line);background:var(--bg)}
footer .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px}
footer h4{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin:0 0 16px}
footer ul{list-style:none;margin:0;padding:0;display:grid;gap:10px;font-size:14px;color:var(--ink-2)}
footer a:hover{color:var(--ink)}
footer .bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:12.5px;color:var(--ink-3);flex-wrap:wrap;gap:12px}

.float{position:fixed;right:20px;bottom:20px;z-index:60;display:none;box-shadow:0 18px 36px -14px rgba(28,31,36,.3)}

@media (max-width:900px){
  .wrap{padding:0 20px}
  nav ul{display:none}
  .hero .grid,.proc,.faq-grid,.aides .head{grid-template-columns:1fr;gap:32px}
  .hero .trust{grid-template-columns:1fr 1fr;gap:0}
  .hero .trust .item{padding:18px 0;border-left:0;border-top:1px solid var(--line)}
  .hero .trust .item:nth-child(odd){padding-right:24px}
  .hero .trust .item:nth-child(even){border-left:1px solid var(--line);padding-left:24px}
  .types,.aides .quad,.testgrid{grid-template-columns:1fr}
  .aides{padding:32px}
  .aides .a{padding:24px 0;border-left:0;border-top:1px solid var(--line)}
  footer .cols{grid-template-columns:1fr 1fr}
  .float{display:inline-flex}
}

.photoband{padding:0;position:relative}
.photoband .wrap{padding:0 28px}
.photoband .img{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.photoband .img img{width:100%;height:clamp(280px,38vw,460px);object-fit:cover;display:block}
.photoband .cap{position:absolute;left:24px;bottom:24px;color:#fbf9f3;font-family:"Newsreader",serif;font-style:italic;font-size:clamp(20px,2vw,28px);letter-spacing:-.01em;line-height:1.1;text-shadow:0 2px 24px rgba(0,0,0,.4);max-width:32ch}
.photoband .cap small{display:block;font-style:normal;font-family:"Manrope",sans-serif;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(251,249,243,.78);margin-bottom:8px}
.photoduo{display:grid;grid-template-columns:1.4fr 1fr;gap:14px}
.photoduo .img img{height:clamp(220px,28vw,340px)}

.ico{stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* === Additions V2 (businesses, locations, navigation, prose riche) === */

.local-info{background:var(--paper);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:0 14px 14px 0;padding:28px 32px;margin:0 auto;max-width:820px}
.local-info .meta{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--ink-3);margin-bottom:14px;padding-bottom:14px;border-bottom:1px dashed var(--line-2)}
.local-info .meta b{color:var(--ink);font-weight:600}
.local-info p{color:var(--ink-2);font-size:15px;line-height:1.75;margin:0 0 1em}

.section-prose{font-size:16px;line-height:1.75;color:var(--ink);max-width:760px;margin:0 auto 28px}
.section-prose>p{margin:0 0 1em}
.section-prose h3{font-family:"Newsreader",serif;font-size:24px;font-weight:400;color:var(--ink);margin:1.6em 0 0.6em;letter-spacing:-.01em}
.section-prose ul, .section-prose ol{margin:0 0 1.2em;padding-left:22px;color:var(--ink-2)}
.section-prose li{margin:0.4em 0}
.section-prose li strong{color:var(--ink)}
.section-prose strong{color:var(--ink);font-weight:600}

.businesses-table{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;font-size:14px;margin-top:24px}
.businesses-table th{background:var(--bg-2);padding:14px 16px;text-align:left;font-weight:600;font-size:12px;color:var(--ink-2);border-bottom:1px solid var(--line);letter-spacing:.04em;text-transform:uppercase}
.businesses-table td{padding:14px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
.businesses-table tr:last-child td{border-bottom:none}
.businesses-table tr:hover{background:var(--bg-2)}
.businesses-table .biz-name{font-weight:600;color:var(--ink)}
.businesses-table .biz-rating{color:var(--accent-2);font-weight:600;white-space:nowrap}
.businesses-table .biz-reviews{color:var(--ink-3);font-size:12px;margin-left:6px}
.businesses-table a.biz-web{color:var(--accent);font-weight:500}
.businesses-table a.biz-web:hover{text-decoration:underline}

.locations{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:32px}
.location{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:20px;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}
.location:hover{transform:translateY(-2px);border-color:var(--line-2);box-shadow:0 8px 20px -10px rgba(28,31,36,.10)}
.location a{display:block;color:var(--ink);font-weight:600;font-size:16px}
.location a:hover{color:var(--accent)}
.location .count{color:var(--ink-3);font-size:13px;margin-top:6px}

.maillage{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:32px}
.nav-block{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:22px}
.nav-block h3{margin:0 0 14px;font-size:13px;font-weight:600;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em}
.nav-block ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.nav-block li a{color:var(--ink);font-size:14px;display:inline-flex;align-items:center;gap:6px;padding:4px 0}
.nav-block li a:hover{color:var(--accent);text-decoration:underline}
.nav-block li a::before{content:"→";color:var(--ink-3);font-size:13px}

.price-table{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;font-size:14px;margin-top:24px}
.price-table th{background:var(--bg-2);padding:14px 16px;text-align:left;font-weight:600;font-size:12px;color:var(--ink-2);border-bottom:1px solid var(--line);letter-spacing:.04em;text-transform:uppercase}
.price-table td{padding:14px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
.price-table tr:last-child td{border-bottom:none}
.price-table tr:hover{background:var(--bg-2)}
.price-table td:nth-child(2){font-weight:600;color:var(--ink);white-space:nowrap}
.price-table td:nth-child(3){color:var(--ink-2);font-size:13px}
.pricing-tip{margin-top:18px;padding:14px 18px;background:color-mix(in oklab,var(--accent) 6%,var(--paper));border-radius:10px;font-size:13px;color:var(--ink-2)}

.mistakes-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:32px}
.mistake-item{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:24px;position:relative}
.mistake-number{display:inline-block;font-family:"Newsreader",serif;font-size:14px;color:var(--accent-2);font-weight:500;letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px;font-style:italic}
.mistake-item h3{margin:0 0 8px;font-size:17px;font-weight:600;color:var(--ink)}
.mistake-item p{margin:0;color:var(--ink-2);font-size:14px;line-height:1.55}

.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:32px}
.photo-gallery .photo-cell{aspect-ratio:4/3;background-color:var(--bg-2);background-size:cover;background-position:center;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
