.elementor-429 .elementor-element.elementor-element-d2082d0{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-429 .elementor-element.elementor-element-c5b6709{--display:flex;}:root{--page-title-display:none;}/* Start custom CSS for shortcode, class: .elementor-element-4255414 *//* Main wrapper - use flexbox for side-by-side layout */
#wpsl-wrap {
    font-family: "Muli", sans-serif;
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    width: 100%;
    height: 800px; /* Fixed height for the entire container */
    margin: 0px;
}

/* Left side: Search + Results wrapper */
.wpsl-search-results-wrapper {
    flex: 0 0 50%; /* Takes 50% width on desktop */
    max-width: 50%;
    height: 800px; /* Same height as container */
    display: flex;
    flex-direction: column;
}

/* Search section (blue area) */
.wpsl-search-results-wrapper .wpsl-search {
    background: linear-gradient(135deg, #2c5aa0 0%, #4a7bc8 100%);
    padding: 40px 30px;
    flex-shrink: 0; /* Prevents search from shrinking */
}

/* Search header styling */
.wpsl-search-header h2 {
    font-size: 36px;
    font-weight: 700;
    color: #ffffff;
    margin: 0 0 10px 0;
    line-height: 1.2;
}

.wpsl-search-header p {
    font-size: 16px;
    color: #ffffff;
    margin: 0 0 30px 0;
    opacity: 0.95;
}

/* Search form wrapper */
#wpsl-search-wrap form {
    display: flex;
    align-items: flex-end;
    gap: 15px;
    flex-wrap: wrap;
}

/* Input field container */
.wpsl-input {
    flex: 1;
    min-width: 200px;
}

.wpsl-input label {
    display: block;
    color: #ffffff;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 8px;
}

#wpsl-search-input {
    width: 100%;
    padding: 12px 16px;
    border: none;
    border-radius: 4px;
    font-size: 15px;
    background-color: #ffffff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

#wpsl-search-input:focus {
    outline: 2px solid #ffffff;
    outline-offset: 2px;
}

/* Select dropdowns wrapper */
.wpsl-select-wrap {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
}

#wpsl-radius,
#wpsl-results {
    flex: 0 0 auto;
}

#wpsl-radius label,
#wpsl-results label {
    display: block;
    color: #ffffff;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 8px;
}

.wpsl-dropdown {
    padding: 12px 16px;
    border: none;
    border-radius: 4px;
    font-size: 15px;
    background-color: #ffffff;
    cursor: pointer;
    min-width: 120px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.wpsl-dropdown:focus {
    outline: 2px solid #E94432;
    outline-offset: 2px;
}

/* Search button */
.wpsl-search-btn-wrap {
    flex: 0 0 auto;
}

#wpsl-search-btn {
    padding: 12px 32px;
    background: #E94432;
    color: #ffffff;
    border-color: #E94432;
    border: none;
    border-radius: 4px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    transition: background-color 0.3s ease;
}

#wpsl-search-btn:hover {
    background-color: #e63939;
}

#wpsl-search-btn:active {
    transform: translateY(1px);
}

/* Results section (white area below search) */
#wpsl-result-list {
    flex: 1;
    overflow-y: auto; /* Makes results scrollable */
    background-color: #ffffff;
    padding: 20px;
    height: 0; /* Allows flex to control height */
}

/* Right side: Map wrapper */
.wpsl-map-wrapper {
    flex: 0 0 50%; /* Takes 50% width on desktop */
    max-width: 50%;
    height: 800px; /* Same height as container */
}

/* Map canvas */
#wpsl-gmap {
    width: 100% !important;
    height: 800px !important; /* Exact same height */
}

/* Credits at bottom (if enabled) */
.wpsl-provided-by {
    flex: 0 0 100%;
    width: 100%;
}

a {
    color: black;
}

#wpsl-result-list {
    width: 100%;
}

#wpsl-category, .wpsl-input, .wpsl-select-wrap {
    margin-bottom: 0px;
}

.wpsl-dropdown {
    padding: 6px 16px;
}

#wpsl-search-wrap {
    display: flex;
}

a.wpsl-directions {
    color: #E94432;
}

