/* LeadGen static site preview styles.
   Keep page CSS here, not inline in the Jinja template. */

*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#f6f7fb;color:#182033;line-height:1.6;padding-bottom:92px}
.site-header{position:sticky;top:0;z-index:9000;background:rgba(255,255,255,.98);border-bottom:1px solid #e2e8f0;box-shadow:0 10px 28px rgba(15,23,42,.08);backdrop-filter:blur(12px)}
.site-header__inner{width:100%;max-width:none;margin:0;padding:10px 34px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.site-header__brand{display:flex;align-items:center;color:#0f172a;text-decoration:none;flex:0 0 auto}
.site-header__logo-img{display:block;width:68px;height:68px;object-fit:contain;flex:0 0 auto}
.site-header__nav{display:flex;align-items:center;justify-content:center;gap:10px;flex:1 1 auto;min-width:0}
.site-header__nav a{color:#334155;text-decoration:none;font-weight:850;font-size:15px;padding:10px 13px;border-radius:999px;white-space:nowrap}
.site-header__nav a:hover{background:#ecfdf5;color:#0f766e}
.site-header__cta{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:11px 19px;border-radius:999px;background:#f97316;color:#fff;text-decoration:none;font-weight:950;white-space:nowrap;box-shadow:0 10px 22px rgba(249,115,22,.28);flex:0 0 auto}
.site-header__cta:hover{background:#ea580c}
@media(max-width:980px){.site-header__inner{padding:10px 16px;gap:12px}.site-header__logo-img{width:54px;height:54px}.site-header__nav{gap:4px}.site-header__nav a{font-size:12px;padding:8px 7px}.site-header__cta{font-size:13px;padding:9px 12px;min-height:38px}}
@media(max-width:720px){.site-header__nav{display:none}.site-header__logo-img{width:48px;height:48px}}
@media(max-width:380px){.site-header__cta{padding:9px 10px}}
.wrap{max-width:1120px;margin:0 auto;padding:26px}
.hero{background:linear-gradient(135deg,#0f766e,#14532d);color:white;border-radius:0;padding:46px 24px 46px max(24px,calc((100vw - 1180px)/2));margin:0 0 24px calc(50% - 50vw);width:100vw;box-shadow:0 15px 35px rgba(15,23,42,.16)}
.hero-grid{display:grid;grid-template-columns:32fr 68fr;gap:24px;align-items:center;max-width:none;margin:0}
.hero-copy{min-width:0}
.hero-form{background:white;color:#172033;border-radius:22px;padding:24px;box-shadow:0 14px 28px rgba(15,23,42,.22)}
.hero-form h2{font-size:24px;margin-bottom:10px}
.form-row{display:grid;gap:10px;margin-top:14px}
.form-row input,.form-row select,.form-row textarea{width:100%;border:1px solid #cbd5e1;border-radius:12px;padding:12px;font:inherit}
.form-row textarea{min-height:88px}
.hero-form .btn{border:0;width:100%;cursor:pointer;margin-top:10px}
@media(max-width:800px){.hero-grid{grid-template-columns:1fr}
.hero{padding:24px}
}
.cta-full-wide{display:grid;grid-template-columns:42fr 58fr;gap:0;align-items:stretch;overflow:hidden;background:#0f172a;color:white;border-radius:24px;margin:26px calc(50% - 50vw);width:100vw;box-shadow:0 18px 38px rgba(15,23,42,.18)}
.cta-full-image{min-height:260px;background:linear-gradient(135deg,rgba(15,23,42,.08),rgba(15,23,42,.18)),url('/static/leadgen/nettoyage_toiture_auvergne/images/mousse-envahissante-toiture.jpg') center/cover no-repeat}
.cta-full-copy{padding:38px max(24px,calc((100vw - 1120px)/2)) 38px 36px;display:flex;flex-direction:column;justify-content:center}
.cta-full-copy h2{color:white;font-size:32px}
.cta-full-copy p{font-size:18px;color:#d1fae5;max-width:680px}
.cta-full-copy .btn{align-self:flex-start;margin-top:8px}
@media(max-width:800px){.cta-full-wide{grid-template-columns:1fr;margin-left:0;width:auto}
.cta-full-copy{padding:24px}
.cta-full-image{min-height:180px}
}
h1{font-size:42px;line-height:1.08;margin:0 0 14px}
.hero p{font-size:18px;max-width:780px;color:#ecfeff}
.btn{display:inline-block;background:#f97316;color:white;text-decoration:none;border-radius:999px;padding:12px 18px;font-weight:900}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}
.card,.section{background:white;border:1px solid #e5e7eb;border-radius:18px;padding:20px;margin:18px 0;box-shadow:0 8px 22px rgba(15,23,42,.06)}
h2{font-size:28px;line-height:1.2;margin:0 0 12px;color:#0f172a}
h3{font-size:20px;margin:18px 0 8px;color:#134e4a}
ul{padding-left:20px}
.links{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px}
.links a{display:block;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px;text-decoration:none;color:#0f766e;font-weight:800}
.meta{font-size:13px;color:#64748b;text-transform:uppercase;letter-spacing:.06em;font-weight:900;margin-bottom:8px}
.form{background:#fff7ed;border-color:#fed7aa}
.breadcrumb{font-size:14px;margin-bottom:16px}
.breadcrumb a{color:#0f766e;font-weight:800;text-decoration:none}
.image-proof-section{padding:0;background:transparent;border:0;box-shadow:none}
.image-proof-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;margin:22px 0 26px}
.image-proof-card{margin:0;background:#fff;border:1px solid #dbe3ef;border-radius:22px;overflow:hidden;box-shadow:0 12px 28px rgba(15,23,42,.10)}
.image-proof-card img{display:block;width:100%;height:260px;object-fit:cover}
.image-proof-card figcaption{padding:16px 18px;color:#334155;font-size:15px;line-height:1.55}
@media(max-width:760px){.image-proof-grid{grid-template-columns:1fr}
.image-proof-card img{height:220px}
}
.artisans-section{background:#fff;border:1px solid #e2e8f0;border-radius:22px;padding:26px;box-shadow:0 12px 28px rgba(15,23,42,.08)}
.seo-reorder-pair{display:flex;flex-direction:column}
.seo-reorder-pair>.intro-section{order:2}
.seo-reorder-pair>.bloc-meteo-demoussage{order:1}
.bloc-meteo-full-wide{margin:26px calc(50% - 50vw)!important;width:100vw}
.bloc-meteo-full-wide>div{border-radius:0!important;padding:18px max(24px,calc((100vw - 1120px)/2))!important}
.bloc-meteo-demoussage .row{display:flex;flex-wrap:wrap;gap:16px}
.bloc-meteo-demoussage .g-2{gap:8px}
.bloc-meteo-demoussage .g-4{gap:24px}
.bloc-meteo-demoussage .align-items-stretch{align-items:stretch}
.bloc-meteo-demoussage .col-lg-7{flex:1 1 58%;min-width:0}
.bloc-meteo-demoussage .col-lg-5{flex:1 1 36%;min-width:300px}
.bloc-meteo-demoussage .col-6{flex:1 1 calc(50% - 8px)}
.bloc-meteo-demoussage .col-md-3{max-width:calc(25% - 8px)}
.bloc-meteo-demoussage iframe{max-width:100%}
.meteo-layout{display:grid;grid-template-columns:7fr 5fr;gap:24px;align-items:stretch}
.meteo-stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.meteo-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
@media(max-width:900px){.bloc-meteo-demoussage .row{display:block}
.bloc-meteo-demoussage .col-lg-7,.bloc-meteo-demoussage .col-lg-5,.bloc-meteo-demoussage .col-6,.bloc-meteo-demoussage .col-md-3{max-width:none;margin-bottom:10px}
.meteo-layout{grid-template-columns:1fr}
.meteo-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.meteo-info-grid{grid-template-columns:1fr}
}
#vud_devis_header{display:none!important}
.devistap_rectangle_gris{display:none!important}
#vud_signature{display:none!important}
.section-lead{font-size:18px;color:#334155;margin-top:8px}
.artisan-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:22px}
.artisan-card{background:#fff;border:1px solid #dbe3ef;border-radius:18px;box-shadow:0 10px 24px rgba(15,23,42,.08);overflow:hidden}
.artisan-card .card-body{padding:18px;display:flex;flex-direction:column;min-height:100%;gap:10px}
.artisan-card .card-title{font-size:19px;line-height:1.25;margin:0;color:#0f172a}
.artisan-category{display:inline-block;align-self:flex-start;background:#ecfdf5;color:#065f46;border-radius:999px;padding:4px 10px;font-size:13px;font-weight:800}
.artisan-address{font-size:14px;color:#475569;margin:0}
.artisan-rating{font-size:15px;color:#334155}
.stars,.review-stars{color:#f59e0b;letter-spacing:1px}
.artisan-reviews{list-style:none;margin:4px 0 0;padding:0;display:grid;gap:8px}
.artisan-reviews li{background:#f8fafc;border-left:3px solid #f97316;border-radius:10px;padding:9px;font-size:13px;color:#334155}
.artisan-cta{margin-top:auto;text-align:center}
.btn-primary{background:#f97316;color:#fff!important}
@media(max-width:980px){.artisan-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:640px){.artisan-grid{grid-template-columns:1fr}
}
.sticky-bottom-devis{position:fixed;left:0;right:0;bottom:0;z-index:9999;background:rgba(15,23,42,.96);border-top:1px solid rgba(255,255,255,.14);box-shadow:0 -12px 32px rgba(15,23,42,.22);backdrop-filter:blur(10px);opacity:0;transform:translateY(110%);pointer-events:none;transition:opacity .18s ease,transform .18s ease}
.sticky-bottom-devis--visible{opacity:1;transform:translateY(0);pointer-events:auto}
.sticky-bottom-devis__inner{max-width:1120px;margin:0 auto;padding:12px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.sticky-bottom-devis__copy{display:flex;flex-direction:column;gap:2px;color:white;line-height:1.2}
.sticky-bottom-devis__copy strong{font-size:18px;font-weight:950;letter-spacing:-.01em}
.sticky-bottom-devis__copy span{font-size:13px;font-weight:850;color:#fed7aa;text-transform:uppercase;letter-spacing:.06em}
.sticky-bottom-devis__btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:12px 20px;border-radius:999px;background:#f97316;color:#fff;text-decoration:none;font-weight:950;white-space:nowrap;box-shadow:0 10px 24px rgba(249,115,22,.32)}
.sticky-bottom-devis__btn:hover{background:#ea580c}
@media(max-width:640px){body{padding-bottom:124px}.sticky-bottom-devis__inner{align-items:stretch;flex-direction:column;gap:10px;padding:12px}.sticky-bottom-devis__copy{text-align:center}.sticky-bottom-devis__btn{width:100%}}


/* City météo/démoussage block generated from CSV stock. */
.bloc-meteo-demoussage {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
}
.bloc-meteo-full-wide {
  margin: 26px calc(50% - 50vw) !important;
  width: 100vw;
}
.bloc-meteo-full-wide > div {
  background: linear-gradient(135deg, #f8fafc 0%, #eef6ff 100%);
  border: 1px solid #e5e7eb;
  border-radius: 0 !important;
  padding: 18px max(24px, calc((100vw - 1120px) / 2)) !important;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .06);
}
.bloc-meteo-demoussage .row {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
.bloc-meteo-demoussage .g-2 { gap: 8px; }
.bloc-meteo-demoussage .g-3 { gap: 14px; }
.bloc-meteo-demoussage .g-4 { gap: 24px; }
.bloc-meteo-demoussage .mt-1 { margin-top: 14px; }
.bloc-meteo-demoussage .align-items-stretch { align-items: stretch; }
.bloc-meteo-demoussage .col-lg-7 { flex: 1 1 58%; min-width: 0; }
.bloc-meteo-demoussage .col-lg-5 { flex: 1 1 36%; min-width: 300px; }
.bloc-meteo-demoussage .col-6 { flex: 1 1 calc(50% - 8px); }
.bloc-meteo-demoussage .col-md-3 { max-width: calc(25% - 8px); }
.bloc-meteo-demoussage .col-md-6 { flex: 1 1 calc(50% - 7px); }
.bloc-meteo-demoussage iframe {
  width: 100%;
  height: 285px;
  border: 0;
  display: block;
  max-width: 100%;
}
.bloc-meteo-demoussage .row.g-2 > .col-6 > div {
  border-radius: 12px;
  padding: 12px 10px;
  text-align: center;
  color: #fff;
  height: 100%;
}
.bloc-meteo-demoussage .row.g-2 > .col-6:nth-child(1) > div { background: #2563eb; }
.bloc-meteo-demoussage .row.g-2 > .col-6:nth-child(2) > div { background: #059669; }
.bloc-meteo-demoussage .row.g-2 > .col-6:nth-child(3) > div { background: #7c3aed; }
.bloc-meteo-demoussage .row.g-2 > .col-6:nth-child(4) > div { background: #ea580c; }
.bloc-meteo-demoussage .row.g-2 > .col-6 > div > div:first-child,
.bloc-meteo-demoussage .row.g-3 .col-md-6 > div > div:first-child {
  font-size: 9px;
  text-transform: uppercase;
  font-weight: 850;
  letter-spacing: .06em;
  margin-bottom: 6px;
}
.bloc-meteo-demoussage .row.g-2 > .col-6 > div > div:first-child {
  opacity: .86;
}
.bloc-meteo-demoussage .row.g-2 > .col-6 > div > div:nth-child(2) {
  font-size: 22px;
  line-height: 1;
  font-weight: 850;
}
.bloc-meteo-demoussage .row.g-2 > .col-6 > div > div:nth-child(2) span {
  font-size: 13px;
  font-weight: 800;
}
.bloc-meteo-demoussage .row.g-3 .col-md-6 > div,
.bloc-meteo-demoussage .col-lg-5 > div {
  border: 1px solid #e5e7eb;
  border-radius: 13px;
  padding: 13px;
  background: #fff;
  height: 100%;
}
.bloc-meteo-demoussage .row.g-3 .col-md-6 > div > div:first-child {
  color: #6b7280;
  margin-bottom: 8px;
}
.bloc-meteo-demoussage .row.g-3 span {
  display: inline-block;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 700;
  border-radius: 999px;
  padding: 4px 9px;
  margin: 0 5px 5px 0;
}
.bloc-meteo-demoussage .row.g-3 .col-md-6:nth-child(2) > div > div:nth-child(2) {
  font-size: 17px;
  font-weight: 850;
  color: #111827;
}
.bloc-meteo-demoussage .row.g-3 .col-md-6:nth-child(2) > div > div:nth-child(3) {
  font-size: 12.5px;
  color: #64748b;
  margin-top: 6px;
  line-height: 1.5;
}
.bloc-meteo-demoussage .col-lg-7 > div:last-child {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-left: 5px solid #ea580c;
  border-radius: 14px;
  padding: 15px 17px;
  margin-top: 14px;
}
.bloc-meteo-demoussage .col-lg-7 > div:last-child p {
  font-size: 15px;
  line-height: 1.75;
  color: #334155;
  margin: 0;
}
.bloc-meteo-demoussage .col-lg-5 > div {
  border-radius: 16px;
  overflow: hidden;
  min-height: 315px;
  padding: 0;
}
.bloc-meteo-demoussage .col-lg-5 > div > div {
  padding: 8px 12px;
  font-size: 11px;
  color: #6b7280;
  background: #f9fafb;
  border-top: 1px solid #e5e7eb;
}
.bloc-meteo-demoussage .col-lg-5 a {
  color: #2563eb;
  text-decoration: none;
  font-weight: 700;
}
@media (max-width: 900px) {
  .bloc-meteo-demoussage .row { display: block; }
  .bloc-meteo-demoussage .col-lg-7,
  .bloc-meteo-demoussage .col-lg-5,
  .bloc-meteo-demoussage .col-6,
  .bloc-meteo-demoussage .col-md-3,
  .bloc-meteo-demoussage .col-md-6 {
    max-width: none;
    margin-bottom: 10px;
  }
}
