@charset "utf-8";
/*
Theme Name: Thoo - Construction Company Html.
Author: https://www.templatemonster.com/authors/codezion/

%%%%%%% Table of CSS %%%%%%%

1.General code
    1.1 Typography
    1.2 Space margins and padding
    1.3 forms
    1.4 Buttons
    1.5 Section-Colors-&-Backgrounds
    1.6 Modal & popups
    1.7 Accordion
2.Homepages
    2.1 Navigation
    2.2 Slider
    2.3 Search
    2.4 About Us
    2.5 Our Categories
    2.6 Our Services
    2.7 Our Product
    2.8 Our Team
    2.9 Why Choose Us
    2.10 Our Blog
    2.11 Our Partners
    2.12 Footer
    2.13 Copyright
3.Blog
4.Blog Details
5.Listing
6.Listing Detail
7.Booking
8.404
9.Coming Soon
10.Contact Us
11.FAQs
12.Gallery
*/
@import url('https://fonts.googleapis.com/css2?family=Barlow:wght@500;600;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Barlow:wght@500;600;700;800;900&display=swap');
/*--------animation---------*/
@keyframes fadeHeaderInDown {
    0% {
        opacity: 0;
        transform: translate3d(0, -100%, 0);
    }
    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

@keyframes shadow {
    0% {
        transform: scale(1) translateY(0px);
    }
    100% {
        transform: scale(0.8) translateY(75px);
    }
}

@keyframes ghost {
    0% {
        transform: scale(1) translateY(0px)
    }
    100% {
        transform: scale(1) translateY(-40px)
    }
}

/*======================
1.General Code
========================*/
html {
    overflow-x: hidden;
}

button:focus, *:focus {
    outline: none;
}

body {
    font-family: 'Barlow', sans-serif;
    margin: 0;
    padding: 0;
    font-size: 14px;
    line-height: 1.8;
    font-weight: 400;
    color: #000;
    background: #ffffff;
    border-color: #dfdfdf;
    transition: transform ease-in .4s;
    overflow: hidden;
}

button {
    background: transparent;
    border: none;
    padding: 0;
}

label {
    line-height: normal;
}

hr {
    margin: 20px 0;
}

.p-relative {
    position: relative;
}

.before-none:after, .after-none:after, .none {
    display: none;
}

.overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

.overlay-bg-black {
    background: #000;
    opacity: 0.1;
}

.overlay-2 {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
}

.image-fit {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.transform-center {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    transform: translate(0%, -50%);
    z-index: 1;
}

.bx-wrapper {
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
}

[class^="flaticon-"]:before, [class*=" flaticon-"]:before {
    font-size: inherit;
    margin: 0;
}

.animate-img {
    position: relative;
    overflow: hidden;
}

.animate-img:hover img {
    transform: scale(1.1);
    transition: 0.5s;
}

.parallax {
    position: relative;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-attachment: fixed;
    transition: border 0.3s ease-in, box-shadow 0.3s ease-in, background 0.3s, opacity 0.3s ease-in;
}

.normal-bg {
    position: relative;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transition: border 0.3s ease-in, box-shadow 0.3s ease-in, background 0.3s, opacity 0.3s ease-in;
}

/*section header*/
.section-header {
    padding-bottom: 30px;
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
}

.section-header .section-heading {
    max-width: 540px;
    margin: auto;
}

.section-header .section-heading h3 {
    font-size: 36px;
}

.section-header .section-heading h3:after {
    content: '';
    display: block;
    width: 80px;
    height: 2px;
    background: #b7291e;
    margin: 20px auto 0;
}

.section-header .section-description {
    margin-bottom: 20px;
    position: relative;
}

.style-left {
    text-align: left;
}

.section-header.style-left .section-heading {
    margin: 0 auto 0 0;
}

.section-header.style-left .section-heading h3:after {
    margin: 20px auto 0 0;
}

.style-right {
    text-align: right;
}

.section-header.style-right .section-heading {
    margin: 0 0 0 auto;
}

.section-header.style-right .section-heading h3:after {
    margin: 20px 0 0 auto;
}

/*Slick Arrow*/
.arrow-layout-2 .slick-arrow, .arrow-layout-1 .slick-arrow {
    position: absolute;
    top: 50%;
    z-index: 10;
    transform: translate(0px, -50%);
    transition: 0.3s all;
    font-size: 0;
    overflow: hidden;
    z-index: 1;
}

.arrow-layout-1 .slick-arrow:after {
    width: 50px;
    height: 50px;
    border: 1px solid #fff0;
    background: #ffffff9e;
    position: relative;
    overflow: hidden;
    color: #090909;
    font-size: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: Flaticon;
}

.arrow-layout-1 .slick-arrow:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 0%;
    background: #b7291e;
    z-index: -1;
    height: 100%;
    transition: 0.5s all;
}

.arrow-layout-1 .slick-arrow:hover:before {
    width: 100%;
}

.arrow-layout-1 .slick-prev {
    left: -100px;
}

.arrow-layout-1 .slick-next {
    right: -100px;
}

.arrow-layout-1 .slick-prev:after {
    content: "\f165";
}

.arrow-layout-1 .slick-next:after {
    content: "\f163";
}

.arrow-layout-1.slick-slider:hover .slick-prev {
    left: 15px;
}

.arrow-layout-1.slick-slider:hover .slick-next {
    right: 15px;
}

.arrow-layout-2 .slick-arrow {
    font-size: 0;
    right: 15px;
}

.arrow-layout-2 .slick-arrow:after {
    background: #111111;
    border-color: #111111;
    color: #fff;
    font-family: flaticon;
    padding: 15px;
    font-size: 20px;
}

.arrow-layout-2 .slick-prev {
    left: 0;
    right: auto;
}

.arrow-layout-2 .slick-next {
    right: 0;
}

.arrow-layout-2 .slick-prev:after {
    content: "\f164";
}

.arrow-layout-2 .slick-next:after {
    content: "\f162";
}

.arrow-layout-2 .slick-arrow:hover:after {
    color: #fff;
    /*background: ffb20_0;*/
    background: #b7291e;
}

.arrow-layout-2.sidebar-arrow .slick-arrow {
    transform: translate(0px, 0%);
    top: auto;
    bottom: 0;
}

.arrow-layout-2.sidebar-arrow .slick-arrow.slick-prev {
    left: 0;
}

.arrow-layout-2.sidebar-arrow .slick-arrow.slick-next {
    right: 0;
}

/*slick bullets*/
.slick-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    list-style: none;
    padding: 0;
    margin-top: 20px;
}

.slick-dots li {
    padding: 0;
    line-height: 0;
}

.slick-dots li button {
    font-size: 0;
    width: 12px;
    height: 6px;
    border-radius: 10px;
    background: #2d3e52;
    margin: 0 5px;
    transition: 0.6s all;
    border: 2px solid #2d3e52;
}

.slick-dots li.slick-active button {
    width: 24px;
    height: 6px;
    border-radius: 50px;
    background: #b7291e;
    border: 2px solid #b7291e;
}

