/* Tarot Sí o No — multi-card spread with vote tally. */

.si-page { padding-top: 2rem; }
.si-header { max-width: 720px; margin: 0 auto 2rem; }
.si-intro { color: var(--text-dim); max-width: 60ch; margin: 0 auto; }

.si-app {
  background: linear-gradient(180deg, rgba(11,4,55,0.55) 0%, rgba(20,8,60,0.35) 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: clamp(1.2rem, 3vw, 2rem);
  box-shadow: var(--shadow-2);
  position: relative; overflow: hidden;
}
.si-app::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(600px 350px at 50% -10%, rgba(81,227,163,0.12), transparent 65%),
    radial-gradient(500px 350px at 90% 110%, rgba(255,85,102,0.1), transparent 60%);
  pointer-events: none;
}
.si-app > * { position: relative; }

.si-instruction {
  text-align: center; color: var(--text-dim);
  font-size: 1.05rem; margin: 0 0 1.6rem;
  font-weight: 500;
}

.si-deck {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: clamp(.5rem, 1.5vw, 1rem);
  perspective: 1500px;
}
.si-slot {
  --w: clamp(95px, 13vw, 150px);
  width: var(--w);
  aspect-ratio: 253 / 342;
  border: 0; padding: 0; background: transparent;
  cursor: pointer; position: relative;
  border-radius: 10px;
  transition: transform .25s ease, filter .2s;
  animation: si-deal .55s ease both;
  animation-delay: calc(var(--i, 1) * 90ms);
  transform-style: preserve-3d;
}
.si-slot:focus-visible { outline: 2px solid var(--accent-3); outline-offset: 4px; }
.si-slot:not(.is-flipped):hover { transform: translateY(-10px) rotate(-1deg); }
.si-slot:not(.is-flipped):active { transform: translateY(-6px); }

.si-slot-back {
  position: absolute; inset: 0; border-radius: 10px;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(255,240,200,0.2), transparent 50%),
    linear-gradient(135deg, #1a0b3a 0%, #4b0f5f 55%, #d4a017 100%);
  border: 1px solid rgba(255,215,100,0.35);
  box-shadow:
    inset 0 0 0 6px rgba(0,0,0,0.18),
    inset 0 0 0 7px rgba(255,215,100,0.15),
    0 14px 28px rgba(0,0,0,0.45);
  overflow: hidden;
  backface-visibility: hidden;
  transition: transform .6s cubic-bezier(.2,.7,.3,1.2), opacity .3s;
}
.si-slot-back::before {
  content: ""; position: absolute; inset: 8px; border-radius: 6px;
  border: 1.5px solid rgba(255,215,100,0.3);
  background:
    radial-gradient(circle at 50% 50%, rgba(255,215,100,0.45) 0 5px, transparent 6px),
    repeating-linear-gradient(45deg, rgba(255,215,100,0.04) 0 6px, transparent 6px 12px);
}
.si-slot-back::after {
  content: "?";
  position: absolute; inset: 0; display: grid; place-items: center;
  color: #ffd966; font-size: calc(var(--w) * 0.5);
  font-family: 'Cinzel', Georgia, serif; font-weight: 700;
  text-shadow: 0 0 14px rgba(255,217,102,0.6), 0 2px 0 rgba(0,0,0,0.4);
}

.si-slot.is-flipped .si-slot-back { transform: rotateY(180deg); opacity: 0; }
.si-slot.is-flipped { cursor: default; }

.si-slot-face {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  background: #0c0420;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 14px 28px rgba(0,0,0,0.45), 0 0 0 1px rgba(255,255,255,0.08);
  animation: si-flipin .65s cubic-bezier(.2,.7,.3,1.2) both;
}
.si-slot-face img {
  width: 100%; height: 62%; object-fit: cover; display: block;
}
.si-slot-face img.is-reversed { transform: rotate(180deg); }
.si-slot-meta {
  padding: .35rem .45rem .45rem;
  display: flex; flex-direction: column; align-items: center; gap: .15rem;
  flex: 1; min-height: 0;
}
.si-slot-meta h4 {
  margin: 0; font-size: .82rem; line-height: 1.15;
  font-family: 'Cinzel', Georgia, serif; text-align: center;
  color: var(--text);
}
.si-slot-meta .si-rev {
  font-size: .68rem; color: var(--muted); font-family: inherit; font-weight: 400;
  display: block;
}
.si-slot-meta .si-meaning {
  display: none; /* hidden in deck view, shown in result view */
}

.si-vote-badge {
  margin-top: auto;
  padding: .2rem .55rem; border-radius: 999px;
  font-size: .72rem; letter-spacing: .08em; font-weight: 700;
  text-transform: uppercase;
}
.si-vote-si { background: rgba(81,227,163,0.15); color: var(--good); border: 1px solid rgba(81,227,163,0.5); }
.si-vote-no { background: rgba(255,85,102,0.15); color: var(--danger); border: 1px solid rgba(255,85,102,0.5); }
.si-vote-dudosa { background: rgba(255,216,74,0.15); color: var(--accent-4); border: 1px solid rgba(255,216,74,0.5); }

.si-error {
  margin-top: 1rem; padding: .9rem 1rem;
  background: rgba(255,85,102,0.12); border: 1px solid rgba(255,85,102,0.4);
  border-radius: 10px; color: #ffd0d4; text-align: center;
}

@keyframes si-deal {
  from { transform: translateY(40px) rotate(-6deg); opacity: 0; }
  to   { transform: translateY(0) rotate(0); opacity: 1; }
}
@keyframes si-flipin {
  from { transform: rotateY(-180deg); opacity: 0; }
  to   { transform: rotateY(0); opacity: 1; }
}

/* ===== Result panel ===== */
.si-result {
  margin-top: 1.6rem;
  text-align: center;
  animation: si-fade .4s ease;
}
@keyframes si-fade {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.si-result-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: .8rem;
  margin-bottom: 1.8rem;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}
.si-result-card {
  margin: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  padding: 0;
  text-align: center;
}
.si-result-card img { width: 100%; height: auto; display: block; }
.si-result-card img.is-reversed { transform: rotate(180deg); }
.si-result-card figcaption {
  padding: .55rem .5rem .7rem;
  display: flex; flex-direction: column; align-items: center; gap: .2rem;
  font-size: .82rem; line-height: 1.2;
}
.si-result-card strong { font-family: 'Cinzel', Georgia, serif; font-weight: 600; }

.si-result-verdict {
  font-family: 'Cinzel', Georgia, serif;
  font-size: clamp(2.5rem, 6vw, 4rem);
  font-weight: 700;
  letter-spacing: .12em;
  margin: 0 0 .4rem;
  background: var(--grad-1);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.si-result-verdict[data-verdict="si"] {
  background: linear-gradient(135deg, #51e3a3 0%, #00e0ff 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.si-result-verdict[data-verdict="no"] {
  background: linear-gradient(135deg, #ff5566 0%, #ff3da6 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.si-result-verdict[data-verdict="dudosa"] {
  background: linear-gradient(135deg, #ffd84a 0%, #ff9f1a 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

.si-result-detail {
  display: flex; flex-wrap: wrap; justify-content: center; gap: .5rem;
  margin: .8rem 0 1.5rem;
}
.si-tally-pill {
  padding: .35rem .8rem; border-radius: 999px;
  font-size: .85rem; font-weight: 500;
}
.si-tally-pill b { font-weight: 700; margin-right: .15em; }

.si-restart { margin-top: .8rem; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .si-slot, .si-slot-back, .si-slot-face, .si-result { animation: none !important; transition: none !important; }
}
