/* =========================================================================
   Nadiejda Huberty — Design system
   Une couleur par discipline. Ivoire chaud, encre profonde, or discret.
   "Écouter ce que le vivant murmure — et l'accompagner avec douceur."
   ========================================================================= */

:root{
  /* Neutres */
  --ink:#241f1a;          /* texte */
  --ink-soft:#5b5248;     /* texte secondaire */
  --ivory:#faf6ef;        /* fond */
  --ivory-2:#f3ece1;      /* cartes */
  --line:#e6ddcf;         /* filets */
  --white:#ffffff;

  /* Une couleur par discipline */
  --animal:#b5651d;       --animal-2:#e0913c;   --animal-bg:#fbf0e4;   /* brun / orange — animaux */
  --astro:#4b3f8f;        --astro-2:#8064c0;    --astro-bg:#efecfa;    /* indigo / violet — astrologie */
  --sante:#3f7d5c;        --sante-2:#5fb187;    --sante-bg:#e9f4ee;    /* vert — médecine intégrée */
  --defunts:#bd9a3f;      --defunts-2:#e0c266;  --defunts-bg:#f7f0dc;  /* doré — contact défunts / deuils */
  --son:#1f9c96;          --son-2:#54c7c0;      --son-bg:#e2f4f2;      /* turquoise — voyages sonores */
  --feminin:#a8517a;      --feminin-2:#cf7da4;  --feminin-bg:#f7e9f0;  /* grenat rosé — accompagnement du Féminin */

  /* Couleur "active" — surchargée page par page via [data-theme] */
  --accent:var(--sante);
  --accent-2:var(--sante-2);
  --accent-bg:var(--sante-bg);

  --radius:18px;
  --radius-sm:12px;
  --shadow:0 10px 40px -12px rgba(50,40,25,.28);
  --shadow-sm:0 4px 18px -8px rgba(50,40,25,.30);
  --maxw:1140px;
  --serif:"Cormorant Garamond",Garamond,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}

/* Thèmes de discipline : ajouter data-theme="animal|astro|sante|defunts|son|feminin" sur <body> ou une section */
[data-theme="animal"] { --accent:var(--animal);  --accent-2:var(--animal-2);  --accent-bg:var(--animal-bg); }
[data-theme="astro"]  { --accent:var(--astro);   --accent-2:var(--astro-2);   --accent-bg:var(--astro-bg); }
[data-theme="sante"]  { --accent:var(--sante);   --accent-2:var(--sante-2);   --accent-bg:var(--sante-bg); }
[data-theme="defunts"]{ --accent:var(--defunts); --accent-2:var(--defunts-2); --accent-bg:var(--defunts-bg); }
[data-theme="son"]    { --accent:var(--son);     --accent-2:var(--son-2);     --accent-bg:var(--son-bg); }
[data-theme="feminin"]{ --accent:var(--feminin); --accent-2:var(--feminin-2); --accent-bg:var(--feminin-bg); }

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);background:var(--ivory);
  font-family:var(--sans);font-size:17px;line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.12;color:var(--ink);margin:.2em 0 .4em}
