/* ===========================================================================
   Taromorphose — Tirage. Tout est scopé sous .tt-tirage pour éviter les conflits.
   Polices / marges / paddings en rem (base 16px). Design issu des maquettes.
   =========================================================================== */
/* Police Outfit embarquée — déposez les fichiers dans assets/fonts/ du plugin. */
@font-face{font-family:"Outfit";font-style:normal;font-weight:300;font-display:swap;
  src:url("../fonts/Outfit-Light.woff2") format("woff2"),url("../fonts/Outfit-Light.woff") format("woff")}
@font-face{font-family:"Outfit";font-style:normal;font-weight:400;font-display:swap;
  src:url("../fonts/Outfit-Regular.woff2") format("woff2"),url("../fonts/Outfit-Regular.woff") format("woff")}
@font-face{font-family:"Outfit";font-style:normal;font-weight:500;font-display:swap;
  src:url("../fonts/Outfit-Medium.woff2") format("woff2"),url("../fonts/Outfit-Medium.woff") format("woff")}

.tt-tirage{
  --beige:#FBF4EB; --beige-2:#F1E6D6;
  --main:#D26A43; --main-soft:#EBB89E; --secondary:#6B4488; --violet:#C2B4E2; --violet-soft:#E9E1F4;
  --ink:#221C2B; --ink-mut:#5A5060; --line:#E2D3C2;
  --font:"Outfit",system-ui,sans-serif;
  --sh-s:0 2px 12px rgba(110,80,80,.10);
  --sh-m:0 18px 50px rgba(107,68,136,.14);
  --sh-card:0 24px 60px rgba(80,50,80,.22);
  font-family:var(--font);font-weight:300;color:var(--ink);line-height:1.6;max-width:1140px;margin:0 auto;
}
.tt-tirage *{box-sizing:border-box}
.tt-tirage h3{font-weight:300;margin:0;line-height:1.12}
.tt-tirage strong,.tt-tirage b{font-weight:500}
.tt-tirage .tt-hidden{display:none !important}   /* utilitaire masquage (au lieu de style inline) */
/* mode formation : pas de question (les modes de tirage sont en haut) */
.tt-formation .tt-ask-question{display:none}
.tt-formation .tt-mode-block{margin-top:0;padding-top:0;border-top:0}

