/* Palet visual utama home agar konsisten dengan identitas Byur */
:root {
  --byr-primary: #2f6fb8;
  --byr-primary-soft: #eaf2fc;
  --byr-accent: #1c9d8a;
  --byr-text: #1f2a37;
  --byr-muted: #607185;
  --byr-surface: #ffffff;
  --byr-line: #e4ebf3;
  --byr-shadow: 0 12px 32px rgba(20, 52, 92, 0.12);
}

body {
  background: linear-gradient(180deg, #f5f9ff 0%, #f8fbff 25%, #ffffff 60%);
  color: var(--byr-text);
}

.swiper {
  max-width: 86%;
}
@media (max-width: 768px) {
  .swiper {
    max-width: 100%;
    margin: 14px 0;
  }
}

.byr-icon-whatsapp {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 100;
  background-color: white;
  border-radius: 50%;
  margin: 0;
  box-shadow: 0 16px 36px rgba(10, 44, 84, 0.22);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.byr-icon-whatsapp a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 76px;
  height: 76px;
  color: #128C7E;
  font-size: 46px;
}
.byr-icon-whatsapp:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(10, 44, 84, 0.3);
}

img {
  width: 100%;
  border-radius: 14px;
}

#sectionBanner {
  margin-top: 112px;
}
#sectionBanner img {
  height: 400px;
  display: block;
  width: 92%;
  margin: 0 auto;
  border-radius: 20px;
  object-fit: cover;
  box-shadow: var(--byr-shadow);
}
@media (max-width: 768px) {
  #sectionBanner img {
    height: 220px;
    border-radius: 14px;
  }
}

#sectionListVoucher {
  margin-top: 50px;
}
#sectionListVoucher .byr-card-promo {
  background-color: rgb(70, 121, 192);
  color: white;
  border-radius: 10px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#sectionListVoucher .swiper-voucher {
  margin: unset;
}
#sectionListVoucher .byr-voucher-text {
  background-color: rgb(70, 121, 192);
  color: white;
  height: 270px;
  display: flex;
  justify-content: center;
  flex-direction: column;
  border-radius: 10px;
  padding-left: 10px;
}
@media (max-width: 768px) {
  #sectionListVoucher .byr-voucher-text {
    height: 150px;
    text-align: center;
  }
}
#sectionListVoucher .swiper-slide {
  cursor: pointer;
  padding: 5px;
  transition: 0.2s;
  border-radius: 10px;
  margin: 20px;
}
#sectionListVoucher .swiper-slide img {
  height: auto;
}
#sectionListVoucher .swiper-slide:hover {
  box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}
@media (max-width: 768px) {
  #sectionListVoucher .swiper-slide {
    margin: 5px;
  }
}
#sectionListVoucher .swiper {
  margin-top: 10px;
}

#sectionListSwimming {
  margin-top: 70px;
  position: relative;
  overflow: hidden;
}
#sectionListSwimming h2 {
  font-weight: 700;
  margin-bottom: 18px;
}
#sectionListSwimming .byr-rectangle-wrapper-swim {
  position: absolute;
  top: 30%;
  left: 10%;
  z-index: -10;
}
#sectionListSwimming .container .byr-grid-swim {
  display: grid;
  gap: 20px;
}
@media (min-width: 280px) {
  #sectionListSwimming .container .byr-grid-swim {
    grid-template-columns: repeat(1, 1fr);
  }
}
@media (min-width: 380px) {
  #sectionListSwimming .container .byr-grid-swim {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 780px) {
  #sectionListSwimming .container .byr-grid-swim {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 1080px) {
  #sectionListSwimming .container .byr-grid-swim {
    grid-template-columns: repeat(4, 1fr);
  }
}
#sectionListSwimming .container .byr-grid-swim .byr-card {
  cursor: pointer;
  border: 1px solid var(--byr-line);
  background: var(--byr-surface);
  box-shadow: 0 8px 20px rgba(20, 52, 92, 0.06);
  border-radius: 16px;
}
#sectionListSwimming .container .byr-grid-swim .byr-card:hover {
  transform: translateY(-3px);
  border-color: rgba(47, 111, 184, 0.35);
  box-shadow: 0 14px 28px rgba(20, 52, 92, 0.14);
}

#sectionIntro {
  margin-top: 70px;
}
#sectionIntro .container {
  position: relative;
  background: linear-gradient(130deg, #ffffff 0%, #f2f7ff 70%);
  border: 1px solid var(--byr-line);
  border-radius: 20px;
  padding: 26px;
  box-shadow: 0 10px 24px rgba(20, 52, 92, 0.08);
}
#sectionIntro h2 {
  font-weight: 700;
}
@media (max-width: 720px) {
  #sectionIntro .container .col-md-8 {
    margin-top: 30px;
  }
}
#sectionIntro .container .byr-intro-image {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: -10;
}
@media (max-width: 720px) {
  #sectionIntro .container .byr-intro-image {
    display: none;
  }
}
#sectionIntro .container .byr-intro-image img {
  height: 100%;
}