h1{font-size:clamp(2.4rem,5.5vw,4rem)}
h2{font-size:clamp(1.9rem,4vw,2.9rem)}
h3{font-size:clamp(1.35rem,2.4vw,1.7rem)}
.lead{font-size:1.22rem;color:var(--ink-soft)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:78px 0}
.section.tight{padding:48px 0}
.center{text-align:center}
.eyebrow{
  text-transform:uppercase;letter-spacing:.22em;font-size:.76rem;font-weight:700;
  color:var(--accent);margin-bottom:.5rem
}
.muted{color:var(--ink-soft)}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  background:var(--accent);color:#fff;border:none;cursor:pointer;
  padding:.85em 1.5em;border-radius:999px;font:600 1rem var(--sans);
  box-shadow:var(--shadow-sm);transition:transform .15s ease,filter .15s ease;
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.06);text-decoration:none;color:#fff}
.btn.ghost{background:transparent;color:var(--accent);border:1.5px solid var(--accent);box-shadow:none}
.btn.ghost:hover{background:var(--accent);color:#fff}
.btn.gold{background:linear-gradient(120deg,var(--defunts),var(--defunts-2))}

/* ---------- Header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(250,246,239,.86);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:70px}
.brand{display:flex;align-items:center;gap:.65rem;font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--ink)}
.brand img{height:46px;width:auto;display:block}
@media(max-width:560px){.brand img{height:36px}}
.brand:hover{text-decoration:none}
.brand .dot{width:12px;height:12px;border-radius:50%;background:conic-gradient(var(--animal),var(--astro),var(--sante),var(--defunts),var(--son),var(--feminin),var(--animal))}
.nav-links{display:flex;gap:1.15rem;align-items:center}
.nav-links > a,.nav-item > a{color:var(--ink-soft);font-weight:500;font-size:.93rem;white-space:nowrap;cursor:pointer}
.nav-links > a:hover,.nav-item > a:hover{color:var(--accent);text-decoration:none}
.nav-item{position:relative}
.nav-item.has-sub > a::after{content:" ⌄";font-size:.85em;opacity:.55}
/* fenêtre volante (flyout) */
.nav-sub{position:absolute;top:calc(100% + 8px);left:0;min-width:240px;background:var(--white);
  border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;
  display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .16s ease,transform .16s ease,visibility .16s;z-index:70}
.nav-sub::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px} /* pont anti-flicker */
.nav-item:hover .nav-sub,.nav-item:focus-within .nav-sub,.nav-item.open .nav-sub{opacity:1;visibility:visible;transform:none}
.nav-sub a{display:block;padding:.55em .85em;border-radius:9px;color:var(--ink);font-size:.9rem;white-space:nowrap}
.nav-sub a:hover{background:var(--accent-bg);color:var(--accent);text-decoration:none}
.nav-sub .sub-title{font-family:var(--serif);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);padding:.4em .85em .1em;pointer-events:none}
.nav-toggle{display:none;background:none;border:none;font-size:1.7rem;cursor:pointer;color:var(--ink)}
@media(max-width:900px){
  .nav-links{position:fixed;inset:70px 0 auto 0;flex-direction:column;align-items:stretch;background:var(--ivory);
    padding:1rem 22px 1.4rem;border-bottom:1px solid var(--line);display:none;gap:.15rem;
    max-height:calc(100vh - 70px);overflow-y:auto}
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
  .nav-item{position:static}
  .nav-item > a{font-weight:600;display:block;padding:.4rem 0}
  .nav-sub{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;
    background:transparent;padding:0 0 .5rem .9rem;min-width:0}
  .nav-sub .sub-title{display:none}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding:96px 0 84px;
  background:radial-gradient(1200px 500px at 80% -10%,var(--accent-bg),transparent 60%),var(--ivory)}
.hero h1{max-width:14ch}
.hero .lead{max-width:52ch;margin-top:1rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.8rem}

/* ---------- Grille de disciplines ---------- */
.disc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.disc-card{
  position:relative;display:block;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:26px 24px 24px;overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease;color:var(--ink)
}
.disc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);text-decoration:none}
.disc-card::before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--accent)}
/* Accordéons « sobres » : sans la pastille ronde (ex. déroulé, FAQ) */
.plain-acc .acc>summary::before{display:none}
.plain-acc .acc>summary{gap:0}
.disc-card .ic{color:var(--accent);margin:0 0 12px;line-height:0}
.disc-card .ic svg{width:30px;height:30px;display:block;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.eico{width:1em;height:1em;display:inline-block;vertical-align:-.13em;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;flex:none}
.disc-card h3{margin:.5rem 0 .3rem}
.disc-card p{color:var(--ink-soft);font-size:.98rem;margin:0}
.disc-card .go{display:inline-block;margin-top:1rem;color:var(--accent);font-weight:600;font-size:.92rem}

/* ---------- Accordéons ---------- */
.acc{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--white);
  margin:14px 0;overflow:hidden;box-shadow:var(--shadow-sm)}
.acc>summary{
  list-style:none;cursor:pointer;padding:20px 22px;font-family:var(--serif);
  font-size:1.28rem;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:.7rem;
  transition:background .15s
}
.acc>summary::-webkit-details-marker{display:none}
.acc>summary::before{
  content:"+";display:grid;place-items:center;flex:0 0 auto;width:30px;height:30px;border-radius:50%;
  background:var(--accent-bg);color:var(--accent);font-weight:700;font-size:1.2rem;transition:transform .2s
}
.acc[open]>summary::before{content:"–"}
.acc>summary:hover{background:var(--accent-bg)}
.acc .acc-body{padding:2px 24px 22px;color:var(--ink-soft)}
.acc .acc-body p:first-child{margin-top:0}
.acc .acc-body strong{color:var(--ink)}
/* Quand le JS prend le relais, l'accordéon devient un déclencheur de fenêtre flottante :
   la pastille passe en icône SVG traits fins (.acc-ic injectée par site.js) */