/* ---- formation : pickers segmentés (disposition / type) ---- */
.tt-pickers{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem 2.5rem;margin-bottom:.5rem}
.tt-picker{display:flex;flex-direction:column;align-items:center;gap:.6rem}
.tt-p-label{font-size:.8125rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--secondary)}
.tt-pickers .tt-seg{flex-wrap:wrap;justify-content:center;max-width:100%}
.tt-pickers .tt-seg-btn{display:flex;flex-direction:column;align-items:center;gap:.1rem;line-height:1.12;padding:.5rem 1.1rem}
.tt-pickers .tt-seg-btn .t{font-size:.875rem;font-weight:500}
.tt-pickers .tt-seg-btn .n{font-size:.7rem;font-weight:400;opacity:.85;letter-spacing:.01em}
.tt-disp-seg .tt-seg-btn .n{max-width:16ch;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---- formation : board (tirage + légende, sans detail) ---- */
.tt-board{display:grid;grid-template-columns:1.35fr 1fr;gap:2.25rem;align-items:start;margin-top:1.5rem}
.tt-stage-col{min-width:0}
.tt-legend{position:sticky;top:1.5rem;text-align:left;background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--sh-s);padding:1.5rem 1.625rem}
.tt-legend-sub{font-size:.85rem;color:var(--ink-mut);line-height:1.5;margin:.6rem 0 1.1rem}
.tt-legend-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.tt-legend-list li{display:flex;align-items:center;gap:.75rem;padding:.55rem .7rem;border-radius:12px;border:1px solid transparent;transition:background .2s,border-color .2s}
.tt-legend-list li::before,.tt-legend-list li::marker{content:none !important;display:none !important}
.tt-leg-badge{flex:none;width:1.75rem;height:1.75rem;border-radius:8px;background:var(--violet-soft);color:var(--secondary);font-weight:500;font-size:.85rem;display:flex;align-items:center;justify-content:center}
.tt-leg-role{font-size:.9rem;color:var(--ink-mut);line-height:1.3}
.tt-legend-list li.on{border-color:var(--violet);background:var(--violet-soft)}
.tt-legend-list li.on .tt-leg-badge{background:var(--secondary);color:#fff}
.tt-legend-list li.on .tt-leg-role{color:var(--ink);font-weight:500}
@media(max-width:860px){
  .tt-board{grid-template-columns:1fr;gap:1.5rem}
  .tt-legend{position:static}
}

/* ---- question ---- */
.tt-ask{max-width:760px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--sh-m);padding:1.875rem 2rem;display:flex;flex-direction:column}
.tt-label{font-size:1rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--secondary)}
.tt-field{margin-top:.75rem}
.tt-ta-wrap{position:relative}
.tt-q{width:100%;border:none;resize:none;font-family:var(--font);font-size:1.1875rem;font-weight:400;color:var(--ink);background:transparent;line-height:1.4;height:calc(var(--inputs-height, 2em) * 1.5);outline:none}
.tt-ta-hint{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:.125rem;height:1.4em;font-size:1.1875rem;line-height:1.4;pointer-events:none}
.tt-ta-hint.gone{display:none}
.tt-caret{display:inline-block;width:2px;height:1.3em;background:var(--main);border-radius:1px;animation:ttCaret 1.05s steps(1,end) infinite}
@keyframes ttCaret{0%,50%{opacity:1}51%,100%{opacity:0}}
.tt-hint-text{color:#b3a596;font-style:italic;transition:opacity .45s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - .5rem)}

/* ---- mode choice ---- */
.tt-mode-block{margin-top:1.375rem;padding-top:1.25rem;border-top:1px solid var(--line)}
.tt-mode-choice{display:flex;gap:.875rem;flex-wrap:wrap;margin-top:.75rem}
.tt-mode-card{flex:1 1 220px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:1.375rem 1.25rem;box-shadow:var(--sh-s);cursor:pointer;text-align:left;font-family:var(--font);transition:transform .2s,box-shadow .2s,border-color .2s,background .2s}
.tt-mode-card:hover{transform:translateY(-4px);box-shadow:var(--sh-m);border-color:var(--main)}
.tt-mode-card h3{font-size:1.05rem;font-weight:500;margin-bottom:.5rem;color:var(--ink)}
.tt-mode-card p{font-size:.8rem;color:var(--ink-mut);line-height:1.5;margin:0}
.tt-mode-card .tt-go{margin-top:.875rem;font-size:.8125rem;font-weight:500;color:var(--main);display:inline-flex;gap:.375rem}
.tt-mode-card.active{border-color:var(--secondary);box-shadow:var(--sh-card),0 0 0 2px var(--secondary);background:var(--violet-soft)}

/* ---- stage ---- */
.tt-stage{padding:2.5rem 0 .625rem;text-align:center;position:relative}
/* Titres "Sélectionnez…" et "Votre tirage" au format .tt-label */
.tt-pick-count{font-size:1rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--secondary);margin-bottom:1.125rem;min-height:1.3125rem}
.tt-deck-hint{margin-top:1rem;font-size:.8125rem;color:var(--ink-mut)}