/*pagination*/
.page-item:first-child .page-link {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.page-item:last-child .page-link {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.page-link:focus {
    box-shadow: none;
    z-index: 1;
}

.page-item .page-link {
    padding: 8px 20px;
    font-size: 14px;
    line-height: 1.5;
    border: 2px solid #eee;
    color: #020202;
    border-radius: 0;
}

.page-item:hover .page-link, .page-item.active .page-link {
    background-color: #b7291e;
    border-color: #b7291e;
    color: #fff;
}

.footer-link-item.active {
    color: #b7291e;
}

/*======================
1.1 Typography
========================*/
h1, h2, h3, h4, h5, h6 {
    margin: 0 0 20px;
    font-family: 'Barlow', sans-serif;
    font-weight: 600;
    color: #000;
}

h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
    color: inherit;
}

h1 {
    font-size: 50px;
    line-height: normal;
}

h2 {
    font-size: 40px;
}

h3 {
    font-size: 35px;
}

h4 {
    font-size: 26px;
}

h5 {
    font-size: 18px;
}

h6 {
    font-size: 16px;
}

p {
    font-size: 14px;
    line-height: 1.8;
    margin-bottom: 20px;
    font-family: 'Barlow', sans-serif;
}

a {
    color: #fff;
    text-decoration: none;
    transition: 0.5s;
}

a:focus, a:hover {
    color: #111111;
    text-decoration: none;
    transition: 0.5s;
}

dl, ol, ul {
    margin-top: 0;
    margin-bottom: 0;
}

ul li, ol li {
    margin: 0;
    position: relative;
}

ul.custom {
    list-style: none;
    padding: 0;
}

ul.custom-flex {
    list-style: none;
    padding: 0;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

blockquote {
    background-color: #fff;
    position: relative;
    display: flex;
    align-items: center;
    padding: 30px;
    padding-left: 70px;
    border-left: 2px solid #b7291e;
}

blockquote span {
    width: 50px;
    height: 50px;
    background: #b7291e;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 15px;
    font-size: 16px;
    margin-right: 0;
    position: absolute;
    left: 0;
    top: 0;
}

blockquote p {
    font-size: 16px;
    font-style: italic;
    margin: 0;
    font-weight: 500;
    word-break: break-word;
}

blockquote h6 {
    color: #000;
    font-weight: 400;
    text-transform: uppercase;
    font-size: 16px;
}

iframe {
    border: none;
    width: 100%;
}

img {
    max-width: 100%;
    width: auto;
    height: auto;
    transition: 0.5s;
}

table th, table td {
    border: 1px solid #dfdfdf;
    padding: 15px;
}

table {
    border: 1px solid #dfdfdf;
    padding: 15px;
    width: 100%;
}

.fs-12 {
    font-size: 12px;
}

.fs-14 {
    font-size: 14px;
}

.fs-16 {
    font-size: 16px;
}

.fs-18 {
    font-size: 18px;
}

.fs-20 {
    font-size: 20px;
}

.fw-100 {
    font-weight: 100;
}

.fw-400 {
    font-weight: 400;
}

.fw-500 {
    font-weight: 500;
}

.fw-600 {
    font-weight: 600;
}

.fw-700 {
    font-weight: 700;
}

/*======================
1.2 Space margins and padding
========================*/
.no-margin {
    margin: 0;
}

.no-padding {
    padding: 0;
}

.full-width {
    width: 100%;
}

.full-height {
    height: 100%;
}

.section-padding {
    padding: 80px 0;
}

.section-padding-top {
    padding-top: 80px;
}

.section-padding-bottom {
    padding-bottom: 80px;
}

.padding-10 {
    padding: 10px;
}

.padding-15 {
    padding: 15px;
}

.padding-20 {
    padding: 20px;
}

.ml-xl-20 {
    margin-left: 20px;
}

.ml-xl-30 {
    margin-left: 30px;
}

.ml-xl-40 {
    margin-left: 40px;
}

.ml-xl-50 {
    margin-left: 50px;
}

.ml-xl-60 {
    margin-left: 60px;
}

.mb-xl-20 {
    margin-bottom: 20px;
}

.mb-xl-30 {
    margin-bottom: 30px;
}

.mb-xl-40 {
    margin-bottom: 40px;
}

.mb-xl-50 {
    margin-bottom: 50px;
}

.mb-xl-80 {
    margin-bottom: 80px;
}

.pb-xl-20 {
    padding-bottom: 20px;
}

/*==================
1.3. Forms
====================*/
.form-control-custom::placeholder {
    font-size: 14px;
}

.banner-tabs .form-control-custom:focus {
    border: 2px solid #ffffff;
    border-bottom: 2px solid #b7291e;
    box-shadow: none;
}

.banner-tabs .form-control-custom, .newsletter .form-control-custom {
    border: 2px solid #b7291e;
}

.form-control-custom {
    height: 40px;
    padding: 0 15px;
    border-radius: 0;
    border: 2px solid #000000;
    width: 100%;
    background: #fff;
    font-size: 14px;
    border-radius: 10px;
}

.form-control-custom:focus {
    border: 2px solid #c1c1c1;
    border-bottom: 2px solid #b7291e;
    box-shadow: none;
}

.form-control:disabled, .form-control[readonly] {
    background-color: #ffffff;
    opacity: 1;
}

.btn-height, button.btn-height {
    height: 40px;
    line-height: 1;
    padding: 0;
}

label.submit {
    height: 15px;
    width: 100%;
    clear: both;
}

.custom-select {
    background-image: none;
}

.custom-select:focus {
    box-shadow: none;
}

.group-form .form-control-custom, .group-form .form-control-custom:not(:last-child) {
    padding: 0 40px 0 15px;
}

.group-form .form-control-custom:focus {
    z-index: 0;
}

.group-form .form-control-custom.custom-select:focus {
    z-index: 10;
}

.group-form .input-group-append {
    position: absolute;
    height: 40px;
    width: 40px;
    background: #000000;
    color: #fff;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    z-index: 0;
    pointer-events: none;
}

.group-form .custom-select {
    padding: 0 30px 0 10px;
}

.group-form .custom-select:after {
    border-bottom-color: #fff;
    border-right-color: #fff;
    right: 15px;
}

.banner-tabs .group-form .input-group-append {
    background: #b7291e;
}

.banner-tabs .group-form .custom-select:before {
    content: '';
    background: #b7291e;
    width: 40px;
    height: 40px;
    display: block;
    position: absolute;
    right: -2px;
    top: -2px;
    margin-top: 0;
}

.group-form .custom-select:before {
    content: '';
    background: #000000;
    width: 40px;
    height: 40px;
    display: block;
    position: absolute;
    right: -2px;
    top: -2px;
    margin-top: 0;
}

textarea.form-control {
    height: auto;
    padding: 20px 15px 0;
}

label.custom-checkbox input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
}

label.custom-checkbox {
    display: block;
    position: relative;
    padding-left: 30px;
    margin-bottom: 10px;
    cursor: pointer;
    user-select: none;
    line-height: normal;
    font-size: 14px;
}

label.custom-checkbox:last-child {
    margin-bottom: 10px;
}

/* Create a custom checkbox */
label.custom-checkbox .checkmark {
    position: absolute;
    top: 0;
    left: 0;
    border: 1px solid #d4d4db;
    width: 20px;
    height: 20px;
    background-color: #fff;
    border-radius: 0;
}

/* On mouse-over, add a grey background color */
label.custom-checkbox:hover input ~ .checkmark {
    background-color: #fff;
    border: 1px solid #b7291e;
}

/* When the checkbox is checked, add a blue background */
label.custom-checkbox input:checked ~ .checkmark {
    background-color: #b7291e;
    border: 1px solid #b7291e;
}

/* Create the checkmark/indicator (hidden when not checked) */
.checkmark:after {
    content: "";
    position: absolute;
    display: none;
}

/* Show the checkmark when checked */
label.custom-checkbox input:checked ~ .checkmark:after {
    display: block;
}

/* Style the checkmark/indicator */
label.custom-checkbox .checkmark:after {
    left: 6px;
    top: 2px;
    width: 5px;
    height: 9px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

/*==================
1.4. Buttons
====================*/
.btn-first {
    display: inline-block;
    padding: 12px 40px;
    position: relative;
    transition: 0.5s all;
    background: transparent;
    color: inherit;
    border: 1px solid transparent;
    font-size: 14px;
    overflow: hidden;
    z-index: 1;
    text-align: center;
    text-transform: uppercase;
}

.btn-submit {
    border-color: #b7291e;
    color: #ffffff;
    background: #b7291e;
    border-radius: 10px;
}

.btn-small:before, .btn-submit:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 100%;
    background-color: #111111;
    width: 0%;
    transition: 0.5s all;
    z-index: -1;
}

.btn-small:hover, .btn-submit:hover {
    color: #fff;
}

.btn-small:focus, .btn-submit:focus {
    background-color: #00a3c8;
    color: #fff;
}

.btn-small:hover:before, .btn-submit:hover:before {
    width: 100%;
}

.btn-second {
    display: inline-block;
    padding: 0 20px;
    position: relative;
    transition: 0.5s all;
    background: transparent;
    color: inherit;
    border: 1px solid transparent;
    font-size: 14px;
    overflow: hidden;
    z-index: 1;
    text-align: center;
    text-transform: uppercase;
}

.btn-small {
    background: #111111;
    border-color: #111111;
    color: #fff;
    border-radius: 10px;
}

.btn-small:hover, .btn-small:focus {
    border-color: #b7291e;
}

/*==================
1.5. Section-Colors-&-Backgrounds
====================*/
.bg-light-white {
    background-color: #f5f5f5;
}

.bg-custom-white {
    background-color: #ffffff;
}

.bg-custom-blue {
    background: #b7291e;
}

.bg-light-black {
    background: #2d3e52;
}

/*Colors*/
.text-custom-black {
    color: #000000;
}

.text-custom-white {
    color: #ffffff;
}

.text-custom-blue {
    color: #b7291e;
}

.text-light-dark {
    color: #838383;;
}

.text-light-black {
    color: #2d3e52;
}

.text-yellow {
    color: #fdb714;
}

/*======================
1.6 Modal & Popups
========================*/
/*======================
1.7 Accordion
========================*/
.custom-accordion .card {
    background: #ffffff;
    border-color: #fff;
    border-radius: 0;
}

.custom-accordion .card .card-header {
    padding: 0;
    background: #ededed;
    border-color: #ededed;
    border-radius: 0;
}

.custom-accordion .card .card-header .collapsebtn {
    font-size: 16px;
    font-weight: 500;
    display: flex;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
    align-items: center;
    padding: 10px 15px;
    width: 100%;
    background: #b7291e;
    color: #fff;
    cursor: pointer;
}

.custom-accordion .card .card-header .collapsebtn.collapsed {
    background: #ededed;
    border-color: #ededed;
    color: #000;
}

.custom-accordion .card .card-header .collapsebtn:before {
    content: '\f068';
    background: #fff;
    color: #b7291e;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    margin-right: 15px;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
}

.custom-accordion .card .card-header .collapsebtn.collapsed:before {
    content: '\f067';
    background: #2d3e52;
    color: #ededed;
}

.custom-accordion .card .card-body {
    padding: 15px 0;
}

/*======================
2. Homepages
========================*/
.header .topbar {
    background: #b7291e;
}

.header .topbar .leftside ul > li > a {
    margin: 10px 10px 10px 0;
    line-height: 33px;
    border: 2px solid #fff;
    width: 36px;
    height: 36px;
    text-align: center;
    display: block;
}

.header .topbar .leftside ul > li:hover > a {
    background-color: #111111;
    border-color: #111111;
    color: #fff;
}

.header .topbar .rightside ul {
    justify-content: flex-end;
}

.header .topbar .rightside ul > li.login {
    background-color: #45afce;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    height: 100%;
    padding: 0 30px;
}

.header .book-appointment > a {
    background: #111111;
    display: flex;
    height: 100%;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    padding: 10px 30px;
    font-weight: 600;
    border-radius: 10px;
    color: #fff;
}

.header .topbar .rightside ul > li > a > i {
    margin-right: 10px;
}

/*Navigation*/
.header .navigation-wrapper {
    background-color: #fff;
    position: absolute;
    z-index: 5;
    left: 0;
    right: 0;
    width: 100%;
    padding: 5px 0;
}

.header .navigation-wrapper.sticky {
    animation-name: fadeHeaderInDown;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 22;
    background: #fff;
    animation-duration: 1s;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
    animation-fill-mode: both;
}

.header .navigation-wrapper nav > .main-navigation .logo {
    width: 185px;
    height: 55px;
    position: absolute;
    top: 0;
}

.header .navigation-wrapper nav > .main-navigation .logo img {
    background: #ffffffbf;
}

.header .navigation-wrapper nav > .main-navigation .main-menu > ul {
    justify-content: flex-end;
}

.header .navigation-wrapper nav > .main-navigation .main-menu > ul > .menu-item {
    margin: 0 8px;
    padding: 15px 0;
}

.header .navigation-wrapper nav > .main-navigation .main-menu > ul > .menu-item:last-child {
    margin-right: 0;
}

.header .navigation-wrapper nav > .main-navigation .main-menu > ul > .menu-item > a {
    color: #000;
    font-weight: 600;
    font-size: 14px;
    position: relative;
    padding: 5px 20px;
}

.header .navigation-wrapper nav > .main-navigation .main-menu > ul > .menu-item > a:after {
    content: '';
    display: block;
    height: 5px;
    background: #b7291e;
    position: absolute;
    bottom: -15px;
    left: 0;
    right: 0;
    width: 100%;
    opacity: 0;
    transition: 0.3s all;
}

.header .navigation-wrapper nav > .main-navigation .main-menu > ul > .menu-item:hover > a:before, .header .navigation-wrapper nav > .main-navigation .main-menu > ul > .menu-item.active > a:before {
    top: -2px;
    opacity: 1;
}

.header .navigation-wrapper nav > .main-navigation .main-menu > ul > .menu-item:hover > a:after, .header .navigation-wrapper nav > .main-navigation .main-menu > ul > .menu-item.active > a:after {
    bottom: -2px;
    opacity: 1;
}

.header .navigation-wrapper nav > .main-navigation .main-menu > ul > .search {
    display: flex;
    align-items: center;
    margin-right: 0;
}

.header .navigation-wrapper nav > .main-navigation .main-menu > ul > .search > a {
    padding: 5px 20px;
    padding-right: 0;
    font-size: 14px;
}

.menu-item-has-children {
    position: relative;
}

.menu-item-has-children > a > .arrow:after, .menu-item-has-megamenu > a > .arrow:after {
    display: inline-block;
    margin-left: .55em;
    content: "\f107";
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
}

.menu-item-has-children .submenu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    width: 200px;
    transform: translateY(10px);
    transition: 0.3s all;
    border-top: 2px solid #b7291e;
    background-color: #fff;
    opacity: 0;
    visibility: hidden;
}

