/* Custom fixes for navbar and mobile optimization */

/* FIX BROKEN ICONS */
.button-icon {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  font-size: 1.2rem !important;
  color: inherit !important;
}

.star-icon {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  font-size: 1rem !important;
  color: #FFD700 !important;
}

/* FAQ ACCORDION FIXES */
.faq_answer {
  overflow: hidden !important;
  max-height: 0 !important;
  transition: max-height 0.3s ease-out !important;
}

.faq_accordion.w--open .faq_answer {
  max-height: 500px !important;
  transition: max-height 0.3s ease-in !important;
}

.faq_question {
  cursor: pointer !important;
}

.faq_question:hover {
  background: rgba(255, 215, 0, 0.05) !important;
}

.faq_icon_wrappper {
  transition: transform 0.3s ease !important;
}

.faq_accordion.w--open .faq_icon_wrappper {
  transform: rotate(45deg) !important;
}

/* Fix testimonials display - Match Webflow export */
.testimonial_text {
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
  color: #fff !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
  margin-top: 20px !important;
  margin-bottom: 20px !important;
  font-style: normal !important; /* Remove italic */
}

.testimonial_slide {
  opacity: 1 !important;
  visibility: visible !important;
  display: inline-block !important;
  vertical-align: top !important;
  width: auto !important;
}

.testimonial_content-top {
  opacity: 1 !important;
  visibility: visible !important;
}

.testimonial_slider {
  display: flex !important;
  gap: 20px !important;
  overflow-x: auto !important;
  scroll-behavior: smooth !important;
}

.testimonial_slide .card {
  opacity: 1 !important;
  visibility: visible !important;
  background: rgba(255, 255, 255, 0.03) !important;
  padding: 30px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  min-width: 350px !important;
  max-width: 400px !important;
  height: 100% !important;
}

/* Ensure stars display properly */
.stars-wrapper {
  display: flex !important;
  gap: 4px !important;
  margin-bottom: 15px !important;
}

/* COMPLETELY REBUILT DROPDOWN SYSTEM */

