/* ConjuresUp Tarot Deck UI styles
   Scoped to shortcode wrapper to avoid touching the theme. */

.conjuresup-tarot-deck-wrap{
  width: 100%;
}

.conjuresup-tarot-wrap{
  --t-bg1: rgba(255,255,255,.14);
  --t-bg2: rgba(191,174,216,.28);
  --t-bg3: rgba(58,37,94,.80);
  --t-bg4: rgba(27,15,46,.96);
  --t-gold: rgba(246,217,138,0.92);
  --t-text: rgba(255,255,255,0.92);
  --t-text2: rgba(255,255,255,0.78);
  --t-line: rgba(255,255,255,0.14);
  --t-line-gold: rgba(246,217,138,0.35);

  --t-card-w: clamp(105px, 11vw, 140px);
  --t-slot-w: calc(var(--t-card-w) + 20px);
  --t-gap: clamp(10px, 1.1vw, 14px);
  --t-r-outer: 26px;
  --t-r-inner: 18px;
  --t-shadow: 0 18px 48px rgba(0,0,0,.45);
  --t-shadow2: 0 10px 26px rgba(0,0,0,.28);

  color: var(--t-text);
  background: linear-gradient(180deg, var(--t-bg1) 0%, var(--t-bg2) 28%, var(--t-bg3) 68%, var(--t-bg4) 100%);
  border: 1px solid var(--t-line-gold);
  border-radius: var(--t-r-outer);
  box-shadow: var(--t-shadow);
  padding: 28px 30px;
}

.conjuresup-tarot-header{
  text-align: center;
  margin-bottom: 16px;
}

.conjuresup-tarot-title{
  margin: 0;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 28px;
}

.conjuresup-tarot-subtitle{
  margin-top: 6px;
  color: rgba(20, 12, 32, 0.78);
  text-shadow: 0 1px 0 rgba(255,255,255,0.75);
  font-weight: 700;
}

.conjuresup-tarot-spreads{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin: 18px 0 20px;
}

.conjuresup-tarot-spread{
  border-radius: 999px;
  padding: 10px 14px;
  border: 1px solid rgba(246,217,138,0.70);
  background: rgba(255,255,255,0.55);
  color: rgba(20, 12, 32, 0.92);
  cursor: pointer;
  transition: .18s ease;
  box-shadow: 0 10px 24px rgba(0,0,0,0.10);
  font-weight: 700;
}

.conjuresup-tarot-spread:hover{
  background: rgba(255,255,255,0.72);
  box-shadow: 0 12px 28px rgba(0,0,0,0.14);
}

.conjuresup-tarot-spread.is-active{
  background: rgba(246,217,138,0.32);
  border-color: rgba(246,217,138,0.95);
  color: rgba(20, 12, 32, 0.96);
  box-shadow: 0 14px 34px rgba(0,0,0,0.16);
}

/* Locked (non-subscriber) spreads */
.conjuresup-tarot-spread.is-locked{
  opacity: 0.62;
  filter: grayscale(0.25);
  position: relative;
}

.conjuresup-tarot-spread.is-locked::after{
  content: "🔒";
  margin-left: 8px;
  font-size: 0.95em;
  vertical-align: middle;
}

.conjuresup-tarot-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.75fr);
  gap: 16px;
}
@media (max-width: 980px){
  .conjuresup-tarot-grid{ grid-template-columns: 1fr; }
}

.conjuresup-tarot-panel{
  background: rgba(0,0,0,0.12);
  border: 1px solid var(--t-line);
  border-radius: var(--t-r-inner);
  box-shadow: var(--t-shadow2);
  padding: 18px 18px 16px;
}

.conjuresup-tarot-panel-title{
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 14px;
  color: var(--t-gold);
  margin-bottom: 10px;
}

.conjuresup-tarot-panel-text{
  color: var(--t-text2);
  line-height: 1.55;
  margin-bottom: 14px;
}

