/* ===================== RESET & BASE ===================== */
/* Palette Senior Autonome : bleu rassurant + orange chaleureux + crème
   Typo plus grande (17px) et contrastes WCAG AA pour accessibilité senior */
:root {
    --c-primary: #0B5FA8;
    --c-primary-dk: #07406F;
    --c-primary-lt: #1E88E5;
    --c-accent: #F59E0B;
    --c-bg: #FAF7F0;
    --c-bg-alt: #EAF3FB;
    --c-bg-warm: #FFF6E5;
    --c-text: #11233A;
    --c-text-2: #3F4B5B;
    --c-text-3: #6B7280;
    --c-white: #fff;
    --c-border: #E5DFD2;
    --shadow-sm: 0 1px 2px rgba(0,0,0,.05);
    --shadow: 0 4px 12px rgba(0,0,0,.07);
    --shadow-lg: 0 10px 32px rgba(0,0,0,.12);
    --r: 14px;
    --r-sm: 8px;
    --nav-h: 70px;
    --mw: 1240px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px}
body{font-family:'Outfit',system-ui,sans-serif;font-size:1rem;line-height:1.65;color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased}
.logo-text{font-weight:800;font-size:1.35rem;letter-spacing:-.01em;color:var(--c-primary-dk)}
.logo-tld{color:var(--c-accent);font-weight:700}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-primary);text-decoration:none}
a:hover{color:var(--c-primary-dk)}
ul{list-style:none}

/* ===================== UTILITIES ===================== */
.container{max-width:var(--mw);margin:0 auto;padding:0 20px}
.section{padding:56px 0}
.section-alt{background:var(--c-bg-alt)}
.section-warm{background:var(--c-bg-warm)}
.text-center{text-align:center}
.section-title{font-size:1.5rem;font-weight:700;color:var(--c-primary-dk);margin-bottom:28px}

