/*
Theme Name: Astralys
Theme URI: https://example.com/astralys
Author: Julien
Description: Thème WordPress mystique pour Mon-horoscope-gratuit.fr : horoscopes du jour, demain, amour et semaine, heures miroirs, tarot, numérologie et outils astrologiques. Calculs astronomiques réels, contenus éditables, FAQ et catégories sur tout le site. Style sombre violet/or étoilé.
Version: 1.3.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: astralys
Tags: horoscope, astrologie, blog, custom-post-types, full-width-template, translation-ready, editor-style
*/

/* =========================================================
   ASTRALYS — Variables & Reset
   ========================================================= */
:root {
  --noir-cosmos: #0a0418;
  --violet-nuit: #160a2e;
  --violet-profond: #241046;
  --violet-medium: #3c1d6e;
  --violet-clair: #7c5cc4;
  --or: #d4af37;
  --or-clair: #f0d97a;
  --or-pale: #fbf3d0;
  --argent: #c8c4e0;
  --texte: #e9e4f5;
  --texte-doux: #b4abce;
  --texte-faible: #7d749a;
  --bordure: rgba(124, 92, 196, 0.22);
  --bordure-or: rgba(212, 175, 55, 0.35);

  --serif: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --titre: "Cinzel", "Cormorant Garamond", serif;
  --corps: "Spectral", Georgia, serif;
  --sans: "Jost", "Century Gothic", sans-serif;

  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 24px;
  --ombre-douce: 0 8px 40px rgba(0, 0, 0, 0.45);
  --ombre-or: 0 0 28px rgba(212, 175, 55, 0.25);
  --max: 1180px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  background: var(--noir-cosmos);
  color: var(--texte);
  font-family: var(--corps);
  font-size: 18px;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  position: relative;
}

