/* =========================================================
   ÉGLISE DE DIEU FLEUVES D'EAU VIVE (EDFEV) — FEUILLE DE STYLE
   Palette : Navy #1B2A4A / Or #B8860B / Crème #F7F4EC
   Polices : Cinzel (titres) + EB Garamond (texte courant)
   ========================================================= */

:root{
  --navy: #1B2A4A;
  --navy-light: #2C4066;
  --gold: #B8860B;
  --gold-light: #D9A94B;
  --cream: #F7F4EC;
  --white: #FFFFFF;
  --sky: #E8F1F7;
  --ink: #2A2A2A;
  --green: #2F6F4E;
  --red: #A3372F;
  --shadow: 0 6px 24px rgba(27,42,74,0.10);
  --radius: 6px;
  --maxw: 1140px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"EB Garamond", Georgia, serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-size:18px;
}
h1,h2,h3,h4{
  font-family:"Cinzel", "Times New Roman", serif;
  color:var(--navy);
  letter-spacing:0.02em;
  line-height:1.25;
  margin:0 0 .6em;
}
h1{font-size:2.4rem;}
h2{font-size:1.75rem;}
h3{font-size:1.3rem; color:var(--gold);}
p{margin:0 0 1em;}
a{color:var(--navy);}
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:3px solid var(--gold-light); outline-offset:2px;
}
img{max-width:100%; display:block;}
.container{max-width:var(--maxw); margin:0 auto; padding:0 24px;}

/* --- Diviseur ornemental --- */
.divider{
  text-align:center; color:var(--gold);
  font-size:1.3rem; letter-spacing:.5em;
  margin:2.2em 0;
}
.divider::before{content:"✥ ❧ ✥";}

/* --- En-tête / bandeau --- */
.top-strip{
  background:var(--navy); color:var(--sky);
  font-size:.82rem; padding:6px 0; text-align:center;
}
.top-strip a{color:var(--gold-light); text-decoration:none;}
.top-strip-inner{display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; text-align:left;}
@media(max-width:600px){.top-strip-inner{justify-content:center; text-align:center;}}

/* --- Lecteur radio compact (bandeau du haut) --- */
.radio-player-compact{gap:8px;}
.radio-player-compact .radio-play{width:26px; height:26px; font-size:.7rem;}
.radio-player-compact .radio-live{font-size:.62rem; padding:2px 9px;}
.radio-player-compact .radio-name{display:none;}
.radio-player-compact .radio-mute{font-size:.95rem;}

header.site-header{
  background:var(--white);
  border-bottom:3px solid var(--gold);
  position:sticky; top:0; z-index:50;
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  max-width:var(--maxw); margin:0 auto; padding:14px 24px;
}
.brand{display:flex; align-items:center; gap:14px; text-decoration:none;}
.brand-crest{width:52px; height:52px; flex-shrink:0; border-radius:50%; object-fit:cover;}
.brand-text{line-height:1.15;}
.brand-text .name{
  font-family:"Cinzel", serif; color:var(--navy); font-size:1.15rem; display:block;
}
.brand-text .tagline{color:var(--gold); font-size:.78rem; font-style:italic;}

/* --- Navigation --- */
nav.main-nav{position:relative;}
.nav-toggle{display:none;}
.nav-list{
  list-style:none; display:flex; gap:2px; margin:0; padding:0;
  font-family:"Cinzel", serif; font-size:.78rem; letter-spacing:.04em;
}
.nav-list > li{position:relative;}
.nav-list > li > a, .nav-list > li > .nav-drop-btn{
  display:block; padding:14px 14px; color:var(--navy); text-decoration:none;
  background:none; border:none; font:inherit; cursor:pointer; text-transform:uppercase;
}
.nav-list > li > a:hover, .nav-list > li > .nav-drop-btn:hover,
.nav-list > li.active > a{ color:var(--gold); }
.dropdown{
  display:none; position:absolute; left:0; top:100%;
  background:var(--white); box-shadow:var(--shadow); min-width:250px;
  border-top:3px solid var(--gold); padding:8px 0; z-index:60;
}
.nav-list > li:hover .dropdown, .nav-list > li:focus-within .dropdown, .nav-list > li.open .dropdown{display:block;}
.dropdown a{
  display:block; padding:10px 18px; color:var(--navy); text-decoration:none;
  font-family:"EB Garamond", serif; font-size:1rem; text-transform:none; letter-spacing:0;
}
.dropdown a:hover{background:var(--sky); color:var(--navy);}

