/* =============================================
   PORN FOR COUPLES V2 – Styles
   ============================================= */
.button_orange{
	margin: unset!important;
}
/* ── Première section : compenser le header ── */
.p4c_first_section {
	padding-top: 100px;
}

/* ── Eyebrow (réutilisé dans plusieurs sections) ── */
.p4c_eyebrow {
	font-size: 1.2rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: #F2E9E0;
	margin-bottom: 12px;
}

/* =============================================
   HERO – Image de fond + CTA
   ============================================= */
.p4c_hero {
	min-height: 700px;
	display: flex;
	align-items: center;
	position: relative;
	background-size: cover;
	background-position: center;
	overflow: hidden;
}
.p4c_hero_overlay {
	position: absolute;
	inset: 0;
	background: #0000007d;
	z-index: 1;
}
.p4c_hero_content {
	position: relative;
	z-index: 2;
	max-width: 1440px;
	width: 100%;
	margin: 0 auto;
	padding: 0 20px;
}
.p4c_hero_content h1,
.p4c_hero_content h2,
.p4c_hero_desc,
.p4c_hero_buttons,
.p4c_hero_content .p4c_eyebrow {
	max-width: 50%;
}
.p4c_hero_content h1,
.p4c_hero_content h2 {
	font-weight: 400;
	font-size: 5.2rem;
	color: #f2e9e0;
	margin-bottom: 15px;
	font-family: 'Recoleta';
	line-height: 1.1;
}
.p4c_hero_content h1{
	font-size: 8rem;
}
.p4c_hero_desc {
	font-size: 1.8rem;
	color: #F2E9E0;
	font-weight: 400;
	line-height: 1.3;
	margin-bottom: 32px;
}
.p4c_hero--center .p4c_hero_content {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	max-width: 1000px;
}
.p4c_hero--center .p4c_hero_content h1,
.p4c_hero--center .p4c_hero_content h2,
.p4c_hero--center .p4c_hero_desc,
.p4c_hero--center .p4c_hero_buttons,
.p4c_hero--center .p4c_hero_content .p4c_eyebrow {
	max-width: 100%;
}
.p4c_hero_buttons {
	display: flex;
	align-items: center;
	gap: 20px;
	margin-top: 10px;
}
.p4c_btn_outline {
	padding: 12px 24px;
	border: 1px solid #F2E9E0;
	border-radius: 100px;
	color: #F2E9E0;
	text-decoration: none;
	font-weight: 500;
	font-size: 1.8rem;
	transition: 0.3s;
}
.p4c_btn_outline:hover {
	background: rgba(255, 255, 255, 0.1);
}

/* =============================================
   TEXTE + IMAGE / VIDÉO
   ============================================= */
.p4c_texte_media {
	padding: 100px 0;
}
.p4c_texte_media > .wrapper {
	display: flex;
	align-items: stretch;
	gap: 60px;
}
.p4c_tm_text {
	flex: 1;
	padding: 100px 0 100px 60px;
}
.p4c_tm_media {
	flex: 1;

}
.p4c_tm_desc {
	font-size: 1.6rem;
	color: #F2E9E0;
	font-weight: 400;
	line-height: 1.3;
}
.p4c_tm_images img {
	border-radius: 20px;
	width: 100%;
	object-fit: cover;
	height: 100%;
	aspect-ratio: 1;
}
.p4c_tm_images--duo {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
.p4c_tm_images--duo img{
	aspect-ratio: unset;
	height: 440px;
	
}
.p4c_tm_images--duo img:first-child {
	transform: translateY(-40px);
}
.p4c_tm_images--duo img:last-child {
transform: translateY(40px);
}
.p4c_tm_video iframe {
	width: 100%;
	aspect-ratio: 16 / 9;
	border-radius: 20px;
	border: none;
}
.p4c_texte_media--reverse > .wrapper {
	flex-direction: row-reverse;
}
.p4c_texte_media--dark > .wrapper {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0.12) 100%);
	border-radius: 24px;
	overflow: hidden;
}
.p4c_texte_media--dark .p4c_tm_media {
	
}
.p4c_texte_media--dark.p4c_texte_media--reverse .p4c_tm_media {
	
}
.p4c_texte_media--dark .p4c_tm_images{
	display: flex;
	height: 100%;
	aspect-ratio: unset;
}
.p4c_texte_media--dark .p4c_tm_images img {
	border-radius: 0;
	height: 100%;
}
.p4c_texte_media--dark .p4c_tm_images--duo {
	gap: 0;
}
.p4c_texte_media--dark .p4c_tm_images--duo img {
	height: 440px;
}
.p4c_texte_media--dark .p4c_tm_images--duo img:first-child {
	transform: translateY(-30px);
}
.p4c_texte_media--dark .p4c_tm_images--duo img:last-child {
	transform: translateY(30px);
}

