/* 🌸 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;
}

.btn-cover {
  font-family: var(--font-body);
  font-size: 14px;
  /* border-radius: 1rem; */
}

@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 var(--heading);
  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: var(--font-body), sans-serif;
  text-align: center;
  letter-spacing: -4px;
}

.container-preloader .animation-preloader .txt-loading .characters:before {
  animation: characters 4s infinite;
  color: var(--heading);
  content: attr(preloader-text);
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  transform: rotateY(-90deg);
}

.container-preloader .animation-preloader .txt-loading .characters {
  color: rgba(255, 255, 255, 0.069);
  position: relative;
  font-family: var(--font-body), 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: #ffffff;
  backdrop-filter: blur(20px);
  opacity: 1;
  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);
}

.container-preloader .animation-preloader .txt-loading {
  font: bold 4.5em "Maulysia", sans-serif;
}

/* 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: var(--heading);
  ;
}

.progress-wrap svg.progress-circle path {
  stroke: var(--heading);
}

.opening {
  z-index: 100;
  overflow: hidden;
  background-color: var(--background);
  font-family: var(--font-body), sans-serif;
  opacity: 1;
  transition: opacity 0.8s ease;
  background: white;
  /* durasi 0.8 detik */
}

.opening.fade {
  opacity: 0;
}

.opening,
.opening .title {
  width: 100%;
  height: 100vh;
  position: fixed !important;
  /* padding-top: 20px; */
}

.border-top-opening {
  width: 0px;
  height: 50px;
  background-color: var(--heading);
  margin-top: 15px;
  margin-bottom: 40px;
}

.opening .title h5 {
  font-family: var(--font-body), sans-serif;
  animation: fadeInText 1s ease-out forwards;
  margin-bottom: 0;
  color: var(--heading);
}

.opening .title h2 {
  /* font-weight: 600; */
  color: var(--heading);
  font-family: var(--font-heading), sans-serif;
  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: var(--font-body), sans-serif;
  margin-top: 10px;
}

.opening-title {
  width: 100%;
  height: 100%;
  padding: 12vh 0;
}

.opening .img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.opening:before {
  content: "";
  height: 100%;
  left: 0;
  opacity: 0.4;
  position: absolute;
  width: 100%;
}

.qr-button {
  position: absolute;
  font-family: var(--font-body), sans-serif;
  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: var(--accent);
}

.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: var(--heading);
  border-radius: 50%;
  left: 10px;
  background: var(--accent);
}

.btn-qr {
  justify-content: center;
  display: flex;
  position: fixed;
  top: 20px;
  z-index: 100;
  width: min(100%, 45px);
  color: var(--heading);
  border-radius: 50%;
  left: 10px;
  background: var(--accent);
  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: #f10202;
}

/* 🌸 Animasi jatuh */
@keyframes fall {
  0% {
    transform: translateY(-30vh) rotate(0deg);
    opacity: 0;
  }

  5% {
    opacity: 0.9;
  }

  100% {
    transform: translateY(120vh) rotate(360deg);
    opacity: 0.7;
  }
}

.opening {
  transition: transform 8s cubic-bezier(.25, .8, .25, 1);
  will-change: transform;
}


.opening.is-hide {
  transform: translateY(-120%);
}

.videoWrapper iframe {
  position: relative;
  top: 0;
  left: 0;
  width: 365px;
  margin-top: 1.5vh;
  height: 250px;
}

.bg-slideshow {
  position: fixed;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  filter: contrast(0.5);
}

.bg-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  transform: scale(1.05);
  transition:
    opacity 1.8s ease-in-out,
    transform 5s ease-in-out;
}

.bg-slide.active {
  opacity: 1;
  transform: scale(1);
}

.btn-close {
  color: var(--paragraphs);
}

.flower-container {
  position: fixed;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
  backdrop-filter: blur(8px) saturate(120%);
  -webkit-backdrop-filter: blur(8px) saturate(120%);
}

