* {
  font-family: "Plus Jakarta Sans", sans-serif;
  scroll-behavior: smooth;
}

html, body {
  width: 100%;
  overflow-x: hidden; /* cegah scroll horizontal */
}

.navbar {
  padding: 16px;
}
.navbar .navbar-brand {
  font-size: 26px;
  font-weight: 500;
}

.navbar-brand {
  font-size: 26px;
  font-weight: 500;
}

.navbar-light .navbar-nav .nav-link.active {
  font-weight: 600;
}

.section-home-header {
  padding: 80px;
  position: relative;
  min-height: 90vh;
  overflow: hidden;
  color: white;
  display: flex;
  flex-direction: column;
  justify-content: end;
  align-items: flex-start;
}
@media only screen and (max-width: 575px) {
  .section-home-header {
    padding: 30px;
  }
}
.section-home-header .bg-layer {
  position: absolute;
  inset: 0;
  background-image: url("../images/homehero.JPG");
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.section-home-header .overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 1;
}
.section-home-header .content-wrapper {
  position: relative;
  z-index: 2;
  padding: 48px;
}
.section-home-header .left-wrapper .title {
  font-size: 36px;
  font-weight: 500;
}
.section-home-header .right-wrapper .subtitle {
  font-size: 16px;
  max-width: 500px;
  margin-bottom: 8px;
}
.section-home-header .right-wrapper .btn-custom {
  margin-top: 24px;
  font-weight: 500;
  padding: 8px 24px;
}

.section-about-us {
  padding: 80px 0px;
  background-color: #fafafa;
}
.section-about-us .left-wrapper .title {
  font-size: 22px;
  font-weight: 500;
  margin-bottom: 4px;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-about-us .right-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 48px;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-about-us .right-wrapper .stats-wrapper .stats-item {
  margin-bottom: 32px;
}
.section-about-us .right-wrapper .stats-wrapper .stats-item .title {
  font-size: 22px;
  font-weight: 500;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-about-us .right-wrapper .stats-wrapper .stats-item .stats-subtitle {
  font-size: 14px;
  font-weight: 300;
  color: #828282;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}

.section-usp {
  padding: 80px 0px 80px 0px;
}
.section-usp .title-wrapper {
  text-align: center;
  margin-bottom: 32px;
}
.section-usp .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 4px;
}
.section-usp .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}
.section-usp .card-how {
  padding: 30px;
  border: 1px solid #eaeaea;
  min-height: 220px;
  border-radius: 8px;
  margin-bottom: 32px;
}
.section-usp .card-how .icon-wrapper {
  padding: 14px;
  width: 48px;
  height: 48px;
  background-color: #e7f6ff;
  display: flex;
  margin-bottom: 24px;
  border-radius: 8px;
}
.section-usp .card-how .icon-wrapper img {
  width: 30px;
}
.section-usp .card-how .text-wrapper .title {
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 4px;
}
.section-usp .card-how .text-wrapper .subtitle {
  font-size: 14px;
  font-weight: 400;
  color: #828282;
}

.section-how {
  padding: 80px 0px 80px 0px;
  background-color: #fafafa;
}
.section-how .title-wrapper {
  text-align: center;
  margin-bottom: 50px;
}
.section-how .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 8px;
}
.section-how .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}
.section-how .left-wrapper {
  margin-bottom: 24px;
}
.section-how .left-wrapper .img-wrapper img {
  width: 100%;
  border-radius: 12px;
}
.section-how .right-wrapper .how-item {
  margin-bottom: 16px;
  padding: 24px;
  background-color: white;
  border-radius: 8px;
}
.section-how .right-wrapper .how-item .number {
  font-weight: 500;
  padding: 12px;
  border-radius: 200px;
  width: 30px;
  height: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #009EE9;
  margin-bottom: 16px;
  color: white;
  font-size: 14px;
}
.section-how .right-wrapper .how-item .title {
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 4px;
}
.section-how .right-wrapper .how-item .subtitle {
  font-size: 14px;
  font-weight: 400;
  color: #828282;
}

.section-works {
  padding: 80px 0px 80px 0px;
}
.section-works .title-wrapper {
  text-align: center;
  margin-bottom: 50px;
}
.section-works .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 4px;
}
.section-works .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}
.section-works .work-item {
  margin-bottom: 48px;
}
.section-works .work-item .img-wrapper {
  margin-bottom: 16px;
  height: 200px;
}
.section-works .work-item .img-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 12px;
}
.section-works .work-item .title {
  font-size: 16px;
  font-weight: 500;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-works .work-item .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}