.conjuresup-tarot-list{
  margin: 0 0 12px 18px;
  color: var(--t-text2);
}

.conjuresup-tarot-reading{
  min-height: 240px;
  border-radius: var(--t-r-inner);
  border: 1px dashed rgba(255,255,255,0.22);
  padding: 14px;
  background: rgba(255,255,255,0.06);
}

.conjuresup-tarot-empty{
  color: rgba(255,255,255,0.78);
  text-align: center;
  padding: 36px 14px;
}

.conjuresup-tarot-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-start;
  margin-top: 12px;
}

.conjuresup-tarot-btn{
  border-radius: 999px;
  padding: 10px 14px;
  border: 1px solid var(--t-line-gold);
  background: rgba(255,255,255,0.10);
  color: var(--t-gold);
  cursor: pointer;
  transition: .18s ease;
}

.conjuresup-tarot-btn:hover{
  background: rgba(246,217,138,0.14);
}

.conjuresup-tarot-btn-primary{
  background: rgba(246,217,138,0.18);
  border-color: rgba(246,217,138,0.55);
  color: rgba(255,255,255,0.96);
}

@keyframes conjuresupTarotPulse{
  0%{
    box-shadow: 0 0 0 0 rgba(246,217,138,0.10);
    transform: translateZ(0) scale(1);
    filter: brightness(1) saturate(1);
  }
  50%{
    box-shadow: 0 0 0 12px rgba(246,217,138,0.22);
    transform: translateZ(0) scale(1.02);
    filter: brightness(1.07) saturate(1.05);
  }
  100%{
    box-shadow: 0 0 0 0 rgba(246,217,138,0.10);
    transform: translateZ(0) scale(1);
    filter: brightness(1) saturate(1);
  }
}

.conjuresup-tarot-btn.conjuresup-tarot-btn-pulse{
  animation: conjuresupTarotPulse 2.6s ease-in-out infinite;
}

.conjuresup-tarot-btn-small{
  padding: 7px 10px;
  font-size: 12px;
}

.conjuresup-tarot-spread-head{
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
  margin-bottom: 10px;
}

.conjuresup-tarot-spread-name{
  font-weight: 600;
  letter-spacing: .04em;
}

.conjuresup-tarot-spread-meta{
  color: rgba(255,255,255,0.70);
  font-size: 12px;
}

.conjuresup-tarot-draw-note{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(255,255,255,0.85);
}

.conjuresup-tarot-deck-warn{
  margin-top: 8px;
  font-size: 12px;
  color: rgba(255,220,170,0.95);
}

.conjuresup-tarot-spread-grid{
  display: grid;
  gap: 12px;
}