/* =============================================
   COLONNES ICÔNES
   ============================================= */
.p4c_colonnes_icones {
	padding: 80px 0;
}
.p4c_ci_list {
	display: flex;
	justify-content: space-between;
	gap: 40px;
}
.p4c_ci_item {
	flex: 1;
	text-align: center;
}
.p4c_ci_icon img {
	width: auto;
	height: 56px;
	margin-bottom: 16px;
	transition: filter 0.4s ease;
}
.p4c_ci_item:hover .p4c_ci_icon img {
	filter: drop-shadow(0 0 4px rgba(255, 255, 255, 1)) drop-shadow(0 0 4px rgba(255, 255, 255, 0.4)) drop-shadow(0 0 14px rgba(255, 255, 255, 1));

}
.p4c_ci_title {
	font-size: 2.4rem;
	color: #F2E9E0;
	font-weight: 400;
	font-family: 'Recoleta';
	margin-bottom: 10px;
}
.p4c_ci_desc {
	font-size: 1.4rem;
	font-weight: 400;
	color: #F2E9E0;
	line-height: 1.3;
}

/* =============================================
   OUR FORMATS GRILLE DE CARDS
   ============================================= */
.p4c_formats {
	padding: 80px 0;
}
.p4c_fg_grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
	margin-top: 40px;
}
.p4c_fg_card {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0.12) 100%);
	border-radius: 12px;
	overflow: hidden;
	transition: transform 0.3s;
}
.p4c_fg_card:hover {
	transform: translateY(-4px);
}
.p4c_fg_card_img img {
	width: 100%;
	height: 220px;
	object-fit: cover;
	display: block;
	border-radius: 12px;
}
.p4c_fg_card_body {
	padding: 16px;
}
.p4c_fg_card_body h3 {
	font-size: 3.2rem;
	color: #F2E9E0;
	font-family: 'Recoleta';
	font-weight: 400;
	margin-bottom: 10px;
}
.p4c_fg_card_desc {
	font-size: 1.4rem;
	color: #F2E9E0;
	font-weight: 400;
	line-height: 1.3;
	margin-bottom: 16px;
}
.p4c_fg_card_link {
	font-size: 1.4rem;
	color: #D6966F;
	text-decoration: none;
	font-weight: 500;
}
.p4c_fg_card_link:hover {
	text-decoration: underline;
}

/* =============================================
   IMAGE PLEINE LARGEUR
   ============================================= */
.p4c_full_image {
	margin: 80px 0;
}
.p4c_full_image img {
	width: 100%;
	display: block;
	object-fit: cover;
}

/* =============================================
   CTA SUBSCRIBE – Hero style
   Copié exactement depuis porn4couples.php
   ============================================= */