.menu-item-has-children:hover > .submenu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.menu-item-has-children .submenu > .menu-item > a {
    padding: 10px;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    display: block;
    color: #000;
}

.menu-item-has-children .submenu > .menu-item:hover > a {
    background-color: #111111;
    color: #fff;
}

.menu-item-has-children .submenu .menu-item-has-children > a > .arrow:after {
    position: absolute;
    right: 10px;
    transform: rotate(-90deg);
}

.menu-item-has-children .submenu .menu-item-has-children > .submenu {
    left: 100%;
    top: 0;
}

.header .navigation-wrapper nav > .main-navigation .hamburger-menu {
    display: none;
    align-items: center;
    cursor: pointer;
    padding: 25px 0;
    justify-content: flex-end;
}

.header .navigation-wrapper nav > .main-navigation .hamburger-menu .menu-btn span {
    background: #000;
    height: 2px;
    width: 25px;
    margin-bottom: 5px;
    display: block;
    transition: 0.3s;
}

.header .navigation-wrapper nav > .main-navigation .hamburger-menu .menu-btn span:last-child {
    margin-bottom: 0;
}

.header .navigation-wrapper nav > .main-navigation .hamburger-menu .menu-btn.active {
    position: relative;
    top: -4px;
    transition: 0.3s;
}

.header .navigation-wrapper nav > .main-navigation .hamburger-menu .menu-btn.active span:first-child {
    transform: rotate(45deg);
    transition: 0.3s;
    position: relative;
    top: 7.4px;
}

.header .navigation-wrapper nav > .main-navigation .hamburger-menu .menu-btn.active span:nth-child(2) {
    display: none;
}

.header .navigation-wrapper nav > .main-navigation .hamburger-menu .menu-btn.active span:last-child {
    transform: rotate(-45deg);
    transition: 0.3s;
}

.header-right-wrap .same-style {
    padding: 13px 0;

    i.fa {
        font-size: 14px;
        text-align: center;
        width: 25px;
    }
}

.header-right-wrap .same-style a {
    padding: 0 5px;
    font-size: 16px;
    color: #000000;
}

.header-right-wrap .same-style a:hover {
    color: #E2B04D;
}

.header-right-wrap .same-style.same-style-mrg-dec:first-child.menu-right {
    background: #E2B04D;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    text-align: center;
    line-height: 50px;
}

/*Main Slider*/
.main-banner .slide-item {
    height: 800px;
    position: relative;
    z-index: 1;
    margin: 0;
}

.main-banner .slide-item:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 100%;
    width: 100%;
    background-color: #000;
    opacity: 0.5;
}

.slider-content {
    width: 576px;
    margin: auto;
    text-align: center;
}

.slider-content h1 {
    font-size: 48px;
}

.slider-content ul {
    margin-bottom: 20px;
}

.slider-content ul li {
    display: flex;
    align-items: center;
    font-size: 20px;
    margin-bottom: 10px;
}

.slider-content ul li i {
    color: #b7291e;
    font-size: 22px;
    margin-right: 15px;
    width: 27px;
    height: 22px;
    text-align: center;
}

.main-banner .slick-dots {
    position: absolute;
    bottom: 20px;
    left: 0;
    right: 0;
}

/*Banner tabs*/
.banner-tabs .tab-pane [class^="col-"], .banner-tabs .tab-pane [class*=" col-"] {
    padding-left: 10px;
    padding-right: 10px;
}

.banner-tabs {
    margin-top: 0;
    background-repeat: repeat;
    background-position: center;
    background-size: auto;
}

.banner-tabs .tabs .nav-tabs .nav-item .nav-link {
    background: #ffffff8c;
    color: #000;
    font-weight: 500;
    letter-spacing: 1px;
}

.tabs .nav-tabs {
    border: none;
}

.tabs .nav-tabs .nav-item {
    text-align: center;
    margin-right: 10px;
    margin-bottom: 10px;
}

.tabs .nav-tabs .nav-item .nav-link:hover, .tabs .nav-tabs .nav-item .nav-link.active {
    background: #b7291e;
    color: #ffffff;
    border: none;
    border-bottom: 2px solid #b7291e;
}

.tabs .nav-tabs .nav-item .nav-link.active:before {
    content: "";
    bottom: -8px;
    left: calc(20% - 6px);
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #b7291e;
}

.tabs .nav-tabs .nav-item .nav-link {
    background: #fff;
    border-radius: 0;
    border: none;
    background: #000;
    border-bottom: 2px solid #b7291e;
    color: #fff;
    font-weight: 600;
    padding: 5px 40px;
    display: block;
    z-index: 10;
    position: relative;
}

.tabs .nav-tabs .nav-item .nav-link:after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 100%;
    background-color: #111111;
    width: 0%;
    transition: 0.5s all;
    z-index: -1;
}

.tabs .nav-tabs .nav-item .nav-link:hover:after {
    width: 100%;
}

/*About us*/

.aboutus-title {
    font-size: 30px;
    letter-spacing: 0;
    line-height: 32px;
    margin: 0 0 39px;
    padding: 0 0 11px;
    position: relative;
    text-transform: uppercase;
    color: #000;
}

.aboutus-title::after {
    background: #fdb801 none repeat scroll 0 0;
    bottom: 0;
    content: "";
    height: 2px;
    left: 0;
    position: absolute;
    width: 54px;
}

.aboutus-text {
    color: #606060;
    font-size: 13px;
    line-height: 22px;
    margin: 0 0 35px;
}

a:hover, a:active {
    color: #ffb901;
    text-decoration: none;
    outline: 0;
}

.aboutus-more {
    border: 1px solid #fdb801;
    border-radius: 10px;
    color: #fdb801;
    display: inline-block;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0;
    padding: 7px 20px;
    text-transform: uppercase;
}

.feature .feature-box .iconset {
    background: #fff none repeat scroll 0 0;
    float: left;
    position: relative;
    width: 18%;
}

.feature .feature-box .iconset::after {
    background: #fdb801 none repeat scroll 0 0;
    content: "";
    height: 150%;
    left: 43%;
    position: absolute;
    top: 100%;
    width: 1px;
}

.feature .feature-box .feature-content h4 {
    color: #0f0f0f;
    font-size: 18px;
    letter-spacing: 0;
    line-height: 22px;
    margin: 0 0 5px;
}

.feature .feature-box .feature-content {
    float: left;
    padding-left: 28px;
    width: 78%;
}

.feature .feature-box .feature-content h4 {
    color: #0f0f0f;
    font-size: 18px;
    letter-spacing: 0;
    line-height: 22px;
    margin: 0 0 5px;
}

.feature .feature-box .feature-content p {
    color: #606060;
    font-size: 13px;
    line-height: 22px;
}

.iconset {
    color: #f4b841;
    padding: 0px;
    border: 1px solid #fdb801;
    border-radius: 50%;
    color: #fdb801;
    font-size: 28px;
    height: 70px;
    line-height: 70px;
    text-align: center;
    width: 70px;
}

/*Product grid*/
.slide-item {
    margin: 4px 0;
}

.Product-grid {
    position: relative;
    overflow: hidden;
}

.Product-grid .Product-grid-wrapper:hover .image-sec > a:after, .Product-grid .Product-grid-wrapper:hover .image-sec > a:before {
    opacity: 1;
    transform: translateX(0%);
}

.Product-grid .Product-grid-wrapper:hover .Product-grid-caption {
    margin-top: -60px;
    transition: 0.8s;
}

.Product-grid .Product-grid-wrapper .Product-grid-caption {
    width: 90%;
    margin-top: -40px;
    margin-left: 12px;
    border-radius: 15px;
    transition: 0.8s;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
}

.Product-grid .Product-grid-wrapper .Product-grid-caption .title {
    letter-spacing: 0.04em;
    line-height: 1em;
}

.Product-grid .Product-grid-wrapper .Product-grid-caption .title:after {
    display: table;
    clear: both;
    content: '';
}

.Product-grid .Product-grid-wrapper .Product-grid-caption ul {
    padding: 0;
}

.Product-grid .Product-grid-wrapper .Product-grid-caption li {
    list-style: none;
    display: inline-block;
}

.Product-grid .Product-grid-wrapper .Product-grid-caption li i {
    color: #b7291e;
}

.Product-grid .Product-grid-wrapper .Product-grid-caption h5 del {
    color: #ccc;
}

.Product-grid .Product-grid-wrapper .Product-grid-caption h5 span {
    color: #000;
}

.Product-grid .Product-grid-wrapper .Product-grid-caption h4 {
    margin-bottom: 10px;
}

.Product-grid .Product-grid-wrapper .Product-grid-caption .action a {
    padding: 0 20px;
}

.Product-grid-caption .product-action a {
    display: inline-block;
    font-size: 16px;
    width: 36px;
    height: 36px;
    line-height: 36px;
    text-align: center;
    margin: 0 3px;
    color: #000;
    background-color: #E2B04D;
    border-radius: 5px;
    opacity: 1;
    z-index: 99;
}

.Product-grid-caption .price {
    font-weight: 700;
    font-size: 20px;
    line-height: 36px;
    margin: 0 3px;
    color: #000;
    z-index: 9;
}

.Product-grid .Product-grid-wrapper.Product-grid .image-sec {
    height: 300px;
}

.Product-grid .Product-grid-wrapper.Product-grid .image-sec img {
    background: rgba(255, 255, 255, 0.7);
    border-radius: 15px;
    width: 100%;
    height: 100%;
    position: relative;
    object-fit: contain;
    object-position: center;
}


/*-------- 26. Login register style ---------*/
.login-register-wrap {
    display: none;
}

.login-register-area {
    padding: 100px 0 100px;
}

.login-register-wrap h3 {
    font-size: 20px;
    margin: 0;
    color: #1D1D1D;
}

.login-register-wrap h3 i {
    margin-right: 10px;
}

.login-register-wrap h3 a {
    color: #969696;
}

.login-register-wrap h3 a:hover {
    color: #E2B04D;
}

