@import url("https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,900");
@import url("https://fonts.googleapis.com/css?family=Great+Vibes|Playfair+Display:400,700");
@import url("fontawesome-all.min.css");

/*
	Aerial by HTML5 UP
	html5up.net | @ajlkn
	Free for personal and commercial use under the CCA 3.0 license (html5up.net/license)
*/

html, body, div, span, applet, object,
iframe, h1, h2, h3, h4, h5, h6, p, blockquote,
pre, a, abbr, acronym, address, big, cite,
code, del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var, b,
u, i, center, dl, dt, dd, ol, ul, li, fieldset,
form, label, legend, table, caption, tbody,
tfoot, thead, tr, th, td, article, aside,
canvas, details, embed, figure, figcaption,
footer, header, hgroup, menu, nav, output, ruby,
section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;}

body {
	line-height: 1;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

	blockquote:before, blockquote:after, q:before, q:after {
		content: '';
		content: none;
	}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

body {
	-webkit-text-size-adjust: none;
}

mark {
	background-color: transparent;
	color: inherit;
}

input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

input, select, textarea {
	-moz-appearance: none;
	-webkit-appearance: none;
	-ms-appearance: none;
	appearance: none;
}

/* Basic */

	html {
		box-sizing: border-box;
	}

	*, *:before, *:after {
		box-sizing: inherit;
	}

	body {
		background: #f8f8f8; /* Lighter background for luxury feel */
		overflow: hidden;
	}

		body.is-preload *, body.is-preload *:before, body.is-preload *:after {
			-moz-animation: none !important;
			-webkit-animation: none !important;
			-ms-animation: none !important;
			animation: none !important;
			-moz-transition: none !important;
			-webkit-transition: none !important;
			-ms-transition: none !important;
			transition: none !important;
		}

	body, input, select, textarea {
		color: #fff; /* Change text color to white */
		font-family: 'Playfair Display', serif; /* Change font to Playfair Display */
		font-size: 15pt;
		font-weight: 400 !important;
		letter-spacing: -0.025em;
		line-height: 1.75em;
	}

	a {
		-moz-transition: border-color 0.2s ease-in-out;
		-webkit-transition: border-color 0.2s ease-in-out;
		-ms-transition: border-color 0.2s ease-in-out;
		transition: border-color 0.2s ease-in-out;
		border-bottom: dotted 1px;
		color: inherit;
		outline: 0;
		text-decoration: none;
	}

		a:hover {
			border-color: transparent;
		}

/* Icon */

	.icon {
		text-decoration: none;
		position: relative;
	}

		.icon:before {
			-moz-osx-font-smoothing: grayscale;
			-webkit-font-smoothing: antialiased;
			display: inline-block;
			font-style: normal;
			font-variant: normal;
			text-rendering: auto;
			line-height: 1;
			text-transform: none !important;
			font-family: 'Font Awesome 5 Free';
			font-weight: 400;
		}

		.icon > .label {
			display: none;
		}

		.icon.solid:before {
			font-weight: 900;
		}

		.icon.brands:before {
			font-family: 'Font Awesome 5 Brands';
		}

/* Wrapper */

	@-moz-keyframes wrapper {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}

	@-webkit-keyframes wrapper {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}

	@-ms-keyframes wrapper {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}

	@keyframes wrapper {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}

	#wrapper {
		-moz-animation: wrapper 3s forwards;
		-webkit-animation: wrapper 3s forwards;
		-ms-animation: wrapper 3s forwards;
		animation: wrapper 3s forwards;
		height: 100%;
		left: 0;
		opacity: 0;
		position: fixed;
		top: 0;
		width: 100%;
	}

