/* ==========================================================================
   interactive-categories.css — Bloc « Catégories Interactives ».
   Layout : menu latéral vertical (≥960px) ou tabs horizontales scrollables (<960px)
            + panneau dynamique à droite.
   Animation swap gérée par GSAP (interactive-categories.js).
   ========================================================================== */

.interactive-categories {
	position: relative;
	color: inherit;
	padding-block: clamp(var(--space-2xl), 8vw, var(--space-3xl));
}

.interactive-categories.alignfull {
	margin-inline: calc(50% - 50vw);
	width: 100vw;
	max-width: 100vw;
}

.interactive-categories__inner {
	display: flex;
	flex-direction: column;
	gap: clamp(var(--space-xl), 4vw, var(--space-2xl));
}

/* ----------------------------------------- Header */

.interactive-categories__header {
	max-width: 720px;
}

.interactive-categories__title {
	font-family: var(--font-display);
	font-size: var(--fs-3xl);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
	letter-spacing: var(--ls-tight);
	margin: 0;
	color: inherit;
	text-wrap: balance;
}

/* ----------------------------------------- Layout (menu + panels) */

.interactive-categories__layout {
	display: grid;
	grid-template-columns: minmax(0, 260px) minmax(0, 1fr);
	gap: clamp(var(--space-lg), 4vw, var(--space-2xl));
	align-items: start;
}

/* ----------------------------------------- Menu latéral (desktop) */

.interactive-categories__menu {
	display: flex;
	flex-direction: column;
	gap: 0;
	border-left: 1px solid var(--color-border);
}

.interactive-categories__menu-item {
	appearance: none;
	background: none;
	border: 0;
	border-left: 2px solid transparent;
	margin-left: -1px; /* aligne le marker actif sur la bordure du menu */
	padding: var(--space-sm) var(--space-md);
	text-align: left;
	font-family: var(--font-sans);
	font-size: var(--fs-base);
	font-weight: var(--fw-medium);
	line-height: var(--lh-snug);
	color: var(--color-text-muted);
	cursor: pointer;
	transition:
		color var(--duration-fast) var(--ease-out),
		border-color var(--duration-fast) var(--ease-out),
		background-color var(--duration-fast) var(--ease-out);
}

.interactive-categories__menu-item:hover {
	color: var(--color-text);
	background-color: var(--color-surface);
}

.interactive-categories__menu-item:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: -2px;
	color: var(--color-text);
}

.interactive-categories__menu-item.is-active {
	color: var(--color-accent);
	border-left-color: var(--color-accent);
	background-color: transparent;
}

.interactive-categories__menu-label {
	display: block;
}

/* ----------------------------------------- Panels */

.interactive-categories__panels {
	position: relative;
	min-height: 360px;
}

.interactive-categories__panel {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
	gap: clamp(var(--space-lg), 3vw, var(--space-2xl));
	align-items: center;
}

/* `hidden` attribut gère la disparition pour a11y ; GSAP gère l'opacity quand présent. */
.interactive-categories__panel[hidden] {
	display: none;
}

.interactive-categories__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.interactive-categories__panel-title {
	font-family: var(--font-display);
	font-size: var(--fs-2xl);
	font-weight: var(--fw-bold);
	line-height: var(--lh-tight);
	letter-spacing: var(--ls-tight);
	margin: 0;
	color: inherit;
	text-wrap: balance;
}

.interactive-categories__description {
	font-size: var(--fs-base);
	line-height: var(--lh-relaxed);
	color: var(--color-text-muted);
}

.interactive-categories__description p {
	margin: 0 0 var(--space-sm);
}

.interactive-categories__description p:last-child {
	margin-bottom: 0;
}

.interactive-categories__description a {
	color: var(--color-accent);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.interactive-categories__description a:hover,
.interactive-categories__description a:focus-visible {
	color: var(--color-accent-light);
}

/* ----------------------------------------- CTAs (2 boutons) */

.interactive-categories__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	margin-top: var(--space-xs);
}

.interactive-categories__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-sm) var(--space-lg);
	text-decoration: none;
	font-weight: var(--fw-medium);
	font-size: var(--fs-sm);
	letter-spacing: var(--ls-wide);
	text-transform: uppercase;
	border-radius: var(--radius-sm);
	transition:
		background var(--duration-fast) var(--ease-out),
		color var(--duration-fast) var(--ease-out),
		border-color var(--duration-fast) var(--ease-out),
		transform var(--duration-fast) var(--ease-out);
}

.interactive-categories__cta-icon {
	display: inline-flex;
	transition: transform var(--duration-fast) var(--ease-out);
}

.interactive-categories__cta:hover .interactive-categories__cta-icon,
.interactive-categories__cta:focus-visible .interactive-categories__cta-icon {
	transform: translateX(4px);
}

.interactive-categories__cta--primary {
	background: var(--color-accent);
	color: var(--color-text);
	box-shadow: var(--shadow-sm);
}

.interactive-categories__cta--primary:hover,
.interactive-categories__cta--primary:focus-visible {
	background: var(--color-accent-dark);
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.interactive-categories__cta--secondary {
	background: transparent;
	color: var(--color-text);
	border: 1px solid var(--color-border-strong);
}

.interactive-categories__cta--secondary:hover,
.interactive-categories__cta--secondary:focus-visible {
	border-color: var(--color-accent);
	color: var(--color-accent);
	transform: translateY(-2px);
}

.interactive-categories__cta:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 3px;
}

/* ----------------------------------------- Media */

.interactive-categories__media {	
	overflow: hidden;
	border-radius: var(--radius-md);
	background: var(--color-surface);
	box-shadow: var(--shadow-md);
}

.interactive-categories__image {
	width: 100%;
	height: 100%;
	max-width: 100%;
	object-fit: cover;
	display: block;
}

/* ----------------------------------------- Responsive : <960px → menu horizontal scrollable */

@media (max-width: 959px) {
	.interactive-categories__layout {
		grid-template-columns: 1fr;
		gap: var(--space-lg);
	}

	.interactive-categories__menu {
		flex-direction: row;
		border-left: 0;
		border-bottom: 1px solid var(--color-border);
		overflow-x: auto;
		overflow-y: hidden;
		scrollbar-width: thin;
		-webkit-overflow-scrolling: touch;
	}

	.interactive-categories__menu-item {
		flex: 0 0 auto;
		border-left: 0;
		border-bottom: 2px solid transparent;
		margin-left: 0;
		margin-bottom: -1px; /* aligne le marker sur la bordure bottom du menu */
		padding: var(--space-sm) var(--space-md);
		white-space: nowrap;
	}

	.interactive-categories__menu-item.is-active {
		border-bottom-color: var(--color-accent);
	}

	.interactive-categories__panel {
		grid-template-columns: 1fr;
		gap: var(--space-md);
	}

	.interactive-categories__media {
		order: -1;		
	}

	.interactive-categories__panels {
		min-height: 0;
	}
}

@media (max-width: 600px) {
	.interactive-categories__ctas {
		flex-direction: column;
		align-items: stretch;
	}

	.interactive-categories__cta {
		justify-content: center;
	}
}

/* ----------------------------------------- Reduced motion */

@media (prefers-reduced-motion: reduce) {
	.interactive-categories__menu-item,
	.interactive-categories__cta,
	.interactive-categories__cta-icon {
		transition: none;
	}

	.interactive-categories__cta--primary:hover,
	.interactive-categories__cta--primary:focus-visible,
	.interactive-categories__cta--secondary:hover,
	.interactive-categories__cta--secondary:focus-visible {
		transform: none;
	}
}
