:root {
    --bg: #FFFFFF;
    --surface: #F4F6F9;
    --fg: #16181D;
    --muted: #67707F;
    --accent: #2F6FB0;
    --accentfg: #FFFFFF;
    --border: #E5E9EF;
    --link: #2563A8;
    --font-heading: 'Space Grotesk', system-ui, sans-serif;
    --font-body: 'IBM Plex Sans', system-ui, -apple-system, sans-serif;
    --radius: 10px;
    --base-size: 17px;
    --space: 34px;
}
:root{--mono:ui-monospace,'SF Mono','Cascadia Mono','JetBrains Mono',Menlo,Consolas,monospace;
  --wrap:1180px;--read:680px;--lead:820px;--manifesto:760px}
*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--fg);
  font:var(--base-size)/1.65 var(--font-body);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;height:auto;display:block}
a{color:var(--link);text-decoration:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--fg);font-weight:500;letter-spacing:-.015em;margin:0}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
main{flex:1 0 auto}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(20px,4vw,44px)}
.eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}
.eyebrow--accent{color:var(--accent)}
.meta{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.meta time{font-variant-numeric:tabular-nums}
.lead{font-size:clamp(17px,1.7vw,20px);line-height:1.6;color:var(--muted)}

/* Avatar monogramme (auteur) */
.avatar{flex:none;border-radius:999px;background:var(--accent);color:var(--accentfg);display:flex;
  align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:600}

/* ───────── En-tête d'accueil : bandeau + marque centrée + nav ───────── */
.topstrip{border-bottom:1px solid var(--border)}
.topstrip .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:11px;padding-bottom:11px}
.topstrip .meta a:hover{color:var(--accent)}

/* Recherche (Google restreint au site, sans JS) */
.search{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--border);border-radius:999px;padding:2px 4px 2px 12px;background:var(--surface)}
.search:focus-within{border-color:var(--accent)}
.search__input{border:0;background:none;color:var(--fg);font-family:var(--font-body);font-size:13px;width:118px;min-width:0;outline:none}
.search__input::placeholder{color:var(--muted)}
.search__btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex:none;border:0;border-radius:999px;background:none;color:var(--muted);cursor:pointer}
.search__btn:hover{color:var(--accent)}
@media(max-width:560px){.search__input{width:84px}}
/* Page /recherche/ : champ pleine largeur + bouton */
.searchpage{display:flex;gap:10px;max-width:540px;margin:6px 0 4px}
.searchpage__input{flex:1;min-width:0;border:1px solid var(--border);border-radius:999px;padding:12px 20px;background:var(--surface);color:var(--fg);font-family:var(--font-body);font-size:16px;outline:none}
.searchpage__input:focus{border-color:var(--accent)}
.searchpage__input::placeholder{color:var(--muted)}
.searchpage__btn{flex:none;border:1px solid var(--accent);border-radius:999px;padding:0 22px;background:var(--accent);color:var(--accentfg);font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:.2s}
.searchpage__btn:hover{filter:brightness(1.06)}
#search-count{margin-top:14px}
@media(max-width:560px){.searchpage__btn{padding:0 16px}}
.masthead{text-align:center;padding:clamp(34px,5vw,56px) 0 clamp(20px,3vw,28px)}
.masthead__brand{display:inline-flex;align-items:center;gap:.4em;font-family:var(--font-heading);font-weight:500;font-size:clamp(34px,5.4vw,54px);line-height:1;letter-spacing:-.02em;color:var(--fg)}
.masthead__brand:hover{color:var(--accent)}
/* Emblème (logo) à côté du mot-symbole — taille relative au texte de la marque */
.brandmark{flex:none;display:inline-flex;align-items:center;justify-content:center;width:.92em;height:.92em;color:var(--accent)}
.brandmark svg{width:100%;height:100%;display:block}
.masthead__tag{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin-top:14px}
.nav{border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.nav__list{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(16px,2.4vw,34px);padding:15px 0;list-style:none;margin:0}
.nav__list a{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.13em;color:var(--muted);padding-bottom:2px}
.nav__list a:hover{color:var(--fg)}
.nav__list a[aria-current]{color:var(--fg);border-bottom:1.5px solid var(--accent)}

/* ───────── En-tête intérieur : slim, collant, flou ───────── */
.siteheader{position:sticky;top:0;z-index:30;border-bottom:1px solid var(--border);background:var(--bg);background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.siteheader .wrap{display:flex;align-items:center;gap:18px;padding-top:14px;padding-bottom:14px}
.siteheader__brand{display:inline-flex;align-items:center;gap:.4em;font-family:var(--font-heading);font-weight:500;font-size:21px;letter-spacing:-.02em;color:var(--fg)}
.siteheader__brand:hover{color:var(--accent)}
.siteheader__right{display:flex;align-items:center;gap:clamp(12px,1.8vw,22px);margin-left:auto;flex-wrap:wrap;justify-content:flex-end}
.siteheader__nav{display:flex;flex-wrap:wrap;gap:clamp(12px,1.8vw,24px);font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.12em}
.siteheader__nav a{color:var(--muted);padding-bottom:2px}.siteheader__nav a:hover{color:var(--fg)}
.siteheader__nav a[aria-current]{color:var(--fg);border-bottom:1.5px solid var(--accent)}

/* ───────── À la une (split image + texte) ───────── */
.featured{padding:clamp(34px,5vw,56px) 0;border-bottom:1px solid var(--border)}
.featured__grid{display:grid;gap:clamp(24px,4vw,50px);align-items:center}
@media(min-width:860px){.featured__grid{grid-template-columns:1.12fr 1fr}}
.featured__media{overflow:hidden;border-radius:8px;background:var(--surface);aspect-ratio:5/4}
.featured__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.22,1,.36,1)}
.featured:hover .featured__media img{transform:scale(1.04)}
.featured h1,.featured h2{font-size:clamp(30px,4.2vw,42px);line-height:1.08;margin:.28em 0 .3em}
.featured h1 a,.featured h2 a{color:var(--fg)}.featured h1 a:hover,.featured h2 a:hover{color:var(--accent)}
.featured__dek{font-size:clamp(16px,1.6vw,18px);line-height:1.6;color:var(--muted);margin:0 0 20px;max-width:46ch}
.byline{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.byline .avatar{width:38px;height:38px;font-size:15px}
.byline__name{font-family:var(--font-heading);font-size:15px;color:var(--fg)}
.byline .meta{display:block;margin-top:2px}
.readlink{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);display:inline-flex;align-items:center;gap:8px;transition:gap .25s cubic-bezier(.22,1,.36,1)}
.readlink:hover{gap:15px;text-decoration:none}

