/* Cartas Zener — test de percepción extrasensorial (25 tiradas × 5 símbolos). */

.zener-page { color: #f5ecd2; }

.zener-header { text-align: center; margin-bottom: 1.4rem; }
.zener-header h1 {
  font-family: 'Cinzel', 'Times New Roman', serif;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  color: #ffd9a8;
  text-shadow: 0 0 16px rgba(255,217,168,0.5);
  margin: 0 0 .6rem;
}
.zener-intro {
  max-width: 60ch;
  margin: 0 auto;
  color: rgba(245,236,210,0.85);
  line-height: 1.55;
}

.zener-app {
  max-width: 640px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.4rem;
}

/* ---------- Intro box ---------- */
.zener-intro-box {
  width: 100%;
  text-align: center;
  background: linear-gradient(160deg, rgba(40,28,70,0.6), rgba(20,12,40,0.4));
  border: 1px solid rgba(255,217,168,0.3);
  border-radius: 14px;
  padding: 1.4rem 1.4rem;
}
.zener-intro-box p {
  margin: 0 0 1.2rem;
  line-height: 1.6;
  color: rgba(245,236,210,0.9);
}
.zener-start, .zener-restart {
  font-family: 'Cinzel', 'Times New Roman', serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: .7rem 1.6rem;
}

/* ---------- Active test ---------- */
.zener-test { width: 100%; display: flex; flex-direction: column; align-items: center; gap: 1.1rem; }

.zener-progress {
  width: 100%;
  display: flex;
  justify-content: space-between;
  font-family: 'Cinzel', 'Times New Roman', serif;
  font-size: 1rem;
  color: rgba(245,236,210,0.85);
  letter-spacing: .04em;
}

.zener-hidden-card {
  width: 156px;
  height: 220px;
  perspective: 800px;
}
.zener-unknown {
  width: 100%;
  height: 100%;
  border-radius: 12px;
  background:
    radial-gradient(circle at 30% 25%, rgba(255,225,180,0.35), transparent 55%),
    linear-gradient(160deg, #3a1a6a 0%, #6a3aaa 50%, #1a0640 100%);
  border: 2px solid rgba(255,217,168,0.5);
  box-shadow:
    inset 0 0 0 4px rgba(0,0,0,0.35),
    0 18px 28px rgba(0,0,0,0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffd9a8;
  font-family: 'Cinzel', serif;
  font-size: 5rem;
  text-shadow: 0 0 18px rgba(255,217,168,0.85);
  animation: zener-pulse 2.2s ease-in-out infinite;
}
@keyframes zener-pulse {
  0%, 100% { transform: scale(1);   filter: brightness(1); }
  50%      { transform: scale(1.02); filter: brightness(1.15); }
}

.zener-instruction {
  text-align: center;
  margin: 0;
  color: rgba(245,236,210,0.85);
  font-size: 1rem;
}

/* Choices row */
.zener-choices {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: .6rem;
  width: 100%;
  max-width: 520px;
}
.zener-choice {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1;
  padding: 0;
  border-radius: 10px;
  border: 2px solid rgba(255,217,168,0.35);
  background: linear-gradient(160deg, rgba(60,38,100,0.6), rgba(20,12,40,0.4));
  color: #f5ecd2;
  cursor: pointer;
  transition: transform .15s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.zener-choice:hover {
  transform: translateY(-2px);
  border-color: rgba(255,217,168,0.8);
  background: linear-gradient(160deg, rgba(80,50,140,0.7), rgba(30,16,60,0.55));
  box-shadow: 0 8px 18px rgba(0,0,0,0.4);
}
.zener-choice:focus-visible { outline: 2px solid #ffd9a8; outline-offset: 2px; }
.zener-choice svg { width: 64%; height: 64%; display: block; }
.zener-choice[disabled] { cursor: not-allowed; opacity: 0.55; transform: none; }
.zener-choice.is-correct {
  border-color: #6dff8d;
  background: linear-gradient(160deg, rgba(0,80,30,0.7), rgba(0,40,15,0.5));
  box-shadow: 0 0 22px rgba(120,255,160,0.55);
}
.zener-choice.is-wrong {
  border-color: #ff8a8a;
  background: linear-gradient(160deg, rgba(80,20,20,0.7), rgba(40,8,8,0.5));
  box-shadow: 0 0 22px rgba(255,140,140,0.5);
}

.zener-feedback {
  min-height: 2.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .8rem;
  font-family: 'Cinzel', serif;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.zener-feedback-text { font-size: 1rem; }
.zener-feedback-text.is-correct { color: #b8ffcc; }
.zener-feedback-text.is-wrong   { color: #ffb8b8; }
.zener-feedback-symbol {
  width: 36px; height: 36px;
  color: rgba(255,217,168,0.85);
}
.zener-feedback-symbol svg { width: 100%; height: 100%; }

/* ---------- Results ---------- */
.zener-results {
  width: 100%;
  text-align: center;
  background: linear-gradient(160deg, rgba(40,28,70,0.7), rgba(20,12,40,0.4));
  border: 1px solid rgba(255,217,168,0.35);
  border-radius: 16px;
  padding: 1.5rem 1.3rem 1.2rem;
  box-shadow: 0 16px 32px rgba(0,0,0,0.5);
  animation: zener-reveal .55s ease-out;
}
@keyframes zener-reveal {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.zener-results h2 {
  font-family: 'Cinzel', serif;
  font-size: 1.4rem;
  color: #ffd9a8;
  margin: 0 0 1rem;
}

.zener-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .6rem;
  margin-bottom: 1.4rem;
}
.zener-stat {
  background: rgba(10,5,30,0.45);
  border: 1px solid rgba(255,217,168,0.18);
  border-radius: 10px;
  padding: .7rem .5rem;
  display: flex;
  flex-direction: column;
  gap: .2rem;
}
.zener-stat-label {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(245,236,210,0.55);
}
.zener-stat-value {
  font-family: 'Cinzel', serif;
  font-size: 1.5rem;
  color: #ffd9a8;
}

.zener-level {
  margin-bottom: 1.2rem;
}
.zener-level-tag {
  display: inline-block;
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(245,236,210,0.55);
  margin-bottom: .3rem;
}
.zener-level-label {
  font-family: 'Cinzel', serif;
  font-size: 1.8rem;
  color: #ffd9a8;
  text-shadow: 0 0 18px rgba(255,217,168,0.6);
  margin: 0 0 .8rem;
  letter-spacing: .04em;
}
.zener-level-desc {
  color: #f5ecd2;
  line-height: 1.6;
  margin: 0;
  max-width: 52ch;
  margin-left: auto;
  margin-right: auto;
}

/* Color cues per tier (high/mid/low) — applied via JS data-tier */
.zener-results[data-tier="high"] .zener-level-label { color: #d5b0ff; text-shadow: 0 0 20px rgba(213,176,255,0.7); }
.zener-results[data-tier="mid"]  .zener-level-label { color: #ffe1a8; text-shadow: 0 0 18px rgba(255,225,168,0.6); }
.zener-results[data-tier="low"]  .zener-level-label { color: #ffb8b8; text-shadow: 0 0 18px rgba(255,184,184,0.55); }

@media (prefers-reduced-motion: reduce) {
  .zener-unknown,
  .zener-results { animation: none; }
}

@media (max-width: 520px) {
  .zener-stats { grid-template-columns: 1fr; }
  .zener-stat-value { font-size: 1.2rem; }
  .zener-choices { gap: .4rem; }
  .zener-hidden-card { width: 130px; height: 184px; }
  .zener-unknown { font-size: 4rem; }
}
