/**
 * @author : Kavithma Thushal
 * @project : Hello-Shoes-FrontEnd
 * @since : 2:02 PM - 4/20/2024
 **/

:root {

    /**
     * colors
     */

    --rich-black-fogra-29: hsl(210, 26%, 7%);
    --champagne-pink_20: hsla(23, 61%, 86%, 0.2);
    --independence_30: hsla(245, 17%, 29%, 0.3);
    --gray-x-11-gray: hsl(0, 0%, 73%);
    --champagne-pink: hsl(23, 61%, 86%);
    --spanish-gray: hsl(0, 0%, 60%);
    --sonic-silver: hsl(0, 0%, 47%);
    --deep-saffron: hsl(32, 100%, 59%);
    --dark-orange: hsl(28, 100%, 58%);
    --desert-sand: hsl(23, 49%, 82%);
    --isabelline: hsl(38, 44%, 96%);
    --gainsboro: hsl(0, 0%, 87%);
    --tangerine: hsl(31, 84%, 50%);
    --cinnabar: hsl(3, 90%, 55%);
    --black_95: hsla(0, 0%, 0%, 0.95);
    --cultured: hsl(0, 0%, 93%);
    --white: hsl(0, 0%, 100%);
    --black: hsl(0, 0%, 0%);
    --onyx: hsl(0, 0%, 27%);

    /**
     * typography
     */

    --ff-shadows-into-light: 'Shadows Into Light', cursive;
    --ff-roboto: 'Roboto', sans-serif;
    --ff-rubik: 'Rubik', sans-serif;

    --fs-1: 3.2rem;
    --fs-2: 2.2rem;
    --fs-3: 1.8rem;
    --fs-4: 1.4rem;
    --fs-5: 1.2rem;

    --fw-500: 500;
    --fw-600: 600;
    --fw-700: 700;

    /**
     * spacing
     */

    --section-padding: 60px;

    /**
     * shadow
     */

    --shadow-1: 0 1px 4px hsla(0, 0%, 0%, 0.2);
    --shadow-2: 0 1px 2px hsla(0, 0%, 0%, 0.2);

    /**
     * transition
     */

    --transition-1: 0.25s ease;
    --transition-2: 0.5s ease;

    /**
     * clip path
     */

    --clip-path-1: polygon(0 40%, 100% 0%, 100% 100%, 0 100%);
    --clip-path-2: polygon(0 0%, 100% 0%, 100% 100%, 0 100%);

}


/*-----------------------------------*\
  #RESET
\*-----------------------------------*/

*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

li {
    list-style: none;
}

a {
    text-decoration: none;
    color: inherit;
}

a,
img,
svg,
span,
input,
select,
button,
textarea,
ion-icon {
    display: block;
}

img {
    height: auto;
}

input,
select,
button,
textarea {
    background: none;
    border: none;
    font: inherit;
}

input,
select,
textarea {
    width: 100%;
}

button {
    cursor: pointer;
}

ion-icon {
    pointer-events: none;
}

address {
    font-style: normal;
}

html {
    font-family: var(--ff-roboto);
    font-size: 10px;
    scroll-behavior: smooth;
}

body {
    background-color: var(--white);
    color: var(--sonic-silver);
    font-size: 1.6rem;
    line-height: 1.6;
    overflow-x: hidden;
}

body.active {
    overflow: hidden;
}

:focus-visible {
    outline-offset: 4px;
}

::selection {
    background-color: var(--deep-saffron);
    color: var(--white);
}

::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background-color: var(--cultured);
}

::-webkit-scrollbar-thumb {
    background-color: var(--deep-saffron);
}

::-webkit-scrollbar-thumb:hover {
    background-color: var(--tangerine);
}


/*-----------------------------------*\
  #REUSED STYLE
\*-----------------------------------*/

.container {
    padding-inline: 15px;
}

.h1,
.h2,
.h3,
.h4 {
    font-family: var(--ff-rubik);
    color: var(--rich-black-fogra-29);
    line-height: 1.2;
    letter-spacing: -1px;
}

