/* Algolia Search Widgets Styles */

/* Main Layout Styles */
#ais-wrapper {
    display: flex !important;
    flex-wrap: nowrap !important; /* Don't wrap to next line */
    gap: 20px;
    width: 100%;
    align-items: flex-start; /* Align items to the top */
}

#ais-main {
    flex: 1 1 75% !important; /* Allow growth and shrinking */
    max-width: 75% !important;
    min-width: 0; /* Allow flex item to shrink */
    width: auto !important; /* Override any width constraints */
}

#ais-facets {
    flex: 0 0 25% !important; /* Don't grow or shrink, fixed 25% */
    max-width: 25% !important;
    min-width: 200px; /* Minimum width to prevent too narrow facets */
    width: auto !important; /* Override any width constraints */
}

/* Search Box Wrapper Styles */
.algolia-search-box-wrapper {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 15px;
}

#algolia-search-box {
    flex: 1;
    min-width: 250px;
}

#algolia-search-box input {
    width: 100%;
    padding: 10px 15px;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 16px;
}

/* Search Controls (Stats and Sort) */
.search-controls-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    flex-wrap: wrap;
    gap: 15px;
}

#algolia-stats {
    font-size: 14px;
    color: #666;
    flex: 1;
    min-width: 200px;
}

#sort-by {
    flex-shrink: 0;
    min-width: 150px;
    display: flex;
    align-items: center;
}

#sort-by select {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid #ddd;
    border-radius: 4px;
    background-color: #fff;
    font-size: 14px;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml;charset=US-ASCII,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3e%3cpath fill='%23666' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 8px center;
    background-size: 12px;
    padding-right: 30px;
}

/* Search Results Container */
#algolia-hits {
    margin-bottom: 20px;
}

/* Facets Container */
#ais-facets {
    padding-left: 20px;
}

.widgettitle {
    margin: 0 0 15px 0;
    font-size: 18px;
    font-weight: 600;
    color: #333;
}

/* Desktop Layout Enforcement */
@media (min-width: 993px) {
    #ais-wrapper {
        flex-wrap: nowrap !important; /* Force no wrapping on desktop */
    }
    
    #ais-main {
        order: 1;
    }
    
    #ais-facets {
        order: 2;
    }
}

/* Responsive Layout */
@media (max-width: 768px) {
    .search-controls-wrapper {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
    
    #algolia-stats,
    #sort-by {
        width: 100%;
        min-width: auto;
    }
}

@media (max-width: 992px) {
    #ais-wrapper {
        flex-direction: column;
        flex-wrap: wrap; /* Allow wrapping on mobile */
    }
    
    #ais-main,
    #ais-facets {
        flex: 0 0 100%;
        max-width: 100%;
        min-width: auto;
    }
    
    #ais-facets {
        padding-left: 0;
        order: -1; /* Show facets first on mobile */
    }
}

/* Collapsible Refinement Styles */
.widgettitle {
    user-select: none;
    transition: background-color 0.2s ease;
    padding: 8px 0;
}

.widgettitle:hover {
    opacity: 0.8;
}

.refinement-toggle {
    font-size: 18px;
    font-weight: bold;
    color: #6c757d;
    min-width: 20px;
    text-align: center;
    transition: transform 0.2s ease;
}

.refinement-toggle.collapsed {
    transform: rotate(0deg);
}

.refinement-toggle:not(.collapsed) {
    transform: rotate(0deg);
}

.refinement-content {
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
    padding: 16px;
}

.refinement-content.collapsed {
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
}

.refinement-widget-container {
    /* Container for the actual Algolia widget */
    position: relative;
}

/* Algolia Widget Overrides for better styling */
.ais-RefinementList,
.ais-HierarchicalMenu,
.ais-Menu {
    font-family: inherit;
}

.ais-RefinementList-list,
.ais-HierarchicalMenu-list,
.ais-Menu-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ais-RefinementList-item,
.ais-HierarchicalMenu-item,
.ais-Menu-item {
    padding: 4px 0;
}

.ais-RefinementList-label,
.ais-HierarchicalMenu-link,
.ais-Menu-link {
    display: flex;
    align-items: center;
    text-decoration: none;
    color: #495057;
    font-size: 14px;
    cursor: pointer;
}

.ais-RefinementList-label:hover,
.ais-HierarchicalMenu-link:hover,
.ais-Menu-link:hover {
    color: #007cba;
}

.ais-RefinementList-checkbox {
    margin-right: 8px;
}

.ais-RefinementList-labelText,
.ais-HierarchicalMenu-linkText,
.ais-Menu-linkText {
    flex: 1;
}

.ais-RefinementList-count,
.ais-HierarchicalMenu-count,
.ais-Menu-count {
    background-color: #e9ecef;
    color: #6c757d;
    font-size: 12px;
    padding: 2px 6px;
    border-radius: 10px;
    margin-left: 8px;
}

/* Animation for smooth expand/collapse */
@keyframes expandRefinement {
    from {
        max-height: 0;
        padding-top: 0;
        padding-bottom: 0;
    }
    to {
        max-height: 500px;
        padding-top: 16px;
        padding-bottom: 16px;
    }
}

@keyframes collapseRefinement {
    from {
        max-height: 500px;
        padding-top: 16px;
        padding-bottom: 16px;
    }
    to {
        max-height: 0;
        padding-top: 0;
        padding-bottom: 0;
    }
}

/* Search Results Grid Layout */
.ais-Stats {
    position: relative;
    top: 0px;
}

.ais-Hits-list {
    display: grid;
    gap: 20px;
    margin: 0;
    padding: 0;
    list-style: none;
}

/* Column Layout Classes */
.ais-hits-columns-1 .ais-Hits-list {
    grid-template-columns: 1fr;
}

.ais-hits-columns-2 .ais-Hits-list {
    width: 100%;
    grid-template-columns: repeat(2, 1fr);
}

.ais-hits-columns-3 .ais-Hits-list {
    grid-template-columns: repeat(3, 1fr);
}

.ais-hits-columns-4 .ais-Hits-list {
    grid-template-columns: repeat(4, 1fr);
}

.ais-Hits-item {
    margin: 0;
    padding: 0;
}

/* Responsive Grid Adjustments */
@media (max-width: 1200px) {
    .ais-hits-columns-4 .ais-Hits-list {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 992px) {
    .ais-hits-columns-3 .ais-Hits-list,
    .ais-hits-columns-4 .ais-Hits-list {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .ais-hits-columns-2 .ais-Hits-list,
    .ais-hits-columns-3 .ais-Hits-list,
    .ais-hits-columns-4 .ais-Hits-list {
        grid-template-columns: 1fr;
    }
    
    .refinement-header {
        padding: 10px 12px;
    }
    
    .refinement-content {
        padding: 12px;
    }
    
    .refinement-content.collapsed {
        padding-top: 0;
        padding-bottom: 0;
    }
}