/* ============================================================
   SNTPT — Feuille de style principale
   Direction : « affiche militante syndicale »
   Oswald (placard) + Inter (texte) · rouge / bleu nuit / vert Afrique
   ============================================================ */

:root{
  --c-red:#E1071A;
  --c-red-deep:#A60412;
  --c-navy:#122E55;
  --c-navy-2:#0C1E3A;
  --c-green:#1E8C42;
  --c-ink:#16181D;
  --c-paper:#F6F3EC;
  --c-paper-2:#ECE7DC;
  --c-line:#DAD3C5;
  --c-muted:#5A5A54;
  --c-white:#FFFFFF;

  --ff-display:"Oswald", "Arial Narrow", sans-serif;
  --ff-body:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --wrap:1200px;
  --r:4px;            /* coins légèrement vifs, esprit affiche */
  --shadow:0 1px 0 var(--c-line), 0 18px 40px -28px rgba(18,46,85,.4);
  --t:.2s ease;
}

/* ----------------------- Base ----------------------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--ff-body);
  font-size:17px;
  line-height:1.65;
  color:var(--c-ink);
  background:var(--c-paper);
  -webkit-font-smoothing:antialiased;
}
body.nav-locked{ overflow:hidden; }
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--c-red); text-decoration:none; transition:color var(--t); }
a:hover{ color:var(--c-red-deep); }
h1,h2,h3,h4{ font-family:var(--ff-display); font-weight:600; line-height:1.08; color:var(--c-navy); margin:0 0 .5em; letter-spacing:.01em; }
p{ margin:0 0 1.1em; }
.wrap{ max-width:var(--wrap); margin-inline:auto; padding-inline:22px; }

.screen-reader-text{
  position:absolute!important; width:1px; height:1px; overflow:hidden;
  clip:rect(1px,1px,1px,1px); white-space:nowrap; border:0; padding:0; margin:-1px;
}
.skip-link{ position:absolute; left:-999px; top:0; z-index:999; background:var(--c-navy); color:#fff; padding:.6em 1em; }
.skip-link:focus{ left:8px; top:8px; }
:focus-visible{ outline:3px solid var(--c-red); outline-offset:2px; }

/* ----------------------- Boutons ----------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--ff-display); font-weight:600; font-size:.82rem; letter-spacing:.09em;
  text-transform:uppercase; padding:.78em 1.5em; border-radius:var(--r);
  border:2px solid transparent; cursor:pointer; transition:transform var(--t),background var(--t),color var(--t),border-color var(--t);
  line-height:1;
}
.btn:hover{ transform:translateY(-2px); }
.btn--red{ background:var(--c-red); color:#fff; }
.btn--red:hover{ background:var(--c-red-deep); color:#fff; }
.btn--dark{ background:var(--c-navy); color:#fff; }
.btn--dark:hover{ background:var(--c-navy-2); color:#fff; }
.btn--ghost{ background:transparent; color:var(--c-navy); border-color:var(--c-navy); }
.btn--ghost:hover{ background:var(--c-navy); color:#fff; }
.btn--light{ background:#fff; color:var(--c-navy); }
.btn--light:hover{ background:var(--c-paper-2); color:var(--c-navy); }
.btn--lg{ padding:1em 1.9em; font-size:.92rem; }

/* ----------------------- Barre utilitaire ----------------------- */
.topbar{ background:var(--c-navy-2); color:#cdd6e4; font-size:.8rem; }
.topbar__inner{ display:flex; justify-content:space-between; align-items:center; gap:1rem; padding-block:.45rem; }
.topbar__slogan{ font-family:var(--ff-display); letter-spacing:.14em; text-transform:uppercase; color:#fff; font-size:.78rem; }
.topbar__right{ display:flex; align-items:center; gap:1.1rem; }
.topbar__link{ color:#cdd6e4; }
.topbar__link:hover{ color:#fff; }
.topbar__social{ display:inline-flex; gap:.4rem; }
.topbar__soc{
  width:24px; height:24px; display:grid; place-items:center; border:1px solid #3a4a66;
  border-radius:50%; color:#cdd6e4; font-family:var(--ff-display); font-size:.72rem;
}
.topbar__soc:hover{ background:var(--c-red); border-color:var(--c-red); color:#fff; }

/* ----------------------- En-tête ----------------------- */
.site-header{
  position:sticky; top:0; z-index:200; background:var(--c-white);
  border-bottom:3px solid var(--c-red);
  transition:box-shadow var(--t),padding var(--t);
}
.site-header.is-scrolled{ box-shadow:0 10px 30px -18px rgba(18,46,85,.55); }
.site-header__inner{ display:flex; align-items:center; gap:1.4rem; padding-block:.85rem; }
.site-header.is-scrolled .site-header__inner{ padding-block:.55rem; }

.brand{ display:inline-flex; align-items:center; gap:.7rem; }
.brand__mark,.custom-logo{ width:54px; height:54px; object-fit:contain; }
.brand__txt{ display:flex; flex-direction:column; line-height:1; }
.brand__name{ font-family:var(--ff-display); font-weight:700; font-size:1.5rem; letter-spacing:.04em; color:var(--c-navy); text-transform:uppercase; }
.brand__sub{ font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--c-muted); margin-top:3px; }

.main-nav{ margin-inline-start:auto; }
.nav__list{ list-style:none; display:flex; gap:.2rem; margin:0; padding:0; }
.nav__list li{ position:relative; }
.nav__list a{
  display:block; font-family:var(--ff-display); font-weight:500; font-size:.92rem;
  letter-spacing:.05em; text-transform:uppercase; color:var(--c-navy);
  padding:.6rem .85rem; border-radius:var(--r);
}
.nav__list a:hover,.nav__list .current-menu-item > a{ color:var(--c-red); }
.nav__list .current-menu-item > a{ background:var(--c-paper-2); }
/* sous-menus */
.nav__list .sub-menu{
  list-style:none; position:absolute; top:100%; left:0; min-width:230px; margin:0;
  padding:.4rem; background:#fff; border:1px solid var(--c-line); border-top:3px solid var(--c-red);
  box-shadow:0 20px 40px -24px rgba(18,46,85,.5); border-radius:0 0 var(--r) var(--r);
  opacity:0; visibility:hidden; transform:translateY(8px); transition:all var(--t); z-index:50;
}
.nav__list li:hover > .sub-menu,.nav__list li.is-open > .sub-menu{ opacity:1; visibility:visible; transform:none; }
.nav__list .sub-menu a{ font-size:.85rem; padding:.55rem .7rem; }

.site-header__actions{ display:flex; align-items:center; gap:.5rem; }
.nav-toggle{ display:none; width:46px; height:42px; background:var(--c-navy); border:0; border-radius:var(--r); position:relative; cursor:pointer; }
.nav-toggle__bar,.nav-toggle__bar::before,.nav-toggle__bar::after{
  content:""; position:absolute; left:50%; top:50%; width:22px; height:2px; background:#fff;
  transform:translate(-50%,-50%); transition:var(--t);
}
.nav-toggle__bar::before{ top:-7px; }
.nav-toggle__bar::after{ top:7px; }
.is-nav-open .nav-toggle__bar{ background:transparent; }
.is-nav-open .nav-toggle__bar::before{ top:0; transform:translate(-50%,-50%) rotate(45deg); }
.is-nav-open .nav-toggle__bar::after{ top:0; transform:translate(-50%,-50%) rotate(-45deg); }

/* ----------------------- HÉROS ----------------------- */
.hero{
  position:relative; overflow:hidden; color:#fff;
  background:linear-gradient(160deg,var(--c-navy) 0%,var(--c-navy-2) 100%);
}
.hero__bg{ position:absolute; inset:0; pointer-events:none; }
.hero__globe{
  position:absolute; right:-120px; top:50%; transform:translateY(-50%);
  width:560px; height:560px; border-radius:50%;
  background:
    repeating-linear-gradient(0deg,transparent 0 38px,rgba(225,7,26,.18) 38px 40px),
    repeating-linear-gradient(90deg,transparent 0 38px,rgba(225,7,26,.18) 38px 40px);
  -webkit-mask:radial-gradient(circle at center, #000 64%, transparent 66%);
          mask:radial-gradient(circle at center, #000 64%, transparent 66%);
  border:3px solid rgba(225,7,26,.35); box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);
  opacity:.9;
}
.hero__inner{ position:relative; padding-block:5.5rem 5rem; max-width:880px; }
.hero__eyebrow{
  font-family:var(--ff-display); letter-spacing:.18em; text-transform:uppercase;
  font-size:.82rem; color:#fff; margin:0 0 1rem; display:inline-block;
  border-left:4px solid var(--c-red); padding-left:.8rem;
}
.hero__title{
  font-size:clamp(3rem,8vw,6.2rem); font-weight:700; line-height:.92;
  text-transform:uppercase; color:#fff; margin:0 0 1.2rem; letter-spacing:.005em;
  display:flex; flex-wrap:wrap; gap:.1em .45em;
}
.hero__word{ position:relative; }
.hero__word--red{ color:var(--c-red); }
.hero__word::after{ content:"·"; color:rgba(255,255,255,.35); margin-left:.45em; }
.hero__word:last-child::after{ display:none; }
.hero__text{ font-size:1.2rem; max-width:620px; color:#dde4ef; margin-bottom:2rem; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:.8rem; }

/* ----------------------- CHIFFRES ----------------------- */
.stats{ background:var(--c-red); color:#fff; }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:1.9rem 1rem; text-align:center; border-right:1px solid rgba(255,255,255,.18); }
.stat:last-child{ border-right:0; }
.stat__num{ display:block; font-family:var(--ff-display); font-weight:700; font-size:2.9rem; line-height:1; }
.stat__lbl{ display:block; margin-top:.35rem; font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; color:#ffe2e4; }

/* ----------------------- TICKER « À la une » ----------------------- */
.ticker{ display:flex; align-items:stretch; background:var(--c-navy-2); color:#fff; overflow:hidden; }
.ticker__label{
  flex:none; display:flex; align-items:center; background:var(--c-red);
  font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.12em;
  font-size:.82rem; padding:.7rem 1.2rem; white-space:nowrap;
}
.ticker__viewport{ overflow:hidden; flex:1; }
.ticker__track{ display:inline-flex; align-items:center; white-space:nowrap; padding-block:.7rem; animation:sntpt-ticker 38s linear infinite; }
.ticker:hover .ticker__track{ animation-play-state:paused; }
.ticker__item{ color:#e6ebf3; font-size:.92rem; padding-inline:.6rem; }
.ticker__item:hover{ color:var(--c-red); }
.ticker__sep{ color:var(--c-red); padding-inline:.3rem; }
@keyframes sntpt-ticker{ from{transform:translateX(0);} to{transform:translateX(-50%);} }

/* ----------------------- En-têtes de section ----------------------- */
.section-head{ margin-block:3rem 1.6rem; }
.section-head--center{ text-align:center; }
.section-head__kicker{
  display:inline-block; font-family:var(--ff-display); letter-spacing:.16em;
  text-transform:uppercase; font-size:.78rem; color:var(--c-red);
  border-bottom:2px solid var(--c-red); padding-bottom:.25rem; margin-bottom:.6rem;
}
.section-head__kicker--light{ color:#ffd2d6; border-color:#ffd2d6; }
.section-head__title{ font-size:clamp(1.7rem,3.4vw,2.5rem); text-transform:uppercase; }

/* ----------------------- UNE PRINCIPALE ----------------------- */
.lead{ padding-bottom:1rem; }
.lead__grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:1.4rem; }
.leadcard{ background:#fff; border:1px solid var(--c-line); border-radius:var(--r); overflow:hidden; }
.lead__main{ grid-row:span 3; display:flex; flex-direction:column; }
.lead__side{ display:grid; grid-template-columns:120px 1fr; }
.leadcard__media{ display:block; overflow:hidden; background:var(--c-paper-2); }
.leadcard__media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.leadcard:hover .leadcard__media img{ transform:scale(1.05); }
.lead__main .leadcard__media{ aspect-ratio:16/9; }
.lead__side .leadcard__media{ height:100%; }
.leadcard__body{ padding:1.1rem 1.2rem; }
.lead__side .leadcard__body{ padding:.9rem 1rem; }
.leadcard__title{ font-size:1.05rem; margin:.4rem 0 0; line-height:1.15; }
.lead__main .leadcard__title{ font-size:1.7rem; }
.leadcard__title a{ color:var(--c-navy); }
.leadcard__title a:hover{ color:var(--c-red); }
.leadcard__excerpt{ color:var(--c-muted); font-size:.96rem; margin-top:.6rem; }

.entry__meta{ display:flex; align-items:center; gap:.7rem; font-size:.78rem; }
.entry__cat{
  font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.07em;
  background:var(--c-red); color:#fff; padding:.18em .6em; border-radius:3px; font-size:.72rem;
}
.entry__cat:hover{ background:var(--c-navy); color:#fff; }
.entry__date{ color:var(--c-muted); text-transform:uppercase; letter-spacing:.05em; }

/* ----------------------- BLOCS CATÉGORIE ----------------------- */
.catblocks{ padding-block:1rem 2rem; }
.catblock{ margin-block:2.6rem; }
.catblock__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; border-bottom:3px solid var(--c-navy); padding-bottom:.5rem; margin-bottom:1.3rem; }
.catblock__title{ font-size:1.5rem; text-transform:uppercase; margin:0; position:relative; }
.catblock__title::before{ content:""; display:inline-block; width:14px; height:14px; background:var(--c-red); margin-right:.55rem; transform:translateY(1px); }
.catblock__all{ font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.06em; font-size:.82rem; color:var(--c-navy); white-space:nowrap; }
.catblock__all:hover{ color:var(--c-red); }
.catblock__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; }

/* ----------------------- Cartes ----------------------- */
.card{ background:#fff; border:1px solid var(--c-line); border-radius:var(--r); overflow:hidden; display:flex; flex-direction:column; transition:transform var(--t),box-shadow var(--t); }
.card:hover{ transform:translateY(-4px); box-shadow:0 22px 40px -26px rgba(18,46,85,.5); }
.card__media{ display:block; position:relative; aspect-ratio:16/10; overflow:hidden; background:var(--c-paper-2); }
.card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.card:hover .card__media img{ transform:scale(1.06); }
.card__placeholder{ position:absolute; inset:0; display:grid; place-items:center; font-family:var(--ff-display); font-size:1.4rem; letter-spacing:.2em; color:#c4bcab; }
.card__cat{
  position:absolute; left:10px; top:10px; font-family:var(--ff-display); text-transform:uppercase;
  letter-spacing:.07em; font-size:.7rem; background:var(--c-red); color:#fff; padding:.2em .6em; border-radius:3px;
}
.card__body{ padding:1rem 1.05rem 1.1rem; display:flex; flex-direction:column; flex:1; }
.card__title{ font-size:1.08rem; line-height:1.18; margin:0 0 .5rem; }
.card__title a{ color:var(--c-navy); }
.card__title a:hover{ color:var(--c-red); }
.card__excerpt{ color:var(--c-muted); font-size:.9rem; margin:0 0 .8rem; }
.card__date{ margin-top:auto; font-size:.74rem; text-transform:uppercase; letter-spacing:.05em; color:var(--c-muted); }

/* ----------------------- ESPACE DÉLÉGUÉ (accueil) ----------------------- */
.delegate{ background:var(--c-navy); color:#fff; }
.delegate__inner{ display:grid; grid-template-columns:1.1fr .9fr; gap:2.4rem; align-items:center; padding-block:3.4rem; }
.delegate__title{ color:#fff; font-size:2.2rem; text-transform:uppercase; }
.delegate__text p{ color:#cdd6e4; }
.delegate__list{ list-style:none; margin:0; padding:0; display:grid; gap:.7rem; }
.delegate__list li{ display:flex; align-items:center; gap:.7rem; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); padding:.85rem 1rem; border-radius:var(--r); font-family:var(--ff-display); letter-spacing:.03em; text-transform:uppercase; font-size:.92rem; }
.delegate__ico{ color:var(--c-red); }

/* ----------------------- APPEL À ADHÉSION ----------------------- */
.join{ background:var(--c-red); color:#fff; }
.join__inner{ text-align:center; padding-block:3.4rem; }
.join__title{ color:#fff; font-size:clamp(1.9rem,4vw,2.8rem); text-transform:uppercase; }
.join__text{ color:#ffe2e4; max-width:560px; margin:0 auto 1.6rem; }

/* ----------------------- PARTENAIRES ----------------------- */
.partners{ padding-block:1rem 3rem; }
.partners__row{ display:flex; flex-wrap:wrap; justify-content:center; gap:1rem 1.4rem; }
.partners__item{
  font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.06em;
  font-size:1rem; color:var(--c-navy); background:#fff; border:1px solid var(--c-line);
  padding:.85rem 1.4rem; border-radius:var(--r);
}

/* ----------------------- NEWSLETTER ----------------------- */
.news-sub{ background:var(--c-paper-2); border-top:1px solid var(--c-line); }
.news-sub__inner{ display:flex; align-items:center; justify-content:space-between; gap:1.6rem; flex-wrap:wrap; padding-block:2.4rem; }
.news-sub__title{ margin:0 0 .2rem; text-transform:uppercase; }
.news-sub__inner p{ margin:0; color:var(--c-muted); }
.news-sub__form{ display:flex; gap:.5rem; flex:1; min-width:280px; max-width:480px; }
.news-sub__form input{ flex:1; padding:.85rem 1rem; border:2px solid var(--c-line); border-radius:var(--r); font:inherit; background:#fff; }
.news-sub__form input:focus{ outline:none; border-color:var(--c-navy); }

/* ----------------------- Mise en page articles ----------------------- */
.layout{ display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:2.6rem; padding-block:2.6rem 3.4rem; align-items:start; }
.layout__content{ min-width:0; }
.page-head{ margin-bottom:1.8rem; border-bottom:3px solid var(--c-navy); padding-bottom:.8rem; }
.page-head__title{ font-size:clamp(1.8rem,4vw,2.6rem); text-transform:uppercase; margin:0; }
.page-head__desc{ color:var(--c-muted); margin-top:.5rem; }
.post-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.5rem; }
.no-results{ color:var(--c-muted); }

/* Article seul */
.entry__header{ margin-bottom:1.4rem; }
.entry__title{ font-size:clamp(2rem,4.4vw,3rem); text-transform:uppercase; margin:.6rem 0 0; }
.entry--page .entry__title{ text-transform:none; }
.entry__cover{ margin:0 0 1.8rem; border-radius:var(--r); overflow:hidden; border:1px solid var(--c-line); }
.entry__content{ font-size:1.06rem; }
.entry__content h2{ font-size:1.6rem; margin-top:2rem; text-transform:none; }
.entry__content h3{ font-size:1.3rem; margin-top:1.6rem; text-transform:none; }
.entry__content a{ text-decoration:underline; text-underline-offset:3px; }
.entry__content blockquote{ margin:1.6rem 0; padding:.4rem 0 .4rem 1.4rem; border-left:4px solid var(--c-red); font-size:1.15rem; color:var(--c-navy); font-style:italic; }
.entry__content img{ border-radius:var(--r); }
.entry__content ul,.entry__content ol{ padding-left:1.3rem; }
.entry__content li{ margin-bottom:.4rem; }
.entry__footer{ margin-top:2rem; }
.entry__tags a{ display:inline-block; font-size:.8rem; background:var(--c-paper-2); border:1px solid var(--c-line); padding:.2em .7em; border-radius:20px; margin:.2em .2em 0 0; color:var(--c-navy); }

.post-nav{ display:flex; justify-content:space-between; gap:1rem; margin-top:2rem; padding-top:1.4rem; border-top:1px solid var(--c-line); font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.04em; font-size:.9rem; }
.post-nav__next{ text-align:right; margin-left:auto; }

/* Pagination */
.pagination,.nav-links{ display:flex; flex-wrap:wrap; gap:.4rem; margin-top:2.4rem; }
.pagination .page-numbers{ display:inline-grid; place-items:center; min-width:42px; height:42px; padding:0 .6rem; border:1px solid var(--c-line); border-radius:var(--r); font-family:var(--ff-display); color:var(--c-navy); background:#fff; }
.pagination .page-numbers.current{ background:var(--c-red); color:#fff; border-color:var(--c-red); }
.pagination a.page-numbers:hover{ background:var(--c-navy); color:#fff; border-color:var(--c-navy); }

/* ----------------------- Colonne latérale / widgets ----------------------- */
.layout__aside{ position:sticky; top:96px; align-self:start; }
.widget{ background:#fff; border:1px solid var(--c-line); border-radius:var(--r); padding:1.2rem 1.3rem; margin-bottom:1.4rem; }
.widget__title{ font-size:1.05rem; text-transform:uppercase; margin:0 0 .9rem; padding-bottom:.5rem; border-bottom:2px solid var(--c-red); }
.widget ul{ list-style:none; margin:0; padding:0; }
.widget li{ padding:.4rem 0; border-bottom:1px solid var(--c-paper-2); font-size:.94rem; }
.widget li:last-child{ border-bottom:0; }
.widget a{ color:var(--c-navy); }
.widget a:hover{ color:var(--c-red); }

/* Formulaire de recherche */
.search-form{ display:flex; gap:.4rem; }
.search-form__field{ flex:1; padding:.7rem .9rem; border:2px solid var(--c-line); border-radius:var(--r); font:inherit; background:#fff; }
.search-form__field:focus{ outline:none; border-color:var(--c-navy); }
.search-form__btn{ font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.06em; background:var(--c-navy); color:#fff; border:0; padding:0 1.1rem; border-radius:var(--r); cursor:pointer; }
.search-form__btn:hover{ background:var(--c-red); }

/* ----------------------- ESPACE DÉLÉGUÉ (page sécurisée) ----------------------- */
.delegate-page{ padding-block:3rem 3.6rem; }
.gate{ max-width:440px; margin-inline:auto; background:#fff; border:1px solid var(--c-line); border-top:4px solid var(--c-red); border-radius:var(--r); padding:2.4rem 2rem; box-shadow:var(--shadow); }
.gate__head{ text-align:center; margin-bottom:1.6rem; }
.gate__lock{ font-size:2rem; }
.gate__title{ text-transform:uppercase; margin:.4rem 0 .4rem; }
.gate__sub{ color:var(--c-muted); font-size:.95rem; }
.gate form p{ margin-bottom:1rem; }
.gate label{ display:block; font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.05em; font-size:.78rem; color:var(--c-navy); margin-bottom:.3rem; }
.gate input[type=text],.gate input[type=password]{ width:100%; padding:.8rem .9rem; border:2px solid var(--c-line); border-radius:var(--r); font:inherit; }
.gate input:focus{ outline:none; border-color:var(--c-navy); }
.gate .login-remember{ font-family:var(--ff-body); text-transform:none; letter-spacing:0; font-size:.9rem; color:var(--c-muted); display:flex; align-items:center; gap:.4rem; }
.gate .login-submit input{ width:100%; background:var(--c-red); color:#fff; border:0; padding:.9em 1.5em; border-radius:var(--r); font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.08em; cursor:pointer; }
.gate .login-submit input:hover{ background:var(--c-red-deep); }
.gate__help{ text-align:center; margin-top:1.2rem; font-size:.86rem; color:var(--c-muted); }
.docs{ margin-top:2rem; }
.docs__title{ text-transform:uppercase; border-bottom:3px solid var(--c-navy); padding-bottom:.5rem; }
.docs__list{ list-style:none; margin:0; padding:0; }
.docs__list a{ display:flex; align-items:center; gap:.6rem; padding:.85rem 1rem; border:1px solid var(--c-line); border-radius:var(--r); margin-bottom:.6rem; color:var(--c-navy); background:#fff; }
.docs__list a:hover{ border-color:var(--c-red); }
.docs__list time{ margin-left:auto; font-size:.78rem; color:var(--c-muted); }
.docs__ico{ color:var(--c-red); }
.docs__empty{ color:var(--c-muted); }
.delegate-page__logout{ margin-top:2rem; }

/* ----------------------- 404 ----------------------- */
.error404{ padding-block:4rem 5rem; text-align:center; }
.error404__inner{ max-width:520px; margin-inline:auto; }
.error404__code{ font-family:var(--ff-display); font-weight:700; font-size:7rem; line-height:1; color:var(--c-red); }
.error404__title{ text-transform:uppercase; }
.error404 .search-form{ max-width:360px; margin:1.4rem auto; }

/* ----------------------- Commentaires ----------------------- */
.comments{ margin-top:2.6rem; padding-top:1.8rem; border-top:1px solid var(--c-line); }
.comments__title{ text-transform:uppercase; font-size:1.4rem; }
.comments__list{ list-style:none; margin:0 0 2rem; padding:0; }
.comments__list .comment-body{ padding:1rem 0; border-bottom:1px solid var(--c-paper-2); }
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{
  width:100%; padding:.8rem; border:2px solid var(--c-line); border-radius:var(--r); font:inherit; margin-top:.3rem;
}
.comment-form input:focus,.comment-form textarea:focus{ outline:none; border-color:var(--c-navy); }
.comment-form .btn,.form-submit input{ background:var(--c-red); color:#fff; border:0; padding:.85em 1.6em; border-radius:var(--r); font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.08em; cursor:pointer; }

/* ----------------------- Pied de page ----------------------- */
.site-footer{ background:var(--c-navy-2); color:#c7d0df; padding-block:3.4rem 1.6rem; margin-top:0; }
.footer__widgets{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.1fr; gap:2rem; padding-bottom:2.4rem; border-bottom:1px solid rgba(255,255,255,.12); }
.footer__brand .brand__name{ color:#fff; }
.footer__brand .brand__sub{ color:#9fb0c8; }
.footer__about{ color:#9fb0c8; font-size:.92rem; margin-top:1rem; }
.footer__slogan{ font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.1em; color:#fff; }
.footer__title{ color:#fff; text-transform:uppercase; font-size:1rem; letter-spacing:.05em; margin:0 0 1rem; }
.footer__menu,.footer__contact{ list-style:none; margin:0; padding:0; }
.footer__menu li,.footer__contact li{ padding:.3rem 0; font-size:.92rem; }
.site-footer a{ color:#c7d0df; }
.site-footer a:hover{ color:#fff; }
.footer__soc{ display:flex; gap:.5rem; margin-top:1rem; flex-wrap:wrap; }
.footer__soc a{ font-family:var(--ff-display); text-transform:uppercase; letter-spacing:.05em; font-size:.74rem; border:1px solid rgba(255,255,255,.2); padding:.35em .7em; border-radius:20px; }
.footer__soc a:hover{ background:var(--c-red); border-color:var(--c-red); color:#fff; }
.footer__bottom{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding-top:1.4rem; font-size:.82rem; color:#8ea1bd; }
.footer__bottom p{ margin:0; }

/* ----------------------- Web-radio flottante ----------------------- */
.radio{
  position:fixed; left:18px; bottom:18px; z-index:300; display:flex; align-items:center; gap:.7rem;
  background:var(--c-navy); color:#fff; border:1px solid rgba(255,255,255,.14);
  border-radius:50px; padding:.4rem .9rem .4rem .4rem; box-shadow:0 18px 40px -20px rgba(0,0,0,.6);
}
.radio__btn{ width:42px; height:42px; border-radius:50%; border:0; background:var(--c-red); color:#fff; cursor:pointer; font-size:.85rem; display:grid; place-items:center; }
.radio__btn:hover{ background:var(--c-red-deep); }
.radio__info{ display:flex; flex-direction:column; line-height:1.1; padding-right:.4rem; }
.radio__live{ display:flex; align-items:center; gap:.35rem; font-family:var(--ff-display); font-size:.7rem; letter-spacing:.1em; color:#ffd2d6; }
.radio__dot{ width:8px; height:8px; border-radius:50%; background:var(--c-red); animation:sntpt-pulse 1.4s infinite; }
.radio.is-playing .radio__dot{ background:#33d17a; }
.radio__label{ font-size:.78rem; color:#dfe6f1; max-width:180px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
@keyframes sntpt-pulse{ 0%,100%{opacity:1;} 50%{opacity:.3;} }

/* ----------------------- Retour haut ----------------------- */
.to-top{
  position:fixed; right:18px; bottom:18px; z-index:300; width:46px; height:46px; border-radius:var(--r);
  background:var(--c-red); color:#fff; display:grid; place-items:center; font-size:1.2rem;
  opacity:0; visibility:hidden; transform:translateY(8px); transition:var(--t);
}
.to-top.is-visible{ opacity:1; visibility:visible; transform:none; }
.to-top:hover{ background:var(--c-red-deep); color:#fff; }

/* ----------------------- Responsive ----------------------- */
@media (max-width:1100px){
  .lead__grid{ grid-template-columns:1fr; }
  .lead__main{ grid-row:auto; }
}
@media (max-width:980px){
  .nav-toggle{ display:inline-grid; }
  .main-nav{
    position:fixed; inset:0 0 0 auto; width:min(86vw,360px); background:#fff; z-index:250;
    transform:translateX(100%); transition:transform .3s ease; padding:5rem 1.2rem 2rem;
    box-shadow:-20px 0 50px -30px rgba(0,0,0,.5); overflow-y:auto; margin:0;
  }
  .is-nav-open .main-nav{ transform:none; }
  .nav__list{ flex-direction:column; gap:.2rem; }
  .nav__list a{ font-size:1.05rem; padding:.7rem .6rem; border-bottom:1px solid var(--c-paper-2); }
  .nav__list .sub-menu{ position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:0; border-left:3px solid var(--c-red); border-radius:0; padding-left:.6rem; display:none; }
  .nav__list li.is-open > .sub-menu{ display:block; }
  .site-header__actions .btn{ display:none; }
  .site-header__actions{ margin-left:auto; }
  .stats__grid{ grid-template-columns:repeat(2,1fr); }
  .stat:nth-child(2){ border-right:0; }
  .stat:nth-child(1),.stat:nth-child(2){ border-bottom:1px solid rgba(255,255,255,.18); }
  .catblock__grid{ grid-template-columns:1fr 1fr; }
  .delegate__inner,.news-sub__inner{ grid-template-columns:1fr; }
  .delegate__inner{ gap:1.6rem; }
  .layout{ grid-template-columns:1fr; }
  .layout__aside{ position:static; }
  .footer__widgets{ grid-template-columns:1fr 1fr; }
  .hero__globe{ width:380px; height:380px; right:-150px; opacity:.55; }
}
@media (max-width:640px){
  body{ font-size:16px; }
  .topbar__right{ display:none; }
  .topbar__inner{ justify-content:center; }
  .hero__inner{ padding-block:3.4rem; }
  .post-grid,.catblock__grid{ grid-template-columns:1fr; }
  .lead__side{ grid-template-columns:100px 1fr; }
  .footer__widgets{ grid-template-columns:1fr; }
  .footer__bottom{ flex-direction:column; }
  .stat__num{ font-size:2.3rem; }
  .radio__label{ display:none; }
}

/* ----------------------- Accessibilité : mouvement réduit ----------------------- */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
  .ticker__track{ animation:none; }
}
