/* 🌸 HERO SECTION */
.vanyaandre-hero {
  position: relative;
  height: 100vh;
  width: 100%;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
}

/* 📸 Background image via <img> */
.vanyaandre-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  transition: filter 1s ease, transform 1s ease;
  filter: blur(0px) saturate(1);
  transform: scale(1);
}

/* 🌑 Overlay gradient */
.vanyaandre-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    var(--va-overlay-top) 0%,
    rgba(0, 0, 0, 0.45) 50%,
    var(--va-overlay-bottom) 100%
  );
  transition: background 900ms ease, opacity 900ms ease;
}

/* ✨ Wedding details bottom-left */
.vanyaandre-details {
  position: relative;
  z-index: 2;
  color: var(--va-text);
  padding: 48px 64px;
  max-width: 520px;
  text-align: left;
}
.vanyaandre-small {
  font-size: 14px;
  opacity: 0.9;
  margin-bottom: 8px;
  letter-spacing: 1px;
}
.vanyaandre-title {
  font-size: 40px;
  font-weight: 700;
  margin-bottom: 6px;
  letter-spacing: 0.6px;
}
.vanyaandre-date {
  font-size: 18px;
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.9);
}

/* 💍 CTA Button Center */
.vanyaandre-cta {
  position: absolute;
  z-index: 3;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  gap: 12px;
  align-items: center;
  transition: opacity 0.4s ease;
}

.vanyaandre-btn {
  background: transparent;
  color: var(--va-text);
  border: 2px solid rgba(255, 255, 255, 0.75);
  padding: 14px 22px;
  font-size: 16px;
  border-radius: 40px;
  cursor: pointer;
  backdrop-filter: blur(4px);
  transition: all 0.25s ease;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.35);
}
.vanyaandre-btn:hover {
  transform: translateY(-3px) scale(1.03);
}
.vanyaandre-btn-primary {
  background: linear-gradient(
    90deg,
    rgba(230, 197, 138, 0.15),
    rgba(230, 197, 138, 0.08)
  );
  border-color: var(--va-accent);
  color: var(--va-accent);
  font-weight: 600;
}

/* 💌 Invitation Modal */
.vanyaandre-card {
  position: fixed;
  z-index: 99;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scale(0.95);
  width: min(720px, 92%);
  max-height: 98vh;
  overflow: auto;
  background: rgb(160 164 142);
  padding: 26px 28px;
  border-radius: 14px;
  box-shadow: 0 30px 60px rgba(6, 6, 6, 0.6);
  opacity: 0;
  pointer-events: none;
  transition: opacity 600ms ease, transform 500ms cubic-bezier(0.2, 0.9, 0.3, 1);
  border: 1px solid rgba(255, 255, 255, 0.06);
  color: #fff;
}
.vanyaandre-card-open {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
  pointer-events: auto;
}
.vanyaandre-card h3 {
  color: var(--va-accent);
  font-size: 18px;
  margin-bottom: 6px;
  letter-spacing: 0.5px;
}
.vanyaandre-card h1 {
  font-size: 28px;
  margin: 0 0 12px;
}
.vanyaandre-card p {
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: 10px;
}
.vanyaandre-card strong {
  background-color: #fff;
  color: rgb(160 164 142);
}
/* 🎞️ When Blurred */
.vanyaandre-blur .vanyaandre-bg {
  filter: blur(8px);
  transform: scale(1.02);
}
.vanyaandre-blur .vanyaandre-overlay {
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.25) 0%,
    rgba(0, 0, 0, 0.6) 50%,
    rgba(0, 0, 0, 0.92) 100%
  );
}
.vanyaandre-blur .vanyaandre-cta {
  opacity: 0;
  pointer-events: none;
}

@media (max-width: 768px) {
  .btn-cover {
    margin-top: 0px !important;
  }
  .vanyaandre-details {
    padding: 22px;
    max-width: 94%;
  }
  .vanyaandre-title {
    font-size: 28px;
  }
  .vanyaandre-date {
    font-size: 16px;
  }
  .vanyaandre-cta {
    top: 60%;
  }
  .vanyaandre-card {
    width: 96%;
    padding: 18px;
  }
}

