/* ========================================
   Kavani Paraglider Landing Page Styles - v2
   ======================================== */

/* === Animations === */
@keyframes fade-in-up {
  0% { opacity: 0; transform: translateY(30px); }
  100% { opacity: 1; transform: translateY(0); }
}

.animate-fade-in-up {
  opacity: 0;
  animation: fade-in-up 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.delay-100 { animation-delay: 0.1s; }
.delay-200 { animation-delay: 0.2s; }
.delay-300 { animation-delay: 0.3s; }
.delay-500 { animation-delay: 0.5s; }

@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-15px); }
}

.animate-float {
  animation: float 6s ease-in-out infinite;
}

.pg-hero-badge {
    animation: fade-in-up 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* === Gravity Forms Style Override === */
#pg-gravity-form-wrapper .gform_wrapper {
  margin: 0 !important;
  padding: 0 !important;
}

#pg-gravity-form-wrapper .gform_wrapper .gform_body {
  padding: 0 !important;
}

#pg-gravity-form-wrapper .gform_wrapper .gfield {
  margin-bottom: 1.25rem !important;
}

#pg-gravity-form-wrapper .gform_wrapper .gfield_label {
  font-family: "Yekan Bakh", sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: #000 !important;
  margin-bottom: 0.5rem !important;
}

#pg-gravity-form-wrapper .gform_wrapper input[type="text"],
#pg-gravity-form-wrapper .gform_wrapper input[type="email"],
#pg-gravity-form-wrapper .gform_wrapper input[type="tel"],
#pg-gravity-form-wrapper .gform_wrapper input[type="number"],
#pg-gravity-form-wrapper .gform_wrapper select,
#pg-gravity-form-wrapper .gform_wrapper textarea {
  font-family: "Yekan Bakh", sans-serif !important;
  width: 100% !important;
  height: 3.25rem !important;
  padding: 0 1rem !important;
  border: 1px solid var(--color-secondary-20, #E9E9E9) !important;
  border-radius: 0.75rem !important;
  background-color: var(--color-secondary-6, #f7f7f7) !important;
  font-size: 0.875rem !important;
  color: #000 !important;
  outline: none !important;
  transition: all 0.3s ease !important;
  direction: rtl !important;
}

#pg-gravity-form-wrapper .gform_wrapper input:focus,
#pg-gravity-form-wrapper .gform_wrapper select:focus,
#pg-gravity-form-wrapper .gform_wrapper textarea:focus {
  border-color: var(--color-primary, #fd4718) !important;
  box-shadow: 0 0 0 3px rgba(253, 71, 24, 0.1) !important;
  background-color: #fff !important;
}

#pg-gravity-form-wrapper .gform_wrapper .gfield_error input,
#pg-gravity-form-wrapper .gform_wrapper .gfield_error select,
#pg-gravity-form-wrapper .gform_wrapper .gfield_error textarea {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1) !important;
}

#pg-gravity-form-wrapper .gform_wrapper .validation_message {
  font-family: "Yekan Bakh", sans-serif !important;
  font-size: 0.75rem !important;
  color: #ef4444 !important;
  margin-top: 0.25rem !important;
}

#pg-gravity-form-wrapper .gform_wrapper .gform_footer,
#pg-gravity-form-wrapper .gform_wrapper .gform_page_footer {
  padding: 1rem 0 0 !important;
  margin: 0 !important;
}

#pg-gravity-form-wrapper .gform_wrapper .gform_footer input[type="submit"],
#pg-gravity-form-wrapper .gform_wrapper .gform_button {
  font-family: "Anjoman", "Yekan Bakh", sans-serif !important;
  width: 100% !important;
  height: 3.25rem !important;
  background-color: var(--color-primary, #fd4718) !important;
  color: #fff !important;
  border: 2px solid var(--color-primary, #fd4718) !important;
  border-radius: 0.75rem !important;
  font-size: 0.9375rem !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
}

#pg-gravity-form-wrapper .gform_wrapper .gform_footer input[type="submit"]:hover,
#pg-gravity-form-wrapper .gform_wrapper .gform_button:hover {
  background-color: rgba(253, 71, 24, 0.9) !important;
  box-shadow: 0 8px 24px rgba(253, 71, 24, 0.3) !important;
  transform: translateY(-1px) !important;
}

/* Gravity Forms confirmation */
#pg-gravity-form-wrapper .gform_confirmation_wrapper {
  text-align: center !important;
  padding: 2rem !important;
}

