.specials .dish-card {
    background-color: #e0e0e0;
    border-radius: 0.5rem;
    overflow: hidden;
    margin: 1rem;
    padding: 0.25rem;
}

.specials .dish-card img {
    border-radius: 0.25rem 0.25rem 0 0;
    mask-image: url("../images/mask.png");
    mask-size: contain;
    aspect-ratio: 3/2;
    object-fit: cover;
}

.specials .dish-card>div {
    padding: 0.75rem;
    color: var(--c3);
}

/* menu tabs */
.menu {
    --br: 16px;
    --o: 8px;
}

.menu-tabs {
    text-align: center;
    z-index: 2;
}

.menu-tabs button {
    /* text-transform: uppercase; */
    color: var(--c4);
    border: none;
    background-color: transparent;
    position: relative;
    opacity: 0.7;
    border-bottom: 4px solid transparent;
    transition: all ease 300ms;
}

.menu-tabs button.active,
.menu-tabs button:hover,
.menu-tabs button:active,
.menu-tabs button:focus {
    opacity: 1;
    color: var(--c2);
}

.menu-tabs button.active {
    opacity: 1;
    color: var(--c1);
}

.menu-tabs button::after {
    content: "";
    position: absolute;
    bottom: -4px;
    left: 0;
    height: 4px;
    width: 100%;
    background-color: transparent;
    transition: all ease 300ms;
    transform: scaleX(0);
}

.menu-tabs button.active::after {
    background-color: var(--c1);
    transform: scaleX(1);
}

.menu-tabs button:not(.active):hover::after {
    background-color: var(--c2);
    transform: scaleX(0.5);
}

/* dishes */
.menu .row .dish-item {
    padding: 0.25rem;
}

/* .dishes .container-fluid {
    max-height: calc(90vh - 3rem);
    overflow-y: auto;
    scrollbar-width: thin;
    mask-image: linear-gradient(to bottom, black 95%, transparent);
    -webkit-mask-image: linear-gradient(to bottom, black 95%, transparent);
} */

.dishes .menu-tabs {
    --t: 0px;
    position: -webkit-sticky;
    position: sticky;
    top: calc(var(--t) + var(--o));
    padding-top: 1rem;
    background-color: #2c3034;
    border-radius: 0 0 var(--br) var(--br);
}

.dishes .container-fluid .row {
    padding-bottom: 2rem;
}

.menu h2 {
    padding: 0.7rem 0;
    background-color: #2c3034;
    position: -webkit-sticky;
    position: sticky;
    top: var(--o);
    z-index: 2;
    border-radius: var(--br) var(--br) 0 0;
}

.menu .dish-card {
    padding: 1rem;
    background-color: hsl(0, 0%, 30%);
    border-radius: 0.5rem;
    box-shadow: 0 0 10px hsl(0, 0%, 10%);
    height: 100%;
    transition: all ease 300ms;
    position: relative;
}

.menu .dish-card:hover {
    background-color: var(--c7);
    color: var(--bg);
    transform: scale(1.05);
    cursor: default;
    z-index: 1;
}

.menu .dish-card hr {
    color: var(--c2);
    opacity: 1;
    width: 10%;
    margin-left: auto;
    margin-right: auto;
    transition: all cubic-bezier(0.48, 0.28, 0.62, 1.44) 300ms;
}

.menu .dish-card:hover hr {
    color: var(--c1);
    opacity: 1;
    width: 90%;
}

.menu .dish-card .dish-name {
    line-height: 1;
    transition: all ease 300ms, transform ease 300ms 200ms;
}

.menu .dish-card:hover .dish-name {
    transform: scaleX(1.1);
}

.menu .dish-card .price {
    font-weight: 500;
    letter-spacing: 1px;
    margin-bottom: 0;
}

.menu .dish-card img {
    border-radius: 0.25rem 0.25rem 0 0;
    mask-image: url("../images/mask.png");
    mask-size: contain;
    aspect-ratio: 3/2;
    object-fit: cover;
}

@media screen and (min-width: 768px) {
    .menu .row .dish-item {
        padding: 0.5rem;
    }
}