/* ===== LOGIN =====  */
.loginMainLayout {
    position: relative;
    width: 100%;
    height: 100dvh;
    padding: 50px;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    overflow: hidden;
}

.loginTitle {
    text-shadow: 5px 5px 0 #11193b, -5px 5px 0 #11193b, 5px -5px 0 #11193b, -5px -5px 0 #11193b, 5px 0 0 #11193b, -5px 0 0 #11193b, 0 5px 0 #11193b, 0 -5px 0 #11193b;
    text-transform: uppercase;
    letter-spacing: 2px;
    font-family: "ZFTERMIN_", sans-serif;
    font-size: 50px;
    line-height: 50px;
}

.modalPR_hr {
    width: 100%;
    height: 3px;
    border-radius: 5px;
    background: #fedeaf;
}

.loginContentMainLayout {
    background: #fbe886;
    border-radius: 30px;
    box-shadow: 1px 1px 5px #000;
    padding: 10px;
}

.loginNavbar_hr2 {
    width: 2px;
    height: 15px;
    margin: 0px 10px;
    background: #474747;
}

.loginContentLayout {
    position: relative;
    width: 100%;
    max-width: 850px;
    height: 100%;
    min-height: 500px;
    border-radius: 25px;
    padding: 40px 50px;
    background: #fffaf0;
    color: #000;
    border: 4px solid #bfa26b;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.loginNavbar_loginSocial {
    width: fit-content;
    height: 35px;
    padding: 5px 15px;
    border-radius: 50px;

    background: linear-gradient(180deg, rgba(16, 15, 44, 1) 0%, rgba(27, 33, 78, 1) 100%);
    border: 2px solid #e7f166;
    color: #fff;

    font-size: 15px;
    font-weight: 500;
    display: flex;
    align-items: center;
}



.regionCountry_mainLayout {
    width: fit-content;
    min-width: 100px;
    height: 45px;
    padding: 5px 15px;
    border-radius: 50px;
    border: 1px solid transparent;

    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;

    /* font-family: "Steamed", sans-serif; */
    font-size: 18px;
    line-height: 18px;
    font-weight: 600;
    text-transform: uppercase;
    color: #1b1b1b;
    background: transparent;
    text-shadow: 2px 2px 0 transparent, -2px 2px 0 transparent, 2px -2px 0 transparent, -2px -2px 0 transparent, 2px 0 0 transparent, -2px 0 0 transparent, 0 2px 0 transparent, 0 -2px 0 transparent;

    cursor: pointer;
    transition: all .5s;
    transition: all 0.3s ease, transform 0.2s ease;
}

.region_img {
    width: 35px;
}

.regionCountry_mainLayout:hover,
.regionCountry_mainLayout.active {
    color: #ffffff;
    text-shadow: 2px 2px 0 #633f13, -2px 2px 0 #633f13, 2px -2px 0 #633f13, -2px -2px 0 #633f13, 2px 0 0 #633f13, -2px 0 0 #633f13, 0 2px 0 #633f13, 0 -2px 0 #633f13;
    background: #fed250;
    border: 2px solid #633f13;
    box-shadow: inset 1px -2px 1px 1px #d7a81a, inset 2px 2px 1px 1px #ffffff80;
    transform: scale(1.05);

}

.regionCountry_btnTitle {
    color: #fff;
    text-shadow: 3px 3px 0 #633f13, -3px 3px 0 #633f13, 3px -3px 0 #633f13, -3px -3px 0 #633f13, 3px 0 0 #633f13, -3px 0 0 #633f13, 0 3px 0 #633f13, 0 -3px 0 #633f13;
    text-transform: uppercase;
    font-size: 30px;
    font-weight: 800;
    line-height: 30px;
    font-family: "PSL345pro", sans-serif;
    letter-spacing: 2px;
}


/* ====== MENU Profile ====== */
.offcanvas-body {
    position: relative;
}

.offcanvas-body.profile {
    position: relative;
    width: 100%;
    height: 100%;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
}

.offcanvas-body.cart {
    position: relative;
    width: 100%;
    height: 100%;
    padding-bottom: 0px;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
}

.profileMenu_infoSocial {
    background: #333333;
    border-radius: 10px;
    padding: 5px 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 50px;

    font-size: 16px;
    line-height: 20px;
    font-weight: 600;
    text-align: center;
}

