/* =========================================================
   BKSI — Thème global (sans hero)
   Version : 1.2.1
   Dernière modification : 2025-08-12 15:51
   Auteur : NAGALTY
   Note : fichier complet, bloc "Header (brand)" modernisé
   ========================================================= */

/* ---------- Variables ---------- */
:root{
  --bksi-bg:#0b0b0f;
  --bksi-surface:#151a22;
  --bksi-border:rgba(255,255,255,.08);
  --bksi-text:#ffffff;
  --bksi-muted:rgba(255,255,255,.65);
  --bksi-accent:#D97B29;
  --bksi-accent-2:#FF9B40;
  --bksi-shadow:0 8px 20px rgba(0,0,0,.25);

  /* alias éventuels */
  --accent:var(--bksi-accent);
  --accent-2:var(--bksi-accent-2);
}

/* ---------- Base / reset ---------- */
*,
*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:"Segoe UI", Roboto, system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
  font-size:16px; line-height:1.5;
  background:var(--bksi-bg); color:var(--bksi-text);
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--bksi-accent); text-decoration:none; }
a:hover{ text-decoration:underline; }
.sr-only{ position:absolute !important; left:-9999px !important; }
html, body{ -webkit-text-size-adjust:100%; }



/* ---------- Containers / sections ---------- */
.container{ max-width:1200px; margin:0 auto; padding:24px; }
.container.home-wrap{ padding:0 1rem; }
.section-header{ display:flex; align-items:center; gap:.65rem; margin:0 0 1rem; }
.section-title{
  font-size:2rem; margin:0; font-weight:800; position:relative;
}
.section-title::after{
  content:""; display:block; width:84px; height:3px; margin-top:.45rem;
  background:var(--bksi-accent); border-radius:3px; box-shadow:0 0 16px rgba(217,123,41,.35);
}
.cta-bar{ display:flex; gap:.8rem; flex-wrap:wrap; margin:0 0 1.6rem; }

/* =========================================================
   BKSI — Header (brand) — MODERNISÉ
   Version bloc : 1.1.0 | 2025-08-12 15:18 (UTC+02)
   Portée : .site-header.bksi + .wrap + .brand + .site-logo img
            .site-meta + .title (+ ::after) + .tagline + .bksi-sep
   ========================================================= */