/* Ciel étoilé global */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(ellipse at 20% 10%, rgba(60, 29, 110, 0.55), transparent 55%),
    radial-gradient(ellipse at 85% 80%, rgba(36, 16, 70, 0.6), transparent 50%),
    linear-gradient(160deg, var(--noir-cosmos), var(--violet-nuit));
}
body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background-image:
    radial-gradient(1px 1px at 10% 20%, #fff, transparent),
    radial-gradient(1px 1px at 30% 70%, #fff, transparent),
    radial-gradient(1px 1px at 50% 40%, rgba(255,255,255,0.8), transparent),
    radial-gradient(1.5px 1.5px at 70% 15%, #fff, transparent),
    radial-gradient(1px 1px at 80% 60%, #fff, transparent),
    radial-gradient(1px 1px at 90% 35%, rgba(255,255,255,0.7), transparent),
    radial-gradient(1.5px 1.5px at 25% 90%, #fff, transparent),
    radial-gradient(1px 1px at 60% 85%, #fff, transparent);
  background-size: 100% 100%;
  opacity: 0.5;
  animation: scintille 6s ease-in-out infinite alternate;
}
@keyframes scintille { from { opacity: 0.3; } to { opacity: 0.65; } }

img { max-width: 100%; height: auto; display: block; }
a { color: var(--or-clair); text-decoration: none; transition: color .25s; }
a:hover { color: var(--or); }

h1, h2, h3, h4 { font-family: var(--titre); font-weight: 600; line-height: 1.2; color: var(--or-pale); letter-spacing: .02em; }
h1 { font-size: clamp(2rem, 5vw, 3.4rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.4rem); }
h3 { font-size: 1.4rem; }
p { margin-bottom: 1.1rem; color: var(--texte-doux); }

.container { max-width: var(--max); margin: 0 auto; padding: 0 24px; }

/* =========================================================
   Header
   ========================================================= */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(10, 4, 24, 0.82);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--bordure);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: 16px 24px; max-width: var(--max); margin: 0 auto; }
.site-logo { display: flex; align-items: center; gap: 12px; font-family: var(--titre); font-size: 1.6rem; color: var(--or-pale); letter-spacing: .12em; text-transform: uppercase; }
.site-logo .glyph { color: var(--or); font-size: 1.4rem; animation: tourne 22s linear infinite; }
@keyframes tourne { to { transform: rotate(360deg); } }

.main-nav ul { display: flex; gap: 28px; list-style: none; align-items: center; }
.menu-toggle { display: none; background: none; border: 1px solid var(--bordure-or); color: var(--or); padding: 8px 12px; border-radius: var(--r-sm); cursor: pointer; font-size: 1.1rem; }

/* Mega-menu (desktop) */
.mega-nav { display: flex; gap: 8px; list-style: none; align-items: center; margin: 0; padding: 0; flex-wrap: nowrap; }
.mega-item { position: relative; }
.mega-toggle {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 10px 12px;
  font-family: var(--sans);
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--texte-doux);
  white-space: nowrap;
  border-radius: var(--r-sm);
}
.mega-toggle:hover { color: var(--or-pale); }
.mega-toggle .caret { font-size: .7rem; color: var(--violet-clair); transition: transform .25s; }
.mega-item:hover .caret { transform: rotate(180deg); }
.mega-panneau {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  width: 240px;
  background: linear-gradient(160deg, rgba(22,10,46,.99), rgba(10,4,24,.99));
  border: 1px solid var(--bordure-or);
  border-radius: var(--r-md);
  box-shadow: var(--ombre-douce);
  padding: 10px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .2s ease, visibility .2s;
  z-index: 300;
}
/* Petite zone tampon invisible pour ne pas perdre le survol entre bouton et panneau */
.mega-panneau::before {
  content: "";
  position: absolute;
  top: -8px; left: 0; right: 0;
  height: 8px;
}
.mega-item:hover .mega-panneau,
.mega-item:focus-within .mega-panneau { opacity: 1; visibility: visible; pointer-events: auto; }
/* Le dernier item à panneau s'ouvre aligné à droite pour ne pas sortir de l'écran */
.mega-item:last-of-type .mega-panneau { left: auto; right: 0; }
.mega-hub {
  display: block;
  padding: 8px 12px 12px;
  margin-bottom: 8px;
  border-bottom: 1px solid var(--bordure);
  font-family: var(--sans);
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--or);
}
.mega-hub:hover { color: var(--or-clair); }
/* Liens empilés verticalement, chacun dans son cadre */
.mega-col {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.mega-col li { margin: 0; padding: 0; }
.mega-panneau .mega-col { display: flex; flex-direction: column; gap: 2px; margin: 0; padding: 0; list-style: none; }
.mega-panneau .mega-col li { margin: 0; padding: 0; border: 0; display: block; }
.mega-panneau .mega-col li a {
  display: block;
  width: 100%;
  padding: 9px 14px;
  margin: 0;
  border-radius: var(--r-sm);
  font-family: var(--corps);
  font-size: .94rem;
  line-height: 1.4;
  font-weight: 400;
  color: var(--texte-doux);
  white-space: nowrap;
  text-transform: none;
  letter-spacing: normal;
  text-align: left;
  transition: background .2s, color .2s;
}
.mega-panneau .mega-col li a::after { display: none !important; content: none !important; }
.mega-panneau .mega-col li a:hover { color: var(--or-pale); background: rgba(60,29,110,.5); }

/* =========================================================
   Hero
   ========================================================= */
.hero { text-align: center; padding: 90px 24px 70px; position: relative; }
.hero .eyebrow { font-family: var(--sans); letter-spacing: .3em; text-transform: uppercase; font-size: .75rem; color: var(--violet-clair); margin-bottom: 18px; }
.hero h1 { margin-bottom: 20px; }
.hero h1 .accent { color: var(--or); }
.hero p.lede { max-width: 640px; margin: 0 auto 34px; font-size: 1.2rem; color: var(--texte-doux); font-style: italic; }

.btn { display: inline-block; font-family: var(--sans); text-transform: uppercase; letter-spacing: .14em; font-size: .82rem; padding: 14px 32px; border-radius: 40px; transition: all .3s; cursor: pointer; border: none; }
.btn-or { background: linear-gradient(135deg, var(--or), var(--or-clair)); color: var(--noir-cosmos); box-shadow: var(--ombre-or); font-weight: 600; }
.btn-or:hover { transform: translateY(-2px); color: var(--noir-cosmos); box-shadow: 0 0 38px rgba(212,175,55,.45); }
.btn-ghost { background: transparent; border: 1px solid var(--bordure-or); color: var(--or-clair); }
.btn-ghost:hover { background: rgba(212,175,55,.08); color: var(--or); }

/* =========================================================
   Roue du zodiaque (12 signes)
   ========================================================= */
.section-titre { text-align: center; margin: 64px 0 12px; }
.section-titre .glyph { color: var(--or); font-size: 1.6rem; display: block; margin-bottom: 8px; }
.section-soustitre { text-align: center; color: var(--texte-faible); font-family: var(--sans); letter-spacing: .12em; text-transform: uppercase; font-size: .78rem; margin-bottom: 40px; }

.zodiaque-grille { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; margin: 0 0 40px; }
.signe-carte {
  background: linear-gradient(160deg, rgba(60,29,110,.35), rgba(22,10,46,.5));
  border: 1px solid var(--bordure);
  border-radius: var(--r-md);
  padding: 22px 12px;
  text-align: center;
  transition: all .3s;
  position: relative;
  overflow: hidden;
}
.signe-carte::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 50% 0%, rgba(212,175,55,.12), transparent 70%); opacity: 0; transition: opacity .3s; }
.signe-carte:hover { border-color: var(--bordure-or); transform: translateY(-4px); box-shadow: var(--ombre-douce); }
.signe-carte:hover::before { opacity: 1; }
.signe-carte .symbole { font-size: 2.2rem; color: var(--or); display: block; margin-bottom: 8px; line-height: 1; }
.signe-carte .nom { font-family: var(--titre); font-size: 1.05rem; color: var(--or-pale); display: block; }
.signe-carte .dates { font-family: var(--sans); font-size: .68rem; color: var(--texte-faible); letter-spacing: .06em; margin-top: 4px; display: block; }

/* =========================================================
   Clusters / hubs
   ========================================================= */
.clusters-grille { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin: 40px 0; }
.cluster-carte {
  background: linear-gradient(160deg, rgba(36,16,70,.6), rgba(10,4,24,.7));
  border: 1px solid var(--bordure);
  border-radius: var(--r-lg);
  padding: 34px 28px;
  transition: all .35s;
  position: relative;
}
.cluster-carte:hover { border-color: var(--bordure-or); box-shadow: var(--ombre-douce); transform: translateY(-5px); }
.cluster-carte .icone { font-size: 2rem; color: var(--or); margin-bottom: 16px; }
.cluster-carte h3 { color: var(--or-pale); margin-bottom: 10px; }
.cluster-carte p { font-size: .96rem; margin-bottom: 18px; }
.cluster-carte .lien-fleche { font-family: var(--sans); text-transform: uppercase; letter-spacing: .12em; font-size: .76rem; color: var(--or); }

/* =========================================================
   Heures miroirs (grille spéciale)
   ========================================================= */
