﻿.catalog {
    container: catalog / inline-size;
}

    .catalog main {
        display: grid;
        grid-template-columns: 250px 1fr;
        grid-template-areas:
            "filter_header results_header"
            "filters results";
        grid-column-gap: 20px;
        grid-row-gap: 5px;
    }

        .catalog main p {
            margin: 0;
        }

.catalog__show-filters {
    display: none;
}

@container catalog (max-width: 800px) {
    .catalog main {
        grid-template-columns: 1fr;
        grid-template-areas:
            "filter_header"
            "filters"
            "results_header"
            "results";
    }

    .catalog .catalog__filters {
        display: none;
    }

        .catalog .catalog__filters.catalog__filters--open {
            display: block;
        }

    .catalog .catalog__show-filters {
        display: inline;
        border: none;
        background: transparent;
        color: var(--sbrgreen-500);
        cursor: pointer;
    }

        .catalog .catalog__show-filters .icon {
            font-size: 36px;
        }

    .catalog .catalog__filters-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        background: var(--sbr-neutral-gray-100);
        padding: 0 1rem;
        border-radius: var(--sbr-radius-8);
        margin: -1rem 0 1rem 0;
    }
}

@container catalog (max-width: 500px) {
    .catalog .catalog__results-header {
        flex-wrap: wrap;
        justify-content: flex-end;
        gap: .5rem;
    }

    .catalog__results-header * {
        white-space: nowrap;
    }
}

.catalog h1 {
    font-size: 1rem;
    font-weight: 700;
}

.catalog__search {
    display: flex;
    justify-content: center;
    background: var(--sbr-neutral-gray-100);
    padding: 1rem;
    margin-bottom: 3rem;
    border-radius: var(--sbr-radius-8);
}

.catalog__search-input {
    display: flex;
    align-items: stretch;
    border: 2px solid var(--sbr-neutral-gray-250);
    border-radius: var(--sbr-radius-8);
    width: 80%;
}

    .catalog__search-input input[type="text"] {
        border-radius: var(--sbr-radius-8) 0 0 var(--sbr-radius-8);
        color: var(--sbr-text-color);
        border: none;
        border-radius: 5px 0 0 5px;
        margin: 2px;
        flex: 1;
    }

    .catalog__search-input a {
        color: var(--sbrgreen-500) !important;
        border: none;
        border-left-width: medium;
        border-left-style: none;
        border-left-color: currentcolor;
        border-left: 2px solid var(--sbr-neutral-gray-250);
        background: var(--sbr-neutral-gray-250);
        padding: 0 1rem;
        cursor: pointer;
        text-decoration: none;
    }

.catalog__filters-header {
    grid-area: filter_header;
    font-size: .875rem;
    font-weight: bold;
    align-content: center;
}

.catalog__results-header {
    grid-area: results_header;
    font-size: .75rem;
    display: flex;
    gap: 2rem;
    align-items: center;
}

