/* ==========================================================================
   Vox Populi — intégration maquette 1920px en flux normal (flex/grid).
   Position absolue réservée aux décors et chevauchements réels :
   logo suspendu, chip citation, collage des étapes, photos en débord.
   Espacements repris des cotes de la maquette.
   ========================================================================== */

:root {
	--navy: #293C54;
	--dark: #061316;
	--cyan: #38A6C2;
	--cyan-light: #9CE3FF;
	--white: #FEFEFE;
	--grad-cyan: linear-gradient(180deg, #38A6C2, #9CE3FF);
	--grad-cyan-2: linear-gradient(180deg, #38A6C2, #9CE3FF);
}

html, body {
	margin: 0;
	padding: 0;
}
body.vp-home {
	font-family: 'Manrope', sans-serif;
	background: var(--navy);
}
.vp-home * { box-sizing: border-box; }
.vp-home p { margin: 0; }
.vp-home a { text-decoration: none; }
.vp-home img { max-width: 100%; }
.vp-strong { font-weight: 700; }

/* Conteneur 1280 centré */
.vp-wrap {
	position: relative;
	max-width: 1280px;
	margin: 0 auto;
}
.vp-section { position: relative; overflow: hidden; }

/* Titres de section : 40px, partie 2 en dégradé cyan */
.vp-title {
	margin: 0;
	font: 800 40px/52px 'Manrope', sans-serif;
}
.vp-cyan { color: var(--cyan); }
.vp-cyan-light { color: var(--cyan-light); }
.vp-grad {
	background: var(--grad-cyan);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

/* Boutons pilule */
.vp-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 28px;
	border-radius: 999px;
	font: 800 13px/16px 'Manrope', sans-serif;
	letter-spacing: .4px;
	text-transform: uppercase;
	text-align: center;
	color: var(--white);
	background: var(--cyan);
	cursor: pointer;
	border: 0;
}
.vp-btn-ghost { background: rgba(254, 254, 254, .25); }
.vp-btn-white { background: var(--white); color: var(--cyan); }

/* Encart citation navy (chip, cartes, étapes) */
.vp-quote-box {
	padding: 16px 24px;
	border-radius: 16px;
	background: var(--navy);
	box-shadow: -1px 2px 6px rgba(0, 0, 0, .10);
	text-align: right;
	color: var(--white);
}
.vp-quote-box .vp-quote { font: 400 18px/22px 'Manrope', sans-serif; }
.vp-quote-box .vp-author { font: 400 16px/20px 'Manrope', sans-serif; margin-top: 4px; }

/* ==========================================================================
   HEADER — barre blanche 84px, logo suspendu (chevauchement réel → absolu)
   ========================================================================== */
.vp-header {
	position: relative;
	background: var(--white);
	box-shadow: 0 9px 20px rgba(0, 0, 0, .10);
	z-index: 50;
}
.vp-header .vp-wrap {
	display: flex;
	align-items: center;
	height: 84px;
}
.vp-logo {
	position: absolute;
	top: 0;
	left: 0;
	width: 184px;
	z-index: 5;
}
.vp-logo img {
	display: block;
	width: 184px;
	height: 150px;
	border-radius: 0 0 16px 16px;
	box-shadow: 0 9px 20px rgba(0, 0, 0, .08);
}
.vp-nav {
	display: flex;
	gap: 24px;
	margin-left: auto;
	white-space: nowrap;
}
.vp-nav a {
	font: 400 16px/22px 'Manrope', sans-serif;
	color: var(--navy);
}
.vp-phone {
	margin-left: 56px;
	padding: 10px 24px;
	border-radius: 999px;
	background: #D8ECF4;
	font: 700 16px/20px 'Manrope', sans-serif;
	color: var(--navy);
	white-space: nowrap;
}
.vp-cta {
	margin-left: 24px;
	padding: 13px 30px;
	border-radius: 999px;
	background: linear-gradient(90deg, #2E96B3, #3FAECB);
	font: 800 15px/18px 'Manrope', sans-serif;
	letter-spacing: .3px;
	color: var(--white);
	white-space: nowrap;
box-shadow: 0 13px 4px 0 rgba(0, 0, 0, 0.00), 0 8px 3px 0 rgba(0, 0, 0, 0.01), 0 5px 3px 0 rgba(0, 0, 0, 0.05), 0 2px 2px 0 rgba(0, 0, 0, 0.09), 0 1px 1px 0 rgba(0, 0, 0, 0.10);
}

/* ==========================================================================
   HERO — fond maquette (zone texte nettoyée au médian), contenu colonne droite
   ========================================================================== */
.vp-hero {
	min-height: 996px;
	background: var(--navy) url(img/hero-bg.jpg) no-repeat top center;
	background-size: 1920px 996px;
}
.vp-hero-content {
	width: 636px;
	margin-left: 644px;
	padding: 254px 0 60px;
}
.vp-hero-title1 {
	margin: 0;
	font: 800 56px/56px 'Manrope', sans-serif;
	color: var(--white);

}

@media only screen and (min-width: 1000px) {
.vp-hero-title1 {

	    max-width: 475px;
}
}
.vp-hero-title2 { font: 700 118px/124px 'Manrope', sans-serif; }
.vp-hero-content p {
	margin-top: 16px;
	font: 400 16px/26px 'Poppins', sans-serif;
	color: var(--white);
}
.vp-hero-btns {
	display: flex;
	gap: 16px;
	margin-top: 14px;
}
.vp-hero-btns .vp-btn { min-width: 268px; }
.vp-hero-visual { display: none; }

/* ==========================================================================
   BANDES NAVY — texture vagues (asset maquette, sans texte)
   ========================================================================== */
.vp-band {
	background: #22354F url(img/waves-bg.jpg) no-repeat center;
	background-size: cover;
}
.vp-band-a { padding-bottom: 150px; }
.vp-band-b { padding: 0 0 150px; }

/* --- Carte 22 ans : photo gauche, texte droite, chip en chevauchement --- */
.vp-card22 {
	position: relative;
	display: grid;
	grid-template-columns: 636px 1fr;
	min-height: 560px;
	background: var(--white);
	border-radius: 24px;
	overflow: hidden;
	box-shadow: 0 17px 37px rgba(0, 0, 0, .10);
}
.vp-card22-photo {
	width: 636px;
	height: 100%;
	min-height: 560px;
	object-fit: cover;
}
.vp-chip22 {
	position: absolute;
	top: 78px;
	    left: 19%;
	width: 252px;
}
.vp-card22-body { padding: 70px; }
.vp-t22 {
	margin: 0;
	font: 800 40px/49px 'Manrope', sans-serif;
	color: var(--navy);
}
.vp-card22-body p {
	margin-top: 26px;
	font: 400 16px/26px 'Manrope', sans-serif;
	color: var(--dark);
}

/* --- Choisir Vox Populi --- */
.vp-tchoisir {
	margin: 150px 0 0;
	text-align: center;
	font: 800 40px/52px 'Manrope', sans-serif;
	color: var(--white);
}
.vp-glass-grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	row-gap: 24px;
	margin-top: 28px;
}
.vp-glass {
	display: flex;
	align-items: flex-start;
	width: 410px;
	min-height: 222px;
	padding: 40px;
	border-radius: 16px;
	background: linear-gradient(180deg, rgba(254, 254, 254, .10), rgba(254, 254, 254, .30));
	color: var(--white);
}
.vp-glass:nth-child(n+4) { width: 628px; min-height: 210px; }
.vp-glass .vp-num {
	flex: none;
	margin-top: 8px;
	font: 400 130px/110px 'Manrope', sans-serif;
}
.vp-glass-body { margin-left: 16px; }
.vp-glass h3 { margin: 0 0 10px; font: 500 18px/22px 'Manrope', sans-serif; }
.vp-glass p { font: 400 16px/24px 'Helvetica Neue', 'Manrope', sans-serif; }

/* ==========================================================================
   CANDIDAT / ÉLU — deux cartes côte à côte
   ========================================================================== */
.vp-duo {
	display: flex;
	gap: 24px;
	align-items: stretch;
}
.vp-card-cand, .vp-card-elu {
	flex: 1;
	min-width: 0;
	border-radius: 16px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

/* Candidat : photo en fond haut + dégradé teal, titre sur la photo */
.vp-card-cand {
	position: relative;
	background: linear-gradient(180deg, #38A6C2 505px, #293C54 800px, #11233A 100%);
}
.vp-card-cand > .vp-card-photo {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 505px;
	object-fit: cover;
}
.vp-card-cand::before {
	/* fondu photo → teal */
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 505px;
	background: linear-gradient(180deg, rgba(56, 166, 194, 0) 60%, #38A6C2 100%);
}
.vp-card-cand .vp-card-body {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 300px 80px 70px;
}
.vp-card-cand h2 {
	margin: 0;
	font: 800 42px/50px 'Manrope', sans-serif;
	color: var(--dark);
}
.vp-card-cand .vp-card-body > p {
	margin-top: 26px;
	font: 400 16px/26px 'Manrope', sans-serif;
	color: var(--white);
}
.vp-card-cand .vp-quote-box { margin-top: 26px; }
.vp-card-cand .vp-btn {
	margin: 32px auto 0;
	max-width: 320px;
}

/* Élu : carte blanche, photo en haut */
.vp-card-elu { background: var(--white); }
.vp-card-elu > .vp-card-photo {
	width: 100%;
	height: 505px;
	object-fit: cover;
}
.vp-card-elu .vp-card-body {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 14px 80px 56px;
}
.vp-card-elu h2 {
	margin: 0;
	font: 800 40px/49px 'Manrope', sans-serif;
	color: var(--dark);
}
.vp-card-elu .vp-card-body > p {
	margin-top: 26px;
	font: 400 16px/26px 'Manrope', sans-serif;
	color: var(--dark);
}
.vp-card-elu .vp-btn { margin: 32px auto 0; min-width: 265px; }

/* ==========================================================================
   CE QUE L'ON CONSTRUIT ENSEMBLE — fond gris + ruban drapeau en décor
   ========================================================================== */
.vp-construit-flag {
	position: absolute;
	top: 0;
	left: calc(50% + 140px);
	width: 820px;
	pointer-events: none;
	-webkit-mask-image: linear-gradient(180deg, #000 55%, transparent 95%), linear-gradient(90deg, transparent 0, #000 18%);
	-webkit-mask-composite: source-in;
	mask-image: linear-gradient(180deg, #000 55%, transparent 95%), linear-gradient(90deg, transparent 0, #000 18%);
	mask-composite: intersect;
}
.vp-construit {
	padding: 150px 0;
	background: #DDDDDD;
}
.vp-tco { width: 626px; color: var(--navy); }
.vp-tco-intro {
	width: 626px;
	font: 400 16px/26px 'Manrope', sans-serif;
	color: var(--dark);
}

.vp-exp-grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 46px 24px;
	margin-top: 6px;
}
.vp-exp-full { grid-column: 1 / -1; }

.vp-exp-head {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	gap: 24px;
	min-height: 128px;
	padding: 24px 40px;
	border-radius: 16px;
	background: var(--navy);
	box-shadow: 0 3px 6px rgba(0, 0, 0, .10);
}
.vp-exp-full .vp-exp-head { padding-left: 286px; }
.vp-exp-head img { height: 80px; width: auto; }
.vp-exp-head h3 {
	margin: 0;
	font: 800 32px/38px 'Manrope', sans-serif;
	color: var(--white);
}
.vp-exp-body {
	position: relative;
	z-index: 1;
	margin-top: -40px;
	padding: 120px 40px 40px;
	border-radius: 16px;
	background: var(--white);
}
.vp-exp-body > p, .vp-exp-col > p {
	font: 400 16px/26px 'Helvetica Neue', 'Manrope', sans-serif;
	color: var(--dark);
}
.vp-exp-body > p + p { margin-top: 26px; }
.vp-exp-points { margin-top: 26px; }
.vp-exp-points p {
	margin-bottom: 10px;
	font: 400 16px/26px 'Helvetica Neue', 'Manrope', sans-serif;
	color: var(--dark);
}
.vp-obtenez {
	margin-top: 26px;
	padding: 16px 24px;
	border-radius: 24px;
	background: rgba(56, 166, 194, .20);
	color: var(--dark);
}
.vp-obtenez h4 { margin: 0; font: 700 18px/23px 'Manrope', sans-serif; }
.vp-obtenez p { margin-top: 8px; font: 400 16px/22px 'Helvetica Neue', 'Manrope', sans-serif; }
.vp-exp-body .vp-quote-box { margin-top: 26px; }

/* Formation : 2 colonnes texte / photo */
.vp-exp-cols {
	display: grid;
	grid-template-columns: 1fr 560px;
	gap: 80px;
	align-items: start;
}
.vp-exp-photo {
	width: 560px;
	height: 536px;
	object-fit: cover;
	border-radius: 16px;
}

/* ==========================================================================
   SCRUTINS — fond sombre, photo en débord à droite
   ========================================================================== */
.vp-scrutins {
	position: relative;
	background: var(--dark);
}
.vp-scrutins-photo {
	position: absolute;
	top: 0;
	bottom: 0;
	left: calc(50% + 18px);
	width: 942px;
	max-width: 49vw;
	height: 100%;
	object-fit: cover;
}
.vp-scrutins-content {
	width: 553px;
	padding: 146px 0 110px;
	color: var(--white);
}
.vp-scrutins-content .vp-title { color: var(--white); }
.vp-scrutins-content > p {
	margin-top: 52px;
	font: 400 16px/26px 'Manrope', sans-serif;
}
.vp-scrutins-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin-top: 26px;
}
.vp-scrutin-chip {
	padding: 16px 24px;
	border-radius: 8px;
	background: rgba(56, 166, 194, .40);
	font: 400 18px/23px 'Manrope', sans-serif;
	white-space: nowrap;
}
.vp-scrutins-content .vp-btn { margin-top: 28px; }

/* ==========================================================================
   ÉTAPES — collage de cartes aligné sur les flèches du fond (absolu assumé)
   ========================================================================== */
.vp-etapes {
	min-height: 1362px;
	background: var(--cyan) url(img/etapes-bg.jpg) no-repeat top center;
	background-size: 1920px 1362px;
}
.vp-etapes-intro {
	width: 627px;
	padding-top: 146px;
}
.vp-etapes-intro .vp-title { color: var(--white); font: 800 40px/49px 'Manrope', sans-serif; }
.vp-etapes-intro .vp-navy { color: var(--navy); }
.vp-etapes-intro p {
	margin-top: 26px;
	font: 400 16px/26px 'Manrope', sans-serif;
	color: var(--white);
}
.vp-etapes-intro p.vp-strong { font-size: 18px; }
.vp-steps {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	pointer-events: none;
}
.vp-step { pointer-events: auto; }
.vp-step {
	position: absolute;
	padding: 40px;
	border-radius: 16px;
	background: var(--white);
	box-shadow: 0 3px 6px rgba(0, 0, 0, .10);
}
/* positions du collage (origine = haut de section, repères maquette) */
.vp-step-1 { top: 265px; left: 761px; width: 410px; }
.vp-step-2 { top: 468px; left: 0; width: 627px; }
.vp-step-3 { top: 907px; left: 327px; width: 410px; }
.vp-step-4 { top: 737px; left: 870px; width: 411px; }
.vp-step-badge {
	display: inline-flex;
	align-items: center;
	padding: 16px 24px;
	border-radius: 16px;
	background: var(--cyan);
	font: 800 32px/38px 'Manrope', sans-serif;
	color: var(--white);
}
.vp-step h3 {
	margin: 10px 0 0;
	font: 500 18px/27px 'Manrope', sans-serif;
	color: var(--dark);
}
.vp-step p {
	margin-top: 4px;
	font: 400 16px/22px 'Satoshi', 'Manrope', sans-serif;
	color: var(--dark);
}
.vp-step .vp-quote-box { margin-top: 20px; }

/* ==========================================================================
   QUAND PASSION — photo en débord droite + décor 3D en pied
   ========================================================================== */
.vp-passion {
	position: relative;
	min-height: 1088px;
	background: #FAFBFC;
}
.vp-passion-photo {
	position: absolute;
	top: 0;
	left: calc(50% - 79px);
	width: 1039px;
	max-width: 54vw;
	height: 778px;
	object-fit: cover;
	z-index: 2;
}
.vp-passion-strip {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 1920px;
	max-width: none;
	z-index: 1;
	pointer-events: none;
}
.vp-passion-content {
	position: relative;
	z-index: 3;
	width: 626px;
	padding: 146px 0 80px;
}
.vp-passion-content .vp-title { width: 585px; font: 800 40px/49px 'Manrope', sans-serif; color: var(--navy); }
.vp-passion-sub {
	margin-top: 26px;
	font: 400 18px/28px 'Manrope', sans-serif;
	color: var(--navy);
}
.vp-convictions { margin-top: 12px; }
.vp-conviction {
	margin-top: 16px;
	padding: 16px 24px;
	border-radius: 8px;
	background: rgba(56, 166, 194, .20);
	font: 400 16px/22px 'Manrope', sans-serif;
	color: var(--navy);
}
.vp-passion-content > p {
	margin-top: 26px;
	font: 400 16px/26px 'Manrope', sans-serif;
	color: var(--navy);
}
.vp-passion-content > p.vp-strong { font-size: 18px; }

/* ==========================================================================
   FAQ — texture claire + galets 3D
   ========================================================================== */
.vp-faq {
	position: relative;
	padding: 150px 0 140px;
	background: var(--white) url(img/faq-bg.jpg) no-repeat center;
	background-size: cover;
}
.vp-faq-stones {
	position: absolute;
	right: -46px;
	bottom: 0;
	width: 499px;
	pointer-events: none;
}
.vp-tfaq { text-align: center; color: var(--dark); }
.vp-faq-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 54px 80px;
	margin-top: 84px;
	position: relative;
	z-index: 1;
}
.vp-faq-item { position: relative; padding-right: 56px; }
.vp-faq-item h3 {
	margin: 0;
	max-width: 544px;
	font: 500 32px/38px 'Manrope', sans-serif;
	color: var(--dark);
}
.vp-faq-chevron {
	position: absolute;
	top: 0;
	right: 0;
	width: 32px;
	height: 32px;
}
.vp-faq-item p {
	margin-top: 8px;
	font: 400 16px/22px 'Satoshi', 'Manrope', sans-serif;
	color: var(--dark);
}

/* ==========================================================================
   CONTACT — fond lattes sombres, carte logo + formulaire
   ========================================================================== */
.vp-contact {
	padding: 150px 0 90px;
	background: var(--dark) url(img/contact-bg.jpg) no-repeat center;
	background-size: cover;
}
.vp-contact-grid {
	display: grid;
	grid-template-columns: 419px 1fr;
	gap: 136px;
	align-items: start;
}
.vp-contact-card {
	padding: 20px 40px 40px;
	border-radius: 16px;
	background: var(--white);
}
.vp-contact-logo {
	display: block;
	width: 100%;
	height: auto;
	margin: 0 auto;
}
.vp-contact-rows { margin-top: 16px; }
.vp-contact-row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 8px;
	font: 400 18px/24px 'Manrope', sans-serif;
	color: var(--navy);
}
.vp-contact-main { color: var(--white); }
.vp-contact-main .vp-title {
	text-align: center;
	color: var(--white);
	font: 800 40px/49px 'Manrope', sans-serif;
}
.vp-contact-sub {
	margin-top: 3px;
	text-align: center;
	font: 700 18px/26px 'Manrope', sans-serif;
}
.vp-contact-sub2 {
	margin-top: 5px;
	text-align: center;
	font: 400 16px/24px 'Manrope', sans-serif;
}

.vp-form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px 24px;
	margin-top: 28px;
}
.vp-form input[type="text"],
.vp-form input[type="email"],
.vp-form input[type="tel"],
.vp-form textarea,
.vp-form .vp-form-fake {
	width: 100%;
	height: 38px;
	padding: 8px 16px;
	border: 0;
	border-radius: 8px;
	background: var(--white);
	font: 400 16px/22px 'Satoshi', 'Manrope', sans-serif;
	color: var(--navy);
}
.vp-form ::placeholder { color: var(--navy); opacity: 1; }
.vp-form .vp-form-fake {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 40px;
}
.vp-form .vp-f-value {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-weight: 700;
	color: var(--cyan);
}
.vp-form .vp-form-fake select,
.vp-form .vp-form-fake input[type="date"] {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: pointer;
}
.vp-situation {
	grid-column: 1 / -1;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px 24px;
	font: 400 16px/22px 'Satoshi', 'Manrope', sans-serif;
	color: var(--white);
}
.vp-radio {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
}
.vp-radio input {
	appearance: none;
	width: 16px;
	height: 16px;
	margin: 0;
	border-radius: 50%;
	background: var(--white);
	cursor: pointer;
}
.vp-radio input:checked { box-shadow: inset 0 0 0 4px var(--cyan); }
.vp-form textarea {
	grid-column: 1 / -1;
	height: 153px;
	resize: none;
}
.vp-form .vp-btn {
	grid-column: 1 / -1;
	justify-self: center;
	min-width: 250px;
	margin-top: 8px;
}

/* Fallback pages standards */
.vp-fallback { max-width: 800px; margin: 60px auto; padding: 0 20px; font-family: 'Manrope', sans-serif; color: var(--dark); }

/* ==========================================================================
   RESPONSIVE — tablette (≤1279px)
   ========================================================================== */
@media (max-width: 1279px) {
	.vp-wrap { max-width: 720px; padding: 0 24px; }

	/* Header : flux, logo réduit */
	.vp-header .vp-wrap { height: auto; padding: 12px 24px; flex-wrap: wrap; gap: 14px; }
	.vp-logo { position: static; width: 90px; }
	.vp-logo img { width: 90px; height: 73px; border-radius: 0 0 10px 10px; box-shadow: none; }
	.vp-phone { margin-left: auto; padding: 8px 18px; }
	.vp-cta { padding: 10px 22px; font-size: 13px; }
	.vp-nav { order: 5; width: 100%; gap: 18px; margin: 0; }

	/* Hero */
	.vp-hero { min-height: 0; background-size: cover; }
	.vp-hero-content { width: auto; margin: 0; padding: 56px 0 64px; }
	.vp-hero-title1 { font-size: 42px; line-height: 1.15; }
	.vp-hero-title2 { font-size: 72px; line-height: 1.1; }
	.vp-hero-btns { flex-wrap: wrap; }
	.vp-hero-btns .vp-btn { min-width: 0; }
	.vp-hero-visual { display: block; width: 100%; max-width: 440px; margin: 36px auto 0; border-radius: 16px; }

	/* 22 ans */
	.vp-band-a { padding: 56px 0 64px; }
	.vp-card22 { display: block; min-height: 0; }
	.vp-card22-photo { width: 100%; height: 280px; min-height: 0; }
	.vp-chip22 { position: relative; top: auto; left: auto; width: auto; max-width: 280px; margin: -40px 20px 0 auto; }
	.vp-card22-body { padding: 24px 32px 40px; }
	.vp-t22 { font-size: 30px; line-height: 1.25; }
	.vp-tchoisir { margin-top: 56px; font-size: 30px; line-height: 1.3; }
	.vp-glass, .vp-glass:nth-child(n+4) { width: 100%; min-height: 0; padding: 28px; }
	.vp-glass .vp-num { font-size: 80px; line-height: 70px; margin-top: 0; }

	/* Candidat / Élu */
	.vp-band-b { padding: 56px 0 64px; }
	.vp-duo { flex-direction: column; gap: 32px; }
	.vp-card-cand { background: linear-gradient(180deg, #38A6C2 300px, #293C54 70%, #11233A 100%); }
	.vp-card-cand > .vp-card-photo, .vp-card-cand::before { height: 300px; }
	.vp-card-cand .vp-card-body { padding: 320px 32px 40px; }
	.vp-card-cand h2 { font-size: 30px; line-height: 1.25; color: var(--white); }
	.vp-card-elu > .vp-card-photo { height: 300px; }
	.vp-card-elu .vp-card-body { padding: 8px 32px 40px; }
	.vp-card-elu h2 { margin-top: 16px; font-size: 30px; line-height: 1.25; }

	/* Construit */
	.vp-construit { padding: 56px 0 64px; }
	.vp-construit-flag { display: none; }
	.vp-tco, .vp-tco-intro { width: auto; }
	.vp-tco { font-size: 30px; line-height: 1.25; }
	.vp-tco-intro { margin-top: 16px; }
	.vp-exp-grid { grid-template-columns: 1fr; gap: 36px; margin-top: 40px; }
	.vp-exp-head { min-height: 0; padding: 18px 24px; gap: 18px; }
	.vp-exp-full .vp-exp-head { padding-left: 24px; }
	.vp-exp-head img { height: 56px; }
	.vp-exp-head h3 { font-size: 22px; line-height: 1.2; }
	.vp-exp-body { padding: 64px 28px 28px; }
	.vp-exp-cols { grid-template-columns: 1fr; gap: 24px; }
	.vp-exp-photo { width: 100%; height: auto; }

	/* Scrutins */
	.vp-scrutins-photo { position: static; display: block; width: 100%; max-width: none; height: 320px; }
	.vp-scrutins-content { width: auto; padding: 56px 0 64px; }
	.vp-scrutins-content .vp-title { font-size: 30px; line-height: 1.3; }
	.vp-scrutins-content > p { margin-top: 20px; }

	/* Étapes : empilées dans l'ordre */
	.vp-etapes { min-height: 0; padding: 56px 0 64px; background: var(--cyan); }
	.vp-etapes-intro { width: auto; padding-top: 0; }
	.vp-etapes-intro .vp-title { font-size: 30px; line-height: 1.25; }
	.vp-steps { position: static; width: auto; margin-top: 36px; display: flex; flex-direction: column; gap: 20px; }
	.vp-step { position: static; width: auto !important; padding: 28px; }

	/* Passion */
	.vp-passion { min-height: 0; }
	.vp-passion-photo { position: static; display: block; width: 100%; max-width: none; height: 320px; }
	.vp-passion-strip { display: none; }
	.vp-passion-content { width: auto; padding: 56px 0 48px; }
	.vp-passion-content .vp-title { width: auto; font-size: 30px; line-height: 1.25; }

	/* FAQ */
	.vp-faq { padding: 56px 0 48px; }
	.vp-faq-stones { display: none; }
	.vp-tfaq { text-align: left; font-size: 30px; line-height: 1.3; }
	.vp-faq-grid { grid-template-columns: 1fr; gap: 36px; margin-top: 32px; }
	.vp-faq-item h3 { font-size: 22px; line-height: 1.25; }

	/* Contact */
	.vp-contact { padding: 56px 0 64px; }
	.vp-contact-grid { grid-template-columns: 1fr; gap: 36px; }
	.vp-contact-card { max-width: 420px; }
	.vp-contact-main .vp-title, .vp-contact-sub, .vp-contact-sub2 { text-align: left; }
	.vp-contact-main .vp-title { font-size: 30px; line-height: 1.3; }
}

/* ==========================================================================
   RESPONSIVE — mobile (≤767px)
   ========================================================================== */
@media (max-width: 767px) {
	.vp-wrap { padding: 0 20px; }

	/* Header compact : menu masqué (ancres dans la page) */
	.vp-nav { display: none; }
	.vp-header .vp-wrap { padding: 10px 16px; }
	.vp-logo { width: 72px; }
	.vp-logo img { width: 72px; height: 59px; }
	.vp-phone { padding: 8px 14px; font-size: 14px; }
	.vp-cta { padding: 9px 16px; font-size: 12px; }

	.vp-hero-title1 { font-size: 32px; }
	.vp-hero-title2 { font-size: 48px; }

	.vp-t22, .vp-tchoisir, .vp-tco, .vp-scrutins-content .vp-title,
	.vp-etapes-intro .vp-title, .vp-passion-content .vp-title,
	.vp-tfaq, .vp-contact-main .vp-title,
	.vp-card-cand h2, .vp-card-elu h2 { font-size: 25px; }

	.vp-glass { display: block; }
	.vp-glass .vp-num { display: block; font-size: 60px; line-height: 56px; margin-bottom: 8px; }
	.vp-glass-body { margin-left: 0; }

	.vp-card22-body, .vp-card-cand .vp-card-body, .vp-card-elu .vp-card-body { padding-left: 20px; padding-right: 20px; }
	.vp-card-cand .vp-card-body { padding-top: 320px; }

	.vp-exp-head h3 { font-size: 18px; }
	.vp-exp-head img { height: 44px; }
	.vp-exp-body { padding: 56px 20px 20px; }

	.vp-scrutins-chips { flex-direction: column; align-items: stretch; }
	.vp-scrutin-chip { white-space: normal; text-align: left; }

	.vp-faq-item h3 { font-size: 19px; }

	.vp-form { grid-template-columns: 1fr; }
	.vp-situation { align-items: flex-start; flex-direction: column; }
}




/* ==========================================================================
   MDOFIS 4/06/26
   ========================================================================== */
.gradient-photo {
  position: relative; /* Nécessaire pour le pseudo-élément */
  overflow: hidden;   /* Cache le débordement du gradient */
	margin-bottom: 0px!important;
}
.gradient-photo::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 23%;
    height: 100%;
    background: linear-gradient(to left, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
}

.vp-card22-body {
	    position: relative;
    left: -14%;
}

.vp-card22-body:before {
	content: "";
	width: 25px;
	height: 20px;
	background: #9CE3FF;
	display: block;
	    position: absolute;
    left: 1%;
}

.vp-glass {
	position: relative;
}


.vp-glass:before {
	top: 0;
	right: 0;
	width: 30%;
	height: 60%;
	border-top: 1px solid rgba(255,255,255,0.6);
	border-right: 1px solid rgba(255,255,255,0.6);
	mask-image: linear-gradient(to left, black 70%, transparent),
		linear-gradient(to bottom, black 70%, transparent);
	mask-composite: intersect;
	-webkit-mask-composite: source-in;
	border-radius: 0px 10px 0px 0px;
	content: "";
	position: absolute;
}