/* deck fan */
.tt-deck{position:relative;height:252px;display:flex;align-items:center;justify-content:center;margin-top:.5rem;--fan:1.4}
.tt-dc{position:absolute;width:118px;height:178px;border-radius:14px;transform-origin:50% 155%;transform:rotate(calc(var(--ang)*var(--fan)));cursor:pointer;transition:transform .5s cubic-bezier(.2,.8,.2,1),opacity .5s,box-shadow .25s;
  background:linear-gradient(160deg,#fff,#F7EFE6);border:1px solid var(--main-soft);box-shadow:var(--sh-s);background-size:cover;background-position:center}
.tt-deck:not(.locked) .tt-dc:hover{transform:rotate(calc(var(--ang)*var(--fan))) translateY(-32px);z-index:99;box-shadow:var(--sh-m)}
.tt-dc.used{transform:rotate(calc(var(--ang)*var(--fan))) translateY(-280px) scale(.62);opacity:0;pointer-events:none}
.tt-deck.shuffling .tt-dc{animation:ttRiffle .72s ease both}
@keyframes ttRiffle{0%{transform:rotate(calc(var(--ang)*var(--fan)))}25%{transform:translateY(-24px) rotate(calc(var(--ang)*var(--fan) - 7deg))}55%{transform:translateY(10px) rotate(calc(var(--ang)*var(--fan) + 7deg))}100%{transform:rotate(calc(var(--ang)*var(--fan)))}}

.tt-deck-controls{margin-top:1.125rem;display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.tt-soft{font-family:var(--font);font-weight:500;font-size:.875rem;color:var(--secondary);background:#fff;border:1px solid var(--line);padding:.6875rem 1.375rem;border-radius:999px;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:var(--sh-s)}
.tt-soft:hover{border-color:var(--secondary);box-shadow:var(--sh-m);transform:translateY(-1px)}

/* manual grid */
.tt-manual-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:.5rem;max-width:820px;margin:.875rem auto 0}
.tt-manual-reset{margin-top:1.125rem}
.tt-mcard{position:relative;display:flex;flex-direction:column;align-items:center;gap:.375rem;background:#fff;border:1px solid var(--line);border-radius:12px;padding:.625rem;cursor:pointer;font-family:var(--font);transition:transform .15s,box-shadow .2s,border-color .2s,background .2s}
.tt-mcard:hover{transform:translateY(-2px);box-shadow:var(--sh-m);border-color:var(--main)}
.tt-mcard img{width:100%;aspect-ratio:15/29;object-fit:cover;border-radius:8px}
.tt-mcard .num{font-size:.625rem;letter-spacing:.14em;color:var(--secondary);font-weight:500}
.tt-mcard .nm{font-size:.72rem;font-weight:500;color:var(--ink);text-transform:uppercase;letter-spacing:.02em;line-height:1.15;text-align:center}
.tt-mcard .badge{position:absolute;top:6px;left:6px;width:1.3125rem;height:1.3125rem;border-radius:50%;background:var(--secondary);color:#fff;font-size:.6875rem;font-weight:500;display:none;align-items:center;justify-content:center}
.tt-mcard.sel{border-color:var(--secondary);box-shadow:var(--sh-card),0 0 0 2px var(--secondary);background:var(--violet-soft)}
.tt-mcard.sel .badge{display:flex}
.tt-mcard.sel::after{content:"✕";position:absolute;top:6px;right:6px;width:1.3125rem;height:1.3125rem;border-radius:50%;background:#fff;border:1px solid var(--line);color:var(--main);font-size:.7rem;display:flex;align-items:center;justify-content:center}
.tt-mcard.locked:not(.sel){opacity:.42;pointer-events:none}
.tt-mcard .rev{position:absolute;bottom:6px;right:6px;width:1.375rem;height:1.375rem;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--secondary);font-size:.8125rem;line-height:1;cursor:pointer;display:none}
.tt-tirage.tt-rev-on .tt-mcard.sel .rev{display:block}   /* ↻ seulement si renversé autorisé */
.tt-mcard.is-rev .rev{background:var(--secondary);color:#fff}
.tt-mcard.is-rev img{transform:rotate(180deg)}

/* switch « cartes renversées » */
.tt-rev-block{margin-top:1.125rem;padding-top:1rem;border-top:1px solid var(--line)}
.tt-switch-row{display:flex;align-items:flex-start;gap:.875rem;cursor:pointer;text-align:left;max-width:560px}
.tt-switch{position:relative;flex:none;margin-top:2px}
.tt-switch input{position:absolute;opacity:0;width:0;height:0}
.tt-switch .track{display:block;width:46px;height:26px;border-radius:999px;background:var(--beige-2);border:1px solid var(--line);transition:background .25s,border-color .25s}
.tt-switch .thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.18);transition:transform .25s}
.tt-switch input:checked + .track{background:var(--secondary);border-color:var(--secondary)}
.tt-switch input:checked + .track .thumb{transform:translateX(20px)}
.tt-switch-txt{display:flex;flex-direction:column;gap:.1875rem;font-size:.84rem}
.tt-switch-txt b{font-weight:500;color:var(--ink)}
.tt-switch-txt .desc{font-size:.75rem;color:var(--ink-mut);line-height:1.45}

/* ---- titre "Votre tirage" : séparateur + marge entre blocs ---- */
.tt-spread-title{display:block;text-align:center;margin:2rem 0 1.125rem;padding-top:1.75rem;border-top:1px solid var(--line)}

/* ---- spread (cartes tirées) ---- */
.tt-spread{display:flex;justify-content:center;gap:clamp(.875rem,3vw,2.5rem);flex-wrap:wrap;perspective:1400px;margin-top:.5rem}
.tt-slot{width:clamp(150px,20vw,200px);opacity:0;transition:opacity .5s,transform .8s cubic-bezier(.2,.8,.2,1)}
.tt-slot.empty{opacity:1;transform:none}            /* dos de carte visible avant le tirage */
.tt-slot.in{opacity:1;transform:none}
.tt-slot.card{transform:translateY(-220px) translateX(60px) scale(.5) rotate(-12deg)}
.tt-slot.card.in{transform:none}
.tt-pos{font-size:.6875rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--main);margin-bottom:.75rem}
.tt-flip{position:relative;width:100%;aspect-ratio:15/29;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.4,.1,.2,1)}
.tt-flip.flipped{transform:rotateY(180deg)}
.tt-face{position:absolute;inset:0;backface-visibility:hidden;border-radius:16px;overflow:hidden}
.tt-face.back{display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#fff,#F7EFE6);border:1px solid var(--main-soft);box-shadow:var(--sh-s);background-size:cover;background-position:center}
.tt-face.front{transform:rotateY(180deg);background:#fff;border:1px solid var(--line);box-shadow:var(--sh-card);overflow:hidden;display:flex;flex-direction:column}
.tt-face.front img{width:100%;height:100%;object-fit:cover;display:block}
.tt-face.front.reversed img{transform:rotate(180deg)}

/* légende sous la carte révélée : numéro + nom + sens (CPT carte) */
.tt-card-under{margin-top:.75rem;text-align:center;opacity:0;transition:opacity .5s}
.tt-card-under.in{opacity:1}
.tt-cu-head{font-size:.8125rem;line-height:1.3}
.tt-cu-num{color:var(--secondary);font-weight:500;letter-spacing:.1em}
.tt-cu-name{font-weight:500;text-transform:uppercase;color:var(--ink)}
.tt-cu-rev{color:var(--main);font-weight:500;font-size:.6875rem}
.tt-cu-sens{margin:.375rem 0 0;font-size:.8125rem;color:var(--ink-mut);line-height:1.5;white-space:pre-line}

/* ---- géométries (reprises de dispositions-tirage.html) ---- */
/* grille pour 1 / 4 / 5 cartes ; colonnes à largeur fixe --cw */
.tt-spread[data-spread="jour"],
.tt-spread[data-spread="doute"],
.tt-spread[data-spread="liberation"]{--cw:clamp(110px,15vw,160px);display:grid;justify-content:center;align-items:center;flex-wrap:nowrap}
.tt-spread[data-spread="jour"] .tt-slot,
.tt-spread[data-spread="doute"] .tt-slot,
.tt-spread[data-spread="liberation"] .tt-slot{width:var(--cw)}
/* pas d'animation de glisse en grille (sinon conflit avec le positionnement) */
.tt-spread[data-spread="jour"] .tt-slot.card,
.tt-spread[data-spread="jour"] .tt-slot.card.in,
.tt-spread[data-spread="doute"] .tt-slot.card,
.tt-spread[data-spread="doute"] .tt-slot.card.in,
.tt-spread[data-spread="liberation"] .tt-slot.card,
.tt-spread[data-spread="liberation"] .tt-slot.card.in{transform:none}

/* 1 carte — centrée */
.tt-spread[data-spread="jour"]{grid-template-columns:var(--cw);grid-template-areas:"a";justify-items:center}
.tt-spread[data-spread="jour"] [data-p="a"]{grid-area:a}

/* 4 cartes — losange : D haut, B/C milieu (éventail), A bas */
.tt-spread[data-spread="doute"]{grid-template-columns:repeat(3,var(--cw));grid-template-areas:". d ." "b . c" ". a .";row-gap:.5rem;column-gap:.75rem}
.tt-spread[data-spread="doute"] [data-p="d"]{grid-area:d}
.tt-spread[data-spread="doute"] [data-p="a"]{grid-area:a}
.tt-spread[data-spread="doute"] [data-p="b"]{grid-area:b;transform:translateX(52%) !important;z-index:2}
.tt-spread[data-spread="doute"] [data-p="c"]{grid-area:c;transform:translateX(-52%) !important;z-index:2}

/* 5 cartes — croix : E haut, B·C·D rangée, A bas */
.tt-spread[data-spread="liberation"]{grid-template-columns:repeat(3,var(--cw));grid-template-areas:". e ." "b c d" ". a .";gap:.875rem .625rem}
.tt-spread[data-spread="liberation"] [data-p="e"]{grid-area:e}
.tt-spread[data-spread="liberation"] [data-p="b"]{grid-area:b}
.tt-spread[data-spread="liberation"] [data-p="c"]{grid-area:c}
.tt-spread[data-spread="liberation"] [data-p="d"]{grid-area:d}
.tt-spread[data-spread="liberation"] [data-p="a"]{grid-area:a}

/* ---- synthèse / reset ---- */
.tt-synth{max-width:680px;margin:1.125rem auto 0;background:var(--violet-soft);border-radius:22px;padding:0;opacity:0;transform:translateY(16px);transition:.6s;overflow:hidden}
.tt-synth.in{opacity:1;transform:none}
.tt-synth-body{padding:1.625rem 1.875rem;font-size:1rem;color:#3A2C47;line-height:1.55;text-align:left}
.tt-again{margin-top:1.5rem;display:flex;justify-content:center;opacity:0;transition:.5s}
.tt-again.in{opacity:1}
.tt-btn{font-family:var(--font);font-weight:500;font-size:.9375rem;border:none;border-radius:999px;padding:.875rem 1.75rem;cursor:pointer;transition:transform .2s,box-shadow .2s}
.tt-btn-ghost{background:transparent;border:1px solid var(--line);color:var(--secondary)}
.tt-btn-ghost:hover{border-color:var(--secondary);background:#fff}

/* ---- wait modal ---- */
.tt-wait{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:rgba(34,28,43,.42);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .4s}
.tt-wait.in{opacity:1;pointer-events:auto}
.tt-wait-box{background:linear-gradient(170deg,#fff,#FBF4EC);border:1px solid var(--line);border-radius:26px;box-shadow:var(--sh-card);max-width:440px;width:100%;padding:2.375rem 2.25rem 2rem;text-align:center;transform:translateY(18px) scale(.96);transition:transform .45s cubic-bezier(.2,.9,.3,1)}
.tt-wait.in .tt-wait-box{transform:none}
.tt-orbit{width:84px;height:84px;margin:0 auto 1.375rem;position:relative}
.tt-ring{position:absolute;inset:0;border-radius:50%;border:2px solid var(--violet);border-top-color:var(--main);animation:ttSpin 1.4s linear infinite}
.tt-ring.two{inset:14px;border-color:var(--main-soft);border-top-color:var(--secondary);animation-duration:2.1s;animation-direction:reverse}
@keyframes ttSpin{to{transform:rotate(360deg)}}
.tt-wait-box h3{font-size:1.5rem;font-weight:500;margin-bottom:.625rem}
.tt-wait-warn{font-size:.84rem;color:var(--main);font-weight:500;margin:0 auto;max-width:34ch}
.tt-wait-phrase{margin-top:1.25rem;font-size:1rem;font-style:italic;color:var(--ink-mut);min-height:3rem;transition:opacity .5s}
.tt-wait-bar{margin-top:1.375rem;height:5px;border-radius:999px;background:var(--beige-2);overflow:hidden}
.tt-wait-bar span{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--main),var(--secondary))}

/* sélecteur d'orientation (mode « mon jeu ») */
.tt-orient{display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap;margin:0 auto 1.125rem}
.tt-orient-label{font-size:.75rem;font-weight:500;letter-spacing:.04em;color:var(--secondary)}
.tt-seg{display:inline-flex;background:var(--beige-2);border:1px solid var(--line);border-radius:999px;padding:.25rem;gap:.125rem}
.tt-seg-btn{font-family:var(--font);font-size:.8125rem;font-weight:500;color:var(--ink-mut);background:transparent;border:none;padding:.5rem 1rem;border-radius:999px;cursor:pointer;transition:color .2s,background .2s,box-shadow .2s;white-space:nowrap}
.tt-seg-btn:hover{color:var(--main)}
.tt-seg-btn.active{color:#fff;background:var(--secondary);box-shadow:0 4px 12px rgba(107,68,136,.28)}

/* affichage configurable des images en sélection « mon jeu » (desktop / mobile) */
@media(min-width:761px){ .tt-tirage:not(.tt-mimg-d) .tt-mcard img{display:none} }
@media(max-width:760px){ .tt-tirage:not(.tt-mimg-m) .tt-mcard img{display:none} }

/* pop-up de message (remplace les alert) */
.tt-msg{position:fixed;inset:0;z-index:110;display:none;align-items:center;justify-content:center;padding:1.5rem;background:rgba(34,28,43,.5);backdrop-filter:blur(6px)}
.tt-msg.in{display:flex;animation:ttFade .25s ease}
@keyframes ttFade{from{opacity:0}to{opacity:1}}
.tt-msg-box{position:relative;max-width:460px;width:100%;background:linear-gradient(170deg,#fff,#FBF4EC);border:1px solid var(--line);border-radius:22px;box-shadow:var(--sh-card);padding:2.125rem 2rem 1.75rem;text-align:center;animation:tiragePop .35s ease}
@keyframes tiragePop{from{opacity:0;transform:translateY(-12px) scale(.98)}to{opacity:1;transform:none}}
.tt-msg-close{position:absolute;top:10px;right:14px;border:0;background:none;font-size:1.75rem;line-height:1;color:#999;cursor:pointer}
.tt-msg-close:hover{color:#333}
.tt-msg-body h3{font-size:1.375rem;font-weight:500;color:var(--secondary);margin-bottom:.625rem}
.tt-msg-body p{font-size:.9375rem;color:var(--ink-mut);line-height:1.5;margin:0}
.tt-msg-actions{margin-top:1.375rem;display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.tt-btn-main{background:var(--main);color:#fff;box-shadow:0 8px 20px rgba(210,106,67,.3)}
.tt-btn-main:hover{transform:translateY(-2px)}

@media(max-width:760px){
  .tt-deck{--fan:.82}
  .tt-spread[data-spread="trois"]{flex-wrap:wrap}
}

/* ===== Page de choix des tarots : [taromorphose_tarots] ===== */
.tt-tarots{
  --main:#D26A43;--secondary:#6B4488;--ink:#221C2B;--ink-mut:#5A5060;--line:#E2D3C2;--violet-soft:#E9E1F4;
  --sh-s:0 2px 12px rgba(110,80,80,.10);--sh-m:0 18px 50px rgba(107,68,136,.14);
  font-family:"Outfit",system-ui,sans-serif;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;max-width:1100px;margin:0 auto;
}
.tt-tarot-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:1rem;overflow:hidden;box-shadow:var(--sh-s);text-decoration:none;color:var(--ink);transition:transform .25s,box-shadow .25s,border-color .25s}
.tt-tarot-card:hover{transform:translateY(-4px);box-shadow:var(--sh-m);border-color:var(--main)}
.tt-tarot-img{width:100%;aspect-ratio:3/2;object-fit:cover;background:var(--violet-soft);display:block}
.tt-tarot-body{padding:1.25rem 1.25rem 1.4rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.tt-tarot-body h3{font-size:1.15rem;font-weight:500;margin:0;color:var(--secondary)}
.tt-tarot-body p{font-size:.9rem;color:var(--ink-mut);line-height:1.5;margin:0;flex:1}
.tt-tarot-duree{font-size:.75rem;font-weight:500;letter-spacing:.04em;color:var(--main);text-transform:uppercase}
.tt-tarot-cta{margin-top:.4rem;font-size:.9rem;font-weight:500;color:var(--main)}
.tt-tarot-card:hover .tt-tarot-cta{text-decoration:underline}

/* ===== mode formation : fiches détaillées (CPT Cartes) ===== */
.tt-fiches{margin-top:3rem;max-width:880px;margin-inline:auto}
.tt-fiches-head{text-align:center;margin-bottom:1.25rem}
.tt-fiches-sub{font-size:.9rem;color:var(--ink-mut);margin:.5rem 0 0}
/* accordéon (multi-cartes) */
.tt-facc{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.55);margin-top:.875rem;box-shadow:var(--sh-s);transition:box-shadow .25s,border-color .25s;overflow:hidden}
.tt-facc.open{box-shadow:var(--sh-m);border-color:var(--violet)}
.tt-facc-head{display:flex;align-items:center;gap:.9rem;width:100%;text-align:left;font-family:var(--font);background:transparent;border:none;cursor:pointer;padding:1.05rem 1.375rem;color:var(--ink)}
.tt-facc-head:disabled{cursor:default}
.tt-facc-badge{flex:none;width:1.875rem;height:1.875rem;border-radius:9px;background:var(--violet-soft);color:var(--secondary);font-weight:500;display:flex;align-items:center;justify-content:center;font-size:.875rem}
.tt-facc.open .tt-facc-badge{background:var(--secondary);color:#fff}
.tt-facc-role{font-weight:500;font-size:.95rem;color:var(--secondary);white-space:nowrap}
.tt-facc-meta{font-size:.8125rem;color:var(--ink-mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.tt-facc.filled .tt-facc-meta{color:var(--ink)}
.tt-facc-chev{margin-left:auto;flex:none;color:var(--secondary);font-size:1.4rem;line-height:1;transition:transform .3s}
.tt-facc:not(.filled) .tt-facc-chev{opacity:.3}
.tt-facc.open .tt-facc-chev{transform:rotate(90deg)}
.tt-facc-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s ease}
.tt-facc.open .tt-facc-body{grid-template-rows:1fr}
.tt-facc-inner{overflow:hidden;min-height:0}
.tt-facc-inner .tt-fiche{padding:0 1.375rem 1.5rem}
/* carte unique */
.tt-fiche-single{margin-top:1rem}
.tt-fiche-lock{text-align:center;padding:1.875rem;font-size:.875rem;font-style:italic;color:var(--ink-mut);border:1px dashed var(--line);border-radius:18px;background:rgba(255,255,255,.4)}
/* fiche (mise en page reprise de Formation Tirages.html) */
.tt-fiche-band{display:flex;align-items:center;gap:2rem;border-radius:18px;padding:1.75rem 2rem;background:linear-gradient(95deg,#FBE7D6 0%,#EBB89E 100%)} /* fond dégradé */
.tt-fiche-art{flex:none;width:130px;aspect-ratio:15/29;object-fit:cover;border-radius:10px;box-shadow:var(--sh-card)} /* visuel à gauche (1er dans le DOM) */
.tt-fiche-band-txt{flex:1;min-width:0}
.tt-fiche-name{font-size:clamp(1.4rem,2.8vw,2.1rem);font-weight:300;color:#2A2030;line-height:1.1}
.tt-fiche-rev{margin:.7rem 0 0;font-size:.85rem;color:#7a3f28}
.tt-fiche-rev b{color:var(--main);font-weight:500}
.tt-fiche-h{font-size:clamp(1.1rem,2vw,1.45rem);font-weight:300;color:var(--secondary);line-height:1.14;margin:0}
/* significations : 2 colonnes */
.tt-fiche-signif{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 3rem;margin-top:2rem}
.tt-fiche-signif p{margin:.9rem 0 0;font-size:.9rem;color:#473e4f;line-height:1.6;white-space:pre-line}
/* vie quotidienne : encadré (gauche) + domaines (droite) */
.tt-fiche-vie{display:grid;grid-template-columns:.82fr 1.18fr;gap:1.875rem 3rem;margin-top:2.5rem;align-items:start}
.tt-fiche-box{margin-top:1.25rem;border-radius:14px;padding:1.375rem 1.625rem;background:var(--violet-soft)} /* encadré quotidien violet */
.tt-fiche-box ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.8rem}
.tt-fiche-box li{position:relative;padding-left:1.5rem;font-size:.875rem;color:#473e4f;line-height:1.45;white-space:pre-line}
.tt-fiche-box li b{font-weight:500;color:var(--ink)}
.tt-fiche-box li::before{content:"";position:absolute;left:2px;top:.45em;width:9px;height:9px;border-radius:50%;border:1.6px solid var(--main);box-sizing:border-box} /* puces anneau */
/* domaines de vie : 2 colonnes */
.tt-fiche-domains{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 2.5rem}
.tt-fiche-domain h5{font-size:1.05rem;font-weight:500;color:var(--ink);margin:0 0 .6rem}
.tt-fiche-domain p{margin:0;font-size:.875rem;color:#473e4f;line-height:1.5;white-space:pre-line}
@media(max-width:760px){
  .tt-fiche-band{flex-direction:column;align-items:flex-start;gap:1.25rem}
  .tt-fiche-art{align-self:center}
  .tt-fiche-signif,.tt-fiche-vie,.tt-fiche-domains{grid-template-columns:1fr}
}