.miroirs-grille { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 12px; margin: 30px 0; }
.miroir-tuile {
  background: rgba(22,10,46,.55);
  border: 1px solid var(--bordure);
  border-radius: var(--r-sm);
  padding: 18px 8px;
  text-align: center;
  font-family: var(--titre);
  font-size: 1.5rem;
  color: var(--or-clair);
  transition: all .25s;
  letter-spacing: .04em;
}
.miroir-tuile:hover { background: rgba(60,29,110,.5); border-color: var(--bordure-or); color: var(--or); transform: scale(1.05); }

/* =========================================================
   Horoscope du jour (bloc article)
   ========================================================= */
.horo-jour {
  background: linear-gradient(160deg, rgba(60,29,110,.4), rgba(22,10,46,.55));
  border: 1px solid var(--bordure-or);
  border-radius: var(--r-lg);
  padding: 40px;
  margin: 30px 0;
  position: relative;
}
.horo-jour .date { font-family: var(--sans); letter-spacing: .14em; text-transform: uppercase; font-size: .78rem; color: var(--violet-clair); margin-bottom: 8px; }
.horo-jour .signe-titre { display: flex; align-items: center; gap: 14px; margin-bottom: 22px; }
.horo-jour .signe-titre .symbole { font-size: 2.6rem; color: var(--or); }
.horo-meta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 26px; }
.horo-meta .item { background: rgba(10,4,24,.5); border: 1px solid var(--bordure); border-radius: var(--r-sm); padding: 12px 18px; flex: 1; min-width: 130px; }
.horo-meta .item .label { font-family: var(--sans); font-size: .68rem; text-transform: uppercase; letter-spacing: .1em; color: var(--texte-faible); display: block; margin-bottom: 4px; }
.horo-meta .item .val { font-family: var(--titre); color: var(--or-pale); font-size: 1.05rem; }
.etoiles { color: var(--or); letter-spacing: 3px; }
.etoiles .vide { color: var(--texte-faible); }

/* =========================================================
   Encart outil (mise en avant) & intro de page-hub
   ========================================================= */
.encart-outil {
  background: linear-gradient(135deg, rgba(60,29,110,.5), rgba(36,16,70,.6));
  border: 1px solid var(--bordure-or);
  border-radius: var(--r-md);
  padding: 36px 26px;
  margin: 40px 0;
  text-align: center;
}
.encart-outil h4 { font-family: var(--titre); color: var(--or-pale); margin-bottom: 8px; font-size: 1.4rem; }
.encart-outil p { max-width: 540px; margin: 0 auto 20px; }

.hub-intro { max-width: 760px; margin: 0 auto 30px; text-align: center; }
.hub-intro p { color: var(--texte-doux); }
.hub-outro { max-width: 760px; margin: 40px auto 0; }
.hub-outro p { color: var(--texte-doux); }
.outil-avant { margin-bottom: 10px; }
.outil-apres { margin-top: 30px; }

/* =========================================================
   Blocs "du jour" (home — façon portail divination)
   ========================================================= */
.blocs-jour { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin: 50px 0; }
.bloc-jour {
  background: linear-gradient(160deg, rgba(36,16,70,.6), rgba(10,4,24,.75));
  border: 1px solid var(--bordure-or);
  border-radius: var(--r-lg);
  padding: 30px 26px;
  position: relative;
  display: flex;
  flex-direction: column;
}
.bloc-jour .bloc-titre { font-family: var(--sans); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--violet-clair); margin-bottom: 18px; }
.bloc-jour h3 { color: var(--or-pale); margin-bottom: 10px; }
.bloc-jour p { font-size: .95rem; }
.bloc-jour .btn { margin-top: auto; align-self: flex-start; }

/* Carte tarot du jour */
.carte-tarot-visuel {
  width: 130px; aspect-ratio: 2/3; margin: 0 auto 18px;
  border-radius: 10px;
  background: linear-gradient(160deg, var(--violet-medium), var(--violet-profond));
  border: 1px solid var(--bordure-or);
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem; color: var(--or);
  box-shadow: var(--ombre-or);
}

/* Podium horoscope du jour */
.podium { display: flex; justify-content: center; gap: 14px; margin: 16px 0; }
.podium .place { text-align: center; }
.podium .place .symbole { font-size: 1.8rem; color: var(--or); display: block; }
.podium .place .rang { font-family: var(--sans); font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--texte-faible); }

/* Aspect du jour */
.aspect-planetes { display: flex; align-items: center; justify-content: center; gap: 14px; margin: 14px 0; }
.aspect-planetes .planete { width: 48px; height: 48px; border-radius: 50%; background: rgba(60,29,110,.5); border: 1px solid var(--bordure-or); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; color: var(--or-clair); }
.aspect-planetes .lien-aspect { color: var(--violet-clair); font-size: 1.4rem; }

@media (max-width: 880px) { .blocs-jour { grid-template-columns: 1fr; } }
.layout-deux-cols { display: grid; grid-template-columns: 1fr 320px; gap: 48px; margin: 50px 0; align-items: start; }
.contenu-principal { min-width: 0; }
.sidebar { position: sticky; top: 90px; }
.widget { background: linear-gradient(160deg, rgba(36,16,70,.45), rgba(10,4,24,.5)); border: 1px solid var(--bordure); border-radius: var(--r-md); padding: 24px; margin-bottom: 26px; }
.widget-title { font-family: var(--titre); color: var(--or-pale); font-size: 1.15rem; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--bordure); }
.widget ul { list-style: none; }
.widget li { padding: 7px 0; border-bottom: 1px solid var(--bordure); }
.widget li:last-child { border-bottom: none; }

