.rsb-form {
	--rsb-accent: #F0A79B;   /* coral */
	--rsb-accent-dark: #e07f6f;
	--rsb-green: #6f9279;
	--rsb-green-dark: #5a7a63;
	--rsb-accent-soft: rgba(240, 167, 155, .18);
	max-width: 620px; margin: 1rem 0; font-size: 15px; line-height: 1.5;
}
.rsb-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 480px) { .rsb-grid2 { grid-template-columns: 1fr; } }
.rsb-row { margin-bottom: 1rem; }
.rsb-form label { display: block; font-weight: 600; margin-bottom: 4px; }
.rsb-form label span { color: var(--rsb-accent-dark); }
.rsb-form input[type="text"],
.rsb-form input[type="email"],
.rsb-form input[type="tel"],
.rsb-form input[type="date"],
.rsb-form textarea {
	width: 100%; padding: 10px 12px; border: 1px solid #d0d0d0; border-radius: 8px;
	font-size: 15px; box-sizing: border-box; background: #fff; font-family: inherit;
	color: #2a2a2a; transition: border-color .15s, box-shadow .15s;
}
.rsb-form input:focus,
.rsb-form textarea:focus {
	outline: none; border-color: var(--rsb-green);
	box-shadow: 0 0 0 3px rgba(111, 146, 121, .18);
}
.rsb-form textarea { resize: vertical; }
.rsb-hint { color: #777; font-style: italic; margin: 4px 0; }

/* --- Custom date field + branded calendar popup --- */
.rsb-datewrap { position: relative; }
.rsb-form input.rsb-date-display {
	cursor: pointer; padding-right: 42px;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236f9279' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2'/><line x1='16' y1='2' x2='16' y2='6'/><line x1='8' y1='2' x2='8' y2='6'/><line x1='3' y1='10' x2='21' y2='10'/></svg>");
	background-repeat: no-repeat; background-position: right 12px center;
}

.rsb-cal {
	position: absolute; z-index: 50; top: calc(100% + 6px); left: 0;
	width: 300px; max-width: 100%; background: #fff; border: 1px solid #e2e2e2;
	border-radius: 12px; box-shadow: 0 10px 30px rgba(0, 0, 0, .12); padding: 12px;
	box-sizing: border-box; user-select: none;
}
.rsb-cal[hidden] { display: none; }
.rsb-cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.rsb-cal-title { font-weight: 700; color: #2a2a2a; font-size: 15px; }
.rsb-cal-nav {
	width: 32px; height: 32px; border: 1px solid #e2e2e2; border-radius: 8px; background: #fff;
	cursor: pointer; font-size: 16px; line-height: 1; color: var(--rsb-green-dark);
	display: flex; align-items: center; justify-content: center; transition: background .15s, border-color .15s;
}
.rsb-cal-nav:hover:not(:disabled) { background: rgba(111, 146, 121, .1); border-color: var(--rsb-green); }
.rsb-cal-nav:disabled { opacity: .35; cursor: not-allowed; }
.rsb-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.rsb-cal-dow {
	text-align: center; font-size: 11px; font-weight: 700; text-transform: uppercase;
	color: #999; padding: 4px 0;
}
.rsb-cal-day {
	aspect-ratio: 1 / 1; border: none; background: transparent; border-radius: 8px;
	cursor: pointer; font: inherit; font-size: 14px; color: #2a2a2a;
	display: flex; align-items: center; justify-content: center; transition: background .12s, color .12s;
}
.rsb-cal-day:hover:not(:disabled):not(.rsb-cal-selected) { background: var(--rsb-accent-soft); }
.rsb-cal-day.rsb-cal-today { box-shadow: inset 0 0 0 1px var(--rsb-green); font-weight: 700; }
.rsb-cal-day.rsb-cal-selected { background: var(--rsb-accent); color: #fff; font-weight: 700; }
.rsb-cal-day:disabled { color: #ccc; cursor: not-allowed; }
.rsb-cal-day.rsb-cal-empty { visibility: hidden; }

.rsb-slots { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 10px; }
.rsb-slot {
	text-align: left; padding: 12px 14px; border: 1px solid #e2e2e2; border-radius: 10px;
	background: #fff; cursor: pointer; display: flex; flex-direction: column; gap: 4px;
	transition: border-color .15s, box-shadow .15s, background .15s; font: inherit;
}
.rsb-slot:hover:not(:disabled) { border-color: var(--rsb-green); }
.rsb-slot-active { border-color: var(--rsb-green); box-shadow: 0 0 0 1px var(--rsb-green); background: #fff; }
.rsb-slot-full { opacity: .55; cursor: not-allowed; background: #f4f4f4; }
.rsb-slot-range { font-weight: 600; }
.rsb-slot-seats { font-size: 13px; }
.rsb-left { color: var(--rsb-green-dark); }
.rsb-full { color: #b32d2e; }

.rsb-panel { margin-bottom: 1rem; }
.rsb-counter { display: flex; align-items: center; gap: 12px; }
.rsb-counter button {
	width: 36px; height: 36px; border: 1px solid #ccc; border-radius: 8px; background: #fff;
	font-size: 18px; cursor: pointer; line-height: 1; transition: border-color .15s, color .15s;
}
.rsb-counter button:hover:not(:disabled) { border-color: var(--rsb-green); color: var(--rsb-green-dark); }
.rsb-counter button:disabled { opacity: .4; cursor: not-allowed; }
.rsb-count { font-size: 20px; font-weight: 600; min-width: 28px; text-align: center; }
.rsb-remain { font-size: 13px; color: #666; margin-left: auto; }

.rsb-submit {
	width: 100%; padding: 13px; border: none; border-radius: 8px; background: var(--rsb-green);
	color: #fff; font-size: 15px; font-weight: 600; cursor: pointer; margin-top: 6px;
	transition: background .15s;
}
.rsb-submit:hover { background: var(--rsb-green-dark); }
.rsb-submit:disabled { opacity: .6; cursor: default; }

.rsb-message { margin-top: 1rem; padding: 12px 14px; border-radius: 8px; }
.rsb-ok { background: #edf7ed; color: #1a7f37; border: 1px solid #b6dfb6; }
.rsb-err { background: #fdecea; color: #b32d2e; border: 1px solid #f2c0bd; }
