/*
Theme Name: Haeresis
Theme URI: https://haeresis.fr
Author: Tracker
Description: Thème éditorial noir et blanc, style presse officielle. Enquêtes et contre-analyses sur des sujets pointus. Typographie Cinzel / Playfair Display / Spectral / Barlow.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: haeresis
*/

/* =========================================================
   1. Variables
   ========================================================= */
:root{
  --hae-black:#111111;
  --hae-ink:#1a1a1a;
  --hae-muted:#555555;
  --hae-grey:#777777;
  --hae-light:#999999;
  --hae-faint:#cccccc;
  --hae-hair:#ededed;
  --hae-bg:#ffffff;
  --hae-bg-soft:#fafafa;

  --hae-display:'Cinzel', serif;          /* logo, sur-titres, lettrines, exergues */
  --hae-title:'Playfair Display', serif;  /* titres d'articles */
  --hae-serif:'Spectral', Georgia, serif; /* corps de lecture */
  --hae-sans:'Barlow', system-ui, sans-serif; /* méta, interface */

  --hae-content:600px;   /* mesure de lecture */
  --hae-wide:680px;      /* images débordantes */
  --hae-max:1080px;      /* largeur cadre */
}

/* =========================================================
   2. Reset léger
   ========================================================= */
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--hae-bg);
  color:var(--hae-ink);
  font-family:var(--hae-serif);
  font-size:17px;
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
a:hover{text-decoration:underline;text-underline-offset:3px;}

.hae-frame{max-width:var(--hae-max);margin:0 auto;border-left:1px solid var(--hae-hair);border-right:1px solid var(--hae-hair);background:var(--hae-bg);}

/* =========================================================
   3. En-tête
   ========================================================= */
.hae-topbar{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 26px;border-bottom:1px solid var(--hae-black);
}
.hae-topbar .hae-dt,
.hae-topbar .hae-tools{min-width:180px;}
.hae-dt{
  font-family:var(--hae-sans);font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--hae-grey);
}
.hae-tools{display:flex;gap:16px;align-items:center;justify-content:flex-end;color:var(--hae-black);font-size:18px;}
.hae-brand{text-align:center;}
.hae-logo{
  font-family:var(--hae-display);font-weight:600;font-size:30px;
  letter-spacing:0.14em;color:var(--hae-black);line-height:1;
}
.hae-baseline{
  font-family:var(--hae-sans);font-size:10px;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--hae-light);margin-top:7px;
}
.hae-nav{
  display:flex;justify-content:center;flex-wrap:wrap;gap:28px;
  padding:11px 16px;border-bottom:1px solid var(--hae-black);
  font-family:var(--hae-sans);font-size:12px;letter-spacing:0.08em;text-transform:uppercase;
}
.hae-nav a{color:var(--hae-muted);}
.hae-nav .current-menu-item a,
.hae-nav a:hover{color:var(--hae-black);text-decoration:none;}

/* =========================================================
   4. Accueil — hero
   ========================================================= */
