:root {
    --color-red: #ff0000; 
    --clr-primary: #393939; 
    --clr-secondary: #555555; 
    --clr-white: #ffffff; 
    --clr-black: #000000; 
    --clr-silver: #cccccc; 
    --clr-gray: #eeeeee; 
    --clr-china-silver: #C7C7C7; 
    --clr-quick-silver: #A1A1A1; 
    --clr-active: #DE2E44; 
    --clr-btn: #228654;
    --clr-main: #228654; 
    --font-title: "Beautique"; 
    --font-bold: "SN-b"; 
    --font-regular: "SN-m"; 
    --font-slogan: "WindSong";   
}
body { font-size: 14px; line-height: 1.5; }
.main__title { text-align: center; margin-bottom: 1.5rem; }
.main__title h1{ font-family: var(--font-title); font-size: 35px; color: var(--clr-main); text-transform: uppercase; }
.main__title p{ font-family: var(--font-title); font-size: 35px; color: var(--clr-main); text-transform: uppercase; }
.title-main {position: relative;text-align: center;}
.title-main span {font-size: 1.5em;font-weight: bold;text-transform: uppercase;}
.ff-title { font-family: var(--font-title) !important; }
.ff-bold { font-family: var(--font-bold) !important; }
.ff-regular { font-family: var(--font-regular) !important; }
.ff-slogan { font-family: var(--font-slogan) !important; }
.rps-xl--visible, .rps-lg--visible, .rps-md--visible { display: none; }
.rps-xl--hidden, .rps-lg--hidden, .rps-md--hidden { display: block; }
.swiper [class*="__item"] {display: block;}
img { max-width: 100%; }
* { box-sizing: border-box; }
a { text-decoration: none; }
.social-plugin { display: flex; margin-top: 10px; }
.scale-img { overflow: hidden; }
.scale-img img, .scale-img picture { transition: all 0.5s; }
.scale-img:hover img, .scale-img:hover picture { transform: scale(1.1, 1.1); }
.hover-img { position: relative; overflow: hidden; display: block; }
.text-split { overflow: hidden; text-overflow: ellipsis; white-space: normal; -webkit-box-orient: vertical; display: -webkit-box; -webkit-line-clamp: 3; }
.p-relative { position: relative; }

/* Transition All */
.transition, .btn-frame .kenit-alo-circle-fill, .control-owl button, .carousel-comment-media .carousel-control a span, .menu ul li a.has-child:after, .menu ul li ul, .menu ul li:hover > ul, .scale-img img, .scale-img:hover > img, .support-online .kenit-alo-circle-fill { transition: 0.3s all; }
.gutter-x-20 { --bs-gutter-x: 20px; }
.gutter-x-5 { --bs-gutter-x: 5px; }