.h1,
.h2 {
    font-size: var(--fs-1);
}

.h2,
.h3,
.h4 {
    font-weight: var(--fw-600);
}

.h3 {
    font-size: var(--fs-2);
}

.h4 {
    font-size: var(--fs-3);
}

.btn1 {
    background-color: var(--bg-color, var(--deep-saffron));
    color: var(--white);
    font-family: var(--ff-rubik);
    font-size: var(--fs-4);
    font-weight: var(--fw-500);
    height: var(--height, 45px);
    padding-inline: var(--padding-inline, 35px);
    transition: var(--transition-1);
}

.btn-hover {
    position: relative;
    overflow: hidden;
    z-index: 1;
}

.btn-hover::after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 20px;
    width: 1px;
    height: 1px;
    transform: translate(-50%, 51%) scale(var(--scale, 1));
    border-radius: 50%;
    background-color: var(--rich-black-fogra-29);
    z-index: -1;
    transition: var(--transition-2);
}

.btn-hover:is(:hover, :focus)::after {
    --scale: 500;
}

.section {
    padding-block: var(--section-padding);
}

.section.white {
    background-color: var(--isabelline);
}

.section-divider {
    position: relative;
}

.section-divider::before,
.section-divider::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 15px;
    background-repeat: repeat no-repeat;
    background-position: bottom;
}

.section-divider.white::after {
    background-image: url("../images/shape-white.png");
}

.section-divider.gray::after {
    background-image: url("../images/shape-grey.png");
}

.w-100 {
    width: 100%;
}

.has-scrollbar {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    scroll-snap-type: inline mandatory;
    padding-block-end: 40px;
}

.has-scrollbar::-webkit-scrollbar {
    height: 12px;
}

.has-scrollbar::-webkit-scrollbar-button {
    width: calc(25% - 40px);
}

.has-scrollbar::-webkit-scrollbar-track {
    outline: 2px solid var(--deep-saffron);
    border-radius: 50px;
}

.has-scrollbar::-webkit-scrollbar-thumb {
    border: 3px solid var(--cultured);
    border-radius: 50px;
}

.section-title > .span {
    display: inline-block;
    color: var(--deep-saffron);
}

.abs-img {
    position: absolute;
    transform: scale(1);
}

.scale-up-anim {
    animation: scaleUp 1s linear infinite alternate;
}

@keyframes scaleUp {
    0% {
        transform: scale(1);
    }

    100% {
        transform: scale(1.05);
    }
}

.section-subtitle {
    color: var(--cinnabar);
    font-family: var(--ff-rubik);
    text-align: center;
    font-weight: var(--fw-500);
}

.badge {
    position: absolute;
    background: var(--bg-color, var(--cinnabar));
    color: var(--white);
    font-size: var(--fs-5);
    font-weight: var(--fw-600);
    padding: var(--padding-block, 2px) 15px;
}

.rating-wrapper {
    display: flex;
    gap: 5px;
    color: var(--deep-saffron);
}


/*-----------------------------------*\
  #NAVIGATION
\*-----------------------------------*/

.header-btn-group .btn1 {
    display: none;
}

.header {
    --color: var(--white);
    --btn-color: var(--champagne-pink);

    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    padding-block: 20px;
    border-block-end: 1px solid var(--champagne-pink_20);
    z-index: 4;
}

.header.active {
    --color: var(--rich-black-fogra-29);
    --btn-color: var(--rich-black-fogra-29);

    position: fixed;
    top: -86px;
    background-color: var(--white);
    box-shadow: var(--shadow-1);
    animation: slideIn 0.5s ease-out forwards;
}

@keyframes slideIn {
    0% {
        transform: translateY(0);
    }

    100% {
        transform: translateY(100%);
    }
}

.header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo {
    color: var(--color);
    font-family: var(--ff-rubik);
    font-size: 2.8rem;
    font-weight: var(--fw-700);
    letter-spacing: -2px;
}

.logo .span {
    display: inline-block;
    color: var(--deep-saffron);
}

.header-btn-group {
    display: flex;
    align-items: center;
    gap: 20px;
}

