#tarot-fan{
  position: relative;
  perspective: 1200px;
  transform-style: preserve-3d;
}

.tarotFanPlane{
  position: absolute;
  inset: 0;
  transform-style: preserve-3d;
  transform: rotateX(58deg);
}

.tarotCard{
  z-index:1;
  position:absolute;
  width:140px;
  aspect-ratio:2 / 3;
  border:none;
  background:none;
  padding:0;
  cursor:pointer;
  transform-origin:center center;
  transition:
    transform .22s ease,
    filter .22s ease,
    box-shadow .22s ease,
    opacity .22s ease;
  will-change:transform;
  container-type:inline-size;

  --card-rotate: 0deg;
  --card-skew: 0deg;
  --card-scale-x: 1;
  --card-scale-y: 1;
  --card-lift: 0px;

  transform:
    translateX(-50%)
    translateY(var(--card-lift))
    rotate(var(--card-rotate))
    skewX(var(--card-skew))
    scaleX(var(--card-scale-x))
    scaleY(var(--card-scale-y));
}

.tarotCard:hover{
  filter:brightness(1.04);
  --card-lift:16px;
}

.tarotCard.is-selected{
  filter:brightness(1.12) drop-shadow(0 0 18px rgba(255,217,120,0.35));
  --card-lift:20px;
}

.tarotCard__inner{
  position:relative;
  display:block;
  width:100%;
  height:100%;
}

.tarotCard__backFace,
.tarotCard__front{
  position:absolute;
  inset:0;
  display:block;
}

.tarotCard__backFace{
  background-image:url('/assets/img/cards/card-back.png');
  background-position:center;
  background-repeat:no-repeat;
  background-size:contain;
  z-index:5;
}

.tarotCard__front{
  position:absolute;
  inset:0;
  z-index:2;
}

.tarotCard__back,
.tarotCard__overlay,
.tarotCard__content{
  position:absolute;
  inset:0;
  display:block;
}

.tarotCard__back,
.tarotCard__overlay,
.tarotCard__art,
.tarotCard__content{
  position:absolute;
  inset:0;
}

.tarotCard__back,
.tarotCard__overlay{
  background-position:center;
  background-repeat:no-repeat;
  background-size:contain;
}

.tarotCard__back{
  background-image:url('/assets/img/cards/card.png');
  background-size:contain;
  z-index:1;
}

.tarotCard--card2 .tarotCard__back{
  background-image:url('/assets/img/cards/card-2.png');
}

.tarotCard--card2 .tarotCard__content,
.tarotCard--card2 .tarotCard__caption{
  display:none;
}

.tarotCard--card2 .tarotCard__art{
  position:absolute;
  left:8%;
  right:8%;
  top:1.25%;
  bottom:1.25%;
  z-index:0;
  overflow:hidden;
  border-radius:4px;
  pointer-events:none;
  display:flex;
  align-items:center;
  justify-content:center;
}

.tarotCard--card2 .tarotCard__art img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center top;
}

.tarotCard__back::after,
.tarotCard__backFace::after{
  content:"";
  position:absolute;
  top:0%;
  bottom:0%;
  left:6.25%;
  right:6.25%;
  border:3.5px solid #04060700;
  border-radius:5.75px;
  box-sizing:border-box;
  pointer-events:none;
  z-index:-1;
  transition:
    border-color .22s ease,
    box-shadow .22s ease;
}

.tarotCard__art{
  position:absolute;
  left:9%;
  right:9%;
  top:2%;
  bottom:4%;
  z-index:0;
  overflow:hidden;
  border-radius:4px;
  pointer-events:none;
}

.tarotCard:not(.tarotCard--card2) .tarotCard__art img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}

.tarotCard--card2 .tarotCard__art img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center top;
}

.tarotCard__overlay{
  z-index:3;
}

.tarotCard__content{
  z-index:2;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:0 11% 6%;
  pointer-events:none;
}

