/* Catalogo publico de familias profesionales y ciclos formativos. */

.fpdual-cycle-catalog {
	width: 100%;
	margin-inline: auto;
	padding-block: 0px;
}

.fpdual-cycle-catalog__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
	gap: 18px;
	align-items: start;
}

.fpdual-cycle-catalog__family {
	min-width: 0;
	border: 1px solid var(--fpdual-color-border);
	background: var(--fpdual-color-surface);
	box-shadow: var(--fpdual-shadow-soft);
}

.fpdual-cycle-catalog__family-title {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 14px;
	margin: 0;
	padding: 18px 18px 16px;
	border-bottom: 2px solid var(--fpdual-color-primary);
	color: var(--fpdual-color-primary);
	font-family: var(--fpdual-font-display);
	font-size: 20px;
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: 0;
}

.fpdual-cycle-catalog__family-count {
	color: var(--fpdual-color-primary);
	font-size: 0.75em;
	font-weight: 800;
	line-height: 1;
	vertical-align: middle;
}

.fpdual-cycle-catalog__list {
	display: grid;
	gap: 0;
	margin: 0;
	padding: 0;
	list-style: none;
}

.fpdual-cycle-catalog__item {
	margin: 0;
	padding: 0;
	list-style: none;
}

.fpdual-cycle-catalog__item + .fpdual-cycle-catalog__item {
	border-top: 1px solid var(--fpdual-color-border);
}

.fpdual-cycle-catalog__link {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 12px;
	align-items: start;
	min-height: 58px;
	padding: 13px 16px;
	color: var(--fpdual-color-primary);
	text-decoration: none;
	transition:
		background-color var(--fpdual-transition),
		color var(--fpdual-transition);
}

.fpdual-cycle-catalog__link:hover,
.fpdual-cycle-catalog__link:focus {
	background: var(--fpdual-color-primary-tint);
	color: var(--fpdual-color-primary-strong);
}

.fpdual-cycle-catalog__link:focus-visible {
	outline: 3px solid var(--fpdual-color-primary-focus);
	outline-offset: -3px;
}

.fpdual-cycle-catalog__link--missing {
	color: var(--fpdual-color-primary-strong);
}

.fpdual-cycle-catalog__cycle {
	min-width: 0;
	font-size: 14px;
	font-weight: 800;
	line-height: 1.3;
}

.fpdual-cycle-catalog__meta {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 6px;
	width: 100%;
	min-width: 0;
}

.fpdual-cycle-catalog__grade,
.fpdual-cycle-catalog__pdf {
	display: inline-flex;
	align-items: center;
	min-height: 26px;
	padding: 4px 8px;
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	white-space: nowrap;
}

.fpdual-cycle-catalog__grade {
	background: var(--fpdual-color-surface-soft);
	color: var(--fpdual-color-text);
}

.fpdual-cycle-catalog__pdf {
	background: var(--fpdual-color-primary);
	color: var(--fpdual-color-on-primary);
}

.fpdual-cycle-catalog__link--missing .fpdual-cycle-catalog__pdf {
	background: var(--fpdual-color-surface-soft);
	color: var(--fpdual-color-muted);
}

.fpdual-cycle-catalog__toggle {
	appearance: none;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 46px;
	margin: 0;
	padding: 12px 16px;
	border: 0;
	border-top: 2px solid var(--fpdual-color-primary);
	border-radius: 0;
	background: var(--fpdual-color-surface);
	color: var(--fpdual-color-primary);
	font-family: var(--fpdual-font-body);
	font-size: 13px;
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
	cursor: pointer;
	transition:
		background-color var(--fpdual-transition),
		color var(--fpdual-transition);
}

.fpdual-cycle-catalog__toggle:hover,
.fpdual-cycle-catalog__toggle:focus {
	background: var(--fpdual-color-primary-tint);
	color: var(--fpdual-color-primary-strong);
}

.fpdual-cycle-catalog__toggle:focus-visible {
	outline: 3px solid var(--fpdual-color-primary-focus);
	outline-offset: -3px;
}

@media (max-width: 767px) {
	.fpdual-cycle-catalog {
		width: 100%;
		padding: 10px;
	}

	.fpdual-cycle-catalog__grid {
		grid-template-columns: 1fr;
		gap: 14px;
	}

	.fpdual-cycle-catalog__family {
		box-shadow: none;
	}

	.fpdual-cycle-catalog__family-title {
		padding: 16px 14px 14px;
		font-size: 18px;
	}

	.fpdual-cycle-catalog__link {
		grid-template-columns: 1fr;
		gap: 10px;
		min-height: 64px;
		padding: 14px;
	}

	.fpdual-cycle-catalog__meta {
		justify-content: flex-end;
	}
}
