/* ══════════════════════════════════════════════════════════════════
   Prenom-musulman.com — Design System 2026
   Palette islamique moderne — vert émeraude + or chaud + ivoire
   ══════════════════════════════════════════════════════════════════ */

/* Google Fonts loaded via <link> in base.html for better performance */

:root {
  --font: 'Inter', -apple-system, system-ui, sans-serif;
  --font-ar: 'Noto Naskh Arabic', 'Traditional Arabic', serif;

  /* Fond ivoire chaud au lieu du gris froid */
  --bg: #f8f5f0;
  --bg-card: #ffffff;
  --border: #e2ddd6;
  --border-light: #ece8e2;

  /* Textes */
  --text: #1c1a16;
  --text-2: #6a6560;
  --text-3: #a09890;

  /* Couleur principale : vert émeraude islamique */
  --bordeaux: #1d6b45;
  --bordeaux-bg: #eef7f2;
  --bordeaux-border: #a8d5bc;

  /* Or chaud pour les accents */
  --or: #b8922a;
  --or-bg: #fdf4e3;
  --or-border: #e8cc8a;

  /* Tags */
  --tag-coran-bg: #eef7f2; --tag-coran: #1d6b45; --tag-coran-border: #a8d5bc;
  --tag-arabe-bg: #fdf4e3; --tag-arabe: #8a6820; --tag-arabe-border: #e8cc8a;
  --tag-fille-bg: #fef2f7; --tag-fille: #9b3060; --tag-fille-border: #f0b8d0;
  --tag-garcon-bg: #f0f6ff; --tag-garcon: #2558a8; --tag-garcon-border: #b0ccf0;
  --tag-mixte-bg: #f4f0ff; --tag-mixte: #5a42a8; --tag-mixte-border: #c8b8f0;

  --r: 10px; --r-lg: 12px; --r-full: 9999px;
  --max-w: 860px;
}