/* ───────── Manifeste ───────── */
.manifesto{border-bottom:1px solid var(--border);text-align:center;padding:clamp(40px,6vw,68px) 0}
.manifesto p:not([class]){font-family:var(--font-heading);font-weight:400;font-size:clamp(20px,2.4vw,27px);line-height:1.45;color:var(--fg);max-width:var(--manifesto);margin:14px auto 0}
.manifesto em{font-style:italic;color:var(--accent)}
.manifesto__sign{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;color:var(--muted);margin-top:20px}

/* ───────── Sections + en-têtes de section ───────── */
.section{padding:clamp(40px,5.5vw,64px) 0}
.section + .section{padding-top:0}
.sechead{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:clamp(24px,3vw,34px)}
.sechead h2,.sechead h3{font-size:clamp(22px,2.6vw,28px)}
.sechead a{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent)}
.sechead a:hover{text-decoration:none;opacity:.75}

/* ───────── Grille de cartes ───────── */
.grid{display:grid;gap:clamp(22px,2.6vw,38px) clamp(22px,2.8vw,42px);grid-template-columns:1fr}
@media(min-width:620px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:920px){.grid{grid-template-columns:repeat(3,1fr)}}
.card{display:flex;flex-direction:column;transition:transform .4s cubic-bezier(.22,1,.36,1)}
.card:hover{transform:translateY(-6px)}
.card__media{overflow:hidden;border-radius:8px;background:var(--surface);aspect-ratio:4/3;margin-bottom:15px}
.card__media img{width:100%;height:100%;object-fit:cover}
.card .eyebrow{margin-bottom:9px}
.card h3,.card h4{font-size:clamp(19px,1.7vw,21px);line-height:1.18;margin:0 0 9px;text-wrap:pretty}
.card h3 a,.card h4 a{color:var(--fg)}.card:hover h3 a,.card:hover h4 a{color:var(--accent)}
.card__dek{font-size:14px;line-height:1.5;color:var(--muted);margin:0 0 12px}
.card__foot{margin-top:auto}