.search-btn {
    color: var(--btn-color);
    font-size: 20px;
}

.search-btn ion-icon {
    --ionicon-stroke-width: 50px;
}

.nav-toggle-btn {
    display: grid;
    gap: 4px;
}

.line {
    width: 10px;
    height: 3px;
    background-color: var(--btn-color);
    border-radius: 5px;
    transition: var(--transition-1);
}

.line.middle {
    width: 20px;
}

.line.bottom {
    margin-left: auto;
}

.nav-toggle-btn.active .line.top {
    transform: translate(1px, 3px) rotate(45deg);
}

.nav-toggle-btn.active .line.middle {
    transform: rotate(-45deg);
}

.nav-toggle-btn.active .line.bottom {
    transform: translate(-1px, -3px) rotate(45deg);
}

.navbar {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 30px);
    background-color: var(--white);
    padding-inline: 20px;
    box-shadow: var(--shadow-1);
    height: 0;
    overflow: hidden;
    visibility: hidden;
    transition: var(--transition-1);
}

.navbar.active {
    height: 236px;
    visibility: visible;
}

.navbar-list {
    margin-block: 10px;
}

.nav-item:not(:last-child) {
    border-block-end: 1px solid hsla(0, 0%, 0%, 0.04);
}

.navbar-link {
    color: var(--rich-black-fogra-29);
    font-size: var(--fs-4);
    font-family: var(--ff-rubik);
    font-weight: var(--fw-500);
    padding: 10px 15px;
    transition: var(--transition-1);
}

.navbar-link:is(:hover, :focus) {
    color: var(--dark-orange);
}


/*-----------------------------------*\
  #SEARCH BOX
\*-----------------------------------*/

.search-container {
    position: fixed;
    top: -60%;
    left: 0;
    width: 100%;
    height: 110%;
    background-color: var(--black_95);
    display: flex;
    justify-content: center;
    align-items: center;
    padding-inline: 15px;
    z-index: 5;
    visibility: hidden;
    opacity: 0;
    transition: var(--transition-2);
}

.search-container.active {
    visibility: visible;
    opacity: 1;
    transform: translateY(50%);
}

.search-box {
    position: relative;
    width: 100%;
    max-width: 500px;
}

.search-input {
    color: var(--gainsboro);
    font-size: 3rem;
    padding: 20px 15px;
    padding-inline-end: 70px;
}

.search-input::placeholder {
    color: var(--spanish-gray);
}

.search-input::-webkit-search-cancel-button {
    display: none;
}

.search-submit {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 15px;
    color: var(--onyx);
    font-size: 4rem;
    transition: var(--transition-1);
}

.search-submit:is(:hover, :focus) {
    color: var(--gainsboro);
}

.search-close-btn {
    position: absolute;
    inset: 0;
    z-index: -1;
    cursor: pointer;
}


/*-----------------------------------*\
  #Home
\*-----------------------------------*/

.hero-banner {
    display: none;
}

.hero {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    padding-block: 145px 60px;
    text-align: center;
}

.hero-subtitle {
    color: var(--dark-orange);
    font-family: var(--ff-shadows-into-light);
    font-size: var(--fs-3);
    letter-spacing: 1px;
    margin-block-end: 25px;
}

.hero-title {
    color: var(--champagne-pink);
    max-width: 12ch;
    margin-inline: auto;
}

.hero-text {
    color: var(--desert-sand);
    margin-block: 15px 30px;
    max-width: 44ch;
    margin-inline: auto;
}

.hero .btn1 {
    margin-inline: auto;
}

.hero .btn1:is(:hover, :focus) {
    background-color: var(--white);
    color: var(--black);
}


/*-----------------------------------*\
  #ABOUT
\*-----------------------------------*/

.about {
    text-align: center;
}

.about-banner {
    position: relative;
    aspect-ratio: 1 / 0.9;
}

.about-img {
    max-width: max-content;
    margin-inline: auto;
}

.about-banner .abs-img {
    top: 0;
    left: 100px;
}

.about .section-title {
    max-width: 15ch;
    margin-block: 40px 10px;
    margin-inline: auto;
}

