*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--navy:#060F1E;--navy-mid:#0B1F3A;--blue:#0B3C5D;--cyan:#1A9FD6;--cyan-l:#4BB8E8;--green:#00FFB2;--green-dim:rgba(0,255,178,0.12);--white:#fff;--gray:#F0F4F8;--text:#1A2B3C;--muted:#607080;--border:rgba(11,60,93,0.1);--fd:'Orbitron',monospace;--fb:'Poppins',sans-serif;--tr:0.25s ease;--r-sm:6px;--r-md:10px;--r-lg:16px}
html{scroll-behavior:smooth}body{font-family:var(--fb);color:var(--text);background:var(--white);overflow-x:hidden;line-height:1.6}
a{text-decoration:none;color:inherit}ul{list-style:none}button{cursor:pointer;font-family:var(--fb)}
.container{max-width:1100px;margin:0 auto;padding:0 2rem}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.6rem;border-radius:var(--r-sm);font-size:.88rem;font-weight:500;border:none;transition:var(--tr);cursor:pointer}
.btn-primary{background:var(--cyan);color:#fff}.btn-primary:hover{background:var(--cyan-l);transform:translateY(-2px);box-shadow:0 6px 20px rgba(26,159,214,.35)}
.btn-white{background:#fff;color:var(--navy)}.btn-white:hover{background:var(--green);color:var(--navy)}
.btn-whatsapp{background:#25D366;color:#fff}.btn-whatsapp:hover{background:#1db954}
.btn-outline{background:transparent;color:var(--cyan);border:1px solid var(--cyan)}.btn-outline:hover{background:var(--cyan);color:#fff}
/* HERO */
.page-hero{background:var(--navy);padding:9rem 2rem 5rem;position:relative;overflow:hidden}
.hero-orb{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(26,159,214,.12) 0%,transparent 70%);top:-100px;right:-100px;pointer-events:none}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(26,159,214,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(26,159,214,.05) 1px,transparent 1px);background-size:60px 60px}
.page-hero{background: linear-gradient(135deg, rgba(6,15,30,0.85) 0%, rgba(11,60,93,0.75) 100%), url('../images/blog.jpg'); background-size: cover; background-position: center;}
.page-hero-content{max-width:750px;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:rgba(255,255,255,.4);margin-bottom:1.5rem}.breadcrumb a{color:var(--cyan)}.breadcrumb span{color:rgba(255,255,255,.25)}
.page-hero h1{font-family:var(--fd);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:900;color:#fff;line-height:1.15;margin-bottom:1.25rem}.page-hero h1 em{color:var(--green);font-style:normal}
.page-hero p{color:rgba(255,255,255,.6);font-size:1rem;line-height:1.8;max-width:580px;margin-bottom:2rem}
.hero-badges{display:flex;flex-wrap:wrap;gap:.5rem}.hbadge{background:rgba(26,159,214,.12);border:1px solid rgba(26,159,214,.25);color:var(--cyan-l);font-size:.75rem;padding:.3rem .85rem;border-radius:20px}
/* FILTRES */
.filters-bar{background:var(--gray);border-bottom:1px solid var(--border);position:sticky;top:68px;z-index:100}
.filters-inner{max-width:1100px;margin:0 auto;padding:0 2rem;display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;padding-top:.75rem;padding-bottom:.75rem}.filters-inner::-webkit-scrollbar{display:none}
.filter-btn{padding:.5rem 1.2rem;border:1px solid var(--border);border-radius:20px;background:#fff;font-size:.82rem;color:var(--muted);transition:var(--tr)}.filter-btn:hover{border-color:var(--cyan);color:var(--cyan)}.filter-btn.active{background:var(--cyan);color:#fff;border-color:var(--cyan)}
/* FORMATIONS DETAIL */
#formations-list{padding:4rem 0}
.formation-detail{margin-bottom:3rem;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);box-shadow:0 2px 16px rgba(11,60,93,.08);transition:var(--tr)}
.formation-detail[data-hidden]{display:none}
.fd-header{padding:2rem 2.5rem;display:flex;align-items:flex-start;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.fh-off{background:linear-gradient(135deg,#0B2A4A,#1A9FD6)}.fh-def{background:linear-gradient(135deg,#0B2A40,#00A896)}.fh-net{background:linear-gradient(135deg,#1A1060,#5B4BE8)}.fh-grc{background:linear-gradient(135deg,#2A0E40,#A855F7)}
.fd-header-left{flex:1}.fd-level{display:inline-block;background:rgba(255,255,255,.18);color:rgba(255,255,255,.9);font-size:.68rem;letter-spacing:1px;text-transform:uppercase;padding:.2rem .65rem;border-radius:20px;margin-bottom:.75rem;font-weight:500}
.fd-header-left h2{color:#fff;font-family:var(--fd);font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:700;margin-bottom:.5rem}
.fd-header-left>p{color:rgba(255,255,255,.65);font-size:.9rem;margin-bottom:1rem}
.fd-meta{display:flex;flex-wrap:wrap;gap:.75rem}.fd-meta span{color:rgba(255,255,255,.6);font-size:.78rem}
.fd-price-box{text-align:right;flex-shrink:0}.fd-price{font-family:var(--fd);font-size:1.6rem;font-weight:900;color:#fff;margin-bottom:.25rem}.fd-price span{font-size:.9rem;opacity:.7}
.fd-price-sub{color:rgba(255,255,255,.5);font-size:.75rem;margin-bottom:1rem}
.fd-body{display:grid;grid-template-columns:1fr 1fr;gap:0;background:#fff}
.fd-col{padding:2rem 2.5rem}.fd-col:first-child{border-right:1px solid var(--border)}
.fd-col h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--cyan)}
.module-list{display:flex;flex-direction:column;gap:1rem}
.module-item{display:flex;gap:1rem;align-items:flex-start}
.module-num{width:32px;height:32px;border-radius:8px;background:rgba(26,159,214,.1);color:var(--cyan);font-family:var(--fd);font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.module-item strong{font-size:.88rem;font-weight:600;color:var(--navy);display:block;margin-bottom:.2rem}
.module-item p{font-size:.78rem;color:var(--muted);line-height:1.5}
.benefits-list{display:flex;flex-direction:column;gap:.85rem;margin-bottom:1.5rem}
.benefit-item{display:flex;gap:.75rem;align-items:flex-start}
.bi-icon{font-size:1.2rem;flex-shrink:0;margin-top:2px}
.benefit-item strong{font-size:.88rem;font-weight:600;color:var(--navy);display:block;margin-bottom:.15rem}
.benefit-item p{font-size:.78rem;color:var(--muted)}
.prereqs{background:var(--gray);border-radius:var(--r-md);padding:1rem 1.25rem;margin-bottom:1.25rem}
.prereqs h4{font-size:.82rem;font-weight:600;color:var(--navy);margin-bottom:.6rem}
.prereqs li{font-size:.78rem;color:var(--muted);padding:.2rem 0;padding-left:1rem;position:relative}.prereqs li::before{content:'›';position:absolute;left:0;color:var(--cyan)}
.next-session{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.82rem;color:var(--text);padding:.75rem 1rem;background:rgba(0,255,178,.06);border:1px solid rgba(0,255,178,.2);border-radius:var(--r-sm)}
.ns-dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:blink-ns 1.5s ease-in-out infinite;flex-shrink:0}
@keyframes blink-ns{0%,100%{opacity:1}50%{opacity:.3}}
.ns-places{background:rgba(0,255,178,.15);color:var(--green);font-size:.72rem;padding:.2rem .6rem;border-radius:10px;font-weight:600;margin-left:auto}
/* PARCOURS */
#parcours{padding:5rem 0;background:var(--gray)}
.section-header{text-align:center;margin-bottom:3rem}.section-header .tag{display:inline-block;font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--cyan);font-weight:600;margin-bottom:.75rem}
.section-header h2{font-family:var(--fd);font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:700;color:var(--navy);margin-bottom:.5rem}
.section-header p{color:var(--muted);font-size:.92rem}.accent-bar{width:44px;height:3px;background:linear-gradient(90deg,var(--cyan),var(--green));margin:1rem auto 0;border-radius:2px}
.parcours-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.parcours-card{background:#fff;border-radius:var(--r-lg);padding:2rem;border:1px solid var(--border);transition:var(--tr)}.parcours-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(11,60,93,.12)}
.pc-icon{font-size:2rem;margin-bottom:1rem}.parcours-card h3{font-size:1rem;font-weight:600;color:var(--navy);margin-bottom:1rem}
.pc-path{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}
.pc-step{background:rgba(26,159,214,.1);color:var(--blue);font-size:.75rem;font-weight:600;padding:.3rem .75rem;border-radius:20px}
.pc-arrow{color:var(--cyan);font-size:.9rem}
.parcours-card p{font-size:.83rem;color:var(--muted);line-height:1.7}
/* FAQ */
#faq{padding:5rem 0;background:#fff}
.faq-list{max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:.75rem}
.faq-item{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}
.faq-q{width:100%;background:none;border:none;padding:1.1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;text-align:left;font-size:.9rem;font-weight:500;color:var(--navy);cursor:pointer;transition:background var(--tr)}.faq-q:hover{background:var(--gray)}
.faq-chev{transition:transform var(--tr)}.faq-item.open .faq-chev{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .2s;padding:0 1.5rem;font-size:.85rem;color:var(--muted);line-height:1.8}.faq-item.open .faq-a{max-height:200px;padding:0 1.5rem 1.25rem}
/* CTA */
#cta{padding:5rem 0;background:var(--gray)}.cta-box{background:linear-gradient(135deg,var(--navy-mid),var(--blue));border-radius:var(--r-lg);padding:3rem;text-align:center;border:1px solid rgba(26,159,214,.2)}
.cta-box h2{font-family:var(--fd);font-size:clamp(1.2rem,2.5vw,1.6rem);color:#fff;margin-bottom:.75rem}
.cta-box p{color:rgba(255,255,255,.55);font-size:.92rem;margin-bottom:2rem}.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
/* FOOTER */
footer{background:var(--navy);color:rgba(255,255,255,.45);padding:4rem 0 2rem;border-top:1px solid rgba(26,159,214,.12)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-logo{font-family:var(--fd);font-size:1.2rem;font-weight:900;color:#fff;letter-spacing:3px;display:block;margin-bottom:1rem}
.footer-brand p{font-size:.82rem;line-height:1.8;color:rgba(255,255,255,.4)}
.footer-col h4{color:#fff;font-size:.85rem;font-weight:600;margin-bottom:1.25rem}
.footer-col ul{display:flex;flex-direction:column;gap:.65rem}.footer-col a{font-size:.82rem;color:rgba(255,255,255,.4);transition:color var(--tr)}.footer-col a:hover{color:var(--cyan)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:1.5rem;font-size:.78rem}
/* WA */
.wa-float{position:fixed;bottom:2rem;right:2rem;z-index:999;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;cursor:pointer;box-shadow:0 4px 20px rgba(37,211,102,.45);animation:float-bounce 3s ease-in-out infinite}
@keyframes float-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
/* AOS */
[data-aos]{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}[data-aos].aos-animate{opacity:1;transform:translateY(0)}[data-aos-delay="100"]{transition-delay:.1s}[data-aos-delay="200"]{transition-delay:.2s}[data-aos-delay="300"]{transition-delay:.3s}[data-aos-delay="400"]{transition-delay:.4s}
@media(max-width:900px){.fd-body{grid-template-columns:1fr}.fd-col:first-child{border-right:none;border-bottom:1px solid var(--border)}.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.fd-header{flex-direction:column}.fd-price-box{text-align:left;width:100%}.footer-grid{grid-template-columns:1fr}}
/* === BLOG SPECIFIQUE === */
.search-bar{display:flex;gap:.5rem;max-width:480px;margin-top:1.5rem}
.search-bar input{flex:1;background:rgba(255,255,255,.08);border:1px solid rgba(26,159,214,.25);border-radius:var(--r-sm);padding:.7rem 1rem;color:#fff;font-size:.9rem;font-family:var(--fb);outline:none}.search-bar input::placeholder{color:rgba(255,255,255,.35)}.search-bar input:focus{border-color:var(--cyan)}
.search-btn{background:var(--cyan);border:none;border-radius:var(--r-sm);padding:.7rem 1rem;font-size:1rem;cursor:pointer;color:#fff}
.categories-bar{background:var(--gray);border-bottom:1px solid var(--border);position:sticky;top:68px;z-index:100}
.categories-inner{max-width:1100px;margin:0 auto;padding:.75rem 2rem;display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none}.categories-inner::-webkit-scrollbar{display:none}
.cat-btn{padding:.45rem 1.1rem;border:1px solid var(--border);border-radius:20px;background:#fff;font-size:.8rem;color:var(--muted);transition:var(--tr);white-space:nowrap}.cat-btn:hover{border-color:var(--cyan);color:var(--cyan)}.cat-btn.active{background:var(--cyan);color:#fff;border-color:var(--cyan)}
#articles{padding:4rem 0}
.article-featured{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:center;background:#fff;border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;margin-bottom:3rem;box-shadow:0 2px 16px rgba(11,60,93,.08)}
.article-featured-img{position:relative;min-height:320px;background:var(--navy);display:flex;align-items:center;justify-content:center}
.af-placeholder{width:100%;height:100%;min-height:320px;display:flex;align-items:center;justify-content:center;font-size:5rem;position:relative}
.af-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(26,159,214,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(26,159,214,.06) 1px,transparent 1px);background-size:30px 30px}
.article-featured-img .cat-badge{position:absolute;top:1rem;left:1rem}
.article-featured-text{padding:2rem 2.5rem 2rem 0}
.art-meta{display:flex;gap:1rem;margin-bottom:.75rem}
.art-date,.art-read{font-size:.75rem;color:var(--muted)}
.article-featured-text h2{font-size:1.3rem;font-weight:700;color:var(--navy);line-height:1.35;margin-bottom:.75rem}
.article-featured-text p{font-size:.88rem;color:var(--muted);line-height:1.8;margin-bottom:1rem}
.art-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.25rem}
.art-tags span{background:var(--gray);color:var(--blue);font-size:.72rem;padding:.2rem .6rem;border-radius:20px;font-weight:500}
.btn-sm{padding:.55rem 1.2rem;font-size:.82rem}
.cat-badge{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:.25rem .65rem;border-radius:20px}
.cat-pentest{background:rgba(26,159,214,.15);color:var(--cyan)}.cat-defense{background:rgba(0,255,178,.12);color:#00B48A}.cat-grc{background:rgba(168,85,247,.12);color:#A855F7}.cat-actu{background:rgba(245,166,35,.12);color:#E09000}.cat-conseils{background:rgba(11,60,93,.08);color:var(--blue)}
.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:2.5rem}
.article-card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;transition:var(--tr);cursor:pointer}
.article-card[data-hidden]{display:none}
.article-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(11,60,93,.12)}
.art-card-img{height:140px;background:var(--navy);display:flex;align-items:center;justify-content:center;font-size:3rem;position:relative}
.art-card-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(26,159,214,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(26,159,214,.05) 1px,transparent 1px);background-size:25px 25px}
.art-card-body{padding:1.25rem 1.5rem}
.art-card-body h3{font-size:.92rem;font-weight:600;color:var(--navy);line-height:1.4;margin:.6rem 0 .5rem}
.art-card-body p{font-size:.8rem;color:var(--muted);line-height:1.7;margin-bottom:.75rem}
.art-card-footer{display:flex;justify-content:space-between;font-size:.73rem;color:var(--muted);border-top:1px solid var(--border);padding-top:.6rem}
.pagination{display:flex;gap:.5rem;justify-content:center}
.page-btn{width:38px;height:38px;border:1px solid var(--border);border-radius:var(--r-sm);background:#fff;font-size:.85rem;color:var(--muted);transition:var(--tr)}.page-btn:hover{border-color:var(--cyan);color:var(--cyan)}.page-btn.active{background:var(--cyan);color:#fff;border-color:var(--cyan)}
.page-next{width:auto;padding:0 1rem}
#newsletter{padding:4rem 0;background:var(--navy)}
.newsletter-box{background:rgba(255,255,255,.04);border:1px solid rgba(26,159,214,.2);border-radius:var(--r-lg);padding:2.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.nl-text h2{font-family:var(--fd);font-size:1.2rem;color:#fff;margin-bottom:.5rem}.nl-text p{color:rgba(255,255,255,.5);font-size:.88rem}
.nl-form{display:flex;gap:.75rem;flex-shrink:0}.nl-form input{background:rgba(255,255,255,.08);border:1px solid rgba(26,159,214,.25);border-radius:var(--r-sm);padding:.7rem 1rem;color:#fff;font-size:.88rem;font-family:var(--fb);outline:none;min-width:240px}.nl-form input:focus{border-color:var(--cyan)}
@media(max-width:900px){.article-featured{grid-template-columns:1fr}.article-featured-text{padding:1.5rem}.newsletter-box{flex-direction:column;text-align:center}.nl-form{flex-direction:column;width:100%}.nl-form input{min-width:0}}

/* ââ HERO 2 COLONNES AVEC IMAGE (comme formations) ââ */
.page-hero { padding: 9rem 2rem 5rem; min-height: auto; }

.page-hero-inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 4rem; align-items: center;
  position: relative; z-index: 1;
}

.page-hero-image { display: flex; justify-content: center; align-items: center; }

.hero-img-wrap { position: relative; width: 100%; max-width: 480px; }

.hero-img-wrap img {
  width: 100%; height: 380px; object-fit: cover;
  border-radius: 16px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.4);
  border: 2px solid rgba(26,159,214,0.3);
  animation: zoomIn 0.85s cubic-bezier(0.22, 1, 0.36, 1) both;
  transform-origin: center center;
}
@keyframes zoomIn {
  from { opacity: 0; transform: scale(0.88); }
  to   { opacity: 1; transform: scale(1); }
}

.hero-img-badge {
  position: absolute; bottom: -18px; left: -20px;
  background: var(--white); border-radius: 12px;
  padding: 0.85rem 1.1rem;
  display: flex; align-items: center; gap: 0.75rem;
  box-shadow: 0 8px 30px rgba(11,60,93,0.2); min-width: 170px;
}
.hero-img-badge i { font-size: 1.5rem; color: var(--cyan); flex-shrink: 0; }
.hero-img-badge strong { display: block; font-size: 1.1rem; font-weight: 700; color: var(--navy); line-height: 1; }
.hero-img-badge span { font-size: 0.72rem; color: var(--muted); }

.hero-img-badge2 {
  position: absolute; top: -14px; right: -16px;
  background: var(--navy); border: 1px solid rgba(26,159,214,0.3);
  border-radius: 20px; padding: 0.5rem 1rem;
  display: flex; align-items: center; gap: 0.4rem;
  font-size: 0.75rem; color: rgba(255,255,255,0.85); font-weight: 500;
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}
.hero-img-badge2 i { font-size: 0.8rem; }

/* ââ HERO BADGES ââ */
.hero-badges { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1.5rem; }
.hbadge {
  display: inline-flex; align-items: center; gap: 0.4rem;
  background: rgba(26,159,214,0.12); border: 1px solid rgba(26,159,214,0.25);
  color: var(--cyan-light); font-size: 0.75rem; padding: 0.3rem 0.85rem;
  border-radius: 20px;
}
.hbadge i { font-size: 0.75rem; }

/* ââ BARRE DE RECHERCHE ââ */
.search-bar {
  position: relative; display: flex; align-items: center;
  gap: 0.5rem; max-width: 480px; margin-top: 1.5rem;
}
.search-icon {
  position: absolute; left: 1rem;
  color: rgba(255,255,255,0.4); font-size: 0.9rem; pointer-events: none;
}
.search-bar input {
  flex: 1; padding: 0.75rem 1rem 0.75rem 2.5rem;
  background: rgba(255,255,255,0.08); border: 1px solid rgba(26,159,214,0.25);
  border-radius: var(--r-sm); color: white; font-size: 0.88rem;
  font-family: var(--font-b); outline: none;
}
.search-bar input::placeholder { color: rgba(255,255,255,0.35); }
.search-bar input:focus { border-color: var(--cyan); background: rgba(255,255,255,0.12); }
.search-btn {
  background: var(--cyan); color: white; border: none;
  padding: 0.75rem 1.25rem; border-radius: var(--r-sm);
  font-size: 0.85rem; font-weight: 500; cursor: pointer;
  transition: var(--tr); white-space: nowrap;
}
.search-btn:hover { background: var(--cyan-light); }

/* ââ CATÉGORIES AVEC ICÔNES ââ */
.cat-btn { display: inline-flex; align-items: center; gap: 0.4rem; }
.cat-btn i { font-size: 0.75rem; }

/* ââ ARTICLE À LA UNE ââ */
.article-featured-img {
  position: relative; overflow: hidden; border-radius: var(--r-lg) 0 0 var(--r-lg);
}
.article-featured-img img {
  width: 100%; height: 100%; min-height: 320px;
  object-fit: cover; display: block;
}
.af-fallback {
  min-height: 320px; background: var(--navy);
  display: flex; align-items: center; justify-content: center;
}
.af-fallback i { font-size: 5rem; color: var(--cyan); opacity: 0.3; position: relative; z-index: 1; }
.af-bg-grid {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(26,159,214,0.06) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(26,159,214,0.06) 1px, transparent 1px);
  background-size: 30px 30px;
}

/* ââ CARDS ARTICLES AVEC IMAGES ââ */
.art-card-img {
  height: 160px; position: relative; overflow: hidden;
  background: var(--navy);
  display: flex; align-items: center; justify-content: center;
}
.art-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  display: block; transition: transform 0.4s ease;
}
.article-card:hover .art-card-img img { transform: scale(1.05); }

.art-card-fallback {
  width: 100%; height: 100%; position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--navy);
}
.art-card-fallback i { font-size: 3rem; color: var(--cyan); opacity: 0.3; }
.art-card-bg {
  position: absolute; inset: 0; pointer-events: none;
  background-image: linear-gradient(rgba(26,159,214,0.05) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(26,159,214,0.05) 1px, transparent 1px);
  background-size: 25px 25px;
}

/* Badges catégorie avec icônes */
.cat-badge { display: inline-flex; align-items: center; gap: 0.3rem; }
.cat-badge i { font-size: 0.65rem; }

/* Meta articles avec icônes */
.art-meta { display: flex; gap: 1rem; margin-bottom: 0.75rem; }
.art-date i, .art-read i { margin-right: 0.3rem; color: var(--cyan); font-size: 0.72rem; }
.art-card-footer span i { margin-right: 0.25rem; color: var(--cyan); font-size: 0.7rem; }

/* Bouton Lire article */
.btn-sm { padding: 0.55rem 1.2rem; font-size: 0.82rem; }
.btn-sm i { font-size: 0.78rem; }

.pagination { display: flex; gap: .5rem; justify-content: center; }
.page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: #fff;
  font-size: .85rem;
  color: var(--muted);
  transition: var(--tr);
  text-decoration: none;
}
.page-btn:hover { border-color: var(--cyan); color: var(--cyan); }
.page-btn.active { background: var(--cyan); color: #fff; border-color: var(--cyan); }
.page-next { width: auto; padding: 0 1rem; }

/* ââ NEWSLETTER ââ */
.nl-icon {
  width: 52px; height: 52px; border-radius: 50%;
  background: rgba(26,159,214,0.15); border: 1px solid rgba(26,159,214,0.3);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1rem;
}
.nl-icon i { font-size: 1.4rem; color: var(--cyan); }
.nl-text h2 { font-family: var(--font-d); font-size: 1.2rem; color: white; margin-bottom: 0.5rem; }

/* Footer */
.footer-contact-info { margin-top: 1.25rem; display: flex; flex-direction: column; gap: 0.6rem; }
.fci-item { display: flex; align-items: flex-start; gap: 0.6rem; font-size: 0.82rem; color: rgba(255,255,255,0.45); }
.fci-item i { color: var(--cyan); font-size: 0.85rem; width: 14px; flex-shrink: 0; margin-top: 2px; }
.fci-item a { color: rgba(255,255,255,0.45); transition: color 0.25s; }
.fci-item a:hover { color: var(--cyan); }
.footer-col li a { display: flex; align-items: center; gap: 0.4rem; }
.footer-col li a i { color: var(--cyan); font-size: 0.75rem; width: 14px; }
.social-btn { display: flex; align-items: center; justify-content: center; }
.social-btn i { font-size: 0.9rem; }
footer { background: var(--navy); color: #ffffff; padding: 4rem 0 2rem; border-top: 1px solid rgba(26,159,214,0.12); }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 3rem; margin-bottom: 3rem; }
.footer-brand .footer-logo { font-family: var(--font-d); font-size: 1.2rem; font-weight: 900; color: white; letter-spacing: 3px; display: block; margin-bottom: 1rem; }
.footer-brand p { font-size: 0.82rem; line-height: 1.8; max-width: 240px; color: #ffffff; }
.footer-col h4 { color: white; font-size: 0.85rem; font-weight: 600; letter-spacing: 0.5px; margin-bottom: 1.25rem; }
.footer-col ul { display: flex; flex-direction: column; gap: 0.65rem; }
.footer-col li a { font-size: 0.82rem; color: #ffffff; transition: color var(--tr); }
.footer-col li a:hover { color: var(--cyan); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.06); padding-top: 1.5rem; display: flex; align-items: center; justify-content: space-between; font-size: 0.78rem; }
.footer-social { display: flex; gap: 0.75rem; }
.social-btn { width: 34px; height: 34px; border-radius: 8px; border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.04); display: flex; align-items: center; justify-content: center; font-size: 0.85rem; transition: var(--tr); color: #ffffff; cursor: pointer; }
.social-btn:hover { background: rgba(255,255,255,0.1); }
.social-btn.social-facebook { color: #1877F2; }
.social-btn.social-facebook:hover { background: #1877F2; color: #ffffff; }
.social-btn.social-whatsapp { color: #25D366; }
.social-btn.social-whatsapp:hover { background: #25D366; color: #ffffff; }
.social-btn.social-linkedin { color: #0A66C2; }
.social-btn.social-linkedin:hover { background: #0A66C2; color: #ffffff; }
/* WhatsApp flottant */
.wa-float {
  position: fixed; bottom: 2rem; right: 2rem; z-index: 999;
  width: 56px; height: 56px; background: #25D366; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,0.45);
  animation: float-bounce 3s ease-in-out infinite;
  text-decoration: none;
}
.wa-float i { font-size: 1.7rem; color: white; }
.wa-float:hover { transform: scale(1.1); }

/* ââ RESPONSIVE COMPLET ââ */

@media (max-width: 900px) {
  /* ââ HERO : image en haut, texte centré en dessous ââ */
  .page-hero { padding: 6rem 1.5rem 3rem; }

  .page-hero-inner {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto;
    grid-template-areas:
      "image"
      "content";
    gap: 2rem;
    text-align: center;
    align-items: center;
    justify-items: center;
  }

  .page-hero-image {
    display: flex !important;
    grid-area: image;
    width: 100%;
    max-width: 380px;
    margin: 0 auto;
    justify-content: center;
  }

  .hero-img-wrap {
    width: 100%;
    max-width: 340px;
    margin: 0 auto;
  }

  .hero-img-wrap img {
    height: 280px;
    width: 100%;
    border-radius: 14px;
  }

  .hero-img-badge {
    bottom: -12px; left: 8px;
    min-width: 130px; padding: 0.65rem 0.85rem;
  }
  .hero-img-badge i { font-size: 1.2rem; }
  .hero-img-badge strong { font-size: 0.95rem; }
  .hero-img-badge2 { top: -10px; right: 8px; left: auto; font-size: 0.7rem; padding: 0.4rem 0.75rem; }

  .page-hero-content {
    grid-area: content;
    width: 100%;
    text-align: center;
    padding: 0;
  }

  .page-hero h1 { font-size: 1.75rem; text-align: center; }
  .page-hero p  { text-align: center; max-width: 100%; font-size: 0.92rem; }
  .breadcrumb   { justify-content: center; }
  .search-bar   { margin: 1.25rem auto 0; }
  .hero-badges  { justify-content: center; }

  /* Article à la une */
  .article-featured { grid-template-columns: 1fr; }
  .article-featured-img { border-radius: var(--r-lg) var(--r-lg) 0 0; min-height: 220px; }
  .article-featured-text { padding: 1.5rem; }

  /* Newsletter */
  .newsletter-box { flex-direction: column; text-align: center; padding: 2rem 1.5rem; }
  .nl-form { flex-direction: column; width: 100%; }
  .nl-form input { min-width: 0; width: 100%; }
  .nl-form .btn { width: 100%; justify-content: center; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}

@media (max-width: 768px) {
  /* Navbar */
  .nav-links, .nav-cta { display: none; }
  .nav-hamburger { display: flex; }
  .nav-links.mobile-open { display: flex !important; }
}

@media (max-width: 640px) {
  /* ââ HERO ââ */
  .page-hero { padding: 5.5rem 1rem 2.5rem; }

  .page-hero-inner {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }

  .page-hero-image {
    order: -1; /* image en premier = en haut */
    width: 100%;
    display: flex !important;
    justify-content: center;
  }

  .hero-img-wrap { max-width: 300px; margin: 0 auto; }
  .hero-img-wrap img { height: 240px; }

  .page-hero-content {
    padding: 0 0.5rem;
    text-align: center;
    width: 100%;
  }

  .page-hero h1 { font-size: 1.5rem; text-align: center; }
  .page-hero p  { font-size: 0.88rem; text-align: center; }
  .breadcrumb   { justify-content: center; }
  .hero-badges  { justify-content: center; }

  /* Badges image cachés sur très petit écran */
  .hero-img-badge  { display: none; }
  .hero-img-badge2 { display: none; }

  /* Search bar */
  .search-bar { flex-direction: column; max-width: 100%; gap: .4rem; margin: 1rem auto 0; }
  .search-bar input { width: 100%; padding-left: 1rem; }
  .search-icon { display: none; }
  .search-btn { width: 100%; justify-content: center; padding: .65rem; }

  /* Hero badges */
  .hero-badges { gap: .35rem; }
  .hbadge { font-size: .7rem; padding: .25rem .65rem; }

  /* Categories bar */
  .categories-inner { padding: .6rem 1rem; gap: .4rem; }
  .cat-btn { font-size: .72rem; padding: .35rem .8rem; }

  /* Section articles */
  #articles { padding: 2rem 0; }
  .container { padding: 0 1rem; }

  /* Article à la une */
  .article-featured { margin-bottom: 2rem; }
  .article-featured-img { min-height: 180px; }
  .article-featured-text { padding: 1.25rem; }
  .article-featured-text h2 { font-size: 1.05rem; }
  .art-meta { flex-wrap: wrap; gap: .4rem; }
  .art-tags { gap: .3rem; }

  /* Grille articles : 1 colonne */
  .articles-grid { grid-template-columns: 1fr; gap: 1rem; margin-bottom: 1.5rem; }

  /* Cards articles */
  .art-card-img { height: 160px; }
  .art-card-body { padding: 1rem; }
  .art-card-body h3 { font-size: .88rem; }
  .art-card-body p { font-size: .78rem; }

  /* Pagination */
  .pagination { gap: .35rem; flex-wrap: wrap; }
  .page-btn { width: 34px; height: 34px; font-size: .8rem; }
  .page-next { padding: 0 .75rem; font-size: .78rem; }

  /* Newsletter */
  #newsletter { padding: 2.5rem 0; }
  .newsletter-box { padding: 1.5rem 1rem; }
  .nl-text h2 { font-size: 1rem; }
  .nl-text p { font-size: .8rem; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .footer-bottom { flex-direction: column; gap: .75rem; text-align: center; font-size: .72rem; }
  .footer-social { justify-content: center; }
  footer { padding: 2.5rem 0 1.5rem; }

  /* WhatsApp */
  .wa-float { bottom: 1.25rem; right: 1.25rem; width: 50px; height: 50px; }
  .wa-float i { font-size: 1.4rem; }
}

/* ââ LOADER ââ */
#loader {
  position: fixed; top: 0; left: 0;
  width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--navy) 0%, var(--blue) 100%);
  display: flex; justify-content: center; align-items: center;
  z-index: 9999;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}
.loader-content { text-align: center; color: #fff; }
.loader-logo img {
  width: 120px; height: auto;
  margin-bottom: 2rem;
  animation: logo-grow 1.5s ease-out forwards;
}
.loader-spinner {
  width: 50px; height: 50px;
  border: 4px solid rgba(255,255,255,0.3);
  border-top: 4px solid var(--cyan);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin: 0 auto 1.5rem;
}
#loader p { font-size: 1rem; font-weight: 500; color: rgba(255,255,255,0.7); margin: 0; }
@keyframes spin { 0%{transform:rotate(0deg)} 100%{transform:rotate(360deg)} }
@keyframes pulse-logo { 0%,100%{opacity:1} 50%{opacity:0.7} }
@keyframes logo-grow { 0%{transform:scale(.5);opacity:0} 50%{transform:scale(1.3);opacity:1} 100%{transform:scale(1);opacity:1} }

/* État caché — transition douce */
#loader.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}