/**
 * Schedule Date Range Picker Styles
 * Custom styling for daterangepicker library
 */

/* ===================================
   Schedule Form - Reduced Gap
   =================================== */

/* Multiple selectors with max specificity to override everything */
#schedule-filters-form .fields--flex,
#schedule-filters-form.search-form .fields--flex,
form#schedule-filters-form .fields--flex,
form#schedule-filters-form .dropdowns-selectors .fields--flex,
form.search-form#schedule-filters-form .fields--flex,
.search-form#schedule-filters-form .dropdowns-selectors .fields--flex {
    gap: 0.5rem !important;
    column-gap: 0.5rem !important;
}

/* Specific override for the schedule page */
body .search-form#schedule-filters-form .fields--flex {
    gap: 0.5rem !important;
}

/* Fix Select2 fixed widths - make them flex */
#schedule-filters-form .fields--flex > .field {
    flex: 1 1 0 !important;
    min-width: 0 !important;
}

/* Make date field slightly wider */
#schedule-filters-form .fields--flex > .field:has(.daterange-wrapper) {
    flex-grow: 1.3 !important;
}

#schedule-filters-form .fields--flex > .field .select2-container {
    width: 100% !important;
}

#schedule-filters-form .fields--flex > .field select,
#schedule-filters-form .fields--flex > .field input {
    width: 100% !important;
    box-sizing: border-box !important;
}

/* ===================================
   Date Range Input Field
   =================================== */

.daterange-wrapper {
    position: relative;
    width: 100%;
}

/* Desktop: Show date range picker, hide native inputs */
.daterange-wrapper--desktop {
    display: block;
}

.daterange-wrapper--mobile {
    display: none;
}

.daterange-input {
    width: 100%;
    min-width: 10rem;
    cursor: pointer;
    font-size: 15px;
    font-weight: 500;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%23666' d='M5 0v2H3C1.3 2 0 3.3 0 5v9c0 1.7 1.3 3 3 3h10c1.7 0 3-1.3 3-3V5c0-1.7-1.3-3-3-3h-2V0h-1v2H6V0H5zm-2 3h10c1.1 0 2 .9 2 2v1H1V5c0-1.1.9-2 2-2zm10 12H3c-1.1 0-2-.9-2-2V7h14v6c0 1.1-.9 2-2 2z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 18px;
    padding-right: 40px;
}

/* Mobile native date inputs */
.daterange-mobile-fields {
    display: flex;
    gap: 0.5rem;
}

.daterange-input-mobile {
    flex: 1;
    width: 100%;
    padding: 0.875rem 1rem;
    font-size: 16px;
    border: 2px solid #e4e8ec;
    border-radius: 0.5rem;
    background-color: #f8fafc;
    color: #111827;
}

/* ===================================
   Daterangepicker Popup Overrides
   =================================== */

/* Popup container */
.daterangepicker {
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    padding: 0;
    font-family: inherit;
}

/* Header (ranges sidebar) */
.daterangepicker .ranges {
    width: 180px;
    padding: 15px 0;
    background: #f8f9fa;
    border-right: 1px solid #e0e0e0;
    border-radius: 8px 0 0 8px;
}

.daterangepicker .ranges ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.daterangepicker .ranges li {
    padding: 10px 20px;
    font-size: 14px;
    color: #333;
    cursor: pointer;
    transition: all 0.2s ease;
    border-left: 3px solid transparent;
}

.daterangepicker .ranges li:hover {
    background: #e8f5ef;
    color: #16B969;
}

.daterangepicker .ranges li.active {
    background: #e8f5ef;
    color: #16B969;
    border-left-color: #16B969;
    font-weight: 600;
}

/* Calendar container */
.daterangepicker .drp-calendar {
    padding: 15px;
}

.daterangepicker .calendar-table {
    border: none;
    padding: 0;
}

/* Month/Year headers */
.daterangepicker .calendar-table th {
    font-size: 13px;
    font-weight: 600;
    color: #666;
    padding: 8px 5px;
}

.daterangepicker select.monthselect,
.daterangepicker select.yearselect {
    font-size: 13px;
    padding: 5px;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: #fff;
    cursor: pointer;
}

/* Day cells */
.daterangepicker td {
    font-size: 13px;
    text-align: center;
    border-radius: 4px;
    transition: all 0.2s ease;
}

.daterangepicker td.available:hover {
    background: #e8f5ef;
    color: #16B969;
}

.daterangepicker td.active,
.daterangepicker td.active:hover {
    background-color: #16B969;
    color: white;
}

.daterangepicker td.in-range {
    background-color: #e8f5ef;
    color: #16B969;
}

.daterangepicker td.start-date,
.daterangepicker td.end-date {
    background-color: #16B969;
    color: white;
    font-weight: 600;
}

.daterangepicker td.off,
.daterangepicker td.off.in-range,
.daterangepicker td.off.start-date,
.daterangepicker td.off.end-date {
    background-color: #f5f5f5;
    color: #999;
}

.daterangepicker td.disabled,
.daterangepicker td.disabled:hover {
    color: #ccc;
    cursor: not-allowed;
}

/* Today marker */
.daterangepicker td.today {
    font-weight: 600;
    position: relative;
}

.daterangepicker td.today::after {
    content: '';
    position: absolute;
    bottom: 4px;
    left: 50%;
    transform: translateX(-50%);
    width: 4px;
    height: 4px;
    background: #16B969;
    border-radius: 50%;
}

/* Buttons */
.daterangepicker .drp-buttons {
    padding: 12px 15px;
    border-top: 1px solid #e0e0e0;
    display: flex !important;
    flex-direction: row !important;
    justify-content: flex-end;
    align-items: center;
    gap: 10px;
}