.tarotCard__caption{
  display:block;
  margin:0;
  text-align:center;
  font-family:'Times New Roman', Times, serif;
  font-size:clamp(8px, 7cqw, 16px);
  font-weight:800;
  line-height:1;
  color:#252525;
  text-shadow:none;
  letter-spacing:0.02em;
  text-transform:uppercase;
  max-width:100%;
  transition:
    color .22s ease,
    text-shadow .22s ease;
}


.tarotCard:hover .tarotCard__back::after,
.tarotCard.is-selected .tarotCard__back::after,
.tarotCard:hover .tarotCard__backFace::after,
.tarotCard.is-selected .tarotCard__backFace::after{
  border-color:#ffd76a;
  box-shadow:
    0 0 10px rgba(255, 215, 106, 0.65),
    0 0 18px rgba(255, 215, 106, 0.4);
}

.tarotCard:hover .tarotCard__caption,
.tarotCard.is-selected .tarotCard__caption{
  color:#ffd76a;
  text-shadow:
    0 0 10px rgba(255, 215, 106, 0.65),
    0 0 18px rgba(255, 215, 106, 0.4);
}

.tarotCard .tarotCard__front{
  opacity:0;
  visibility:hidden;
}

.tarotCard .tarotCard__backFace{
  opacity:1;
  visibility:visible;
}

.tarotCard.is-revealed .tarotCard__front{
  opacity:1;
  visibility:visible;
}

.tarotCard.is-revealed .tarotCard__backFace{
  opacity:0;
  visibility:hidden;
}


.readingView{
  width:min(1180px, calc(100vw - 28px));
  margin:0 auto;
  padding:calc(var(--header-h) + 20px) 0 80px;
}

.readingView__intro{
  text-align:center;
  margin:0 0 28px;
  padding:0 12px;
}

.readingView__intro h2{
  margin:0 0 10px;
  font-size:clamp(2rem, 4vw, 3.8rem);
  line-height:1;
  color:var(--gold-soft);
}

.readingView__intro p{
  margin:0;
  color:var(--text-dim);
  font-size:clamp(1rem, 1.4vw, 1.2rem);
}

.readingStack{
  display:grid;
  gap:26px;
}

.readingChosen{
  position:relative;
  overflow:hidden;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:var(--shadow-soft);
  background:
    linear-gradient(rgba(20, 7, 20, 0.34), rgba(20, 7, 20, 0.34)),
    url('/assets/img/table/card-reading-bg.png') center / cover no-repeat;
  isolation:isolate;
  padding:34px 26px 30px;
}

.readingChosen::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at center, rgba(255,255,255,0.06), transparent 52%);
  pointer-events:none;
}

.readingChosen__row{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:center;
  align-items:flex-end;
  gap:14px;
  flex-wrap:nowrap;
  margin:0 0 24px;
}

.readingChosen__card{
  display:flex;
  justify-content:center;
  align-items:center;
}

.readingChosen__intro{
  position:relative;
  z-index:1;
  text-align:center;
  margin:0;
}

.readingChosen__title{
  margin:0 0 10px;
  font-size:clamp(1.05rem, 4.4vw, 3.2rem);
  line-height:0.95;
  color:#fff1d8;
  white-space:nowrap;
}

.readingChosen__subtitle{
  margin:0;
  color:rgba(255,255,255,0.82);
  font-size:clamp(0.98rem, 1.2vw, 1.08rem);
  letter-spacing:0.01em;
}

.readingChosen__display{
  position:relative;
  left:auto;
  bottom:auto;
  width:min(14vw, 130px);
  min-width:84px;
  aspect-ratio:2 / 3;
  cursor:default;
  transform:none;
  filter:drop-shadow(0 18px 24px rgba(0,0,0,0.28));
  --card-lift:0px;
  --card-rotate:0deg;
  --card-skew:0deg;
  --card-scale-x:1;
  --card-scale-y:1;
}

