/* ════════════════════════════════════════════════════════════════
   blog.css — styles partagés index.blade + show.blade
   Palette : bleu ciel vif
════════════════════════════════════════════════════════════════ */

/* ── TOKENS ─────────────────────────────────────────────────── */
:root{
  --sky:#0284c7;
  --sky-d:#0369a1;
  --sky-l:#bae6fd;
  --sky-ll:#f0f9ff;
  --navy:#1e3a5f;
  --ink:#1e293b;
  --ink2:#475569;
  --ink3:#94a3b8;
  --surf:#ffffff;
  --bg:#f0f8ff;
  --bdr:#7dd3fc;
  --bdr2:#e2e8f0;
  --green:#10b981;
  --amber:#f59e0b;
  --red:#ef4444;
  --r:14px;
  --r-sm:10px;
  --r-lg:20px;
  --sh:0 2px 8px rgba(2,132,199,.10),0 1px 3px rgba(0,0,0,.05);
  --sh-md:0 6px 24px rgba(2,132,199,.14);
  --sh-lg:0 12px 40px rgba(2,132,199,.18);
  --tr:all .22s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);font-family:'Inter',system-ui,sans-serif;color:var(--ink)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

/* ════════════════════════════════════════════════════════════════
   BARRE DE TITRE (une seule ligne) — utilisée sur les deux pages
════════════════════════════════════════════════════════════════ */
.page-bar{
  background:linear-gradient(90deg,#075985 0%,#0284c7 60%,#0ea5e9 100%);
  padding:.7rem 1.5rem;
}
.page-bar-inner{
  max-width:1360px;
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:.6rem;
  flex-wrap:wrap;
}
.page-bar-home{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.78rem;font-weight:600;color:rgba(255,255,255,.75);
  padding:.28rem .65rem;border-radius:6px;
  background:rgba(255,255,255,.12);
  transition:var(--tr);
}
.page-bar-home:hover{background:rgba(255,255,255,.22);color:#fff}
.page-bar-sep{color:rgba(255,255,255,.45);font-size:.78rem}
.page-bar-title{
  font-size:.9rem;font-weight:700;color:#fff;
  letter-spacing:.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:640px;
}
.page-bar-badge{
  margin-left:auto;
  display:inline-flex;align-items:center;gap:.35rem;
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);
  border-radius:99px;padding:.25rem .7rem;
  font-size:.7rem;font-weight:700;color:#fff;white-space:nowrap;
}

/* ════════════════════════════════════════════════════════════════
   LAYOUT
════════════════════════════════════════════════════════════════ */
.page-wrap{max-width:1360px;margin:0 auto;padding:2rem 1.25rem}
.blog-layout{display:grid;grid-template-columns:1fr 320px;gap:2rem;align-items:start}
.art-layout{display:grid;grid-template-columns:1fr 300px;gap:2rem;align-items:start}
@media(max-width:1024px){.blog-layout,.art-layout{grid-template-columns:1fr}}

/* ════════════════════════════════════════════════════════════════
   INDEX — FILTRES BAR
════════════════════════════════════════════════════════════════ */
.filters-bar{
  background:var(--surf);border:1px solid var(--bdr);
  border-radius:var(--r);padding:.85rem 1.25rem;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;box-shadow:var(--sh);
}
.filters-title{font-size:1rem;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:.5rem}
.filters-title i{color:var(--sky)}
.sort-select{
  background:var(--sky-ll);border:1.5px solid var(--bdr);
  border-radius:8px;padding:.42rem .9rem;color:var(--ink);
  font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--tr);outline:none;
}
.sort-select:focus{border-color:var(--sky);box-shadow:0 0 0 3px rgba(2,132,199,.12)}

/* ════════════════════════════════════════════════════════════════
   INDEX — GRILLE ARTICLES
════════════════════════════════════════════════════════════════ */
.articles-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(310px,1fr));
  gap:1.35rem;
  margin-bottom:1.75rem;
}
.art-card{
  background:var(--surf);border:1px solid var(--bdr2);
  border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);
  transition:var(--tr);display:flex;flex-direction:column;
}
.art-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:var(--bdr)}