.about-list {
    margin-block: 20px 30px;
}

.about-item {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
}

.about-item:not(:last-child) {
    margin-block-end: 10px;
}

.about-item ion-icon {
    background-color: var(--deep-saffron);
    color: var(--white);
    font-size: 1.2rem;
    padding: 4px;
    border-radius: 50%;
    --ionicon-stroke-width: 110px;
}

.about-item .span {
    color: var(--rich-black-fogra-29);
    font-family: var(--ff-rubik);
    font-weight: var(--fw-500);
}

.about .btn1 {
    margin-inline: auto;
}


/*-----------------------------------*\
  #SHOES
\*-----------------------------------*/

.food-menu {
    background-color: var(--isabelline);
    text-align: center;
}

.food-menu .section-title {
    margin-block: 10px 20px;
}

.food-menu .section-text {
    max-width: 44ch;
    margin-inline: auto;
    margin-block-end: 30px;
}

.fiter-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-block-end: 40px;
}

.filter-btn {
    background-color: var(--white);
    color: var(--color, var(--rich-black-fogra-29));
    font-family: var(--ff-rubik);
    font-weight: var(--fw-500);
    padding: 5px 20px;
    border: 1px solid var(--border-color, var(--cultured));
}

.filter-btn.active {
    background-color: var(--deep-saffron);
    --color: var(--white);
    --border-color: var(--deep-saffron);
}

.food-menu-list {
    display: grid;
    gap: 30px;
}

.food-menu-card {
    background-color: var(--white);
    padding: 40px;
    box-shadow: var(--shadow-2);
}

.food-menu-card:focus-within {
    outline: 1px auto -webkit-focus-ring-color;
}

.food-menu-card .card-banner {
    position: relative;
    padding-block-start: 30px;
    max-width: max-content;
    aspect-ratio: 1 / 1;
    margin-inline: auto;
}

.food-menu-card .badge {
    top: 0;
    left: 0;
}

.food-menu-btn {
    position: absolute;
    top: calc(50% + 15px);
    left: 50%;
    transform: translate(-50%, 0);
    min-width: max-content;
    --bg-color: var(--cinnabar);
    width: 60%;
    --height: 40px;
    --padding-inline: 20px;
    opacity: 0;
    transition: var(--transition-2);
}

.food-menu-btn:is(:hover, :focus) {
    --bg-color: var(--deep-saffron);
}

.food-menu-card:is(:hover, :focus-within) .food-menu-btn {
    transform: translate(-50%, -50%);
    opacity: 1;
}

.food-menu-card .wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
    margin-block: 20px 10px;
}

.food-menu-card .category {
    font-family: var(--ff-rubik);
    font-weight: var(--fw-500);
}

.food-menu-card .rating-wrapper {
    font-size: 1.4rem;
}

.food-menu-card .card-title {
    margin-block-end: 10px;
}

.food-menu-card .price-wrapper {
    display: flex;
    justify-content: center;
    gap: 5px;
    font-family: var(--ff-rubik);
    font-weight: var(--fw-600);
}

.food-menu-card .price-text {
    color: var(--cinnabar);
    text-transform: uppercase;
    padding-inline-end: 5px;
}

.food-menu-card .price {
    color: var(--deep-saffron);
}

.food-menu-card .del {
    color: var(--gray-x-11-gray);
}


/*-----------------------------------*\
  #CTA
\*-----------------------------------*/

.cta {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    text-align: center;
    overflow: hidden;
}

.cta::before {
    bottom: auto;
    top: 0;
    background-image: url("../images/shape-grey.png");
    transform: scaleY(-1);
}

.cta .section-title {
    color: var(--white);
    line-height: 1.5;
    letter-spacing: -2px;
    max-width: 17ch;
    margin-inline: auto;
}

.cta .section-text {
    color: var(--gainsboro);
    margin-block: 25px 20px;
}

.cta .btn1 {
    margin-inline: auto;
}

.cta-banner {
    position: relative;
    aspect-ratio: 1 / 0.9;
}