/* Article single */
.article-corps { font-size: 1.08rem; }
.article-corps h2 { margin: 38px 0 16px; color: var(--or-pale); }
.article-corps h3 {
  margin: 30px 0 12px;
  color: var(--or-clair);
  font-size: 1.3rem;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--bordure);
}
.article-corps h3:first-child { margin-top: 0; }
.article-corps p strong { color: var(--or-pale); }
/* Conseil/mantra de fin : dernier paragraphe en gras mis en valeur */
.horo-jour .article-corps p:last-child strong,
.article-corps > p:last-child strong {
  display: block;
  margin-top: 18px;
  padding: 16px 20px;
  background: linear-gradient(135deg, rgba(60,29,110,.45), rgba(212,175,107,.12));
  border-left: 3px solid var(--or);
  border-radius: var(--r-sm);
  color: var(--or-pale);
  font-style: italic;
}
.article-corps ul, .article-corps ol { margin: 0 0 1.2rem 1.4rem; color: var(--texte-doux); }
.article-corps blockquote { border-left: 3px solid var(--or); padding-left: 22px; margin: 26px 0; font-style: italic; color: var(--argent); }
.entry-thumb { border-radius: var(--r-md); margin-bottom: 30px; border: 1px solid var(--bordure); }

/* Fil d'ariane */
.ariane { font-family: var(--sans); font-size: .76rem; letter-spacing: .06em; color: var(--texte-faible); padding: 20px 0; text-transform: uppercase; }
.ariane a { color: var(--violet-clair); }
.ariane .sep { margin: 0 8px; color: var(--bordure-or); }

/* Cartes articles (archive) */
.articles-grille { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 28px; }
.article-carte { background: linear-gradient(160deg, rgba(36,16,70,.4), rgba(10,4,24,.5)); border: 1px solid var(--bordure); border-radius: var(--r-md); overflow: hidden; transition: all .3s; }
.article-carte:hover { border-color: var(--bordure-or); transform: translateY(-4px); box-shadow: var(--ombre-douce); }
.article-carte .vignette { aspect-ratio: 16/10; object-fit: cover; width: 100%; }
.article-carte .carte-corps { padding: 22px; }
.article-carte h3 { font-size: 1.2rem; margin-bottom: 8px; }
.article-carte .extrait { font-size: .92rem; color: var(--texte-doux); }
.article-carte .carte-meta { font-family: var(--sans); font-size: .7rem; text-transform: uppercase; letter-spacing: .1em; color: var(--texte-faible); margin-top: 14px; }

/* =========================================================
   Footer
   ========================================================= */
.site-footer { border-top: 1px solid var(--bordure); margin-top: 80px; padding: 56px 24px 30px; background: rgba(10,4,24,.6); }
.footer-grille { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; max-width: var(--max); margin: 0 auto 40px; }
.footer-col h4 { font-family: var(--titre); color: var(--or-pale); font-size: 1rem; margin-bottom: 16px; letter-spacing: .08em; }
.footer-col ul { list-style: none; }
.footer-col li { padding: 5px 0; }
.footer-col a { color: var(--texte-doux); font-size: .92rem; }
.footer-bas { text-align: center; padding-top: 24px; border-top: 1px solid var(--bordure); color: var(--texte-faible); font-family: var(--sans); font-size: .78rem; letter-spacing: .06em; max-width: var(--max); margin: 0 auto; }