.site-header.bksi{
  position: relative;
  background:
    radial-gradient(1200px 300px at 20% 0%, rgba(255,140,0,.08), transparent 60%),
    linear-gradient(#0c1116, #0b0f14);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
/* léger quadrillage en haut qui s'efface vers le bas */
.site-header.bksi::before{
  content: "";
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 100% 6px;
  pointer-events: none;
  mask-image: linear-gradient(to bottom, black, transparent 70%);
}
/* container interne */
.site-header .wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 18px 20px;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 10px 16px;
}
/* lien de marque : logo + meta */
.site-header .brand{
  display: flex;
  align-items: center;
  gap: clamp(12px, 2.2vw, 20px);
  text-decoration: none;
  color: #eaf2ff;
}
/* logo fluide + petit relief */
.site-header .site-logo img{
  display: block;
  max-height: clamp(58px, 7.5vw, 92px);
  width: auto;
  border-radius: 8px;
  filter: drop-shadow(0 6px 12px rgba(0,0,0,.35));
}
/* pile titre + tagline */
.site-header .site-meta{
  display: flex;
  flex-direction: column;
  gap: 6px;
}
/* titre boosté + glow discret + soulignement accent BKSI */
.site-header .title{
  margin: 0;
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -0.3px;
  font-size: clamp(28px, 3.6vw, 46px);
  color: #eef4ff;
  text-shadow:
    0 1px 0 rgba(0,0,0,.55),
    0 0 18px rgba(255,155,64,.10);
  position: relative;
}
.site-header .title::after{
  content: "";
  position: absolute;
  left: 0; bottom: -6px;
  width: 72%;
  height: 3px;
  background: linear-gradient(90deg, transparent, #ff9b40, transparent);
  opacity: .9;
  filter: drop-shadow(0 0 6px rgba(255,155,64,.35));
  border-radius: 2px;
}
/* sous‑titre optionnel */
.site-header .tagline{
  margin-top: 6px;
  font-size: clamp(12px, 1.25vw, 14px);
  color: rgba(255,255,255,.72);
  letter-spacing: .02em;
}
/* séparateur orange (si tu l’utilises sous le header) */
.site-header .bksi-sep{
  height: 3px;
  background: linear-gradient(90deg, rgba(255,140,0,0), rgba(255,140,0,.8), rgba(255,140,0,0));
  box-shadow: 0 0 24px rgba(255,140,0,.25);
}
/* Responsive */
@media (max-width:720px){
  .site-header .site-logo img{ max-height:72px; }
  .site-header .wrap{ padding:12px 14px; }
}
@media (max-width:520px){
  .site-header .brand{ gap:12px; }
  .site-header .site-logo img{ max-height:64px; }
  .site-header .title::after{ width:64%; bottom:-5px; }
}

/* ---------- Grilles ---------- */
.grid{ display:grid; gap:22px; }
.home-section .grid{
  grid-template-columns:repeat(auto-fit, minmax(320px,1fr));
  justify-content:center;
}
@media (min-width:1100px){
  .home-section:last-of-type .grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}

/* ---------- Cartes / listes ---------- */
.home-section{
  background-color:rgba(255,255,255,.02);
  border-radius:8px; padding:1.5rem;
}
.bksi-card{
  position:relative;
  background:linear-gradient(180deg,#12181f,#0f141a);
  border:1px solid var(--bksi-border);
  border-radius:14px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
  overflow:hidden;
}
.bksi-card::before{
  content:""; position:absolute; inset:0 auto auto 0; height:3px; width:100%;
  background:linear-gradient(90deg, transparent, var(--bksi-accent), transparent);
  box-shadow:0 0 22px rgba(255,140,0,.25);
}
.bksi-card .card-body{ position:relative; padding:16px; }

.bksi-block-title{
  display:flex; align-items:center; gap:10px;
  font-weight:800; letter-spacing:.2px;
  font-size:clamp(16px,1.4vw,18px);
  margin:8px 0 12px;
}
.bksi-block-title .dot{
  width:10px; height:10px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, var(--bksi-accent-2), var(--bksi-accent));
  box-shadow:0 0 10px rgba(255,140,0,.7);
}

.bksi-grid{ display:grid; grid-template-columns:1fr; gap:14px; }
@media (min-width:900px){ .bksi-grid.cols-2{ grid-template-columns:1fr 1fr; } }

/* === Accueil === */
.page-sommaire .bksi-item{
  position:relative; padding:14px 14px 12px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--bksi-border);
  border-radius:12px;
  transition: box-shadow .25s ease, transform .25s ease, border-color .25s ease;
}
.page-sommaire .bksi-item:hover{
  box-shadow:0 0 0 1px rgba(255,140,0,.25), 0 10px 28px rgba(0,0,0,.35);
  border-color:rgba(255,140,0,.25);
  transform:translateY(-1px);
}

/* === Rubriques (même rendu que l’accueil) === */
.page-rubrique .bksi-item{
  position:relative; padding:14px 14px 12px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--bksi-border);
  border-radius:12px;
  transition: box-shadow .25s ease, transform .25s ease, border-color .25s ease;
}
.page-rubrique .bksi-item:hover{
  box-shadow:0 0 0 1px rgba(255,140,0,.25), 0 10px 28px rgba(0,0,0,.35);
  border-color:rgba(255,140,0,.25);
  transform:translateY(-1px);
}

/* === Membres (pas de hover qui bouge) === */
.page-membres .bksi-item{
  position:relative; padding:14px 14px 12px;
  background:rgba(255,255,255,.02);
  border:1px solid var(--bksi-border);
  border-radius:12px;
  display:flex; flex-direction:column; height:100%;
}
/* neutralise tout hover résiduel */
.page-membres .bksi-item:hover{
  box-shadow:none; transform:none; border-color:var(--bksi-border);
}

/* éléments communs (conservent ton style d'origine) */
.bksi-item .kicker{ font-size:12px; text-transform:uppercase; letter-spacing:.12em; color:var(--bksi-muted); }
.bksi-item .title{ font-weight:800; font-size:clamp(15px,1.4vw,17px); margin:6px 0 2px; }
.bksi-item .thumb{
  display:block; position:relative; overflow:hidden;
  border-radius:10px; border:1px solid var(--bksi-border);
  margin:10px 0 10px; background:#0e141a;
}
.bksi-item .thumb img{ display:block; width:100%; height:auto; transform:translateZ(0); transition:transform .35s; }
.bksi-item .thumb::after{ content:""; position:absolute; inset:0; pointer-events:none; background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.18)); }