.login-register-wrap .login-register-form {
    margin: 30px 0 0;
}

.login-register-wrap .login-register-form .sin-login-register {
    margin: 0 0 10px;
}

.login-register-wrap .login-register-form .sin-login-register input {
    background: transparent;
    border: 1px solid #CDCDCD;
    height: 70px;
    width: 100%;
    padding: 5px 20px;
    color: #777;
}

.login-register-wrap .login-register-form .sin-login-register input:focus {
    border: 1px solid #262626;
}

.login-register-btn button {
    border: none;
    padding: 0;
    font-weight: bold;
    text-transform: uppercase;
    color: #fff;
    line-height: 1;
    margin-right: 7px;
}

.login-register-btn button.login {
    padding: 18px 50px;
    background-color: #ffffff;
    border: 2px solid #E2B04D;
    border-radius: 8px;
    color: #000000;
}

.login-register-btn button.login-fb {
    padding: 18px 30px;
    background-color: #435DA7;
}

.login-register-btn button:hover {
    background-color: #E2B04D;
}

.remember-lost-wrap {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin: 23px 0 45px;
    justify-content: space-between;
}

.remember-lost-wrap .remember-wrap {
    display: flex;
}

.remember-lost-wrap .remember-wrap input {
    width: 16px;
    height: auto;
}

.remember-lost-wrap .remember-wrap label {
    line-height: 1;
    margin: 0 0 0 10px;
    color: #1D1D1D;
}

.remember-lost-wrap .lost-wrap a {
    line-height: 1;
    color: #D25B5B;
}

.remember-lost-wrap .lost-wrap a:hover {
    text-decoration: underline;
}

.register-form-wrap {
    display: none;
}

.login-register-wrap {
    h3 {
        i {
            margin-right: 10px;
        }

        font-size: 20px;
        margin: 0;
        color: #1D1D1D;

        a {
            color: #969696;
        }
    }

    .login-register-form {
        margin: 30px 0 0;

        .sin-login-register {
            margin: 0 0 10px;

            input {
                background: transparent;
                border: 1px solid #CDCDCD;
                height: 70px;
                padding: 5px 20px;
                color: #777;

                &:focus {
                    border: 1px solid #262626;
                }
            }
        }
    }
}


.padding-10 {
    padding-top: 10px;
}

.img-bottom {
    position: absolute;
    top: 54%;
    width: 100%;
    background-color: #000;
    opacity: 0.7;
    padding: 25px 0;
    display: none;
    transition: 0.5s;
    text-align: center;
}

.img-bottom li {
    list-style: none;
    display: inline-block;
}

.img-bottom li i {
    color: #fff;
    padding: 0 10px;
}

/*our categreses*/

.fancy-title-view1 {
    float: left;
    width: 100%;
    margin-bottom: 70px;
    text-align: center;
}

.fancy-title-view1 h2 {
    margin-bottom: 8px;
    font-size: 40px;
    font-weight: 700;
    display: block;
}

.fancy-title-view1 p {
    margin-bottom: 0;
    display: inline-block;
    width: 65%;
}

.fancy-title-view1 i {
    font-size: 22px;
}

.fancy-title-view1-color h2, .fancy-title-view1-color p {
    color: #ffffff;
}

.light-transparent {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    opacity: 0.65;
    background-color: #000;
}

.categories-view1-full {
    padding: 80px 0 80px 0;
    margin-top: 0;
    margin-bottom: 0;
    background: url(../images/catgrybg.jpg);
    background-attachment: fixed;
    position: relative;
    min-height: 100vh;
}

.categories-1, .categories-view1-wrap {
    float: left;
    width: 100%;
}

.categories-1, .categories-view1-wrap a {
    color: #000;
}

.categories-1 ul li {
    list-style: none;
}

.categories-1 > ul > li {
    float: none;
    display: inline-block;
    margin: 0 0 30px 0;
    vertical-align: top;
}

.categories-view1-wrap {
    box-shadow: 0 0 25px 0 rgba(0, 0, 0, 0.08);
    padding: 90px 50px 30px 95px;
    border-radius: 10px;
    position: relative;
    background-color: #ffffff;
}

.categories-view1 i {
    position: absolute;
    left: 40%;
    top: 36px;
    font-size: 30px;
    color: #b7291e;
    width: 70px;
    height: 70px;
    border-radius: 0 0 100% 100%;
    text-align: center;
    padding-top: 18px;
    margin-top: -36px;
    background-color: #ffffff;
    border: 1px solid #eee;
    border-left: none;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
}

.categories-view1 li:hover i {
    color: #ffffff;
    background-color: #b7291e;
}

.categories-view1 a {
    display: block;
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 0;
}

.categories-view1 small {
    font-size: 13px;
    color: #666;
}

.categories-view1 span {
    position: absolute;
    right: 5px;
    top: 8px;
    font-size: 90px;
    font-weight: 500;
    color: #999;
    opacity: 0.07;
    line-height: 1;
}

.main-load-btn {
    float: left;
    width: 100%;
    text-align: center;
    margin: 30px 0;
}

.main-load-btn a {
    display: inline-block;
    line-height: 1;
    padding: 18px 45px;
    color: #ffffff;
    border-radius: 40px;
    font-size: 16px;
    font-weight: 600;
    -webkit-transition: all 0.4s ease-in-out;
    -moz-transition: all 0.4s ease-in-out;
    -ms-transition: all 0.4s ease-in-out;
    -o-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
    background-color: #b7291e;
}

.main-load-btn a:hover {
    background-color: #000;
}

.more-spacer {
    float: left;
    width: 100%;
    margin: 10px 0;
}

/*Our Services*/
.center-heading {
    text-align: center;
}

.center-heading .section-title {
    font-weight: 400;
    font-size: 28px;
    color: #3B566E;
    letter-spacing: 1.1px;
    line-height: 38px;
    margin-bottom: 20px;
}

.center-heading.colored .section-title {
    color: #ffffff;
}

.center-text {
    text-align: center;
    font-weight: 400;
    font-size: 16px;
    color: #6F8BA4;
    line-height: 28px;
    letter-spacing: 1px;
    margin-bottom: 50px;
}

.center-text.colored {
    color: #C7E5FF;
}

.center-text p {
    margin-bottom: 30px;
}

.services-small-item {
    display: block;
    background: #fff;
    box-shadow: 0 2px 48px 0 rgba(0, 0, 0, 0.06);
    border-radius: 5px;
    padding: 40px 28px;
    text-align: center;
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    position: relative;
    z-index: 2;
    margin-bottom: 30px;
}

