@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap");

body {
  font-family: "Montserrat", sans-serif;
}

.box-text a:not(.button),
.box-text h1,
.box-text h2,
.box-text h3,
.box-text h4,
.box-text h5,
.box-text h6,
.box-text p {
  margin: 0;
}

.dark.nav-dropdown.nav-dropdown-bold > li.nav-dropdown-col,
.dark.nav-dropdown.nav-dropdown-simple > li.nav-dropdown-col,
.nav-dark .header-divider:after,
.nav-dark .nav-divided > li + li > a:after,
.nav-dark .nav > li.header-divider,
.nav-dropdown.dark .nav-column > li > a,
.nav-dropdown.dark > li > a {
  border: 0;
}

.home #header {
  background-image: linear-gradient(360deg, #00000000 0%, #000000 80%);
}

#top-bar {
  background-color: transparent;
  padding: 5px 0;
  border-bottom: 1px solid #ffffff1a;
}

#top-bar a.social-link {
  font-size: 16px;
  margin-right: 20px;
}

#top-bar .nav-right {
  flex-wrap: wrap;
  text-align: end;
}

#top-bar .html_topbar_left a,
#top-bar .html_topbar_right a {
  font-size: 16px;
  padding: 0;
}

#top-bar .html_topbar_right i {
  color: var(--fs-color-primary);
  margin-right: 5px;
}

#top-bar .html_topbar_left svg {
  width: 16px;
  fill: var(--fs-color-primary);
  margin-right: 5px;
}

#masthead .nav-left {
  justify-content: center;
}

#masthead .nav > li {
  margin: 0 20px;
}

#masthead .nav > li > a {
  font-size: 14px;
  color: #fff;
  font-weight: 600;
}

#masthead .flex-col .button {
  background-color: var(--fs-color-primary);
  border: 1px solid var(--fs-color-primary);
  border-radius: 0 !important;
  width: 136px;
  height: 40px;
  line-height: 40px;
}

.page_header {
  height: 500px;
  background-image: url(https://cochinsaigonhotels.com/wp-content/uploads/2025/01/page-title-bg.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  padding-top: 250px;
  padding-bottom: 105px;
}

.page_header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: transparent;
  --background-overlay: "";
  background-image: linear-gradient(180deg, #112021e6 30%, #00000000 100%);
  z-index: 0;
  opacity: 0.5;
}

.page_header > .container {
  position: relative;
  z-index: 1;
}

.page_header .page_header_title {
  font-size: 3.8rem;
  font-weight: 400;
  color: #fff;
  margin-bottom: 20px;
}

#breadcrumbs * {
  font-size: 14px;
  color: #fff;
}

#breadcrumbs .breadcrumb_last {
  font-weight: 600;
}

.slider.flickity-enabled button.flickity-prev-next-button {
  border-radius: 99px;
  width: 2.5rem;
  height: 2.5rem;
  top: 50%;
  bottom: unset;
  transform: translateY(-50%) !important;
  border: 0;
  border: 1px solid rgb(229, 231, 235);
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
  opacity: 1 !important;
  margin-top: unset;
  background-color: #fff;
}

.slider.flickity-enabled
  button.flickity-prev-next-button
  svg.flickity-button-icon {
  width: 2rem;
  height: 2rem;
  background-color: transparent !important;
  border-color: transparent !important;
  fill: #242424 !important;
}

.slider.flickity-enabled
  button.flickity-prev-next-button
  svg.flickity-button-icon
  path {
  fill: #242424 !important;
}

.searchform input[type="search"] {
  border: 1px solid #e5e1e1;
  background-color: #f4f5f8;
  height: 60px;
  box-shadow: none !important;
  border-top-left-radius: 8px;
  border-bottom-left-radius: 8px;
}

.searchform .button.icon {
  height: 60px;
  width: 50px;
  background-color: var(--fs-color-primary);
  border-top-right-radius: 8px;
  border-bottom-right-radius: 8px;
}