/* Desktop only */
@media (min-width: 992px) {
  /* Dropdown parent positioning */
  .navbar_menu-dropdown.w-dropdown {
    position: relative !important;
  }
  
  /* Extend hover area below the toggle to prevent flicker when moving into the menu */
  .navbar_menu-dropdown.w-dropdown::after {
    content: '' !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    top: 100% !important;
    height: 16px !important; /* Buffer area between toggle and dropdown list */
  }
  
  /* Reset and hide dropdown by default */
  .w-dropdown-list,
  nav.w-dropdown-list {
    position: absolute !important;
    top: 100% !important; /* Remove vertical gap so cursor doesn't leave hover area */
    left: 0 !important;
    min-width: 220px !important;
    
    /* Background and appearance */
    background-color: #1a1a1a !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 8px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5) !important;
    
    /* Spacing - MASSIVE bottom padding AND margin */
    padding: 12px 0 40px 0 !important;
    margin: 0 0 50px 0 !important;
    
    /* Display control */
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    
    /* Z-index */
    z-index: 99999 !important;
    
    /* Remove ALL size constraints */
    max-height: none !important;
    min-height: 0 !important;
    height: auto !important;
    width: auto !important;
    max-width: none !important;
    min-width: 220px !important;
    
    /* Force dropdown to render on own layer */
    transform: translate3d(0, 0, 0) !important;
    will-change: transform, opacity !important;
    backface-visibility: hidden !important;
    
    /* Force container to respect children */
    box-sizing: content-box !important;
    
    /* NUCLEAR OPTION - No clipping whatsoever */
    overflow: visible !important;
    overflow-y: visible !important;
    overflow-x: visible !important;
    clip-path: none !important;
    clip: auto !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
    
    /* Force layout */
    contain: none !important;
    isolation: auto !important;
  }
  
  /* Show dropdown on hover/open */
  .navbar_menu-dropdown:hover .w-dropdown-list,
  .navbar_menu-dropdown:hover nav.w-dropdown-list,
  .w-dropdown.w--open .w-dropdown-list,
  .w-dropdown.w--open nav.w-dropdown-list {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
  
  /* Fix hover transition to keep dropdown accessible */
  .navbar_menu-dropdown:hover {
    pointer-events: auto !important;
  }
  
  /* Dropdown links */
  .dropdown-link,
  .w-dropdown-link {
    display: block !important;
    padding: 12px 24px !important;
    color: #ffffff !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    transition: background-color 0.2s ease !important;
    background-color: transparent !important;
  }
  
  .dropdown-link:hover,
  .w-dropdown-link:hover {
    background-color: rgba(255, 255, 255, 0.1) !important;
  }
  
  /* Ensure all links have proper spacing */
  .w-dropdown-list .dropdown-link,
  .w-dropdown-list .w-dropdown-link,
  nav.w-dropdown-list .dropdown-link,
  nav.w-dropdown-list .w-dropdown-link {
    margin: 0 !important;
  }
  
  /* CRITICAL: Last link needs extra bottom padding to show background */
  .w-dropdown-list a:last-child,
  nav.w-dropdown-list a:last-child,
  .w-dropdown-list .dropdown-link:last-of-type,
  .w-dropdown-list .w-dropdown-link:last-of-type {
    padding-bottom: 18px !important;
  }
  
  /* Add pseudo-element to extend background below last item */
  .w-dropdown-list::after,
  nav.w-dropdown-list::after {
    content: '' !important;
    display: block !important;
    height: 6px !important;
    width: 100% !important;
    flex-shrink: 0 !important;
  }
  
  /* ULTRA-SPECIFIC: Target the exact Services dropdown structure */
  .navbar_menu-dropdown.w-dropdown > nav.w-dropdown-list,
  div[data-hover="false"] > nav.w-dropdown-list {
    padding-bottom: 20px !important;
    padding-top: 12px !important;
  }
  
  /* ULTRA-SPECIFIC: Target last link in Services dropdown */
  .navbar_menu-dropdown.w-dropdown > nav.w-dropdown-list > a:last-child,
  div[data-hover="false"] > nav.w-dropdown-list > a.w-dropdown-link:last-child {
    padding-bottom: 20px !important;
    margin-bottom: 0 !important;
  }
}

/* Fix appearance property for compatibility */
* {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -o-font-smoothing: antialiased;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none; /* Standard property */
}

/* Dropdown arrow icon - Override Webflow icon font */
.nav-link-icon {
  width: 12px !important;
  height: 12px !important;
  margin-left: 6px !important;
  display: inline-block !important;
  position: relative !important;
  font-family: inherit !important; /* Override Webflow icon font */
  font-size: 0 !important; /* Hide any text content */
}

.nav-link-icon::before {
  content: '' !important; /* Clear any icon font content */
}

.nav-link-icon::after {
  content: '' !important;
  display: block !important;
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid currentColor;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: transform 0.3s ease;
}

/* Rotate arrow when dropdown is open */
.w--open .nav-link-icon::after {
  transform: translate(-50%, -50%) rotate(180deg);
}

/* Ensure mobile menu is hidden by default */
@media (max-width: 991px) {
  .navbar_menu {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.95);
    padding-top: 80px;
    transform: translateY(-100%);
    opacity: 0;
    visibility: hidden;
    transition: transform 0.3s ease, opacity 0.3s ease, visibility 0.3s ease;
  }
  
  .navbar_menu.w--open {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
  }
}

/* Old dropdown code removed - using rebuilt system above */

/* Mobile menu button animation */
.navbar_menu-button {
  cursor: pointer;
  z-index: 1000;
  pointer-events: auto !important;
}

.menu-icon2 {
  position: relative;
  width: 24px;
  height: 18px;
  pointer-events: auto !important;
}

