/* ============================================================
   Centre Culturel Musulman de Furiani — Feuille de style
   Design system issu de la charte graphique
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Amiri:ital,wght@0,400;0,700;1,400&family=Cormorant+Garamond:wght@400;500;600;700&family=Mulish:wght@300;400;500;600;700;800&display=swap');

:root{
  --z-bleu:#1F356A; --z-bleu-fonce:#152449; --z-bleu-clair:#2A4789;
  --or:#C4A24E; --or-clair:#D9BE73; --or-fonce:#9C7F33;
  --creme:#EBE0C6; --blanc-casse:#F6F3EC; --encre:#222C36;
  --acier:#74879A; --acier-clair:#AEBCC8;
  --vert:#2C6049; --terre:#8A4B38; --ocre:#DDB24A;
  --serif:'Cormorant Garamond',Georgia,serif;
  --arabe:'Amiri',serif;
  --sans:'Mulish',system-ui,sans-serif;
  --shadow:0 18px 40px -24px rgba(34,44,54,.5);
  --radius:16px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--encre);background:var(--blanc-casse);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.center{text-align:center}
.hidden{display:none!important}

h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08;color:var(--encre)}
h2{font-size:clamp(1.9rem,4vw,2.9rem);letter-spacing:.5px;margin-bottom:18px}
h3{font-size:1.45rem;margin-bottom:8px}
p.lead{font-size:1.1rem;max-width:60ch;color:#46545f;margin:0 auto}
.eyebrow{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--or-fonce);font-weight:800;margin-bottom:14px;display:inline-flex;align-items:center;gap:12px;justify-content:center}
.eyebrow::before,.eyebrow.solo::after{content:"";width:30px;height:1px;background:var(--or)}
strong{font-weight:700;color:var(--encre)}

section{padding:84px 0;position:relative}
.alt{background:#fff}
.dark{background:var(--z-bleu-fonce);color:var(--blanc-casse)}
.dark h2,.dark h3{color:#fff}
.dark p.lead{color:var(--acier-clair)}

/* ---- Frise zellige polychrome ---- */
.frieze{height:26px;width:100%;
  background:repeating-linear-gradient(90deg,
    var(--z-bleu) 0 14px,transparent 14px 16px,
    var(--terre) 16px 30px,transparent 30px 32px,
    var(--vert) 32px 46px,transparent 46px 48px,
    var(--ocre) 48px 62px,transparent 62px 64px);
  border-top:3px solid var(--or);border-bottom:3px solid var(--or);position:relative}
.frieze::after{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(90deg,transparent 0 6px,rgba(255,255,255,.5) 6px 8px,transparent 8px 16px)}

