/* content  */
.container-coffee {
  height: fit-content;
  padding-bottom: 40px;
}

.container-coffee .mobile-banner {
  width: 100vw;
}

.container-coffee .mobile-banner img {
  width: 100%;
}

.container-coffee .desktop-banner {
  display: none;
  width: 100vw;
  max-width: 1200px;
  margin: 0 auto;
}

.container-coffee .desktop-banner img {
  width: 100%;
  max-height: 500px;
  object-fit: cover;
  margin-top: 40px;
  border-radius: 16px;
  box-shadow: 0px 3px 8px 2px rgba(0, 0, 0, 0.11);
}

/* our service  */
.our-service-list {
  padding: 24px;
  margin-bottom: 40px;
}

.our-service-list .slider-wrapper {
  margin-top: 52px;
}

.our-service-list .swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
  font-size: 20px;
  font-weight: bold;
}

.our-service-slide .swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
  font-size: 20px;
  font-weight: bold;
}

.our-service-list .swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
  font-size: 20px;
  font-weight: bold;
}

.our-service-slide .swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
  font-size: 20px;
  font-weight: bold;
}

.our-service-list
  .swiper-pagination-horizontal.swiper-pagination-bullets
  .swiper-pagination-bullet {
  height: 8px;
  width: 8px;
}

.our-service-slide
  .swiper-pagination-horizontal.swiper-pagination-bullets
  .swiper-pagination-bullet {
  height: 8px;
  width: 8px;
}

.our-service-list .swiper-wrapper {
  height: 288px;
}

.our-service-list .swiper-wrapper {
  max-height: 288px;
  width: 100%;
  object-fit: contain;
}

.our-service-card {
  background: #ffffff;
  box-sizing: border-box;
  box-shadow: 0px 3px 8px 2px rgba(0, 0, 0, 0.11);
  border-radius: 8px;
  margin-top: 40px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
}

.our-service-card .illustration-image {
  position: relative;
}

.our-service-card .illustration-image img {
  width: 100%;
}

.our-service-card .illustration-image .title {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 16px 0;
  background: #7e7e7e;
  border-radius: 8px 8px 0px 0px;
  color: #ffffff;
  font-size: 22px;
  letter-spacing: 0.04em;
}

.our-service-card .text-button-wrapper {
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 180px;
}

.our-service-card .text-button-wrapper .text {
  margin-bottom: 24px;
  font-size: 15px;
  line-height: 23px;
  color: #1f1f1f;
  font-weight: 600;
}

/* our-service-list-slider */

.our-service-list-slider {
  display: none;
  overflow: scroll;
  margin: 60px 0 80px;
  gap: 24px;
  padding: 12px;
  margin-left: -12px;
}

.our-service-list-slider .our-service-slide:first-child {
  margin-left: 24px;
}

.our-service-list-slider .our-service-slide:last-child {
  margin-right: 24px;
}

.our-service-list-slider .illustration-image {
  width: 100%;
  height: 192px;
}

.our-service-list-slider .title {
  background: #3e4444;
  border-radius: 8px 8px 0px 0px;
  padding: 12px;
  font-size: 18px;
  letter-spacing: 0.04em;
  color: #ffffff;
  text-align: center;
}

.our-service-list-slider .illustration-image img {
  width: 100%;
  height: 100%;
  overflow: hidden;
  object-fit: cover;
}

.our-service-list-slider .our-service-slide {
  min-width: 248px;
  background: #ffffff;
  box-sizing: border-box;
  box-shadow: 0px 3px 8px 2px rgba(0, 0, 0, 0.11);
  border-radius: 8px 0px 8px 8px;
  height: fit-content;
}

.our-service-list-slider .text {
  font-size: 16px;
  line-height: 24px;
  color: #1f1f1f;
  padding: 16px;
}

.our-service-list-slider .button {
  background: #bababa;
  border-radius: 0px 0px 8px 8px;
}

.slick-slider-wrapper {
  width: 100%;
  max-width: 1200px;
  margin: auto auto 60px;
}

.slick-slider-wrapper li {
  display: none;
}

.slick-slider-wrapper .slick-track {
  display: flex;
  gap: 32px;
}

.slick-slider-wrapper .slider-home {
  padding: 24px;
}

.slick-slider-wrapper .slider-home img {
  width: 100%;
}

.slick-slider-wrapper .slider-home .slick-slide {
  width: 100%;
}