#wpsl-search-wrap .wpsl-input, #wpsl-search-wrap .wpsl-select-wrap {
    display: flex;
    align-items: center;
}

#wpsl-search-wrap .wpsl-input label, #wpsl-search-wrap .wpsl-input input, #wpsl-search-wrap #wpsl-radius, #wpsl-search-wrap #wpsl-results, #wpsl-search-btn {
    display: flex;
    align-items: center;
}

#wpsl-search-wrap input, #wpsl-search-btn {
    border: none;
    border-radius: 3px;
}
/* Mobile responsive - stack vertically on smaller screens */
@media (max-width: 768px) {
    .wpsl-search-results-wrapper,
    .wpsl-map-wrapper {
        flex: 0 0 100%;
        max-width: 100%;
    }
    
    .wpsl-map-wrapper {
        height: 400px; /* Fixed height on mobile */
        position: relative;
    }
    
    #wpsl-search-wrap form {
        flex-direction: column;
        align-items: stretch;
    }
    
    .wpsl-input,
    #wpsl-radius,
    #wpsl-results,
    .wpsl-search-btn-wrap {
        width: 100%;
    }
    
    #wpsl-search-btn {
        width: 100%;
    }
}

/* Mobile responsive styles - add these to your existing CSS */
@media (max-width: 768px) {
    /* Make main wrapper stack vertically and allow natural height */
    #wpsl-wrap {
        flex-direction: column;
        height: auto; /* Remove fixed height on mobile */
    }
    
    /* Search + Results wrapper - full width on mobile */
    .wpsl-search-results-wrapper {
        flex: 0 0 100%;
        max-width: 100%;
        height: auto; /* Allow natural height based on content */
    }
    
    /* Search section adjustments */
    .wpsl-search-results-wrapper .wpsl-search {
        padding: 30px 20px;
    }
    
    .wpsl-search-header h2 {
        font-size: 28px;
    }
    
    .wpsl-search-header p {
        font-size: 14px;
        margin-bottom: 20px;
    }
    
    /* Make form stack vertically */
    #wpsl-search-wrap form {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
        width: 100%;
    }
    
    /* Full width inputs and selects */
    .wpsl-input,
    .wpsl-select-wrap {
        width: 100%;
        min-width: 100%;  
        flex-direction: column;
    }
    
    .wpsl-select-wrap {
        flex-direction: column;
        gap: 12px;
    }
    
    #wpsl-radius,
    #wpsl-results {
        width: 100%;
        flex-direction: column;
    }
    
    .wpsl-dropdown {
        width: 100%;
        min-width: 100%;
    }
    
    /* Full width search button */
    .wpsl-search-btn-wrap {
        width: 100%;
    }
    
    #wpsl-search-btn {
        width: 100%;
        padding: 14px 32px;
    }
    
    /* Results section - allow scrolling with max height */
    #wpsl-result-list {
        max-height: 400px; /* Limit height so map is visible */
        padding: 15px;
    }
    
    /* Map wrapper - full width and fixed height */
    .wpsl-map-wrapper {
        flex: 0 0 100%;
        max-width: 100%;
        height: 400px; /* Fixed height for mobile */
        min-height: 400px;
    }
    
    /* Map canvas - ensure it shows properly */
    #wpsl-gmap {
        width: 100% !important;
        height: 400px !important;
        min-height: 400px !important;
    }
    
    .wpsl-search-header h2, .wpsl-search-header p{
        text-align: center;
    }
}

/* Smaller mobile devices */
@media (max-width: 480px) {
    .wpsl-search-results-wrapper .wpsl-search {
        padding: 20px 15px;
    }
    
    .wpsl-search-header h2 {
        font-size: 24px;
    }
    
    .wpsl-search-header p {
        font-size: 13px;
    }
    
    #wpsl-search-input,
    .wpsl-dropdown {
        padding: 10px 14px;
        font-size: 14px;
    }
    
    /* Slightly smaller map on very small screens */
    .wpsl-map-wrapper,
    #wpsl-gmap {
        height: 300px !important;
        min-height: 300px !important;
    }
    #wpsl-search-wrap div label {
        text-align: center;
    }
}/* End custom CSS */