/* Pagination */
.pagination { display: flex; justify-content: center; gap: 8px; margin: 50px 0; }
.pagination .page-numbers { padding: 10px 16px; border: 1px solid var(--bordure); border-radius: var(--r-sm); color: var(--texte-doux); font-family: var(--sans); }
.pagination .page-numbers.current, .pagination .page-numbers:hover { background: var(--or); color: var(--noir-cosmos); border-color: var(--or); }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 920px) {
  .layout-deux-cols { grid-template-columns: 1fr; }
  .sidebar { position: static; }
  .clusters-grille { grid-template-columns: repeat(2, 1fr); }
  .zodiaque-grille { grid-template-columns: repeat(4, 1fr); }
  .footer-grille { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .menu-toggle { display: block; }
  .header-inner { flex-wrap: wrap; }
  .main-nav {
    display: none;
    flex-basis: 100%;
    width: 100%;
    margin-top: 12px;
    max-height: 78vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .main-nav.ouvert { display: block; }
  .mega-nav { flex-direction: column; gap: 0; padding: 0; align-items: stretch; width: 100%; }
  .mega-item { position: static; border-bottom: 1px solid var(--bordure); }
  .mega-toggle {
    padding: 16px 4px;
    justify-content: space-between;
    font-size: .9rem;
    width: 100%;
  }
  .mega-item:hover .caret { transform: none; }
  .mega-item.ouvert .caret { transform: rotate(180deg); }
  /* Panneau en accordéon : on neutralise tout le positionnement desktop */
  .mega-panneau {
    position: static;
    left: auto;
    right: auto;
    width: 100%;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    box-shadow: none;
    border: none;
    border-radius: 0;
    background: rgba(10,4,24,.35);
    padding: 0;
    margin: 0 0 8px;
    display: none;
    transition: none;
  }
  .mega-panneau::before { display: none; }
  .mega-item:hover .mega-panneau { display: none; } /* le survol ne déclenche rien sur mobile */
  .mega-item.ouvert .mega-panneau { display: block; }
  .mega-hub {
    padding: 12px 16px;
    margin: 0;
    border-bottom: 1px solid var(--bordure);
  }
  .mega-col { width: 100%; padding: 0; gap: 0; }
  .mega-col li { padding: 0; border-bottom: 1px solid var(--bordure); }
  .mega-col li:last-child { border-bottom: none; }
  .mega-col a {
    display: block;
    padding: 13px 16px;
    font-size: .92rem;
    white-space: normal;
    color: var(--texte-doux);
  }
}
@media (max-width: 600px) {
  .clusters-grille { grid-template-columns: 1fr; }
  .zodiaque-grille { grid-template-columns: repeat(3, 1fr); }
  .footer-grille { grid-template-columns: 1fr; }
  .horo-jour { padding: 26px; }
}

/* =========================================================
   Outils interactifs (thème astral, tarot, numérologie…)
   ========================================================= */
.astralys-outil { margin: 40px 0; }
.ao-titre { text-align: center; margin-bottom: 26px; }
.ao-titre .glyph { color: var(--or); }

.ao-form {
  background: linear-gradient(160deg, rgba(36,16,70,.5), rgba(10,4,24,.6));
  border: 1px solid var(--bordure);
  border-radius: var(--r-md);
  padding: 26px;
  display: grid;
  gap: 16px;
}
.ao-champ { display: flex; flex-direction: column; gap: 6px; font-family: var(--sans); font-size: .82rem; letter-spacing: .04em; color: var(--texte-doux); }
.ao-champ input, .ao-champ select {
  padding: 12px 14px;
  background: rgba(10,4,24,.6);
  border: 1px solid var(--bordure);
  border-radius: var(--r-sm);
  color: var(--texte);
  font-family: var(--corps);
  font-size: 1rem;
}
.ao-champ input:focus, .ao-champ select:focus { outline: none; border-color: var(--or); }
.ao-aide { font-size: .8rem; color: var(--texte-faible); font-style: italic; margin: 0; }

.ao-actions { text-align: center; margin: 22px 0; }

/* Autocomplétion ville */
.ao-champ-ville { position: relative; }
.ao-suggestions {
  position: absolute;
  top: 100%; left: 0; right: 0;
  z-index: 50;
  background: var(--violet-nuit);
  border: 1px solid var(--bordure-or);
  border-radius: var(--r-sm);
  margin-top: 4px;
  max-height: 240px;
  overflow-y: auto;
  box-shadow: var(--ombre-douce);
}
.ao-suggestion {
  padding: 10px 14px;
  font-family: var(--corps);
  font-size: .92rem;
  color: var(--texte-doux);
  cursor: pointer;
  border-bottom: 1px solid var(--bordure);
}
.ao-suggestion:last-child { border-bottom: none; }
.ao-suggestion:hover { background: rgba(60,29,110,.5); color: var(--or-clair); }
.ao-ville-ok { font-family: var(--sans); font-size: .76rem; color: #7fd4a8; margin-top: 4px; }

.ao-resultat:empty { display: none; }
.ao-resultat {
  background: linear-gradient(160deg, rgba(60,29,110,.4), rgba(22,10,46,.55));
  border: 1px solid var(--bordure-or);
  border-radius: var(--r-lg);
  padding: 34px;
  margin-top: 10px;
  text-align: center;
  animation: ao-apparition .5s ease;
}
@keyframes ao-apparition { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.ao-resultat h3 { color: var(--or-pale); margin: 14px 0 8px; }
.ao-resultat p { color: var(--texte-doux); text-align: left; }
.ao-meta { text-align: center !important; font-family: var(--sans); font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; color: var(--violet-clair); }

.ao-sceau {
  width: 90px; height: 90px; margin: 0 auto 8px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 40%, var(--violet-medium), var(--violet-profond));
  border: 1px solid var(--bordure-or);
  display: flex; align-items: center; justify-content: center;
  font-size: 2.6rem; color: var(--or);
  box-shadow: var(--ombre-or);
}
.ao-heure-sceau { font-family: var(--titre); font-size: 1.6rem; }

/* Positions planétaires (thème astral) */
.ao-positions { margin: 16px 0; text-align: left; }
.ao-ligne { display: flex; align-items: center; gap: 12px; padding: 8px 0; border-bottom: 1px solid var(--bordure); }
.ao-ligne .ao-sym { width: 30px; font-size: 1.3rem; color: var(--or); text-align: center; }
.ao-ligne .ao-nom { flex: 1; font-family: var(--titre); color: var(--or-pale); }
.ao-ligne .ao-val { font-family: var(--corps); color: var(--texte-doux); }
.ao-ligne .ao-val em { color: var(--violet-clair); font-style: normal; font-size: .8rem; }
.ao-ligne.ao-special .ao-sym { font-family: var(--sans); font-size: .7rem; color: var(--or-clair); }

.ao-aspects { text-align: left; margin-top: 8px; }
.ao-aspect { padding: 8px 0; border-bottom: 1px solid var(--bordure); font-size: .92rem; color: var(--texte-doux); }
.ao-aspect strong { color: var(--or-clair); }

/* Duo (compatibilité) */
.ao-duo { display: flex; align-items: center; justify-content: center; gap: 18px; font-size: 2.4rem; color: var(--or); margin-bottom: 6px; }
.ao-duo .ao-coeur { color: #e0719a; font-size: 1.6rem; }

/* Cartes de tarot */
.ao-cartes { display: flex; flex-wrap: wrap; gap: 18px; justify-content: center; margin-top: 10px; }
.ao-carte {
  background: linear-gradient(160deg, rgba(36,16,70,.7), rgba(10,4,24,.8));
  border: 1px solid var(--bordure-or);
  border-radius: var(--r-md);
  padding: 20px;
  max-width: 240px;
  text-align: center;
}
.ao-carte-petite { flex: 1; min-width: 180px; max-width: 220px; }
.ao-carte.renversee .ao-carte-visuel { transform: rotate(180deg); }
.ao-carte-label { font-family: var(--sans); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--violet-clair); display: block; margin-bottom: 8px; }
.ao-carte-visuel {
  width: 70px; height: 110px; margin: 0 auto 12px;
  border-radius: 8px;
  background: linear-gradient(160deg, var(--violet-medium), var(--violet-profond));
  border: 1px solid var(--bordure-or);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--titre); font-size: 1.8rem; color: var(--or);
}
.ao-carte h4 { font-family: var(--titre); color: var(--or-pale); margin-bottom: 6px; font-size: 1.05rem; }
.ao-carte h4 em { color: var(--violet-clair); font-size: .8rem; }
.ao-carte p { font-size: .88rem; text-align: center !important; }

/* Réponse oui/non */
.ao-reponse { font-family: var(--titre); font-size: 2.6rem; margin-bottom: 18px; }
.ao-reponse.ao-oui { color: #7fd4a8; }
.ao-reponse.ao-non { color: #e0719a; }
.ao-reponse.ao-peutetre { color: var(--or-clair); }

.ao-erreur { color: #e0a0b4; text-align: center; padding: 14px; font-style: italic; }

/* Métas horoscope du jour */
.ao-horo-meta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 22px; }
.ao-horo-meta .item { flex: 1; min-width: 120px; background: rgba(10,4,24,.5); border: 1px solid var(--bordure); border-radius: var(--r-sm); padding: 12px 16px; text-align: center; }
.ao-horo-meta .label { font-family: var(--sans); font-size: .64rem; text-transform: uppercase; letter-spacing: .1em; color: var(--texte-faible); display: block; margin-bottom: 4px; }
.ao-horo-meta .val { font-family: var(--titre); color: var(--or-pale); font-size: 1rem; }
@media (max-width: 600px) { .ao-horo-meta .item { min-width: calc(50% - 6px); } }

/* =========================================================
   Responsive — renforcement mobile
   ========================================================= */
@media (max-width: 760px) {
  .ao-cartes { gap: 14px; }
  .ao-carte, .ao-carte-petite { max-width: 100%; min-width: 0; flex: 1 1 100%; }
}

@media (max-width: 600px) {
  body { font-size: 17px; }
  .container { padding: 0 16px; }
  .header-inner { padding: 14px 16px; }
  .site-logo { font-size: 1.3rem; }
  .hero { padding: 56px 16px 44px; }
  .blocs-jour { gap: 16px; margin: 32px 0; }
  .bloc-jour { padding: 24px 20px; }
  .articles-grille { grid-template-columns: 1fr; }
  .miroirs-grille { grid-template-columns: repeat(auto-fill, minmax(88px, 1fr)); gap: 8px; }
  .miroir-tuile { font-size: 1.2rem; padding: 14px 6px; }
  /* Outils */
  .ao-form { padding: 18px; }
  .ao-resultat { padding: 22px 18px; }
  .ao-sceau { width: 72px; height: 72px; font-size: 2rem; }
  .ao-ligne { gap: 8px; flex-wrap: wrap; }
  .ao-ligne .ao-nom { flex: 1 1 auto; font-size: .95rem; }
  .ao-ligne .ao-val { font-size: .85rem; width: 100%; padding-left: 42px; }
  .ao-duo { font-size: 2rem; gap: 12px; }
  .ao-reponse { font-size: 2.1rem; }
  .ao-titre { font-size: 1.5rem; }
}

@media (max-width: 420px) {
  body { font-size: 16px; }
  h1 { font-size: clamp(1.7rem, 8vw, 2.2rem); }
  .zodiaque-grille { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .signe-carte .symbole { font-size: 1.8rem; }
  .miroirs-grille { grid-template-columns: repeat(3, 1fr); }
  .btn { padding: 12px 22px; font-size: .76rem; }
  .ao-ligne .ao-val { padding-left: 0; }
}

/* Évite tout débordement horizontal sur petits écrans */
@media (max-width: 600px) {
  img, table, pre { max-width: 100%; }
  .article-corps { overflow-wrap: break-word; }
}

/* =========================================================
   Commentaires
   ========================================================= */
.commentaires { margin: 56px 0 20px; }
.commentaires-titre { display: flex; align-items: center; gap: 10px; font-size: 1.5rem; margin-bottom: 28px; }
.commentaires-titre .glyph { color: var(--or); font-size: 1.2rem; }

.commentaires-liste { list-style: none; margin: 0 0 36px; padding: 0; }
.commentaires-liste .children { list-style: none; margin: 18px 0 0; padding-left: 28px; border-left: 1px solid var(--bordure); }

.commentaire { margin-bottom: 18px; }
.commentaire-corps {
  background: linear-gradient(160deg, rgba(36,16,70,.45), rgba(10,4,24,.5));
  border: 1px solid var(--bordure);
  border-radius: var(--r-md);
  padding: 20px 22px;
}
.commentaire-tete { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.commentaire-avatar img { border-radius: 50%; border: 1px solid var(--bordure-or); display: block; }
.commentaire-meta { display: flex; flex-direction: column; }
.commentaire-auteur { font-family: var(--titre); color: var(--or-pale); font-size: 1.05rem; }
.commentaire-date { font-family: var(--sans); font-size: .72rem; letter-spacing: .06em; text-transform: uppercase; color: var(--texte-faible); }
.commentaire-texte { color: var(--texte-doux); }
.commentaire-texte p { color: var(--texte-doux); }
.commentaire-attente { color: var(--or-clair); font-style: italic; font-size: .9rem; }
.commentaire-actions { margin-top: 10px; }
.commentaire-actions a, .comment-reply-link {
  font-family: var(--sans); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase;
  color: var(--violet-clair);
}
.commentaire-actions a:hover, .comment-reply-link:hover { color: var(--or); }

/* Formulaire de commentaire */
.comment-respond {
  background: linear-gradient(160deg, rgba(36,16,70,.5), rgba(10,4,24,.6));
  border: 1px solid var(--bordure);
  border-radius: var(--r-lg);
  padding: 30px;
  margin-top: 30px;
}
.comment-reply-title { display: flex; align-items: center; gap: 10px; font-size: 1.4rem; margin-bottom: 18px; }
.comment-reply-title .glyph { color: var(--or); font-size: 1.1rem; }
.comment-reply-title small { margin-left: 10px; font-size: .8rem; }
.comment-form { display: grid; gap: 16px; }
.comment-form p { margin: 0; }
.comment-form label {
  display: block; margin-bottom: 6px;
  font-family: var(--sans); font-size: .8rem; letter-spacing: .04em; color: var(--texte-doux);
}
.comment-form .requis { color: var(--or); }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
  width: 100%;
  padding: 12px 14px;
  background: rgba(10,4,24,.6);
  border: 1px solid var(--bordure);
  border-radius: var(--r-sm);
  color: var(--texte);
  font-family: var(--corps);
  font-size: 1rem;
}
.comment-form input:focus, .comment-form textarea:focus { outline: none; border-color: var(--or); }
.comment-form textarea { resize: vertical; min-height: 120px; }
.comment-form .comment-form-author,
.comment-form .comment-form-email { display: inline-block; width: calc(50% - 8px); vertical-align: top; }
.comment-form .comment-form-email { margin-left: 12px; }
.comment-form .form-submit { margin-top: 6px; }
.comment-notes, .comment-form-cookies-consent label { font-size: .82rem; color: var(--texte-faible); }
.comment-form-cookies-consent { display: flex; align-items: center; gap: 10px; }
.comment-form-cookies-consent input { width: auto !important; }

.commentaires-fermes { text-align: center; color: var(--texte-faible); font-style: italic; padding: 16px 0; }

@media (max-width: 600px) {
  .comment-respond { padding: 20px; }
  .comment-form .comment-form-author,
  .comment-form .comment-form-email { display: block; width: 100%; margin-left: 0; }
  .commentaires-liste .children { padding-left: 14px; }
  .commentaire-corps { padding: 16px; }
}

/* =========================================================
   FAQ (page d'accueil)
   ========================================================= */
.faq-accueil { margin: 64px 0 20px; }
.faq-liste { max-width: 820px; margin: 0 auto; }
.faq-item {
  background: linear-gradient(160deg, rgba(36,16,70,.45), rgba(10,4,24,.5));
  border: 1px solid var(--bordure);
  border-radius: var(--r-md);
  margin-bottom: 14px;
  overflow: hidden;
}
.faq-item[open] { border-color: var(--bordure-or); }
.faq-question {
  cursor: pointer;
  padding: 20px 24px;
  font-family: var(--titre);
  font-size: 1.12rem;
  color: var(--or-pale);
  list-style: none;
  position: relative;
  padding-right: 50px;
  transition: color .2s;
}
.faq-question::-webkit-details-marker { display: none; }
.faq-question::after {
  content: "+";
  position: absolute;
  right: 22px; top: 50%;
  transform: translateY(-50%);
  font-size: 1.5rem;
  color: var(--or);
  transition: transform .25s;
}
.faq-item[open] .faq-question::after { content: "\2212"; }
.faq-question:hover { color: var(--or); }
.faq-reponse { padding: 0 24px 22px; }
.faq-reponse p { color: var(--texte-doux); margin-bottom: .8rem; }
.faq-reponse p:last-child { margin-bottom: 0; }

@media (max-width: 600px) {
  .faq-question { padding: 16px 44px 16px 18px; font-size: 1.02rem; }
  .faq-reponse { padding: 0 18px 18px; }
}

/* =========================================================
   Archive d'un signe (filtres + badges)
   ========================================================= */
.signe-filtres { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin: 24px 0 36px; }
.signe-filtre {
  font-family: var(--sans);
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 9px 18px;
  border: 1px solid var(--bordure);
  border-radius: 40px;
  color: var(--texte-doux);
  transition: all .2s;
}
.signe-filtre:hover { border-color: var(--bordure-or); color: var(--or-clair); }
.signe-filtre.actif { background: linear-gradient(135deg, var(--or), var(--or-clair)); color: var(--noir-cosmos); border-color: var(--or); }
.carte-badge {
  display: inline-block;
  font-family: var(--sans);
  font-size: .64rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--violet-clair);
  border: 1px solid var(--bordure);
  border-radius: 30px;
  padding: 3px 10px;
  margin-bottom: 10px;
}

/* =========================================================
   Vignettes de sous-catégories (rubrique)
   ========================================================= */
.rubrique-vignettes {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 18px;
  margin: 30px 0;
}
.vignette-cat {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 26px 24px;
  border-radius: var(--r-md);
  background: linear-gradient(160deg, rgba(36,16,70,.55), rgba(10,4,24,.55));
  border: 1px solid var(--bordure);
  transition: border-color .25s, transform .25s;
}
.vignette-cat:hover { border-color: var(--bordure-or); transform: translateY(-3px); }
.vignette-glyph { font-size: 2rem; color: var(--or); }
.vignette-titre { font-family: var(--titre); font-size: 1.3rem; color: var(--or-pale); }
.vignette-desc { font-size: .92rem; color: var(--texte-doux); flex-grow: 1; }
.vignette-fleche { font-family: var(--sans); font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: var(--violet-clair); margin-top: 6px; }
.vignette-cat:hover .vignette-fleche { color: var(--or); }

/* =========================================================
   Bloc auteur (sous les articles)
   ========================================================= */
.bloc-auteur {
  display: flex;
  gap: 22px;
  align-items: center;
  margin: 44px 0;
  padding: 28px 30px;
  border-radius: var(--r-lg);
  background: linear-gradient(160deg, rgba(36,16,70,.6), rgba(10,4,24,.6));
  border: 1px solid var(--bordure-or);
  box-shadow: var(--ombre-douce);
}
.bloc-auteur-avatar {
  flex-shrink: 0;
  width: 92px;
  height: 92px;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid var(--or);
  box-shadow: 0 0 0 4px rgba(212,175,107,.15);
}
.bloc-auteur-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 50%;
}
.bloc-auteur-eyebrow { font-family: var(--sans); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--texte-faible); }
.bloc-auteur-nom { font-family: var(--titre); font-size: 1.4rem; margin: 4px 0 8px; }
.bloc-auteur-nom a { color: var(--or-pale); }
.bloc-auteur-nom a:hover { color: var(--or); }
.bloc-auteur-bio { color: var(--texte-doux); margin-bottom: 10px; line-height: 1.6; }
.bloc-auteur-lien { font-family: var(--sans); font-size: .76rem; letter-spacing: .1em; text-transform: uppercase; color: var(--violet-clair); }
.bloc-auteur-lien:hover { color: var(--or); }
@media (max-width: 600px) { .bloc-auteur { flex-direction: column; align-items: center; text-align: center; padding: 24px; } }

/* Profil auteur */
.profil-auteur { text-align: center; padding: 56px 20px 20px; }
.profil-avatar img { border-radius: 50%; border: 2px solid var(--bordure-or); margin-bottom: 16px; }
.profil-nom { font-size: 2rem; }
.profil-bio { max-width: 600px; margin: 10px auto 0; color: var(--texte-doux); }

/* =========================================================
   Heures miroirs — cartes
   ========================================================= */
.hero-miroirs { padding: 64px 24px 30px; text-align: center; }
.miroirs-cartes {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 18px;
  margin: 30px 0;
}
.miroir-carte {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 28px 24px;
  border-radius: var(--r-md);
  background: linear-gradient(160deg, rgba(36,16,70,.5), rgba(10,4,24,.6));
  border: 1px solid var(--bordure);
  position: relative;
  overflow: hidden;
  transition: border-color .25s, transform .25s;
}
.miroir-carte::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% -10%, rgba(212,175,107,.18), transparent 60%);
  opacity: 0;
  transition: opacity .3s;
}
.miroir-carte:hover { border-color: var(--bordure-or); transform: translateY(-4px); }
.miroir-carte:hover::before { opacity: 1; }
.miroir-heure {
  font-family: var(--titre);
  font-size: 2.4rem;
  color: var(--or-pale);
  letter-spacing: .04em;
}
.miroir-extrait { font-size: .9rem; color: var(--texte-doux); flex-grow: 1; line-height: 1.5; }
.miroir-plus { font-family: var(--sans); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--violet-clair); }
.miroir-carte:hover .miroir-plus { color: var(--or); }