.conjuresup-tarot-spread-grid.is-three{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
.conjuresup-tarot-spread-grid.is-five{ grid-template-columns: repeat(5, minmax(0, 1fr)); }
.conjuresup-tarot-spread-grid.is-celtic{ display:grid; }
@media (max-width: 980px){
  .conjuresup-tarot-spread-grid.is-five{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .conjuresup-tarot-spread-grid.is-celtic{ display:grid; }
}

.conjuresup-tarot-slot{
  width: var(--t-slot-w);
  max-width: var(--t-slot-w);
  text-align: left;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(0,0,0,0.10);
  padding: 10px;
  cursor: pointer;
  transition: .18s ease;
}
.conjuresup-tarot-slot:hover{
  border-color: rgba(246,217,138,0.35);
  box-shadow: 0 12px 22px rgba(0,0,0,.22);
}

.conjuresup-tarot-slot-label{
  font-size: 12px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.70);
  margin-bottom: 8px;
}

.conjuresup-tarot-slot-card{
  width: var(--t-card-w);
  margin: 0 auto;
  /* Tarot cards are closer to 11/19 than 3/4; this reduces awkward cropping. */
  aspect-ratio: 11 / 19;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  overflow: hidden;
  position: relative;
  perspective: 1000px;
}

.conjuresup-tarot-flip{
  position: absolute;
  inset: 0;
  transform-style: preserve-3d;
  transition: transform .55s ease;
}

.conjuresup-tarot-face{
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  border-radius: 14px;
  overflow: hidden;
}

.conjuresup-tarot-back{
  background-image: var(--csut-back-a);
  background-size: cover;
  background-position: center;
  filter: saturate(1.05) contrast(1.02);
}

.conjuresup-tarot-slot[data-back="b"] .conjuresup-tarot-back{
  background-image: var(--csut-back-b);
}

.conjuresup-tarot-front{
  transform: rotateY(180deg);
  background: rgba(12,7,22,0.22);
  display: flex;
  align-items: center;
  justify-content: center;
}

.conjuresup-tarot-slot.is-revealed .conjuresup-tarot-flip{
  transform: rotateY(180deg);
}


.conjuresup-tarot-slot-face{
  padding: 10px;
  text-align: center;
  color: rgba(255,255,255,0.85);
  font-weight: 600;
  line-height: 1.25;
}

.conjuresup-tarot-slot-face img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.conjuresup-tarot-slot.is-reversed .conjuresup-tarot-slot-face img{
  transform: rotate(180deg);
}

.conjuresup-tarot-slot.is-reversed .conjuresup-tarot-slot-face{
  opacity: 0.92;
}

/* History */
.conjuresup-tarot-history{ margin-top: 10px; }
.conjuresup-tarot-history-head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}
.conjuresup-tarot-history-item{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.06);
  padding: 12px;
  margin-bottom: 10px;
}
.conjuresup-tarot-history-top{
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
.conjuresup-tarot-history-title{ font-weight: 600; }
.conjuresup-tarot-history-when{ color: rgba(255,255,255,0.70); font-size: 12px; }
.conjuresup-tarot-history-cards{ color: rgba(255,255,255,0.80); margin: 8px 0 10px; }
.conjuresup-tarot-history-actions{ display:flex; gap: 8px; }
.conjuresup-tarot-history-empty{ color: rgba(255,255,255,0.75); padding: 6px; }

/* Modal */
.conjuresup-tarot-modal{ position: fixed; inset: 0; z-index: 999999; }
.conjuresup-tarot-modal-backdrop{ position: absolute; inset: 0; background: rgba(0,0,0,0.55); }
.conjuresup-tarot-modal-card{
  position: relative;
  width: min(780px, 94vw);
  margin: 6vh auto;
  border-radius: 22px;
  border: 1px solid rgba(246,217,138,0.40);
  background: radial-gradient(120% 140% at 50% 0%, rgba(246,217,138,.12) 0%, rgba(120,70,180,.22) 18%, rgba(28,15,51,.96) 62%, rgba(11,6,20,.99) 100%);
  box-shadow: 0 22px 65px rgba(0,0,0,.55);
  padding: 18px;
}
.conjuresup-tarot-modal-close{
  position: absolute;
  top: 10px;
  right: 10px;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.25);
  background: rgba(255,255,255,0.92);
  color: #000;
  font-size: 22px;
  cursor: pointer;
}
.conjuresup-tarot-modal-body{ color: rgba(255,255,255,0.92); }
.conjuresup-tarot-modal-title{ font-size: 22px; font-weight: 700; letter-spacing: .04em; }
.conjuresup-tarot-modal-meta{ color: rgba(255,255,255,0.72); margin-top: 4px; }
.conjuresup-tarot-modal-img{ margin: 14px 0 10px; }
.conjuresup-tarot-modal-img img{ width: 100%; max-height: 340px; object-fit: cover; border-radius: 18px; border: 1px solid rgba(255,255,255,0.12); }
.conjuresup-tarot-modal-keywords{ color: rgba(255,255,255,0.78); margin: 6px 0 14px; }
.conjuresup-tarot-modal-section{ border-top: 1px solid rgba(246,217,138,0.25); padding-top: 12px; margin-top: 12px; }
.conjuresup-tarot-modal-h{ color: rgba(246,217,138,0.92); letter-spacing: .10em; text-transform: uppercase; font-size: 12px; margin-bottom: 6px; }
.conjuresup-tarot-modal-p{ line-height: 1.6; color: rgba(255,255,255,0.86); }