.art-img-wrap{position:relative;height:210px;overflow:hidden;flex-shrink:0}
.art-img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.art-card:hover .art-img{transform:scale(1.04)}
.art-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(2,132,199,.72) 0%,transparent 55%)}
.art-img-fallback{width:100%;height:100%;background:linear-gradient(135deg,var(--sky-d),var(--navy));display:flex;align-items:center;justify-content:center}
.art-img-fallback i{font-size:3rem;color:rgba(255,255,255,.22)}
.art-date-badge{position:absolute;top:.75rem;left:.75rem;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);border-radius:7px;padding:.25rem .65rem;font-size:.68rem;font-weight:700;color:var(--sky-d)}
.art-overlay-title{position:absolute;bottom:.8rem;left:.8rem;right:.8rem;color:#fff;font-size:.9rem;font-weight:700;line-height:1.3;text-shadow:0 1px 4px rgba(0,0,0,.3)}

.art-body{padding:1.1rem;display:flex;flex-direction:column;flex:1}
.art-meta{display:flex;align-items:center;gap:.6rem;margin-bottom:.75rem;flex-wrap:wrap}
.art-author{display:flex;align-items:center;gap:.4rem}
.art-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--sky),var(--navy));color:#fff;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.art-author-name{font-size:.76rem;color:var(--ink2);font-weight:600}
.art-chip{display:inline-flex;align-items:center;gap:.28rem;background:var(--sky-ll);border:1px solid var(--bdr);border-radius:5px;padding:.18rem .55rem;font-size:.68rem;color:var(--sky-d);font-weight:600}
.art-excerpt{color:var(--ink2);font-size:.86rem;line-height:1.65;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1;margin-bottom:.9rem}
.art-footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:.8rem;border-top:1px solid var(--bdr2)}
.art-cats{display:flex;gap:.35rem;flex-wrap:wrap}
.art-cat{background:rgba(2,132,199,.1);color:var(--sky-d);padding:.15rem .5rem;border-radius:5px;font-size:.65rem;font-weight:700}
.art-read-more{display:inline-flex;align-items:center;gap:.32rem;background:linear-gradient(135deg,var(--sky),var(--sky-d));color:#fff;padding:.38rem .9rem;border-radius:99px;font-size:.76rem;font-weight:700;white-space:nowrap;transition:var(--tr);flex-shrink:0}
.art-read-more:hover{background:linear-gradient(135deg,var(--sky-d),var(--navy));transform:translateX(2px)}
.art-read-more i{font-size:.6rem}

/* ── PAGINATION ── */
.pag-wrap{display:flex;justify-content:center;margin-top:1.25rem}
.pag-wrap .pagination{display:flex;gap:.32rem;flex-wrap:wrap;list-style:none}
.pag-wrap .page-item .page-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1.5px solid var(--bdr);background:var(--surf);color:var(--sky-d);font-weight:600;font-size:.82rem;transition:var(--tr)}
.pag-wrap .page-item.active .page-link{background:var(--sky);border-color:var(--sky);color:#fff;box-shadow:0 3px 10px rgba(2,132,199,.35)}
.pag-wrap .page-item .page-link:hover{background:var(--sky-l);border-color:var(--sky)}
.pag-wrap .page-item.disabled .page-link{opacity:.4;pointer-events:none}

/* ════════════════════════════════════════════════════════════════
   SIDEBAR (partagé index + show)
════════════════════════════════════════════════════════════════ */
.sidebar,.art-sidebar{display:flex;flex-direction:column;gap:1.35rem}
.sidebar{position:sticky;top:1.25rem}
.art-sidebar{position:sticky;top:4.5rem}

.side-card{background:var(--surf);border:1px solid var(--bdr2);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}
.side-hd{display:flex;align-items:center;gap:.6rem;padding:.8rem 1rem;border-bottom:1px solid var(--bdr2)}
.side-hd-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.78rem;color:#fff;flex-shrink:0}
.side-hd-icon.fire{background:linear-gradient(135deg,#f97316,#ef4444)}
.side-hd-icon.star{background:linear-gradient(135deg,#10b981,#059669)}
.side-hd-icon.sky{background:linear-gradient(135deg,var(--sky),var(--sky-d))}
.side-hd-icon.nav{background:linear-gradient(135deg,#7c3aed,#6d28d9)}
.side-title{font-size:.82rem;font-weight:700;color:var(--navy)}
.side-body{padding:.65rem 1rem}

.pop-item{display:flex;gap:.6rem;padding:.55rem 0;border-bottom:1px solid var(--bdr2)}
.pop-item:last-child{border-bottom:none}
.pop-num{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,var(--sky),var(--sky-d));color:#fff;font-size:.68rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pop-title{font-size:.78rem;font-weight:600;color:var(--ink);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.18rem;transition:var(--tr)}
.pop-title:hover{color:var(--sky-d)}
.pop-meta{font-size:.65rem;color:var(--ink3)}

.rec-item{padding:.6rem 0;border-bottom:1px solid var(--bdr2)}
.rec-item:last-child{border-bottom:none}
.rec-img{width:100%;height:95px;object-fit:cover;border-radius:var(--r-sm);margin-bottom:.5rem}
.rec-title{font-size:.82rem;font-weight:700;color:var(--ink);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.28rem;transition:var(--tr)}
.rec-title:hover{color:var(--sky-d)}
.rec-date{font-size:.68rem;color:var(--ink3)}

/* Newsletter */
.news-card{background:linear-gradient(135deg,#075985,#0284c7 60%,#0ea5e9 100%);border-radius:var(--r);padding:1.35rem 1.1rem;text-align:center;position:relative;overflow:hidden}
.news-card::before{content:'';position:absolute;width:120px;height:120px;background:rgba(255,255,255,.07);border-radius:50%;top:-35px;right:-35px}
.news-title{font-size:.95rem;font-weight:800;color:#fff;margin-bottom:.4rem}
.news-desc{font-size:.78rem;color:rgba(255,255,255,.85);margin-bottom:.9rem;line-height:1.5}
.news-input{width:100%;padding:.62rem .9rem;border-radius:99px;border:1.5px solid rgba(255,255,255,.3);background:rgba(255,255,255,.15);color:#fff;font-size:.82rem;margin-bottom:.55rem;outline:none;transition:var(--tr)}
.news-input::placeholder{color:rgba(255,255,255,.6)}
.news-input:focus{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.65)}
.news-btn{width:100%;padding:.65rem;border-radius:99px;border:none;background:#fff;color:var(--sky-d);font-weight:800;font-size:.84rem;cursor:pointer;transition:var(--tr)}
.news-btn:hover{background:var(--sky-ll);transform:translateY(-1px)}

/* ════════════════════════════════════════════════════════════════
   SHOW — BARRE DE PROGRESSION LECTURE
════════════════════════════════════════════════════════════════ */
#read-bar{position:fixed;top:0;left:0;width:0;height:3px;background:linear-gradient(90deg,#075985,#0284c7,#0ea5e9);z-index:9999;transition:width .12s linear;box-shadow:0 1px 8px rgba(2,132,199,.35)}

/* ════════════════════════════════════════════════════════════════
   SHOW — IMAGE PRINCIPALE
════════════════════════════════════════════════════════════════ */
.art-main-img-wrap{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);margin-bottom:1.5rem;aspect-ratio:16/7;position:relative}
.art-main-img{width:100%;height:100%;object-fit:cover}
.art-main-img-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#075985,#0284c7,#0ea5e9)}

/* ════════════════════════════════════════════════════════════════
   SHOW — PARTAGE : icônes uniquement, très compact
════════════════════════════════════════════════════════════════ */
.share-strip{
  display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;
  background:var(--surf);border:1px solid var(--bdr);
  border-radius:var(--r-sm);padding:.55rem 1rem;
  margin-bottom:1.5rem;box-shadow:var(--sh);
}
.share-lbl{font-size:.72rem;font-weight:700;color:var(--ink3);white-space:nowrap}
.share-btns{display:flex;gap:.38rem}
.sh-btn{
  width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;transition:var(--tr);flex-shrink:0;
}
.sh-btn:hover{transform:translateY(-2px);box-shadow:var(--sh)}
.sh-tw{background:#bae6fd;color:#0369a1}
.sh-fb{background:#bae6fd;color:#0284c7}
.sh-li{background:#bae6fd;color:#075985}
.sh-cp{background:var(--sky-ll);color:var(--sky-d)}
.sh-share{background:#f1f5f9;color:var(--ink2)}

/* ════════════════════════════════════════════════════════════════
   SHOW — CARTE ARTICLE
════════════════════════════════════════════════════════════════ */
.art-card-show{background:var(--surf);border:1px solid var(--bdr2);border-radius:var(--r-lg);box-shadow:var(--sh);overflow:hidden;position:relative;margin-bottom:1.5rem}
.art-card-show-bar{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#075985,#0284c7,#0ea5e9)}

/* ── TOC (fermé par défaut) ── */
.toc-box{background:var(--sky-ll);border:1.5px solid var(--bdr);border-radius:var(--r-sm);overflow:hidden;margin:1.35rem 1.5rem}
.toc-box details{/* PAS d'attribut open dans le HTML : fermé par défaut */}
.toc-box summary{
  list-style:none;cursor:pointer;
  padding:.75rem 1rem;
  display:flex;align-items:center;gap:.55rem;
  font-size:.84rem;font-weight:700;color:var(--navy);
  user-select:none;
}
.toc-box summary::-webkit-details-marker{display:none}
.toc-box summary i.toc-chevron{margin-left:auto;font-size:.6rem;transition:transform .22s;color:var(--sky-d)}
.toc-box details[open] summary i.toc-chevron{transform:rotate(180deg)}
.toc-box ul{padding:.2rem 1rem .8rem 1.6rem;list-style:none}
.toc-box ul li{border-bottom:1px solid rgba(186,230,253,.45);padding:.25rem 0}
.toc-box ul li:last-child{border-bottom:none}
.toc-box ul li a{font-size:.82rem;color:var(--sky-d);font-weight:600;transition:var(--tr);display:block;padding:.08rem .28rem;border-radius:4px}
.toc-box ul li a:hover{background:rgba(2,132,199,.1);color:var(--navy)}
.toc-box .toc-sub{padding-left:.9rem}
.toc-box .toc-sub li a{font-size:.76rem;font-weight:500;color:var(--ink2)}

/* ── CONTENU ARTICLE ── */
.art-content{padding:1.5rem}
.art-text{font-size:.95rem;line-height:1.8;color:var(--ink2)}
.art-text h1{font-size:1.55rem;font-weight:800;color:var(--navy);margin:2.25rem 0 .85rem;padding-bottom:.55rem;border-bottom:3px solid var(--sky)}
.art-text h2{font-size:1.25rem;font-weight:800;color:var(--navy);margin:2rem 0 .75rem;padding-left:.85rem;border-left:4px solid var(--sky)}
.art-text h3{font-size:1.05rem;font-weight:700;color:#1e5c8a;margin:1.6rem 0 .6rem}
.art-text h4{font-size:.95rem;font-weight:700;color:var(--sky-d);margin:1.25rem 0 .45rem}
.art-text p{margin-bottom:1rem}
.art-text ul,.art-text ol{margin:0 0 1rem 1.5rem}
.art-text li{margin-bottom:.5rem;line-height:1.7}
.art-text strong{color:var(--navy);font-weight:700}
.art-text a{color:var(--sky-d);font-weight:600;border-bottom:1px solid var(--bdr);transition:var(--tr)}
.art-text a:hover{color:var(--navy);border-color:var(--navy)}
.art-text .intro,.art-text .intro-box{background:var(--sky-ll);border-left:4px solid var(--sky);border-radius:0 var(--r-sm) var(--r-sm) 0;padding:.85rem 1.1rem;margin:1.1rem 0;font-size:.96rem}
.art-text .highlight{background:#fffbeb;border-left:4px solid #f59e0b;border-radius:0 var(--r-sm) var(--r-sm) 0;padding:.85rem 1.1rem;margin:1.1rem 0}
.art-text .warning{background:#fff1f2;border-left:4px solid #ef4444;border-radius:0 var(--r-sm) var(--r-sm) 0;padding:.85rem 1.1rem;margin:1.1rem 0;color:#be123c}
.art-text .info-box{background:var(--sky-ll);border:1px solid var(--bdr);border-radius:var(--r-sm);padding:.85rem 1.1rem;margin:1.1rem 0}
.art-text .section-title{background:linear-gradient(135deg,var(--sky-d),var(--navy));color:#fff;padding:.55rem .9rem;border-radius:var(--r-sm);margin:1.75rem 0 .85rem;font-size:.88rem;font-weight:700}
.art-text :target{scroll-margin-top:80px}

/* ── SIGNATURE AUTEUR ── */
.art-author-sig{display:flex;align-items:center;gap:.9rem;background:var(--sky-ll);border:1px solid var(--bdr);border-radius:var(--r-sm);padding:.9rem 1.25rem;margin:1.25rem 1.5rem 0}
.auth-avatar-lg{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--sky),var(--navy));color:#fff;font-size:1.1rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid var(--sky)}
.auth-name{font-size:.88rem;font-weight:700;color:var(--navy);margin-bottom:.12rem}
.auth-role{font-size:.72rem;color:var(--ink3)}

/* ── TAGS ── */
.art-tags{padding:1rem 1.5rem;border-top:1px solid var(--bdr2)}
.tags-title{font-size:.72rem;font-weight:700;color:var(--ink3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.55rem;display:flex;align-items:center;gap:.35rem}
.tags-list{display:flex;flex-wrap:wrap;gap:.45rem}
.tag{background:linear-gradient(135deg,var(--sky),var(--sky-d));color:#fff;padding:.32rem .78rem;border-radius:99px;font-size:.72rem;font-weight:700;box-shadow:0 2px 7px rgba(2,132,199,.28);transition:var(--tr)}
.tag:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(2,132,199,.4)}

/* ── CTA COMPACT ── */
.art-cta{
  background:linear-gradient(135deg,#075985 0%,#0284c7 60%,#0ea5e9 100%);
  border-radius:var(--r-lg);
  padding:1.25rem 1.5rem;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;flex-wrap:wrap;
  margin-bottom:1.5rem;
  position:relative;overflow:hidden;
}
.art-cta::before{content:'';position:absolute;width:120px;height:120px;background:rgba(255,255,255,.07);border-radius:50%;top:-35px;right:-35px;pointer-events:none}
.art-cta-text h3{font-size:1rem;font-weight:800;color:#fff;margin-bottom:.28rem}
.art-cta-text p{color:rgba(255,255,255,.85);font-size:.8rem;line-height:1.5;margin:0}
.art-cta-btn{
  display:inline-flex;align-items:center;gap:.45rem;
  background:#fff;color:var(--sky-d);
  padding:.6rem 1.4rem;border-radius:99px;
  font-size:.82rem;font-weight:800;white-space:nowrap;
  box-shadow:0 4px 14px rgba(255,255,255,.22);
  transition:var(--tr);flex-shrink:0;position:relative;z-index:1;
}
.art-cta-btn:hover{background:var(--sky-ll);transform:translateY(-1px)}

/* ── TOC SIDEBAR ── */
.toc-side{padding:.4rem 0}
.toc-side a{display:block;padding:.32rem .9rem;font-size:.78rem;color:var(--ink2);border-left:2px solid transparent;transition:var(--tr);line-height:1.4}
.toc-side a:hover,.toc-side a.active{color:var(--sky-d);border-left-color:var(--sky);background:var(--sky-ll)}
.toc-side .toc-h3{padding-left:1.75rem;font-size:.73rem;color:var(--ink3)}

/* ════════════════════════════════════════════════════════════════
   SHOW — COMMENTAIRES
════════════════════════════════════════════════════════════════ */
.comments-section{background:var(--surf);border-radius:var(--r-lg);border:1px solid var(--bdr2);box-shadow:var(--sh);overflow:hidden;margin-bottom:1.5rem}
.comments-hd{padding:1rem 1.4rem;border-bottom:1px solid var(--bdr2);display:flex;align-items:center;gap:.65rem}
.comments-hd-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--sky),var(--sky-d));display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;flex-shrink:0}
.comments-hd-title{font-size:1rem;font-weight:800;color:var(--navy)}
.comments-body{padding:1.1rem 1.4rem}
.cmt-item{padding:.9rem 0;border-bottom:1px solid var(--bdr2);position:relative;padding-left:.9rem}
.cmt-item:last-child{border-bottom:none}
.cmt-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--sky),var(--sky-d));border-radius:99px}
.cmt-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;flex-wrap:wrap;gap:.4rem}
.cmt-author-row{display:flex;align-items:center;gap:.5rem}
.cmt-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--sky-l),var(--sky));color:var(--sky-d);font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cmt-name{font-size:.85rem;font-weight:700;color:var(--ink)}
.cmt-date{font-size:.68rem;color:var(--ink3);background:var(--sky-ll);padding:.18rem .55rem;border-radius:5px}
.cmt-text{font-size:.85rem;line-height:1.65;color:var(--ink2)}
.cmt-empty{text-align:center;padding:2.25rem;color:var(--ink3)}
.cmt-empty i{font-size:2rem;display:block;margin-bottom:.55rem;opacity:.3}
.cmt-form-wrap{border-top:1.5px solid var(--bdr2);padding-top:1.35rem;margin-top:.4rem}
.cmt-form-title{font-size:.9rem;font-weight:700;color:var(--navy);margin-bottom:1rem;display:flex;align-items:center;gap:.45rem}
.cmt-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-bottom:.85rem}
.cmt-label{display:block;font-size:.75rem;font-weight:700;color:var(--ink2);margin-bottom:.35rem}
.cmt-label i{color:var(--sky);margin-right:.28rem}
.cmt-input{width:100%;padding:.65rem .9rem;border:1.5px solid var(--bdr2);border-radius:var(--r-sm);font-size:.85rem;background:#f8fafc;transition:var(--tr);color:var(--ink);outline:none}
.cmt-input:focus{border-color:var(--sky);background:#fff;box-shadow:0 0 0 3px rgba(2,132,199,.10)}
.cmt-textarea{min-height:120px;resize:vertical}
.cmt-logged-in{background:var(--sky-ll);border:1px solid var(--bdr);border-radius:var(--r-sm);padding:.75rem .9rem;font-size:.82rem;color:var(--sky-d);font-weight:600;margin-bottom:.85rem;display:flex;align-items:center;gap:.45rem}
.cmt-submit{background:linear-gradient(135deg,var(--sky),var(--sky-d));color:#fff;border:none;padding:.72rem 1.75rem;border-radius:99px;font-size:.86rem;font-weight:700;cursor:pointer;transition:var(--tr);display:inline-flex;align-items:center;gap:.45rem;box-shadow:0 3px 12px rgba(2,132,199,.3)}
.cmt-submit:hover{background:linear-gradient(135deg,var(--sky-d),var(--navy));transform:translateY(-1px)}
@media(max-width:540px){.cmt-form-grid{grid-template-columns:1fr}}

/* ════════════════════════════════════════════════════════════════
   SHOW — ARTICLES SIMILAIRES
════════════════════════════════════════════════════════════════ */
.related-section{padding:2.5rem 1.25rem;background:var(--surf);border-top:1px solid var(--bdr2)}
.related-inner{max-width:1240px;margin:0 auto}
.related-hd{text-align:center;margin-bottom:1.75rem}
.related-hd h2{font-size:1.35rem;font-weight:800;color:var(--navy);display:flex;align-items:center;justify-content:center;gap:.55rem;margin-bottom:.4rem}
.related-hd p{color:var(--ink3);font-size:.85rem;max-width:520px;margin:0 auto}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.35rem}
.rel-card{background:var(--surf);border:1px solid var(--bdr2);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);transition:var(--tr)}
.rel-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg);border-color:var(--bdr)}
.rel-img{width:100%;height:165px;object-fit:cover}
.rel-img-fallback{height:165px;background:linear-gradient(135deg,var(--sky-d),var(--navy));display:flex;align-items:center;justify-content:center}
.rel-img-fallback i{font-size:2.25rem;color:rgba(255,255,255,.22)}
.rel-body{padding:1rem 1.1rem}
.rel-meta{display:flex;align-items:center;gap:.45rem;margin-bottom:.55rem;font-size:.72rem;color:var(--ink3);flex-wrap:wrap}
.rel-meta span{display:flex;align-items:center;gap:.28rem}
.rel-title{font-size:.9rem;font-weight:700;color:var(--ink);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.6rem;transition:var(--tr)}
.rel-title:hover{color:var(--sky-d)}
.rel-excerpt{font-size:.78rem;color:var(--ink3);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:.75rem;line-height:1.55}
.rel-link{display:inline-flex;align-items:center;gap:.3rem;color:var(--sky-d);font-size:.76rem;font-weight:700;background:var(--sky-ll);padding:.3rem .8rem;border-radius:99px;transition:var(--tr)}
.rel-link:hover{background:var(--sky-l);color:var(--navy)}

/* ════════════════════════════════════════════════════════════════
   SHOW — FAQ
════════════════════════════════════════════════════════════════ */
.faq-section{padding:2.25rem 1.25rem;background:var(--bg)}
.faq-inner{max-width:860px;margin:0 auto}
.faq-header{text-align:center;margin-bottom:1.75rem}
.faq-badge{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--sky),var(--sky-d));color:#fff;font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem}
.faq-header h2{font-size:1.3rem;font-weight:800;color:var(--navy);margin-bottom:.35rem}
.faq-header p{color:var(--ink3);font-size:.86rem}
.faq-item{background:var(--surf);border:1.5px solid var(--bdr2);border-radius:var(--r-sm);margin-bottom:.6rem;overflow:hidden;transition:border-color .2s}
.faq-item.open{border-color:var(--bdr)}
.faq-question-btn{
  width:100%;background:none;border:none;padding:.95rem 1.1rem;
  text-align:left;cursor:pointer;display:flex;align-items:center;
  gap:.75rem;transition:background .18s;
}
.faq-question-btn:hover{background:var(--sky-ll)}
.faq-q-icon{width:30px;height:30px;border-radius:7px;background:var(--sky-ll);color:var(--sky-d);display:flex;align-items:center;justify-content:center;font-size:.72rem;flex-shrink:0;transition:var(--tr)}
.faq-item.open .faq-q-icon{background:var(--sky);color:#fff}
.faq-q-text{flex:1;font-size:.88rem;font-weight:700;color:var(--ink);line-height:1.4;text-align:left}
.faq-toggle-icon{color:var(--ink3);transition:transform .22s;font-size:.7rem;flex-shrink:0}
.faq-item.open .faq-toggle-icon{transform:rotate(180deg);color:var(--sky-d)}
.faq-answer{
  display:none;
  padding:.2rem 1.1rem 1rem 3.9rem;
  font-size:.86rem;color:var(--ink2);line-height:1.7;
}
.faq-item.open .faq-answer{display:block;animation:faqIn .2s ease}
@keyframes faqIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.faq-answer i.ans-icon{color:var(--sky-d);margin-right:.45rem}

/* ── FLASH ── */
.flash-ok{background:linear-gradient(135deg,#10b981,#34d399);color:#fff;padding:.85rem 1.25rem;border-radius:var(--r-sm);margin-bottom:1.35rem;display:flex;align-items:center;gap:.6rem;font-size:.88rem;font-weight:600;box-shadow:0 3px 12px rgba(16,185,129,.28)}

/* ── SCROLL TO TOP ── */
#scroll-top{position:fixed;bottom:1.5rem;right:1.5rem;background:linear-gradient(135deg,var(--sky),var(--sky-d));color:#fff;border:none;width:44px;height:44px;border-radius:50%;cursor:pointer;box-shadow:0 3px 12px rgba(2,132,199,.38);opacity:0;visibility:hidden;transition:var(--tr);z-index:1000;display:flex;align-items:center;justify-content:center;font-size:.9rem}
#scroll-top.visible{opacity:1;visibility:visible}
#scroll-top:hover{background:linear-gradient(135deg,var(--sky-d),var(--navy));transform:translateY(-2px)}

/* ── EMPTY ── */
.empty-state{text-align:center;padding:3.5rem 1rem;color:var(--ink3);grid-column:1/-1}
.empty-state i{font-size:2.5rem;display:block;margin-bottom:.6rem;opacity:.32}

/* ── RESPONSIVE ── */

/* Tablet & narrow desktop */
@media(max-width:1024px){
  .blog-layout{grid-template-columns:1fr}
  .art-layout{grid-template-columns:1fr}
  .art-sidebar{position:static;top:auto}
}

/* Mobile ≤ 768px */
@media(max-width:768px){
  /* Wrap */
  .page-wrap{padding:1rem .75rem}

  /* Layout show : sidebar passe sous l'article */
  .art-layout{
    display:flex;
    flex-direction:column;
    gap:1.25rem;
  }
  .art-sidebar{display:none} /* masquée sur mobile : alourdit la lecture */

  /* Image principale : hauteur réduite, pas de débordement */
  .art-main-img-wrap{
    border-radius:var(--r-sm);
    aspect-ratio:16/9;
    margin-bottom:1rem;
    width:100%;
    overflow:hidden;
  }
  .art-main-img{width:100%;height:100%;object-fit:cover}

  /* Share strip compact */
  .share-strip{padding:.45rem .75rem;gap:.45rem;flex-wrap:wrap}
  .sh-btn{width:32px;height:32px}

  /* Carte article */
  .art-card-show{border-radius:var(--r-sm)}
  .art-content{padding:1rem .85rem}
  .toc-box{margin:.9rem .85rem}
  .art-author-sig{margin:.9rem .85rem 0;padding:.75rem .9rem;gap:.65rem}
  .art-tags{padding:.75rem .85rem}

  /* Texte article : évite tout débordement horizontal */
  .art-text{font-size:.9rem;overflow-wrap:break-word;word-break:break-word}
  .art-text h1{font-size:1.25rem;margin:1.5rem 0 .65rem}
  .art-text h2{font-size:1.1rem;margin:1.35rem 0 .6rem}
  .art-text h3{font-size:1rem;margin:1.1rem 0 .5rem}
  .art-text img{max-width:100%;height:auto;border-radius:var(--r-sm)}
  .art-text pre,.art-text code{overflow-x:auto;max-width:100%;white-space:pre-wrap;word-break:break-word}
  .art-text table{display:block;overflow-x:auto;max-width:100%}
  .art-text iframe{max-width:100%}

  /* CTA compact */
  .art-cta{padding:.9rem 1rem;flex-direction:column;gap:.65rem;text-align:center}
  .art-cta-text h3{font-size:.9rem}
  .art-cta-text p{font-size:.76rem}
  .art-cta-btn{width:100%;justify-content:center}

  /* Commentaires */
  .comments-section{border-radius:var(--r-sm)}
  .comments-hd{padding:.85rem 1rem}
  .comments-body{padding:.9rem 1rem}
  .cmt-form-grid{grid-template-columns:1fr}

  /* Articles similaires */
  .related-section{padding:1.75rem .75rem}
  .related-grid{grid-template-columns:1fr}

  /* FAQ */
  .faq-section{padding:1.75rem .75rem}
  .faq-answer{padding:.2rem .9rem .9rem 3rem}
}

/* Mobile étroit ≤ 480px */
@media(max-width:480px){
  .page-bar-inner{gap:.35rem}
  .page-bar-title{font-size:.74rem;max-width:calc(100vw - 120px)}
  .page-bar-badge{display:none}

  /* Articles index */
  .articles-grid{grid-template-columns:1fr}
  .art-img-wrap{height:185px}

  /* Show */
  .art-content{padding:.8rem .7rem}
  .toc-box{margin:.75rem .7rem}
  .art-author-sig{margin:.75rem .7rem 0;flex-direction:column;text-align:center;gap:.5rem}
  .art-tags{padding:.65rem .7rem}
  .art-text{font-size:.86rem}
  .art-text h1{font-size:1.1rem}
  .art-text h2{font-size:1rem}

  .share-strip{flex-wrap:wrap;gap:.38rem}
  .comments-hd{padding:.75rem .8rem}
  .comments-body{padding:.75rem .8rem}

  /* Scroll top button */
  #scroll-top{bottom:1rem;right:1rem;width:40px;height:40px;font-size:.82rem}
}