span.widget-title {
  background: var(--primary-color);
  display: block;
  color: #fff;
  padding: 20px 15px;
  text-align: center;
  text-transform: uppercase;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  font-size: 16px;
  font-weight: 600;
}

.post_comments,
.widget .is-divider {
  display: none;
}

.recent-blog-posts-li .badge,
.recent-blog-posts-li .badge-inner {
  width: 100px;
  height: 70px;
  border-radius: 8px;
}

.recent-blog-posts-li .flex-col.flex-grow {
  max-width: calc(100% - 100px);
}

.widget ul {
  padding: 7px 15px;
  border: 1px solid var(--fs-color-primary);
  background-color: #f4f5f8;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
}

.widget ul .mr-half {
  margin-right: 10px;
}

.recent-blog-posts a {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
  margin: 0;
  color: #000;
  font-weight: 500;
  line-height: 1.4;
}

.main-button {
  font-size: 16px;
  font-weight: 500;
  margin: 0;
  height: 50px;
  line-height: 50px;
  min-width: 150px;
}

.box-category {
  position: relative;
}

.box-category .box-text {
  padding: 0;
  padding-top: 18px;
  color: #222222;
}

.box-category .box-text h3 {
  font-size: 20px;
  font-weight: 500;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 10px;
}

.box-category .box-text i {
  color: var(--fs-color-primary);
}

.box-category .box-text .button {
  position: absolute;
  right: 0;
  bottom: 0;
}

p.branch-address {
  font-size: 16px;
  height: 52px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 15px;
}

.branch-price .arrt {
  display: block;
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
}

.branch-price .price {
  font-size: 24px;
  font-weight: 700;
  color: var(--fs-color-primary);
}

/* home */
.home_about {
  padding: 100px 0;
}

.home_news {
  padding: 80px 0;
}

.title h3 {
  font-size: 18px;
  font-weight: 500;
  text-transform: uppercase;
  color: #666666;
  letter-spacing: 2px;
  display: block;
  width: fit-content;
  margin: 0 auto;
  position: relative;
  margin-bottom: 10px;
}

.title h3::before {
  content: "";
  position: absolute;
  top: 10px;
  left: -50px;
  width: 37px;
  height: 10px;
  background-image: url(/wp-content/uploads/before.png);
}

.title h3::after {
  content: "";
  position: absolute;
  top: 10px;
  left: 100%;
  margin-left: 5px;
  width: 37px;
  height: 10px;
  background-image: url(/wp-content/uploads/before.png);
}

.title h2 {
  font-size: 50px;
  font-weight: 400;
  color: #222222;
  margin-bottom: 40px;
}

.archive-page-header {
  display: none;
}

.page-wrapper {
  padding: 50px 0;
}

/* branch */
.branch1 {
  padding: 40px 0;
}

.branch1 .img {
  border-radius: 4px;
  overflow: hidden;
}

.branch-gallery-two-columns.row {
  margin-left: -1px !important;
  margin-right: -1px !important;
}

.branch-gallery-two-columns .col {
  padding: 0 1px 2px;
}

.gallery-col-right .four-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2px;
}

.gallery-more {
  position: relative;
}

.gallery-more .more-count {
  background-color: hsla(0, 0%, 7%, 0.6);
  position: absolute;
  bottom: 8px;
  right: 8px;
  color: #fff;
  padding: 4px 8px;
  border-radius: 99px;
}

h2.branch-title {
  font-size: 50px;
  font-weight: 400;
  color: #222222;
  margin-bottom: 40px;
}

.branch-facilities {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  column-gap: 8px;
  row-gap: 8px;
}

.facility-item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.facility-item img {
  width: 26px;
  height: 26px;
}

.facility-item .facility-title {
  font-size: 16px;
  font-weight: 500;
  margin: 0;
}

