/**
 * Quiz Pages Stylesheet
 *
 * Modern & Minimalist design for Tutor LMS quizzes.
 * Focus on writing/essay activities for English courses.
 */

/* ============================================
   CSS Variables
   ============================================ */
:root {
	/* Layout */
	--tutor-content-max-width: 860px;
	--tutor-sidebar-width: 320px;

	/* Essay/Writing */
	--tutor-essay-min-height: 350px;
	--tutor-essay-font-family: 'Georgia', 'Times New Roman', serif;
	--tutor-essay-font-size: 17px;
	--tutor-reading-line-height: 1.8;

	/* Colors */
	--tutor-paper-bg: #ffffff;
	--tutor-paper-border: #f0f0f0;
	--tutor-ink-color: #1a1a2e;
	--tutor-accent-subtle: rgba(70, 40, 119, 0.06);
	--tutor-focus-ring: rgba(70, 40, 119, 0.12);

	/* Spacing - increased for more breathing room */
	--tutor-spacing-xs: 10px;
	--tutor-spacing-sm: 16px;
	--tutor-spacing-md: 24px;
	--tutor-spacing-lg: 32px;
	--tutor-spacing-xl: 48px;

	/* Borders */
	--tutor-radius-sm: 8px;
	--tutor-radius-md: 12px;
	--tutor-radius-lg: 16px;

	/* Transitions */
	--tutor-transition-fast: 0.15s ease;
	--tutor-transition-base: 0.25s ease;
}

/* ============================================
   Quiz Page Container
   ============================================ */
.tutor-quiz-single-wrap {
	background: var(--tutor-paper-bg);
}

/* Main quiz content area */
.tutor-quiz-wrapper {
	max-width: var(--tutor-content-max-width);
	margin: 0 auto;
	padding: var(--tutor-spacing-xl) var(--tutor-spacing-lg);
}

/* ============================================
   Quiz Start Screen (Top)
   ============================================ */
.tutor-quiz-start-wrapper {
	max-width: var(--tutor-content-max-width);
	margin: 0 auto;
	padding: var(--tutor-spacing-xl);
	text-align: center;
}

/* Also support legacy class */
.tutor-start-quiz-wrapper {
	max-width: var(--tutor-content-max-width);
	margin: 0 auto;
	padding: var(--tutor-spacing-xl);
	text-align: center;
}

.tutor-quiz-start-header {
	margin-bottom: var(--tutor-spacing-xl);
}

.tutor-quiz-start-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	background: var(--tutor-accent-subtle);
	color: var(--tutorbase-color-primary, #462877);
	font-size: 0.8125rem;
	font-weight: 600;
	border-radius: 20px;
	margin-bottom: var(--tutor-spacing-md);
}

.tutor-quiz-start-badge svg {
	width: 14px;
	height: 14px;
}

.tutor-quiz-start-title {
	font-size: 2rem;
	font-weight: 700;
	color: var(--tutor-ink-color);
	margin: 0 0 var(--tutor-spacing-md) 0;
	line-height: 1.3;
}

.tutor-quiz-start-description {
	font-size: 1rem;
	line-height: 1.7;
	color: #6b7280;
	max-width: 600px;
	margin: 0 auto;
}

.tutor-quiz-start-description p {
	margin: 0;
}

/* Quiz Info Cards */
.tutor-quiz-info-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: var(--tutor-spacing-md);
	margin: var(--tutor-spacing-xl) 0;
}

.tutor-quiz-info-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tutor-spacing-sm);
	background: var(--tutor-paper-bg);
	border: 1px solid var(--tutor-paper-border);
	border-radius: var(--tutor-radius-md);
	padding: var(--tutor-spacing-lg);
	transition: border-color var(--tutor-transition-base), box-shadow var(--tutor-transition-base);
}

.tutor-quiz-info-card:hover {
	border-color: var(--tutorbase-color-primary, #462877);
	box-shadow: 0 4px 12px rgba(70, 40, 119, 0.08);
}

.tutor-quiz-info-card-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	background: var(--tutor-accent-subtle);
	border-radius: 50%;
	color: var(--tutorbase-color-primary, #462877);
}

.tutor-quiz-info-card-icon svg {
	width: 24px;
	height: 24px;
}

.tutor-quiz-info-card-content {
	text-align: center;
}

.tutor-quiz-info-card-value {
	display: block;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--tutor-ink-color);
	line-height: 1.2;
}