.page-membres .bksi-grid{
  display:grid; grid-template-columns:repeat(5, minmax(0,1fr));
  gap:22px; align-items:stretch;
}
@media (max-width:1280px){ .page-membres .bksi-grid{ grid-template-columns:repeat(4,1fr); } }
@media (max-width:1024px){ .page-membres .bksi-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:820px){  .page-membres .bksi-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){  .page-membres .bksi-grid{ grid-template-columns:1fr; } }

.page-membres .bksi-item .excerpt{ flex:1 1 auto; margin-top:8px; }
.page-membres .bksi-item .cta-cuivre{ margin-top:auto; }
.page-membres .bksi-item .tags{ margin-top:12px; }



.bksi-item .kicker{
  font-size:12px; text-transform:uppercase; letter-spacing:.12em; color:var(--bksi-muted);
}
.bksi-item .title{ font-weight:800; font-size:clamp(15px,1.4vw,17px); margin:6px 0 2px; }

.bksi-item .thumb{
  display:block; position:relative; overflow:hidden;
  border-radius:10px; border:1px solid var(--bksi-border);
  margin:10px 0 10px; background:#0e141a;
}
.bksi-item .thumb img{ display:block; width:100%; height:auto; transform:translateZ(0); transition:transform .35s; }
.bksi-item .thumb::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,.18));
}

.bksi-badges{ display:flex; gap:8px; align-items:center; }
.badge{
  padding:4px 10px; font-size:12px; line-height:1;
  border-radius:999px; background:rgba(255,255,255,.06);
  color:var(--bksi-muted); border:1px solid var(--bksi-border);
}
.badge.accent{
  background:linear-gradient(180deg, var(--bksi-accent-2), var(--bksi-accent));
  color:#1a1207; border:none; box-shadow:0 4px 18px rgba(255,140,0,.25); font-weight:800;
}

