/* ---------- Reservation CTA ---------- */
.ssyp-reservation { background: var(--primary); color: #fff; position: relative; overflow: hidden; }
.ssyp-reservation::before { content: ''; position: absolute; inset: 0; background: url(../images/storefront.jpg) center/cover; opacity: .12; }
.ssyp-reservation .ssyp-container { position: relative; z-index: 1; }
.ssyp-reservation-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
@media (max-width: 1024px) { .ssyp-reservation-grid { grid-template-columns: 1fr; gap: 48px; } }
.ssyp-reservation .lead h2 { color: #fff; font-size: clamp(32px, 4vw, 48px); margin-bottom: 16px; }
.ssyp-reservation .lead p { color: rgba(255,255,255,.7); font-size: 16px; margin-bottom: 32px; }
.ssyp-reservation-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; padding-top: 32px; border-top: 1px solid rgba(255,255,255,.15); }
.ssyp-reservation-stats .num { font-family: var(--font-serif); font-size: 28px; color: var(--accent-light); font-weight: 700; }
.ssyp-reservation-stats .label { font-size: 12px; color: rgba(255,255,255,.6); margin-top: 4px; }
.ssyp-form { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); padding: 48px; backdrop-filter: blur(8px); }
.ssyp-form h3 { color: #fff; margin: 0 0 6px; font-size: 24px; }
.ssyp-form .sub { color: rgba(255,255,255,.6); font-size: 13px; margin-bottom: 28px; }
.ssyp-field { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.ssyp-field label { font-size: 11px; color: rgba(255,255,255,.6); letter-spacing: .2em; }
.ssyp-field input, .ssyp-field select, .ssyp-field textarea {
	background: transparent; border: 0; border-bottom: 1px solid rgba(255,255,255,.25); color: #fff; padding: 12px 0; font-size: 14px; outline: none;
}
/* 原生下拉的 option 在白底上渲染，select 的白字会和背景一样消失 — 给 option 单独着深色 */
.ssyp-field select option { color: #1f1814; background: #fff; }
.ssyp-field select:invalid { color: rgba(255,255,255,.5); }
.ssyp-field input:focus, .ssyp-field select:focus { border-bottom-color: var(--accent-light); }
.ssyp-field input::placeholder { color: rgba(255,255,255,.35); }
.ssyp-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ssyp-form .submit { width: 100%; margin-top: 8px; }
.ssyp-form .submit:disabled { opacity: .65; cursor: wait; }
.ssyp-form-message { margin: 16px 0 0; font-size: 13px; line-height: 1.6; }
.ssyp-form-message.is-success { color: #8fd48f; }
.ssyp-form-message.is-error { color: #ffb3a8; }

.ssyp-alert { margin: 0 0 24px; padding: 14px 18px; border: 1px solid var(--border); background: var(--card); color: var(--foreground); }
.ssyp-alert-success { border-color: rgba(46, 125, 50, .35); }
.ssyp-alert-error { border-color: rgba(180, 40, 40, .35); }
.ssyp-form-light { background: var(--card); border-color: var(--border); color: var(--foreground); }
.ssyp-form-light h3 { color: var(--primary); }
.ssyp-form-light .sub, .ssyp-form-light .ssyp-field label { color: var(--muted-foreground); }
.ssyp-form-light .ssyp-field input, .ssyp-form-light .ssyp-field select, .ssyp-form-light .ssyp-field textarea { color: var(--foreground); border-bottom-color: var(--border); }
.ssyp-form-light .ssyp-field select:invalid { color: var(--muted-foreground); }
.ssyp-form-light .ssyp-field input:focus, .ssyp-form-light .ssyp-field select:focus, .ssyp-form-light .ssyp-field textarea:focus { border-bottom-color: var(--accent); }