.daterangepicker .drp-buttons .btn {
    padding: 8px 20px !important;
    font-size: 13px !important;
    font-weight: 600;
    border-radius: 4px;
    border: none;
    cursor: pointer;
    transition: all 0.2s ease;
    flex: 0 0 auto !important;
    min-width: 80px !important;
    max-width: 120px !important;
    width: auto !important;
    display: inline-block !important;
    float: none !important;
}

.daterangepicker .cancelBtn {
    background: #f0f0f0 !important;
    color: #666 !important;
    order: 1;
}

.daterangepicker .cancelBtn:hover {
    background: #e0e0e0 !important;
}

.daterangepicker .applyBtn {
    background: #16B969 !important;
    color: white !important;
    order: 2;
}

.daterangepicker .applyBtn:hover {
    background: #129954 !important;
    box-shadow: 0 2px 8px rgba(22, 185, 105, 0.3);
}

/* Arrow (caret) */
.daterangepicker:before,
.daterangepicker:after {
    border-bottom-color: #e0e0e0;
}

.daterangepicker:after {
    border-bottom-color: #fff;
}

/* ===================================
   Responsive
   =================================== */

/* Tablet and below - stack filters in 2 columns */
@media (max-width: 1024px) {
    #schedule-filters-form .fields--flex {
        flex-wrap: wrap !important;
    }
    
    #schedule-filters-form .fields--flex > .field {
        flex: 1 1 calc(50% - 0.25rem) !important;
        min-width: calc(50% - 0.25rem) !important;
    }
    
    /* Date field takes full width on last row if needed */
    #schedule-filters-form .fields--flex > .field:has(.daterange-wrapper) {
        flex: 1 1 calc(50% - 0.25rem) !important;
        flex-grow: 1 !important;
    }
    
    /* Submit button takes full width */
    #schedule-filters-form .fields--flex .field--submit {
        flex: 1 1 100% !important;
    }
}

/* Mobile - single column layout */
@media (max-width: 768px) {
    /* Switch to native date inputs on mobile */
    .daterange-wrapper--desktop {
        display: none !important;
    }
    
    .daterange-wrapper--mobile {
        display: block !important;
    }
    
    #schedule-filters-form .fields--flex {
        flex-direction: column !important;
        gap: 0.75rem !important;
    }
    
    #schedule-filters-form .fields--flex > .field,
    #schedule-filters-form .fields--flex > .field:has(.daterange-wrapper),
    #schedule-filters-form .fields--flex .field--submit {
        flex: 1 1 100% !important;
        width: 100% !important;
        min-width: 100% !important;
        margin-bottom: 0 !important;
    }
    
    /* Ensure inputs take full width on mobile */
    #schedule-filters-form .fields--flex > .field select,
    #schedule-filters-form .fields--flex > .field input,
    #schedule-filters-form .fields--flex > .field .select2-container,
    #schedule-filters-form .fields--flex > .field .daterange-input {
        width: 100% !important;
    }
    
    /* Larger touch targets on mobile */
    #schedule-filters-form .fields--flex > .field input,
    #schedule-filters-form .fields--flex > .field select,
    #schedule-filters-form .fields--flex > .field .daterange-input,
    #schedule-filters-form .fields--flex .field--submit input[type="submit"] {
        padding: 0.875rem 1rem !important;
        font-size: 16px !important;
    }
    
    /* Native select styling on mobile */
    #schedule-filters-form .fields--flex > .field select {
        -webkit-appearance: menulist;
        -moz-appearance: menulist;
        appearance: menulist;
        background-image: none;
        padding-right: 2.5rem;
    }
    
    /* Hide Select2 on mobile if it was initialized */
    #schedule-filters-form .fields--flex > .field .select2-container {
        display: none !important;
    }
    
    #schedule-filters-form .fields--flex > .field select.select2-hidden-accessible {
        display: block !important;
        opacity: 1 !important;
        position: relative !important;
        width: 100% !important;
    }
    
    /* Actions spacing on mobile */
    #schedule-filters-form .actions {
        margin-top: 1.25rem;
    }
    
    #schedule-filters-form .filters {
        gap: 0.75rem;
        flex-direction: column;
        align-items: flex-start;
    }
    
    #schedule-filters-form .single-filter {
        width: 100%;
    }
}

/* Daterangepicker popup on mobile */
@media (max-width: 768px) {
    .daterangepicker {
        max-width: 100% !important;
        left: 10px !important;
        right: 10px !important;
    }
    
    .daterangepicker .ranges {
        width: 100%;
        border-right: none;
        border-bottom: 1px solid #e0e0e0;
        border-radius: 8px 8px 0 0;
    }
    
    .daterangepicker .drp-calendar {
        float: none !important;
        width: 100% !important;
    }
    
    .daterangepicker .calendar-table {
        font-size: 12px;
    }
    
    .daterangepicker .drp-buttons {
        flex-direction: row;
        gap: 8px;
    }
    
    .daterangepicker .drp-buttons .btn {
        flex: 1;
    }
}

/* ===================================
   Disabled State (during loading)
   =================================== */

.daterange-input:disabled,
.daterange-input-mobile:disabled {
    cursor: not-allowed !important;
    opacity: 0.6;
}

/* ===================================
   Filter Actions (Checkboxes)
   =================================== */

#schedule-filters-form .actions {
    margin-top: 1.5rem;
}

#schedule-filters-form .filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

#schedule-filters-form .single-filter {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    margin: 0;
}

#schedule-filters-form .single-filter input[type="checkbox"] {
    margin: 0;
    cursor: pointer;
}

#schedule-filters-form .single-filter .description {
    font-size: 0.9rem;
    margin: 0;
    white-space: nowrap;
}
