/* ==========================================
   AVAILABILITY CALENDAR — PUBLIC PAGE
   Two-month interactive calendar
   ========================================== */

/* Controls — Room Tabs + Month Nav */
.avail-controls {
    padding: 0;
    background: var(--color-white);
    border-bottom: 1px solid var(--color-border-light);
    position: sticky;
    top: 60px;
    z-index: 100;
}

.avail-controls .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
    padding-top: 16px;
    padding-bottom: 16px;
}

.room-selector {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.room-tab {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 10px 20px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    background: transparent;
    cursor: pointer;
    font-family: var(--font-sans);
    transition: all var(--transition-fast);
}

.room-tab-name {
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.3px;
    color: var(--color-text);
}

.room-tab-price {
    font-size: 0.72rem;
    color: var(--color-text-muted);
    margin-top: 1px;
}

.room-tab:hover {
    border-color: var(--color-accent);
    background: var(--color-accent-glow);
}

.room-tab.active {
    background: var(--color-primary);
    border-color: var(--color-primary);
}

.room-tab.active .room-tab-name {
    color: var(--color-white);
}

.room-tab.active .room-tab-price {
    color: var(--color-accent-light);
}

/* Month Navigation */
.month-nav {
    display: flex;
    align-items: center;
    gap: 14px;
}

.month-nav-btn {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 1px solid var(--color-border);
    background: transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text);
    transition: all var(--transition-fast);
}

.month-nav-btn:hover:not(:disabled) {
    border-color: var(--color-accent);
    background: var(--color-accent-glow);
    color: var(--color-accent-dark);
}

.month-nav-btn:disabled {
    cursor: not-allowed;
}

.month-nav-label {
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-primary);
    min-width: 200px;
    text-align: center;
    white-space: nowrap;
}

/* Selection Hint */
.avail-selection-hint {
    padding: 12px 0;
    background: var(--color-cream);
    border-bottom: 1px solid var(--color-border-light);
}

.selection-hint-inner {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: center;
    font-family: var(--font-sans);
    font-size: 0.85rem;
    color: var(--color-text-light);
}

.selection-hint-inner svg {
    color: var(--color-accent);
    flex-shrink: 0;
}

/* ==========================================
   DATE PICKER BAR
   ========================================== */
.avail-date-bar {
    padding: 0;
    background: var(--color-cream);
    border-bottom: 1px solid var(--color-border-light);
}

.date-bar-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 18px 0 14px;
}

.date-bar-fields {
    display: flex;
    align-items: flex-end;
    gap: 14px;
    flex-wrap: wrap;
    justify-content: center;
}

.date-bar-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.date-bar-field label {
    font-family: var(--font-sans);
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
}

.date-bar-field input[type="date"] {
    font-family: var(--font-sans);
    font-size: 0.88rem;
    font-weight: 500;
    padding: 10px 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-white);
    color: var(--color-text);
    outline: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    min-width: 160px;
}

.date-bar-field input[type="date"]:focus {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(var(--accent-rgb, 193, 154, 107), 0.15);
}

.date-bar-arrow {
    color: var(--color-accent);
    display: flex;
    align-items: center;
    padding-bottom: 6px;
}

.date-bar-nights {
    display: flex;
    align-items: center;
    gap: 5px;
    background: var(--color-accent);
    color: #fff;
    padding: 8px 16px;
    border-radius: 20px;
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: 0.85rem;
    margin-bottom: 1px;
}

.date-bar-nights-num {
    font-size: 1.05rem;
}

.date-bar-hint {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-sans);
    font-size: 0.8rem;
    color: var(--color-text-muted);
}

.date-bar-hint svg {
    color: var(--color-accent);
    flex-shrink: 0;
}

/* ==========================================
   STAY DAYS BREAKDOWN (in selection panel)
   ========================================== */
.stay-days-breakdown {
    margin-bottom: 20px;
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-white);
}

.stay-days-header {
    font-family: var(--font-sans);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-muted);
    padding: 10px 16px;
    background: var(--color-cream);
    border-bottom: 1px solid var(--color-border-light);
}

.stay-day-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    font-family: var(--font-sans);
    font-size: 0.84rem;
    border-bottom: 1px solid rgba(0,0,0,0.04);
}

.stay-day-row:last-child {
    border-bottom: none;
}

