/**
 * Free mock test catalog — search, filters, cards, take flow.
 */

.mslms-free-mock-catalog {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 0 64px;
}

.mslms-free-mock-catalog__hero {
	margin-bottom: 40px;
	padding: 48px 32px;
	background: linear-gradient(135deg, rgba(11, 79, 135, 0.08), rgba(12, 154, 70, 0.08));
	border: 1px solid var(--msa-glass-border, rgba(255, 255, 255, 0.45));
	border-radius: var(--msa-radius-lg, 28px);
	text-align: center;
	backdrop-filter: blur(12px);
}

.mslms-free-mock-catalog__eyebrow {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--msa-primary-green, #0C9A46);
	margin-bottom: 12px;
}

.mslms-free-mock-catalog__title {
	font-family: 'Fraunces', Georgia, serif;
	font-size: clamp(2rem, 5vw, 2.75rem);
	font-weight: 600;
	color: var(--msa-primary-blue, #0B4F87);
	margin: 0 0 12px;
}

.mslms-free-mock-catalog__subtitle {
	color: var(--msa-muted-text, rgba(44, 62, 80, 0.72));
	font-size: 1.1rem;
	max-width: 640px;
	margin: 0 auto;
	line-height: 1.6;
}

.mslms-free-mock-catalog__search-bar {
	display: flex;
	align-items: stretch;
	gap: 0;
	background: var(--msa-glass-bg, rgba(255, 255, 255, 0.62));
	border: 1px solid var(--msa-glass-border);
	border-radius: var(--msa-radius-lg, 28px);
	box-shadow: var(--msa-shadow-sm, 0 14px 34px -22px rgba(11, 79, 135, 0.3));
	overflow: hidden;
	margin-bottom: 24px;
	backdrop-filter: blur(12px);
}

.mslms-free-mock-catalog__search-input {
	flex: 1;
	border: 0;
	background: transparent;
	padding: 16px 24px;
	font-size: 1rem;
	color: var(--msa-text, #2C3E50);
	outline: none;
}

.mslms-free-mock-catalog__search-btn {
	border: 0;
	background: var(--msa-gradient-accent, linear-gradient(135deg, #27B45B, #0C9A46));
	color: #fff;
	padding: 0 24px;
	cursor: pointer;
	display: flex;
	align-items: center;
}

.mslms-free-mock-catalog__filters-toggle {
	display: none;
	width: 100%;
	align-items: center;
	justify-content: space-between;
	min-height: 48px;
	padding: 14px 20px;
	margin-bottom: 16px;
	background: var(--msa-glass-bg);
	border: 1px solid var(--msa-border, rgba(11, 79, 135, 0.12));
	border-radius: var(--msa-radius-md, 18px);
	font-weight: 600;
	cursor: pointer;
}

.mslms-free-mock-catalog__filters {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	padding: 24px;
	background: var(--msa-glass-bg);
	border: 1px solid var(--msa-glass-border);
	border-radius: var(--msa-radius-lg);
	box-shadow: var(--msa-shadow-sm);
	margin-bottom: 24px;
	backdrop-filter: blur(12px);
}

.mslms-free-mock-catalog__filter label {
	display: block;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--msa-muted-text);
	margin-bottom: 8px;
}

.mslms-free-mock-catalog__count {
	font-size: 0.9rem;
	color: var(--msa-muted-text);
	margin-bottom: 20px;
}

.mslms-free-mock-catalog__count-num {
	font-family: 'IBM Plex Mono', monospace;
	font-weight: 600;
	color: var(--msa-primary-blue);
}

.mslms-free-mock-catalog__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 24px;
}

.mslms-free-mock-catalog__results.is-loading {
	opacity: 0.55;
	pointer-events: none;
}

.mslms-free-mock-catalog__empty {
	text-align: center;
	padding: 48px 24px;
	color: var(--msa-muted-text);
	background: var(--msa-bg-alt, #F5F8FB);
	border-radius: var(--msa-radius-md);
}

/* Cards */
.mslms-free-mock-card {
	background: var(--msa-glass-bg);
	border: 1px solid var(--msa-glass-border);
	border-radius: var(--msa-radius-lg);
	box-shadow: var(--msa-shadow-sm);
	overflow: hidden;
	transition: transform 0.2s, box-shadow 0.2s;
}

.mslms-free-mock-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--msa-shadow-md, 0 20px 60px -20px rgba(8, 61, 107, 0.25));
}

.mslms-free-mock-card__body {
	padding: 24px;
}

.mslms-free-mock-card__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 12px;
}