/* ---------- Boutons BKSI ---------- */
.bksi-btn{
  display:inline-block; padding:8px 14px; border-radius:10px;
  background:linear-gradient(180deg, var(--bksi-accent-2), var(--bksi-accent));
  color:#1a1207; font-weight:800; text-decoration:none;
  box-shadow:0 8px 20px rgba(255,140,0,.25);
}
.bksi-btn.dark{
  background:linear-gradient(180deg,#1a1f25,#141a21);
  color:var(--bksi-text); border:1px solid var(--bksi-border);
}
.bksi-btn:hover{ filter:brightness(1.06); box-shadow:0 10px 26px rgba(255,140,0,.28); }

.bksi-section-footer{ text-align:right; padding:10px 14px 14px; }

/* ---------- Page Article : gabarit & typo ---------- */
.container.article-wrap{ max-width:980px; margin:0 auto; padding:0 1rem 2.5rem; }

.post{ background:rgba(255,255,255,.02); border:1px solid var(--bksi-border); border-radius:12px; padding:18px; }
.post-chapo{ font-size:1.05rem; color:var(--bksi-muted); margin:0 0 10px; }
.post-content{ font-size:1.03rem; line-height:1.75; }
.post-content p{ margin:0 0 1.05rem; color:#f5f7fa; }
.post-content h2,.post-content h3,.post-content h4{ margin:1.6rem 0 .6rem; }
.post-content h2{ font-size:1.4rem; } .post-content h3{ font-size:1.2rem; }
.post-content ul, .post-content ol{ padding-left:1.15rem; margin:.45rem 0 1rem; }
.post-content li{ margin:.25rem 0; }

/* Citations & code */
.post-content blockquote{
  margin:1.1rem 0; padding:.85rem 1rem; border-left:3px solid var(--bksi-accent);
  background:rgba(255,255,255,.03); color:#e9edf3; border-radius:6px;
}
.post-content pre, .post-content code{
  font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
}
.post-content pre{
  background:#0b0f14; color:#e2e8f0; padding:12px; border-radius:8px; border:1px solid var(--bksi-border);
  overflow:auto; margin:1rem 0;
}
.post-content code{ background:#0b0f14; color:#e2e8f0; padding:.15rem .35rem; border-radius:4px; }
.post-content pre code{ padding:0; background:transparent; }

/* Tableaux SPIP */
.post-content table{ width:100%; border-collapse:collapse; margin:1rem 0; font-size:.98rem; }
.post-content th, .post-content td{ border:1px solid var(--bksi-border); padding:.5rem .55rem; }
.post-content th{ background:rgba(255,255,255,.04); text-align:left; }

/* Galerie */
.post-gallery{ margin:1.5rem 0 1rem; }
.h-sub{ margin:.2rem 0 .75rem; font-size:1.05rem; color:var(--bksi-muted); letter-spacing:.03em; text-transform:uppercase; }
.gal-grid{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:10px; }
.gal-item{ display:block; border:1px solid var(--bksi-border); border-radius:8px; overflow:hidden; background:#0c1016; }
.gal-item img{ width:100%; height:100%; object-fit:cover; transition:transform .35s; }
.gal-item:hover img{ transform:scale(1.03); }
.legend{ display:block; text-align:center; font-size:.85rem; color:var(--bksi-muted); margin-top:.35rem; }

/* Pièces jointes */
.post-docs{ margin:1.2rem 0 1rem; }
.doc-list{ list-style:none; padding:0; margin:0; display:grid; gap:.45rem; }
.doc-link{
  display:flex; align-items:center; gap:.5rem; border:1px solid var(--bksi-border);
  padding:.55rem .65rem; border-radius:8px; background:rgba(255,255,255,.02);
}
.doc-link:hover{ border-color:var(--bksi-accent); text-decoration:none; }
.doc-meta{ color:var(--bksi-muted); font-size:.9rem; }

/* Post‑scriptum & nav */
.post-ps{ margin:1.3rem 0 0; padding:1rem; border:1px solid var(--bksi-border); border-radius:10px; background:rgba(255,255,255,.02); }
.post-nav{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:1.4rem 0 0; }
.navcard{ display:block; padding:.7rem .8rem; border:1px solid var(--bksi-border); border-radius:10px; background:rgba(255,255,255,.02); }
.navcard:hover{ border-color:var(--bksi-accent); text-decoration:none; }
.n-label{ display:block; color:var(--bksi-muted); font-size:.85rem; }
.n-title{ display:block; font-weight:800; color:#fff; margin-top:.15rem; }

/* Espace après le dernier bloc sur la page sommaire */
body.page-sommaire .home-section:last-of-type {
  margin-bottom: 48px; /* ajuste la valeur si besoin */
}

/* ---------- Footer ---------- */
.footer{
  text-align:center; padding:1rem 0; background:var(--bksi-bg); color:var(--bksi-muted);
  border-top:2px solid var(--bksi-accent); box-shadow:0 -2px 10px rgba(217,123,41,0.3) inset;
}
.footer .colophon{ margin:0; font-size:.95rem; }
.footer a{ color:var(--accent); }
.footer a:hover{ color:var(--accent-2); }

/* ---------- Accessibilité ---------- */
a:focus, button:focus, .btn:focus{ outline:2px solid rgba(208,77,58,.85); outline-offset:2px; }
::selection{ background:rgba(208,77,58,.35); color:#fff; }

/* === Sommaire : cartes alignées + placeholder quand pas d'image === */
.page-sommaire .bksi-grid.cols-2{ align-items:stretch; }
.page-sommaire .bksi-item{
  display:flex;
  flex-direction:column;
  height:100%;
}
/* Vignette : même hauteur pour tout le monde */
.page-sommaire .bksi-item .thumb{
  height:210px;              /* ajuste si tu veux */
  margin:10px 0 10px;
  border:1px solid var(--bksi-border);
  border-radius:10px;
  overflow:hidden;
  background:#0e141a;
}

/* Forcer le ratio 16:9 des vignettes */
.page-sommaire .bksi-item .thumb{
  aspect-ratio: 16 / 9; /* garde toujours le format paysage */
  height: auto;         /* supprime la hauteur forcée */
}

/* Image non recadrée */
.page-sommaire .bksi-item .thumb img{
  width:100%;
  height:auto;
  object-fit:contain; /* garde toute l’image */
}

/* Placeholder discret si pas d’image */
.page-sommaire .bksi-item.no-thumb .thumb{
  background:
    radial-gradient(600px 200px at 30% 0%, rgba(255,155,64,.08), transparent 60%),
    linear-gradient(180deg,#111822,#0d131a);
  position:relative;
}
.page-sommaire .bksi-item.no-thumb .thumb::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(0,0,0,.18));
  pointer-events:none;
}
/* === Fix du décalage des cartes dans la grille du sommaire === */
.page-sommaire .bksi-grid .bksi-item {
  margin-top: 0 !important;   /* on supprime la marge entre items en grille */
}
.page-sommaire .bksi-grid.cols-2 {
  gap: 14px;                   /* géré uniquement par le gap */
  align-items: stretch;        /* étire toutes les cartes à la même hauteur */
}
/* Optionnel : clamp de l'extrait pour régulariser la hauteur */
.page-sommaire .bksi-item .excerpt {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;       /* max 3 lignes */
  overflow: hidden;
}
/* === Sommaire : fix du décalage des cartes dans la grille === */
.page-sommaire .bksi-grid .bksi-item{
  margin-top: 0 !important;   /* on neutralise la marge héritée */
}
.page-sommaire .bksi-grid.cols-2{
  gap: 14px;                   /* l'espacement est géré par le gap */
  align-items: stretch;
}
/* Optionnel : clamp propre des extraits pour des hauteurs plus régulières */
.page-sommaire .bksi-item .excerpt{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;       /* 3 lignes max */
  overflow: hidden;
}
.bksi-block-title {
  text-transform: uppercase;
}

/* Effet zoom + fade + ombre animée pour les logos (articles, rubriques, sommaire) */
.logo-article.zoom-in,
.logo-rubrique.zoom-in,
.logo-sommaire.zoom-in {
  opacity: 0;
  transform: scale(0.96);
  animation: zoomFadeShadow 0.8s ease forwards;
  animation-delay: 0.15s;
  box-shadow: 0 0 0 rgba(255, 155, 64, 0);
}
@keyframes zoomFadeShadow {
  0% {
    opacity: 0;
    transform: scale(0.96);
    box-shadow: 0 0 0 rgba(255, 155, 64, 0);
  }
  60% {
    opacity: 1;
    transform: scale(1.02);
    box-shadow: 0 0 14px rgba(255, 155, 64, 0.25);
  }
  100% {
    opacity: 1;
    transform: scale(1);
    box-shadow: 0 0 10px rgba(255, 155, 64, 0.15);
  }
}

/* =========================================================
   BKSI — PATCH Header (brand) — sans animation (SAFE OVERRIDE)
   Date : 2025-08-12 15:55 (UTC+02)
   Usage : coller à la FIN de bksi.css (sans toucher au reste)
   Effets : logo un peu plus grand, gap ajusté, titre gradient doux,
            soulignement plus net, tagline plus lisible.
   ========================================================= */

.site-header .brand{
  align-items: center;
  gap: clamp(14px, 2.4vw, 22px);
}

.site-header .site-logo img{
  max-height: clamp(62px, 8vw, 100px);
  border-radius: 8px;
  filter: drop-shadow(0 6px 14px rgba(0,0,0,.35));
}

/* Titre : fallback couleur intact (hérité), gradient appliqué si supporté */
@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .site-header .title{
    background: linear-gradient(
      180deg,
      #ffffff 0%,
      #ffe4c4 40%,
      #ff9b40 60%,
      #ffd8a6 100%
    );
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
            color: transparent;
  }
}

/* Soulignement "rayon" un peu plus marqué (pas d'animation) */
.site-header .title::after{
  height: 4px;
  width: 76%;
  bottom: -8px;
  background: linear-gradient(90deg,
    rgba(255,155,64,0) 0%,
    rgba(255,155,64,.95) 50%,
    rgba(255,155,64,0) 100%);
  border-radius: 3px;
  box-shadow:
    0 0 10px rgba(255,155,64,.45),
    0 0 22px rgba(255,155,64,.25);
}

/* Tagline : un poil plus lisible */
.site-header .tagline{
  margin-top: 8px;
  font-size: clamp(12px, 1.25vw, 15px);
  color: rgba(235,241,250,.78);
  letter-spacing: .02em;
}

/* Petits écrans */
@media (max-width: 520px){
  .site-header .site-logo img{ max-height: 70px; }
  .site-header .title::after{ width: 66%; bottom: -6px; height: 3px; }
}
/* micro-polish header */
.site-header .title{ transform: translateY(1px); }           /* aligne un poil avec le logo */
.site-header .title::after{ width: 78%; }                     /* trait un peu plus long (72% → 78%) */
.site-header .site-logo img{ max-height: clamp(64px, 8vw, 102px); } /* logo +2px */

/* =========================================================
   BKSI — Thème "Cuivre sombre"
   Date : 2025‑08‑12 16:05 (UTC+02)
   Patch SAFE : surcharge couleurs uniquement
   ========================================================= */

/* Palette cuivre sombre */
:root{
  --bksi-bg: #0b0b0f;              /* inchangé */
  --bksi-text: #ffffff;            /* inchangé */

  /* Cuivres */
  --bksi-orange:       #d67a35;    /* cuivre principal (remplace accent) */
  --bksi-orange-light: #e28c48;    /* cuivre clair (glow) */
  --bksi-orange-dark:  #a55a24;    /* cuivre foncé (bordures/hover) */

  /* Mappage des anciens alias → nouveaux tons */
  --bksi-accent:   var(--bksi-orange);
  --bksi-accent-2: var(--bksi-orange-light);

  /* Bordures un peu plus chaudes */
  --bksi-border: rgba(226, 140, 72, .10);
}

/* -------- Header (brand) harmonisé cuivre -------- */
.site-header .title{
  /* gradient cuivre (avec fallback si non supporté) */
  color: #f2e7dd;
  background: linear-gradient(180deg, #fff 0%, #f3d7c0 40%, var(--bksi-orange) 60%, #ffd8a6 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  text-shadow: 0 1px 0 rgba(0,0,0,.55), 0 0 16px rgba(226,140,72,.12);
}
.site-header .title::after{
  background: linear-gradient(90deg, transparent, var(--bksi-orange), transparent);
  box-shadow: 0 0 8px rgba(226,140,72,.35);
}
.site-header .bksi-sep{
  background: linear-gradient(90deg, rgba(214,122,53,0), rgba(214,122,53,.85), rgba(214,122,53,0));
  box-shadow: 0 0 20px rgba(214,122,53,.25);
}

/* -------- Boutons & badges en cuivre -------- */
.btn-primary{
  background: var(--bksi-orange);
  border-color: var(--bksi-orange);
}
.btn-primary:hover{ filter: brightness(1.04); }

.badge.accent{
  background: linear-gradient(180deg, var(--bksi-orange-light), var(--bksi-orange));
  box-shadow: 0 4px 18px rgba(214,122,53,.25);
}

/* -------- Cartes / encadrés : bordures chaudes -------- */
.bksi-card,
.post,
.navcard,
.doc-link,
.post-ps,
.gal-item,
.bksi-item{
  border-color: var(--bksi-border);
}
.bksi-item:hover{
  border-color: rgba(214,122,53,.28);
  box-shadow: 0 0 12px rgba(214,122,53,.14), 0 8px 20px rgba(0,0,0,.35);
}

/* -------- Liens et états actifs -------- */
a{ color: var(--bksi-orange); }
a:hover{ color: var(--bksi-orange-light); }

/* Titres blocs soulignés (sommaire/rubrique/tous articles) */
.page-sommaire .bksi-block-title::after,
.page-rubrique .bksi-block-title::after,
.page-tous-articles .bksi-block-title::after{
  background: var(--bksi-orange);
  box-shadow: 0 0 16px rgba(226,140,72,.35);
}

/* Bouton CTA générique */
.bksi-btn{
  background: linear-gradient(180deg, var(--bksi-orange-light), var(--bksi-orange));
  box-shadow: 0 8px 20px rgba(214,122,53,.25);
}
.bksi-btn.dark{ border-color: var(--bksi-border); }

/* Kicker / puces décoratives */
.bksi-block-title .dot,
.page-tous-articles .kicker .dot{
  background: radial-gradient(circle at 30% 30%, var(--bksi-orange-light), var(--bksi-orange));
  box-shadow: 0 0 8px rgba(214,122,53,.5);
}
/* =========================================================
   BKSI — Ajustement couleur cuivre foncé pour titres blocs
   ========================================================= */
.bksi-block-title .dot {
  background: radial-gradient(circle at 30% 30%, #da8543, #a55a24) !important;
  box-shadow: 0 0 8px rgba(165, 90, 36, 0.45) !important;
}

.bksi-block-title::after {
  background: linear-gradient(90deg, transparent, #a55a24, transparent) !important;
  box-shadow: 0 0 14px rgba(165, 90, 36, 0.3) !important;
  height: 3px;
}

/* === BKSI — Hover cartes (scopé : sommaire + rubriques) === */

/* État normal */
.page-sommaire .bksi-item,
.page-rubrique:not(.page-membres) .bksi-item {
  border:1px solid var(--bksi-border);
  border-radius:12px;
  background:rgba(255,255,255,.03);
  box-shadow:0 2px 8px rgba(0,0,0,.35);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  transform:translateY(0);
}

/* Hover */
.page-sommaire .bksi-item:hover,
.page-rubrique:not(.page-membres) .bksi-item:hover {
  transform:translateY(-3px);
  box-shadow:0 8px 20px rgba(0,0,0,.50), 0 0 12px rgba(255,155,64,.15);
  border-color:var(--bksi-accent);
}

/* Sécurité : on neutralise l’hover pour les fiches membres */
.page-rubrique.page-membres .bksi-item:hover,
.page-rubrique.page-membres .member-card:hover {
  transform:none !important;
  box-shadow:none !important;
  border-color:var(--bksi-border) !important;
}


/* Sécurité explicite : la page membres NE bouge PAS */
.page-rubrique.page-membres :is(.bksi-item, .member-card):hover{
  transform:none !important;
  box-shadow:none !important;
  border-color:var(--bksi-border) !important;
}

/* === Sommaire : "Lire la suite" aligné + barre cuivre au hover === */

/* La carte est déjà en flex-column ; on fait pousser l’extrait */
.page-sommaire .bksi-item .excerpt{
  flex: 1 1 auto;   /* prend la place dispo pour caler le CTA en bas */
}

/* Style du lien "Lire la suite" (sans changer le HTML) */
.page-sommaire .bksi-item a.more,
.page-sommaire .bksi-item .read-more,
.page-sommaire .bksi-item a.more-link,
.page-sommaire .bksi-item a[href*="Lire la suite"]{
  position: relative;
  display: inline-block;
  font-weight: 700;
  color: var(--bksi-accent);
  padding-bottom: 6px;           /* espace pour la barre */
  text-decoration: none;         /* propre */
}

/* Barre cuivre façon "liste des membres" */
.page-sommaire .bksi-item a.more::after,
.page-sommaire .bksi-item .read-more::after,
.page-sommaire .bksi-item a.more-link::after,
.page-sommaire .bksi-item a[href*="Lire la suite"]::after{
  content: "";
  position: absolute;
  left: 0; right: auto;
  bottom: 0;
  height: 3px;
  width: 0;                              /* cachée par défaut */
  background: linear-gradient(90deg, transparent, var(--bksi-accent), transparent);
  box-shadow: 0 0 14px rgba(255,155,64,.25);
  border-radius: 3px;
  transition: width .25s ease;
}

/* Déploiement de la barre au hover/focus (accessibilité) */
.page-sommaire .bksi-item a.more:hover::after,
.page-sommaire .bksi-item a.more:focus::after,
.page-sommaire .bksi-item .read-more:hover::after,
.page-sommaire .bksi-item .read-more:focus::after,
.page-sommaire .bksi-item a.more-link:hover::after,
.page-sommaire .bksi-item a.more-link:focus::after,
.page-sommaire .bksi-item a[href*="Lire la suite"]:hover::after,
.page-sommaire .bksi-item a[href*="Lire la suite"]:focus::after{
  width: 120px;                        /* même esprit que "Voir la fiche" */
}

/* === CTA Cuivre — Glow cuivré === */
a.cta-cuivre{
  --cuivre: #f08c1b;
  --bar-h: 2px;       /* épaisseur de la barre */
  --gap: 4px;         /* écart texte/barre */
  position: relative;
  display: inline-block;
  align-self: flex-start;
  color: var(--cuivre);
  font-weight: 700;
  text-decoration: none;
  line-height: 1.2;
  padding-bottom: var(--gap);
}

a.cta-cuivre::after{
  content:"";
  position:absolute; left:0; bottom:0;
  height: var(--bar-h);
  width: 0;
  background: linear-gradient(90deg, transparent, var(--cuivre), transparent);
  box-shadow: 0 0 14px color-mix(in oklab, var(--cuivre) 50%, black);
  transition: width .35s cubic-bezier(.22,.61,.36,1);
}

a.cta-cuivre:hover::after,
a.cta-cuivre:focus-visible::after{
  width: 100%;
}

/* Accessibilité focus */
a.cta-cuivre:focus-visible{
  outline: 2px solid color-mix(in oklab, var(--cuivre) 60%, white);
  outline-offset: 2px;
}

/* === Rubriques : aligner les cartes et le CTA en bas === */
.page-rubrique .bksi-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 26px;
  align-items: stretch; /* chaque carte prend la même hauteur */
}

.page-rubrique .bksi-item{
  display: flex;
  flex-direction: column; /* empile titre, image, texte, CTA */
}

.page-rubrique .bksi-item .thumb{ flex: 0 0 auto; }  /* l'image ne s'étire pas */
.page-rubrique .bksi-item .excerpt{ flex: 1 1 auto; margin-top: 12px; } /* prend le restant */
.page-rubrique .bksi-item .cta-cuivre{ margin-top: auto; } /* pousse le CTA en bas */


/* === SCOPE ACCUEIL : hover/ombre sur les cartes === */
.page-sommaire .bksi-item {
  display: flex;
  flex-direction: column;
  background: rgba(15,20,26,.88);
  border: 1px solid rgba(255,155,64,.14);
  border-radius: 10px;
  padding: 14px;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.page-sommaire .bksi-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 0 12px rgba(255,155,64,.15), 0 8px 20px rgba(0,0,0,.40);
  border-color: rgba(255,155,64,.28);
}
.page-sommaire .bksi-item .thumb{ aspect-ratio:16/9; display:block; overflow:hidden; border-radius:8px; margin-bottom:10px; }
.page-sommaire .bksi-item .thumb img{ width:100%; height:auto; object-fit:cover; display:block; }
.page-sommaire .bksi-item .excerpt{ flex:1 1 auto; margin-top:8px; }
.page-sommaire .bksi-item .cta-cuivre{ margin-top:auto; }

/* === SCOPE MEMBRES : layout stable + grille responsive === */
.page-membres .bksi-grid{
  display:grid;
  grid-template-columns:repeat(5, minmax(0,1fr));
  gap:22px;
  align-items:stretch;
}
@media (max-width:1280px){ .page-membres .bksi-grid{ grid-template-columns:repeat(4,1fr); } }
@media (max-width:1024px){ .page-membres .bksi-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:820px){  .page-membres .bksi-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){  .page-membres .bksi-grid{ grid-template-columns:1fr; } }

.page-membres .bksi-item{
  display:flex; flex-direction:column; height:100%;
  background: rgba(15,20,26,.88);
  border:1px solid rgba(255,155,64,.14);
  border-radius:10px;
  padding:14px;
}
.page-membres .bksi-item .thumb{ aspect-ratio:16/9; display:block; overflow:hidden; border-radius:8px; margin-bottom:10px; }
.page-membres .bksi-item .thumb img{ width:100%; height:auto; object-fit:cover; display:block; }
.page-membres .bksi-item .excerpt{ flex:1 1 auto; margin-top:8px; }
.page-membres .bksi-item .cta-cuivre{ margin-top:auto; }
.page-membres .bksi-item .tags{ margin-top:12px; }

/* === CTA cuivre (glow) — classe unique partout === */
a.cta-cuivre{
  --cuivre:#f08c1b; --bar-h:2px; --gap:4px;
  position:relative; display:inline-block; align-self:flex-start;
  color:var(--cuivre); font-weight:700; text-decoration:none;
  line-height:1.2; padding-bottom:var(--gap);
}
a.cta-cuivre::after{
  content:""; position:absolute; left:0; bottom:0; height:var(--bar-h); width:0;
  background:linear-gradient(90deg,transparent,var(--cuivre),transparent);
  box-shadow:0 0 14px rgba(240,140,27,.5);
  transition:width .35s cubic-bezier(.22,.61,.36,1);
}
a.cta-cuivre:hover::after,
a.cta-cuivre:focus-visible::after{ width:100%; }