/* ── Reset ─────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.6;font-size:15px}
a{color:var(--bordeaux);text-decoration:none;transition:color .15s}
a:hover{color:var(--text)}
ul,ol{list-style:none}
img{max-width:100%;height:auto;display:block}

/* ── Nav ───────────────────────────────────────────────────────── */
.nav{background:var(--bg-card);border-bottom:.5px solid var(--border-light);height:52px;position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:center}
.nav-inner{max-width:var(--max-w);width:100%;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:8px}
.nav-logo-icon{width:28px;height:28px;background:var(--bordeaux);border-radius:6px;display:flex;align-items:center;justify-content:center}
.nav-logo-icon span{color:white;font-family:var(--font-ar);font-size:14px;font-weight:500}
.nav-logo-text{font-size:14px;font-weight:500;color:var(--text)}
.nav-links{display:flex;gap:20px}
.nav-link{font-size:13px;color:var(--text-2);cursor:pointer;transition:color .15s}
.nav-link:hover{color:var(--bordeaux)}
.nav-burger{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--text)}
.nav-burger svg{display:block}
.nav-cta{background:var(--bordeaux);color:white;font-size:12px;padding:6px 14px;border-radius:6px;border:none;cursor:pointer;font-family:var(--font);font-weight:500;transition:background .15s}
.nav-cta:hover{background:#155234;text-decoration:none;color:white}

/* ── Hero ──────────────────────────────────────────────────────── */
.hero{
  background:linear-gradient(160deg,#0d3d27 0%,#1d6b45 50%,#155234 100%);
  padding:28px 24px 24px;
  text-align:center;
  position:relative;
  overflow:visible;
  border-bottom:none;
}
.hero::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 15% 50%,rgba(184,146,42,.12) 0%,transparent 45%),
    radial-gradient(circle at 85% 20%,rgba(255,255,255,.05) 0%,transparent 40%);
  pointer-events:none;
}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);color:rgba(255,255,255,.9);font-size:12px;padding:4px 12px;border-radius:20px;margin-bottom:16px;border:.5px solid rgba(255,255,255,.25);backdrop-filter:blur(4px)}
.hero-badge-dot{width:6px;height:6px;background:#6cd08a;border-radius:50%}
.hero h1,.hero h2{font-size:26px;font-weight:600;color:#fff;line-height:1.25;margin-bottom:6px}
.hero h1 span,.hero h2 span,.hero h2 .highlight{color:#f0c070}
.hero-sub,.hero p{font-size:13px;color:rgba(255,255,255,.72);margin-bottom:14px;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.5}
.hero-credibilite{font-size:11px;color:rgba(255,255,255,.45);display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:20px;flex-wrap:wrap}
.cred-dot{width:5px;height:5px;border-radius:50%;background:#6cd08a;display:inline-block;flex-shrink:0}
.cred-sep{color:rgba(255,255,255,.2)}

.search-wrap,.hero-search{max-width:540px;margin:0 auto 24px;position:relative;z-index:200}
.search-input,.hero-search input{width:100%;height:46px;border:none;border-radius:23px;padding:0 120px 0 20px;font-size:14px;background:#fff;color:var(--text);outline:none;font-family:var(--font);transition:box-shadow .15s;box-shadow:0 2px 8px rgba(0,0,0,.18)}
.search-input::placeholder,.hero-search input::placeholder{color:#aaa}
.search-input:focus,.hero-search input:focus{box-shadow:0 2px 16px rgba(0,0,0,.28)}
.search-btn{position:absolute;right:5px;top:5px;height:36px;padding:0 18px;background:#b8922a;color:white;border:none;border-radius:18px;font-size:13px;cursor:pointer;font-family:var(--font);font-weight:500;transition:background .15s}
.search-btn:hover{background:#9a7820}

.hero-stats,.stats-bar{display:flex;justify-content:center;gap:32px}
.stat{text-align:center}
.stat-num,.stat-number{font-size:20px;font-weight:600;color:#fff;display:block}
.stat-num span{color:#f0c070}
.stat-label{font-size:10px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.8px;margin-top:2px}

/* ── Content wrapper ───────────────────────────────────────────── */
.content,.container main{max-width:var(--max-w);margin:0 auto;padding:40px 24px;display:flex;flex-direction:column;gap:56px}
.container{max-width:920px;margin:0 auto;padding:0 24px}

/* ── Section headers ───────────────────────────────────────────── */
.section{padding:0}
.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:20px;padding-top:24px;margin-top:8px;border-top:.5px solid var(--border-light)}
.section-title{font-size:17px;font-weight:600;color:var(--text);margin-bottom:0;display:flex;align-items:center;gap:8px}
.section-title::before{content:"";width:3px;height:18px;background:var(--bordeaux);border-radius:2px;display:inline-block;flex-shrink:0}
.section-link{font-size:13px;color:var(--bordeaux);cursor:pointer}

/* ── Tags ──────────────────────────────────────────────────────── */
.tag,.badge{font-size:11px;padding:3px 9px;border-radius:10px;background:var(--bg);color:var(--text-2);border:.5px solid var(--border-light);display:inline-block}
.tag.fille,.badge-feminin,.badge-féminin{background:var(--tag-fille-bg);color:var(--tag-fille);border-color:var(--tag-fille-border)}
.tag.coran,.badge-coranique{background:var(--tag-coran-bg);color:var(--tag-coran);border-color:var(--tag-coran-border)}
.tag.arabe,.badge-origine{background:var(--tag-arabe-bg);color:var(--tag-arabe);border-color:var(--tag-arabe-border)}
.tag.garcon,.badge-masculin{background:var(--tag-garcon-bg);color:var(--tag-garcon);border-color:var(--tag-garcon-border)}
.tag.mixte,.badge-mixte{background:var(--tag-mixte-bg);color:var(--tag-mixte);border-color:var(--tag-mixte-border)}
.badge-compagnon{background:var(--tag-coran-bg);color:var(--tag-coran);border-color:var(--tag-coran-border)}
.badge-tendance,.pc-trend{font-size:10px;color:var(--tag-coran);background:var(--tag-coran-bg);padding:2px 7px;border-radius:8px}

/* ── Prénom du jour ────────────────────────────────────────────── */
.prenom-jour{background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r-lg);padding:12px 16px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;transition:border-color .15s}
.prenom-jour:hover{border-color:var(--bordeaux);text-decoration:none}
.pj-name,.prenom-jour-name{font-size:20px;font-weight:600;color:var(--text);margin-bottom:4px}
.pj-tags,.prenom-jour-tags{display:flex;gap:5px;margin-bottom:6px;flex-wrap:wrap}
.pj-signif,.prenom-jour-meaning{font-size:12px;color:var(--text-2);line-height:1.5}
.pj-arrow{font-size:16px;color:var(--bordeaux);transition:transform .15s}
a.prenom-jour:hover .pj-arrow{transform:translateX(3px)}
a.prenom-jour{color:inherit}
a.prenom-jour:hover{text-decoration:none}
.pj-right,.prenom-jour-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.pj-arabic,.prenom-jour-arabic{font-size:28px;font-family:var(--font-ar);color:var(--text);direction:rtl;line-height:1.3}
.pj-translit,.prenom-jour-translit{font-size:11px;color:var(--text-3)}

/* ── Genres ─────────────────────────────────────────────────────── */
.genres,.gender-links{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.genre-card,.gender-link{background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r-lg);padding:20px 16px;text-align:center;cursor:pointer;transition:border-color .15s;display:flex;flex-direction:column;align-items:center;color:var(--text);font-weight:500;font-size:14px}
.genre-card:hover,.gender-link:hover{border-color:var(--bordeaux);transform:translateY(-2px);text-decoration:none}
.genre-card:hover .genre-icon{transform:scale(1.08);transition:transform .15s}
.genre-card:hover .genre-count{color:var(--bordeaux)}
.genre-icon,.gender-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.genre-icon svg{display:block}
.genre-icon.g,.gender-icon-boy{background:#E6F1FB}
.genre-icon.f,.gender-icon-girl{background:var(--bordeaux-bg)}
.genre-icon.m,.gender-icon-mix{background:#EAF3DE}
.genre-name{font-size:14px;font-weight:500;color:var(--text);margin-bottom:3px}
.genre-count,.gender-link .count{font-size:12px;color:var(--text-3);font-weight:400}

/* ── Lettres ───────────────────────────────────────────────────── */
.lettres,.letter-grid{display:flex;flex-wrap:wrap;gap:6px}
.lettre-btn,.letter-grid a{width:44px;height:44px;border-radius:var(--r);border:.5px solid var(--border-light);background:var(--bg-card);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;color:var(--text);text-decoration:none}
.lettre-btn:hover,.letter-grid a:hover{border-color:var(--bordeaux);background:var(--bordeaux-bg)}
.lettre-btn:hover .lettre-char{color:var(--bordeaux)}
.lettre-char,.letter-grid a{font-size:14px;font-weight:500;color:var(--text)}
.lettre-count,.letter-grid .count{font-size:9px;color:var(--text-3)}

/* ── Origines ──────────────────────────────────────────────────── */
.origines,.origin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.origine-card,.origin-card{background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r);padding:14px;cursor:pointer;transition:border-color .15s;color:var(--text);text-decoration:none;display:block}
.origine-card:hover,.origin-card:hover{border-color:var(--bordeaux);background:var(--bordeaux-bg)}
.origine-card:hover .origine-name{color:var(--bordeaux)}
.origine-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:10px;flex-shrink:0;transition:transform .15s}
.origine-icon span{font-weight:600;line-height:1}
.origine-card:hover .origine-icon{transform:scale(1.08)}
.origine-icon.arabe{background:#E6F1FB;color:#185FA5}
.origine-icon.arabe span{font-family:var(--font-ar);font-size:13px;direction:rtl}
.origine-icon.coranique{background:#EAF3DE;color:#3B6D11}
.origine-icon.coranique span{font-family:var(--font-ar);font-size:11px;direction:rtl}
.origine-icon.berbere{background:#FAEEDA;color:#854F0B}
.origine-icon.berbere span{font-size:18px;font-weight:700}
.origine-icon.persan{background:#F3F0FF;color:#534AB7}
.origine-icon.persan span{font-family:var(--font-ar);font-size:12px;direction:rtl}
.origine-icon.hebreu{background:var(--bordeaux-bg);color:var(--bordeaux)}
.origine-icon.hebreu span{font-size:14px;font-weight:700}
.origine-icon.turc{background:#FCEBEB;color:#A32D2D}
.origine-icon.turc span{font-family:var(--font-ar);font-size:12px;direction:rtl}
.origine-icon.grec{background:#F1EFE8;color:#5F5E5A}
.origine-icon.grec span{font-size:14px;font-weight:700}
.origine-icon.ourdou{background:#F0F4FF;color:#3B5998}
.origine-icon.ourdou span{font-family:var(--font-ar);font-size:12px;direction:rtl}
.origine-icon.swahili{background:#E1F5EE;color:#0F6E56}
.origine-icon.swahili span{font-family:var(--font-ar);font-size:13px;direction:rtl}
.origine-icon.preislamique{background:#FAEEDA;color:#633806}
.origine-icon.preislamique span{font-family:var(--font-ar);font-size:12px;direction:rtl}
.origine-flag,.origin-icon{font-size:18px;margin-bottom:6px}
.origine-name,.origin-card-name{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px}
.origine-count,.origin-card-count{font-size:11px;color:var(--text-3)}

/* ── Prénoms populaires ────────────────────────────────────────── */
.prenoms-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.name-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.prenom-card{
  background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r);
  padding:16px 18px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start;
  cursor:pointer;transition:border-color .15s;color:var(--text);text-decoration:none;
}
.prenom-card:hover{border-color:var(--border);border-left:3px solid var(--bordeaux);transform:translateY(-2px)}
.name-card{
  background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r);
  padding:14px 16px;cursor:pointer;transition:border-color .15s;color:var(--text);text-decoration:none;display:block;
}
.name-card:hover{border-color:var(--border)}
.pc-left{min-width:0}
.pc-name{font-size:16px;font-weight:600;color:var(--text);margin-bottom:6px}
.prenom-card:hover .pc-name{color:var(--bordeaux)}
.pc-signif{font-size:12px;color:var(--text-2);margin-bottom:10px;line-height:1.5;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.pc-tags{display:flex;gap:4px;flex-wrap:wrap}
.pc-right{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.pc-arabic{font-size:24px;font-family:var(--font-ar);color:var(--text);direction:rtl;line-height:1.3}
.name-card-title{font-size:15px;font-weight:500;color:var(--text);margin-bottom:4px}
.name-card-meaning{font-size:12px;color:var(--text-2);margin-bottom:8px;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.name-card-meta{display:flex;gap:4px;flex-wrap:wrap}
.name-card-arabic{font-size:20px;font-family:var(--font-ar);color:var(--text);direction:rtl;margin-bottom:4px}
.name-card-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}

/* ── Article à la une ──────────────────────────────────────────── */
.article-card,.featured-article{background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r-lg);overflow:hidden;display:grid;grid-template-columns:3fr 1fr;transition:border-color .15s;color:var(--text);text-decoration:none}
.article-card:hover,.featured-article:hover{border-color:var(--border)}
.article-body{padding:20px 24px}
.article-tag,.featured-article-tag{font-size:11px;color:var(--bordeaux);background:var(--bordeaux-bg);padding:3px 10px;border-radius:10px;border:.5px solid var(--bordeaux-border);display:inline-block;margin-bottom:10px}
.article-title,.featured-article-title{font-size:16px;font-weight:500;color:var(--text);margin-bottom:8px;line-height:1.4}
.article-excerpt,.featured-article-excerpt{font-size:13px;color:var(--text-2);line-height:1.6}
.article-sidebar{background:var(--bg);padding:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;border-left:.5px solid var(--border-light)}
.article-arabic-deco{font-size:48px;font-family:var(--font-ar);color:var(--text-3);direction:rtl}

/* ── Footer CTA ────────────────────────────────────────────────── */
.footer-cta,.cta-section{background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r-lg);padding:28px 24px;text-align:center}
.footer-cta h3,.cta-section h3{font-size:18px;font-weight:500;color:var(--text);margin-bottom:8px}
.footer-cta p,.cta-section p{font-size:14px;color:var(--text-2);margin-bottom:20px;max-width:500px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;gap:10px;justify-content:center}
.btn-primary,.cta-btn{background:var(--bordeaux);color:white;border:none;padding:10px 24px;border-radius:8px;font-size:14px;cursor:pointer;font-family:var(--font);font-weight:500;transition:background .15s;display:inline-block}
.btn-primary:hover,.cta-btn:hover{background:#155234;color:white;text-decoration:none}
.btn-secondary{background:transparent;color:var(--text);border:.5px solid var(--border);padding:10px 24px;border-radius:8px;font-size:14px;cursor:pointer;font-family:var(--font)}

/* ── Footer ────────────────────────────────────────────────────── */
.site-footer{background:var(--bg-card);border-top:.5px solid var(--border-light);color:var(--text-2);padding:20px 0;margin-top:0;font-size:12px}
.site-footer a{color:var(--bordeaux)}
.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;max-width:var(--max-w);margin:0 auto;padding:0 24px}

/* ── Breadcrumb ────────────────────────────────────────────────── */
.breadcrumb{padding:16px 0 8px;font-size:12px;color:var(--text-3);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.breadcrumb a{color:var(--text-2);font-weight:500}
.breadcrumb a:hover{color:var(--bordeaux)}
.breadcrumb span{color:var(--text-3)}

/* ── Name List (tables) ────────────────────────────────────────── */
.name-list{width:100%;border-collapse:separate;border-spacing:0;background:var(--bg-card);border-radius:var(--r);overflow:hidden;border:.5px solid var(--border-light)}
.name-list th{text-align:left;padding:10px 14px;background:var(--bg);font-size:11px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;border-bottom:.5px solid var(--border-light)}
.name-list td{padding:10px 14px;border-bottom:.5px solid var(--border-light);font-size:14px}
.name-list tr:last-child td{border-bottom:none}
.name-list tr:hover td{background:var(--bordeaux-bg)}
.name-list td a{font-weight:500;color:var(--text)}
.name-list td a:hover{color:var(--bordeaux)}
.name-list .col-arabic{font-family:var(--font-ar);direction:rtl;text-align:right;font-size:18px;color:var(--text)}

/* ── Prenom Page ───────────────────────────────────────────────── */
.prenom-hero{background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r-lg);padding:32px 24px;margin:16px 0;text-align:center;position:relative;overflow:hidden}
.prenom-hero::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--bordeaux)}
.prenom-arabic{font-family:var(--font-ar);direction:rtl;font-size:42px;color:var(--text);margin-bottom:8px;line-height:1.4;font-weight:700}
.prenom-name{font-size:28px;font-weight:500;color:var(--text);margin-bottom:4px}
.prenom-meaning{font-size:15px;color:var(--text-2);margin-bottom:16px}
.prenom-badges{display:flex;justify-content:center;gap:6px;flex-wrap:wrap}
.prenom-badges .badge{font-size:12px;padding:4px 10px}

.prenom-section{background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r);padding:20px 24px;margin-bottom:8px}
.prenom-section h2{font-size:15px;font-weight:500;color:var(--text);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.prenom-section h2::before{content:"";width:3px;height:16px;background:var(--bordeaux);border-radius:2px;display:inline-block;flex-shrink:0}
.prenom-section p{margin-bottom:8px;color:var(--text-2);line-height:1.7;font-size:14px}

.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.info-item{padding:10px 12px;background:var(--bg);border-radius:var(--r)}
.info-label{font-size:10px;color:var(--text-3);font-weight:500;text-transform:uppercase;letter-spacing:.6px;margin-bottom:2px}
.info-value{font-size:14px;font-weight:500;color:var(--text)}

.variantes-list{display:flex;gap:6px;flex-wrap:wrap}
.variante-tag{padding:4px 10px;background:var(--bg);border-radius:var(--r-full);font-size:13px;font-weight:500;color:var(--text-2);transition:all .15s;border:.5px solid var(--border-light)}
a.variante-tag:hover{background:var(--bordeaux-bg);color:var(--bordeaux);border-color:var(--bordeaux-border);text-decoration:none}

.related-names{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px}
.related-names a{display:block;padding:8px;background:var(--bg);border:.5px solid var(--border-light);border-radius:var(--r);text-align:center;font-weight:500;font-size:13px;color:var(--text-2);transition:all .15s}
.related-names a:hover{border-color:var(--bordeaux);color:var(--bordeaux);background:var(--bordeaux-bg);text-decoration:none}

/* ── Vote Button ──────────────────────────────────────────────── */
.vote-container{display:flex;justify-content:center;margin-top:18px}
.vote-btn{display:inline-flex;align-items:center;gap:8px;background:var(--bordeaux-bg);border:1px solid var(--bordeaux-border);border-radius:var(--r-full);padding:10px 24px;cursor:pointer;font-family:var(--font);font-size:14px;font-weight:500;color:var(--bordeaux);transition:all .2s}
.vote-btn:hover{background:var(--bordeaux);color:white;border-color:var(--bordeaux)}
.vote-btn:hover .vote-heart{fill:white;stroke:white}
.vote-btn.voted{background:var(--bordeaux);color:white;border-color:var(--bordeaux)}
.vote-heart{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;transition:all .2s;flex-shrink:0}
.vote-btn.voted .vote-heart{fill:white;stroke:white}
.vote-label{white-space:nowrap}
.vote-count{font-weight:600}
.vote-count:empty{display:none}
@keyframes vote-pulse{0%{transform:scale(1)}50%{transform:scale(1.15)}100%{transform:scale(1)}}
@keyframes vote-shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-3px)}75%{transform:translateX(3px)}}
.vote-btn.vote-pulse{animation:vote-pulse .4s ease}
.vote-btn.vote-shake{animation:vote-shake .4s ease}

/* ── Top Votes ────────────────────────────────────────────────── */
.top-votes-list{display:flex;flex-direction:column;gap:6px}
.top-vote-item{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r);transition:border-color .15s;text-decoration:none;color:var(--text)}
.top-vote-item:hover{border-color:var(--bordeaux);border-left:3px solid var(--bordeaux)}
.top-vote-rank{font-size:15px;font-weight:600;color:var(--bordeaux);min-width:36px}
.top-vote-name{font-size:15px;font-weight:500;flex:1}
.top-vote-count{font-size:13px;color:var(--text-2);display:flex;align-items:center;gap:4px}

/* ── Search Page ───────────────────────────────────────────────── */
.search-box{background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r-lg);padding:20px 24px;margin-bottom:16px}
.search-row{display:flex;gap:10px;flex-wrap:wrap}
.search-row+.search-row{margin-top:10px}
.search-field{flex:1;min-width:130px}
.search-field-main{flex:3;min-width:260px}
.search-field label{display:block;font-size:10px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:4px}
.search-field input,.search-field select{width:100%;padding:8px 12px;border:.5px solid var(--border);border-radius:var(--r);font-family:var(--font);font-size:14px;color:var(--text);background:var(--bg);transition:border-color .15s;appearance:none;-webkit-appearance:none}
.search-field input:focus,.search-field select:focus{outline:none;border-color:var(--bordeaux)}
.search-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239b9b9b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.input-icon{position:relative}
.input-icon svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}
.input-icon input{padding-left:34px!important}
.search-status{font-size:13px;color:var(--text-2);margin-bottom:12px;min-height:1.3em}

/* ── Article Page ──────────────────────────────────────────────── */
.article-page{max-width:680px;margin:0 auto;padding:24px 0 32px}
.article-page h1{font-size:24px;font-weight:500;color:var(--text);line-height:1.3;margin-bottom:12px}
.article-page .article-intro{font-size:15px;color:var(--text-2);line-height:1.7;margin-bottom:24px;border-left:3px solid var(--bordeaux);padding-left:16px}
.article-page h2{font-size:18px;font-weight:500;color:var(--text);margin:24px 0 12px}
.article-page h3{font-size:15px;font-weight:500;color:var(--text);margin:16px 0 8px}
.article-page p{color:var(--text-2);line-height:1.8;margin-bottom:12px;font-size:14px}
.article-page ul,.article-page ol{margin:0 0 16px 20px;color:var(--text-2)}
.article-page li{margin-bottom:6px;line-height:1.7;list-style:disc;font-size:14px}
.article-page ol li{list-style:decimal}
.article-page strong{color:var(--text);font-weight:500}
.article-page .example-box{background:var(--bg);border:.5px solid var(--border-light);border-radius:var(--r);padding:16px 20px;margin:12px 0 16px}
.article-page .example-box p{margin-bottom:4px}
.article-page .example-label{font-size:10px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}
.article-page .warning-box{background:#fef2f2;border:.5px solid #fecaca;border-radius:var(--r);padding:16px 20px;margin:12px 0 16px;color:#991b1b}
.article-page .tip-box{background:var(--bordeaux-bg);border:.5px solid var(--bordeaux-border);border-radius:var(--r);padding:16px 20px;margin:12px 0 16px;color:#155234}
.article-page .conclusion{background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r-lg);padding:20px 24px;margin:24px 0}
.article-page .conclusion h2{margin-top:0}
.article-page .faq-item{margin-bottom:16px}
.article-page .faq-item h3{color:var(--bordeaux);margin-bottom:4px}

/* ── Pagination ────────────────────────────────────────────────── */
.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin:24px 0 16px}
.pagination-btn{display:inline-flex;align-items:center;padding:8px 16px;background:var(--bg-card);border:.5px solid var(--border);border-radius:var(--r);font-size:13px;font-weight:500;color:var(--bordeaux);transition:all .15s}
.pagination-btn:hover{border-color:var(--bordeaux);background:var(--bordeaux-bg);text-decoration:none}
.pagination-info{font-size:13px;color:var(--text-3)}

.coran-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}

/* ── Responsive ────────────────────────────────────────────────── */
@media(max-width:768px){
  .hero{padding:32px 16px}
  .hero h1,.hero h2{font-size:24px}
  .hero-stats,.stats-bar{gap:20px;flex-wrap:wrap}
  .stat-num,.stat-number{font-size:18px}
  .genres,.gender-links{grid-template-columns:1fr}
  .origines,.origin-grid{grid-template-columns:repeat(2,1fr)}
  .coran-grid{grid-template-columns:repeat(2,1fr)}
  .prenoms-grid{grid-template-columns:1fr}
  .name-grid{grid-template-columns:1fr}
  .prenom-jour{grid-template-columns:1fr;text-align:center}
  .pj-right,.prenom-jour-right{text-align:center;margin-top:8px}
  .article-card,.featured-article{grid-template-columns:1fr}
  .article-sidebar{display:none}
  .info-grid{grid-template-columns:1fr}
  .prenom-arabic{font-size:32px}
  .prenom-name{font-size:22px}
  .name-list th:nth-child(3),.name-list td:nth-child(3){display:none}
  .name-list th:nth-child(4),.name-list td:nth-child(4){display:none}
  .name-list td{padding:8px 12px;font-size:13px}
  .name-list .col-arabic{font-size:16px}
  .nav-links{display:none;position:absolute;top:52px;left:0;right:0;background:var(--bg-card);border-bottom:.5px solid var(--border-light);flex-direction:column;padding:12px 24px;gap:4px;box-shadow:0 4px 12px rgba(0,0,0,.06);z-index:99}
  .nav-links.open{display:flex}
  .nav-link{padding:10px 0;font-size:14px;border-bottom:.5px solid var(--border-light)}
  .nav-link:last-child{border-bottom:none}
  .nav-burger{display:flex}
  .search-row{flex-direction:column}
  .search-field{min-width:100%}
  .cta-btns{flex-direction:column}
  .footer-content{flex-direction:column;text-align:center}
}
@media(max-width:480px){
  .hero-stats,.stats-bar{flex-wrap:wrap;gap:8px 12px;justify-content:center}
  .stat{min-width:0;flex:0 0 auto}
  .stat-num,.stat-number{font-size:15px}
  .stat-label{font-size:9px;letter-spacing:.5px}
  .origines,.origin-grid{grid-template-columns:1fr}
  .coran-grid{grid-template-columns:1fr}
}
/* ── Autocomplete suggestions ──────────────────────────────────── */
/* ── Section coraniques ────────────────────────────────────────── */
.section-subtitle{font-size:13px;color:var(--text-3);margin-top:2px}
.coran-tabs{display:flex;gap:6px;margin-bottom:16px}
.coran-tab{padding:7px 18px;border-radius:20px;border:.5px solid var(--border-light);background:var(--bg-card);font-size:13px;font-family:var(--font);color:var(--text-2);cursor:pointer;transition:all .15s}
.coran-tab.active{background:var(--bordeaux);color:white;border-color:var(--bordeaux)}
.coran-tab:hover:not(.active){border-color:var(--border)}
.coran-panel{display:block}
.coran-panel.hidden{display:none}
.hidden{display:none!important}
.coran-card{background:var(--bg-card);border:.5px solid var(--border-light);border-radius:var(--r-lg);padding:14px 16px;display:flex;justify-content:space-between;align-items:flex-start;text-decoration:none;color:inherit;transition:border-color .15s;gap:12px}
.coran-card:hover{border-color:var(--bordeaux)}
.coran-card-left{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}
.coran-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;color:#3B6D11;background:#EAF3DE;border:.5px solid #C0DD97;padding:2px 8px;border-radius:8px;width:fit-content}
.coran-name{font-size:17px;font-weight:500;color:var(--text);margin-top:2px}
.coran-card:hover .coran-name{color:var(--bordeaux)}
.coran-sourate{font-size:11px;color:var(--text-3);font-style:italic}
.coran-signif{font-size:12px;color:var(--text-2);line-height:1.5;margin-top:2px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.coran-card-right{text-align:right;flex-shrink:0}
.coran-arabic{font-size:24px;font-family:var(--font-ar);color:var(--text);direction:rtl;line-height:1.3}
.coran-translit{font-size:11px;color:var(--text-3);margin-top:3px}
.coran-voir-plus{display:block;text-align:center;font-size:13px;color:var(--bordeaux);text-decoration:none;padding:10px}
.coran-voir-plus:hover{text-decoration:underline}

/* ── Hero crédibilité ──────────────────────────────────────────── */
.hero-credibilite{font-size:12px;color:var(--text-3);display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.cred-dot{width:6px;height:6px;border-radius:50%;background:#2f9e44;display:inline-block;flex-shrink:0}
.cred-sep{color:#D1D5DB}

/* ── Filtres populaires ───────────────────────────────────────── */
.pop-filters{display:flex;gap:6px;margin-bottom:16px}
.pop-filter{padding:6px 16px;border-radius:20px;border:.5px solid var(--border-light);background:var(--bg-card);font-size:13px;font-family:var(--font);color:var(--text-2);cursor:pointer;transition:all .15s}
.pop-filter:hover:not(.active){border-color:var(--bordeaux);color:var(--bordeaux)}
.pop-filter.active{background:var(--bordeaux);color:white;border-color:var(--bordeaux)}

/* ── Flèche carte prénom ──────────────────────────────────────── */
.prenom-card-arrow{font-size:16px;color:var(--bordeaux);opacity:0;transform:translateX(-4px);transition:opacity .15s,transform .15s;flex-shrink:0;margin-left:8px;align-self:center}
.prenom-card:hover .prenom-card-arrow{opacity:1;transform:translateX(0)}
@media(hover:none){.prenom-card-arrow{opacity:1;transform:translateX(0);color:#D1D5DB}}

.search-wrap{position:relative}
.search-suggestions{display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;background:white;border:.5px solid #E5E7EB;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.2);max-height:380px;overflow-y:auto;z-index:100}
.search-suggestions.visible{display:block}
.suggestion-item{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;cursor:pointer;border-bottom:.5px solid #F3F4F6;text-decoration:none;color:inherit;transition:background .1s;gap:12px}
.suggestion-item:last-child{border-bottom:none}
.suggestion-item:hover,.suggestion-item.active{background:var(--bordeaux-bg)}
.suggestion-left{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1;text-align:left}
.suggestion-name{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.suggestion-name mark{background:none;color:var(--bordeaux);font-weight:600}
.suggestion-meta{font-size:11px;color:#9CA3AF;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.suggestion-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.suggestion-arabic{font-size:18px;font-family:var(--font-ar);color:var(--text);direction:rtl}
.suggestion-tag{font-size:10px;padding:2px 7px;border-radius:8px;background:#F3F4F6;color:#6B7280}
.suggestion-tag.fille,.suggestion-tag.féminin{background:var(--bordeaux-bg);color:var(--bordeaux)}
.suggestion-tag.masculin{background:#E6F1FB;color:#185FA5}
.suggestion-tag.mixte{background:#EAF3DE;color:#3B6D11}
.suggestion-tag.coran{background:#EAF3DE;color:#3B6D11}
.suggestion-empty{padding:16px;text-align:center;font-size:13px;color:#9CA3AF}
.suggestion-footer{padding:10px 16px;text-align:center;font-size:12px;color:var(--bordeaux);border-top:.5px solid #F3F4F6;cursor:pointer}
.suggestion-footer:hover{background:var(--bordeaux-bg)}

/* ── Focus & Active states ─────────────────────────────────────── */
.prenom-card:focus-visible,.genre-card:focus-visible,.origine-card:focus-visible,.coran-card:focus-visible,.lettre-btn:focus-visible{outline:2px solid var(--bordeaux);outline-offset:2px}
.prenom-card:active,.genre-card:active,.origine-card:active,.coran-card:active{transform:translateY(0);transition:transform .05s}
@media(hover:none){.prenom-card:hover,.genre-card:hover,.origine-card:hover,.coran-card:hover,.lettre-btn:hover{transform:none}}

@media print{
  .nav,.site-header,.site-footer,.breadcrumb,.cta-section,.footer-cta{display:none}
  body{background:white;font-size:12pt}
}