@media(max-width:920px){
  .nav-toggle{
    display:block; background:none; border:2px solid var(--navy); border-radius:4px;
    font-size:1.4rem; padding:4px 10px; color:var(--navy); cursor:pointer;
  }
  .nav-list{
    display:none; position:absolute; top:100%; right:0; left:0;
    flex-direction:column; background:var(--white); box-shadow:var(--shadow);
    padding:10px 0; border-top:3px solid var(--gold);
  }
  .nav-list.show{display:flex;}
  .dropdown{position:static; box-shadow:none; border-top:1px solid var(--sky); display:none;}
  .nav-list > li.open .dropdown{display:block;}
}

/* --- Hero --- */
.hero{
  background:linear-gradient(180deg, var(--sky) 0%, var(--cream) 100%);
  padding:70px 0 90px; text-align:center; position:relative; overflow:hidden;
}
.hero h1{font-size:2.6rem; max-width:820px; margin:0 auto .3em;}
.hero .subtitle{color:var(--navy-light); font-size:1.2rem; font-style:italic; max-width:640px; margin:0 auto 1.4em;}
.hero > .container{position:relative; z-index:2;}
.hero-waves{position:absolute; bottom:-1px; left:0; width:100%; line-height:0; z-index:1; pointer-events:none;}
@media(max-width:600px){
  .hero{padding:50px 0 100px;}
  .hero h1{font-size:1.9rem;}
  .hero .subtitle{font-size:1.05rem;}
  .btn-row{gap:12px;}
  .btn{width:100%; max-width:320px;}
}

.page-hero{
  background:var(--navy); color:var(--sky); padding:56px 0 44px; text-align:center;
}
.page-hero h1{color:var(--white);}
.page-hero .eyebrow{
  color:var(--gold-light); text-transform:uppercase; letter-spacing:.15em; font-size:.85rem;
  font-family:"Cinzel", serif;
}

/* --- Boutons --- */
.btn{
  display:inline-block; padding:13px 30px; border-radius:var(--radius);
  text-decoration:none; font-family:"Cinzel", serif; font-size:.85rem;
  letter-spacing:.05em; text-transform:uppercase; border:2px solid transparent; cursor:pointer;
}
.btn-gold{background:var(--gold); color:var(--white);}
.btn-gold:hover{background:var(--gold-light);}
.btn-outline{background:transparent; border-color:var(--white); color:var(--white);}
.btn-outline:hover{background:var(--white); color:var(--navy);}
.btn-navy{background:var(--navy); color:var(--white);}
.btn-navy:hover{background:var(--navy-light);}
.btn-row{display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:1.4em;}

/* --- Sections / cartes --- */
section{padding:60px 0;}
section.alt{background:var(--white);}
.section-title{text-align:center; margin-bottom:.2em;}
.section-lead{text-align:center; max-width:680px; margin:0 auto 2.4em; color:var(--navy-light);}
.grid{display:grid; gap:26px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
@media(max-width:800px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}}

.card{
  background:var(--white); border:1px solid #E7DFC9; border-radius:var(--radius);
  padding:26px; box-shadow:var(--shadow);
}
.card.on-cream{background:var(--cream);}
.card h3{margin-top:0;}