/* BG */

	#bg {
		-moz-animation: bg 15s linear infinite;
		-webkit-animation: bg 15s linear infinite;
		-ms-animation: bg 15s linear infinite;
		animation: bg 15s linear infinite;
		-moz-backface-visibility: hidden;
		-webkit-backface-visibility: hidden;
		-ms-backface-visibility: hidden;
		backface-visibility: hidden;
		-moz-transform: translate3d(0,0,0);
		-webkit-transform: translate3d(0,0,0);
		-ms-transform: translate3d(0,0,0);
		transform: translate3d(0,0,0);
	/* Set your background with this */

		background: #348cb2 url("images/bg.jpg") left 30%;
		background-repeat: repeat-x;
		height: 100%;
		left: 0;
		opacity: 1;
		position: fixed;
		top: 0;
	}

	@-moz-keyframes bg {
		0% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
		}

		100% {
			-moz-transform: translate3d(-2250px,0,0);
			-webkit-transform: translate3d(-2250px,0,0);
			-ms-transform: translate3d(-2250px,0,0);
			transform: translate3d(-2250px,0,0);
		}
	}

	@-webkit-keyframes bg {
		0% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
		}

		100% {
			-moz-transform: translate3d(-2250px,0,0);
			-webkit-transform: translate3d(-2250px,0,0);
			-ms-transform: translate3d(-2250px,0,0);
			transform: translate3d(-2250px,0,0);
		}
	}

	@-ms-keyframes bg {
		0% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
		}

		100% {
			-moz-transform: translate3d(-2250px,0,0);
			-webkit-transform: translate3d(-2250px,0,0);
			-ms-transform: translate3d(-2250px,0,0);
			transform: translate3d(-2250px,0,0);
		}
	}

	@keyframes bg {
		0% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
		}

		100% {
			-moz-transform: translate3d(-2250px,0,0);
			-webkit-transform: translate3d(-2250px,0,0);
			-ms-transform: translate3d(-2250px,0,0);
			transform: translate3d(-2250px,0,0);
		}
	}

	#bg {
		background-size: 2250px auto;
		width: 6750px;
	}

/* Overlay */

	@-moz-keyframes overlay {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}

	@-webkit-keyframes overlay {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}

	@-ms-keyframes overlay {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}

	@keyframes overlay {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}

	#overlay {
		-moz-animation: overlay 1.5s 1.5s forwards;
		-webkit-animation: overlay 1.5s 1.5s forwards;
		-ms-animation: overlay 1.5s 1.5s forwards;
		animation: overlay 1.5s 1.5s forwards;
		background-attachment: fixed, fixed;
		background-image: url("images/overlay-pattern.png"), url("images/overlay.svg");
		background-position: top left, center center;
		background-repeat: repeat, no-repeat;
		background-size: auto, cover;
		height: 100%;
		left: 0;
		opacity: 0;
		position: fixed;
		top: 0;
		width: 100%;
	}

/* Main */

	#main {
		height: 100%;
		left: 0;
		position: fixed;
		text-align: center;
		top: 0;
		width: 100%;
	}

		#main:before {
			content: '';
			display: inline-block;
			height: 100%;
			margin-right: 0;
			vertical-align: middle;
			width: 1px;
		}

