/*
Theme Name: Astrologie Spirituelle
Theme URI: https://astrologiespirituelle.com/
Author: Astrologie Spirituelle
Author URI: https://astrologiespirituelle.com/
Description: Thème WordPress sur-mesure pour un site d'astrologie spirituelle. Design épuré et mystique (bleu nuit & or), responsive, optimisé pour le SEO et la prise de rendez-vous en ligne.
Version: 1.1.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: astrologie-spirituelle
*/

/* ============================================================
   VARIABLES & RESET
   ============================================================ */
:root{
  /* Palette calée sur le logo : bleu nuit marine + or */
  --as-nuit:#1b2238;       /* bleu nuit du logo */
  --as-nuit-2:#252e4a;     /* bleu nuit clair (dégradés) */
  --as-violet:#34406a;     /* bleu acier (accent secondaire) */
  --as-lavande:#c4cbe0;    /* bleu très clair (texte sur fond nuit) */
  --as-or:#c2a05a;         /* or du logo */
  --as-or-clair:#e0c489;   /* or clair */
  --as-creme:#faf8f3;
  --as-creme-2:#f1ece0;
  --as-texte:#1f2433;
  --as-texte-doux:#555d72;
  --as-blanc:#ffffff;
  --as-radius:16px;
  --as-radius-sm:10px;
  --as-shadow:0 18px 45px -25px rgba(27,19,64,.55);
  --as-max:1180px;
  --as-serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --as-sans:"Jost","Helvetica Neue",Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--as-sans);
  font-size:18px;
  line-height:1.7;
  color:var(--as-texte);
  background:var(--as-creme);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--as-violet);text-decoration:none;transition:color .2s ease;}
a:hover{color:var(--as-nuit);}

h1,h2,h3,h4{font-family:var(--as-serif);font-weight:600;line-height:1.15;color:var(--as-nuit);margin:0 0 .5em;}
h1{font-size:clamp(2.4rem,5vw,3.7rem);}
h2{font-size:clamp(1.9rem,3.6vw,2.7rem);}
h3{font-size:clamp(1.4rem,2.4vw,1.8rem);}
p{margin:0 0 1.1em;}

/* ============================================================
   LAYOUT
   ============================================================ */
.as-container{width:100%;max-width:var(--as-max);margin:0 auto;padding:0 22px;}
.as-section{padding:80px 0;}
.as-section--tight{padding:56px 0;}
.as-narrow{max-width:760px;margin:0 auto;}
.as-center{text-align:center;}
.as-eyebrow{
  font-family:var(--as-sans);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.78rem;
  font-weight:600;
  color:var(--as-or);
  margin:0 0 .8em;
  display:block;
}
.as-lead{font-size:1.18rem;color:var(--as-texte-doux);}

/* ============================================================
   BOUTONS
   ============================================================ */
