/* ============================================================
   k100 – Quiz page styles
   ============================================================ */

/* ── Page layout ─────────────────────────────────────────── */
.k100-quiz-page {
	min-height: 100dvh;
	background: #111;
	color: #e8e4de;
	font-family: 'Georgia', 'Times New Roman', Times, serif;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 0 1rem 4rem;
}

body.k100-quiz-body .k100-quiz-page {
	padding-top: calc(var(--k100-page-topbar-top) + var(--k100-page-topbar-h) + 1.25rem);
}

/* ── Header ──────────────────────────────────────────────── */
.quiz-header {
	width: 100%;
	max-width: 860px;
	padding: 0 0 1rem;
	display: flex;
	flex-direction: column;
	gap: .5rem;
}

.quiz-back-link {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	color: rgba(200,169,110,.9);
	text-decoration: none;
	font-size: .88rem;
	letter-spacing: .04em;
	transition: color .15s;
}

.quiz-back-link:hover { color: #c8a96e; }

.quiz-page-title {
	font-size: clamp(1.6rem, 4vw, 2.4rem);
	font-weight: 700;
	color: #fff;
	margin: 0;
}

/* ── Wrap ────────────────────────────────────────────────── */
.k100-quiz-wrap {
	width: 100%;
	max-width: 860px;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

/* ── Intro screen ────────────────────────────────────────── */
.quiz-intro {
	width: 100%;
	display: flex;
	justify-content: center;
	padding: clamp(1.5rem, 5vw, 3rem) 0 clamp(2rem, 6vw, 3.5rem);
}

.quiz-intro-inner {
	width: min(640px, 100%);
	display: grid;
	gap: clamp(1.35rem, 4vw, 2rem);
	justify-items: center;
	text-align: center;
	padding: clamp(1rem, 4vw, 1.5rem) 0;
}

.quiz-intro[hidden] {
	display: none !important;
}

.quiz-intro-text {
	margin: 0;
	font-size: clamp(1.05rem, 2.8vw, 1.28rem);
	line-height: 1.55;
	color: rgba(241,248,245,.94);
	max-width: 52ch;
}

.quiz-start-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: min(100%, 16rem);
	padding: .95rem 2.2rem;
	border: none;
	border-radius: 999px;
	background: #c8a96e;
	color: #0d0d0d;
	font-family: inherit;
	font-size: clamp(.95rem, 2.4vw, 1.05rem);
	font-weight: 700;
	letter-spacing: .05em;
	cursor: pointer;
	transition: transform .18s, background .18s;
}

.quiz-start-btn:hover {
	background: #d9bb82;
	transform: translateY(-1px);
}

.quiz-start-btn:focus-visible {
	outline: 2px solid #f5dfb0;
	outline-offset: 3px;
}

.k100-quiz-wrap.is-intro .quiz-progress-wrap,
.k100-quiz-wrap.is-intro .quiz-questions-stage {
	display: none;
}

/* ── Progress bar ────────────────────────────────────────── */
.quiz-progress-wrap {
	position: relative;
	height: 6px;
	background: rgba(255,255,255,.1);
	border-radius: 999px;
	overflow: visible;
}

.quiz-progress-bar {
	height: 100%;
	width: 0;
	background: #c8a96e;
	border-radius: 999px;
	transition: width .45s ease;
}

.quiz-progress-label {
	position: absolute;
	right: 0;
	top: 12px;
	font-size: .82rem;
	color: rgba(255,255,255,.55);
	letter-spacing: .04em;
}

/* ── Stage ───────────────────────────────────────────────── */
.quiz-questions-stage {
	position: relative;
	min-height: 280px;
}

/* ── Question card ───────────────────────────────────────── */
.quiz-question {
	display: none;
	flex-direction: column;
	gap: 1.4rem;
	animation: quiz-slide-in .35s ease both;
}

.quiz-question.is-active {
	display: flex;
}

@keyframes quiz-slide-in {
	from { opacity: 0; transform: translateX(28px); }
	to   { opacity: 1; transform: translateX(0); }
}

.quiz-q-counter {
	font-size: .82rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: #c8a96e;
	font-weight: 700;
}

.quiz-question-title {
	font-size: clamp(1.15rem, 2.8vw, 1.7rem);
	font-weight: 600;
	color: #fff;
	margin: 0;
	line-height: 1.35;
}

.quiz-question-body {
	font-size: 1rem;
	color: rgba(232,228,222,.8);
	line-height: 1.7;
}

/* ── Media area ──────────────────────────────────────────── */
.quiz-media-area {
	border-radius: 12px;
	overflow: hidden;
	background: #1a1a1a;
	max-height: 420px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.quiz-media-area img {
	width: 100%;
	max-height: 420px;
	object-fit: contain;
	display: block;
}

.quiz-media-area video {
	width: 100%;
	max-height: 420px;
	display: block;
	background: #000;
}

.quiz-media-credit {
	font-size: .78rem;
	color: rgba(255,255,255,.45);
	margin-top: .3rem;
	font-style: italic;
}

/* ── Answers – multiple choice ───────────────────────────── */
.quiz-answers-mc {
	display: grid;
	gap: .6rem;
}

.quiz-multi-correct-note {
	margin: -.4rem 0 .2rem;
	font-size: .86rem;
	color: rgba(255,255,255,.62);
	font-style: italic;
}

.quiz-answer-btn {
	display: flex;
	align-items: center;
	gap: .75rem;
	width: 100%;
	padding: .85rem 1.2rem;
	border-radius: .6rem;
	background: rgba(255,255,255,.04);
	border: 1.5px solid rgba(255,255,255,.12);
	color: rgba(232,228,222,.9);
	font-family: inherit;
	font-size: 1rem;
	text-align: left;
	cursor: pointer;
	transition: background .18s, border-color .18s, color .18s;
}

.quiz-answer-btn:hover:not(:disabled) {
	background: rgba(200,169,110,.1);
	border-color: rgba(200,169,110,.45);
	color: #fff;
}

.quiz-answer-btn.is-selected {
	background: rgba(200,169,110,.14);
	border-color: rgba(200,169,110,.7);
	color: #fff;
}

.quiz-answer-btn.is-correct {
	background: rgba(34,197,94,.12);
	border-color: #22c55e;
	color: #bbf7d0;
}

.quiz-answer-btn.is-wrong {
	background: rgba(239,68,68,.1);
	border-color: #ef4444;
	color: #fecaca;
}

.quiz-answer-btn:disabled {
	cursor: default;
}

.quiz-answer-indicator {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	border: 2px solid rgba(255,255,255,.25);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: .7rem;
	transition: border-color .18s, background .18s;
}

.quiz-answers-mc.is-multi .quiz-answer-indicator {
	border-radius: .3rem;
	font-size: .8rem;
	font-weight: 700;
	line-height: 1;
}

.quiz-answer-btn.is-selected .quiz-answer-indicator {
	background: #c8a96e;
	border-color: #c8a96e;
	color: #0d0d0d;
}

.quiz-answer-btn.is-correct .quiz-answer-indicator {
	background: #22c55e;
	border-color: #22c55e;
}

.quiz-answer-btn.is-wrong .quiz-answer-indicator {
	background: #ef4444;
	border-color: #ef4444;
}

/* ── Text input ──────────────────────────────────────────── */
.quiz-text-input-wrap {
	display: flex;
	gap: .7rem;
	flex-wrap: wrap;
}

.quiz-text-input {
	flex: 1;
	min-width: 200px;
	padding: .8rem 1rem;
	border-radius: .55rem;
	background: rgba(255,255,255,.06);
	border: 1.5px solid rgba(255,255,255,.18);
	color: #e8e4de;
	font-family: inherit;
	font-size: 1rem;
	outline: none;
	transition: border-color .18s;
}

.quiz-text-input:focus {
	border-color: rgba(200,169,110,.7);
}

.quiz-text-input:disabled {
	opacity: .6;
	cursor: default;
}

/* ── Feedback ────────────────────────────────────────────── */
.quiz-feedback {
	display: none;
	align-items: center;
	gap: .6rem;
	padding: .75rem 1.1rem;
	border-radius: .55rem;
	font-weight: 700;
	font-size: .95rem;
}

.quiz-feedback.is-visible { display: flex; }

.quiz-feedback.is-visible:not(.is-correct):not(.is-wrong) {
	background: rgba(200,169,110,.12);
	border: 1px solid rgba(200,169,110,.55);
	color: #f5dfb0;
}

.quiz-feedback.is-correct {
	background: rgba(34,197,94,.12);
	border: 1px solid #22c55e;
	color: #bbf7d0;
}

.quiz-feedback.is-wrong {
	background: rgba(239,68,68,.08);
	border: 1px solid #ef4444;
	color: #fecaca;
}

.quiz-feedback-icon { font-size: 1.1rem; }

/* ── Hints ───────────────────────────────────────────────── */
.quiz-hints {
	display: flex;
	flex-direction: column;
	gap: .6rem;
}

.quiz-hint-toggle {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	padding: .45rem .95rem;
	border-radius: 999px;
	background: none;
	border: 1px solid rgba(200,169,110,.4);
	color: rgba(200,169,110,.9);
	font-family: inherit;
	font-size: .85rem;
	font-weight: 600;
	cursor: pointer;
	transition: background .18s, border-color .18s, color .18s;
}

.quiz-hint-toggle:hover {
	background: rgba(200,169,110,.1);
	border-color: rgba(200,169,110,.65);
	color: #c8a96e;
}

.quiz-hint-text {
	display: none;
	padding: .65rem 1rem;
	border-radius: .5rem;
	background: rgba(200,169,110,.08);
	border-left: 3px solid #c8a96e;
	color: rgba(232,228,222,.85);
	font-size: .9rem;
	line-height: 1.6;
}

.quiz-hint-text.is-open { display: block; }

/* ── Action row ──────────────────────────────────────────── */
.quiz-actions {
	display: flex;
	gap: .75rem;
	flex-wrap: wrap;
}

.quiz-results-subtitle {
	font-size: 1.05rem;
	margin: .2rem 0 .45rem;
	color: rgba(255,255,255,.92);
}

.quiz-results-breakdown {
	display: grid;
	gap: .45rem;
	width: min(680px, 100%);
	margin-bottom: .8rem;
}

.quiz-results-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .8rem;
	padding: .55rem .75rem;
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.1);
	border-radius: .55rem;
}

