.animation-progress {
  position: fixed;
  inset: 0 0 auto;
  z-index: 1200;
  height: 2px;
  pointer-events: none;
}

.animation-progress span {
  display: block;
  width: 100%;
  height: 100%;
  background: var(--sage);
  transform: scaleX(0);
  transform-origin: left;
  will-change: transform;
}

.version-animada main > section {
  position: relative;
  isolation: isolate;
}

.version-animada .section-transition {
  position: absolute;
  top: 0;
  left: 50%;
  z-index: 5;
  width: min(88%, 1120px);
  height: 42px;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.version-animada .section-transition::before, .version-animada .section-transition::after {
  content: "";
  position: absolute;
  top: 20px;
  width: calc(50% - 12px);
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(111, 127, 103, .5));
  transform: scaleX(0);
  transition: transform 1.05s cubic-bezier(.22, .61, .36, 1);
}

.version-animada .section-transition::before {
  right: calc(50% + 12px);
  transform-origin: right;
}

.version-animada .section-transition::after {
  left: calc(50% + 12px);
  background: linear-gradient(90deg, rgba(111, 127, 103, .5), transparent);
  transform-origin: left;
}

.version-animada .section-transition span {
  position: absolute;
  top: 15px;
  left: 50%;
  width: 14px;
  height: 14px;
  border: 1px solid rgba(111, 127, 103, .7);
  background: var(--sage);
  box-shadow: 0 0 0 6px rgba(111, 127, 103, .1);
  opacity: 0;
  transform: translateX(-50%) rotate(45deg) scale(.35);
  transition: opacity .4s .55s ease, transform .65s .5s cubic-bezier(.34, 1.56, .64, 1);
}

.version-animada main > section.section-entered > .section-transition::before, .version-animada main > section.section-entered > .section-transition::after {
  transform: scaleX(1);
}

.version-animada main > section.section-entered > .section-transition span {
  opacity: 1;
  transform: translateX(-50%) rotate(45deg) scale(1);
  animation: transitionMarker 2.4s 1.1s ease-in-out infinite;
}

.version-animada .section-transition-sweep {
  position: absolute;
  inset: 0;
  z-index: 4;
  background: linear-gradient(180deg, rgba(255, 254, 250, .28), transparent 30%);
  opacity: 0;
  transform: translateY(-26px);
  transition: opacity .85s ease, transform 1s cubic-bezier(.22, .61, .36, 1);
  pointer-events: none;
}

.version-animada main > section.section-entered > .section-transition-sweep {
  opacity: 1;
  transform: translateY(0);
}

.version-animada main > section.section-entered > .container {
  animation: sectionArrival 1.05s cubic-bezier(.22, .61, .36, 1) both;
}

.version-animada .wedding-nav {
  transition: background-color .35s ease, box-shadow .35s ease;
}

.version-animada .wedding-nav.animation-scrolled {
  box-shadow: 0 10px 34px rgba(17, 20, 18, .08);
}

.version-animada .hero-panel-logo, .version-animada .hero-date-line {
  animation: heroEntrance 1.25s cubic-bezier(.22, .61, .36, 1) both;
}

.version-animada .hero-date-line {
  animation-delay: .18s;
}

.version-animada .hero-centerpiece::before, .version-animada .hero-centerpiece::after {
  animation: lineReveal 1.15s .35s cubic-bezier(.22, .61, .36, 1) both;
}

.version-animada .hero-scroll-note {
  animation: scrollNote 2.4s 1.1s ease-in-out infinite;
}

.version-animada .hero-slide.active img {
  animation: weddingKenBurns 8.6s ease-out both;
}

.version-animada .animate-in {
  opacity: 0;
  transform: translate3d(0, 34px, 0);
  transition: opacity .82s cubic-bezier(.22, .61, .36, 1), transform .82s cubic-bezier(.22, .61, .36, 1);
  transition-delay: var(--animation-delay, 0ms);
  will-change: opacity, transform;
}

.version-animada .animate-in.animation-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.version-animada .animate-left {
  transform: translate3d(-38px, 0, 0);
}

.version-animada .animate-right {
  transform: translate3d(38px, 0, 0);
}

.version-animada .animate-left.animation-visible, .version-animada .animate-right.animation-visible {
  transform: translate3d(0, 0, 0);
}

.version-animada .animate-scale {
  transform: scale(.96);
}

.version-animada .animate-scale.animation-visible {
  transform: scale(1);
}

.version-animada .event-card, .version-animada .travel-card, .version-animada .album-tile, .version-animada .dress-feature, .version-animada .recommendation-grid > div {
  transition: transform .38s cubic-bezier(.22, .61, .36, 1), box-shadow .38s ease, filter .38s ease;
}

.version-animada .event-card:hover, .version-animada .travel-card:hover, .version-animada .dress-feature:hover, .version-animada .recommendation-grid > div:hover {
  transform: translateY(-7px);
}

.version-animada .album-tile img, .version-animada .story-photo-grid img, .version-animada .recommendation-grid img {
  transition: transform .9s cubic-bezier(.22, .61, .36, 1), filter .7s ease;
}

.version-animada .album-tile:hover img, .version-animada .story-photo-grid img:hover, .version-animada .recommendation-grid > div:hover img {
  transform: scale(1.045);
  filter: saturate(1.05);
}

.version-animada .count-box strong {
  transition: transform .26s ease, opacity .26s ease;
}

.version-animada .count-box.count-tick strong {
  animation: numberPulse .42s ease;
}

