/* Tarodivino — revival Phase 1 — feuille de style moderne
   Objectif : lisibilité longue traîne SEO + rendu credible/mystique + responsive mobile */

:root{
  --night:#1c1740;         /* indigo nuit */
  --night-2:#151033;
  --gold:#d4af5a;          /* or */
  --gold-soft:#e7cf95;
  --ink:#23202e;           /* texte corps */
  --ink-soft:#4a4658;
  --paper:#faf8f4;         /* fond */
  --card:#ffffff;
  --line:#e7e2d6;
  --link:#6b4fb0;          /* violet lien */
  --link-hover:#4a2f8f;
  --maxw:720px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font:400 1.0625rem/1.75 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:20px}
.skip{position:absolute;left:-9999px}
.skip:focus{left:8px;top:8px;background:var(--gold);color:var(--night);padding:8px 12px;border-radius:6px;z-index:10}

/* ---------- Header ---------- */
.site-header{
  background:linear-gradient(180deg,var(--night),var(--night-2));
  color:#efeafc;
  border-bottom:2px solid var(--gold);
}
.header-inner{display:flex;align-items:center;gap:16px;padding-block:14px;max-width:1040px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff;font-weight:700}
.brand-mark{color:var(--gold);font-size:1.4rem;line-height:1}
.brand-name{font-family:Georgia,"Times New Roman",serif;font-size:1.5rem;letter-spacing:.5px}
.nav-toggle{margin-left:auto;background:none;border:1px solid rgba(255,255,255,.35);color:#fff;font-size:1.2rem;border-radius:8px;padding:4px 10px;cursor:pointer;display:none}
.site-nav{margin-left:auto;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.site-nav a{color:#dcd5f2;text-decoration:none;font-size:.94rem;font-weight:500}
.site-nav a:hover{color:#fff}
.site-nav a.cta{background:var(--gold);color:var(--night);padding:8px 14px;border-radius:999px;font-weight:700}
.site-nav a.cta:hover{background:var(--gold-soft);color:var(--night)}

/* ---------- Contenu (prose) ---------- */
main{padding-block:36px 56px;min-height:60vh}
.prose h1{
  font-family:Georgia,"Times New Roman",serif;
  font-size:2rem;line-height:1.2;color:var(--night);
  margin:0 0 .2em;
}
.prose h1::after{content:"";display:block;width:64px;height:3px;background:var(--gold);margin-top:.5rem;border-radius:2px}
.prose h2{font-family:Georgia,serif;font-size:1.5rem;color:var(--night);margin:2rem 0 .6rem}
.prose h3{font-size:1.2rem;color:var(--night-2);margin:1.6rem 0 .4rem}
.prose p{margin:0 0 1.15rem;text-align:left}
.prose a{color:var(--link);text-decoration:underline;text-underline-offset:2px}
.prose a:hover{color:var(--link-hover)}
.prose img{max-width:100%;height:auto;border-radius:8px}
.prose ul,.prose ol{margin:0 0 1.15rem;padding-left:1.4rem}
.prose li{margin:.3rem 0}
.prose table{width:100%;border-collapse:collapse;margin:1.2rem 0;overflow-x:auto;display:block}
.prose blockquote{border-left:3px solid var(--gold);margin:1.4rem 0;padding:.4rem 0 .4rem 1.1rem;color:var(--ink-soft);font-style:italic}
.prose hr{border:none;border-top:1px solid var(--line);margin:2rem 0}

/* ---------- Footer ---------- */
.site-footer{background:var(--night-2);color:#c9c2e0;padding-block:28px;margin-top:40px}
.footer-inner{max-width:1040px}
.footer-nav{display:flex;flex-wrap:wrap;gap:8px 20px;margin-bottom:14px}
.footer-nav a{color:#c9c2e0;text-decoration:none;font-size:.9rem}
.footer-nav a:hover{color:var(--gold-soft)}
.footer-legal{font-size:.82rem;color:#8f88ab;margin:0}

/* ---------- Responsive ---------- */
@media (max-width:640px){
  .nav-toggle{display:block}
  .site-nav{display:none;flex-direction:column;align-items:flex-start;width:100%;gap:10px;padding-top:10px}
  .site-nav.open{display:flex}
  .prose h1{font-size:1.6rem}
}

/* ---------- Thème sombre (préférence système) ---------- */
@media (prefers-color-scheme:dark){
  :root{--paper:#14121c;--card:#1b1826;--ink:#e7e3f2;--ink-soft:#b3adc7;--line:#2c2740;--night:#221a4d;--link:#b79bf0;--link-hover:#d3c2ff}
  .prose h1,.prose h2,.prose h3{color:#efeafc}
}

/* =====================  ACCUEIL / LANDING  ===================== */
.main-full{padding:0;max-width:none;min-height:auto}
.section-title{font-family:Georgia,serif;font-size:1.7rem;color:var(--night);text-align:center;margin:0 0 .3em}
.section-lead{text-align:center;color:var(--ink-soft);max-width:52ch;margin:0 auto 2rem}
.band{padding:56px 0}
.band-alt{background:color-mix(in srgb,var(--night) 5%,var(--paper))}

/* Hero */
.hero{background:radial-gradient(120% 140% at 50% -20%,#2a2160 0%,var(--night) 45%,var(--night-2) 100%);color:#efeafc;text-align:center;padding:72px 0 64px;border-bottom:2px solid var(--gold)}
.eyebrow{color:var(--gold-soft);letter-spacing:.14em;text-transform:uppercase;font-size:.8rem;font-weight:600;margin:0 0 1rem}
.hero-title{font-family:Georgia,serif;font-size:clamp(2.1rem,6vw,3.4rem);line-height:1.1;margin:0 0 .5em;color:#fff;text-wrap:balance}
.hero-sub{max-width:56ch;margin:0 auto 2rem;color:#d7d0ee;font-size:1.1rem;line-height:1.6}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-cards{display:flex;gap:16px;justify-content:center;margin-top:2.6rem}
.tcard{width:54px;height:82px;border:1px solid var(--gold);border-radius:8px;display:grid;place-items:center;font-size:1.5rem;color:var(--gold-soft);background:rgba(255,255,255,.04)}

/* Boutons */
.btn{display:inline-block;padding:13px 26px;border-radius:999px;text-decoration:none;font-weight:700;font-size:1rem;transition:transform .12s,background .2s}
.btn:hover{transform:translateY(-1px)}
.btn-gold{background:var(--gold);color:var(--night-2)}
.btn-gold:hover{background:var(--gold-soft)}
.btn-ghost{border:1px solid rgba(255,255,255,.4);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.1)}

/* Étapes */
.steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:26px;counter-reset:s}
.steps li{text-align:center}
.step-n{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:50%;background:var(--night);color:var(--gold);font-family:Georgia,serif;font-size:1.2rem;font-weight:700;margin-bottom:.6rem}
.steps h3{margin:.2rem 0 .3rem;color:var(--night);font-size:1.15rem}
.steps p{margin:0;color:var(--ink-soft);font-size:.96rem}

/* Cartes services */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.card{display:block;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;text-decoration:none;color:var(--ink);transition:border-color .2s,transform .12s,box-shadow .2s}
.card:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 8px 24px rgba(28,23,64,.08)}
.card-ico{display:inline-grid;place-items:center;width:46px;height:46px;border-radius:12px;background:color-mix(in srgb,var(--gold) 18%,transparent);color:var(--gold);font-size:1.5rem}
.card h3{margin:.5rem 0 .3rem;color:var(--night);font-size:1.1rem}
.card p{margin:0;color:var(--ink-soft);font-size:.95rem}

/* Bandeau confiance */
.trust{background:linear-gradient(180deg,var(--night),var(--night-2));color:#efeafc;padding:40px 0}
.trust-inner{display:flex;justify-content:center;gap:48px;flex-wrap:wrap;text-align:center}
.stat{display:flex;flex-direction:column}
.stat strong{font-family:Georgia,serif;font-size:1.9rem;color:var(--gold-soft)}
.stat span{font-size:.9rem;color:#c9c2e0}

/* Grille de liens contenu */
.link-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.link-grid a{display:block;padding:14px 16px;background:var(--card);border:1px solid var(--line);border-radius:10px;text-decoration:none;color:var(--link);font-size:.95rem;font-weight:500;transition:border-color .2s,color .2s}
.link-grid a:hover{border-color:var(--gold);color:var(--link-hover)}

/* CTA final */
.cta-final{text-align:center;padding:64px 0;background:color-mix(in srgb,var(--gold) 12%,var(--paper))}
.cta-final h2{font-family:Georgia,serif;font-size:1.9rem;color:var(--night);margin:0 0 .3em}
.cta-final p{color:var(--ink-soft);margin:0 0 1.6rem}

@media (max-width:640px){
  .steps{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .link-grid{grid-template-columns:1fr}
  .trust-inner{gap:28px}
}

/* séparateur (remplace l'ancienne image barre410.gif) */
.prose hr.sep{border:none;border-top:1px solid var(--line);max-width:410px;margin:1.6rem auto}

/* =====================  AUTH / ESPACE MEMBRE  ===================== */
.authform{display:flex;flex-direction:column;gap:16px;max-width:400px;margin:1.4rem 0}
.authform label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:var(--night);font-size:.95rem}
.authform input{font:inherit;padding:11px 13px;border:1px solid var(--line);border-radius:10px;background:var(--card);color:var(--ink)}
.authform input:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.authform .btn{align-self:flex-start;cursor:pointer;border:none}
.alert{background:color-mix(in srgb,#c0413a 12%,var(--paper));border-left:4px solid #c0413a;
  padding:12px 14px;border-radius:0 8px 8px 0;color:var(--night2);margin:0 0 1.2rem;max-width:400px}
.authlinks{font-size:.92rem;margin-top:1rem}
.member-stats{display:flex;gap:16px;flex-wrap:wrap;margin:1.6rem 0}
.member-stats .ms{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 22px;text-align:center;min-width:120px}
.member-stats .ms strong{display:block;font-family:Georgia,serif;font-size:1.8rem;color:var(--night)}
.member-stats .ms span{font-size:.85rem;color:var(--ink-soft)}
@media (prefers-color-scheme:dark){
  .authform label{color:#efeafc}
  .member-stats .ms strong{color:#efeafc}
}

/* =====================  MOTEUR DE TIRAGE  ===================== */
.tirage-intro{color:var(--ink-soft);max-width:60ch}
.cartes{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin:1.8rem 0}
.carte{margin:0;text-align:center;width:96px}
.carte img{width:96px;height:auto;border:2px solid var(--gold);border-radius:8px;background:#0e0b1e;box-shadow:0 6px 16px rgba(28,23,64,.18)}
.carte figcaption{font-size:.8rem;color:var(--night2);margin-top:6px;font-weight:600}
.themes{display:grid;gap:16px;margin:2rem 0}
.theme{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:0 12px 12px 0;padding:16px 20px}
.theme h2{font-family:Georgia,serif;font-size:1.25rem;color:var(--night);margin:0 0 .5rem}
.theme p{margin:.35rem 0}
.theme .tense{font-weight:700;color:var(--gold);font-size:.85rem;text-transform:uppercase;letter-spacing:.04em}
.theme .futur{color:var(--ink-soft)}
.upsell{background:color-mix(in srgb,var(--gold) 12%,var(--paper));border-radius:10px;padding:14px 18px;color:var(--night2);max-width:60ch}
@media (prefers-color-scheme:dark){
  .carte figcaption{color:#e7e3f2}
  .theme h2{color:#efeafc}
}

/* =====================  TIRAGE PROGRESSIF (interactif)  ===================== */
#tirageApp{margin:1.5rem 0}
/* La croix */
.croix{display:grid;grid-template-columns:repeat(3,92px);grid-template-rows:repeat(3,150px);
  gap:12px;justify-content:center;margin:1.5rem auto;min-height:150px}
.slot{width:92px;height:150px}
.slot.pos-top{grid-column:2;grid-row:1}
.slot.pos-left{grid-column:1;grid-row:2}
.slot.pos-center{grid-column:2;grid-row:2}
.slot.pos-right{grid-column:3;grid-row:2}
.slot.pos-bottom{grid-column:2;grid-row:3}
.slot .flipper{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s ease}
.slot.flipped .flipper{transform:rotateY(180deg)}
.slot .cardback,.slot .cardface{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  border:2px solid var(--gold);border-radius:9px;overflow:hidden;box-shadow:0 6px 16px rgba(0,0,0,.25)}
.slot .cardback{background:radial-gradient(circle at 50% 35%,#3a2f73,#140f31);display:grid;place-items:center;color:var(--gold-soft);font-size:1.8rem}
.slot .cardface{transform:rotateY(180deg);background:#0e0b1e;display:flex;flex-direction:column}
.slot .cardface img{width:100%;flex:1;min-height:0;object-fit:contain;background:#0e0b1e}
.slot .cardface .cname{font-size:.64rem;line-height:1.2;padding:3px 2px;background:var(--night2);color:var(--gold-soft);text-align:center}
/* Le paquet des 22 faces cachées */
.pool{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:560px;margin:1.4rem auto;transition:opacity .5s}
.pool.spent{opacity:.35;pointer-events:none}
.poolcard{width:46px;height:70px;border:1.5px solid var(--gold);border-radius:7px;cursor:pointer;
  background:radial-gradient(circle at 50% 35%,#3a2f73,#140f31);color:var(--gold-soft);font-size:1rem;
  display:grid;place-items:center;transition:transform .15s,opacity .35s,box-shadow .15s}
.poolcard:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 6px 14px rgba(58,47,115,.5)}
.poolcard.used{opacity:.15;transform:scale(.9)}
.poolcard:disabled{cursor:default}
/* Révélation des thèmes */
#themesBox{display:grid;gap:16px;margin-top:1.5rem}
#themesBox .theme{opacity:0;transform:translateY(12px);transition:opacity .55s ease,transform .55s ease}
#themesBox .theme.show{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .slot .flipper,#themesBox .theme,.poolcard{transition:none}
}
@media (max-width:480px){
  .croix{grid-template-columns:repeat(3,80px);grid-template-rows:repeat(3,130px)}
  .slot{width:80px;height:130px}
}

/* messages succès + cases à cocher inscription */
.success{background:color-mix(in srgb,#3aa06b 12%,var(--paper));border-left:4px solid #3aa06b;padding:12px 14px;border-radius:0 8px 8px 0;color:var(--night2);margin:0 0 1.2rem;max-width:60ch}
.authform label.checkline{flex-direction:row;align-items:flex-start;gap:9px;font-weight:400;font-size:.9rem;color:var(--ink-soft)}
.authform label.checkline input{margin-top:3px;width:auto}
@media (prefers-color-scheme:dark){ .success{color:#e7e3f2} }

/* bandeau "service temporairement indisponible" */
.notice-indispo{background:color-mix(in srgb,var(--gold) 14%,var(--paper));border:1px solid var(--gold);
  border-radius:10px;padding:14px 18px;margin:0 0 1.4rem;color:var(--night2)}
.notice-indispo a{color:var(--link)}
.indispo-line{color:var(--ink-soft);font-style:italic;background:color-mix(in srgb,var(--line) 40%,transparent);
  display:inline-block;padding:6px 14px;border-radius:8px;margin:6px 0}
.form-indispo{opacity:.5;pointer-events:none}
@media (prefers-color-scheme:dark){ .notice-indispo{color:#efeafc} }

/* écran de choix du tirage (gratuit vs complet) */
.tirage-choices{display:flex;gap:16px;flex-wrap:wrap;margin:1.5rem 0}
.tirage-choices .choice{margin:0}
.choice-btn{display:flex;flex-direction:column;align-items:center;gap:5px;text-align:center;line-height:1.3;padding:16px 26px;cursor:pointer;border:none}
.choice-btn small{font-weight:400;font-size:.8rem;opacity:.85}
.btn-outline{background:transparent;border:2px solid var(--gold);color:var(--night)}
.btn-outline:hover{background:color-mix(in srgb,var(--gold) 15%,transparent)}
.choice-btn .pts{background:var(--night);color:var(--gold-soft);font-size:.7rem;padding:2px 8px;border-radius:999px}
@media (prefers-color-scheme:dark){ .btn-outline{color:#efeafc} }
