body{font-family:Arial,sans-serif;margin:0;background:#f5f7fb;color:#102033}
.top{display:flex;justify-content:space-between;gap:18px;align-items:stretch;padding:14px 28px;background:#fff;border-bottom:1px solid #d9e2ef;box-shadow:0 8px 28px rgba(16,32,51,.06)}
.brand{display:flex;align-items:center;justify-content:center;color:#123b68;text-decoration:none;flex:0 0 96px;min-width:96px}
.brand img{width:86px;height:86px;object-fit:contain;display:block}
.brand span{display:none}
.top nav{display:flex;flex-wrap:wrap;gap:10px;align-items:stretch;flex:1 1 auto;width:100%}
.top nav a{display:flex;align-items:center;justify-content:center;box-sizing:border-box;flex:1 1 calc((100% - 60px)/7);min-height:42px;padding:9px 10px;border-radius:12px;background:#0b5cad;color:#fff;text-decoration:none;font-weight:800;text-align:center;line-height:1.12;box-shadow:0 8px 18px rgba(11,92,173,.18)}
.top nav a:hover{background:#074a8d}
.menu-toggle{display:none;margin-left:auto;width:48px;height:48px;border:1px solid #d9e2ef;border-radius:14px;background:#fff;box-shadow:0 8px 18px rgba(16,32,51,.10);cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.menu-toggle span{display:block;width:24px;height:3px;border-radius:999px;background:#0b5cad;transition:transform .2s ease,opacity .2s ease}
.top.menu-open .menu-toggle span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.top.menu-open .menu-toggle span:nth-child(2){opacity:0}
.top.menu-open .menu-toggle span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.links a{color:#0b5cad;text-decoration:none;font-weight:700}
.breadcrumb{width:80%;margin:18px auto 0;display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:14px;color:#526174}
.breadcrumb a{color:#0b5cad;text-decoration:none;font-weight:700}
.breadcrumb span[aria-current="page"]{font-weight:800;color:#102033}
.links{margin:0;padding-left:1.2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px 22px}
.links li{line-height:1.45}
.hero{width:100%;box-sizing:border-box;padding:28px;display:grid;grid-template-columns:minmax(0,40fr) minmax(0,60fr);gap:20px;align-items:start;background:linear-gradient(135deg,#e8f4ff,#fff)}
h1{font-weight:900;letter-spacing:-.045em;line-height:.98;color:#061474;font-size:clamp(48px,5vw,70px);margin:0 0 22px}
h2{font-weight:550;letter-spacing:-.025em;line-height:1.08;color:#2a724b;font-size:clamp(30px,3vw,42px);margin:0 0 28px}
h3{font-weight:800;letter-spacing:-.015em;line-height:1.16;color:#e86f10;font-size:clamp(20px,1.8vw,26px);margin:22px 0 10px;padding-left:12px;border-left:4px solid #ff8a1f;background:linear-gradient(90deg,rgba(255,138,31,.12),rgba(255,138,31,0));border-radius:8px}
.sub{font-size:19px;line-height:1.55;color:#344054}
.hero-copy{min-width:0}
.hero-image-figure{margin:18px 0 0}
.hero-image-figure img{display:block;width:100%;height:auto;max-height:330px;object-fit:cover;border-radius:18px;border:1px solid #d9e2ef;box-shadow:0 14px 34px rgba(16,32,51,.14)}
.hero-image-figure figcaption{margin-top:9px;font-size:14px;line-height:1.45;color:#526174}
.form{background:#fff;border:1px solid #d9e2ef;border-radius:18px;padding:22px;box-shadow:0 18px 50px rgba(16,32,51,.12)}
.btn{display:inline-block;background:#f97316;color:#fff;padding:14px 18px;border-radius:12px;text-decoration:none;font-weight:800}
main{padding:0 0 28px}
.bache-visual-flow{display:flex;flex-direction:column}
.bache-visual-flow>*{order:3}
.bache-visual-flow>.hero{order:1}
.bache-visual-flow>.intro-section{order:2;margin-top:28px}
.panel{background:#fff;border:1px solid #d9e2ef;border-radius:18px;padding:22px;margin:0 auto 18px;width:80%;box-sizing:border-box}
.panel:not(.grand-cta-section):not(.bottom-devis-section) p{font-size:18px;line-height:1.72;color:#000;margin:0 0 18px}
@media(max-width:850px){.panel:not(.grand-cta-section):not(.bottom-devis-section) p{font-size:16.5px;line-height:1.68}}
.image-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.image-grid figure{margin:0}
.image-grid img{display:block;width:100%;height:auto;border-radius:16px;border:1px solid #d9e2ef}
.image-grid figcaption{font-size:14px;color:#526174;margin-top:8px}
.grand-cta-section{background:#0f2d4a;color:#fff;border-color:#0f2d4a;width:100%;margin:0 0 18px;border-radius:0}
.grand-cta-section h2{display:inline-block;color:#fff;font-weight:550;padding:0;margin-bottom:28px}
.grand-cta-section p,.grand-cta-section li{color:#eef6ff;line-height:1.55}
.grand-cta-grid{display:grid;grid-template-columns:minmax(240px,38fr) minmax(0,62fr);gap:24px;align-items:center}
.grand-cta-grid figure{margin:0}
.grand-cta-grid img{display:block;width:100%;height:auto;border-radius:18px}
.grand-cta-grid figcaption{color:#cfe3f8;font-size:14px;margin-top:8px}
.grand-cta-btn{display:block;width:100%;box-sizing:border-box;text-align:center;margin:16px 0 0}
.grand-cta-situation{margin-top:18px;padding:18px;border:1px solid rgba(255,255,255,.22);border-radius:16px;background:rgba(255,255,255,.08)}
.grand-cta-situation h3{margin:0 0 10px;color:#fff;font-size:20px;line-height:1.25}
.grand-cta-situation p{margin:0;color:#eef6ff;line-height:1.55}
.bottom-devis-section{position:fixed;left:0;right:0;bottom:0;z-index:9999;width:100%;box-sizing:border-box;margin:0;border-radius:0;background:#000;color:#fff;border:0;text-align:left;padding:12px 18px;box-shadow:0 -12px 34px rgba(0,0,0,.28)}
.bottom-devis-inner{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,2fr) auto;gap:14px;align-items:center}
.bottom-devis-section h2{margin:0;color:#f97316;font-weight:550;font-size:20px;line-height:1.18}
.bottom-devis-section p{margin:0;color:#fff;font-size:15px;line-height:1.35}
.bottom-devis-btn{background:#000;color:#fff;font-size:16px;padding:12px 18px;border-radius:999px;white-space:nowrap;border:1px solid #fff}
body{padding-bottom:112px}
@media(max-width:820px){.bottom-devis-inner{grid-template-columns:1fr;gap:8px;text-align:center}
.bottom-devis-section{padding:10px 14px}
.bottom-devis-section h2{font-size:17px}
.bottom-devis-section p{font-size:13px}
body{padding-bottom:190px}
}
.faq-section .accordion{display:grid;gap:10px}
.faq-section .accordion-item{border:1px solid #d9e2ef;border-radius:14px;overflow:hidden;background:#fff}
.faq-section .accordion-header{margin:0}
.faq-section .accordion-button{width:100%;text-align:left;background:#f8fbff;border:0;padding:16px 18px;font-weight:800;color:#102033;font-size:16px;cursor:pointer}
.faq-section .accordion-button.collapsed{background:#ffffff}
.faq-section .accordion-body{padding:0 18px 16px;line-height:1.55;color:#344054}
.artisans-gmb-section h2{font-size:clamp(28px,3vw,42px);line-height:1.08;letter-spacing:-.02em;color:#2a724b;font-weight:550;margin:0 0 22px}
.artisans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.artisans-grid>[class*="col-"]{display:block}
.artisan-card{height:100%;background:#fff;border:1px solid #d9e2ef!important;border-radius:16px;padding:0;box-shadow:0 10px 28px rgba(16,32,51,.08)}
.artisan-card .card-body{padding:18px;display:flex;flex-direction:column;height:100%;box-sizing:border-box}
.artisan-card h3,.artisan-card .card-title{margin:0 0 10px;font-size:15px;line-height:1.28;letter-spacing:0;color:#102033;font-weight:900}
.artisan-card p{margin:0 0 10px;line-height:1.45;color:#344054}
.artisan-card .text-uppercase{margin:0 0 6px;font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:#0b5cad;font-weight:900}
.artisan-reviews{padding-left:1.1rem;display:grid;gap:10px;margin:0 0 16px;color:#344054}
.artisan-reviews li{line-height:1.45}
.artisan-card .btn{margin-top:auto;text-align:center;border-radius:12px}
.small{font-size:13px}
.text-muted{color:#667085}
.text-primary{color:#0b5cad}
.fw-bold,.fw-semibold{font-weight:800}
@media(max-width:850px){.top{align-items:center;flex-direction:row;flex-wrap:wrap;gap:12px;padding:10px 14px;position:sticky;top:0;z-index:10000}
.brand{flex:0 0 auto;min-width:0}
.brand img{width:58px;height:58px}
.menu-toggle{display:flex}
.top nav{display:none;flex:1 0 100%;width:100%;padding:8px 0 4px;border-top:1px solid #d9e2ef}
.top.menu-open nav{display:grid;grid-template-columns:1fr;gap:9px}
.top nav a{width:100%;min-height:44px;flex:0 0 auto;justify-content:flex-start;padding:12px 14px;border-radius:12px;font-size:15px;text-align:left}
.hero,.image-grid,.grand-cta-grid{grid-template-columns:1fr}
.panel{width:92%}
.grand-cta-section{width:100%}
}