.grid{display:grid;gap:16px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

/* ===================== NAV ===================== */
.nav{position:fixed;inset:0 0 auto;z-index:1000;height:var(--nav-h);background:rgba(255,255,255,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--c-border)}
.nav.scrolled{box-shadow:var(--shadow)}
.nav-inner{display:flex;align-items:center;height:100%;gap:20px}
.logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1.1rem;color:var(--c-primary-dk);white-space:nowrap}
.logo svg{color:var(--c-primary);flex-shrink:0}
.nav-menu{display:flex;align-items:center;gap:20px;margin-left:auto}
.nav-menu a{color:var(--c-text);font-weight:500;font-size:.88rem}
.nav-menu a:hover{color:var(--c-primary)}
.search-wrap{position:relative;width:200px}
.search-wrap input{width:100%;padding:7px 12px 7px 32px;border:1.5px solid var(--c-border);border-radius:20px;font:inherit;font-size:.82rem;background:var(--c-bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85zm-5.242.156a5 5 0 1 1 0-10 5 5 0 0 1 0 10z'/%3E%3C/svg%3E") no-repeat 10px center}
.search-wrap input:focus{outline:none;border-color:var(--c-primary)}
.search-dd{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--c-white);border-radius:var(--r-sm);box-shadow:var(--shadow-lg);max-height:280px;overflow-y:auto;border:1px solid var(--c-border);z-index:50}
.search-dd a{display:block;padding:10px 14px;font-size:.88rem;color:var(--c-text);border-bottom:1px solid #f3f4f6}
.search-dd a:hover{background:var(--c-bg-alt)}
.search-dd .sub{display:block;font-size:.72rem;color:var(--c-text-3)}
.burger{display:none;background:0;border:0;cursor:pointer;padding:4px;flex-direction:column;gap:5px;margin-left:auto}
.burger span{display:block;width:22px;height:2px;background:var(--c-text);border-radius:1px}

/* ===================== BUTTONS ===================== */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 22px;border-radius:8px;font:inherit;font-weight:600;font-size:.88rem;border:0;cursor:pointer;transition:.2s}
.btn-p{background:var(--c-primary);color:#fff}
.btn-p:hover{background:var(--c-primary-dk);color:#fff;transform:translateY(-1px);box-shadow:0 4px 14px rgba(15,118,110,.25)}
.btn-a{background:var(--c-accent);color:var(--c-text)}
.btn-a:hover{background:#fbbf24;color:var(--c-text);transform:translateY(-1px)}
.btn-lg{padding:13px 32px;font-size:.95rem;border-radius:10px}

/* ===================== HERO (home) ===================== */
.hero{padding:calc(var(--nav-h) + 40px) 0 48px;background:linear-gradient(160deg,#042f2e,var(--c-primary-dk) 40%,var(--c-primary) 80%,var(--c-primary-lt));color:#fff}
.hero-row{display:flex;gap:32px;align-items:flex-start}
.hero-left{flex:1;min-width:0}
.hero-right{flex:2;min-width:0}
.hero h1{font-size:2.2rem;font-weight:800;line-height:1.15;margin-bottom:14px;letter-spacing:-.02em}
.hero-sub{font-size:1.05rem;opacity:.85;margin-bottom:24px;font-weight:300;line-height:1.6;max-width:520px}
.hero-search{position:relative;max-width:440px;margin-bottom:32px}
.hero-search input{width:100%;padding:14px 20px;border:0;border-radius:12px;font:inherit;font-size:.95rem;box-shadow:var(--shadow-lg)}
.hero-search input:focus{outline:3px solid var(--c-accent);outline-offset:1px}
.hero-search .search-dd{margin-top:6px;border-radius:var(--r)}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap;margin-top:12px}
.stat strong{display:block;font-size:1.7rem;font-weight:800}
.stat span{font-size:.82rem;opacity:.7}

/* ===================== MAGAZINE HOMEPAGE ===================== */
.mag-hero{padding:calc(var(--nav-h) + 32px) 0 28px;background:linear-gradient(160deg,#042f2e,var(--c-primary-dk) 60%,var(--c-primary));color:#fff;text-align:center}
.mag-hero-top h1{font-size:2rem;font-weight:800;letter-spacing:-.02em;margin-bottom:6px}
.mag-hero-sub{font-size:1rem;opacity:.75;font-weight:300;margin-bottom:20px}
.mag-search{max-width:480px;margin:0 auto;position:relative}
.mag-search input{width:100%;padding:12px 20px;border:0;border-radius:10px;font:inherit;font-size:.92rem;box-shadow:0 4px 20px rgba(0,0,0,.15)}
.mag-search input:focus{outline:3px solid var(--c-accent);outline-offset:1px}
.mag-search .search-dd{margin-top:6px;border-radius:var(--r)}

.mag-grid-top{display:grid;grid-template-columns:1.3fr 1fr;gap:20px}
.mag-featured{display:block;position:relative;border-radius:14px;overflow:hidden;text-decoration:none;color:#fff;min-height:420px;background:#1e293b}
.mag-featured-img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .3s}
.mag-featured:hover .mag-featured-img{transform:scale(1.03)}
.mag-featured-overlay{position:absolute;bottom:0;left:0;right:0;padding:28px;background:linear-gradient(transparent,rgba(0,0,0,.75) 40%)}
.mag-featured-overlay h2{font-size:1.4rem;font-weight:700;line-height:1.25;margin-bottom:8px}
.mag-featured-overlay p{font-size:.88rem;opacity:.85;line-height:1.5;margin-bottom:6px}
.mag-cat{display:inline-block;padding:3px 10px;background:var(--c-primary);border-radius:6px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.mag-date{font-size:.75rem;opacity:.6}

.mag-secondary{display:flex;flex-direction:column;gap:12px}
.mag-sec-card{display:flex;gap:14px;text-decoration:none;color:var(--c-text);padding:12px;border-radius:10px;border:1px solid var(--c-border);background:var(--c-white);transition:.15s}
.mag-sec-card:hover{border-color:var(--c-primary);box-shadow:0 2px 12px rgba(15,118,110,.08)}
.mag-sec-img{width:110px;height:80px;object-fit:cover;border-radius:8px;flex-shrink:0}
.mag-sec-body{flex:1;min-width:0}
.mag-sec-body h3{font-size:.88rem;font-weight:600;line-height:1.3;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mag-cat-sm{display:inline-block;padding:1px 6px;background:#e0f2fe;color:#0369a1;border-radius:4px;font-size:.65rem;font-weight:600;margin-bottom:4px}

/* Articles grid magazine */
.mag-articles-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.mag-art-card{display:flex;flex-direction:column;text-decoration:none;color:var(--c-text);border-radius:12px;overflow:hidden;background:var(--c-white);border:1px solid var(--c-border);transition:.2s}
.mag-art-card:hover{border-color:var(--c-primary);box-shadow:0 4px 20px rgba(15,118,110,.08);transform:translateY(-2px)}
.mag-art-img-wrap{overflow:hidden}
.mag-art-img{width:100%;height:200px;object-fit:cover;transition:transform .3s}
.mag-art-card:hover .mag-art-img{transform:scale(1.04)}
.mag-art-large .mag-art-img{height:240px}
.mag-art-body{padding:16px 18px 18px}
.mag-art-body h3{font-size:.95rem;font-weight:700;line-height:1.3;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mag-art-large .mag-art-body h3{font-size:1.08rem}
.mag-art-excerpt{font-size:.82rem;color:var(--c-text-2);line-height:1.5;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
@media(min-width:769px){
    .mag-articles-grid{grid-template-columns:repeat(4,1fr)}
    .mag-art-large{grid-column:span 2}
}
@media(max-width:768px){
    .mag-articles-grid{grid-template-columns:1fr}
    .mag-art-card{flex-direction:row}
    .mag-art-img-wrap{width:120px;flex-shrink:0}
    .mag-art-img,.mag-art-large .mag-art-img{width:120px;height:100%;min-height:100px}
    .mag-art-large .mag-art-body h3{font-size:.92rem}
    .mag-art-excerpt{display:none}
}

/* About section */
.mag-about{display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:center}
.mag-about-text h2{font-size:1.4rem;font-weight:800;margin-bottom:16px;color:var(--c-primary-dk)}
.mag-about-text p{font-size:.92rem;line-height:1.7;color:var(--c-text-2);margin-bottom:12px}
.mag-about-numbers{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.mag-about-stat{text-align:center;padding:20px 12px;background:var(--c-bg);border-radius:12px;border:1px solid var(--c-border)}
.mag-about-stat strong{display:block;font-size:1.5rem;font-weight:800;color:var(--c-primary)}
.mag-about-stat span{font-size:.78rem;color:var(--c-text-2)}
@media(max-width:768px){.mag-about{grid-template-columns:1fr;gap:24px}}

/* Engagement cards */
.mag-engage-card{background:var(--c-white);border:1px solid var(--c-border);border-radius:12px;overflow:hidden}
.mag-engage-img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.mag-engage-card h3{font-size:1rem;font-weight:700;margin-bottom:8px;padding:0 20px}
.mag-engage-card h3:first-of-type{padding-top:18px}
.mag-engage-card p{font-size:.85rem;color:var(--c-text-2);line-height:1.6;padding:0 20px 20px}

.mag-presta-card{display:flex;gap:14px;align-items:flex-start}
.mag-presta-icon{width:48px;height:48px;flex-shrink:0}
.mag-presta-card h3{font-size:.92rem;margin-bottom:2px}
.mag-presta-card p{font-size:.8rem;color:var(--c-text-2);margin:0}

.mag-regions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.mag-region-tag{padding:6px 16px;border:1.5px solid var(--c-border);border-radius:20px;font-size:.82rem;font-weight:500;color:var(--c-text);text-decoration:none;transition:.15s}
.mag-region-tag:hover{border-color:var(--c-primary);background:var(--c-primary);color:#fff}

@media(max-width:768px){
    .mag-grid-top{grid-template-columns:1fr}
    .mag-featured{min-height:280px}
    .mag-sec-card{padding:8px}
    .mag-sec-img{width:80px;height:60px}
    .mag-hero-top h1{font-size:1.5rem}
}

/* ===================== DEVIS CARD (in hero/header) ===================== */
.devis-card{background:var(--c-white);border-radius:var(--r);padding:20px 24px;box-shadow:var(--shadow-lg);color:var(--c-text);scroll-margin-top:calc(var(--nav-h) + 16px)}
.devis-card-title{font-size:1.05rem;font-weight:700;color:var(--c-primary-dk);margin-bottom:4px;text-align:center}
.devis-card .devis-sub{font-size:.8rem;color:var(--c-text-3);text-align:center;margin-bottom:12px}

/* Force hidden attribute */
[hidden]{display:none!important}

/* Formulaire devis multi-étapes */
.devis-form{display:flex;flex-direction:column;gap:0}
.df-step{display:flex;flex-direction:column;gap:10px}
.df-step-header{display:flex;align-items:center;gap:10px;margin-bottom:6px;padding-bottom:10px;border-bottom:1px solid var(--c-border)}
.df-step-num{width:28px;height:28px;border-radius:50%;background:var(--c-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}
.df-step-label{font-weight:600;font-size:.95rem;color:var(--c-primary-dk)}
.df-step-count{margin-left:auto;font-size:.72rem;color:var(--c-text-3);font-weight:500}
.df-row{display:flex;gap:10px}
.df-row .df-field{flex:1}
.df-field{display:flex;flex-direction:column;gap:3px}
.df-field label{font-size:.78rem;font-weight:600;color:var(--c-text-2)}
.df-field input,.df-field select,.df-field textarea{width:100%;padding:10px 12px;border:1.5px solid var(--c-border);border-radius:var(--r-sm);font:inherit;font-size:.88rem;color:var(--c-text);background:var(--c-bg);transition:border-color .2s}
.df-field input:focus,.df-field select:focus,.df-field textarea:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(15,118,110,.08)}
.df-field select{cursor:pointer;appearance:auto}
.df-field textarea{resize:vertical;min-height:56px}
/* Pills cliquables */
.pill-group,.pill-group-multi{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.pill,.pill-m{padding:8px 14px;border-radius:20px;border:1.5px solid var(--c-border);background:var(--c-bg);font:inherit;font-size:.82rem;color:var(--c-text-2);cursor:pointer;transition:.2s;white-space:nowrap}
.pill:hover,.pill-m:hover{border-color:var(--c-primary-lt);color:var(--c-primary)}
.pill.active,.pill-m.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.pill.active:hover,.pill-m.active:hover{background:var(--c-primary-dk)}
.df-next{width:100%;margin-top:4px}
.df-actions{display:flex;gap:10px;margin-top:4px}
.btn-back{background:transparent;color:var(--c-text-2);border:1.5px solid var(--c-border);flex-shrink:0}
.btn-back:hover{background:var(--c-bg);color:var(--c-text)}
.df-submit{flex:1}
.df-legal{font-size:.68rem;color:var(--c-text-3);text-align:center;margin-top:8px;line-height:1.4}
.df-legal a{color:var(--c-text-3);text-decoration:underline}
.df-success{text-align:center;padding:24px 0}
.df-success-icon{font-size:2.5rem;color:var(--c-primary);margin-bottom:8px}
.df-success-text{font-size:.95rem;font-weight:600;color:var(--c-primary-dk)}
.df-error{font-size:.82rem;color:#dc2626;text-align:center;padding:8px;background:#fef2f2;border-radius:var(--r-sm);margin-top:6px}

/* ===================== PAGE HEADER (ville/presta/region) ===================== */
.pg-header{padding:calc(var(--nav-h) + 36px) 0 40px;background:linear-gradient(160deg,#042f2e,var(--c-primary-dk) 50%,var(--c-primary));color:#fff}
.pg-row{display:flex;gap:32px;align-items:flex-start}
.pg-left{flex:1;min-width:0}
.pg-right{flex:2;min-width:0}
.pg-header h1{font-size:1.8rem;font-weight:800;margin-bottom:10px;letter-spacing:-.01em}
.pg-header .lead{font-size:.98rem;opacity:.85;font-weight:300;max-width:600px;line-height:1.6}
/* Trust bar — pleine largeur */
.trust-bar{display:flex;justify-content:space-between;gap:8px;margin-top:28px;padding:16px 0;border-top:1px solid rgba(255,255,255,.15)}
.trust-item{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.9);font-size:.9rem}
.trust-icon{font-size:1.4rem;flex-shrink:0}
.trust-item strong{font-weight:700;color:#fff}
.trust-bar-home{margin-top:32px}

.rating-line{display:flex;align-items:center;gap:8px;margin:10px 0}
.stars{color:var(--c-accent);font-size:.95rem;letter-spacing:1px}
.rating-txt{font-size:.88rem;opacity:.8}

/* ===================== BREADCRUMB ===================== */
.bc{margin-bottom:16px}
.bc ol{display:flex;flex-wrap:wrap;align-items:center;gap:2px;font-size:.82rem}
.bc li{display:flex;align-items:center}
.bc li::after{content:'›';margin:0 8px;opacity:.35;font-size:.9rem}
.bc li:last-child::after{display:none}
.bc a{color:rgba(255,255,255,.8);transition:color .2s;font-weight:400}
.bc a:hover{color:#fff}
.bc .active{color:rgba(255,255,255,.55);font-weight:500}

/* ===================== CARDS ===================== */
.card{background:var(--c-white);border-radius:var(--r);padding:20px;border:1px solid var(--c-border);transition:.2s}
a.card{display:block;color:var(--c-text)}
a.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--c-primary-lt)}
.card-img{width:100%;height:120px;object-fit:contain;border-radius:var(--r-sm);margin-bottom:10px;background:var(--c-bg-alt);padding:6px}
.card h2,.card h3{font-size:1rem;font-weight:600;margin-bottom:6px;color:var(--c-primary-dk)}
.card p{font-size:.84rem;color:var(--c-text-2);line-height:1.5}
.card .badge{display:inline-block;background:var(--c-bg-alt);color:var(--c-primary);padding:3px 10px;border-radius:16px;font-size:.75rem;font-weight:600}
.card .meta{display:block;font-size:.75rem;color:#6b7280;margin-top:4px}
.card-arrow{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--c-primary);opacity:0;transition:.2s}
a.card:hover .card-arrow{opacity:1}
.card-prestation-link{position:relative}

/* ===================== ARTISAN CARDS ===================== */
.art-card{background:var(--c-white);border-radius:var(--r);padding:20px;border:1px solid var(--c-border);display:flex;flex-direction:column;gap:10px}
.art-top{display:flex;align-items:center;gap:12px}
.art-av{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--c-primary-lt),var(--c-primary));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem;flex-shrink:0}
.art-name{font-weight:700;font-size:.95rem;color:var(--c-text)}
.art-forme{font-size:.75rem;color:var(--c-text-3)}
.art-spec{font-size:.84rem;color:var(--c-text-2);font-style:italic}
.art-addr{font-size:.78rem;color:var(--c-text-3)}
.art-rating{display:flex;align-items:center;gap:6px}
.art-rating .stars{font-size:.85rem}
.art-rating span:last-child{font-size:.78rem;color:var(--c-text-2)}
.art-badges{display:flex;flex-wrap:wrap;gap:4px}
.art-badge{padding:2px 8px;border-radius:12px;font-size:.7rem;font-weight:600;background:var(--c-bg-alt);color:var(--c-primary);border:1px solid rgba(15,118,110,.12)}
.art-siret{font-size:.72rem;color:var(--c-text-3);font-family:monospace}
.art-badge-rge{background:#dcfce7;color:#166534;border-color:rgba(22,101,52,.15)}
.art-review{font-size:.82rem;color:var(--c-text-2);padding:10px;background:#f9fafb;border-radius:6px;border-left:3px solid var(--c-primary-lt);line-height:1.5}
.art-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:6px}
.art-exp{font-size:.75rem;color:var(--c-text-3)}
.art-cta{font-size:.82rem;padding:8px 16px}

/* ===================== PRESTA DETAIL ===================== */
.presta-row{display:flex;gap:32px;align-items:flex-start}
.presta-img{width:220px;flex-shrink:0}
.presta-img img{width:100%;border-radius:var(--r);background:var(--c-bg-alt);padding:10px}
.presta-body{flex:1;min-width:0}
.presta-body h2{font-size:1.2rem;color:var(--c-primary-dk);margin:0 0 8px}
.presta-body h2+h2{margin-top:20px}
.presta-body p{color:var(--c-text-2);line-height:1.7;margin-bottom:12px;font-size:.92rem}

/* ===================== FEATURES ===================== */
.feat{text-align:center;padding:20px 14px;border-radius:var(--r);background:var(--c-white);border:1px solid var(--c-border)}
.feat-icon{font-size:1.8rem;margin-bottom:10px;display:block}
.feat h3{font-size:.92rem;font-weight:600;margin-bottom:6px;color:var(--c-primary-dk)}
.feat p{font-size:.82rem;color:var(--c-text-2)}

/* ===================== FAQ ===================== */
/* Calendar */
.cal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cal-card{background:var(--c-white);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.06);border:1px solid var(--c-border)}
.cal-header{display:flex;align-items:center;gap:8px;padding:12px 16px;color:#fff}
.cal-icon{font-size:1.3rem}
.cal-month{font-weight:700;font-size:1rem}
.cal-body{padding:14px 16px}
.cal-task{display:flex;gap:8px;align-items:flex-start;font-size:.82rem;line-height:1.5;color:var(--c-text-2);padding:5px 0;border-bottom:1px solid #f1f5f9}
.cal-task:last-child{border-bottom:none}
.cal-check{color:var(--c-primary);font-weight:700;flex-shrink:0;font-size:.75rem;margin-top:2px}
@media(max-width:900px){.cal-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.cal-grid{grid-template-columns:1fr}}

/* Pest cards */
.pest-card{background:var(--c-white);border:1px solid var(--c-border);border-radius:12px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.pest-top{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px}
.pest-icon{font-size:1.6rem;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border-radius:10px;flex-shrink:0}
.pest-name{font-size:.95rem;display:block;margin-bottom:4px}
.pest-tags{display:flex;gap:6px;flex-wrap:wrap}
.pest-tag{font-size:.68rem;font-weight:600;padding:2px 8px;border-radius:10px}
.pest-tag-type{background:#fef3c7;color:#92400e}
.pest-tag-period{background:#e0f2fe;color:#0369a1}
.pest-desc{font-size:.84rem;color:var(--c-text-2);line-height:1.6;margin-bottom:14px}
.pest-solution{display:flex;gap:10px;align-items:flex-start;font-size:.82rem;background:#f0fdf4;padding:12px 14px;border-radius:8px;line-height:1.5;color:var(--c-text)}
.pest-sol-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}

.faq-list{max-width:720px;margin:0 auto}
.faq-item{background:var(--c-white);border-radius:var(--r-sm);margin-bottom:8px;border:1px solid var(--c-border);overflow:hidden}
.faq-item[open]{border-color:var(--c-primary-lt)}
.faq-item summary{padding:14px 18px;font-weight:600;font-size:.9rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-item summary:hover{color:var(--c-primary)}
.faq-item summary::after{content:'+';font-size:1.3rem;color:var(--c-primary);font-weight:300;transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{padding:0 18px 14px;color:var(--c-text-2);font-size:.88rem;line-height:1.65}

/* ===================== LEGAL ===================== */
.legal{max-width:720px;text-align:left;color:rgba(255,255,255,.9)}
.legal h2{margin:24px 0 8px;font-size:1.15rem}
.legal p{margin-bottom:12px;line-height:1.7}

/* ===================== FOOTER ===================== */
.footer{background:#042f2e;color:rgba(255,255,255,.7);padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:36px}
.footer h3{color:#fff;font-size:.9rem;font-weight:600;margin-bottom:14px}
.footer p,.footer a{font-size:.84rem;color:rgba(255,255,255,.75);line-height:1.6}
.footer a:hover{color:#fff}
.footer ul li{margin-bottom:8px}
.footer-bot{border-top:1px solid rgba(255,255,255,.08);padding-top:18px;text-align:center;font-size:.78rem;color:rgba(255,255,255,.6)}

/* ===================== CTA BAND ===================== */
.city-hub-link{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:20px 24px;background:#f0fdfa;border:1.5px solid #99f6e4;border-radius:10px}
.city-hub-link strong{display:block;font-size:1rem;color:var(--c-primary-dk);margin-bottom:2px}
.city-hub-link span{font-size:.85rem;color:var(--c-text-2)}
@media(max-width:768px){.city-hub-link{flex-direction:column;text-align:center;gap:12px}}
.cta-band{background:linear-gradient(135deg,var(--c-primary-dk),var(--c-primary));padding:36px 0;color:#fff}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.cta-band-inner strong{display:block;font-size:1.2rem;font-weight:700;margin-bottom:4px}
.cta-band-inner span{font-size:.92rem;opacity:.8}
.cta-band-final{background:linear-gradient(135deg,#042f2e,var(--c-primary-dk) 50%,var(--c-primary))}

/* CTA inline (dans le corps de page) */
.cta-inline{margin-top:16px}

/* Texte SEO entre sections */
.seo-text{font-size:.9rem;color:var(--c-text-2);line-height:1.75;margin-top:24px;max-width:900px}

/* ===================== STICKY CTA MOBILE ===================== */
.sticky-cta{display:none}
@media(max-width:768px){
    .sticky-cta{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:999;background:var(--c-accent);color:var(--c-text);font-weight:700;font-size:.95rem;text-align:center;align-items:center;justify-content:center;padding:14px 20px;box-shadow:0 -4px 16px rgba(0,0,0,.15)}
    .sticky-cta:hover{background:#fbbf24;color:var(--c-text)}
    .footer{padding-bottom:70px}
}

/* ===================== MODAL ARTISAN ===================== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;backdrop-filter:blur(4px)}
.modal-box{background:var(--c-white);border-radius:var(--r);padding:36px 32px;max-width:460px;width:100%;text-align:center;position:relative;box-shadow:var(--shadow-lg);animation:modalIn .25s ease}
@keyframes modalIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.modal-close{position:absolute;top:12px;right:16px;background:0;border:0;font-size:1.6rem;color:var(--c-text-3);cursor:pointer;line-height:1}
.modal-close:hover{color:var(--c-text)}
.modal-icon{font-size:2.5rem;margin-bottom:12px}
.modal-title{font-size:1.15rem;font-weight:700;color:var(--c-primary-dk);margin-bottom:12px}
.modal-text{font-size:.9rem;color:var(--c-text-2);line-height:1.6;margin-bottom:10px}
.modal-cta{width:100%;margin-top:16px}
.modal-sub{font-size:.75rem;color:var(--c-text-3);margin-top:10px}

/* ===================== RICH CONTENT ===================== */
.rich-content{font-size:.92rem;color:var(--c-text-2);line-height:1.75;max-width:900px}
.rich-content p{margin-bottom:14px}
.rich-content strong{color:var(--c-text);font-weight:700}
.rich-content ul,.rich-content ol{margin:12px 0 16px 20px}
.rich-content li{margin-bottom:6px}
.rich-content table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.88rem;background:var(--c-white);border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--shadow-sm)}
.rich-content thead{background:var(--c-primary-dk);color:#fff}
.rich-content th{padding:12px 16px;text-align:left;font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}
.rich-content td{padding:10px 16px;border-bottom:1px solid var(--c-border)}
.rich-content tbody tr:last-child td{border-bottom:0}
.rich-content tbody tr:hover{background:var(--c-bg-alt)}
.rich-content .price-highlight{background:var(--c-bg-warm);font-weight:700;color:var(--c-text)}
.faq-answer{padding:0 18px 14px;color:var(--c-text-2);font-size:.88rem;line-height:1.65}
.faq-answer strong{color:var(--c-text)}

/* ===================== BLOG ===================== */
.blog-card{display:flex;flex-direction:column;border:none;box-shadow:none}
.blog-card:hover{box-shadow:none}
.blog-card-img{width:100%;height:180px;object-fit:cover;border-radius:var(--r-sm);margin-bottom:10px}
.blog-card-cat{display:inline-block;font-size:.7rem;font-weight:600;color:var(--c-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.blog-card h3{font-size:.95rem;margin-bottom:6px}
.blog-card p{font-size:.82rem;color:var(--c-text-2);line-height:1.5;flex:1}

/* ===================== ARTICLE PAGE ===================== */
.art-page{background:var(--c-bg)}

/* Header */
.art-header{background:var(--c-white);padding:calc(var(--nav-h) + 24px) 0 28px;border-bottom:1px solid var(--c-border)}
.art-header-inner{max-width:800px;margin:0 auto}
/* Breadcrumb dans article (fond blanc, pas vert) */
.art-header .bc a{color:var(--c-text-2)}
.art-header .bc a:hover{color:var(--c-primary)}
.art-header .bc .active{color:#6b7280}
.art-header .bc li::after{color:var(--c-border)}
.art-header h1{font-size:2.4rem;font-weight:800;line-height:1.3;color:var(--c-text);letter-spacing:-.02em;margin-bottom:16px}
.art-meta{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--c-text-2);flex-wrap:wrap}
.art-meta strong{color:var(--c-text);font-weight:600}
.art-meta-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;margin-right:2px}
.art-meta-author{color:var(--c-text);text-decoration:none}
.art-meta-author:hover{color:var(--c-primary);text-decoration:underline}
.art-meta-sep{color:var(--c-border)}

/* Featured image */
.art-featured-img{width:100%;max-height:520px;object-fit:cover;border-radius:12px;margin-top:24px;display:block}

/* Share buttons */
.art-share{display:flex;gap:8px;padding:18px 0;max-width:800px;margin:0 auto;flex-wrap:wrap}
.art-share-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font:inherit;font-size:.82rem;font-weight:600;text-decoration:none;border:1.5px solid var(--c-border);background:var(--c-white);color:var(--c-text-2);cursor:pointer;transition:.15s}
.art-share-fb{background:#1877f2;color:#fff;border-color:#1877f2}
.art-share-fb:hover{background:#1565c0;border-color:#1565c0;color:#fff}
.art-share-wa{background:#25D366;color:#fff;border-color:#25D366}
.art-share-wa:hover{background:#1ebe57;border-color:#1ebe57;color:#fff}
.art-share-x{background:#000;color:#fff;border-color:#000}
.art-share-x:hover{background:#333;border-color:#333;color:#fff}
.art-share-li{background:#0A66C2;color:#fff;border-color:#0A66C2}
.art-share-li:hover{background:#084e96;border-color:#084e96;color:#fff}
.art-share-pin{background:#E60023;color:#fff;border-color:#E60023}
.art-share-pin:hover{background:#c8001e;border-color:#c8001e;color:#fff}
.art-share-mail{background:#EA4335;color:#fff;border-color:#EA4335}
.art-share-mail:hover{background:#d33426;border-color:#d33426;color:#fff}
.art-share-copy{background:var(--c-white);color:var(--c-text-2);border-color:var(--c-border)}
.art-share-copy:hover{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}

/* Body wrap — layout 2 colonnes */
.art-body-wrap{padding:32px 0 48px;background:var(--c-bg)}
.art-layout{display:flex;gap:0;align-items:stretch}
.art-main{flex:1;min-width:0;background:var(--c-white);padding:24px 32px}

/* Sidebar */
.art-sidebar{width:300px;flex-shrink:0;background:var(--c-white);padding:20px}
.art-sidebar-sticky{position:static}
.art-sidebar-box{padding:0;overflow:hidden}
.art-sidebar-title{padding:14px 16px;margin:0;font-size:.95rem;border-bottom:1px solid var(--c-border)}
.art-sidebar-item{display:block;padding:0;text-decoration:none;color:var(--c-text);border-bottom:1px solid #f5f5f5;transition:.15s}
.art-sidebar-item:last-child{border-bottom:0}
.art-sidebar-item:hover{opacity:.85}
.art-sidebar-img-full{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.art-sidebar-item-title{display:block;padding:10px 16px 14px;font-size:.88rem;font-weight:700;line-height:1.3;color:var(--c-text)}

/* Table des matières */
.art-toc{background:var(--c-white);border:1px solid var(--c-border);border-left:4px solid var(--c-primary);border-radius:0 var(--r-sm) var(--r-sm) 0;padding:0;margin-bottom:32px;overflow:hidden}
.art-toc-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;user-select:none}
.art-toc-header strong{font-size:.92rem;color:var(--c-text)}
.art-toc-toggle{font-size:.7rem;color:var(--c-text-2);transition:transform .2s}
.art-toc.collapsed .art-toc-toggle{transform:rotate(-90deg)}
.art-toc.collapsed ul{display:none}
.art-toc ul{list-style:none;padding:0 18px 14px;margin:0}
.art-toc li{padding:5px 0}
.art-toc a{color:var(--c-primary-dk);text-decoration:none;font-size:.88rem;font-weight:500}
.art-toc a:hover{color:var(--c-primary);text-decoration:underline}

/* Contenu article */
.art-content{font-size:1.05rem;line-height:1.75;color:var(--c-text)}
.art-content p{margin-bottom:20px}
.art-content h2{font-size:1.6rem;font-weight:700;margin:40px 0 16px;color:var(--c-primary-dk);letter-spacing:-.01em}
.art-content h3{font-size:1.25rem;font-weight:600;margin:28px 0 12px;color:var(--c-text)}
.art-content h4{font-size:1.05rem;font-weight:600;margin:20px 0 8px}
.art-content a{color:var(--c-primary);text-decoration:underline;text-underline-offset:2px}
.art-content a:hover{color:var(--c-primary-dk)}
.art-content strong{color:var(--c-text);font-weight:700}
.art-content ul,.art-content ol{margin:8px 0 20px 24px}
.art-content li{margin-bottom:6px}
.art-content img{max-width:100%;border-radius:10px;margin:20px 0;display:block}
.art-content blockquote{border-left:4px solid var(--c-primary-lt);padding:14px 24px;margin:24px 0;background:var(--c-bg-alt);border-radius:0 10px 10px 0;font-style:italic;color:var(--c-text-2);font-size:1rem}
.art-content .table-wrap{overflow-x:auto;margin:20px 0;-webkit-overflow-scrolling:touch}
.art-content table{width:100%;border-collapse:collapse;font-size:.92rem;min-width:400px}
.art-content thead{background:var(--c-primary-dk);color:#fff}
.art-content th{padding:10px 14px;text-align:left;font-weight:600}
.art-content td{padding:8px 14px;border-bottom:1px solid var(--c-border)}
.art-content hr{border:none;border-top:2px solid var(--c-border);margin:32px 0}

/* Encadré "À lire aussi" dans le corps */
.art-read-also{margin:28px 0;padding:16px;background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--r-sm);border-left:4px solid var(--c-accent)}
.art-read-also-label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#92400e;margin-bottom:8px}
.art-read-also-link{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--c-text)}
.art-read-also-link img{width:100px;height:66px;object-fit:cover;border-radius:6px;flex-shrink:0}
.art-read-also-link span{font-weight:600;font-size:.95rem;line-height:1.3}
.art-read-also-link:hover span{color:var(--c-primary)}

/* Auteur box */
.art-author-box{display:flex;gap:16px;align-items:flex-start;padding:24px;background:var(--c-white);border-radius:var(--r);margin-top:40px;border:1px solid var(--c-border)}
.art-author-img{width:64px;height:64px;border-radius:50%;object-fit:cover;flex-shrink:0;border:3px solid var(--c-bg-alt)}
.art-author-box strong{display:block;margin-bottom:4px;font-size:1rem;color:var(--c-text)}
.art-author-box p{font-size:.88rem;color:var(--c-text-2);line-height:1.55;margin:0}

/* ===================== RESPONSIVE ARTICLE + BLOG ===================== */
@media(max-width:768px){
    /* Article page */
    .art-header{padding:calc(var(--nav-h) + 16px) 0 18px}
    .art-header h1{font-size:1.5rem;line-height:1.25}
    .art-meta{font-size:.8rem;gap:5px}
    .art-meta-avatar{width:26px;height:26px}
    .art-featured-img{border-radius:0;margin-left:-20px;margin-right:-20px;width:calc(100% + 40px);max-width:none;margin-top:16px}
    .art-share{justify-content:center;padding:12px 0}
    .art-share-btn{flex:1;justify-content:center;min-width:0;padding:8px 6px;font-size:.75rem}
    .art-share-btn svg{width:14px;height:14px}
    .art-layout{flex-direction:column}
    .art-sidebar{display:none}
    .art-body-wrap{padding:20px 0 32px}
    .art-content{font-size:.95rem}
    .art-content h2{font-size:1.25rem;margin:28px 0 12px}
    .art-content h3{font-size:1.05rem}
    .art-content blockquote{padding:10px 14px;margin:16px 0}
    .art-toc{margin-bottom:20px}
    .art-read-also{padding:12px}
    .art-read-also-link{gap:10px}
    .art-read-also-link img{width:70px;height:46px}
    .art-author-box{flex-direction:column;align-items:center;text-align:center;padding:18px}
    .art-author-img{width:52px;height:52px}

    /* Blog list */
    .blog-card-img{height:140px}
    .blog-card h3{font-size:.88rem}
    .blog-card p{font-size:.78rem}
}

@media(max-width:480px){
    .art-header h1{font-size:1.3rem}
    .art-share-btn svg{display:none}
    .art-share-btn{font-size:.72rem;padding:7px 4px}
    .art-content{font-size:.9rem;line-height:1.65}
}

/* ===================== MISC ===================== */
.notice{font-size:.82rem;color:var(--c-text-3);margin-top:10px}

/* ===================== RESPONSIVE ===================== */
@media(max-width:992px){
    .g4{grid-template-columns:repeat(3,1fr)}
    .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
    .trust-bar{flex-wrap:wrap;justify-content:center;gap:12px 24px}
    .cta-band-inner{flex-direction:column;text-align:center;gap:16px}
    .hero-row,.pg-row{flex-direction:column;gap:24px}
    .hero-right,.pg-right{flex:none;width:100%}
    .hero h1{font-size:1.7rem}
    .pg-header h1{font-size:1.4rem}
    .hero-stats{gap:24px}
    .g2,.g3,.g4{grid-template-columns:repeat(2,1fr)}
    .section{padding:40px 0}
    .presta-row{flex-direction:column;gap:20px}
    .presta-img{width:160px;margin:0 auto}
    .nav-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:var(--c-white);flex-direction:column;padding:20px;box-shadow:var(--shadow-lg)}
    .nav-menu.open{display:flex}
    .search-wrap{display:none!important}
    .burger{display:flex;margin-left:auto}
    .footer-grid{grid-template-columns:1fr;gap:20px}
}
@media(max-width:480px){
    .g2,.g3,.g4{grid-template-columns:1fr}
    .hero{padding-top:calc(var(--nav-h) + 24px)}
    .hero h1{font-size:1.4rem}
    .hero-right{max-width:100%}
    .stat strong{font-size:1.3rem}
    .hero-stats{gap:16px}
}