.readingChosen__display:hover{
  transform:none;
  filter:drop-shadow(0 18px 24px rgba(0,0,0,0.28));
  --card-lift:0px;
}

.readingChosen__display .tarotCard__backFace{
  display:none;
}

.readingChosen__display .tarotCard__content{
  inset:auto 0 0 0;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:0 0 6%;
}

.readingChosen__display .tarotCard__caption{
  font-size:clamp(7px, 7.4cqw, 18px);
  line-height:1;
  letter-spacing:0;
  white-space:nowrap;
  text-align:center;
}

.readingCard{
  position:relative;
  overflow:hidden;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:var(--shadow-soft);
  background:
    linear-gradient(rgba(20, 7, 20, 0.34), rgba(20, 7, 20, 0.34)),
    url('/assets/img/table/card-reading-bg.png') center / cover no-repeat;
  isolation:isolate;
}

.readingCard::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at center, rgba(255,255,255,0.06), transparent 52%);
  pointer-events:none;
}

.readingCard__inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(220px, 320px) minmax(0, 1fr);
  align-items:center;
  gap:30px;
  min-height:420px;
  padding:34px;
}

.readingCard--reverse .readingCard__inner{
  grid-template-columns:minmax(0, 1fr) minmax(220px, 320px);
}

.readingCard__visual{
  display:flex;
  align-items:center;
  justify-content:center;
}

.readingCard__text{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
}

.readingCard--reverse .readingCard__visual{
  order:2;
}

.readingCard--reverse .readingCard__text{
  order:1;
  text-align:center;
}

.readingCard__display{
  position:relative;
  left:auto;
  bottom:auto;
  width:min(100%, 220px);
  aspect-ratio:2 / 3;
  cursor:default;
  transform:none;
  filter:drop-shadow(0 22px 28px rgba(0,0,0,0.34));
  --card-lift:0px;
  --card-rotate:0deg;
  --card-skew:0deg;
  --card-scale-x:1;
  --card-scale-y:1;
}

.readingCard__display:hover{
  transform:none;
  filter:drop-shadow(0 22px 28px rgba(0,0,0,0.34));
  --card-lift:0px;
}

.readingCard__display .tarotCard__backFace{
  display:none;
}

.readingCard__eyebrow{
  display:block;
  margin:0 0 8px;
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:rgba(255, 228, 183, 0.78);
}

.readingCard__title{
  margin:0 0 12px;
  font-size:clamp(1.25rem, 2vw, 2rem);
  line-height:1.02;
  color:#fff1d8;
  text-transform: uppercase;
}

.readingCard__eyebrow,
.readingCard__title{
  text-align:center;
  width:100%;
}

.readingCard__body{
  margin:0 auto;
  max-width:52ch;
  font-size:clamp(0.96rem, 1vw, 1.02rem);
  line-height:1.65;
  text-align:center;
  color:rgba(255,255,255,0.9);
}

.readingFinalIntro{
  text-align:center;
}

.readingFinalIntro__inner{
  padding:8px 20px 2px;
}

.readingFinalIntro__title{
  margin:0;
  font-size:clamp(1.2rem, 2vw, 1.6rem);
  line-height:1.1;
  color:#fff1d8;
}

.readingClosing{
  position:relative;
  overflow:hidden;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:var(--shadow-soft);
  background:
    linear-gradient(rgba(20, 7, 20, 0.34), rgba(20, 7, 20, 0.34)),
    url('/assets/img/table/card-reading-bg.png') center / cover no-repeat;
  isolation:isolate;
}

.readingClosing::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at center, rgba(255,255,255,0.06), transparent 52%);
  pointer-events:none;
}

.readingClosing__inner{
  position:relative;
  z-index:1;
  padding:42px 30px;
  text-align:center;
}

.readingClosing__eyebrow{
  display:block;
  margin:0 0 12px;
  font-size:0.82rem;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:rgba(255, 228, 183, 0.78);
}

.readingClosing__title{
  margin:0 0 16px;
  font-size:clamp(1.7rem, 3vw, 2.8rem);
  line-height:1;
  color:#fff1d8;
}