.cta-img {
    transform: scale(1.3) translateY(60px);
}

.cta-banner .abs-img {
    top: 50px;
    left: 10px;
}


/*-----------------------------------*\
  #REVIEWS
\*-----------------------------------*/

.testi {
    text-align: center;
}

.testi .section-title {
    margin-block: 10px 20px;
}

.testi .section-text {
    max-width: 44ch;
    margin-inline: auto;
    margin-block-end: 30px;
}

.testi-card {
    background-color: var(--white);
    padding: 40px;
    text-align: left;
    box-shadow: var(--shadow-2);
}

.testi-card .profile-wrapper {
    display: flex;
    align-items: center;
    gap: 15px;
}

.testi-card .avatar {
    min-width: max-content;
    border-radius: 10px;
    overflow: hidden;
}

.testi-card .testi-name {
    margin-block-end: 2px;
}

.testi-card .testi-title {
    font-family: var(--ff-rubik);
    font-size: var(--fs-4);
}

.testi-card .testi-text {
    margin-block: 20px 15px;
}

.testi-item {
    min-width: 100%;
    scroll-snap-align: start;
}


/*-----------------------------------*\
  #BANNER
\*-----------------------------------*/

.banner {
    color: var(--white);
}

.banner-list {
    display: grid;
    gap: 10px;
}

.banner-lg {
    height: 430px;
}

.banner-sm {
    height: 200px;
}

.banner-md {
    height: 240px;
}

.banner-card {
    position: relative;
    height: 100%;
    box-shadow: var(--shadow-2);
    overflow: hidden;
}

.banner-card .banner-img {
    background-color: var(--gainsboro);
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1);
    transition: var(--transition-2);
}

.banner-card:is(:hover, :focus-within) .banner-img {
    transform: scale(1.05);
}

.banner-item-content {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 20px;
    right: 20px;
    max-height: calc(100% - 30px);
}

.banner-md .banner-item-content {
    left: 50%;
}

.banner-subtitle,
.banner-title {
    font-family: var(--ff-rubik);
    font-weight: var(--fw-600);
    line-height: 1.2;
    letter-spacing: -0.5px;
}

.banner-lg .banner-subtitle {
    font-size: var(--fs-2);
    margin-block-end: 10px;
}

.banner-lg .banner-title {
    font-size: var(--fs-1);
    max-width: 16ch;
}

:is(.banner-md, .banner-sm) .banner-title {
    font-size: var(--fs-2);
    max-width: 10ch;
}

.banner-card .banner-text {
    margin-block: 10px 15px;
}

.banner-card .btn1 {
    --bg-color: var(--dark-orange);
    --height: 40px;
    --padding-inline: 25px;
}

.banner-card .btn1:is(:hover, :focus) {
    background-color: var(--rich-black-fogra-29);
}


/*-----------------------------------*\
  #FOOTER
\*-----------------------------------*/

footer {
    background: var(--raisin-black-1);
    color: var(--white-opacity);
    font-weight: var(--fw-500);
}

.footer-top {
    padding-block: var(--section-padding);
}

.footer-brand {
    margin-bottom: 60px;
}

footer .logo {
    margin-bottom: 25px;
}

.footer-text {
    font-size: var(--fs-6);
    line-height: 1.8;
    margin-bottom: 25px;
}

.social-list {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 20px;
}

.social-link {
    color: var(--white-opacity);
    font-size: 25px;
    transition: var(--transition);
}

.social-link:is(:hover, :focus) {
    color: var(--white);
}

.footer-link-box {
    display: grid;
    gap: 50px;
}

.footer-list li:first-child {
    margin-bottom: 20px;
}

.footer-item-title {
    color: var(--white);
    font-family: var(--ff-mulish);
    font-weight: var(--fw-700);
}

.footer-link {
    color: var(--white-opacity);
    font-size: var(--fs-6);
    transition: var(--transition);
    padding-block: 10px;
}

.footer-link:is(:hover, :focus) {
    color: var(--white);
    transform: translateX(5px);
}

.footer-bottom {
    background: var(--raisin-black-2);
    padding-block: 20px;
    text-align: center;
}

