:root {
    --color-main: #AC13AC;
    --color-bt: #17A013;
    --color-more: #F6BE24;
    --color-bg: #FAE9FA;
    --color-text: #002642;
    --color-hover: #EE2636;
    --font-main: "SVN-Poppins"
}

body {
    font-family: var(--font-main);
    font-size: 14px;
    color: #111;
    top: 0 !important;
    max-width: 1920px;
    min-width: 320px;
    position: relative;
    margin: auto;
    line-height: 1.5;
}

[x-cloak] {
    display: none !important
}

h1,
h2,
h3,
h4,
h5,
h6 {
    line-height: 1.5
}

::-webkit-scrollbar {
    width: 5px;
    height: 5px
}

::-webkit-scrollbar-track {
    -webkit-box-shadow: inset 0 0 6px rgb(0 0 0 / 10%)
}

::-webkit-scrollbar-thumb {
    background: var(--color-main)
}

img {
    max-width: 100%;
    height: auto !important;
    vertical-align: top;
    display: inline-block
}

* {
    box-sizing: border-box
}

a {
    text-decoration: none;
}
b, strong {font-weight:700;}
.h-card, .hidden-seo {
 position: absolute;
 width: 1px;
 height: 1px;
 padding: 0;
 margin: -1px;
 overflow: hidden;
 clip: rect(0, 0, 0, 0);
 white-space: nowrap;
 border-width: 0;
}

.scale-img {
    overflow: hidden
}

.scale-img img {
    transition: all .4s;
}