.tutor-quiz-info-card-label {
	display: block;
	font-size: 0.8125rem;
	font-weight: 500;
	color: #6b7280;
	margin-top: 2px;
}

/* Quiz Start Actions */
.tutor-quiz-start-actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tutor-spacing-md);
	margin-top: var(--tutor-spacing-xl);
}

.tutor-quiz-btn-start {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 32px;
	font-size: 1rem;
	font-weight: 600;
	color: #fff;
	background: linear-gradient(135deg, var(--tutorbase-color-primary, #462877) 0%, #5e3a9a 100%);
	border: none;
	border-radius: var(--tutor-radius-md);
	cursor: pointer;
	transition: all var(--tutor-transition-base);
}

.tutor-quiz-btn-start:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(70, 40, 119, 0.25);
}

.tutor-quiz-btn-start:active {
	transform: translateY(0);
}

.tutor-quiz-btn-start svg {
	transition: transform var(--tutor-transition-fast);
}

.tutor-quiz-btn-start:hover svg {
	transform: translateX(4px);
}

.tutor-quiz-btn-skip {
	padding: 12px 24px;
	font-size: 0.9375rem;
	font-weight: 500;
	color: #6b7280;
	background: transparent;
	border: none;
	cursor: pointer;
	transition: color var(--tutor-transition-fast);
}

.tutor-quiz-btn-skip:hover {
	color: var(--tutorbase-color-primary, #462877);
}

/* No Attempts Left */
.tutor-quiz-no-attempts {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tutor-spacing-sm);
	padding: var(--tutor-spacing-xl);
	background: #fef3c7;
	border-radius: var(--tutor-radius-md);
	color: #92400e;
}

.tutor-quiz-no-attempts svg {
	color: #f59e0b;
}

.tutor-quiz-no-attempts p {
	margin: 0;
	font-weight: 500;
}

/* ============================================
   Quiz Progress Header (During Quiz)
   ============================================ */
.tutor-quiz-progress-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--tutor-spacing-md);
	padding-bottom: var(--tutor-spacing-lg);
	margin-bottom: var(--tutor-spacing-lg);
	border-bottom: 1px solid var(--tutor-paper-border);
}

.tutor-quiz-progress-info {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.tutor-quiz-title {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--tutor-ink-color);
	margin: 0;
}

.tutor-quiz-question-count {
	font-size: 0.875rem;
	color: #6b7280;
}

.tutor-quiz-timer-display {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: var(--tutor-accent-subtle);
	border-radius: var(--tutor-radius-md);
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--tutorbase-color-primary, #462877);
}

.tutor-quiz-timer-display svg {
	flex-shrink: 0;
}

.tutor-quiz-timer-display.warning {
	background: #fef3c7;
	color: #92400e;
}

.tutor-quiz-timer-display.danger {
	background: #fee2e2;
	color: #991b1b;
	animation: timer-pulse 1s infinite;
}

@keyframes timer-pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.7; }
}

/* Questions Container */
.tutor-quiz-questions-container {
	position: relative;
}

/* Empty/No Questions State */
.tutor-quiz-no-questions {
	text-align: center;
	padding: var(--tutor-spacing-xl);
}

.tutor-quiz-empty-state {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--tutor-spacing-md);
	padding: var(--tutor-spacing-xl);
	color: #6b7280;
}

.tutor-quiz-empty-state svg {
	color: #d1d5db;
}

.tutor-quiz-empty-state p {
	margin: 0;
}

.tutor-quiz-finish-form {
	margin-top: var(--tutor-spacing-lg);
}

/* ============================================
   Question Container
   ============================================ */
.quiz-attempt-single-question {
	background: var(--tutor-paper-bg);
	border: 1px solid var(--tutor-paper-border);
	border-radius: var(--tutor-radius-lg);
	padding: var(--tutor-spacing-xl);
	margin-bottom: var(--tutor-spacing-lg);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
	transition: box-shadow var(--tutor-transition-base);
}