/* custom banner */
.swiper .swiper-banner .swiper-slide {
  position: relative;
}

.swiper .swiper-banner .swiper-slide .effect-wrapper {
  position: absolute;
  height: calc(100% - 19%);
  margin-top: 1.5%;
  width: 100%;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.swiper .swiper-banner .swiper-slide .kti-wave-rotating {
  display: flex;
  justify-content: flex-end;
  position: relative;
  margin-right: 8%;
  margin-top: -4%;
}

.swiper .swiper-banner .swiper-slide .kti-image {
  width: 100px;
  position: absolute;
}

.swiper .swiper-banner .swiper-slide .kti-wave-text {
  display: flex;
  justify-content: flex-end;
  position: absolute;
  right: 11%;
  width: 25%;
  top: 22%;
}

.singgle-banner .img-banner {
  width: 100%;
  position: relative;
}

.singgle-banner .img-banner img {
  max-width: 100%;
  width: 100%;
  border-radius: 8px;
}

.singgle-banner .img-banner .box-list-wrapper {
  display: flex;
  gap: 20px;
  position: absolute;
  top: calc(30%);
  width: 100%;
  padding: 0 20px;
  justify-content: space-between;
  box-sizing: border-box;
  height: 50%;
}

.singgle-banner .img-banner .box-list-wrapper > div {
  position: relative;
  width: 25%;
  height: 100%;
}

.singgle-banner .img-banner .box-list-wrapper .box-item {
  position: absolute;
  width: 100%;
  border-radius: 0;
  transform-style: preserve-3d;
  height: 100%;
}

.singgle-banner .img-banner .box-list-wrapper .box-item img {
  border-radius: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.singgle-banner .img-banner .box-list-wrapper  .box-item-detail {
  transform: translate3d(0, 0, 35px);
}

.singgle-banner .img-banner .box-list-wrapper  .box-item-text {
  transform: translate3d(0, 0, 25px);
}

/* responsive */

@media screen and (min-width: 768px) {
  .container-coffee .mobile-banner {
    display: none;
  }

  .container-coffee .desktop-banner {
    display: block;
  }

  .our-service-card .text-button-wrapper .text {
    font-size: 18px;
    line-height: 20px;
    min-height: 120px;
  }

  .our-service-list {
    display: none;
    max-width: 1200px;
    margin: auto;
    gap: 40px;
    justify-content: space-between;
    margin-bottom: 0;
    margin-top: 0;
  }

  .our-service-card {
    max-width: 308px;
    flex: 1;
  }

  .our-service-card .illustration-image img {
    width: 100%;
    min-height: 206px;
    object-fit: cover;
  }

  .our-service-list-slider {
    display: flex;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    overflow: auto;
  }

  .our-service-list-slider .our-service-slide {
    display: flex;
    width: 50%;
    min-width: 553px;
  }

  .our-service-list-slider .title {
    padding-top: 16px;
    padding-bottom: 16px;
    height: 50px;
    min-height: fit-content;
    box-sizing: border-box;
  }

  .our-service-list-slider .illustration-image {
    width: 260px;
    height: 208px;
  }

  .our-service-list-slider .illustration-image img {
    border-bottom-left-radius: 8px;
  }

  .our-service-list-slider .text-button-wrapper {
    display: flex;
    flex-direction: column-reverse;
    justify-content: left;
  }

  .our-service-list-slider .title {
    border-radius: 8px 0 0 0;
  }

  .our-service-list-slider .text {
    font-size: 18px;
    line-height: 24px;
  }

  .our-service-list-slider .button {
    border-radius: 0 8px 0 0;
    height: 50px;
    justify-content: flex-end;
  }

  .slick-slider-wrapper {
    margin: 100px auto 0;
  }

  .slick-slider-wrapper .slick-track {
    gap: 60px;
  }
}

html,
body {
  position: relative;
  height: 100%;
}

body {
  font-family: Helvetica Neue, Helvetica, Arial, sans-serif;
  font-size: 14px;
  color: #000;
  margin: 0;
  padding: 0;
}

.swiper {
  width: 100%;
  height: 100%;
}

.swiper-slide {
  text-align: center;
  font-size: 18px;
  background: #fff;

  /* Center slide text vertically */
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}

.swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.swiper {
  margin-left: auto;
  margin-right: auto;
}

.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
  margin-left: calc(50% - 40px);
}