.scale-img:hover img.w-100 {
    transform: scale(1.15, 1.15);
}
.hover-sang { position: relative; overflow: hidden; }
.hover-sang:before, .hover-sang:after { content: ""; position: absolute; width: 0; height: 0; background: #fffb; }
.hover-sang:before { top: 0; right: 0; }
.hover-sang:after { left: 0; bottom: 0; }
.hover-sang:hover:before, .hover-sang:hover:after { width: 100%; height: 100%; background: #fff0; transition: all 0.75s; }

.more {
    display: inline-block;
    background: var(--color-more);
    color: #fff;
    font-size: 14px;
    font-weight: 600;
    line-height: 20px;
    padding: 10px 25px;
    text-transform: uppercase;
    border-radius: 5px;
}
.more svg {
    display: inline-block;
    margin: 0 4px  0 0;
    width: 20px;
    height: 20px;
}
.more:hover {
    background-color: var(--color-bg);
    color: var(--color-text);
}
.button {
    display: inline-block;
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    /* text-transform: uppercase; */
    background: var(--color-bt);
    padding: 13px 50px;
    line-height: 22px;
    border-radius: 30px;
}
.button:hover {
    background: var(--color-main);
    color: #fff;
} 
.text-split,.text-split-2 {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    -webkit-line-clamp: 3
}
.text-split-2 {
    -webkit-line-clamp: 2;
}
.transition {
    transition: .3s all
}

.share {
    padding: 17px 10px 10px 10px;
    line-height: normal;
    background: rgba(128, 128, 128, .15);
    margin-top: 15px;
    border-radius: 5px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.pagination {
    margin: 30px 0 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px
}

.pagination li a,
.pagination li span {
    cursor: pointer;
    border-radius: 5px !important;
    border: 1px solid #cacaca;
    background: #ffff;
    min-width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #4d4d4d;
    font-size: 14px;
    padding: 5px
}

.pagination li a:hover {
    color: var(--color-main);
    border-color: var(--color-main)
}

.pagination .page-item.active .page-link {
    background: var(--color-main);
    border-color: var(--color-main);
    color: #fff
}

.wrap-main {
    margin: 30px 0
}

.wrap-content {
    max-width: 1330px;
    padding: 0 15px;
    margin: 0 auto
}

.social {
    display: flex;
    align-items: center;
    flex-wrap:wrap;
    gap: 10px;
}

.social a:hover img {
    transform: rotateY(360deg);
    transition: all .5s linear;
}

.header__top {
    background: var(--color-bg);
    /* color: #fff; */
    padding: 11px 0;
}
.header__bottom {padding: 5px 0;background: #fff;}
.header__top-flex {
    display: flex;
    justify-content: space-between;
    gap: 15px;
    align-items: center;
}

.header-left {
    width: calc(50% - 100px);
}
.header-right {
    width: calc(50% - 100px);
    display: flex;
    gap: 15px;
    justify-content: flex-end;
}
.header__top-info {
    display: block;
    padding: 0 0 0 50px;
    line-height: 1.25;
}

.header__top-info.hotline {
    background: url(../images/phone-32.png) no-repeat left center;
}

.header__top-info a {
    font-weight: 600;
    color: var(--color-main);
    text-decoration: underline;
}

.header__top-info a:hover {
    color: var(--color-hover);
}

.header__info-icon {
    width: 16px;
}

.header__info-text {
    font-weight: 500;
}

.header__info-hotline {
    font-size: 22px;
    color: var(--color-hover);
    font-weight: 600;
}

.socialh li a {
    display: block;
    max-width: 35px
}

.header__bottom-flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 15px
}

.header__logo {
    width: 120px;
    margin: 0;
    display: block;
    transition: all 0.5s;
}

.menu_fix .header__logo {
    /* margin: 0; */
    scale: 0.6;
}

.header__logo canvas {
    width: 100%;
    max-width: 100%;
}

.notify-phone {
    animation: notifyPhone 1s infinite ease-in-out
}

@keyframes notifyPhone {
    0% {
        transform: rotate(0) scale(1) skew(1deg)
    }

    10% {
        transform: rotate(-25deg) scale(1) skew(1deg)
    }

    20% {
        transform: rotate(25deg) scale(1) skew(1deg)
    }

    30% {
        transform: rotate(-25deg) scale(1) skew(1deg)
    }

    40% {
        transform: rotate(25deg) scale(1) skew(1deg)
    }

    50% {
        transform: rotate(0) scale(1) skew(1deg)
    }

    100% {
        transform: rotate(0) scale(1) skew(1deg)
    }
}

.search-inline {
    display: flex;
    align-items: center;
    gap: 5px;
    max-width: 230px;
    border-radius: 25px;
    /* border: 1px solid #bababa; */
    background: #fff;
    padding: 5px;
}

.search-inline p {
    width: 32px;
    height: 32px;
    cursor: pointer;
    text-align: center;
    margin: 0;
    background: var(--color-more);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 10px;
    border-radius: 50%;
}

.search-inline input {
    width: calc(100% - 32px);
    height: 32px;
    outline: 0;
    padding: 0;
    border: 0;
    background: 0;
    text-indent: 12px;
    font-size: 12px;
    line-height: 32px;
}

.search-inline input::-webkit-input-placeholder {
    color: #7d7d7d
}

.search-inline input:-moz-placeholder {
    color: #7d7d7d
}

.search-inline input::-moz-placeholder {
    color: #7d7d7d
}

.search-inline input:-ms-input-placeholder {
    color: #7d7d7d
}

.header__lang {
    position: relative;
    z-index: 101
}

.header__lang-button {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    border-radius: clamp(12px, calc(120 / 1200 * 100vw), 120px);
    background: #dae1e7;
    backdrop-filter: blur(8px);
    padding: 10px
}

.header__lang-flag {
    max-width: 35px;
    border-radius: 3px;
    overflow: hidden
}

.header__lang-country {
    font-weight: 700;
    font-size: clamp(13px, calc(14 / 1200 * 100vw), 14px)
}

.header__lang-box {
    position: absolute;
    right: 0;
    margin-top: 10px;
    background: #fff;
    box-shadow: rgba(0, 0, 0, .35) 0 5px 15px;
    padding: 10px;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 150px
}

.header__lang-picker {
    display: flex;
    align-items: center;
    gap: 5px;
    cursor: pointer
}

.header__lang-icon {
    display: inline-block;
    width: 25px
}

.header__lang-name {
    font-size: clamp(13px, calc(14 / 1200 * 100vw), 14px);
    font-weight: 500;
    flex: 1 1 0%
}

.header__lang-picker:hover .header__lang-name {
    color: orange
}

#google_translate_element {
    clear: both;
    width: auto !important;
    text-align: right;
    display: none
}

.skiptranslate {
    display: none !important
}

.menu-res {
    display: none
}

.menu {
    background: var(--color-main);
    position: sticky;
    z-index: 10;
    top: 0;
    left: 0;
    right: 0
}

.menu .wrap-menu {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
}

.menu ul {
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none
}

.menu ul li {
    /* position: relative; */
}

.menu ul.menu-main {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 50%;
    position: relative;
    z-index: 9;
    gap: 1px;
    flex-grow: 1;
}

.menu ul li a {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    color: #000;
    font-size: 15px;
    font-weight: 700;
    text-transform: uppercase;
    transition: .2s;
    padding: 10px;
    gap: 6px
}
.menu .menu-main > li {
    flex-grow: 1;
}

.menu .menu-main > li.menu-search {
    flex-grow: 0;
    width: 230px;
    margin: 0 0 0 30px;
}
.menu .menu-main > li > a {
    padding: 15px 0;
    font-size: 15px;
    font-weight: 600;
    color: #fff;
    line-height: 22px;
    display: block;
    text-align: center;
}

.menu ul li:hover>a {
    color: var(--color-more);
}
.menu ul li a.active {
    background: #0003;
}
.menu_dmsp .menu_lvl {
    position: absolute;
    width: 280px;
    top: calc(100% + 10px);
    opacity: 0;
    visibility: hidden;
    transition: .3s;
    background-color: #fafafa;
    box-shadow: 1px 1px 15px rgba(0, 0, 0, .15)
}

.menu_dmsp .menu_lvl3,
.menu_dmsp .menu_lvl4 {
    left: calc(100% + 1px)
}

.menu_dmsp .menu_lvl2 .menu_lvl3 ul li:hover .menu_lvl4,
.menu_dmsp .menu_lvl2 ul li:hover .menu_lvl3,
.menu_dmsp:not(.block_hover):hover .menu_lvl2 {
    opacity: 1;
    visibility: visible;
    top: 100%
}

.slideshow_left .menu_lvl2 {
    -webkit-transform: perspective(600px) rotateX(0);
    transform: perspective(600px) rotateX(0);
    transform-origin: 0 0 0;
    -webkit-transform-origin: 0 0 0;
    opacity: 1;
    visibility: visible;
    margin-top: 0
}

.menu_vlist_pic {
    max-width: 24px
}

.menu_dmsp .menu_lvl ul li a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    /* text-transform: capitalize; */
    gap: 10px;
    color: #555;
    font-size: 14px;
    line-height: 1.5;
    text-align: left;
    font-weight: 500;
    padding: 10px;
    margin: 0;
    height: auto
}

.menu_dmsp .menu_lvl ul li:hover>a {
    color: var(--color-main)
}

.menu ul li ul li a:after {
    display: none !important
}

.menu_dmsp .menu_lvl ul {
    max-height: calc(100vh - 100px);
    overflow-x: hidden;
    overflow-y: auto;
    padding: 0;
    margin: 0
}

.spacer {
    margin: clamp(45px, calc(60 / 1300 * 100vw), 60px) 0;
}

.pronb-wrap {
    padding: clamp(50px, calc(80 / 1300 * 100vw), 80px) 0;
    background: url(../images/bg-sanpham.jpg) no-repeat center center/ cover;
}

.title-main-ind {
    margin: 0 0 20px 0;
    font-size: 15px;
}

.title-main-ind.d-flex {
    justify-content: space-between;
    align-items: center;
    gap: 0 10px;
}

.title-main-ind .pronb-nav {
    display: flex;
    gap: 8px;
    margin: 15px 0 0 0;
}

.pronb-nav i {
    color: #7d7d7d;
    font-size: 14px;
    border: 1px solid #9a9a9a;
    padding: 7px;
    width: 30px;
    text-align: center;
    border-radius: 50%;
    cursor: pointer;
}

.pronb-nav i:hover {
    background: var(--color-main);
    border-color: var(--color-main);
    color: #fff;
}

.title-main-ind .tt {
    font-weight: bold;
    text-transform: uppercase;
}

.title-main-ind .name {
    /* font-family: Oswald; */
    color: var(--color-main);
    font-size: clamp(24px, calc(44 / 1200 * 100vw), 44px);
    font-weight: bold;
    text-transform: uppercase;
    line-height: 1.5;
    margin: 0;
}
.title-main {
    text-align: center;
    margin-bottom: 30px;
}
.title-main.title-bg {
    padding: 0 0 10px 0;
    background: url(../images/tcat-b.png) no-repeat bottom center;
}
.title-main h1,
.title-main h2,
.title-main .name {
    margin-bottom: 0;
    font-size: clamp(26px, calc(44 / 1200 * 100vw), 44px);
    font-weight: 700;
    color: var(--color-main);
    text-transform: uppercase;
    /* font-family: 'Oswald'; */
}

.title-main .tt {
    display: flex;
    justify-content: center;
    font-size: 15px;
    font-weight: bold;
    gap:5px;
    align-items: center;
    margin: 5px 0 0 0;
}
.title-main .tt::before,.title-main .tt::after {
    content:"";
    width: 20px;
    height: 16px;
    background: url(../images/tcat-l.png) no-repeat right center;
    flex-grow:1;
    max-width: 202px;
 }
.title-main .tt::after{
    background: url(../images/tcat-r.png) no-repeat right center;
}
.title-main-list {
    background: #efefef;
    box-shadow: 0 1px 0 var(--color-main) inset;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: space-between;
    align-items: center;
    margin: 0 0 30px 0;
}

.title-main-list .name {
    font-size: 18px;
    font-weight: bold;
    color: #fff;
    background: var(--color-main);
    text-transform: uppercase;
    position: relative;
    padding: 10px 24px;
    line-height: 30px;
    min-width: 250px;
    max-width: 100%;
    margin: 0 20px 0 0;
}

.title-main-list .v-more {
    font-size: 14px;
    font-weight: bold;
    text-transform: uppercase;
    color: var(--color-main);
    padding: 5px;
    margin: 10px;
    line-height: 20px;
}

.title-main-list .v-more:hover {
    text-decoration: underline;
}

.title-main-list .name:after {
    content: "";
    position: absolute;
    top: 0;
    left: 100%;
    bottom: 0;
    width: 20px;
    background: url(../images/tt-r.png) no-repeat left center / 20px 100%;
}
.title-detail {
    margin-bottom: 20px
}

.title-detail h1 {
    font-size: clamp(22px, calc(30/1200*100vw), 30px);
    font-weight: 700;
    color: var(--color-main);
    margin-bottom: 0
}

.search-popup {
    position: relative
}

.search-popup .icon-search {
    width: 40px;
    height: 40px;
    border-radius: 40px;
    cursor: pointer;
    text-align: center;
    color: var(--color-main);
    font-size: 17px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    border: 1px solid var(--color-main);
}

.search-popup .icon-search.active {
    background: #fff;
    color: var(--color-main);
    border: solid 1px var(--color-main)
}

.search-popup .search-grid {
    position: absolute;
    top: 50px;
    right: 0;
    width: 0;
    height: 40px;
    overflow: hidden;
    background: #fff;
    border: 1px solid var(--color-main);
    z-index: 2;
    opacity: 0;
    border-radius: 25px;
    display: flex;
    align-items: center
}

.search-popup .search-grid p {
    width: 35px;
    height: 35px;
    cursor: pointer;
    outline: 0;
    border: none;
    margin: 0;
    font-size: 17px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-main)
}

.search-popup .search-grid input {
    width: calc(100% - 35px);
    float: right;
    line-height: 35px;
    outline: 0;
    border: none;
    color: #000;
    font-size: 14px
}

