@font-face{font-family:'Barlow';src:local('Arial');size-adjust:98%;ascent-override:90%;descent-override:22%;line-gap-override:0%}
@font-face{font-family:'Barlow Condensed';src:local('Arial Narrow'),local('Arial');size-adjust:88%;ascent-override:90%;descent-override:22%;line-gap-override:0%}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --rouge:#C8102E;--rouge-hover:#a50d25;--rouge-light:#fdf0f2;
  --noir:#111111;--gris-fonce:#2a2a2a;--gris-mid:#555;--gris:#6b6b6b;
  --gris-clair:#f7f7f5;--blanc:#ffffff;--border:#e5e5e2;
  --font-display:'Barlow Condensed',sans-serif;--font-body:'Barlow',sans-serif;
  --max:1080px;--pad:clamp(16px,5vw,48px)
}

body{font-family:var(--font-body);background:var(--blanc);color:var(--noir);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;padding-bottom:72px}

/* ========== HEADER ========== */
#nav-toggle{display:none}
header{position:sticky;top:0;z-index:200;background:var(--blanc);border-bottom:1px solid var(--border)}
.header-bar{height:60px;display:flex;align-items:center;padding:0 var(--pad);gap:20px}
.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;line-height:1}
.logo-mark{width:32px;height:32px;background:var(--rouge);border-radius:4px;display:flex;align-items:center;justify-content:center;margin-right:8px;flex-shrink:0}
.logo-text{display:flex;flex-direction:column}
.logo-name{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--noir);letter-spacing:.02em;line-height:1;text-transform:uppercase}
.logo-tagline{font-size:9px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:#555;margin-top:3px}
.nav-links{display:flex;gap:28px;align-items:center;margin-left:auto}
.nav-links a{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.09em;color:var(--gris-fonce);text-decoration:none;transition:color .2s;white-space:nowrap}
.nav-links a:hover{color:var(--rouge)}
.btn-nav{background:var(--rouge);color:#fff!important;padding:8px 18px;border-radius:2px;font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;text-decoration:none;transition:background .2s;white-space:nowrap}
.btn-nav:hover{background:var(--rouge-hover)}
.hamburger-label{display:none;width:36px;height:36px;margin-left:auto;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.hamburger-label span{display:block;width:22px;height:2px;background:var(--noir);border-radius:2px;transition:transform .3s,opacity .3s,width .3s;transform-origin:center}
#nav-toggle:checked~header .hamburger-label span:nth-child(1){transform:translateY(7px) rotate(45deg)}
#nav-toggle:checked~header .hamburger-label span:nth-child(2){opacity:0;width:0}
#nav-toggle:checked~header .hamburger-label span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:none;flex-direction:column;border-top:1px solid var(--border);background:var(--blanc);padding:8px 0 16px}
.nav-mobile a{padding:12px var(--pad);font-size:14px;font-weight:500;text-transform:uppercase;letter-spacing:.07em;color:var(--gris-fonce);text-decoration:none;border-bottom:1px solid var(--border);transition:color .2s,background .2s}
.nav-mobile a:last-child{border-bottom:none}
.nav-mobile a:hover{color:var(--rouge);background:var(--rouge-light)}
.nav-mobile .btn-mobile{margin:12px var(--pad) 0;background:var(--rouge);color:#fff;padding:13px;text-align:center;border-radius:2px;border-bottom:none;font-size:13px}
.nav-mobile .btn-mobile:hover{background:var(--rouge-hover)}
#nav-toggle:checked~header .nav-mobile{display:flex}

/* ========== BREADCRUMB ========== */
.breadcrumb{background:var(--gris-clair);border-bottom:1px solid var(--border);padding:11px var(--pad);font-size:14px;color:var(--gris);font-family:var(--font-body)}
.breadcrumb a{color:var(--gris);text-decoration:none}
.breadcrumb a:hover{color:var(--rouge)}
.breadcrumb .sep{margin:0 6px}
.breadcrumb .current{color:var(--rouge)}

/* ========== BOUTONS COMMUNS ========== */
.btn-cta{display:inline-block;background:var(--rouge);color:#fff;font-family:var(--font-body);font-size:12px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;padding:13px 28px;border-radius:2px;text-decoration:none;border:none;cursor:pointer;transition:background .2s,transform .15s;min-width:280px;text-align:center}
.btn-cta:hover{background:var(--rouge-hover);transform:translateY(-1px)}
.btn-cta-article{display:inline-block;background:var(--rouge);color:#fff!important;font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:12px 24px;border-radius:2px;text-decoration:none;border:none;cursor:pointer;transition:background .2s,transform .15s;margin:20px 0}
.btn-cta-article:hover{background:var(--rouge-hover);transform:translateY(-1px)}

/* ========== SECTIONS COMMUNES ========== */
.section-wrap{max-width:var(--max);margin:0 auto;padding:48px var(--pad)}
.section-header{display:flex;align-items:baseline;gap:12px;margin-bottom:28px}
.section-header h2{font-family:var(--font-display);font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--noir);letter-spacing:.02em;white-space:nowrap}
.section-header h2 .rouge{color:var(--rouge)}
.section-header::after{content:'';flex:1;height:1px;background:var(--border);min-width:20px}
.section-bg{background:var(--gris-clair);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}

/* ========== TEMOIGNAGES ========== */
.tem-card{display:grid;grid-template-columns:70px 1fr;gap:16px;align-items:start;padding:20px 0;border-bottom:1px solid var(--border)}
.tem-card:last-child{border-bottom:none}
.tem-avatar img{width:70px;height:70px;border-radius:50%;object-fit:cover;display:block;border:2px solid var(--border)}
.tem-titre{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--rouge);line-height:1.2;margin-bottom:4px}
.tem-meta{font-size:13px;color:var(--gris);margin-bottom:8px}
.tem-extrait{font-size:14px;color:var(--gris-fonce);line-height:1.7;font-style:italic}
.tem-lien{display:inline-block;margin-top:8px;color:var(--rouge);font-size:13px;font-weight:600;text-decoration:none}
.tem-lien:hover{text-decoration:underline}

/* ========== LISTEM ========== */
.listem-wrap{background:var(--blanc);border-top:1px solid var(--border)}
.listem-wrap-grey{background:var(--gris-clair);border-top:1px solid var(--border)}
.listem-inner{max-width:var(--max);margin:0 auto;padding:40px var(--pad)}
.listem-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.listem-grid picture{display:block}
.listem-grid picture img{width:100%;height:100%;object-fit:cover;border-radius:6px;display:block;min-height:260px}
.listem-inner h2{font-family:var(--font-display);font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--noir);margin-bottom:8px}
.listem-inner p.listem-desc{font-size:14px;color:var(--gris);margin-bottom:20px}
.listem-inner ul{list-style:none;display:flex;flex-direction:column;gap:0}
.listem-inner ul li{border-bottom:1px solid var(--border)}
.listem-inner ul li:first-child{border-top:1px solid var(--border)}
.listem-inner ul li a{display:block;font-size:15px;color:var(--rouge);font-weight:600;text-decoration:none;padding:10px 0 10px 14px;position:relative;transition:padding-left .15s}
.listem-inner ul li a::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:4px;border-radius:50%;background:var(--rouge)}
.listem-inner ul li a:hover{padding-left:20px;color:var(--rouge-hover)}

/* ========== VILLES / PILLS ========== */
.villes-grid{display:flex;flex-wrap:wrap;gap:8px}
.ville-pill{border:1px solid var(--border);border-radius:20px;padding:5px 15px;font-size:13px;color:var(--gris-fonce);text-decoration:none;transition:border-color .2s,color .2s,background .2s}
.ville-pill:hover{border-color:var(--rouge);color:var(--rouge);background:var(--rouge-light)}

/* ========== FOOTER ========== */
footer{border-top:1px solid var(--border);padding:18px var(--pad);font-size:12px;color:var(--gris);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
footer a{color:var(--gris);text-decoration:none}
footer a:hover{color:var(--rouge)}

/* ========== STICKY BAR ========== */
.sticky-bar{position:fixed;bottom:0;left:0;right:0;z-index:199;background:var(--blanc);border-top:1px solid var(--border);padding:10px var(--pad);display:flex;justify-content:center;box-shadow:0 -4px 24px rgba(0,0,0,.07);transition:bottom .25s ease}

/* ========== ARTICLE ========== */
.article-wrap{max-width:var(--max);margin:0 auto;padding:48px var(--pad)}
.article-eyebrow{display:flex;align-items:center;gap:10px;font-size:11px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--rouge);margin-bottom:16px}
.article-eyebrow::before{content:'';width:28px;height:1px;background:var(--rouge)}
h1{font-family:var(--font-display);font-size:clamp(28px,4vw,48px);font-weight:800;line-height:1.05;color:var(--noir);margin-bottom:28px}
.article-body h2.titre2pommenorm{font-family:var(--font-display);font-size:clamp(20px,2.5vw,26px);font-weight:700;color:var(--rouge);margin:36px 0 12px}
.article-body p.txtparblanc{font-size:16px;color:var(--gris-fonce);line-height:1.8;margin-bottom:16px}
.article-body a{color:#a50d25;font-weight:600;text-decoration:none}
.article-body a:hover{text-decoration:underline}
.article-body strong{color:var(--noir)}
.article-body ul{list-style:none;margin:12px 0 24px 0}
.article-body ul li{font-size:16px;color:var(--gris-fonce);line-height:1.8;margin-bottom:20px;padding-left:18px;position:relative}
.article-body ul li::before{content:'';position:absolute;left:0;top:11px;width:6px;height:6px;border-radius:50%;background:var(--rouge)}
.article-body ul li strong{color:var(--noir)}
.article-body picture{display:block;margin:28px 0}
.article-body picture img{width:100%;height:auto;display:block;border-radius:4px}
.article-body img{width:100%;height:auto;display:block;border-radius:4px;margin:28px 0}

/* ========== RESPONSIVE COMMUN ========== */
@media(max-width:640px){
  .nav-links{display:none}
  .hamburger-label{display:flex}
  .listem-grid{grid-template-columns:1fr}
  .tem-card{grid-template-columns:1fr}
  .tem-avatar{display:none}
  footer{flex-direction:column;text-align:center}
  .section-header h2{white-space:normal}
}