/**
 * RSVP form — Devonshire Grove brand palette.
 * Cream / teal / bronze, mirrors the rest of the site.
 */

.crsvp {
	display: block;
	max-width: 640px;
	margin: 36px auto;
	background: #FFFFFF;
	border: 1px solid #D9CDB8;
	border-radius: 4px;
	padding: 26px 28px;
	color: #2C3E3D;
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

.crsvp__head {
	margin-bottom: 18px;
}
.crsvp__eyebrow {
	margin: 0 0 6px;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: #8C6F45;
	font-weight: 700;
}
.crsvp__title {
	margin: 0 0 8px;
	font-family: Georgia, 'Times New Roman', serif;
	font-size: 26px;
	font-weight: 400;
	color: #4A9B97;
	line-height: 1.2;
}
.crsvp__lede {
	margin: 0;
	font-size: 14px;
	color: #5C6766;
	line-height: 1.55;
}

.crsvp__row {
	margin-bottom: 14px;
}
.crsvp__row--cols {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}
.crsvp__row--inline {
	margin-top: 4px;
}
.crsvp__row label {
	display: block;
}
.crsvp__row label > span {
	display: block;
	font-size: 11px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #8B8576;
	font-weight: 700;
	margin-bottom: 5px;
}
.crsvp__row label em {
	color: #8B8576;
	font-style: normal;
	font-weight: 400;
	letter-spacing: 0;
	text-transform: none;
}
.crsvp__row input[type="text"],
.crsvp__row input[type="email"],
.crsvp__row input[type="tel"],
.crsvp__row select,
.crsvp__row textarea {
	width: 100%;
	padding: 10px 12px;
	background: #FAF4E9;
	border: 1px solid #D9CDB8;
	border-radius: 3px;
	color: #2C3E3D;
	font-size: 15px;
	font-family: inherit;
	box-shadow: none;
	transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease;
}
.crsvp__row input:focus,
.crsvp__row select:focus,
.crsvp__row textarea:focus {
	background: #fff;
	border-color: #4A9B97;
	box-shadow: 0 0 0 3px rgba(74, 155, 151, 0.18);
	outline: none;
}

.crsvp__birthday {
	background: #FAF4E9;
	border: 1px dashed #D9CDB8;
	border-radius: 3px;
	padding: 14px 16px;
	margin-bottom: 14px;
}
.crsvp__birthday-line {
	margin: 0 0 12px;
	font-size: 13px;
	color: #2C3E3D;
	line-height: 1.5;
}
.crsvp__birthday-line em {
	color: #8B8576;
	font-style: italic;
}
.crsvp__birthday-icon {
	margin-right: 4px;
}

.crsvp__check {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-size: 13px;
	color: #2C3E3D;
	cursor: pointer;
}
.crsvp__check span {
	margin: 0;
	font-size: 13px;
	letter-spacing: 0;
	text-transform: none;
	font-weight: 400;
	line-height: 1.5;
	color: #5C6766;
}
.crsvp__check input { margin-top: 3px; }

.crsvp__row--submit {
	margin-top: 6px;
	display: flex;
	gap: 16px;
	align-items: center;
	flex-wrap: wrap;
}
.crsvp__submit {
	background: #8C6F45;
	color: #fff;
	border: 0;
	padding: 14px 28px;
	border-radius: 3px;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background-color 160ms ease, box-shadow 160ms ease;
}
.crsvp__submit:hover {
	background: #6F5836;
	box-shadow: 0 0 0 3px rgba(184, 152, 104, 0.22);
}
.crsvp__submit:disabled {
	opacity: 0.6;
	cursor: progress;
}
.crsvp__status {
	margin: 0;
	font-size: 13px;
	color: #5C6766;
}
.crsvp__status.is-error  { color: #B23A48; }
.crsvp__status.is-success { color: #1F6B47; }

.crsvp__notice {
	background: #FAF4E9;
	border-left: 3px solid #4A9B97;
	padding: 14px 18px;
	border-radius: 0 3px 3px 0;
	color: #2C3E3D;
	font-size: 14px;
	line-height: 1.55;
}
.crsvp__notice--closed {
	border-left-color: #B86E0A;
	color: #5C6766;
}

@media (max-width: 600px) {
	.crsvp { padding: 20px 18px; }
	.crsvp__row--cols { grid-template-columns: 1fr; }
	.crsvp__row input,
	.crsvp__row select,
	.crsvp__row textarea { font-size: 16px; } /* avoid iOS auto-zoom */
}

/* ── Social-login prefill ────────────────────────────────── */
.crsvp__social {
	margin: 0 0 18px;
	padding: 0 0 18px;
	border-bottom: 1px solid #ECE4D2;
}
.crsvp__social-hint {
	margin: 0 0 10px;
	font-size: 12px;
	color: #8B8576;
	letter-spacing: 0.04em;
}
.crsvp__social-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}
.crsvp__social-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 11px 14px;
	border-radius: 3px;
	font-size: 14px;
	font-weight: 600;
	text-decoration: none;
	transition: border-color 160ms ease, background-color 160ms ease, transform 80ms ease;
}
.crsvp__social-btn:active { transform: translateY(1px); }
.crsvp__social-btn--google {
	background: #fff;
	border: 1px solid #D9CDB8;
	color: #2C3E3D;
}
.crsvp__social-btn--google:hover { border-color: #4A9B97; }
.crsvp__social-btn--apple,
.crsvp__social-btn--apple:link,
.crsvp__social-btn--apple:visited {
	background: #000;
	border: 1px solid #000;
	color: #fff !important;
}
.crsvp__social-btn--apple svg { fill: #fff !important; }
.crsvp__social-btn--apple span { color: #fff !important; }
.crsvp__social-btn--apple:hover {
	background: #1a1a1a;
	color: #fff !important;
}

.crsvp__social-or {
	margin: 14px 0 0;
	text-align: center;
	font-size: 12px;
	color: #8B8576;
	letter-spacing: 0.04em;
	position: relative;
}
.crsvp__social-or::before,
.crsvp__social-or::after {
	content: '';
	position: absolute;
	top: 50%;
	width: 38%;
	height: 1px;
	background: #ECE4D2;
}
.crsvp__social-or::before { left: 0; }
.crsvp__social-or::after  { right: 0; }

@media (max-width: 480px) {
	.crsvp__social-row { grid-template-columns: 1fr; }
}

/* ── External-tickets mode (third-party link) ──────────── */
.crsvp__external {
	text-align: center;
	padding: 6px 0;
}
.crsvp__external-eyebrow {
	margin: 0 0 6px;
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: #8C6F45;
	font-weight: 700;
}
.crsvp__external-title {
	margin: 0 0 8px;
	font-family: Georgia, 'Times New Roman', serif;
	font-size: 24px;
	font-weight: 400;
	color: #4A9B97;
	line-height: 1.2;
}
.crsvp__external-lede {
	margin: 0 0 22px;
	font-size: 14px;
	color: #5C6766;
}
.crsvp__external-btn {
	display: inline-block;
	background: #8C6F45;
	color: #fff !important;
	text-decoration: none;
	padding: 14px 28px;
	border-radius: 3px;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	transition: background-color 160ms ease, box-shadow 160ms ease;
}
.crsvp__external-btn:hover {
	background: #6F5836;
	box-shadow: 0 0 0 3px rgba(184, 152, 104, 0.22);
}
.crsvp__external-source {
	margin: 16px 0 0;
	font-size: 11px;
	color: #8B8576;
	letter-spacing: 0.04em;
}
