/* ===== Champs & Cheptels — theme Joornal ===== */
:root{
  --color-primary:#2F5233;
  --color-primary-dark:#203a23;
  --color-secondary:#8B5E3C;
  --color-accent:#D4A537;
  --color-text:#2B2B28;
  --color-bg:#FAF6EC;
  --color-bg-alt:#F0E6D2;
  --color-cream:#FFFDF8;
  --font-display:'Fraunces', serif;
  --font-body:'Inter', sans-serif;
  --container-max:1200px;
  --container-narrow:720px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--color-text);
  background:var(--color-bg);
  font-size:16px;
  line-height:1.65;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-display);margin:0 0 .5em;line-height:1.1;color:var(--color-primary-dark);}
p{margin:0 0 1.2em;}

.container{max-width:var(--container-max);margin:0 auto;padding:0 24px;}
.container--narrow{max-width:var(--container-narrow);}
.container--article{max-width:760px;}

/* ===== NAV ===== */
.site-nav{
  background:var(--color-primary);
  padding:14px 0;
  border-bottom:4px solid var(--color-accent);
}
.nav-inner{
  max-width:var(--container-max);
  margin:0 auto;
  padding:0 24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.nav-logo img{height:72px;width:auto;display:block;}
.nav-toggle-checkbox{display:none;}
.nav-toggle-label{
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  padding:8px;
}
.nav-toggle-label span{width:28px;height:3px;background:var(--color-cream);display:block;border-radius:2px;}

.nav-menu{
  display:flex;
  list-style:none;
  margin:0;
  padding:0;
  gap:8px;
  flex-wrap:wrap;
}
.nav-menu__item{margin:0;}
.nav-menu__link{
  display:inline-block;
  padding:10px 16px;
  color:var(--color-cream);
  font-weight:600;
  font-size:.95rem;
  text-transform:uppercase;
  letter-spacing:.04em;
  border-radius:4px;
  transition:background .2s,color .2s;
}
.nav-menu__link:hover{background:var(--color-accent);color:var(--color-primary-dark);}

@media (max-width:720px){
  .nav-toggle-label{display:flex;}
  .nav-menu{
    display:none;
    position:absolute;
    top:100%;
    left:0;right:0;
    background:var(--color-primary);
    flex-direction:column;
    padding:8px 24px 20px;
    z-index:30;
  }
  .nav-toggle-checkbox:checked ~ .nav-menu{display:flex;}
  .site-nav{position:relative;}
  .nav-logo img{height:52px;}
}
@media (max-width:480px){
  .nav-logo img{height:48px;}
}

/* ===== MAIN / FOOTER ===== */
.site-main{display:block;}
.site-footer{
  background:var(--color-secondary);
  color:var(--color-cream);
  padding:40px 0;
  margin-top:60px;
}
.footer-inner{
  max-width:var(--container-max);
  margin:0 auto;
  padding:0 24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}
.footer-copy{margin:0;font-size:.9rem;}
.footer-domain{margin:0;font-size:.85rem;opacity:.8;font-style:italic;}

/* ===== HOME — Archétype D : bandeau journal ===== */
.home-banner{
  background:var(--color-primary);
  color:var(--color-cream);
  padding:70px 0 56px;
  position:relative;
  overflow:hidden;
}
.home-banner::after{
  content:"";
  position:absolute;
  right:-60px;top:-60px;
  width:240px;height:240px;
  border-radius:50%;
  background:rgba(212,165,55,0.18);
}
.home-banner__kicker{
  font-family:var(--font-body);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.8rem;
  color:var(--color-accent);
  font-weight:700;
  margin:0 0 14px;
}
.home-banner__title{
  color:var(--color-cream);
  font-size:clamp(2.4rem,5vw,3.6rem);
  font-weight:600;
  max-width:760px;
  margin:0 0 16px;
}
.home-banner__baseline{
  font-size:1.15rem;
  max-width:560px;
  color:#E8E0CC;
  margin:0;
  font-style:italic;
  font-family:var(--font-display);
}

.home-content{padding:60px 0;}
.home-content__inner{overflow:hidden;}
.home-thumb{
  float:right;
  width:42%;
  margin:0 0 20px 28px;
  border-radius:6px;
  box-shadow:0 12px 30px -10px rgba(43,43,40,0.3);
}
.home-content__text{font-size:1.05rem;color:var(--color-text);}
.home-content__text h2{font-size:1.6rem;margin-top:1.4em;}

@media (max-width:600px){
  .home-thumb{float:none;width:100%;margin:0 0 20px;}
}

.home-showcase{background:var(--color-bg-alt);padding:60px 0 70px;}
.home-showcase__title{
  font-size:1.8rem;
  margin-bottom:32px;
  border-bottom:3px solid var(--color-accent);
  padding-bottom:14px;
  display:inline-block;
}
.showcase-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:32px;
}
@media (max-width:720px){
  .showcase-grid{grid-template-columns:1fr;}
}

