/*** Spinner Start ***/
/*** Spinner ***/
#spinner {
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 0.5s ease-out,
    visibility 0s linear 0.5s;
  z-index: 99999;
}

#spinner.show {
  transition:
    opacity 0.5s ease-out,
    visibility 0s linear 0s;
  visibility: visible;
  opacity: 1;
}
/*** Spinner End ***/

.back-to-top {
  position: fixed;
  right: 30px;
  bottom: 30px;
  transition: 0.5s;
  z-index: 99;
}

/*** Button Start ***/
.btn {
  font-weight: 600;
  transition: 0.5s;
}

.btn-square {
  width: 32px;
  height: 32px;
}

.btn-sm-square {
  width: 34px;
  height: 34px;
}

.btn-md-square {
  width: 44px;
  height: 44px;
}

.btn-lg-square {
  width: 56px;
  height: 56px;
}

.btn-xl-square {
  width: 66px;
  height: 66px;
}

.btn-square,
.btn-sm-square,
.btn-md-square,
.btn-lg-square,
.btn-xl-square {
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: normal;
}

.btn.btn-primary {
  color: var(--bs-white);
}

.btn.btn-primary:hover {
  background: var(--bs-secondary);
  border: 1px solid var(--bs-secondary);
}

.btn.btn-secondary {
  color: var(--bs-white);
}

.btn.btn-secondary:hover {
  background: var(--bs-primary);
  border: 1px solid var(--bs-primary);
  color: var(--bs-white);
}

.btn.btn-light {
  color: var(--bs-primary);
}

.btn.btn-light:hover {
  color: var(--bs-white);
  background: var(--bs-primary);
  border: 1px solid var(--bs-primary);
}

/*** Icon Animation Start ***/
@keyframes icon-animat {
  0% {
    border-radius: 67% 33% 29% 71% / 39% 46% 54% 61%;
  }

  25% {
    border-radius: 69% 31% 19% 81% / 43% 37% 63% 57%;
  }

  50% {
    border-radius: 67% 33% 16% 84% / 57% 37% 63% 43%;
  }

  75% {
    border-radius: 77% 23% 61% 39% / 36% 61% 39% 64%;
  }

  100% {
    border-radius: 67% 33% 29% 71% / 39% 46% 54% 61%;
  }
}
/*** Icon Animation End ***/

/*** Navbar Start ***/
.nav-bar {
  background: var(--bs-white);
}

.sticky-top {
  transition: 1s;
}

.navbar-light .navbar-nav .nav-link {
  position: relative;
  margin-right: 25px;
  padding: 35px 0;
  letter-spacing: 1px;
  color: var(--bs-dark);
  font-size: 17px;
  font-weight: 500;
  outline: none;
  transition: 0.5s;
}

.sticky-top .navbar-light .navbar-nav .nav-link {
  padding: 20px 0;
  color: var(--bs-dark);
}

.navbar-light .navbar-nav .nav-link:hover,
.navbar-light .navbar-nav .nav-link.active {
  color: var(--bs-primary);
}

.navbar-light .navbar-brand img {
  max-height: 60px;
  transition: 0.5s;
}

.sticky-top .navbar-light .navbar-brand img {
  max-height: 50px;
}

.navbar .dropdown-toggle::after {
  border: none;
  content: "\f107";
  font-family: "Font Awesome 5 Free";
  font-weight: 600;
  vertical-align: middle;
  margin-left: 8px;
}

.dropdown .dropdown-menu a:hover {
  background: var(--bs-primary);
  color: var(--bs-white);
}

.navbar .nav-item:hover .dropdown-menu {
  transform: rotateX(0deg);
  visibility: visible;
  margin-top: 8px !important;
  background: var(--bs-dark);
  transition: 0.5s;
  opacity: 1;
}

@media (min-width: 992px) {
  .navbar .nav-item .dropdown-menu {
    display: block;
    visibility: hidden;
    top: 100%;
    transform: rotateX(-75deg);
    transform-origin: 0% 0%;
    border: 0;
    border-radius: 10px;
    margin-top: 8px !important;
    transition: 0.5s;
    opacity: 0;
  }
}