/* Header */
.header {background: var(--clr-main);padding: 20px 0;} 
.header-hotline .text a {line-height: 1;}
.header-btn {padding: 10px 10px;background: var(--clr-white);border-radius: 5px;color: var(--clr-main);font-family: var(--font-bold);font-size: 16px;min-width: 210px;text-align: center;margin: 0;cursor: pointer; transition: all 300ms ease;}
.header-btn:hover {background: var(--clr-active); color: var(--clr-white); transition: all 300ms ease;}
.flex-header { display: flex; justify-content: space-between; align-items: center; }
.cart-head { border: 1px solid #fff; padding: 10px; border-radius: 5px; position: relative; color: #fff; }
.cart-head:hover { color: #fed402; }
.cart-head i { font-size: 20px; }
.cart-head .count-cart { position: absolute; z-index: 999; color: #fff; background: #f00; border-radius: 50%; top: -10px; right: 20px; width: 20px; height: 20px; text-align: center; }
.menu-head { display: flex; gap: 20px; justify-content: space-between; align-items: center; }
.menu-head a { color: #fff; }
.menu-head a:hover { color: #fed402; }
.line-head { background-color: #72b2fd; height: 32px; width: 1px; }

/* slideshow */
.slideshow { position: relative; }

/* Search */
.search { width: 50%; max-width: 400px; background: #fff; position: relative; border-radius: 10px; display: flex; justify-content: space-between; align-items: center; }
.search input { width: calc(100% - 35px); font-size: 13px; color: #333; border-radius: 10px; border: none; }
.search input:focus { border: none; box-shadow: none; }
.search label { height: 35px; cursor: pointer; text-align: center; font-size: 16px; background: #f00; color: #fff; border-radius: 10px; margin-right: 3px; padding: 5px 10px; }
.search label i { font-weight: bold; color: #999; }
.box-search { padding: 10px; border-bottom: 1px solid #f1f1f1; display: flex; justify-content: space-between; align-items: center; }
.ds-item-search { width: calc(100% - 70px); }
.ds-item-search a { font-size: 14px; color: #333; }
.show-search { position: absolute; z-index: 9999; top: 100%; background: #fff; width: 100%; border-radius: 10px; box-shadow: 0 1px 8px rgba(0, 0, 0, 0.3); }
.box-search .price-product { width: 100%; margin: 0px; text-align: left; }
.box-search .price-product .price-new { color: #f00; font-size: 14px; font-weight: bold; }
.box-search .price-product .price-old { color: #999; text-decoration-line: line-through; }

/* Mmenu */
.offcanvas-body { flex-grow: 1; padding: 1rem 1rem; overflow: scroll; }
.offcanvas-body::-webkit-scrollbar { width: 4px; height: 4px; transition: all 1s; }
.offcanvas-body::-webkit-scrollbar-thumb { background-color: #0d6efd; border-radius: 5px; transition: all 1s; }
.offcanvas-body::-webkit-scrollbar-track { background: #fff; width: 4px; height: 4px; transition: all 1s; }
.btn-close-menu { position: absolute; right: 20px; top: 20px; }
.menu-mobile ul { padding: 0px; }
.menu-mobile ul li { position: relative; }
.menu-mobile ul li > span i { transition: transform 0.3s ease; }
.menu-mobile ul li a { display: block; padding-right: 30px; color: #333; font-size: 15px; padding: 10px 0px; border-bottom: 1px solid #f1f1f1; }
.menu-mobile ul li a i { margin-right: 10px; }
.menu-mobile ul li li a { font-weight: normal; }
.menu-mobile ul li a:hover { color: #f00; }
.menu-mobile ul li .scroll {position: absolute;right: 0px;top: 9px;background: var(--clr-main);font-size: 17px;line-height: 18px;height: 25px;color: #fff;width: 35px;border-radius: 5px;display: flex;justify-content: center;align-items: center;cursor: pointer;padding-right: 14px;}
.menu-mobile ul li:hover { color: #f00; }
.menu-mobile ul ul li .scroll { background: none; color: var(--clr-main); }
.menu-mobile ul li ul { padding-left: 10px; }
.company { border-bottom: 1px solid #f1f1f1; padding-bottom: 10px; }
.company p { margin-bottom: 5px; font-size: 13px; }
.company p span { color: var(--clr-main); }
.head-menu { display: flex; justify-content: center; flex-wrap: wrap; }
.head-menu img { max-width: 160px; }
.search-menu { width: 100%; position: relative; margin: 10px 0px; }
.search-menu input { width: 100%; background: #f5f5fa; border: 1px solid #f1f1f1; height: 40px !important; font-size: 13px; }
.search-menu p { position: absolute; right: 10px; bottom: 8px; }

/* ? Navigation*/
.navigation {position: relative;z-index: 501;background: #DBFFED;-webkit-transition: all 0.3s ease-out;-o-transition: all 0.3s ease-out;-moz-transition: all 0.3s ease-out;transition: all 0.3s ease-out;}
.navigation>.navigation__inner {-webkit-column-gap: 1rem;-moz-column-gap: 1rem;column-gap: 1rem;}
.navigation nav#menu {-webkit-box-flex: 1;-webkit-flex: 1;-moz-box-flex: 1;-ms-flex: 1;flex: 1;max-width: 885px;}
.navigation nav#menu ul { list-style: none; padding: 0; margin: 0; }
.navigation nav#menu ul:has(.level-0) { display: -webkit-box; display: -webkit-flex; display: -moz-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -webkit-justify-content: space-between; -moz-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: center; -webkit-align-items: center; -moz-box-align: center; -ms-flex-align: center; align-items: center; }
.navigation nav#menu ul li { position: relative; z-index: 1; }
.navigation nav#menu ul li .navigation__name::before {position: absolute;content: '';width: 100%;height: 2px;background: var(--clr-active);border-radius: 5px;left: 0px;bottom: 0;transform-origin: right;transform: scaleX(0);transition: transform 0.5s;}
.navigation nav#menu ul li ul li .navigation__name::before { content: none; }
.navigation nav#menu ul li.active .navigation__name::before,
.navigation nav#menu ul li:hover > .navigation__name::before { transform-origin: left; transform: scaleX(1); }
.navigation nav#menu ul li .navigation__name {display: block;position: relative;font-family: var(--font-bold);font-size: 16px;color: var(--clr-black);text-transform: capitalize;padding: .87rem 0.5rem .8rem;text-decoration: none;overflow: hidden;}
.navigation nav#menu ul li.active>.navigation__name,
.navigation nav#menu ul li:hover>.navigation__name {color: var(--clr-active);background: transparent;}
.navigation nav#menu ul li ul { opacity: 0; visibility: hidden; position: absolute; top: 100%; left: 0; min-width: 250px; -webkit-border-radius: 0.25rem; -moz-border-radius: 0.25rem; border-radius: 0.25rem; background: var(--clr-white); -webkit-box-shadow: 1px 1px 15px var(--clr-black)26; -moz-box-shadow: 1px 1px 15px var(--clr-black)26; box-shadow: 1px 1px 15px var(--clr-black)26; padding: 0.75rem 0; margin-top: -5px; -webkit-transform: perspective(600px) scaleY(1.5) translateY(15px); -moz-transform: perspective(600px) scaleY(1.5) translateY(15px); transform: perspective(600px) scaleY(1.5) translateY(15px); -webkit-transform-origin: 0 0 0; -moz-transform-origin: 0 0 0; -ms-transform-origin: 0 0 0; -o-transform-origin: 0 0 0; transform-origin: 0 0 0; -webkit-transition: all .5s ease-out; -o-transition: all .5s ease-out; -moz-transition: all .5s ease-out; transition: all .5s ease-out; box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px; }
.navigation nav#menu ul li:hover>ul { opacity: 1; visibility: visible; -webkit-transform: perspective(600px) scaleY(1) translateY(0); -moz-transform: perspective(600px) scaleY(1) translateY(0); transform: perspective(600px) scaleY(1) translateY(0); -webkit-transform-origin: 0 0 0; -moz-transform-origin: 0 0 0; -ms-transform-origin: 0 0 0; -o-transform-origin: 0 0 0; transform-origin: 0 0 0; -webkit-transition: all .5s ease-out; -o-transition: all .5s ease-out; -moz-transition: all .5s ease-out; transition: all .5s ease-out; top: -webkit-calc(100% + 10px); top: -moz-calc(100% + 10px); top: calc(100% + 10px); }
.navigation nav#menu ul li ul li>ul { left: 100%; top: 0 !important; }
.navigation nav#menu ul li ul li { isolation: isolate; padding: 0 0.75rem; }
.navigation nav#menu ul li ul li a.navigation__name { color: var(--clr-black); padding: .7rem 0; }
.navigation nav#menu ul li ul li:hover>.navigation__name { background: transparent; color: var(--clr-active); }
.navigation nav#menu ul li ul li:not(:last-child):before { content: ''; position: absolute; right: 0.75rem; bottom: 0; left: 0.75rem; z-index: -1; height: 1px; background: var(--clr-silver); }

/* Menu */ 
#hamburger { display: none; width: 35px; height: 23px; position: relative; cursor: pointer; }
#hamburger:before, #hamburger:after, #hamburger span { background: #ffffff; content: ''; display: block; width: 100%; height: 2px; position: absolute; left: 0px; }
#hamburger:before { top: 0px; }
#hamburger span { top: 10px; }
#hamburger:after { top: 20px; }
#hamburger:before, #hamburger:after, #hamburger span { -webkit-transition: none 0.5s ease 0.5s; transition: none 0.5s ease 0.5s; -webkit-transition-property: transform, top, bottom, left, opacity; -webkit-transition-property: top, bottom, left, opacity, -webkit-transform; transition-property: top, bottom, left, opacity, -webkit-transform; transition-property: transform, top, bottom, left, opacity; transition-property: transform, top, bottom, left, opacity, -webkit-transform; }
 
/* News */
.share { padding: 17px 10px 10px 10px; line-height: normal; background: rgba(128, 128, 128, 0.15); margin-top: 15px; border-radius: 5px; }
.share b { display: block; margin-bottom: 5px; }
 
/* Toc */
.tt-toc { position: relative; font-size: 18px; text-transform: uppercase; font-family: var(--font-bold); display: flex; justify-content: space-between; align-items: center; cursor: pointer; }
.box-readmore { padding: 8px 15px; border: 1px solid #dedede; margin-bottom: 2rem; border-radius: 5px; background-color: #eeeeee; }
.box-readmore li ul > li { margin: 0; margin-bottom: 8px; }
.box-readmore li ul > li:before { content: counters(item, '.') ' '; }
.box-readmore ul { list-style-type: none; counter-reset: item; margin-bottom: 0px; padding-left: 0px !important; margin-top: 8px; display: none; }
.box-readmore ul li { display: table; counter-increment: item; margin-bottom: 5px; }
.box-readmore ul li:before { content: counters(item, '.') '. '; display: table-cell; padding-right: 5px; }
.box-readmore ul li a { color: #333333; cursor: pointer; font-weight: 600; }
.box-readmore ul li a:hover { color: #767676; }
 
/* Video */ 
.video-main { position: relative; }
.list-video { margin-top: 10px; width: 100%; border-radius: 5px; border: 1px solid #ddd; }
.img-video span { position: absolute; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); border: 1px solid #ff000066; border-radius: 50%; width: 50px; height: 50px; display: flex; justify-content: center; align-items: center; color: #f00; background: #ffffffa8; font-size: 27px; cursor: pointer; transition: all 1s; }
.video-item:hover span { transform: translateX(-50%) translateY(-50%) rotate(360deg); }
.video-name { text-align: center; font-size: 16px; margin-top: 10px; }

/* 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; }

/* Product */
.filter { position: absolute; right: 0px; top: 0px; padding: 5px 10px; background: #f1f1f1; display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; text-transform: uppercase; border-radius: 5px; cursor: pointer; border: 1px solid #ddd; display: none; }
.flex-product-main { display: flex; gap: 20px; }
.flex-product-main .left-product { width: 250px; border: 1px solid #f1f1f1; padding: 20px; border-radius: 5px; }
.flex-product-main .right-product { width: calc(100% - 250px); }
.wr-search p { font-weight: bold; text-transform: uppercase; }

/* product detail */ 
.left-pro-detail .MagicZoom { border: 1px solid var(--clr-gray); padding: 7px; -webkit-border-radius: 5px; -moz-border-radius: 5px; border-radius: 5px; background-color: var(--clr-white); }
.tabs-pro-detail .tab-content { border: 1px solid #ddd; border-top: none; padding: 20px; }
.nav-tabs li a { text-transform: uppercase; font-weight: 500; color: #333; }
.nav-tabs .nav-item.show .nav-link, .nav-tabs .nav-link.active, .nav-tabs .nav-link:hover { color: #f00; }
.attr-pro-detail { margin: auto; padding: 0; }
.title-pro-detail { text-transform: capitalize; display: block; }
.price-new-pro-detail { font-weight: 700; font-size: 20px; color: #ff2e00; }
.price-old-pro-detail { font-weight: 500; color: #666; text-decoration: line-through; padding-left: 10px; }
.color-pro-detail.active, .size-pro-detail.active, .size-pro-detail:hover { color: #fff !important; background: #232323; }
.quantity-pro-detail { width: 100%; max-width: 110px; line-height: normal; display: flex; align-items: center; justify-content: space-between; text-align: center; margin-right: 20px; font-weight: 500; }
.quantity-pro-detail span { line-height: 40px; padding: 0; width: 30px; height: 40px; color: #000; cursor: pointer; font-size: 22px; }
.quantity-pro-detail span.quantity-plus-pro-detail { border-left: 0; }
.quantity-pro-detail span.quantity-minus-pro-detail { border-right: 0; }
.quantity-pro-detail input { height: 40px; width: calc(100% - 60px); text-align: center; font-size: 20px; padding: 5px; font-weight: 700; }
.cart-pro-detail { margin-bottom: 1rem; display: flex; align-items: center; justify-content: flex-start; }
.cart-pro-detail a { text-align: center; color: #fff; padding: 8px 15px; cursor: pointer; border-radius: 5px; font-weight: bold; }
.cart-pro-detail a.addnow { margin-right: 10px; color: #fff; border-radius: 5px; }
.cart-pro-detail a.addnow:hover { background-color: #f00; color: #fff; border-color: #f00; }
.cart-pro-detail a.buynow { background-color: #000; }
.cart-pro-detail a.buynow:hover { background-color: #f00; color: #fff; }
.cart-pro-detail a i { vertical-align: top; margin-top: 3px; margin-right: 8px; }
  
/* modal-detail */
.modal-detail::-webkit-scrollbar { width: 10px; }
.modal-detail::-webkit-scrollbar-thumb { width: 10px; background: #4d90e0; border-radius: 10px; height: 50px; }
.modal-detail { position: fixed; z-index: 999; background: #000000c4; top: 0px; left: 0px; width: 100%; height: 100%; overflow-y: scroll; }
.content-modal-detail { background: #fff; max-width: 1200px; margin: 0px auto; min-height: 100vh; }
.content-modal-detail .tabs { display: flex; cursor: pointer; padding: 0; list-style: none; justify-content: center; border-bottom: 1px solid #e0e0e0; position: sticky; top: 0px; background: #fff; z-index: 99; }
.content-modal-detail .tabs li { padding: 20px 20px; margin-right: 5px; font-weight: bold; position: relative; border-bottom: 4px solid #fff; }
.content-modal-detail .tabs li.active { color: #2d9cdb; border-bottom: 4px solid #2d9cdb; }
.content-modal-detail .tab-content { padding: 20px; max-width: 900px; margin: 0px auto; }
.content-modal-detail .tab-content.active { display: block; }
.close-tab { position: fixed; top: 15px; right: 20px; z-index: 10; }
.btn-closemenu { position: fixed; top: 10px; right: 20px; background-color: #fff; border: 1px solid #e0e0e0; border-radius: 4px; color: #333; cursor: pointer; line-height: 21px; padding: 7px; text-align: right; width: 72px; }
.btn-closemenu::before { transform: rotate(45deg); }
.btn-closemenu::after { transform: rotate(-45deg); }
.btn-closemenu::before, .btn-closemenu::after { background-color: #333; content: ''; left: 13px; height: 14px; position: absolute; top: 10px; width: 1px; }
.cursor-pointer { cursor: pointer; }

/* Contact */
.contact-map { position: relative; height: 500px; margin-top: 30px; }
.contact-map iframe { position: absolute; left: 0px; top: 0px; width: 100%; height: 100%; }
.frm_contact { border: 1px solid #ddd; padding: 30px; }

/*  breadCrumbs */
.breadCrumbs { padding: 10px 0px; background: #ddd; }
.breadCrumbs ol { margin: 0px; }
.breadCrumbs ol li a { color: #333; }
.breadCrumbs ol li a:hover { color: #f00; }

/* paging */
.paging-product { position: relative; }
.pagination { margin: 20px 0px; }
.pagination li span { cursor: pointer; }
.btn-frame { display: block; width: 50px; height: 50px; position: fixed; right: 20px; z-index: 10; cursor: pointer; }
.btn-frame i { width: 50px; height: 50px; border-radius: 50%; background: #1182fc; position: relative; z-index: 1; display: flex; align-items: center; justify-content: center; }
.btn-frame i img { vertical-align: middle; width: 70%; }
.btn-frame .animated.infinite { animation-iteration-count: infinite; }
.btn-frame .kenit-alo-circle { width: 60px; height: 60px; top: -5px; right: -5px; position: absolute; background-color: transparent; border-radius: 100%; border: 2px solid rgba(7, 41, 103, 0.8); opacity: 0.1; border-color: #1182fc; opacity: 0.5; }
.btn-frame .zoomIn { animation-name: zoomIn; }
.btn-frame .animated { animation-duration: 1s; animation-fill-mode: both; }
.btn-frame .kenit-alo-circle-fill { width: 70px; height: 70px; top: -10px; right: -10px; position: absolute; border-radius: 100%; border: 2px solid transparent; background-color: rgba(7, 41, 103, 0.35); opacity: 0.4; }
.btn-frame .pulse { animation-name: pulse; }
.grid-properties { display: flex; gap: 10px; }
.grid-properties span { position: relative; border: 1px solid #ddd; padding: 5px 15px; cursor: pointer; }
.grid-properties span:hover, .grid-properties span.active { border: 1px solid #f00; color: #f00; }
.grid-properties span:hover:after, .grid-properties span.active:after { content: ''; border: 0.9375rem solid transparent; border-bottom: 0.9375rem solid var(#d0011b, #ee4d2d); bottom: 0; position: absolute; right: -0.9375rem; }
.grid-properties span.outstock { pointer-events: none; background-color: #fafafa; color: rgba(0, 0, 0, 0.26); cursor: not-allowed; }

/* scrollToTop */
.scrollToTop { width: 41px; height: 41px; text-align: center; font-weight: bold; color: #444; text-decoration: none; position: fixed; bottom: 65px; right: 25px; display: none; z-index: 10; cursor: pointer; }

/* Hidden Google Captcha */
.grecaptcha-badge { display: none !important; width: 0px !important; height: 0px !important; visibility: hidden !important; overflow: hidden; }
[x-cloak] { display: none !important; }

/* CSSS T */
a.views_dm { width: 140px; height: 38px; }
.effect_button { transform-style: preserve-3d; transform: translateZ(-25px); transition: transform 0.25s; position: relative; display: inline-flex; z-index: 1; }
.effect_button:after, .effect_button:before { position: absolute; content: 'xem thêm'; height: 100%; width: 100%; display: flex; align-items: center; justify-content: center; border: 1px solid #f00; box-sizing: border-box; border-radius: 5px; z-index: -1; text-transform: uppercase; font-weight: 700; font-size: 15px; }
.effect_button:before { color: #fff; background: #f00; transform: rotateY(0deg) translateZ(25px); }
.effect_button:after { color: #f00; transform: rotateX(90deg) translateZ(25px); }
.effect_button:hover { transform: translateZ(-25px) rotateX(-90deg); }

/* News */
.grid-news { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.ds-news span { display: block; line-height: 25px; color: #999; font-size: 13px; margin: 10px 0px 0px; font-style: italic; }
.ds-news h3 { font-size: 16px; margin: 0; color: #000; font-weight: 500; text-transform: uppercase; -webkit-line-clamp: 2 !important; }
.ds-news .desc { color: #333; }
.item-news-all a { display: flex; justify-content: space-between; }
.item-news-all a .ds-news { width: calc(100% - 110px); }
.item-news-all a .ds-news h3 { text-transform: capitalize; font-size: 15px; }
.flex-news-detail { display: flex; justify-content: space-between; align-items: start; flex-wrap: wrap; }
.news-left { width: 68%; }
.news-right { position: sticky; top: 20px; width: 30%; background: #f1f1f1cc; padding: 20px; box-shadow: 0px 0px 5px #99999978; }

/* Swipper */
.swiper .swiper-wrapper { width: inherit; height: inherit; }
.swiper.swiper-initialized .swiper-wrapper { margin: 0; width: 100%; height: 100%; }
.swiper.swiper-initialized .swiper-slide { padding: 0; margin: 0px; overflow: hidden; }

/* Popup */
.modal-title { font-size: 20px; }

/* CSS cho loading */
.loading-overlay { display: none; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(255, 255, 255, 0.7); justify-content: center; align-items: center; z-index: 999; }
.loading { width: 50px; height: 50px; border: 5px solid rgba(0, 0, 0, 0.1); border-radius: 50%; border-top: 5px solid #3498db; animation: spin 1s linear infinite; }

/* Album */ 
.album__item-inner {position: relative; z-index: 1;}
.album__info {position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #00000082; z-index: 1; display: grid; place-content: center; padding: 10px 15px; opacity: 0; transition: all 300ms ease;}
.album__name {font-family: var(--font-bold); font-size: clamp(16px, calc(20 / 1188 * 100vw), 20px); color: var(--clr-white); width: 0; overflow: hidden; white-space: nowrap; text-overflow: ellipsis;}
.album__item:hover .album__info {opacity: 1; transition: all 300ms ease;}
.album__item:hover .album__name {width: 100%; transition: all 300ms ease;} 


/* ? Policy */
.grid-policy {display: grid; grid-template-columns: repeat(2,1fr); gap: 15px;}  
.policy-item a{background: var(--clr-gray); font-family: var(--font-bold); padding: 12px 20px; border-radius: 10px; display: block;}
.policy-item h3 { font-size: 16px;  color: black;  transition: all 300ms ease;}
.policy-item h3:hover {color: var(--clr-active); transition: all 300ms ease;}

/* TODO: Search Toggle */
.search__toggle { --height: 40px; position: relative; }
.search__toggle .search__icon {display: grid;place-items: center;width: 40px;height: var(--height);font-size: 17px;color: var(--clr-white);cursor: pointer;}
.search__toggle .search__icon.active { color: var(--clr-active); -webkit-border-radius: 50%; -moz-border-radius: 50%; border-radius: 50%; background: var(--clr-white); }
.search__toggle .search__grid {opacity: 1;width: 230px;overflow: hidden;position: absolute;top: 50px;right: 0px;display: -webkit-box;display: -webkit-flex;display: -moz-box;display: -ms-flexbox;display: flex;height: var(--height);border: 1px solid var(--clr-active);-webkit-border-radius: 999px;-moz-border-radius: 999px;border-radius: 999px;background: var(--clr-white);padding: 0rem 0.25rem;}
.search__toggle .search__grid .search__button { display: grid; place-items: center; width: 35px; font-size: 17px; color: var(--clr-active); background: none; }
.search__toggle .search__grid .search__input {-webkit-box-flex: 1;-webkit-flex: 1;-moz-box-flex: 1;-ms-flex: 1;flex: 1;color: var(--clr-active);text-indent: 10px;width: 100%;}
.search__toggle .search__grid input:focus {box-shadow: none;}
.search__toggle .search__grid input::-webkit-input-placeholder { /* autoprefixer: off */ color: var(--clr-silver); }
.search__toggle .search__grid input:-moz-placeholder { /* autoprefixer: off */ color: var(--clr-silver); }
.search__toggle .search__grid input::-moz-placeholder { /* autoprefixer: off */ color: var(--clr-silver); }
.search__toggle .search__grid input:-ms-input-placeholder { /* autoprefixer: off */ color: var(--clr-silver); }
 

/* TODO: Search Block */
.search__block {--child-height: 40px;-webkit-border-radius: 50px;-moz-border-radius: 50px;border-radius: 50px;}
.search__block .search__block-inner {display: -webkit-box;display: -webkit-flex;display: -moz-box;display: -ms-flexbox;display: flex;width: 222px;height: var(--child-height);position: relative;z-index: 2;}
.search__block .search__block-inner:before {content: '';width: 95%;height: 1px;background: var(--clr-main);position: absolute;bottom: 10px;left: 5px;}
.search__block .search__button {display: grid;place-items: center;width: 40px;font-size: 13px;color: var(--clr-main);background: none;}
.search__block .search__input {-webkit-box-flex: 1;-webkit-flex: 1;-moz-box-flex: 1;-ms-flex: 1;flex: 1;font-size: 13px;color: var(--clr-block);text-indent: 10px;background: none;padding: 0;}
.search__block .search__input:focus {box-shadow: none;}
.search__block .search__input::-webkit-input-placeholder { /* autoprefixer: off */ color: var(--clr-black); }
.search__block .search__input:-ms-input-placeholder { /* autoprefixer: off */ color: var(--clr-black); }
.search__block .search__input:-moz-placeholder { /* autoprefixer: off */ color: var(--clr-black); }
.search__block .search__input::placeholder { /* autoprefixer: off */ color: var(--clr-black); }

/* ? Intro */
.intro-quote{font-size: 40px; color: var(--clr-main); font-family: var(--font-slogan);}
.intro-name {font-size: 70px;font-family: var(--font-title);line-height: 1;margin-left: 9rem;}
.intro-desc {color: #333333;max-width: 560px;margin-left: auto;margin-top: 1.5rem;text-align: justify;line-height: 30px;}
.intro-criteria {display: flex;gap: 50px;margin-top: 3rem;}
.criteria-item {display: flex; align-items: center; gap: 17px;}
.criteria-photo {width: 52px;}
.criteria-info {flex: 1;}
.criteria-name {margin-bottom: 0;font-family: var(--font-title);font-size: 20px;line-height: 1;}
.intro-photo {z-index: 11;}
.intro-worktime {position: relative;z-index: 12;max-width: 410px;width: 100%;background: var(--clr-main);color: var(--clr-white);margin-left: 50px;padding: 35px;height: max-content;}
.intro-worktime>span {font-family: var(--font-title);font-size: 30px;display: block;margin-bottom: .65rem;}
.intro-time {display: flex;justify-content: space-between;gap: 15px;flex-wrap: wrap;padding: 13px 0;border-bottom: 1px solid #4BAA7B;}

/* ? Service */
.grid-service {display: grid; grid-template-columns: repeat(3,1fr); gap: 30px;}
.wrap-serviceHome {background: url(../images/bg-service.jpg) no-repeat center center /cover;}
.service-item {background: var(--clr-white); border-radius: 20px;  box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;}
.service-photo {padding: 8px; position: relative;}
.service-photo:before {content: '';width: 100%;height: 60px;background: url(../images/i-sv.png) no-repeat center center / 100% 100%;position: absolute;bottom: 0;left: 0;z-index: 11;}
.service-info {text-align: center;margin-top: 1.25rem;font-family: var(--font-title);padding: 0 10px 25px;}
.service-name a { font-size: 24px; color: #393D3B; --line-clamp:1; transition: all 300ms ease;}
.service-name a:hover {color: var(--clr-active); transition: all 300ms ease;}
.service-price.price_sale {display: flex; align-items: center; justify-content: center; gap: 10px; margin-top: .25rem;}
.service-price.price_sale .price {line-height: 1;}
.service-price.price_sale .price:last-child {text-decoration: line-through; color: var(--clr-secondary);}
.box-price {display: flex; justify-content: space-between; gap: 10px; flex-direction: column;}
.service-price {  color: var(--clr-active);}
.service-price .price {font-size: 30px; color: var(--clr-active);}
.service-price .unit {font-size: 18px;}

/* ? Album */
.wrap-albumHome .wrap-content {--w:1366px;width: min(100% - 1rem, var(--w));}
.albumHome__main {display: grid; grid-template-columns: repeat(3,1fr);gap: 2px;}
.album-btn {padding: 8px 22px 4px 22px;border-radius: 10px;background: var(--clr-main);color: var(--clr-white);font-family: var(--font-title);text-align: center;font-size: 18px;margin: 1.5rem auto;  transition: all 300ms ease;}
.album-btn:hover {background: var(--clr-active); color: var(--clr-white); transition: all 300ms ease;}

/* ? amenities */
.wrap-amenities .swiper-slide {overflow: unset !important;}
.amenities-item {position: relative; z-index: 1;}
.amenities-item:before {content: '';width: 1px;height: 100%;position: absolute;top: 0;left: calc(100% + 30px);z-index: 1; background: #D9D9D9;}
.amenities-photo {width: 100px;height: 100px;padding: 24px;background: linear-gradient(180deg, #DE2E44 0%, #FF697C 100%);border-radius: 100%;margin: auto;}
.amenities-info {text-align: center;margin-top: 1.75rem;}
.amenities-name {font-family: var(--font-bold);font-size: 16px;max-width: 67%;margin: 0 auto 1rem;}
.amenities-desc {font-size: 13px; color: #555; line-height: 25px; min-height: 75px;}
 
/* Footer */
.footer-article { background: url(../images/bg-footer.jpg) no-repeat center center / cover; }
.footer-article .wrap-content {position: relative; padding: 30px 0; z-index: 1; padding-bottom: 75px;}
.footer-article .wrap-content:before {content: ''; width: 100%; height: 100%; background: url(../images/i-footer.png) no-repeat center bottom / 100% 100%; position: absolute; z-index: -1; top: 0; left: 0;}
.footer-article__inner {display: -webkit-box;display: -webkit-flex;display: -moz-box;display: -ms-flexbox;display: flex;-webkit-flex-wrap: wrap;-ms-flex-wrap: wrap;flex-wrap: wrap;-webkit-box-pack: justify;-webkit-justify-content: space-between;-moz-box-pack: justify;-ms-flex-pack: justify;justify-content: space-between;padding: 0 46px;margin-top: 1.5rem;}
.footer-article--1 { width: 35.583942%;}
.footer-article--2 { width: 16.423358%;}
.footer-article--3 { width: 30.109489%;}
.footer__title {font-family: var(--font-bold);font-size: 16px;color: var(--clr-white);position: relative;margin-bottom: 20px;}
.footer__info {color: var(--clr-white);}
.footer__policy { list-style: none; padding: 0; margin: 0; }
.footer__policy li:not(:last-child) {margin-bottom: 18px;}
.footer__policy li a { color: var(--clr-white);  transition: all 300ms ease;}
.footer__policy li a:hover {color: var(--clr-active); transition: all 300ms ease;}
.footer-form-desc {color: var(--clr-white); line-height: 30px; margin-bottom: .5rem;}

.newsletter__input2, .newsletter__button { width: 100%; position: relative; }
.newsletter__input2, .newsletter__textarea { margin-bottom: 10px; }
.newsletter__input2 input { height: 50px; }
.newsletter__input2 input {font-size: 14px;color: var(--clr-white);border: 1px solid #94D3B2;background: transparent; border-radius: 5px;}
.newsletter__input2 input::placeholder, .newsletter__input2 input:focus { /* autoprefixer: off */ font-size: 14px; color: var(--clr-white); background: transparent; box-shadow: none !important; }
.newsletter__button2 input {border-radius: 0;height: 50px;font-family: var(--font-bold);font-size: 18px;color: var(--clr-main);text-transform: uppercase;outline: none;border: 1px solid var(--clr-white);background: var(--clr-white);padding: 0 20px;width: 100%; border-radius: 5px;}
.newsletter__button2 input::placeholder, .newsletter__button2 input:focus { /* autoprefixer: off */ box-shadow: none !important; }
.newsletter__button2 input:hover { color: var(--clr-white); background: var(--clr-active); border-color: var(--clr-active); box-shadow: none; }
.newsletter__button2 span { position: absolute; top: 50%; right: 22%; -webkit-transform: translate(-50%, -50%); -moz-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); -o-transform: translate(-50%, -50%); transform: translate(-50%, -50%); color: var(--clr-white); }


.footer-copyright {text-align: center;padding: 34px 0;color: var(--clr-white);}
.footer-copyright span {color: var(--clr-white);}
.footer-statistic { text-align: right; }
.footer-statistic span { padding: 0 10px; }
.footer-statistic span:last-child { padding-right: 0px; }
.footer-statistic span:not(:last-child) { border-right: 1px solid var(--clr-white); }
.footer__map { position: relative; height: 415px; }
.footer__map iframe { position: absolute !important; width: 100% !important; height: 100% !important; top: 0px !important; left: 0px !important; }

/* ? News */
.news-info {margin-top: .5rem; text-align: center; padding: 0 10px 15px;}
.news-name a {font-size: 18px; font-family: var(--font-bold); color: #333; --line-clamp:2;transition: all 300ms ease;}
.news-name a:hover {color: var(--clr-active); transition: all 300ms ease;}

/* ? Form */
.exampleModal .modal-body {background: url(../images/bg-footer.jpg) no-repeat center center / cover; position: relative; z-index: 1;}
.exampleModal .btn-close {position: absolute;top: 10px;right: 10px;color: var(--clr-white);opacity: 1;font-size: 18px; background: transparent;}
.exampleModal .newsletter__form {margin-top: 2rem;}
.newsletter__input, .newsletter__button { width: 100%; position: relative; }
.newsletter__input, .newsletter__textarea { margin-bottom: 10px; }
.newsletter__input input { height: 45px; }
.newsletter__input input,
.newsletter__textarea textarea {font-size: 14px;color: var(--clr-secondary);border: 1px solid #E9E9E9;background: var(--clr-white);}
.newsletter__input input::placeholder, .newsletter__input input:focus ,
.newsletter__textarea textarea::placeholder, .newsletter__textarea textarea:focus { /* autoprefixer: off */ font-size: 14px; color: var(--clr-secondary); background: var(--clr-white); box-shadow: none !important; }
.newsletter__button input {border-radius: 0;height: 50px;font-family: var(--font-bold);font-size: 18px;color: var(--clr-main);text-transform: uppercase;outline: none;border: 1px solid var(--clr-white);background: var(--clr-white);padding: 0 20px;width: 100%; border-radius: 5px;}
.newsletter__button input::placeholder, .newsletter__button input:focus { /* autoprefixer: off */ box-shadow: none !important; }
.newsletter__button input:hover { color: var(--clr-white); background: var(--clr-active); border-color: var(--clr-active); box-shadow: none; }
.newsletter__button span { position: absolute; top: 50%; right: 22%; -webkit-transform: translate(-50%, -50%); -moz-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); -o-transform: translate(-50%, -50%); transform: translate(-50%, -50%); color: var(--clr-white); }