.services-small-item:before {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    border-radius: 5px;
    background-image: linear-gradient(135deg, #b7291e 0%, #a78537 100%);
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    opacity: 0;
}

.services-small-item.active:before, .services-small-item:hover:before {
    opacity: 1;
}

.services-small-item.active .icon:before, .services-small-item:hover .icon:before {
    opacity: .26;
}

.services-small-item.active .icon i, .services-small-item:hover .icon i {
    background: -webkit-linear-gradient(#fff, #fff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.services-small-item.active .services-title, .services-small-item:hover .services-title {
    color: #ffffff;
}

.services-small-item.active p, .services-small-item:hover p {
    color: #ffffff;
}

.services-small-item.active .button i, .services-small-item:hover .button i {
    background-image: linear-gradient(135deg, #fff 0%, #fff 100%) !important;
    color: #2b708b !important;
}

.services-small-item:hover {
    margin: -10px;
}

.services-small-item .icon {
    width: 139px;
    height: 113px;
    margin: auto;
    position: relative;
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}

.services-small-item .icon i {
    display: block;
    height: 67px;
    line-height: 67px;
    position: absolute;
    width: 100%;
    top: 22px;
    z-index: 2;
    font-size: 28px;
    background-image: linear-gradient(135deg, #b7291e 0%, #b7291e 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}

.services-small-item .services-title {
    font-weight: 400;
    font-size: 16px;
    color: #3B566E;
    letter-spacing: 0.7px;
    margin-bottom: 15px;
    position: relative;
    z-index: 2;
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}

.services-small-item p {
    font-weight: 400;
    font-size: 14px;
    color: #6F8BA4;
    letter-spacing: 0.88px;
    line-height: 26px;
    position: relative;
    z-index: 2;
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    margin-bottom: 30px;
}

.services-small-item .button {
    position: relative;
    z-index: 2;
}

.services-small-item .button i {
    width: 42px;
    height: 42px;
    background-image: linear-gradient(135deg, #b7291e 0%, #b7291e 100%);
    line-height: 42px;
    text-align: center;
    -webkit-border-radius: 100px;
    -moz-border-radius: 100px;
    border-radius: 100px;
    color: #fff;
    padding-left: 3px;
}

.services-small-item:hover + .item-bg {
    bottom: 30px;
}

.item-bg {
    content: '';
    position: absolute;
    width: 80%;
    height: 15px;
    bottom: 15px;
    left: 0;
    right: 0;
    margin: auto;
    border-bottom-right-radius: 5px;
    border-bottom-left-radius: 5px;
    z-index: 1;
    background: #fff;
    box-shadow: 0 2px 48px 0 rgba(0, 0, 0, 0.06);
    -webkit-transition: all 0.3s ease 0s;
    -moz-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}

/*our-team*/

.team-area .single-item {
    margin-bottom: 30px;
}

.team-area .item .thumb {
    position: relative;
    overflow: hidden;
    z-index: 1;
}

.team-area .item .thumb::after {
    background: #232323 none repeat scroll 0 0;
    content: "";
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: all 0.35s ease-in-out;
    -webkit-transition: all 0.35s ease-in-out;
    -moz-transition: all 0.35s ease-in-out;
    -ms-transition: all 0.35s ease-in-out;
    -o-transition: all 0.35s ease-in-out;
    width: 100%;
}

.team-area .team-items .item:hover .thumb::after {
    opacity: 0.7;
}

.team-area .item .thumb .overlay {
    top: -100%;
    left: 0;
    padding: 20px;
    position: absolute;
    text-align: center;
    -webkit-transition: all 0.35s ease-in-out;
    -moz-transition: all 0.35s ease-in-out;
    -ms-transition: all 0.35s ease-in-out;
    -o-transition: all 0.35s ease-in-out;
    transition: all 0.35s ease-in-out;
    width: 100%;
    z-index: 1;
}

.team-area .item:hover .thumb .overlay {
    top: 50%;
    transform: translate(-50%, -20%);
    left: 50%;
}

.team-area .item .thumb .overlay p {
    color: #ffffff;
}

.team-area .item .thumb .overlay h4 {
    color: #ffffff;
    display: inline-block;
    position: relative;
    text-transform: uppercase;
}

.team-area .item .thumb img {
    -webkit-transition: all 0.35s ease-in-out;
    -moz-transition: all 0.35s ease-in-out;
    -ms-transition: all 0.35s ease-in-out;
    -o-transition: all 0.35s ease-in-out;
    transition: all 0.35s ease-in-out;
}

.team-area .item:hover .thumb img {
    opacity: .6;
}

.team-area .item .thumb .social li {
    display: inline-block;
}

.team-area .item .thumb .social li a {
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    color: #ffffff;
    display: inline-block;
    height: 40px;
    line-height: 40px;
    margin: 0 2px;
    text-align: center;
    width: 40px;
}

.team-area .item:hover .info {
    margin-top: -70px;
    transition: 0.8s;
}

.team-area .info {
    background: #ffffff none repeat scroll 0 0;
    -moz-box-shadow: 0 0 10px #cccccc;
    -webkit-box-shadow: 0 0 10px #cccccc;
    -o-box-shadow: 0 0 10px #cccccc;
    box-shadow: 0 0 10px #cccccc;
    padding: 40px 20px 20px;
    position: relative;
    text-align: center;
    z-index: 9;
    width: 90%;
    margin-left: 17px;
    margin-top: -40px;
    border-radius: 15px;
    transition: 0.8s;
}

.team-area .info .message {
    height: 50px;
    line-height: 40px;
    margin-left: -25px;
    margin-top: -25px;
    position: absolute;
    text-align: center;
    top: 0;
    width: 50px;
}

.team-area .info .message a {
    background: #fff none repeat scroll 0 0;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    -moz-box-shadow: 0 0 10px #cccccc;
    -webkit-box-shadow: 0 0 10px #cccccc;
    -o-box-shadow: 0 0 10px #cccccc;
    box-shadow: 0 0 10px #cccccc;
    box-sizing: border-box;
    color: #b7291e;
    display: inline-block;
    font-size: 20px;
    height: 50px;
    line-height: 50px;
    width: 50px;
}

.team-area .info .message a i {
    font-weight: 500;
}

.team-area .info h4 {
    font-weight: 600;
    margin-bottom: 5px;
    text-transform: capitalize;
}

.team-area .info span {
    color: #b7291e;
    font-weight: 600;
    text-transform: uppercase;
}

.team-area .social li.twitter a {
    background-color: #00b6f1;
}

.team-area .social li.pinterest a {
    background-color: #bd081c;
}

.team-area .social li.facebook a {
    background-color: #3b5998;
}

.team-area .social li.google-plus a {
    background-color: #df4a32;
}

.team-area .social li.vimeo a {
    background-color: #1ab7ea;
}

.team-area .social li.instagram a {
    background-color: #cd486b;
}

/*why choose us*/
.choose-icon {
    position: relative;
}

.choose-title p {
    padding: 0 190px;
    margin-bottom: 10px;
}

.choose-icon i {
    font-size: 40px;
    color: #e8bc00;
    margin-bottom: 20px;
    display: inline-block;
}

.choose-wrap {
    border: 1px solid #e6e6e6;
    padding: 50px 30px;
    position: relative;
}

.choose-wrap p {
    position: relative;
}

.choose-wrap h4 {
    font-weight: 600;
    color: #1e2331;
    margin-bottom: 17px;
    font-size: 18px;
    text-transform: capitalize;
    position: relative;
}

.choose-wrap a {
    font-size: 14px;
    font-weight: 600;
    position: relative;
    color: #e8bc00;
}

/*our articles*/
.blog-details .post .post-wrapper .blog-meta .post-meta-box .post-meta .post-date, .our_articles .post .post-wrapper .post-img .post-date {
    text-align: center;
    width: 70px;
    margin-top: 0;
    z-index: 1;
    position: absolute;
    left: 20px;
    top: 20px;
    text-transform: capitalize;
}

.blog-details .post .post-wrapper .blog-meta .post-meta-box .post-meta .post-date .year, .our_articles .post .post-wrapper .post-img .post-date .year {
    background-color: #111111;
}

.our_articles .post .post-wrapper .blog-meta .post-meta {
    display: flex;
    justify-content: space-between;
}

.blog-details .post .post-wrapper .blog-meta .post-meta-box .post-meta .post-date .date, .our_articles .post .post-wrapper .post-img .post-date .date {
    font-size: 30px;
    line-height: 1.1;
    padding: 7px 0;
}

.our_articles .post .post-wrapper .blog-meta .post-heading h2 {
    margin-top: -10px;
    line-height: 28px;
}

.our_articles .post .post-wrapper .post-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-top: 1px solid #f5f5f5;
    background: #fff;
}

.our_articles .post .post-wrapper .post-footer .post-author a {
    color: #000;
}

.our_articles .post .post-wrapper .post-footer > a {
    text-transform: uppercase;
    padding: 10px 20px;
    background: #b7291e;
    width: 40%;
    text-align: center;
    border-radius: 10px;
    margin: 10px 20px;
}

.our_articles .post .post-wrapper .post-footer > a:hover {
    background: #000;
}

/*footer*/
.footer {
    background: #000;
    padding: 80px 0 20px;
}

.footer .social-link {
    margin-top: 15px;
}

.footer ul {
    padding: 0;
}

.footer li {
    list-style: none;
}

.footer .social-link > li {
    display: inline-block;
    list-style: none;
}

.footer .social-link > li > a {
    color: #ffffff;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
    height: 2.4em;
    line-height: 2.4em;
    width: 2.4em;
    display: block;
    border-radius: 50%;
    text-align: center;
}

.footer .social-link > li > a.twitter:hover {
    background: #00acee;
}

.footer .social-link > li > a.linkedin:hover {
    background: #0e76a8;
}

.footer .social-link > li > a.instagram:hover {
    background: #3f729b;
}

.footer .social-link > li > a.facebook:hover {
    background: #3b5998;
}

.footer .footer-title {
    color: #ffffff;
    font-size: 20px;
}

.footer .footer-link > li > a > i {
    font-size: 12px;
    margin-right: 5px;
}

.btn-submits {
    border-color: #b7291e;
    color: #fff;
    background: #b7291e;
    width: 100%;
    border-radius: 10px;
}

.offset-lg-1 {
    margin-left: 0;
}

.footer .footer-link > li > a {
    padding: 8px 0;
    display: block;
}

.footer .copyright {
    text-align: center;
    color: #ffffff;
    padding-top: 20px;
    border-top: 1px solid rgba(152, 152, 152, 0.5);
    margin: 30px 0 0;
}

/*back to top*/
#back-top {
    text-align: center;
    display: none;
}

#back-top a {
    display: block;
    width: 40px;
    height: 40px;
    border-radius: 0;
    text-align: center;
    line-height: 36px;
    border: #b7291e solid 1px;
    color: #ffffff;
    border-radius: 50%;
    background: #b7291e;
    transition-duration: 0.3s;
    font-size: 22px;
    box-shadow: rgba(0, 0, 0, 0.05) 0 0 10px;
    position: fixed;
    z-index: 100;
    bottom: 60px;
    right: 20px;
}

/*======================
3. Blog
========================*/
/*sub header*/
.subheader {
    background-image: url(../images/subheader.jpg);
    text-align: center;
    height: 300px;
    padding-top: 140px;
}

.subheader:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: #2d3e52;
    opacity: 0.5;
}

.subheader h1 {
    line-height: 1;
}

.subheader ul li a {
    color: #fff;
}

.subheader ul li a:after {
    content: '/';
    color: #fff;
    font-size: 14px;
    margin: 0 5px;
}

.subheader ul li.active {
    color: #b7291e;
}

/*sidebar*/
.sidebar_wrap .sidebar .sidebar_widgets {
    padding: 20px;
    background: #fff;
    border: #eee solid 1px;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
}

.sidebar_wrap .sidebar .sidebar_widgets .widget_title {
    margin: -20px -20px 20px;
    padding: 20px;
}

.sidebar_wrap .sidebar .sidebar_widgets .categories li {
    position: relative;
    margin-bottom: 10px;
}

.sidebar_wrap .sidebar .sidebar_widgets .categories li:last-child {
    margin-bottom: 0;
}

.sidebar_wrap .sidebar .sidebar_widgets .categories li a {
    font-weight: 500;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.sidebar_wrap .sidebar .sidebar_widgets .popular_post li .post .post-wrapper {
    width: 100%;
    display: flex;
    align-items: center;
}

.sidebar_wrap .sidebar .sidebar_widgets .popular_post li .post .post-wrapper .popular_post_img {
    flex: 0 0 80px;
    max-width: 80px;
    height: 80px;
}

.sidebar_wrap .sidebar .sidebar_widgets .popular_post li .post .post-wrapper .popular_post_title {
    flex: 0 0 calc(100% - 80px);
    max-width: calc(100% - 80px);
    padding: 5px 15px;
    width: 100%;
}

.sidebar_wrap .sidebar .sidebar_widgets .popular_post li .post .post-wrapper .popular_post_title h6 {
    margin-bottom: 10px;
}

.blog-details .post-details-tags-social .tags a, .sidebar_wrap .sidebar .sidebar_widgets .tags a {
    display: inline-block;
    padding: 5px 15px;
    border: #eee solid 1px;
    margin: 0 5px 10px 0;
    background: #ffffff;
    font-weight: 600;
    border-radius: 50px;
    color: #838383;
}

.blog-details .post-details-tags-social .tags a:hover, .sidebar_wrap .sidebar .sidebar_widgets .tags a:hover {
    border-color: #b7291e;
    color: #b7291e;
}

/*======================
4. Blog Details
========================*/
.blog-details .post .post-wrapper .post-img, .blog-details .post .post-wrapper .blog-meta .blog-video iframe {
    height: 450px;
}

.blog-details .post .post-wrapper .blog-meta .post-meta-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.blog-details .post .post-wrapper .blog-meta .post-meta-box .post-meta {
    display: flex;
}

.blog-details .post .post-wrapper .blog-meta .post-meta-box .post-meta .post-date {
    position: absolute;
    right: 0;
    height: 75px;
    margin-top: 0;
    left: 20px;
    top: 20px;
}

.blog-details .post .post-wrapper .blog-meta .post-heading h2 {
    font-size: 30px;
    font-weight: 600;
}

.blog-details .post .post-wrapper .blog-meta .post-heading h2:after {
    content: '';
    display: block;
    width: 80px;
    height: 2px;
    background: #b7291e;
    margin-top: 20px;
}

.blog-details .post .post-wrapper .blog-meta .post-author {
    display: flex;
    align-items: center;
    margin-right: 15px;
    flex-wrap: wrap;
    width: auto;
    border: none;
}

.blog-details .post .post-wrapper .blog-meta .post-author .author-img {
    margin-right: 15px;
    flex: 0 0 40px;
    max-width: 40px;
    height: 40px;
    border-radius: 50%;
}

.blog-details .post-details-tags-social .tags-box {
    display: flex;
    align-items: flex-start;
}

.blog-details .post-details-tags-social .tags {
    margin-left: 15px;
}

.blog-details .post-details-tags-social .social-media-box ul {
    justify-content: flex-end;
}

.blog-details .post-details-tags-social .social-media-box ul li {
    display: flex;
    align-items: center;
    margin-left: 10px;
}

.blog-details .post-details-tags-social .social-media-box ul li a {
    width: 35px;
    height: 35px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    z-index: 1;
}

.sidebar_wrap .sidebar .sidebar_widgets {
    padding: 20px;
    background: #fff;
    border: #ccc solid 1px;
}

.sidebar_wrap .sidebar .sidebar_widgets .widget_title {
    margin: 0 0 0;
    padding: 0 0 20px 0;
    position: relative;
    text-align: left;
}

.sidebar_wrap .sidebar .sidebar_widgets .widget_title:after {
    content: '';
    display: block;
    width: 80px;
    height: 2px;
    background: #b7291e;
    margin: 20px 0 auto;
}

.sidebar_wrap .sidebar .sidebar_widgets .widget_title h5 {
    font-size: 20px;
    line-height: 1;
    font-weight: 600;
    text-transform: uppercase;
    color: #000000;
}

.blog-details .post-details-tags-social .social-media-box ul li .social-number {
    padding: 2px 10px;
    border-radius: 0 15px 15px 0;
    margin-left: -8px;
    z-index: 0;
    font-size: 14px;
}

.fb {
    background-color: #3b5998;
}

.tw {
    background-color: #1da1f2;
}

.yt {
    background-color: #b7291e;
}

.ldin {
    background-color: #0077b5;
}

.blog-details .post-author {
    display: flex;
    align-items: center;
    width: 100%;
}

.blog-details .post-author .author-img {
    flex: 0 0 150px;
    max-width: 150px;
    height: 150px;
    margin-right: 15px;
    border-radius: 0%;
}

.blog-details .post-author .author-caption {
    flex: 0 0 calc(100% - 165px);
    max-width: calc(100% - 165px);
    width: 100%;
    position: relative;
}

.blog-details .post-author .author-caption h5 {
    margin-bottom: 10px;
}

.blog-details .post-author .author-caption .authorpost {
    top: 0;
    position: absolute;
    right: 0;
}

.pagination-btn nav ul {
    justify-content: space-between;
}

.comment-box .children, .comment-box .comments {
    margin-bottom: 35px;
}

.comment-box .children {
    padding-left: 95px;
}

.comment-box .comments li.comment {
    list-style: outside none none;
    padding-left: 0;
    margin-bottom: 20px;
}

.comment-box .comments li article {
    display: flex;
    width: 100%;
    position: relative;
    margin-bottom: 20px;
}

.comment-box .comments li article .comment-avatar {
    margin-right: 20px;
    float: left;
    overflow: hidden;
    height: 80px;
    border-radius: 50px;
}

.comment-box .comments li article .comment-content {
    float: right;
    width: calc(100% - 50px);
}

.comment-box .comments li article .comment-content .comment-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 15px;
    flex-wrap: wrap;
}

.comment-box .comments li article .comment-content .comment-meta .comment-meta-reply .comment-reply-link {
    font-size: 20px;
    padding: 0 15px;
}

.comment-box .comments li article .comment-content .comment-meta .comment-meta-header .post-date .date {
    display: inline-block;
    padding: 8px 15px;
    position: relative;
    line-height: 10px;
    font-size: 14px;
    position: relative;
    color: #fff;
    border-radius: 10px;
}

/*======================
5. Listing
========================*/
.listing-top-heading {
    border-bottom: 2px solid #b7291e;
    background: #fff;
    padding: 0 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.listing-top-heading h6 {
    padding: 20px 0;
}

.listing-top-heading .sort-by {
    display: flex;
    align-items: center;
}

.listing-top-heading .sort-by span {
    white-space: nowrap;
    margin-right: 15px;
}

.listing-top-heading .sort-by .custom-select {
    margin-bottom: 0;
    background: #fff;
}

.checkbox-group .form-group {
    margin-bottom: 1px;
    background: #eee;
    padding: 15px;
}

.checkbox-group .form-group label {
    margin-bottom: 0;
    line-height: 1.5;
}

.checkbox-group button {
    margin-top: 20px;
}

.widget_range .irs--round .irs-from, .widget_range .irs--round .irs-to, .widget_range .irs--round .irs-single {
    background-color: transparent;
    color: #ffffff;
    font-size: 12px;
    font-weight: 600;
}

.widget_range .irs--round .irs-from, .widget_range .irs--round .irs-to, .widget_range .irs--round .irs-single {
    background: #b7291e;
}

.widget_range .irs--round .irs-from:before, .widget_range .irs--round .irs-to:before, .widget_range .irs--round .irs-single:before {
    border-top-color: #b7291e;
}

.widget_range .irs--round .irs-handle {
    border: none;
    width: 15px;
    height: 15px;
    top: 30px;
    background-color: #b7291e;
    cursor: pointer;
}

.widget_range .irs--round .irs-bar {
    background-color: #b7291e;
}

/*======================
6. Listing Detail
========================*/
.listing-details-inner .detail-slider-for .slide-item {
    height: 450px;
    position: relative;
    margin: 0;
}

.listing-details-inner .detail-slider-for .slide-item:hover .popup:after, .listing-details-inner .detail-slider-for .slide-item:hover .popup:before {
    opacity: 1;
}

.listing-details-inner .listing-meta-sec .hotel-type ul li {
    text-transform: uppercase;
    font-size: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 5px;
}

.listing-details-inner .listing-meta-sec .hotel-type ul li:last-child {
    margin-bottom: 0;
}

.listing-details-inner .listing-meta-sec .listing-testimonial .tesimonial-item .testimonial-author {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin-top: 15px;
}

.listing-details-inner .listing-meta-sec .amenities .icon-box {
    background-color: #f5f5f5;
    height: 42px;
    display: flex;
    align-items: center;
    font-size: 14px;
    margin-bottom: 1px;
}

.listing-details-inner .listing-meta-sec .amenities .icon-box i {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    float: left;
    background: #b7291e;
    color: #fff;
    height: 42px;
    font-size: 2em;
    margin-right: 15px;
}

.listing-details-inner .need-help ul li {
    position: relative;
}

.listing-details-inner .need-help ul li i {
    margin: 5px;
}

.listing-details-inner .listing-meta-sec .travel-info > .row > div {
    border-right: 1px solid #fff;
}

.listing-details-inner .listing-meta-sec .travel-info .head {
    border-bottom: 1px solid #fff;
}

.listing-details-inner .listing-meta-sec .travel-info .travel-info-body .date-wrapper {
    display: flex;
    align-items: center;
}

.listing-details-inner .listing-meta-sec .travel-info .travel-info-body .date-wrapper .icon {
    margin-right: 10px;
    position: relative;
    top: -3px;
    width: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.listing-details-inner .listing-meta-sec .travel-info .travel-info-body .date-wrapper .text p {
    line-height: 0.5;
}

/*======================
7. Booking
========================*/
/*======================
8. About Us
========================*/
.about-counter {
}

.about-counter .counter-box .counter-box-inner {
    width: 100%;
    position: relative;
    background: #fff;
    padding: 40px 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 4px 3px 10px 0 rgba(0, 0, 0, 0.08);
}

.about-counter .counter-box .counter-box-inner .counter .icon {
    font-size: 48px;
    height: 48px;
    line-height: 48px;
    margin-bottom: 10px;
    color: #ccc;
}

.about-counter .counter-box .counter-box-inner .counter .count {
    font-size: 32px;
    line-height: 1;
    font-weight: 700;
}

/*======================
9. 404
========================*/
.page-404 {
    background-image: url(../images/catgrybg.jpg);
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: auto;
}

.page-404 .page-404-text {
    width: 100%;
    text-align: center;
    border: 10px solid #fff;
    margin: 0 auto;
    border-radius: 8px;
}

.page-404 .page-404-text .text-wrapper h1 {
    font-size: 12vw;
    line-height: 1;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 10px;
}

.page-404 .page-404-text .text-wrapper h6 {
    font-size: 18px;
    line-height: 22px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}

/*======================
10. Coming Soon
========================*/
.coming-soon {
    background-image: url(../images/catgrybg.jpg);
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: auto;
}

.coming-soon .coming-soon-img {
    min-height: 450px;
}

.coming-soon .coming-soon-text {
    padding: 80px 40px;
    background-color: #fff;
    text-align: center;
}

.coming-soon .coming-soon-text h1 {
    font-size: 60px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 10.5px;
}

.coming-soon .coming-soon-text .counter {
    display: flex;
    justify-content: center;
    margin: 0 0 30px;
}

.coming-soon .coming-soon-text .counter .counter-box {
    text-align: center;
    width: 25%;
    padding: 0 15px;
    margin: 0 15px;
    position: relative;
    background-color: #b7291e;
}

.coming-soon .coming-soon-text .counter .counter-box .inner-box {
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    border-radius: 0;
    margin-bottom: 10px;
    font-size: 50px;
    line-height: 1;
    margin-top: 20px;
    font-weight: 600;
}

.coming-soon .newsletter-form .group-form .input-group-append {
    pointer-events: all;
    width: 80px;
}

.coming-soon .coming-soon-contact ul li {
    text-align: center;
    width: 33.33%;
    margin-bottom: 20px;
}

.coming-soon .social-media ul {
    justify-content: center;
}

.coming-soon .social-media ul li {
    margin: 0 10px;
    font-size: 22px;
}

/*======================
11. Contact Us
========================*/
.contact-info-box:hover {
    background: #fff;
}

.contact-info-box {
    background: #fff;
    padding-top: 72px;
    text-align: center;
    max-width: 310px;
    height: 310px;
    margin: 0 auto;
    border-radius: 50%;
}

.contact-info-box i {
    height: 75px;
    width: 75px;
    color: #fff;
    background: #b7291e;
    border-radius: 50%;
    line-height: 75px;
    font-size: 30px;
    margin-bottom: 25px;
    display: inline-block;
}

.contact-info-box h6 {
    line-height: 26px;
}

/*======================
12. Faqs
========================*/
.faqs .custom-accordion .card .card-body {
    padding: 15px;
}

/*======================
13. Gallery
========================*/
.gallery .tabs .nav-tabs {
    justify-content: center;
}

.gallery .gallery-item {
    height: 300px;
    position: relative;
    overflow: hidden;
}

/* Fixes */
.about-left-side {
    max-width: 560px;
}

.banner-tabs .tab-content {
    padding: 50px 0;
}

.quick-quote h5::after, .need-help h5::after {
    content: '';
    display: block;
    width: 80px;
    height: 2px;
    background: #b7291e;
    margin: 20px 0 auto;
}


.text-ellipsis {
    display: -webkit-box;
    overflow: hidden;
    text-overflow: ellipsis;
    word-wrap: break-word;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
}

.text-ellipsis-1 {
    -webkit-line-clamp: 1;
}

.text-ellipsis-2 {
    -webkit-line-clamp: 2;
}

.text-ellipsis-3 {
    -webkit-line-clamp: 3;
}

.text-ellipsis-4 {
    -webkit-line-clamp: 4;
}

.text-ellipsis-5 {
    -webkit-line-clamp: 5;
}

.p-0 {
    padding: 0 !important;
}

.p-1 {
    padding: 0.25rem !important;
}

.p-2 {
    padding: 0.5rem !important;
}

.p-3 {
    padding: 1rem !important;
}

.p-4 {
    padding: 1.5rem !important;
}

.p-5 {
    padding: 3rem !important;
}

.py-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.py-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
}

.py-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
}

.py-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
}

.py-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
}

