:root {
    --BaseColor: #080;
    --BaseColorDark: #040;
}
* {
    margin: 0; padding: 0;
    text-decoration: none;
    scrollbar-width: none;
    box-sizing: border-box;
    font-family: 'Nunito Sans';
}
body {
    width: 100svw; height: 100svh;
    font-size: min(2.25vmin, 16px + 0.25vmin);

    overflow-x: clip; overflow-y: auto;
}
::-webkit-scrollbar {
    width: 0px; display: none;
}


.MainContainer {
    padding-top: 6em;
    background-color: #ddd;
    width: 100%; min-height: 100%;

    display: flex;
    flex-direction: column;
    justify-content: stretch;
    align-items: stretch;
}

.Navigation {
    background-color: #fff;
    width: 100%; height: 4em;
    box-shadow: 0em 0.25em 0.25em rgba(0, 0, 0, 0.15),
        inset 0em -0.15em 0.15em rgba(0, 0, 0, 0.4);

    position: fixed;
    top: 0; z-index: 1000;
}
.Navigation .Container {
    padding: 0.6em 1em;
    width: min(100%, 90em);
    margin: auto; height: 100%;

    display: flex; gap: 1em;
    justify-content: space-between;
    align-items: center;
}
.Navigation .CompanyName {
    outline: none;
    color: var(--BaseColor);
    text-transform: uppercase;
    font: 900 1.85em Montserrat;
}
.Navigation .DeliveryLocation {
    cursor: pointer;

    display: flex; gap: 0.25em;
    align-items: center;
}
.Navigation .DeliveryLocation img {
    object-fit: contain;
    object-position: center;
    height: 1.5em; aspect-ratio: 1;
}
.Navigation .DeliveryLocation .Title {
    font: 700 0.8em Poppins;
    text-transform: uppercase;
}
.Navigation .DeliveryLocation .Address {
    white-space: nowrap;
    font: 400 0.9em 'Merriweather Sans';
}
.Navigation .SearchBar {
    padding-left: 1.25em;
    flex: 1 1; max-width: 40em;

    display: flex;
    justify-content: stretch;
    position: relative;
}
.Navigation .SearchBar .CategoryFilter {
    cursor: pointer; position: relative;
}
.Navigation .SearchBar .Selected {
    height: 100%; color: #fff;

    display: flex;
    align-items: center;
    position: relative;
    z-index: 1;
}
.Navigation .SearchBar .Selected span {
    white-space: nowrap;
    text-transform: uppercase;
    font: 700 0.9em 'Merriweather Sans';
}
.Navigation .SearchBar .Selected::before {
    content: '';
    border-radius: 2em;
    width: calc(100% + 2.5em);
    height: calc(100% + 0.5em);
    background-color: var(--BaseColor);

    position: absolute;
    top: 50%; left: 50%;
    translate: -50% -50%;
    z-index: -1;
}
.Navigation .SearchBar .SearchContainer {
    width: 100%; position: relative;
}
.Navigation .SearchBar #SearchInput {
    width: 100%; outline: none;
    border: 0.25em solid #000;
    font: 700 0.9em 'Nunito Sans';
    padding: 0.4em 3em 0.4em 1.5em;
    border-radius: 0em 2em 2em 0em;
}
.Navigation .SearchBar .SearchIcon {
    cursor: pointer;
    background-color: #888;
    height: 50%; aspect-ratio: 1;

    position: absolute;
    top: 50%; right: 1em;
    translate: 0% -50%;
    mask-size: contain;
    -webkit-mask-size: contain;
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-image: url('Search.svg');
    -webkit-mask-image: url('Search.svg');
}
.Navigation .SearchBar:hover .SearchIcon {
    background-color: #000;
}
.Navigation .SearchBar .Options {
    max-height: 15em;
    border-radius: 1em;
    background-color: #fff;
    min-width: 100%; padding: 0.5em;
    box-shadow: 0em 0em 0.5em 0.25em rgba(0, 0, 0, 0.3);

    position: absolute; left: 50%;
    display: flex; gap: 0.2em;
    flex-direction: column;
    translate: -50% 0%;
    overflow-y: auto;
}
.Navigation .SearchBar .Options div {
    cursor: pointer;
    text-align: center;
    white-space: nowrap;
    border-radius: 0.75em;
    padding: 0.4em 0.75em;
    font: 600 0.9em 'Merriweather Sans';

    user-select: none;
    -webkit-user-select: none;

    transition: 0.15s ease-out;
}
.Navigation .SearchBar .Options div:hover {
    background-color: rgba(0, 0, 0, 0.1);
}
.Navigation .SearchBar .Options .Active {
    background-color: rgba(0, 0, 0, 0.2) !important;
}
.Navigation .SearchBar .SearchContainer .Options {
    margin-top: 0.25em;
    min-width: calc(100% - 3em);
}
.Navigation .Cart {
    cursor: pointer;
    border-radius: 0.75em;
    padding: 0.2em 0.75em;
    height: 90%; outline: none;
    border: 0.2em solid #000;

    display: flex; gap: 0.25em;
    justify-content: center;
    align-items: center;
    position: relative;
}
.Navigation .Cart img {
    object-fit: cover;
    object-position: center;
    height: 75%; aspect-ratio: 1;
}
.Navigation .Cart span {
    color: #000;
    font: 700 1em Montserrat;
}
.Navigation .Cart .Counter {
    color: #fff;
    padding: 0.1em 0.5em;
    border-radius: 0.75em;
    font: 700 0.85em Poppins;
    background-color: var(--BaseColor);

    position: absolute;
    top: 0%; right: 0%;
    translate: 40% -40%;
}
.Navigation .UserProfile {
    outline: none;
    border-radius: 0.5em;
    height: 95%; aspect-ratio: 1;
    border: 0.2em solid #000;

    overflow: clip;
}
.Navigation .UserProfile.Small {
    border: none; height: 75%;
}
.Navigation .UserProfile img {
    object-fit: cover;
    object-position: center;
    width: 100%; height: 100%;
}