.menu-icon2_line-top,
.menu-icon2_line-middle,
.menu-icon2_line-bottom {
  width: 100%;
  height: 2px;
  background: #fff;
  position: absolute;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.menu-icon2_line-top {
  top: 0;
}

.menu-icon2_line-middle {
  top: 50%;
  transform: translateY(-50%);
}

.menu-icon2_line-bottom {
  bottom: 0;
}

/* Animate hamburger to X when open */
.w--open .menu-icon2_line-top {
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.w--open .menu-icon2_line-middle {
  opacity: 0;
}

.w--open .menu-icon2_line-bottom {
  bottom: 50%;
  transform: translateY(50%) rotate(-45deg);
}

/* Ensure navbar overlays do not block interaction */
.navbar_blur {
  pointer-events: none !important;
}

/* STICKY NAVBAR FIX */
.navbar_component {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 9999 !important;
  width: 100% !important;
  background: rgba(0, 0, 0, 0.95) !important;
  backdrop-filter: blur(10px) !important;
  transition: all 0.3s ease !important;
  overflow: visible !important;
  contain: none !important;
  min-height: 4rem !important; /* Match Webflow original */
}

/* Ensure navbar container doesn't clip dropdowns */
.navbar_container {
  overflow: visible !important;
}

.navbar_menu {
  overflow: visible !important;
}

/* Fix all potential clipping containers */
.nav-menu,
.navbar_menu-left,
.navbar_menu-right,
.navbar_nav-menu-wrapper,
.w-nav-menu {
  overflow: visible !important;
}

/* Ensure dropdown parents don't clip */
.navbar_menu-dropdown,
.navbar_menu-dropdown.w-dropdown,
.w-dropdown {
  overflow: visible !important;
}

/* Webflow nav containers */
.w-nav {
  overflow: visible !important;
}

/* CRITICAL: Ensure the toggle wrapper doesn't clip */
.w-dropdown-toggle,
.navbar_link-wrapper,
.navbar_component,
.navbar_component.mobile,
.page-wrapper {
  overflow: visible !important;
}

/* The navbar itself must not clip */
.navbar_component.mobile.w-nav[data-animation],
.navbar_component[data-animation] {
  overflow: visible !important;
}

/* Add body padding for fixed navbar - matches Webflow 4rem navbar */
body {
  padding-top: 4rem !important;
}

/* Contact Us button - prevent text wrapping */
.button.see-plans {
  white-space: nowrap !important;
  min-width: auto !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}

.button.see-plans .text-block-4,
.button.see-plans .is-secondary {
  white-space: nowrap !important;
  display: inline-block !important;
}

/* ===== ENHANCED MOBILE OPTIMIZATION ===== */

/* Touch-friendly button sizes (minimum 44px as per iOS guidelines) */
button,
.button,
.w-button,
a[class*="button"],
.navbar_menu-button {
  min-height: 44px;
  min-width: 44px;
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(253, 185, 19, 0.2);
}

/* Prevent text selection on buttons and interactive elements */
button,
.button,
.w-button,
.navbar_menu-button,
.dropdown-link {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* Smooth momentum scrolling on iOS */
body,
.navbar_menu {
  -webkit-overflow-scrolling: touch;
}

/* Prevent zoom on input focus (iOS) */
@media (max-width: 991px) {
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="number"],
  textarea {
    font-size: 16px !important;
  }
}

/* Mobile navigation improvements */
@media (max-width: 991px) {
  /* Add safe area padding for notched devices */
  .navbar_component {
    padding-top: env(safe-area-inset-top);
  }
  
  /* CRITICAL: Hide Contact Us button on mobile, show hamburger */
  .navbar_button-wrapper .button,
  .navbar_button-wrapper .nav-cta,
  .navbar_button-wrapper .w-button {
    display: none !important;
  }
  
  /* Ensure hamburger menu button is visible */
  .navbar_menu-button,
  .w-nav-button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    cursor: pointer !important;
  }
  
  /* Fix hamburger icon lines - FORCE WHITE COLOR */
  .menu-icon2 {
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    width: 24px !important;
    height: 18px !important;
  }
  
  .menu-icon2_line-top,
  .menu-icon2_line-middle,
  .menu-icon2_line-bottom,
  .w-nav-button .menu-icon2_line-top,
  .w-nav-button .menu-icon2_line-middle,
  .w-nav-button .menu-icon2_line-bottom,
  .navbar_menu-button .menu-icon2_line-top,
  .navbar_menu-button .menu-icon2_line-middle,
  .navbar_menu-button .menu-icon2_line-bottom {
    display: block !important;
    width: 24px !important;
    height: 2px !important;
    background: #ffffff !important;
    background-color: #ffffff !important;
    position: relative !important;
  }
  
  .menu-icon2_line-middle-inner {
    display: none !important;
  }
  
  .navbar_menu {
    padding-top: calc(80px + env(safe-area-inset-top));
    padding-bottom: env(safe-area-inset-bottom);
    max-height: 100vh;
    max-height: 100dvh; /* Dynamic viewport height for mobile browsers */
    overflow-y: auto;
  }
  
  /* Larger tap targets for mobile menu items */
  .nav-link {
    padding: 16px 20px;
    display: block;
  }
  
  /* Better mobile dropdown behavior */
  .navbar_menu-dropdown {
    width: 100%;
  }
  
  .w-dropdown-list,
  nav.w-dropdown-list {
    position: static !important;
    width: 100% !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding-left: 20px !important;
    min-height: 0 !important;
  }
}

/* Tablet optimizations */
@media (min-width: 768px) and (max-width: 991px) {
  .navbar_menu {
    max-width: 400px;
    right: 0;
    left: auto;
  }
}

/* Performance optimizations */
.navbar_menu,
.w-dropdown-list,
.menu-icon2_line-top,
.menu-icon2_line-middle,
.menu-icon2_line-bottom {
  will-change: transform, opacity;
  transform: translateZ(0);
  backface-visibility: hidden;
}

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  .button,
  .dropdown-link {
    border: 2px solid currentColor;
  }
}

