/* RSVP Wedding - Public CSS */

.rsvp-wedding-wrap {
	--rsvp-bg-utama: #fff8f0;
	--rsvp-bg-field: #ffffff;
	--rsvp-border-field: #e8c9a0;
	--rsvp-warna-teks: #4a3728;
	--rsvp-font-family: inherit;
	--rsvp-font-size: 15px;
	--rsvp-warna-tombol: #c9976a;
	--rsvp-teks-tombol: #ffffff;

	font-family: var(--rsvp-font-family);
	font-size: var(--rsvp-font-size);
	color: var(--rsvp-warna-teks);
	max-width: 680px;
	margin: 0 auto;
}

/* ---- FORM SECTION ---- */
.rsvp-form-section {
	background: var(--rsvp-bg-utama);
	border: 1px solid var(--rsvp-border-field);
	border-radius: 14px;
	padding: 28px 32px;
	margin-bottom: 30px;
}

.rsvp-judul {
	margin: 0 0 20px;
	font-size: 1.3em;
	font-weight: 700;
	color: var(--rsvp-warna-teks);
	text-align: center;
}

.rsvp-field-group {
	margin-bottom: 16px;
}

.rsvp-field-group label {
	display: block;
	font-size: 0.88em;
	font-weight: 600;
	margin-bottom: 6px;
	color: var(--rsvp-warna-teks);
	opacity: .85;
	letter-spacing: .3px;
}

.rsvp-field-group input[type="text"],
.rsvp-field-group textarea,
.rsvp-field-group select {
	width: 100%;
	padding: 10px 14px;
	background: var(--rsvp-bg-field);
	border: 1.5px solid var(--rsvp-border-field);
	border-radius: 8px;
	font-family: var(--rsvp-font-family);
	font-size: inherit;
	color: var(--rsvp-warna-teks);
	box-sizing: border-box;
	transition: border-color .2s, box-shadow .2s;
	outline: none;
	-webkit-appearance: none;
	appearance: none;
}

.rsvp-field-group select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M6 8L0 0h12z' fill='%23888'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 36px;
	cursor: pointer;
}

.rsvp-field-group input[type="text"]:focus,
.rsvp-field-group textarea:focus,
.rsvp-field-group select:focus {
	border-color: var(--rsvp-warna-tombol);
	box-shadow: 0 0 0 3px rgba(201,151,106,.15);
}

.rsvp-field-group textarea {
	resize: vertical;
	min-height: 90px;
}

/* Tombol Kirim */
.rsvp-btn-kirim {
	display: block;
	width: 100%;
	padding: 12px 20px;
	background: var(--rsvp-warna-tombol);
	color: var(--rsvp-teks-tombol);
	border: none;
	border-radius: 8px;
	font-family: var(--rsvp-font-family);
	font-size: 1em;
	font-weight: 700;
	letter-spacing: .5px;
	cursor: pointer;
	transition: opacity .2s, transform .1s;
	margin-top: 4px;
}
.rsvp-btn-kirim:hover  { opacity: .88; }
.rsvp-btn-kirim:active { transform: scale(.98); }
.rsvp-btn-kirim:disabled { opacity: .6; cursor: not-allowed; }

/* Pesan notifikasi */
.rsvp-pesan {
	padding: 12px 16px;
	border-radius: 8px;
	margin-bottom: 16px;
	font-size: .92em;
}
.rsvp-pesan-sukses {
	background: #d4edda;
	color: #155724;
	border: 1px solid #c3e6cb;
}
.rsvp-pesan-error {
	background: #f8d7da;
	color: #721c24;
	border: 1px solid #f5c6cb;
}

/* ---- UCAPAN LIST ---- */
.rsvp-ucapan-section {
	margin-top: 10px;
}

.rsvp-ucapan-judul {
	font-size: 1.05em;
	font-weight: 700;
	color: var(--rsvp-warna-teks);
	margin: 0 0 16px;
	padding-bottom: 10px;
	border-bottom: 2px solid var(--rsvp-border-field);
}

.rsvp-loading {
	text-align: center;
	color: #aaa;
	padding: 20px;
}

.rsvp-ucapan-empty {
	text-align: center;
	color: #bbb;
	padding: 30px 10px;
	font-style: italic;
}

/* Kartu ucapan */
.rsvp-ucapan-item {
	background: var(--rsvp-bg-utama);
	border: 1px solid var(--rsvp-border-field);
	border-radius: 10px;
	padding: 16px 18px;
	margin-bottom: 14px;
	animation: rsvpFadeIn .4s ease;
}

@keyframes rsvpFadeIn {
	from { opacity: 0; transform: translateY(-8px); }
	to   { opacity: 1; transform: translateY(0); }
}

.rsvp-ucapan-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 8px;
	gap: 10px;
	flex-wrap: wrap;
}

.rsvp-ucapan-nama {
	font-weight: 700;
	font-size: 1em;
}

.rsvp-ucapan-badge {
	display: inline-block;
	padding: 2px 10px;
	border-radius: 20px;
	font-size: .78em;
	font-weight: 700;
}
.rsvp-kehadiran-hadir       { background: #d4edda; color: #155724; }
.rsvp-kehadiran-tidak_hadir { background: #f8d7da; color: #721c24; }
.rsvp-kehadiran-ragu_ragu   { background: #fff3cd; color: #856404; }

.rsvp-ucapan-teks {
	font-size: .95em;
	line-height: 1.6;
	color: var(--rsvp-warna-teks);
	margin: 0;
}

.rsvp-ucapan-date {
	font-size: .75em;
	color: #aaa;
	margin-top: 8px;
}

/* Responsive */
@media (max-width: 480px) {
	.rsvp-form-section { padding: 20px 16px; }
}