#pg-gravity-form-wrapper .gform_confirmation_message {
  font-family: "Yekan Bakh", sans-serif !important;
  font-size: 0.9375rem !important;
  font-weight: 500 !important;
  color: var(--color-success, #3c7147) !important;
  background-color: rgba(60, 113, 71, 0.05) !important;
  border: 1px solid rgba(60, 113, 71, 0.15) !important;
  border-radius: 1rem !important;
  padding: 1.5rem !important;
  line-height: 1.8 !important;
}

/* Gravity Forms 2-column layout */
#pg-gravity-form-wrapper .gform_wrapper .gform_fields {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 0 1rem !important;
}

@media (min-width: 640px) {
  #pg-gravity-form-wrapper .gform_wrapper .gform_fields {
    grid-template-columns: 1fr 1fr !important;
  }
  
  #pg-gravity-form-wrapper .gform_wrapper .gfield--width-full {
    grid-column: 1 / -1 !important;
  }
}

/* === FAQ Accordion === */
.pg-faq-item.active {
  border-color: rgba(253, 71, 24, 0.2);
  box-shadow: 0 4px 24px rgba(253, 71, 24, 0.05);
}

.pg-faq-item.active .pg-faq-icon {
  background-color: var(--color-primary, #fd4718);
  transform: rotate(180deg);
}

.pg-faq-item.active .pg-faq-icon svg {
  color: #fff;
}

.pg-faq-item .pg-faq-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease, padding 0.35s ease;
}

.pg-faq-item.active .pg-faq-content {
  display: block;
  max-height: 500px;
}

/* === Smooth Scroll === */
html {
  scroll-behavior: smooth;
}

/* === CTA Button Pulse === */
.pg-cta-btn {
  position: relative;
}

.pg-cta-btn::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: inherit;
  background: var(--color-primary, #fd4718);
  opacity: 0;
  z-index: -1;
  animation: pg-pulse 2s ease-in-out infinite;
}

@keyframes pg-pulse {
  0%, 100% { opacity: 0; transform: scale(1); }
  50% { opacity: 0.15; transform: scale(1.04); }
}

/* === Step Cards Connector Line (Desktop) === */
@media (min-width: 1024px) {
  .pg-step-card:not(:last-child)::after {
    content: '';
    position: absolute;
    top: 2.5rem;
    left: -1rem;
    width: 2rem;
    height: 2px;
    background: linear-gradient(to left, var(--color-secondary-20, #E9E9E9), var(--color-primary, #fd4718));
    opacity: 0.4;
  }
}

/* === Image Placeholder Fallback === */
.pg-img-placeholder {
  background: linear-gradient(135deg, rgba(253, 71, 24, 0.08), rgba(253, 71, 24, 0.03));
  display: flex;
  align-items: center;
  justify-content: center;
}

/* === Gravity Forms Spinner Override === */
#pg-gravity-form-wrapper .gform_ajax_spinner {
  display: inline-block !important;
  width: 1.5rem !important;
  height: 1.5rem !important;
  margin-right: 0.5rem !important;
}

/* === Header Override for Paraglider Landing (Dark Mode) === */

/* Menu Items */
.page-id-18367 header .menu > li > a {
    color: #fff !important;
}

/* Search Icon */
.page-id-18367 header #header-search-toggle {
    color: #fff !important;
}

/* Cart Icon */
.page-id-18367 header .link-cart,
.page-id-18367 header button[data-open="#cart-mobile"] {
    color: #fff !important;
}

/* Auth/User Button */
.page-id-18367 header .link-auth {
    color: #fff !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
}

.page-id-18367 header .link-auth:hover {
    background-color: #fff !important;
    color: #000 !important;
    border-color: #fff !important;
}

/* Mobile Menu Toggle */
.page-id-18367 header .btn-nav {
    color: #fff !important;
    border-color: rgba(255, 255, 255, 0.3) !important;
}

.page-id-18367 header .btn-nav:hover {
    background-color: #fff !important;
    color: #000 !important;
    border-color: #fff !important;
}

/* === FAQ Accordion === */
.pg-faq-item {
    transition: all 0.3s ease;
}

.pg-faq-item.active {
    border-color: var(--color-primary, #fd4718) !important;
    box-shadow: 0 4px 20px rgba(253, 71, 24, 0.1);
}

.pg-faq-item.active .pg-faq-icon {
    background-color: var(--color-primary, #fd4718);
    color: #fff;
}

.pg-faq-content {
    will-change: max-height, padding-bottom;
}