.quiz-results-row-title {
	font-size: .92rem;
	color: rgba(232,228,222,.94);
}

.quiz-results-row-badge {
	padding: .25rem .55rem;
	border-radius: 999px;
	font-size: .78rem;
	font-weight: 700;
	letter-spacing: .03em;
}

.quiz-results-row-badge.is-correct {
	background: rgba(34,197,94,.15);
	color: #bbf7d0;
	border: 1px solid rgba(34,197,94,.45);
}

.quiz-results-row-badge.is-wrong {
	background: rgba(239,68,68,.12);
	color: #fecaca;
	border: 1px solid rgba(239,68,68,.45);
}

.quiz-show-answers-btn {
	margin: .3rem 0 .8rem;
	padding: .6rem 1rem;
	border-radius: 999px;
	border: 1px solid rgba(200,169,110,.6);
	background: rgba(200,169,110,.12);
	color: #f5dfb0;
	font-weight: 700;
	font-family: inherit;
}

.quiz-correct-answers {
	display: grid;
	gap: .8rem;
	width: min(680px, 100%);
	margin-bottom: .9rem;
}

.quiz-correct-answers[hidden] {
	display: none !important;
}

.quiz-correct-item {
	padding: .7rem .8rem;
	border-radius: .6rem;
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.1);
}