.flower {
  position: absolute;
  top: -10vh;
  background-size: contain;
  background-repeat: no-repeat;
  opacity: 0;
  width: 60px;
  height: 60px;
  will-change: transform, opacity;
  filter: drop-shadow(0 4px 6px rgba(0, 0, 0, 0.1));
  animation: fall linear infinite;
}

/* 🌸 Animasi jatuh */
@keyframes fall {
  0% {
    transform: translateY(-30vh) rotate(0deg);
    opacity: 0;
  }

  5% {
    opacity: 0.9;
  }

  100% {
    transform: translateY(120vh) rotate(360deg);
    opacity: 0.7;
  }
}

.lang-select {
  background: rgba(255, 255, 255, 0.4);
  backdrop-filter: blur(8px) saturate(140%);
  -webkit-backdrop-filter: blur(8px) saturate(140%);
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 8px;
  padding: 4px 6px;
  font-size: 12px;
  color: #333;
  cursor: pointer;
  outline: none;
  transition: all 0.3s ease;
}

.lang-select:hover {
  background: rgba(255, 255, 255, 0.7);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

@media (prefers-color-scheme: dark) {
  .lang-select {
    background: rgba(30, 30, 30, 0.6);
    color: #f1f1f1;
    border-color: rgba(255, 255, 255, 0.1);
  }

  .lang-select:hover {
    background: rgba(50, 50, 50, 0.8);
  }
}

.loader-logo {
  width: 180px;
  max-width: 100%;
  height: auto;
}

.loader-text {
  font-size: 12px;
  text-align: center;
  margin-top: -6vh;
  color: #000;
}

.couple-toggle {
  display: flex;
  justify-content: flex-start;
  gap: 12px;
  margin: 0 50px;
  margin-top: 80px;
}

.toggle-btn {
  padding: 0px 15px;
  border-bottom: 2px solid var(--heading);
  background: #213c8000;
  color: var(--heading);
  cursor: pointer;
  /* border-radius: 1rem; */
  font-size: 14px;
  text-transform: uppercase;
  transition: all .9s ease;
}

.toggle-btn.active {
  background: #ffffff75;
  color: var(--background);
  border-bottom: 2px solid var(--background);
}

#section-bride,
#section-groom,
#section-story {
  transition:
    transform 3.4s cubic-bezier(.19, 1, .22, 1),
    opacity 0.8s ease;
  will-change: transform, opacity;
}

.hidden {
  opacity: 0;
  pointer-events: none;
  position: absolute;
  transform: translateY(80px);
}

.photo-slideshow {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.photo-track {
  display: flex;
  transition: transform 1.2s cubic-bezier(.22, .61, .36, 1);
  height: 50vh;
}

.photo-track img {
  width: 100%;
  flex-shrink: 0;
  object-fit: cover;
}

.icon-mono {
  color: currentColor;
  /* ikut warna teks */
  opacity: 0.75;
  margin-right: 8px;
  font-size: 0.95em;
  vertical-align: middle;
}

.subtitle .icon-mono,
.heading .icon-mono {
  opacity: 0.85;
}

.mono-btn {
  border: 1px solid currentColor;
  background: transparent;
}

.mono-btn:hover {
  background: rgba(0, 0, 0, 0.05);
}

/* kondisi awal */
[data-aos="popup-down"] {
  transform: translateY(-60px);
  opacity: 1;
  /* tidak fade */
  transition-property: transform;
}

/* saat aktif */
[data-aos="popup-down"].aos-animate {
  transform: translateY(0);
}

[data-aos="popup-down"] {
  transform: translateY(-70px);
  transition: transform 1s cubic-bezier(.22, 1, .36, 1);
}

[data-aos="popup-down"].aos-animate {
  transform: translateY(0);
}

[data-aos="popup-down"] {
  will-change: transform;
}