/*
 * COMPONENTES INTERACTIVOS — toggle de tema, dialog, tabs, slider.
 * El JS correspondiente solo se importa si el componente está en la página.
 */

/* ---- Toggle claro/oscuro/sistema -------------------------------------- */
.theme-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: var(--radius-sm);
	color: var(--color-ink-soft);
	transition: color var(--duration-fast) var(--ease-out), background-color var(--duration-fast) var(--ease-out);
}

.theme-toggle:hover {
	color: var(--color-ink);
	background-color: var(--color-surface);
}

.theme-toggle .icon {
	display: none;
}

.theme-toggle[data-mode='light'] .icon--sun,
.theme-toggle[data-mode='dark'] .icon--moon,
.theme-toggle[data-mode='system'] .icon--contrast {
	display: block;
}

/* ---- Dialog nativo ------------------------------------------------------ */
.modal {
	width: min(92vw, 34rem);
	border: none;
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	background-color: var(--color-base);
	color: var(--color-ink);
	box-shadow: var(--shadow-card);
}

.modal::backdrop {
	background-color: oklch(15% 0.02 255 / 0.6);
	backdrop-filter: blur(3px);
}

.modal__close {
	position: absolute;
	inset-block-start: var(--space-3);
	inset-inline-end: var(--space-3);
	width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--radius-sm);
	color: var(--color-ink-soft);
}

.modal__close:hover {
	color: var(--color-ink);
	background-color: var(--color-surface);
}

/* ---- Tabs ------------------------------------------------------------------ */
.tabs__list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-1);
	border-block-end: 1px solid var(--color-line);
	margin-block-end: var(--space-5);
}

.tabs__tab {
	padding: var(--space-3) var(--space-4);
	font-weight: var(--weight-medium);
	color: var(--color-ink-soft);
	position: relative;
	transition: color var(--duration-fast) var(--ease-out);
}

.tabs__tab:hover {
	color: var(--color-ink);
}

.tabs__tab[aria-selected='true'] {
	color: var(--color-ink);
	font-weight: var(--weight-semibold);
}

.tabs__tab[aria-selected='true']::after {
	content: '';
	position: absolute;
	inset-inline: var(--space-4);
	inset-block-end: -1px;
	height: 2px;
	background-color: var(--color-accent);
}

.tabs__panel[hidden] {
	display: none;
}

/* ---- Slider (scroll-snap) ---------------------------------------------------- */
.slider {
	position: relative;
}

.slider__track {
	display: flex;
	gap: var(--space-5);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scrollbar-width: none;
	padding-block-end: var(--space-2);
}

.slider__track::-webkit-scrollbar {
	display: none;
}

.slider__track > * {
	flex: 0 0 min(100%, 26rem);
	scroll-snap-align: start;
}

.slider__controls {
	display: flex;
	gap: var(--space-2);
	justify-content: flex-end;
	margin-block-start: var(--space-4);
}

.slider__btn {
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--color-line);
	border-radius: 50%;
	color: var(--color-ink);
	transition: border-color var(--duration-fast) var(--ease-out), background-color var(--duration-fast) var(--ease-out);
}

.slider__btn:hover:not(:disabled) {
	border-color: var(--color-primary);
	background-color: var(--color-surface);
}

.slider__btn:disabled {
	opacity: 0.35;
	cursor: default;
}

.slider__btn--prev .icon {
	rotate: 180deg;
}