.profileMenu_infoMenu {
    width: 100%;
    height: 50px;
    padding: 5px 15px;
    border-radius: 10px;

    font-weight: 600;
    font-size: 15px;

    display: flex;
    align-items: center;
    justify-content: space-between;

    background: #333333;
    border: 1px solid #1c1c1c;
    color: #fff;
    transition: all .5s;
}

.profileMenu_infoMenu:hover,
.rofileMenu_infoMenu.active {
    background: #fff;
    border: 1px solid #1c1c1c;
    color: #000;
}

.profileMenu_infoCount {
    width: 20px;
    height: 20px;
    border-radius: 50px;
    font-size: 12px;
    background: #ED5E5E;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ==== MENU Cart ====  */
.cartMenu_mainLayoutCard {
    width: 100%;
    min-height: 150px;
    padding: 10px 15px;
    border-radius: 10px;
    margin-bottom: 10px;

    background: #2b2b2b;
    color: #fff;

    display: flex;
    flex-direction: column;
}

.cartMenuCard_img {
    width: 70px;
    min-width: 70px;
    height: 70px;
    padding: 10px;
    border-radius: 10px;

    background: #00000041;
}

.cartMenuCard_title {
    font-weight: 16px;
    font-weight: 600;

    color: #fff;
}

.cartMenuCard_title span {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;

    line-height: 1.4;
    max-height: calc(1.4em * 2);
}

.cartMenuCard_mainLayoutBtnCount {
    width: 100%;
    display: flex;
    align-items: center;
}

.cartMenuCard_mainLayoutBtnCount input {
    width: 80px;
    min-width: 80px;
    height: 35px;
    text-align: center;

    background: #fff;
    border: 1px solid #fff;
    border-left: 1px solid transparent;
    border-right: 1px solid transparent;
    color: #000;
}

.cartMenuCard_mainLayoutBtnCount button {
    width: 35px;
    min-width: 35px;
    height: 35px;
    border: 1px solid #fff;

    color: #fff;
    background: #1f1f1f;
}

.cartMenuCard_mainLayoutBtnCount button:nth-of-type(1) {
    border-radius: 6px 0 0 6px;
}

.cartMenuCard_mainLayoutBtnCount button:nth-of-type(2) {
    border-radius: 0 6px 6px 0;
}

.cartItem_cardDiscountPrice {
    font-size: 16px;
    line-height: 17px;
    color: #959595;
    text-decoration: line-through;
}

.cartItem_cardPrice {
    font-size: 20px;
    font-weight: 600;
}

.cartMenu_footerMainLayout {
    width: 100%;
    /* min-height: 200px; */
    background: #202020;
    color: #fff;
    left: 0px;
    bottom: -0px;
    padding: 10px 0px;
    position: sticky;

    display: flex;
    flex-direction: column;
    align-items: center;
}


/* =========================
   HOMEPAGE PAGE
========================== */
.homepageMainLayout {
    width: 100%;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 120px;
    padding-bottom: 50px;
}

.homepageContentmainLayout {
    width: 100%;
    max-width: 1390px;

    display: flex;
    flex-direction: column;
    align-items: center;
}


.mainContent_bannerMainLayout {
    width: 100%;
    height: 400px;
    /* background: #fffffff6; */
    border-radius: 20px;
    padding: 10px;
    /* border: 3px solid #ddba5a; */

    display: flex;
    align-items: center;
    justify-content: space-between;
    /* box-shadow: 1px 1px 10px #ffe49a8e; */
}

.carousel-inner {
    height: 100%;
    border-radius: 20px;
}


/* =========================
   PAYMENT MODAL : HOMEPAGE PAGE
========================== */
/* modal ใหญ่กว่า modal-xl */
.modal-xxxl {
    max-width: 1400px;
    width: 95vw;
}

.modal-content.payment {
    background: transparent;
    box-shadow: 0px 0px 0px transparent;
    border: 1px solid transparent;

}

.modalPaymentMethod_contentLayout {
    width: 100%;
    min-height: 300px;
    padding: 20px 25px;
    border-radius: 20px;
    border: 3px solid #bfa26b;
    background: #fffaf0;
    color: #323232;

    box-shadow: 0px 0px 0px 8px #fbe886;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: start;
}

.provider_contentLayout {
    width: 350px;
    min-width: 350px;
    padding: 0px 25px;


    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.provider_cardMainLayout {
    position: relative;
    width: 100%;
    min-width: 100%;
    min-height: 150px;
    border-radius: 20px;
    padding: 10px;

    background: url(../images/background/progress_card.png);
    background-position: center;
    background-size: cover;

    border: 3px solid #fff;
    box-shadow: 2px 2px 5px #000;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    /* overflow: hidden; */

    transition: all .5s;
}

.provider_title {
    width: fit-content;
    min-width: 145px;
    min-height: 40px;
    border-radius: 50px;
    padding: 10px 20px;
    background: #303030;
    box-shadow: inset 0px 0px 15px 2px #000;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 16px;
    line-height: 20px;
    font-weight: 600;
}

.provider_imgLayout {
    width: 100px;
    height: 100px;
    padding: 15px;
    border-radius: 50%;
    background: #fff;
    border: 3px solid #b4b2af;
    display: flex;
    align-items: center;
    justify-content: center;
}

.provider_img {
    width: 100%;
    border-radius: 10px;

    overflow: hidden;
    filter: drop-shadow(2px 2px 2px #00000088);
}

.provider_cardMainLayout:hover,
.provider_cardMainLayout.active {
    background: url("../images/background/progress_card_active.png");
    background-position: center;
    background-size: cover;
    border: 3px solid #f6f867;
}

.provider_count {
    position: absolute;
    top: -5px;
    right: -5px;
    width: 25px;
    height: 25px;
    border-radius: 50px;
    font-size: 16px;
    font-weight: 600;
    background: #ED5E5E;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
}

.provider_count.hidden {
    display: none;
}

/* ==== PRODUCT ====  */
.productSearchLayout {
    position: relative;
    width: 100%;
}

.productSearchLayout input {
    width: 100%;
    height: 45px;
    padding: 10px 20px 10px 35px;
    border-radius: 10px;

    background: #fff;
    border: 1px solid #e2c106;
    color: #141414;
    font-size: 18px;
}

.productSearchLayout i {
    position: absolute;
    top: 15px;
    left: 10px;
    color: #141414;
    font-size: 14px;
}


.productMultidropdown {
    position: relative;
    width: 100%;
    height: 45px;
}

.dropdown-btn {
    height: 45px;
    padding: 10px 20px;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;

    border-radius: 10px;
    background: #fff;
    border: 1px solid #e2c106;
    color: #141414;
}

.dropdown-menu {
    display: none;
    position: absolute;
    width: 100%;
    background: #fff;
    border: 1px solid #ccc;
    margin-top: 2px;
    z-index: 10;
    max-height: 240px;
    overflow-y: auto;
}

.search-input {
    width: calc(100% - 20px);
    margin: 10px;
    padding: 6px;
    border: 1px solid #ccc;
}

.dropdown-menu label {
    display: block;
    padding: 8px 10px;
    cursor: pointer;
}

.dropdown-menu label:hover {
    background: #f2f2f2;
}

.no-result {
    display: none;
    padding: 10px;
    text-align: center;
    color: #999;
    font-size: 14px;
}

.show {
    display: block;
}

.form-select {
    width: fit-content;
    height: 45px;
    border-radius: 10px;
    background: #fff;
    border: 1px solid #e2c106;

    cursor: pointer;
}

/* =========================
   HISTORY PAGE
========================== */
.breadcrumbMainLayout {
    width: 100%;
    height: 80px;
    padding: 0px 10px;
    margin-bottom: 20px;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    /* background: #000; */
}

.breadcrumb_title {
    font-size: 35px;
    line-height: 50px;
    font-weight: 800;

    color: #fff;
}

.btn.breadcrumb {
    width: fit-content;
    min-width: fit-content;
    height: 40px;
    margin-bottom: 0;
    padding: 5px 10px;
    border: 0px solid transparent !important;

    display: flex;
    align-items: center;
    justify-content: center;

    color: #fff;
    transition: all .5s;
    font-size: 16px;
}

.btn.breadcrumb.active {
    color: #1279ff;
}

.mainHistoryMainLayout {
    width: 100%;
    max-width: 1400px;
    height: 100%;
    padding-top: 70px;

    background: transparent;
}