/*
Theme Name: Résurrection
Theme URI: https://revueresurrection.fr
Description: Thème de la Revue Résurrection. Identité éditoriale « revue savante, patrimoine vivant » : ivoire papier, bordeaux profond, or patiné, typographies EB Garamond / Source Serif 4 / Inter. Thème enfant de Twenty Twenty-Five (blocs / FSE), entièrement modifiable dans l'éditeur Gutenberg.
Author: WinWin Partners
Template: twentytwentyfive
Version: 1.0.3
Requires at least: 6.7
Requires PHP: 7.2
Text Domain: resurrection
*/

:root{
  --res-bordeaux-f:#581620;
  --res-filet:rgba(29,26,23,.14);
  --res-filet-or:rgba(184,155,94,.5);
}

/* ---------- Labels / sur-titres ---------- */
.res-surtitre{
  font-family:var(--wp--preset--font-family--sans);
  text-transform:uppercase; letter-spacing:.2em;
  font-size:.72rem; font-weight:600;
  color:var(--wp--preset--color--cuir);
  margin:0 0 1rem;
}
.res-label{
  font-family:var(--wp--preset--font-family--sans);
  text-transform:uppercase; letter-spacing:.16em;
  font-size:.68rem; font-weight:600; color:var(--wp--preset--color--pierre);
  margin:0 0 .4rem;
}
.res-label.has-bordeaux-color{ color:var(--wp--preset--color--bordeaux); }
.res-baseline{
  font-family:var(--wp--preset--font-family--garamond);
  font-style:italic; color:var(--wp--preset--color--cuir);
  line-height:1.35;
}
.res-lead{ font-size:clamp(1.15rem,1.8vw,1.32rem); line-height:1.6; color:#3a352f; }
.res-meta{ font-family:var(--wp--preset--font-family--sans); font-size:.78rem; color:var(--wp--preset--color--pierre); letter-spacing:.02em; }

/* Largeur de lecture confortable */
.res-measure{ max-width:62ch; }

/* Lettrine */
.res-lettrine p:first-of-type::first-letter,
p.res-lettrine::first-letter{
  font-family:var(--wp--preset--font-family--garamond);
  font-weight:600; color:var(--wp--preset--color--bordeaux);
  float:left; font-size:3.6em; line-height:.72; padding:.05em .12em 0 0;
}

/* ---------- Filet doré + ornement ---------- */
.res-ornement{ display:flex; align-items:center; justify-content:center; gap:.9rem; color:var(--wp--preset--color--or); }
.res-ornement::before,.res-ornement::after{ content:""; height:1px; width:min(110px,16vw); background:var(--wp--preset--color--or); opacity:.6; }
.res-ornement span{ font-family:var(--wp--preset--font-family--garamond); font-size:1.1rem; line-height:1; }

/* ---------- Cadre fin autour des visuels ---------- */
.res-frame{ padding:8px; background:var(--wp--preset--color--papier); border:1px solid var(--res-filet); box-shadow:0 12px 30px -22px rgba(29,26,23,.5); }
.res-frame > .res-gravure{ border:1px solid var(--res-filet-or); }
figcaption,.res-caption{ font-family:var(--wp--preset--font-family--sans); font-size:.72rem; color:var(--wp--preset--color--pierre); margin-top:.7rem; letter-spacing:.02em; }
.res-caption:empty{ display:none; }

/* ---------- Gravure (placeholder patrimonial) ---------- */
.res-gravure{
  position:relative; min-height:260px; aspect-ratio:4/5; background:#EAE0CE; overflow:hidden;
  background-image:
    repeating-linear-gradient(45deg, rgba(122,85,56,.10) 0 1px, transparent 1px 5px),
    repeating-linear-gradient(-45deg, rgba(29,26,23,.06) 0 1px, transparent 1px 7px);
  display:flex; align-items:center; justify-content:center;
}
.res-gravure.is-wide{ aspect-ratio:3/2; min-height:0; }
.res-gravure::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 60px rgba(122,85,56,.25); pointer-events:none; }
.res-gravure > *{ position:relative; font-family:var(--wp--preset--font-family--sans); text-transform:uppercase; letter-spacing:.18em; font-size:.6rem; font-weight:600; color:var(--wp--preset--color--cuir); background:rgba(246,240,230,.7); padding:.35rem .7rem; border:1px solid var(--res-filet-or); margin:0; }
/* Vraie image insérée dans le cadre patrimonial : neutralise le rendu « placeholder » */
.res-gravure:has(img){ min-height:0; aspect-ratio:auto; background:none; background-image:none; display:block; }
.res-gravure:has(img)::after{ display:none; }
.res-gravure > .wp-block-image{ margin:0; padding:0; border:0; background:none; letter-spacing:normal; text-transform:none; }
.res-gravure > .wp-block-image img{ display:block; width:100%; height:auto; }