.as-btn,
.wp-block-button__link{
  display:inline-block;
  font-family:var(--as-sans);
  font-weight:600;
  letter-spacing:.02em;
  padding:15px 34px;
  border-radius:999px;
  background:var(--as-nuit);
  color:var(--as-blanc)!important;
  border:1.5px solid var(--as-nuit);
  cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
}
.as-btn:hover,
.wp-block-button__link:hover{
  background:var(--as-nuit-2);
  color:#fff!important;
  transform:translateY(-2px);
  box-shadow:var(--as-shadow);
}
.as-btn--or{
  background:linear-gradient(120deg,var(--as-or),var(--as-or-clair));
  border-color:var(--as-or);
  color:var(--as-nuit)!important;
}
.as-btn--or:hover{color:var(--as-nuit)!important;background:var(--as-or-clair);}
.as-btn--ghost{background:transparent;color:var(--as-nuit)!important;border-color:var(--as-nuit);}
.as-btn--ghost:hover{background:var(--as-nuit);color:#fff!important;}

/* ============================================================
   HEADER
   ============================================================ */
.as-header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,247,240,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(27,19,64,.08);
}
.as-header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 0;}
.as-logo{font-family:var(--as-serif);font-size:1.5rem;font-weight:600;color:var(--as-nuit);line-height:1.1;}
.as-logo span{display:block;font-family:var(--as-sans);font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:var(--as-or);}
.as-logo img{max-height:120px;width:auto;}
.as-logo a{display:inline-block;line-height:0;}
.as-header__inner{padding:8px 0;}
@media(max-width:720px){.as-logo img{max-height:84px;}}
.as-nav ul{list-style:none;display:flex;gap:30px;margin:0;padding:0;align-items:center;}
.as-nav a{font-family:var(--as-sans);font-weight:500;color:var(--as-texte);font-size:1rem;}
.as-nav a:hover,.as-nav .current-menu-item>a{color:var(--as-or);}
.as-nav .as-cta-li a{
  background:var(--as-nuit);color:#fff;padding:10px 22px;border-radius:999px;
}
.as-nav .as-cta-li a:hover{background:var(--as-nuit-2);color:#fff;}
.as-burger{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.as-burger span{display:block;width:26px;height:2px;background:var(--as-nuit);margin:5px 0;transition:.3s;}

/* ============================================================
   HERO
   ============================================================ */
.as-hero{
  position:relative;
  background:
    radial-gradient(circle at 20% 20%,rgba(52,64,106,.65),transparent 45%),
    radial-gradient(circle at 80% 70%,rgba(194,160,90,.26),transparent 50%),
    linear-gradient(160deg,var(--as-nuit) 0%,var(--as-nuit-2) 100%);
  color:#fff;
  overflow:hidden;
  text-align:center;
  padding:110px 0 120px;
}
.as-hero::after{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(2px 2px at 15% 30%,rgba(255,255,255,.6),transparent),
    radial-gradient(1.5px 1.5px at 60% 20%,rgba(255,255,255,.5),transparent),
    radial-gradient(2px 2px at 80% 60%,rgba(255,255,255,.45),transparent),
    radial-gradient(1px 1px at 35% 75%,rgba(255,255,255,.5),transparent),
    radial-gradient(1.5px 1.5px at 90% 35%,rgba(255,255,255,.4),transparent);
  pointer-events:none;opacity:.7;
}
.as-hero__video{
  position:absolute!important;
  top:0;left:0;
  width:100%!important;
  height:100%!important;
  min-height:100%;
  object-fit:cover!important;
  object-position:center!important;
  display:block;
  margin:0;
  z-index:0;
  pointer-events:none;
}
.as-hero__overlay{
  position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;
  background:linear-gradient(160deg,rgba(27,34,56,.78),rgba(37,46,74,.66));
}
.as-hero .as-container{position:relative;z-index:3;}
.as-hero h1{color:#fff;max-width:18ch;margin-left:auto;margin-right:auto;}
.as-hero .as-eyebrow{color:var(--as-or-clair);}
.as-hero p{color:var(--as-lavande);font-size:1.22rem;max-width:60ch;margin:0 auto 2em;}
.as-hero__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* ============================================================
   CARTES / GRILLES
   ============================================================ */
.as-grid{display:grid;gap:26px;}
.as-grid--3{grid-template-columns:repeat(3,1fr);}
.as-grid--2{grid-template-columns:repeat(2,1fr);}
.as-card{
  background:var(--as-blanc);
  border:1px solid rgba(27,19,64,.07);
  border-radius:var(--as-radius);
  padding:34px 30px;
  box-shadow:0 12px 30px -22px rgba(27,19,64,.4);
  transition:transform .25s ease,box-shadow .25s ease;
}
.as-card:hover{transform:translateY(-4px);box-shadow:var(--as-shadow);}
.as-card__icon{font-size:2rem;color:var(--as-or);margin-bottom:.4em;}
.as-card h3{margin-bottom:.4em;}
.as-card p{color:var(--as-texte-doux);margin-bottom:0;}

/* Bandeau "consultation gratuite" */
.as-band{
  background:linear-gradient(120deg,var(--as-nuit),var(--as-violet));
  color:#fff;border-radius:var(--as-radius);
  padding:54px 48px;text-align:center;
}
.as-band h2{color:#fff;}
.as-band p{color:var(--as-lavande);max-width:60ch;margin:0 auto 1.6em;}

/* Étapes */
.as-steps{counter-reset:step;display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.as-step{position:relative;padding-top:14px;}
.as-step::before{
  counter-increment:step;content:counter(step);
  display:flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(120deg,var(--as-or),var(--as-or-clair));
  color:var(--as-nuit);font-family:var(--as-serif);font-size:1.4rem;font-weight:700;
  margin-bottom:18px;
}

/* ============================================================
   CONTENU EDITORIAL (pages standard)
   ============================================================ */
.as-page-head{
  background:linear-gradient(160deg,var(--as-nuit),var(--as-nuit-2));
  color:#fff;text-align:center;padding:90px 0 80px;
}
.as-page-head h1{color:#fff;}
.as-page-head p{color:var(--as-lavande);max-width:62ch;margin:0 auto;}
.as-content{padding:70px 0;}
.as-content .as-narrow > *:first-child{margin-top:0;}
.as-content h2{margin-top:1.6em;}
.as-content ul,.as-content ol{padding-left:1.2em;margin-bottom:1.3em;}
.as-content li{margin-bottom:.5em;}
.as-faq details{
  border:1px solid rgba(27,19,64,.1);border-radius:var(--as-radius-sm);
  padding:18px 22px;margin-bottom:14px;background:#fff;
}
.as-faq summary{font-family:var(--as-serif);font-size:1.25rem;color:var(--as-nuit);cursor:pointer;font-weight:600;}
.as-faq summary::-webkit-details-marker{display:none;}

/* Calendly */
.as-calendly{min-height:720px;width:100%;}

/* ============================================================
   FOOTER
   ============================================================ */
.as-footer{background:var(--as-nuit);color:var(--as-lavande);padding:64px 0 28px;}
.as-footer a{color:var(--as-lavande);}
.as-footer a:hover{color:var(--as-or-clair);}
.as-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;}
.as-footer h4{color:#fff;font-family:var(--as-sans);text-transform:uppercase;letter-spacing:.16em;font-size:.82rem;margin-bottom:1.1em;}
.as-footer ul{list-style:none;padding:0;margin:0;}
.as-footer li{margin-bottom:.6em;}
.as-footer__brand{font-family:var(--as-serif);font-size:1.5rem;color:#fff;margin-bottom:.4em;}
.as-footer__bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:44px;padding-top:22px;font-size:.85rem;text-align:center;color:rgba(207,198,240,.7);}

/* ============================================================
   WORDPRESS DÉFAUTS
   ============================================================ */
.alignwide{max-width:1100px;margin-left:auto;margin-right:auto;}
.alignfull{max-width:none;}
.wp-block-image img{border-radius:var(--as-radius-sm);}
blockquote{border-left:3px solid var(--as-or);padding-left:22px;font-family:var(--as-serif);font-size:1.3rem;color:var(--as-nuit);font-style:italic;}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);height:1px;width:1px;overflow:hidden;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:900px){
  .as-grid--3,.as-steps{grid-template-columns:1fr 1fr;}
  .as-footer__grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:720px){
  body{font-size:17px;}
  .as-burger{display:block;}
  .as-nav{
    position:absolute;top:100%;left:0;right:0;
    background:var(--as-creme);border-bottom:1px solid rgba(27,19,64,.1);
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:.25s;
  }
  .as-nav.is-open{transform:translateY(0);opacity:1;pointer-events:auto;}
  .as-nav ul{flex-direction:column;gap:0;padding:14px 22px;align-items:stretch;}
  .as-nav li{padding:10px 0;border-bottom:1px solid rgba(27,19,64,.06);}
  .as-grid--3,.as-grid--2,.as-steps,.as-footer__grid{grid-template-columns:1fr;}
  .as-section{padding:60px 0;}
  .as-band{padding:40px 24px;}
}

/* ============================================================
   ENHANCEMENTS v1.1 — design & composants
   ============================================================ */

/* Titre de section avec petit séparateur étoilé */
.as-eyebrow + h2{margin-bottom:.35em;}
.as-divider{
  display:flex;align-items:center;justify-content:center;gap:14px;
  margin:0 auto 2.4em;max-width:240px;color:var(--as-or);
}
.as-divider::before,.as-divider::after{
  content:"";height:1px;flex:1;
  background:linear-gradient(90deg,transparent,var(--as-or));
}
.as-divider::after{background:linear-gradient(90deg,var(--as-or),transparent);}
.as-divider span{font-size:1.1rem;line-height:1;}

/* Animation d'apparition douce au scroll (CSS pur) */
@keyframes asFadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:none;}}
.as-card,.as-step,.as-testimonial,.as-zodiac__item,.as-stat,.as-forwhom__item{
  animation:asFadeUp .7s ease both;
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;}}

/* Cartes : liseré doré au survol + icône en pastille */
.as-card{position:relative;overflow:hidden;}
.as-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--as-or),var(--as-or-clair));
  transform:scaleX(0);transform-origin:left;transition:transform .3s ease;
}
.as-card:hover::before{transform:scaleX(1);}
.as-card__icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;border-radius:14px;
  background:linear-gradient(135deg,rgba(194,160,90,.16),rgba(224,196,137,.28));
  font-size:1.7rem;margin-bottom:.5em;
}

