@charset "UTF-8";
:root {
  --satu-font-size-h1: clamp(1.4rem, 0.904rem + 1.9868vw, 1.875rem);
}

.satu-bg-bg-icon, .card.card-benefit .card-thumb .thumb {
  background-color: var(--satu-color-bg-icon);
}

article.post {
  --post-padding-y: 8px;
  --post-padding-x: 8px;
  --post-thumb-gap: 12px;
  --post-radius: 6px;
  background-color: #ebebeb;
  border-radius: var(--post-radius);
  transition: all .2s ease;
  overflow: hidden;
  padding: var(--post-padding-y) var(--post-padding-x);
  line-height: 1.2;
  font-size: 1rem;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: start;
      justify-content: flex-start;
  height: 100%;
  transition: all 0.3s ease;
}

article.post .post-thumb {
  margin: calc(var(--post-padding-y) * -1) calc(var(--post-padding-x) * -1);
  margin-bottom: var(--post-thumb-gap, var(--post-padding-y));
}

article.post .post-thumb img {
  width: 100%;
  height: var(--thumb-height, 150px);
  object-fit: cover;
  border-radius: var(--post-radius);
}

article.post .title-post {
  font-weight: 700;
  line-height: 1.4;
  margin-top: 0;
  margin-bottom: 0;
}