.catalog__filters {
    grid-area: filters;
    border: solid 1px var(--sbr-neutral-gray-250);
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.catalog__results {
    grid-area: results;
}

.catalog__result-items {
    border: solid 1px var(--sbr-neutral-gray-250);
}

.catalog__results-count {
    margin-right: auto;
}

.catalog__view-select {
    display: flex;
    align-items: center;
    gap: .25rem;
}

    .catalog__view-select:only-child {
        margin-left: auto;
    }

    .catalog__view-select a {
        border: solid 1px var(--sbr-neutral-gray-250);
        border-radius: var(--sbr-radius-4);
        width: 1.5rem;
        aspect-ratio: 1;
        display: flex;
        justify-content: center;
        align-items: center;
    }

        .catalog__view-select a svg {
            stroke: var(--sbrgreen-500);
            width: 1rem;
        }

.catalog__grid-sort {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .75rem;
}

    .catalog__grid-sort label {
        width: auto;
    }

    .catalog__grid-sort select {
        border: solid 1px var(--sbr-neutral-gray-250);
        background: #fff;
        border-radius: var(--sbr-radius-4);
        padding: .25rem .5rem;
        font-size: .75rem;
        font-family: var(--sbr-font-family);
    }

.catalog__switch-sort a {
    display: flex;
    text-decoration: none;
    color: var(--sbrgreen-500) !important;
    letter-spacing: -.3rem;
    font-size: 1rem;
}

    .catalog__switch-sort a:before {
        content: "▲";
        opacity: .3;
    }

    .catalog__switch-sort a:after {
        content: "▼";
        opacity: .3;
    }

.catalog__switch-sort[data-sort-dir="asc"] a:before {
    opacity: 1;
}

.catalog__switch-sort[data-sort-dir="desc"] a:after {
    opacity: 1;
}

.catalog__no-results-message {
    font-size: .875rem;
    font-weight: 500;
    padding: 1rem;
    display: block;
}

/*
    Date / Zip filters
*/
.catalog__date-filters > p:first-child,
.catalog__zip-filter > p:first-child {
    font-size: .75rem;
    font-weight: 500;
    margin-bottom: .5rem;
}

.catalog__date-range-input,
.catalog__zip-filter-input {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    justify-content: space-between;
}

.catalog__date-input {
    position: relative;
    margin-top: .25rem;
}

    .catalog__date-input label {
        width: auto;
        position: absolute;
        top: -.5rem;
        left: .5rem;
        padding: 0;
        margin: 0;
        font-size: .7rem;
        background: #fff;
    }

    .catalog__date-input input,
    .catalog__zip-filter-input input,
    .catalog__zip-filter-input select {
        width: 100%;
        background: #fff;
        box-sizing: border-box;
        font-family: Roboto, sans-serif;
        font-size: .875rem;
    }

    .catalog__date-input input {
        padding-top: 12px; /* account for the abs pos label */
    }

/*
    Filter buttons
*/

.catalog__filter-controls,
.catalog__filter-share {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.catalog__filter-share {
    padding-top: 2rem;
}

    .catalog__filter-share p {
        font-size: .75rem;
        color: var(--sbr-neutral-gray-500);
        padding: .5rem;
    }

/*
	Catalog filters
*/

.catalog__filter-list {
    display: flex;
    flex-direction: column;
    padding: .5rem 0;
}

.catalog__filter {
    border-top: solid 1px var(--sbr-neutral-gray-250);
    padding: 1rem 0;
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

    .catalog__filter:last-child {
        border-bottom: solid 1px var(--sbr-neutral-gray-250);
    }

.catalog__filter-header {
    font-weight: 500;
    display: flex;
    align-items: center;
    cursor: pointer;
}

    .catalog__filter-header:after {
        font-size: 28px;
        font-family: sunbelticons;
        font-style: normal;
        content: ""; /* chevron down */
        color: var(--sbrgreen-500);
        margin-left: auto;
    }

.catalog__filter-choices {
    display: none;
}

.catalog__filter-choice {
    font-size: .875rem;
    margin-bottom: .5rem;
}

.catalog__filter-choice {
    display: flex;
    align-items: flex-start;
    gap: .5rem;
}

    .catalog__filter-choice label {
        margin: 0;
    }

.catalog__filter-header--open + .catalog__filter-choices {
    display: flex;
    flex-direction: column;
}

.catalog__filter-header--open:after {
    content: ""; /* chevron up */
}

.catalog__select-all-filter-choices {
    font-size: .875rem;
    font-weight: 500;
    cursor: pointer;
    color: var(--sbrgreen-500);
    text-align: left;
    border: none;
    background: transparent;
    margin-bottom: .5rem;
}

/*
    List View
*/

.catalog__results--list-view .catalog__results-list-headers,
.catalog__results--list-view .catalog__result-details {
    display: grid;
    grid-template-columns: minmax(0, 3fr) minmax(0, 2fr) minmax(0, 3fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
    align-items: center;
    gap: .5rem;
}

    .catalog__results--list-view .catalog__results-list-headers > *,
    .catalog__results--list-view .catalog__result-details > * {
        padding: 1rem;
    }

.catalog__results--list-view .catalog__results-list-headers {
    font-size: 0.875rem;
}

    .catalog__results--list-view .catalog__results-list-headers a {
        text-decoration: none;
        color: var(--sbrgreen-500) !important;
        font-weight: 500;
    }

.catalog__results--list-view .catalog__result-details {
    font-size: 0.75rem;
}

.catalog__results--list-view .catalog__result-image,
.catalog__results--list-view .catalog__result-desc {
    display: none;
}

.catalog__results--list-view .catalog__result:nth-child(even) {
    background: var(--sbr-neutral-gray-100);
}

.catalog__add-to-cart a {
    color: var(--sbrgreen-500) !important;
    text-decoration: none !important;
}

/*
    List/Grid Views
*/

.catalog__results--list-view .catalog__result-name a,
.catalog__results--grid-view .catalog__result-name a {
    font-weight: 500;
    color: var(--sbrgreen-500);
    text-decoration: none;
}

/*
    List View
*/

.catalog__results--list-view {
    container: results / inline-size;
}

@container results (max-width: 675px ) {
    .catalog__results--list-view .catalog__results-list-headers {
        display: none;
    }

    .catalog__results--list-view .catalog__result {
        border: 1px solid var(--sbr-neutral-gray-250);
        border-radius: var(--sbr-radius-4);
        margin: 1rem;
        padding: 1rem;
    }

        .catalog__results--list-view .catalog__result:nth-child(2n) {
            background: unset;
        }

    .catalog__results--list-view .catalog__result-details {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        grid-template-areas:
            "name name name"
            "delivery delivery delivery"
            "date date date"
            "location zip ."
            "price . add-to-cart";
        align-items: center;
        gap: .5rem;
    }

        .catalog__results--list-view .catalog__result-details p {
            padding: 0;
            margin-bottom: .5rem;
        }

            .catalog__results--list-view .catalog__result-details p:before {
                content: attr(data-label);
                display: block;
                border-bottom: 1px solid var(--sbr-neutral-gray-100);
                margin-bottom: .25rem;
                font-weight: 700;
            }

            .catalog__results--list-view .catalog__result-details p.catalog__add-to-cart:before {
                border-color: transparent;
            }

    .catalog__results--list-view .catalog__result-name {
        grid-area: name;
        font-weight: 700;
    }

    .catalog__results--list-view .catalog__result-delivery {
        grid-area: delivery;
    }

    .catalog__results--list-view .catalog__result-date {
        grid-area: date;
    }

    .catalog__results--list-view .catalog__result-loc {
        grid-area: location;
    }

    .catalog__results--list-view .catalog__result-zip {
        grid-area: zip;
    }

    .catalog__results--list-view .catalog__result-price {
        grid-area: price;
    }

    .catalog__results--list-view .catalog__add-to-cart {
        grid-area: add-to-cart;
        justify-self: end;
    }
}
/*
    Grid View
*/

.catalog__results--grid-view {
    container-type: inline-size;
}

    .catalog__results--grid-view .catalog__result-items {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 1rem;
        border: none;
    }

    .catalog__results--grid-view .catalog__no-results-message {
        grid-column: span 3;
    }

@container (max-width: 700px ) {
    .catalog__results--grid-view .catalog__result-items {
        grid-template-columns: 1fr 1fr;
    }

    .catalog__results--grid-view .catalog__no-results-message {
        grid-column: span 2;
    }
}

@container (max-width: 475px ) {
    .catalog__results--grid-view .catalog__result-items {
        grid-template-columns: 1fr;
    }

    .catalog__results--grid-view .catalog__no-results-message {
        grid-column: span 1;
    }
}

.catalog__results--grid-view .catalog__results-list-headers {
    display: none;
}

.catalog__results--grid-view .catalog__result {
    border: solid 1px var(--sbr-neutral-gray-250);
    border-radius: var(--sbr-radius-4);
    display: flex;
    flex-direction: column;
    font-size: .875rem;
}

.catalog__results--grid-view .catalog__result-image img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    border-radius: var(--sbr-radius-4);
}

.catalog__results--grid-view .catalog__result-details {
    padding: 1rem;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto 1fr;
    grid-template-areas:
        "delivery"
        "name"
        "dsecription"
        "price";
    align-items: end;
    flex: 1;
}

.catalog__results--grid-view .catalog__result-name {
    grid-area: name;
    margin-top: 1rem;
}

.catalog__results--grid-view .catalog__result-desc {
    grid-area: dsecription;
    margin-top: 1rem;
}

.catalog__results--grid-view .catalog__result-delivery {
    grid-area: delivery;
}

.catalog__results--grid-view .catalog__result-date {
    display: none;
}

.catalog__results--grid-view .catalog__result-loc {
    display: none;
}

.catalog__results--grid-view .catalog__result-zip {
    display: none;
}

.catalog__results--grid-view .catalog__result-price {
    grid-area: price;
    margin-top: 1rem;
}

.catalog__results--grid-view .catalog__add-to-cart {
    display: none;
}

.catalog__results--grid-view .catalog__result-delivery span {
    background: var(--sbr-brand-green-100);
    border-radius: var(--sbr-radius-4);
    padding: .25rem .75rem;
    font-size: .75rem;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: .25rem;
}

    .catalog__results--grid-view .catalog__result-delivery span:before {
        content: '';
        display: inline-block;
        background-image: url('https://via.placeholder.com/150');
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
        width: 1.75rem;
        aspect-ratio: 1/1;
        margin-right: 10px;
    }

.catalog__results--grid-view .catalog__result-delivery--elearning span:before {
    background-image: url('/uploads/images/delivery-elearning.png');
}

.catalog__results--grid-view .catalog__result-delivery--in-person span:before {
    background-image: url('/uploads/images/delivery-classroom.png');
}

.catalog__results--grid-view .catalog__result-delivery--v-ilt span:before {
    background-image: url('/uploads/images/delivery-virtual.png');
}

.catalog__results--grid-view .catalog__result-delivery--blended span:before {
    background-image: url('/uploads/images/delivery-blended.png');
}

.catalog__results--grid-view .catalog__result-name span {
    font-weight: 700;
}

.catalog__results--grid-view .catalog__result-desc span {
    font-size: .75rem;
}

.catalog__results--grid-view .catalog__result-price span {
    font-weight: 500;
}

/*
    Calendar View
*/

.catalog__calendar {
    container: calendar / inline-size;
}

    .catalog__calendar > table {
        border: solid 1px var(--sbr-neutral-gray-250);
        margin: 0;
        font-size: .875rem;
    }
    /* Month header and nav are in a nested table */
    .catalog__calendar table.catalog__cal-title,
    .catalog__calendar table.catalog__cal-title :is(th,td) {
        border: none;
        margin: 0;
        vertical-align: middle;
        text-align: center;
    }

        .catalog__calendar table.catalog__cal-title td:first-child {
            text-align: left;
        }

        .catalog__calendar table.catalog__cal-title td:last-child {
            text-align: right;
        }

    .catalog__calendar table.catalog__cal-title {
        font-size: 1.25rem;
        font-weight: 700;
        text-transform: uppercase;
    }

        .catalog__calendar table.catalog__cal-title a {
            text-decoration: none;
            color: var(--sbrgreen-500) !important;
            font-size: 2rem;
        }

        .catalog__calendar table.catalog__cal-title .icon {
            font-size: 36px;
        }

    .catalog__calendar > table th {
        color: var(--sbr-text-color);
        border: solid 1px var(--sbr-neutral-gray-250);
    }

    .catalog__calendar > table td {
        color: var(--sbr-text-color);
        border: solid 1px var(--sbr-neutral-gray-250);
        padding: 0;
    }

.catalog__cal-day-content {
    min-height: 125px;
}

.catalog__cal-day-num {
    padding: .25rem;
    font-size: .9rem;
}

.catalog__cal-day--other-month .catalog__cal-day-num {
    color: var(--sbr-neutral-gray-250);
}

.catalog__cal-day-events {
    padding: .25rem;
    font-size: .75rem;
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.catalog__cal-day-event {
    padding: .25rem;
    border-radius: var(--sbr-radius-4);
    background: var(--sbr-neutral-gray-100);
}

    .catalog__cal-day-event a {
        text-decoration: none;
        color: var(--sbrgreen-500) !important;
    }

@container calendar (max-width: 760px) {
    .catalog__calendar > table > tbody tr:nth-child(2) { /* day header row */
        display: none;
    }

    .catalog__calendar > table > tbody tr:nth-child(n+3) { /* week rows */
        display: flex;
        flex-direction: column;
    }

        .catalog__calendar > table > tbody tr:nth-child(n+3) .catalog__cal-day {
            width: 100% !important; /* this is necessary to override the inline style */
            box-sizing: border-box;
        }

        .catalog__calendar > table > tbody tr:nth-child(n+3) .catalog__cal-day--other-month {
            display: none;
        }

    .catalog__calendar .catalog__cal-day-content {
        min-height: unset;
    }

    .catalog__calendar .catalog__cal-day-events {
        flex-direction: row;
        flex-wrap: wrap;
        gap: .75rem;
    }

        .catalog__calendar .catalog__cal-day-events:empty {
            padding: 0;
        }
}

/*
    Active sorting icons
*/

.catalog__results-list-headers[data-sort] a:after {
    margin-left: .25rem;
}

.catalog__results-list-headers[data-sort="name-asc"] .catalog__sort-name:after {
    content: "▲";
}

.catalog__results-list-headers[data-sort="name-desc"] .catalog__sort-name:after {
    content: "▼"
}

.catalog__results-list-headers[data-sort="delivery-asc"] .catalog__sort-delivery:after {
    content: "▲";
}

.catalog__results-list-headers[data-sort="delivery-desc"] .catalog__sort-delivery:after {
    content: "▼"
}

.catalog__results-list-headers[data-sort="date-asc"] .catalog__sort-date:after {
    content: "▲";
}

.catalog__results-list-headers[data-sort="date-desc"] .catalog__sort-date:after {
    content: "▼"
}

.catalog__results-list-headers[data-sort="location-asc"] .catalog__sort-location:after {
    content: "▲";
}

.catalog__results-list-headers[data-sort="location-desc"] .catalog__sort-location:after {
    content: "▼"
}

.catalog__results-list-headers[data-sort="zip-asc"] .catalog__sort-zip:after {
    content: "▲";
}

.catalog__results-list-headers[data-sort="zip-desc"] .catalog__sort-zip:after {
    content: "▼"
}

.catalog__results-list-headers[data-sort="price-asc"] .catalog__sort-price:after {
    content: "▲";
}

.catalog__results-list-headers[data-sort="price-desc"] .catalog__sort-price:after {
    content: "▼"
}
/*
    Active view icons
*/

.catalog__view-select[data-current-view="list"] a.catalog__view-list {
    background: var(--sbr-neutral-gray-250);
}

.catalog__view-select[data-current-view="grid"] a.catalog__view-grid {
    background: var(--sbr-neutral-gray-250);
}

.catalog__view-select[data-current-view="calendar"] a.catalog__view-calendar {
    background: var(--sbr-neutral-gray-250);
}