.hae-hero{
  position:relative;min-height:340px;display:flex;flex-direction:column;
  justify-content:flex-end;padding:34px 30px;color:#fff;background:var(--hae-black);
  background-size:cover;background-position:center;
}
.hae-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.15),rgba(0,0,0,0.72));}
.hae-hero > *{position:relative;z-index:1;}
.hae-kicker{font-family:var(--hae-sans);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:#cfcfcf;margin-bottom:12px;}
.hae-hero h1{
  font-family:var(--hae-title);font-weight:500;font-size:44px;line-height:1.05;
  margin:0 0 14px;max-width:640px;color:#fff;
}
.hae-hero p{font-family:var(--hae-serif);font-size:16px;line-height:1.5;color:#e3e3e3;max-width:560px;margin:0 0 14px;}
.hae-hero .hae-byline{font-family:var(--hae-sans);font-size:12px;letter-spacing:0.06em;text-transform:uppercase;color:#bbb;}

/* =========================================================
   5. Accueil — sommaire
   ========================================================= */
.hae-section-title{
  font-family:var(--hae-display);font-size:13px;letter-spacing:0.2em;text-transform:uppercase;
  text-align:center;color:var(--hae-black);padding:13px 0;border-bottom:1px solid var(--hae-black);
}
.hae-sommaire{padding:6px 26px 24px;}
.hae-item{
  display:flex;gap:16px;align-items:center;padding:18px 0;border-bottom:1px solid var(--hae-hair);
}
.hae-item:last-child{border-bottom:none;}
.hae-num{font-family:var(--hae-display);font-size:22px;color:var(--hae-faint);min-width:38px;}
.hae-thumb{
  flex:0 0 96px;width:96px;height:72px;object-fit:cover;
  filter:grayscale(100%) contrast(1.05);background:#eee;border:1px solid #e0e0e0;
}
.hae-item-body{flex:1;}
.hae-cat{font-family:var(--hae-sans);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--hae-light);margin-bottom:4px;}
.hae-item-body h3{font-family:var(--hae-title);font-size:21px;line-height:1.18;font-weight:500;margin:0 0 5px;color:var(--hae-black);}
.hae-item-body p{font-family:var(--hae-sans);font-size:13px;line-height:1.45;color:#666;margin:0;}
.hae-read{font-family:var(--hae-sans);font-size:12px;color:var(--hae-light);min-width:50px;text-align:right;}

/* =========================================================
   6. Article (single)
   ========================================================= */
.hae-article{padding-bottom:10px;}
.hae-article-head{max-width:var(--hae-content);margin:0 auto;padding:36px 22px 0;text-align:center;}
.hae-article-head .hae-cat{margin-bottom:16px;letter-spacing:0.18em;}
.hae-article-head h1{
  font-family:var(--hae-title);font-size:40px;line-height:1.1;font-weight:500;
  letter-spacing:-0.01em;margin:0 0 18px;color:var(--hae-black);
}
.hae-chapo{font-family:var(--hae-serif);font-size:19px;line-height:1.5;font-style:italic;color:var(--hae-muted);margin:0 0 24px;}
.hae-meta{
  display:flex;justify-content:center;align-items:center;gap:11px;flex-wrap:wrap;
  max-width:var(--hae-content);margin:0 auto 26px;padding:16px 22px;
  border-top:1px solid var(--hae-hair);border-bottom:1px solid var(--hae-hair);
  font-family:var(--hae-sans);
}
.hae-avatar{width:30px;height:30px;border-radius:50%;background:var(--hae-black);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;}
.hae-meta .author{font-size:13px;color:var(--hae-black);font-weight:500;}
.hae-meta .info{font-size:13px;color:var(--hae-light);}
.hae-meta .actions{display:flex;gap:12px;color:var(--hae-light);font-size:16px;margin-left:6px;}

.hae-figure{max-width:var(--hae-wide);margin:0 auto;padding:0 22px;}
.hae-figure img{width:100%;filter:grayscale(100%) contrast(1.05);}
.hae-figure figcaption{font-family:var(--hae-serif);font-size:11px;font-style:italic;color:var(--hae-light);margin:8px 0 30px;}

.hae-content{max-width:var(--hae-content);margin:0 auto;padding:0 22px;}
.hae-content p{font-family:var(--hae-serif);font-size:17px;line-height:1.72;color:var(--hae-ink);margin:0 0 18px;text-align:justify;}
.hae-content h2{font-family:var(--hae-title);font-size:25px;font-weight:500;line-height:1.2;margin:32px 0 14px;color:var(--hae-black);}
.hae-content h3{font-family:var(--hae-title);font-size:19px;font-weight:500;line-height:1.25;margin:26px 0 12px;color:var(--hae-black);}
.hae-content blockquote{border-left:3px solid var(--hae-black);margin:28px 0;padding:6px 0 6px 22px;}
.hae-content blockquote p{font-size:23px;line-height:1.4;font-style:italic;color:var(--hae-black);margin:0;text-align:left;}
.hae-content a{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;}
.hae-content ul,.hae-content ol{font-family:var(--hae-serif);font-size:17px;line-height:1.72;padding-left:1.3em;margin:0 0 18px;}
.hae-content img{margin:24px auto;filter:grayscale(100%) contrast(1.05);}

/* lettrine sur le premier paragraphe */
.hae-content > p:first-of-type::first-letter{
  font-family:var(--hae-display);font-weight:600;font-size:58px;line-height:0.72;
  float:left;padding:6px 10px 0 0;color:var(--hae-black);
}

.hae-tags{max-width:var(--hae-content);margin:0 auto;padding:18px 22px 0;display:flex;gap:8px;flex-wrap:wrap;}
.hae-tags a{
  font-family:var(--hae-sans);font-size:11px;letter-spacing:0.05em;text-transform:uppercase;
  border:1px solid var(--hae-faint);padding:5px 11px;color:var(--hae-muted);
}
.hae-tags a:hover{border-color:var(--hae-black);color:var(--hae-black);text-decoration:none;}

/* =========================================================
   7. Bloc « même rubrique » + cartes
   ========================================================= */
.hae-related{border-top:1px solid var(--hae-black);margin:30px 26px 0;padding:22px 0;}
.hae-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.hae-card .hae-card-thumb{width:100%;height:110px;object-fit:cover;filter:grayscale(100%) contrast(1.05);background:#eee;margin-bottom:10px;}
.hae-card h4{font-family:var(--hae-title);font-size:15px;line-height:1.25;font-weight:500;margin:0;color:var(--hae-black);}

/* =========================================================
   8. Newsletter + pied de page
   ========================================================= */
.hae-newsletter{
  border-top:1px solid var(--hae-black);padding:20px 26px;background:var(--hae-bg-soft);
  display:flex;justify-content:space-between;align-items:center;gap:18px;
}
.hae-newsletter p{font-family:var(--hae-sans);font-size:13px;color:var(--hae-muted);margin:0;max-width:60%;}
.hae-btn{
  font-family:var(--hae-sans);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  background:var(--hae-black);color:#fff;padding:9px 16px;border:none;cursor:pointer;display:inline-block;
}
.hae-btn:hover{text-decoration:none;background:#000;}

.hae-footer{background:var(--hae-black);color:#fff;padding:26px;}
.hae-footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:20px;}
.hae-footer-logo{font-family:var(--hae-display);font-weight:600;font-size:22px;letter-spacing:0.1em;margin-bottom:8px;}
.hae-footer .hae-foot-base{font-family:var(--hae-sans);font-size:11px;color:#888;letter-spacing:0.06em;}
.hae-footer ul{list-style:none;margin:0;padding:0;font-family:var(--hae-sans);font-size:12px;line-height:2;}
.hae-footer ul a{color:#bbb;}
.hae-footer ul a:hover{color:#fff;text-decoration:none;}

/* =========================================================
   9. Archive / index
   ========================================================= */
.hae-archive{padding:8px 26px 24px;}
.hae-archive-head{text-align:center;padding:30px 0 6px;border-bottom:1px solid var(--hae-black);}
.hae-archive-head h1{font-family:var(--hae-display);font-weight:600;font-size:26px;letter-spacing:0.12em;text-transform:uppercase;margin:0;color:var(--hae-black);}

.hae-pagination{display:flex;justify-content:center;gap:16px;padding:24px 0;font-family:var(--hae-sans);font-size:12px;letter-spacing:0.08em;text-transform:uppercase;}
.hae-pagination a,.hae-pagination span{color:var(--hae-muted);border:1px solid var(--hae-faint);padding:8px 14px;}
.hae-pagination .current{background:var(--hae-black);color:#fff;border-color:var(--hae-black);}

/* =========================================================
   10. Responsive
   ========================================================= */
@media (max-width:760px){
  .hae-topbar{flex-wrap:wrap;gap:10px;justify-content:center;}
  .hae-topbar .hae-dt,.hae-topbar .hae-tools{min-width:auto;}
  .hae-logo{font-size:26px;}
  .hae-hero h1{font-size:32px;}
  .hae-article-head h1{font-size:30px;}
  .hae-cards{grid-template-columns:1fr;}
  .hae-footer-grid{grid-template-columns:1fr 1fr;}
  .hae-item{flex-wrap:wrap;}
  .hae-thumb{order:3;}
  .hae-newsletter{flex-direction:column;align-items:flex-start;}
  .hae-newsletter p{max-width:100%;}
}
@media (max-width:460px){
  .hae-num{display:none;}
  .hae-footer-grid{grid-template-columns:1fr;}
}

.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden;}

/* =========================================================
   11. Styles de blocs Gutenberg personnalisés (front)
   ========================================================= */
.hae-content .is-style-haeresis-chapo,
.is-style-haeresis-chapo{
  font-family:var(--hae-serif);font-size:19px;line-height:1.5;font-style:italic;color:var(--hae-muted);
}
.hae-content .is-style-haeresis-exergue,
.is-style-haeresis-exergue{
  font-family:var(--hae-display);font-size:18px;line-height:1.5;letter-spacing:0.04em;
  color:var(--hae-black);text-align:center;margin:28px 0;
}
.hae-content .wp-block-quote.is-style-haeresis-pleine{
  border-left:3px solid var(--hae-black);padding:6px 0 6px 22px;margin:28px 0;font-style:italic;
}
.hae-content .wp-block-quote.is-style-haeresis-pleine p{font-size:23px;line-height:1.4;color:var(--hae-black);text-align:left;}
.hae-content .wp-block-quote.is-style-haeresis-pleine cite{font-family:var(--hae-sans);font-size:13px;font-style:normal;color:var(--hae-light);display:block;margin-top:8px;}