@media (min-width: 600px) {
  article.post .title-post {
    display: block;
    display: -webkit-box;
    max-height: 2.4rem;
    font-size: 1rem;
    line-height: 1.2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

@media (max-width: 600px) {
  article.post .title-post {
    display: block;
    display: -webkit-box;
    max-height: 2.4rem;
    font-size: 1rem;
    line-height: 1.2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

article.post .title-post ~ .excerpt {
  margin-top: 6px;
  margin-bottom: 12px;
}

article.post:hover .title-post a {
  color: var(--wp--preset--color--primary-hover);
}

article.post .excerpt {
  margin-bottom: 0;
  display: block;
  display: -webkit-box;
  max-height: 2.1rem;
  font-size: 0.875rem;
  line-height: 1.2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 600px) {
  article.post .excerpt {
    display: block;
    display: -webkit-box;
    max-height: 2.1rem;
    font-size: 0.875rem;
    line-height: 1.2;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

article.post .meta-post {
  margin-top: auto;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  font-size: 0.8rem;
}

@media (max-width: 782px) {
  article.post .meta-post {
    font-size: 0.8rem;
  }
}

article.post .meta-post .meta-tag ul {
  list-style-type: none;
  padding-left: 0;
  margin-bottom: 0;
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 155px;
  text-align: right;
}

@media (max-width: 767.98px) {
  article.post .meta-post .meta-tag ul {
    width: 140px;
  }
}

article.post .meta-post .meta-tag ul li {
  display: inline;
  position: relative;
}

article.post .meta-post .meta-tag ul li:not(:last-child)::after {
  content: ',';
  margin-left: 1px;
  margin-right: -1px;
}

.card {
  --card-padding: 1rem;
  padding: var(--card-padding);
  border-radius: 16px;
  border: 1px solid #EDEDED;
  background-color: #FFF;
  height: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: start;
      justify-content: flex-start;
  box-shadow: 0px 1px 2px 0px #1018280F, 0px 1px 3px 0px #1018281A;
  border-radius: 16px;
  overflow: hidden;
  font-size: var(--card-body, 13px);
  transition: all .2s ease;
  transform: translateY(0);
}

.card:hover {
  transform: translateY(-4px);
}

.card .card-title {
  margin-top: 0;
  margin-bottom: 8px;
  font-size: var(--card-title, 16px);
  line-height: 1.4;
}

.card .card-title,
.card .card-title a {
  color: var(--card-title-color, var(--satu-color-text-primary)) !important;
}

.card .card-title a:hover {
  color: var(--card-title-color-hover, var(--card-title-color)) !important;
}

.card p:first-of-type {
  margin-top: 0;
}

.card p:last-of-type {
  margin-bottom: 0;
}

.card .button-wrap {
  margin-top: auto;
  padding-top: 28px;
  -ms-flex: 1 1 100%;
      flex: 1 1 100%;
  width: 100%;
}

@media (max-width: 600px) {
  .card .button-wrap {
    --satu-btn-padding-y: 8px;
  }
  .card .button-wrap .btn {
    width: 100%;
  }
}

.card.card-destination {
  --card-padding: 0;
  position: relative;
  --card-title-color: #FFF;
}

.card.card-destination .card-thumb img {
  width: 100%;
  height: 251px;
  object-fit: cover;
}

@media (max-width: 600px) {
  .card.card-destination .card-thumb img {
    height: 200px;
  }
}

.card.card-destination .card-body {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
  padding: 0;
}

@media (max-width: 600px) {
  .card.card-destination .card-body {
    font-size: 14px;
    font-weight: 400;
  }
}

.card.card-destination .card-body::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #00000033;
  z-index: 1;
}

.card.card-destination .card-body .link {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 5;
  padding: 24px;
  color: var(--card-title-color) !important;
}

.card.card-destination .card-body .link .card-title {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.4;
  margin-top: 0;
  margin-bottom: 4px;
}

.card.card-destination .card-body .link p:not(:first-child) {
  margin-top: 0;
}

.card.card-destination .card-body .link p:not(:last-child) {
  margin-bottom: 0;
}

@media (max-width: 600px) {
  .card.card-destination .card-body .link {
    padding: 12px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
        flex-direction: column;
    -ms-flex-pack: end;
        justify-content: flex-end;
  }
  .card.card-destination .card-body .link .card-title {
    font-size: 18px;
  }
}

.card.card-tour, .card.card-post {
  --card-padding: 1rem;
  --card-title-color-hover: var(--satu-color-link-hover);
}

@media (max-width: 480px) {
  .card.card-tour, .card.card-post {
    --card-padding: .8rem;
    font-size: 13px;
  }
}

.card.card-tour .card-thumb, .card.card-post .card-thumb {
  margin: calc(var(--card-padding) * -1) calc(var(--card-padding) * -1) var(--card-padding);
}

.card.card-tour .card-thumb .image-thumb, .card.card-post .card-thumb .image-thumb {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 276/184;
}

@media (min-width: 768px) and (max-width: 991px) {
  .card.card-tour .card-thumb .image-thumb, .card.card-post .card-thumb .image-thumb {
    aspect-ratio: 1/1;
  }
}

@media (max-width: 480px) {
  .card.card-tour .card-thumb .image-thumb, .card.card-post .card-thumb .image-thumb {
    aspect-ratio: 173/145;
  }
}

.card.card-tour .price-wrap, .card.card-post .price-wrap {
  margin-top: -48px;
  margin-bottom: 0.5rem;
}

.card.card-tour .price-wrap .price, .card.card-post .price-wrap .price {
  color: #FFF;
  padding: 6px 16px;
  margin-left: -1rem;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-direction: column;
      flex-direction: column;
  border-radius: 0 8px 8px 0;
  position: relative;
  overflow: hidden;
}

.card.card-tour .price-wrap .price > *, .card.card-post .price-wrap .price > * {
  position: relative;
  z-index: 2;
}

.card.card-tour .price-wrap .price::before, .card.card-post .price-wrap .price::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--satu-color-primary);
}

.card.card-tour .price-wrap .price .price-label, .card.card-post .price-wrap .price .price-label {
  display: block;
  font-size: .6rem;
  opacity: 0.6;
}

.card.card-tour .price-wrap .price .price-value, .card.card-post .price-wrap .price .price-value {
  font-weight: 700;
  margin-top: -3px;
  font-size: 0.95rem;
}

@media (max-width: 600px) {
  .card.card-tour .price-wrap .price .price-value, .card.card-post .price-wrap .price .price-value {
    font-size: 0.9rem;
  }
}

.card.card-tour .card-title, .card.card-post .card-title {
  margin-bottom: 0;
}

@media (max-width: 991px) {
  .card.card-tour .card-title, .card.card-post .card-title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
}

.card.card-tour .card-category, .card.card-post .card-category {
  color: var(--satu-color-primary);
  text-transform: uppercase;
  font-weight: 500;
}

.card.card-tour .date-tour, .card.card-post .date-tour {
  margin-top: 8px;
}

.card.card-tour .date-tour .date-wrap .date, .card.card-post .date-tour .date-wrap .date {
  margin-bottom: 0;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--satu-color-primary);
}

.card.card-tour .meta-info, .card.card-post .meta-info {
  margin-top: auto;
  padding-top: var(--card-padding);
  list-style-type: none;
  padding-left: 0;
  margin-bottom: 0;
  color: #757575;
  line-height: 1.4;
}

.card.card-tour .meta-info li, .card.card-post .meta-info li {
  position: relative;
  padding-left: 20px;
}

.card.card-tour .meta-info li:not(:last-child), .card.card-post .meta-info li:not(:last-child) {
  margin-bottom: 6px;
}

.card.card-tour .meta-info li .icon, .card.card-post .meta-info li .icon {
  color: var(--satu-color-primary);
  position: absolute;
  left: 0;
}

.card.card-tour .meta-info li .icon svg, .card.card-post .meta-info li .icon svg {
  width: 18px;
  height: 18px;
}

.card.card-tour .meta-info li .icon ~ span, .card.card-post .meta-info li .icon ~ span {
  margin-left: 2px;
}

.card.card-benefit {
  text-align: center;
  color: #757575;
  --card-title: var(--satu-font-size-h5);
  height: 100%;
}

.card.card-benefit .card-thumb {
  margin-bottom: 16px;
}

.card.card-benefit .card-thumb .thumb {
  margin: 0 auto;
  width: 80px;
  height: 80px;
  display: -ms-flexbox;
  display: flex;
  border-radius: 50%;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
}

.card.card-benefit .card-thumb .thumb img {
  width: calc(100% - 32px);
  height: calc(100% - 32px);
  object-fit: contain;
}

.card.card-testimonial {
  display: -ms-flexbox;
  display: flex;
  overflow: unset;
  -ms-flex-direction: column;
      flex-direction: column;
}

.card.card-testimonial .card-top {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.card.card-testimonial .author-top {
  -ms-flex: 0 1 auto;
      flex: 0 1 auto;
}

.card.card-testimonial .star-rating {
  -ms-flex: 0 1 auto;
      flex: 0 1 auto;
  margin-left: auto;
}

.card.card-testimonial .img-author {
  width: 75px;
  height: 75px;
  border-radius: 50%;
  object-fit: cover;
  margin-top: -50px;
}

.card.card-testimonial .content {
  margin: 32px 0;
  color: #757575;
}

.card.card-testimonial .author-bottom {
  color: #404040;
  font-size: 14px;
  margin-top: auto;
}

.card.card-testimonial .author-bottom .author-name {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 4px;
}

.card.card-gallery {
  --card-padding: 0;
  position: relative;
}

.card.card-gallery .img-photo {
  width: 100%;
  height: 250px;
  object-fit: cover;
  transition: all .2s ease-out;
  transform: scale(1);
}

.card.card-gallery:hover .img-photo {
  transform: scale(1.05);
}

.card.card-gallery:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.1);
  opacity: 1;
  transition: all .2s ease-out;
  z-index: 2;
}

.card.card-gallery:after {
  content: '';
  width: 50px;
  height: 50px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' fill='%23FFF' viewBox='0 0 256 256'%3E%3Cpath d='M232.49,215.51,185,168a92.12,92.12,0,1,0-17,17l47.53,47.54a12,12,0,0,0,17-17ZM44,112a68,68,0,1,1,68,68A68.07,68.07,0,0,1,44,112Z'%3E%3C/path%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: 70%;
  background-position: center;
  border-radius: 50%;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  transition: all .2s ease-out;
  opacity: 0;
  z-index: 3;
}

@media (max-width: 782px) {
  .card.card-gallery .img-photo {
    height: 200px;
  }
}

.card.card-post .meta-info li {
  padding-left: 0;
}

.star-rating {
  display: inline-block;
  font-size: 0;
}

.star {
  display: inline-block;
  width: var(--star-size);
  height: var(--star-size);
  margin-right: 2px;
  position: relative;
}

.star::before {
  content: '★';
  font-size: var(--star-size);
  color: #ddd;
}

.star.filled::before {
  color: #ffd700;
}

.swiper {
  --swiper-theme-color: var(--satu-color-primary);
  --swiper-pagination-bottom: 0;
  --swiper-pagination-bullet-inactive-opacity: 1;
  --swiper-pagination-bullet-inactive-color: #c7c7c7;
  --swiper-pagination-bullet-horizontal-gap: calc(16px * 0.5);
  --swiper-pagination-bullet-size: 12px;
}

@media (max-width: 782px) {
  .swiper {
    margin-left: -15px !important;
    margin-right: -15px !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
}

.swiper-button-next, .swiper-button-prev {
  --swiper-navigation-sides-offset: 45px;
  background-color: var(--satu-color-white);
  padding: 8px;
  width: 40px !important;
  height: 40px !important;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  color: var(--swiper-theme-color);
  border-radius: 50%;
}

.swiper-button-next .icon svg, .swiper-button-prev .icon svg {
  width: 28px;
  height: 28px;
}

.swiper-button-next::after, .swiper-button-prev::after {
  display: none;
}

.swiper-button-prev.swiper-button-disabled, .swiper-button-next.swiper-button-disabled {
  pointer-events: unset !important;
}

.swiper-pagination.swiper-pagination-bullets {
  width: 100%;
  background-color: transparent;
  border-radius: 50px;
  padding: 0 0;
  left: 0;
  -ms-flex-pack: center;
      justify-content: center;
  transform: unset;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.swiper.swiper-benefits {
  padding: 3px;
}

@media (max-width: 782px) {
  .swiper.swiper-benefits {
    padding-top: 3px;
    padding-bottom: 0;
  }
}

.swiper.swiper-benefits .swiper-slide {
  height: auto;
}

.swiper.swiper-testimonials {
  padding-top: 35px;
  padding-bottom: 40px;
}

.swiper.swiper-testimonials .swiper-slide {
  height: auto;
}

.swiper.swiper-singtop-slider {
  --swiper-pagination-bottom: 16px;
  --swiper-pagination-bullet-width: 20px;
  --swiper-pagination-bullet-height: 6px;
  --swiper-pagination-bullet-border-radius: 50px;
  --swiper-pagination-bullet-inactive-opacity: .6;
  --swiper-pagination-bullet-inactive-color: #FFF;
  --swiper-pagination-bullet-horizontal-gap: calc(10px * 0.5);
  padding-bottom: 0;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Source: https://www.frontend.fyi/v/css-only-logo-marquee*/
.marquee {
  max-width: 100%;
  overflow: hidden;
  --speed: 25s;
  --single-slide-speed: calc(var(--speed) / var(--numItems));
  --item-width: 200px;
  --item-gap: 25px;
  --item-width-plus-gap: calc(var(--item-width) + var(--item-gap));
  --track-width: calc(var(--item-width-plus-gap) * calc(var(--numItems) - 1));
}

.marquee-track {
  container-type: inline-size;
  display: grid;
  grid-template-columns: var(--track-width) [track] 0px [resting];
  width: max-content;
}

.marquee-item {
  grid-area: resting;
  animation: marquee-move var(--speed) linear infinite var(--direction, forwards);
  animation-delay: calc(var(--single-slide-speed) * var(--item-position) * -1);
  width: var(--item-width);
  aspect-ratio: 16/9;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
}

.marquee-item svg, .marquee-item img {
  height: 70px;
  width: 70%;
}

@keyframes marquee-move {
  to {
    transform: translateX(calc(-100cqw - 100%));
  }
}

.fadeout-horizontal {
  mask-image: linear-gradient(to right, transparent, black 5rem, black calc(100% - 5rem), transparent);
}

section.section .section-body > .btn-wrap, section.section .section-body > .button-wrap {
  margin-top: var(--section-btn-margin, 35px);
  text-align: center;
}

section.section .section-body > .button-wrap .btn {
  --satu-btn-padding-x: 24px;
  --satu-btn-padding-y: 10px;
  --satu-btn-font-size: .9rem;
}

@media (max-width: 600px) {
  section.section .section-body > .button-wrap .btn {
    width: 100%;
  }
}

section.section.section-hero {
  position: relative;
  color: #FFF;
  border-radius: 0;
  overflow: hidden;
  --section-py: 0;
  --section-px: 0;
}

section.section.section-hero .bg-hero {
  height: 600px;
  width: 100%;
  object-fit: cover;
}

section.section.section-hero .overlay-hero {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.72) 12.5%, rgba(0, 0, 0, 0.45) 100%);
}

section.section.section-hero .inner-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 3;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  padding-top: 100px;
}

@media (max-width: 480px) {
  section.section.section-hero .inner-wrap {
    text-align: center;
    padding-top: 56px;
  }
}

section.section.section-hero .inner-wrap .inner {
  max-width: 720px;
  width: 100%;
  font-weight: 400;
  color: #FFF;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.6;
}

section.section.section-hero .inner-wrap .inner .subtitle {
  display: inline-block;
  background-color: var(--satu-color-accent);
  padding: 4px 8px;
  border-radius: 4px;
  color: var(--satu-color-text-primary);
  font-weight: 700;
  line-height: 1.3;
}

section.section.section-hero .inner-wrap .inner .title {
  margin: 0 0 16px;
  font-family: Inter;
  font-size: 33px;
  font-weight: 700;
  line-height: 1.3;
}

section.section.section-hero .inner-wrap .inner .title strong {
  font-weight: 700;
  color: var(--satu-color-primary);
}

@media (max-width: 600px) {
  section.section.section-hero .inner-wrap .inner .title {
    font-size: 24px;
  }
}

section.section.section-hero .inner-wrap .inner ul li:not(:last-child), section.section.section-hero .inner-wrap .inner ol li:not(:last-child) {
  margin-bottom: 8px;
}

section.section.section-hero .inner-wrap .inner .button-wrap {
  margin-top: 40px;
}

section.section.section-hero .inner-wrap .inner .button-wrap > .btn {
  padding: 12px 24px;
}

section.section.section-hero .inner-wrap .inner .button-wrap > .btn:not(:last-child) {
  margin-right: 20px;
}

@media (max-width: 600px) {
  section.section.section-hero .inner-wrap .inner .button-wrap .btn {
    width: 100%;
  }
  section.section.section-hero .inner-wrap .inner .button-wrap .btn:not(:last-child) {
    margin-right: 0;
    margin-bottom: 15px;
  }
}

section.section.section-hero .inner-wrap .inner .btn-outline-primary {
  background-color: #FFF;
}

section.section.section-hero .inner-wrap .inner .btn-outline-primary:hover {
  color: var(--satu-color-primary);
}

section.section.section-tours {
  --section-bg: var(--satu-color-bg-secondary);
  --head-maxwidth: unset;
  --head-align: left;
}

section.section.section-tours .row-head {
  --satu-gutter-x: 100px;
  -ms-flex-align: end;
      align-items: flex-end;
}

section.section.section-tours .row-head .button-wrap {
  padding: 5px 0;
}

@media (max-width: 782px) {
  section.section.section-tours {
    --head-align: center;
  }
  section.section.section-tours .section-head {
    overflow-x: hidden;
  }
  section.section.section-tours .row-head > [class*=col]:last-child {
    display: none;
  }
}

section.section.section-testimonials {
  --section-bg: var(--satu-color-bg-tertiary);
}

section.section.section-gallery {
  --section-bg: var(--satu-color-bg-secondary);
}
