/* ============================================================
   Blog & articles — complète site.css (réutilise ses :root vars)
   ============================================================ */
.blog-main{padding-top:118px;min-height:60vh}
.blog-head{max-width:760px;margin:0 auto 46px;text-align:center;padding:0 22px}
.blog-head .eyebrow{display:inline-block;font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--violet);background:var(--lav);padding:6px 14px;border-radius:999px;margin-bottom:18px}
.blog-head h1{font-family:var(--serif);font-weight:600;font-size:clamp(34px,5vw,52px);line-height:1.05;color:var(--ink);margin:0 0 16px}
.blog-head p{color:var(--ink-soft);font-size:18px;line-height:1.6;margin:0}

/* grille des cartes */
.blog-grid{max-width:1140px;margin:0 auto;padding:0 22px 90px;display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
@media(max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}
.acard{display:flex;flex-direction:column;background:#fffdf9;border-radius:22px;overflow:hidden;box-shadow:0 16px 40px -28px rgba(27,31,59,.3);transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .4s;text-decoration:none;color:inherit}
.acard:hover{transform:translateY(-7px);box-shadow:0 32px 60px -30px rgba(123,91,214,.42)}
.acard-cover{aspect-ratio:16/10;background:var(--lav) center/cover no-repeat;display:block}
.acard-ph{aspect-ratio:16/10;background:linear-gradient(135deg,var(--lav),var(--mint))}
.acard-body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
.acard-body h2{font-family:var(--serif);font-weight:600;font-size:21px;line-height:1.2;color:var(--ink);margin:0}
.acard-body p{color:var(--ink-soft);font-size:14.5px;line-height:1.55;margin:0;flex:1}
.acard-more{font-family:var(--sans);font-weight:700;font-size:14px;color:var(--violet);display:inline-flex;align-items:center;gap:7px;margin-top:6px}
.acard:hover .acard-more svg{transform:translateX(4px)}
.acard-more svg{width:16px;height:16px;transition:transform .3s}
.blog-empty{max-width:620px;margin:0 auto 90px;text-align:center;color:var(--ink-soft);background:#fffdf9;border-radius:20px;padding:48px 30px}

/* page article (mode thème) */
.article-hero{max-width:820px;margin:0 auto;padding:118px 22px 0;text-align:center}
.article-meta{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--violet);margin-bottom:16px}
.article-hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(32px,5vw,50px);line-height:1.06;color:var(--ink);margin:0 0 18px}
.article-lead{color:var(--ink-soft);font-size:19px;line-height:1.6;max-width:680px;margin:0 auto}
.article-cover{max-width:1000px;margin:42px auto 0;padding:0 22px}
.article-cover img{width:100%;border-radius:22px;display:block;box-shadow:0 24px 60px -34px rgba(27,31,59,.45)}

.article-body{max-width:720px;margin:48px auto 70px;padding:0 22px;font-family:var(--sans);color:var(--ink);font-size:17.5px;line-height:1.78}
.article-body h2{font-family:var(--serif);font-weight:600;font-size:30px;line-height:1.15;margin:46px 0 16px;color:var(--ink)}
.article-body h3{font-family:var(--serif);font-weight:600;font-size:23px;margin:34px 0 12px;color:var(--ink)}
.article-body p{margin:0 0 20px}
.article-body a{color:var(--violet);text-decoration:underline;text-underline-offset:3px}
.article-body ul,.article-body ol{margin:0 0 20px;padding-left:24px}
.article-body li{margin:0 0 9px}
.article-body img{max-width:100%;height:auto;border-radius:16px;margin:24px 0;display:block}
.article-body blockquote{margin:26px 0;padding:14px 24px;border-left:4px solid var(--violet);background:var(--lav);border-radius:0 12px 12px 0;color:var(--ink-soft);font-style:italic}
.article-body pre{background:#1a1d36;color:#f2eefb;padding:18px 20px;border-radius:14px;overflow:auto;font-family:var(--mono);font-size:14px;margin:24px 0}
.article-body code{font-family:var(--mono);font-size:.9em;background:var(--lav);padding:2px 6px;border-radius:6px}
.article-body pre code{background:none;padding:0}
.article-gallery{max-width:720px;margin:0 auto 60px;padding:0 22px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.article-gallery img{width:100%;border-radius:14px;display:block}
@media(max-width:600px){.article-gallery{grid-template-columns:1fr}}
.article-back{max-width:720px;margin:0 auto 80px;padding:0 22px}
.article-back a{font-family:var(--sans);font-weight:700;color:var(--violet);display:inline-flex;align-items:center;gap:8px}

/* pied de page slim pour le blog */
.blog-foot{background:var(--ink);color:#cfd2e8;padding:30px 0;margin-top:40px}
.blog-foot-in{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.blog-foot .brand-logo{height:30px;filter:brightness(0) invert(1);opacity:.92}
.blog-foot-links{display:flex;gap:22px;flex-wrap:wrap}
.blog-foot-links a{color:#cfd2e8;text-decoration:none;font-size:14.5px}
.blog-foot-links a:hover{color:#fff}
.blog-foot-copy{font-size:13px;color:#9aa0c4}

/* ===================== Améliorations SEO / UX ===================== */

/* Fil d'Ariane */
.crumbs{max-width:820px;margin:0 auto;padding:110px 22px 0;display:flex;flex-wrap:wrap;align-items:center;gap:8px;
  font-family:var(--sans);font-size:13.5px;color:var(--muted)}
.crumbs a{color:var(--muted);text-decoration:none}
.crumbs a:hover{color:var(--violet)}
.crumbs span{color:var(--line)}
.crumbs .cur{color:var(--ink-soft);font-weight:600;max-width:60ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.crumbs + .article-hero{padding-top:22px}

/* Cover : réserve la place (évite le layout shift) */
.article-cover img{aspect-ratio:16/9;object-fit:cover;height:auto}

/* Sommaire (table des matières) */
.toc{max-width:720px;margin:40px auto 0;padding:18px 22px;background:var(--paper-2);border:1px solid var(--line);
  border-radius:16px;font-family:var(--sans)}
.toc-title{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:10px}
.toc ol{list-style:none;margin:0;padding:0;counter-reset:toc}
.toc li{margin:5px 0}
.toc li.lvl3{margin-left:18px;font-size:14.5px}
.toc a{color:var(--ink-soft);text-decoration:none;border-bottom:1px solid transparent;transition:.15s}
.toc a:hover{color:var(--violet);border-color:var(--violet)}

/* Articles liés */
.related{max-width:1140px;margin:10px auto 80px;padding:40px 22px 0;border-top:1px solid var(--line)}
.related-title{font-family:var(--serif);font-weight:600;font-size:26px;color:var(--ink);text-align:center;margin:0 0 28px}

/* Filtres + recherche du blog */
.blog-filters{max-width:1140px;margin:-22px auto 30px;padding:0 22px;display:flex;flex-direction:column;gap:16px;align-items:center}
.blog-search{display:flex;align-items:center;gap:8px;width:100%;max-width:560px;background:var(--paper-2);
  border:1px solid var(--line);border-radius:999px;padding:6px 6px 6px 16px;box-shadow:var(--shadow-sm)}
.blog-search svg{width:18px;height:18px;color:var(--muted);flex:none}
.blog-search input{flex:1;border:none;background:none;outline:none;font-family:var(--sans);font-size:15px;color:var(--ink);padding:8px 0}
.blog-search button{border:none;cursor:pointer;font-family:var(--sans);font-weight:600;font-size:14px;color:#fff;
  background:var(--grad);border-radius:999px;padding:9px 18px}
.chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.chip{font-family:var(--sans);font-size:13.5px;font-weight:600;text-decoration:none;color:var(--ink-soft);
  background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:6px 14px;transition:.15s}
.chip:hover{border-color:var(--violet);color:var(--violet)}
.chip.on{background:var(--ink);border-color:var(--ink);color:#fff}
.chips.tags .chip{color:var(--muted);font-weight:500}
.chip.tag.on{background:var(--violet);border-color:var(--violet);color:#fff}
.blog-count{text-align:center;color:var(--muted);font-family:var(--sans);font-size:14px;margin:0 auto 24px}
.blog-count a{color:var(--violet)}
.acard-cat{display:inline-block;font-family:var(--sans);font-size:11.5px;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:var(--violet);background:var(--lav);border-radius:999px;padding:3px 10px;margin-bottom:10px}

/* Pagination */
.pager{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;padding:0 22px 90px}
.pg{font-family:var(--sans);font-size:14px;font-weight:600;text-decoration:none;color:var(--ink-soft);
  background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:9px 14px;transition:.15s}
.pg:hover{border-color:var(--violet);color:var(--violet)}
.pg.num{min-width:42px;text-align:center}
.pg.on{background:var(--ink);border-color:var(--ink);color:#fff}

/* Liens utiles sur la 404 */
.nf-links{max-width:620px;margin:40px auto 0}
.nf-label{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:12px}
.nf-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.nf-grid a{font-family:var(--sans);font-size:14px;font-weight:600;text-decoration:none;color:var(--ink-soft);
  background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:8px 16px}
.nf-grid a:hover{border-color:var(--violet);color:var(--violet)}

/* Cartes projet : sous-titre client · année + bouton lien projet */
.acard-sub{font-family:var(--sans);font-size:13px;color:var(--violet);font-weight:600;margin:0 0 6px}
.proj-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;justify-content:center}
.proj-link{margin-top:22px}

/* ===================== Liste d'articles (une ligne, miniature à gauche) ===================== */
.article-list{max-width:860px;margin:0 auto;padding:0 22px;display:flex;flex-direction:column;gap:18px}
.arow{display:flex;gap:0;align-items:stretch;text-decoration:none;background:var(--paper-2);
  border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:.18s;box-shadow:var(--shadow-sm)}
.arow:hover{transform:translateY(-2px);border-color:var(--violet);box-shadow:0 16px 40px -22px rgba(123,91,214,.5)}
.arow-thumb{flex:none;width:210px;align-self:stretch;min-height:148px;background:var(--lav) center/cover no-repeat}
.arow-thumb.arow-ph{background:var(--grad)}
.arow-body{padding:18px 22px;display:flex;flex-direction:column;gap:7px;min-width:0}
.arow-body .acard-cat{margin-bottom:2px}
.arow-body h2{font-family:var(--serif);font-weight:600;font-size:21px;color:var(--ink);margin:0;line-height:1.25}
.arow-body p{color:var(--muted);font-size:14.5px;margin:0;line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.arow-date{font-family:var(--sans);font-size:12.5px;color:var(--muted);margin-top:auto;padding-top:4px}
@media (max-width:620px){
  .arow{flex-direction:column}
  .arow-thumb{width:100%;min-height:180px}
}

/* ===================== Sommaire flottant (bulle en bas à gauche) ===================== */
.toc-fab-wrap{position:fixed;left:22px;bottom:22px;z-index:60}
.toc-fab{width:52px;height:52px;border-radius:50%;border:none;cursor:pointer;background:var(--grad);color:#fff;
  box-shadow:0 14px 32px -10px rgba(123,91,214,.6);display:flex;align-items:center;justify-content:center;transition:.18s}
.toc-fab:hover{transform:translateY(-2px)}
.toc-fab svg{width:22px;height:22px}
.toc-fab-wrap.open .toc-fab{background:var(--ink)}
.toc-pop{position:absolute;left:0;bottom:64px;width:300px;max-width:78vw;max-height:60vh;overflow:auto;
  background:var(--paper-2);border:1px solid var(--line);border-radius:16px;
  box-shadow:0 24px 60px -24px rgba(20,22,40,.5);padding:16px 18px;animation:tocIn .14s ease-out}
.toc-pop[hidden]{display:none}
@keyframes tocIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.toc-pop-title{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:10px}
.toc-pop ol{list-style:none;margin:0;padding:0;counter-reset:toc}
.toc-pop li{margin:5px 0}
.toc-pop li.lvl3{margin-left:16px;font-size:13.5px}
.toc-pop a{color:var(--ink-soft);text-decoration:none;font-size:14.5px;border-bottom:1px solid transparent;transition:.15s}
.toc-pop a:hover{color:var(--violet);border-color:var(--violet)}