#couples_hero {
	overflow: hidden;
	position: relative;
}
#couples_hero > .wrapper {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	z-index: 10;
}
.couples_hero_eyebrow {
	display: inline-block;
	border: 1px solid #f2e9e0;
	border-radius: 999px;
	color: #f2e9e0;
	font-size: 1.2rem;
	font-weight: 500;
	letter-spacing: 0.15em;
	padding: 8px 24px;
	margin-bottom: 20px;
	text-transform: uppercase;
}
#couples_hero h1,
#couples_hero h2 {
	font-weight: 400;
	font-size: 8rem;
	color: #f2e9e0;
	margin-bottom: 15px;
	font-family: 'Recoleta';
}
.hero_catchphrase {
	font-size: 1.8rem;
	color: #F2E9E0;
	font-weight: 400;
	text-align: center;
	max-width: 600px;
	margin-bottom: 24px;
	line-height: 1.3;
}
.line_carusel {
	display: flex;
	gap: 12px;
	margin-bottom: 12px;
}
.line_carusel img {
	border-radius: 12px;
	height: 260px;
	object-fit: cover;
}
.grid_carusel_hero {
	position: relative;
}
.grid_carusel_hero .line_carusel:first-child {
	width: max-content;
	animation: scrollSecond 80s linear infinite;
	will-change: transform;
}
.grid_carusel_hero .line_carusel:nth-child(2) {
	width: max-content;
	animation: scrollThird 80s linear infinite;
	will-change: transform;
}
.grid_carusel_hero .line_carusel:last-child {
	width: max-content;
	animation: scrollSecond 80s linear infinite;
	will-change: transform;
}
.grid_carusel_hero:before {
	content: " ";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(360deg, #1F1E1D 8%, rgba(31, 30, 29, 0.4) 50%, #1F1E1D 100%);
	z-index: 9;
}

@keyframes scrollSecond {
	from { transform: translateX(0); }
	to { transform: translateX(-50%); }
}
@keyframes scrollThird {
	from { transform: translateX(-50%); }
	to { transform: translateX(0%); }
}

/* =============================================
   FAQ – ACCORDÉON
   ============================================= */
.p4c_faq {
	padding: 80px 0;
}
.p4c_faq .simple_title {
	text-align: center;
	margin-bottom: 40px;
}
.p4c_faq_list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}
.p4c_faq_item {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0.12) 100%);
	border-radius: 16px;
	padding: 24px 28px;
}
.p4c_faq_question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	cursor: pointer;
	font-size: 2rem;
	color: #F2E9E0;
	font-weight: 400;
	font-family: 'Recoleta';
	list-style: none;
}
.p4c_faq_question::-webkit-details-marker {
	display: none;
}
.p4c_faq_icon {
	width: 24px;
	height: 24px;
	position: relative;
	flex-shrink: 0;
	margin-left: 20px;
}
.p4c_faq_icon:before,
.p4c_faq_icon:after {
	content: "";
	position: absolute;
	background: #F2E9E0;
	transition: transform 0.3s;
}
.p4c_faq_icon:before {
	width: 24px;
	height: 2px;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
}
.p4c_faq_icon:after {
	width: 2px;
	height: 24px;
	left: 50%;
	top: 0;
	transform: translateX(-50%);
}
.p4c_faq_item[open] .p4c_faq_icon:after {
	transform: translateX(-50%) rotate(90deg);
	opacity: 0;
}
.p4c_faq_answer {
	font-size: 1.6rem;
	color: #F2E9E0;
	font-weight: 400;
	line-height: 1.3;
	padding-top: 16px;
}

/* =============================================
   RESPONSIVE
   ============================================= */
/* ── Tablet ── */
@media screen and (max-width: 1024px) {
	/* Hero */
	.p4c_hero_content h1,
	.p4c_hero_content h2,
	.p4c_hero_desc,
	.p4c_hero_buttons,
	.p4c_hero_content .p4c_eyebrow {
		max-width: 100%;
	}
	.p4c_hero_content h1 {
		font-size: 5rem;
	}
	.p4c_hero_content h2 {
		font-size: 4.2rem;
	}

	/* Texte + média : passe en colonne */
	.p4c_texte_media > .wrapper {
		flex-direction: column-reverse;
		gap: 40px;
	}
	.p4c_texte_media--reverse > .wrapper {
		flex-direction: column;
	}
	.p4c_tm_text {
		padding: 0;
	}
	/* Dark card : image reprend toute la largeur en dessous */
	.p4c_texte_media--dark > .wrapper {
		border-radius: 20px;
	}
	.p4c_texte_media--dark .p4c_tm_text {
		padding: 10px 30px 40px;
	}

	/* Colonnes icônes */
	.p4c_ci_list {
		flex-wrap: wrap;
	}
	.p4c_ci_item {
		flex: 0 0 45%;
	}

	/* Formats grille */
	.p4c_fg_grid {
		grid-template-columns: repeat(2, 1fr);
	}

	/* CTA Subscribe */
	#couples_hero h1,
	#couples_hero h2 {
		font-size: 5rem;
		padding-right: 20px;
		padding-left: 10px;
		line-height: 1.2;
	}
	#couples_hero .button_orange {
		font-size: 2rem;
		width: calc(100% - 49px);
	}
	.line_carusel img {
		height: 200px;
		max-width: 280px;
	}
}