/* ───────── Tuiles catégorie ───────── */
.tiles{display:grid;gap:clamp(16px,2vw,24px);grid-template-columns:1fr}
@media(min-width:560px){.tiles{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.tiles{grid-template-columns:repeat(4,1fr)}}
.tile{display:block;border:1px solid var(--border);border-radius:10px;background:var(--surface);overflow:hidden;transition:transform .4s cubic-bezier(.22,1,.36,1),border-color .25s}
.tile:hover{transform:translateY(-5px);border-color:var(--accent);text-decoration:none}
.tile__strip{height:6px;background:var(--accent);opacity:.85}
.tile__body{padding:clamp(16px,2vw,22px)}
.tile h3,.tile h4{font-size:18px;margin:0 0 6px}.tile h3 a,.tile h4 a{color:var(--fg)}
.tile .eyebrow{display:block;margin-bottom:8px}
.tile__desc{font-size:13.5px;line-height:1.5;color:var(--muted);margin:0}

/* ───────── Page article ───────── */
.crumb{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0 0 18px}
.crumb a{color:var(--muted)}.crumb a:hover{color:var(--accent)}
.arthead{max-width:var(--lead);margin:0 auto;text-align:center;padding:clamp(34px,5vw,56px) 0 clamp(24px,3vw,34px)}
.arthead .eyebrow a{color:inherit}.arthead .eyebrow a:hover{color:var(--accent)}
.arthead h1{font-size:clamp(32px,5vw,52px);line-height:1.06;margin:.2em 0 .3em;text-wrap:balance}
.arthead__dek{font-size:clamp(18px,1.9vw,21px);line-height:1.55;color:var(--muted);max-width:34em;margin:0 auto 26px}
.arthead .byline{justify-content:center}
.herofig{max-width:1120px;margin:0 auto clamp(8px,2vw,14px)}
.herofig img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:8px;background:var(--surface)}
.herofig figcaption,.figcaption{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--muted);text-align:center;margin-top:10px}

.article{max-width:880px;margin:clamp(30px,4vw,46px) auto 0;display:grid;gap:clamp(0px,3vw,42px);grid-template-columns:1fr}
@media(min-width:820px){.article{grid-template-columns:48px 1fr}}
.share{display:none}
@media(min-width:820px){.share{display:block;position:sticky;top:104px;height:max-content}}
.share__label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);writing-mode:vertical-rl;margin:0 auto 14px;display:block}
.share a{display:flex;width:40px;height:40px;border:1px solid var(--border);border-radius:999px;align-items:center;justify-content:center;color:var(--muted);margin:0 auto 10px;font-family:var(--mono);font-size:13px;transition:border-color .2s,color .2s,background .2s}
.share a:hover{border-color:var(--accent);color:var(--accent);background:var(--surface);text-decoration:none}

/* Prose */
.prose{max-width:var(--read);min-width:0}
.prose p{font-family:var(--font-heading);font-weight:400;font-size:clamp(18px,1.25vw,20px);line-height:1.72;color:var(--fg);margin:0 0 1.3em}
.prose > p:first-child::first-letter{font-family:var(--font-heading);font-weight:500;float:left;font-size:4.1em;line-height:.72;padding:7px 14px 0 0;color:var(--accent)}
.prose h2{font-size:clamp(24px,2.6vw,29px);line-height:1.2;margin:1.7em 0 .5em;text-wrap:balance}
.prose h3{font-size:clamp(20px,2vw,23px);margin:1.5em 0 .4em}
.prose a{color:var(--link);text-decoration:underline;text-underline-offset:2px}
.prose ul,.prose ol{font-family:var(--font-heading);font-size:clamp(18px,1.25vw,20px);line-height:1.7;margin:0 0 1.3em;padding-left:1.3em;color:var(--fg)}.prose li{margin:.35em 0}
.prose blockquote{margin:1.7em 0;padding-left:26px;border-left:3px solid var(--accent);font-family:var(--font-heading);font-style:italic;font-size:clamp(22px,2.3vw,26px);line-height:1.4;color:var(--fg)}
.prose blockquote p{font-size:inherit;line-height:inherit;font-weight:inherit;margin:0}
.prose figure{margin:1.8em 0}.prose figure img{border-radius:6px;background:var(--surface)}
.prose figure figcaption{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--muted);margin-top:9px}
.prose hr{border:0;border-top:1px solid var(--border);margin:2.2em 0}
/* Inline & blocs Markdown (gras, italique, h4-h6, listes imbriquées, code, tableaux GFM, barré) */
.prose strong,.prose b{font-weight:700}
.prose em,.prose i{font-style:italic}
.prose h4{font-size:clamp(17px,1.6vw,19px);line-height:1.3;margin:1.3em 0 .35em}
.prose h5,.prose h6{font-size:clamp(16px,1.4vw,18px);line-height:1.3;margin:1.2em 0 .3em}
.prose del{color:var(--muted)}
.prose li>ul,.prose li>ol{margin:.4em 0}
.prose p,.prose li{overflow-wrap:break-word}
.prose a,.prose code{overflow-wrap:anywhere}
.prose code{font-family:var(--mono);font-size:.85em;background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:.08em .4em}
.prose pre{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px 18px;overflow:auto;margin:1.6em 0;font-size:14px;line-height:1.55}
.prose pre code{background:none;border:0;padding:0;font-size:inherit}
.prose img{border-radius:6px}
.prose input[type=checkbox]{accent-color:var(--accent);margin-right:.4em}
/* Tableaux : largeur du contenu, jamais plus que la colonne ; défilent seuls sur mobile (pas la page) */
.prose table{display:block;width:fit-content;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-collapse:collapse;margin:1.7em 0;font-family:var(--font-heading);font-size:clamp(15px,1.1vw,17px);line-height:1.5}
.prose th,.prose td{text-align:left;padding:.6em .9em;border-bottom:1px solid var(--border);vertical-align:top}
.prose thead th{font-weight:600;border-bottom:2px solid var(--border)}
.prose tbody tr:last-child td{border-bottom:0}