.py-5 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
}

.px-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
}

.px-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
}

.px-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
}

.px-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
}

.px-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
}

.px-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !important;
}

.pt-0 {
    padding-top: 0 !important;
}

.pt-1 {
    padding-top: 0.25rem !important;
}

.pt-2 {
    padding-top: 0.5rem !important;
}

.pt-3 {
    padding-top: 1rem !important;
}

.pt-4 {
    padding-top: 1.5rem !important;
}

.pt-5 {
    padding-top: 3rem !important;
}

.pe-0 {
    padding-right: 0 !important;
}

.pe-1 {
    padding-right: 0.25rem !important;
}

.pe-2 {
    padding-right: 0.5rem !important;
}

.pe-3 {
    padding-right: 1rem !important;
}

.pe-4 {
    padding-right: 1.5rem !important;
}

.pe-5 {
    padding-right: 3rem !important;
}

.pb-0 {
    padding-bottom: 0 !important;
}

.pb-1 {
    padding-bottom: 0.25rem !important;
}

.pb-2 {
    padding-bottom: 0.5rem !important;
}

.pb-3 {
    padding-bottom: 1rem !important;
}

.pb-4 {
    padding-bottom: 1.5rem !important;
}

.pb-5 {
    padding-bottom: 3rem !important;
}