.stay-day-row.weekend {
    background: rgba(245, 158, 11, 0.05);
}

.stay-day-num {
    font-weight: 600;
    color: var(--color-primary);
    min-width: 60px;
}

.stay-day-date {
    flex: 1;
    color: var(--color-text);
}

.stay-day-rate {
    font-size: 0.76rem;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 12px;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.stay-day-row:not(.weekend) .stay-day-rate {
    color: #166534;
    background: rgba(34, 197, 94, 0.08);
}

.stay-day-row.weekend .stay-day-rate {
    color: #92400e;
    background: rgba(245, 158, 11, 0.1);
}

/* Legend */
.avail-legend-section {
    padding: 20px 0 10px;
    background: var(--color-white);
}

.avail-legend {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
    justify-content: center;
}

.legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font-sans);
    font-size: 0.78rem;
    color: var(--color-text-light);
}

.legend-swatch {
    width: 14px;
    height: 14px;
    border-radius: 3px;
    flex-shrink: 0;
}

.legend-swatch.available { background: #22c55e; }
.legend-swatch.limited  { background: #f59e0b; }
.legend-swatch.full     { background: #ef4444; }
.legend-swatch.past     { background: #d4d4d8; }
.legend-swatch.today    { background: var(--color-white); border: 2px solid var(--color-accent); }

/* ==========================================
   TWO-MONTH CALENDAR
   ========================================== */
.avail-calendar-section {
    padding: 30px 0 40px;
    background: var(--color-white);
}

.calendar-two-month {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    max-width: 920px;
    margin: 0 auto;
}

/* Month Panel */
.cal-month-panel {
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-white);
    box-shadow: 0 2px 12px rgba(0,0,0,0.04);
}

.cal-month-header {
    padding: 16px 20px;
    background: var(--color-primary);
    color: var(--color-white);
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 600;
    text-align: center;
    letter-spacing: 0.3px;
}

.cal-month-header.current-month {
    background: var(--color-accent-dark);
}

.cal-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    padding: 12px 12px 6px;
}

.cal-weekday {
    text-align: center;
    font-family: var(--font-sans);
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--color-text-muted);
    letter-spacing: 0.5px;
}

.cal-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    padding: 6px 12px 16px;
}

/* Day cell */
.cal-day {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 6px 2px 4px;
    border-radius: 6px;
    cursor: default;
    position: relative;
    transition: all 0.15s ease;
    min-height: 48px;
}

.cal-day.empty {
    background: transparent;
    min-height: 0;
}

.cal-day-num {
    font-family: var(--font-sans);
    font-size: 0.82rem;
    font-weight: 600;
    line-height: 1;
    pointer-events: none;
}

.cal-day-price {
    font-family: var(--font-sans);
    font-size: 0.6rem;
    font-weight: 500;
    color: inherit;
    opacity: 0.7;
    margin-top: 2px;
    line-height: 1;
    pointer-events: none;
}

/* Availability states */
.cal-day.past {
    color: #c4c4c8;
    background: #f8f8f9;
}

.cal-day.available {
    color: #166534;
    background: rgba(34, 197, 94, 0.08);
    cursor: pointer;
}

.cal-day.available:hover {
    background: rgba(34, 197, 94, 0.2);
    transform: scale(1.05);
}

.cal-day.limited {
    color: #92400e;
    background: rgba(245, 158, 11, 0.08);
    cursor: pointer;
}

.cal-day.limited:hover {
    background: rgba(245, 158, 11, 0.2);
    transform: scale(1.05);
}

.cal-day.full {
    color: #991b1b;
    background: rgba(239, 68, 68, 0.06);
}

.cal-day.today {
    outline: 2px solid var(--color-accent);
    outline-offset: -1px;
}

.cal-day.today .cal-day-num {
    font-weight: 800;
}

.cal-day.weekend .cal-day-num {
    color: inherit;
}

