/* Infinity Business page styles */

/* Force hero section positioning with maximum specificity */
.sub-page-hero .container-full .sub-hero-content-block {
  padding-bottom: 0px !important;
  margin-bottom: 0px !important;
  justify-content: flex-end !important;
  align-items: flex-end !important;
  display: flex !important;
  flex-direction: column !important;
}

.sub-page-hero .container-full .sub-hero-content-block .sub-hero-desc-block {
  margin-bottom: 0px !important;
  margin-left: 0px !important;
  width: 75% !important;
  max-width: none !important;
  position: absolute !important;
  bottom: 60px !important;
  left: 0px !important;
}

/* Ultra-specific override for left positioning */
.sub-page-hero.background-7-business .container-full .sub-hero-content-block .sub-hero-desc-block {
  left: 0px !important;
  margin-left: 0px !important;
  padding-left: 0px !important;
}

/* Mobile optimization for hero sections */
@media (max-width: 768px) {
  .sub-page-hero .container-full .sub-hero-content-block {
    padding-bottom: 0.1% !important;
  }
  .sub-page-hero .container-full .sub-hero-content-block .sub-hero-desc-block {
    margin-bottom: 0.05% !important;
    margin-left: 0.3% !important;
    width: 90% !important;
  }
  .sub-hero-h1 {
    margin-bottom: 10px !important;
  }
  .sub-hero-h2 {
    margin-bottom: 8px !important;
    font-size: 1.2em !important;
  }
  .sub-page-p-big-white {
    margin-top: 5px !important;
    line-height: 1.3 !important;
  }
}

@media (max-width: 480px) {
  .sub-page-hero .container-full .sub-hero-content-block .sub-hero-desc-block {
    margin-bottom: 0.02% !important;
    margin-left: 0.2% !important;
    width: 95% !important;
  }
  .sub-hero-h1 {
    margin-bottom: 5px !important;
    font-size: 1.8em !important;
  }
  .sub-hero-h2 {
    margin-bottom: 5px !important;
    font-size: 1.1em !important;
  }
  .sub-page-p-big-white {
    margin-top: 3px !important;
    font-size: 0.9em !important;
    line-height: 1.2 !important;
  }
}

/* Ensure sections are full width with no scrolling */
.main-section-2 {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
  overflow-y: visible !important;
}

.main-section-2 .container-full {
  width: 100% !important;
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  overflow-x: hidden !important;
}

.main-section-2 .sub-page-main-focus-block {
  width: 80% !important;
  max-width: 80% !important;
  overflow-x: hidden !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: clamp(16px, 4vw, 40px) !important;
  padding-right: clamp(16px, 4vw, 40px) !important;
}

.main-section-2 .sub-page-main-focus-grid {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
  display: grid !important;
  grid-template-columns: 2fr 3fr !important; /* 2:3 ratio image:text (default - image first) */
  gap: clamp(20px, 4vw, 40px) !important;
  align-items: center !important;
}

/* Custom styling for sections where text comes first (3:2 text:image ratio, image on right) */
.main-section-2 .sub-page-main-focus-grid:has(.sub-focus-grid-text-block:first-child) {
  grid-template-columns: 3fr 2fr !important; /* 3:2 ratio text:image */
}

.main-section-2 .sub-focus-grid-image-block {
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

.main-section-2 .sub-focus-grid-image-block img {
  max-width: 425px !important;
  width: 100% !important;
  height: auto !important;
  display: block !important;
  border-radius: 20px !important;
}

.main-section-2 .sub-focus-grid-text-block {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
  word-wrap: break-word !important;
  overflow-wrap: break-word !important;
}

.main-section-2 .sub-focus-grid-text-block * {
  max-width: 100% !important;
  word-wrap: break-word !important;
  overflow-wrap: break-word !important;
}

/* Business packages section - 80% width on desktop */
.main-section-2 .business-packages-main-block {
  width: 80% !important;
  max-width: 80% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow-x: hidden !important;
  overflow-y: visible !important;
  max-height: none !important;
}

.main-section-2 .business-packages-grid {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
  overflow-y: visible !important;
  max-height: none !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: clamp(24px, 3vh, 40px) !important;
}

.business-packages-grid-title-block {
  width: 100% !important;
  max-width: 100% !important;
  overflow: visible !important;
}

/* Card styling with hover effect - move entire card up */
.business-grid-sub-grid {
  transform: none !important;
  box-shadow: none !important;
  transition: transform 0.3s ease !important;
  border-radius: 20px !important;
  overflow: hidden !important;
  border: 1.5px solid rgba(0, 0, 0, 0.2) !important;
  background-color: #fff !important;
  display: grid !important;
  grid-template-columns: 2fr 3fr !important;
  align-items: stretch !important;
  height: auto !important;
  max-height: none !important;
  min-height: auto !important;
}

.business-grid-sub-grid:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
}

/* Image block - 2:3 ratio, covers full height on desktop */
.business-packages-grid .business-grid-image-block {
  height: 100% !important;
  max-height: none !important;
  min-height: 100% !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  display: flex !important;
  align-items: stretch !important;
  justify-content: stretch !important;
  border-radius: 0 !important;
  overflow: hidden !important;
}