.ps-0 {
    padding-left: 0 !important;
}

.ps-1 {
    padding-left: 0.25rem !important;
}

.ps-2 {
    padding-left: 0.5rem !important;
}

.ps-3 {
    padding-left: 1rem !important;
}

.ps-4 {
    padding-left: 1.5rem !important;
}

.ps-5 {
    padding-left: 3rem !important;
}

.m-0 {
    margin: 0 !important;
}

.m-1 {
    margin: 0.25rem !important;
}

.m-2 {
    margin: 0.5rem !important;
}

.m-3 {
    margin: 1rem !important;
}

.m-4 {
    margin: 1.5rem !important;
}

.m-5 {
    margin: 3rem !important;
}

.m-auto {
    margin: auto !important;
}

.mx-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
}

.mx-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
}

.mx-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
}

.mx-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
}

.mx-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
}

.mx-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
}

.mx-auto {
    margin-right: auto !important;
    margin-left: auto !important;
}

.my-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.my-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
}

.my-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
}

.my-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
}

.my-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
}

.my-5 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
}

.my-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
}

.mt-0 {
    margin-top: 0 !important;
}

.mt-1 {
    margin-top: 0.25rem !important;
}

.mt-2 {
    margin-top: 0.5rem !important;
}

.mt-3 {
    margin-top: 1rem !important;
}

.mt-4 {
    margin-top: 1.5rem !important;
}

.mt-5 {
    margin-top: 3rem !important;
}

.mt-6 {
    margin-top: 4.5rem !important;
}

.mt-7 {
    margin-top: 6rem !important;
}

.mt-auto {
    margin-top: auto !important;
}

.me-0 {
    margin-right: 0 !important;
}

.me-1 {
    margin-right: 0.25rem !important;
}

.me-2 {
    margin-right: 0.5rem !important;
}

.me-3 {
    margin-right: 1rem !important;
}

.me-4 {
    margin-right: 1.5rem !important;
}

.me-5 {
    margin-right: 3rem !important;
}

.me-auto {
    margin-right: auto !important;
}

.mb-0 {
    margin-bottom: 0 !important;
}

.mb-1 {
    margin-bottom: 0.25rem !important;
}

.mb-2 {
    margin-bottom: 0.5rem !important;
}

.mb-3 {
    margin-bottom: 1rem !important;
}

.mb-4 {
    margin-bottom: 1.5rem !important;
}

.mb-5 {
    margin-bottom: 3rem !important;
}

.mb-auto {
    margin-bottom: auto !important;
}

.ms-0 {
    margin-left: 0 !important;
}

.ms-1 {
    margin-left: 0.25rem !important;
}

.ms-2 {
    margin-left: 0.5rem !important;
}

.ms-3 {
    margin-left: 1rem !important;
}

.ms-4 {
    margin-left: 1.5rem !important;
}

.ms-5 {
    margin-left: 3rem !important;
}

.ms-auto {
    margin-left: auto !important;
}

.m-lg-0 {
    margin: 0 !important;
}

.m-lg-1 {
    margin: 0.25rem !important;
}

.m-lg-2 {
    margin: 0.5rem !important;
}

.m-lg-3 {
    margin: 1rem !important;
}

.m-lg-4 {
    margin: 1.5rem !important;
}

.m-lg-5 {
    margin: 3rem !important;
}

.m-lg-auto {
    margin: auto !important;
}

.mx-lg-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
}

.mx-lg-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
}

.mx-lg-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
}

.mx-lg-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
}

.mx-lg-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
}

.mx-lg-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
}

.mx-lg-auto {
    margin-right: auto !important;
    margin-left: auto !important;
}

.my-lg-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

.my-lg-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
}

.my-lg-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
}

.my-lg-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
}

.my-lg-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
}

.my-lg-5 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
}

.my-lg-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
}

.mt-lg-0 {
    margin-top: 0 !important;
}

.mt-lg-1 {
    margin-top: 0.25rem !important;
}

.mt-lg-2 {
    margin-top: 0.5rem !important;
}

.mt-lg-3 {
    margin-top: 1rem !important;
}

.mt-lg-4 {
    margin-top: 1.5rem !important;
}

.mt-lg-5 {
    margin-top: 3rem !important;
}

.mt-lg-auto {
    margin-top: auto !important;
}

.me-lg-0 {
    margin-right: 0 !important;
}

.me-lg-1 {
    margin-right: 0.25rem !important;
}

.me-lg-2 {
    margin-right: 0.5rem !important;
}

.me-lg-3 {
    margin-right: 1rem !important;
}

.me-lg-4 {
    margin-right: 1.5rem !important;
}

.me-lg-5 {
    margin-right: 3rem !important;
}

.me-lg-auto {
    margin-right: auto !important;
}

.mb-lg-0 {
    margin-bottom: 0 !important;
}

.mb-lg-1 {
    margin-bottom: 0.25rem !important;
}

.mb-lg-2 {
    margin-bottom: 0.5rem !important;
}

.mb-lg-3 {
    margin-bottom: 1rem !important;
}

.mb-lg-4 {
    margin-bottom: 1.5rem !important;
}

.mb-lg-5 {
    margin-bottom: 3rem !important;
}

.mb-lg-auto {
    margin-bottom: auto !important;
}

.ms-lg-0 {
    margin-left: 0 !important;
}

.ms-lg-1 {
    margin-left: 0.25rem !important;
}

.ms-lg-2 {
    margin-left: 0.5rem !important;
}

.ms-lg-3 {
    margin-left: 1rem !important;
}

.ms-lg-4 {
    margin-left: 1.5rem !important;
}

.ms-lg-5 {
    margin-left: 3rem !important;
}

.ms-lg-auto {
    margin-left: auto !important;
}