.section-services {
  padding: 80px 0px 80px 0px;
}
.section-services .title-wrapper {
  text-align: center;
  margin-bottom: 50px;
}
.section-services .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 4px;
}
.section-services .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}
.section-services .work-item {
  margin-bottom: 24px;
}
.section-services .work-item .img-wrapper {
  margin-bottom: 16px;
  height: 300px;
}
@media only screen and (max-width: 575px) {
  .section-services .work-item .img-wrapper {
    height: 200px;
  }
}
.section-services .work-item .img-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 12px;
}
.section-services .work-item .title {
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 4px;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-services .work-item .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}

.section-cta {
  padding: 80px 0px 80px 0px;
  background-color: #fafafa;
}
.section-cta .title-wrapper {
  margin-bottom: 32px;
}
.section-cta .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 4px;
}
.section-cta .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}
.section-cta .card-contact-wrapper {
  background-color: #ffffff;
  border-radius: 8px;
  font-size: 16px;
  padding: 40px;
}
.section-cta .card-contact-wrapper .btn-custom {
  margin-top: 24px;
  font-weight: 500;
}

.section-contact-page .left-wrapper {
  min-height: 90vh;
  height: 90vh;
}
.section-contact-page .left-wrapper .img-wrapper {
  height: 100%;
}
.section-contact-page .left-wrapper .img-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.section-contact-page .right-wrapper {
  padding: 70px;
}
.section-contact-page .right-wrapper .title-wrapper {
  margin-bottom: 48px;
}
.section-contact-page .right-wrapper .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
}
.section-contact-page .right-wrapper .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}

.section-contact-detail {
  padding: 80px 0px;
}
.section-contact-detail .title-wrapper {
  margin-bottom: 32px;
}
.section-contact-detail .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 4px;
}
.section-contact-detail .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}
.section-contact-detail .contact-detail-wrapper {
  padding: 30px;
  border: 1px solid #eaeaea;
  min-height: 220px;
  height: 220px;
  border-radius: 8px;
  margin-bottom: 32px;
}
.section-contact-detail .contact-detail-wrapper .icon-wrapper {
  padding: 14px;
  width: 48px;
  height: 48px;
  background-color: #e7f6ff;
  display: flex;
  margin-bottom: 24px;
  border-radius: 8px;
}
.section-contact-detail .contact-detail-wrapper .icon-wrapper img {
  width: 30px;
}
.section-contact-detail .contact-detail-wrapper .text-wrapper .title {
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 4px;
}
.section-contact-detail .contact-detail-wrapper .text-wrapper .subtitle {
  font-size: 14px;
  font-weight: 400;
  color: #828282;
}
.section-contact-detail .contact-detail-wrapper .text-wrapper .subtitle a {
  font-size: 14px;
  font-weight: 400;
  color: #828282;
  text-decoration: underline;
}

.section-work-list {
  padding: 80px 0px;
  text-align: center;
}
.section-work-list .title-wrapper {
  margin-bottom: 32px;
}
.section-work-list .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 4px;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-work-list .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-work-list .work-wrapper {
  text-align: start;
}
.section-work-list .work-wrapper .work-item {
  margin-bottom: 24px;
}
.section-work-list .work-wrapper .work-item .img-wrapper {
  margin-bottom: 16px;
  height: 250px;
}
.section-work-list .work-wrapper .work-item .img-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 12px;
}
.section-work-list .work-wrapper .work-item .title {
  font-size: 16px;
  font-weight: 500;
}
.section-work-list .work-wrapper .work-item .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}
.section-work-list .nav-link {
  background-color: white;
  color: #696969;
}
.section-footer {
  padding: 50px;
  background-color: #1e1e1e;
  color: #d2d2d2;
}
.section-footer .footer-wrapper {
  margin-bottom: 50px;
}
.section-footer .footer-wrapper .logo-wrapper {
  width: 150px;
  margin-bottom: 24px;
}
.section-footer .footer-wrapper .logo-wrapper img {
  width: 100%;
  border-radius: 8px;
}
.section-footer .footer-wrapper .address-wrapper a {
  font-size: 14px;
  font-weight: 400;
  color: #fff;
  text-decoration: underline;
}
.section-footer .footer-wrapper .footer-item-wrapper .title {
  font-weight: 500;
  margin-bottom: 16px;
}
.section-footer .footer-wrapper .footer-item-wrapper .subtitle {
  margin-bottom: 4px;
}
.section-footer .footer-wrapper .footer-item-wrapper .subtitle a {
  font-size: 16px;
  color: #d2d2d2;
}
.section-footer .copyright {
  font-size: 14px;
  font-weight: 400;
  color: #d2d2d2;
  text-align: center;
}