/* Bande de chiffres / confiance */
.as-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  background:linear-gradient(120deg,var(--as-nuit),var(--as-nuit-2));
  border-radius:var(--as-radius);padding:48px 40px;color:#fff;text-align:center;
}
.as-stat__num{font-family:var(--as-serif);font-size:2.6rem;font-weight:700;color:var(--as-or-clair);line-height:1;}
.as-stat__label{display:block;margin-top:.4em;color:var(--as-lavande);font-size:.95rem;letter-spacing:.02em;}

/* Strip du zodiaque */
.as-zodiac{display:grid;grid-template-columns:repeat(6,1fr);gap:16px;margin-top:40px;}
.as-zodiac__item{
  background:var(--as-blanc);border:1px solid rgba(27,34,56,.08);
  border-radius:var(--as-radius-sm);padding:18px 10px;text-align:center;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.as-zodiac__item:hover{transform:translateY(-4px);border-color:var(--as-or);box-shadow:var(--as-shadow);}
.as-zodiac__sym{font-size:1.9rem;color:var(--as-or);display:block;line-height:1;}
.as-zodiac__name{display:block;margin-top:.5em;font-size:.92rem;color:var(--as-texte);}
.as-zodiac__date{display:block;font-size:.74rem;color:var(--as-texte-doux);}

/* Témoignages */
.as-testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:44px;text-align:left;}
.as-testimonial{
  background:var(--as-blanc);border:1px solid rgba(27,34,56,.07);
  border-radius:var(--as-radius);padding:30px 28px;box-shadow:0 12px 30px -24px rgba(27,34,56,.5);
}
.as-testimonial__stars{color:var(--as-or);letter-spacing:.15em;margin-bottom:.6em;}
.as-testimonial p{font-family:var(--as-serif);font-size:1.18rem;font-style:italic;color:var(--as-nuit);}
.as-testimonial__author{font-family:var(--as-sans);font-style:normal;font-size:.92rem;color:var(--as-texte-doux);font-weight:500;}