/* Selection states */
.cal-day.sel-start,
.cal-day.sel-end {
    background: var(--color-accent) !important;
    color: #fff !important;
    transform: scale(1.08);
    z-index: 2;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

.cal-day.sel-start .cal-day-price,
.cal-day.sel-end .cal-day-price {
    opacity: 0.9;
}

.cal-day.sel-range {
    background: rgba(var(--accent-rgb, 193, 154, 107), 0.18) !important;
    color: var(--color-text) !important;
    border-radius: 4px;
}

.cal-day.sel-preview {
    background: rgba(var(--accent-rgb, 193, 154, 107), 0.1) !important;
    border-radius: 4px;
}

/* ==========================================
   SELECTION PANEL
   ========================================== */
.calendar-selection-panel {
    margin-top: 28px;
    max-width: 920px;
    margin-left: auto;
    margin-right: auto;
    animation: slideUp 0.3s ease;
}

@keyframes slideUp {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

.selection-panel-inner {
    background: var(--color-cream);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    padding: 28px 32px;
}

.selection-dates {
    display: flex;
    align-items: center;
    gap: 20px;
    justify-content: center;
    margin-bottom: 24px;
    flex-wrap: wrap;
}

.selection-date-block {
    text-align: center;
}

.selection-date-label {
    display: block;
    font-family: var(--font-sans);
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    margin-bottom: 4px;
}

.selection-date-value {
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--color-primary);
}

.selection-arrow {
    color: var(--color-accent);
}

.selection-nights {
    font-family: var(--font-sans);
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-accent-dark);
    background: rgba(var(--accent-rgb, 193, 154, 107), 0.12);
    padding: 6px 14px;
    border-radius: 20px;
}

/* Available rooms in selection panel */
.selection-rooms {
    margin-bottom: 16px;
}

.sel-rooms-hint {
    text-align: center;
    font-family: var(--font-sans);
    font-size: 0.88rem;
    color: var(--color-text-muted);
    padding: 8px 0;
}

.sel-room-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px;
    background: var(--color-white);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    margin-bottom: 8px;
    transition: box-shadow 0.2s ease;
}

.sel-room-card:hover {
    box-shadow: var(--shadow-sm);
}

.sel-room-info h4 {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-primary);
    margin: 0 0 2px;
}

.sel-room-total {
    font-family: var(--font-sans);
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--color-accent-dark);
}

.sel-room-per {
    font-weight: 400;
    color: var(--color-text-muted);
    font-size: 0.78rem;
}

.sel-room-book {
    white-space: nowrap;
}

.btn-sm {
    padding: 8px 18px;
    font-size: 0.78rem;
}

.sel-no-rooms {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: center;
    padding: 16px;
    background: rgba(239, 68, 68, 0.06);
    border-radius: var(--radius-md);
    font-family: var(--font-sans);
    font-size: 0.88rem;
    color: #991b1b;
}

.selection-actions {
    text-align: center;
}

.selection-clear {
    font-size: 0.8rem;
    padding: 8px 20px;
}

/* Room Cards */
.avail-rooms-section {
    padding: 80px 0;
    background: var(--color-cream);
}

.avail-room-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
    margin-top: 40px;
}

.avail-room-card {
    background: var(--color-white);
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid var(--color-border-light);
    transition: all var(--transition-base);
}

.avail-room-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-4px);
}

.avail-room-img {
    height: 200px;
    background-size: cover;
    background-position: center;
}

.avail-room-info {
    padding: 24px;
}

.avail-room-info h3 {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 600;
    margin-bottom: 8px;
}

.avail-room-info p {
    font-family: var(--font-body);
    font-size: 1rem;
    color: var(--color-text-light);
    line-height: 1.6;
    margin-bottom: 16px;
}

.avail-room-price {
    display: flex;
    align-items: baseline;
    gap: 6px;
    margin-bottom: 16px;
}

.avail-room-features {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 20px;
}

.avail-room-features span {
    font-family: var(--font-sans);
    font-size: 0.72rem;
    font-weight: 500;
    padding: 4px 12px;
    background: var(--color-cream);
    border-radius: 20px;
    color: var(--color-text-light);
}

/* CTA */
.avail-cta {
    padding: 80px 0;
    background: var(--color-primary);
    text-align: center;
}

.avail-cta-box {
    max-width: 600px;
    margin: 0 auto;
}

.avail-cta h2 {
    font-family: var(--font-display);
    font-size: 2.2rem;
    color: var(--color-white);
    margin-bottom: 16px;
}

.avail-cta p {
    font-family: var(--font-body);
    font-size: 1.1rem;
    color: rgba(255,255,255,0.75);
    line-height: 1.7;
    margin-bottom: 28px;
}

.avail-cta-actions {
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
}