#sectionGalleries {
  margin-top: 92px;
}
#sectionGalleries h2 {
  font-weight: 700;
  margin-bottom: 14px;
}
#sectionGalleries .swiper-slide img {
  border-radius: 16px;
  box-shadow: var(--byr-shadow);
}

#sectionMap {
  margin-top: 90px;
  background: linear-gradient(135deg, #2f6fb8 0%, #2f87b8 50%, #1c9d8a 100%);
  color: white;
  padding: 56px 24px;
  border-radius: 24px 24px 0 0;
}
#sectionMap h2 {
  margin-bottom: 30px;
  font-weight: 700;
}
#sectionMap iframe {
  border-radius: 16px;
  box-shadow: 0 16px 34px rgba(8, 34, 64, 0.35);
}

/* Footer baru dengan visual lebih ramah keluarga dan struktur lebih jelas */
.byr-footer {
  margin-top: 0;
  padding-top: 34px;
  background:
    radial-gradient(circle at 10% 15%, rgba(255, 255, 255, 0.12), transparent 25%),
    linear-gradient(130deg, #1f6fb6 0%, #2c8abf 45%, #27b099 100%);
  color: #f5fbff;
}
.byr-footer-top {
  padding: 24px 0;
}
.byr-footer-bottom {
  margin-top: 10px;
  padding: 14px 0 18px;
  border-top: 1px solid rgba(255, 255, 255, 0.24);
}
.byr-footer-bottom p {
  margin: 0;
  text-align: center;
  color: #e5f4ff;
  font-size: 14px;
}
.byr-footer h2,
.byr-footer h4 {
  color: #ffffff;
  font-weight: 800;
}
.byr-footer h2 {
  margin-bottom: 8px;
}
.byr-footer h4 {
  margin-bottom: 14px;
  font-size: 20px;
}
.byr-footer-desc,
.byr-footer-address {
  color: #e9f7ff;
  margin-bottom: 10px;
}
.byr-footer-links {
  margin: 0;
  padding: 0;
  list-style: none;
}
.byr-footer-links li {
  margin-bottom: 10px;
}
.byr-footer a {
  color: #f5fbff;
  text-decoration: none;
  transition: color 0.2s ease, opacity 0.2s ease;
}
.byr-footer a:hover {
  color: #fff9d8;
}
.byr-footer-social {
  display: grid;
  gap: 10px;
}
.byr-social-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.25);
  background: rgba(255, 255, 255, 0.08);
}
.byr-social-item i {
  font-size: 18px;
}
@media (max-width: 768px) {
  .byr-footer {
    padding-top: 24px;
  }
  .byr-footer-top {
    padding: 10px 0 18px;
  }
  .byr-footer h2 {
    font-size: 28px;
  }
}

a.byr-card {
  text-decoration: none;
  color: var(--byr-text);
}

.byr-card {
  border-radius: 14px;
  transition: 0.2s ease;
  padding: 10px;
}
.byr-card .byr-card-img img {
  width: 100%;
  border-radius: 12px;
  aspect-ratio: 16 / 11;
  object-fit: cover;
}
.byr-card .byr-card-body .byr-card-info {
  margin-top: 5px;
  margin-bottom: 20px;
}
.byr-card .byr-card-body .byr-card-info p {
  margin-bottom: 0;
  font-size: 20px;
  font-weight: 600;
}
.byr-card .byr-card-body .byr-card-info small {
  color: var(--byr-muted);
}
.byr-card .byr-card-price p {
  margin-bottom: 0;
  color: var(--byr-primary);
  font-weight: 700;
}

/* Perapihan area promo package agar gambar tampil lebih premium tanpa ubah konten */
#sectionPackage .container {
  margin-top: 28px !important;
}
#sectionPackage h4 {
  font-weight: 700;
  margin-bottom: 8px;
}
#sectionPackage .col-md-6 img {
  border-radius: 18px;
  box-shadow: var(--byr-shadow);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
#sectionPackage .col-md-6 a:hover img {
  transform: translateY(-3px);
  box-shadow: 0 18px 34px rgba(20, 52, 92, 0.16);
}

