:root{
  --blue:#09234a;--blue2:#123f82;--green:#34721f;--green2:#5b8d31;--orange:#e89412;--orange2:#c66f00;--bg:#f4f7ef;--line:rgba(9,35,74,.13);--muted:#60708a;--shadow:0 18px 45px rgba(9,35,74,.13);--soft:rgba(255,255,255,.82)
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:linear-gradient(180deg,#fbfcf8 0,#eef4e9 100%);color:var(--blue);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}a{color:inherit}.site-header{min-height:92px;background:rgba(255,255,255,.97);display:grid;grid-template-columns:300px minmax(420px,1fr) auto;align-items:center;gap:20px;padding:12px clamp(20px,4vw,62px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;box-shadow:0 8px 24px rgba(9,35,74,.06);backdrop-filter:blur(10px)}.site-brand{display:flex;align-items:center;gap:13px;text-decoration:none;min-width:0}.brand-dog{width:60px;height:54px;display:grid;place-items:center}.brand-dog svg{width:60px;height:50px;fill:none;stroke:var(--orange);stroke-width:4.2;stroke-linecap:round;stroke-linejoin:round}.brand-copy strong{display:block;font-family:Georgia,serif;font-size:25px;line-height:1;color:var(--blue)}.brand-copy small{display:block;margin-top:6px;font-size:12px;color:#526782}.main-nav{display:flex;align-items:center;justify-content:center;gap:18px;min-width:0}.main-nav a{text-decoration:none;text-transform:uppercase;font-size:12px;font-weight:900;color:var(--blue);padding:32px 0 28px;border-bottom:4px solid transparent;white-space:nowrap}.main-nav a.active,.main-nav a:hover{color:var(--green);border-bottom-color:var(--green)}.header-actions{display:flex;align-items:center;gap:12px}.languages{display:flex;gap:6px}.languages a{width:33px;height:33px;border:1px solid var(--line);border-radius:999px;background:#f7f9f4;text-decoration:none;display:grid;place-items:center;font-size:10px;font-weight:900}.languages a.active{background:var(--green);border-color:var(--green);color:#fff}.join-button-top{background:linear-gradient(135deg,var(--orange),var(--orange2));color:#fff;text-decoration:none;border-radius:12px;padding:12px 17px;font-weight:900;white-space:nowrap;box-shadow:0 10px 22px rgba(232,148,18,.25)}
.home-page{width:min(1420px,calc(100% - 28px));margin:0 auto 34px;background:#fff;border:1px solid var(--line);border-top:0;border-radius:0 0 26px 26px;box-shadow:0 22px 70px rgba(9,35,74,.14);overflow:hidden}.hero-stage{height:clamp(430px,48vw,620px);min-height:430px;position:relative;background:linear-gradient(90deg,rgba(0,0,0,.10),rgba(255,255,255,.04)),url('/assets/img/bl-design/header-labrador-lac-propre-20260508.webp') center center/cover no-repeat;overflow:hidden;border-bottom:1px solid rgba(9,35,74,.10)}.hero-stage:after{content:"";position:absolute;inset:auto 0 0;height:34%;background:linear-gradient(0deg,rgba(255,255,255,.55),rgba(255,255,255,0));pointer-events:none}.hero-card{position:absolute;z-index:2;background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.75);box-shadow:0 24px 70px rgba(9,35,74,.16);backdrop-filter:blur(10px);border-radius:24px}.hero-main-card{left:33%;top:12%;width:40%;min-height:52%;padding:28px 30px 34px;text-align:left}.eyebrow{font-weight:950;color:var(--green);text-transform:uppercase;font-size:12px;letter-spacing:.12em;margin:0 0 10px}.hero-main-card h1{font-family:Georgia,serif;font-size:clamp(29px,3.1vw,47px);line-height:1.05;margin:0;color:var(--blue);max-width:650px}.hero-lead{font-size:clamp(15px,1.35vw,19px);line-height:1.5;color:#344760;margin:14px 0 18px;max-width:680px}.hero-points{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0 20px}.hero-points span{background:rgba(255,255,255,.72);border:1px solid rgba(9,35,74,.10);border-radius:13px;padding:10px 9px;font-size:13px;font-weight:800;color:#273d5b}.hero-cta{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--green),#236016);color:#fff;text-decoration:none;border-radius:12px;padding:13px 24px;font-weight:950;box-shadow:0 14px 26px rgba(52,114,31,.26)}.hero-qr-card{right:4.2%;top:13%;width:22%;min-height:50%;padding:22px 22px 26px}.qr-placeholder{height:130px;border:2px dashed rgba(9,35,74,.18);border-radius:16px;background:rgba(255,255,255,.55);display:grid;place-items:center;color:#a7b0bd;font-weight:950;font-size:28px;letter-spacing:.12em}.hero-qr-card h2{font-family:Georgia,serif;font-size:clamp(22px,2vw,33px);line-height:1.1;margin:24px 0 9px}.hero-qr-card p{font-size:15px;line-height:1.5;color:#526179;margin:0}.content-board,.feature-grid,.partner-grid{padding:26px clamp(18px,2.4vw,34px)}.section-top{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:18px}.section-top h2{font-family:Georgia,serif;font-size:28px;margin:0}.section-top a,.card-title-line a{font-weight:950;text-decoration:none;color:var(--blue2);text-transform:uppercase;font-size:12px}.board-grid{display:grid;gap:20px}.board-grid-three{grid-template-columns:1.08fr 1.18fr .92fr}.home-card,.feature-card,.wide-feature,.internal-card{background:rgba(255,255,255,.98);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);overflow:hidden}.event-card{display:grid;grid-template-columns:84px 168px 1fr;gap:16px;align-items:stretch;padding:18px}.date-box{background:#f6f8fb;border:1px solid rgba(9,35,74,.08);border-radius:16px;display:grid;place-items:center;text-align:center;align-self:stretch}.date-box strong{font-size:43px;line-height:.9;color:var(--blue2)}.date-box span{text-transform:uppercase;font-size:12px;font-weight:950;color:#4e5d74}.event-card img{width:100%;height:100%;min-height:168px;object-fit:cover;border-radius:16px}.card-copy{padding:2px 4px}.tag{font-size:12px;font-weight:950;color:var(--blue2);text-transform:uppercase;margin:0 0 6px}.card-copy h3,.card-title-line h3,.feature-card h3,.wide-feature h3{font-family:Georgia,serif;margin:0;color:var(--blue)}.card-copy h3{font-size:22px}.card-copy p{color:#50627a;line-height:1.45}.card-copy a,.feature-card a{display:inline-flex;background:var(--blue2);color:#fff;text-decoration:none;border-radius:10px;padding:10px 15px;font-weight:900;font-size:13px}.regions-card,.feed-card{padding:18px}.card-title-line{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.card-title-line h3{font-size:24px}.region-list{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.region-mini{position:relative;min-height:180px;border-radius:16px;overflow:hidden;text-decoration:none;display:flex;align-items:flex-end;background:#112}.region-mini img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .25s}.region-mini:hover img{transform:scale(1.04)}.region-mini:after{content:"";position:absolute;inset:45% 0 0;background:linear-gradient(0deg,rgba(0,0,0,.72),rgba(0,0,0,0))}.region-mini span{position:relative;z-index:2;color:#fff;font-size:13px;font-weight:950;padding:12px;text-shadow:0 2px 8px rgba(0,0,0,.5)}.feed-row{display:grid;grid-template-columns:34px 1fr 72px;gap:11px;align-items:center;padding:10px 0;border-bottom:1px solid rgba(9,35,74,.08)}.feed-row:last-child{border-bottom:0}.feed-dot{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#e8ddd0,#c9ddeb)}.feed-row p{margin:0;color:#51627a;font-size:14px;line-height:1.35}.feed-row img{width:72px;height:58px;object-fit:cover;border-radius:11px}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.feature-card{display:grid;grid-template-columns:1.05fr .95fr;align-items:stretch;min-height:230px}.feature-copy{padding:22px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}.feature-icon{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;font-size:22px;margin-bottom:13px;background:#f4f8ef;border:1px solid rgba(52,114,31,.22)}.feature-card h3{font-size:25px}.feature-card p,.wide-feature p{color:#51627a;line-height:1.5}.feature-card img{width:100%;height:100%;object-fit:cover}.feature-card.green a{background:var(--green)}.feature-card.orange a{background:var(--orange)}.feature-card.blue a{background:var(--blue2)}.partner-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.wide-feature{display:grid;grid-template-columns:66px 1fr 38%;gap:18px;align-items:center;padding:18px;min-height:150px}.wide-feature .feature-icon{margin:0}.wide-feature h3{font-size:24px}.wide-feature img{width:100%;height:120px;border-radius:16px;object-fit:cover}.internal-page{width:min(1160px,calc(100% - 28px));margin:34px auto}.internal-card{padding:42px}.internal-card h1{font-family:Georgia,serif;font-size:clamp(34px,5vw,62px);margin:0 0 14px}.internal-card p{font-size:18px;line-height:1.65;color:#41506a}.simple-button{display:inline-flex;background:var(--green);color:#fff;text-decoration:none;border-radius:10px;padding:12px 18px;font-weight:900}.site-footer{width:min(1420px,calc(100% - 28px));margin:0 auto 24px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 28px rgba(9,35,74,.08);display:flex;align-items:center;justify-content:space-around;gap:20px;padding:22px;color:var(--blue);font-weight:900}.site-footer a{text-decoration:none}.socials{margin-left:auto;color:#27466f}
@media(max-width:1280px){.site-header{grid-template-columns:1fr auto}.main-nav{grid-column:1/-1;order:3;overflow:auto;justify-content:flex-start;padding-bottom:2px}.main-nav a{padding:10px 0}.hero-main-card{left:28%;width:46%}.hero-qr-card{right:3%;width:24%}.board-grid-three{grid-template-columns:1fr}.feature-grid,.partner-grid{grid-template-columns:1fr}.event-card{grid-template-columns:90px 210px 1fr}.region-list{grid-template-columns:repeat(4,1fr)}}
@media(max-width:860px){.home-page,.site-footer{width:100%;border-left:0;border-right:0;border-radius:0}.site-header{position:relative;grid-template-columns:1fr;padding:14px 18px}.header-actions{justify-content:space-between}.hero-stage{height:auto;min-height:0;background-position:left top;padding:300px 14px 18px;display:grid;gap:14px}.hero-card{position:relative;left:auto;right:auto;top:auto;width:auto}.hero-main-card,.hero-qr-card{width:auto;min-height:0;padding:22px}.hero-points{grid-template-columns:1fr}.qr-placeholder{height:96px}.content-board,.feature-grid,.partner-grid{padding:16px 12px}.event-card,.feature-card,.wide-feature{grid-template-columns:1fr}.event-card img,.feature-card img,.wide-feature img{height:190px}.region-list{grid-template-columns:repeat(2,1fr)}.site-footer{flex-wrap:wrap}.socials{margin-left:0}}
@media(max-width:520px){.brand-copy strong{font-size:21px}.main-nav{gap:14px}.hero-stage{padding-top:260px;background-size:auto 360px;background-repeat:no-repeat}.section-top{align-items:flex-start;flex-direction:column}.event-card{padding:14px}.region-list{grid-template-columns:1fr}.feed-row{grid-template-columns:30px 1fr}.feed-row img{display:none}.wide-feature{gap:12px}}


/* Correctif V6 - header propre sans blocs incrustés dans l'image */
.hero-stage{
  background-image:linear-gradient(90deg,rgba(0,0,0,.10),rgba(255,255,255,.04)),url('/assets/img/bl-design/header-labrador-lac-propre-20260508.webp') !important;
  background-position:center center !important;
  background-size:cover !important;
  background-repeat:no-repeat !important;
  height:clamp(390px,42vw,560px) !important;
  min-height:390px !important;
}
.hero-stage:after{
  background:linear-gradient(0deg,rgba(255,255,255,.28),rgba(255,255,255,0)) !important;
}
.hero-card{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
}
.hero-main-card{
  left:36% !important;
  top:15% !important;
  width:39% !important;
  min-height:auto !important;
  padding:0 !important;
  text-shadow:0 2px 14px rgba(255,255,255,.75) !important;
}
.hero-main-card h1,
.hero-lead,
.hero-points span,
.eyebrow{
  background:transparent !important;
}
.hero-points span{
  border:0 !important;
  padding:4px 0 !important;
  box-shadow:none !important;
}
.hero-qr-card{
  right:4.8% !important;
  top:18% !important;
  width:20% !important;
  min-height:auto !important;
  padding:0 !important;
  background:transparent !important;
  text-shadow:0 2px 14px rgba(255,255,255,.78) !important;
}
.qr-placeholder{
  display:none !important;
}
@media(max-width:860px){
  .hero-stage{
    height:auto !important;
    min-height:0 !important;
    background-position:left top !important;
    padding:310px 16px 22px !important;
  }
  .hero-main-card,.hero-qr-card{
    left:auto !important;right:auto !important;top:auto !important;width:auto !important;
    background:rgba(255,255,255,.78) !important;
    border:1px solid rgba(255,255,255,.75) !important;
    border-radius:20px !important;
    padding:18px !important;
    text-shadow:none !important;
  }
}

/* === BL FIX HERO TAILLES RAISONNABLES 2026-05-08 V10 === */
/* Correction ciblée : on ne touche pas à l'image, pas au HTML, pas au body.
   On remet le titre et le sous-titre à une taille raisonnable.
   On garde uniquement les 3 lignes et le bouton un peu plus visibles. */

/* Le logo SVG reste propre, mais pas énorme. */
.brand-logo-img{
  width:76px !important;
  height:auto !important;
  display:block !important;
  flex:0 0 auto !important;
}
.brand-copy strong{
  font-size:clamp(20px,1.65vw,27px) !important;
  line-height:1.04 !important;
}
.brand-copy small{
  font-size:12px !important;
}

/* Aucun bloc/voile derrière le texte du hero. */
.hero-card,
.hero-main-card,
.hero-copy,
.hero-content,
.hero-text-box,
.hero-title-box,
.hero-info,
.hero-intro,
.bl-hero-main,
.bl-hero-content{
  background:transparent !important;
  background-color:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  outline:0 !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}
.hero-card *,
.hero-main-card *,
.hero-copy *,
.hero-content *,
.hero-text-box *,
.hero-title-box *,
.hero-info *,
.hero-intro *,
.bl-hero-main *,
.bl-hero-content *{
  background-color:transparent !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}

/* Zone texte centrale : on la garde dans la photo. */
.hero-main-card{
  left:35% !important;
  top:14% !important;
  width:40% !important;
  max-width:620px !important;
  padding:0 !important;
  z-index:3 !important;
}

/* Titre remis plus petit : il doit rentrer dans l'image. */
.hero-main-card h1,
.hero-title,
.bl-hero-title{
  color:#ffffff !important;
  font-size:clamp(31px,3.05vw,48px) !important;
  line-height:1.02 !important;
  font-weight:950 !important;
  max-width:600px !important;
  margin:0 0 10px !important;
  text-shadow:0 2px 3px rgba(0,24,58,.96),0 6px 18px rgba(0,24,58,.82) !important;
}

/* Sous-titre remis plus petit aussi. */
.hero-lead,
.hero-subtitle,
.bl-hero-subtitle{
  color:#fff8e6 !important;
  font-size:clamp(15px,1.25vw,20px) !important;
  line-height:1.32 !important;
  font-weight:800 !important;
  max-width:560px !important;
  margin:8px 0 12px !important;
  text-shadow:0 2px 3px rgba(0,24,58,.94),0 5px 16px rgba(0,24,58,.78) !important;
}

.hero-main-card .eyebrow,
.hero-stage .eyebrow{
  color:#ffffff !important;
  font-size:clamp(12px,.9vw,15px) !important;
  font-weight:900 !important;
  letter-spacing:.11em !important;
  margin-bottom:7px !important;
  text-shadow:0 2px 3px rgba(0,24,58,.94),0 5px 15px rgba(0,24,58,.76) !important;
}

/* Ce sont ces 3 lignes qui sont volontairement un peu plus grandes. */
.hero-points{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:6px !important;
  margin:12px 0 16px !important;
  max-width:520px !important;
}
.hero-points span,
.bl-hero-list li,
.bl-hero-list span{
  color:#ffffff !important;
  font-size:clamp(17px,1.35vw,23px) !important;
  line-height:1.16 !important;
  font-weight:950 !important;
  padding:0 !important;
  border:0 !important;
  border-radius:0 !important;
  text-shadow:0 2px 3px rgba(0,24,58,.98),0 6px 18px rgba(0,24,58,.86) !important;
}

/* Bouton ajouté/renforcé, mais pas gigantesque. */
.hero-cta,
.hero-real-button,
.bl-hero-button,
.cta-button,
a.hero-cta{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:46px !important;
  padding:12px 24px !important;
  border-radius:15px !important;
  background:linear-gradient(135deg,#2f7d24,#185b16) !important;
  color:#ffffff !important;
  font-size:clamp(16px,1.05vw,19px) !important;
  font-weight:950 !important;
  text-decoration:none !important;
  box-shadow:0 12px 25px rgba(0,49,22,.30) !important;
  text-shadow:none !important;
  border:1px solid rgba(255,255,255,.30) !important;
}

/* Seul le QR garde son petit bloc blanc. */
.hero-qr-card,
.bl-hero-qr,
.hero-qr,
.qr-card{
  background:rgba(255,255,255,.94) !important;
  border:1px solid rgba(255,255,255,.95) !important;
  border-radius:18px !important;
  box-shadow:0 14px 30px rgba(3,22,45,.16) !important;
  padding:11px !important;
  width:clamp(125px,11vw,165px) !important;
  right:4.4% !important;
  top:18% !important;
  z-index:4 !important;
  text-shadow:none !important;
}
.hero-qr-card *,
.bl-hero-qr *,
.hero-qr *,
.qr-card *{
  color:#102f52 !important;
  text-shadow:none !important;
  background:transparent !important;
  box-shadow:none !important;
}
.qr-placeholder{
  display:grid !important;
  place-items:center !important;
  width:66px !important;
  height:66px !important;
  margin:0 auto 7px auto !important;
  border-radius:12px !important;
  background:#f6f8fb !important;
  border:1px dashed rgba(16,47,82,.28) !important;
  color:#8b96a8 !important;
  font-size:16px !important;
}
.hero-qr-card h2{font-size:clamp(15px,1vw,18px) !important;line-height:1.12 !important;margin:5px 0 4px !important;}
.hero-qr-card p{font-size:11px !important;line-height:1.24 !important;margin:0 !important;}

@media(max-width:1280px){
  .hero-main-card{left:32% !important;width:45% !important;top:13% !important;}
  .hero-main-card h1{font-size:clamp(29px,3vw,43px) !important;}
  .hero-lead{font-size:clamp(14px,1.25vw,18px) !important;}
  .hero-points span{font-size:clamp(16px,1.45vw,21px) !important;}
}
@media(max-width:860px){
  .brand-logo-img{width:64px !important;}
  .hero-stage{padding:300px 16px 22px !important;background-position:left top !important;}
  .hero-main-card{
    position:relative !important;
    left:auto !important;right:auto !important;top:auto !important;width:auto !important;max-width:none !important;
    padding:0 !important;
  }
  .hero-main-card h1{font-size:clamp(30px,9vw,42px) !important;}
  .hero-lead{font-size:clamp(16px,4.5vw,20px) !important;}
  .hero-points span{font-size:17px !important;}
  .hero-cta{font-size:16px !important;min-height:44px !important;padding:11px 20px !important;}
  .hero-qr-card{
    position:relative !important;
    left:auto !important;right:auto !important;top:auto !important;width:150px !important;
    margin-top:14px !important;
  }
}
/* === FIN BL FIX HERO TAILLES RAISONNABLES 2026-05-08 V10 === */



/* === BODY BELGIQUE-LABRADOR V15 SPACING - DEBUT === */
/* Body uniquement : ne touche pas au header, hero, logo, textes ou images. */

.content-board,
.feature-grid,
.partner-grid{
  padding-top: 14px !important;
  padding-bottom: 14px !important;
  padding-left: clamp(14px, 1.6vw, 22px) !important;
  padding-right: clamp(14px, 1.6vw, 22px) !important;
}

.section-top{
  margin-bottom: 10px !important;
}

.section-top h2{
  font-size: clamp(22px, 1.7vw, 27px) !important;
  line-height: 1.1 !important;
}

.board-grid,
.feature-grid,
.partner-grid{
  gap: 12px !important;
}

.board-grid-three{
  grid-template-columns: 1.04fr 1.18fr .98fr !important;
  align-items: stretch !important;
}

.home-card,
.feature-card,
.wide-feature{
  border-radius: 17px !important;
  box-shadow: 0 10px 24px rgba(9,35,74,.09) !important;
}

.event-card{
  padding: 12px !important;
  gap: 12px !important;
  grid-template-columns: 74px 150px minmax(0,1fr) !important;
}

.date-box{
  border-radius: 13px !important;
}

.date-box strong{
  font-size: 34px !important;
}

.date-box span{
  font-size: 11px !important;
}

.event-card img{
  min-height: 145px !important;
  border-radius: 14px !important;
}

.card-copy h3{
  font-size: clamp(18px, 1.25vw, 22px) !important;
}

.card-copy p{
  margin: 8px 0 10px !important;
  font-size: 14px !important;
}

.card-copy a,
.feature-card a{
  padding: 8px 14px !important;
  font-size: 12px !important;
}

.regions-card,
.feed-card{
  padding: 14px !important;
}

.card-title-line{
  margin-bottom: 10px !important;
}

.card-title-line h3{
  font-size: clamp(20px, 1.35vw, 24px) !important;
}

.region-list{
  gap: 9px !important;
}

.region-mini{
  min-height: 150px !important;
  border-radius: 14px !important;
}

.region-mini span{
  font-size: 12px !important;
  padding: 10px !important;
}

.feed-row{
  padding: 8px 0 !important;
  gap: 10px !important;
  grid-template-columns: 32px minmax(0,1fr) 68px !important;
}

.feed-dot{
  width: 32px !important;
  height: 32px !important;
}

.feed-row p{
  font-size: 13px !important;
  line-height: 1.35 !important;
}

.feed-row img{
  width: 68px !important;
  height: 52px !important;
  border-radius: 10px !important;
}

.feature-card{
  min-height: 205px !important;
  grid-template-columns: minmax(0,1fr) minmax(145px,.88fr) !important;
}

.feature-copy{
  padding: 18px !important;
}

.feature-icon{
  width: 40px !important;
  height: 40px !important;
  border-radius: 13px !important;
  font-size: 21px !important;
  margin-bottom: 10px !important;
}

.feature-card h3{
  font-size: clamp(20px, 1.45vw, 26px) !important;
}

.feature-card p{
  font-size: 14px !important;
  margin: 8px 0 12px !important;
}

.feature-card img{
  min-height: 205px !important;
}

.wide-feature{
  min-height: 130px !important;
  padding: 14px !important;
  gap: 14px !important;
  grid-template-columns: 52px minmax(0,1fr) minmax(165px,34%) !important;
}

.wide-feature h3{
  font-size: clamp(20px, 1.35vw, 25px) !important;
}

.wide-feature p{
  font-size: 14px !important;
  margin: 7px 0 0 !important;
}

.wide-feature img{
  height: 100px !important;
  border-radius: 14px !important;
}

.site-footer{
  margin-top: 8px !important;
}

/* Responsive body uniquement */
@media(max-width:1360px){
  .board-grid-three{
    grid-template-columns: 1fr 1fr !important;
  }

  .feed-card{
    grid-column: 1 / -1 !important;
  }
}

@media(max-width:980px){
  .board-grid-three,
  .feature-grid,
  .partner-grid{
    grid-template-columns: 1fr !important;
  }

  .event-card,
  .feature-card,
  .wide-feature{
    grid-template-columns: 1fr !important;
  }

  .event-card img,
  .feature-card img{
    height: 190px !important;
    min-height: 190px !important;
  }

  .wide-feature img{
    height: 150px !important;
  }
}

@media(max-width:560px){
  .content-board,
  .feature-grid,
  .partner-grid{
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .event-card{
    padding: 12px !important;
  }

  .region-list{
    grid-template-columns: 1fr !important;
  }

  .feed-row{
    grid-template-columns: 32px minmax(0,1fr) !important;
  }

  .feed-row img{
    display: none !important;
  }
}

/* === BODY BELGIQUE-LABRADOR V15 SPACING - FIN === */

/* === BODY BELGIQUE-LABRADOR V20 V14 COMPACT - DEBUT === */
/* ACCUEIL BODY UNIQUEMENT : ne touche pas header, hero, logo, autres pages. */

.home-page .home-body-v14{
  width: min(1320px, calc(100% - 34px)) !important;
  margin: 0 auto !important;
  padding: 10px 0 14px !important;
}

/* Bloc principal : événements / régions / fil du club */
.home-page .home-body-v14 .v14-board{
  display: grid !important;
  grid-template-columns: 1.02fr 1.2fr .92fr !important;
  gap: 8px !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  align-items: stretch !important;
}

/* Ligne des 3 cartes */
.home-page .home-body-v14 .v14-focus-grid{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
}

/* Ligne marketplace / services */
.home-page .home-body-v14 .v14-partner-grid{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Cartes générales */
.home-page .home-body-v14 .v14-card,
.home-page .home-body-v14 .v14-feature,
.home-page .home-body-v14 .v14-wide{
  margin: 0 !important;
  border-radius: 15px !important;
  box-shadow: 0 8px 18px rgba(9,35,74,.08) !important;
}

/* Titres de cartes */
.home-page .home-body-v14 .v14-card-head{
  margin: 0 0 7px !important;
  padding: 0 !important;
}

.home-page .home-body-v14 .v14-card-head h2{
  margin: 0 !important;
  font-size: 21px !important;
  line-height: 1.08 !important;
}

/* Cartes hautes */
.home-page .home-body-v14 .v14-events,
.home-page .home-body-v14 .v14-regions,
.home-page .home-body-v14 .v14-feed{
  padding: 10px !important;
}

/* Événements */
.home-page .home-body-v14 .v14-event-list{
  display: grid !important;
  gap: 6px !important;
}

.home-page .home-body-v14 .v14-event-row{
  display: grid !important;
  grid-template-columns: 54px minmax(0,1fr) 74px !important;
  gap: 7px !important;
  align-items: center !important;
  min-height: 68px !important;
  padding: 6px !important;
  border-radius: 12px !important;
}

.home-page .home-body-v14 .v14-date{
  width: 54px !important;
  min-height: 54px !important;
  border-radius: 10px !important;
}

.home-page .home-body-v14 .v14-date strong{
  font-size: 25px !important;
  line-height: 1 !important;
}

.home-page .home-body-v14 .v14-date em{
  font-size: 9px !important;
  line-height: 1 !important;
}

.home-page .home-body-v14 .v14-event-copy strong{
  font-size: 14px !important;
  line-height: 1.12 !important;
}

.home-page .home-body-v14 .v14-event-copy small{
  font-size: 11px !important;
  line-height: 1.2 !important;
  margin-top: 3px !important;
}

.home-page .home-body-v14 .v14-event-row img{
  width: 74px !important;
  height: 54px !important;
  border-radius: 10px !important;
  object-fit: cover !important;
}

/* Régions */
.home-page .home-body-v14 .v14-region-list{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 7px !important;
}

.home-page .home-body-v14 .v14-region{
  min-height: 122px !important;
  border-radius: 12px !important;
  padding: 9px !important;
}

.home-page .home-body-v14 .v14-region img{
  height: 62px !important;
  border-radius: 10px !important;
}

.home-page .home-body-v14 .v14-region strong{
  font-size: 14px !important;
  line-height: 1.1 !important;
  margin-top: 5px !important;
}

.home-page .home-body-v14 .v14-region span{
  font-size: 11px !important;
  line-height: 1.2 !important;
  margin-top: 2px !important;
}

.home-page .home-body-v14 .v14-region em{
  font-size: 10px !important;
  margin-top: 3px !important;
}

/* Fil du club */
.home-page .home-body-v14 .v14-feed-list{
  display: grid !important;
  gap: 6px !important;
}

.home-page .home-body-v14 .v14-feed-row{
  display: grid !important;
  grid-template-columns: 28px minmax(0,1fr) 60px !important;
  gap: 7px !important;
  align-items: center !important;
  padding: 6px !important;
  border-radius: 12px !important;
  min-height: 62px !important;
}

.home-page .home-body-v14 .v14-avatar{
  width: 28px !important;
  height: 28px !important;
  font-size: 12px !important;
}

.home-page .home-body-v14 .v14-feed-row strong{
  font-size: 12.5px !important;
  line-height: 1.15 !important;
}

.home-page .home-body-v14 .v14-feed-row strong em{
  font-size: 10px !important;
}

.home-page .home-body-v14 .v14-feed-row small{
  font-size: 11px !important;
  line-height: 1.22 !important;
  margin-top: 2px !important;
}

.home-page .home-body-v14 .v14-feed-row img{
  width: 60px !important;
  height: 46px !important;
  border-radius: 9px !important;
  object-fit: cover !important;
}

/* Liens de bas de carte */
.home-page .home-body-v14 .v14-link{
  margin-top: 7px !important;
  padding: 7px 10px !important;
  font-size: 11px !important;
  border-radius: 999px !important;
}

/* Cartes focus */
.home-page .home-body-v14 .v14-feature{
  display: grid !important;
  grid-template-columns: minmax(0,1fr) 42% !important;
  min-height: 184px !important;
  overflow: hidden !important;
}

.home-page .home-body-v14 .v14-feature-copy{
  padding: 14px !important;
}

.home-page .home-body-v14 .v14-icon{
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  border-radius: 11px !important;
  font-size: 18px !important;
  margin-bottom: 8px !important;
}

.home-page .home-body-v14 .v14-feature h3{
  font-size: 21px !important;
  line-height: 1.08 !important;
  margin: 0 0 6px !important;
}

.home-page .home-body-v14 .v14-feature p{
  font-size: 13px !important;
  line-height: 1.34 !important;
  margin: 0 0 9px !important;
}

.home-page .home-body-v14 .v14-feature a{
  padding: 7px 12px !important;
  font-size: 11px !important;
  border-radius: 999px !important;
}

.home-page .home-body-v14 .v14-feature > img{
  height: 100% !important;
  min-height: 184px !important;
  object-fit: cover !important;
}

/* Cartes larges partenaires */
.home-page .home-body-v14 .v14-wide{
  display: grid !important;
  grid-template-columns: 42px minmax(0,1fr) 34% !important;
  gap: 10px !important;
  align-items: center !important;
  min-height: 112px !important;
  padding: 10px !important;
}

.home-page .home-body-v14 .v14-wide .v14-icon{
  margin: 0 !important;
}

.home-page .home-body-v14 .v14-wide h3{
  font-size: 21px !important;
  line-height: 1.08 !important;
  margin: 0 0 5px !important;
}

.home-page .home-body-v14 .v14-wide p{
  font-size: 13px !important;
  line-height: 1.3 !important;
  margin: 0 0 6px !important;
}

.home-page .home-body-v14 .v14-wide a{
  font-size: 11px !important;
}

.home-page .home-body-v14 .v14-wide img{
  width: 100% !important;
  height: 84px !important;
  border-radius: 11px !important;
  object-fit: cover !important;
}

/* Responsive accueil uniquement */
@media(max-width:1200px){
  .home-page .home-body-v14 .v14-board{
    grid-template-columns: 1fr 1fr !important;
  }

  .home-page .home-body-v14 .v14-feed{
    grid-column: 1 / -1 !important;
  }

  .home-page .home-body-v14 .v14-focus-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media(max-width:820px){
  .home-page .home-body-v14{
    width: calc(100% - 20px) !important;
  }

  .home-page .home-body-v14 .v14-board,
  .home-page .home-body-v14 .v14-focus-grid,
  .home-page .home-body-v14 .v14-partner-grid{
    grid-template-columns: 1fr !important;
  }

  .home-page .home-body-v14 .v14-feature,
  .home-page .home-body-v14 .v14-wide{
    grid-template-columns: 1fr !important;
  }

  .home-page .home-body-v14 .v14-feature > img,
  .home-page .home-body-v14 .v14-wide img{
    height: 170px !important;
    min-height: 170px !important;
  }
}

@media(max-width:520px){
  .home-page .home-body-v14{
    width: calc(100% - 14px) !important;
    padding-top: 7px !important;
  }

  .home-page .home-body-v14 .v14-event-row,
  .home-page .home-body-v14 .v14-feed-row{
    grid-template-columns: 44px minmax(0,1fr) !important;
  }

  .home-page .home-body-v14 .v14-event-row img,
  .home-page .home-body-v14 .v14-feed-row img{
    display: none !important;
  }

  .home-page .home-body-v14 .v14-region-list{
    grid-template-columns: 1fr !important;
  }
}

/* === BODY BELGIQUE-LABRADOR V20 V14 COMPACT - FIN === */

/* === BODY BELGIQUE-LABRADOR V21 LARGEUR FOOTER GRATUIT - DEBUT === */
/* Ajustement léger : largeur body + footer. Hero/logo/image non touchés. */

/* Le body V14 utilise quasiment toute la largeur de la page blanche. */
.home-page .home-body-v14{
  width: calc(100% - 14px) !important;
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Les grilles respirent mais ne flottent plus au milieu avec trop de marge. */
.home-page .home-body-v14 .v14-board,
.home-page .home-body-v14 .v14-focus-grid,
.home-page .home-body-v14 .v14-partner-grid{
  width: 100% !important;
}

/* Première ligne mieux proportionnée sur grande largeur. */
.home-page .home-body-v14 .v14-board{
  grid-template-columns: 1.08fr 1.28fr 1fr !important;
}

/* Les cartes du bas prennent mieux la largeur aussi. */
.home-page .home-body-v14 .v14-focus-grid{
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.home-page .home-body-v14 .v14-partner-grid{
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

/* Footer pleine largeur, plus propre pour une vraie fin de page. */
.site-footer{
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  border-left: 0 !important;
  border-right: 0 !important;
  border-radius: 0 !important;
  padding-left: clamp(18px, 4vw, 64px) !important;
  padding-right: clamp(18px, 4vw, 64px) !important;
}

/* Le bouton header peut être un peu plus long maintenant. */
.join-button-top{
  padding-left: 16px !important;
  padding-right: 16px !important;
  font-size: 13px !important;
}

/* Responsive : on garde le comportement V20. */
@media(max-width:1200px){
  .home-page .home-body-v14 .v14-board{
    grid-template-columns: 1fr 1fr !important;
  }
}

@media(max-width:820px){
  .home-page .home-body-v14{
    width: calc(100% - 16px) !important;
  }

  .home-page .home-body-v14 .v14-board,
  .home-page .home-body-v14 .v14-focus-grid,
  .home-page .home-body-v14 .v14-partner-grid{
    grid-template-columns: 1fr !important;
  }

  .site-footer{
    flex-wrap: wrap !important;
    justify-content: center !important;
    text-align: center !important;
  }
}

/* === BODY BELGIQUE-LABRADOR V21 LARGEUR FOOTER GRATUIT - FIN === */

/* === FOOTER BELGIQUE-LABRADOR V22 PREMIUM - DEBUT === */
/* Footer premium uniquement. Header, hero, logo et body non touchés. */

.site-footer.premium-footer{
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  display: block !important;
  background:
    radial-gradient(circle at 8% 0%, rgba(235,153,33,.16), transparent 32%),
    radial-gradient(circle at 92% 20%, rgba(52,114,31,.18), transparent 34%),
    linear-gradient(135deg, #061f44 0%, #082b5c 48%, #0f3d73 100%) !important;
  color: #fff !important;
  overflow: hidden !important;
}

.premium-footer-inner{
  width: min(1380px, calc(100% - 48px));
  margin: 0 auto;
  padding: 42px 0 32px;
  display: grid;
  grid-template-columns: minmax(260px, 1.35fr) minmax(160px, .7fr) minmax(170px, .75fr) minmax(260px, 1fr);
  gap: clamp(24px, 3vw, 54px);
  align-items: start;
}

.footer-brand-block strong{
  display: block;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(30px, 3vw, 46px);
  line-height: .95;
  letter-spacing: -.04em;
  color: #fff;
}

.footer-brand-block p{
  max-width: 420px;
  margin: 14px 0 18px;
  color: rgba(255,255,255,.78);
  font-size: 15px;
  line-height: 1.55;
}

.footer-pill{
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  padding: 10px 14px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.86);
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .01em;
}

.footer-column h3{
  margin: 4px 0 15px;
  color: #f2b34b;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 950;
}

.footer-column a{
  display: table;
  margin: 0 0 10px;
  color: rgba(255,255,255,.82) !important;
  text-decoration: none !important;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.25;
  transition: color .18s ease, transform .18s ease;
}

.footer-column a:hover{
  color: #fff !important;
  transform: translateX(3px);
}

.footer-contact p{
  margin: 0 0 16px;
  color: rgba(255,255,255,.76);
  font-size: 14px;
  line-height: 1.55;
}

.footer-socials{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.footer-socials span{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.16);
  color: rgba(255,255,255,.86);
  font-size: 12px;
  font-weight: 900;
}

.premium-footer-bottom{
  border-top: 1px solid rgba(255,255,255,.12);
  width: min(1380px, calc(100% - 48px));
  margin: 0 auto;
  padding: 16px 0 20px;
  display: flex;
  justify-content: space-between;
  gap: 18px;
  color: rgba(255,255,255,.62);
  font-size: 12px;
  font-weight: 750;
}

@media(max-width:980px){
  .premium-footer-inner{
    grid-template-columns: 1fr 1fr;
    width: calc(100% - 32px);
    padding-top: 34px;
  }

  .premium-footer-bottom{
    width: calc(100% - 32px);
    flex-direction: column;
    gap: 6px;
  }
}

@media(max-width:620px){
  .premium-footer-inner{
    grid-template-columns: 1fr;
  }

  .footer-brand-block strong{
    font-size: 34px;
  }
}

/* === FOOTER BELGIQUE-LABRADOR V22 PREMIUM - FIN === */

/* === BODY BELGIQUE-LABRADOR V23 PREMIUM - DEBUT === */
/* Body premium uniquement. Header, hero, logo et footer non touchés. */

.home-page .home-body-v14{
  width: calc(100% - 18px) !important;
  max-width: none !important;
  margin: 0 auto !important;
  padding: 12px 0 16px !important;
  background:
    linear-gradient(180deg, rgba(248,251,245,.96), rgba(255,255,255,1)) !important;
}

/* Grille principale premium */
.home-page .home-body-v14 .v14-board{
  display: grid !important;
  grid-template-columns: 1.08fr 1.26fr 1fr !important;
  gap: 12px !important;
  margin: 0 0 12px !important;
  padding: 0 !important;
  align-items: stretch !important;
}

.home-page .home-body-v14 .v14-focus-grid{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin: 0 0 12px !important;
  padding: 0 !important;
}

.home-page .home-body-v14 .v14-partner-grid{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Cartes premium */
.home-page .home-body-v14 .v14-card,
.home-page .home-body-v14 .v14-feature,
.home-page .home-body-v14 .v14-wide{
  position: relative !important;
  overflow: hidden !important;
  border-radius: 20px !important;
  border: 1px solid rgba(9,35,74,.10) !important;
  background: rgba(255,255,255,.98) !important;
  box-shadow: 0 14px 34px rgba(9,35,74,.10) !important;
}

.home-page .home-body-v14 .v14-card::before,
.home-page .home-body-v14 .v14-feature::before,
.home-page .home-body-v14 .v14-wide::before{
  content: "" !important;
  position: absolute !important;
  inset: 0 0 auto 0 !important;
  height: 4px !important;
  background: linear-gradient(90deg, #34721f, #1273c4, #e89412) !important;
  opacity: .9 !important;
  pointer-events: none !important;
}

/* En-têtes de cartes */
.home-page .home-body-v14 .v14-card-head{
  margin: 0 0 12px !important;
  padding: 0 0 10px !important;
  border-bottom: 1px solid rgba(9,35,74,.08) !important;
}

.home-page .home-body-v14 .v14-card-head h2{
  margin: 0 !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: clamp(22px, 1.45vw, 28px) !important;
  line-height: 1.08 !important;
  color: #082957 !important;
  letter-spacing: -.03em !important;
}

/* Cartes hautes */
.home-page .home-body-v14 .v14-events,
.home-page .home-body-v14 .v14-regions,
.home-page .home-body-v14 .v14-feed{
  padding: 18px !important;
}

/* Événements premium */
.home-page .home-body-v14 .v14-event-list{
  display: grid !important;
  gap: 10px !important;
}

.home-page .home-body-v14 .v14-event-row{
  display: grid !important;
  grid-template-columns: 60px minmax(0,1fr) 86px !important;
  gap: 11px !important;
  align-items: center !important;
  min-height: 78px !important;
  padding: 10px !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, #f7faf4, #ffffff) !important;
  border: 1px solid rgba(9,35,74,.08) !important;
  text-decoration: none !important;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease !important;
}

.home-page .home-body-v14 .v14-event-row:hover{
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 24px rgba(9,35,74,.10) !important;
  border-color: rgba(18,115,196,.20) !important;
}

.home-page .home-body-v14 .v14-date{
  width: 60px !important;
  min-height: 60px !important;
  border-radius: 15px !important;
  background: linear-gradient(135deg, #082957, #123f82) !important;
  color: #fff !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
  box-shadow: 0 8px 18px rgba(8,41,87,.20) !important;
}

.home-page .home-body-v14 .v14-date strong{
  display: block !important;
  font-size: 27px !important;
  line-height: .9 !important;
  color: #fff !important;
}

.home-page .home-body-v14 .v14-date em{
  display: block !important;
  margin-top: 3px !important;
  font-style: normal !important;
  font-size: 10px !important;
  font-weight: 950 !important;
  letter-spacing: .08em !important;
  color: rgba(255,255,255,.82) !important;
}

.home-page .home-body-v14 .v14-event-copy strong{
  display: block !important;
  font-size: 15px !important;
  line-height: 1.15 !important;
  color: #082957 !important;
}

.home-page .home-body-v14 .v14-event-copy small{
  display: block !important;
  margin-top: 5px !important;
  font-size: 12px !important;
  line-height: 1.28 !important;
  color: #52657d !important;
}

.home-page .home-body-v14 .v14-event-copy b{
  color: #34721f !important;
  font-weight: 950 !important;
}

.home-page .home-body-v14 .v14-event-row img{
  width: 86px !important;
  height: 62px !important;
  border-radius: 14px !important;
  object-fit: cover !important;
}

/* Régions premium */
.home-page .home-body-v14 .v14-region-list{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.home-page .home-body-v14 .v14-region{
  position: relative !important;
  min-height: 150px !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  padding: 0 !important;
  text-decoration: none !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  background: #082957 !important;
  border: 1px solid rgba(9,35,74,.08) !important;
}

.home-page .home-body-v14 .v14-region img{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  opacity: .88 !important;
  transform: scale(1.01) !important;
  transition: transform .22s ease !important;
}

.home-page .home-body-v14 .v14-region:hover img{
  transform: scale(1.06) !important;
}

.home-page .home-body-v14 .v14-region::after{
  content: "" !important;
  position: absolute !important;
  inset: 28% 0 0 !important;
  background: linear-gradient(0deg, rgba(5,24,55,.88), rgba(5,24,55,.05)) !important;
}

.home-page .home-body-v14 .v14-region strong,
.home-page .home-body-v14 .v14-region span,
.home-page .home-body-v14 .v14-region em{
  position: relative !important;
  z-index: 2 !important;
  padding-left: 13px !important;
  padding-right: 13px !important;
}

.home-page .home-body-v14 .v14-region strong{
  color: #fff !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 19px !important;
  line-height: 1.05 !important;
  margin: 0 0 4px !important;
}

.home-page .home-body-v14 .v14-region span{
  color: rgba(255,255,255,.84) !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
}

.home-page .home-body-v14 .v14-region em{
  color: #f2b34b !important;
  font-size: 11px !important;
  font-style: normal !important;
  font-weight: 950 !important;
  margin: 7px 0 12px !important;
}

/* Fil du club premium */
.home-page .home-body-v14 .v14-feed-list{
  display: grid !important;
  gap: 10px !important;
}

.home-page .home-body-v14 .v14-feed-row{
  display: grid !important;
  grid-template-columns: 34px minmax(0,1fr) 72px !important;
  gap: 10px !important;
  align-items: center !important;
  padding: 10px !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, #f8faf6, #fff) !important;
  border: 1px solid rgba(9,35,74,.08) !important;
  text-decoration: none !important;
  transition: transform .18s ease, box-shadow .18s ease !important;
}

.home-page .home-body-v14 .v14-feed-row:hover{
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 24px rgba(9,35,74,.10) !important;
}

.home-page .home-body-v14 .v14-avatar{
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  display: grid !important;
  place-items: center !important;
  background: linear-gradient(135deg, #34721f, #1d5a12) !important;
  color: #fff !important;
  font-weight: 950 !important;
  font-size: 13px !important;
}

.home-page .home-body-v14 .v14-feed-row strong{
  display: block !important;
  color: #082957 !important;
  font-size: 13px !important;
  line-height: 1.15 !important;
}

.home-page .home-body-v14 .v14-feed-row strong em{
  color: #8290a3 !important;
  font-size: 10px !important;
  font-style: normal !important;
  font-weight: 800 !important;
}

.home-page .home-body-v14 .v14-feed-row small{
  display: block !important;
  margin-top: 3px !important;
  color: #52657d !important;
  font-size: 11.5px !important;
  line-height: 1.25 !important;
}

.home-page .home-body-v14 .v14-feed-row img{
  width: 72px !important;
  height: 54px !important;
  object-fit: cover !important;
  border-radius: 12px !important;
}

/* Liens de cartes */
.home-page .home-body-v14 .v14-link{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: 12px !important;
  padding: 9px 14px !important;
  border-radius: 999px !important;
  background: #082957 !important;
  color: #fff !important;
  text-decoration: none !important;
  font-size: 12px !important;
  font-weight: 950 !important;
}

/* Cartes focus premium */
.home-page .home-body-v14 .v14-feature{
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 43% !important;
  min-height: 220px !important;
  background: #fff !important;
}

.home-page .home-body-v14 .v14-feature-copy{
  padding: 22px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: center !important;
}

.home-page .home-body-v14 .v14-icon{
  width: auto !important;
  min-width: 0 !important;
  height: auto !important;
  padding: 7px 10px !important;
  border-radius: 999px !important;
  background: rgba(18,115,196,.10) !important;
  color: #082957 !important;
  font-size: 10px !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  letter-spacing: .12em !important;
  font-weight: 950 !important;
  margin-bottom: 13px !important;
}

.home-page .home-body-v14 .v14-green .v14-icon{
  background: rgba(52,114,31,.12) !important;
  color: #1d5a12 !important;
}

.home-page .home-body-v14 .v14-orange .v14-icon{
  background: rgba(232,148,18,.14) !important;
  color: #9f5b00 !important;
}

.home-page .home-body-v14 .v14-blue .v14-icon{
  background: rgba(18,115,196,.12) !important;
  color: #0f4f90 !important;
}

.home-page .home-body-v14 .v14-feature h3,
.home-page .home-body-v14 .v14-wide h3{
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: clamp(23px, 1.7vw, 31px) !important;
  line-height: 1.05 !important;
  margin: 0 0 9px !important;
  color: #082957 !important;
  letter-spacing: -.03em !important;
}

.home-page .home-body-v14 .v14-feature p,
.home-page .home-body-v14 .v14-wide p{
  color: #52657d !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
  margin: 0 0 14px !important;
}

.home-page .home-body-v14 .v14-feature a,
.home-page .home-body-v14 .v14-wide a{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 9px 14px !important;
  border-radius: 999px !important;
  background: #082957 !important;
  color: #fff !important;
  text-decoration: none !important;
  font-size: 12px !important;
  font-weight: 950 !important;
}

.home-page .home-body-v14 .v14-feature > img{
  width: 100% !important;
  height: 100% !important;
  min-height: 220px !important;
  object-fit: cover !important;
}

/* Passerelles premium */
.home-page .home-body-v14 .v14-wide{
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 36% !important;
  gap: 18px !important;
  align-items: center !important;
  min-height: 155px !important;
  padding: 20px !important;
}

.home-page .home-body-v14 .v14-wide > .v14-icon{
  display: none !important;
}

.home-page .home-body-v14 .v14-wide img{
  width: 100% !important;
  height: 118px !important;
  border-radius: 16px !important;
  object-fit: cover !important;
}

/* Responsive body premium */
@media(max-width:1200px){
  .home-page .home-body-v14 .v14-board{
    grid-template-columns: 1fr 1fr !important;
  }

  .home-page .home-body-v14 .v14-feed{
    grid-column: 1 / -1 !important;
  }

  .home-page .home-body-v14 .v14-focus-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media(max-width:820px){
  .home-page .home-body-v14{
    width: calc(100% - 18px) !important;
  }

  .home-page .home-body-v14 .v14-board,
  .home-page .home-body-v14 .v14-focus-grid,
  .home-page .home-body-v14 .v14-partner-grid{
    grid-template-columns: 1fr !important;
  }

  .home-page .home-body-v14 .v14-feature,
  .home-page .home-body-v14 .v14-wide{
    grid-template-columns: 1fr !important;
  }

  .home-page .home-body-v14 .v14-feature > img,
  .home-page .home-body-v14 .v14-wide img{
    height: 180px !important;
    min-height: 180px !important;
  }
}

@media(max-width:520px){
  .home-page .home-body-v14{
    width: calc(100% - 12px) !important;
  }

  .home-page .home-body-v14 .v14-event-row,
  .home-page .home-body-v14 .v14-feed-row{
    grid-template-columns: 54px minmax(0,1fr) !important;
  }

  .home-page .home-body-v14 .v14-event-row img,
  .home-page .home-body-v14 .v14-feed-row img{
    display: none !important;
  }

  .home-page .home-body-v14 .v14-region-list{
    grid-template-columns: 1fr !important;
  }
}

/* === BODY BELGIQUE-LABRADOR V23 PREMIUM - FIN === */

/* === BODY BELGIQUE-LABRADOR V24 CARTES SANS BANDE - DEBUT === */
/* Accueil body uniquement : enlève la bande couleur des cartes + adoucit le rendu. */

/* Supprime la bande colorée ajoutée en haut des cartes premium */
.home-page .home-body-v14 .v14-card::before,
.home-page .home-body-v14 .v14-feature::before,
.home-page .home-body-v14 .v14-wide::before{
  display: none !important;
  content: none !important;
}

/* Cartes plus douces, légèrement translucides */
.home-page .home-body-v14 .v14-card,
.home-page .home-body-v14 .v14-feature,
.home-page .home-body-v14 .v14-wide{
  background: rgba(255,255,255,.92) !important;
  border: 1px solid rgba(9,35,74,.085) !important;
  box-shadow: 0 12px 28px rgba(9,35,74,.075) !important;
  backdrop-filter: blur(6px) !important;
}

/* Titres plus propres sans effet "pancarte" */
.home-page .home-body-v14 .v14-card-head{
  border-bottom: 1px solid rgba(9,35,74,.055) !important;
}

/* Photos des clubs régionaux : plus nettes, moins assombries */
.home-page .home-body-v14 .v14-region img{
  opacity: 1 !important;
  filter: saturate(1.08) contrast(1.04) brightness(1.02) !important;
  transform: scale(1.02) !important;
}

/* Dégradé un peu moins lourd pour mieux voir les photos */
.home-page .home-body-v14 .v14-region::after{
  inset: 38% 0 0 !important;
  background: linear-gradient(0deg, rgba(5,24,55,.76), rgba(5,24,55,0)) !important;
}

/* Petit mouvement propre au survol : ça vit sans faire kermesse */
.home-page .home-body-v14 .v14-region{
  transition: transform .22s ease, box-shadow .22s ease !important;
}

.home-page .home-body-v14 .v14-region:hover{
  transform: translateY(-3px) !important;
  box-shadow: 0 14px 28px rgba(9,35,74,.14) !important;
}

.home-page .home-body-v14 .v14-region:hover img{
  transform: scale(1.08) !important;
}

/* Même logique légère sur les cartes événements/fil */
.home-page .home-body-v14 .v14-event-row,
.home-page .home-body-v14 .v14-feed-row{
  background: rgba(255,255,255,.88) !important;
}

/* === BODY BELGIQUE-LABRADOR V24 CARTES SANS BANDE - FIN === */

/* === HEADER BELGIQUE-LABRADOR V25 LOGO BUTTON - DEBUT === */
/* Ajustement léger logo + bouton header. Hero/body/footer non touchés. */

.brand-logo-img{
  width: clamp(62px, 5vw, 86px) !important;
  height: auto !important;
  object-fit: contain !important;
}

.site-brand{
  gap: 10px !important;
}

.join-button-top{
  font-size: 12px !important;
  line-height: 1.05 !important;
  padding: 11px 14px !important;
  border-radius: 999px !important;
  white-space: nowrap !important;
  box-shadow: 0 10px 22px rgba(232,148,18,.22) !important;
}

@media(max-width:980px){
  .join-button-top{
    font-size: 11px !important;
    padding: 10px 12px !important;
  }
}

/* === HEADER BELGIQUE-LABRADOR V25 LOGO BUTTON - FIN === */

/* === LOGO FAVICON BELGIQUE-LABRADOR V26 - DEBUT === */
/* Logo + favicon uniquement. Body, hero et footer non touchés. */

.site-brand{
  display: flex !important;
  align-items: center !important;
  min-width: 0 !important;
}

.brand-logo-img.brand-logo-full{
  display: block !important;
  width: clamp(230px, 20vw, 330px) !important;
  max-width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
}

@media(max-width:1200px){
  .brand-logo-img.brand-logo-full{
    width: clamp(210px, 28vw, 300px) !important;
  }
}

@media(max-width:700px){
  .brand-logo-img.brand-logo-full{
    width: 220px !important;
  }
}

/* === LOGO FAVICON BELGIQUE-LABRADOR V26 - FIN === */

/* === LOGO ICON BELGIQUE-LABRADOR V27 - DEBUT === */
/* Logo rond seul à gauche + texte existant à droite. */

.site-brand{
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  min-width: 260px !important;
  text-decoration: none !important;
}

.brand-logo-img{
  display: block !important;
  width: 74px !important;
  height: 74px !important;
  min-width: 74px !important;
  object-fit: contain !important;
}

.brand-logo-img.brand-logo-full{
  width: 74px !important;
  height: 74px !important;
  min-width: 74px !important;
}

.brand-copy{
  display: block !important;
}

.brand-copy strong{
  display: block !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 27px !important;
  line-height: .95 !important;
  color: #082957 !important;
  white-space: nowrap !important;
}

.brand-copy small{
  display: block !important;
  margin-top: 5px !important;
  font-size: 12px !important;
  color: #526782 !important;
  white-space: nowrap !important;
}

@media(max-width:1200px){
  .brand-logo-img,
  .brand-logo-img.brand-logo-full{
    width: 64px !important;
    height: 64px !important;
    min-width: 64px !important;
  }

  .brand-copy strong{
    font-size: 23px !important;
  }
}

@media(max-width:700px){
  .site-brand{
    min-width: 0 !important;
  }

  .brand-logo-img,
  .brand-logo-img.brand-logo-full{
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
  }

  .brand-copy strong{
    font-size: 20px !important;
  }

  .brand-copy small{
    font-size: 10px !important;
  }
}

/* === LOGO ICON BELGIQUE-LABRADOR V27 - FIN === */

/* === LOGO FINAL BELGIQUE-LABRADOR IMAGE - DEBUT === */

.site-brand{
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  min-width: 280px !important;
  text-decoration: none !important;
}

.brand-logo-img{
  display: block !important;
  width: 82px !important;
  height: 82px !important;
  min-width: 82px !important;
  object-fit: contain !important;
  object-position: center !important;
}

.brand-copy{
  display: block !important;
}

.brand-copy strong{
  display: block !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 27px !important;
  line-height: .95 !important;
  color: #082957 !important;
  white-space: nowrap !important;
}

.brand-copy small{
  display: block !important;
  margin-top: 5px !important;
  font-size: 12px !important;
  color: #526782 !important;
  white-space: nowrap !important;
}

@media(max-width:1200px){
  .brand-logo-img{
    width: 68px !important;
    height: 68px !important;
    min-width: 68px !important;
  }

  .brand-copy strong{
    font-size: 23px !important;
  }
}

@media(max-width:700px){
  .site-brand{
    min-width: 0 !important;
  }

  .brand-logo-img{
    width: 58px !important;
    height: 58px !important;
    min-width: 58px !important;
  }

  .brand-copy strong{
    font-size: 20px !important;
  }

  .brand-copy small{
    font-size: 10px !important;
  }
}

/* === LOGO FINAL BELGIQUE-LABRADOR IMAGE - FIN === */

/* === BODY BELGIQUE-LABRADOR V15 PREMIUM - DEBUT ===
   Zone volontairement limitée : accueil sous le hero + pages internes + footer.
   Interdit ici : header, logo, menu, hero, image du haut.
   Objectif : rendu plus premium, proche de la maquette de départ, avec vrais blocs HTML/CSS.
*/

.home-page{
  background:
    radial-gradient(circle at 12% 4%, rgba(232,148,18,.10), transparent 26%),
    radial-gradient(circle at 84% 7%, rgba(52,114,31,.09), transparent 28%),
    linear-gradient(180deg,#ffffff 0%, #fbfcf7 46%, #eef5ea 100%) !important;
}

.content-board,
.feature-grid,
.partner-grid{
  width:100% !important;
  max-width:1320px !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

.content-board{
  padding:clamp(28px,3vw,46px) clamp(18px,3vw,42px) clamp(22px,2.6vw,38px) !important;
  position:relative !important;
}

.content-board::before{
  content:"" !important;
  display:block !important;
  height:1px !important;
  width:100% !important;
  margin:0 0 clamp(22px,2vw,30px) !important;
  background:linear-gradient(90deg, transparent, rgba(9,35,74,.16), transparent) !important;
}

.section-top{
  display:flex !important;
  align-items:flex-end !important;
  justify-content:space-between !important;
  gap:18px !important;
  margin-bottom:clamp(18px,2vw,26px) !important;
}

.section-top h2{
  margin:0 !important;
  color:#082957 !important;
  font-family:Georgia,"Times New Roman",serif !important;
  font-size:clamp(28px,2.2vw,38px) !important;
  line-height:1 !important;
  letter-spacing:-.03em !important;
}

.section-top a,
.card-title-line a{
  color:#123f82 !important;
  background:#eef5ff !important;
  border:1px solid rgba(18,63,130,.12) !important;
  border-radius:999px !important;
  padding:10px 15px !important;
  font-size:11px !important;
  font-weight:950 !important;
  text-decoration:none !important;
  text-transform:uppercase !important;
  white-space:nowrap !important;
}

.board-grid{
  display:grid !important;
  gap:clamp(18px,2vw,26px) !important;
}

.board-grid-three{
  grid-template-columns:minmax(450px,1.18fr) minmax(430px,1.08fr) minmax(300px,.74fr) !important;
  align-items:stretch !important;
}

.home-card,
.feature-card,
.wide-feature,
.internal-card{
  position:relative !important;
  overflow:hidden !important;
  background:rgba(255,255,255,.96) !important;
  border:1px solid rgba(9,35,74,.10) !important;
  border-radius:26px !important;
  box-shadow:0 18px 42px rgba(9,35,74,.10) !important;
}

.home-card::before,
.feature-card::before,
.wide-feature::before{
  content:"" !important;
  position:absolute !important;
  inset:0 0 auto 0 !important;
  height:5px !important;
  background:linear-gradient(90deg,#123f82,#34721f,#e89412) !important;
  opacity:.88 !important;
  z-index:2 !important;
}

.home-card:hover,
.feature-card:hover,
.wide-feature:hover{
  transform:translateY(-2px) !important;
  box-shadow:0 24px 56px rgba(9,35,74,.14) !important;
  transition:transform .18s ease, box-shadow .18s ease !important;
}

.event-card{
  display:grid !important;
  grid-template-columns:96px minmax(170px,210px) minmax(0,1fr) !important;
  gap:18px !important;
  align-items:stretch !important;
  padding:20px !important;
  min-height:252px !important;
}

.date-box{
  border-radius:22px !important;
  border:1px solid rgba(232,148,18,.22) !important;
  background:linear-gradient(180deg,#fff8e9,#fff) !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.82) !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:100% !important;
}

.date-box strong{
  color:#d47a00 !important;
  font-size:48px !important;
  line-height:.9 !important;
  letter-spacing:-.06em !important;
}

.date-box span{
  color:#082957 !important;
  font-size:12px !important;
  font-weight:950 !important;
  text-transform:uppercase !important;
  text-align:center !important;
  line-height:1.25 !important;
}

.event-card img{
  width:100% !important;
  height:100% !important;
  min-height:210px !important;
  border-radius:22px !important;
  object-fit:cover !important;
  box-shadow:0 12px 28px rgba(9,35,74,.13) !important;
}

.card-copy{
  min-width:0 !important;
  padding:4px 4px 4px 2px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
}

.tag{
  margin:0 0 8px !important;
  color:#34721f !important;
  font-size:12px !important;
  font-weight:950 !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
}

.card-copy h3,
.card-title-line h3,
.feature-card h3,
.wide-feature h3{
  color:#082957 !important;
  font-family:Georgia,"Times New Roman",serif !important;
  letter-spacing:-.025em !important;
}

.card-copy h3{
  margin:0 !important;
  font-size:clamp(23px,1.55vw,30px) !important;
  line-height:1.08 !important;
}

.card-copy p,
.feed-row p,
.feature-card p,
.wide-feature p,
.internal-card p{
  color:#485a72 !important;
  line-height:1.55 !important;
}

.card-copy p{
  margin:10px 0 16px !important;
  font-size:15px !important;
}

.card-copy a,
.feature-card a,
.simple-button{
  align-self:flex-start !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:42px !important;
  border-radius:999px !important;
  padding:11px 18px !important;
  background:linear-gradient(135deg,#123f82,#0b2c5f) !important;
  color:#fff !important;
  font-size:12px !important;
  font-weight:950 !important;
  text-decoration:none !important;
  text-transform:uppercase !important;
  box-shadow:0 12px 24px rgba(18,63,130,.22) !important;
}

.regions-card,
.feed-card{
  padding:22px !important;
}

.card-title-line{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:14px !important;
  margin-bottom:18px !important;
}

.card-title-line h3{
  margin:0 !important;
  font-size:clamp(24px,1.65vw,31px) !important;
  line-height:1.05 !important;
}

.region-list{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:12px !important;
}

.region-mini{
  position:relative !important;
  min-height:205px !important;
  border-radius:22px !important;
  overflow:hidden !important;
  background:#11243e !important;
  box-shadow:0 12px 24px rgba(9,35,74,.13) !important;
}

.region-mini img{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  transition:transform .22s ease !important;
}

.region-mini:hover img{transform:scale(1.045) !important;}

.region-mini::after{
  content:"" !important;
  position:absolute !important;
  inset:34% 0 0 !important;
  background:linear-gradient(0deg,rgba(0,16,38,.82),rgba(0,16,38,0)) !important;
}

.region-mini span{
  position:absolute !important;
  z-index:3 !important;
  left:12px !important;
  right:12px !important;
  bottom:12px !important;
  color:#fff !important;
  font-size:13px !important;
  font-weight:950 !important;
  line-height:1.14 !important;
  text-shadow:0 2px 10px rgba(0,0,0,.56) !important;
}

.feed-card{
  background:linear-gradient(180deg,#ffffff,#f7faf5) !important;
}

.feed-row{
  display:grid !important;
  grid-template-columns:38px minmax(0,1fr) 84px !important;
  gap:13px !important;
  align-items:center !important;
  padding:13px 0 !important;
  border-bottom:1px solid rgba(9,35,74,.08) !important;
}

.feed-row:last-child{border-bottom:0 !important;}

.feed-dot{
  width:38px !important;
  height:38px !important;
  border-radius:999px !important;
  background:linear-gradient(135deg,#e8f5e3,#dbe9ff) !important;
  border:1px solid rgba(9,35,74,.10) !important;
  box-shadow:inset 0 0 0 4px #fff !important;
}

.feed-row p{
  margin:0 !important;
  font-size:14px !important;
}

.feed-row img{
  width:84px !important;
  height:66px !important;
  border-radius:16px !important;
  object-fit:cover !important;
}

.feature-grid{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:clamp(18px,2vw,26px) !important;
  padding:clamp(18px,2vw,30px) clamp(18px,3vw,42px) clamp(24px,3vw,46px) !important;
}

.feature-card{
  display:grid !important;
  grid-template-columns:minmax(0,1.02fr) minmax(150px,.98fr) !important;
  min-height:278px !important;
  background:linear-gradient(135deg,#fff,#f7faf3) !important;
}

.feature-copy{
  padding:clamp(24px,2.2vw,34px) !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  justify-content:center !important;
}

.feature-icon{
  width:52px !important;
  height:52px !important;
  border-radius:18px !important;
  display:grid !important;
  place-items:center !important;
  font-size:25px !important;
  margin-bottom:15px !important;
  background:#f2f8ed !important;
  border:1px solid rgba(52,114,31,.20) !important;
}

.feature-card h3{
  margin:0 !important;
  font-size:clamp(25px,1.9vw,34px) !important;
  line-height:1.04 !important;
}

.feature-card p{
  margin:12px 0 17px !important;
  font-size:15px !important;
}

.feature-card img{
  width:100% !important;
  height:100% !important;
  min-height:278px !important;
  object-fit:cover !important;
}

.feature-card.green a{background:linear-gradient(135deg,#34721f,#1d5f18) !important;}
.feature-card.orange a{background:linear-gradient(135deg,#e89412,#c96f00) !important;}
.feature-card.blue a{background:linear-gradient(135deg,#123f82,#092957) !important;}

.partner-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:clamp(18px,2vw,26px) !important;
  padding:0 clamp(18px,3vw,42px) clamp(34px,3.4vw,58px) !important;
}

.wide-feature{
  display:grid !important;
  grid-template-columns:62px minmax(0,1fr) minmax(190px,40%) !important;
  gap:18px !important;
  align-items:center !important;
  min-height:176px !important;
  padding:22px !important;
  background:linear-gradient(135deg,#ffffff,#f6f9ff) !important;
}

.wide-feature .feature-icon{margin:0 !important;}
.wide-feature h3{margin:0 !important;font-size:clamp(23px,1.6vw,31px) !important;line-height:1.05 !important;}
.wide-feature p{margin:9px 0 0 !important;font-size:15px !important;}
.wide-feature img{width:100% !important;height:132px !important;border-radius:20px !important;object-fit:cover !important;}

.internal-page{
  width:min(1180px,calc(100% - 28px)) !important;
  margin:clamp(28px,4vw,56px) auto !important;
}

.internal-card{
  padding:clamp(34px,4vw,62px) !important;
  background:
    radial-gradient(circle at 90% 12%, rgba(52,114,31,.10), transparent 26%),
    linear-gradient(135deg,#ffffff,#f8fbf5) !important;
}

.internal-card h1{
  color:#082957 !important;
  font-family:Georgia,"Times New Roman",serif !important;
  font-size:clamp(38px,5vw,68px) !important;
  line-height:1 !important;
  letter-spacing:-.04em !important;
}

.site-footer{
  max-width:1320px !important;
  background:rgba(255,255,255,.96) !important;
  border:1px solid rgba(9,35,74,.10) !important;
  border-radius:24px !important;
  box-shadow:0 18px 42px rgba(9,35,74,.10) !important;
}

@media(max-width:1360px){
  .board-grid-three{grid-template-columns:minmax(0,1fr) minmax(0,1fr) !important;}
  .feed-card{grid-column:1 / -1 !important;}
  .feature-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}

@media(max-width:980px){
  .content-board,.feature-grid,.partner-grid{padding-left:14px !important;padding-right:14px !important;}
  .board-grid-three,.feature-grid,.partner-grid{grid-template-columns:1fr !important;}
  .event-card,.feature-card,.wide-feature{grid-template-columns:1fr !important;}
  .event-card img,.feature-card img{height:230px !important;min-height:230px !important;}
  .wide-feature img{height:210px !important;}
  .region-list{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}

@media(max-width:560px){
  .section-top{align-items:flex-start !important;flex-direction:column !important;}
  .event-card{grid-template-columns:1fr !important;padding:16px !important;}
  .date-box{min-height:86px !important;}
  .region-list{grid-template-columns:1fr !important;}
  .feed-row{grid-template-columns:38px minmax(0,1fr) !important;}
  .feed-row img{display:none !important;}
  .wide-feature{grid-template-columns:1fr !important;}
}
/* === BODY BELGIQUE-LABRADOR V15 PREMIUM - FIN === */


/* === V16 - Correction CTA hero + titres body sans icônes === */
.hero-member-note{
  margin: 6px 0 12px !important;
  color: #fff !important;
  font-weight: 950 !important;
  font-size: clamp(15px, 1.35vw, 20px) !important;
  line-height: 1.2 !important;
  letter-spacing: .01em !important;
  text-shadow: 0 2px 8px rgba(0,0,0,.72), 0 0 18px rgba(8,41,87,.42) !important;
}

.hero-cta{
  margin-top: 2px !important;
}

.section-top h2,
.card-title-line h3{
  letter-spacing: -.02em !important;
}
/* === V16 - FIN === */

/* === V19 BODY : suppression des pictos décoratifs dans les blocs === */
/* Ne touche pas au header, ni au hero, ni aux boutons */
.feature-card .feature-icon,
.wide-feature .feature-icon {
  display: none !important;
}

.feature-card .feature-copy {
  padding-top: clamp(22px, 2.2vw, 32px) !important;
}

.wide-feature {
  grid-template-columns: minmax(0, 1fr) minmax(180px, 38%) !important;
}

@media(max-width:980px){
  .wide-feature {
    grid-template-columns: 1fr !important;
  }
}
/* === V19 FIN === */


/* === V19 BODY : suppression des pictos décoratifs dans les blocs === */
/* Ne touche pas au header, ni au hero, ni aux boutons */
.feature-card .feature-icon,
.wide-feature .feature-icon {
  display: none !important;
}

.feature-card .feature-copy {
  padding-top: clamp(22px, 2.2vw, 32px) !important;
}

.wide-feature {
  grid-template-columns: minmax(0, 1fr) minmax(180px, 38%) !important;
}

@media(max-width:980px){
  .wide-feature {
    grid-template-columns: 1fr !important;
  }
}
/* === V19 FIN === */


/* === V22 : neutralisation totale des pictos v14 === */
.v14-icon,
span.v14-icon,
div.v14-icon,
.v14-feature-copy .v14-icon,
.v14-wide .v14-icon {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
}
/* === V22 FIN === */


/* === V23 : boutons premium sans pictos === */
.join-button-top,
.hero-cta,
.v14-link,
.v14-feature a,
.v14-wide a,
.card-copy a,
.feature-card a,
.simple-button {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  border: 0 !important;
  border-radius: 999px !important;
  font-weight: 950 !important;
  letter-spacing: .01em !important;
  text-decoration: none !important;
  line-height: 1 !important;
  transform: translateZ(0) !important;
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease !important;
}

.join-button-top {
  min-height: 42px !important;
  padding: 12px 20px !important;
  background: linear-gradient(135deg, #123f82 0%, #0b2c5f 100%) !important;
  color: #fff !important;
  box-shadow: 0 12px 26px rgba(9, 35, 74, .20) !important;
}

.hero-cta {
  min-height: 48px !important;
  padding: 14px 28px !important;
  background: linear-gradient(135deg, #34721f 0%, #245a17 100%) !important;
  color: #fff !important;
  box-shadow: 0 16px 34px rgba(52, 114, 31, .30) !important;
}

.v14-feature a,
.card-copy a,
.feature-card a,
.simple-button {
  min-height: 42px !important;
  padding: 12px 20px !important;
  background: linear-gradient(135deg, #123f82 0%, #0b2c5f 100%) !important;
  color: #fff !important;
  box-shadow: 0 12px 24px rgba(18, 63, 130, .20) !important;
}

.v14-green a,
.feature-card.green a {
  background: linear-gradient(135deg, #34721f 0%, #245a17 100%) !important;
  box-shadow: 0 12px 24px rgba(52, 114, 31, .22) !important;
}

.v14-orange a,
.feature-card.orange a {
  background: linear-gradient(135deg, #e89412 0%, #c87306 100%) !important;
  box-shadow: 0 12px 24px rgba(232, 148, 18, .24) !important;
}

.v14-link,
.v14-wide a {
  width: fit-content !important;
  min-height: 40px !important;
  padding: 11px 18px !important;
  background: rgba(18, 63, 130, .08) !important;
  color: #123f82 !important;
  box-shadow: inset 0 0 0 1px rgba(18, 63, 130, .12) !important;
}

.join-button-top:hover,
.hero-cta:hover,
.v14-link:hover,
.v14-feature a:hover,
.v14-wide a:hover,
.card-copy a:hover,
.feature-card a:hover,
.simple-button:hover {
  transform: translateY(-2px) !important;
  filter: saturate(1.05) brightness(1.02) !important;
}

.join-button-top:active,
.hero-cta:active,
.v14-link:active,
.v14-feature a:active,
.v14-wide a:active,
.card-copy a:active,
.feature-card a:active,
.simple-button:active {
  transform: translateY(0) !important;
}

@media(max-width: 560px) {
  .join-button-top,
  .hero-cta,
  .v14-feature a,
  .v14-wide a,
  .card-copy a,
  .feature-card a,
  .simple-button {
    width: 100% !important;
  }
}
/* === V23 FIN === */


/* === V24 PAGES INTERNES PREMIUM - sans toucher header/hero/home === */

.premium-inner-page {
  width: min(1420px, calc(100% - 28px)) !important;
  margin: 34px auto 34px !important;
}

.premium-inner-hero {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr) !important;
  gap: clamp(22px, 3vw, 42px) !important;
  align-items: stretch !important;
  background:
    radial-gradient(circle at top left, rgba(232,148,18,.13), transparent 34%),
    linear-gradient(135deg, #ffffff 0%, #f4f8ef 100%) !important;
  border: 1px solid rgba(9,35,74,.10) !important;
  border-radius: 30px !important;
  box-shadow: 0 26px 70px rgba(9,35,74,.13) !important;
  overflow: hidden !important;
  padding: clamp(22px, 3vw, 42px) !important;
}

.premium-inner-copy {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-height: 360px !important;
}

.premium-inner-copy h1 {
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: clamp(38px, 4.4vw, 72px) !important;
  line-height: .98 !important;
  margin: 0 0 18px !important;
  color: #082957 !important;
  max-width: 760px !important;
}

.premium-inner-copy > p:not(.eyebrow) {
  font-size: clamp(17px, 1.35vw, 21px) !important;
  line-height: 1.62 !important;
  color: #43546b !important;
  max-width: 760px !important;
  margin: 0 !important;
}

.premium-inner-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin-top: 26px !important;
}

.simple-button.secondary {
  background: rgba(18,63,130,.08) !important;
  color: #123f82 !important;
  box-shadow: inset 0 0 0 1px rgba(18,63,130,.13) !important;
}

.premium-inner-visual {
  margin: 0 !important;
  min-height: 360px !important;
  border-radius: 24px !important;
  overflow: hidden !important;
  box-shadow: 0 18px 48px rgba(9,35,74,.16) !important;
  position: relative !important;
}

.premium-inner-visual::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(0deg, rgba(9,35,74,.18), transparent 48%) !important;
  pointer-events: none !important;
}

.premium-inner-visual img {
  width: 100% !important;
  height: 100% !important;
  min-height: 360px !important;
  object-fit: cover !important;
  display: block !important;
}

.premium-inner-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2vw, 26px) !important;
  margin-top: clamp(22px, 2.6vw, 36px) !important;
}

.premium-inner-card {
  background: #fff !important;
  border: 1px solid rgba(9,35,74,.10) !important;
  border-radius: 24px !important;
  box-shadow: 0 18px 46px rgba(9,35,74,.09) !important;
  padding: clamp(22px, 2.2vw, 32px) !important;
  min-height: 210px !important;
}

.premium-inner-card h2 {
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: clamp(24px, 2vw, 32px) !important;
  line-height: 1.08 !important;
  color: #082957 !important;
  margin: 0 0 12px !important;
}

.premium-inner-card p {
  color: #4b5d75 !important;
  line-height: 1.58 !important;
  font-size: 16px !important;
  margin: 0 !important;
}

.premium-inner-note {
  display: flex !important;
  justify-content: space-between !important;
  gap: 22px !important;
  align-items: center !important;
  margin-top: clamp(22px, 2.6vw, 36px) !important;
  background: linear-gradient(135deg, #0b2c5f 0%, #123f82 100%) !important;
  color: #fff !important;
  border-radius: 26px !important;
  padding: clamp(22px, 2.5vw, 36px) !important;
  box-shadow: 0 22px 58px rgba(9,35,74,.20) !important;
}

.premium-inner-note .eyebrow {
  color: #f3c45f !important;
}

.premium-inner-note h2 {
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: clamp(26px, 2.3vw, 38px) !important;
  line-height: 1.05 !important;
  margin: 0 0 10px !important;
}

.premium-inner-note p:not(.eyebrow) {
  margin: 0 !important;
  color: rgba(255,255,255,.82) !important;
  line-height: 1.55 !important;
  max-width: 820px !important;
}

.premium-inner-note .simple-button {
  background: #fff !important;
  color: #0b2c5f !important;
  box-shadow: 0 14px 32px rgba(0,0,0,.16) !important;
  white-space: nowrap !important;
}

@media(max-width: 980px) {
  .premium-inner-page {
    width: calc(100% - 20px) !important;
    margin-top: 22px !important;
  }

  .premium-inner-hero,
  .premium-inner-grid {
    grid-template-columns: 1fr !important;
  }

  .premium-inner-copy {
    min-height: auto !important;
  }

  .premium-inner-visual,
  .premium-inner-visual img {
    min-height: 300px !important;
  }

  .premium-inner-note {
    align-items: flex-start !important;
    flex-direction: column !important;
  }
}

@media(max-width: 560px) {
  .premium-inner-page {
    width: 100% !important;
    margin-top: 0 !important;
  }

  .premium-inner-hero,
  .premium-inner-note {
    border-radius: 0 !important;
  }

  .premium-inner-grid {
    padding: 0 12px !important;
  }

  .premium-inner-visual,
  .premium-inner-visual img {
    min-height: 230px !important;
  }
}

/* === V24 FIN === */


/* === V25 ESPACE MEMBRE MINIMAL PREMIUM === */

.member-page {
  width: min(1420px, calc(100% - 28px));
  margin: 34px auto;
}

.member-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(340px, .95fr);
  gap: clamp(22px, 3vw, 42px);
  align-items: stretch;
  background:
    radial-gradient(circle at top left, rgba(232,148,18,.14), transparent 34%),
    linear-gradient(135deg, #ffffff 0%, #f4f8ef 100%);
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 30px;
  box-shadow: 0 26px 70px rgba(9,35,74,.13);
  overflow: hidden;
  padding: clamp(22px, 3vw, 42px);
}

.member-hero-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 360px;
}

.member-hero-copy h1 {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(40px, 4.7vw, 76px);
  line-height: .98;
  margin: 0 0 18px;
  color: #082957;
}

.member-hero-copy > p:not(.eyebrow) {
  font-size: clamp(17px, 1.35vw, 21px);
  line-height: 1.62;
  color: #43546b;
  max-width: 760px;
  margin: 0;
}

.member-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.member-hero-img {
  margin: 0;
  min-height: 360px;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 18px 48px rgba(9,35,74,.16);
}

.member-hero-img img {
  width: 100%;
  height: 100%;
  min-height: 360px;
  object-fit: cover;
  display: block;
}

.member-form-card,
.member-dashboard-grid {
  margin-top: clamp(22px, 2.6vw, 36px);
}

.member-form-card {
  display: grid;
  grid-template-columns: minmax(280px, .75fr) minmax(0, 1.25fr);
  gap: clamp(22px, 3vw, 42px);
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 28px;
  box-shadow: 0 22px 58px rgba(9,35,74,.10);
  padding: clamp(22px, 3vw, 42px);
}

.member-form-card.compact {
  grid-template-columns: .8fr 1.2fr;
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
}

.member-form-intro h2,
.member-dash-card h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  margin: 0 0 12px;
  font-size: clamp(26px, 2.3vw, 38px);
  line-height: 1.06;
}

.member-form-intro p,
.member-dash-card p {
  color: #4b5d75;
  line-height: 1.58;
  margin: 0;
}

.member-form {
  display: grid;
  gap: 16px;
}

.member-form label {
  display: grid;
  gap: 7px;
  color: #082957;
  font-weight: 900;
  font-size: 14px;
}

.member-form input,
.member-form select {
  width: 100%;
  min-height: 48px;
  border: 1px solid rgba(9,35,74,.15);
  border-radius: 14px;
  padding: 0 14px;
  font: inherit;
  background: #fbfcf8;
  color: #082957;
  outline: none;
}

.member-form input:focus,
.member-form select:focus {
  border-color: rgba(52,114,31,.55);
  box-shadow: 0 0 0 4px rgba(52,114,31,.12);
}

.member-check {
  display: flex !important;
  grid-template-columns: auto 1fr;
  align-items: flex-start;
  gap: 10px !important;
  font-weight: 700 !important;
  color: #4b5d75 !important;
}

.member-check input {
  width: 18px;
  min-height: 18px;
  margin-top: 2px;
}

.member-form button {
  min-height: 50px;
  border: 0;
  border-radius: 999px;
  padding: 14px 24px;
  background: linear-gradient(135deg, #34721f 0%, #245a17 100%);
  color: #fff;
  font-weight: 950;
  font-size: 15px;
  cursor: pointer;
  box-shadow: 0 16px 34px rgba(52,114,31,.28);
}

.member-muted-link {
  color: #123f82;
  text-decoration: none;
  font-weight: 900;
  width: fit-content;
}

.member-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(18px, 2vw, 26px);
}

.member-dash-card {
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 24px;
  box-shadow: 0 18px 46px rgba(9,35,74,.09);
  padding: clamp(22px, 2.2vw, 32px);
  min-height: 210px;
}

.member-dash-card a {
  display: inline-flex;
  margin-top: 18px;
  color: #123f82;
  text-decoration: none;
  font-weight: 950;
}

@media(max-width: 1100px) {
  .member-dashboard-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media(max-width: 900px) {
  .member-page {
    width: calc(100% - 20px);
    margin-top: 22px;
  }

  .member-hero,
  .member-form-card,
  .member-form-card.compact {
    grid-template-columns: 1fr;
  }

  .member-hero-copy {
    min-height: auto;
  }

  .member-hero-img,
  .member-hero-img img {
    min-height: 280px;
  }
}

@media(max-width: 560px) {
  .member-page {
    width: 100%;
    margin-top: 0;
  }

  .member-hero,
  .member-form-card {
    border-radius: 0;
  }

  .member-dashboard-grid {
    grid-template-columns: 1fr;
    padding: 0 12px;
  }

  .member-actions .simple-button {
    width: 100%;
  }
}

/* === V25 FIN === */


/* Espace membre V1 : carte statut */
.member-status-card {
  margin-top: clamp(22px, 2.6vw, 36px);
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 24px;
  box-shadow: 0 18px 46px rgba(9,35,74,.09);
  padding: clamp(22px, 2.2vw, 32px);
}

.member-status-card h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  margin: 0 0 10px;
  font-size: clamp(24px, 2vw, 34px);
}

.member-status-card p:not(.eyebrow) {
  color: #4b5d75;
  line-height: 1.55;
  margin: 0 0 16px;
}

/* Mes Labradors - espace membre V1 */
.member-form textarea {
  width: 100%;
  border: 1px solid rgba(9,35,74,.15);
  border-radius: 14px;
  padding: 12px 14px;
  font: inherit;
  background: #fbfcf8;
  color: #082957;
  outline: none;
  resize: vertical;
}

.member-form textarea:focus {
  border-color: rgba(52,114,31,.55);
  box-shadow: 0 0 0 4px rgba(52,114,31,.12);
}

.labrador-form-card {
  align-items: start;
}

.member-labradors-list {
  margin-top: clamp(22px, 2.6vw, 36px);
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 28px;
  box-shadow: 0 22px 58px rgba(9,35,74,.10);
  padding: clamp(22px, 3vw, 42px);
}

.member-list-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-end;
  margin-bottom: 22px;
}

.member-list-head h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  margin: 0;
  font-size: clamp(28px, 2.4vw, 42px);
  line-height: 1.05;
}

.member-list-head p {
  margin: 0;
  color: #4b5d75;
  font-weight: 900;
}

.member-empty-card,
.member-labrador-card {
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 22px;
  background: linear-gradient(135deg, #fff 0%, #f7faf4 100%);
  padding: 22px;
}

.member-labrador-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.member-labrador-card h3,
.member-empty-card h3 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: 28px;
  line-height: 1.08;
  margin: 0 0 12px;
}

.member-labrador-card p,
.member-empty-card p {
  color: #4b5d75;
  line-height: 1.5;
  margin: 7px 0;
}

.member-dog-description {
  border-top: 1px solid rgba(9,35,74,.10);
  padding-top: 12px;
  margin-top: 12px !important;
}

.member-status-pill {
  display: inline-flex;
  margin-top: 14px;
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(232,148,18,.12);
  color: #9a5800;
  font-weight: 950;
  font-size: 12px;
  text-transform: uppercase;
}

@media(max-width: 980px) {
  .member-labrador-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .member-list-head {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media(max-width: 560px) {
  .member-labrador-grid {
    grid-template-columns: 1fr;
  }
}

/* Module fiche Labrador + album photo */
.member-dog-link {
  display: inline-flex;
  margin-top: 14px;
  color: #123f82;
  text-decoration: none;
  font-weight: 950;
}

.dog-profile-page {
  display: grid;
  gap: clamp(22px, 2.6vw, 36px);
  margin-top: clamp(22px, 2.6vw, 36px);
}

.dog-profile-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
  gap: clamp(22px, 3vw, 42px);
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 30px;
  box-shadow: 0 24px 66px rgba(9,35,74,.12);
  padding: clamp(22px, 3vw, 42px);
}

.dog-profile-copy h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: clamp(40px, 4vw, 70px);
  line-height: .98;
  margin: 0 0 20px;
}

.dog-profile-meta {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 18px 0;
}

.dog-profile-meta span {
  background: #f7f9f4;
  border: 1px solid rgba(9,35,74,.08);
  border-radius: 16px;
  padding: 12px;
  color: #43546b;
}

.dog-profile-meta strong {
  display: block;
  text-transform: uppercase;
  font-size: 11px;
  color: #082957;
  margin-bottom: 5px;
}

.dog-profile-description,
.dog-profile-age {
  color: #4b5d75;
  line-height: 1.58;
}

.dog-profile-cover {
  margin: 0;
  border-radius: 24px;
  overflow: hidden;
  min-height: 330px;
  box-shadow: 0 18px 48px rgba(9,35,74,.16);
}

.dog-profile-cover img {
  width: 100%;
  height: 100%;
  min-height: 330px;
  object-fit: cover;
  display: block;
}

.dog-birthday-card,
.dog-photo-upload-card,
.dog-gallery-section,
.dog-offers-section {
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 28px;
  box-shadow: 0 20px 54px rgba(9,35,74,.09);
  padding: clamp(22px, 3vw, 42px);
}

.dog-birthday-card {
  display: flex;
  justify-content: space-between;
  gap: 22px;
  align-items: center;
  background:
    radial-gradient(circle at top left, rgba(232,148,18,.18), transparent 34%),
    linear-gradient(135deg, #fff 0%, #f7faf4 100%);
}

.dog-birthday-card h2,
.dog-photo-upload-card h2,
.dog-offers-section h2,
.dog-gallery-section h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  margin: 0 0 10px;
  font-size: clamp(28px, 2.5vw, 42px);
  line-height: 1.05;
}

.dog-birthday-card p,
.dog-photo-upload-card p {
  color: #4b5d75;
  line-height: 1.55;
  margin: 0;
}

.birthday-badge {
  white-space: nowrap;
  display: inline-flex;
  border-radius: 999px;
  padding: 12px 16px;
  background: rgba(232,148,18,.15);
  color: #9a5800;
  font-weight: 950;
}

.dog-photo-upload-card {
  display: grid;
  grid-template-columns: minmax(260px, .75fr) minmax(0, 1.25fr);
  gap: clamp(22px, 3vw, 42px);
}

.dog-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.dog-gallery-item {
  margin: 0;
  border-radius: 20px;
  overflow: hidden;
  background: #f7f9f4;
  border: 1px solid rgba(9,35,74,.10);
}

.dog-gallery-item img {
  width: 100%;
  height: 210px;
  object-fit: cover;
  display: block;
}

.dog-gallery-item figcaption {
  padding: 12px;
  color: #43546b;
  font-weight: 800;
  font-size: 14px;
}

.dog-offer-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.dog-offer-card {
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 22px;
  background: linear-gradient(135deg, #fff 0%, #f7faf4 100%);
  padding: 22px;
}

.dog-offer-card span {
  display: inline-flex;
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(18,63,130,.08);
  color: #123f82;
  font-weight: 950;
  text-transform: uppercase;
  font-size: 11px;
}

.dog-offer-card h3 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: 25px;
  line-height: 1.08;
  margin: 14px 0 10px;
}

.dog-offer-card p,
.dog-offer-card em {
  color: #4b5d75;
  line-height: 1.5;
}

@media(max-width: 1100px) {
  .dog-profile-meta,
  .dog-gallery-grid,
  .dog-offer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media(max-width: 900px) {
  .dog-profile-hero,
  .dog-photo-upload-card {
    grid-template-columns: 1fr;
  }

  .dog-birthday-card {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media(max-width: 560px) {
  .dog-profile-meta,
  .dog-gallery-grid,
  .dog-offer-grid {
    grid-template-columns: 1fr;
  }

  .dog-profile-hero,
  .dog-birthday-card,
  .dog-photo-upload-card,
  .dog-gallery-section,
  .dog-offers-section {
    border-radius: 0;
  }
}

/* Module fiche Labrador + album photo */
.member-dog-link {
  display: inline-flex;
  margin-top: 14px;
  color: #123f82;
  text-decoration: none;
  font-weight: 950;
}

.dog-profile-page {
  display: grid;
  gap: clamp(22px, 2.6vw, 36px);
  margin-top: clamp(22px, 2.6vw, 36px);
}

.dog-profile-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
  gap: clamp(22px, 3vw, 42px);
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 30px;
  box-shadow: 0 24px 66px rgba(9,35,74,.12);
  padding: clamp(22px, 3vw, 42px);
}

.dog-profile-copy h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: clamp(40px, 4vw, 70px);
  line-height: .98;
  margin: 0 0 20px;
}

.dog-profile-meta {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 18px 0;
}

.dog-profile-meta span {
  background: #f7f9f4;
  border: 1px solid rgba(9,35,74,.08);
  border-radius: 16px;
  padding: 12px;
  color: #43546b;
}

.dog-profile-meta strong {
  display: block;
  text-transform: uppercase;
  font-size: 11px;
  color: #082957;
  margin-bottom: 5px;
}

.dog-profile-description,
.dog-profile-age {
  color: #4b5d75;
  line-height: 1.58;
}

.dog-profile-cover {
  margin: 0;
  border-radius: 24px;
  overflow: hidden;
  min-height: 330px;
  box-shadow: 0 18px 48px rgba(9,35,74,.16);
}

.dog-profile-cover img {
  width: 100%;
  height: 100%;
  min-height: 330px;
  object-fit: cover;
  display: block;
}

.dog-birthday-card,
.dog-photo-upload-card,
.dog-gallery-section,
.dog-offers-section {
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 28px;
  box-shadow: 0 20px 54px rgba(9,35,74,.09);
  padding: clamp(22px, 3vw, 42px);
}

.dog-birthday-card {
  display: flex;
  justify-content: space-between;
  gap: 22px;
  align-items: center;
  background:
    radial-gradient(circle at top left, rgba(232,148,18,.18), transparent 34%),
    linear-gradient(135deg, #fff 0%, #f7faf4 100%);
}

.dog-birthday-card h2,
.dog-photo-upload-card h2,
.dog-offers-section h2,
.dog-gallery-section h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  margin: 0 0 10px;
  font-size: clamp(28px, 2.5vw, 42px);
  line-height: 1.05;
}

.dog-birthday-card p,
.dog-photo-upload-card p {
  color: #4b5d75;
  line-height: 1.55;
  margin: 0;
}

.birthday-badge {
  white-space: nowrap;
  display: inline-flex;
  border-radius: 999px;
  padding: 12px 16px;
  background: rgba(232,148,18,.15);
  color: #9a5800;
  font-weight: 950;
}

.dog-photo-upload-card {
  display: grid;
  grid-template-columns: minmax(260px, .75fr) minmax(0, 1.25fr);
  gap: clamp(22px, 3vw, 42px);
}

.dog-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.dog-gallery-item {
  margin: 0;
  border-radius: 20px;
  overflow: hidden;
  background: #f7f9f4;
  border: 1px solid rgba(9,35,74,.10);
}

.dog-gallery-item img {
  width: 100%;
  height: 210px;
  object-fit: cover;
  display: block;
}

.dog-gallery-item figcaption {
  padding: 12px;
  color: #43546b;
  font-weight: 800;
  font-size: 14px;
}

.dog-offer-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.dog-offer-card {
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 22px;
  background: linear-gradient(135deg, #fff 0%, #f7faf4 100%);
  padding: 22px;
}

.dog-offer-card span {
  display: inline-flex;
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(18,63,130,.08);
  color: #123f82;
  font-weight: 950;
  text-transform: uppercase;
  font-size: 11px;
}

.dog-offer-card h3 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: 25px;
  line-height: 1.08;
  margin: 14px 0 10px;
}

.dog-offer-card p,
.dog-offer-card em {
  color: #4b5d75;
  line-height: 1.5;
}

@media(max-width: 1100px) {
  .dog-profile-meta,
  .dog-gallery-grid,
  .dog-offer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media(max-width: 900px) {
  .dog-profile-hero,
  .dog-photo-upload-card {
    grid-template-columns: 1fr;
  }

  .dog-birthday-card {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media(max-width: 560px) {
  .dog-profile-meta,
  .dog-gallery-grid,
  .dog-offer-grid {
    grid-template-columns: 1fr;
  }

  .dog-profile-hero,
  .dog-birthday-card,
  .dog-photo-upload-card,
  .dog-gallery-section,
  .dog-offers-section {
    border-radius: 0;
  }
}

/* Fiche Labrador : formulaire de modification */
.dog-edit-card {
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 28px;
  box-shadow: 0 20px 54px rgba(9,35,74,.09);
  padding: clamp(22px, 3vw, 42px);
  display: grid;
  grid-template-columns: minmax(260px, .7fr) minmax(0, 1.3fr);
  gap: clamp(22px, 3vw, 42px);
}

.dog-edit-intro h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: clamp(28px, 2.5vw, 42px);
  line-height: 1.05;
  margin: 0 0 10px;
}

.dog-edit-intro p:not(.eyebrow) {
  color: #4b5d75;
  line-height: 1.55;
  margin: 0;
}

.dog-edit-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.dog-edit-form .dog-edit-wide,
.dog-edit-form button {
  grid-column: 1 / -1;
}

@media(max-width: 900px) {
  .dog-edit-card,
  .dog-edit-form {
    grid-template-columns: 1fr;
  }
}

@media(max-width: 560px) {
  .dog-edit-card {
    border-radius: 0;
  }
}

/* Album photo Labrador : actions photo */
.dog-gallery-item {
  position: relative;
}

.dog-cover-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  display: inline-flex;
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(52,114,31,.92);
  color: #fff;
  font-weight: 950;
  font-size: 11px;
  text-transform: uppercase;
  box-shadow: 0 8px 20px rgba(0,0,0,.18);
}

.dog-photo-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  padding: 12px;
  border-top: 1px solid rgba(9,35,74,.08);
  background: #fff;
}

.dog-photo-actions form {
  margin: 0;
}

.dog-photo-actions button {
  width: 100%;
  min-height: 38px;
  border: 0;
  border-radius: 999px;
  padding: 9px 12px;
  background: rgba(18,63,130,.08);
  color: #123f82;
  font-weight: 950;
  cursor: pointer;
}

.dog-photo-actions button.danger {
  background: rgba(150,30,30,.09);
  color: #9b1c1c;
}

.dog-photo-actions button:hover {
  filter: brightness(.98);
}

/* Upload album photo par lots */
.album-upload-card {
  align-items: start;
}

.album-upload-help {
  margin: -4px 0 0;
  color: #4b5d75;
  font-size: 14px;
  line-height: 1.45;
}

.album-upload-progress {
  min-height: 24px;
  color: #123f82;
  font-weight: 900;
  line-height: 1.45;
}

.album-upload-form button:disabled {
  opacity: .65;
  cursor: wait;
}

/* Fil du club membre */
.member-feed-layout {
  display: grid;
  grid-template-columns: minmax(320px, .78fr) minmax(0, 1.22fr);
  gap: clamp(22px, 3vw, 42px);
  margin-top: clamp(22px, 2.6vw, 36px);
  align-items: start;
}

.member-feed-compose,
.member-feed-list,
.member-feed-post {
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 28px;
  box-shadow: 0 20px 54px rgba(9,35,74,.09);
}

.member-feed-compose,
.member-feed-list {
  padding: clamp(22px, 3vw, 42px);
}

.member-feed-compose h2,
.member-feed-list h2,
.member-feed-post h3 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  line-height: 1.05;
}

.member-feed-compose h2 {
  font-size: clamp(28px, 2.5vw, 42px);
  margin: 0 0 10px;
}

.member-feed-compose p {
  color: #4b5d75;
  line-height: 1.55;
}

.member-post-form textarea {
  width: 100%;
  border: 1px solid rgba(9,35,74,.15);
  border-radius: 14px;
  padding: 12px 14px;
  font: inherit;
  background: #fbfcf8;
  color: #082957;
  outline: none;
  resize: vertical;
}

.member-feed-list {
  display: grid;
  gap: 18px;
}

.member-feed-post {
  padding: clamp(18px, 2vw, 28px);
}

.feed-post-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 14px;
}

.feed-post-top strong {
  display: block;
  color: #082957;
  font-weight: 950;
}

.feed-post-top span {
  display: block;
  margin-top: 4px;
  color: #66758c;
  font-size: 13px;
  font-weight: 800;
}

.feed-status {
  display: inline-flex;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  white-space: nowrap;
}

.feed-status.published {
  background: rgba(52,114,31,.13);
  color: #245a17;
}

.feed-status.pending {
  background: rgba(232,148,18,.15);
  color: #9a5800;
}

.feed-status.rejected,
.feed-status.archived {
  background: rgba(150,30,30,.10);
  color: #9b1c1c;
}

.member-feed-post h3 {
  font-size: clamp(24px, 2vw, 34px);
  margin: 0 0 10px;
}

.member-feed-post p {
  color: #4b5d75;
  line-height: 1.6;
  margin: 0 0 14px;
}

.member-feed-post figure {
  margin: 16px 0 0;
  border-radius: 20px;
  overflow: hidden;
  background: #f7f9f4;
}

.member-feed-post figure img {
  width: 100%;
  max-height: 420px;
  object-fit: cover;
  display: block;
}

.member-feed-post small {
  display: block;
  margin-top: 14px;
  color: #9a5800;
  font-weight: 900;
}

@media(max-width: 1000px) {
  .member-feed-layout {
    grid-template-columns: 1fr;
  }
}

@media(max-width: 560px) {
  .member-feed-compose,
  .member-feed-list,
  .member-feed-post {
    border-radius: 0;
  }

  .feed-post-top {
    flex-direction: column;
  }
}

/* Signalement et gel de publication */
.member-feed-post.is-flagged {
  background:
    radial-gradient(circle at top left, rgba(232,148,18,.13), transparent 34%),
    #fff;
}

.feed-under-review {
  border: 1px dashed rgba(154,88,0,.28);
  border-radius: 18px;
  background: rgba(232,148,18,.08);
  padding: 18px;
}

.feed-under-review h3 {
  margin: 0 0 8px;
}

.feed-under-review p,
.feed-under-review small {
  color: #6b520f;
  font-weight: 800;
}

.feed-report-box {
  margin-top: 16px;
  border-top: 1px solid rgba(9,35,74,.10);
  padding-top: 14px;
}

.feed-report-box summary {
  cursor: pointer;
  color: #123f82;
  font-weight: 950;
}

.feed-report-box form {
  display: grid;
  gap: 12px;
  margin-top: 12px;
  background: #f7f9f4;
  border: 1px solid rgba(9,35,74,.08);
  border-radius: 16px;
  padding: 14px;
}

.feed-report-box label {
  display: grid;
  gap: 7px;
  font-weight: 900;
  color: #082957;
}

.feed-report-box select,
.feed-report-box textarea {
  width: 100%;
  border: 1px solid rgba(9,35,74,.15);
  border-radius: 12px;
  padding: 10px 12px;
  font: inherit;
  background: #fff;
  color: #082957;
}

.feed-report-box button {
  border: 0;
  border-radius: 999px;
  padding: 11px 16px;
  background: #123f82;
  color: #fff;
  font-weight: 950;
  cursor: pointer;
}

.member-suspended-card {
  background: #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 30px;
  box-shadow: 0 24px 66px rgba(9,35,74,.12);
  padding: clamp(28px, 4vw, 56px);
  max-width: 980px;
  margin: 34px auto;
}

.member-suspended-card h1 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: clamp(38px, 4vw, 68px);
  line-height: .98;
  margin: 0 0 18px;
}

.member-suspended-card p {
  color: #4b5d75;
  line-height: 1.6;
}

.member-suspended-warning {
  display: grid;
  gap: 6px;
  border-radius: 18px;
  background: rgba(232,148,18,.10);
  border: 1px solid rgba(232,148,18,.25);
  padding: 16px;
  margin: 22px 0;
  color: #6b520f;
}

.suspended-appeal-form textarea {
  width: 100%;
  border: 1px solid rgba(9,35,74,.15);
  border-radius: 14px;
  padding: 12px 14px;
  font: inherit;
  background: #fbfcf8;
  color: #082957;
  resize: vertical;
}

/* Navigation rapide espace membre */
.member-quick-nav {
  width: min(1420px, calc(100% - 28px));
  margin: 20px auto 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 999px;
  box-shadow: 0 14px 34px rgba(9,35,74,.08);
  padding: 10px;
}

.member-quick-nav a {
  text-decoration: none;
  border-radius: 999px;
  padding: 10px 15px;
  font-weight: 950;
  color: #082957;
  background: #f7f9f4;
  border: 1px solid rgba(9,35,74,.08);
}

.member-quick-nav a.active {
  background: #123f82;
  color: #fff;
}

.member-quick-nav a.logout {
  margin-left: auto;
  background: rgba(150,30,30,.08);
  color: #9b1c1c;
}

@media(max-width: 640px) {
  .member-quick-nav {
    width: calc(100% - 18px);
    border-radius: 22px;
  }

  .member-quick-nav a,
  .member-quick-nav a.logout {
    margin-left: 0;
    flex: 1 1 auto;
    text-align: center;
  }
}

/* Page compte suspendu : contenu reproché */
.reported-content-card,
.member-appeal-sent {
  margin: 24px 0;
  border: 1px solid rgba(154,28,28,.18);
  border-radius: 24px;
  background:
    radial-gradient(circle at top left, rgba(154,28,28,.08), transparent 34%),
    #fff;
  padding: clamp(18px, 2.4vw, 30px);
}

.reported-content-card h2,
.member-appeal-sent h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: clamp(26px, 2.4vw, 40px);
  margin: 0 0 10px;
  line-height: 1.05;
}

.reported-content-card h3 {
  color: #082957;
  font-size: 22px;
  margin: 18px 0 10px;
}

.reported-content-info,
.reported-content-note {
  color: #6b520f;
  font-weight: 800;
  line-height: 1.55;
}

.reported-content-body {
  border: 2px solid rgba(154,28,28,.18);
  border-radius: 18px;
  background: rgba(154,28,28,.055);
  padding: 16px;
  color: #273d5b;
  line-height: 1.6;
  font-weight: 800;
}

.reported-content-image {
  margin: 16px 0 0;
  border-radius: 18px;
  overflow: hidden;
  border: 2px solid rgba(154,28,28,.18);
  background: #f7f9f4;
}

.reported-content-image img {
  width: 100%;
  max-height: 420px;
  object-fit: contain;
  display: block;
}

.reported-content-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.reported-content-meta span {
  display: inline-flex;
  border-radius: 999px;
  background: rgba(18,63,130,.08);
  color: #123f82;
  padding: 8px 11px;
  font-weight: 950;
  font-size: 13px;
}

.member-appeal-sent p {
  color: #4b5d75;
  line-height: 1.6;
}

.member-appeal-sent small {
  display: block;
  color: #6b520f;
  font-weight: 900;
}

/* Vérification e-mail membre */
.email-wait-card {
  text-align: left;
}

.email-wait-card h1 {
  max-width: 780px;
}

.email-wait-card .simple-button {
  margin-top: 14px;
}

/* Réactions positives fil du club */
.feed-reaction-row,
.member-feed-actions,
.club-post-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 14px;
}

.feed-reaction-form,
.member-feed-actions form,
.club-post-actions form {
  margin: 0;
}

.feed-reaction-button,
.member-feed-actions button,
.club-post-actions button {
  border: 1px solid rgba(18,63,130,.14);
  border-radius: 999px;
  background:
    radial-gradient(circle at top left, rgba(52,114,31,.12), transparent 40%),
    #fff;
  color: #082957;
  padding: 9px 13px;
  font-weight: 950;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(9,35,74,.06);
}

.feed-reaction-button:hover,
.member-feed-actions button:hover,
.club-post-actions button:hover {
  transform: translateY(-1px);
  border-color: rgba(52,114,31,.28);
}

.feed-reaction-count,
.reaction-count {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: rgba(52,114,31,.08);
  color: #245a17;
  padding: 8px 11px;
  font-weight: 950;
  font-size: 13px;
}

/* Membre confirmé */
.member-verification-card {
  width: min(940px, calc(100% - 28px));
  margin: 34px auto;
  background:
    radial-gradient(circle at top left, rgba(52,114,31,.10), transparent 34%),
    #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 28px;
  box-shadow: 0 22px 70px rgba(9,35,74,.12);
  padding: clamp(24px, 4vw, 52px);
}

.member-verification-card h1 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1.04;
  margin: 0 0 14px;
}

.member-verification-card p {
  color: #4b5d75;
  font-size: 17px;
  line-height: 1.6;
}

.member-confirmed-badge,
.member-confirm-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 10px 0 16px;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 950;
  text-decoration: none;
}

.member-confirmed-badge {
  background: rgba(52,114,31,.12);
  color: #245a17;
  border: 1px solid rgba(52,114,31,.22);
}

.member-confirm-link {
  background: rgba(18,63,130,.09);
  color: #123f82;
  border: 1px solid rgba(18,63,130,.15);
}

.member-confirm-link:hover {
  transform: translateY(-1px);
}

.member-form .checkline {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.member-form .checkline input {
  width: auto;
  margin-top: 5px;
}

/* Profil membre */
.member-profile-card {
  width: min(1040px, calc(100% - 28px));
  margin: 34px auto;
  background:
    radial-gradient(circle at top left, rgba(18,63,130,.09), transparent 34%),
    #fff;
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 28px;
  box-shadow: 0 22px 70px rgba(9,35,74,.12);
  padding: clamp(24px, 4vw, 52px);
}

.member-profile-card h1,
.member-profile-card h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  line-height: 1.04;
}

.member-profile-card h1 {
  font-size: clamp(34px, 4vw, 58px);
  margin: 0 0 14px;
}

.member-profile-card h2 {
  font-size: clamp(24px, 2.4vw, 36px);
  margin: 0 0 6px;
}

.member-profile-top {
  display: grid;
  grid-template-columns: 128px 1fr;
  gap: 22px;
  align-items: center;
  margin: 24px 0;
  padding: 18px;
  border-radius: 24px;
  background: rgba(247,249,244,.82);
  border: 1px solid rgba(9,35,74,.08);
}

.member-profile-avatar {
  width: 128px;
  height: 128px;
  border-radius: 999px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #123f82, #34721f);
  color: #fff;
  font-size: 52px;
  font-weight: 950;
  box-shadow: 0 18px 42px rgba(9,35,74,.16);
}

.member-profile-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.member-profile-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.member-form small {
  display: block;
  margin-top: 6px;
  color: #61718a;
  font-weight: 750;
}

@media (max-width: 720px) {
  .member-profile-top {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .member-profile-avatar {
    margin: 0 auto;
  }

  .member-profile-grid {
    grid-template-columns: 1fr;
  }
}

/* Fil du club premium */
.club-feed-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(52,114,31,.10), transparent 32%),
    radial-gradient(circle at top right, rgba(18,63,130,.10), transparent 34%),
    #f4f7f1;
  color: #082957;
}

.club-feed-topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  width: min(1500px, calc(100% - 24px));
  margin: 12px auto 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  border: 1px solid rgba(9,35,74,.10);
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(12px);
  border-radius: 22px;
  padding: 12px 16px;
  box-shadow: 0 14px 38px rgba(9,35,74,.09);
}

.club-feed-brand {
  display: grid;
  text-decoration: none;
  color: #082957;
}

.club-feed-brand strong {
  font-size: 20px;
}

.club-feed-brand span {
  color: #61718a;
  font-weight: 800;
  font-size: 13px;
}

.club-feed-nav {
  display: flex;
  align-items: center;
  gap: 8px;
  overflow-x: auto;
}

.club-feed-nav a {
  white-space: nowrap;
  text-decoration: none;
  border-radius: 999px;
  padding: 9px 12px;
  color: #123f82;
  font-weight: 950;
  background: rgba(18,63,130,.07);
}

.club-feed-shell {
  width: min(1500px, calc(100% - 24px));
  margin: 18px auto 40px;
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr) 310px;
  gap: 18px;
  align-items: start;
}

.club-feed-side {
  position: sticky;
  top: 92px;
  display: grid;
  gap: 16px;
}

.club-member-mini-card,
.club-side-card,
.club-compose-card,
.club-post-card {
  border: 1px solid rgba(9,35,74,.10);
  background: rgba(255,255,255,.96);
  border-radius: 26px;
  box-shadow: 0 16px 44px rgba(9,35,74,.08);
}

.club-member-mini-card {
  padding: 22px;
  text-align: center;
}

.club-member-avatar,
.club-feed-avatar {
  overflow: hidden;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #123f82, #34721f);
  color: #fff;
  font-weight: 950;
}

.club-member-avatar {
  width: 118px;
  height: 118px;
  border-radius: 999px;
  margin: 0 auto 14px;
  font-size: 48px;
  box-shadow: 0 16px 38px rgba(9,35,74,.16);
}

.club-feed-avatar {
  width: 52px;
  height: 52px;
  border-radius: 999px;
  flex: 0 0 52px;
}

.club-feed-avatar.small {
  width: 44px;
  height: 44px;
  flex-basis: 44px;
}

.club-member-avatar img,
.club-feed-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.club-member-mini-card h1 {
  font-family: Georgia, "Times New Roman", serif;
  margin: 0 0 4px;
  font-size: 28px;
  line-height: 1.05;
}

.club-member-mini-card p {
  color: #60718a;
  font-weight: 800;
}

.club-member-links {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.club-member-links a,
.club-side-card a {
  text-decoration: none;
  border-radius: 999px;
  background: rgba(18,63,130,.08);
  color: #123f82;
  padding: 10px 12px;
  font-weight: 950;
}

.club-compose-card {
  padding: 18px;
  margin-bottom: 18px;
}

.club-compose-head,
.club-post-head {
  display: flex;
  align-items: center;
  gap: 12px;
}

.club-compose-head {
  margin-bottom: 14px;
}

.club-compose-head strong,
.club-post-head strong {
  display: block;
  color: #082957;
}

.club-compose-head span,
.club-post-head small {
  display: block;
  color: #61718a;
  font-size: 13px;
  font-weight: 800;
}

.club-compose-card form {
  display: grid;
  gap: 12px;
}

.club-compose-card input,
.club-compose-card textarea,
.club-compose-card select {
  width: 100%;
  border: 1px solid rgba(9,35,74,.12);
  border-radius: 16px;
  padding: 12px 13px;
  font: inherit;
  background: #fff;
}

.club-compose-card textarea {
  resize: vertical;
}

.club-compose-grid {
  display: grid;
  grid-template-columns: 160px 1fr 1fr;
  gap: 10px;
}

.club-compose-card button {
  justify-self: end;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #34721f, #245a17);
  color: #fff;
  padding: 12px 20px;
  font-weight: 950;
  cursor: pointer;
}

.club-post-list {
  display: grid;
  gap: 18px;
}

.club-post-card {
  padding: 18px;
}

.club-post-card h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: clamp(22px, 2vw, 32px);
  line-height: 1.08;
  margin: 14px 0 8px;
}

.club-post-body {
  color: #344760;
  line-height: 1.6;
  font-size: 16px;
}

.club-post-badge {
  display: inline-flex;
  margin-top: 4px;
  border-radius: 999px;
  background: rgba(52,114,31,.10);
  color: #245a17;
  padding: 5px 8px;
  font-size: 12px;
  font-weight: 950;
}

.club-post-image {
  margin: 14px 0 0;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(9,35,74,.08);
  background: #f7f9f4;
}

.club-post-image img {
  width: 100%;
  max-height: 540px;
  object-fit: contain;
  display: block;
}

.club-post-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 14px;
}

.club-post-actions form {
  margin: 0;
}

.club-post-actions button {
  border: 1px solid rgba(18,63,130,.14);
  border-radius: 999px;
  background: #fff;
  color: #123f82;
  padding: 9px 12px;
  font-weight: 950;
  cursor: pointer;
}

.club-post-actions button.active {
  background: rgba(52,114,31,.12);
  color: #245a17;
  border-color: rgba(52,114,31,.24);
}

.club-post-actions button.report {
  color: #6b520f;
  background: rgba(232,148,18,.09);
}

.reaction-count {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: rgba(52,114,31,.08);
  color: #245a17;
  padding: 9px 11px;
  font-weight: 950;
  font-size: 13px;
}

.club-side-card {
  padding: 18px;
}

.club-side-card h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: 24px;
  margin: 0 0 8px;
}

.club-side-card p {
  color: #526782;
  line-height: 1.55;
  font-weight: 750;
}

.club-feed-notice {
  border-radius: 18px;
  padding: 13px 15px;
  margin-bottom: 14px;
  font-weight: 950;
}

.club-feed-notice.success {
  background: rgba(52,114,31,.10);
  color: #245a17;
}

.club-feed-notice.warning {
  background: rgba(232,148,18,.11);
  color: #7a4a00;
}

@media (max-width: 1180px) {
  .club-feed-shell {
    grid-template-columns: 240px minmax(0, 1fr);
  }

  .club-feed-right {
    display: none;
  }
}

@media (max-width: 820px) {
  .club-feed-topbar {
    position: relative;
    flex-direction: column;
    align-items: stretch;
  }

  .club-feed-shell {
    width: min(100% - 16px, 720px);
    grid-template-columns: 1fr;
  }

  .club-feed-side {
    position: static;
  }

  .club-feed-left {
    order: 2;
  }

  .club-feed-center {
    order: 1;
  }

  .club-compose-grid {
    grid-template-columns: 1fr;
  }
}

/* Correction avatar : ne pas garder le fond vert derrière une vraie photo */
.member-profile-avatar:has(img),
.club-member-avatar:has(img),
.club-feed-avatar:has(img) {
  background: #fff !important;
}

.member-profile-avatar img,
.club-member-avatar img,
.club-feed-avatar img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  background: #fff !important;
}

/* Sécurité si navigateur ancien : l’image passe au-dessus proprement */
.member-profile-avatar,
.club-member-avatar,
.club-feed-avatar {
  position: relative;
}

.member-profile-avatar img,
.club-member-avatar img,
.club-feed-avatar img {
  position: relative;
  z-index: 2;
}

.member-profile-avatar span,
.club-member-avatar span,
.club-feed-avatar span {
  position: relative;
  z-index: 1;
}

/* Commentaires fil du club */
.club-comments-block {
  margin-top: 16px;
  border-top: 1px solid rgba(9,35,74,.08);
  padding-top: 14px;
}

.club-comments-list {
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
}

.club-comment {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 10px;
  align-items: start;
}

.club-feed-avatar.tiny {
  width: 34px;
  height: 34px;
  flex-basis: 34px;
  font-size: 14px;
}

.club-comment > div:last-child {
  background: rgba(247,249,244,.86);
  border: 1px solid rgba(9,35,74,.08);
  border-radius: 16px;
  padding: 9px 11px;
}

.club-comment strong {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  color: #082957;
  font-size: 14px;
}

.club-comment strong span {
  display: inline-flex;
  border-radius: 999px;
  background: rgba(52,114,31,.10);
  color: #245a17;
  padding: 3px 6px;
  font-size: 11px;
  font-weight: 950;
}

.club-comment p {
  margin: 4px 0 3px;
  color: #344760;
  line-height: 1.45;
}

.club-comment small {
  color: #718196;
  font-size: 12px;
  font-weight: 750;
}

.club-comment-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
}

.club-comment-form input {
  border: 1px solid rgba(9,35,74,.12);
  border-radius: 999px;
  padding: 11px 13px;
  font: inherit;
  background: #fff;
}

.club-comment-form button {
  border: 0;
  border-radius: 999px;
  background: #123f82;
  color: #fff;
  font-weight: 950;
  padding: 0 15px;
  cursor: pointer;
}

@media (max-width: 560px) {
  .club-comment-form {
    grid-template-columns: 1fr;
  }

  .club-comment-form button {
    padding: 11px 15px;
  }
}

/* Nom public / pseudo membre */
.member-profile-grid label small {
  line-height: 1.35;
}

.member-profile-grid input[name="public_display_name"] {
  font-weight: 900;
  color: #082957;
}

/* Discussion publication séparée */
.club-comments-summary {
  margin-top: 14px;
  border-top: 1px solid rgba(9,35,74,.08);
  padding-top: 12px;
}

.club-comments-summary a {
  display: inline-flex;
  text-decoration: none;
  border-radius: 999px;
  background: rgba(18,63,130,.08);
  color: #123f82;
  padding: 9px 12px;
  font-weight: 950;
}

.discussion-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(52,114,31,.10), transparent 32%),
    radial-gradient(circle at top right, rgba(18,63,130,.10), transparent 34%),
    #f4f7f1;
}

.discussion-shell {
  width: min(980px, calc(100% - 24px));
  margin: 18px auto 42px;
  display: grid;
  gap: 18px;
}

.discussion-main-post h1 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: clamp(28px, 4vw, 52px);
  line-height: 1.05;
  margin: 16px 0 10px;
}

.discussion-write-card,
.discussion-comments-card {
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 26px;
  box-shadow: 0 16px 44px rgba(9,35,74,.08);
  padding: 18px;
}

.discussion-write-card h2,
.discussion-comments-card h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  margin: 0 0 12px;
  font-size: 26px;
}

.discussion-write-card form {
  display: grid;
  gap: 10px;
}

.discussion-write-card textarea {
  width: 100%;
  border: 1px solid rgba(9,35,74,.12);
  border-radius: 18px;
  padding: 13px;
  font: inherit;
  resize: vertical;
}

.discussion-write-card button,
.discussion-reply-box button {
  border: 0;
  border-radius: 999px;
  background: #123f82;
  color: #fff;
  padding: 10px 15px;
  font-weight: 950;
  cursor: pointer;
}

.discussion-write-card button {
  justify-self: end;
}

.discussion-comments-level {
  display: grid;
  gap: 12px;
}

.discussion-comments-level.depth-1,
.discussion-comments-level.depth-2,
.discussion-comments-level.depth-3,
.discussion-comments-level.depth-4,
.discussion-comments-level.depth-5,
.discussion-comments-level.depth-6 {
  margin-left: clamp(18px, 4vw, 42px);
  margin-top: 10px;
  border-left: 2px solid rgba(18,63,130,.10);
  padding-left: 12px;
}

.discussion-comment {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 10px;
  align-items: start;
}

.discussion-avatar {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #123f82, #34721f);
  color: #fff;
  font-weight: 950;
}

.discussion-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.discussion-comment-body {
  background: rgba(247,249,244,.9);
  border: 1px solid rgba(9,35,74,.08);
  border-radius: 18px;
  padding: 11px 13px;
}

.discussion-comment-body strong {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
  color: #082957;
}

.discussion-comment-body strong span {
  border-radius: 999px;
  background: rgba(52,114,31,.10);
  color: #245a17;
  padding: 3px 6px;
  font-size: 11px;
  font-weight: 950;
}

.discussion-comment-body p {
  color: #344760;
  line-height: 1.5;
  margin: 6px 0;
}

.discussion-comment-body small {
  color: #718196;
  font-size: 12px;
  font-weight: 750;
}

.discussion-reply-box {
  margin-top: 8px;
}

.discussion-reply-box summary {
  cursor: pointer;
  color: #123f82;
  font-weight: 950;
  font-size: 13px;
}

.discussion-reply-box form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  margin-top: 8px;
}

.discussion-reply-box input {
  border: 1px solid rgba(9,35,74,.12);
  border-radius: 999px;
  padding: 10px 12px;
  font: inherit;
}

@media (max-width: 620px) {
  .discussion-comments-level.depth-1,
  .discussion-comments-level.depth-2,
  .discussion-comments-level.depth-3,
  .discussion-comments-level.depth-4,
  .discussion-comments-level.depth-5,
  .discussion-comments-level.depth-6 {
    margin-left: 10px;
    padding-left: 8px;
  }

  .discussion-reply-box form {
    grid-template-columns: 1fr;
  }
}

/* Discussion : formulaires pliables propres */
.discussion-main-comment-box,
.discussion-reply-box {
  margin: 0;
}

.discussion-main-comment-box > summary,
.discussion-reply-box > summary {
  list-style: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  border-radius: 999px;
  background: rgba(18,63,130,.08);
  color: #123f82;
  border: 1px solid rgba(18,63,130,.14);
  padding: 9px 13px;
  font-weight: 950;
  cursor: pointer;
  user-select: none;
}

.discussion-main-comment-box > summary::-webkit-details-marker,
.discussion-reply-box > summary::-webkit-details-marker {
  display: none;
}

.discussion-main-comment-box[open] > summary,
.discussion-reply-box[open] > summary {
  background: rgba(52,114,31,.10);
  color: #245a17;
  border-color: rgba(52,114,31,.22);
  margin-bottom: 10px;
}

.discussion-main-comment-box > summary::before,
.discussion-reply-box > summary::before {
  content: "↩";
  margin-right: 7px;
  font-weight: 950;
}

.discussion-main-comment-box form {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.discussion-main-comment-box textarea {
  width: 100%;
  border: 1px solid rgba(9,35,74,.12);
  border-radius: 18px;
  padding: 13px;
  font: inherit;
  resize: vertical;
  background: #fff;
}

.discussion-main-comment-box button {
  justify-self: end;
  border: 0;
  border-radius: 999px;
  background: #123f82;
  color: #fff;
  padding: 10px 15px;
  font-weight: 950;
  cursor: pointer;
}

.discussion-reply-box form {
  margin-top: 10px;
  padding: 10px;
  border-radius: 16px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(9,35,74,.08);
}

/* On neutralise l'ancien style trop visible du bloc "ajouter un commentaire" */
.discussion-write-card h2 {
  display: none;
}

/* Discussion : formulaires pliables propres */
.discussion-main-comment-box,
.discussion-reply-box {
  margin: 0;
}

.discussion-main-comment-box > summary,
.discussion-reply-box > summary {
  list-style: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  border-radius: 999px;
  background: rgba(18,63,130,.08);
  color: #123f82;
  border: 1px solid rgba(18,63,130,.14);
  padding: 9px 13px;
  font-weight: 950;
  cursor: pointer;
  user-select: none;
}

.discussion-main-comment-box > summary::-webkit-details-marker,
.discussion-reply-box > summary::-webkit-details-marker {
  display: none;
}

.discussion-main-comment-box[open] > summary,
.discussion-reply-box[open] > summary {
  background: rgba(52,114,31,.10);
  color: #245a17;
  border-color: rgba(52,114,31,.22);
  margin-bottom: 10px;
}

.discussion-main-comment-box > summary::before,
.discussion-reply-box > summary::before {
  content: "↩";
  margin-right: 7px;
  font-weight: 950;
}

.discussion-main-comment-box form {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.discussion-main-comment-box textarea {
  width: 100%;
  border: 1px solid rgba(9,35,74,.12);
  border-radius: 18px;
  padding: 13px;
  font: inherit;
  resize: vertical;
  background: #fff;
}

.discussion-main-comment-box button {
  justify-self: end;
  border: 0;
  border-radius: 999px;
  background: #123f82;
  color: #fff;
  padding: 10px 15px;
  font-weight: 950;
  cursor: pointer;
}

.discussion-reply-box form {
  margin-top: 10px;
  padding: 10px;
  border-radius: 16px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(9,35,74,.08);
}

/* On neutralise l'ancien style trop visible du bloc "ajouter un commentaire" */
.discussion-write-card h2 {
  display: none;
}

/* Signalement commentaires */
.discussion-comment-actions {
  margin-top: 8px;
}

.discussion-comment-actions form {
  margin: 0;
}

.discussion-comment-actions button {
  border: 1px solid rgba(232,148,18,.18);
  border-radius: 999px;
  background: rgba(232,148,18,.08);
  color: #7a4a00;
  padding: 6px 9px;
  font-weight: 900;
  font-size: 12px;
  cursor: pointer;
}

/* Notifications membre */
.notifications-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(52,114,31,.10), transparent 32%),
    radial-gradient(circle at top right, rgba(18,63,130,.10), transparent 34%),
    #f4f7f1;
}

.notifications-shell {
  width: min(980px, calc(100% - 24px));
  margin: 18px auto 42px;
  display: grid;
  gap: 16px;
}

.notifications-header,
.notification-card {
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 26px;
  box-shadow: 0 16px 44px rgba(9,35,74,.08);
  padding: 22px;
}

.notifications-header h1 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1.04;
  margin: 0 0 10px;
}

.notifications-header p,
.notification-card p {
  color: #42546c;
  line-height: 1.6;
}

.notifications-list {
  display: grid;
  gap: 14px;
}

.notification-card.unread {
  border-color: rgba(18,63,130,.22);
  background:
    radial-gradient(circle at top left, rgba(18,63,130,.08), transparent 34%),
    #fff;
}

.notification-card.read {
  opacity: .86;
}

.notification-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.notification-top span {
  display: inline-flex;
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(18,63,130,.08);
  color: #123f82;
  font-weight: 950;
  font-size: 12px;
}

.notification-top small {
  color: #718196;
  font-weight: 800;
}

.notification-card h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: clamp(22px, 2vw, 32px);
  margin: 0 0 8px;
}

.notification-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  align-items: center;
  margin-top: 14px;
}

.notification-actions a,
.notification-actions button,
.notification-read-label {
  border: 0;
  border-radius: 999px;
  padding: 9px 12px;
  font-weight: 950;
  text-decoration: none;
}

.notification-actions a {
  background: #123f82;
  color: #fff;
}

.notification-actions button {
  background: rgba(52,114,31,.11);
  color: #245a17;
  cursor: pointer;
}

.notification-actions form {
  margin: 0;
}

.notification-read-label {
  background: rgba(9,35,74,.07);
  color: #526782;
}

/* Messagerie privée membres */
.messages-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(52,114,31,.10), transparent 32%),
    radial-gradient(circle at top right, rgba(18,63,130,.10), transparent 34%),
    #f4f7f1;
}

.messages-shell {
  width: min(1280px, calc(100% - 24px));
  margin: 18px auto 42px;
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.messages-sidebar,
.messages-panel,
.messages-new-card,
.messages-empty-panel {
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 26px;
  box-shadow: 0 16px 44px rgba(9,35,74,.08);
}

.messages-sidebar {
  padding: 14px;
  display: grid;
  gap: 14px;
}

.messages-new-card {
  padding: 18px;
  box-shadow: none;
}

.messages-new-card h1 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  margin: 0 0 8px;
  font-size: 32px;
}

.messages-new-card p {
  color: #526782;
  line-height: 1.5;
}

.messages-new-card summary {
  display: inline-flex;
  border-radius: 999px;
  background: #123f82;
  color: #fff;
  padding: 10px 14px;
  font-weight: 950;
  cursor: pointer;
}

.messages-new-card form {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.messages-new-card label {
  display: grid;
  gap: 6px;
  color: #082957;
  font-weight: 900;
}

.messages-new-card select,
.messages-new-card textarea,
.message-reply-form textarea {
  width: 100%;
  border: 1px solid rgba(9,35,74,.12);
  border-radius: 16px;
  padding: 12px;
  font: inherit;
  background: #fff;
}

.messages-new-card button,
.message-reply-form button {
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #34721f, #245a17);
  color: #fff;
  font-weight: 950;
  padding: 11px 16px;
  cursor: pointer;
}

.conversation-list {
  display: grid;
  gap: 8px;
}

.conversation-item {
  position: relative;
  display: grid;
  grid-template-columns: 46px 1fr auto;
  gap: 10px;
  align-items: center;
  border-radius: 18px;
  padding: 10px;
  text-decoration: none;
  color: #082957;
  background: rgba(247,249,244,.76);
  border: 1px solid rgba(9,35,74,.07);
}

.conversation-item.active {
  background: rgba(18,63,130,.08);
  border-color: rgba(18,63,130,.20);
}

.conversation-item strong {
  display: block;
}

.conversation-item span {
  display: block;
  color: #61718a;
  font-size: 13px;
  font-weight: 750;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.conversation-item em {
  display: grid;
  place-items: center;
  min-width: 24px;
  height: 24px;
  border-radius: 999px;
  background: #123f82;
  color: #fff;
  font-style: normal;
  font-size: 12px;
  font-weight: 950;
}

.message-avatar {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #123f82, #34721f);
  color: #fff;
  font-weight: 950;
}

.message-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.messages-panel {
  min-height: 640px;
  display: grid;
  grid-template-rows: auto 1fr auto;
  overflow: hidden;
}

.messages-empty-panel {
  padding: 32px;
  box-shadow: none;
}

.messages-empty-panel h2,
.messages-thread-head h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  margin: 0 0 6px;
  font-size: 30px;
}

.messages-thread-head {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 18px;
  border-bottom: 1px solid rgba(9,35,74,.08);
  background: rgba(255,255,255,.82);
}

.messages-thread-head p {
  margin: 0;
  color: #61718a;
  font-weight: 800;
}

.messages-thread {
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow-y: auto;
  max-height: 620px;
}

.private-message {
  width: fit-content;
  max-width: min(640px, 82%);
  border-radius: 20px;
  padding: 11px 13px;
}

.private-message.mine {
  align-self: flex-end;
  background: #123f82;
  color: #fff;
  border-bottom-right-radius: 6px;
}

.private-message.theirs {
  align-self: flex-start;
  background: rgba(247,249,244,.95);
  color: #082957;
  border: 1px solid rgba(9,35,74,.08);
  border-bottom-left-radius: 6px;
}

.private-message p {
  margin: 0 0 5px;
  line-height: 1.45;
}

.private-message small {
  display: block;
  opacity: .72;
  font-size: 12px;
}

.message-reply-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  padding: 14px;
  border-top: 1px solid rgba(9,35,74,.08);
  background: rgba(255,255,255,.9);
}

@media (max-width: 900px) {
  .messages-shell {
    grid-template-columns: 1fr;
  }

  .messages-panel {
    min-height: 520px;
  }

  .message-reply-form {
    grid-template-columns: 1fr;
  }
}

/* Signalement message privé */
.private-message-report {
  margin-top: 7px;
}

.private-message-report button {
  border: 1px solid rgba(232,148,18,.18);
  border-radius: 999px;
  background: rgba(232,148,18,.08);
  color: #7a4a00;
  padding: 6px 9px;
  font-weight: 900;
  font-size: 12px;
  cursor: pointer;
}

.private-message.mine .private-message-report {
  display: none;
}

/* Annuaire membres */
.member-directory-page,
.public-profile-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(52,114,31,.10), transparent 32%),
    radial-gradient(circle at top right, rgba(18,63,130,.10), transparent 34%),
    #f4f7f1;
}

.member-directory-shell,
.public-profile-shell {
  width: min(1220px, calc(100% - 24px));
  margin: 18px auto 42px;
  display: grid;
  gap: 18px;
}

.member-directory-header,
.public-profile-hero,
.public-profile-section,
.member-directory-card {
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 26px;
  box-shadow: 0 16px 44px rgba(9,35,74,.08);
}

.member-directory-header {
  padding: clamp(22px, 4vw, 42px);
}

.member-directory-header h1,
.public-profile-hero h1,
.public-profile-section h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  line-height: 1.05;
  margin: 0 0 10px;
}

.member-directory-header h1,
.public-profile-hero h1 {
  font-size: clamp(34px, 4vw, 58px);
}

.member-directory-header p,
.public-profile-hero p,
.public-profile-section p {
  color: #526782;
  line-height: 1.58;
}

.member-directory-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px auto;
  gap: 10px;
  margin-top: 18px;
}

.member-directory-search input,
.member-directory-search select {
  border: 1px solid rgba(9,35,74,.12);
  border-radius: 999px;
  padding: 12px 14px;
  font: inherit;
  background: #fff;
}

.member-directory-search button {
  border: 0;
  border-radius: 999px;
  background: #123f82;
  color: #fff;
  font-weight: 950;
  padding: 0 18px;
  cursor: pointer;
}

.member-directory-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.member-directory-card {
  padding: 18px;
  display: grid;
  grid-template-columns: 74px 1fr;
  gap: 14px;
  align-items: start;
}

.member-directory-avatar,
.public-profile-avatar {
  border-radius: 999px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #123f82, #34721f);
  color: #fff;
  font-weight: 950;
}

.member-directory-avatar {
  width: 74px;
  height: 74px;
  font-size: 28px;
}

.public-profile-avatar {
  width: 156px;
  height: 156px;
  font-size: 62px;
  box-shadow: 0 20px 46px rgba(9,35,74,.16);
}

.member-directory-avatar img,
.public-profile-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.member-directory-info h2 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  font-size: 24px;
  margin: 0 0 6px;
}

.member-directory-info p {
  color: #61718a;
  font-weight: 800;
}

.member-directory-actions,
.public-profile-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.member-directory-actions a,
.public-profile-actions a {
  text-decoration: none;
  border-radius: 999px;
  background: #123f82;
  color: #fff;
  padding: 9px 12px;
  font-weight: 950;
  font-size: 13px;
}

.public-profile-actions a.secondary {
  background: rgba(18,63,130,.08);
  color: #123f82;
}

.public-profile-hero {
  padding: clamp(22px, 4vw, 42px);
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 24px;
  align-items: center;
}

.public-profile-section {
  padding: clamp(22px, 4vw, 34px);
}

.public-dog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.public-dog-card {
  background: rgba(247,249,244,.84);
  border: 1px solid rgba(9,35,74,.08);
  border-radius: 20px;
  padding: 16px;
}

.public-dog-card h3 {
  font-family: Georgia, "Times New Roman", serif;
  color: #082957;
  margin: 0 0 8px;
  font-size: 24px;
}

@media (max-width: 980px) {
  .member-directory-grid,
  .public-dog-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .member-directory-search {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .member-directory-grid,
  .public-dog-grid,
  .public-profile-hero {
    grid-template-columns: 1fr;
  }

  .public-profile-avatar {
    width: 128px;
    height: 128px;
  }

  .member-directory-card {
    grid-template-columns: 64px 1fr;
  }
}

/* Correction globale avatars : si une vraie photo existe, aucun fond vert ne doit apparaître derrière */
.member-profile-avatar:has(img),
.club-member-avatar:has(img),
.club-feed-avatar:has(img),
.member-directory-avatar:has(img),
.public-profile-avatar:has(img),
.message-avatar:has(img),
.discussion-avatar:has(img) {
  background: #fff !important;
}

.member-profile-avatar img,
.club-member-avatar img,
.club-feed-avatar img,
.member-directory-avatar img,
.public-profile-avatar img,
.message-avatar img,
.discussion-avatar img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  background: #fff !important;
  position: relative;
  z-index: 2;
}

/* Sécurité : les initiales restent derrière, mais ne doivent pas passer au-dessus d’une photo */
.member-profile-avatar span,
.club-member-avatar span,
.club-feed-avatar span,
.member-directory-avatar span,
.public-profile-avatar span,
.message-avatar span,
.discussion-avatar span {
  position: relative;
  z-index: 1;
}

/* Sécurité supplémentaire pour les avatars nouvellement créés */
.member-directory-avatar,
.public-profile-avatar,
.message-avatar,
.discussion-avatar {
  position: relative;
}

/* Vrais contacts membres */
.contacts-section {
  display: grid;
  gap: 14px;
}

.member-directory-actions form,
.public-profile-actions form {
  margin: 0;
  display: inline-flex;
  gap: 8px;
  flex-wrap: wrap;
}

.member-directory-actions button,
.public-profile-actions button {
  border: 0;
  border-radius: 999px;
  background: #123f82;
  color: #fff;
  padding: 9px 12px;
  font-weight: 950;
  cursor: pointer;
  font-size: 13px;
}

.member-directory-actions button[value="remove"],
.member-directory-actions button[value="decline"] {
  background: rgba(154,28,28,.10);
  color: #9b1c1c;
}

.contact-pending-label {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: rgba(232,148,18,.11);
  color: #7a4a00;
  padding: 9px 12px;
  font-weight: 950;
  font-size: 13px;
}

/* Messagerie : arrivée automatique des nouveaux messages */
.private-message[data-message-id] {
  animation: messageSoftAppear .18s ease-out;
}

@keyframes messageSoftAppear {
  from {
    opacity: .25;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Messagerie : arrivée automatique des nouveaux messages */
.private-message[data-message-id] {
  animation: messageSoftAppear .18s ease-out;
}

@keyframes messageSoftAppear {
  from {
    opacity: .25;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Messagerie : fil confortable */
.messages-panel {
  min-height: calc(100vh - 150px);
}

.messages-thread {
  scroll-behavior: smooth;
  min-height: 360px;
}

.message-reply-form {
  position: sticky;
  bottom: 0;
  z-index: 5;
}

/* Messagerie : fil confortable */
.messages-panel {
  min-height: calc(100vh - 150px);
}

.messages-thread {
  scroll-behavior: smooth;
  min-height: 360px;
}

.message-reply-form {
  position: sticky;
  bottom: 0;
  z-index: 5;
}

/* Messagerie : titre de liste conversations */
.conversation-list-title {
  margin: 2px 4px 6px;
  color: #082957;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 22px;
}

#messages-thread-bottom {
  width: 100%;
  height: 1px;
}

/* Confidentialité profil membre */
.member-privacy-box {
  margin-top: 18px;
  padding: 18px;
  border-radius: 22px;
  background: rgba(247,249,244,.82);
  border: 1px solid rgba(9,35,74,.08);
  display: grid;
  gap: 10px;
}

.member-privacy-box h2 {
  margin: 0 0 4px;
  color: #082957;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 26px;
}

.member-privacy-box .checkline {
  background: #fff;
  border: 1px solid rgba(9,35,74,.08);
  border-radius: 16px;
  padding: 10px 12px;
}

/* Dashboard membre : cartes bientôt */
.member-dash-card.is-disabled {
  opacity: .78;
  background:
    radial-gradient(circle at top left, rgba(232,148,18,.08), transparent 34%),
    rgba(255,255,255,.92);
}

.member-dash-soon {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 9px 13px;
  background: rgba(232,148,18,.12);
  color: #7a4a00;
  font-weight: 950;
  font-size: 13px;
}

/* Dashboard membre : cartes bientôt */
.member-dash-card.is-disabled {
  opacity: .78;
  background:
    radial-gradient(circle at top left, rgba(232,148,18,.08), transparent 34%),
    rgba(255,255,255,.92);
}

.member-dash-soon {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 9px 13px;
  background: rgba(232,148,18,.12);
  color: #7a4a00;
  font-weight: 950;
  font-size: 13px;
}

/* Dashboard membre : compteurs */
.member-dash-counter {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 10px;
  margin: 4px 0 10px;
  background: rgba(18,63,130,.08);
  color: #123f82;
  font-weight: 950;
  font-size: 12px;
}

/* Dashboard membre : priorités */
.member-dashboard-priority {
  margin-top: 18px;
  background:
    radial-gradient(circle at top left, rgba(18,63,130,.08), transparent 34%),
    rgba(255,255,255,.96);
  border: 1px solid rgba(9,35,74,.10);
  border-radius: 26px;
  box-shadow: 0 16px 44px rgba(9,35,74,.08);
  padding: clamp(18px, 3vw, 28px);
  display: grid;
  gap: 14px;
}

.member-dashboard-priority h2 {
  margin: 0;
  color: #082957;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(26px, 3vw, 38px);
}

.priority-ok {
  margin: 0;
  width: fit-content;
  border-radius: 999px;
  padding: 10px 14px;
  background: rgba(52,114,31,.11);
  color: #245a17;
  font-weight: 950;
}

.priority-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.priority-actions a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  border-radius: 18px;
  background: #123f82;
  color: #fff;
  padding: 12px 14px;
  font-weight: 900;
}

.priority-actions a strong {
  display: grid;
  place-items: center;
  min-width: 30px;
  height: 30px;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
}

.priority-actions a span {
  font-size: 14px;
}

/* === BODY ACCUEIL V26 V14 PRUDENT - DEBUT === */
/*
  Ciblage strict :
  - uniquement l'accueil
  - uniquement le body sous le hero
  - vraies classes actuelles : home-body-v14 / v14-*
  - ne touche pas au header, hero, logo, pages internes
*/

.home-page > .home-body-v14{
  width: calc(100% - 18px) !important;
  max-width: 1420px !important;
  margin: 0 auto !important;
  padding: 10px 0 14px !important;
  background: linear-gradient(180deg, #f8fbf5 0%, #ffffff 52%, #f4f8f1 100%) !important;
}

/* Grilles principales : plus serrées, plus proches de la maquette */
.home-page > .home-body-v14 > .v14-board{
  display: grid !important;
  grid-template-columns: 1.05fr 1.25fr .95fr !important;
  gap: 10px !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  align-items: stretch !important;
}

.home-page > .home-body-v14 > .v14-focus-grid{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  align-items: stretch !important;
}

.home-page > .home-body-v14 > .v14-partner-grid{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
  margin: 0 !important;
  padding: 0 !important;
  align-items: stretch !important;
}

/* Cartes : compactes, propres, sans grosses bandes */
.home-page .home-body-v14 .v14-card,
.home-page .home-body-v14 .v14-feature,
.home-page .home-body-v14 .v14-wide{
  border-radius: 16px !important;
  border: 1px solid rgba(9,35,74,.09) !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 9px 22px rgba(9,35,74,.075) !important;
  overflow: hidden !important;
  margin: 0 !important;
}

.home-page .home-body-v14 .v14-card::before,
.home-page .home-body-v14 .v14-feature::before,
.home-page .home-body-v14 .v14-wide::before{
  display: none !important;
  content: none !important;
}

/* En-têtes */
.home-page .home-body-v14 .v14-card-head{
  padding: 14px 14px 8px !important;
  margin: 0 !important;
  border-bottom: 1px solid rgba(9,35,74,.055) !important;
}

.home-page .home-body-v14 .v14-card-head h2{
  margin: 0 !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: clamp(20px, 1.35vw, 25px) !important;
  line-height: 1.08 !important;
  color: #082957 !important;
  letter-spacing: -.025em !important;
}

/* Événements */
.home-page .home-body-v14 .v14-events,
.home-page .home-body-v14 .v14-regions,
.home-page .home-body-v14 .v14-feed{
  padding: 0 !important;
}

.home-page .home-body-v14 .v14-event-list{
  display: grid !important;
  gap: 8px !important;
  padding: 10px 12px 10px !important;
}

.home-page .home-body-v14 .v14-event-row{
  display: grid !important;
  grid-template-columns: 56px minmax(0,1fr) 76px !important;
  gap: 9px !important;
  align-items: center !important;
  min-height: 68px !important;
  padding: 8px !important;
  border-radius: 13px !important;
  background: #ffffff !important;
  border: 1px solid rgba(9,35,74,.075) !important;
  text-decoration: none !important;
}

.home-page .home-body-v14 .v14-date{
  width: 52px !important;
  min-height: 52px !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, #082957, #123f82) !important;
  color: #fff !important;
  display: grid !important;
  place-items: center !important;
  text-align: center !important;
}

.home-page .home-body-v14 .v14-date strong{
  font-size: 24px !important;
  line-height: .85 !important;
}

.home-page .home-body-v14 .v14-date em{
  margin-top: 2px !important;
  font-size: 9px !important;
  font-style: normal !important;
  font-weight: 950 !important;
}

.home-page .home-body-v14 .v14-event-copy strong{
  display: block !important;
  font-size: 13.5px !important;
  line-height: 1.14 !important;
  color: #082957 !important;
}

.home-page .home-body-v14 .v14-event-copy small{
  display: block !important;
  margin-top: 4px !important;
  font-size: 11.2px !important;
  line-height: 1.22 !important;
  color: #52657d !important;
}

.home-page .home-body-v14 .v14-event-row img{
  width: 76px !important;
  height: 52px !important;
  border-radius: 10px !important;
  object-fit: cover !important;
}

/* Régions */
.home-page .home-body-v14 .v14-region-list{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  gap: 8px !important;
  padding: 10px 12px 10px !important;
}

.home-page .home-body-v14 .v14-region{
  position: relative !important;
  min-height: 134px !important;
  border-radius: 13px !important;
  overflow: hidden !important;
  text-decoration: none !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  background: #082957 !important;
}

.home-page .home-body-v14 .v14-region img{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  opacity: 1 !important;
  filter: saturate(1.06) contrast(1.03) !important;
}

.home-page .home-body-v14 .v14-region::after{
  content: "" !important;
  position: absolute !important;
  inset: 38% 0 0 !important;
  background: linear-gradient(0deg, rgba(5,24,55,.78), rgba(5,24,55,0)) !important;
}

.home-page .home-body-v14 .v14-region strong,
.home-page .home-body-v14 .v14-region span,
.home-page .home-body-v14 .v14-region em{
  position: relative !important;
  z-index: 2 !important;
  padding-left: 11px !important;
  padding-right: 11px !important;
}

.home-page .home-body-v14 .v14-region strong{
  color: #fff !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 17px !important;
  line-height: 1.05 !important;
  margin: 0 0 3px !important;
}

.home-page .home-body-v14 .v14-region span{
  color: rgba(255,255,255,.86) !important;
  font-size: 11.2px !important;
  line-height: 1.22 !important;
}

.home-page .home-body-v14 .v14-region em{
  color: #f2b34b !important;
  font-style: normal !important;
  font-size: 10.5px !important;
  font-weight: 950 !important;
  margin: 6px 0 10px !important;
}

/* Fil du club */
.home-page .home-body-v14 .v14-feed-list{
  display: grid !important;
  gap: 8px !important;
  padding: 10px 12px 10px !important;
}

.home-page .home-body-v14 .v14-feed-row{
  display: grid !important;
  grid-template-columns: 32px minmax(0,1fr) 64px !important;
  gap: 8px !important;
  align-items: center !important;
  min-height: 68px !important;
  padding: 8px !important;
  border-radius: 13px !important;
  background: #ffffff !important;
  border: 1px solid rgba(9,35,74,.075) !important;
  text-decoration: none !important;
}

.home-page .home-body-v14 .v14-avatar{
  width: 30px !important;
  height: 30px !important;
  border-radius: 999px !important;
  display: grid !important;
  place-items: center !important;
  font-size: 13px !important;
  font-weight: 950 !important;
  background: #eef6e9 !important;
  color: #34721f !important;
}

.home-page .home-body-v14 .v14-feed-row strong{
  display: block !important;
  font-size: 12.2px !important;
  line-height: 1.15 !important;
  color: #082957 !important;
}

.home-page .home-body-v14 .v14-feed-row strong em{
  font-size: 10px !important;
  font-style: normal !important;
  color: #7b8798 !important;
}

.home-page .home-body-v14 .v14-feed-row small{
  display: block !important;
  margin-top: 3px !important;
  font-size: 11px !important;
  line-height: 1.22 !important;
  color: #52657d !important;
}

.home-page .home-body-v14 .v14-feed-row img{
  width: 64px !important;
  height: 46px !important;
  border-radius: 9px !important;
  object-fit: cover !important;
}

/* Liens */
.home-page .home-body-v14 .v14-link{
  margin: 0 12px 12px !important;
  min-height: 34px !important;
  padding: 8px 13px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
}

/* Cartes focus */
.home-page .home-body-v14 .v14-feature{
  display: grid !important;
  grid-template-columns: minmax(0,1fr) 42% !important;
  min-height: 190px !important;
}

.home-page .home-body-v14 .v14-feature-copy{
  padding: 17px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

.home-page .home-body-v14 .v14-feature h3,
.home-page .home-body-v14 .v14-wide h3{
  margin: 0 !important;
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: clamp(20px, 1.35vw, 25px) !important;
  line-height: 1.08 !important;
  color: #082957 !important;
}

.home-page .home-body-v14 .v14-feature p,
.home-page .home-body-v14 .v14-wide p{
  margin: 8px 0 11px !important;
  font-size: 13px !important;
  line-height: 1.34 !important;
  color: #52657d !important;
}

.home-page .home-body-v14 .v14-feature > img{
  width: 100% !important;
  height: 100% !important;
  min-height: 190px !important;
  object-fit: cover !important;
}

.home-page .home-body-v14 .v14-feature a,
.home-page .home-body-v14 .v14-wide a{
  min-height: 34px !important;
  padding: 8px 14px !important;
  font-size: 11px !important;
  border-radius: 999px !important;
}

/* Passerelles */
.home-page .home-body-v14 .v14-wide{
  display: grid !important;
  grid-template-columns: minmax(0,1fr) 36% !important;
  gap: 12px !important;
  align-items: center !important;
  min-height: 120px !important;
  padding: 13px !important;
}

.home-page .home-body-v14 .v14-wide img{
  width: 100% !important;
  height: 96px !important;
  object-fit: cover !important;
  border-radius: 12px !important;
}

/* Footer légèrement rapproché sans toucher au style général */
.site-footer{
  margin-top: 8px !important;
}

/* Responsive */
@media(max-width: 1180px){
  .home-page > .home-body-v14 > .v14-board{
    grid-template-columns: 1fr 1fr !important;
  }

  .home-page > .home-body-v14 > .v14-board > .v14-feed{
    grid-column: 1 / -1 !important;
  }

  .home-page > .home-body-v14 > .v14-focus-grid{
    grid-template-columns: 1fr 1fr !important;
  }

  .home-page > .home-body-v14 > .v14-focus-grid > .v14-blue{
    grid-column: 1 / -1 !important;
  }
}

@media(max-width: 820px){
  .home-page > .home-body-v14{
    width: calc(100% - 14px) !important;
    padding-top: 8px !important;
  }

  .home-page > .home-body-v14 > .v14-board,
  .home-page > .home-body-v14 > .v14-focus-grid,
  .home-page > .home-body-v14 > .v14-partner-grid{
    grid-template-columns: 1fr !important;
    gap: 9px !important;
  }

  .home-page > .home-body-v14 > .v14-focus-grid > .v14-blue{
    grid-column: auto !important;
  }

  .home-page .home-body-v14 .v14-region-list{
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  }

  .home-page .home-body-v14 .v14-feature,
  .home-page .home-body-v14 .v14-wide{
    grid-template-columns: 1fr !important;
  }

  .home-page .home-body-v14 .v14-feature > img{
    height: 180px !important;
    min-height: 180px !important;
  }

  .home-page .home-body-v14 .v14-wide img{
    height: 145px !important;
  }
}

@media(max-width: 520px){
  .home-page .home-body-v14 .v14-event-row,
  .home-page .home-body-v14 .v14-feed-row{
    grid-template-columns: 52px minmax(0,1fr) !important;
  }

  .home-page .home-body-v14 .v14-event-row img,
  .home-page .home-body-v14 .v14-feed-row img{
    display: none !important;
  }

  .home-page .home-body-v14 .v14-region-list{
    grid-template-columns: 1fr !important;
  }
}

/* === BODY ACCUEIL V26 V14 PRUDENT - FIN === */

/* === CORRECTION BOUTON MODIFIER FIL DU CLUB === */
.club-post-actions a.button-small,
.discussion-comment-actions a.button-small {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 8px 13px;
  background: #f7f9f4;
  border: 1px solid rgba(9,35,74,.12);
  color: #082957;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
}

.club-post-actions a.button-small:hover,
.discussion-comment-actions a.button-small:hover {
  background: #eef6e9;
  color: #34721f;
}
/* === FIN CORRECTION BOUTON MODIFIER FIL DU CLUB === */