/* ===== POST CARD — numérotation éditoriale ===== */
.post-card{
  display:grid;
  grid-template-columns:64px 1fr;
  gap:18px;
  background:var(--color-cream);
  border:1px solid rgba(43,43,40,0.08);
  border-radius:8px;
  padding:20px;
  position:relative;
}
.post-card__number{
  font-family:var(--font-display);
  font-size:2.4rem;
  font-weight:700;
  color:var(--color-accent);
  line-height:1;
}
.post-card__media{
  grid-column:1 / -1;
  order:-1;
  border-radius:6px;
  overflow:hidden;
  margin:-20px -20px 14px -20px;
}
.post-card__media img{width:100%;height:200px;object-fit:cover;}
.post-card__category{
  display:inline-block;
  font-size:.75rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:700;
  color:var(--color-secondary);
  margin-bottom:8px;
}
.post-card__title{font-size:1.25rem;margin:0 0 8px;}
.post-card__title a:hover{color:var(--color-secondary);}
.post-card__excerpt{font-size:.95rem;color:#55534c;margin-bottom:12px;}
.post-card__meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:.85rem;
  border-top:1px solid rgba(43,43,40,0.08);
  padding-top:10px;
}
.post-card__link{font-weight:700;color:var(--color-primary);}
.post-card__date{color:#857f6f;}

/* ===== POST LIST — hero split 50/50 ===== */
.list-hero{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:280px;
}
.list-hero__text{
  background:var(--color-bg-alt);
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:48px 48px;
}
.list-hero__kicker{
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.8rem;
  font-weight:700;
  color:var(--color-secondary);
  margin-bottom:12px;
}
.list-hero__title{font-size:clamp(2rem,4vw,2.8rem);margin-bottom:12px;}
.list-hero__desc{max-width:480px;color:#54514a;}
.list-hero__shape{
  background:var(--color-primary);
  position:relative;
  overflow:hidden;
}
.list-hero__shape::before{
  content:"";
  position:absolute;
  width:320px;height:320px;
  background:var(--color-accent);
  opacity:.85;
  border-radius:48% 52% 60% 40%/50% 45% 55% 50%;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
}
@media (max-width:720px){
  .list-hero{grid-template-columns:1fr;}
  .list-hero__shape{min-height:160px;}
  .list-hero__text{padding:36px 24px;}
}

.list-content{padding:56px 0;}
.post-loop-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px;
  margin-bottom:40px;
}
@media (max-width:720px){
  .post-loop-list{grid-template-columns:1fr;}
}

.pagination{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;}
.page-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:38px;
  height:38px;
  border-radius:4px;
  border:1px solid rgba(43,43,40,0.15);
  font-weight:600;
  color:var(--color-text);
}
.page-link--active{background:var(--color-primary);color:var(--color-cream);border-color:var(--color-primary);}

/* ===== POST — flush-left, sans bandeau ===== */
.post{padding:48px 0 0;}
.post-breadcrumb{
  font-size:.85rem;
  color:#857f6f;
  margin-bottom:24px;
}
.post-breadcrumb a{color:var(--color-secondary);}
.post-header{margin-bottom:28px;}
.post-meta{
  display:flex;
  gap:16px;
  align-items:center;
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.05em;
  font-weight:600;
  margin-bottom:14px;
  flex-wrap:wrap;
}
.post-category{color:var(--color-accent);}
.post-date,.post-reading{color:#857f6f;}
.post-title{
  font-size:clamp(2.2rem,5vw,3.4rem);
  text-align:left;
  max-width:740px;
}
.post-thumb img{
  width:100%;
  border-radius:8px;
  margin:24px 0 36px;
  max-height:480px;
  object-fit:cover;
}
.post-body{font-size:1.08rem;}
.post-body h2{font-size:1.7rem;margin-top:1.8em;}
.post-body h3{font-size:1.3rem;}
.post-body img{border-radius:6px;margin:1.5em 0;}
.post-body blockquote{
  border-left:4px solid var(--color-accent);
  margin:1.8em 0;
  padding:.4em 0 .4em 1.4em;
  font-style:italic;
  font-family:var(--font-display);
  font-size:1.15rem;
  color:var(--color-secondary);
}

.post-signatory{
  margin:48px 0;
  padding:24px;
  background:var(--color-bg-alt);
  border-radius:8px;
  border-left:4px solid var(--color-primary);
}

.post-related{padding:40px 0 70px;}
.post-related__title{
  font-size:1.6rem;
  border-bottom:3px solid var(--color-accent);
  padding-bottom:12px;
  display:inline-block;
  margin-bottom:28px;
}

@media (max-width:480px){
  .container,.container--article{padding:0 18px;}
  .post-title{font-size:2rem;}
  .home-banner{padding:48px 0 40px;}
}
