@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=DM+Sans:wght@400;500;700&family=Fraunces:ital,opsz,wght@1,9..144,400;1,9..144,500&display=swap');

/* tarot-score.fr — thème illustré "arcanes" (parchemin + cartes vibrantes) */
:root{
  --cream:#f3ead4;        /* parchemin */
  --cream2:#eaddbf;
  --paper:#fffdf6;        /* cartes / panneaux */
  --ink:#221a33;          /* indigo presque noir */
  --ink2:#4d4566;
  --muted:#7b7390;
  --line:#e2d5b6;
  --line2:#d7c79f;
  --indigo:#3f25cf;       /* THE FOOL / THE MOON */
  --indigo-d:#2a17a0;
  --indigo-soft:#ece9fb;
  --orange:#e8531c;       /* THE SUN */
  --gold:#f2a81c;         /* cadres / étoiles */
  --gold-d:#cf8c00;
  --green:#1f6b4f;        /* THE HIGH PRIESTESS */
  --lilac:#b9a3e8;        /* THE MOON clair */
  --good:#1f6b4f; --bad:#c0392b;
  --radius:16px;
  --maxw:1060px;
  --display:"Cinzel",Georgia,"Times New Roman",serif;
  --sans:"DM Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --italic:"Fraunces",Georgia,serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; color:var(--ink); font-family:var(--sans); line-height:1.62; font-size:17px;
  background:var(--cream);
  background-image:radial-gradient(circle at 12% 18%,rgba(63,37,207,.05),transparent 38%),
                   radial-gradient(circle at 88% 12%,rgba(232,83,28,.05),transparent 40%);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.brand{font-family:var(--display); color:var(--ink); font-weight:700; line-height:1.16}
h1{font-size:clamp(2.1rem,5.6vw,3.6rem); text-transform:uppercase; letter-spacing:.02em; margin:.12em 0 .28em}
h2{font-size:clamp(1.4rem,3.2vw,2.05rem); margin:1.7em 0 .5em}
h3{font-size:1.18rem; margin:1.3em 0 .4em; color:var(--indigo-d)}
a{color:var(--indigo-d); text-underline-offset:3px}
a:hover{color:var(--orange)}
p{margin:.65em 0}
code{font-family:ui-monospace,Menlo,Consolas,monospace; background:var(--indigo-soft); padding:2px 6px; border-radius:5px; font-size:.92em; color:var(--indigo-d)}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px}

/* eyebrow + étoiles décoratives */
.eyebrow{font-family:var(--sans); text-transform:uppercase; letter-spacing:.28em; font-size:.72rem; color:var(--orange); font-weight:700; margin:0}
.stars{color:var(--gold); letter-spacing:.4em; font-size:1.1rem; line-height:1}
.lead{font-family:var(--italic); font-style:italic; font-size:1.22rem; color:var(--ink2)}