.version-animada .timeline-item::before {
  transition: transform .4s ease, background-color .4s ease;
}

.version-animada .timeline-item.animation-visible::before {
  animation: timelinePulse 1.2s .25s ease both;
}

.version-animada .faq-accordion .accordion-button::after {
  transition: transform .35s cubic-bezier(.22, .61, .36, 1), background-color .3s ease;
}

.version-animada .faq-accordion .accordion-button:not(.collapsed)::after {
  transform: rotate(45deg);
}

.version-animada .faq-accordion .accordion-collapse {
  transition: height .42s cubic-bezier(.22, .61, .36, 1);
}

.version-animada .btn {
  transition: transform .25s ease, background-color .25s ease, color .25s ease, box-shadow .25s ease;
}

.version-animada .btn:hover {
  transform: translateY(-2px);
}

.version-animada .btn:active {
  transform: translateY(0) scale(.98);
}

.version-animada .rsvp-form .form-control:focus, .version-animada .rsvp-form .form-select:focus {
  transform: translateY(-1px);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.version-animada .gift-envelope {
  animation: envelopeFloat 4.8s ease-in-out infinite;
}

.version-animada .gift-floral span {
  transform-origin: bottom center;
  animation: floralSway 5.2s ease-in-out infinite alternate;
}

.version-animada .gift-floral span:nth-child(2) {
  animation-delay: -.8s;
}

.version-animada .gift-floral span:nth-child(3) {
  animation-delay: -1.6s;
}

@keyframes heroEntrance {
  from {
    opacity: 0;
    transform: translateY(24px) scale(.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes lineReveal {
  from {
    opacity: 0;
    transform: scaleX(0);
  }
  to {
    opacity: 1;
    transform: scaleX(1);
  }
}

@keyframes weddingKenBurns {
  from {
    transform: scale(1.035);
  }
  to {
    transform: scale(1);
  }
}

@keyframes scrollNote {
  0%, 100% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(7px);
  }
}

@keyframes numberPulse {
  0% {
    opacity: .45;
    transform: translateY(-4px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes timelinePulse {
  0% {
    transform: scale(.2);
  }
  70% {
    transform: scale(1.3);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes envelopeFloat {
  0%, 100% {
    transform: translateY(0) rotate(-1deg);
  }
  50% {
    transform: translateY(-9px) rotate(1deg);
  }
}

@keyframes floralSway {
  from {
    transform: rotate(-2deg);
  }
  to {
    transform: rotate(3deg);
  }
}

@keyframes sectionArrival {
  from {
    opacity: .3;
    filter: blur(7px);
    transform: translateY(58px);
  }
  to {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0);
  }
}

@keyframes transitionMarker {
  0%, 100% {
    box-shadow: 0 0 0 6px rgba(111, 127, 103, .08);
  }
  50% {
    box-shadow: 0 0 0 12px rgba(111, 127, 103, 0);
  }
}

@media (max-width: 1199.98px) {
  .version-animada .wedding-nav .navbar-collapse {
    transform-origin: top;
  }
}

@media (max-width: 1199.98px) {
  .version-animada .wedding-nav .navbar-collapse.show {
    animation: menuReveal .36s cubic-bezier(.22, .61, .36, 1) both;
  }
}

@media (max-width: 1199.98px) {
  .version-animada .wedding-nav .navbar-collapse.show .nav-item {
    animation: menuItemReveal .42s cubic-bezier(.22, .61, .36, 1) both;
  }
}

@media (max-width: 1199.98px) {
  .version-animada .wedding-nav .navbar-collapse.show .nav-item:nth-child(2) {
    animation-delay: .035s;
  }
}

@media (max-width: 1199.98px) {
  .version-animada .wedding-nav .navbar-collapse.show .nav-item:nth-child(3) {
    animation-delay: .07s;
  }
}

@media (max-width: 1199.98px) {
  .version-animada .wedding-nav .navbar-collapse.show .nav-item:nth-child(4) {
    animation-delay: .105s;
  }
}

@media (max-width: 1199.98px) {
  .version-animada .wedding-nav .navbar-collapse.show .nav-item:nth-child(5) {
    animation-delay: .14s;
  }
}

@media (max-width: 1199.98px) {
  .version-animada .wedding-nav .navbar-collapse.show .nav-item:nth-child(6) {
    animation-delay: .175s;
  }
}

@media (max-width: 1199.98px) {
  .version-animada .wedding-nav .navbar-collapse.show .nav-item:nth-child(7) {
    animation-delay: .21s;
  }
}

@keyframes menuReveal {
  from {
    opacity: 0;
    transform: translateY(-12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes menuItemReveal {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 575.98px) {
  .version-animada .section-transition {
    width: calc(100% - 2rem);
  }
}

@media (max-width: 575.98px) {
  .version-animada .section-transition::before, .version-animada .section-transition::after {
    width: calc(50% - 10px);
  }
}

@media (max-width: 575.98px) {
  .version-animada .section-transition::before {
    right: calc(50% + 10px);
  }
}

@media (max-width: 575.98px) {
  .version-animada .section-transition::after {
    left: calc(50% + 10px);
  }
}

@media (hover: none) {
  .version-animada .event-card:active, .version-animada .travel-card:active, .version-animada .dress-feature:active, .version-animada .recommendation-grid > div:active {
    transform: scale(.985);
  }
}

@media (prefers-reduced-motion: reduce) {
  .version-animada *, .version-animada *::before, .version-animada *::after {
    scroll-behavior: auto !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .version-animada .animate-in {
    opacity: 1;
    transform: none;
  }
}