.quiz-attempt-single-question:focus-within {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

/* Question number badge */
.quiz-question-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: var(--tutorbase-color-primary, #462877);
	color: #fff;
	font-size: 0.875rem;
	font-weight: 600;
	border-radius: 50%;
	margin-bottom: var(--tutor-spacing-md);
}

/* Question title/text */
.quiz-question-title,
.quiz-question .tutor-fs-6,
.quiz-question-ans-choice-area h4 {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--tutor-ink-color);
	line-height: 1.6;
	margin: 0 0 var(--tutor-spacing-lg) 0;
}

/* Required indicator */
.quiz-answer-required::before {
	content: '';
}

.quiz-answer-required::after {
	content: ' *';
	color: #dc3545;
}

/* ============================================
   Essay/Open-Ended Question (Enhanced)
   ============================================ */
.tutor-quiz-wrap .tutor-essay-container,
.tutor-essay-container {
	background: var(--tutor-paper-bg);
	border: 2px solid var(--tutor-paper-border);
	border-radius: var(--tutor-radius-md);
	overflow: hidden;
	transition: all var(--tutor-transition-base);
}

.tutor-quiz-wrap .tutor-essay-container:focus-within,
.tutor-essay-container:focus-within {
	border-color: var(--tutorbase-color-primary, #462877);
	box-shadow: 0 0 0 4px var(--tutor-focus-ring);
}

/* Enhanced textarea */
.tutor-quiz-wrap .tutor-essay-textarea,
.tutor-quiz-wrap .question-type-open_ended .tutor-form-control,
.tutor-quiz-wrap .question-type-short_answer .tutor-form-control,
.tutor-essay-textarea,
.question-type-open_ended .tutor-form-control,
.question-type-short_answer .tutor-form-control {
	width: 100% !important;
	min-height: var(--tutor-essay-min-height) !important;
	padding: var(--tutor-spacing-lg) !important;
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
	font-size: var(--tutor-essay-font-size) !important;
	line-height: var(--tutor-reading-line-height) !important;
	color: var(--tutor-ink-color) !important;
	background: #fff !important;
	border: none !important;
	resize: vertical;
	outline: none !important;
	box-sizing: border-box;
	box-shadow: none !important;
}

.tutor-essay-textarea::placeholder,
.question-type-open_ended .tutor-form-control::placeholder,
.question-type-short_answer .tutor-form-control::placeholder {
	color: #9ca3af !important;
	font-style: normal !important;
	font-family: inherit !important;
}

/* Short answer uses smaller height */
.question-type-short_answer .tutor-form-control {
	min-height: 120px !important;
}

/* ============================================
   Essay Footer (Word/Char Count)
   ============================================ */
.tutor-quiz-wrap .tutor-essay-footer,
.tutor-essay-footer {
	display: flex !important;
	justify-content: space-between;
	align-items: center;
	padding: 12px 20px !important;
	background: #f8f7fc !important;
	border-top: 1px solid var(--tutor-paper-border);
	font-size: 0.875rem;
	color: #6b7280;
	gap: 20px;
}

.tutor-essay-stats {
	display: flex;
	gap: var(--tutor-spacing-lg);
}

.tutor-essay-stat {
	display: flex;
	align-items: center;
	gap: 6px;
}

.tutor-essay-stat-value {
	font-weight: 600;
	font-variant-numeric: tabular-nums;
	color: var(--tutor-ink-color);
}

/* Status indicator */
.tutor-essay-status {
	display: flex;
	align-items: center;
	gap: 6px;
	font-weight: 500;
}

.tutor-essay-status-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #9ca3af;
	transition: background var(--tutor-transition-fast);
}

.tutor-essay-status.typing .tutor-essay-status-dot {
	background: #f59e0b;
	animation: pulse 1.5s ease-in-out infinite;
}

.tutor-essay-status.saved .tutor-essay-status-dot {
	background: #10b981;
}

@keyframes pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.5; }
}

/* Character limit warning */
.tutor-char-count {
	font-variant-numeric: tabular-nums;
}