.map-address p {
  margin-bottom: 0;
  margin-top: 10px;
}

.mainSlider {
  margin-bottom: 12px;
}

.mainSlider img {
  border-radius: 12px;
  overflow: hidden;
}

.mainSlider .flickity-prev-next-button {
  opacity: 1;
  height: 36px;
  width: 36px;
  background-color: #fff;
  border-radius: 99px;
  min-height: unset;
  transform: unset;
}

.mainSlider .flickity-prev-next-button svg {
  width: 30px;
}

.mainSlider .flickity-prev-next-button.previous {
  left: 15px;
}

.mainSlider .flickity-prev-next-button.next {
  right: 15px;
}

.thumbSlider {
  margin-left: -6px !important;
  margin-right: -6px !important;
  margin-bottom: 12px;
}

.thumbSlider img {
  border-radius: 6px;
  border: 1px solid transparent;
  border-radius: 6px;
}

.thumbSlider .is-selected img {
  border-color: var(--fs-color-primary);
}

.thumbSlider .col {
  padding: 0 6px;
}

h1.product-title {
  font-size: 26px;
  font-weight: 500;
}

.product-content {
  font-size: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid #eee;
  margin-bottom: 10px;
}

h3.info-title {
  font-size: 16px;
  font-weight: 600;
}

.info-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 5px;
}

.info-item img {
  width: 20px;
  height: 20px;
}

.info-item svg {
  width: 20px;
  height: 20px;
  fill: var(--fs-color-primary);
}

.info-item svg path {
  fill: var(--fs-color-primary);
}

.info-block {
  padding-bottom: 10px;
  border-bottom: 1px solid #eee;
  margin-bottom: 10px;
}

#product-list h1.product-title {
  font-size: 18px;
  font-weight: 600;
}

#product-list .product-content * {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

#product-list .product-content,
#product-list .info-block {
  padding: 0;
  border: 0;
}

#product-list h3.info-title {
  display: none;
}

#product-list .info-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.price-wrapper {
  font-size: 14px;
}

.price-wrapper span {
  display: block;
}

.price-wrapper .price {
  font-size: 24px;
  font-weight: 700;
  color: var(--fs-color-primary);
}

.price-note {
  font-size: 12px;
  color: rgb(107 114 128);
  font-weight: 500;
  font-style: italic;
  display: block;
  margin-bottom: 15px;
}

.branch3 {
  background-color: #fafafa;
  padding: 40px 0;
}

#product-list > .row {
  background-color: #fff;
  box-shadow: rgba(16, 25, 40, 0.05) 0px 5px 13px -5px;
  border-radius: 12px;
  margin: 0;
  padding-top: 10px;
  position: relative;
  margin-bottom: 20px;
}

#product-list > .row .col {
  padding-bottom: 10px;
}

#product-list > .row a.fancybox {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
}

#product-list .prd-img {
  border-radius: 8px;
  overflow: hidden;
}

.btn-action {
  background-color: var(--fs-color-primary);
  color: #fff;
  padding: 8px 24px;
  border-radius: 99px;
  font-size: 16px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
}

.btn-action span {
  margin-left: 5px;
}

#product-list .price-box {
  text-align: end;
}

#product-list .btn-action {
  background-color: var(--fs-color-primary);
  color: #fff;
  padding: 8px 24px;
  border-radius: 99px;
  font-size: 16px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  margin-left: auto;
  margin-top: 30px;
  position: relative;
  z-index: 2;
}

#product-list h2 {
  font-size: 50px;
  font-weight: 400;
  color: #222222;
  margin-bottom: 30px;
}

div.fancybox__content {
  border-radius: 12px;
  overflow: hidden;
}

div.fancybox__content > .carousel__button.is-close {
  margin: 0;
  top: 8px;
  right: 8px;
  color: #000;
  background-color: rgb(243 244 246);
  text-shadow: none;
  font-size: 16px;
  width: 36px;
  height: 36px;
  min-height: unset;
}