@media (max-width: 991px) {
  .navbar.navbar-expand-lg .navbar-toggler {
    padding: 8px 15px;
    border: 1px solid var(--bs-primary);
    color: var(--bs-primary);
  }

  .sticky-top .navbar-light .navbar-nav .nav-link {
    padding: 12px 0;
  }
}
/*** Navbar End ***/

/*** Carousel Header Start ***/
.carousel .carousel-item img {
  object-fit: cover;
}

.carousel .carousel-item,
.carousel .carousel-item img {
  height: 700px;
}

.carousel-item .carousel-caption {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
}

.carousel .carousel-indicators {
  left: 75%;
  top: 50%;
  margin-right: 25%;
  transform: translateY(-50%);
  flex-direction: column;
}

.carousel-indicators [data-bs-target] {
  display: flex;
  width: 15px;
  height: 15px;
  border: 6px solid var(--bs-white);
  border-radius: 15px;
  padding: 0;
  margin-top: 10px;
  margin-bottom: 10px;
  background-color: var(--bs-secondary);
  opacity: 1;
  transition: 0.5s;
}

.carousel-indicators [data-bs-target].active {
  background-color: var(--bs-primary);
}

@media (max-width: 992px) {
  .carousel-indicators [data-bs-target] {
    display: none;
  }
}
/*** Carousel Header End ***/

/*** Single Page Hero Header Start ***/
.bg-breadcrumb {
  position: relative;
  overflow: hidden;
  background: linear-gradient(rgba(31, 46, 78, 1), rgba(0, 12, 33, 0.8)),
    url(../img/byd-bsd-tangerang-01.png);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 60px 0 60px 0;
  transition: 0.5s;
}

.bg-breadcrumb .breadcrumb {
  position: relative;
}

.bg-breadcrumb .breadcrumb .breadcrumb-item a {
  color: var(--bs-white);
}
/*** Single Page Hero Header End ***/

/*** Features Start ***/
.feature {
  background: var(--bs-light);
}

.feature .feature-item {
  display: flex;
  border-radius: 10px;
}

.feature .feature-item .feature-icon span {
  width: 90px;
  height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bs-secondary);
  background: var(--bs-primary);
  border-radius: 67% 33% 29% 71% / 39% 46% 54% 61%;
  animation-name: icon-animat;
  animation-duration: 5s;
  animation-delay: 1s;
  animation-direction: alternate;
  animation-iteration-count: infinite;
  transition: 0.5s;
}

/*** Features End ***/

/*** About Start ***/
.about .about-item .about-item-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 10px;
  background: var(--bs-light);
  transition: 0.5s;
}

.about .about-item .about-item-inner .about-icon {
  width: 90px;
  height: 90px;
  border-radius: 67% 33% 29% 71% / 39% 46% 54% 61%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bs-secondary);
  background: var(--bs-primary);
  animation-name: icon-animat;
  animation-duration: 5s;
  animation-delay: 1s;
  animation-direction: alternate;
  animation-iteration-count: infinite;
  transition: 0.5s;
}

.about .about-img {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
}

.about .about-img .img-1 {
  height: 85%;
  margin-right: 50px;
}

.about .about-img .img-2 {
  position: absolute;
  width: 100%;
  bottom: 0;
  right: 0;
  padding-left: 50px;
  border-radius: 10px;
}

.about .about-img::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 98%;
  top: 0;
  right: 0;
  border-radius: 10px;
  background: var(--bs-primary);
  z-index: -1;
}

.about .about-item .text-item {
  position: relative;
  padding-left: 25px;
}

.about .about-item .text-item::after {
  content: "";
  position: absolute;
  width: 5px;
  height: 100%;
  top: 0;
  left: 0;
  border-radius: 10px;
  background: var(--bs-secondary);
}
/*** About End ***/

