/**
 * Portal de trivias — línea visual Grupo DEMA (azul marino, celeste, tarjetas y botones tipo píldora).
 */

.dema-trivia-portal {
	--dema-navy: #0c2340;
	--dema-navy-mid: #153a5c;
	--dema-sky: #3d9ce9;
	--dema-sky-soft: #8ec5f5;
	--dema-sky-bg: #e8f4fc;
	--dema-gray-fill: #f0f2f5;
	--dema-gray-border: #e2e6eb;
	--dema-text: #1a2332;
	--dema-text-muted: #5c6778;
	--dema-radius-card: 18px;
	--dema-radius-pill: 9999px;
	--dema-shadow: 0 8px 32px rgba(12, 35, 64, 0.08);
	--dema-font: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

	box-sizing: border-box;
	max-width: 880px;
	margin: 2rem auto;
	padding: 0 1rem;
	font-family: var(--dema-font);
	color: var(--dema-text);
	line-height: 1.5;
}

.dema-trivia-portal *,
.dema-trivia-portal *::before,
.dema-trivia-portal *::after {
	box-sizing: border-box;
}

/* Tarjeta principal */
.dema-trivia-card {
	background: #fff;
	border-radius: var(--dema-radius-card);
	box-shadow: var(--dema-shadow);
	border: 1px solid var(--dema-gray-border);
	overflow: hidden;
}

.dema-trivia-card--message {
	padding: 2rem 1.75rem;
	text-align: center;
}

.dema-trivia-card__header {
	position: relative;
	padding: 1.75rem 1.75rem 1.25rem;
	background: linear-gradient(165deg, var(--dema-navy) 0%, var(--dema-navy-mid) 55%, #1a4a6e 100%);
	color: #fff;
}

/* Título del bloque oscuro: el tema a veces fuerza color, !important o gradiente en h2 */
html body .dema-trivia-portal .dema-trivia-card__header h2.dema-trivia-card__title,
.dema-trivia-portal .dema-trivia-card__header h2.dema-trivia-card__title {
	margin: 0 0 0.5rem;
	font-size: clamp(1.35rem, 4vw, 1.75rem);
	font-weight: 800;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	line-height: 1.2;
	color: #fff !important;
	-webkit-text-fill-color: #fff !important;
	background: none !important;
	-webkit-background-clip: border-box !important;
	background-clip: border-box !important;
}

.dema-trivia-card__meta {
	margin: 0;
	font-size: 0.95rem;
	opacity: 0.92;
	font-weight: 500;
}

.dema-trivia-card__meta-label {
	font-weight: 700;
	text-transform: uppercase;
	font-size: 0.8rem;
	letter-spacing: 0.06em;
	opacity: 0.85;
	margin-right: 0.35rem;
}

.dema-trivia-card__accent {
	height: 4px;
	margin-top: 1.25rem;
	border-radius: 2px;
	background: linear-gradient(90deg, var(--dema-sky-soft), var(--dema-sky), var(--dema-navy));
	opacity: 0.95;
}

.dema-trivia-card__body {
	padding: 1.75rem 1.75rem 2rem;
}

.dema-trivia-lead {
	margin: 0 0 1rem;
	font-size: 1.05rem;
	color: var(--dema-text);
}

.dema-trivia-description {
	margin-bottom: 1.25rem;
	color: var(--dema-text-muted);
	font-size: 0.98rem;
}

.dema-trivia-description p:last-child {
	margin-bottom: 0;
}

.dema-trivia-description p:first-child {
	margin-top: 0;
}

/* Progreso */
.dema-trivia-progress-label {
	margin: 0 0 0.65rem;
	font-size: 0.85rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--dema-navy);
}

.dema-trivia-progress {
	display: flex;
	gap: 6px;
	margin-bottom: 1.75rem;
}