/* Dark mode support (if needed in future) */
@media (prefers-color-scheme: dark) {
  /* Already using dark theme, but this ensures proper system integration */
  body {
    color-scheme: dark;
  }
}

/* Image optimization for mobile */
@media (max-width: 991px) {
  img {
    max-width: 100%;
    height: auto;
  }
}

/* Horizontal scroll prevention */
* {
  max-width: 100%;
}

html {
  overflow-x: hidden;
}

/* Focus styles for accessibility */
a:focus,
button:focus,
input:focus,
textarea:focus,
select:focus {
  outline: 2px solid #FDB913;
  outline-offset: 2px;
}

/* Focus visible (modern browsers) */
a:focus-visible,
button:focus-visible,
input:focus-visible {
  outline: 2px solid #FDB913;
  outline-offset: 2px;
}

/* Remove outline for mouse users */
a:focus:not(:focus-visible),
button:focus:not(:focus-visible) {
  outline: none;
}

/* ===== SCROLL ANIMATIONS ===== */

/* Remove Webflow animation styles - let Webflow handle its own animations */
/* DO NOT force override data-w-id elements */

/* Only apply to elements without inline animation styles */
.animate-on-scroll:not([data-w-id]):not([style*="opacity"]) {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.animate-on-scroll.animated {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* Specific animation delays for staggered effects */
.animate-on-scroll:nth-child(1) {
  transition-delay: 0.1s;
}

.animate-on-scroll:nth-child(2) {
  transition-delay: 0.2s;
}

.animate-on-scroll:nth-child(3) {
  transition-delay: 0.3s;
}

.animate-on-scroll:nth-child(4) {
  transition-delay: 0.4s;
}

/* Fade in from left */
.animate-fade-left:not([data-w-id]):not([style*="opacity"]) {
  opacity: 0;
  transform: translateX(-50px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.animate-fade-left.animated {
  opacity: 1 !important;
  transform: translateX(0) !important;
}

/* Fade in from right */
.animate-fade-right:not([data-w-id]):not([style*="opacity"]) {
  opacity: 0;
  transform: translateX(50px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.animate-fade-right.animated {
  opacity: 1 !important;
  transform: translateX(0) !important;
}

/* Fade in with scale */
.animate-scale:not([data-w-id]):not([style*="opacity"]) {
  opacity: 0;
  transform: scale(0.9);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.animate-scale.animated {
  opacity: 1 !important;
  transform: scale(1) !important;
}

/* Star rating icons - Show filled black stars like real site */
.star-icon {
  width: 18px !important;
  height: 18px !important;
  display: inline-block !important;
  position: relative !important;
  margin: 0 1px !important;
  font-family: Arial, sans-serif !important;
  font-size: 0 !important;
  line-height: 1 !important;
}

.star-icon::after {
  content: '★' !important;
  color: #fff !important;
  font-size: 18px !important;
  line-height: 1 !important;
  display: block !important;
  text-align: center !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  font-family: Arial, Helvetica, sans-serif !important;
}

.star-wrapper {
  display: inline-block !important;
  vertical-align: middle !important;
}

.stars-wrapper {
  display: flex !important;
  align-items: center !important;
  gap: 2px !important;
}

/* Respect reduced motion preferences */
@media (prefers-reduced-motion: reduce) {
  .animate-on-scroll,
  .animate-fade-left,
  .animate-fade-right,
  .animate-scale {
    opacity: 1 !important;
    transform: none !important;
    transition: none;
  }
}

/* ===== COMPREHENSIVE MOBILE OPTIMIZATION ===== */

/* Mobile content spacing */
@media (max-width: 767px) {
  /* Reduce section padding on mobile */
  .h1-wintir-header,
  section {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }
  
  /* Reduce container padding */
  .container,
  .w-container {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  
  /* Mobile typography */
  .heading-style-h1,
  h1 {
    font-size: 2rem !important;
    line-height: 1.2 !important;
  }
  
  .heading-style-h2,
  h2 {
    font-size: 1.75rem !important;
    line-height: 1.3 !important;
  }
  
  .heading-style-h3,
  h3 {
    font-size: 1.25rem !important;
    line-height: 1.4 !important;
  }
  
  /* Mobile paragraph text */
  p,
  .text-color-secondary,
  .text-section-paragraph {
    font-size: 1rem !important;
    line-height: 1.6 !important;
  }
  
  /* Stack grids on mobile */
  ._2-grid,
  ._3-grid,
  ._4-grid,
  ._1-2-grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  
  /* Full width cards on mobile */
  .card {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  
  /* Mobile buttons - full width */
  .button-group {
    flex-direction: column !important;
    width: 100% !important;
  }
  
  .button-group .button {
    width: 100% !important;
    text-align: center !important;
    justify-content: center !important;
  }
  
  /* Hero section mobile */
  .hero-section,
  .header_component {
    min-height: auto !important;
    padding-top: 80px !important;
    padding-bottom: 60px !important;
  }
  
  /* Mobile-friendly spacing */
  .margin-bottom {
    margin-bottom: 16px !important;
  }
  
  .margin-bottom.margin-large {
    margin-bottom: 32px !important;
  }
  
  /* FAQ accordion mobile */
  .faq_question {
    padding: 16px !important;
  }
  
  .faq_answer {
    padding: 0 16px 16px 16px !important;
  }
  
  /* Blog cards mobile */
  .blog_image-wrapper {
    height: 200px !important;
  }
  
  .blog_card-content {
    padding: 16px !important;
  }
  
  /* Footer mobile */
  .footer-grid {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }
  
  .footer-link-column {
    margin-bottom: 24px !important;
  }
  
  /* Contact form mobile */
  .form-field-wrapper {
    flex-direction: column !important;
  }
  
  .form-field-wrapper .form-field {
    width: 100% !important;
  }
  
  /* Pricing cards mobile */
  .pricing-card {
    width: 100% !important;
    margin-bottom: 20px !important;
  }
  
  /* Testimonial slider mobile */
  .testimonial_slide .card {
    min-width: 280px !important;
    max-width: 100% !important;
  }
}

/* Small mobile (phones) */
@media (max-width: 479px) {
  .heading-style-h1,
  h1 {
    font-size: 1.75rem !important;
  }
  
  .heading-style-h2,
  h2 {
    font-size: 1.5rem !important;
  }
  
  .container,
  .w-container {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  
  /* Smaller buttons on very small screens */
  .button {
    padding: 12px 20px !important;
    font-size: 0.9rem !important;
  }
}