.search-popup .search-grid input::placeholder {
    color: #ccc
}
.about-wrap {
    padding: clamp(50px, calc(80 / 1200 * 100vw), 80px) 0;
    background-color: #FBEFFB;
    background-image: linear-gradient( #fff 50%, #FBEFFB 100%);
}
.about-flex {
    display:flex;
    flex-wrap: wrap;
    gap: 24px 0;
    align-items: flex-start;
    justify-content: space-between;
}
.about-info {
    width: 48.7%;
}

.about-info .v-more {
    display: inline-block;
    background-color: var(--color-main);
    background-image: linear-gradient(90deg, #AC13AC 0%, #F6BE24 100%);
    font-size: 16px;
    font-weight: bold;
    color: #fff;
    padding: 20px 40px;
    border-radius: 12px;
}

.about-info .hotline {
    font-size: 15px;
    color: #637285;
    line-height: 1.4;
    background: url(../images/phone-44.png) no-repeat left center;
    padding: 0 0 0 56px;
}

.about-info .hotline b {
    font-size: 22px;
    color: var(--color-main);
    font-weight: 600;
}
.about-info .v-more:hover{
        background: var(--color-main);
}
.about-desc {
    line-height: 2;
}

.about-info .title-main-ind .tt {
    font-size: 15px;
    font-weight: 600;
    padding: 0 0 0 25px;
    background: url(../images/tt-ab.png) no-repeat left top;
}
.about-photo {
    width: calc(50% - 20px);
    /* padding: 0 30px 30px 0; */
    position: relative;
}

.about-photo .img {
    border-radius: 30px;
}

.about-photo:before {
    /* content: ""; */
    position: absolute;
    bottom: 0;
    right: 0;
    left: 30px;
    top: 30px;
    border: 2px solid #939393;
    border-radius: 10px;
}
.slide__about .img {
    border-radius: 10px;
    position:relative;
    overflow:hidden
}
.slide__about .splide__pagination {
    left: auto;
    right: -19px;
    flex-direction: column;
    padding: 0;
    gap: 10px;
}
.slide__about .splide__pagination .splide__pagination__page {
    background: #bfbfbf;
    opacity: 1;
    width: 10px;
    height: 10px;
    margin: 0;
    display: block;
}
.slide__about .splide__pagination .splide__pagination__page.is-active {
    transform: scale(1);
    background: var(--color-main);
}
.quytrinh {margin: 20px 0 0 0;border-top: 1px solid #e6e6e6;padding: 30px 0 0 0;}

.quytrinh .title-main-ind {
    padding: 0 0 20px 0;
    background: url(../images/tt-quytrinh.png) no-repeat bottom left;
}

.qtlv {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.item-quytrinh {
    /* box-shadow: 0 0 0 1px #d1d1d1 inset; */
    /* padding: 3px; */
    position: relative;
}
.item-quytrinh:hover {
    /* box-shadow: 0 0 0 1px #FDC40A inset; */
}
.item-quytrinh:before {
    /* content: ""; */
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    top: 0;
    background: url(../images/goc-tc.png) no-repeat bottom left,url(../images/goc-duoi.jpg) no-repeat bottom left,url(../images/goc-tren.jpg) no-repeat top right;
    z-index: 1;
}
.item-quytrinh:hover:before {
    background: url(../images/goc-tc.png) no-repeat bottom left,url(../images/goc-duoi-a.jpg) no-repeat bottom left,url(../images/goc-tren-a.jpg) no-repeat top right;
}
.item-quytrinh .content {
    display: flex;
    align-items: flex-start;
    position: relative;
    z-index: 2;
    gap: 10px;
}
.item-quytrinh .numb {
    /* width: 74px; */
    /* height: 74px; */
    /* display: flex; */
    /* line-height: 1; */
    margin: 0 0 5px 0;
    line-height: 40px;
    color: var(--color-bt);
    font-size: 36px;
    font-weight: 600;
}
.item-quytrinh .img {
    margin: 7px 0;
    /* color: #111; */
}
.item-quytrinh .info {
    width: calc(100% - 34px);
    display: flex;
    flex-direction: column-reverse;
}

.item-quytrinh .name {
    /* font-size: 15px; */
    /* font-weight: bold; */
    /* -webkit-line-clamp: 1; */
    line-height: 22px;
}
.product-item .content {
    background: #fff;
    box-shadow: 0 0 12px #00000011;
    border-radius: 16px;
    padding: 9px;
}
.product-item a {
    display: block;
    position: relative
}

.product-item__pic {
    background: #eee;
    overflow: hidden;
    border-radius: 8px;
}

.product-item__info {
    text-align: center;
    margin: 15px 0 5px 0;
    display: flex;
    flex-direction: column;
    gap: 5px;
    justify-content: space-around;
    min-height: 45px;
}

.product-item__name {
    -webkit-line-clamp: 2;
    font-size: 15px;
    transition: .2s ease-in-out;
    margin: 0;
    color: #111;
    font-weight: 600;
    line-height: 1.5;
    /* height: 45px; */
}

.product-item a:hover .product-item__name {
    color: var(--color-main)
}
.product-item__price {
    display:flex;
    align-items: baseline;
    justify-content: center;
    gap: 0 15px;
    flex-wrap: wrap;
}
.product-item-contact {
    background: var(--color-main);
    color: #fff;
    font-size: 13px;
    font-weight: bold;
    text-transform: uppercase;
    padding: 10px 20px;
    border-radius: 5px;
    display: inline-block;
    /* margin: 6px 0 0 0; */
}
.product-item__price--new {
    font-size: clamp(16px, calc(20/1200*100vw), 20px);
    font-weight: 700;
    color: var(--color-main);
    margin: 5px 0 0 0;
}

.product-item__price--old {
    margin: 5px 0 0 0;
    font-size: clamp(14px, calc(16/1200*100vw), 16px);
    color: #6c757d;
    text-decoration: line-through
}

.product-item__price--per {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: var(--color-main);
    font-size: 11px;
    border-radius: 20px;
    padding: 3px 10px;
    gap: 5px
}

.splide.procategory:not(.is-overflow) .splide__list {
    justify-content: center
}

.notify-phone {
    animation: notifyPhone 1s infinite ease-in-out
}

@keyframes notifyPhone {
    0% {
        transform: rotate(0) scale(1) skew(1deg)
    }

    10% {
        transform: rotate(-25deg) scale(1) skew(1deg)
    }

    20% {
        transform: rotate(25deg) scale(1) skew(1deg)
    }

    30% {
        transform: rotate(-25deg) scale(1) skew(1deg)
    }

    40% {
        transform: rotate(25deg) scale(1) skew(1deg)
    }

    50% {
        transform: rotate(0) scale(1) skew(1deg)
    }

    100% {
        transform: rotate(0) scale(1) skew(1deg)
    }
}

.category-nav {
    display: flex;
    margin: 0 0 30px 0;
    flex-wrap: wrap;
    gap: 10px 15px;
    align-items: center;
    justify-content: center;
}

.category-nav span {
    height: 18px;
    border-left: 1px solid #969696;
}

.category-nav__item {
    font-size: clamp(14px, calc(15 / 1200 * 100vw), 15px);
    border-radius: 5px;
    color: inherit;
    display: inline-block;
    vertical-align: top;
    padding: 10px 15px;
    transition: .2s;
    font-weight: 600;
    background-color: #eaeaea;
    text-transform: capitalize;
    line-height: 24px;
    min-width: 100px;
}

.category-nav__item.active, .category-nav__item:hover {
    background: var(--color-more);
    color: #111;
}

.main-widget {
    position: fixed;
    right: 14px;
    bottom: 20px;
    z-index: 99;
    top: auto !important
}

@media (max-width: 767px) {
    .main-widget {
        bottom: 85px
    }
}

.main-widge .img svg {
    width: 100%;
    height: 100%
}

.main-widget .img {
    width: 25px;
    height: 25px
}

.main-icon svg {
    width: 20px;
    height: 20px;
    fill: #fff;
    margin-bottom: 5px
}

.main-icon p {
    font-size: 10px;
    color: #fff;
    margin: 0
}

.out-circle {
    overflow: hidden;
    padding: 17px;
    border-radius: 100%;
    background: var(--color-main);
    width: 60px;
    height: 60px
}

.main-icon {
    line-height: 0;
    color: #fff;
    width: 100%;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    position: absolute;
    top: 43%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center
}

.main-icon i {
    width: 26px;
    height: 26px;
    transform: translateX(2px)
}

.ser-icon {
    display: inline-flex;
    position: absolute;
    font-size: 30px;
    top: 0;
    left: 0;
    padding: 10%;
    background: #fff;
    max-width: 100%;
    overflow: hidden;
    border-radius: 100%;
    color: var(--color-main);
    width: 70%;
    height: 70%;
    margin: 15%;
    transition: .2s all
}

.unsee {
    opacity: 0;
    transform: scale(0)
}

.process {
    display: inline-flex;
    transform: translateX(0);
    transition: .15s linear transform;
    line-height: 0
}

.ser-icon .item {
    margin-right: 40px;
    width: 30px;
    height: 30px;
    color: var(--color-main);
    display: flex;
    justify-content: center;
    align-items: center
}

.ser-icon .item svg {
    width: 25px;
    height: 25px;
    color: var(--color-main)
}

.ser-icon i:nth-child(2n) {
    color: #000
}

.def-content {
    position: absolute;
    bottom: 62px;
    right: 0;
    background: #fff;
    border-radius: 8px;
    transition: .2s all;
    box-shadow: 0 0 10px rgba(0, 0, 0, .2);
    width: 300px;
    z-index: 1
}

.def-content:before {
    position: absolute;
    bottom: -8px;
    right: 22px;
    left: auto;
    display: inline-block !important;
    border-right: 8px solid transparent;
    border-top: 8px solid #fff;
    border-left: 8px solid transparent;
    content: ''
}

.def-content .def-header {
    background: var(--color-main);
    padding: 10px;
    border-radius: 8px 8px 0 0;
    color: #fff;
    position: relative;
    font-size: 16px;
    font-weight: 700
}

.def-content .def-header .close-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    right: 10px;
    top: 10px;
    left: initial;
    padding: 0;
    margin: 0;
    border: 0 none;
    background: 0 0;
    line-height: 1;
    width: 26px;
    height: 26px;
    cursor: pointer;
    color: #fff;
    background: var(--color-main);
    border-radius: 50%;
    text-align: center
}

.def-content .item>a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 5px 10px;
    transition: .3s linear all
}

.def-content .item>a .img {
    flex-grow: 0;
    flex: none;
    height: 34px;
    width: 34px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: 10px;
    border-radius: 50%;
    color: #fff !important
}

.def-content .item>a .img svg {
    height: 20px;
    width: 20px
}

.def-content .item>a .detail {
    flex-grow: 1;
    line-height: normal
}

.def-content .item>a .detail .arcu-item-title {
    font-weight: 700;
    font-size: 15px;
    display: block;
    line-height: normal;
    color: #000
}

.def-content .item>a .detail .arcu-item-subtitle {
    font-size: 14px;
    color: #787878
}

.def-content .item.phone>a .img {
    background: #4eb625
}

.def-content .item.mess>a .img {
    background: #31adff
}

.def-content .item.zalo>a .img {
    background: #0165f8
}

.def-content .item.map>a .img {
    background: #d94234
}

.def-content .item:last-child {
    margin-bottom: 0
}

.main-widget .close-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    font-size: 25px;
    top: 0;
    padding: 10px;
    left: 0;
    width: 60px;
    height: 60px;
    line-height: 1;
    text-align: center;
    color: #fff;
    background: var(--color-main);
    border-radius: 100%;
    transition: .2s all;
    transform: rotate(0);
    cursor: pointer
}

.main-widget .close-icon svg {
    width: 25px;
    height: 25px
}

.close-icon.unsee {
    transform: rotate(180deg)
}

.pregan {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background: #e53b16;
    z-index: -2;
    border-radius: 100%;
    opacity: .6;
    animation: zoomzoom 3s linear .2s infinite
}

.pregan:nth-child(1) {
    animation-delay: .5s
}

.main-widget .item svg {
    fill: var(--color-main)
}

.def-content .item svg {
    fill: #fff
}

.def-content .item:hover {
    background: #f1f1f1
}

@keyframes zoomzoom {
    from {
        transform: scale(0)
    }

    to {
        transform: scale(1.2)
    }
}

.scrollToTop {
    position: fixed;
    bottom: 80px;
    right: 20px;
    z-index: 98;
    top: auto;
    width: 40px;
    height: 40px;
    display: flex;
    background: 0 0;
    text-decoration: none;
    transition: all .3s ease-out 0s;
    transform: translateY(-20px);
    background-color: color-mix(in srgb, var(--color-main) 10%, #fff);
    border-radius: 7px;
    cursor: pointer
}

@media (max-width: 870px) {
    .scrollToTop {
        bottom: 140px
    }
}

.scrollToTop svg {
    width: 100%;
    height: 100%;
    transform: rotate(270deg)
}

.scrollToTop svg path {
    stroke: var(--color-main)
}

.scrollToTop:hover {
    background: var(--color-main)
}

.scrollToTop:hover svg path {
    stroke: color-mix(in srgb, var(--color-main) 10%, #fff)
}
.flex-news {
    display: flex;
    justify-content: space-between;
    gap: 30px 40px;
    align-items: flex-start;
}
.info-news {
   width: calc(50% - 20px);
}
.news-item {
    box-shadow: 0 0 0 1px #e6e7e8 inset;
    border-radius: 18px;
}
.news-item.news-item-ind{
    box-shadow: none;
}
.news-item-ind .content {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.news-item-ind .scale-img, .news-item-ind .info {
    width: calc(50% - 20px);
    padding: 0;
}

.info-news .news-item .info {
    margin: 0;
    width: calc(100% - 220px);
}

.info-news .news-item .name {
    -webkit-line-clamp: 1;
}
.info-news .news-item .date {
    font-size: 13px;
    color: #777;
}
.info-news .news-item .date i {
    color: var(--color-main);
}
.news-item a {
    display: block;
    position: relative
}

.news-item .v-more {
    display: inline-block;
    font-weight: 600;
    background: var(--color-bt);
    color: #fff;
    padding: 14px 30px;
    border-radius: 4px;
}

.news-item__pic {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    border-radius: 18px;
}

.news-item__date {
    position: absolute;
    top: 0;
    left: 0;
    background-color: var(--color-main);
    padding: 5px;
    border-radius: 10px 0 10px 0;
    color: #fff;
    font-size: 12px;
    font-weight: 600
}

.news-item__info {
    padding: 20px;
}

.news-item__name {
    /* -webkit-line-clamp: 2 !important; */
    color: var(--color-text);
    font-size: clamp(15px, calc(16/1200*100vw), 16px);
    font-weight: 700;
    margin-bottom: 7px;
    transition: .2s;
    margin: 0;
}

.news-item-ind .name {
    margin: 0 0 15px 0;
    font-size: clamp(20px, calc(25 / 1200 * 100vw), 25px);
    font-weight: bold;
}

.news-item a:hover .news-item__name {
    color: var(--color-main)
}

.news-item__desc {
    line-height: 2;
    color: #6e6e6e;
    /* line-height: 20px; */
    font-size: 13px;
    word-break: break-word
}

.news-item-ind .desc {
    -webkit-line-clamp: 4;
}

.news-item__next {
    font-weight: 600;
    color: var(--color-text);
    transition: .2s
}

.news-item a:hover .news-item__next {
    color: var(--color-main)
}
.service-item {
    position: relative;
}

.service-item .info {
    margin: 0;
    position: absolute;
    left: 0;
    bottom: 0;
    right: 0;
    top: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 20px;
    border-radius: 20px;
    justify-content: flex-end;
    color: #fff;
    pointer-events: none;
    opacity: 0;
}

.service-item:hover .info {
    /* background: #00000066; */
    background-image: linear-gradient(#0000 60%, #000000e6 100%);
    opacity: 1;
}

.service-item .name {
    font-size: 18px;
    font-weight: 600;
    color: #fff;
    margin: 0;
    line-height: 26px;
    text-align: center;
    /* bottom: -40px; */
}

.service-item .v-more {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-bg);
    /* color: transparent; */
}

.service-item:not(:hover) .v-more, .service-item:not(:hover) .desc {
    color: transparent;
    pointer-events: none;
}
.congtrinh-item .content {
    display: flex;
    padding: 10px;
    background: #fff;
    box-shadow: 0px 2px 12px #0003;
    border-radius: 10px;
    margin: 15px 0;
    gap: 10px;
    align-items: center;
}

.congtrinh-item .scale-img {
    width: 46.67%;
    min-width: 220px;
    background: url(../images/arr-up-left.png) no-repeat bottom right;
    background-size: 15.25%;
}

.congtrinh-item .img {
    -webkit-mask-image: url(../images/mark-img-news.png);
    mask-image: url(../images/mark-img-news.png);
    mask-repeat: no-repeat;
    mask-size: 100%;
}

.congtrinh-item .info {
    display: flex;
    flex-direction: column;
    gap: 5px;
    justify-content: space-between;
    padding: 10px;
    width: 50%;
    margin: 0;
    flex-grow: 1;
}

.congtrinh-item .name {
    font-size: 17px;
    font-weight: bold;
}
.congtrinh-item .v-more {
    font-size: 15px;
    font-weight: bold;
    color: var(--color-main);
}
.visao-wrap {
    padding: clamp(50px, calc(80 / 1300 * 100vw), 80px) 0;
    background: #f8f8f8;
}

.visao-item {
    border-radius: 30px;
    background: #fff;
    padding: 4px;
}

.visao-item .content {
    border-radius: 27px;
    text-align: center;
    padding: 20px 35px;
    background: var(--color-bg);
    line-height: 1.8;
    display: flex;
    flex-direction: column;
    gap: 15px;
    height: 100%;
    background-image: linear-gradient( #fff 0%, #FAE9FA 100%);
}

.visao-detail.visao-item .content {
    flex-direction: row;
    padding: 0 10px;
    align-items: center;
    background-image: linear-gradient(90deg, #fff 0%, #FAE9FA 100%);
    border-radius: 12px;
}

.visao-item .img {
    width: 105px;
    height: 105px;
    margin: 0 auto;
    background: url(../images/bg-ic-tc.png) no-repeat center center /100% 100%;
    padding: 9.5%;
}

.visao-detail.visao-item .img {
    width: 70px;
    height: 70px;
    padding: 18px;
    background-size: 100%;
}
.visao-detail.visao-item .info {
    width: 50%;
    flex-grow:1;
    text-align: left;
}
.visao-item .name {
    font-size: 17px;
    font-weight: 600;
    line-height: 1.5;
}
.visao-detail.visao-item .name {
    font-size: 15px;
    font-weight: 500;
}
.quytrinh-wrap {
    padding: 60px 0 0 0;
    background: url(../images/bg-quytrinh.jpg) no-repeat top center;
}

.quytrinh-wrap .title-main .name, .quytrinh-wrap .title-main,.khachhang-wrap .title-main .name, .khachhang-wrap .title-main {
    color: #fff;
}
.box-quytrinh {
    background: #fff;
    max-width: 1230px;
    margin:0 auto;
    padding: 6.5%;
}
.quytrinh-item {
    background: #f5f5f5;
    padding: 40px 45px 30px 45px;
    position: relative;
}

.quytrinh-item:not(.item-0):before {
    content: "";
    display: block;
    width: 54px;
    height: 54px;
    position: absolute;
    background: url(../images/arr-next.png);
    left: -32px;
    top: calc(50% - 27px);
}

.quytrinh-item .numb {
    position: absolute;
    right: 45px;
    font-size: 34px;
    line-height: 40px;
    margin: 10px 0;
    color: #ddd;
}
.quytrinh-item .img {
    width: 60px;
    margin: 0 0 15px 0;
}
.quytrinh-item .info {
    position: relative;
    height: 150px;
    overflow-y: auto;
}
.quytrinh-item .name {
    font-size: 17px;
    font-weight: 600;
}
.khachhang-wrap {
    padding: clamp(40px, calc(60 / 1200 * 100vw), 60px) 0;
    background: url(../images/bg-khachhang.jpg) no-repeat center center / cover;
}
.khachhang-item {
    background: url(../images/nhay-98.png) no-repeat bottom right 20px, #fff;
    border-radius: 20px;
    box-shadow: 0 2px 12px #0003;
    margin: 15px 0;
    /* border-bottom: 3px solid var(--color-main); */
    padding: 27px 30px;
}

.khachhang-item .cont {
    line-height: 2.25;
    padding: 20px 0 0 0;
    background: url(../images/star.png) no-repeat left top;
    -webkit-line-clamp: 5;
}
.khachhang-item .content {
    display: flex;
    align-items: center;
    gap: 15px;
}

.khachhang-item .img {
    border-radius: 50%;
    width: 50px;
}

.khachhang-item .info {
    width: calc(100% - 65px);
    /* padding: 5px 20px; */
    font-size: 15px;
}
.khachhang-item .name {
    font-size: 14px;
    font-weight: 600;
    -webkit-line-clamp: 1;
}
.khachhang-item .desc {
    font-size: 14px;
    -webkit-line-clamp: 1;
}
.khachhang .splide__pagination {
    position: relative;
    bottom: 0;
}
.tuvan-wrap {
    padding: 70px 0;
    background-color: var(--color-main);
    background-image: linear-gradient(90deg, var(--color-main) 0%, var(--color-more) 100%);
    text-align: center;
    color: #fff;
    font-size: 20px;
}

.tuvan-wrap .name {
    font-size: clamp(26px, calc(43 / 1200 * 100vw), 43px);
    font-weight: 600;
}

.tuvan-wrap .social {
    margin: 20px 0;
    justify-content: center;
}
.tuvan-wrap .v-more {
    font-weight: 600;
    text-transform: uppercase;
    background: var(--color-more);
    border-radius: 10px;
    padding: 11px 50px;
}

.tuvan-wrap .hotline {
    background: #fff;
    padding: 11px 30px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--color-main);
    border-radius: 10px;
}

.tuvan-wrap .hotline:hover {
    background: var(--color-bg);
}
.box-cauhoi {
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.cauhoi-item {
    background: #f4f4f4;
    border-radius: 4px;
    padding: 20px 25px;
    line-height: 1.75;
}

.cauhoi-item .name {
    position: relative;
    font-weight: bold;
    font-size: 17px;
    color: #002642;
    line-height: 1.5;
    margin: 5px 0;
    padding: 0 20px 0 0;
    cursor: pointer;
}

.cauhoi-item .name:after {
    content: "+";
    position: absolute;
    right: 0;
    top: 0;
    font-weight: 500;
    font-size: 20px;
    line-height: 24px;
    width: 15px;
    text-align: center;
}

.cauhoi-item .name.active:after {
    content: "-";
}
.splide__arrow {
    background: color-mix(in srgb, var(--color-main) 10%, #fff) !important;
    opacity: 1 !important;
    border-radius: 5px !important;
    transition: .2s;
    width: 35px !important;
    height: 35px !important
}

.splide__arrow--prev {
    left: -30px
}

.splide__arrow--next {
    right: -30px
}

.splide__arrow svg {
    fill: var(--color-main) !important;
    width: 24px;
    height: 24px;
    transition: .2s
}

.splide__arrow:hover {
    background: var(--color-main) !important
}

.splide__arrow:hover svg {
    fill: color-mix(in srgb, var(--color-main) 10%, #fff) !important
}
.splide__pagination__page.is-active {
    background: var(--color-main);
}

#footer-map {
    overflow: hidden
}

#footer-map iframe {
    display: block;
    width: 100%;
    /* height: 400px; */
}

.footer-article {
    background: url(../images/bg-footer.jpg) no-repeat center center / cover, var(--color-main);
    padding: 50px 0;
    color: #fff;
    font-size: 15px;
}

.footer-top {
    border-bottom: 1px solid #fff6;
    padding: 0 0 50px 0;
}

.footer-powered {
    padding: 20px 0;
    background: #790879;
    font-size: 13px;
    line-height: 20px;
    color: #fff;
    position: relative;
    box-shadow: 0px -1px 0 #EECD26;
}

.footer-powered:before {
    content: "";
    width: 122px;
    height: 37px;
    background: url(../images/bg-powered-t.png);
    position: absolute;
    bottom: 100%;
    left: calc(50% - 61px);
}

.footer-flex {
    display: flex;
    justify-content: space-between;
    gap: 30px 3.5%;
    flex-wrap: wrap;
}

.footer-info {
    padding: 5px 0 6px 70px;
    /* margin: 20px 0 0 0; */
}

.footer-info.address {
    background: url(../images/map-60.png) no-repeat left top;
    max-width: 500px;
}
.footer-info.hotline {
    background: url(../images/phone-60.png) no-repeat left top;
}
.footer-info.email {
    background: url(../images/mail-60.png) no-repeat left top;
}
.footer-info.website {
    background: url(../images/web-60.png) no-repeat left top;
}
.footer-news.ft-1 {
    width: 41%;
}
.footer-news.ft-2 {
    width: 16%;
}
.footer-news.ft-3 {
    width: 27%;
}
.footer-news.social-ft {
    width: 400px;
    max-width: 32%;
}

.footer-name {
    text-align: center;
    color: var(--color-bg);
    font-weight: 700;
    text-transform: uppercase;
    font-family: 'Oswald';
    font-size: clamp(30px, calc(40 / 1200 * 100vw), 40px);
}
.footer-title {
    font-size: 16px;
    font-weight: 700;
    /* text-transform: uppercase; */
    margin-bottom: 20px
}

.social-ft {
    justify-content: center;
}
.footer-title:after {
    /* content:""; */
    display: block;
    width: 40px;
    border-bottom: 3px solid #fff;
    margin: 10px 0 0 0;
}
.footer-ul {
    /* list-style: disc; */
    /* padding-left: 15px; */
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.footer-ul li {
    color: var(--color-main)
}

.footer-article a {
    color: #fff;
    transition: .2s
}

.footer-article a:hover {
    color: var(--color-more);
}

.footer-copyright {
    /* text-transform: uppercase; */
    text-align: center
}

.form-group,
.form-group-select {
    position: relative;
    margin-bottom: 15px
}

.form-group input,
.form-group textarea {
    width: 100%;
    font-size: 14px;
    transition: .1s ease;
    resize: vertical;
    background: #fff !important;
    box-shadow: none !important;
    border-radius: 5px;
    border: 1px solid #cacaca
}

.form-group.novalidate input,
.form-group.novalidate textarea {
    border: 1px solid #e2e2e2 !important
}

.form-group input {
    height: 45px
}

.box-newsletter .form-group input {
    border: none;
    height: auto;
    padding: 15px 0px;
    font-size: 14px;
    border-bottom: 1px solid #e8e8e8;
    border-radius: 0;
}
.box-newsletter .form-group textarea {
    border: none;
    padding: 10px 0px;
    font-size: 14px;
    border-bottom: 1px solid #e8e8e8;
    border-radius: 0;
}
.box-newsletter .form-btn--submit {
    text-transform: uppercase;
    font-weight: bold;
    background: var(--color-more);
    padding: 14px 25px;
    margin: 9px 0;
    font-size: 16px;
    border-radius: 18px;
    text-align: center;
    width: 100%;
}
.form-group input.date-picker {
    padding-right: 35px
}

.form-group input:hover,
.form-group textarea:hover {
    border-color: #7799d0 !important
}

.form-group label,
.form-group-select>label {
    position: absolute;
    left: 12px;
    top: 12px;
    font-size: 14px;
    color: #777;
    transition: .1s ease;
    pointer-events: none;
    background-color: transparent;
    margin: 0;
    line-height: 1.5
}

.form-group>span {
    position: absolute;
    right: 12px;
    top: 12px;
    transition: .1s ease;
    pointer-events: none;
    display: inline-block;
    max-width: 20px
}

.form-group input:focus,
.form-group textarea:focus {
    border-color: var(--main-color);
    outline: 0
}

.form-group input:focus+label,
.form-group input:not(:placeholder-shown)+label,
.form-group textarea:focus+label,
.form-group textarea:not(:placeholder-shown)+label,
.form-group-select>label {
    top: -10px;
    font-size: 12px;
    background: #fff;
    padding: 0 5px;
    left: 8px;
    transform: none
}

.custom-file {
    position: relative;
    display: inline-block;
    width: 100%;
    height: calc(1.5em + .75rem + 2px);
    margin-bottom: 0
}

.custom-file-input {
    position: relative;
    z-index: 2;
    width: 100%;
    height: calc(1.5em + .75rem + 2px);
    margin: 0;
    overflow: hidden;
    opacity: 0
}

.custom-file-label {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1;
    height: calc(1.5em + .75rem + 2px);
    padding: .375rem .75rem;
    overflow: hidden;
    font-weight: 400;
    line-height: 1.5;
    color: #495057;
    background-color: #fff;
    border: 1px solid #ced4da;
    border-radius: .25rem
}

.custom-file-label::after {
    content: attr(title);
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 3;
    display: block;
    height: calc(1.5em + .75rem);
    padding: .375rem .75rem;
    line-height: 1.5;
    color: #495057;
    content: "Browse";
    background-color: #e9ecef;
    border-left: inherit;
    border-radius: 0 .25rem .25rem 0
}

.modal {
    backdrop-filter: blur(4px);
    background: rgba(0, 0, 0, 0.7);
}

.modal-header {
    border-bottom: 1px solid #d1d5db;
    background: rgba(249, 250, 251, .6)
}

.modal-title {
    font-weight: 600;
    letter-spacing: .05em;
    color: #111827
}

.modal-footer {
    border-top: 1px solid #d1d5db;
    background: rgba(249, 250, 251, .6)
}

.modal-btn--close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    font-size: 14px;
    color: #fff;
    background: red;
    position: absolute;
    top: -10px;
    right: -10px;
    z-index: 1;
    overflow: hidden;
    border-radius: 50%
}

.invalid-feedback {
    font-size: 13px;
   
}
.newsletter-wrap {
    padding: clamp(50px, calc(80 / 1300 * 100vw), 80px) 0;
    background: url(../images/bg-dichvu.jpg) no-repeat center center / cover;
    color: #fff;
}

.newsletter-wrap .box-service .title-main-ind .name {
    color: var(--color-bg);
}
.newsletter-wrap .box-service .pronb-nav i {
    border-color: #cfcfcf;
    color: #fff;
}
.newsletter-wrap .box-service .pronb-nav i:hover{
    border-color: var(--color-bg);
    background: var(--color-bg);
    color: #000;
}
.flex-newsletter {
    display: flex;
    justify-content: space-between;
    /* align-items: flex-start; */
    gap: 30px;
}

.flex-newsletter .img {
    border-radius: 20px;
}

.box-service {
    width: calc(100% - 420px);
}

.box-service .scroll_y {
    position: relative;
    max-height: 500px;
    overflow-y: auto;
}

.info-newsletter {
    width: 345px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
}

.info-newsletter .title {
    text-align: center;
    font-size: clamp(18px, calc(22 / 1200 * 100vw), 22px);
    position: relative;
    font-weight: bold;
    color: #002642;
}
.info-newsletter .hotline {
    color: #646464;
    background: url(../images/phone-44-2.png) no-repeat left center;
    padding: 0 0 0 55px;
    margin: 10px 0;
}

.info-newsletter .hotline b {
    font-size: 27px;
    font-weight: 600;
    color: var(--color-more);
    line-height: 30px;
}

.info-newsletter .desc {
    line-height: 30px;
}
.info-newsletter .line {
    content: "";
    width: 100%;
    display: block;
    position: relative;
    margin: 12px 0 0 0;
    border-bottom: 1px solid #f0f0f0;
}
.box-newsletter {
    border-top: 1px solid var(--color-main);
    border-bottom: 1px solid var(--color-main);
    border-radius: 10px;
    box-shadow: 0 0 20px #eaeaea;
    padding: 30px 35px;
}
.box-newsletter .title {
    color: #7b7b7b;
    line-height: 2;
    margin: 0 0 20px 0;
}

.box-newsletter .title .name {
    font-size: clamp(22px, calc(30 / 1200 * 100vw), 30px);
    font-weight: bold;
    color: var(--color-main);
    line-height: 40px;
    padding: 0 0 0 60px;
    margin: 0 0 10px 0;
    background: url(../images/mail-40.png) no-repeat left top;
}
.box-newsletter .invalid-feedback{
    position: absolute;
    width: auto;
    left: auto;
    right: 0;
    top: 0;
    margin: 10px 0;
}
.form-button {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px
}

.form-btn--submit {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-main);
    color: #fff;
    border-radius: 5px;
    padding: 10px 20px;
    font-weight: 600;
    font-size: clamp(14px, calc(16/1200*100vw), 16px)
}

.breadCrumbs {
    background: color-mix(in srgb, var(--color-main) 10%, #fff);
    margin-bottom: 30px
}

.breadcrumb {
    gap: 10px;
    padding: 10px 0 !important
}

.breadcrumb li {
    display: flex;
    align-items: center;
    gap: 15px
}

.breadcrumb li a {
    flex: 1 1 0%;
    color: #666;
    transition: .2s;
}

.breadcrumb li a:hover {
    color: var(--color-main)
}

.breadcrumb li.active a {
    font-weight: 500;
    color: var(--color-main)
}

.breadcrumb li svg {
    width: 7px;
    color: #666;
    margin-top: 2px
}

.box-toc {
    background: #fff;
    border: 1px solid #e2e8f0;
    color: #111;
    border-radius: 12px;
    margin-bottom: 2rem;
    overflow: hidden;
    width: 100%;
    max-width: 100%;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06)
}

.box-toc__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 20px;
    background: #f8fafc;
    cursor: pointer;
    border-bottom: 1px solid transparent;
    user-select: none
}

.box-toc__header:hover {
    background: #f1f5f9
}

.box-toc__title {
    font-weight: 700;
    font-size: 16px;
    color: var(--color-text);
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 10px
}

.box-toc__title i {
    font-size: 20px
}

.box-toc__toggle-icon {
    color: #64748b
}

.box-toc__body {
    max-height: 0;
    overflow: hidden
}

.box-toc--open .box-toc__body {
    max-height: 1000px;
    border-top: 1px solid #e2e8f0
}

.box-toc--open .box-toc__toggle-icon {
    transform: rotate(180deg)
}

.box-toc__list {
    list-style: none;
    padding: 12px 0;
    margin: 0
}

.box-toc__item {
    margin: 0;
    position: relative
}

.box-toc__link {
    display: block;
    padding: 8px 20px;
    color: #64748b;
    text-decoration: none;
    font-size: .95rem;
    line-height: 1.5;
    border-left: 3px solid transparent
}

.box-toc__link:hover {
    color: var(--color-main) !important;
    background: #eff6ff !important
}

.box-toc__link--active {
    color: var(--color-main);
    font-weight: 600;
    background: #eff6ff;
    border-left-color: var(--color-main)
}

.box-toc__item--h2 .box-toc__link {
    padding-left: 10px;
    font-weight: 600;
    color: #334155;
    font-size: 15px
}

.box-toc__item--h3 .box-toc__link {
    padding-left: 20px;
    font-size: 14px
}

.box-toc__item--h4 .box-toc__link {
    padding-left: 30px;
    font-size: 13px;
    font-style: italic
}

.content-main {
    line-height: 26px
}

.content-main h1 {
    text-align: center;
    font-size: 22px;
    margin-bottom: 30px
}

.content-main h2 {
    margin: 20px 0;
    font-size: 19px
}

.content-main h3 {
    margin: 15px 0 20px;
    font-size: 17px
}

.content-main h4 {
    margin: 10px 0 20px;
    font-size: 15px
}

.content-main table {
    width: 100%;
    margin: 10px 0 20px;
    font-size: 13px
}

.content-main table th {
    background: #444;
    color: #fff;
    text-align: center;
    padding: 12px 7px
}

.content-main table tr td {
    padding: 10px 7px
}

.content-main tr:nth-child(even) {
    background: #f4f4f4
}

.content-main tr:nth-child(odd) {
    background: #fff
}

/* .content-main ol,
.content-main ul {
    list-style-type: disc;
    margin: 10px 0
} */

.content-main ol li,
.content-main ul li {
    margin-bottom: 10px
}

.content-main a {
    color: #05f;
    font-weight: 700;
    display: contents
}

.content-main iframe {
    width: 100% !important;
    display: block;
    margin: 10px auto 20px
}

.content-main tr:nth-child(even) {
    background-color: #f2f2f2
}

.content-main tr:hover {
    background-color: #ddd
}

.content-main th {
    padding-top: 12px;
    padding-bottom: 12px;
    text-align: left;
    background-color: var(--color-main);
    color: #fff
}

.content-main td,
.content-main th {
    border: 1px solid #ddd;
    padding: 8px
}

.content-main figcaption {
    text-align: center
}

.content-main a img {
    max-width: 100%;
    height: auto !important
}

.content-main blockquote {
    border-left: solid 3px #ccc;
    padding-left: 20px;
    margin-left: 20px;
    font-style: italic
}

.skeleton-item {
    box-shadow: 0 2px 5px rgba(0, 0, 0, .05);
    padding: 10px;
}

.skeleton-box {
    background: #eee;
    background: linear-gradient(110deg, #ececec 8%, #f5f5f5 18%, #ececec 33%);
    background-size: 200% 100%;
    animation: 1.5s shine linear infinite;
    border-radius: 4px
}

.skeleton-img {
    width: 100%;
    margin-bottom: 10px
}

.skeleton-title {
    height: 20px;
    width: 80%;
    margin-bottom: 8px
}

.skeleton-price {
    height: 20px;
    width: 50%
}

@keyframes shine {
    to {
        background-position-x: -200%
    }
}

.ggdich-box {
    position: relative;
    display: inline-block
}

.ggdich-box__toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    background: 0 0;
    border: none;
    padding: 0;
    cursor: pointer;
    font-size: 16px;
    color: inherit
}

.ggdich-box__icon {
    margin-right: 6px
}

.ggdich-box__dropdown {
    position: absolute;
    z-index: 15;
    top: 100%;
    left: 0;
    margin-top: 10px;
    min-width: 150px;
    background-color: #fff;
    padding: 8px;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)
}

.ggdich-box__item {
    display: flex;
    align-items: center;
    cursor: pointer;
    color: #000;
    margin-bottom: 10px;
    transition: color .2s
}

.ggdich-box__item:last-child {
    margin-bottom: 0
}

.ggdich-box__item:hover {
    color: #c0392b
}

.ggdich-box__flag {
    margin-right: 7px;
    display: inline-block;
    max-width: 22px
}

.ggdich-box__flag img {
    width: 100%;
    display: block
}

.sidebox-group {
    position: sticky;
    top: 60px;
    border: 1px solid #dee2e6;
    border-radius: clamp(5px, calc(10/1200*100vw), 10px);
    padding: clamp(10px, calc(15/1200*100vw), 15px)
}

.sidebox-group__header {
    display: flex;
    font-size: clamp(15px, calc(16/1200*100vw), 16px);
    font-weight: 700;
    text-transform: uppercase;
    align-items: center;
    gap: 7px;
    font-weight: 600;
    padding: 0 0 8px;
    border-bottom: .5px dashed #ebe0e0;
    margin-bottom: 10px
}

.sidebox-group__icon {
    font-size: 22px
}

.sidebox-group__list {
    margin: 0;
    padding: 0;
    list-style: none
}

.sidebox-group__item {
    position: relative
}

.sidebox-group__link {
    color: #252a2b;
    position: relative;
    font-size: 15px;
    font-weight: 500;
    display: block;
    text-transform: capitalize;
    transition: .3s;
    padding: 5px 0
}

.sidebox-group__item--has-child>.sidebox-group__link {
    padding-right: 30px
}

.sidebox-group__link--active,
.sidebox-group__link:hover {
    color: var(--color-main) !important
}

.sidebox-group__toggle {
    width: 25px;
    height: 25px;
    cursor: pointer;
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    border: 1px solid transparent;
    display: none
}

.sidebox-group__item--has-child .sidebox-group__toggle {
    display: block
}

.sidebox-group__toggle:hover {
    border: 1px solid #e7e7e7
}

.sidebox-group__toggle::after,
.sidebox-group__toggle::before {
    background: rgba(9, 9, 9, .6);
    content: '';
    display: block;
    position: absolute;
    margin-right: 7px;
    top: 50%;
    right: 0;
    transition: all .25s linear
}

.sidebox-group__toggle::before {
    width: 9px;
    height: 1px;
    transform: translateY(-50%)
}

.sidebox-group__toggle::after {
    width: 1px;
    height: 9px;
    right: 4px;
    transform: translateY(-50%) scale(1, 1)
}

.sidebox-group__item.opened>.sidebox-group__link .sidebox-group__toggle::after {
    transform: translateY(-50%) scale(1, 0)
}

.sidebox-group__sublist {
    margin: 0;
    padding-left: 10px;
    list-style: none;
    display: none
}

.prodetail {
    display: block;
    width: 100%
}

.prodetail__header {
    margin-bottom: 30px;
    display: flex;
    /* grid-template-columns: 45% 1fr; */
    gap: 20px;
    flex-wrap: wrap;
}

.prodetail__gallery {
    position: relative;
    width: 25%;
    flex-grow: 1;
}

.prodetail__info {
    position: relative;
    width: 30%;
    flex-grow: 1;
}

.prodetail__visao {
    width: 280px;
    display: grid;
    flex-direction: column;
    gap: 5px;
}

.prodetail__thumb {
    margin-bottom: 10px;
    border: solid 1px #eee;
    background: #fff;
    border-radius: 10px;
    overflow: hidden
}

.prodetail__nav .splide__slide {
    opacity: .6;
    transition: opacity .3s;
    border: 1px solid transparent;
    border-radius: 10px;
    overflow: hidden;
}

.prodetail__nav .splide__slide.is-active {
    opacity: 1;
    border: solid 1px var(--color-main) !important;
    overflow: hidden;
}

.prodetail__title {
    font-size: clamp(20px, calc(25/1200*100vw), 25px);
    font-weight: 700;
    margin-bottom: 10px
}

.prodetail__option {
    margin: 15px 0;
    list-style: none;
    padding: 0;
    display: flex;
    gap: 10px;
    flex-wrap: wrap
}

.prodetail__option li span {
    color: var(--color-main)
}

.prodetail__social {
    margin: 15px 0;
    display: flex;
    align-items: center;
    gap: 10px
}

.prodetail__social-title {
    display: flex;
    align-items: center;
    gap: 10px;
    white-space: nowrap
}

.prodetail__price {
    margin: 15px 0;
    font-size: clamp(14px, calc(15/1200*100vw), 15px)
}

.prodetail__price-new {
    font-size: clamp(18px, calc(24/1200*100vw), 24px);
    font-weight: 700;
    color: #d0021b
}

.prodetail__price-old {
    text-decoration: line-through;
    color: #888;
    margin: 0 10px
}

.prodetail__price-discount {
    background: #d0021b;
    color: #fff;
    padding: 2px 3px;
    border-radius: 5px;
    font-size: 11px;
    position: relative
}

.prodetail__price-discount::before {
    content: "";
    border-right: 6px solid #d0021b;
    border-bottom: 6px solid transparent;
    border-top: 6px solid transparent;
    position: absolute;
    top: 50%;
    left: -4px;
    transform: translate(0, -50%)
}

.prodetail__qty-group {
    margin: 20px 0;
    display: flex;
    align-items: center
}

.prodetail__qty-group label {
    font-weight: 600;
    margin-right: 15px
}

.prodetail__qty-control {
    display: flex;
    align-items: center;
    border: 1px solid #dadada;
    border-radius: 4px;
    overflow: hidden
}

.prodetail__qty-btn {
    width: 35px;
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    background: #f3f3f3;
    transition: .2s
}

.prodetail__qty-btn:hover {
    background: #eee
}

.prodetail__qty-btn svg {
    width: 14px;
    height: 14px
}

.prodetail__qty-input {
    width: 60px;
    height: 35px;
    border: none;
    text-align: center;
    outline: 0;
    -moz-appearance: textfield;
    border-left: solid 1px #dadada;
    border-right: solid 1px #dadada
}

.prodetail__qty-input::-webkit-inner-spin-button,
.prodetail__qty-input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0
}

.prodetail__desc {
    margin: 20px 0
}

.prodetail__actions {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
    margin: 20px 0
}

.prodetail__btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding-block: clamp(7px, calc(10/1200*100vw), 10px);
    border: none;
    border-radius: 4px;
    font-size: clamp(14px, calc(15/1200*100vw), 15px);
    transition: all .3s;
    text-decoration: none;
    min-height: 45px;
    cursor: pointer
}

.prodetail__btn:hover {
    color: #fff !important;
    background: color-mix(in srgb, var(--color-main) 70%, #000) !important
}
.prodetail__btn--zalo:hover {
    background: color-mix(in srgb, #0068ff 70%, #000) !important;
}
.prodetail__btn--add {
    color: #d0021b;
    background: var(--color-bg);
    border-color: #d0021b
}

.prodetail__btn--buy {
    color: #fff;
    background: #d0021b;
    border-color: #d0021b
}

.prodetail__btn--hotline {
    color: #fff !important;
    background: var(--color-main);
    border-color: var(--color-main)
}

.prodetail__btn--zalo {
    color: #fff !important;
    background: #0068ff;
    border-color: #0068ff;
    padding: 5px 10px;
    text-align: left;
    justify-content: center;
}

.prodetail__btn-text {
    font-weight: 500;
    text-transform: uppercase
}

.prodetail__btn-subtext {
    display: block;
    font-size: 13px;
    font-weight: 300;
    text-transform: none
}

.prodetail__tab-header {
    display: flex;
    gap: 20px;
    border-bottom: 2px solid #eee;
    margin-bottom: 20px;
    padding: 0;
    list-style: none
}

.prodetail__tab-header li {
    padding: 10px 0;
    font-size: clamp(14px, calc(18/1200*100vw), 18px);
    cursor: pointer;
    font-weight: 600;
    text-transform: uppercase;
    position: relative;
    transition: color .3s
}

.prodetail__tab-header li:after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--color-main);
    transition: width .3s
}

.prodetail__tab-header li.active {
    color: var(--color-main)
}

.prodetail__tab-header li.active:after {
    width: 100%
}

.prodetail__tab-body {
    display: none
}

.prodetail__tab-body[x-show] {
    display: block
}

.prodetail__related {
    margin-top: 40px
}

.prodetail__related-title h2 {
    font-size: clamp(18px, calc(24/1200*100vw), 24px);
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 20px;
    border-left: 4px solid var(--color-main);
    padding-left: 10px
}

.prodetail__related-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px 15px
}