.quiz-correct-item-title {
	margin: 0 0 .45rem;
	font-size: .95rem;
	color: #fff;
}

.quiz-correct-list {
	margin: 0;
	padding-left: 1.1rem;
	color: rgba(232,228,222,.9);
}

.quiz-raffle-form {
	width: min(680px, 100%);
	display: grid;
	gap: .45rem;
	padding: .9rem;
	border-radius: .65rem;
	background: rgba(255,255,255,.035);
	border: 1px solid rgba(255,255,255,.11);
	margin-bottom: .7rem;
}

.quiz-raffle-label {
	font-size: .84rem;
	color: rgba(255,255,255,.78);
}

.quiz-raffle-input {
	padding: .7rem .8rem;
	border-radius: .45rem;
	border: 1px solid rgba(255,255,255,.18);
	background: rgba(255,255,255,.06);
	color: #fff;
	font-family: inherit;
}

.quiz-raffle-submit {
	margin-top: .35rem;
	padding: .72rem 1.2rem;
	border-radius: 999px;
	border: 1px solid rgba(200,169,110,.7);
	background: rgba(200,169,110,.14);
	color: #f5dfb0;
	font-weight: 700;
	font-family: inherit;
}

.quiz-raffle-msg {
	margin: .25rem 0 0;
	font-size: .86rem;
	color: #bbf7d0;
}

.quiz-raffle-msg.is-error {
	color: #fecaca;
}