/* Header */

	@-moz-keyframes header {
		0% {
			-moz-transform: translate3d(0,1em,0);
			-webkit-transform: translate3d(0,1em,0);
			-ms-transform: translate3d(0,1em,0);
			transform: translate3d(0,1em,0);
			opacity: 0;
		}

		100% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
			opacity: 1;
		}
	}

	@-webkit-keyframes header {
		0% {
			-moz-transform: translate3d(0,1em,0);
			-webkit-transform: translate3d(0,1em,0);
			-ms-transform: translate3d(0,1em,0);
			transform: translate3d(0,1em,0);
			opacity: 0;
		}

		100% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
			opacity: 1;
		}
	}

	@-ms-keyframes header {
		0% {
			-moz-transform: translate3d(0,1em,0);
			-webkit-transform: translate3d(0,1em,0);
			-ms-transform: translate3d(0,1em,0);
			transform: translate3d(0,1em,0);
			opacity: 0;
		}

		100% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
			opacity: 1;
		}
	}

	@keyframes header {
		0% {
			-moz-transform: translate3d(0,1em,0);
			-webkit-transform: translate3d(0,1em,0);
			-ms-transform: translate3d(0,1em,0);
			transform: translate3d(0,1em,0);
			opacity: 0;
		}

		100% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
			opacity: 1;
		}
	}

	@-moz-keyframes nav-icons {
		0% {
			-moz-transform: translate3d(0,1em,0);
			-webkit-transform: translate3d(0,1em,0);
			-ms-transform: translate3d(0,1em,0);
			transform: translate3d(0,1em,0);
			opacity: 0;
		}

		100% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
			opacity: 1;
		}
	}

	@-webkit-keyframes nav-icons {
		0% {
			-moz-transform: translate3d(0,1em,0);
			-webkit-transform: translate3d(0,1em,0);
			-ms-transform: translate3d(0,1em,0);
			transform: translate3d(0,1em,0);
			opacity: 0;
		}

		100% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
			opacity: 1;
		}
	}

	@-ms-keyframes nav-icons {
		0% {
			-moz-transform: translate3d(0,1em,0);
			-webkit-transform: translate3d(0,1em,0);
			-ms-transform: translate3d(0,1em,0);
			transform: translate3d(0,1em,0);
			opacity: 0;
		}

		100% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
			opacity: 1;
		}
	}

	@keyframes nav-icons {
		0% {
			-moz-transform: translate3d(0,1em,0);
			-webkit-transform: translate3d(0,1em,0);
			-ms-transform: translate3d(0,1em,0);
			transform: translate3d(0,1em,0);
			opacity: 0;
		}

		100% {
			-moz-transform: translate3d(0,0,0);
			-webkit-transform: translate3d(0,0,0);
			-ms-transform: translate3d(0,0,0);
			transform: translate3d(0,0,0);
			opacity: 1;
		}
	}

	#header {
		-moz-animation: header 1s 2.25s forwards;
		-webkit-animation: header 1s 2.25s forwards;
		-ms-animation: header 1s 2.25s forwards;
		animation: header 1s 2.25s forwards;
		-moz-backface-visibility: hidden;
		-webkit-backface-visibility: hidden;
		-ms-backface-visibility: hidden;
		backface-visibility: hidden;
		-moz-transform: translate3d(0,0,0);
		-webkit-transform: translate3d(0,0,0);
		-ms-transform: translate3d(0,0,0);
		transform: translate3d(0,0,0);
		cursor: default;
		display: inline-block;
		opacity: 0;
		position: relative;
		text-align: center;
		top: -1em;
		vertical-align: middle;
		width: 90%;
	}

		#header h1 {
			color: #fff; /* Change header text color to white */
			font-family: 'Great Vibes', cursive; /* Fancier font for the name */
			font-size: 4.5em; /* Slightly larger font size */
			font-weight: 700; /* Bold for emphasis */
			letter-spacing: -0.02em;
			line-height: 1em;
			color: #eeeae5; /* Gold color for luxury */
		}

		#header p {
			color: #fff; /* Change paragraph text color to white */
			font-size: 1.25em;
			margin: 0.75em 0 0.25em 0;
			opacity: 0.85; /* Slightly more opaque for readability */
		}

		#header nav {
			margin: 1.5em 0 0 0;
		}

			#header nav li {
				-moz-animation: nav-icons 0.5s ease-in-out forwards;
				-webkit-animation: nav-icons 0.5s ease-in-out forwards;
				-ms-animation: nav-icons 0.5s ease-in-out forwards;
				animation: nav-icons 0.5s ease-in-out forwards;
				-moz-backface-visibility: hidden;
				-webkit-backface-visibility: hidden;
				-ms-backface-visibility: hidden;
				backface-visibility: hidden;
				-moz-transform: translate3d(0,0,0);
				-webkit-transform: translate3d(0,0,0);
				-ms-transform: translate3d(0,0,0);
				transform: translate3d(0,0,0);
				display: inline-block;
				height: 5.35em;
				line-height: 5.885em;
				opacity: 0;
				position: relative;
				top: 0;
				width: 5.35em;
			}

				#header nav li:nth-child(1) {
					-moz-animation-delay: 2.5s;
					-webkit-animation-delay: 2.5s;
					-ms-animation-delay: 2.5s;
					animation-delay: 2.5s;
				}

				#header nav li:nth-child(2) {
					-moz-animation-delay: 2.75s;
					-webkit-animation-delay: 2.75s;
					-ms-animation-delay: 2.75s;
					animation-delay: 2.75s;
				}

				#header nav li:nth-child(3) {
					-moz-animation-delay: 3s;
					-webkit-animation-delay: 3s;
					-ms-animation-delay: 3s;
					animation-delay: 3s;
				}

				#header nav li:nth-child(4) {
					-moz-animation-delay: 3.25s;
					-webkit-animation-delay: 3.25s;
					-ms-animation-delay: 3.25s;
					animation-delay: 3.25s;
				}

				#header nav li:nth-child(5) {
					-moz-animation-delay: 3.5s;
					-webkit-animation-delay: 3.5s;
					-ms-animation-delay: 3.5s;
					animation-delay: 3.5s;
				}

				#header nav li:nth-child(6) {
					-moz-animation-delay: 3.75s;
					-webkit-animation-delay: 3.75s;
					-ms-animation-delay: 3.75s;
					animation-delay: 3.75s;
				}

				#header nav li:nth-child(7) {
					-moz-animation-delay: 4s;
					-webkit-animation-delay: 4s;
					-ms-animation-delay: 4s;
					animation-delay: 4s;
				}

				#header nav li:nth-child(8) {
					-moz-animation-delay: 4.25s;
					-webkit-animation-delay: 4.25s;
					-ms-animation-delay: 4.25s;
					animation-delay: 4.25s;
				}

				#header nav li:nth-child(9) {
					-moz-animation-delay: 4.5s;
					-webkit-animation-delay: 4.5s;
					-ms-animation-delay: 4.5s;
					animation-delay: 4.5s;
				}

				#header nav li:nth-child(10) {
					-moz-animation-delay: 4.75s;
					-webkit-animation-delay: 4.75s;
					-ms-animation-delay: 4.75s;
					animation-delay: 4.75s;
				}

			#header nav a {
				-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
				-webkit-touch-callout: none;
				border: 0;
				display: inline-block;
			}

				#header nav a:before {
					-moz-transition: all 0.2s ease-in-out;
					-webkit-transition: all 0.2s ease-in-out;
					-ms-transition: all 0.2s ease-in-out;
					transition: all 0.2s ease-in-out;
					border-radius: 100%;
					border: solid 1px #fff;
					display: block;
					font-size: 1.75em;
					height: 2.5em;
					line-height: 2.5em;
					position: relative;
					text-align: center;
					top: 0;
					width: 2.5em;
				}

				#header nav a:hover {
					font-size: 1.1em;
				}

					#header nav a:hover:before {
						background-color: rgba(255, 255, 255, 0.175);
						color: #fff;
					}

				#header nav a:active {
					font-size: 0.95em;
					background: none;
				}

					#header nav a:active:before {
						background-color: rgba(255, 255, 255, 0.35);
						color: #fff;
					}

				#header nav a span {
					display: none;
				}

	/* Ensure nav icons and text align horizontally */
	#header nav ul li a {
		display: inline-flex;
		align-items: center;
		gap: 0.5rem;
		color: #fff;
	}

	/* Small venue/time line under header */
	#header .venue {
		margin: 0.5em 0 0;
		font-size: 1rem;
		color: #fff;
		opacity: 0.95;
	}

