/*
 * tdn-partners-band — Phase C.6 Bloc 5b (Page Expertises)
 *
 * Bandeau pink-200 avec intro multi-couleur + 3 cards partenaires horizontales.
 *   - Bg pink-200 saturé
 *   - Header intro : midnight + pink-700 50% (segment 2 souligne offre groupe)
 *   - 3 cards partenaires : bg white drop-shadow, photo 250×250 + cool-shape 32×32
 *     + titre Heavy 24 + mention pink-200 uppercase tracking 2px + description gray
 *
 * Spec Figma : node 8115:5792. Pattern réutilisable potentiel KP/PS.
 */

/* ===== 1. Section root ============================================ */
.tdn-partners-band {
	position: relative;
	background: var(--tdn-color-pink-100, #F6C9D0);
	padding: 100px 0 120px;
	overflow: hidden;
	font-family: var(--tdn-font-family-brand, 'Nunito Sans', sans-serif);
}

/* ===== 2. Inner wrapper ========================================== */
.tdn-partners-band__inner {
	max-width: 1442px;
	margin: 0 auto;
	padding: 0 52px;
	position: relative;
}

/* ===== 3. Header intro multi-couleur ============================== */
.tdn-partners-band__intro {
	margin: 0 auto 80px;
	max-width: 1280px;
	font-weight: var(--tdn-h2-weight);
	font-size: clamp(32px, 4vw, 48px);
	line-height: 1.2;
	letter-spacing: -0.03em;
	text-align: center;
	color: var(--tdn-color-midnight-900, #1A1A2E);
	font-style: normal;
}

.tdn-partners-band__intro-accent {
	color: rgba(150, 56, 56, 0.5); /* pink-700 50% opacity, valeur Figma exacte */
}

/* ===== 4. Cards row =============================================== */
.tdn-partners-band__cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	align-items: stretch;
}

/* ===== 5. Card individuelle ======================================= */
.tdn-partners-band__card {
	background: var(--tdn-color-neutral-0, #FFFFFF);
	border-radius: 32px;
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 16px;
	box-shadow: 0 14px 16px rgba(0, 0, 0, 0.1);
}

/* ===== 6. Hero photo ============================================== */
.tdn-partners-band__card-photo {
	display: block;
	width: 100%;
	height: 250px;
	object-fit: cover;
	border-radius: 16px;
	margin: 0;
}

/* ===== 7. Text row (icon + title + mention + description) ========= */
.tdn-partners-band__card-text {
	display: flex;
	flex-direction: column;
	gap: 16px;
	padding: 8px;
}

/* ===== 8. Cool-shape icon (mask image) ============================
 * Fichiers .svg (Figma exporte SVG via mask URLs imgGradient).
 * Note : initialement stockés en .png (extension trompeuse), renommés en .svg
 * pour que le serveur OVH les serve avec Content-Type: image/svg+xml correct.
 * Mask-image CSS rejette les fichiers dont le Content-Type ne correspond pas. */
.tdn-partners-band__card-icon {
	display: block; /* span vide → inline par défaut → width/height ignorés */
	width: 32px;
	height: 32px;
	flex-shrink: 0;
	background-color: var(--tdn-color-pink-500, #C06D80);
	-webkit-mask-position: center;
	mask-position: center;
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-size: contain;
	mask-size: contain;
}

.tdn-partners-band__card-icon--karreprod {
	-webkit-mask-image: url("../../images/partners/icons/icon-karreprod.svg");
	mask-image: url("../../images/partners/icons/icon-karreprod.svg");
}

.tdn-partners-band__card-icon--tdn {
	-webkit-mask-image: url("../../images/partners/icons/icon-tdn.svg");
	mask-image: url("../../images/partners/icons/icon-tdn.svg");
}

.tdn-partners-band__card-icon--piano {
	-webkit-mask-image: url("../../images/partners/icons/icon-piano.svg");
	mask-image: url("../../images/partners/icons/icon-piano.svg");
}

/* ===== 9. Titre service =========================================== */
.tdn-partners-band__card-title {
	margin: 0;
	font-weight: var(--tdn-h2-weight);
	font-size: 24px;
	line-height: 1.2;
	color: var(--tdn-color-midnight-900, #1A1A2E);
	font-style: normal;
}

/* ===== 10. Mention groupe (pink-200 uppercase tracking 2px) ======= */
.tdn-partners-band__card-mention {
	margin: 0;
	font-weight: var(--tdn-eyebrow-weight);
	font-size: 16px;
	letter-spacing: var(--tdn-letter-spacing-wider);
	text-transform: uppercase;
	color: var(--tdn-color-pink-200, #C06D80);
	font-style: normal;
}

/* ===== 11. Description ============================================ */
.tdn-partners-band__card-description {
	margin: 0;
	font-weight: var(--tdn-font-weight-medium);
	font-size: 16px;
	line-height: 1.5;
	color: var(--tdn-color-neutral-700, #4D4D4C);
	font-style: normal;
}

/* ===== 12. Responsive <1024 (tablette : 2 cols, 3e card pleine largeur) === */
@media (max-width: 1023px) {
	.tdn-partners-band {
		padding: 80px 0 100px;
	}

	.tdn-partners-band__inner {
		padding: 0 32px;
	}

	.tdn-partners-band__intro {
		margin-bottom: 60px;
		font-size: 36px;
	}

	.tdn-partners-band__cards {
		grid-template-columns: 1fr 1fr;
	}

	.tdn-partners-band__card:last-child {
		grid-column: 1 / -1;
		max-width: 600px;
		justify-self: center;
	}
}

/* ===== 13. Responsive <768 (mobile — CAR0 carrousel horizontal) ====
 * Markup CAR0 : <section class="... gk-carousel"> avec .gk-carousel__viewport
 * sur .__cards et .gk-carousel__track wrap les cards. gk-carousel-mobile.css
 * pose le scroll-snap horizontal + nav arrows + indicators. Ici on neutralise
 * le grid desktop et on cale les variables CAR0 pour cette section. */
@media (max-width: 767px) {
	.tdn-partners-band {
		padding: 60px 0 80px;
	}

	.tdn-partners-band__inner {
		padding: 0;
	}

	.tdn-partners-band__intro {
		padding: 0 16px;
		font-size: 28px;
		line-height: 1.25;
	}

	/* Override grid 1col desktop → gk-carousel viewport flex row.
	 * scroll-padding-inline-start élevé à 40px (edge 16 + peek 24) pour rendre
	 * la card précédente partiellement visible à gauche dès la slide 2.
	 * padding-block-end: 32px pour englober le box-shadow card 0 14px 16px (= 30px
	 * sous la card) sans qu'il soit clippé par overflow-y: hidden du viewport. */
	.tdn-partners-band__cards.gk-carousel__viewport {
		display: flex;
		grid-template-columns: none;
		flex-direction: row;
		gap: var(--gk-carousel-gap);
		align-items: stretch;
		scroll-padding-inline-start: 40px;
		padding-block-end: 32px;
	}

	/* Variables CAR0 spécifiques (peek symétrique 24px gauche + droite).
	 * Formule : viewport(100vw) = peek_gauche(24) + gap(16) + card + gap(16) + peek_droite(24)
	 * → card = 100vw - 80. Combiné à scroll-padding-inline-start: 40px (cf. viewport).
	 * Dot color override : default = pink-100 = couleur identique au bg section → invisible.
	 * Forcé à midnight 30% opacity pour contraste discret mais lisible sur fond pink-100. */
	.tdn-partners-band.gk-carousel {
		--gk-carousel-card-width: calc(100vw - 80px);
		--gk-carousel-gap: 16px;
		--gk-carousel-peek: 24px;
		--gk-carousel-arrow-color: var(--tdn-color-midnight-900, #1A1A2E);
		--gk-carousel-dot-color: rgba(26, 26, 46, 0.3);
	}

	/* Reset grid-column desktop sur dernière card (centrage 2+1) */
	.tdn-partners-band__card:last-child {
		grid-column: auto;
		max-width: none;
		justify-self: auto;
	}

	.tdn-partners-band__card-title {
		font-size: 20px;
	}

	.tdn-partners-band__card-photo {
		height: 200px;
	}

	/* iOS : bloquer tap preview sur photo */
	.tdn-partners-band__card-photo {
		pointer-events: none;
		-webkit-touch-callout: none;
		-webkit-user-select: none;
		user-select: none;
	}

	.tdn-partners-band__card {
		-webkit-tap-highlight-color: transparent;
	}

	/* Indicators : hitbox compactée 28×28 + gap 0 (resserrer 3 dots). */
	.tdn-partners-band .gk-carousel__indicators {
		gap: 0;
	}

	.tdn-partners-band .gk-carousel__dot {
		width: 28px;
		height: 28px;
	}
}

/* ===== 14. Ajouts défensifs ======================================= */
.tdn-partners-band,
.tdn-partners-band__intro,
.tdn-partners-band__card-title,
.tdn-partners-band__card-mention,
.tdn-partners-band__card-description {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
