/* ============================================================
   MYSTELUNE — Feuille de style (mystique & premium)
   ============================================================ */
:root{
  --bg:#0b0a1a;
  --bg-2:#13102a;
  --panel:#1a1638;
  --panel-2:#221c46;
  --border:#3a2f6e;
  --gold:#d4af37;
  --gold-soft:#f3d27a;
  --violet:#7c5cff;
  --violet-soft:#a98bff;
  --pink:#e64980;
  --text:#ece9ff;
  --muted:#a79fd0;
  --green:#4ad6a0;
  --radius:16px;
  --shadow:0 24px 60px rgba(0,0,0,.45);
  --font-display:'Cinzel',serif;
  --font-serif:'Cormorant Garamond',serif;
  --font-sans:'Poppins',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-sans);color:var(--text);line-height:1.6;
  background:
    radial-gradient(1200px 700px at 50% -200px,#2a2160 0%,transparent 60%),
    radial-gradient(900px 600px at 90% 10%,#3a1f57 0%,transparent 55%),
    linear-gradient(180deg,#0d0b1f 0%,#0b0a1a 100%);
  background-attachment:fixed;min-height:100vh;
}
a{color:inherit;text-decoration:none}
img{max-width:100%}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.2;margin:0 0 .5em}
.container{width:min(1180px,92%);margin:0 auto}

/* ---- Étoiles scintillantes ---- */
.stars{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:
    radial-gradient(1.5px 1.5px at 20% 30%,#fff,transparent),
    radial-gradient(1.5px 1.5px at 70% 60%,#fff,transparent),
    radial-gradient(1px 1px at 40% 80%,#fff,transparent),
    radial-gradient(1.5px 1.5px at 90% 20%,#fff,transparent),
    radial-gradient(1px 1px at 60% 10%,#fff,transparent),
    radial-gradient(1px 1px at 10% 70%,#fff,transparent),
    radial-gradient(1.5px 1.5px at 85% 85%,#fff,transparent),
    radial-gradient(1px 1px at 30% 50%,#fff,transparent);
  background-size:cover;opacity:.5;animation:twinkle 6s ease-in-out infinite alternate}
@keyframes twinkle{from{opacity:.25}to{opacity:.6}}

/* ---- Header / Navigation ---- */
.site-header{position:sticky;top:0;z-index:50;
  background:rgba(13,11,31,.72);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px}
.brand-moon{font-size:26px;filter:drop-shadow(0 0 8px rgba(212,175,55,.6))}
.brand-name{font-family:var(--font-display);font-size:22px;font-weight:700;
  background:linear-gradient(135deg,var(--gold-soft),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:.5px}
.menu{display:flex;align-items:center;gap:22px}
.menu a{color:var(--muted);font-size:15px;font-weight:400;transition:color .2s}
.menu a:hover{color:#fff}
.nav-credits{color:var(--gold)!important;font-weight:600!important;
  border:1px solid var(--border);padding:5px 12px;border-radius:20px}
.nav-admin{color:var(--violet-soft)!important;font-weight:500!important}
.nav-logout{font-size:13px!important;opacity:.7}
.navtoggle,.burger{display:none}

/* ---- Boutons ---- */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;
  padding:11px 22px;border-radius:30px;font-family:var(--font-sans);font-weight:500;
  font-size:15px;cursor:pointer;border:1px solid transparent;transition:transform .15s,box-shadow .2s;
  white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-gold{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#1a1330;
  box-shadow:0 10px 24px rgba(212,175,55,.32);font-weight:600}
.btn-violet{background:linear-gradient(135deg,var(--violet),#5a3fd6);color:#fff;
  box-shadow:0 10px 24px rgba(124,92,255,.35)}
.btn-ghost{background:rgba(255,255,255,.05);border-color:var(--border);color:var(--text)}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-block{width:100%}
.btn-lg{padding:15px 32px;font-size:17px}
.btn-sm{padding:7px 16px;font-size:13px}

/* ---- Messages flash ---- */
.flash{padding:13px 18px;border-radius:12px;margin:18px 0;font-size:15px;border:1px solid}
.flash-success{background:rgba(74,214,160,.12);border-color:var(--green);color:#aef5d6}
.flash-error{background:rgba(230,73,128,.12);border-color:var(--pink);color:#ffb3cf}
.flash-info{background:rgba(124,92,255,.12);border-color:var(--violet);color:#cdbcff}

/* ---- Hero ---- */
.hero{text-align:center;padding:90px 0 70px}
.hero .eyebrow{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:3px;
  font-size:13px;color:var(--gold);margin-bottom:20px}
.hero h1{font-size:clamp(34px,5.5vw,60px);margin-bottom:22px;
  background:linear-gradient(180deg,#fff,#c8bfff);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-family:var(--font-serif);font-size:clamp(18px,2.4vw,24px);color:var(--muted);
  max-width:680px;margin:0 auto 34px}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-stats{display:flex;gap:40px;justify-content:center;margin-top:50px;flex-wrap:wrap}
.hero-stats .stat b{font-family:var(--font-display);font-size:30px;color:var(--gold);display:block}
.hero-stats .stat span{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}

/* ---- Sections ---- */
.section{padding:64px 0}
.section-head{text-align:center;margin-bottom:44px}
.section-head .eyebrow{text-transform:uppercase;letter-spacing:3px;font-size:12px;color:var(--violet-soft)}
.section-head h2{font-size:clamp(26px,4vw,40px);margin-top:8px}
.section-head p{color:var(--muted);max-width:620px;margin:6px auto 0;font-family:var(--font-serif);font-size:19px}

/* ---- Grille de voyants ---- */
.voyant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.vcard{position:relative;background:linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--border);border-radius:var(--radius);padding:26px;overflow:hidden;
  transition:transform .2s,border-color .2s,box-shadow .2s}
.vcard:hover{transform:translateY(-5px);border-color:var(--gold);box-shadow:var(--shadow)}
.vcard .vtop{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.vavatar{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;font-size:30px;
  flex-shrink:0;border:2px solid rgba(255,255,255,.15)}
.vcard h3{margin:0;font-size:21px}
.vcard .vtag{color:var(--muted);font-size:14px}
.vcard .vdesc{color:var(--muted);font-size:14.5px;margin:14px 0;min-height:44px}
.vmeta{display:flex;align-items:center;justify-content:space-between;margin-top:16px;
  padding-top:16px;border-top:1px solid var(--border)}
.vprice b{color:var(--gold);font-size:18px;font-family:var(--font-display)}
.vprice span{color:var(--muted);font-size:12px}
.vrating{color:var(--gold);font-size:14px}
.vrating span{color:var(--muted)}
.specs{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.spec-tag{font-size:11.5px;padding:3px 10px;border-radius:20px;background:rgba(124,92,255,.14);
  color:var(--violet-soft);border:1px solid rgba(124,92,255,.25)}

/* ---- Badge statut ---- */
.status{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;
  padding:3px 11px;border-radius:20px}
.status::before{content:'';width:8px;height:8px;border-radius:50%}
.status.on{background:rgba(74,214,160,.15);color:var(--green)}
.status.on::before{background:var(--green);box-shadow:0 0 8px var(--green)}
.status.busy{background:rgba(255,169,77,.15);color:#ffb877}
.status.busy::before{background:#ffb877}
.status.off{background:rgba(167,159,208,.12);color:var(--muted)}
.status.off::before{background:var(--muted)}

/* ---- Toolbar filtres ---- */
.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;margin-bottom:28px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:7px 16px;border-radius:24px;border:1px solid var(--border);color:var(--muted);
  font-size:14px;background:rgba(255,255,255,.03);transition:.2s}
.chip:hover,.chip.active{border-color:var(--gold);color:var(--gold)}
select{background:var(--panel);color:var(--text);border:1px solid var(--border);
  padding:9px 14px;border-radius:10px;font-family:var(--font-sans);font-size:14px}

/* ---- Page générique / contenu ---- */
.page{padding:50px 0;max-width:820px}
.page h1{font-size:38px;margin-bottom:24px}
.page h2{font-size:24px;margin-top:34px;color:var(--gold-soft)}
.page p,.page li{color:var(--muted);font-size:16px}
.prose{font-family:var(--font-serif);font-size:19px}
.prose p{color:#d8d3ff;margin:0 0 18px}

/* ---- Cartes / panneaux ---- */
.panel{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--border);
  border-radius:var(--radius);padding:30px}
.grid-2{display:grid;grid-template-columns:1.4fr .9fr;gap:30px;align-items:start}

/* ---- Formulaires ---- */
.form-card{max-width:460px;margin:50px auto;background:linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--border);border-radius:20px;padding:40px;box-shadow:var(--shadow)}
.form-card h1{font-size:30px;text-align:center;margin-bottom:6px}
.form-card .sub{text-align:center;color:var(--muted);margin-bottom:26px}
label{display:block;font-size:14px;color:var(--muted);margin:16px 0 7px}
input[type=text],input[type=email],input[type=password],input[type=number],textarea,.input{
  width:100%;padding:13px 15px;border-radius:11px;border:1px solid var(--border);
  background:rgba(8,7,22,.6);color:#fff;font-family:var(--font-sans);font-size:15px;transition:border-color .2s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--gold)}
textarea{resize:vertical;min-height:90px}
.form-foot{text-align:center;margin-top:20px;color:var(--muted);font-size:14px}
.form-foot a{color:var(--gold)}
.errors{background:rgba(230,73,128,.12);border:1px solid var(--pink);border-radius:11px;
  padding:12px 16px;margin-bottom:18px;color:#ffb3cf;font-size:14px}
.errors ul{margin:0;padding-left:18px}

/* ---- Fiche voyant détail ---- */
.voyant-hero{display:flex;gap:30px;align-items:center;flex-wrap:wrap;
  background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--border);
  border-radius:20px;padding:34px;margin:30px 0}
.voyant-hero .vavatar{width:110px;height:110px;font-size:54px}
.voyant-hero h1{font-size:34px;margin:0}
.voyant-hero .vtag{color:var(--gold-soft);font-family:var(--font-serif);font-size:20px}
.vstat-row{display:flex;gap:26px;flex-wrap:wrap;margin-top:14px}
.vstat b{display:block;font-family:var(--font-display);font-size:20px;color:#fff}
.vstat span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.cta-box{margin-left:auto;text-align:center;background:rgba(212,175,55,.08);
  border:1px solid rgba(212,175,55,.3);border-radius:16px;padding:22px;min-width:210px}
.cta-box .price{font-family:var(--font-display);font-size:30px;color:var(--gold)}
.cta-box .price span{font-size:14px;color:var(--muted)}

/* ---- Avis ---- */
.review{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:14px;
  padding:18px 20px;margin-bottom:14px}
.review .rhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.review .rname{font-weight:600}
.review .rstars{color:var(--gold)}
.review .rtime{color:var(--muted);font-size:13px}

/* ---- Tarot ---- */
.tarot-wrap{text-align:center;padding:30px 0 70px}
.tarot-deck{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin:40px 0}
.tcard{width:200px;height:320px;perspective:1000px;cursor:pointer}
.tcard-inner{position:relative;width:100%;height:100%;transition:transform .8s;
  transform-style:preserve-3d}
.tcard.flipped .tcard-inner{transform:rotateY(180deg)}
.tface{position:absolute;inset:0;backface-visibility:hidden;border-radius:16px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px;text-align:center}
.tface-back{background:
    repeating-linear-gradient(45deg,#1a1442,#1a1442 8px,#221a52 8px,#221a52 16px);
  border:2px solid var(--gold);box-shadow:0 14px 30px rgba(0,0,0,.5)}
.tface-back .tmoon{font-size:64px;filter:drop-shadow(0 0 14px rgba(212,175,55,.7))}
.tface-front{background:linear-gradient(180deg,#241c52,#150f33);border:2px solid var(--gold);
  transform:rotateY(180deg);box-shadow:0 14px 30px rgba(0,0,0,.5)}
.tface-front .tsymbol{font-size:54px;margin-bottom:8px}
.tface-front .tname{font-family:var(--font-display);color:var(--gold);font-size:18px;margin-bottom:6px}
.tface-front .tkw{font-size:12px;color:var(--violet-soft);margin-bottom:10px}
.tface-front .tmeaning{font-size:12.5px;color:var(--muted);line-height:1.45}
.tface-front .trev{font-size:10px;color:var(--pink);text-transform:uppercase;letter-spacing:1px;margin-top:8px}
.tpos{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:10px}

/* ---- Horoscope ---- */
.zodiac-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:18px}
.zcard{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--border);
  border-radius:16px;padding:24px;text-align:center;transition:.2s}
.zcard:hover{border-color:var(--gold);transform:translateY(-4px)}
.zsign{font-size:46px;color:var(--gold)}
.zcard h3{margin:10px 0 2px;font-size:20px}
.zcard .zdates{color:var(--muted);font-size:13px}
.horo-detail{max-width:760px;margin:0 auto}
.horo-line{display:flex;gap:16px;align-items:flex-start;background:rgba(255,255,255,.03);
  border:1px solid var(--border);border-radius:14px;padding:18px 20px;margin-bottom:14px}
.horo-line .ico{font-size:28px}
.horo-line h4{margin:0 0 4px;color:var(--gold-soft)}
.horo-line p{margin:0;color:var(--muted)}
.horo-line .score{margin-left:auto;color:var(--gold);white-space:nowrap}

/* ---- Tableau de bord ---- */
.dash-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin:34px 0 26px}
.balance{background:linear-gradient(135deg,rgba(212,175,55,.15),rgba(124,92,255,.12));
  border:1px solid var(--gold);border-radius:18px;padding:24px 30px;text-align:right}
.balance .amt{font-family:var(--font-display);font-size:38px;color:var(--gold)}
.cards-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:18px;margin-bottom:30px}
.statcard{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--border);
  border-radius:16px;padding:22px}
.statcard .n{font-family:var(--font-display);font-size:32px;color:#fff}
.statcard .l{color:var(--muted);font-size:14px}

/* ---- Tables ---- */
table{width:100%;border-collapse:collapse;font-size:14.5px}
th,td{text-align:left;padding:13px 14px;border-bottom:1px solid var(--border)}
th{color:var(--muted);font-weight:500;font-size:13px;text-transform:uppercase;letter-spacing:.5px}
tr:hover td{background:rgba(255,255,255,.02)}
.table-card{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--border);
  border-radius:16px;padding:8px 22px;overflow-x:auto}

/* ---- Chat consultation ---- */
.chat{max-width:760px;margin:24px auto}
.chat-head{display:flex;align-items:center;gap:14px;background:linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--border);border-radius:16px 16px 0 0;padding:18px 22px}
.chat-head .vavatar{width:50px;height:50px;font-size:26px}
.chat-body{background:rgba(8,7,22,.5);border-left:1px solid var(--border);border-right:1px solid var(--border);
  padding:24px;min-height:340px;max-height:520px;overflow-y:auto;display:flex;flex-direction:column;gap:14px}
.bubble{max-width:75%;padding:12px 16px;border-radius:16px;font-size:15px;line-height:1.5}
.bubble.voyant{align-self:flex-start;background:var(--panel-2);border:1px solid var(--border);border-bottom-left-radius:4px}
.bubble.client{align-self:flex-end;background:linear-gradient(135deg,var(--violet),#5a3fd6);
  color:#fff;border-bottom-right-radius:4px}
.bubble .who{display:block;font-size:11px;opacity:.6;margin-bottom:3px}
.chat-foot{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--border);
  border-radius:0 0 16px 16px;padding:16px;display:flex;gap:10px}
.chat-foot input{flex:1}
.chat-note{text-align:center;color:var(--muted);font-size:13px;margin-top:14px}
.chat-ended{text-align:center;background:rgba(167,159,208,.1);border:1px dashed var(--border);
  border-radius:12px;padding:16px;color:var(--muted);margin-top:14px}

/* ---- Recharge ---- */
.pack-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;margin-top:10px}
.pack{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--border);
  border-radius:16px;padding:26px;text-align:center;transition:.2s;position:relative}
.pack:hover{border-color:var(--gold);transform:translateY(-4px)}
.pack .pc{font-family:var(--font-display);font-size:40px;color:var(--gold)}
.pack .pe{color:var(--muted);margin-bottom:14px}
.pack.popular::after{content:'Populaire';position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:#1a1330;font-size:11px;font-weight:600;padding:3px 12px;border-radius:20px}

/* ---- CTA bandeau ---- */
.cta-banner{background:linear-gradient(135deg,rgba(124,92,255,.18),rgba(212,175,55,.14));
  border:1px solid var(--border);border-radius:22px;padding:50px;text-align:center;margin:40px 0}
.cta-banner h2{font-size:32px}
.cta-banner p{color:var(--muted);font-family:var(--font-serif);font-size:20px;margin-bottom:24px}

/* ---- Articles ---- */
.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.acard{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--border);
  border-radius:16px;overflow:hidden;transition:.2s}
.acard:hover{border-color:var(--gold);transform:translateY(-4px)}
.acard .athumb{font-size:54px;text-align:center;padding:30px;background:rgba(124,92,255,.08)}
.acard .abody{padding:22px}
.acard h3{font-size:19px}
.acard p{color:var(--muted);font-size:14px}

/* ---- Liens fil d'ariane / retour ---- */
.back{color:var(--muted);font-size:14px;display:inline-block;margin:24px 0 0}
.back:hover{color:var(--gold)}

/* ---- Footer ---- */
.site-footer{margin-top:70px;border-top:1px solid var(--border);background:rgba(8,7,22,.5);padding:50px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px}
.footer-grid h4{font-family:var(--font-sans);font-size:14px;text-transform:uppercase;letter-spacing:1px;
  color:var(--gold);margin-bottom:14px}
.footer-grid a{display:block;color:var(--muted);font-size:14px;margin-bottom:9px;transition:.2s}
.footer-grid a:hover{color:#fff}
.footer-tag{color:var(--muted);font-family:var(--font-serif);font-size:18px;margin-top:10px}
.footer-bottom{margin-top:36px;padding-top:24px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
.footer-bottom p{color:var(--muted);font-size:13px;margin:0}
.disclaimer{max-width:520px;opacity:.7}

/* ---- Responsive ---- */
@media(max-width:860px){
  .grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .voyant-hero .cta-box{margin-left:0;width:100%}
  .burger{display:block;font-size:26px;color:var(--gold);cursor:pointer;user-select:none}
  .menu{position:fixed;inset:64px 0 auto 0;flex-direction:column;gap:0;
    background:rgba(13,11,31,.98);border-bottom:1px solid var(--border);
    max-height:0;overflow:hidden;transition:max-height .3s;padding:0 24px}
  .menu a{padding:14px 0;border-bottom:1px solid var(--border);width:100%}
  .navtoggle:checked ~ .menu{max-height:80vh;padding:10px 24px 24px}
}
@media(max-width:560px){
  .footer-grid{grid-template-columns:1fr}
  .hero{padding:60px 0 40px}
  .tcard{width:150px;height:250px}
}