body.quiz-redirect-open {
	overflow: hidden;
}

.quiz-redirect-overlay {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
	background: rgba(8,8,8,.7);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	opacity: 1;
	transition: opacity .9s ease, backdrop-filter .9s ease;
}

.quiz-redirect-overlay[hidden] {
	display: none;
}

.quiz-redirect-overlay.is-fading {
	opacity: 0;
	backdrop-filter: blur(0);
}

.quiz-redirect-overlay-dialog {
	width: min(680px, 92vw);
	padding: 2rem 2.25rem 1.85rem;
	border-radius: 16px;
	background: rgba(17,17,17,.94);
	border: 1px solid rgba(255,255,255,.19);
	box-shadow: 0 26px 80px rgba(0,0,0,.45);
	display: grid;
	gap: 1.15rem;
}

.quiz-redirect-overlay-message {
	margin: 0;
	text-align: center;
	font-size: clamp(1.35rem, 3.6vw, 1.75rem);
	line-height: 1.35;
	color: #f5dfb0;
	font-weight: 700;
}

.quiz-redirect-overlay-progress {
	height: 16px;
	border-radius: 999px;
	overflow: hidden;
	background: rgba(255,255,255,.14);
	border: 1px solid rgba(255,255,255,.2);
}

.quiz-redirect-overlay-progress-bar {
	display: block;
	width: 0;
	height: 100%;
	background: linear-gradient(90deg, #c8a96e 0%, #22c55e 100%);
	transition: width .12s linear;
}

.quiz-redirect-overlay-countdown {
	display: none;
}

.quiz-raffle-redirect {
	margin-top: .55rem;
	padding: .85rem .9rem;
	border-radius: .65rem;
	background: linear-gradient(180deg, rgba(200,169,110,.13), rgba(34,197,94,.08));
	border: 1px solid rgba(200,169,110,.35);
	display: grid;
	gap: .4rem;
	text-align: left;
}

.quiz-raffle-redirect[hidden] {
	display: none;
}

.quiz-raffle-redirect-lead {
	margin: 0;
	font-size: .9rem;
	line-height: 1.45;
	color: #f5dfb0;
	font-weight: 700;
}

.quiz-raffle-redirect-hint {
	margin: 0;
	font-size: .84rem;
	line-height: 1.4;
	color: rgba(232,228,222,.9);
}

.quiz-raffle-redirect-progress {
	height: 8px;
	border-radius: 999px;
	overflow: hidden;
	background: rgba(255,255,255,.18);
	border: 1px solid rgba(255,255,255,.15);
}

.quiz-raffle-redirect-progress-bar {
	display: block;
	width: 0;
	height: 100%;
	background: linear-gradient(90deg, #c8a96e 0%, #22c55e 100%);
	transition: width .12s linear;
}

.quiz-raffle-redirect-countdown {
	margin: 0;
	font-size: .82rem;
	letter-spacing: .04em;
	color: #bbf7d0;
}

.quiz-raffle-hp {
	position: absolute;
	left: -10000px;
	width: 1px;
	height: 1px;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
}

.quiz-check-btn,
.quiz-next-btn,
.quiz-prev-btn,
.quiz-finish-btn {
	display: inline-flex;
	align-items: center;
	gap: .45rem;
	padding: .8rem 1.8rem;
	border-radius: 999px;
	font-family: inherit;
	font-size: .95rem;
	font-weight: 700;
	letter-spacing: .05em;
	cursor: pointer;
	border: none;
	transition: transform .18s, background .18s, opacity .18s;
}

.quiz-check-btn {
	background: #c8a96e;
	color: #0d0d0d;
}

.quiz-check-btn:hover:not(:disabled) {
	background: #d9bb82;
	transform: translateY(-1px);
}

.quiz-check-btn:disabled {
	opacity: .5;
	cursor: default;
}

.quiz-raffle-submit:disabled {
	opacity: .7;
	cursor: default;
}

.quiz-next-btn {
	display: none;
	background: rgba(255,255,255,.08);
	color: rgba(255,255,255,.9);
	border: 1.5px solid rgba(255,255,255,.22);
}

.quiz-next-btn.is-visible {
	display: inline-flex;
}

.quiz-next-btn:hover {
	background: rgba(255,255,255,.14);
	transform: translateY(-1px);
}

.quiz-prev-btn {
	background: rgba(255,255,255,.08);
	color: rgba(255,255,255,.9);
	border: 1.5px solid rgba(255,255,255,.22);
}

.quiz-prev-btn:hover:not(:disabled) {
	background: rgba(255,255,255,.14);
	transform: translateY(-1px);
}

.quiz-prev-btn:disabled {
	opacity: .45;
	cursor: default;
}

.quiz-finish-btn {
	display: none;
	background: rgba(34,197,94,.12);
	color: #bbf7d0;
	border: 1.5px solid rgba(34,197,94,.55);
}

.quiz-finish-btn.is-visible {
	display: inline-flex;
}

.quiz-finish-btn:hover {
	background: rgba(34,197,94,.2);
	transform: translateY(-1px);
}

/* ── Results ─────────────────────────────────────────────── */
.quiz-results {
	width: 100%;
	max-width: 860px;
	display: flex;
	justify-content: center;
}

.quiz-results[hidden] { display: none; }

.quiz-results-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.2rem;
	padding: 3rem 2rem;
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 16px;
	text-align: center;
	width: 100%;
	transition: opacity .9s ease, transform .9s ease, filter .9s ease;
	will-change: opacity, transform, filter;
}

.quiz-results.is-redirect-fadeout .quiz-results-inner {
	opacity: 0;
	transform: translateY(14px) scale(.985);
	filter: blur(1.2px);
	pointer-events: none;
}

.quiz-results-icon { font-size: 3.5rem; line-height: 1; }

.quiz-results-title {
	font-size: clamp(1.5rem, 4vw, 2.2rem);
	font-weight: 700;
	color: #fff;
	margin: 0;
}

.quiz-score-text {
	font-size: 1.1rem;
	color: rgba(232,228,222,.8);
	margin: 0;
}

.quiz-score-value {
	font-size: 1.8rem;
	color: #c8a96e;
	display: block;
	margin-top: .3rem;
}

.quiz-restart-btn {
	display: inline-flex;
	align-items: center;
	padding: .8rem 2rem;
	border-radius: 999px;
	background: #c8a96e;
	color: #0d0d0d;
	font-family: inherit;
	font-size: .95rem;
	font-weight: 700;
	letter-spacing: .05em;
	cursor: pointer;
	border: none;
	transition: background .18s, transform .18s;
}

.quiz-restart-btn:hover {
	background: #d9bb82;
	transform: translateY(-1px);
}

.quiz-home-btn {
	display: inline-flex;
	align-items: center;
	gap: .3rem;
	padding: .6rem 1.4rem;
	border-radius: 999px;
	background: none;
	border: 1.5px solid rgba(255,255,255,.2);
	color: rgba(232,228,222,.8);
	text-decoration: none;
	font-size: .9rem;
	transition: border-color .18s, color .18s;
}

.quiz-home-btn:hover {
	border-color: rgba(255,255,255,.45);
	color: #fff;
}

/* ── Empty state ─────────────────────────────────────────── */
.quiz-empty {
	color: rgba(255,255,255,.45);
	font-style: italic;
	text-align: center;
	padding: 4rem 1rem;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 767px) {
	.quiz-results-inner {
		padding: 1.25rem 1rem;
		gap: .85rem;
	}

	.quiz-results-row {
		flex-direction: column;
		align-items: flex-start;
	}

	.quiz-restart-btn,
	.quiz-home-btn,
	.quiz-show-answers-btn {
		width: 100%;
		justify-content: center;
	}
}

@media (max-width: 640px) {
	.k100-quiz-page {
		padding-bottom: 3rem;
	}

	.quiz-text-input-wrap { flex-direction: column; }
	.quiz-text-input { min-width: 0; }

	.quiz-actions { flex-direction: column; }
	.quiz-check-btn,
	.quiz-next-btn.is-visible,
	.quiz-prev-btn,
	.quiz-finish-btn.is-visible { width: 100%; justify-content: center; }

	.quiz-start-btn {
		width: 100%;
	}

	.quiz-media-area { max-height: 280px; }
	.quiz-media-area img,
	.quiz-media-area video { max-height: 280px; }

	.quiz-redirect-overlay-dialog {
		width: min(680px, calc(100vw - 1.5rem));
		padding: 1.55rem 1.15rem 1.35rem;
		border-radius: 14px;
		gap: 1rem;
	}

	.quiz-redirect-overlay-message {
		font-size: clamp(1.25rem, 5.2vw, 1.55rem);
		line-height: 1.3;
	}

	.quiz-redirect-overlay-progress {
		height: 14px;
	}
}