.copyright a {
    display: inline-block;
    color: var(--white-opacity);
    transition: var(--transition);
}

.copyright a:is(:hover, :focus) {
    color: var(--white);
}


/*-----------------------------------*\
  #BACK TO TOP
\*-----------------------------------*/

.back-top-btn {
    position: fixed;
    bottom: 10px;
    right: 20px;
    background-color: var(--deep-saffron);
    color: var(--white);
    padding: 15px;
    border-radius: 50%;
    box-shadow: var(--shadow-1);
    z-index: 2;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition-1);
}

.back-top-btn.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(-10px);
}

.back-top-btn:is(:hover, :focus) {
    background-color: var(--rich-black-fogra-29);
}


/*-----------------------------------*\
  #MEDIA QUERIES
\*-----------------------------------*/

/**
 * responsive for larger than 480px screen
 */

@media (min-width: 480px) {
    /*Header*/
    .header-btn-group .btn1 {
        display: block;
        --bg-color: var(--dark-orange);
    }
}


/**
 * responsive for larger than 550px screen
 */

@media (min-width: 550px) {

    /**
     * REUSED STYLE
     */
    .container {
        max-width: 550px;
        width: 100%;
        margin-inline: auto;
    }

    .has-scrollbar > li {
        min-width: calc(50% - 5px);
    }


    /**
     * HERO
     */
    .hero-title {
        --fs-1: 4.2rem;
    }


    /**
     * FOOTER
     */
    .footer-top .container {
        grid-template-columns: 1fr 1fr;
    }

}


/**
 * responsive for larger than 768px screen
 */

@media (min-width: 768px) {

    /**
     * REUSED STYLE
     */
    .container {
        max-width: 720px;
    }


    /**
     * HERO
     */
    .hero {
        position: relative;
        text-align: left;
        overflow: hidden;
        z-index: 1;
    }

    .hero-content > :is(*, .btn1) {
        margin-inline: 0;
    }

    .hero-banner {
        display: block;
        position: absolute;
        top: calc(50% + 86px);
        transform: translateY(-50%);
        right: 50px;
        max-width: 40%;
        aspect-ratio: 1 / 0.9;
    }

    .hero-img {
        position: absolute;
        bottom: 30px;
    }

    .hero::after {
        content: "";
        position: absolute;
        right: 0;
        bottom: -2px;
        width: 100%;
        height: 100%;
        background-image: url("../images/home-shape.png");
        background-repeat: no-repeat;
        background-size: contain;
        background-position: right bottom;
        pointer-events: none;
        z-index: -1;
    }


    /**
     * ABOUT
     */
    .about .container {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 30px;
    }

    .about {
        text-align: left;
    }

    .about .section-title {
        margin-block-start: 0;
    }

    .about :is(.section-title, .btn1) {
        margin-inline: 0;
    }

    .about-item {
        justify-content: flex-start;
    }


    /**
     * FOOD MENU
     */
    .food-menu-list {
        grid-template-columns: 1fr 1fr;
    }

    .food-menu-card :is(.wrapper, .price-wrapper) {
        justify-content: flex-start;
    }

    .food-menu-card .card-title {
        text-align: left;
    }


    /**
     * CTA
     */
    .cta .container {
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: center;
        gap: 30px;
    }

    .cta {
        text-align: left;
    }

    .cta :is(.section-title, .btn1) {
        margin-inline: 0;
    }

    .cta-img {
        transform: scale(1.3) translate(90px, 20px);
    }


    /**
     * DELIVERY
     */
    .delivery .container {
        display: grid;
        grid-template-columns: 1fr 1fr;
        align-items: center;
        gap: 50px;
    }


    /**
     * BANNER
     */
    .banner-list {
        grid-template-columns: repeat(4, 1fr);
    }

    .banner-lg {
        grid-column: 1 / 3;
        grid-row: 1 / 3;
    }

    .banner-md {
        grid-column: 3 / 5;
        grid-row: 2 / 3;
        height: 220px;
    }


    /**
     * BLOG
     */
    .blog-list {
        grid-template-columns: 1fr 1fr;
    }

    .blog-card {
        height: 100%;
    }


    /**
     * FOOTER
     */
    .footer-link-box {
        grid-template-columns: repeat(3, 1fr);
    }

}