/* ---------- Couverture (maquette) ---------- */
.res-cover{
  width:min(300px,80vw); aspect-ratio:3/4.15; margin-inline:auto;
  background:var(--wp--preset--color--olive); border:1px solid var(--wp--preset--color--olive);
  box-shadow:0 16px 36px -24px rgba(29,26,23,.55);
  padding:1.6rem 1.3rem; display:flex; flex-direction:column; text-align:center; position:relative;
}
.res-cover::before{ content:""; position:absolute; inset:7px; border:1px solid var(--wp--preset--color--or); pointer-events:none; }
.res-cover > *{ position:relative; color:var(--wp--preset--color--papier); margin:0; }
.res-cover .res-cover__rev{ font-family:var(--wp--preset--font-family--sans); text-transform:uppercase; letter-spacing:.3em; font-size:.56rem; font-weight:600; color:#EDEFD9; }
.res-cover .res-cover__title{ font-family:var(--wp--preset--font-family--garamond); font-weight:600; font-size:1.9rem; line-height:1; margin-top:.5rem; }
.res-cover .res-cover__theme{ font-family:var(--wp--preset--font-family--garamond); font-style:italic; font-size:1.55rem; margin:auto 0; line-height:1.2; }
.res-cover .res-cover__num{ font-family:var(--wp--preset--font-family--sans); text-transform:uppercase; letter-spacing:.18em; font-size:.62rem; color:#D9DCC0; margin-top:auto; }

/* ---------- Chiffres-clés ---------- */
.res-chiffre .res-nombre{ font-family:var(--wp--preset--font-family--garamond); font-weight:600; font-size:clamp(2.6rem,5.5vw,3.8rem); line-height:1; color:var(--wp--preset--color--bordeaux); margin:0; }
.res-chiffre .res-libelle{ font-family:var(--wp--preset--font-family--sans); text-transform:uppercase; letter-spacing:.12em; font-size:.68rem; color:var(--wp--preset--color--pierre); margin:.7rem 0 0; line-height:1.5; }

/* ---------- Rubriques (cartes) ---------- */
.res-rubrique{ border:1px solid var(--res-filet); border-radius:1px; transition:border-color .2s ease, transform .2s ease; height:100%; }
.res-rubrique:hover{ border-color:var(--wp--preset--color--or); transform:translateY(-2px); }

/* ---------- Articles (grille éditoriale) ---------- */
.res-article h3{ line-height:1.18; }
.res-article h3 a{ color:var(--wp--preset--color--encre); border-bottom:1px solid transparent; }
.res-article h3 a:hover{ color:var(--wp--preset--color--bordeaux); border-color:var(--wp--preset--color--or); text-decoration:none; }

/* ---------- Archives (bande défilable) ---------- */
.res-archives{ display:flex; gap:1.1rem; overflow-x:auto; padding-bottom:1.2rem; }
.res-archives .res-mini-cover{ flex:0 0 auto; width:132px; aspect-ratio:3/4.15; border:1px solid var(--res-filet); padding:.8rem .6rem; display:flex; flex-direction:column; text-align:center; transition:transform .2s ease, border-color .2s ease; }
.res-mini-cover:hover{ transform:translateY(-3px); border-color:var(--wp--preset--color--or); }
.res-mini-cover > *{ margin:0; }
.res-mini-cover .mc-nom{ font-family:var(--wp--preset--font-family--garamond); font-size:.9rem; font-weight:600; color:var(--wp--preset--color--bordeaux); }
.res-mini-cover .mc-an{ font-family:var(--wp--preset--font-family--garamond); font-size:1.9rem; color:var(--wp--preset--color--encre); margin:auto 0; }
.res-mini-cover .mc-num{ font-family:var(--wp--preset--font-family--sans); font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; color:var(--wp--preset--color--pierre); }

/* ---------- Numéros (CPT) : couvertures & cartes de boucle ---------- */
.res-cover-img img{ border:1px solid var(--res-filet); box-shadow:0 14px 32px -24px rgba(29,26,23,.5); }
.res-cover-img.wp-block-post-featured-image{ margin:0; }
.res-numeros-loop .res-article{ display:flex; flex-direction:column; height:100%; }
.res-numeros-loop .wp-block-post-title{ font-family:var(--wp--preset--font-family--garamond); font-weight:500; font-size:1.42rem; line-height:1.18; }
.res-numeros-loop .wp-block-post-title a{ color:var(--wp--preset--color--encre); border-bottom:1px solid transparent; text-decoration:none; }
.res-numeros-loop .wp-block-post-title a:hover{ color:var(--wp--preset--color--bordeaux); border-color:var(--wp--preset--color--or); }
.res-numeros-loop .wp-block-post-excerpt{ color:#4a443d; }
.res-numeros-loop .wp-block-post-excerpt__excerpt{ margin:0; }
.res-numeros-loop .wp-block-post-excerpt__more-link{ display:none; }
/* Grille 3 colonnes des cartes de numéros (accueil + archive), robuste si l'éditeur repasse la boucle en « flux » */
.res-numeros-loop ul.wp-block-post-template{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:clamp(1.6rem,3vw,2.6rem); }
.res-numeros-loop ul.wp-block-post-template > li{ margin-block-start:0; }
@media (max-width:781px){ .res-numeros-loop ul.wp-block-post-template{ grid-template-columns:1fr; } }
.wp-block-query-pagination .wp-block-query-pagination-numbers,
.wp-block-query-pagination a,
.wp-block-query-pagination .current{ font-family:var(--wp--preset--font-family--sans); font-size:.85rem; letter-spacing:.04em; }

/* ---------- En-tête ---------- */
.res-topline{ height:3px; background:var(--wp--preset--color--bordeaux); }
.res-header{ border-bottom:1px solid var(--res-filet); }
.res-header .wp-block-site-title a{ text-decoration:none; }
.res-header .wp-block-navigation a{ color:var(--wp--preset--color--encre); }
.res-header .wp-block-navigation a:hover{ color:var(--wp--preset--color--bordeaux); text-decoration:none; }
.res-boutique a{
  font-family:var(--wp--preset--font-family--sans); font-size:.78rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.12em; color:var(--wp--preset--color--olive)!important;
  border:1px solid var(--res-filet); padding:.5rem .95rem; border-radius:1px; text-decoration:none;
}
.res-boutique a:hover{ border-color:var(--wp--preset--color--olive); background:rgba(79,91,46,.08); }
.res-wordmark .res-wordmark__sur{ font-family:var(--wp--preset--font-family--sans); text-transform:uppercase; letter-spacing:.42em; font-size:.54rem; font-weight:600; color:var(--wp--preset--color--cuir); margin:0 0 .2rem; }
.res-header .res-logo.wp-block-site-logo{ margin:0; line-height:0; }
.res-header .res-logo img{ height:auto; }
@media(max-width:781px){ .res-header .res-logo.wp-block-site-logo{ width:200px!important; } }

/* ---------- Pied de page ---------- */
.res-footer{ background:var(--wp--preset--color--encre); color:rgba(246,240,230,.78); }
.res-footer :where(h1,h2,h3,h4){ color:var(--wp--preset--color--or); }
.res-footer a{ color:rgba(246,240,230,.78); text-decoration:none; }
.res-footer a:hover{ color:var(--wp--preset--color--papier); }
.res-footer .res-footer-h{ font-family:var(--wp--preset--font-family--sans); text-transform:uppercase; letter-spacing:.16em; font-size:.7rem; font-weight:600; color:var(--wp--preset--color--or); }
.res-footer .res-wordmark__nom{ font-family:var(--wp--preset--font-family--garamond); font-size:1.55rem; color:var(--wp--preset--color--papier); }

/* ---------- Boutons : variante contour ---------- */
.wp-block-button.is-style-contour .wp-block-button__link{
  background:transparent; color:var(--wp--preset--color--bordeaux);
  border:1px solid var(--wp--preset--color--bordeaux);
}
.wp-block-button.is-style-contour .wp-block-button__link:hover{
  background:var(--wp--preset--color--bordeaux); color:var(--wp--preset--color--papier);
}
.res-footer .wp-block-button.is-style-contour .wp-block-button__link{ color:var(--wp--preset--color--papier); border-color:rgba(246,240,230,.45); }
.res-footer .wp-block-button.is-style-contour .wp-block-button__link:hover{ background:var(--wp--preset--color--papier); color:var(--wp--preset--color--encre); }

/* ---------- Pages de contenu : marge interne des sections ---------- */
/* Donne aux sections pleine largeur des pages (hors accueil, qui a déjà
   ses paddings en ligne) une respiration verticale haut/bas. */
.page:not(.home) main .wp-block-group.alignfull.has-background{
  padding-top:var(--wp--preset--spacing--60);
  padding-bottom:var(--wp--preset--spacing--60);
}

/* ---------- Séparateurs ---------- */
.wp-block-separator.is-style-wide{ border-color:var(--res-filet-or); opacity:1; }

/* ---------- Accessibilité : mouvement réduit ---------- */
@media (prefers-reduced-motion: reduce){
  *{ transition-duration:.001ms !important; animation-duration:.001ms !important; }
}
