/* ═══════════════════════════════════════════════════════════════════════════
   Template ROMANTIQUE — Élégance classique de la haute couture.
   Inspirations : Carolina Herrera, dentelle Chantilly, bougies, pivoines
   Effets : ornements floraux SVG, animations reveal, drop cap doré
   ═══════════════════════════════════════════════════════════════════════════ */

.wpm--romantique {
	background:
		radial-gradient(ellipse 1200px 600px at 50% -200px, color-mix(in srgb, var(--wpm-primary) 12%, transparent) 0%, transparent 60%),
		radial-gradient(ellipse 900px 500px at 50% calc(100% + 200px), color-mix(in srgb, var(--wpm-accent) 18%, transparent) 0%, transparent 60%),
		var(--wpm-surface);
}

/* ────── Sections : aérées, max-width 860px ────── */
.wpm--romantique > section {
	padding: 110px 24px;
	max-width: 860px;
	position: relative;
}
.wpm--romantique > section:first-child { padding: 0; max-width: none; }

/* ────── Titre de section : italique + ornement floral ────── */
.wpm--romantique .wpm-section-title {
	font-style: italic;
	font-weight: 400;
	letter-spacing: .015em;
	position: relative;
	padding-top: 38px;
}
/* Petit ornement SVG flower au-dessus de chaque titre */
.wpm--romantique .wpm-section-title::before {
	content: '';
	position: absolute;
	top: 0; left: 50%; transform: translateX(-50%);
	width: 26px; height: 26px;
	background:
		radial-gradient(circle, var(--wpm-primary) 0 4px, transparent 4px),
		radial-gradient(circle at 50% 0,   var(--wpm-primary) 0 3px, transparent 3px),
		radial-gradient(circle at 50% 100%, var(--wpm-primary) 0 3px, transparent 3px),
		radial-gradient(circle at 0% 50%,  var(--wpm-primary) 0 3px, transparent 3px),
		radial-gradient(circle at 100% 50%, var(--wpm-primary) 0 3px, transparent 3px);
	background-repeat: no-repeat;
	opacity: .55;
}
.wpm--romantique .wpm-section-title::after {
	width: 90px; height: 1px;
	background: linear-gradient(90deg, transparent, var(--wpm-primary) 40%, var(--wpm-primary) 60%, transparent);
	opacity: .8;
	margin-top: 18px;
}

/* ────── HERO : pleine page, prénoms en cascade, ornement encadrant ────── */
.wpm--romantique .wpm-hero {
	min-height: 100vh;
	position: relative;
}
.wpm--romantique .wpm-hero__overlay {
	background:
		radial-gradient(ellipse at 50% 40%, transparent 0%, rgba(0,0,0,.35) 70%, rgba(0,0,0,.65) 100%);
}
.wpm--romantique .wpm-hero__inner {
	position: relative;
	animation: wpm-fade-up 1.4s cubic-bezier(.2,.7,.2,1) both;
}
/* Cadre fin or autour du hero */
.wpm--romantique .wpm-hero__inner::before,
.wpm--romantique .wpm-hero__inner::after {
	content: '';
	position: absolute;
	border: 1px solid rgba(255, 255, 255, .35);
	width: 90px; height: 90px;
	pointer-events: none;
}
.wpm--romantique .wpm-hero__inner::before {
	top: -40px; left: -40px;
	border-right: 0; border-bottom: 0;
}
.wpm--romantique .wpm-hero__inner::after {
	bottom: -40px; right: -40px;
	border-left: 0; border-top: 0;
}
.wpm--romantique .wpm-hero__subtitle {
	font-size: .8rem;
	animation: wpm-letter-spacing 2s ease both;
}
.wpm--romantique .wpm-hero__subtitle::before,
.wpm--romantique .wpm-hero__subtitle::after {
	content: '◆'; margin: 0 14px; opacity: .55; font-size: .6em;
}
.wpm--romantique .wpm-hero__names {
	letter-spacing: .015em;
	gap: 0;
}
.wpm--romantique .wpm-hero__amp {
	font-family: var(--wpm-font-heading);
	font-style: italic;
	font-size: .68em;
	color: var(--wpm-accent);
	margin: -.1em 0;
	opacity: .95;
}
.wpm--romantique .wpm-hero__date {
	font-size: 1rem;
	letter-spacing: .25em;
}
.wpm--romantique .wpm-hero__date::before {
	content: '— '; opacity: .6;
}
.wpm--romantique .wpm-hero__date::after {
	content: ' —'; opacity: .6;
}