/* Navbar baru dengan style lebih segar dan ramah keluarga */
.byr-navbar {
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid #e2ebf6;
  box-shadow: 0 8px 24px rgba(19, 57, 95, 0.08);
}
.byr-navbar .container {
  min-height: 74px;
}
.byr-navbar-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
  color: #1d5d99;
}
.byr-navbar-brand img {
  /* Menetapkan ukuran logo agar proporsional dan konsisten di seluruh halaman public */
  width: auto;
  height: 42px;
  max-width: 100%;
  object-fit: contain;
  border-radius: 10px;
}
.byr-navbar .nav-link {
  color: #35506e;
  font-weight: 600;
  padding: 10px 12px !important;
  border-radius: 10px;
}
.byr-navbar .nav-link.active,
.byr-navbar .nav-link:hover {
  color: #1d5d99;
  background: #edf4fd;
}
.byr-navbar .dropdown-menu {
  border: 1px solid #e4ecf7;
  border-radius: 12px;
  box-shadow: 0 16px 30px rgba(19, 57, 95, 0.14);
}
.byr-navbar-cta {
  border-radius: 999px;
  padding: 8px 16px;
  font-weight: 700;
  color: #ffffff;
  background: linear-gradient(135deg, #1d6db0 0%, #24a893 100%);
  border: none;
}
.byr-navbar-cta:hover {
  color: #ffffff;
  opacity: 0.92;
}
@media (max-width: 991px) {
  .byr-navbar-brand img {
    /* Ukuran logo diperkecil pada layar mobile agar area navbar tetap lega */
    height: 36px;
  }
  .byr-navbar-brand span {
    font-size: 15px;
  }
  .byr-navbar .navbar-collapse {
    padding: 8px 0 14px;
  }
}

/* Styling area autentikasi agar halaman login/register lebih rapi dan konsisten */
.byr-auth-section {
  margin-top: 110px;
  margin-bottom: 36px;
}
.byr-auth-card {
  border: 1px solid #dce7f5;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 16px 34px rgba(19, 57, 95, 0.12);
}
.byr-auth-head {
  background: linear-gradient(135deg, #eef5ff 0%, #e9f8f3 100%);
  border-bottom: 1px solid #dce7f5;
  padding: 18px 20px;
}
.byr-auth-head h4 {
  margin: 0;
  color: #1d5d99;
  font-weight: 800;
}
.byr-auth-head p {
  margin: 6px 0 0;
  color: #4b6481;
  font-size: 14px;
}
.byr-auth-card .card-body {
  padding: 20px;
}
.byr-auth-card label {
  font-weight: 600;
  color: #35506e;
}
.byr-auth-input {
  border-radius: 10px;
  border: 1px solid #d7e2ef;
  padding: 10px 12px;
}
.byr-auth-input:focus {
  border-color: #487bbe;
  box-shadow: 0 0 0 0.2rem rgba(72, 123, 190, 0.16);
}
.byr-auth-link {
  display: inline-block;
  margin-top: 8px;
  font-size: 14px;
  color: #1d5d99;
  text-decoration: none;
}
.byr-auth-link:hover {
  color: #174d81;
  text-decoration: underline;
}
.byr-auth-btn {
  width: 100%;
  border-radius: 10px;
  padding: 10px 14px;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, #1d6db0 0%, #24a893 100%);
  border: none;
}
.byr-auth-btn:hover {
  color: #fff;
  opacity: 0.92;
}
.byr-auth-terms {
  display: block;
  margin-top: 10px;
  color: #5a6f87;
}
.byr-auth-terms a {
  color: #1d5d99;
}
@media (max-width: 991px) {
  .byr-auth-section {
    margin-top: 96px;
  }
}

#formCheckout {
  margin-top: 110px;
}
@media (max-width: 992px) {
  #formCheckout .byr-person-booking {
    order: 2;
  }
  #formCheckout .byr-info-booking {
    order: 1;
  }
}
#formCheckout .byr-img-service-checkout {
  height: 120px;
}
#formCheckout .byr-img-service-checkout img {
  height: 100%;
}
#formCheckout .byr-line-checkout {
  border: 1px solid rgba(0, 0, 0, 0.2);
  margin: 20px 0;
}
#formCheckout .byr-card-checkout-info {
  display: flex;
  justify-content: space-between;
  font-size: 18px;
  margin: 10px 0;
}
#formCheckout .byr-card-checkout-info .label {
  font-weight: 500;
}

#sectionSearch {
  margin-top: 50px;
}

.success_booking {
  margin-top: 100px;
}
.success_booking img {
  height: 200px;
  width: 200px;
}

#sectionPaymentConfirmation {
  margin-top: 80px;
}

#sectionAnotherSwimming {
  margin-top: 50px;
}

.parent-loader {
  position: fixed;
  background-color: rgba(0, 0, 0, 0.5);
  width: 100vw;
  height: 100vh;
  z-index: 9999999;
  top: 0;
}
.parent-loader::after {
  content: " ";
  display: block;
  width: 64px;
  height: 64px;
  margin: 8px;
  border-radius: 50%;
  border: 6px solid #fff;
  border-color: #fff transparent #fff transparent;
  animation: lds-dual-ring 1.2s linear infinite;
  position: absolute;
  top: 50%;
  left: 50%;
}

@keyframes lds-dual-ring {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}/*# sourceMappingURL=style.css.map */