/* Carte auteur */
.authorcard{margin-top:clamp(34px,4vw,48px);padding:clamp(22px,3vw,30px);border:1px solid var(--border);border-radius:12px;background:var(--surface);display:flex;gap:clamp(16px,2vw,22px);align-items:flex-start}
.authorcard .avatar{width:60px;height:60px;font-size:23px}
.authorcard .eyebrow{margin-bottom:6px}
.authorcard h3{font-size:21px;margin:0 0 8px}
.authorcard p{font-size:15px;line-height:1.6;color:var(--muted);margin:0 0 12px;max-width:52ch}
.pill{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--border);border-radius:999px;padding:7px 15px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--fg);transition:.2s}
.pill:hover{border-color:var(--accent);color:var(--accentfg);background:var(--accent);text-decoration:none}
.tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:6px}

/* Page catégorie / archive */
.archead{border-bottom:1px solid var(--border);padding:clamp(30px,4vw,48px) 0}
.archead h1{font-size:clamp(34px,5vw,52px);line-height:1.05;margin:.15em 0 .3em}
.archead__desc{font-size:clamp(17px,1.7vw,20px);line-height:1.55;color:var(--muted);max-width:48ch;margin:0 0 14px}

/* À propos */
.about-hero{padding:clamp(34px,5vw,60px) 0;border-bottom:1px solid var(--border)}
.about-hero__grid{display:grid;gap:clamp(24px,4vw,46px);align-items:center}
@media(min-width:780px){.about-hero__grid{grid-template-columns:1.1fr .9fr}}
.about-hero h1{font-size:clamp(32px,4.6vw,54px);line-height:1.05;margin:.25em 0 .3em;text-wrap:balance}
.about-portrait{aspect-ratio:4/5;border-radius:10px;background:var(--surface);overflow:hidden;display:flex;align-items:center;justify-content:center}
@media(max-width:779px){.about-portrait{aspect-ratio:16/10;max-height:240px}} /* pas un grand vide en mobile */
.about-portrait .avatar{width:96px;height:96px;font-size:38px}
.storyband{max-width:720px;margin:0 auto}
.storyband p{font-family:var(--font-heading);font-size:clamp(18px,1.4vw,20px);line-height:1.72;color:var(--fg);margin:0 0 1.3em}

/* Document long-form simple (mentions légales) — pas de lettrine */
.doc{max-width:var(--read);padding:clamp(24px,3vw,36px) 0}
.doc h1{font-size:clamp(28px,4vw,42px);margin:0 0 .5em}
.doc h2{font-family:var(--font-heading);font-size:1.4em;margin:1.7em 0 .4em}
.doc p{font-family:var(--font-heading);font-size:17px;line-height:1.7;color:var(--fg);margin:0 0 1.1em}
.doc a{color:var(--link);text-decoration:underline;text-underline-offset:2px}

/* Pied de page */
.footer{border-top:1px solid var(--border);background:var(--surface);margin-top:clamp(40px,6vw,72px);padding:clamp(34px,5vw,52px) 0}
.footer__grid{display:grid;gap:28px;grid-template-columns:1fr}
@media(min-width:680px){.footer__grid{grid-template-columns:1.6fr 1fr 1fr}}
.footer__brand{font-family:var(--font-heading);font-size:21px;color:var(--fg);display:block;margin-bottom:8px}
.footer__about{font-size:14px;color:var(--muted);max-width:32rem;line-height:1.6}
.footer h2{font-family:var(--mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin:0 0 13px}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;font-size:14.5px}
.footer__copy{margin-top:clamp(26px,4vw,38px);padding-top:20px;border-top:1px solid var(--border);font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--muted)}

/* État vide / 404 */
.empty{min-height:48vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:clamp(28px,5vw,48px) 0;color:var(--muted)}
.empty h1{font-size:clamp(26px,4vw,38px);margin:0 0 10px;color:var(--fg)}
.empty .readlink{margin-top:16px}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip{position:absolute;left:-9999px}.skip:focus{left:8px;top:8px;z-index:40;background:var(--bg);padding:10px 14px;border:1px solid var(--border);border-radius:8px}