.tutor-char-count.warning {
	color: #f59e0b;
	font-weight: 600;
}

.tutor-char-count.danger {
	color: #dc3545;
	font-weight: 600;
}

/* Legacy character counter styling */
.answer_limit_desc {
	padding: var(--tutor-spacing-sm) var(--tutor-spacing-md);
	background: var(--tutor-accent-subtle);
	border-radius: 0 0 var(--tutor-radius-md) var(--tutor-radius-md);
	font-size: 0.8125rem;
	color: #6b7280;
	margin: 0;
}

.characters_remaining {
	font-weight: 600;
	font-variant-numeric: tabular-nums;
	color: var(--tutor-ink-color);
}

.characters_remaining.warning {
	color: #f59e0b;
}

.characters_remaining.limit-reached {
	color: #dc3545;
}

/* ============================================
   Short Answer Question Container
   ============================================ */
.tutor-short-answer-container {
	background: var(--tutor-paper-bg);
	border: 2px solid var(--tutor-paper-border);
	border-radius: var(--tutor-radius-md);
	overflow: hidden;
	transition: border-color var(--tutor-transition-base), box-shadow var(--tutor-transition-base);
}

.tutor-short-answer-container:focus-within {
	border-color: var(--tutorbase-color-primary, #462877);
	box-shadow: 0 0 0 4px var(--tutor-focus-ring);
}

.tutor-short-answer-textarea {
	width: 100%;
	min-height: 100px;
	padding: var(--tutor-spacing-md);
	border: none;
	outline: none;
	resize: vertical;
	font-size: 1rem;
	line-height: 1.6;
	background: transparent;
	color: var(--tutor-ink-color);
}

.tutor-short-answer-textarea::placeholder {
	color: #9ca3af;
}

.tutor-short-answer-footer {
	display: flex;
	justify-content: flex-end;
	padding: var(--tutor-spacing-xs) var(--tutor-spacing-md);
	background: var(--tutor-accent-subtle);
	border-top: 1px solid var(--tutor-paper-border);
}

.tutor-short-answer-char-count {
	font-size: 0.8125rem;
	color: #6b7280;
}

.tutor-answer-required-note {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-top: var(--tutor-spacing-sm);
	font-size: 0.8125rem;
	color: #6b7280;
}

.tutor-answer-required-note svg {
	flex-shrink: 0;
	color: #f59e0b;
}

/* ============================================
   Writing Prompt Box
   ============================================ */
.tutor-writing-prompt {
	background: var(--tutor-accent-subtle);
	border-left: 4px solid var(--tutorbase-color-primary, #462877);
	border-radius: 0 var(--tutor-radius-md) var(--tutor-radius-md) 0;
	padding: var(--tutor-spacing-lg);
	margin-bottom: var(--tutor-spacing-xl);
}

.tutor-writing-prompt-label {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--tutorbase-color-primary, #462877);
	margin-bottom: var(--tutor-spacing-xs);
}

.tutor-writing-prompt-text {
	font-size: 1rem;
	line-height: 1.7;
	color: var(--tutor-ink-color);
	margin: 0;
}

/* ============================================
   Quiz Navigation Buttons
   ============================================ */
.tutor-quiz-btn-group {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--tutor-spacing-md);
	margin-top: var(--tutor-spacing-xl);
	padding-top: var(--tutor-spacing-xl);
	border-top: 1px solid var(--tutor-paper-border);
}

/* Primary action button */
.tutor-quiz-btn-primary,
.tutor-quiz-btn-group .tutor-btn-primary {
	padding: 14px 28px;
	font-size: 1rem;
	font-weight: 600;
	color: #fff;
	background: linear-gradient(135deg, var(--tutorbase-color-primary, #462877) 0%, #5e3a9a 100%);
	border: none;
	border-radius: var(--tutor-radius-md);
	cursor: pointer;
	transition: all var(--tutor-transition-base);
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.tutor-quiz-btn-primary:hover,
.tutor-quiz-btn-group .tutor-btn-primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(70, 40, 119, 0.35);
}

/* Secondary/outline button */
.tutor-quiz-btn-secondary,
.tutor-quiz-btn-group .tutor-btn-outline-primary {
	padding: 14px 28px;
	font-size: 1rem;
	font-weight: 600;
	color: var(--tutorbase-color-primary, #462877);
	background: transparent;
	border: 2px solid var(--tutor-paper-border);
	border-radius: var(--tutor-radius-md);
	cursor: pointer;
	transition: all var(--tutor-transition-base);
}

.tutor-quiz-btn-secondary:hover,
.tutor-quiz-btn-group .tutor-btn-outline-primary:hover {
	border-color: var(--tutorbase-color-primary, #462877);
	background: var(--tutor-accent-subtle);
}

/* ============================================
   Quiz Progress Indicator
   ============================================ */
.tutor-quiz-progress {
	display: flex;
	align-items: center;
	gap: var(--tutor-spacing-md);
	margin-bottom: var(--tutor-spacing-xl);
}

.tutor-quiz-progress-bar {
	flex: 1;
	height: 6px;
	background: var(--tutor-paper-border);
	border-radius: 3px;
	overflow: hidden;
}

.tutor-quiz-progress-fill {
	height: 100%;
	background: linear-gradient(90deg, var(--tutorbase-color-primary, #462877), var(--tutorbase-color-accent, #0b4799));
	border-radius: 3px;
	transition: width 0.5s ease;
}

.tutor-quiz-progress-text {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--tutor-ink-color);
	white-space: nowrap;
}

/* ============================================
   Quiz Timer
   ============================================ */
.tutor-quiz-timer {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: var(--tutor-spacing-sm) var(--tutor-spacing-md);
	background: var(--tutor-accent-subtle);
	border-radius: var(--tutor-radius-md);
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--tutor-ink-color);
}

.tutor-quiz-timer-icon {
	color: var(--tutorbase-color-primary, #462877);
}

.tutor-quiz-timer.warning {
	background: #fef3c7;
	color: #92400e;
}

.tutor-quiz-timer.danger {
	background: #fee2e2;
	color: #991b1b;
	animation: timerPulse 1s ease-in-out infinite;
}

@keyframes timerPulse {
	0%, 100% { transform: scale(1); }
	50% { transform: scale(1.02); }
}

/* ============================================
   Quiz Question Meta Bar
   ============================================ */
.quiz-meta-info {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--tutor-spacing-md);
	padding: var(--tutor-spacing-md) var(--tutor-spacing-lg);
	background: var(--tutor-accent-subtle);
	border-radius: var(--tutor-radius-md);
	margin-bottom: var(--tutor-spacing-xl);
}

/* ============================================
   Question Navigation Pills
   ============================================ */
.tutor-quiz-question-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: var(--tutor-spacing-xl);
}

.tutor-quiz-question-pill {
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--tutor-ink-color);
	background: var(--tutor-paper-bg);
	border: 2px solid var(--tutor-paper-border);
	border-radius: 50%;
	cursor: pointer;
	transition: all var(--tutor-transition-fast);
}

.tutor-quiz-question-pill:hover {
	border-color: var(--tutorbase-color-primary, #462877);
	background: var(--tutor-accent-subtle);
}

.tutor-quiz-question-pill.is-current {
	color: #fff;
	background: var(--tutorbase-color-primary, #462877);
	border-color: var(--tutorbase-color-primary, #462877);
}

.tutor-quiz-question-pill.is-answered {
	color: #fff;
	background: #10b981;
	border-color: #10b981;
}

/* ============================================
   Submit Confirmation Modal
   ============================================ */
.tutor-quiz-submit-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.5);
	backdrop-filter: blur(4px);
	opacity: 0;
	visibility: hidden;
	transition: all var(--tutor-transition-base);
}

.tutor-quiz-submit-modal.is-open {
	opacity: 1;
	visibility: visible;
}

.tutor-quiz-submit-modal-content {
	background: var(--tutor-paper-bg);
	border-radius: var(--tutor-radius-lg);
	padding: var(--tutor-spacing-xl);
	max-width: 400px;
	width: 90%;
	text-align: center;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
	transform: scale(0.95);
	transition: transform var(--tutor-transition-base);
}

.tutor-quiz-submit-modal.is-open .tutor-quiz-submit-modal-content {
	transform: scale(1);
}

/* ============================================
   Responsive Design
   ============================================ */
@media (max-width: 768px) {
	.tutor-quiz-wrapper {
		padding: var(--tutor-spacing-lg) var(--tutor-spacing-md);
	}

	.quiz-attempt-single-question,
	.tutor-quiz-top-info {
		padding: var(--tutor-spacing-lg);
	}

	.tutor-essay-textarea,
	.question-type-open_ended .tutor-form-control,
	.question-type-short_answer .tutor-form-control {
		min-height: 250px;
		padding: var(--tutor-spacing-md);
		font-size: 16px; /* Prevent iOS zoom */
	}

	.tutor-essay-footer {
		flex-direction: column;
		gap: var(--tutor-spacing-sm);
		text-align: center;
	}

	.tutor-essay-stats {
		flex-direction: column;
		gap: var(--tutor-spacing-xs);
	}

	.tutor-quiz-btn-group {
		flex-direction: column;
	}

	.tutor-quiz-btn-group button {
		width: 100%;
	}

	.tutor-quiz-info-cards {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 480px) {
	.tutor-quiz-info-cards {
		grid-template-columns: 1fr;
	}
}

/* ============================================
   Reduced Motion
   ============================================ */
@media (prefers-reduced-motion: reduce) {
	.tutor-essay-status.typing .tutor-essay-status-dot,
	.tutor-quiz-timer.danger {
		animation: none;
	}

	*,
	*::before,
	*::after {
		transition-duration: 0.01ms !important;
	}
}

/* ============================================
   Save Indicator States
   ============================================ */
.tutor-essay-save-indicator {
	display: none;
	align-items: center;
	gap: 6px;
	font-size: 0.8125rem;
	font-weight: 500;
	color: #6b7280;
	transition: color var(--tutor-transition-fast);
}

.tutor-essay-save-indicator svg {
	flex-shrink: 0;
}

/* Saving state with spinner */
.tutor-essay-save-indicator.saving {
	color: #6b7280;
}

.tutor-essay-save-indicator.saving .spinner {
	animation: spin 1s linear infinite;
}

@keyframes spin {
	from { transform: rotate(0deg); }
	to { transform: rotate(360deg); }
}

/* Saved state */
.tutor-essay-save-indicator.saved {
	color: #10b981;
}

/* Error state */
.tutor-essay-save-indicator.error {
	color: #dc3545;
}

/* Word count styling */
.tutor-quiz-wrap .tutor-essay-counts,
.tutor-essay-counts {
	display: flex !important;
	align-items: center;
	gap: 24px;
}

.tutor-quiz-wrap .tutor-essay-word-count,
.tutor-quiz-wrap .tutor-essay-char-count,
.tutor-essay-word-count,
.tutor-essay-char-count {
	display: inline-flex !important;
	align-items: center;
	gap: 6px;
	font-size: 0.875rem;
}

.tutor-essay-word-count .count-number,
.tutor-essay-char-count .count-number,
.tutor-essay-char-count .characters_remaining {
	font-weight: 700;
	font-variant-numeric: tabular-nums;
	color: var(--tutorbase-color-primary, #462877);
	font-size: 1rem;
}

/* Separator between counts */
.tutor-essay-word-count::after {
	content: '•';
	margin-left: 18px;
	color: #d1d5db;
}

/* Required note */
.tutor-quiz-wrap .tutor-essay-required-note,
.tutor-essay-required-note {
	display: flex !important;
	align-items: center;
	gap: 8px;
	margin-top: 12px;
	padding: 10px 16px;
	font-size: 0.8125rem;
	color: #92400e;
	background: #fef3c7;
	border-radius: 8px;
}

.tutor-essay-required-note svg {
	flex-shrink: 0;
	color: #f59e0b;
}

/* ============================================
   GSAP Animation Initial States
   ============================================ */
.tutor-quiz-animate .quiz-attempt-single-question {
	opacity: 0;
	transform: translateY(20px);
}

.tutor-quiz-animate .tutor-quiz-btn-group {
	opacity: 0;
	transform: translateY(10px);
}