/*** Fact Counter Start ***/
.counter {
  background: linear-gradient(rgba(0, 12, 33, 0.9), rgba(31, 46, 78, 0.9)),
    url(../img/fact-bg.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.counter .counter-item .counter-item-icon {
  width: 90px;
  height: 90px;
  border-radius: 67% 33% 29% 71% / 39% 46% 54% 61%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bs-secondary);
  background: var(--bs-primary);
  animation-name: icon-animat;
  animation-duration: 5s;
  animation-delay: 1s;
  animation-direction: alternate;
  animation-iteration-count: infinite;
  transition: 0.5s;
}

/*** Fact Counter End ***/

/*** Services Start ***/
.service .service-item {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-shadow: 0 0 45px rgba(0, 0, 0, 0.1);
  border-radius: 10px;
  background: var(--bs-white);
  transition: 0.5s;
}

.service .service-item:hover {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 60px;
  background: var(--bs-light);
}

.service .service-item::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  bottom: 0;
  left: 0;
  background: var(--bs-primary);
  border-radius: 10px;
  z-index: -1;
  transition: 0.5s;
  opacity: 0;
}

.service .service-item:hover::after {
  opacity: 1;
}

.service .service-item .service-icon {
  width: 90px;
  height: 90px;
  border-radius: 67% 33% 29% 71% / 39% 46% 54% 61%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bs-secondary);
  background: var(--bs-primary);
  animation-name: icon-animat;
  animation-duration: 5s;
  animation-delay: 1s;
  animation-direction: alternate;
  animation-iteration-count: infinite;
  transition: 0.5s;
}
/*** Service End ***/

/*** Cars Categories Start ***/
.categories .categories-item {
  position: relative;
  border: 1px solid var(--bs-secondary);
  border-radius: 10px;
  transition: 0.5s;
}

.categories .categories-item:hover {
  border: 1px solid var(--bs-primary);
}

.categories .categories-item .categories-item-inner {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  transition: 0.5s;
}

.categories .categories-item .categories-item-inner:hover {
  box-shadow: 0 0 50px rgba(234, 0, 30, 0.3);
}

.categories .categories-item-inner .categories-img {
  background: var(--bs-light);
}

.categories .categories-item-inner .categories-content {
  border-top: 4px solid var(--bs-white);
  text-align: center;
  background: var(--bs-light);
}

.categories .categories-item-inner .categories-review {
  display: flex;
  align-items: center;
  justify-content: center;
}

.categories-carousel .owl-stage-outer {
  margin-top: 65px;
  margin-right: -1px;
}

.categories-carousel .owl-nav .owl-prev,
.categories-carousel .owl-nav .owl-next {
  position: absolute;
  top: -65px;
  padding: 10px 35px;
  color: var(--bs-white);
  background: var(--bs-primary);
  border-radius: 50px;
  transition: 0.5s;
}

.categories-carousel .owl-nav .owl-prev {
  left: 0 !important;
}

.categories-carousel .owl-nav .owl-next {
  right: 0;
}

.categories-carousel .owl-nav .owl-prev:hover,
.categories-carousel .owl-nav .owl-next:hover {
  background: var(--bs-secondary);
  color: var(--bs-white);
}
/*** Cars Categories End ***/