/* ---- Boutons ---- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:700;font-size:.9rem;
  letter-spacing:.04em;padding:14px 28px;border-radius:10px;cursor:pointer;border:none;transition:.22s;white-space:nowrap}
.btn-or{background:var(--or);color:var(--encre)}.btn-or:hover{background:var(--or-fonce);color:#fff;transform:translateY(-2px)}
.btn-blue{background:var(--z-bleu);color:#fff}.btn-blue:hover{background:var(--z-bleu-fonce);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--z-bleu);border:1.6px solid var(--acier)}.btn-ghost:hover{background:var(--z-bleu);color:#fff;border-color:var(--z-bleu)}
.btn-ghost-light{background:transparent;color:#fff;border:1.6px solid rgba(255,255,255,.5)}.btn-ghost-light:hover{background:#fff;color:var(--z-bleu)}
.btn-lg{padding:17px 36px;font-size:1rem}
.btn-block{width:100%;justify-content:center}

/* ---- En-tête / navigation ---- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(21,36,73,.97);backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(196,162,78,.3)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:12px;color:#fff}
.brand .bname{font-family:var(--serif);font-size:1.35rem;font-weight:600;letter-spacing:.5px;line-height:1}
.brand .bsub{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--or-clair);font-weight:700}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{color:var(--acier-clair);font-weight:600;font-size:.88rem;transition:.2s}
.nav-links a:hover{color:var(--or-clair)}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.3s}
@media(max-width:920px){
  .nav-links{position:fixed;inset:72px 0 auto 0;flex-direction:column;background:var(--z-bleu-fonce);
    padding:24px;gap:18px;transform:translateY(-130%);transition:.35s;border-bottom:3px solid var(--or)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{font-size:1rem}
  .burger{display:flex}
  .nav-cta .btn{display:none}
}

/* ---- Héro ---- */
.hero{position:relative;overflow:hidden;background:var(--z-bleu-fonce);color:var(--blanc-casse);text-align:center}
.hero .zbg{position:absolute;inset:0;opacity:.28}
.hero-inner{position:relative;z-index:3;padding:88px 24px 96px}
.hero .arabe{font-family:var(--arabe);font-size:clamp(1.5rem,3.4vw,2.2rem);color:var(--or-clair);margin:22px 0 6px}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.3rem,5.5vw,4.2rem);letter-spacing:1px}
.hero .sub{margin-top:18px;font-size:.95rem;letter-spacing:.18em;text-transform:uppercase;color:var(--creme);font-weight:600}
.hero-cta{margin-top:38px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.emblem-glow{filter:drop-shadow(0 10px 26px rgba(0,0,0,.5))}

/* ---- Carte Hadith du jour ---- */
.hadith{background:linear-gradient(160deg,#fff,#fbf8f0);border:1px solid rgba(196,162,78,.35);
  border-radius:var(--radius);padding:48px 44px;max-width:760px;margin:0 auto;box-shadow:var(--shadow);position:relative;text-align:center}
.hadith::before,.hadith::after{content:"";position:absolute;width:40px;height:40px;border:2px solid var(--or);opacity:.5}
.hadith::before{top:16px;left:16px;border-right:none;border-bottom:none}
.hadith::after{bottom:16px;right:16px;border-left:none;border-top:none}
.hadith .ar{font-family:var(--arabe);font-size:1.7rem;color:var(--z-bleu);direction:rtl;line-height:1.9;margin-bottom:18px}
.hadith .fr{font-family:var(--serif);font-size:1.45rem;font-style:italic;color:var(--encre);margin-bottom:14px}
.hadith .src{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--or-fonce);font-weight:700}

/* ---- Horaires de prière ---- */
.salat-head{display:flex;flex-wrap:wrap;gap:8px;align-items:baseline;justify-content:center;margin-bottom:26px}
.salat-date{font-size:.95rem;color:var(--acier-clair)}
.salat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;max-width:920px;margin:0 auto}
.salat-cell{background:rgba(255,255,255,.06);border:1px solid rgba(196,162,78,.3);border-radius:14px;padding:22px 10px;text-align:center}
.salat-cell.next{background:var(--or);border-color:var(--or)}
.salat-cell.next .nm,.salat-cell.next .tm{color:var(--encre)}
.salat-cell .nm{font-family:var(--serif);font-size:1.2rem;color:var(--or-clair);font-weight:600}
.salat-cell .ar{font-family:var(--arabe);font-size:.95rem;color:var(--acier-clair);margin:2px 0 8px}
.salat-cell .tm{font-size:1.35rem;font-weight:800;color:#fff;letter-spacing:.02em}
.salat-note{text-align:center;margin-top:18px;font-size:.85rem;color:var(--acier-clair)}
@media(max-width:780px){.salat-grid{grid-template-columns:repeat(2,1fr)}}

/* ---- Projet / cagnotte ---- */
.project{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
@media(max-width:860px){.project{grid-template-columns:1fr;gap:30px}}
.project .visual{background:var(--z-bleu);border-radius:var(--radius);min-height:300px;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow)}
.project .visual .zbg{position:absolute;inset:0;opacity:.4}
.project .visual .badge{position:relative;z-index:2;text-align:center;color:#fff;padding:30px}
.project .visual .badge .ar{font-family:var(--arabe);color:var(--or-clair);font-size:1.6rem;margin-bottom:10px}
.gauge{margin:26px 0}
.gauge .bar{height:18px;background:#e7e1d2;border-radius:20px;overflow:hidden;border:1px solid rgba(0,0,0,.05)}
.gauge .fill{height:100%;width:0;background:linear-gradient(90deg,var(--or),var(--or-fonce));border-radius:20px;transition:width 1.6s cubic-bezier(.2,.7,.2,1)}
.gauge .nums{display:flex;justify-content:space-between;margin-top:12px;font-weight:700}
.gauge .nums .collected{color:var(--or-fonce);font-size:1.3rem;font-family:var(--serif)}
.gauge .nums .goal{color:var(--acier);font-size:1.05rem}

/* ---- Don ---- */
.don-card{background:#fff;border:1px solid rgba(116,135,154,.22);border-radius:var(--radius);padding:38px;max-width:680px;margin:0 auto;box-shadow:var(--shadow)}
.amounts{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:10px 0 8px}
.amount{padding:16px 4px;border:1.6px solid #e2dccb;border-radius:12px;text-align:center;font-weight:800;font-size:1.05rem;
  background:var(--blanc-casse);cursor:pointer;transition:.18s;color:var(--encre)}
.amount:hover{border-color:var(--or)}
.amount.active{background:var(--z-bleu);color:#fff;border-color:var(--z-bleu)}
.free-amount{display:flex;align-items:center;gap:10px;margin:14px 0 6px;border:1.6px solid #e2dccb;border-radius:12px;padding:4px 16px}
.free-amount input{flex:1;border:none;font-size:1.1rem;font-weight:700;padding:14px 0;background:transparent;outline:none;color:var(--encre)}
.free-amount .eur{font-size:1.2rem;font-weight:800;color:var(--acier)}
.freq{display:flex;gap:10px;margin:18px 0}
.freq label{flex:1;text-align:center;padding:12px;border:1.6px solid #e2dccb;border-radius:12px;cursor:pointer;font-weight:700;transition:.18s}
.freq input{display:none}
.freq input:checked+span{color:var(--z-bleu)}
.freq label:has(input:checked){border-color:var(--z-bleu);background:rgba(31,53,106,.06)}
.methods{display:flex;gap:8px;margin:8px 0 16px}
.method-tab{flex:1;text-align:center;padding:12px;border:1.6px solid #e2dccb;border-radius:12px;cursor:pointer;font-weight:700;font-size:.85rem;transition:.18s}
.method-tab.active{background:var(--or);border-color:var(--or);color:var(--encre)}
.method-panel{display:none;padding:18px;background:var(--blanc-casse);border-radius:12px;margin-bottom:14px;font-size:.92rem;color:#54616b}
.method-panel.active{display:block}
.iban-box{background:#fff;border:1px dashed var(--acier);border-radius:10px;padding:14px 16px;margin:10px 0;display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.iban-box code{font-size:1rem;font-weight:700;letter-spacing:.08em;color:var(--z-bleu);font-family:var(--sans)}
.copy-btn{background:var(--z-bleu);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-weight:700;font-size:.78rem;cursor:pointer}
.fiscal{margin-top:14px;font-size:.82rem;color:#7d8a94;text-align:center;line-height:1.5}
@media(max-width:560px){.amounts{grid-template-columns:repeat(2,1fr)}}

/* ---- Activités ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;margin-top:14px}
.card{background:#fff;border:1px solid rgba(116,135,154,.2);border-radius:var(--radius);overflow:hidden;transition:.25s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card .ico{height:78px;display:flex;align-items:center;justify-content:center;background:var(--z-bleu);color:var(--or-clair);position:relative}
.card .ico .zbg{position:absolute;inset:0;opacity:.35}
.card .ico svg{position:relative;z-index:2}
.card .body{padding:22px}
.card .body h3{margin-bottom:6px}
.card .body p{font-size:.9rem;color:#7d8a94}

/* ---- Nous trouver ---- */
.find{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:stretch}
@media(max-width:820px){.find{grid-template-columns:1fr}}
.find .info{display:flex;flex-direction:column;gap:18px}
.info-row{display:flex;gap:14px;align-items:flex-start}
.info-row .ic{flex:none;width:42px;height:42px;border-radius:11px;background:rgba(31,53,106,.08);display:flex;align-items:center;justify-content:center;color:var(--z-bleu)}
.info-row .tx h4{font-size:1.05rem;margin-bottom:2px}
.info-row .tx p{font-size:.92rem;color:#54616b}
.map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid rgba(116,135,154,.25);min-height:320px;box-shadow:var(--shadow)}
.map-wrap iframe{width:100%;height:100%;min-height:320px;border:0;display:block}

/* ---- Bandeau adhérent ---- */
.member-banner{background:linear-gradient(135deg,var(--z-bleu),var(--z-bleu-clair));border-radius:var(--radius);
  padding:46px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;position:relative;overflow:hidden}
.member-banner .zbg{position:absolute;inset:0;opacity:.22}
.member-banner > *{position:relative;z-index:2}
.member-banner h3{color:#fff;font-size:1.7rem}
.member-banner p{color:var(--acier-clair);max-width:46ch;margin-top:6px}

/* ---- Pied de page ---- */
.foot{background:var(--z-bleu-fonce);color:var(--acier-clair);padding:60px 0 30px;position:relative;overflow:hidden}
.foot .zbg{position:absolute;inset:0;opacity:.14}
.foot .inner{position:relative;z-index:2}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;margin-bottom:34px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:26px}}
.foot h4{color:#fff;font-size:1.1rem;margin-bottom:14px}
.foot a,.foot p{font-size:.9rem;line-height:1.9}
.foot a:hover{color:var(--or-clair)}
.foot .arabe{font-family:var(--arabe);color:var(--or-clair);font-size:1.4rem;margin-top:8px}
.foot .bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;text-align:center;font-size:.78rem;color:#5a6772;letter-spacing:.04em}

/* ---- Notices / démo ---- */
.demo-note{background:rgba(221,178,74,.16);border:1px solid var(--ocre);color:#6e561c;border-radius:12px;
  padding:14px 18px;font-size:.85rem;margin:0 auto 26px;max-width:760px;text-align:center}

/* ---- Espace adhérent ---- */
.auth-wrap{min-height:calc(100vh - 72px);display:flex;align-items:center;justify-content:center;padding:50px 24px;
  background:var(--z-bleu-fonce);position:relative;overflow:hidden}
.auth-wrap .zbg{position:absolute;inset:0;opacity:.2}
.auth-card{position:relative;z-index:2;background:#fff;border-radius:20px;padding:46px;max-width:420px;width:100%;box-shadow:0 30px 70px -30px rgba(0,0,0,.6);text-align:center}
.auth-card .emb{color:var(--or-fonce);margin-bottom:10px}
.field{text-align:left;margin-bottom:16px}
.field label{display:block;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--acier);margin-bottom:6px}
.field input{width:100%;padding:14px 16px;border:1.6px solid #e2dccb;border-radius:11px;font-size:1rem;outline:none;transition:.18s}
.field input:focus{border-color:var(--z-bleu)}
.dash{padding:40px 0 70px}
.dash-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;margin-bottom:30px}
.status-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:30px;font-weight:700;font-size:.85rem}
.status-ok{background:rgba(44,96,73,.14);color:var(--vert)}
.status-due{background:rgba(138,75,56,.14);color:var(--terre)}
.dash-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:24px}
@media(max-width:820px){.dash-grid{grid-template-columns:1fr}}
.box{background:#fff;border:1px solid rgba(116,135,154,.2);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.box h3{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.kv{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid #efeadd;font-size:.92rem}
.kv:last-child{border-bottom:none}.kv span:first-child{color:#7d8a94}.kv span:last-child{font-weight:700}
table.cotis{width:100%;border-collapse:collapse;font-size:.88rem}
table.cotis th{text-align:left;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--acier);padding:10px 8px;border-bottom:2px solid #efeadd}
table.cotis td{padding:13px 8px;border-bottom:1px solid #f2eee2}
.tag-paid{background:rgba(44,96,73,.14);color:var(--vert);padding:3px 10px;border-radius:20px;font-size:.74rem;font-weight:700}
.link-recu{color:var(--z-bleu);font-weight:700;font-size:.82rem;cursor:pointer}
.link-recu:hover{color:var(--or-fonce)}

.fade{opacity:0;transform:translateY(22px);transition:all .8s cubic-bezier(.2,.7,.2,1)}
.fade.in{opacity:1;transform:none}
