/* CCSE adaptive quiz · estética Atlántico/Fisterra/Arena */
.quiz-screen { margin: 1.5rem 0; }

.quiz-card {
  background: #fff;
  border-radius: 16px;
  padding: 2rem 1.75rem;
  box-shadow: 0 8px 28px rgba(30,77,107,0.08), 0 2px 6px rgba(30,77,107,0.04);
  border: 1px solid #ECE6DC;
}
.quiz-card h2 { font-family: 'Fraunces', serif; color: #1E4D6B; margin: 0 0 0.6rem; font-size: 1.55rem; font-weight: 500; }
.quiz-card-msg { color: #4A5859; margin: 0 0 1.4rem; line-height: 1.55; }
.quiz-card-foot { color: #6E7878; font-size: 0.85rem; margin-top: 1rem; }

.quiz-card-head { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1.1rem; }
.quiz-pill {
  display: inline-block; padding: 0.3rem 0.7rem; border-radius: 999px;
  background: #DBE7F0; color: #1E4D6B; font-size: 0.78rem; font-weight: 500; letter-spacing: 0.01em;
}
.quiz-pill--ok { background: #E5F0DC; color: #3F5E2C; }

.btn--lg { padding: 0.95rem 1.6rem; font-size: 1.05rem; }

.quiz-extras { margin-top: 1.25rem; color: #4A5859; }
.quiz-extras summary { cursor: pointer; color: #1E4D6B; font-weight: 500; padding: 0.5rem 0; }
.quiz-extras ul { margin: 0.5rem 0 0 1rem; padding: 0; }
.quiz-extras li { margin: 0.4rem 0; }

/* RUNNER */
.quiz-head {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  background: #fff; border-radius: 14px; padding: 0.9rem 1.1rem;
  box-shadow: 0 4px 14px rgba(30,77,107,0.06); border: 1px solid #ECE6DC;
  margin-bottom: 1rem;
}
.quiz-head-left { flex: 1; min-width: 0; }
.quiz-progress-label { display: block; font-size: 0.85rem; color: #4A5859; margin-bottom: 0.4rem; }
.quiz-progress-bar { height: 6px; border-radius: 999px; background: #ECE6DC; overflow: hidden; }
.quiz-progress-fill { height: 100%; background: linear-gradient(90deg, #1E4D6B, #6B8E5A); width: 0; transition: width 0.3s ease; }

.quiz-head-right { display: flex; align-items: center; gap: 0.75rem; }
.quiz-timer {
  font-family: 'Fraunces', serif; font-size: 1.4rem; font-weight: 500; color: #1E4D6B;
  font-variant-numeric: tabular-nums; padding: 0.25rem 0.7rem; border-radius: 8px; background: #DBE7F0;
}
.quiz-timer.warning { background: #F5E5C8; color: #8A5F2F; }
.quiz-timer.danger  { background: #F0D0D0; color: #8A2F2F; animation: pulse 1.4s ease-in-out infinite; }
@keyframes pulse { 50% { opacity: 0.7; } }
.quiz-quit { background: transparent; border: 1px solid #C8C0B0; color: #4A5859; padding: 0.4rem 0.7rem; border-radius: 8px; cursor: pointer; font-size: 0.85rem; }
.quiz-quit:hover { border-color: #8A2F2F; color: #8A2F2F; }

.quiz-question {
  background: #fff; border-radius: 16px; padding: 1.6rem 1.4rem;
  box-shadow: 0 6px 20px rgba(30,77,107,0.07); border: 1px solid #ECE6DC; margin-bottom: 1rem;
}
.quiz-block-tag { font-size: 0.78rem; color: #6B8E5A; text-transform: uppercase; letter-spacing: 0.08em; margin: 0 0 0.5rem; font-weight: 500; }
.quiz-question-text { font-family: 'Fraunces', serif; color: #1E4D6B; font-size: 1.35rem; font-weight: 500; line-height: 1.4; margin: 0 0 1.2rem; }

.quiz-options { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.6rem; }
.quiz-option {
  display: flex; align-items: flex-start; gap: 0.75rem;
  padding: 0.85rem 1rem; border: 2px solid #ECE6DC; border-radius: 12px;
  cursor: pointer; transition: border-color 0.15s, background 0.15s, transform 0.05s;
  background: #FAF6F0; text-align: left; width: 100%; font: inherit; color: inherit;
}
.quiz-option:hover { border-color: #C8C0B0; }
.quiz-option:focus-visible { outline: 3px solid #1E4D6B; outline-offset: 2px; }
.quiz-option:active { transform: translateY(1px); }
.quiz-option.selected { border-color: #1E4D6B; background: #DBE7F0; }
.quiz-option-key {
  flex: 0 0 auto; width: 26px; height: 26px; border-radius: 8px;
  background: #fff; border: 1px solid #C8C0B0; display: inline-flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 0.85rem; color: #1E4D6B;
}
.quiz-option.selected .quiz-option-key { background: #1E4D6B; color: #fff; border-color: #1E4D6B; }

.quiz-actions {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  background: #fff; border-radius: 14px; padding: 0.85rem 1.1rem;
  box-shadow: 0 4px 14px rgba(30,77,107,0.06); border: 1px solid #ECE6DC;
}
.quiz-keyboard-hint { color: #6E7878; font-size: 0.78rem; }
@media (max-width: 600px) { .quiz-keyboard-hint { display: none; } }

/* RESULTS */
.quiz-results-card { padding: 2rem 1.75rem; }
.results-score-row { display: flex; align-items: baseline; gap: 1rem; flex-wrap: wrap; margin: 0.6rem 0 0.5rem; }
.results-score { font-family: 'Fraunces', serif; font-size: 3.2rem; font-weight: 500; line-height: 1; color: #1E4D6B; }
.results-score.passed { color: #3F5E2C; }
.results-score.failed { color: #8A2F2F; }
.results-verdict { font-family: 'Fraunces', serif; font-size: 1.15rem; color: #4A5859; }
.results-msg { color: #4A5859; margin: 0.4rem 0 1.5rem; line-height: 1.6; }

.quiz-results-card h3 { font-family: 'Fraunces', serif; color: #1E4D6B; font-size: 1.05rem; font-weight: 500; margin: 1.6rem 0 0.7rem; }

.results-blocks-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 0.75rem; }
.results-block-card { background: #FAF6F0; border: 1px solid #ECE6DC; border-radius: 12px; padding: 0.85rem 1rem; }
.results-block-card .name { font-family: 'Fraunces', serif; color: #1E4D6B; font-size: 0.95rem; font-weight: 500; }
.results-block-card .stat { color: #4A5859; font-size: 0.8rem; margin-top: 0.2rem; }
.results-block-card .bar { height: 5px; background: #ECE6DC; border-radius: 999px; margin-top: 0.6rem; overflow: hidden; }
.results-block-card .bar > span { display: block; height: 100%; background: #1E4D6B; }
.results-block-card.weak .bar > span { background: #8A2F2F; }
.results-block-card.weak { border-color: #E8C8C8; }

.results-plan {
  background: #DBE7F0; border-left: 4px solid #1E4D6B; border-radius: 8px;
  padding: 1rem 1.1rem; color: #1E4D6B; line-height: 1.65; white-space: pre-wrap;
  font-size: 0.97rem;
}

.results-review { margin-top: 1.5rem; }
.results-review summary { cursor: pointer; color: #1E4D6B; font-weight: 500; }
.results-review-list { padding-left: 1.2rem; margin-top: 0.7rem; }
.results-review-list li { margin: 0.7rem 0; color: #4A5859; }
.results-review-list li .q { color: #1E4D6B; font-weight: 500; }
.results-review-list li .ans { font-size: 0.85rem; }
.results-review-list li .ans .ok { color: #3F5E2C; }
.results-review-list li .ans .bad { color: #8A2F2F; }
.results-review-list li .why { font-size: 0.85rem; color: #6E7878; margin-top: 0.2rem; }

.results-actions { display: flex; flex-wrap: wrap; gap: 0.7rem; margin-top: 1.6rem; }

.quiz-upsell {
  margin-top: 1.5rem; padding: 1.2rem 1.4rem; border-radius: 14px;
  background: linear-gradient(135deg, #1E4D6B 0%, #2A6B7E 100%); color: #fff;
}
.quiz-upsell p { margin: 0 0 0.9rem; line-height: 1.5; }
.quiz-upsell .btn--primary { background: #fff; color: #1E4D6B; }
.quiz-upsell .btn--primary:hover { background: #FAF6F0; }

/* MODAL */
.quiz-modal { position: fixed; inset: 0; background: rgba(30,77,107,0.55); display: flex; align-items: center; justify-content: center; padding: 1rem; z-index: 100; }
.quiz-modal-card { background: #fff; border-radius: 16px; padding: 1.75rem; max-width: 460px; width: 100%; box-shadow: 0 20px 60px rgba(0,0,0,0.25); }
.quiz-modal-card h3 { font-family: 'Fraunces', serif; color: #1E4D6B; margin: 0 0 0.7rem; font-size: 1.3rem; font-weight: 500; }
.quiz-modal-card p { color: #4A5859; line-height: 1.55; margin: 0 0 1rem; }
.quiz-modal-card label { display: block; color: #1E4D6B; font-weight: 500; margin-bottom: 0.4rem; font-size: 0.9rem; }
.quiz-modal-card input[type=email] { width: 100%; padding: 0.7rem 0.9rem; border: 1px solid #C8C0B0; border-radius: 10px; font: inherit; box-sizing: border-box; }
.quiz-modal-card input[type=email]:focus { outline: 3px solid #DBE7F0; border-color: #1E4D6B; }
.quiz-modal-actions { display: flex; gap: 0.6rem; margin-top: 1rem; justify-content: flex-end; }
.quiz-modal-foot { font-size: 0.85rem; color: #4A5859; min-height: 1.2em; margin-top: 0.5rem; }
.quiz-modal-foot.ok { color: #3F5E2C; }
.quiz-modal-foot.err { color: #8A2F2F; }

@media (max-width: 600px) {
  .quiz-card, .quiz-question, .quiz-results-card { padding: 1.3rem 1.1rem; }
  .quiz-question-text { font-size: 1.15rem; }
  .results-score { font-size: 2.4rem; }
  .quiz-actions { flex-wrap: wrap; }
  .quiz-actions .btn { flex: 1; }
}