/* ────── COUNTDOWN : cartes en bas relief, ornement central ────── */
.wpm--romantique .wpm-countdown {
	background:
		linear-gradient(180deg, color-mix(in srgb, var(--wpm-accent) 50%, transparent), var(--wpm-accent)),
		var(--wpm-surface);
}
.wpm--romantique .wpm-countdown__grid > div {
	background: rgba(255, 255, 255, .55);
	border: 1px solid rgba(255, 255, 255, .8);
	border-radius: 100% / 18%;
	backdrop-filter: blur(8px);
	box-shadow:
		0 18px 36px -18px rgba(0,0,0,.18),
		inset 0 1px 0 rgba(255,255,255,.8);
}
.wpm--romantique .wpm-countdown__grid strong {
	background: linear-gradient(180deg, var(--wpm-ink) 0%, color-mix(in srgb, var(--wpm-ink) 60%, var(--wpm-primary)) 100%);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent;
}

/* ────── HISTOIRE : drop cap luxe + ornements latéraux ────── */
.wpm--romantique .wpm-histoire {
	position: relative;
}
.wpm--romantique .wpm-histoire::before,
.wpm--romantique .wpm-histoire::after {
	content: '';
	position: absolute;
	top: 50%; transform: translateY(-50%);
	width: 30px; height: 200px;
	opacity: .25;
	background: linear-gradient(180deg, transparent, var(--wpm-primary), transparent);
	mask: linear-gradient(180deg, transparent 0, #000 30%, #000 70%, transparent 100%);
}
.wpm--romantique .wpm-histoire::before { left: 5%; }
.wpm--romantique .wpm-histoire::after  { right: 5%; }
@media (max-width: 720px) {
	.wpm--romantique .wpm-histoire::before,
	.wpm--romantique .wpm-histoire::after { display: none; }
}
.wpm--romantique .wpm-histoire__body {
	font-family: var(--wpm-font-body);
	font-size: 1.12rem;
	line-height: 1.85;
	max-width: 640px;
}
.wpm--romantique .wpm-histoire__body p:first-child::first-letter {
	font-family: var(--wpm-font-heading);
	font-size: 4.4em;
	float: left;
	line-height: .85;
	margin: 8px 14px 0 0;
	color: var(--wpm-primary);
	font-style: italic;
	background: linear-gradient(180deg, var(--wpm-accent), var(--wpm-primary));
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent;
	text-shadow: 0 2px 24px color-mix(in srgb, var(--wpm-primary) 30%, transparent);
}

/* ────── CARDS : album photo arrondi avec hover lift ────── */
.wpm--romantique .wpm-lieu__step,
.wpm--romantique .wpm-menu__card,
.wpm--romantique .wpm-places__card,
.wpm--romantique .wpm-prestas__card,
.wpm--romantique .wpm-livre__msg {
	border-radius: 24px;
	transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s;
	overflow: hidden;
}
.wpm--romantique .wpm-lieu__step:hover,
.wpm--romantique .wpm-places__card:hover {
	transform: translateY(-6px);
	box-shadow: 0 32px 64px -32px color-mix(in srgb, var(--wpm-primary) 50%, transparent);
}
.wpm--romantique .wpm-lieu__step-type {
	background: linear-gradient(135deg, var(--wpm-primary), color-mix(in srgb, var(--wpm-primary) 70%, var(--wpm-accent)));
}

/* ────── GALERIE : grid asymétrique avec hover scale + or filter ────── */
.wpm--romantique .wpm-galerie__grid {
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 12px;
}
.wpm--romantique .wpm-galerie__item {
	border-radius: 18px;
	box-shadow: 0 8px 24px -16px rgba(0,0,0,.4);
}
.wpm--romantique .wpm-galerie__item::after {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.3));
	opacity: 0; transition: opacity .3s;
	pointer-events: none;
}
.wpm--romantique .wpm-galerie__item:hover::after { opacity: 1; }

/* ────── RSVP : CTA princier avec halo lumineux ────── */
.wpm--romantique .wpm-rsvp__cta {
	background: linear-gradient(135deg, var(--wpm-primary) 0%, color-mix(in srgb, var(--wpm-primary) 80%, var(--wpm-ink)) 100%);
	box-shadow:
		0 14px 32px -14px color-mix(in srgb, var(--wpm-primary) 70%, transparent),
		inset 0 1px 0 rgba(255,255,255,.2);
	position: relative;
	overflow: hidden;
	padding: 18px 40px;
}
.wpm--romantique .wpm-rsvp__cta::before {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%);
	background-size: 200% 100%;
	animation: wpm-shimmer 4s linear infinite;
	pointer-events: none;
}

/* ────── FOOTER : signature manuscrite ────── */
.wpm--romantique .wpm-footer {
	background: linear-gradient(180deg, var(--wpm-primary) 0%, color-mix(in srgb, var(--wpm-primary) 80%, #000) 100%);
}
.wpm--romantique .wpm-footer__love {
	font-size: 1.8rem; letter-spacing: .03em;
	font-style: italic;
}
.wpm--romantique .wpm-footer__love::before {
	content: '✦'; margin-right: 14px; opacity: .6; font-size: .7em;
}
.wpm--romantique .wpm-footer__love::after {
	content: '✦'; margin-left: 14px; opacity: .6; font-size: .7em;
}