/* Footer */

	#footer {
		background-image: -moz-linear-gradient(top, rgba(0,0,0,0), rgba(0,0,0,0.5) 75%);
		background-image: -webkit-linear-gradient(top, rgba(0,0,0,0), rgba(0,0,0,0.5) 75%);
		background-image: -ms-linear-gradient(top, rgba(0,0,0,0), rgba(0,0,0,0.5) 75%);
		background-image: linear-gradient(top, rgba(0,0,0,0), rgba(0,0,0,0.5) 75%);
		bottom: 0;
		cursor: default;
		height: 6em;
		left: 0;
		line-height: 8em;
		position: absolute;
		text-align: center;
		width: 100%;
	}

/* RSVP / password gating styles (updated) */
.rsvp-wrap {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 3rem 1rem;
	background: transparent;
}

.rsvp-card {
	background: rgba(0,0,0,0.48);
	padding: 2rem;
	border-radius: 12px;
	max-width: 720px;
	width: 100%;
	color: #fff;
	text-align: center;
	box-shadow: 0 10px 30px rgba(0,0,0,0.25);
}

.rsvp-card h2 { font-family: 'Great Vibes', cursive; font-size: 2.6rem; margin: 0 0 .25rem; }
.rsvp-card p.lead { margin: .5rem 0 1rem; opacity: .95; }

.password-panel {
	margin-bottom: 1rem;
}

.password-panel input[type="password"] {
	padding: .6rem .75rem;
	border-radius: 6px;
	border: none;
	outline: none;
	min-width: 220px;
}

.password-panel button {
	margin-left: .5rem;
	padding: .6rem .9rem;
	border-radius: 6px;
	border: none;
	background: #b88b4a;
	color: #fff;
	cursor: pointer;
}

.rsvp-form { margin-top: 1rem; text-align: left; display: none; }
.rsvp-form.visible { display: block; }

.rsvp-form label { display:block; margin: .45rem 0 .15rem; font-weight:600; }