/* =========================================================
   Heures miroirs — page unique (sommaire + accordéon)
   ========================================================= */
.miroirs-sommaire { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin: 24px 0 36px; }
.miroir-puce {
  font-family: var(--titre);
  font-size: 1rem;
  padding: 8px 14px;
  border-radius: 30px;
  border: 1px solid var(--bordure);
  color: var(--or-pale);
  transition: all .2s;
}
.miroir-puce:hover { border-color: var(--or); background: rgba(60,29,110,.4); color: var(--or); }

.miroirs-liste-complete { max-width: 820px; margin: 0 auto 30px; }
.miroir-item {
  background: linear-gradient(160deg, rgba(36,16,70,.45), rgba(10,4,24,.5));
  border: 1px solid var(--bordure);
  border-radius: var(--r-md);
  margin-bottom: 12px;
  overflow: hidden;
  scroll-margin-top: 90px;
}
.miroir-item[open] { border-color: var(--bordure-or); }
.miroir-item-titre {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  padding: 18px 24px;
  list-style: none;
}
.miroir-item-titre::-webkit-details-marker { display: none; }
.miroir-item-heure { font-family: var(--titre); font-size: 1.6rem; color: var(--or-pale); letter-spacing: .04em; }
.miroir-item-plus { font-size: 1.6rem; color: var(--or); transition: transform .25s; }
.miroir-item[open] .miroir-item-plus { transform: rotate(45deg); }
.miroir-item-corps { padding: 0 24px 22px; }
.miroir-item-corps p { color: var(--texte-doux); }
.miroir-item-lien { font-family: var(--sans); font-size: .74rem; letter-spacing: .1em; text-transform: uppercase; color: var(--violet-clair); }
.miroir-item-lien:hover { color: var(--or); }
@media (max-width: 600px) {
  .miroir-item-titre { padding: 14px 18px; }
  .miroir-item-corps { padding: 0 18px 18px; }
}

/* Bloc SEO en bas de page catégorie */
.seo-bas-page {
  max-width: 820px;
  margin: 50px auto 0;
  padding-top: 30px;
  border-top: 1px solid var(--bordure);
  color: var(--texte-doux);
}
.seo-bas-page h2, .seo-bas-page h3 { color: var(--or-clair); }