.section-about-header {
  padding: 80px;
  position: relative;
  min-height: 90vh;
  overflow: hidden;
  color: white;
  display: flex;
  flex-direction: column;
  justify-content: end;
  align-items: flex-start;
}
@media only screen and (max-width: 575px) {
  .section-about-header {
    padding: 30px;
  }
}
.section-about-header .bg-layer {
  position: absolute;
  inset: 0;
  background-image: url("../images/abouthero.JPG");
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.section-about-header .overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 1;
}
.section-about-header .content-wrapper {
  position: relative;
  z-index: 2;
  padding: 48px;
}
.section-about-header .left-wrapper .title {
  font-size: 36px;
  font-weight: 500;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-about-header .right-wrapper .subtitle {
  font-size: 16px;
  max-width: 500px;
  margin-bottom: 8px;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-about-header .right-wrapper .btn-custom {
  margin-top: 24px;
  font-weight: 500;
  padding: 8px 24px;
}

.section-portfolio-header {
  padding: 80px;
  position: relative;
  min-height: 90vh;
  overflow: hidden;
  color: white;
  display: flex;
  flex-direction: column;
  justify-content: end;
  align-items: flex-start;
}
@media only screen and (max-width: 575px) {
  .section-portfolio-header {
    padding: 30px;
  }
}
.section-portfolio-header .bg-layer {
  position: absolute;
  inset: 0;
  background-image: url("../images/portfoliohero.JPG");
  background-size: cover;
  background-position: center;
  z-index: 0;
}
.section-portfolio-header .overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 1;
}
.section-portfolio-header .content-wrapper {
  position: relative;
  z-index: 2;
  padding: 48px;
}
.section-portfolio-header .left-wrapper .title {
  font-size: 36px;
  font-weight: 500;
}
.section-portfolio-header .right-wrapper .subtitle {
  font-size: 16px;
  max-width: 500px;
  margin-bottom: 8px;
}
.section-portfolio-header .right-wrapper .btn-custom {
  margin-top: 24px;
  font-weight: 500;
  padding: 8px 24px;
}

.section-story {
  padding: 80px 0px 80px 0px;
}
.section-story .title-wrapper {
  margin-bottom: 48px;
  text-align: center;
}
.section-story .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
}
.section-story .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}
.section-story .stats-wrapper .stats-item {
  margin-bottom: 32px;
}
.section-story .stats-wrapper .stats-item .title {
  font-size: 22px;
  font-weight: 500;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-story .stats-wrapper .stats-item .stats-subtitle {
  font-size: 14px;
  font-weight: 300;
  color: #828282;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-story .left-wrapper {
  text-align: start;
}
.section-story .right-wrapper {
  text-align: start;
}
.section-story .img-wrapper {
  margin-bottom: 48px;
}
.section-story .img-wrapper img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  border-radius: 12px;
}
.section-story .our-vision {
  text-align: start;
  margin-bottom: 48px;
}
.section-story .our-vision .title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 8px;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-story .our-mission {
  text-align: start;
}
.section-story .our-mission .title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 8px;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}

.section-gallery {
  padding: 80px 0px 80px 0px;
  text-align: center;
}
.section-gallery .title-wrapper {
  margin-bottom: 48px;
}
.section-gallery .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-gallery .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.section-gallery .gallery-wrapper .img-wrapper {
  margin-bottom: 32px;
  height: 150px;
}
.section-gallery .gallery-wrapper .img-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 12px;
}

.section-our-partner {
  padding: 0px 0px 80px 0px;
  text-align: center;
}
.section-our-partner .title-wrapper {
  margin-bottom: 48px;
}
.section-our-partner .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
}
.section-our-partner .logo-wrapper .img-wrapper {
  padding: 24px;
}
.section-our-partner .logo-wrapper .img-wrapper img {
  width: 100%;
}

.section-faq {
  padding: 80px 0px 80px 0px;
}
.section-faq .title-wrapper {
  text-align: center;
  margin-bottom: 32px;
}
.section-faq .title-wrapper .title {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 4px;
}
.section-faq .title-wrapper .subtitle {
  font-size: 16px;
  font-weight: 400;
  color: #828282;
}
.section-faq .accordion-wrapper .card {
  margin-bottom: 16px;
}
.section-faq .accordion-wrapper .card .card-header {
  padding: 20px;
  background-color: white;
  border: 0.2px solid #cecece;
}
.section-faq .accordion-wrapper .card .card-header .accordion-title a {
  color: #131313;
  font-weight: 400;
  font-size: 18px;
}
.section-faq .accordion-wrapper .card .card-body {
  font-size: 16px;
  background-color: #f8f8f8;
}/*# sourceMappingURL=main.css.map */