/* Polices Goudy (hébergées localement, récupérées du site de Loisy) :
   GoudyModern pour les titres, GoudyOldstyle pour les italiques élégantes. */
@font-face{
  font-family:'GoudyModern'; font-style:normal; font-weight:400; font-display:swap;
  src:url('../fonts/goudy-modern-regular.woff2') format('woff2');
}
@font-face{
  font-family:'GoudyOldstyle'; font-style:italic; font-weight:400; font-display:swap;
  src:url('../fonts/goudy-oldstyle-italic.woff2') format('woff2');
}

/* Police Servus (hébergée localement, récupérée du site de la Province de France) */
@font-face{
  font-family:'Servus'; font-style:normal; font-weight:400; font-display:swap;
  src:url('../fonts/Servus-Regular.woff2') format('woff2'),
      url('../fonts/Servus-Regular.woff') format('woff');
}
@font-face{
  font-family:'Servus'; font-style:italic; font-weight:400; font-display:swap;
  src:url('../fonts/Servus-RegularItalic.woff2') format('woff2'),
      url('../fonts/Servus-RegularItalic.woff') format('woff');
}
@font-face{
  font-family:'Servus'; font-style:normal; font-weight:700; font-display:swap;
  src:url('../fonts/Servus-Bold.woff2') format('woff2'),
      url('../fonts/Servus-Bold.woff') format('woff');
}
@font-face{
  font-family:'Servus'; font-style:italic; font-weight:700; font-display:swap;
  src:url('../fonts/Servus-BoldItalic.woff2') format('woff2'),
      url('../fonts/Servus-BoldItalic.woff') format('woff');
}
@font-face{
  font-family:'Servus'; font-style:normal; font-weight:600; font-display:swap;
  src:url('../fonts/Servus-SemiBold.woff2') format('woff2'),
      url('../fonts/Servus-SemiBold.woff') format('woff');
}
@font-face{
  font-family:'Servus'; font-style:italic; font-weight:600; font-display:swap;
  src:url('../fonts/Servus-SemiBoldItalic.woff2') format('woff2'),
      url('../fonts/Servus-SemiBoldItalic.woff') format('woff');
}
@font-face{
  font-family:'Servus'; font-style:normal; font-weight:300; font-display:swap;
  src:url('../fonts/Servus-Light.woff2') format('woff2'),
      url('../fonts/Servus-Light.woff') format('woff');
}
@font-face{
  font-family:'Servus'; font-style:italic; font-weight:300; font-display:swap;
  src:url('../fonts/Servus-LightItalic.woff2') format('woff2'),
      url('../fonts/Servus-LightItalic.woff') format('woff');
}

/* ============================================================
   CHARTE GRAPHIQUE DU SITE — palette BLEUE (inspirée de la Province de France).
   ------------------------------------------------------------
   Pour changer les couleurs ou les polices de tout le site, il suffit de
   modifier les variables ci-dessous (bloc :root). Tout le reste s'adapte.
   Titres : Prata (serif élégant). Texte : DM Sans (sans-serif lisible).
   ============================================================ */
:root{
  /* Bleus de la charte */
  --navy:#2b3550; --navy-dark:#1d2540; --bleu:#4f6f9c; --bleu-clair:#93aac4;
  /* Fonds et encre */
  --fond:#f6f8fb; --fond-2:#eaeff5; --encre:#26303f; --gris:#5b6677;

  /* --- Noms historiques conservés (désormais en BLEU) : ainsi toutes les règles
         et les gabarits qui utilisent var(--bordeaux), var(--or)... suivent. --- */
  --bordeaux:#2b3550; --bordeaux-dark:#1d2540; --rouge:#4f6f9c;
  --or:#7290b3; --or-clair:#cdd9e8; --or-fonce:#4f6f9c;
  --creme:#f6f8fb; --creme-2:#eaeff5;

  /* Polices */
  --titre:'GoudyModern', Georgia, 'Times New Roman', serif;
  --titre-italique:'GoudyOldstyle', Georgia, serif;
  --corps:'Servus', 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --sans:'Google Sans Flex', 'DM Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--corps);color:var(--encre);background:var(--fond);font-size:17px;line-height:1.7}
h1,h2,h3,h4{font-family:var(--titre);font-weight:400;line-height:1.2;color:var(--navy)}
/* Éléments UI : navigation, badges, étiquettes, dates, formulaires → sans-serif */
.nav-links a,.sub-menu a,
.tile-tag,.tile-date,.tile-author,
.fc-date,.fc-author,
.news-filter a,.news-filter-year a,
.pagination a,.pagination span,
.btn,.ap-title,.ap-spd-btn,
.news-search input,.nl-group input,.nl-group select,
input,button,select,textarea{font-family:var(--sans)}
a{color:var(--bleu);text-decoration:none}
a:hover{color:var(--navy)}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}

#progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--bleu);z-index:60;transition:width .1s}

/* ---------- Barre de menu : fixée tout en haut, pleine largeur ---------- */
/* Logo collé à gauche, langues collées à droite, menu au centre. Transparente sur
   l'image ; fond bleu progressif au défilement (site.js fait varier --navbg). */
.mainnav{position:fixed;top:0;left:0;right:0;z-index:50;min-height:60px;
  background:rgba(29,37,64,calc(var(--navbg,0)));transition:background .25s,box-shadow .25s;
  display:flex;justify-content:center}