.nav-pagination > li > a,
.nav-pagination > li > span {
  width: 40px;
  height: 40px;
  border-radius: 4px;
  line-height: 2.6;
}

/* about */
.about1 {
  padding: 80px 0 50px;
}

.about1 h3 {
  font-size: 18px;
  font-weight: 500;
  text-transform: uppercase;
  color: #666666;
  letter-spacing: 2px;
}

.about1 h2 {
  font-size: 50px;
  font-weight: 400;
  color: #222222;
  margin-bottom: 20px;
}

.about2 {
  padding-bottom: 50px;
}

.about2 .icon-box h3 {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 5px;
}

.about3 h2 {
  font-size: 50px;
  font-weight: 400;
  color: #222222;
  margin-bottom: 20px;
}

/* contact */
.contact1 {
  padding: 100px 0 50px;
}

.contact1 h3 {
  font-size: 18px;
  font-weight: 500;
  text-transform: uppercase;
  color: #666666;
  letter-spacing: 2px;
}

.contact1 h2 {
  font-size: 50px;
  font-weight: 400;
  color: #222222;
  margin-bottom: 40px;
}

.contact1 form .row {
  margin-left: -5px !important;
  margin-right: -5px !important;
}

.contact1 form .row .col {
  padding: 0 10px 20px;
}

.contact1 input,
.contact1 textarea {
  background-color: #f4f5f8;
  border: 1px solid #f4f5f8;
  box-shadow: none !important;
  height: 60px;
  border-radius: 5px;
  margin-bottom: 0;
}

.contact1 textarea {
  height: 200px;
}

.contact1 input[type="submit"] {
  background-color: var(--fs-color-primary);
  border-radius: 0;
  font-size: 14px;
  font-weight: 600;
  min-width: 150px;
}

.contact-info-item {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 20px;
}

.contact-info-item .contact-icon {
  width: 80px;
  height: 80px;
  background-color: var(--fs-color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  color: #fff;
}

.contact-info-item h3 {
  font-size: 24px;
  font-weight: 400;
  color: #222222;
  text-transform: none;
  margin-bottom: 5px;
}

.contact-info-item p,
.contact-info-item a {
  font-size: 16px;
  margin: 0;
  color: #000;
}

.contact2 * {
  margin: 0;
}

/*  */
.post-item .box-text {
  padding: 0;
  padding-top: 18px;
}

.post-item .post-title {
  font-size: 20px;
  font-weight: 500;
}

.post-item .post-title a {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.post-item ul.entry-meta {
  font-size: 14px;
  color: #a1a1a1;
  list-style: none;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 8px;
}

.post-item ul.entry-meta li {
  margin: 0;
  text-transform: uppercase;
}

.post-item ul.entry-meta li a {
  color: #a1a1a1;
}

.post-item ul.entry-meta li i {
  color: var(--fs-color-primary);
}

.box-blog-post .is-divider {
  display: none;
}

/* footer */
#footer {
  background-color: #121212;
  font-size: 15px;
  color: #75727b;
  padding-top: 50px;
}

#footer h3 {
  font-size: 20px;
  color: #cccccc;
  font-weight: 500;
}

#footer .ux-logo-link {
  padding: 0 !important;
}

.absolute-footer.dark {
  display: none;
}

.copy-right {
  border-top: 1px solid #ffffff1a;
}

.copy-right p {
  font-size: 18px;
  color: #cccccc;
  text-align: center;
  margin: 0;
  padding: 15px 0;
}

.fancybox__carousel .fancybox__slide.has-iframe .fancybox__content {
  max-width: 1200px;
}

html.with-fancybox {
  overflow-y: hidden;
}

@media only screen and (max-width: 48em) {
  .fancybox__carousel .fancybox__slide.has-iframe .fancybox__content {
    padding: 15px;
  }
}