.prodetail__attribute {
    margin-bottom: 20px
}

.prodetail__attribute-label {
    display: block;
    font-size: clamp(14px, calc(16/1200*100vw), 16px);
    font-weight: 700;
    margin-bottom: 10px
}

.prodetail__attribute-list {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 10px
}

.prodetail__attribute-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 35px;
    padding: 5px 12px;
    border: 1px solid #dadada;
    border-radius: 2px;
    background: #fff;
    color: #111;
    font-size: clamp(12px, 1.5vw, 14px);
    cursor: pointer;
    overflow: hidden
}

.prodetail__attribute-btn:hover {
    border-color: var(--color-main)
}

.prodetail__attribute-btn.active {
    border-color: var(--color-main);
    color: var(--color-main)
}

.prodetail__attribute-check {
    position: absolute;
    bottom: -1px;
    right: -1px;
    z-index: 1;
    width: 20px;
    height: 20px;
    display: none;
    align-items: flex-end;
    justify-content: flex-end;
    clip-path: polygon(100% 0, 0 100%, 100% 100%);
    color: #fff;
    background-color: var(--color-main)
}

.prodetail__attribute-btn.active .prodetail__attribute-check {
    display: flex
}

.contact-flex {
    display: grid;
    grid-template-columns: 50% 1fr;
    gap: 20px
}