/* ── Mobile ── */
@media screen and (max-width: 768px) {
	/* Première section */
	.p4c_first_section {
		padding-top: 80px;
	}

	/* Hero */
	.p4c_hero {
		min-height: 450px;
	}
	.p4c_hero[style*="--hero-bg-mobile"] {
		background-image: var(--hero-bg-mobile) !important;
	}
	.p4c_hero_content h1 {

	}
	.p4c_hero_content h2 {
		font-size: 3rem;
	}
	.p4c_hero_desc {
		font-size: 1.6rem;
	}
	.p4c_hero_buttons {
		flex-direction: column;
		width: 100%;
	}
	.p4c_hero_buttons .button_orange,
	.p4c_hero_buttons .p4c_btn_outline {
		width: 100%;
        box-sizing: border-box;
		text-align: center;
	}
	.p4c_eyebrow {
		font-size: 1.1rem;
	}

	/* Texte + média */
	.p4c_texte_media {
		padding: 60px 10px;
	}
	.p4c_texte_media > .wrapper {
		gap: 30px;
	}
	.p4c_texte_media--dark > .wrapper {
		border-radius: 16px;
		padding: 0;
	}
	.p4c_texte_media--dark .p4c_tm_text {
		padding: 0px 20px 30px;
	}
	/* Duo images : superposées avec décalage */
	.p4c_tm_images--duo {
		display: block;
		position: relative;
		width: 100%;
		height: 360px;
	}
	.p4c_tm_images--duo img {
		position: absolute;
		width: 70%;
		height: 280px;
		object-fit: cover;
	}
	.p4c_tm_images--duo img:first-child {
		top: 0;
		left: 0;
		transform: none;
		z-index: 1;
	}
	.p4c_tm_images--duo img:last-child {
		bottom: 0;
		right: 0;
		transform: none;
		z-index: 2;
	}
	.p4c_texte_media--dark .p4c_tm_images--duo img {
		height: 260px;
	}
	.p4c_texte_media--dark .p4c_tm_images--duo img:first-child,
	.p4c_texte_media--dark .p4c_tm_images--duo img:last-child {
		transform: none;
	}

	/* Colonnes icônes */
	.p4c_ci_item {
		flex: 0 0 100%;
	}
	.p4c_ci_item:hover .p4c_ci_icon img {
		filter: none;
	}

	/* Formats grille */
	.p4c_fg_grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.p4c_fg_card_body h3 {
		font-size: 2.4rem;
	}

	/* Image pleine largeur */
	.p4c_full_image {
		margin: 40px 0;
	}

	/* FAQ */
	.p4c_faq_list {
		grid-template-columns: 1fr;
		gap: 12px;
	}
	.p4c_faq_item {
		padding: 20px;
	}
	.p4c_faq_question {
		font-size: 1.8rem;
	}
	.p4c_faq_answer {
		font-size: 1.4rem;
	}

	/* CTA Subscribe */
	#couples_hero {
		text-align: center;
		margin-bottom: 40px;
	}
	#couples_hero h1,
	#couples_hero h2 {
		font-size: 3.6rem;
		padding: 0 15px;
		line-height: 1.2;
	}
	#couples_hero .button_orange {
		font-size: 1.8rem;
		width: calc(100% - 40px);
	}
	.hero_catchphrase {
		font-size: 1.6rem;
		padding: 0 15px;
	}
	.line_carusel img {
		height: 160px;
		max-width: 220px;
	}

	/* Sections padding */
	.p4c_colonnes_icones,
	.p4c_formats,
	.p4c_faq {
		padding: 50px 0;
	}
}