/* 🎵 Floating Buttons */
.vanyaandre-floating-btns {
  position: fixed;
  bottom: 15px;
  left: 20px;
  z-index: 99;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.vanyaandre-floating-btns button {
  width: 44px;
  height: 44px;
  border: 2px solid rgba(255, 255, 255, 0.7);
  border-radius: 50%;
  background: rgb(160 164 142 / 70%);
  color: #fff;
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s ease;
  backdrop-filter: blur(4px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
}

.vanyaandre-floating-btns button:hover {
  transform: scale(1.1);
  background: rgba(230, 197, 138, 0.15);
  border-color: var(--va-accent);
  color: var(--va-accent);
}

.container-preloader {
  align-items: center;
  cursor: none;
  display: flex;
  height: 100%;
  justify-content: center;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 100000;
}
.container-preloader .animation-preloader {
  position: absolute;
  z-index: 10000;
}
.container-preloader .animation-preloader .spinner {
  animation: spinner 1s infinite linear;
  border-radius: 50%;
  border: 10px solid rgba(0, 0, 0, 0.2);
  border-top-color: #c7653d; /* It is not in alphabetical order so that you do not overwrite it */
  height: 9em;
  margin: 0 auto 3.5em auto;
  width: 9em;
}
/* Loading text */
.container-preloader .animation-preloader .txt-loading {
  font: Marcellus, sans-serif;
  text-align: center;
  letter-spacing: -4px;
}
.container-preloader .animation-preloader .txt-loading .characters:before {
  animation: characters 4s infinite;
  color: #a1a58f;
  content: attr(preloader-text);
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  transform: rotateY(-90deg);
}
.container-preloader .animation-preloader .txt-loading .characters {
  color: rgb(255 255 255 / 70%);
  position: relative;
  font-family: Marcellus, sans-serif !important;
}
.container-preloader
  .animation-preloader
  .txt-loading
  .characters:nth-child(2):before {
  animation-delay: 0.2s;
}
.container-preloader
  .animation-preloader
  .txt-loading
  .characters:nth-child(3):before {
  animation-delay: 0.4s;
}
.container-preloader
  .animation-preloader
  .txt-loading
  .characters:nth-child(4):before {
  animation-delay: 0.6s;
}
.container-preloader
  .animation-preloader
  .txt-loading
  .characters:nth-child(5):before {
  animation-delay: 0.8s;
}
.container-preloader
  .animation-preloader
  .txt-loading
  .characters:nth-child(6):before {
  animation-delay: 1s;
}
.container-preloader
  .animation-preloader
  .txt-loading
  .characters:nth-child(7):before {
  animation-delay: 1.2s;
}
.container-preloader
  .animation-preloader
  .txt-loading
  .characters:nth-child(8):before {
  animation-delay: 1.4s;
}
.container-preloader
  .animation-preloader
  .txt-loading
  .characters:nth-child(9):before {
  animation-delay: 1.6s;
}
.container-preloader
  .animation-preloader
  .txt-loading
  .characters:nth-child(10):before {
  animation-delay: 1.8s;
}
.container-preloader .loader-section {
  /* background: rgb(241, 241, 241); */
  backdrop-filter: blur(20px);
  opacity: 0.8;
  height: 100%;
  position: fixed;
  top: 0;
  width: calc(50% + 1px);
  /* background-image: url("./images/open-frame.png"); */
  background-size: cover;
}
.container-preloader .loader-section.section-left {
  left: 0;
}
.container-preloader .loader-section.section-right {
  right: 0;
}
/* Fade effect on loading animation */
.loaded .animation-preloader {
  opacity: 0;
  transition: 0.3s ease-out;
}
/* Curtain effect */
.loaded .loader-section.section-left {
  transform: translateX(-101%);
  transition: 0.7s 0.3s all cubic-bezier(0.1, 0.1, 0.1, 1);
}
.loaded .loader-section.section-right {
  transform: translateX(101%);
  transition: 0.7s 0.3s all cubic-bezier(0.1, 0.1, 0.1, 1);
}
/* Animation of the preloader */
@keyframes spinner {
  to {
    transform: rotateZ(360deg);
  }
}
/* Animation of letters loading from the preloader */
@keyframes characters {
  0%,
  75%,
  100% {
    opacity: 0;
    transform: rotateY(-90deg);
  }
  25%,
  50% {
    opacity: 1;
    transform: rotateY(0deg);
  }
}
/* Laptop size back (laptop, tablet, cell phone) */
@media screen and (max-width: 767px) {
  /* Preloader */
  /* Spinner Loading */
  .container-preloader .animation-preloader .spinner {
    height: 8em;
    width: 8em;
  }
  /* Text Loading */
  .container-preloader .animation-preloader .txt-loading {
    font: bold 3.5em "Maulysia", sans-serif;
  }
}
@media screen and (max-width: 500px) {
  /* Prelaoder */
  /* Spinner Loading */
  .container-preloader .animation-preloader .spinner {
    height: 7em;
    width: 7em;
  }
  .header .title {
    left: 33% !important;
  }
  /*Loading text */
  .container-preloader .animation-preloader .txt-loading {
    font: bold 2em "Maulysia", sans-serif;
  }
}
/* ======= toTop Button style ======= */
.progress-wrap {
  position: fixed;
  bottom: 15px;
  right: 20px;
  height: 45px;
  width: 45px;
  cursor: pointer;
  display: block;
  border-radius: 50px;
  -webkit-box-shadow: inset 0 0 0 2px rgba(0, 0, 0, 0.2);
  box-shadow: inset 0 0 0 2px rgba(0, 0, 0, 0.2);
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(20px);
  -ms-transform: translateY(20px);
  transform: translateY(20px);
  -webkit-transition: all 400ms linear;
  -o-transition: all 400ms linear;
  transition: all 400ms linear;
}
.progress-wrap.active-progress {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
}
.progress-wrap::after {
  position: absolute;
  content: "\2191";
  text-align: center;
  line-height: 45px;
  font-size: 12px;
  font-weight: 700;
  color: #323232;
  left: 0;
  top: 0;
  height: 45px;
  width: 45px;
  cursor: pointer;
  display: block;
  z-index: 1;
  -webkit-transition: all 400ms linear;
  -o-transition: all 400ms linear;
  transition: all 400ms linear;
}
.progress-wrap svg path {
  fill: none;
}
.progress-wrap svg.progress-circle path {
  stroke: rgba(0, 0, 0, 0.2);
  stroke-width: 4;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 400ms linear;
  -o-transition: all 400ms linear;
  transition: all 400ms linear;
}
.progress-wrap {
  -webkit-box-shadow: inset 0 0 0 2px rgba(0, 0, 0, 0.2);
  box-shadow: inset 0 0 0 2px rgba(0, 0, 0, 0.2);
}
.progress-wrap::after {
  color: #000000;
}
.progress-wrap svg.progress-circle path {
  stroke: #ffffff;
}
.opening {
  z-index: 100;
  overflow: hidden;
  background-color: #ecede8fa;
  font-family: Quicksand, sans-serif;
  opacity: 1;
  transition: opacity 0.8s ease; /* durasi 0.8 detik */
}
.opening.fade {
  opacity: 0;
}
.opening,
.opening .title {
  width: 100%;
  height: 100vh;
  position: fixed !important;
  padding: 20px;
}
.opening .title {
  color: #fff;
  font-family: Marcellus, sans-serif;
}
.opening .title h5 {
  font-family: Marcellus, sans-serif;
  animation: fadeInText 1s ease-out forwards;
  margin-bottom: auto;
  color: #f8f2f2;
}
.opening .title h2 {
  /* font-weight: 600; */
  color: #f8f2f2;
  animation: fadeInText 1.5s ease-out forwards;
}
.opening .title .btn {
  width: min(100%, 200px);
  color: #f8f2f2;
  border-radius: 2px !important;
  backdrop-filter: blur(10px);
  background-color: #eeaa6a;
  /* background-image: radial-gradient(ellipse at top, transparent 0%, #000), radial-gradient(ellipse at bottom, #657280, rgba(145, 233, 255, 0.2)), repeating-linear-gradient(220deg, #000 0px, #000 19px, transparent 19px, transparent 22px), repeating-linear-gradient(189deg, #000 0px, #000 19px, transparent 19px, transparent 22px), repeating-linear-gradient(148deg, #000 0px, #000 19px, transparent 19px, transparent 22px), linear-gradient(90deg, #00fffa, #f0f0f3); */
  background-size: cover;
  font-family: "VARUNA", sans-serif;
  margin-top: 10px;
}
.opening-title {
  width: 100%;
  height: 100%;
  padding: 12vh 0;
}

.opening .img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.opening:before {
  content: "";
  height: 100%;
  left: 0;
  opacity: 0.4;
  position: absolute;
  width: 100%;
}

.qr-button {
  position: absolute;
  font-family: "themify";
  text-align: center;
  line-height: 45px;
  font-size: 12px;
  font-weight: 700;
  color: #323232;
  left: 0;
  top: 0;
  height: 45px;
  width: 45px;
  cursor: pointer;
  display: block;
  z-index: 2;
  -webkit-transition: all 400ms linear;
  -o-transition: all 400ms linear;
  transition: all 400ms linear;
}
.qr-button img {
  width: min(100%, 30px);
}

.qr-button a {
  background: white;
}
.play-pause {
  justify-content: center;
  display: flex;
  position: fixed;
  bottom: 12px;
  z-index: 100;
  padding: 7px 3px;
  font-size: 20px;
  width: min(100%, 45px);
  color: #a0a48e;
  border-radius: 50%;
  left: 10px;
  background: #ffffff;
}

.btn-qr {
  justify-content: center;
  display: flex;
  position: fixed;
  bottom: 65px;
  z-index: 100;
  width: min(100%, 45px);
  color: #a0a48e;
  border-radius: 2px;
  left: 10px;
  background: #ffffff;
  text-align: center;
  letter-spacing: 0px;
  text-transform: uppercase;
}
.postcard-container {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: -100px 0 0 0;
  width: 100%;
}

.postcard-img {
  width: 90%;
  max-width: 500px;
  border: 1px solid #ddd;
  border-radius: 4px; /* bisa ubah ke 1px kalau mau benar-benar kecil */
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  object-fit: cover;
  animation: fadeInText 1s ease-in-out forwards;
}
.error {
  color: #d87878;
}