/**
 * responsive for larger than 992px screen
 */

@media (min-width: 992px) {

    /**
     * CUSTOM PROPERTY
     */
    :root {

        /**
         * spacing
         */

        --section-padding: 120px;

    }


    /**
     * REUSED STYLE
     */
    .container {
        max-width: 960px;
    }

    .has-scrollbar > li {
        min-width: calc(33.33% - 6.66px);
    }

    .h2 {
        --fs-1: 4.2rem;
    }

    /*Header*/
    .nav-toggle-btn {
        display: none;
    }

    .header .container {
        gap: 20px;
    }

    .navbar,
    .navbar.active {
        all: unset;
        margin-inline-start: auto;
    }

    .navbar-list {
        margin-block: 0;
        display: flex;
        gap: 5px;
    }

    .nav-item:not(:last-child) {
        border-block-end: none;
    }

    .navbar-link {
        --fs-4: 1.5rem;
        color: var(--btn-color);
        letter-spacing: -0.5px;
    }


    /**
     * HERO
     */
    .hero {
        min-height: 660px;
        display: grid;
        align-items: center;
    }

    .hero-subtitle {
        --fs-3: 3.2rem;
    }

    .hero-title {
        --fs-1: 7rem;
        letter-spacing: -2.5px;
    }

    .hero-text {
        font-size: var(--fs-3);
    }

    .hero-banner {
        max-width: 45%;
        top: auto;
        bottom: 0;
        transform: translateY(0);
    }

    .hero-img-bg {
        transform: scale(0) translate(20px, -20px);
    }


    /**
     * FOOD MENU
     */
    .food-menu-list {
        grid-template-columns: repeat(3, 1fr);
    }

    .food-menu-card {
        height: 100%;
    }


    /**
     * CTA
     */
    .cta-img {
        transform: scale(1.4) translate(20px, 40px);
    }

    .cta-banner .abs-img {
        left: -50px;
    }

    :is(.cta, .delivery) .section-title {
        line-height: 1.2;
    }


    /**
     * BANNER
     */
    .banner-lg .banner-title {
        --fs-1: 3.6rem;
        letter-spacing: -2px;
    }

    :is(.banner-md, .banner-sm) .banner-title,
    .banner-lg .banner-subtitle {
        --fs-2: 3.2rem;
    }


    /**
     * TESTIMONIALS
     */
    .testi-list {
        padding-block-end: 0;
    }


    /**
     * BLOG
     */
    .blog-list {
        grid-template-columns: repeat(3, 1fr);
    }

    .blog-card .card-title {
        --fs-3: 2.2rem;
    }


    /**
     * FOOTER
     */
    .footer-top .container {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        gap: 50px;
    }

    .footer-brand {
        margin-bottom: 0;
        max-width: 300px;
    }

    .footer-list {
        width: 140px;
    }


    /**
     * BACK TO TOP
     */
    .back-top-btn {
        bottom: 20px;
        right: 30px;
    }

}


/**
 * responsive for larger than 1200px screen
 */

@media (min-width: 1200px) {

    /**
     * REUSED STYLE
     */
    .container {
        max-width: 1200px;
    }


    /**
     * HERO
     */
    .hero {
        min-height: 770px;
    }


    /**
     * PROMO
     */
    .promo .promo-item {
        min-width: calc(25% - 7.5px);
    }


    /**
     * ABOUT
     */
    .about .container {
        gap: 60px;
    }


    /**
     * CTA
     */
    .cta {
        --section-padding: 60px;
    }

    .cta .section-title {
        max-width: 18ch;
    }


    /**
     * BANNER
     */
    .banner-md .banner-item-content {
        left: 55%;
    }


    /**
     * FOOTER
     */
    .footer-link-box {
        margin-right: 40px;
    }

    .footer-list {
        width: 170px;
    }

}