.js-float .acc>summary::before{display:none}
.acc-ic{display:none;place-items:center;flex:0 0 auto;width:30px;height:30px;border-radius:50%;
  background:var(--accent-bg);color:var(--accent)}
.js-float .acc-ic{display:grid}
.acc-ic svg{width:14px;height:14px;display:block;stroke:currentColor;fill:none;
  stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.plain-acc .acc-ic{display:none}

/* ---------- Fenêtres flottantes ---------- */
.float-backdrop{position:fixed;inset:0;background:rgba(20,18,40,.55);backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;
  z-index:1000;opacity:0;transition:opacity .2s}
.float-backdrop.in{opacity:1}
.float-win{background:var(--white);border-radius:var(--radius);box-shadow:0 30px 80px rgba(0,0,0,.35);
  max-width:660px;width:100%;max-height:86vh;overflow:auto;position:relative;
  transform:translateY(14px) scale(.985);transition:transform .22s}
.float-backdrop.in .float-win{transform:none}
.float-win .float-head{position:sticky;top:0;background:var(--white);display:flex;align-items:flex-start;
  gap:1rem;padding:22px 26px 14px;border-bottom:1px solid var(--line);z-index:1}
.float-win .float-head h3{font-family:var(--serif);font-size:1.4rem;line-height:1.15;color:var(--ink);margin:0;flex:1}
.float-close{flex:0 0 auto;width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;
  background:var(--accent-bg);color:var(--accent);font-size:1.4rem;line-height:1;display:grid;place-items:center;
  transition:background .15s,color .15s}
.float-close:hover{background:var(--accent);color:#fff}
.float-win .float-body{padding:18px 26px 28px;color:var(--ink-soft)}
.float-win .float-body p:first-child{margin-top:0}
.float-win .float-body strong{color:var(--ink)}
body.float-lock{overflow:hidden}

/* ---------- Bloc panneau / carte contenu ---------- */
.panel{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px;box-shadow:var(--shadow-sm)}
.panel-accent{background:var(--accent-bg);border-color:transparent}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:820px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* ---------- Bannière discipline (en-tête de page) ---------- */
.page-hero{padding:70px 0 40px;background:
  radial-gradient(900px 380px at 85% -20%,var(--accent-bg),transparent 65%),var(--ivory);
  border-bottom:1px solid var(--line)}
.page-hero .badge{display:inline-flex;align-items:center;gap:.5em;background:var(--accent);color:#fff;
  padding:.35em .9em;border-radius:999px;font-size:.8rem;font-weight:600;letter-spacing:.04em}

/* ---------- Packs / tarifs ---------- */
.packs{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:820px){.packs{grid-template-columns:1fr}}
.pack{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.pack.feature{border:2px solid var(--accent);box-shadow:var(--shadow);transform:translateY(-6px)}
.pack .price{font-family:var(--serif);font-size:2.4rem;color:var(--accent);font-weight:600;margin:.3rem 0}
.pack ul{list-style:none;padding:0;margin:.6rem 0 1.2rem}
.pack li{padding:.32rem 0 .32rem 1.6rem;position:relative;color:var(--ink-soft)}
.pack li::before{content:"✦";position:absolute;left:0;color:var(--accent)}

/* ---------- Formulaires ---------- */
.form{display:grid;gap:14px;max-width:560px}
.form label{font-weight:600;font-size:.9rem;color:var(--ink)}
.form input,.form textarea,.form select{
  width:100%;padding:.8em 1em;border:1px solid var(--line);border-radius:12px;background:var(--white);
  font:inherit;color:var(--ink)}
.form input:focus,.form textarea:focus{outline:2px solid var(--accent);border-color:transparent}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.form .row{grid-template-columns:1fr}}
.form-note{font-size:.85rem;color:var(--ink-soft)}
.form-status{font-weight:600;min-height:1.4em}
.form-status.ok{color:var(--sante)}
.form-status.err{color:#b5432f}

/* ---------- Chat oracle ---------- */
.chat-fab{position:fixed;right:22px;bottom:42px;z-index:60;padding:.85em 1.4em;border-radius:999px;
  background:linear-gradient(135deg,var(--astro),var(--astro-2));color:#fff;border:none;cursor:pointer;
  font:600 1rem var(--sans);white-space:nowrap;box-shadow:var(--shadow);transition:transform .15s}
.chat-fab:hover{transform:scale(1.06)}
.chat-panel{position:fixed;right:22px;bottom:116px;z-index:60;width:min(400px,92vw);height:min(560px,74vh);
  background:var(--white);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);
  display:none;flex-direction:column;overflow:hidden}
.chat-panel.open{display:flex}
.chat-head{background:linear-gradient(135deg,var(--astro),var(--astro-2));color:#fff;padding:16px 18px}
.chat-head b{font-family:var(--serif);font-size:1.2rem}
.chat-head small{opacity:.9;display:block}
.chat-log{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:var(--ivory)}
.msg{padding:.7em 1em;border-radius:14px;max-width:88%;font-size:.95rem;white-space:pre-wrap}
.msg.u{align-self:flex-end;background:var(--astro);color:#fff;border-bottom-right-radius:4px}
.msg.a{align-self:flex-start;background:var(--white);border:1px solid var(--line);border-bottom-left-radius:4px}
.msg.sys{align-self:center;background:transparent;color:var(--ink-soft);font-size:.82rem;text-align:center}
.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:var(--white)}
.chat-input textarea{flex:1;resize:none;height:44px;border:1px solid var(--line);border-radius:12px;padding:.55em .8em;font:inherit}
.chat-input button{background:var(--astro);color:#fff;border:none;border-radius:12px;width:44px;font-size:1.2rem;cursor:pointer}
.chat-quota{font-size:.78rem;color:var(--ink-soft);text-align:center;padding:4px}

/* ---------- Footer ---------- */
.site-footer{background:#1b1738;color:#e7e6f5;padding:56px 0 30px;margin-top:40px}
.footer-banner{display:block;width:min(610px,90%);height:auto;margin:0 auto 44px}
/* ---------- Section newsletter (avant le footer) ---------- */
.news-section{background:var(--accent-bg)}
.news-section .lead{max-width:56ch;margin:.4rem auto 0}
.news-section form{max-width:560px;margin:1.8rem auto 0}
.news-section .news-row input{background:var(--white);border:1px solid var(--line);color:var(--ink)}
.news-section .news-row input::placeholder{color:#9a9385}
.news-section .form-status{margin-top:.7rem;font-size:.9rem}
.news-section .form-note{margin-top:.5rem;font-size:.82rem;color:var(--ink-soft)}
.news-row{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center}
.news-row input{flex:1;min-width:220px;padding:.75em 1em;border-radius:999px;border:1px solid #454873;background:#221d44;color:#fff;font:inherit}
.news-row input::placeholder{color:#9a9cc4}
.news-row .btn{white-space:nowrap}
.site-footer a{color:#e7e6f5}
.footer-brand{display:inline-block;margin-bottom:.4rem}
.footer-brand img{height:56px;width:auto;display:block}
.footer-brand:hover{text-decoration:none}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:1.05rem;letter-spacing:.02em}
.site-footer .fine{border-top:1px solid #454873;margin-top:34px;padding-top:18px;font-size:.85rem;color:#b7b9de;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- Divers ---------- */
.pill{display:inline-block;background:var(--accent-bg);color:var(--accent);border-radius:999px;
  padding:.28em .9em;font-size:.82rem;font-weight:600;margin:.15em}
.quote{font-family:var(--serif);font-size:1.5rem;line-height:1.4;color:var(--ink);
  border-left:4px solid var(--accent);padding:.2em 0 .2em 1.1em;margin:1.4em 0}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
hr.soft{border:none;border-top:1px solid var(--line);margin:2.4rem 0}
.case{background:var(--animal-bg);border-radius:var(--radius);padding:24px;border:1px solid var(--line)}
.case .demande{font-weight:600;color:var(--animal)}
.case .retour{font-style:italic;color:var(--ink);margin-top:.6rem;border-left:3px solid var(--animal-2);padding-left:1em}