body.conjuresup-tarot-modal-open{ overflow: hidden; }


/* === Celtic Cross Layout Fix ===
   Pure CSS layout for .conjuresup-tarot-spread-grid.is-celtic
   Does not affect draw/reshuffle/clear logic.
================================= */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic{ display:grid; }

/* Base: ensure cards don't stretch weirdly */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot{
  width: var(--t-slot-w);
  max-width: var(--t-slot-w);
}

/* Slot mapping (order defined in JS):
   1 Present, 2 Challenge, 3 Past, 4 Future, 5 Above, 6 Below,
   7 Advice, 8 External, 9 Hopes/Fears, 10 Outcome
*/
/* Present (center) */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(1){
  grid-column: 2;
  grid-row: 2;
  z-index: 2;
}
/* Challenge (crossing over Present) */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(2){
  grid-column: 2;
  grid-row: 2;
  z-index: 3;
  transform: rotate(90deg) scale(0.88);
  transform-origin: center center;
}
/* Past (left) */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(3){
  grid-column: 1;
  grid-row: 2;
}
/* Future (right) */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(4){
  grid-column: 3;
  grid-row: 2;
}
/* Above (top) */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(5){
  grid-column: 2;
  grid-row: 1;
}
/* Below (bottom) */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(6){
  grid-column: 2;
  grid-row: 3;
}