.mslms-free-mock-badge {
	display: inline-block;
	padding: 4px 12px;
	border-radius: 999px;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.mslms-free-mock-badge--authority {
	background: rgba(11, 79, 135, 0.1);
	color: var(--msa-primary-blue);
}

.mslms-free-mock-badge--free {
	background: rgba(12, 154, 70, 0.12);
	color: var(--msa-primary-green);
}

.mslms-free-mock-card__meta {
	font-size: 0.85rem;
	color: var(--msa-muted-text);
	margin: 0 0 8px;
}

.mslms-free-mock-card__title {
	font-size: 1.15rem;
	font-weight: 600;
	color: var(--msa-text);
	margin: 0 0 16px;
	line-height: 1.35;
}

.mslms-free-mock-card__stats {
	display: flex;
	gap: 20px;
	list-style: none;
	margin: 0 0 20px;
	padding: 0;
	font-size: 0.85rem;
	color: var(--msa-muted-text);
}

.mslms-free-mock-card__stats strong {
	display: block;
	font-size: 1.25rem;
	color: var(--msa-primary-blue);
	font-family: 'IBM Plex Mono', monospace;
}

.mslms-free-mock-card__btn {
	display: block;
	width: 100%;
	text-align: center;
	padding: 14px 20px;
	background: var(--msa-gradient-accent);
	color: #fff !important;
	border-radius: 999px;
	font-weight: 600;
	text-decoration: none;
	transition: opacity 0.2s;
}

.mslms-free-mock-card__btn:hover {
	opacity: 0.92;
}

/* Take flow */
.mslms-free-mock-take {
	max-width: 800px;
	margin: 0 auto;
	padding-bottom: 48px;
}

.mslms-free-mock-take__back {
	margin-bottom: 24px;
}

.mslms-free-mock-take__back a {
	color: var(--msa-primary-blue);
	text-decoration: none;
	font-weight: 500;
}

.mslms-free-mock-take__login-card {
	background: var(--msa-glass-bg);
	border: 1px solid var(--msa-glass-border);
	border-radius: var(--msa-radius-lg);
	padding: 40px 32px;
	text-align: center;
	box-shadow: var(--msa-shadow-sm);
}

.mslms-free-mock-take__title {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.75rem;
	color: var(--msa-primary-blue);
	margin: 16px 0 12px;
}

.mslms-free-mock-take__lead {
	color: var(--msa-muted-text);
	margin-bottom: 20px;
}

.mslms-free-mock-take__info {
	list-style: none;
	padding: 0;
	margin: 0 0 28px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 16px;
	font-size: 0.9rem;
	color: var(--msa-text);
}

.mslms-free-mock-take__login-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
}

.mslms-free-mock-exam .mslms-mock-exam__start {
	background: var(--msa-glass-bg);
	border: 1px solid var(--msa-glass-border);
	border-radius: var(--msa-radius-lg);
	padding: 32px;
}

/* Results upgrade CTA */
.mslms-free-mock-results__upgrade {
	margin-top: 32px;
	padding: 32px;
	background: linear-gradient(135deg, rgba(11, 79, 135, 0.06), rgba(12, 154, 70, 0.1));
	border: 1px solid var(--msa-glass-border);
	border-radius: var(--msa-radius-lg);
	text-align: center;
}

.mslms-free-mock-results__upgrade-title {
	font-family: 'Fraunces', Georgia, serif;
	font-size: 1.5rem;
	color: var(--msa-primary-blue);
	margin: 0 0 12px;
}

.mslms-free-mock-results__upgrade-text {
	color: var(--msa-muted-text);
	margin: 0 0 24px;
	max-width: 520px;
	margin-left: auto;
	margin-right: auto;
}

.mslms-free-mock-results__upgrade-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	justify-content: center;
}

.mslms-button--accent {
	background: var(--msa-gradient-accent) !important;
	color: #fff !important;
}

.mslms-button--ghost {
	background: transparent !important;
	border: 1px solid var(--msa-border) !important;
	color: var(--msa-primary-blue) !important;
}

@media (max-width: 768px) {
	.mslms-free-mock-catalog__filters-toggle {
		display: flex;
	}

	.mslms-free-mock-catalog__filters {
		display: none;
	}

	.mslms-free-mock-catalog__filters.is-open {
		display: grid;
		grid-template-columns: 1fr;
	}

	.mslms-free-mock-catalog__hero {
		padding: 32px 20px;
	}

	.mslms-free-mock-catalog__grid {
		grid-template-columns: 1fr;
	}

	.mslms-free-mock-take__nav {
		flex-direction: column;
		gap: 12px;
	}

	.mslms-free-mock-take__nav .mslms-button {
		width: 100%;
		justify-content: center;
		min-height: 48px;
	}
}

@media (max-width: 375px) {
	.mslms-free-mock-catalog__hero {
		padding: 24px 16px;
	}
}
