/* Animations and transitions */

/* Carousel fade transition */
.carousel-content {
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.carousel-content.transitioning {
  opacity: 0;
  transform: translateY(10px);
}

/* Modal animations */
.modal-backdrop {
  opacity: 0;
  transition: opacity 0.3s ease;
}

.modal-backdrop.active {
  opacity: 1;
}

.modal-content {
  opacity: 0;
  transform: scale(0.95);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.modal-content.active {
  opacity: 1;
  transform: scale(1);
}

/* Mobile menu slide (below header) */
.mobile-menu {
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.32, 0.72, 0, 1), top 0.3s ease;
}

.mobile-menu.open {
  transform: translateX(0);
}

/* Mobile nav link touch states */
.mobile-nav-link {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: background-color 0.15s ease;
}

/* Dropdown */
.dropdown-menu {
  opacity: 0;
  transform: translateY(-0.5rem);
  visibility: hidden;
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
}

.dropdown-menu.open {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
}

/* Accordion */
.accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-out;
}

.accordion-content.open {
  max-height: 500px;
}

.accordion-icon {
  transition: transform 0.3s ease;
}

.accordion-item.open .accordion-icon {
  transform: rotate(180deg);
}

/* Header scroll effect */
.header {
  transition: background-color 0.5s ease, padding 0.5s ease, border-color 0.5s ease;
}

.header.scrolled {
  background-color: rgba(249, 248, 246, 0.95);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.header.menu-open {
  background-color: #F9F8F6 !important;
}

.header.no-transition,
.header.no-transition * {
  transition: none !important;
}

/* PDF card rotation */
.pdf-card {
  transition: transform 0.5s ease;
}

.pdf-card:hover {
  transform: rotate(0deg) !important;
}

/* Hover scale */
.hover-scale {
  transition: transform 1s ease;
}

.hover-scale:hover {
  transform: scale(1.05);
}

/* Link underline animation */
.link-underline {
  position: relative;
}

.link-underline::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 2px;
  background-color: #C5A992;
  transition: width 0.3s ease;
}

.link-underline:hover::after {
  width: 100%;
}

/* Icon group hover */
.icon-box {
  transition: background-color 0.3s ease;
}

.group:hover .icon-box {
  background-color: #2C2825;
}

.group:hover .icon-box svg {
  color: #F9F8F6;
}

/* Testimonial pagination dots */
.dot {
  transition: width 0.3s ease, background-color 0.3s ease;
}

.dot.active {
  width: 2rem;
  background-color: #C5A992;
}