/* --- Encadré Écriture (verset) --- */
.scripture{
  background:var(--white); border-left:5px solid var(--gold);
  padding:20px 26px; margin:1.6em 0; box-shadow:var(--shadow); border-radius:0 var(--radius) var(--radius) 0;
}
.scripture cite{display:block; margin-top:.5em; color:var(--gold); font-style:normal; font-size:.9rem; letter-spacing:.03em;}
.scripture.warn{border-left-color:var(--red); background:#FBF1EF;}
.scripture.victory{border-left-color:var(--green); background:#F0F7F2;}

/* --- Tableaux --- */
table{width:100%; border-collapse:collapse; background:var(--white); box-shadow:var(--shadow);}
th,td{padding:12px 16px; text-align:left; border-bottom:1px solid #EEE7D4;}
th{background:var(--navy); color:var(--white); font-family:"Cinzel",serif; font-size:.82rem; text-transform:uppercase; letter-spacing:.04em;}
tr:nth-child(even) td{background:#FBF9F2;}

/* --- Barre de progression (financement) --- */
.progress-wrap{background:var(--white); border-radius:20px; padding:5px; box-shadow:var(--shadow);}
.progress-bar{height:26px; border-radius:16px; background:linear-gradient(90deg, var(--gold) 0%, var(--gold-light) 100%); display:flex; align-items:center; justify-content:flex-end; padding-right:10px; color:var(--white); font-size:.78rem; font-weight:bold;}
.progress-track{background:var(--sky); border-radius:16px; overflow:hidden;}

/* --- Barres du tableau de bord --- */
.bar-chart{display:flex; align-items:flex-end; gap:14px; height:220px; padding:20px 0;}
.bar-chart .bar-col{flex:1; display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%;}
.bar-chart .bar{width:60%; background:var(--navy); border-radius:4px 4px 0 0; position:relative;}
.bar-chart .bar.goal{background:repeating-linear-gradient(45deg, var(--gold), var(--gold) 6px, var(--gold-light) 6px, var(--gold-light) 12px);}
.bar-chart .bar-label{margin-top:8px; font-size:.8rem; text-align:center; color:var(--navy-light);}
.bar-chart .bar-value{position:absolute; top:-22px; left:0; right:0; text-align:center; font-size:.78rem; color:var(--navy); font-weight:bold;}

.stat{text-align:center;}
.stat .num{font-family:"Cinzel", serif; font-size:2.1rem; color:var(--gold); display:block;}
.stat .label{color:var(--navy-light); font-size:.9rem; text-transform:uppercase; letter-spacing:.05em;}

/* --- Formulaires --- */
form.card label{display:block; font-family:"Cinzel", serif; font-size:.8rem; text-transform:uppercase; letter-spacing:.04em; color:var(--navy); margin:1em 0 .4em;}
form.card input, form.card select, form.card textarea{
  width:100%; padding:11px 13px; border:1px solid #CBBF9A; border-radius:4px;
  font-family:"EB Garamond", serif; font-size:1rem; background:var(--cream);
}
form.card textarea{min-height:120px; resize:vertical;}
form.card .hint{font-size:.85rem; color:#6b6b6b; margin-top:-.3em;}
form.card fieldset{border:1px solid #E7DFC9; border-radius:4px; margin:1em 0; padding:10px 16px;}
form.card legend{font-family:"Cinzel",serif; color:var(--navy); font-size:.8rem; text-transform:uppercase; padding:0 8px;}

/* --- Liste horaires --- */
.schedule-list{list-style:none; margin:0; padding:0;}
.schedule-list li{
  display:flex; justify-content:space-between; gap:16px; padding:14px 0; border-bottom:1px dashed #CBBF9A;
}
.schedule-list li:last-child{border-bottom:none;}
.schedule-list .when{font-family:"Cinzel",serif; color:var(--navy); font-size:.9rem;}
.schedule-list .what{color:var(--navy-light); text-align:right;}

/* --- Timeline --- */
.timeline{border-left:3px solid var(--gold); margin-left:14px; padding-left:26px;}
.timeline .item{position:relative; margin-bottom:28px;}
.timeline .item::before{
  content:""; position:absolute; left:-33px; top:4px; width:14px; height:14px;
  background:var(--gold); border-radius:50%; border:3px solid var(--white); box-shadow:0 0 0 2px var(--gold);
}
.timeline .item .date{font-family:"Cinzel",serif; color:var(--gold); font-size:.85rem;}

/* --- Badges --- */
.badge{display:inline-block; padding:3px 12px; border-radius:20px; font-size:.75rem; font-family:"Cinzel",serif; letter-spacing:.03em;}
.badge.ok{background:#E4F1E8; color:var(--green);}
.badge.pending{background:#FCEFD8; color:#8a6416;}

/* --- Lecteur radio personnalisé --- */
.radio-player{display:flex; align-items:center; gap:12px; flex-wrap:wrap;}
.radio-play{
  width:40px; height:40px; border-radius:50%; background:var(--gold); color:#fff;
  border:none; display:flex; align-items:center; justify-content:center; cursor:pointer;
  font-size:1rem; flex-shrink:0; box-shadow:0 2px 8px rgba(0,0,0,.25); transition:background .15s;
}
.radio-play:hover{background:var(--gold-light);}
.radio-live{
  display:inline-flex; align-items:center; gap:6px; font-family:"Cinzel",serif; font-size:.68rem;
  letter-spacing:.06em; color:#fff; background:var(--red); padding:4px 12px; border-radius:20px; white-space:nowrap;
}
.radio-live .dot{width:7px; height:7px; border-radius:50%; background:#fff; animation:radioPulse 1.4s infinite;}
@keyframes radioPulse{0%,100%{opacity:1;} 50%{opacity:.25;}}
.radio-name{font-family:"Cinzel",serif; font-size:.85rem; letter-spacing:.02em; white-space:nowrap;}
.radio-mute{background:none; border:none; font-size:1.15rem; cursor:pointer; color:inherit; flex-shrink:0;}
.radio-player audio{display:none;}

/* --- Mini lecteur radio (pied de page) --- */
.radio-strip{
  background:rgba(255,255,255,0.06); border-top:1px solid rgba(255,255,255,.15);
  border-bottom:1px solid rgba(255,255,255,.15);
  padding:14px 0; margin-top:20px;
}
.radio-strip .container{display:flex; align-items:center; gap:16px; flex-wrap:wrap; justify-content:center;}
.radio-strip .radio-live, .radio-strip .radio-name{color:var(--sky);}

/* --- Lecteur radio (page d'accueil) --- */
.radio-card{background:var(--navy); color:var(--sky); border-radius:var(--radius); padding:30px; text-align:center; box-shadow:var(--shadow);}
.radio-card h3{color:var(--gold-light); margin-top:0;}
.radio-card .radio-player{justify-content:center; margin-top:14px;}

/* --- Pied de page --- */
footer.site-footer{
  background:var(--navy); color:var(--sky); padding:50px 0 20px; margin-top:60px;
}
footer.site-footer h4{color:var(--gold-light); font-size:1rem;}
footer.site-footer a{color:var(--sky); text-decoration:none; font-size:.95rem;}
footer.site-footer a:hover{color:var(--gold-light);}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px;}
@media(max-width:800px){.footer-grid{grid-template-columns:1fr 1fr;}}
.footer-bottom{
  text-align:center; border-top:1px solid rgba(255,255,255,.15); margin-top:36px; padding-top:18px;
  font-size:.82rem; color:#B9C4D6;
}
.footer-grid ul{list-style:none; padding:0; margin:0;}
.footer-grid li{margin-bottom:8px;}

/* --- Alerte / bannière --- */
.banner{background:var(--gold); color:var(--white); text-align:center; padding:10px 0; font-size:.92rem;}
.banner a{color:var(--white); text-decoration:underline;}

/* --- Galerie photo --- */
.gallery-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:14px;
}
@media(max-width:900px){.gallery-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:600px){.gallery-grid{grid-template-columns:repeat(2,1fr);}}
.gallery-grid a{
  display:block; aspect-ratio:1/1; overflow:hidden; border-radius:var(--radius);
  box-shadow:var(--shadow); border:1px solid #E7DFC9;
}
.gallery-grid img{
  width:100%; height:100%; object-fit:cover; display:block; transition:transform .25s ease;
}
.gallery-grid a:hover img{transform:scale(1.06);}

/* --- Utilitaires --- */
.text-center{text-align:center;}
.mt-0{margin-top:0;}
.small{font-size:.88rem; color:#6b6b6b;}