.business-packages-grid .business-grid-image-block a {
  display: flex !important;
  width: 100% !important;
  height: 100% !important;
  align-items: stretch !important;
  flex: 1 1 100% !important;
  max-width: 100% !important;
  border-radius: 0 !important;
}

.business-packages-grid .business-grid-image-block img {
  height: 100% !important;
  width: 100% !important;
  max-width: 100% !important;
  object-fit: cover !important;
  max-height: 100% !important;
  border-radius: 0 !important;
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
  flex: 1 1 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  display: block !important;
}

.business-grid-sub-grid .business-sub-text-block {
  border-radius: 0 0 20px 20px !important;
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
  border-bottom-left-radius: 20px !important;
  border-bottom-right-radius: 20px !important;
  padding-left: clamp(16px, 2vw, 24px) !important;
  padding-right: clamp(16px, 2vw, 24px) !important;
  padding-top: clamp(16px, 2vh, 24px) !important;
  padding-bottom: clamp(16px, 2vh, 24px) !important;
  overflow-x: hidden !important;
  overflow-y: visible !important;
  max-height: none !important;
  height: auto !important;
}

/* Mobile optimizations */
@media (max-width: 991px) {
  .main-section-2 .sub-page-main-focus-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    gap: clamp(20px, 4vh, 32px) !important;
  }
  
  /* Override desktop 3:2 ratio for mobile - force single column */
  .main-section-2 .sub-page-main-focus-grid:has(.sub-focus-grid-text-block:first-child) {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
  }
  
  .main-section-2 .sub-page-main-focus-block {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: clamp(16px, 5vw, 24px) !important;
    padding-right: clamp(16px, 5vw, 24px) !important;
  }
  
  /* On mobile: always show image first, then text (regardless of HTML order) */
  .main-section-2 .sub-focus-grid-image-block {
    order: 1 !important; /* Image always appears first on mobile */
    width: 80% !important;
    max-width: 80% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  
  .main-section-2 .sub-focus-grid-text-block {
    order: 2 !important; /* Text always appears second on mobile */
  }
  
  .main-section-2 .sub-focus-grid-image-block img {
    max-width: 100% !important;
    width: 100% !important;
  }
  
  .main-section-2 .business-packages-main-block {
    width: 100% !important;
    max-width: 100% !important;
  }
  
  /* Mobile: Stack image on top, text below */
  .business-grid-sub-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
  }
  
  .business-grid-sub-grid .business-grid-image-block {
    order: 1 !important;
    height: auto !important;
    min-height: auto !important;
  }
  
  .business-grid-sub-grid .business-sub-text-block {
    order: 2 !important;
    border-radius: 0 0 20px 20px !important;
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
  }
  
  .business-grid-sub-grid .business-grid-image-block img {
    height: auto !important;
    max-height: none !important;
    border-radius: 20px 20px 0 0 !important;
    border-top-left-radius: 20px !important;
    border-top-right-radius: 20px !important;
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
  }
}

@media (max-width: 768px) {
  .main-section-2 {
    padding-top: clamp(40px, 8vh, 60px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
  }
  
  .main-section-2 .sub-page-main-focus-block {
    padding-left: clamp(16px, 4vw, 20px) !important;
    padding-right: clamp(16px, 4vw, 20px) !important;
  }
  
  .main-section-2 .sub-page-main-focus-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    gap: clamp(16px, 3vh, 24px) !important;
  }
  
  /* Override desktop 3:2 ratio for mobile - force single column */
  .main-section-2 .sub-page-main-focus-grid:has(.sub-focus-grid-text-block:first-child) {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
  }
  
  .main-section-2 .sub-focus-grid-image-block {
    order: 1 !important; /* Image always appears first on mobile */
    width: 80% !important;
    max-width: 80% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  
  .main-section-2 .sub-focus-grid-text-block {
    order: 2 !important; /* Text always appears second on mobile */
  }
  
  .main-section-2 .sub-focus-grid-image-block img {
    max-width: 100% !important;
    width: 100% !important;
  }
}

@media (max-width: 480px) {
  .main-section-2 {
    padding-top: clamp(32px, 6vh, 48px) !important;
    padding-bottom: clamp(32px, 6vh, 48px) !important;
  }
  
  .main-section-2 .sub-page-main-focus-block {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  
  .main-section-2 .sub-page-main-focus-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    gap: 16px !important;
  }
  
  /* Override desktop 3:2 ratio for mobile - force single column */
  .main-section-2 .sub-page-main-focus-grid:has(.sub-focus-grid-text-block:first-child) {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
  }
  
  .main-section-2 .sub-focus-grid-image-block {
    order: 1 !important; /* Image always appears first on mobile */
    width: 80% !important;
    max-width: 80% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  
  .main-section-2 .sub-focus-grid-text-block {
    order: 2 !important; /* Text always appears second on mobile */
  }
  
  .main-section-2 .sub-focus-grid-image-block img {
    max-width: 100% !important;
    width: 100% !important;
  }
}