/*** Process Start ***/
.steps {
  background: linear-gradient(rgba(0, 0, 0, 0.9), rgba(0, 0, 0, 0.9)),
    url(../img/bg-1.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.steps .steps-item {
  position: relative;
  background: var(--bs-secondary);
  border-radius: 10px;
}

.steps .steps-item h4,
.steps .steps-item p {
  color: var(--bs-white);
}

.steps .steps-item .setps-number {
  position: absolute;
  width: 64px;
  height: 64px;
  bottom: 0;
  right: 40px;
  font-weight: 900;
  border: 1px solid var(--bs-white);
  border-radius: 64px;
  transform: translateY(50%);
  color: var(--bs-white);
  background: var(--bs-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
}
/*** Process End ***/

/*** Blog Start ***/
.blog .blog-item {
  border-radius: 10px;
  transition: 0.5s;
}

.blog .blog-item:hover {
  box-shadow: 0 0 45px rgba(0, 0, 0, 0.2);
}

.blog .blog-item .blog-img {
  position: relative;
  overflow: hidden;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.blog .blog-item .blog-img::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 0;
  bottom: 0;
  left: 0;
  background: rgba(255, 255, 255, 0.3);
  transition: 0.5s;
}

.blog .blog-item:hover .blog-img::after {
  height: 100%;
}

.blog .blog-item .blog-img img {
  transition: 0.5s;
}

.blog .blog-item:hover .blog-img img {
  transform: scale(1.2);
}

.blog .blog-item .blog-content {
  position: relative;
  background: var(--bs-light);
}

.blog .blog-item .blog-content .blog-date {
  position: absolute;
  top: 0;
  left: 25px;
  transform: translateY(-50%);
  padding: 12px 25px;
  border-radius: 10px;
  color: var(--bs-white);
  background: var(--bs-primary);
}

.blog .blog-item .blog-content .blog-comment {
  display: flex;
  justify-content: space-between;
}
/*** Blog End ***/

/*** Banner Start ***/
.banner .banner-item {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 10px;
  transition: 0.5s;
  z-index: 1;
}

.banner .banner-item::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.6);
  z-index: 2;
}

.banner .banner-item .banner-content {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  margin-left: 0;
  margin-bottom: 0;
  padding: 25px;
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: end;
  z-index: 5;
}

@media (min-width: 992px) {
  .banner .banner-item .banner-content h2 {
    font-size: 45px;
    margin-bottom: 20px;
  }

  .banner .banner-item .banner-content h1 {
    font-size: 50px;
    margin-bottom: 20px;
  }

  .banner .banner-item .banner-content p {
    font-size: 40px;
    margin-bottom: 20px;
  }
}
/*** Banner End ***/

/*** Team Start ***/
.team .team-item {
  position: relative;
  text-align: center;
  border-radius: 10px;
  margin-top: 100px;
  background: var(--bs-light);
  transition: 0.5s;
  z-index: 1;
}

.team .team-item::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 0;
  bottom: 0;
  left: 0;
  border-radius: 10px;
  background: var(--bs-secondary);
  z-index: 2;
  transition: 0.5s;
}

.team .team-item:hover::after {
  height: 100%;
}

.team .team-item .team-content {
  position: relative;
  z-index: 5;
}

.team .team-item .team-content h4,
.team .team-item .team-content p {
  transition: 0.5s;
}

.team .team-item:hover .team-content h4 {
  color: var(--bs-white);
}
.team .team-item:hover .team-content p {
  color: var(--bs-white);
}

.team .team-item .team-img {
  position: relative;
  overflow: hidden;
  top: -100px;
  margin-bottom: -100px;
  border-radius: 10px;
  z-index: 3;
}

.team .team-item .team-img img {
  transition: 0.5s;
}

.team .team-item:hover .team-img img {
  transform: scale(1.1);
}

.team .team-item .team-img::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 0;
  top: 0;
  left: 0;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.3);
  z-index: 4;
  transition: 0.5s;
}

.team .team-item:hover .team-img::after {
  height: 100%;
}
/*** Team End ***/

/*** Testimonial Start ***/
.testimonial-carousel .owl-stage-outer {
  margin-right: -1px;
}

.testimonial .testimonial-item {
  position: relative;
  margin-top: 35px;
  border: 1px solid var(--bs-secondary);
  border-radius: 10px;
}

