/* Booking page specific styles (lean and modular) */
.hero-booking {
  background: linear-gradient(135deg, color-mix(in oklab, var(--color-primary) 16%, transparent), color-mix(in oklab, var(--color-success) 12%, transparent));
}
.hero-grid { display: grid; gap: var(--space-8); grid-template-columns: 1.2fr 1fr; align-items: center; }
.hero-actions { display: flex; gap: var(--space-4); margin-top: var(--space-4); }
.hero-media { aspect-ratio: 16/10; overflow: hidden; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); }

.section-muted { background: var(--gray-50); }
.section-accent { background: color-mix(in oklab, var(--color-warning) 6%, var(--color-background)); }

.room-cards img { border-radius: var(--radius-md); margin-top: var(--space-4); }
.card-placeholder { height: 180px; border-radius: var(--radius-md); background: repeating-linear-gradient(135deg, var(--gray-100), var(--gray-100) 8px, var(--gray-200) 8px, var(--gray-200) 16px); margin-top: var(--space-4); }

.steps { counter-reset: step; display: grid; gap: var(--space-6); list-style: none; padding: 0; }
.steps > li { background: var(--color-surface); padding: var(--space-5); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
.steps > li h3 { display: flex; align-items: center; gap: var(--space-3); }
.steps > li h3::before { counter-increment: step; content: counter(step); display: inline-grid; place-items: center; width: 36px; height: 36px; border-radius: var(--radius-full); background: var(--color-primary); color: var(--on-primary); box-shadow: var(--shadow-sm); }

.custom-grid .checkbox { display: inline-flex; gap: var(--space-2); align-items: center; margin-right: var(--space-4); margin-top: var(--space-3); }

.avail-grid { align-items: start; }
.slots-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-4); }
.slots-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: var(--space-3); }
.slot-btn { --_bg: var(--gray-100); --_text: var(--color-text); display: inline-flex; align-items: center; justify-content: center; width: 100%; padding: 0.7em 0.9em; border: 1px solid var(--gray-300); border-radius: var(--radius-md); background: var(--_bg); color: var(--_text); box-shadow: var(--shadow-sm); cursor: pointer; transition: transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-fast) var(--ease-spring), background-color var(--duration-fast) linear; }
.slot-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.slot-btn[aria-pressed="true"] { background: color-mix(in oklab, var(--color-primary) 15%, white); border-color: var(--color-primary); box-shadow: var(--shadow-glow-primary); }
.slot-btn[disabled], .slot-btn[aria-disabled="true"] { background: var(--gray-100); color: var(--gray-500); border-style: dashed; cursor: not-allowed; }

.price-box { padding: var(--space-4); background: var(--gray-50); border: 1px solid var(--gray-200); border-radius: var(--radius-md); }
.status { margin-top: var(--space-3); min-height: 1.25rem; }
.muted { color: var(--gray-600); }
.small { font-size: var(--fs-sm); }

/* Responsive */
@media (max-width: 960px) {
  .hero-grid { grid-template-columns: 1fr; }
  .avail-grid { grid-template-columns: 1fr; }
}