.avail-cta .btn-outline {
    border-color: rgba(255,255,255,0.3);
    color: var(--color-white);
}

.avail-cta .btn-outline:hover {
    border-color: var(--color-accent);
    background: rgba(255,255,255,0.08);
}

.btn-lg {
    padding: 14px 32px;
    font-size: 0.9rem;
}

.avail-cta-note {
    font-family: var(--font-sans);
    font-size: 0.82rem;
    color: rgba(255,255,255,0.5);
    margin-top: 20px;
}

[data-theme="dark"] .avail-cta { background: #222a2f; }
[data-theme="dark"] .avail-cta h2 { color: #e8e4de; }
[data-theme="dark"] .avail-cta .btn-outline { color: #e8e4de; }

/* ---- Dark mode: room tab active state ---- */
[data-theme="dark"] .room-tab.active { background: #222a2f; border-color: #222a2f; }
[data-theme="dark"] .room-tab.active .room-tab-name { color: #e8e4de; }

/* ---- Dark mode: calendar month header ---- */
[data-theme="dark"] .cal-month-header { background: #222a2f; color: #e8e4de; }

/* ---- Dark mode: calendar day availability states ---- */
[data-theme="dark"] .cal-day.past { color: #6b6b72; background: rgba(255,255,255,0.03); }
[data-theme="dark"] .cal-day.available { color: #6ee096; background: rgba(34, 197, 94, 0.1); }
[data-theme="dark"] .cal-day.available:hover { background: rgba(34, 197, 94, 0.22); }
[data-theme="dark"] .cal-day.limited { color: #fbbf24; background: rgba(245, 158, 11, 0.1); }
[data-theme="dark"] .cal-day.limited:hover { background: rgba(245, 158, 11, 0.22); }
[data-theme="dark"] .cal-day.full { color: #fca5a5; background: rgba(239, 68, 68, 0.08); }

/* ---- Dark mode: stay days breakdown rate badges ---- */
[data-theme="dark"] .stay-day-row:not(.weekend) .stay-day-rate { color: #6ee096; background: rgba(34, 197, 94, 0.1); }
[data-theme="dark"] .stay-day-row.weekend .stay-day-rate { color: #fbbf24; background: rgba(245, 158, 11, 0.1); }

/* ---- Dark mode: no rooms available error state ---- */
[data-theme="dark"] .sel-no-rooms { background: rgba(239, 68, 68, 0.08); color: #fca5a5; }

/* ==========================================
   RESPONSIVE
   ========================================== */
@media (max-width: 900px) {
    .calendar-two-month {
        grid-template-columns: 1fr;
        max-width: 440px;
    }

    .avail-room-cards {
        grid-template-columns: 1fr;
        max-width: 480px;
        margin-left: auto;
        margin-right: auto;
    }

    .month-nav-label {
        font-size: 0.9rem;
        min-width: 160px;
    }
}

@media (max-width: 640px) {
    .avail-controls .container {
        flex-direction: column;
        align-items: stretch;
    }

    .room-selector {
        justify-content: center;
    }

    .room-tab {
        padding: 8px 14px;
    }

    .room-tab-name {
        font-size: 0.75rem;
    }

    .month-nav {
        justify-content: center;
    }

    .month-nav-label {
        font-size: 0.82rem;
        min-width: auto;
    }

    .avail-legend {
        gap: 12px;
    }

    .legend-item {
        font-size: 0.7rem;
    }

    .selection-panel-inner {
        padding: 20px 16px;
    }

    .selection-dates {
        gap: 12px;
    }

    .sel-room-card {
        flex-direction: column;
        gap: 12px;
        text-align: center;
    }

    .avail-cta h2 {
        font-size: 1.6rem;
    }

    .avail-cta-actions {
        flex-direction: column;
        align-items: center;
    }

    .date-bar-fields {
        flex-direction: column;
        align-items: stretch;
        gap: 8px;
    }

    .date-bar-arrow {
        justify-content: center;
        padding-bottom: 0;
    }

    .date-bar-field input[type="date"] {
        min-width: auto;
        width: 100%;
    }

    .date-bar-nights {
        align-self: center;
    }

    .stay-day-row {
        flex-wrap: wrap;
        gap: 4px 10px;
    }

    .stay-day-num {
        min-width: auto;
    }
}