/* Make text inputs readable on white background */
.rsvp-form input[type="text"],
.rsvp-form input[type="number"],
.password-panel input[type="password"] {
	width: 100%;
	padding: .5rem .6rem;
	border-radius: 6px;
	border: 1px solid #ddd;
	margin-bottom: .6rem;
	background: #fff;
	color: #000;            /* ensure input text is black */
	caret-color: #000;
}

/* placeholder color */
.rsvp-form input::placeholder,
.password-panel input::placeholder {
	color: #666;
}

/* Accept/Decline as selectable buttons */
.choices {
	display:flex;
	gap:1rem;
	align-items:center;
	margin-bottom:.6rem;
}

.choice-button {
	flex: 1 1 auto;
	padding: .6rem .75rem;
	border-radius: 8px;
	border: 1px solid rgba(255,255,255,0.15);
	background: rgba(255,255,255,0.06);
	color: #fff;
	cursor: pointer;
	font-weight:600;
	transition: background .15s, transform .06s, color .12s;
	text-align:center;
}

.choice-button:hover { transform: translateY(-2px); }

.choice-button.selected {
	background: #fff;
	color: #000;
	border-color: rgba(0,0,0,0.08);
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

/* submit button */
.rsvp-form button.submit {
	padding: .7rem 1rem;
	border-radius: 8px;
	background: #b88b4a;
	color:#fff;
	border:none;
	cursor:pointer;
}

/* RSVP summary and validation styles */
.rsvp-summary {
	background: rgba(255,255,255,0.95);
	color: #111;
	padding: 1.25rem;
	border-radius: 10px;
	margin-top: 1rem;
	text-align: left;
}

.rsvp-summary h3 {
	margin: 0 0 0.5rem 0;
	font-family: 'Playfair Display', serif;
	font-weight: 700;
}

.rsvp-summary p { margin: .35rem 0; }

.field-error {
	color: #ff6b6b;
	font-size: 0.9rem;
	margin-top: 0.25rem;
}

/* ensure the white inputs keep black text for summary/button contrast */
.rsvp-form input[type="text"],
.rsvp-form input[type="number"],
.password-panel input[type="password"] {
	/* ...existing code... */
	color: #000;
}

/* Story page styles */
.story-wrap {
	min-height: 100vh;
	background: transparent;
	overflow-y: auto;
	padding: 3rem 1rem;
}

.story-section {
	max-width: 900px;
	margin: 0 auto 4rem;
	background: rgba(0,0,0,0.45);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 10px 30px rgba(0,0,0,0.25);
	animation: fadeInUp 0.8s ease-out forwards;
	opacity: 0;
}

@keyframes fadeInUp {
	from { opacity: 0; transform: translateY(30px); }
	to { opacity: 1; transform: translateY(0); }
}

.story-section:nth-child(1) { animation-delay: 0.2s; }
.story-section:nth-child(2) { animation-delay: 0.4s; }
.story-section:nth-child(3) { animation-delay: 0.6s; }
.story-section:nth-child(4) { animation-delay: 0.8s; }

.story-content {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 2rem;
	padding: 2rem;
}

/* Default ordering for odd sections: image left, text right */
.story-section:nth-of-type(odd) .story-image { order: 0; }
.story-section:nth-of-type(odd) .story-text  { order: 1; }

/* Reverse ordering for even sections: image right, text left */
.story-section:nth-of-type(even) .story-image { order: 1; }
.story-section:nth-of-type(even) .story-text  { order: 0; }

/* Make sure image and text take appropriate space */
.story-image { flex: 0 0 40%; }
.story-text  { flex: 1 1 60%; }

.story-image {
	flex: 0 0 40%;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 8px 20px rgba(0,0,0,0.3);
}

.story-image img {
	width: 100%;
	height: auto;
	display: block;
}

.story-text {
	flex: 1 1 60%;
	color: #fff;
	text-align: left;
}

.story-text h2 {
	font-family: 'Great Vibes', cursive;
	font-size: 2.2rem;
	margin: 0 0 0.5rem;
	color: #fff;
}

.story-text p {
	font-family: 'Playfair Display', serif;
	font-size: 1rem;
	line-height: 1.8;
	margin: 0.5rem 0;
	opacity: 0.95;
}

.story-back {
	text-align: center;
	margin-top: 3rem;
	padding: 2rem 1rem;
}

.story-back a {
	display: inline-block;
	color: #fff;
	text-decoration: none;
	border: 1px solid rgba(255,255,255,0.4);
	padding: 0.7rem 1.2rem;
	border-radius: 999px;
	transition: all 0.2s ease;
	font-size: 1rem;
	background: rgba(255,255,255,0.08);
}

.story-back a:hover {
	background: rgba(255,255,255,0.15);
	border-color: rgba(255,255,255,0.6);
	transform: translateY(-2px);
}

/* animation on phone*/
@media screen and (max-width: 480px) {
	#bg {
		animation-duration: 15s;
	}
}