.testimonial .testimonial-item .testimonial-quote {
  position: absolute;
  width: 70px;
  height: 70px;
  top: 0;
  right: 25px;
  transform: translateY(-50%);
  border-radius: 70px;
  color: var(--bs-white);
  background: var(--bs-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.testimonial .testimonial-item .testimonial-inner {
  display: flex;
  align-items: center;
  background: var(--bs-light);
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.testimonial .testimonial-item .testimonial-inner img {
  width: 100px;
  height: 100px;
  border-radius: 100px;
  border: 4px solid var(--bs-white);
}

.testimonial-carousel .owl-dots {
  display: flex;
  justify-content: center;
}

.testimonial-carousel .owl-dots .owl-dot {
  width: 30px;
  height: 30px;
  border-radius: 30px;
  margin: 20px 10px 0 10px;
  background: var(--bs-primary);
  transition: 0.5s;
}

.testimonial-carousel .owl-dots .owl-dot.active {
  width: 30px;
  height: 30px;
  border-radius: 30px;
  background: var(--bs-secondary);
  transition: 0.5s;
}

.testimonial-carousel .owl-dots .owl-dot span {
  position: relative;
  margin-top: 50%;
  margin-left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.testimonial-carousel .owl-dots .owl-dot.active span::after {
  background: var(--bs-primary);
}

.testimonial-carousel .owl-dots .owl-dot span::after {
  content: "";
  width: 15px;
  height: 15px;
  border-radius: 15px;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: var(--bs-white);
  transition: 0.5s;
}
/*** Testimonial End ***/

/*** Contact Start ***/
.contact .contact-add-item {
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: var(--bs-light);
}

.contact .contact-add-item .contact-icon {
  width: 90px;
  height: 90px;
  border-radius: 67% 33% 29% 71% / 39% 46% 54% 61%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bs-secondary);
  background: var(--bs-primary);
  animation-name: icon-animat;
  animation-duration: 5s;
  animation-delay: 1s;
  animation-direction: alternate;
  animation-iteration-count: infinite;
  transition: 0.5s;
}

/*** Contact End ***/

/*** Footer Start ***/
.footer {
  background: var(--bs-dark);
}

.footer .footer-item a {
  line-height: 35px;
  color: var(--bs-body);
  transition: 0.5s;
}

.footer .footer-item p {
  line-height: 35px;
}

.footer .footer-item a:hover {
  letter-spacing: 1px;
  color: var(--bs-primary);
}

.footer .footer-item .footer-btn a,
.footer .footer-item .footer-btn a i {
  transition: 0.5s;
}

.footer .footer-item .footer-btn a:hover {
  background: var(--bs-white);
}

.footer .footer-item .footer-btn a:hover i {
  color: var(--bs-primary) !important;
}
/*** Footer End ***/

/*** copyright Start ***/
.copyright {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  background: var(--bs-dark);
}
/*** copyright end ***/

/*--------------------------------------------------------------
# Whatsapp Bubble
--------------------------------------------------------------*/
body, main {
    padding-top: 1rem;
  }
  .whats-app-bubble {
    position: fixed;
    bottom: 24px;
    left: 20px;
    z-index: 17;
  }
  
  .whats-app-bubble svg {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    box-shadow: #00000026 0 4px 12px;
    transition: background-color 0.3s;
  }
  
  .whats-app-bubble:hover {
    background-color: transparent;
  }

/*--------------------------------------------------------------
# Alert
--------------------------------------------------------------*/
.alert {
  --bs-alert-bg: transparent;
  --bs-alert-padding-x: 1rem;
  --bs-alert-padding-y: 1rem;
  --bs-alert-margin-bottom: 1rem;
  --bs-alert-color: inherit;
  --bs-alert-border-color: transparent;
  --bs-alert-border: 1px solid var(--bs-alert-border-color);
  --bs-alert-border-radius: 0.375rem;
  position: relative;
  padding: var(--bs-alert-padding-y) var(--bs-alert-padding-x);
  margin-bottom: var(--bs-alert-margin-bottom);
  color: var(--bs-alert-color);
  background-color: var(--bs-alert-bg);
  border: var(--bs-alert-border);
  border-radius: var(--bs-alert-border-radius);
}

.alert-heading {
  color: inherit;
}

.alert-link {
  font-weight: 700;
}

.alert-dismissible {
  padding-right: 3rem;
}
.alert-dismissible .btn-close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  padding: 1.25rem 1rem;
}

.alert-primary {
  --bs-alert-color: #121d92;
  --bs-alert-bg: #d2d6fd;
  --bs-alert-border-color: #bcc1fb;
}
.alert-primary .alert-link {
  color: #0e1775;
}

.alert-secondary {
  --bs-alert-color: #88124d;
  --bs-alert-bg: #f9d2e6;
  --bs-alert-border-color: #f6bcd9;
}
.alert-secondary .alert-link {
  color: #6d0e3e;
}

.alert-success {
  --bs-alert-color: #0f5132;
  --bs-alert-bg: #d1e7dd;
  --bs-alert-border-color: #badbcc;
}
.alert-success .alert-link {
  color: #0c4128;
}

.alert-info {
  --bs-alert-color: #055160;
  --bs-alert-bg: #cff4fc;
  --bs-alert-border-color: #b6effb;
}
.alert-info .alert-link {
  color: #04414d;
}

.alert-warning {
  --bs-alert-color: #664d03;
  --bs-alert-bg: #fff3cd;
  --bs-alert-border-color: #ffecb5;
}
.alert-warning .alert-link {
  color: #523e02;
}

.alert-danger {
  --bs-alert-color: #842029;
  --bs-alert-bg: #f8d7da;
  --bs-alert-border-color: #f5c2c7;
}
.alert-danger .alert-link {
  color: #6a1a21;
}

.alert-light {
  --bs-alert-color: #636464;
  --bs-alert-bg: #fefefe;
  --bs-alert-border-color: #fdfdfe;
}
.alert-light .alert-link {
  color: #4f5050;
}

.alert-dark {
  --bs-alert-color: #141619;
  --bs-alert-bg: #d3d3d4;
  --bs-alert-border-color: #bcbebf;
}
.alert-dark .alert-link {
  color: #101214;
}


/* =========================================================
   hargabydterbaru.com - Modern BYD Sales UI Enhancement
   Dibuat untuk Bootstrap template existing
   ========================================================= */
:root {
  --bs-primary: #003b73;
  --bs-secondary: #00a7df;
  --bs-dark: #07111f;
  --bs-light: #f5f8fb;
  --byd-navy: #06172b;
  --byd-blue: #006dba;
  --byd-cyan: #00a7df;
  --byd-soft: #eef7ff;
  --byd-text: #223044;
  --byd-muted: #68788f;
  --byd-gradient: linear-gradient(135deg, #052446 0%, #005aa7 52%, #00a7df 100%);
  --byd-radius: 24px;
  --byd-shadow: 0 18px 45px rgba(7, 17, 31, .12);
}

body {
  color: var(--byd-text);
  background: #ffffff;
  font-family: 'Lato', Arial, sans-serif;
}

h1, h2, h3, h4, h5, h6, .navbar-brand {
  font-family: 'Montserrat', Arial, sans-serif;
  letter-spacing: -.02em;
}

.text-primary { color: var(--bs-primary) !important; }
.bg-primary { background: var(--bs-primary) !important; }
.bg-secondary { background: var(--byd-navy) !important; }

.topbar {
  background: #06172b !important;
  color: #d9edff;
}
.topbar a { color: #d9edff !important; }
.topbar .text-primary { color: #6bd6ff !important; }

.nav-bar {
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(14px);
  box-shadow: 0 12px 34px rgba(7,17,31,.08);
}
.navbar-light .navbar-nav .nav-link {
  font-weight: 700;
  color: #10243c;
}
.navbar-light .navbar-nav .nav-link:hover,
.navbar-light .navbar-nav .nav-link.active {
  color: var(--byd-blue);
}
.navbar .dropdown-menu {
  box-shadow: var(--byd-shadow);
}
.dropdown .dropdown-menu a:hover {
  background: var(--byd-gradient);
}

.btn {
  border-radius: 999px;
  letter-spacing: .01em;
}
.btn-primary,
.btn.btn-primary {
  background: var(--byd-gradient);
  border: 0;
  box-shadow: 0 12px 25px rgba(0, 109, 186, .25);
}
.btn-primary:hover,
.btn.btn-primary:hover {
  transform: translateY(-2px);
  background: linear-gradient(135deg, #003b73 0%, #0079d1 100%);
  border: 0;
}
.btn-secondary,
.btn.btn-secondary {
  background: #00a66c;
  border: 0;
}
.btn-light:hover { background: var(--byd-blue); }

.byd-hero {
  position: relative;
  overflow: hidden;
  min-height: 680px;
  display: flex;
  align-items: center;
  background: radial-gradient(circle at 72% 20%, rgba(0, 167, 223, .24), transparent 28%),
              linear-gradient(135deg, rgba(4, 18, 36, .88), rgba(0, 59, 115, .78)),
              var(--hero-image, url('../img/byd-bsd-tangerang-caraousel-001.png')) center/cover no-repeat;
}
.byd-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 120px;
  background: linear-gradient(0deg, #fff 0%, rgba(255,255,255,0) 100%);
}
.byd-hero .container { position: relative; z-index: 2; }
.hero-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  color: #e8f7ff;
  border: 1px solid rgba(255,255,255,.2);
  font-weight: 800;
  margin-bottom: 18px;
}
.hero-title {
  color: #fff;
  font-weight: 900;
  line-height: 1.04;
  font-size: clamp(2.3rem, 5vw, 4.8rem);
}
.hero-desc {
  color: #e7f3ff;
  font-size: 1.12rem;
  line-height: 1.8;
  max-width: 660px;
}
.hero-panel,
.sales-card,
.soft-card,
.product-card,
.price-card,
.form-card,
.contact-add-item {
  background: #ffffff;
  border: 1px solid rgba(0, 59, 115, .08);
  border-radius: var(--byd-radius);
  box-shadow: var(--byd-shadow);
}
.hero-panel {
  padding: 28px;
  background: rgba(255,255,255,.96);
}
.hero-panel .label {
  color: var(--byd-muted);
  font-size: .85rem;
  text-transform: uppercase;
  font-weight: 800;
  letter-spacing: .08em;
}
.hero-stat {
  padding: 14px;
  border-radius: 18px;
  background: var(--byd-soft);
}
.hero-stat strong { color: var(--byd-navy); font-size: 1.15rem; }

.section-title {
  display: inline-flex;
  color: var(--byd-blue);
  background: rgba(0, 167, 223, .12);
  border-radius: 999px;
  padding: 8px 16px !important;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.section-title::before,
.section-title::after { display: none !important; }

.bg-breadcrumb {
  background: radial-gradient(circle at 70% 15%, rgba(0, 167, 223, .24), transparent 30%),
              linear-gradient(135deg, rgba(4, 18, 36, .92), rgba(0, 59, 115, .85)),
              url(../img/byd-bsd-tangerang-01.png) center/cover no-repeat;
  padding: 88px 0;
}

.soft-section {
  background: linear-gradient(180deg, #f6fbff 0%, #ffffff 100%);
}
.soft-card, .product-card, .price-card, .sales-card, .form-card {
  transition: .35s ease;
}
.soft-card:hover, .product-card:hover, .price-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 55px rgba(7,17,31,.16);
}
.icon-badge {
  width: 56px;
  height: 56px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: var(--byd-gradient);
  box-shadow: 0 14px 24px rgba(0, 109, 186, .25);
}
.product-card { overflow: hidden; height: 100%; }
.product-card img {
  width: 100%;
  height: 230px;
  object-fit: cover;
  background: #f3f8fc;
}
.product-card .product-body { padding: 24px; }
.product-badge {
  display: inline-block;
  padding: 6px 12px;
  border-radius: 999px;
  color: var(--byd-blue);
  background: rgba(0,167,223,.12);
  font-weight: 800;
  font-size: .85rem;
}
.price-card { padding: 24px; height: 100%; }
.price-card img { height: 190px; object-fit: cover; border-radius: 18px; background: #f3f8fc; }
.price-list { margin: 0; padding: 0; list-style: none; }
.price-list li {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  border-bottom: 1px dashed rgba(0, 59, 115, .16);
  padding: 10px 0;
  font-weight: 700;
}
.price-list li:last-child { border-bottom: 0; }
.price-list span:last-child { color: var(--byd-blue); white-space: nowrap; }

.sales-card { padding: 28px; }
.sales-avatar {
  width: 74px;
  height: 74px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--byd-gradient);
  color: #fff;
  font-size: 2rem;
  box-shadow: 0 18px 34px rgba(0,109,186,.25);
}
.cta-band {
  position: relative;
  overflow: hidden;
  border-radius: 32px;
  padding: 44px;
  background: var(--byd-gradient);
  color: #fff;
  box-shadow: var(--byd-shadow);
}
.cta-band::before {
  content: "";
  position: absolute;
  width: 260px;
  height: 260px;
  right: -80px;
  top: -80px;
  border-radius: 50%;
  background: rgba(255,255,255,.14);
}
.cta-band * { position: relative; z-index: 1; }

.form-card { padding: 34px; }
.form-control, .form-select {
  border-radius: 16px;
  border-color: rgba(0, 59, 115, .16);
  min-height: 56px;
}
.form-control:focus, .form-select:focus {
  border-color: var(--byd-cyan);
  box-shadow: 0 0 0 .25rem rgba(0,167,223,.16);
}

.footer {
  background: linear-gradient(135deg, #06172b 0%, #0a2b4f 100%) !important;
}
.copyright { background: #041124 !important; }
.whats-app-bubble {
  position: fixed;
  right: 24px;
  bottom: 96px;
  z-index: 999;
  filter: drop-shadow(0 16px 25px rgba(0,0,0,.25));
  transform: translateZ(0);
}
.whats-app-bubble:hover { transform: translateY(-4px); }
.back-to-top { right: 26px; bottom: 24px; }

.trust-strip {
  margin-top: -42px;
  position: relative;
  z-index: 3;
}
.trust-item {
  background: #fff;
  border-radius: 22px;
  padding: 20px;
  box-shadow: var(--byd-shadow);
  height: 100%;
}

.feature-row img,
.product-detail-img {
  border-radius: 28px;
  box-shadow: var(--byd-shadow);
}
.feature-row:nth-child(even) .text-col { order: -1; }

@media (max-width: 991px) {
  .byd-hero { min-height: 760px; padding: 90px 0 120px; }
  .hero-panel { margin-top: 28px; }
  .navbar-light .navbar-nav .nav-link { padding: 11px 0; }
  .feature-row:nth-child(even) .text-col { order: 0; }
  .cta-band { padding: 30px; border-radius: 24px; }
}
@media (max-width: 575px) {
  .hero-title { font-size: 2.15rem; }
  .product-card img, .price-card img { height: 180px; }
  .form-card { padding: 22px; }
  .whats-app-bubble svg { width: 56px; height: 56px; }
}
/* =========================================================
   FIX FOOTER TEXT & WHATSAPP CLICK AREA
   ========================================================= */

/* Footer dibuat lebih terang agar mudah dibaca */
.footer {
  background: linear-gradient(135deg, #06172b 0%, #0a2b4f 100%) !important;
  color: #dcecff !important;
}

.footer h4,
.footer .footer-item h4 {
  color: #ffffff !important;
}

.footer .footer-item p {
  color: #dcecff !important;
  opacity: 1 !important;
  line-height: 1.9;
}

.footer .footer-item a {
  color: #dcecff !important;
  opacity: 1 !important;
  text-decoration: none;
  line-height: 35px;
}

.footer .footer-item a i {
  color: #7fdcff !important;
}

.footer .footer-item a:hover {
  color: #ffffff !important;
  letter-spacing: .5px;
}

.footer .footer-item a:hover i {
  color: #ffffff !important;
}

.footer .btn-secondary {
  background: #00a66c !important;
  color: #ffffff !important;
  border: 0 !important;
}

.footer .btn-secondary:hover {
  background: #00c981 !important;
  color: #ffffff !important;
}

.footer .btn-md-square {
  color: #ffffff !important;
}

.footer .btn-md-square i {
  color: #ffffff !important;
}

.copyright {
  background: #041124 !important;
  color: #dcecff !important;
}

.copyright .text-body {
  color: #dcecff !important;
}

.copyright a {
  color: #ffffff !important;
}

.copyright a:hover {
  color: #7fdcff !important;
}


/* =========================================================
   FIX WHATSAPP BUBBLE - hanya icon yang bisa diklik
   ========================================================= */

.whats-app-bubble {
  position: fixed !important;
  left: 20px !important;
  right: auto !important;
  bottom: 24px !important;
  width: 64px !important;
  height: 64px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 9999 !important;
  padding: 0 !important;
  margin: 0 !important;
  line-height: 0 !important;
  background: transparent !important;
  border-radius: 50% !important;
  overflow: visible !important;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.25));
}

.whats-app-bubble svg {
  width: 64px !important;
  height: 64px !important;
  display: block !important;
  border-radius: 50% !important;
  pointer-events: auto !important;
}

.whats-app-bubble:hover {
  transform: translateY(-4px);
  background: transparent !important;
}

@media (max-width: 575px) {
  .whats-app-bubble {
    left: 16px !important;
    bottom: 20px !important;
    width: 56px !important;
    height: 56px !important;
  }

  .whats-app-bubble svg {
    width: 56px !important;
    height: 56px !important;
  }
}