.LocationSelector {
    padding: 0.75em 2em;
    background-color: #fff;
    width: 100%; height: 14em;

    display: flex;
    flex-direction: column;
    position: fixed;
    bottom: 0; z-index: 1000;
    transition: 0.25s ease-out;
}
.LocationSelector.Hidden {
    transform: translateY(100%);
}
.LocationSelector .Header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.LocationSelector .Header .Title {
    font: 700 1.5em Poppins;

    display: flex;
    align-items: center;
}
.LocationSelector .Header .Title img {
    object-fit: contain;
    padding-bottom: 0.15em;
    object-position: center;
    height: 1.25em; aspect-ratio: 1;
}
.LocationSelector .Header .Options {
    display: flex;
    align-items: center;
}
.LocationSelector .Header .Options div {
    cursor: pointer;
    text-align: center;
    border-radius: 2.5em;
    font: 700 1em Poppins;
    padding: 0.25em 1.25em;
    text-transform: uppercase;
}
.LocationSelector .Header .Options .Active {
    color: #fff; background-color: var(--BaseColor);
}
.LocationSelector .Display {
    flex: 1 1 100%;
    padding: 0.75em 1.5em 0.25em;

    display: flex; gap: 1em;
    align-items: center;
    overflow: auto;
}
.LocationSelector .Display.Hidden {
    display: none;
}
.LocationSelector .Display > div {
    height: 100%;
    cursor: pointer;
    min-width: 15em;
    padding: 0.5em 1em;
    border-radius: 0.75em;
    border: 0.2em solid #000;

    display: flex;
    flex-direction: column;
}
.LocationSelector .Display .Name {
    margin-bottom: 0.25em;
    font: 700 1.2em Montserrat;
}
.LocationSelector .Display .Subline {
    color: #444;
    padding-top: 0.25em;
    font: 500 0.95em 'Merriweather Sans';
}
.LocationSelector .Display .AddLocation {
    border: 0.25em dashed #888;

    display: flex; gap: 0.75em;
    justify-content: center;
    flex-direction: column;
    align-items: center;
}
.LocationSelector .Display .AddLocation .Icon {
    background-color: #999;
    height: 2.75em; aspect-ratio: 1;

    mask-size: contain;
    -webkit-mask-size: contain;
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-image: url('Plus.svg');
    -webkit-mask-image: url('Plus.svg');
}
.LocationSelector .Display .Location {
    color: #005de9;
    margin-top: auto;
    font: 700 1em Poppins;
    border: none; outline: none;

    transition: 0.2s ease-out;
    display: flex; gap: 0.25em;
    justify-content: end;
    align-items: center;
}
.LocationSelector .Display .Location:hover {
    color: #0028ac;
}
.LocationSelector .Display .Location .Icon {
    background-color: #005de9;
    height: 1em; aspect-ratio: 1;

    mask-image: url('Location.svg');
    -webkit-mask-image: url('Location.svg');
    mask-size: contain;
    -webkit-mask-size: contain;
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;

    transition: 0.2s ease-out;
}
.LocationSelector .Display .Location:hover .Icon {
    background-color: #0028ac;
}