/* Pour qui ? */
.as-forwhom{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 36px;margin-top:36px;text-align:left;}
.as-forwhom__item{display:flex;gap:14px;align-items:flex-start;}
.as-forwhom__item span{color:var(--as-or);font-size:1.3rem;line-height:1.4;flex-shrink:0;}
.as-forwhom__item p{margin:0;color:var(--as-texte-doux);}
.as-forwhom__item strong{color:var(--as-nuit);display:block;font-family:var(--as-serif);font-size:1.15rem;font-weight:600;margin-bottom:.1em;}

/* Bandeau CTA final avec étoiles */
.as-cta-final{position:relative;overflow:hidden;background:linear-gradient(150deg,var(--as-nuit),var(--as-violet));color:#fff;border-radius:var(--as-radius);padding:64px 48px;text-align:center;}
.as-cta-final h2{color:#fff;}
.as-cta-final p{color:var(--as-lavande);max-width:60ch;margin:0 auto 1.8em;}
.as-cta-final::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.6;
  background-image:radial-gradient(2px 2px at 12% 30%,rgba(255,255,255,.6),transparent),
    radial-gradient(1.5px 1.5px at 78% 25%,rgba(255,255,255,.5),transparent),
    radial-gradient(2px 2px at 60% 70%,rgba(255,255,255,.45),transparent),
    radial-gradient(1.5px 1.5px at 30% 80%,rgba(255,255,255,.4),transparent);
}
.as-cta-final > *{position:relative;z-index:1;}

/* Tableau comparatif consultations */
.as-table{width:100%;border-collapse:collapse;margin:30px 0;background:#fff;border-radius:var(--as-radius-sm);overflow:hidden;box-shadow:0 12px 30px -26px rgba(27,34,56,.5);}
.as-table th,.as-table td{padding:16px 18px;text-align:left;border-bottom:1px solid rgba(27,34,56,.08);}
.as-table th{background:var(--as-nuit);color:#fff;font-family:var(--as-sans);font-weight:600;font-size:.92rem;letter-spacing:.03em;}
.as-table tr:last-child td{border-bottom:0;}
.as-table td:first-child{font-weight:600;color:var(--as-nuit);}

/* Listes éditoriales avec puces étoilées */
.as-content .as-checklist{list-style:none;padding:0;}
.as-content .as-checklist li{position:relative;padding-left:30px;margin-bottom:.7em;}
.as-content .as-checklist li::before{content:"\2727";position:absolute;left:0;top:0;color:var(--as-or);font-size:1.05rem;}

/* Liens boutons côte à côte centrés */
.as-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:36px;}

@media(max-width:900px){
  .as-stats{grid-template-columns:repeat(2,1fr);}
  .as-zodiac{grid-template-columns:repeat(4,1fr);}
  .as-testimonials{grid-template-columns:1fr;}
}
@media(max-width:720px){
  .as-stats{grid-template-columns:1fr 1fr;padding:34px 22px;}
  .as-zodiac{grid-template-columns:repeat(3,1fr);}
  .as-forwhom{grid-template-columns:1fr;}
  .as-cta-final{padding:44px 24px;}
  .as-table th,.as-table td{padding:12px 12px;font-size:.9rem;}
}