/* Staff column (right side) — Outcome (top) → Hopes → External → Advice (bottom) */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(10){
  grid-column: 5;
  grid-row: 1;
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(9){
  grid-column: 5;
  grid-row: 2;
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(8){
  grid-column: 5;
  grid-row: 3;
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(7){
  grid-column: 5;
  grid-row: 4;
}

/* Make the cross column feel visually connected (slightly tighter vertical spacing) */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic{ display:grid; }

/* Responsive fallback: on small screens, revert to a simple grid so it doesn’t get cramped */
@media (max-width: 820px){
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic{ display:grid; }
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot{
    grid-column: auto !important;
    grid-row: auto !important;
    transform: none !important;
  }
}



/* =========================================
   SAO (Situation / Action / Outcome) — Pyramid layout
   CSS-only layout + sizing (does not affect draw/reshuffle/clear logic)
========================================= */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-sao{
  display: grid;
  /* fixed card lanes so cards never blow up to full panel width */
  grid-template-columns: 190px 190px;
  grid-template-areas:
    "outcome outcome"
    "situation action";
  gap: 16px;
  justify-content: center;
  justify-items: center;
  align-items: start;
}

.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-sao .conjuresup-tarot-slot{
  width: 100%;
  max-width: 190px;
}

/* Place cards (order is fixed by JS: 1 Situation, 2 Action, 3 Outcome) */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-sao .conjuresup-tarot-slot:nth-child(1){ grid-area: situation; }
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-sao .conjuresup-tarot-slot:nth-child(2){ grid-area: action; }
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-sao .conjuresup-tarot-slot:nth-child(3){
  grid-area: outcome;
  transform: translateY(-8px);
}

/* Responsive: on narrow screens, stack neatly (still sized, not massive) */
@media (max-width: 720px){
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-sao{
    grid-template-columns: 190px;
    grid-template-areas:
      "outcome"
      "situation"
      "action";
    gap: 14px;
  }
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-sao .conjuresup-tarot-slot:nth-child(3){
    transform: none;
  }
}







.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship .conjuresup-tarot-slot{
  width:100%;
  max-width:var(--t-slot-w);
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship .conjuresup-tarot-slot:nth-child(1){grid-area:you;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship .conjuresup-tarot-slot:nth-child(2){grid-area:them;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship .conjuresup-tarot-slot:nth-child(3){grid-area:dynamic; transform:translateY(-4px);}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship .conjuresup-tarot-slot:nth-child(4){grid-area:advice;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship .conjuresup-tarot-slot:nth-child(5){grid-area:outcome;}

@media (max-width: 720px){
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship{
    grid-template-columns:var(--t-slot-w);
    grid-template-areas:
      "dynamic"
      "you"
      "them"
      "advice"
      "outcome";
    gap:calc(var(--t-gap) - 2px);
  }
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship .conjuresup-tarot-slot:nth-child(3){transform:none;}
}

.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career .conjuresup-tarot-slot{
  width:auto;
  max-width:var(--t-slot-w);
  flex: 0 0 var(--t-slot-w);
}

/* Career spread should render as a single 5-card row on desktop.
   The JS applies `.is-career` but does not add `.is-five`, so we must
   define the 5-column grid here (outside media queries). */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career{
  display: grid;
  grid-template-columns: repeat(5, minmax(0, var(--t-slot-w)));
  grid-template-areas: "now block strength action next";
  gap: var(--t-gap);
  justify-content: center;
  align-items: start;
  width: 100%;
  overflow: hidden;
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career .conjuresup-tarot-slot:nth-child(1){grid-area:now;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career .conjuresup-tarot-slot:nth-child(2){grid-area:block;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career .conjuresup-tarot-slot:nth-child(3){grid-area:strength;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career .conjuresup-tarot-slot:nth-child(4){grid-area:action;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career .conjuresup-tarot-slot:nth-child(5){grid-area:next; transform:translateY(-2px);}

@media (max-width: 720px){
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career{
  display:flex;
  flex-wrap:wrap;
  gap: var(--t-gap);
  justify-content:center;
  align-items:flex-start;
  max-width: calc((var(--t-slot-w) * 5) + (var(--t-gap) * 4));
  margin: 0 auto;
}
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career .conjuresup-tarot-slot:nth-child(5){transform:none;}
}




/* =========================================
   Relationship Spread — Standard 5-card Cross
   Slot order (JS): 1 You, 2 Them, 3 Dynamic, 4 Challenge, 5 Outcome
========================================= */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship-cross{
  display:grid;
  grid-template-columns:var(--t-slot-w) var(--t-slot-w) var(--t-slot-w);
  grid-template-areas:
    ". outcome ."
    "you dynamic them"
    ". challenge .";
  gap:var(--t-gap);
  justify-content:center;
  justify-items:center;
  align-items:start;
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship-cross .conjuresup-tarot-slot{
  width:100%;
  max-width:var(--t-slot-w);
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship-cross .conjuresup-tarot-slot:nth-child(1){grid-area:you;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship-cross .conjuresup-tarot-slot:nth-child(2){grid-area:them;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship-cross .conjuresup-tarot-slot:nth-child(3){grid-area:dynamic;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship-cross .conjuresup-tarot-slot:nth-child(4){grid-area:challenge;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship-cross .conjuresup-tarot-slot:nth-child(5){grid-area:outcome; transform:translateY(-4px);}

@media (max-width: 820px){
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship-cross{
    grid-template-columns:var(--t-slot-w) var(--t-slot-w);
    grid-template-areas:
      "outcome outcome"
      "you them"
      "dynamic dynamic"
      "challenge challenge";
    gap:calc(var(--t-gap) - 2px);
  }
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-relationship-cross .conjuresup-tarot-slot:nth-child(5){transform:none;}
}

.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot{
  width:100%;
  max-width:var(--t-slot-w);
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot:nth-child(1){grid-area:now;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot:nth-child(2){grid-area:block;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot:nth-child(3){grid-area:focus;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot:nth-child(4){grid-area:opportunity;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot:nth-child(5){grid-area:outcome;}

@media (max-width: 900px){
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--t-slot-w), 1fr));
  gap: var(--t-gap);
  justify-content:center;
  justify-items:center;
  align-items:start;
  max-width: calc((var(--t-slot-w) * 5) + (var(--t-gap) * 4));
  margin: 0 auto;
}
}
/* =========================================
   Career Spread — Simple 5-card Horizontal Row
   Slot order (JS): 1 Now, 2 Block, 3 Focus, 4 Opportunity, 5 Outcome
========================================= */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--t-slot-w), 1fr));
  gap: var(--t-gap);
  justify-content:center;
  justify-items:center;
  align-items:start;
  max-width: calc((var(--t-slot-w) * 5) + (var(--t-gap) * 4));
  margin: 0 auto;
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot{
  width:100%;
  max-width:var(--t-slot-w);
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot:nth-child(1){grid-area:now;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot:nth-child(2){grid-area:block;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot:nth-child(3){grid-area:focus;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot:nth-child(4){grid-area:opportunity;}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-career-ladder .conjuresup-tarot-slot:nth-child(5){grid-area:outcome;}

/* =========================================
   Celtic Cross — fixed layout (prevents overlap on responsive sizing)
   Slot order (JS): 1 Present, 2 Challenge, 3 Past, 4 Future, 5 Above,
                    6 Below, 7 Advice, 8 External, 9 Hopes/Fears, 10 Outcome
========================================= */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic{
  display:grid;
  grid-template-columns: var(--t-slot-w) var(--t-slot-w) var(--t-slot-w) clamp(10px, 1.0vw, 16px) var(--t-slot-w);
  grid-template-areas:
    ". above . . outcome"
    "past present future . hopes"
    ". below . . external"
    ". . . . advice";
  gap: var(--t-gap);
  justify-content: center;
  justify-items: center;
  align-items: start;
  position: relative;
}

/* map areas */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(1){ grid-area: present; z-index: 1; }
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(2){
  grid-area: present;
  z-index: 3;
  justify-self: center;
  align-self: center;
  /* Keep the crossing card compact to avoid overlapping Past/Future */
  transform: rotate(90deg) scale(0.58) translateX(-10px);
  transform-origin: center;
  pointer-events: auto;
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(3){ grid-area: past; }
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(4){ grid-area: future; }
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(5){ grid-area: above; }
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(6){ grid-area: below; }
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(7){ grid-area: advice; }
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(8){ grid-area: external; }
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(9){ grid-area: hopes; }
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(10){ grid-area: outcome; }

@media (max-width: 980px){
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic{
    grid-template-columns: var(--t-slot-w) var(--t-slot-w);
    grid-template-areas:
      "above outcome"
      "past future"
      "present present"
      "below hopes"
      "external advice";
    gap: calc(var(--t-gap) - 2px);
  }
  .conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(2){
    transform: rotate(90deg) scale(0.72);
  }
}


/* --- Tarot card media sizing (global) --- */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-slot-card img,
.conjuresup-tarot-deck-wrap .conjuresup-tarot-card-face img{
  width: 100%;
  height: auto;
  aspect-ratio: 2.5 / 4.25;
  object-fit: contain;
  display: block;
}

/* --- Celtic Cross — overlap tuning --- */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(2) .conjuresup-tarot-slot-card{
  position: relative;
  z-index: 2;
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(2) .conjuresup-tarot-slot-card.is-rotated,
.conjuresup-tarot-deck-wrap .conjuresup-tarot-spread-grid.is-celtic .conjuresup-tarot-slot:nth-child(2) .conjuresup-tarot-slot-card.rotated{
  transform: rotate(90deg) scale(0.72);
  transform-origin: center center;
}

/* --- VIP panel squeeze fix --- */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-grid{
  grid-template-columns: minmax(0, 1fr) minmax(260px, 420px);
}
.conjuresup-tarot-deck-wrap .conjuresup-tarot-panel{
  min-width: 0;
}

/* --- Global slot safety (max) --- */
.conjuresup-tarot-deck-wrap .conjuresup-tarot-slot-card{
  max-width: 100%;
}