.contact-map {
    position: relative;
    border-radius: 10px;
    overflow: hidden;
    margin: 30px 0 0 0;
}

.contact-map iframe {
    width: 100%;
    height: 100%;
    min-height: 450px
}

.contact-form {
    /* margin-top: 20px; */
    background: #f5f5f5;
    padding: 15px;
    border: 1px solid #ddd;
    border-radius: 10px
}

.contact-input {
    margin-bottom: 10px
}

.contact-input input,
.contact-input textarea {
    border-radius: 7px;
    border: 1px solid #e1e1e1;
    text-indent: 0;
    color: #000;
    font-size: 13px;
    min-height: 40px
}
.slide_mar_15 .splide__track {
    margin: 0 -15px;
    padding: 0 15px !important;
}
/* Sort */
.sort-select {
	display: flex;
	justify-content: end;
	margin: 20px 0px;
	position: relative;
}

.sort-select .click-sort {
	border: 1px solid #e0e0e0;
	border-radius: 4px;
	cursor: pointer;
	font-size: 14px;
	padding: 6px 10px 6px 8px;
	margin: 0px;
}

.sort-select-main {
	display: grid;
	background-color: #fff;
	border-radius: 4px;
	box-shadow: 0 4px 6px rgb(0 0 0 / 20%);
	position: absolute;
	padding: 0 7px;
	top: 30px;
	right: 0;
	width: 160px;
	z-index: 2;
}

.sort-select-main p {
	border-bottom: 1px solid #f1f1f1;
	margin: 0px;
	order: 2;
}

.sort-select-main p:has(.check) {
	order: 1;
}

.sort a {
	color: #000;
	font-size: 14px;
	line-height: 17px;
	padding: 11px 3px;
	display: block;
	cursor: pointer;
}

.sort a.check i {
	box-sizing: border-box;
	position: relative;
	display: inline-block;
	transform: scale(var(--ggs, 1));
	width: 22px;
	height: 16px;
	border: 2px solid transparent;
	border-radius: 100px;
	vertical-align: middle;
}

.sort a.check i::after {
	content: '';
	display: block;
	box-sizing: border-box;
	position: absolute;
	left: 3px;
	top: -4px;
	width: 6px;
	height: 10px;
	border-width: 0 2px 2px 0;
	border-style: solid;
	transform-origin: bottom left;
	transform: rotate(45deg);
}

.sort-select .sort-show {
	padding-right: 12px;
	position: relative;
}

.sort-select .sort-show::before {
	content: '';
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	border-top: 4px solid #333;
	content: '';
	height: 0;
	position: absolute;
	top: 6px;
	right: 0;
	width: 0;
}