/* Mobile responsive */
@media (max-width: 768px) {
	.story-content {
		flex-direction: column;
		padding: 1.5rem;
		gap: 1rem;
	}

	.story-section .story-image,
	.story-section .story-text {
		order: 0 !important;
		flex: 0 0 100%;
	}
	.story-image img { width: 100%; height: auto; display:block; }
}

/* Make RSVP form wider on mobile */
@media screen and (max-width: 736px) {
	.rsvp-wrap {
		padding: 2rem 0.5rem; /* reduce side padding so card can grow */
	}

	.rsvp-card {
		max-width: 96%;      /* allow card to use most of the viewport */
		padding: 1.25rem;    /* slightly smaller padding for mobile */
		margin: 0 2%;
		box-sizing: border-box;
	}

	.google-form-wrapper {
		max-width: 100%;
		padding: 0;
	}

	.google-form-wrapper iframe {
		width: 100% !important;
		height: auto; /* let iframe height be managed by embed or container */
		min-height: 500px;
	}
}

/* Extra adjustment for very small phones */
@media screen and (max-width: 480px) {
	.rsvp-card {
		max-width: 98%;
		padding: 1rem;
		margin: 0 1%;
	}
}

/* Custom sparkling wand cursor - smaller size */
* {
	cursor: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20"><defs><style>.spark{fill:%23FFD700;}</style></defs><path class="spark" d="M10 1 L12 6 L17 8 L12 12 L14 17 L10 14 L6 17 L8 12 L3 8 L8 6 Z"/><circle class="spark" cx="10" cy="1" r="1" opacity="0.8"/><circle class="spark" cx="17" cy="8" r="0.7" opacity="0.6"/></svg>') 5 1, auto;
}

a, button {
	cursor: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20"><defs><style>.spark{fill:%23FFD700;}</style></defs><path class="spark" d="M10 1 L12 6 L17 8 L12 12 L14 17 L10 14 L6 17 L8 12 L3 8 L8 6 Z"/><circle class="spark" cx="10" cy="1" r="1" opacity="0.8"/><circle class="spark" cx="17" cy="8" r="0.7" opacity="0.6"/></svg>') 5 1, pointer;
}

/* Sparkle trail animation */
.sparkle {
	position: fixed;
	pointer-events: none;
	font-size: 1.2rem;
	animation: sparkleTrail 0.6s ease-out forwards;
	z-index: 9999;
}

@keyframes sparkleTrail {
	0% {
		opacity: 1;
		transform: translate(0, 0) scale(1);
	}
	100% {
		opacity: 0;
		transform: translate(var(--tx), var(--ty)) scale(0.3);
	}
}

/* Collage gallery for story page */
.collage {
	max-width: 1100px;
	margin: 2rem auto;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	grid-auto-rows: 8px; /* base row height used for spanning */
	gap: 10px;
	padding: 1rem;
}

.collage-item {
	width: 100%;
	overflow: hidden;
	border-radius: 10px;
	box-shadow: 0 10px 30px rgba(0,0,0,0.35);
	position: relative;
	background: rgba(255,255,255,0.03);
}

.collage-item img {
	display: block;
	width: 100%;
	height: auto;
	vertical-align: middle;
	object-fit: cover;
	transition: transform .45s ease, filter .35s ease;
}

.collage-item:hover img {
	transform: scale(1.03);
	filter: saturate(1.05) brightness(1.03);
}

/* Empty/placeholder message */
.collage-empty {
	max-width: 800px;
	margin: 3rem auto;
	color: #fff;
	text-align: center;
	opacity: 0.9;
	font-family: 'Playfair Display', serif;
}

/* Make collage padding tighter on small screens */
@media (max-width: 480px) {
	.collage { gap: 8px; grid-auto-rows: 6px; }
}