.mainnav.solid{box-shadow:0 2px 12px rgba(0,0,0,.22)}
/* Wrapper centré qui contient tout le contenu de la barre */
.nav-inner{width:100%;max-width:1180px;display:flex;align-items:center;gap:18px;padding:0 30px}
.nav-logo{flex-shrink:0;display:flex;align-items:center;overflow:visible}
.nav-logo img{height:40px;width:auto;display:block;transition:height .3s,opacity .3s,transform .3s}
/* Accueil : logo caché, apparaît avec la barre bleue au scroll */
.home .nav-logo img{opacity:0;pointer-events:none}
.home .mainnav.solid .nav-logo img{opacity:1;pointer-events:auto}
/* Autres pages : logo grand, descendu sous la barre ; remonte et se réduit au scroll */
body:not(.home) .nav-logo img{height:72px;transform:translateY(16px)}
body:not(.home) .mainnav.solid .nav-logo img{height:40px;transform:translateY(0)}
.nav-collapse{flex:1;display:flex;align-items:center}
.nav-links{list-style:none;display:flex;align-items:center;flex-wrap:wrap;gap:2px;flex:1;justify-content:center;margin:0}
.nav-links a{display:block;padding:10px 14px;font-family:var(--sans);font-size:14px;font-weight:500;
  letter-spacing:1.2px;text-transform:uppercase;color:#fff;transition:.2s}
.nav-links a:hover{color:var(--bleu-clair)}
/* --- Sous-menus déroulants (desktop) --- */
.nav-links li{position:relative}
/* Parent non-cliquable (span à la place du <a>) */
.nav-links span.nav-parent-label{
  display:block;padding:10px 14px;font-family:var(--sans);font-size:14px;font-weight:500;
  letter-spacing:1.2px;text-transform:uppercase;color:#fff;cursor:default;opacity:.7;
}
.sub-toggle{display:none} /* visible seulement sur mobile */
.sub-menu{
  display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);
  min-width:230px;background:var(--navy-dark);
  border-top:2px solid var(--bleu);border-radius:0 0 8px 8px;
  box-shadow:0 14px 32px rgba(0,0,0,.35);list-style:none;z-index:55;
  padding:6px 0 6px;
  /* Pont invisible : le padding-top crée une zone de survol continue entre
     le lien parent et le sous-menu, évitant le "hover gap" qui referme
     le dropdown quand la souris traverse l'espace entre les deux. */
}
.sub-menu::before{
  content:"";position:absolute;top:-10px;left:0;right:0;height:10px;
  /* Zone tampon transparente qui prolonge la zone de survol vers le haut */
}
.sub-menu a{
  display:block;padding:11px 20px;
  font-family:var(--sans);font-size:13.5px;font-weight:400;
  letter-spacing:.4px;text-transform:none;
  color:rgba(255,255,255,.85);
  border-bottom:1px solid rgba(255,255,255,.07);transition:.15s
}
.sub-menu li:last-child a{border-bottom:none}
.sub-menu a:hover{background:rgba(79,111,156,.28);color:#fff;padding-left:26px}
/* Afficher au survol du <li> (focus-within pour le clavier) */
.has-sub:hover>.sub-menu,.has-sub:focus-within>.sub-menu{display:block}
/* Sélecteur de langue : drapeau courant + menu déroulant à drapeaux */
.nav-langs{flex-shrink:0;position:relative}
.lang-current{display:flex;align-items:center;gap:7px;background:none;border:0;cursor:pointer;
  color:#fff;font-family:var(--sans);font-size:13px;letter-spacing:1px;padding:7px 8px}
.lang-current img{width:22px;height:auto;border-radius:2px;display:block;box-shadow:0 0 0 1px rgba(255,255,255,.25)}
.lang-current .caret{font-style:normal;font-size:10px;opacity:.8}
.lang-menu{position:absolute;top:100%;right:0;margin:6px 0 0;padding:6px 0;list-style:none;
  background:var(--navy-dark);min-width:160px;border-radius:8px;box-shadow:0 10px 26px rgba(0,0,0,.35);
  display:none;z-index:60}
.nav-langs.open .lang-menu{display:block}
.lang-menu a{display:flex;align-items:center;gap:10px;padding:9px 14px;color:#fff;font-family:var(--sans);font-size:14px}
.lang-menu a:hover{background:rgba(255,255,255,.08)}
.lang-menu a.active{color:var(--bleu-clair)}
.lang-menu img{width:24px;height:auto;border-radius:2px;display:block}
.nav-burger{display:none;background:none;border:0;cursor:pointer;padding:10px;flex-direction:column;gap:5px}
.nav-burger span{display:block;width:26px;height:2px;background:#fff;transition:.25s}

/* ---------- Bandeau de tête (masthead) ---------- */
.masthead{position:relative;background-color:var(--navy);background-size:cover;background-position:center;
  color:#fff;min-height:36vh;display:flex;flex-direction:column;justify-content:center}
.masthead--big{min-height:60vh}
/* Titre + devise, centrés en blanc (padding haut pour passer sous la barre fixe). */
.masthead-center{text-align:center;padding:90px 24px 50px;max-width:1000px;margin:0 auto}
.masthead-center h1{color:#fff;font-size:clamp(30px,5.2vw,56px);line-height:1.1;text-shadow:0 2px 16px rgba(0,0,0,.4)}
.masthead-center .devise{font-family:var(--titre-italique);font-style:italic;color:#e7eef7;font-size:clamp(18px,2.6vw,28px);margin-top:14px;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.masthead-logo{width:135px;height:auto;margin:0 auto 20px;display:block;filter:drop-shadow(0 2px 12px rgba(0,0,0,.45))}

/* ---------- Encart de présentation, débordant sur le bas du bandeau ---------- */
.intro-card-wrap{max-width:1080px;margin:0 auto;padding:0 24px;position:relative;z-index:5}
.intro-card{background:#fff;margin-top:-72px;padding:40px 48px;border-radius:14px;border-top:4px solid var(--bleu);
  box-shadow:0 18px 50px rgba(29,37,64,.18);color:#39424f;text-align:justify}
.intro-card p{font-size:1.18rem;line-height:1.85;margin:0}
@media(max-width:640px){
  .intro-card{margin-top:-44px;padding:26px 22px;border-radius:10px}
  .masthead-logo{width:100px}
  .intro-card p{font-size:1.05rem}
}

/* ---------- Hero (accueil) : image assombrie + titre blanc ---------- */
.hero{position:relative;height:88vh;min-height:480px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero .bg{position:absolute;inset:0;background:linear-gradient(rgba(20,28,48,.5),rgba(20,28,48,.78)),url('../img/masthead.jpg') center/cover;animation:slowzoom 18s ease-out forwards}
@keyframes slowzoom{from{transform:scale(1)}to{transform:scale(1.12)}}
.hero .inner{position:relative;max-width:820px;padding:40px 24px;color:#fff}
.hero h2{color:#fff;font-size:clamp(34px,6vw,58px);font-weight:400;margin-bottom:18px;letter-spacing:1px}
.hero blockquote{font-size:clamp(18px,2.4vw,23px);font-style:italic;color:#dbe5f1;line-height:1.5}
.hero cite{display:block;margin-top:14px;font-size:15px;font-style:normal;letter-spacing:1px;color:#b9c8dc}
.scrolldown{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:var(--bleu-clair);font-size:28px;animation:bob 1.8s infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,10px)}}
.btn{display:inline-block;margin-top:26px;padding:12px 30px;border:1px solid var(--bleu-clair);color:#fff;text-transform:uppercase;letter-spacing:2px;font-size:14px;transition:.2s;cursor:pointer}
.btn:hover{background:var(--bleu-clair);color:var(--navy-dark)}
.btn.solid{background:var(--bleu);color:#fff;border-color:var(--bleu)} .btn.solid:hover{background:var(--navy)}

section{padding:80px 0}
.section-title{text-align:center;font-size:clamp(28px,4vw,38px);margin-bottom:8px}
.section-sub{text-align:center;color:var(--gris);font-style:italic;margin-bottom:46px}
.rule{width:90px;height:2px;background:var(--bleu);margin:10px auto 0}

.split{display:grid;grid-template-columns:0.9fr 1.1fr;gap:48px;align-items:center}
.split.rev{grid-template-columns:1.1fr 0.9fr}
.split .ph{height:360px;background:var(--fond-2) center/cover;border:6px solid #fff;box-shadow:0 14px 34px rgba(29,37,64,.16);background-image:linear-gradient(rgba(29,37,64,.08),rgba(29,37,64,.08)),url('../img/masthead.jpg')}
.split h2{font-size:34px;margin-bottom:14px}
.split p{margin-bottom:14px}

.piliers{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.pilier{text-align:center;padding:34px 18px;background:#fff;border:1px solid #e3e9f1;border-top:3px solid var(--bleu);transition:.25s}
.pilier:hover{transform:translateY(-6px);box-shadow:0 14px 30px rgba(29,37,64,.14)}
.pilier .ico{font-size:42px;color:var(--bleu);margin-bottom:14px}
.pilier h3{font-size:23px;margin-bottom:8px} .pilier p{font-size:16px;color:var(--gris)}


.access{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.acard{background:#fff;border:1px solid #e3e9f1;padding:30px;transition:.25s;border-left:3px solid var(--bleu)}
.acard:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(29,37,64,.12)}
.acard h3{font-size:24px;margin-bottom:8px} .acard p{color:var(--gris);font-size:16px}
.acard .more{display:inline-block;margin-top:12px;font-size:14px;text-transform:uppercase;letter-spacing:1px;color:var(--bleu)}

.news{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid #e3e9f1;overflow:hidden;display:flex;flex-direction:column;transition:.25s}
.card:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(29,37,64,.12)}
.card .thumb{height:175px;background:var(--fond-2) center/cover;border-bottom:3px solid var(--bleu)}
.card .body{padding:22px} .card .date{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--bleu);margin-bottom:6px}
.card h3{font-size:22px;margin-bottom:8px} .card p{font-size:16px;color:var(--gris)}

.band{background:linear-gradient(rgba(20,28,48,.82),rgba(20,28,48,.9)),url('../img/masthead.jpg') center/cover;color:#fff;text-align:center;padding:90px 0}
.band h2{color:#fff;font-size:clamp(28px,4vw,40px);margin-bottom:14px}
.band p{max-width:620px;margin:0 auto 6px;color:#dbe5f1}

/* ---------- Bandeau de titre des pages internes : image assombrie + titre blanc ---------- */
.page-head{position:relative;background:linear-gradient(rgba(20,28,48,.55),rgba(20,28,48,.72)),url('../img/masthead.jpg') center/cover;color:#fff;padding:70px 0 64px;text-align:center}
.page-head h1{color:#fff;font-size:clamp(30px,5vw,46px)}
.page-head .crumb{color:var(--bleu-clair);font-size:14px;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.page-head .crumb a{color:var(--bleu-clair)} .page-head .crumb a:hover{color:#fff}
.prose{max-width:820px;margin:0 auto;padding:60px 24px}
.prose h2{font-size:30px;margin:28px 0 12px} .prose h3{font-size:24px;margin:22px 0 10px}
.prose p{margin-bottom:16px;text-align:justify} .prose img{margin:18px 0;border-radius:5px;box-shadow:0 0 10px 0 rgba(0,0,0,.3)}
.prose ul,.prose ol{margin:0 0 16px 26px}
/* Apparences d'image dans le corps des articles (choisies dans l'éditeur) */
.prose .img-left,.prose figure.img-left{float:left;max-width:42%;margin:6px 26px 14px 0}
.prose .img-right,.prose figure.img-right{float:right;max-width:42%;margin:6px 0 14px 26px}
.prose .img-center,.prose figure.img-center{display:block;margin:18px auto}
.prose .img-full,.prose figure.img-full{display:block;width:100%;margin:18px 0}
.prose figure{margin:18px 0} .prose figure img{margin:0;width:100%}
.prose figcaption{font-size:14px;color:var(--gris);text-align:center;margin-top:6px;font-style:italic}
.prose::after{content:"";display:block;clear:both}
/* Lettrine : <span class="drop_cap">L</span> en début de paragraphe */
.drop_cap{float:left;font-family:var(--titre);font-size:60px;line-height:52px;margin-right:10px;color:var(--bleu-clair)}
@media(max-width:640px){
  .prose .img-left,.prose figure.img-left,.prose .img-right,.prose figure.img-right{float:none;max-width:100%;margin:18px 0}
}
/* ── Galerie miniatures ── */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;max-width:1100px;margin:30px auto;padding:0 24px}
.gallery figure{margin:0}
.gallery figcaption{font-size:13px;color:var(--gris);margin-top:4px;text-align:center;line-height:1.4}

a.gal-thumb{display:block;overflow:hidden;border-radius:2px}
a.gal-thumb img{
  height:185px;width:100%;object-fit:cover;
  border:3px solid #fff;box-shadow:0 6px 16px rgba(29,37,64,.12);
  display:block;
  transition:transform .25s ease;
}
a.gal-thumb:hover img,a.gal-thumb:focus img{transform:scale(1.04)}

/* ── Lightbox / visualiseur plein écran ── */
/* Caché par défaut via display:none (pas l'attribut hidden que les styles
   auteur écrasent). Affiché en ajoutant la classe .gal-lb--open via JS. */
.gal-lb{
  display:none;
  position:fixed;inset:0;z-index:9000;
  background:rgba(0,0,0,.93);
  flex-direction:column;
  align-items:center;justify-content:center;
}
.gal-lb.gal-lb--open{display:flex}

/* Zone centrale : image + légende */
.gal-lb-stage{
  display:flex;flex-direction:column;align-items:center;
  padding:0 70px;   /* espace pour les flèches latérales */
  max-width:100vw;
  box-sizing:border-box;
}
.gal-lb-img{
  max-width:100%;max-height:calc(100vh - 160px);
  object-fit:contain;
  border:2px solid rgba(255,255,255,.07);
  box-shadow:0 8px 48px rgba(0,0,0,.7);
}
.gal-lb-caption{
  color:rgba(255,255,255,.78);font-size:14px;line-height:1.5;
  text-align:center;margin:10px 0 0;padding:0 16px;
  max-width:680px;
}

/* Bouton fermer — coin haut droit, absolu dans le parent fixed */
.gal-lb-close{
  position:absolute;top:14px;right:14px;
  width:42px;height:42px;
  background:rgba(255,255,255,.13);border:none;border-radius:50%;
  cursor:pointer;color:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
  z-index:1;
}
.gal-lb-close svg{width:22px;height:22px}
.gal-lb-close:hover{background:rgba(255,255,255,.28)}

/* Flèches gauche / droite — absolues, centrées verticalement */
.gal-lb-prev,.gal-lb-next{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;
  background:rgba(255,255,255,.13);border:none;border-radius:50%;
  cursor:pointer;color:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
  z-index:1;
}
.gal-lb-prev{left:12px}
.gal-lb-next{right:12px}
.gal-lb-prev svg,.gal-lb-next svg{width:28px;height:28px}
.gal-lb-prev:hover,.gal-lb-next:hover{background:rgba(255,255,255,.28)}

/* Pied de page lightbox : compteur + diaporama — absolu en bas */
.gal-lb-footer{
  position:absolute;bottom:0;left:0;right:0;
  display:flex;align-items:center;justify-content:center;gap:20px;
  padding:14px 20px 20px;
  background:linear-gradient(transparent,rgba(0,0,0,.6));
}
.gal-lb-counter{color:rgba(255,255,255,.6);font-size:14px;min-width:64px;text-align:right}
.gal-lb-play{
  display:flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);
  border-radius:20px;color:#fff;cursor:pointer;
  padding:6px 18px;font-size:13px;
  transition:background .2s;
}
.gal-lb-play svg{width:15px;height:15px}
.gal-lb-play:hover{background:rgba(255,255,255,.26)}

@media(max-width:600px){
  .gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;padding:0 12px}
  a.gal-thumb img{height:130px}
  .gal-lb-stage{padding:0 48px}
  .gal-lb-prev,.gal-lb-next{width:36px;height:36px}
  .gal-lb-prev svg,.gal-lb-next svg{width:20px;height:20px}
  .gal-lb-prev{left:6px}
  .gal-lb-next{right:6px}
}
.list-items{max-width:900px;margin:0 auto;padding:50px 24px;display:grid;gap:18px}
.list-item{background:#fff;border:1px solid #e3e9f1;border-left:3px solid var(--bleu);padding:22px}
.list-item h3{font-size:24px;margin-bottom:6px}
.list-item .date{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--bleu)}
/* Grille 2 tuiles — sermons & conférences */
.formation-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
  max-width:1100px;margin:0 auto;padding:32px 24px}
@media(max-width:660px){.formation-grid{grid-template-columns:1fr}}
.fc{background:#fff;border:1px solid #e3e9f1;border-left:3px solid var(--bleu);
  padding:18px 20px;display:flex;flex-direction:column;gap:6px;
  position:relative;cursor:pointer}
.fc:hover{border-color:var(--bleu);box-shadow:0 2px 8px rgba(29,57,95,.08)}
/* En-tête : titre à gauche, date à droite sur la même ligne */
.fc-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.fc-header h3{flex:1;font-size:17px;margin:0;line-height:1.35;font-family:var(--titre)}
.fc-date{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--bleu);
  white-space:nowrap;margin-top:2px;flex-shrink:0}
.fc-header h3 a{color:var(--navy);text-decoration:none}
.fc-header h3 a:hover{color:var(--bleu)}
/* Lien étiré : rend toute la tuile cliquable */
.fc-header h3 a::after{content:'';position:absolute;inset:0}
.fc-author{display:inline-block;font-size:13px;background:rgba(29,57,95,.1);color:var(--navy);
  padding:3px 9px;border-radius:3px;width:fit-content;position:relative;z-index:1}

footer{background:var(--navy-dark);color:#aebccf;font-size:15px;padding:54px 0 28px}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
footer h4{color:var(--bleu-clair);font-size:20px;margin-bottom:14px;font-weight:400;font-family:var(--titre)}
footer a{color:#aebccf} footer a:hover{color:#fff}
footer ul{list-style:none} footer li{padding:4px 0}
.copyright{text-align:center;border-top:1px solid rgba(147,170,196,.22);margin-top:34px;padding-top:18px;font-size:13px;color:#8294ab}

.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}.hero .bg{animation:none}}

@media(max-width:980px){
  .piliers{grid-template-columns:1fr 1fr}.news,.access{grid-template-columns:1fr}
  .pays{grid-template-columns:1fr 1fr}.split,.split.rev{grid-template-columns:1fr}
  footer .cols{grid-template-columns:1fr 1fr}
}
/* ---------- Mobile : hamburger + menu glissant depuis la droite ---------- */
@media(max-width:880px){
  .nav-burger{display:flex;margin-left:auto}
  .mainnav{background:var(--navy)}  /* toujours opaque sur mobile (lisibilité) */
  .nav-collapse{
    position:fixed;top:0;right:0;height:100vh;width:80%;max-width:330px;
    flex-direction:column;align-items:flex-start;
    background:var(--navy-dark);padding:78px 22px 22px;
    transform:translateX(100%);transition:transform .3s ease;box-shadow:-6px 0 24px rgba(0,0,0,.4);
    overflow-y:auto;
  }
  .nav-collapse.open{transform:translateX(0)}
  .nav-links{flex-direction:column;align-items:flex-start;width:100%;flex:none}
  .nav-links a{padding:14px 4px;font-size:16px;width:100%}
  .nav-langs{border-top:1px solid rgba(255,255,255,.2);margin-top:10px;padding-top:12px;width:100%}
  .lang-current{padding-left:4px}
  /* Dans le tiroir mobile, le menu de langues s'affiche en dessous (pas en flottant). */
  .lang-menu{position:static;display:none;background:transparent;box-shadow:none;min-width:0;margin:4px 0 0;padding:0}
  .nav-langs.open .lang-menu{display:block}
  .lang-menu a{padding:10px 4px}
  body.nav-open .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.nav-open .nav-burger span:nth-child(2){opacity:0}
  body.nav-open .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  /* --- Sous-menus sur mobile (inline dans le tiroir) --- */
  .has-sub>a::after{display:none} /* flèche CSS remplacée par le bouton */
  .sub-toggle{
    display:inline-flex;align-items:center;justify-content:center;
    background:none;border:none;color:rgba(255,255,255,.55);cursor:pointer;
    font-size:16px;padding:4px 10px;margin-left:auto;transition:transform .2s;vertical-align:middle
  }
  .has-sub{display:flex;flex-wrap:wrap;align-items:center}
  .has-sub>a{flex:1}
  .sub-menu{
    position:static;transform:none;box-shadow:none;
    border-top:none;border-radius:0;
    border-left:2px solid var(--bleu);
    padding:4px 0;margin:4px 0 8px 18px;
    background:rgba(0,0,0,.18);width:100%;order:3
  }
  .sub-menu::before{display:none}
  .has-sub>.sub-menu{display:none}
  .has-sub.open>.sub-menu{display:block}
  .has-sub.open>.sub-toggle{transform:rotate(180deg);color:var(--bleu-clair)}
  .sub-menu a{padding:10px 14px;font-size:14px;border-bottom-color:rgba(255,255,255,.06)}
  .sub-menu a:hover{padding-left:20px}
}
@media(max-width:560px){.piliers,.pays{grid-template-columns:1fr}footer .cols{grid-template-columns:1fr}}

/* ============================================================
   SECTION ACTUALITÉS — vue en tuiles chronologiques
   ============================================================ */

/* Barre de filtres par catégorie */
.news-filter{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;padding:36px 0 24px}
.news-filter a{
  display:inline-block;padding:8px 22px;border-radius:20px;font-size:13px;
  letter-spacing:.7px;text-transform:uppercase;font-weight:500;transition:.18s;
  border:1px solid var(--bleu-clair);color:var(--bleu);background:#fff;
}
.news-filter a:hover{background:var(--bleu);color:#fff;border-color:var(--bleu)}
.news-filter a.active{background:var(--navy);color:#fff;border-color:var(--navy)}

/* Grille de tuiles */
.news-tiles{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:1180px;margin:0 auto;padding:0 24px 60px;
}

/* Tuile individuelle */
.news-tile{
  position:relative;border-radius:6px;overflow:hidden;cursor:pointer;
  background:var(--navy);aspect-ratio:4/3;
  display:flex;flex-direction:column;justify-content:flex-end;
  box-shadow:0 4px 16px rgba(29,37,64,.12);
  transition:transform .22s,box-shadow .22s;
}
.news-tile:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(29,37,64,.22)}

/* Image de couverture en fond */
.news-tile .tile-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform .38s ease;
}
.news-tile:hover .tile-bg{transform:scale(1.05)}

/* Dégradé sombre sur la moitié basse (lisibilité du titre) */
.news-tile::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(20,28,48,.05) 25%,rgba(20,28,48,.85) 100%);
}
/* Tuile sans image : fond bleu marine direct, pas de dégradé */
.news-tile.no-cover::after{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-dark) 100%);
  opacity:.92;
}

/* Badge de catégorie (lien cliquable pour filtrer) */
.news-tile .tile-tag{
  position:absolute;top:12px;left:12px;z-index:3;
  background:var(--bleu);color:#fff;
  font-size:11px;letter-spacing:1px;text-transform:uppercase;font-weight:600;
  padding:4px 10px;border-radius:3px;text-decoration:none;
  transition:background .15s;
}
.news-tile .tile-tag:hover{background:var(--navy-dark)}

/* Texte de la tuile en bas */
.news-tile .tile-body{position:relative;z-index:2;padding:14px 18px 18px}
.news-tile .tile-date{font-size:12px;color:rgba(255,255,255,.55);letter-spacing:.8px;text-transform:uppercase;margin-bottom:6px}
.news-tile .tile-title{font-family:var(--titre);font-size:clamp(15px,1.5vw,19px);color:#fff;line-height:1.25}
.news-tile .tile-author{font-size:12px;color:rgba(255,255,255,.55);margin-top:5px;font-style:italic}
.news-tile .tile-excerpt{font-size:13px;color:rgba(255,255,255,.6);margin-top:6px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 24px 50px;flex-wrap:wrap}
.pagination a,.pagination span{display:inline-flex;align-items:center;padding:8px 18px;border-radius:4px;font-size:15px;font-weight:500;transition:.18s}
.pagination a{border:1px solid var(--bleu-clair);color:var(--bleu)}
.pagination a:hover{background:var(--bleu);color:#fff;border-color:var(--bleu)}
.pagination .current{background:var(--navy);color:#fff;border:1px solid var(--navy)}
.pagination .disabled{color:var(--gris);border:1px solid #e3e9f1;cursor:default}

/* Responsive tuiles */
@media(max-width:980px){.news-tiles{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){
  .news-tiles{grid-template-columns:1fr;padding:0 16px 40px}
  .news-tile{aspect-ratio:16/9}
  .news-tile .tile-title{font-size:16px}
}

/* Bouton retour en haut à gauche d'une page album (racine ou sous-album) */
.album-back{max-width:1180px;margin:0 auto;padding:24px 24px 0}
.album-back-btn{display:inline-flex;align-items:center;gap:5px;font-size:14px;letter-spacing:.3px;color:var(--bleu)}
.album-back-btn:hover{color:var(--navy);text-decoration:underline}

/* Filtre par année (sous la barre de filtres principale, vue Photographies) */
/* Filtre par année : menu déroulant stylé (page Photographies) */
.year-filter{display:flex;align-items:center;justify-content:center;gap:10px;padding:0 0 10px}
.year-filter-label{font-size:13px;letter-spacing:.7px;text-transform:uppercase;
  font-weight:500;color:var(--gris);font-family:var(--sans)}
.year-select-wrap{position:relative;display:inline-block}
.year-select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  font-family:var(--sans);font-size:13px;letter-spacing:.5px;font-weight:500;
  color:var(--bleu);background:#fff;border:1px solid var(--bleu-clair);
  border-radius:20px;padding:9px 40px 9px 20px;cursor:pointer;outline:none;
  transition:border-color .18s,box-shadow .18s,background .18s,color .18s;min-width:150px}
.year-select:hover{border-color:var(--bleu)}
.year-select:focus{border-color:var(--bleu);box-shadow:0 0 0 3px rgba(79,111,156,.2)}
/* Chevron dessiné en CSS (aucune image externe) */
.year-select-wrap::after{
  content:"";position:absolute;right:16px;top:50%;width:7px;height:7px;
  border-right:2px solid var(--bleu);border-bottom:2px solid var(--bleu);
  transform:translateY(-70%) rotate(45deg);pointer-events:none}

/* Grille de sous-albums dans la page d'un album (réutilise les classes .news-tiles) */
.sub-albums{padding:30px 0 0}

/* ============================================================
   Lecteur audio soigné (page sermon/article avec fichier audio)
   ============================================================ */
.audio-player{display:flex;align-items:center;gap:16px;background:var(--navy);color:#fff;
  border-radius:10px;padding:16px 20px;margin:30px 0;max-width:620px}
.ap-btn{flex-shrink:0;width:44px;height:44px;border-radius:50%;background:var(--bleu);
  border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s;color:#fff}
.ap-btn:hover{background:var(--bleu-clair)}
.ap-btn svg{width:18px;height:18px;fill:#fff;display:block}
.ap-track{flex:1;min-width:0}
.ap-title{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;margin-bottom:3px;font-family:var(--sans)}
.ap-author{font-size:11px;color:rgba(255,255,255,.55);font-style:italic;margin-bottom:7px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ap-controls{display:flex;align-items:center;gap:10px}
.ap-progress{flex:1;height:5px;background:rgba(255,255,255,.2);border-radius:3px;
  cursor:pointer;position:relative}
.ap-fill{height:100%;background:var(--bleu-clair);border-radius:3px;width:0;
  pointer-events:none;transition:width .05s linear}
.ap-time{font-size:12px;color:rgba(255,255,255,.65);white-space:nowrap;
  font-variant-numeric:tabular-nums;min-width:80px;text-align:right}
.ap-speed{display:flex;gap:5px;margin-top:7px}
.ap-spd-btn{
  background:rgba(255,255,255,.1);border:none;color:rgba(255,255,255,.65);
  font-size:11px;font-family:var(--sans);padding:3px 8px;border-radius:3px;
  cursor:pointer;transition:.15s;letter-spacing:.2px;line-height:1.4;
}
.ap-spd-btn:hover{background:rgba(255,255,255,.22);color:#fff}
.ap-spd-btn.active{background:var(--bleu-clair);color:#fff;font-weight:600}

/* ============================================================
   Barre de recherche dans la section Actualités
   ============================================================ */
.news-search{display:flex;align-items:center;gap:6px;max-width:420px;margin:14px auto 28px;
  padding:0 24px}
.news-search input[type=search]{
  flex:1;border:1px solid #d0daea;border-radius:6px;padding:8px 12px;font-size:14px;
  font-family:var(--sans);color:var(--encre);background:#fff;outline:none;
  transition:border .15s}
.news-search input[type=search]:focus{border-color:var(--bleu)}
.search-clear{color:var(--gris);font-size:20px;line-height:1;cursor:pointer;
  text-decoration:none;padding:0 4px}
.search-clear:hover{color:var(--navy)}
@media(max-width:600px){.news-search{max-width:100%;margin-top:10px}}

/* ============================================================
   Formulaire newsletter
   ============================================================ */
.nl-form{margin-top:.5rem}

/* Groupe label + champ (label au-dessus) */
.nl-group{display:flex;flex-direction:column;gap:5px;margin-bottom:1.1rem}
.nl-group label{font-size:14px;font-weight:500;color:var(--navy)}
.nl-group input,.nl-group select{
  width:100%;padding:10px 13px;font-size:15px;font-family:var(--sans);
  color:var(--encre);border:1px solid #c8d4e2;border-radius:6px;
  background:#fff;outline:none;transition:border-color .15s;box-sizing:border-box}
.nl-group input:focus,.nl-group select:focus{border-color:var(--bleu);box-shadow:0 0 0 3px rgba(30,80,160,.08)}

/* Variante étroite pour le titre de politesse */
.nl-group--narrow{max-width:160px}

/* Deux colonnes côte à côte (prénom / nom) */
.nl-row--2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* Ligne de consentement avec case à cocher */
.nl-row--check{display:flex;align-items:flex-start;gap:10px;margin-bottom:1.4rem}
.nl-row--check input[type=checkbox]{flex-shrink:0;width:17px;height:17px;
  margin-top:2px;cursor:pointer;accent-color:var(--bleu)}
.nl-row--check label{font-size:14px;line-height:1.55;color:var(--encre);cursor:pointer}
.nl-row--check label a{color:var(--bleu);text-decoration:underline}
.nl-row--check label a:hover{color:var(--navy)}

/* Astérisque obligatoire */
.req{color:var(--bordeaux);margin-left:2px}

/* Messages de confirmation / erreur */
.nl-notice{padding:13px 17px;border-radius:7px;margin-bottom:1.5rem;font-size:15px;line-height:1.5}
.nl-notice--ok{background:#edf7f1;color:#1a6836;border:1px solid #b0d9c0}
.nl-notice--err{background:#fdf0f0;color:#8b1a1a;border:1px solid #f0b4b4}

@media(max-width:540px){
  .nl-row--2{grid-template-columns:1fr}
  .nl-group--narrow{max-width:100%}
}
@media(max-width:600px){.news-search{max-width:100%;margin-top:10px}}

/* ============================================================
   Page Histoire — frise chronologique
   ============================================================ */
.history-wrap{max-width:900px;margin:0 auto;padding:0 1.5rem 4rem}
.history-intro{font-size:17px;line-height:1.75;color:var(--encre);margin:2rem auto 3rem;
  max-width:680px;text-align:center}

/* Conteneur de la frise — ligne verticale centrale via ::before */
.timeline{position:relative;padding:1rem 0}
.timeline::before{
  content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;
  background:linear-gradient(to bottom, transparent 0%, var(--or) 5%, var(--or) 95%, transparent 100%);
  transform:translateX(-50%)}

/* Rangée : 3 colonnes — gauche | point central | droite */
.tl-row{
  display:grid;grid-template-columns:1fr 48px 1fr;
  align-items:center;margin-bottom:3rem;gap:0}

/* Colonne centrale avec le point doré */
.tl-pin{display:flex;justify-content:center;align-items:center;z-index:1}
.tl-dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--or);border:3px solid #f4f7fb;
  box-shadow:0 0 0 2px var(--or);flex-shrink:0}

/* Bulle de contenu */
.tl-bubble{
  background:#fff;border:1px solid #dce5f0;border-radius:9px;
  padding:1.15rem 1.5rem;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.tl-heading{
  display:block;font-family:var(--titre);font-size:1.05rem;
  color:var(--navy);font-weight:400;margin-bottom:.45rem}
.tl-bubble p{margin:0;font-size:14.5px;line-height:1.65;color:var(--encre)}

/* Année affichée de l'autre côté du trait */
.tl-date{
  font-family:var(--titre);font-size:1.75rem;color:var(--navy);
  font-weight:400;opacity:.7;line-height:1}

/* Rangée NORMALE (index pair) : bulle à gauche, année à droite */
.tl-row:not(.tl-right) .tl-bubble{text-align:right;padding-right:1.8rem}
.tl-row:not(.tl-right) .tl-date{padding-left:1.8rem;text-align:left}

/* Rangée INVERSÉE (index impair) : année à gauche, bulle à droite */
.tl-row.tl-right .tl-date{text-align:right;padding-right:1.8rem}
.tl-row.tl-right .tl-bubble{padding-left:1.8rem}

/* Année dans la bulle — cachée sur desktop, visible sur mobile */
.tl-year-mobile{display:none}

/* ── Mobile : colonne unique, trait sur la gauche ─────────────── */
@media(max-width:620px){
  .timeline::before{left:15px;transform:none}
  .tl-row{
    grid-template-columns:30px 1fr;
    gap:0 12px;margin-bottom:2rem}
  .tl-row .tl-pin{grid-column:1;grid-row:1;align-self:start;padding-top:4px}
  .tl-row .tl-bubble{grid-column:2;grid-row:1;text-align:left !important;
    padding:1rem 1.2rem !important}
  .tl-row .tl-date,.tl-row.tl-right .tl-date{display:none}
  .tl-row.tl-right .tl-pin{grid-column:1;grid-row:1}
  .tl-row.tl-right .tl-bubble{grid-column:2;grid-row:1}
  .tl-year-mobile{
    display:block;font-family:var(--titre);font-size:1.1rem;
    color:var(--navy);opacity:.65;margin-bottom:.35rem;font-weight:400}
}

/* ---------- FAQ (accordéon <details>/<summary>) ---------- */
.faq-wrap{max-width:820px;margin:0 auto;padding:0 1.5rem 4rem}
.faq-intro{font-size:17px;line-height:1.75;color:var(--encre);margin:2rem auto 2.5rem}
.faq-list{display:flex;flex-direction:column;gap:.5rem}
.faq-item{border:1px solid #d6dce8;border-radius:10px;background:#fff;overflow:hidden;
  box-shadow:0 2px 8px rgba(29,37,64,.06)}
.faq-item[open]{border-color:var(--bleu)}
.faq-q{cursor:pointer;padding:1.1rem 1.4rem;font-family:var(--titre);font-size:1.06rem;
  color:var(--navy);list-style:none;display:flex;align-items:center;gap:.7rem;
  user-select:none;line-height:1.4}
.faq-q::-webkit-details-marker{display:none}
.faq-q::before{content:"";display:block;flex-shrink:0;width:20px;height:20px;
  border-radius:50%;background:var(--bleu);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-size:14px;background-repeat:no-repeat;background-position:center;
  transition:transform .2s}
.faq-item[open] .faq-q::before{transform:rotate(180deg)}
.faq-a{padding:.2rem 1.4rem 1.2rem 3.5rem;color:var(--encre);font-size:1rem;line-height:1.8}
@media(max-width:540px){
  .faq-q{padding:.9rem 1rem;font-size:.97rem}
  .faq-a{padding:.1rem 1rem 1rem 1rem}
}

/* ---------- Bloc renvoi FAQ sur la page d'accueil ---------- */
.faq-promo{background:var(--creme-2);padding:4rem 1.5rem}
.faq-promo .wrap{max-width:760px;margin:0 auto;text-align:center}
.faq-promo h2{font-family:var(--titre);font-size:clamp(22px,3.2vw,32px);color:var(--navy);margin-bottom:.8rem}
.faq-promo p{color:var(--encre);font-size:1.08rem;line-height:1.7;margin-bottom:1.8rem}

/* ============================================================
   WIDGET « PENSÉES ET TEXTES DU JOUR »
   ============================================================ */
/* Fond neutre entre les sections, avec espacement vertical */
.daily-widget-wrap{background:var(--fond);padding:2rem 1.5rem}
/* Cadre blanc centré — ne prend pas toute la largeur */
.daily-widget-wrap .wrap{
  max-width:1100px;margin:0 auto;
  background:#fff;
  border:1px solid var(--bleu-clair);
  border-radius:10px;
  box-shadow:0 2px 16px rgba(43,53,80,.08);
  padding:0 2rem;
  overflow:hidden;
}

/* Bouton accordéon */
.daily-toggle{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:14px 0;border:none;background:transparent;cursor:pointer;
  font-family:var(--titre);font-size:clamp(14px,1.6vw,17px);font-weight:600;
  color:var(--navy);letter-spacing:.4px;gap:10px;
}
.daily-toggle:hover .daily-toggle-label{color:var(--bleu)}
.daily-toggle-chevron{
  width:22px;height:22px;flex-shrink:0;stroke:var(--bleu);stroke-width:2.2;
  fill:none;stroke-linecap:round;stroke-linejoin:round;
  transition:transform .3s ease;
}
.daily-toggle[aria-expanded="true"] .daily-toggle-chevron{transform:rotate(180deg)}

/* Panneau coulissant */
.daily-panel{
  max-height:0;overflow:hidden;
  transition:max-height .45s ease, padding .35s ease;
}
.daily-panel.daily-open{
  max-height:900px;
  padding-bottom:28px;
}

/* Spinner de chargement */
.daily-loading{
  padding:18px 0;font-size:13px;color:var(--gris);font-style:italic;
  text-align:center;
}

/* ============================================================
   PAGE SPIRITUALITÉ DU CHARISME (/institute/spirituality)
   ============================================================ */

.sp-wrap{
  max-width:820px;
  margin:0 auto;
  padding:clamp(32px,5vw,60px) clamp(16px,4vw,32px);
}

/* Texte d'introduction */
.sp-intro{
  font-size:clamp(15px,1.7vw,18px);
  line-height:1.75;
  color:var(--navy);
  margin-bottom:clamp(36px,5vw,56px);
  border-left:3px solid var(--or);
  padding-left:20px;
}

/* Blocs thématiques */
.sp-sections{
  display:flex;
  flex-direction:column;
  gap:clamp(28px,4vw,44px);
}

.sp-block{
  padding:clamp(20px,3vw,32px);
  background:var(--fond-2,#f5f4f0);
  border-radius:4px;
  border-top:3px solid var(--bleu);
}

.sp-heading{
  font-family:var(--titre);
  font-size:clamp(16px,1.9vw,21px);
  font-weight:700;
  color:var(--navy);
  margin:0 0 14px;
  letter-spacing:.3px;
}

.sp-body{
  font-size:clamp(14px,1.55vw,16px);
  line-height:1.8;
  color:var(--gris-fonce,#333);
}

.sp-body strong{ color:var(--navy); }
.sp-body em{ font-style:italic; color:var(--navy); }

@media(max-width:600px){
  .sp-block{ padding:18px 16px; }
}

/* Grille 3 colonnes */
.daily-cols{
  display:grid;
  grid-template-columns:1fr 1fr 0.6fr;
  gap:28px 36px;
  padding-top:12px;
  border-top:1px solid var(--fond-2);
}

/* Colonne */
.daily-col{
  display:flex;flex-direction:column;gap:10px;
}
.daily-col-center{
  border-left:1px solid var(--fond-2);
  border-right:1px solid var(--fond-2);
  padding:0 28px;
}

/* Titres des colonnes */
.daily-col-title{
  font-family:var(--titre);font-size:13px;font-weight:700;
  letter-spacing:.8px;text-transform:uppercase;color:var(--bleu);
  margin:0 0 4px;
  display:flex;align-items:center;gap:7px;
}
.daily-benoit-title{color:var(--navy)}
.daily-saint-date{font-family:var(--corps);font-size:10px;font-weight:400;letter-spacing:0;text-transform:none;color:var(--gris);margin-left:4px}
.daily-icon{width:16px;height:16px;fill:var(--navy);flex-shrink:0}

/* Date / sous-titre Règle */
.daily-benoit-date{
  font-size:12px;font-style:italic;color:var(--gris);margin:0 0 4px;
}

/* Corps du texte — même police et justifié pour les 3 colonnes */
.daily-col-body{
  font-size:14px;line-height:1.8;color:var(--encre);flex:1;
  font-family:var(--corps);
  text-align:justify;
}
.daily-col-body p{margin:.6em 0 0}
.daily-col-body p:first-child{margin-top:0}

/* Image du saint : flottante en haut à droite avec habillage de texte */
.daily-saint-img{
  float:right;
  width:50%;
  height:auto;
  object-fit:cover;
  margin:0 0 8px 12px;
  border-radius:4px;
  box-shadow:0 1px 6px rgba(43,53,80,.18);
}

/* Colonne centre : légèrement plus grande, même police */
.daily-col-center .daily-col-body{
  font-size:14.5px;
  color:var(--navy);
}

/* Source / attribution */
.daily-col-source{
  font-size:12px;color:var(--gris);font-style:italic;
  margin:0;padding-top:6px;border-top:1px solid var(--fond-2);
}

/* Responsive : 2 col sur tablette, 1 col sur mobile */
@media(max-width:860px){
  .daily-cols{grid-template-columns:1fr 1fr}
  .daily-col-center{border:none;padding:0;border-top:1px solid var(--fond-2);border-bottom:1px solid var(--fond-2);grid-column:1/-1;padding:14px 0}
}
@media(max-width:560px){
  .daily-cols{grid-template-columns:1fr}
  .daily-col-center{border:none;padding:0}
  .daily-panel.daily-open{max-height:2400px}
}

