/* Availability -- Multi-day column layout with sub-tab navigation */

.availability-module {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.av-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: var(--space-3);
    gap: var(--space-3);
}

.av-sub-tabs {
    flex: 1;
}

.av-header-date {
    flex-shrink: 0;
}

.availability-module > .ra-columns {
    flex: 1;
    min-height: 0;
}

/* ========================================
   COLUMN CONTAINER
   ======================================== */

.ra-columns {
    display: flex;
    gap: var(--space-2);
    height: 100%;
    min-height: 0;
    overflow-x: auto;
}

/* ========================================
   ENTITY COLUMN
   ======================================== */

.ra-column {
    flex: 1;
    min-width: 220px;
    display: flex;
    flex-direction: column;
    background: var(--bg-layer-3);
    border: var(--border-width-1) solid var(--border-default);
    border-radius: var(--border-radius-lg);
    overflow: hidden;
}

.ra-column-closed {
    opacity: 0.5;
}

.ra-column-info {
    flex: 0 0 200px;
}

/* ========================================
   COLUMN HEADER (sticky)
   ======================================== */

.ra-column-header {
    position: sticky;
    top: 0;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: var(--bg-layer-3);
    border-bottom: var(--border-width-1) solid var(--border-default);
}

.ra-column-header-left {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
}

.ra-column-name {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
}

.ra-column-cuisine {
    font-size: var(--text-2xs);
    color: var(--text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}

/* ========================================
   COLUMN BODY (scrollable day content)
   ======================================== */

.ra-column-body {
    flex: 1;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-2) var(--space-3) var(--space-3);
}

/* ========================================
   BOOKING MODAL -- Two Column Layout
   (shared with Bookings via BookingFormModal)
   ======================================== */

/* Modal helper panel layout now provided by Modal organism (.modal-body-columns / .modal-body-helper) */

/* Two-column booking modal scroll: the rooms/form column scrolls on its own;
   the helper (guest lookup) panel stays fixed and visible. The modal body is
   height-bounded (modal-content max-height 90vh), so the columns own the
   scroll instead of the whole two-column block scrolling as one unit. Desktop
   /tablet only -- on mobile the columns stack and the body scrolls normally. */
@media (min-width: 769px) {
    #ra-booking-modal .modal-body { overflow: hidden; display: flex; flex-direction: column; }
    #ra-booking-modal .modal-body-columns { flex: 1; min-height: 0; }
    #ra-booking-modal .modal-body-main { min-height: 0; }
    #ra-booking-modal .modal-body-helper { min-height: 0; }
}

.ra-booking-date {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--text-primary);
    padding-bottom: var(--space-2);
    border-bottom: var(--border-width-1) solid var(--border-subtle);
    margin-bottom: var(--space-2);
}

.ra-slot-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
}

.ra-guest-row {
    display: grid;
    grid-template-columns: 1fr 1fr 64px 64px;
    gap: var(--space-2);
}

.ra-party-field {
    min-width: 0;
}

.ra-mode-row {
    display: flex;
    align-items: flex-end;
    gap: var(--space-3);
}

.ra-mode-row .segmented-control {
    flex-shrink: 0;
}

.ra-mode-row .form-field {
    flex: 1;
    min-width: 0;
}

.ra-mode-row .ra-find-btn {
    flex-shrink: 0;
    align-self: flex-end;
}

/* ========================================
   ROOM PANELS (Multi-Room)
   ======================================== */

.ra-rooms-section {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.ra-rooms-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.ra-rooms-title {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--text-primary);
}

.ra-add-room-btn { color: var(--text-muted); }
.ra-add-room-btn:hover { color: var(--color-primary); }

.ra-room-panel {
    overflow: visible !important;
}

.ra-room-panel.expanded .expandable-panel-content {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.ra-room-header-content {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex: 1;
    min-width: 0;
}

.ra-room-header-label {
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
}

.ra-room-header-room {
    font-size: var(--text-xs);
    color: var(--text-muted);
    white-space: nowrap;
}

.ra-room-header-guest {
    font-size: var(--text-sm);
    color: var(--text-body);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ra-room-header-covers {
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--text-muted);
    white-space: nowrap;
    margin-left: auto;
}

/* Helper panel states now use standard EmptyState/ErrorState molecules */

/* ========================================
   GUEST CARD (in helper panel)
   ======================================== */

.ra-guest-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.ra-guest-card-header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.ra-guest-card-room {
    font-size: var(--text-xs);
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.ra-guest-card-name {
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--text-primary);
}

.ra-guest-card-details {
    display: flex;
    flex-direction: column;
    gap: var(--space-1_5);
    font-size: var(--text-sm);
    color: var(--text-body);
}

.ra-guest-card-details strong {
    color: var(--text-primary);
    font-weight: 600;
}

/* .ra-helper-no-data removed -- use EmptyState molecule */

.ra-guest-card-action {
    padding-top: var(--space-2);
    border-top: var(--border-width-1) solid var(--border-subtle);
    margin-top: var(--space-1);
}

/* ========================================
   ENTITLEMENT DISPLAY (in helper panel)
   ======================================== */

.ra-entitlement-section {
    padding-top: var(--space-2);
    border-top: var(--border-width-1) solid var(--border-subtle);
}

.ra-entitlement-row {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.ra-entitlement-type {
    font-size: var(--text-xs);
    font-weight: var(--font-weight-medium);
    color: var(--text-muted);
}

.ra-entitlement-meals {
    font-size: var(--text-xs);
    color: var(--text-muted);
    font-style: italic;
}

/* ========================================
   FACILITY INFO (non-bookable columns)
   ======================================== */

.ra-facility-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.ra-info-row {
    display: flex;
    flex-direction: column;
    gap: var(--space-0_5);
}

.ra-info-label {
    font-size: var(--text-2xs);
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.ra-info-value {
    font-size: var(--text-sm);
    color: var(--text-body);
}

.ra-info-empty {
    color: var(--text-muted);
    font-size: var(--text-xs);
    font-style: italic;
    padding: var(--space-2);
}

/* ========================================
   RESPONSIVE: stack modal columns on mobile
   ======================================== */

@media (max-width: 768px) {
    .ra-mode-row {
        flex-direction: column;
        align-items: stretch;
    }

    .ra-slot-row {
        grid-template-columns: 1fr;
    }

    .ra-guest-row {
        grid-template-columns: 1fr 1fr 56px 56px;
    }
}