/* ===== Header ===== */
header.site{position:sticky; top:0; z-index:40; background:rgba(243,234,212,.9); backdrop-filter:blur(10px); border-bottom:1px solid var(--line2)}
.nav{display:flex; align-items:center; gap:16px; padding:13px 22px; max-width:var(--maxw); margin:0 auto; flex-wrap:wrap}
.brand{font-size:1.3rem; color:var(--ink); text-decoration:none; display:flex; align-items:center; gap:8px; font-weight:700; letter-spacing:.04em}
.brand b{color:var(--indigo)}
.nav nav{margin-left:auto; display:flex; gap:2px; flex-wrap:wrap}
.nav nav a{color:var(--ink2); text-decoration:none; padding:7px 12px; border-radius:8px; font-size:.92rem; font-weight:500}
.nav nav a:hover{background:var(--cream2)}
.nav nav a[aria-current]{background:var(--indigo); color:#fff}

/* ===== Hero ===== */
.hero{padding:48px 0 16px; text-align:center}
.hero .eyebrow{margin-bottom:8px}
.hero .stars{display:block; margin:0 0 6px}
.hero p.lead{max-width:660px; margin:.5em auto 0}

/* éventail des cartes (images réelles) */
.card-fan{position:relative; height:340px; margin:26px auto 8px; max-width:760px}
.tcard{position:absolute; left:50%; top:0; width:172px; margin-left:-86px;
  border-radius:14px; box-shadow:0 18px 40px rgba(34,26,51,.28); transform-origin:50% 118%;
  border:1px solid rgba(0,0,0,.06)}
.tcard:nth-child(1){transform:rotate(-26deg) translateX(-30px) translateY(34px)}
.tcard:nth-child(2){transform:rotate(-13deg) translateX(-12px) translateY(8px)}
.tcard:nth-child(3){transform:rotate(0deg); z-index:5}
.tcard:nth-child(4){transform:rotate(13deg) translateX(12px) translateY(8px)}
.tcard:nth-child(5){transform:rotate(26deg) translateX(30px) translateY(34px)}
@media(max-width:720px){.card-fan{height:230px; transform:scale(.62)}}

/* carte unique dans le hero des pages cluster */
.hero-card{width:188px; border-radius:14px; box-shadow:0 16px 36px rgba(34,26,51,.26); margin:22px auto 4px; display:block}

/* ===== Panneaux ===== */
.panel{background:var(--paper); border:1px solid var(--line2); border-radius:var(--radius); padding:24px; margin:22px 0;
  box-shadow:0 10px 30px rgba(34,26,51,.06)}
/* cadre "carte de tarot" : double filet or */
.panel.tarot-frame{position:relative; box-shadow:inset 0 0 0 4px var(--paper),inset 0 0 0 5px var(--gold),0 12px 34px rgba(34,26,51,.1); border:1.5px solid var(--ink)}
.panel.tarot-frame::before{content:"✦"; position:absolute; top:9px; left:14px; color:var(--gold); font-size:.9rem}
.panel.tarot-frame::after{content:"✦"; position:absolute; bottom:9px; right:14px; color:var(--gold); font-size:.9rem}

.grid{display:grid; gap:16px}
@media(min-width:680px){.cols-2{grid-template-columns:1fr 1fr}.cols-3{grid-template-columns:1fr 1fr 1fr}}
label{display:block; font-family:var(--sans); font-size:.7rem; color:var(--muted); margin:0 0 6px; text-transform:uppercase; letter-spacing:.12em; font-weight:700}
select,input[type=number],input[type=text]{width:100%; padding:12px 13px; border-radius:9px;
  border:1px solid var(--line2); background:#fff; color:var(--ink); font-size:1.04rem; font-family:inherit}
select:focus,input:focus{outline:none; border-color:var(--indigo); box-shadow:0 0 0 3px var(--indigo-soft)}

/* boutons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; cursor:pointer;
  border:1px solid var(--indigo); border-radius:10px; padding:12px 20px; font-size:1rem; font-weight:700;
  font-family:var(--sans); background:var(--indigo); color:#fff; transition:.14s}
.btn:hover{background:var(--indigo-d); border-color:var(--indigo-d)}
.btn.ghost{background:transparent; color:var(--ink); border:1px solid var(--line2)}
.btn.ghost:hover{background:var(--cream2); border-color:var(--ink); color:var(--ink)}
.btn.alt{background:var(--orange); color:#fff; border-color:var(--orange)}
.btn.alt:hover{background:#c8410f; border-color:#c8410f}
.btn-row{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}

/* segments */
.seg{display:flex; flex-wrap:wrap; gap:7px}
.seg button{flex:1 1 auto; padding:11px 10px; border-radius:9px; border:1px solid var(--line2); background:#fff;
  color:var(--ink2); cursor:pointer; font-family:inherit; font-size:.96rem; font-weight:500; transition:.12s}
.seg button:hover{border-color:var(--indigo)}
.seg button[aria-pressed=true]{background:var(--indigo); color:#fff; border-color:var(--indigo); font-weight:700}

.result{font-size:1.05rem}
.result .big{font-size:1.6rem; font-family:var(--display); color:var(--indigo-d); margin:.1em 0}

/* tableau */
table{width:100%; border-collapse:collapse; margin:12px 0; font-size:.98rem}
th,td{padding:11px 12px; border-bottom:1px solid var(--line); text-align:center}
th{font-family:var(--sans); color:var(--muted); font-size:.7rem; text-transform:uppercase; letter-spacing:.1em; font-weight:700}
td:first-child,th:first-child{text-align:left}
td.pos{color:var(--good); font-weight:700}
td.neg{color:var(--bad); font-weight:700}
tfoot td{font-weight:700; color:var(--ink); border-top:2px solid var(--gold); font-size:1.12rem}

.note{color:var(--muted); font-size:.9rem}

ul.clean{list-style:none; padding:0; margin:.6em 0}
ul.clean li{padding:9px 0 9px 28px; border-bottom:1px solid var(--line); position:relative}
ul.clean li::before{content:"✦"; position:absolute; left:2px; top:10px; color:var(--gold-d); font-size:.78em}

/* cartes liens (à lire aussi) */
.cards{display:grid; gap:14px; margin-top:8px}
@media(min-width:680px){.cards{grid-template-columns:1fr 1fr}}
.card{display:block; background:var(--paper); border:1px solid var(--line2); border-radius:14px; padding:18px; text-decoration:none; color:var(--ink2); transition:.14s}
.card:hover{border-color:var(--indigo); transform:translateY(-2px); box-shadow:0 12px 26px rgba(34,26,51,.1)}
.card b{color:var(--ink); font-family:var(--display); font-size:1.02rem}

/* galerie d'arcanes (accueil) */
.arcanes{display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin:14px 0}
@media(min-width:620px){.arcanes{grid-template-columns:repeat(5,1fr)}}
.arcane{text-align:center}
.arcane img{width:100%; border-radius:12px; box-shadow:0 10px 24px rgba(34,26,51,.16); transition:.16s}
.arcane img:hover{transform:translateY(-4px) rotate(-1.5deg)}
.arcane span{display:block; margin-top:8px; font-family:var(--display); font-size:.82rem; letter-spacing:.05em; color:var(--ink2)}

/* emplacements AdSense */
.ad{display:flex; align-items:center; justify-content:center; margin:22px auto; max-width:728px;
  background:repeating-linear-gradient(45deg,#ece0c4,#ece0c4 11px,#f1e7ce 11px,#f1e7ce 22px);
  border:1px dashed var(--line2); border-radius:9px; color:#a8987a; font-size:.72rem; letter-spacing:.12em; font-family:ui-monospace,Menlo,monospace; text-transform:uppercase}
.ad-top{min-height:100px}
.ad-mid{min-height:250px}
.ad-foot{min-height:100px}

footer.site{margin-top:48px; border-top:1px solid var(--line2); background:var(--cream2)}
footer.site .wrap{padding:26px 22px; color:var(--muted); font-size:.92rem}
footer.site a{color:var(--ink2); text-decoration:none; margin-right:16px}
footer.site a:hover{color:var(--orange)}

.faq dt{font-weight:700; color:var(--ink); margin-top:16px; font-family:var(--display); font-size:1.02rem}
.faq dd{margin:.3em 0 0; color:var(--ink2)}
dl.faq{margin-top:.4em}

.cookie{position:fixed; bottom:16px; left:16px; right:16px; max-width:540px; margin:0 auto; z-index:60;
  background:var(--paper); border:1px solid var(--ink); border-radius:14px; padding:16px 18px; box-shadow:0 16px 44px rgba(34,26,51,.24); display:none}
.cookie.show{display:block}
.cookie p{margin:0 0 10px; font-size:.9rem; color:var(--ink2)}

article{font-size:1.04rem}

@media print{
  header.site,footer.site,.ad,.cookie,.btn-row,.card-fan,.hero-card,.arcanes,.stars,.no-print{display:none!important}
  body{background:#fff; color:#000}
  .panel{box-shadow:none; border:1px solid #999; background:#fff}
}