.dema-trivia-progress__seg {
	flex: 1;
	height: 6px;
	border-radius: 3px;
	background: linear-gradient(180deg, #d8ebf9, var(--dema-sky-soft));
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}

/* Formulario */
.dema-trivia-form {
	margin-top: 0.25rem;
}

.dema-trivia-question {
	border: none;
	margin: 0 0 1.75rem;
	padding: 0;
	min-width: 0;
}

.dema-trivia-question:last-of-type {
	margin-bottom: 1.25rem;
}

.dema-trivia-question__legend {
	display: block;
	width: 100%;
	padding: 0;
	margin: 0 0 0.85rem;
	font-size: 1.02rem;
	font-weight: 700;
	color: var(--dema-navy);
	line-height: 1.35;
}

.dema-trivia-options {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.dema-trivia-option {
	display: block;
	cursor: pointer;
	margin: 0;
}

.dema-trivia-option input {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
	pointer-events: none;
}

.dema-trivia-option__text {
	display: block;
	padding: 0.85rem 1.2rem;
	border-radius: var(--dema-radius-pill);
	background: var(--dema-gray-fill);
	color: var(--dema-text);
	font-size: 0.98rem;
	font-weight: 500;
	border: 2px solid transparent;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.dema-trivia-option:hover .dema-trivia-option__text {
	background: #e4eaf0;
}

.dema-trivia-option input:focus-visible + .dema-trivia-option__text {
	outline: 2px solid var(--dema-sky);
	outline-offset: 2px;
}

.dema-trivia-option:has(input:checked) .dema-trivia-option__text {
	background: var(--dema-navy);
	color: #fff;
	border-color: var(--dema-navy);
	box-shadow: 0 4px 14px rgba(12, 35, 64, 0.25);
}

.dema-trivia-form__actions {
	display: flex;
	justify-content: flex-end;
	margin-top: 0.5rem;
	padding-top: 0.25rem;
}

/* Botones */
.dema-trivia-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.9rem 1.85rem;
	font-family: inherit;
	font-size: 0.95rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	text-decoration: none;
	border-radius: var(--dema-radius-pill);
	border: none;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}

.dema-trivia-btn--primary {
	background: var(--dema-navy);
	color: #fff;
	box-shadow: 0 4px 16px rgba(12, 35, 64, 0.28);
}

.dema-trivia-btn--primary:hover {
	background: #081a2e;
	color: #fff;
	box-shadow: 0 6px 20px rgba(12, 35, 64, 0.35);
}

.dema-trivia-btn--primary:active {
	transform: translateY(1px);
}

/* Estados vacíos / éxito */
.dema-trivia-empty {
	margin: 0;
	color: var(--dema-text-muted);
}

.dema-trivia-success {
	padding: 1.25rem 1.35rem;
	background: var(--dema-sky-bg);
	border: 1px solid #b8d9f0;
	border-radius: 14px;
	text-align: center;
	font-weight: 600;
	color: var(--dema-navy);
}

.dema-trivia-success p {
	margin: 0;
}

/* Pantalla de gracias / resultados */
.dema-trivia-thanks {
	padding: 1.75rem 1.25rem;
	background: linear-gradient(180deg, var(--dema-sky-bg) 0%, #fff 55%);
	border: 1px solid var(--dema-gray-border);
	border-radius: 16px;
	text-align: center;
	margin-bottom: 1.75rem;
}

.dema-trivia-thanks__title {
	margin: 0 0 1.25rem;
	font-size: 1.35rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: var(--dema-navy);
}

.dema-trivia-thanks__stats {
	display: flex;
	justify-content: center;
	gap: 1.5rem;
	flex-wrap: wrap;
	margin-bottom: 1rem;
}

.dema-trivia-stat {
	min-width: 120px;
	padding: 1rem 1.25rem;
	background: #fff;
	border-radius: 14px;
	border: 1px solid var(--dema-gray-border);
	box-shadow: 0 2px 12px rgba(12, 35, 64, 0.06);
}

.dema-trivia-stat__value {
	display: block;
	font-size: 2rem;
	font-weight: 800;
	line-height: 1.1;
	color: var(--dema-sky);
}

.dema-trivia-stat__label {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--dema-text-muted);
}

.dema-trivia-thanks__note {
	margin: 0;
	font-size: 0.92rem;
	color: var(--dema-text-muted);
}

.dema-trivia-review__heading {
	margin: 0 0 1.1rem;
	font-size: 1.05rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--dema-navy);
}

.dema-trivia-review {
	margin-top: 0.5rem;
}

.dema-review-item {
	border-radius: 14px;
	padding: 1.15rem 1.25rem;
	margin-bottom: 1rem;
	background: #fff;
	border: 1px solid var(--dema-gray-border);
	box-shadow: 0 2px 10px rgba(12, 35, 64, 0.04);
}

.dema-review-item:last-child {
	margin-bottom: 0;
}

.dema-review-item.is-correct {
	border-color: #9ed4b3;
	background: linear-gradient(180deg, #f4fbf7 0%, #fff 100%);
}

.dema-review-item.is-incorrect {
	border-color: #f0b4b4;
	background: linear-gradient(180deg, #fff8f8 0%, #fff 100%);
}

.dema-review-question {
	margin: 0 0 0.65rem;
	font-size: 1rem;
	font-weight: 700;
	color: var(--dema-navy);
	line-height: 1.35;
}

.dema-review-answer {
	margin: 0 0 0.5rem;
	font-size: 0.95rem;
	color: var(--dema-text);
}

.dema-review-answer__label {
	font-weight: 700;
	color: var(--dema-text-muted);
}

.dema-review-badge {
	display: inline-block;
	margin: 0 0 0.35rem;
	padding: 0.25rem 0.75rem;
	border-radius: var(--dema-radius-pill);
	font-size: 0.8rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.dema-review-badge--ok {
	background: #d4edda;
	color: #155724;
}

.dema-review-badge--no {
	background: #f8d7da;
	color: #721c24;
}

.dema-review-correct {
	margin: 0;
	font-size: 0.92rem;
	color: var(--dema-text);
}

.dema-review-correct__label {
	font-weight: 700;
	color: var(--dema-text-muted);
}

/* Compatibilidad: caja antigua si el tema aún usa .dema-trivia-box */
.dema-trivia-box {
	max-width: 880px;
	margin: 2rem auto;
	padding: 0;
	border: none;
	border-radius: var(--dema-radius-card);
	background: transparent;
}

.dema-trivia-box h2 {
	margin-top: 0;
}

/* WooCommerce — Mi cuenta */
.dema-my-account-chances {
	margin: 18px 0 22px;
	padding: 1rem 1.25rem;
	background: var(--dema-sky-bg);
	border: 1px solid #b8d9f0;
	border-radius: 14px;
	font-family: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
	font-size: 16px;
	color: var(--dema-text);
}

.dema-my-account-chances p {
	margin: 0;
}

.dema-my-account-chances a {
	font-weight: 700;
	color: var(--dema-navy);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.dema-my-account-chances a:hover {
	color: var(--dema-sky);
}

/* ——— Admin (backoffice) ——— */
.dema-admin-question {
	border: 1px solid #ddd;
	padding: 15px;
	margin-bottom: 20px;
	background: #fff;
}

.dema-admin-question-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 12px;
}

.dema-admin-option {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 10px;
	flex-wrap: wrap;
}

.dema-options-wrapper {
	margin-top: 12px;
}