.MainFooter {
    margin-top: 2.5em;
    background-color: var(--BaseColorDark);

    display: flex;
    flex-direction: column;
    align-items: center;
}
.MainFooter .Top {
    color: #fff;
    width: min(100%, 85em);
    padding: 2.5em 1em 1.5em;

    display: flex; gap: 10em;
}
.MainFooter .Top .CompanyName {
    background-color: #fff;
    height: 1.75em; width: 21.8em;

    mask-size: contain;
    -webkit-mask-size: contain;
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-image: url('CompanyName.webp');
    -webkit-mask-image: url('CompanyName.webp');
}
.MainFooter .Top .Description {
    padding-left: 1em;
    padding-top: 0.5em;
    text-align: justify;
    font: 500 1.1em 'Nunito Sans';
}
.MainFooter .Top .Title {
    text-align: center;
    margin-bottom: 0.5em;
    font: 600 1.25em Poppins;
}
.MainFooter .Top .Contact, .MainFooter .Top a {
    color: #fff;
    text-align: center;
    white-space: nowrap;
    padding-bottom: 0.5em;
    font: 300 0.9em 'Merriweather Sans';

    transition: 0.2s ease-out;
    display: block;
}
.MainFooter .Top a:hover {
    text-decoration: underline;
    text-underline-offset: 0.2em;
    text-decoration-thickness: 0.05em;
}
.MainFooter .Bottom {
    padding: 0.5em 1em;
    width: min(100%, 90em);
    border-top: 0.15em solid #fff;

    display: flex;
    justify-content: space-between;
    align-items: center;
}
.MainFooter .Bottom .Copyright {
    color: #fff;
    font: 600 0.85em Poppins;
}
.MainFooter .Bottom .Links {
    display: flex; gap: 0.75em;
}
.MainFooter .Bottom .Links a {
    font: 400 0.8em Poppins;
    color: #fff; cursor: pointer;

    transition: 0.2s ease-out;
}
.MainFooter .Bottom .Links a:hover {
    text-decoration: underline;
    text-underline-offset: 0.2em;
    text-decoration-thickness: 0.05em;
}


@media screen and (max-aspect-ratio: 2) {
    .MainFooter .Top {gap: 7.5em;}
}
@media screen and (max-aspect-ratio: 1.6) {
    .Navigation .CompanyName {display: none;}

    .MainFooter .Top {gap: 2.5em;}
}
@media screen and (max-aspect-ratio: 1.375) {
    .MainFooter .Top {flex-direction: column;}
    .MainFooter .Top .CompanyName {margin: auto;}
    .MainFooter .Top .Description {
        padding-left: 0em;
        text-align: center;
        max-width: 35em; margin: auto;
    }
}
@media screen and (min-aspect-ratio: 0.6) and (max-aspect-ratio: 1.25) {
    .Navigation .SearchBar {
        padding-left: 0.875em;
        flex: 1 1; max-width: 25em;
    }
    .Navigation .SearchBar .Selected span {
        max-width: 7.5em;

        text-overflow: ellipsis;
        overflow: hidden;
    }
    .Navigation .SearchBar .Selected::before {
        width: calc(100% + 1.75em);
        height: calc(100% + 0.3em);
    }
    .Navigation .SearchBar #SearchInput {padding-left: 1em;}
    .Navigation .Cart img {display: none;}
}
@media screen and (max-aspect-ratio: 0.6) {
    body {font-size: 3.25vmin;}

    .MainContainer {
        padding-top: 7.75em;
    }

    .Navigation .DeliveryLocation {
        margin-right: 5em;
    }
    .Navigation .SearchBar {
        padding: 0.75em 0em;
        padding-left: 1em;
        background-color: #fff;
        max-width: unset; width: 100%;
        box-shadow: 0em 0.25em 0.25em rgba(0, 0, 0, 0.15),
            inset 0em -0.15em 0.15em rgba(0, 0, 0, 0.4);

        position: absolute;
        justify-content: center;
        top: 100%; left: 0%;
        z-index: -1;
    }
    .Navigation .SearchBar .Selected::before {
        width: calc(100% + 1.75em);
        height: calc(100% + 0.3em);
    }
    .Navigation .SearchBar .InputSection {
        width: 55%;
    }

    .MainFooter .Bottom {flex-direction: column;}
}