.text-uppercase {
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.text-nowrap {
    white-space: nowrap !important;
}

.text-sm {
    font-size: 0.85rem !important;
}

.text-gray {
    color: #aaa !important;
}

.border {
    border: 1px solid #dee2e6 !important;
}

.border-0 {
    border: 0 !important;
}

.border-top {
    border-top: 1px solid #dee2e6 !important;
}

.border-top-0 {
    border-top: 0 !important;
}

.border-end {
    border-right: 1px solid #dee2e6 !important;
}

.border-end-0 {
    border-right: 0 !important;
}

.border-bottom {
    border-bottom: 1px solid #dee2e6 !important;
}

.border-bottom-0 {
    border-bottom: 0 !important;
}

.border-start {
    border-left: 1px solid #dee2e6 !important;
}

.border-solid {
    border: 1px solid #dee2e6 !important;
}

.border-start-0 {
    border-left: 0 !important;
}

.border-primary {
    border-color: #429244 !important;
}

.border-secondary {
    border-color: #6c757d !important;
}

.border-success {
    border-color: #28a745 !important;
}

.border-info {
    border-color: #17a2b8 !important;
}

.border-warning {
    border-color: #ffc107 !important;
}

.border-danger {
    border-color: #dc3545 !important;
}

.border-light {
    border-color: #f8f9fa !important;
}

.border-dark {
    border-color: #000 !important;
}

.border-white {
    border-color: #fff !important;
}

.border-1 {
    border-width: 1px !important;
}

.border-2 {
    border-width: 2px !important;
}

.border-3 {
    border-width: 3px !important;
}

.border-4 {
    border-width: 4px !important;
}

.border-5 {
    border-width: 5px !important;
}

.d-inline {
    display: inline !important;
}

.d-inline-block {
    display: inline-block !important;
}

.d-block {
    display: block !important;
}

.d-grid {
    display: grid !important;
}

.d-table {
    display: table !important;
}

.d-table-row {
    display: table-row !important;
}

.d-table-cell {
    display: table-cell !important;
}

.d-flex {
    display: flex !important;
}

.d-inline-flex {
    display: inline-flex !important;
}

.d-none {
    display: none !important;
}

.reset-anchor {
    color: inherit;
    transition: all 0.3s;
}

.reset-anchor:hover, .reset-anchor:focus {
    text-decoration: none;
}

.reset-anchor.width-10 {
    display: inline-block;
    white-space: collapse;
}

.align-baseline {
    vertical-align: baseline !important;
}

.align-top {
    vertical-align: top !important;
}

.align-middle {
    vertical-align: middle !important;
}

.align-bottom {
    vertical-align: bottom !important;
}

.align-text-bottom {
    vertical-align: text-bottom !important;
}

.align-text-top {
    vertical-align: text-top !important;
}

.quantity {
    display: flex;
    align-items: center;
}

.quantity input {
    width: 2rem;
    text-align: center;
}

.quantity button {
    background: none;
    border: none;
    width: 1rem;
    outline: none;
}

.shadow-0 {
    box-shadow: none !important;
}

.form-control {
    display: block;
    width: 100%;
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #212529;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #ced4da;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0;
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.form-control-sm {
    min-height: calc(1.5em + 0.75rem + 2px);
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
    border-radius: 0;
}

.form-control-sm::-webkit-file-upload-button {
    padding: 0.375rem 0.75rem;
    margin: -0.375rem -0.75rem;
    -webkit-margin-end: 0.75rem;
    margin-inline-end: 0.75rem;
}

.form-control-sm::file-selector-button {
    padding: 0.375rem 0.75rem;
    margin: -0.375rem -0.75rem;
    -webkit-margin-end: 0.75rem;
    margin-inline-end: 0.75rem;
}

.form-control-sm::-webkit-file-upload-button {
    padding: 0.375rem 0.75rem;
    margin: -0.375rem -0.75rem;
    -webkit-margin-end: 0.75rem;
    margin-inline-end: 0.75rem;
}

small, .small {
    font-size: 0.875em;
}

.cart-goods-url {
    width: 100px;
    height: 100px;
    border-radius: 9px;
    border: 1px solid #E3E3E3;
    overflow: hidden;
    padding: 0;
    margin: 0;
}

.cart-goods-url-c {
    border-radius: 50%;
}

.user-name {
    font-weight: 600;
    font-size: 20px;
    color: #333333;
    line-height: 40px;
}

.total-price {
    font-weight: 600;
    font-size: 20px;
    color: #E60027;
}

.width-10 {
    width: 10vw;
}

.width-200 {
    width: 200px;
}

.box-shadow {
    box-shadow: 0 0 8px 1px #E8E8E8;
}

.justify-content-evenly {
    justify-content: space-evenly;
}

.PaymentWayItem {
    border-radius: 10px;
    margin-bottom: 20px;

    .inner-row {
        padding: 10px 10px 10px 5px;

        .way-icon {
        }

        .way-name {
            font-size: 28rpx;
            color: #313131;
            font-weight: 500;
            padding: 12px 4px 12px 12px;
        }
    }

    .doPay {
        color: #f56c6c;
        background: #fef0f0;
        border: 1px solid #fbc4c4;
        border-radius: 8px;
        padding: 0 4px;
        margin-right: 4px;
    }
}

.editAddressModal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
}

.modal-dialog {
    position: relative;
    margin: 1% auto;
    width: 50%;
}

.modal-content {
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 5px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.modal-header, .modal-footer {
    padding: 10px;
    border-bottom: 1px solid #ccc;
}

.modal-header {
    border-bottom: 1px solid #ccc;
}

.modal-footer {
    border-top: 1px solid #ccc;
}

.close {
    float: right;
    font-size: 28px;
    font-weight: bold;
}

.close:hover, .close:focus {
    color: #000;
    text-decoration: none;
    cursor: pointer;
}

.message-box {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /*background: rgba(0, 0, 0, 0.5);*/
    display: flex;
    justify-content: center;
    align-items: self-start;
    z-index: 1000;
    transition: padding-top 0.3s ease; /* 添加过渡效果 */

    .message-content {
        padding: 10px 20px;
        border-radius: 8px;
        text-align: center;
    }

    .message-info {
        color: #409eff;
        background: #ecf5ff;
        border: 1px solid #b3d8ff;
    }

    .message-success {
        color: rgb(108, 196, 64);
        background: rgb(235, 247, 229);
        border: 1px solid rgb(191, 230, 172);
    }

    .message-warning {
        color: rgb(231, 165, 66);
        background: rgb(252, 244, 231);
        border: 1px solid rgb(245, 216, 174);
    }

    .message-error {
        color: #f56c6c;
        background: #fef0f0;
        border: 1px solid #fbc4c4;
    }

    .message-content p {
        margin: 0 !important;
    }
}

.hidden {
    display: none;
}

.line-height-1 {
    line-height: 1;
}

.line-height-2 {
    line-height: 2;
}

.line-height-3 {
    line-height: 3;
}

.line-height-4 {
    line-height: 4;
}

.line-height-5 {
    line-height: 5;
}

.my-order {
    min-height: 800px;

    .my-infos {
        background: #F7F8F9;
        border-radius: 1px;
    }

    ul li a {
        font-size: 20px;
        line-height: 40px;
        color: #333333;
    }

    .pic-img {
        width: 100px;
        height: 100px
    }
}

.border-radius-5 {
    border-radius: 5px
}

.border-radius-10 {
    border-radius: 10px
}

.width-1000 {
    width: 100%;
}

.card-tabs {
    background: #F7F8F9;
    border-radius: 0;
    padding: 10px 0;
}

.card-tabs .tab-item:hover,
.card-tabs .tab-item.active {
    font-weight: 600;
    color: #B61920;
    border-bottom: 3px solid #B61920;
}

.left-nav .nav-link {
    text-align: center;
}

.left-nav .nav-link:hover,
.left-nav .nav-link.active {
    font-weight: 600;
    color: #B61920;
}

.is-empty {
    line-height: 5;
    text-align: center;
}

.head-info {
    height: 200px;
    width: 100%;
    text-align: center;
}

.add-address {
    display: inline-block;
    background: #B2231E;
    padding: 0 13px;
    font-weight: 600;
    font-size: 18px;
    color: #FFFFFF;
    line-height: 40px;
}

.address-list {
    .address-item {
        .col-auto.d-flex {
            padding: 0 !important;
        }

        .tab-btn {
            background: #C7C7C7;
            border-radius: 2px;
            font-weight: 400;
            font-size: 12px;
            color: #FFFFFF;
            padding: 4px 8px;
        }

        .tab-btn-default {
            background: #B2231E;
        }

        .label {
            width: 120px;
            text-align: right;
        }

        .label-info {
            font-weight: 500;
            font-size: 20px;
            color: #666666;
            line-height: 40px;
        }
    }
}

.link-error {
    font-weight: 500;
    font-size: 16px;
    color: #B2231E;
    line-height: 48px;
}

.cart-badge {
    position: absolute;
    top: 20px;
    right: 12px;
    transform: translateY(-50%) translateX(100%);

    background-color: #f56c6c;
    border-radius: 10px;
    color: #fff;
    display: inline-block;
    font-size: 12px;
    height: 18px;
    line-height: 1.2;
    padding: 0 4px;
    text-align: center;
    white-space: nowrap;
    border: 1px solid #fff;
}

/*商品页面 START*/
.search-view{
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
}

.search-view .search-in-el,
.search-view .search-but{
    height: 44px;
    line-height: 44px;
    outline: none;
    border: none;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

.search-view .search-in-el{
    border: 1px solid #b1231e;
    line-height: 42px;
    width: 360px;
    padding: 0 15px;
    border-right: none;
}

.search-view .search-but{
    padding: 0 44px;
    line-height: 42px;
    background-color: #b1231e;
    color: #efecec;
    text-align: center;
    user-select: none;
    cursor: pointer;
    border: 1px solid #b1231e;
    position: relative;
    overflow: hidden;
}

.search-view .search-but:hover{
    color: #FFFFFF;
}

.search-view  .but-loading{
    pointer-events: none;
    background-color: #fdc2c1;
    color: #ececec;
}
.search-view  .but-loading::after{
    content:"";
    display:block;
    position:absolute;
    z-index: 2000;
    top:50%;
    left:50%;
    margin-left: -14px;
    margin-top: -14px;
    width:28px;
    height:28px;
    background-image: url('/assets/images/app-loading.png');
    /*background-color: darkgoldenrod;*/
    background-position: center;
    background-repeat: no-repeat;
    background-size: auto 100%;
    /* 添加旋转动画 */
    animation: loading-app-span 0.4s infinite linear;
}
@keyframes loading-app-span {
    0% {
        -webkit-transform: rotate(0);
        transform: rotate(0);
    }
    50% {
        -webkit-transform: rotate(-180deg);
        transform: rotate(-180deg);
    }
    100% {
        -webkit-transform: rotate(-360deg);
        transform: rotate(-360deg);
    }
}

/*商品页面 END*/


/*商品详情页 START*/

.product-details {
    height: 0;
    overflow: hidden;
    /*display: none;*/
}

.product-detail-content {
    display: grid;
    grid-template-columns: auto 1.5fr 1fr;
    align-items: flex-start;
    gap: 20px;
}

.product-detail-content .pro-imgs{
    width: 180px;
    background-color: darkgoldenrod;
}

.pro-imgs .pro-img-el{
    width: 180px;
    height: 180px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    background-color: #FFFFFF;
}


.product-detail-content .pro-img-preview{
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    background-color: #FFFFFF;
}

.product-content{
    margin-top: 40px;
}

.product-content p{
    width: 100%;
}

.product-content p img{
    width: 100%;
    display: block;
    outline: none;
    border: none;
}

#pro-pro-info{

}

#pro-pro-info .product-name{
    font-weight: bold;
    font-size: 20px;
}

#pro-pro-info .product-spec-str{
    font-weight: bold;
    font-size: 20px;
    color: #666666;
    margin-top: 6px;
}
#pro-pro-info .product-price{
    font-weight: bold;
    font-size: 20px;
    color: #b1231e;
    margin-top: 6px;
}

#pro-pro-info .product-attr{
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    font-size: 15px;
    color: #666666;
    padding: 20px 0;
}

#pro-pro-info .number-cart-view{
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    width: fit-content;
    gap: 10px;
}

#pro-pro-info .number-cart-view #add-cart-number{
    width: 100%;
    height: 40px;
    line-height: 40px;
    font-size: 20px;
    text-align: center;
}

#pro-pro-info .number-cart-view .add-cart-but{
    background-color: #b1231e;
    color: #eaeaea;
    width: 168px;
    height: 40px;
    line-height: 40px;
    text-align: center;
    cursor: pointer;
}
#pro-pro-info .number-cart-view .add-cart-but:hover{
    color: #FFF;
    transition: all 0.16s;
    transform: scale(1.01);
}

#pro-pro-info .number-cart-view .add-cart-but:active{
    transition: all 0.16s;
    transform: scale(0.99);
}

.loading-product{
    text-align: center;
}


/*商品详情页 END*/