.readingClosing__body{
  margin:0 auto;
  max-width:64ch;
  font-size:clamp(1rem, 1.2vw, 1.12rem);
  line-height:1.8;
  color:rgba(255,255,255,0.9);
}

.readingAd{
  position:relative;
  overflow:hidden;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:var(--shadow-soft);
  background:
    linear-gradient(rgba(20, 7, 20, 0.34), rgba(20, 7, 20, 0.34)),
    url('/assets/img/table/card-reading-bg.png') center / cover no-repeat;
  isolation:isolate;
}

.readingAd::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at center, rgba(255,255,255,0.06), transparent 52%);
  pointer-events:none;
}

.readingAd__inner{
  position:relative;
  z-index:1;
  min-height:140px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:-3px;
  padding:20px;
  text-align:center;
}

.readingAd__label{
  display:block;
  width:100%;
  margin:0;
  text-align:center;
  font-size:0.88rem;
  font-weight:700;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:rgba(255, 228, 183, 0.78);
}

.readingAd__text{
  margin:0;
  max-width:34ch;
  text-align:center;
  font-size:clamp(0.98rem, 1.2vw, 1.2rem);
  line-height:1.35;
  color:#fff1d8;
}

@media (max-width: 860px){
  .readingChosen{
    border-radius:30px;
    padding:30px 16px 24px;
  }

.readingChosen__row{
  display:grid;
  grid-template-columns:repeat(3, 92px);
  justify-content:center;
  justify-items:center;
  align-items:end;
  column-gap:8px;
  row-gap:10px;
  margin:0 0 20px;
}

.readingChosen__card{
  width:92px;
  display:flex;
  justify-content:center;
}

.readingChosen__display{
  width:92px;
  min-width:92px;
}

.readingAd{
  position:relative;
  overflow:hidden;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:var(--shadow-soft);
  background:
    linear-gradient(rgba(20, 7, 20, 0.34), rgba(20, 7, 20, 0.34)),
    url('/assets/img/table/card-reading-bg.png') center / cover no-repeat;
  isolation:isolate;
}

.readingAd::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at center, rgba(255,255,255,0.06), transparent 52%);
  pointer-events:none;
}

.readingAd__inner{
  position:relative;
  z-index:1;
  min-height:140px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:-3px;
  padding:20px;
  text-align:center;
}

.readingAd__label{
  display:block;
  width:100%;
  margin:0;
  text-align:center;
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:rgba(255, 228, 183, 0.78);
}

.readingAd__text{
  margin:0;
  max-width:34ch;
  text-align:center;
  font-size:clamp(0.98rem, 1.2vw, 1.2rem);
  line-height:1.35;
  color:#fff1d8;
}
  .readingAd{
    border-radius:30px;
  }

  .readingAd__inner{
    min-height:120px;
    padding:18px;
  }

  .readingCard{
    min-height:640px;
    border-radius:30px;
  }

  .readingCard__inner,
  .readingCard--reverse .readingCard__inner{
    grid-template-columns:1fr;
    grid-template-rows:auto 1fr;
    gap:24px;
    min-height:640px;
    padding:34px 20px 34px;
    align-content:stretch;
  }

  .readingCard__visual,
  .readingCard__text,
  .readingCard--reverse .readingCard__visual,
  .readingCard--reverse .readingCard__text{
    order:initial;
    text-align:left;
  }

  .readingCard__visual{
    justify-content:center;
    align-self:start;
    padding-top:6px;
  }

  .readingCard__text{
    justify-content:end;
    align-self:end;
  }

  .readingCard__display{
    width:min(100%, 190px);
  }

  .readingCard__body{
    max-width:none;
  }

  .readingClosing{
    border-radius:30px;
  }

  .readingClosing__inner{
    padding:34px 20px;
  }
  
  .readingChosen__display .tarotCard__content{
    padding:0 1% 5%;
  }
}