/* Cart page layout */
.cart-grid { margin-top: 20px; }
.cart-row { display:grid; grid-template-columns: 1fr 140px 120px 140px; gap:14px; align-items:center; padding:12px 0; border-bottom:1px solid #e5e7eb; }
.cart-col-price, .cart-col-qty, .cart-col-total { text-align: right; }
.cart-head { font-weight:700; border-bottom:2px solid #cbd5e1; }
.cart-col-item .cart-item { display:flex; gap:12px; align-items:center; }
.cart-item img { width:80px; height:80px; object-fit:cover; border-radius:8px; }
.cart-name { font-weight:600; }
.cart-remove { font-size:12px; color:#6b7280; text-decoration:underline; }
.cart-col-qty { display:flex; align-items:center; gap:6px; justify-content:flex-end; }
.qty-box { border:1px solid #1f2937; border-radius:10px; padding:0; gap:0; display:inline-grid; grid-template-columns: 12px 28px 10px; align-items: stretch; justify-items: stretch; justify-self: end; height: 40px; }
.qty-box .cart-qty { width:100%; height:100%; border:0; background:transparent; color:#1f2937; font-size:16px; cursor:pointer; line-height:1; display:flex; align-items:center; justify-content:center; margin:0; padding:0; -webkit-appearance:none; appearance:none; }
.qty-box .cart-qty.dec { color:#9ca3af; justify-content:flex-start; padding-left:0; grid-column: 1; }
.qty-box .cart-qty.inc { color:#1f2937; justify-content:flex-end; padding-right:0; width:100%; min-width:0; grid-column: 3; }
.qty-box .cart-qty-input { width:18px; text-align:center; border:0; height:100%; font-size:16px; background:transparent; margin:0; grid-column: 2; justify-self: start; }
.qty-box .cart-qty-input::-webkit-outer-spin-button,
.qty-box .cart-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.qty-box .cart-qty-input[type=number] { appearance: textfield; -moz-appearance: textfield; }
.cart-summary { margin-top: 28px; padding: 8px 0 4px; display:flex; flex-direction:column; gap:16px; align-items:stretch; }
.cart-summary-line { display:flex; justify-content:space-between; gap:30px; width:100%; max-width: 760px; color:#1f2937; margin-left:auto; }
.cart-summary-line span:last-child { min-width:140px; text-align:right; }
.cart-summary-line span:first-child { font-size:16px; font-weight:400; }
.cart-summary-line span:last-child { font-size:16px; font-weight:400; }
.cart-summary-total { display:flex; justify-content:space-between; gap:30px; width:100%; max-width: 760px; margin-top:28px; margin-left:auto; }
.cart-summary-total span:last-child { min-width:140px; text-align:right; }
.cart-summary-total span:first-child { font-size:24px; font-weight:800; }
.cart-summary-total span:last-child { font-size:24px; font-weight:800; }
.cart-actions { margin-top:28px; display:grid; grid-template-columns: 1fr 1fr; gap:18px; max-width: 760px; margin-left:auto; }
.cart-actions .w-button, .cart-actions .product-button-block { width:100% !important; display:block; text-align:center; padding:18px 20px; appearance: none; -webkit-appearance: none; }
.cart-actions .product-button-block h1 { font-size:18px !important; line-height:24px !important; margin:0 !important; }
@media (max-width: 767px){ .cart-row { grid-template-columns: 1fr 90px 120px 100px; } }

/* Two-column layout like reference */
.cart-two-col { display:block; }
.cart-right { width:min(500px, 100%); margin-left:auto; margin-top:16px; }
.cart-info-cards { display:grid; grid-template-columns: repeat(3,1fr); gap:20px; margin-top:24px; }
.cart-info-card { border:1px solid #e5e7eb; border-radius:12px; padding:16px; background:#fff; }
.cart-info-title { font-weight:700; margin-bottom:8px; }
.cart-info-text { color:#374151; margin-bottom:10px; }
.cart-info-link { font-size:12px; text-decoration:underline; color:#374151; }
@media (max-width: 991px){ .cart-info-cards { grid-template-columns: 1fr; } }
/* Full-width Instagram embed on homepage */
.instagram-media { max-width: 980px !important; width: 100% !important; min-width: 0 !important; margin: 0 auto !important; border-radius: 12px !important; box-shadow: 0 6px 20px rgba(0,0,0,.08) !important; }
.instagram-media > div { padding: 0 !important; }
/* Shop: lightweight cart UI */
.shop-cart-fab { position: fixed; right: 18px; bottom: 18px; width: 56px; height: 56px; border-radius: 50%; background:#3D688E; color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 6px 18px rgba(0,0,0,.2); z-index: 50; cursor:pointer; }
.shop-cart-fab span { font-weight:700; font-size:14px; }
.shop-cart-drawer { position: fixed; right: 0; top:0; bottom:0; width: 360px; max-width: 90vw; background:#fff; box-shadow: -10px 0 24px rgba(0,0,0,.15); transform: translateX(100%); transition: transform .25s ease; z-index: 60; display:flex; flex-direction:column; }
.shop-cart-drawer.is-open { transform: translateX(0); }
.shop-cart-header { display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid #e5e7eb; }
.shop-cart-list { flex:1; overflow:auto; padding: 8px 16px; }
.shop-cart-item { display:flex; gap:10px; align-items:center; padding:8px 0; border-bottom:1px solid #f1f5f9; }
.shop-cart-item img { width:48px; height:48px; border-radius:8px; object-fit:cover; }
.shop-cart-footer { padding: 12px 16px; border-top:1px solid #e5e7eb; }
.shop-cart-total { font-weight:700; margin-bottom:10px; }
.add-cart-btn { margin-top:8px; background:#e5eff6; color:#1e3a5f; border:1px solid #c6d5e4; border-radius:10px; padding:8px 10px; cursor:pointer; }
/* Login/Password images: rounded corners for login-section.webp */
.login-image-block img { border-radius: 24px !important; }
/* Shop: make Purchase buttons match footer color (#3D688E) */
.products-grid .products-grid-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

/* Decrease font size and left-align small descriptions on shop products */
.products-grid-item .sub-page-p-small {
  font-size: 0.95em !important;
  text-align: left !important;
  width: 100% !important;
}

.products-grid .product-button-block { 
  background-color: #3D688E !important; 
  display: inline-flex !important; 
  align-items: center; 
  justify-content: center; 
  margin: 12px auto 0; 
  width: auto;
  text-align: center;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
  will-change: transform;
}
.products-grid .product-button-block .focus-text-white { color:#fff !important; }
.products-grid .product-button-block:hover { 
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 8px 20px rgba(61, 104, 142, 0.3);
  filter: brightness(1.05);
}

/* Hide hero dots on the Staples slide only */
/* Ensure hero dots always show (even on slide 4) */
[data-hero-slider][data-slide-idx="3"] #heroDots { display: inline-flex !important; }

/* Shop categories: smoother scale/hover animation */
.shop-main-image-block-item .shop-image-block {
  transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
  will-change: transform;
  transform: translateZ(0);
}
.shop-main-image-block-item .shop-image-block img { transition: transform .45s cubic-bezier(.2,.7,.2,1); transform-origin: center; }
.shop-main-image-block-item:hover .shop-image-block {
  transform: translateY(-4px) scale(1.06);
  box-shadow: 0 14px 28px rgba(0,0,0,.16);
}
.shop-main-image-block-item:hover .shop-image-block img { transform: scale(1.08); }

/* Shop products: whole card hover effect */
.products-grid-item {
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
  border: 1.5px solid rgba(0, 0, 0, 0.08) !important;
  border-radius: 12px !important;
  padding: 16px !important;
  background-color: #fff !important;
}
.products-grid-item:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
}
.products-grid-item .product-image-block { 
  border-radius: 12px; 
  overflow: hidden; 
  transition: none;
  aspect-ratio: 1 / 1 !important;
  width: 100% !important;
  height: 250px !important;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #f9fafb;
}
.products-grid-item .product-image-block img { 
  display:block; 
  transition: none;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* Make shop product text non-clickable */
.products-grid .products-grid-item .product-content-block h1,
.products-grid .products-grid-item .product-content-block h2,
.products-grid .products-grid-item .product-content-block h3,
.products-grid .products-grid-item .product-content-block p {
  pointer-events: none;
  cursor: default;
}

/* Make product short description italic */
.product-short,
.product-short p,
.product-short .sub-page-p-small {
  font-style: italic !important;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .shop-main-image-block-item .shop-image-block,
  .shop-main-image-block-item .shop-image-block img,
  .products-grid-item,
  .products-grid-item .product-image-block img { transition: none !important; }
}
/* User area dynamic sections */
.user-content .user-section { display: none !important; }
.user-content .user-section.is-active { display: block !important; }
.user-sidebar .user-nav-item.is-active { background:#f3f4f6; border-color:#e5e7eb; box-shadow: 0 2px 10px rgba(0,0,0,.05); }
@import url('https://fonts.googleapis.com/css2?family=Rosario:wght@400;500;600;700&display=swap');
/* Project-specific overrides without touching the base bundle */

/* Global smooth scrolling; respects reduced-motion */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

/* Futuristic motion primitives */
:root { --anim-speed: 8s; }
@keyframes glowPulse {
  0% { text-shadow: 0 0 0px rgba(111,189,255,.0), 0 0 0px rgba(111,189,255,.0); }
  50% { text-shadow: 0 0 18px rgba(111,189,255,.25), 0 0 36px rgba(17,129,255,.15); }
  100% { text-shadow: 0 0 0px rgba(111,189,255,.0), 0 0 0px rgba(111,189,255,.0); }
}
@keyframes floatY {
  0% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
  100% { transform: translateY(0); }
}
@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

.anim-glow { animation: glowPulse 3.6s ease-in-out infinite; }
.anim-float { animation: floatY 6s ease-in-out infinite; will-change: transform; }

/* Shimmer underline for links */
.anim-shimmer {
  position: relative;
  background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.35) 50%, rgba(255,255,255,0) 100%);
  background-size: 200% 2px;
  background-repeat: no-repeat;
  background-position: 0 100%;
  animation: shimmer 2.6s linear infinite;
}

/* Scroll reveal utility */
.reveal-on-scroll { opacity: 0; transform: translateY(18px); transition: opacity .8s ease, transform .8s ease; }
.reveal-on-scroll.reveal-visible { opacity: 1; transform: none; }

/* Keep scroll reveal animations but fix section height issues on mobile */
@media (max-width: 767px) {
  /* Ensure sections only take up the space they need - remove extra height */
  .main-section-1,
  .main-section-2,
  .main-section-3,
  .main-story-section,
  .main-about-section {
    min-height: auto !important;
    max-height: none !important;
    height: auto !important;
    overflow: visible !important;
  }
  
  /* Reduce padding to prevent extra scroll space */
  .main-section-1,
  .main-section-2,
  .main-section-3,
  .main-story-section,
  .main-about-section {
    padding-top: clamp(32px, 5vh, 48px) !important;
    padding-bottom: clamp(32px, 5vh, 48px) !important;
    margin-bottom: 0 !important;
  }
  
  /* Ensure containers don't add extra height */
  .main-section-1 .container-full,
  .main-section-2 .container-full,
  .main-section-3 .container-full,
  .main-story-section .container-full,
  .main-about-section .container-full {
    min-height: auto !important;
    max-height: none !important;
    height: auto !important;
    overflow: visible !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  
  /* Ensure reveal-on-scroll doesn't create extra scroll space */
  .reveal-on-scroll {
    /* Transform should not create extra layout space */
    will-change: transform, opacity;
  }
  
  /* Prevent reveal-on-scroll from creating layout shifts that add height */
  .reveal-on-scroll:not(.reveal-visible) {
    /* Ensure transforms don't push content and create extra scroll */
    margin: 0 !important;
  }
}

/* Variant: reveal from right */
.reveal-on-scroll.reveal-right { transform: translateX(22px); }
.reveal-visible.reveal-right { transform: none; }

/* Variant: reveal from left */
.reveal-on-scroll.reveal-left { transform: translateX(-22px); }
.reveal-visible.reveal-left { transform: none; }

/* Variants */
.reveal-scale { transform: translateY(16px) scale(.98); transition: opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1); }
.reveal-visible.reveal-scale { transform: none; }

/* Button pulse to attract attention */
@keyframes buttonPulse {
  0% { box-shadow: 0 0 0 0 rgba(60,122,76,.45); }
  70% { box-shadow: 0 0 0 18px rgba(60,122,76,0); }
  100% { box-shadow: 0 0 0 0 rgba(60,122,76,0); }
}
.btn-pulse { animation: buttonPulse 2.4s ease-out infinite; }

/* Subtle 3D tilt on hover */
.tilt-hover { transition: transform .35s ease; transform-style: preserve-3d; }
.tilt-hover:hover { transform: perspective(800px) rotateX(3deg) rotateY(-3deg) translateZ(0); }

/* Keep staples in a single row; allow gentle horizontal scroll on small screens */
.staples-block {
  white-space: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.staples-link {
  display: inline-block;
  vertical-align: middle;
}

/* Home staples icons: gently enlarge on hover */
.staples-link img { transition: transform .3s ease-out; transform-origin: center; }
.staples-link:hover img { transform: scale(1.2); }

/* On wider screens, give a bit more room so all icons fit comfortably */
@media (min-width: 1200px) {
  .staples-block {
    max-width: 980px;
  }
}

/* Desktop: Fix homepage section spacing and hide scroll icons */
@media (min-width: 768px) {
  /* Reduce sub-page-slogan-p font size on desktop */
  .sub-page-slogan-p {
    font-size: 28px !important;
    line-height: 1.5 !important;
  }
  
  /* Hide any scroll indicators/icons on desktop */
  .reveal-on-scroll::before,
  .reveal-on-scroll::after,
  [class*="scroll"]::before,
  [class*="scroll"]::after,
  .scroll-indicator,
  .scroll-icon,
  .scroll-hint {
    display: none !important;
  }
  
  /* Fix homepage section spacing for desktop */
  .main-section-1,
  .main-section-2,
  .main-section-3,
  .main-story-section {
    padding-top: 100px !important;
    padding-bottom: 100px !important;
  }
  
  /* Fix overflow issues for all main sections on desktop - prevent internal scrolling */
  .main-section-1,
  .main-section-2,
  .main-section-3,
  .main-about-section,
  .main-story-section {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  .main-section-1 .container-full,
  .main-section-2 .container-full,
  .main-section-3 .container-full,
  .main-about-section .container-full,
  .main-story-section .container-full {
    overflow: visible !important;
    max-height: none !important;
  }
  
  .main-section-3 .main-grid-3-list,
  .main-section-2 .main-grid-3-list,
  .main-about-section .main-about-grid {
    overflow: visible !important;
    max-height: none !important;
  }
  
  /* main-about-section: reduce content padding to prevent overflow while maintaining spacing */
  .main-about-section {
    padding-top: 60px !important;
    padding-bottom: 40px !important;
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  .main-about-section .main-about-content {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }
  
  .main-about-section .container-full {
    overflow: visible !important;
    max-height: none !important;
  }
  
  .main-about-section .main-about-grid {
    overflow: visible !important;
    max-height: none !important;
  }
  
  /* CTA section: prevent overflow while maintaining spacing */
  .cta-section {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
    height: auto !important;
  }
  
  .cta-section .container-full {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
    height: auto !important;
  }
  
  .cta-section .cta-grid {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
    height: auto !important;
  }
  
  /* About-us page: Ensure ALL sections are full-size with no internal scrolling on desktop */
  .main-section-2:has(.about-history-grid),
  .main-section-2:has(.about-faq-main-block),
  .main-section-2:has(.about-text-block),
  .main-section-2:has(.about-image-block) {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
    height: auto !important;
  }
  
  .main-section-2:has(.about-history-grid) .container-full,
  .main-section-2:has(.about-faq-main-block) .container-full,
  .main-section-2:has(.about-text-block) .container-full,
  .main-section-2:has(.about-image-block) .container-full,
  .main-section-2 .container-full:has(.about-history-grid),
  .main-section-2 .container-full:has(.about-faq-main-block),
  .main-section-2 .container-full:has(.about-text-block),
  .main-section-2 .container-full:has(.about-image-block) {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
    height: auto !important;
  }
  
  /* All about-us specific containers and grids on desktop */
  .about-history-grid,
  .about-faq-main-block,
  .about-text-block,
  .about-image-block,
  .about-faq-item,
  .about-faq-item:not([data-accordion]) .faq-item-text,
  .about-faq-item[data-accordion].open .faq-item-text,
  .cta-grid,
  .cta-item {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
    height: auto !important;
  }
  
  /* Ensure accordion items can collapse - override the above rule */
  .about-faq-item[data-accordion] .faq-item-text:not(.open) {
    height: 0 !important;
    max-height: 0 !important;
    overflow: hidden !important;
  }
  
  /* Constrain about image size on desktop */
  .main-about-section .main-about-image {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 40px !important;
  }
  
  .main-about-section .about-image {
    max-width: 300px;
    width: 50%;
    height: auto;
  }
  
  /* Ensure main-section-1 fits on screen without scroll */
  .main-section-1.main-section-mobile-padding {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  .main-section-1 .container-full {
    overflow: visible !important;
    max-height: none !important;
  }
  
  .main-section-1 .main-grid-start {
    max-height: none !important;
    overflow: visible !important;
  }
  
  /* Ensure main-story-section fits on screen without scroll */
  .main-story-section {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  .main-story-section .container-full {
    overflow: visible !important;
    max-height: none !important;
  }
  
  .main-story-section .main-story-grid {
    max-height: none !important;
    overflow: visible !important;
  }
  
  /* Ensure main-section-2 on what-is-infinity page fits on screen without scroll */
  .main-section-2:has(.infinity-grid),
  .main-section-2:has(.infinity-sub-grid),
  .main-section-2:has(.infinity-experience-grid),
  .main-section-2:has(.infinity-questions-grid),
  .main-section-2:has(.infinity-get-started-grid) {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  .main-section-2:has(.infinity-grid) .container-full,
  .main-section-2:has(.infinity-sub-grid) .container-full,
  .main-section-2:has(.infinity-experience-grid) .container-full,
  .main-section-2:has(.infinity-questions-grid) .container-full,
  .main-section-2:has(.infinity-get-started-grid) .container-full {
    overflow: visible !important;
    max-height: none !important;
  }
  
  .main-section-2:has(.infinity-grid) .w-layout-grid,
  .main-section-2:has(.infinity-sub-grid) .w-layout-grid,
  .main-section-2:has(.infinity-experience-grid) .w-layout-grid,
  .main-section-2:has(.infinity-questions-grid) .w-layout-grid,
  .main-section-2:has(.infinity-get-started-grid) .w-layout-grid {
    max-height: none !important;
    overflow: visible !important;
  }
  
  /* Infinity grid child elements - prevent overflow */
  .main-section-2:has(.infinity-grid) .infinity-grid-title-block,
  .main-section-2:has(.infinity-grid) .infinity-grid-image-block,
  .main-section-2:has(.infinity-grid) .infinity-grid-side-text-block,
  .main-section-2:has(.infinity-grid) .infinity-grid-main-text-block {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  .main-section-2.home-intro-tall {
    padding-top: 120px !important;
    padding-bottom: 120px !important;
  }
  
  /* Ensure sections fit properly */
  .main-p-container {
    max-width: 800px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  
  .main-story-grid,
  .main-grid-start {
    gap: 60px !important;
  }
  
  /* Restore image sizes on desktop - balanced sizing */
  /* Restore specific image block sizes with reasonable constraints */
  .main-loop-image {
    max-width: 500px !important;
  }
  
  .main-loop-image img {
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
  }
  
  .image-block img,
  .main-story-grid .image-block img {
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
  }
  
  .infinity-grid-image-block {
    min-width: 450px !important;
    max-width: 450px !important;
  }
  
  .infinity-grid-image-block img,
  .infinity-grid-image-block video {
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
  }
  
  
  /* Desktop: Slightly increase size of CHECK OUR TESTIMONIALS button */
  @media (min-width: 992px) {
    .sub-page-focus-button-second {
      padding: 16px 32px !important;
      gap: 12px !important;
      transition: all 0.3s ease !important;
    }
    
    .sub-page-focus-button-second .focus-text {
      font-size: 18px !important;
      line-height: 1.4 !important;
    }
    
    .sub-page-focus-button-second .focus-icon-block {
      max-width: 22px !important;
      width: 22px !important;
      height: 22px !important;
      flex-shrink: 0 !important;
      transition: transform 0.3s ease !important;
    }
    
    .sub-page-focus-button-second .focus-icon-block img {
      width: 100% !important;
      height: 100% !important;
      object-fit: contain !important;
    }
    
    /* Hover animation */
    .sub-page-focus-button-second:hover {
      transform: translateY(-2px) scale(1.02) !important;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
      border-color: #999 !important;
    }
    
    .sub-page-focus-button-second:hover .focus-icon-block {
      transform: translateX(3px) !important;
    }
  }
  
  /* Desktop: Reduce size of "What People Experience" section */
  @media (min-width: 992px) {
    /* Reduce image sizes in infinity-experience-grid (from 250px to 200px - 20% reduction) */
    .infinity-experience-grid-image-block {
      flex: 0 0 200px !important;
      width: 200px !important;
      height: 200px !important;
      max-width: 200px !important;
      max-height: 200px !important;
      min-width: 200px !important;
      min-height: 200px !important;
    }
    
    .infinity-experience-grid-image-block img {
      width: 100% !important;
      height: 100% !important;
    }
    
    /* Reduce font size for sub-page-h1-light in infinity-experience-grid (from 36px to 28px) */
    .infinity-experience-grid-side-text-block .sub-page-h1-light {
      font-size: 28px !important;
      line-height: 1.3 !important;
    }
    
    /* Reduce title size (from default to 32px) */
    .infinity-experience-grid-title-block .sub-page-h1 {
      font-size: 32px !important;
      line-height: 1.2 !important;
    }
  }
  
  /* Desktop: Match all visuals to infinity-grid-image-block size (reference) */
  @media (min-width: 992px) {
    /* Reference: Video in infinity-grid - use original max-width: 400px */
    .infinity-grid-image-block {
      max-width: 400px !important;
      width: 400px !important;
      min-width: 400px !important; /* Match min-width for consistency */
    }
    
    .infinity-grid-image-block video {
      width: 100% !important;
      height: auto !important;
      max-width: 100% !important;
    }
    
    /* Match infinity-sub-grid images to EXACT same size as infinity-grid-image-block */
    .main-section-2 .infinity-sub-grid-image-block,
    .infinity-sub-grid .infinity-sub-grid-image-block,
    .infinity-sub-grid-sub-block-first .infinity-sub-grid-image-block,
    .infinity-sub-grid-sub-block-second .infinity-sub-grid-image-block,
    .infinity-sub-grid-image-block {
      max-width: 400px !important; /* Match exactly */
      width: 400px !important; /* Match exactly */
      min-width: 400px !important; /* Force minimum to match */
      /* Match the exact same properties as infinity-grid-image-block */
      flex-flow: column !important;
      justify-content: flex-start !important;
      align-items: center !important;
      display: flex !important;
    }
    
    .infinity-sub-grid-image-block img {
      width: 100% !important;
      height: auto !important;
      max-width: 100% !important;
      display: block !important;
    }
  }
  
  /* Base styles for infinity-sub-grid-image-block (mobile/tablet) */
  /* Note: Desktop sizing is handled in media query above */
  @media (max-width: 991px) {
    .infinity-sub-grid-image-block {
      min-width: 450px !important;
      max-width: 450px !important;
    }
  }
  
  .infinity-sub-grid-image-block img {
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
  }
  
  /* Ensure reveal animations work properly */
  .infinity-sub-grid-image-block.reveal-on-scroll.reveal-left {
    opacity: 0;
    transform: translateX(-22px);
    transition: opacity .8s ease, transform .8s ease;
  }
  
  .infinity-sub-grid-image-block.reveal-on-scroll.reveal-left.reveal-visible {
    opacity: 1 !important;
    transform: none !important;
  }
  
  /* Restore circular images for infinity-experience-grid */
  .infinity-experience-grid-image-block {
    border-radius: 50% !important;
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    aspect-ratio: 1 / 1 !important;
    width: 250px !important;
    height: 250px !important;
    max-width: 250px !important;
    max-height: 250px !important;
    min-width: 250px !important;
    min-height: 250px !important;
    flex: 0 0 250px !important;
  }
  
  .infinity-experience-grid-image-block img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    border-radius: 50% !important;
    display: block !important;
  }
  
  .sub-focus-grid-image-block img,
  .grid-sub-image-block img {
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
  }
  
  .about-image-right-block {
    max-width: 600px !important;
  }
  
  .about-image-right-block img {
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
  }
  
  .about-faq-item .faq-item-text.about .about-faq-image-block {
    flex: 0 0 320px !important;
    max-width: 320px !important;
    min-width: 320px !important;
  }
  
  .about-faq-item .faq-item-text.about .about-faq-image-block img {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* About Us accordion behavior (animated fold) */
.about-faq-item .faq-item-title { position: relative; cursor: pointer; }
.about-faq-item .faq-item-title::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 40px;
  line-height: 1;
  color: #0f0f0f;
  transition: transform .3s ease;
}
.about-faq-item.open .faq-item-title::after { transform: translateY(-50%) rotate(45deg); }

/* Fold open animation - use explicit height transitions for reliable collapse */
.about-faq-item[data-accordion] .faq-item-text {
  overflow: hidden !important;
  height: 0 !important;
  max-height: 0 !important;
  opacity: 0;
  transform: perspective(600px) rotateX(-6deg);
  transform-origin: top;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  /* Closing: very smooth and gradual fade out and collapse */
  transition: opacity .6s ease-in-out .15s, transform .7s ease-in-out, height .9s cubic-bezier(0.4, 0, 0.2, 1), max-height .9s cubic-bezier(0.4, 0, 0.2, 1), margin-top .9s cubic-bezier(0.4, 0, 0.2, 1), margin-bottom .9s cubic-bezier(0.4, 0, 0.2, 1), padding-top .9s cubic-bezier(0.4, 0, 0.2, 1), padding-bottom .9s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: height, max-height, opacity, transform;
  display: block !important; /* ensure transition works regardless of base styles */
}
.about-faq-item[data-accordion].open .faq-item-text {
  height: auto !important;
  max-height: none !important;
  opacity: 1;
  transform: none;
  overflow: visible !important; /* Prevent internal scrolling */
  margin-top: 40px !important; /* Match base style */
  margin-bottom: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  /* Opening: expand height first, then fade in */
  transition: height .55s ease, max-height .55s ease, opacity .6s ease-out .1s, transform .55s ease, margin-top .55s ease, margin-bottom .55s ease, padding-top .55s ease, padding-bottom .55s ease;
}

/* Layout: show image and text side-by-side when revealed */
.about-faq-item .faq-item-text.about { display:flex !important; align-items: flex-start; gap: 20px; }
.about-faq-item .faq-item-text.about .about-faq-image-block { flex: 0 0 320px; max-width: 320px; min-width: 320px !important; }
.about-faq-item .faq-item-text.about .about-faq-image-block img { width:100%; height:auto; display:block; border-radius: 12px; }
.about-faq-item .faq-item-text.about .about-faq-text-block { flex: 1 1 auto; }

/* Ensure smooth layout transitions for items below */
.about-faq-item[data-accordion] {
  transition: margin-bottom .9s cubic-bezier(0.4, 0, 0.2, 1);
}
.about-faq-main-block {
  transition: none; /* Let individual items handle their own transitions */
}

/* Prevent internal scrolling on all main sections - Desktop and Mobile */
.main-section-1,
.main-section-2,
.main-section-3,
.main-about-section,
.main-story-section,
.cta-section {
  overflow: visible !important;
  max-height: none !important;
  min-height: auto !important;
  height: auto !important;
}

.main-section-1 .container-full,
.main-section-2 .container-full,
.main-section-3 .container-full,
.main-about-section .container-full,
.main-story-section .container-full,
.cta-section .container-full {
  overflow: visible !important;
  max-height: none !important;
  min-height: auto !important;
  height: auto !important;
}

/* About-us page: Ensure ALL containers and grids have no internal scrolling */
.about-history-grid,
.about-faq-main-block,
.about-text-block,
.about-image-block,
.about-faq-item,
.about-faq-item .faq-item-text,
.about-faq-item.open .faq-item-text,
.cta-grid,
.cta-item {
  overflow: visible !important;
  max-height: none !important;
  min-height: auto !important;
  height: auto !important;
}

@media (max-width: 768px){
  .about-faq-item .faq-item-text.about { flex-direction: column; }
  .about-faq-item .faq-item-text.about .about-faq-image-block { max-width: 100%; min-width: 0 !important; width: 100%; }
}

/* FAQ page: accordion indicators and animated fold */
.faq-page-main-block .faq-item-title,
.faq-page-main-block .faq-sub-item-title { position: relative; cursor: pointer; }

/* Outer section "+" indicator */
.faq-page-main-block .faq-item-title::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 40px;
  line-height: 1;
  color: #0f0f0f;
  transition: transform .3s ease;
}
.faq-page-main-block .faq-page-item.open > .faq-item-title::after { transform: translateY(-50%) rotate(45deg); }

/* Inner question "+" indicator */
.faq-page-main-block .faq-sub-item-title::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 32px;
  line-height: 1;
  color: #0f0f0f;
  transition: transform .3s ease;
}
.faq-page-main-block .faq-page-sub-block.sub-open .faq-sub-item-title::after { transform: translateY(-50%) rotate(45deg); }

/* Remove Lottie icons in FAQ headers to avoid double plus signs */
.faq-item-title .lottie-animation,
.faq-sub-item-title .lottie-animation-small { display: none !important; }

/* Override page-local display toggles to enable animation */
.faq-page-main-block .faq-page-item .faq-page-sub-block { display: block !important; }
.faq-page-main-block .faq-page-sub-block .faq-item-text { display: block !important; }

/* Animate outer section opening (reveals list of inner questions) */
.faq-page-main-block .faq-page-item .faq-page-sub-block {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: perspective(600px) rotateX(-6deg);
  transform-origin: top;
  /* Opening */
  transition: max-height .55s ease, opacity .6s ease-out, transform .55s ease;
  will-change: max-height, opacity, transform;
}
.faq-page-main-block .faq-page-item.open .faq-page-sub-block {
  max-height: 1200px; /* large enough for each block */
  opacity: 1;
  transform: none;
  margin-top: 0; /* avoid extra top gap when revealed */
  margin-bottom: 0; /* avoid extra bottom gap when revealed */
  /* Closing */
  transition: opacity .5s ease-in, transform .5s ease-in, max-height .55s ease .1s;
}

/* Animate inner answer fold */
.faq-page-main-block .faq-page-sub-block .faq-item-text {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: perspective(600px) rotateX(-6deg);
  transform-origin: top;
  /* Opening */
  transition: max-height .55s ease, opacity .6s ease-out, transform .55s ease;
  will-change: max-height, opacity, transform;
}
.faq-page-main-block .faq-page-sub-block.sub-open .faq-item-text {
  max-height: 700px;
  opacity: 1;
  transform: none;
  /* Closing */
  transition: opacity .5s ease-in, transform .5s ease-in, max-height .55s ease .1s;
}

/* FAQ: visually indent subsections under their headers */
.faq-page-main-block .faq-page-sub-block {
  margin-left: 10px;
  padding-left: 16px;
  border-left: 0;
  margin-top: 0;
  margin-bottom: 0;
}
@media (max-width: 767px){
  .faq-page-main-block .faq-page-sub-block { margin-left: 6px; padding-left: 12px; }
}

/* Revert header navigation font sizes to default (remove previous override) */

/* Make footer link pills transparent so page-specific footer color shows through */
.footer .link-block {
  background-color: transparent !important;
}

/* Footer: indicate selected/hovered links by nudging up slightly */
.footer .footer-link {
  display: inline-block;
  transition: transform .18s ease, color .18s ease;
}
.footer .footer-link:hover,
.footer .footer-link.is-active {
  transform: translateY(-3px);
}

/* Header active link styling: color only (no underline) */
.nav-menu-wrapper-three .is-active { color:#232f50 !important; font-weight: 700 !important; text-decoration: none !important; }

/* Force normal weight for the literal word INFINITY in What-is page hero */
.sub-page-hero .sub-hero-h1 .no-bold { font-weight: 400 !important; }

/* Content width limit - 80% max width for readability */
.container-full {
  max-width: 80% !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Mobile: use full width for better mobile experience */
@media (max-width: 767px) {
  .container-full {
    max-width: 100% !important;
    padding-left: clamp(16px, 6vw, 24px) !important;
    padding-right: clamp(16px, 6vw, 24px) !important;
  }
}

/* Header: apply 80% width limit with proper padding */
.navbar-logo-center-container.shadow-three .container-full {
  max-width: 80% !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: visible !important;
  /* Slightly larger gap from edges */
  padding-left: clamp(24px, 3vw, 60px) !important;
  padding-right: clamp(24px, 3vw, 60px) !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* Increase header top and bottom padding by 6px for desktop */
@media (min-width: 768px) {
  .navbar-logo-center-container.shadow-three {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }
}

/* Laptop header fixes - ensure proper centered layout */
@media (max-width: 1728px) and (min-width: 1024px) {
  .navbar-logo-center-container.shadow-three .container-full {
    max-width: 80% !important;
    padding-left: clamp(24px, 3vw, 60px) !important;
    padding-right: clamp(24px, 3vw, 60px) !important;
  }
  .navbar-wrapper-three {
    justify-content: center !important;
    align-items: center !important;
    position: relative !important;
    overflow: visible !important;
  }
  .navbar-brand-three {
    position: absolute !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 10 !important;
    overflow: visible !important;
    width: auto !important;
    max-width: none !important;
  }
  .nav-menu-wrapper-three {
    width: 100% !important;
    overflow: visible !important;
  }
  .nav-menu-three {
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
  }
  .nav-menu-block {
    flex-wrap: nowrap !important;
    gap: clamp(8px, 1.2vw, 16px) !important;
  }
  .nav-menu-block:first-child {
    justify-content: flex-start !important;
  }
  .nav-menu-block:last-child {
    justify-content: flex-end !important;
  }
}

/* Make header sticky only on mobile - desktop keeps original behavior */
@media (max-width: 767px) {
  .navbar-logo-center-container.shadow-three { 
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
    background: #F8F9FA !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
    height: auto !important;
    min-height: auto !important;
    width: 100% !important;
  }
  .navbar-logo-center-container.shadow-three .container-full {
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
    height: auto !important;
    min-height: auto !important;
    width: 100% !important;
  }
}

/* Hero title spacing: anchor titles; remove viewport-based transforms */
[data-hero-slider] .slider-content-big-text { transform: none !important; will-change: auto; }
@media (max-width: 991px){ [data-hero-slider] .slider-content-big-text { transform: none !important; } }

/* Prevent scroll effects on hero slider - ensure it stays static during page scroll */
.slider-section {
  position: relative !important;
  /* Prevent parallax or scroll-based transforms */
  transform: none !important;
}

.main-hero-bg {
  position: relative !important;
  /* Prevent parallax background effect */
  background-attachment: scroll !important;
  /* Allow slider's own animations but prevent scroll-based transforms */
}

/* Ensure hero slider elements don't have reveal-on-scroll effects */
.slider-section .reveal-on-scroll,
.main-hero-bg .reveal-on-scroll,
[data-hero-slider] .reveal-on-scroll,
.slider-content .reveal-on-scroll,
.slider-content-big-text .reveal-on-scroll,
.hero-bottom-right .reveal-on-scroll {
  opacity: 1 !important;
  /* Only override scroll-based transforms, allow slider animations */
  transition: none !important;
}

/* Ensure reveal-on-scroll doesn't interfere with hero slider animations */
.slider-section .reveal-on-scroll:not(.reveal-visible),
.main-hero-bg .reveal-on-scroll:not(.reveal-visible),
[data-hero-slider] .reveal-on-scroll:not(.reveal-visible) {
  /* Force visible immediately - don't wait for scroll */
  opacity: 1 !important;
  transform: none !important;
}

/* Convert specific focus button into an informational badge (non-clickable) */
.sub-page-focus-button.is-info {
  cursor: default !important;
  background: #f7f7f7 !important;
  border: 1px dashed #c8c8c8 !important;
  box-shadow: none !important;
}
.sub-page-focus-button.is-info .focus-text { color:#333 !important; letter-spacing: 0 !important; }
.sub-page-focus-button.is-info:hover { transform: none !important; }

/* Alternative: subtle note card with left accent bar */
.sub-page-focus-button.is-note {
  display: inline-flex !important;
  align-items: center;
  gap: 10px;
  padding: 10px 16px !important;
  white-space: nowrap;
}
.sub-page-focus-button.is-note .focus-text {
  font-size: clamp(14px, 1.8vw, 18px) !important;
  line-height: 1.2 !important;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .sub-page-focus-button.is-note {
    gap: 8px;
    padding: 9px 14px !important;
  }
  .sub-page-focus-button.is-note .focus-text {
    font-size: clamp(13px, 3.6vw, 15px) !important;
  }
}
.sub-page-focus-button.is-note:hover { transform: none !important; }

/* Contact page theme color */
.contact .login-button-block-colored.contact,
.contact .w-button.contact,
.login-button-block-colored.contact {
  background-color: #0A5D38 !important;
}
.cta-section .button-second.w-button.contact { background-color: #0A5D38 !important; }

/* Contact: vertically center email/address inside pill */
.contact-info-block .info-text-block { display:flex; align-items:center; justify-content:center; min-height: 80px; }
.contact-info-block .info-text-block h1 { margin: 0; }

/* Contact form: preferred contact chips */
.contact-pref-grid { display:flex; flex-wrap: wrap; gap:12px; }
.pref-item { display:inline-flex; align-items:center; gap:0; padding:8px 14px; border:1px solid #cbd5e1; border-radius:999px; cursor:pointer; user-select:none; transition: transform .15s ease, background-color .15s ease, border-color .15s ease; font-size:16px; }
/* Hide the checkbox boxes; keep labels clickable */
.pref-item input { position:absolute; opacity:0; width:0; height:0; pointer-events:none; }
/* Highlight and slightly enlarge when selected */
.pref-item:has(input:checked) { transform: scale(1.06); background-color:#eef2f7; border-color:#94a3b8; }
.pref-item input:checked + span { font-weight:600; }
/* Make inputs height auto for selects/textarea consistency */
.contact-main-block .input { height: auto; padding: 12px 14px; }
.contact-main-block .input.message { height: 180px; }

/* Contact form: slight reveal and focus animations */
.contact-main-block .form.reveal-on-scroll .form-block { opacity: 0; transform: translateY(12px); transition: opacity .5s ease, transform .5s ease; }
.contact-main-block .form.reveal-on-scroll.reveal-visible .form-block { opacity: 1; transform: none; }
.contact-main-block .input:focus { box-shadow: 0 0 0 3px rgba(35,47,80,.12); border-color: #94a3b8; outline: none; }
.contact-main-block select.input:focus { outline: none; }
.contact-main-block .form-actions { margin-top: 10px; }

/* Ensure textarea and preference row span full width in the 2-col grid */
.form .form-block-full { grid-column: 1 / -1; }

/* Contact form: restore labels above fields (override floating label style) */
.contact-main-block .form-text {
  position: static !important;
  bottom: auto !important;
  padding-left: 0 !important;
  margin-bottom: 6px !important;
  display: block !important;
}
.contact-main-block .contact-pref-grid { margin-top: 6px; }

/* Contact form select field mobile optimization */
@media (max-width: 767px) {
  .contact-main-block select.input {
    font-size: 16px !important; /* Prevent iOS zoom on focus */
    min-height: 44px !important; /* Ensure adequate touch target */
    padding: 12px 14px !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    background-size: 12px !important;
    padding-right: 40px !important;
  }
}

/* Contact page map section - remove gap below and top spacing on desktop */
@media (min-width: 768px) {
  .main-section-2:has(iframe) {
    margin-top: 0 !important;
    padding-top: 0 !important;
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }
}

.main-section-2:has(iframe) {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}
.main-section-2:has(iframe) > div {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  line-height: 0 !important;
}
.main-section-2:has(iframe) iframe {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
  display: block !important;
}

/* Generic helper to theme forms if needed */
.theme-green { background-color: #109B5D !important; border-color: #109B5D !important; }


/* Login: custom remember-me toggle */
.remember-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: nowrap;
  margin: 10px 0 20px;
}
.remember-text {
  font-size: 16px;
  white-space: nowrap;
}
.remember-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  background: transparent;
  border: 0;
  padding: 0;
}
.remember-toggle .toggle-input { display:none; }
.remember-toggle .toggle-slider {
  display: block;
  width: 80px;
  height: 40px;
  background: #e5e7eb; /* light grey when OFF */
  border-radius: 9999px;
  position: relative;
  transition: background 0.2s ease;
}
.remember-toggle .toggle-slider::after {
  content: "";
  position: absolute;
  top: 4px;
  left: 6px;
  width: 32px;
  height: 32px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0,0,0,.2);
  transition: transform 0.2s ease;
}
button.remember-toggle[aria-pressed="true"] .toggle-slider { background: #232f50; }
button.remember-toggle[aria-pressed="true"] .toggle-slider::after { transform: translateX(40px); }

/* Sub-hero title size override */
.sub-hero-h1 {
  font-size: 44px !important;
}
.sub-hero-h2 {
  font-size: clamp(22px, 3.3vw, 44px) !important;
}
@media (min-width: 992px) {
  .sub-hero-h2 { white-space: nowrap; }
}

/* Move hero content - title top-right, description bottom-left */
.sub-hero-content-block {
  align-items: flex-end !important;
  justify-content: space-between !important;
  padding-bottom: 80px !important;
  padding-top: 60px !important;
  position: relative !important;
}

.sub-hero-h1, .sub-her-h1-black {
  float: right !important;
  text-align: right !important;
  padding-top: 0 !important;
  margin-bottom: 0 !important;
  position: absolute !important;
  top: 60px !important;
  right: 40px !important;
  left: auto !important;
  z-index: 2 !important;
  transform: none !important;
}

.sub-hero-desc-block {
  position: absolute !important;
  bottom: 40px !important;
  left: 0px !important;
  right: auto !important;
  text-align: left !important;
  max-width: 500px !important;
  z-index: 2 !important;
  margin-bottom: 10px !important;
}

/* Override any page-specific background classes to ensure title top-right, description bottom-left */
.background-1 .sub-hero-content-block,
.background-2-about .sub-hero-content-block,
.background-3-testimonials .sub-hero-content-block,
.background-4-faq .sub-hero-content-block,
.background-5-partner .sub-hero-content-block,
.background-6-offering .sub-hero-content-block,
.background-7-business .sub-hero-content-block,
.background-8-explore .sub-hero-content-block,
.background-9-blog .sub-hero-content-block,
.background-9-community .sub-hero-content-block,
.background-10-community .sub-hero-content-block,
.background-11-guides .sub-hero-content-block {
  align-items: flex-end !important;
  justify-content: space-between !important;
  padding-bottom: 80px !important;
  padding-top: 60px !important;
}

.background-1 .sub-hero-h1,
.background-2-about .sub-hero-h1,
.background-3-testimonials .sub-hero-h1,
.background-4-faq .sub-hero-h1,
.background-5-partner .sub-hero-h1,
.background-6-offering .sub-hero-h1,
.background-7-business .sub-hero-h1,
.background-8-explore .sub-hero-h1,
.background-9-blog .sub-hero-h1,
.background-9-community .sub-hero-h1,
.background-10-community .sub-hero-h1,
.background-11-guides .sub-hero-h1,
.background-1 .sub-her-h1-black,
.background-2-about .sub-her-h1-black,
.background-3-testimonials .sub-her-h1-black,
.background-4-faq .sub-her-h1-black,
.background-5-partner .sub-her-h1-black,
.background-6-offering .sub-her-h1-black,
.background-7-business .sub-her-h1-black,
.background-8-explore .sub-her-h1-black,
.background-9-blog .sub-her-h1-black,
.background-9-community .sub-her-h1-black,
.background-10-community .sub-her-h1-black,
.background-11-guides .sub-her-h1-black {
  float: right !important;
  text-align: right !important;
  padding-top: 0 !important;
  margin-bottom: 0 !important;
  position: absolute !important;
  top: 60px !important;
  right: 40px !important;
  left: auto !important;
  z-index: 2 !important;
  transform: none !important;
}

.background-1 .sub-hero-desc-block,
.background-2-about .sub-hero-desc-block,
.background-3-testimonials .sub-hero-desc-block,
.background-5-partner .sub-hero-desc-block,
.background-6-offering .sub-hero-desc-block,
.background-7-business .sub-hero-desc-block,
.background-8-explore .sub-hero-desc-block,
.background-9-blog .sub-hero-desc-block,
.background-9-community .sub-hero-desc-block,
.background-10-community .sub-hero-desc-block,
.background-11-guides .sub-hero-desc-block {
  position: absolute !important;
  bottom: 20px !important;
  left: 0px !important;
  right: auto !important;
  text-align: left !important;
  max-width: 500px !important;
  z-index: 2 !important;
}

/* FAQ and What is Infinity use same structure - bottom: 60px, width: 75% */
.background-1 .sub-hero-desc-block,
.background-4-faq .sub-hero-desc-block {
  bottom: 60px !important;
  width: 75% !important;
  max-width: none !important;
}

/* Ensure FAQ hero subtitle fits one line on desktop */
@media (min-width: 992px) {
  .background-4-faq .sub-hero-h2 {
    font-size: 36px !important;
    white-space: nowrap;
  }
}

/* Removed Rosario helper rules */
/* Style the literal word INFINITY site-wide */
.infinity-word, .infinity-word * { font-family: 'Rosario', sans-serif !important; letter-spacing: 0.02em; }

/* Subtle white blend for images when needed (tuned) */
.blend-white { opacity: .7; mix-blend-mode: normal; }

/* FAQ hero paragraph to match design */
.background-4-faq .sub-hero-desc-block p {
  color: #fff !important;
  font-size: clamp(18px, 1.7vw, 22px) !important;
  line-height: 1.6 !important;
  max-width: 760px; /* approximate width in the mock */
  margin-top: 10px;
}

/* Partner page: replace blue section background with #1F3D2B */
.sub-page-hero.background-5-partner ~ .main-section-1 {
  background-color: #1F3D2B !important;
}

/* Ensure Explore hero background shows (and has height) */
.sub-page-hero.background-8-explore {
  background-image: url('../images/explore-sub-hero-image.jpg') !important;
  background-size: cover !important;
  background-position: 50% 50% !important;
  min-height: 80vh !important;
}

/* Ensure Business hero background matches other pages */
.sub-page-hero.background-7-business {
  min-height: 80vh !important;
}

/* Mobile: Match process page hero height */
@media (max-width: 991px) {
  .sub-page-hero.background-7-business,
  .sub-page-hero.background-8-explore {
    min-height: 60vh !important;
  }
}

@media (max-width: 767px) {
  .sub-page-hero.background-7-business,
  .sub-page-hero.background-8-explore {
    min-height: 52vh !important;
  }
}

/* Subtle readability overlay on all sub-page heroes (exclude homepage hero) */
.sub-page-hero { position: relative; }
.sub-page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.28);
  pointer-events: none;
}
.sub-page-hero > .container-full { position: relative; z-index: 1; }

/* Guides page: dedicated hero background */
.sub-page-hero.background-11-guides {
  background-image: url('../images/guide-hero.png') !important;
  background-size: cover !important;
  background-position: 50% 50% !important;
}

/* Partner colored grid: add spacing for bottom call-to-action button */
.focus-colored-grid-block .sub-focus-grid-button-block {
  display: flex;
  justify-content: center;
  margin-top: 22px; /* nudge slightly lower */
  margin-bottom: 24px; /* small gap from bottom */
}

/* Reduce excessive bottom padding on desktop for focus-colored-grid-block */
@media (min-width: 768px) {
  .focus-colored-grid-block {
    padding-bottom: 20px !important;
  }
}

/* Button hover effects */
.button-second,
.button-second-white,
a.button-second,
a.button-second-white {
  transition: all 0.3s ease !important;
  position: relative !important;
  overflow: hidden !important;
}

.button-second:hover,
a.button-second:hover {
  transform: translateY(-3px) scale(1.02) !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25) !important;
  border-color: #808080 !important;
}

.button-second-white:hover,
a.button-second-white:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(255, 255, 255, 0.2) !important;
  border-color: #d0d0d0 !important;
  background-color: rgba(255, 255, 255, 0.05) !important;
}
@media (min-width: 992px){
  .focus-colored-grid-block .sub-focus-grid-button-block { margin-top: 28px; margin-bottom: 32px; }
}

/* Match vertical spacing for top Partner grid button (below the first grid) */
.main-section-2 .sub-focus-grid-button-block {
  display: flex;
  justify-content: center;
  margin-top: 18px;
  margin-bottom: 40px;
}
@media (min-width: 992px){
  .main-section-2 .sub-focus-grid-button-block { margin-top: 22px; margin-bottom: 60px; }
}

/* Move only the button that sits AFTER a colored grid (first section) */
.focus-colored-grid-block .sub-page-main-focus-grid-colored + .sub-focus-grid-button-block { margin-top: 48px; }
@media (min-width: 992px){
  .focus-colored-grid-block .sub-page-main-focus-grid-colored + .sub-focus-grid-button-block { margin-top: 64px; }
}

/* Partner page: revert section height to base styles (remove override) */
/* Remove section padding override so base spacing controls height */

/* Home: make the intro paragraph section taller */
.home-intro-tall { padding-top: 80px !important; padding-bottom: 80px !important; }
@media (min-width: 992px){ .home-intro-tall { padding-top: 120px !important; padding-bottom: 120px !important; } }

/* User area dashboard layout - Side navigation for desktop, mobile menu for mobile */
.user-area-wrapper { 
  display:flex; 
  flex-direction:row; 
  gap:24px; 
  position:relative;
}


/* Side Navigation / Mobile Menu */
.user-area-sidebar {
  width: 280px;
  min-width: 280px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: 20px 24px;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
  height: fit-content;
  position: sticky;
  top: 24px;
}

.user-sidebar-header {
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid #e5e7eb;
}

.user-sidebar-title {
  margin: 0;
  font-size: 22px;
  font-weight: 700;
  color: #111827;
}

.user-sidebar-sub {
  color: #6b7280;
  font-size: 14px;
  margin-top: 4px;
}

.user-sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.user-sidebar-item {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  border-radius: 10px;
  color: #374151;
  text-decoration: none;
  border: 1px solid transparent;
  transition: all .2s ease;
  background: #f9fafb;
}

.user-sidebar-item:hover {
  background: #f3f4f6;
  border-color: #e5e7eb;
  color: #111827;
}

.user-sidebar-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.user-sidebar-item em {
  display: block;
  font-style: normal;
  color: #6b7280;
  font-size: 11px;
  line-height: 1.2;
}

.user-sidebar-item strong {
  display: block;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.3;
}

.user-sidebar-item.is-active {
  background: #eef2ff;
  border-color: #c7d2fe;
  color: #1e40af;
  box-shadow: 0 2px 4px rgba(99,102,241,.1);
}

.user-sidebar-item.is-active em {
  color: #6366f1;
}

.user-sidebar-item.is-active strong {
  color: #1e40af;
  font-weight: 700;
}

.user-sidebar-logout {
  background: #dc2626 !important;
  color: #fff !important;
  margin-top: 24px;
  border: 2px solid #b91c1c !important;
  font-weight: 600;
  box-shadow: 0 2px 4px rgba(220, 38, 38, 0.2);
}

.user-sidebar-logout:hover {
  background: #b91c1c !important;
  border-color: #991b1b !important;
  color: #fff !important;
  box-shadow: 0 4px 8px rgba(220, 38, 38, 0.3);
  transform: translateY(-1px);
}

.user-sidebar-logout strong {
  color: inherit;
  font-weight: 600;
  font-size: 15px;
}

.user-sidebar-logout em {
  display: none;
}

.user-content {
  flex: 1;
  min-width: 0;
}

/* Mobile Styles */
@media (max-width: 991px) {
  .user-area-wrapper {
    flex-direction: column;
    gap: 16px;
  }

  .user-area-sidebar {
    width: 100%;
    min-width: 100%;
    position: relative;
    top: auto;
  }

  .user-content {
    width: 100%;
  }
}

.user-content-header { margin-bottom:14px; }
.user-content-sub { color:#6b7280; }

.active-card { display:flex; justify-content:space-between; align-items:center; background:#fff; border:1px solid #e5e7eb; border-radius:18px; padding:18px; box-shadow: 0 6px 26px rgba(0,0,0,.06); max-width:960px; }
.active-card-left { display:flex; align-items:center; gap:14px; }
.dot-online { width:10px; height:10px; border-radius:50%; background:#10b981; box-shadow:0 0 0 4px rgba(16,185,129,.15); }
.active-title { font-weight:700; }
.active-sub { color:#6b7280; font-size:14px; }

.support-bar { margin-top:24px; display:flex; gap:12px; align-items:center; border:1px solid #e5e7eb; border-radius:14px; padding:10px; background:#fff; box-shadow: 0 6px 20px rgba(0,0,0,.04); }
.support-input { flex:1; border:0; outline:0; padding:10px 12px; border-radius:10px; background:#f9fafb; }
.support-button { border:1px solid #e5e7eb; background:#fff; border-radius:10px; padding:10px 16px; cursor:pointer; }

@media (max-width: 991px) {
  .user-area-dashboard { grid-template-columns: 1fr; }
  .user-sidebar { position:relative; }
}

/* User Area header cloned from login layout (scoped) */
.ua-header { background:#fff; border:1px solid #e5e7eb; border-radius:16px; padding:12px 16px; margin-bottom:16px; box-shadow: 0 6px 16px rgba(0,0,0,.05); }
.ua-header-inner { max-width: 1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:16px; }
.ua-logo-wrap { display:flex; align-items:center; gap:10px; }
.ua-logo-box { width:32px; height:32px; background: linear-gradient(135deg, #2563eb 0%, #7c3aed 100%); border-radius:8px; display:flex; align-items:center; justify-content:center; }
.ua-logo-diamond { width:14px; height:14px; border:2px solid #fff; border-bottom-color: transparent; transform: rotate(45deg); display:inline-block; }
.ua-brand { font-size:18px; font-weight:700; color:#1e293b; margin:0; }
.ua-brand-sub { font-size:12px; color:#64748b; }
.ua-nav { display:none; align-items:center; gap:18px; }
.ua-nav a { font-size:12px; color:#64748b; text-decoration:none; }
.ua-nav a:hover { color:#0f172a; }
.ua-actions { display:flex; align-items:center; gap:8px; }
.ua-btn { font-size:12px; color:#0f172a; border:1px solid #e5e7eb; border-radius:8px; padding:6px 10px; text-decoration:none; background:#fff; }
.ua-btn.ua-outline { background:#fff; }
@media (min-width: 992px){ .ua-nav { display:flex; } }

/* UA hero */
.ua-hero { position:relative; border-radius:20px; padding:18px; color:#fff; overflow:hidden; background: linear-gradient(135deg, #2563eb, #7c3aed); box-shadow: 0 10px 24px rgba(0,0,0,.12); }
.ua-hero::after { content:""; position:absolute; inset:0; background: linear-gradient(90deg, rgba(37,99,235,.2), rgba(124,58,237,.2)); }
.ua-hero > * { position:relative; z-index:1; }
.ua-hero-top { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.ua-hero-icon { width:32px; height:32px; border-radius:10px; background:rgba(255,255,255,.18); display:flex; align-items:center; justify-content:center; }
.ua-hero-title { font-size:22px; font-weight:700; margin:0; }
.ua-hero-sub { color:#dbeafe; font-size:13px; margin-top:4px; }
.ua-metrics { display:grid; grid-template-columns: repeat(3,1fr); gap:10px; margin-top:12px; }
.ua-metric { background: rgba(255,255,255,.12); backdrop-filter: blur(6px); border-radius:12px; padding:10px; text-align:left; }
.ua-metric-val { font-size:20px; font-weight:700; }
.ua-metric-label { font-size:12px; color:#c7d2fe; }

/* UA cards */
.ua-grid { display:grid; grid-template-columns: 1fr 1fr; gap:16px; margin-top:16px; }
@media (max-width: 991px){ .ua-grid { grid-template-columns: 1fr; } }
.ua-card { background:#fff; border:1px solid #e5e7eb; border-radius:16px; box-shadow: 0 10px 24px rgba(0,0,0,.06); }
.ua-card.ua-full { grid-column: 1 / -1; }
.ua-card-header { display:flex; align-items:center; gap:10px; padding:14px 16px 6px; }
.ua-card-icon { width:40px; height:40px; border-radius:12px; display:flex; align-items:center; justify-content:center; color:#fff; font-size:18px; }
.ua-bg-blue { background: linear-gradient(135deg, #2563eb, #7c3aed); }
.ua-bg-emerald { background: linear-gradient(135deg, #10b981, #0ea5e9); }
.ua-bg-violet { background: linear-gradient(135deg, #7c3aed, #6d28d9); }
.ua-bg-rose { background: linear-gradient(135deg, #ec4899, #e11d48); }
.ua-card-title { font-weight:700; }
.ua-card-sub { color:#6b7280; font-size:14px; }
.ua-card-thumb { width:48px; height:48px; border-radius:10px; overflow:hidden; display:flex; align-items:center; justify-content:center; background:#eef2ff; }
.ua-card-thumb img { width:100%; height:100%; object-fit:cover; }
.ua-thumb-desc { font-size:16px; color:#374151; margin-bottom:8px; }
/* Subscription details text sizing */
.ua-list-title { font-size:16px; font-weight:600; }
.ua-list-sub { font-size:14px; }
.ua-card-body { padding:12px 16px 16px; display:flex; flex-direction:column; gap:12px; }
.ua-list { display:flex; flex-direction:column; gap:10px; }
.ua-list-item { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:12px; border-radius:12px; border:1px solid; }
.ua-list-blue .ua-list-item { background: linear-gradient(90deg, #eff6ff, #f5f3ff); border-color:#bfdbfe; }
.ua-list-red .ua-list-item { background: linear-gradient(90deg, #fef2f2, #ffe4e6); border-color:#fecaca; }
.ua-list-green .ua-list-item { background: linear-gradient(90deg, #f0fdf4, #ecfdf5); border-color:#bbf7d0; }
.ua-list-left { display:flex; align-items:center; gap:10px; }
.ua-dot { width:10px; height:10px; border-radius:50%; display:inline-block; }
.ua-green { background:#10b981; }
.ua-orange { background:#f59e0b; }
.ua-badge { font-size:11px; padding:4px 8px; border-radius:999px; border:1px solid; }
.ua-badge-green { background:#dcfce7; color:#065f46; border-color:#bbf7d0; }
.ua-badge-orange { background:#ffedd5; color:#9a3412; border-color:#fed7aa; }
.ua-badge-red { background:#fee2e2; color:#991b1b; border-color:#fecaca; }
.ua-badge-success { background:#dcfce7; color:#065f46; border-color:#bbf7d0; }
.ua-badge-error { background:#fee2e2; color:#991b1b; border-color:#fecaca; }

.ua-button { display:inline-block; padding:8px 16px; border-radius:6px; border:none; cursor:pointer; font-size:0.875rem; font-weight:500; text-decoration:none; transition:all 0.2s ease; }
.ua-button-small { padding:6px 12px; font-size:0.875rem; }
.ua-button-danger { background:#ef4444; color:#ffffff; }
.ua-button-danger:hover { background:#dc2626; }
.ua-button-warning { background:#f59e0b; color:#ffffff; }
.ua-button-warning:hover { background:#d97706; }
.ua-right { text-align:right; }
.ua-price { font-weight:700; font-size:16px; }

.ua-btn-primary { background: linear-gradient(135deg, #2563eb, #7c3aed); color:#fff; text-decoration:none; padding:10px 12px; border-radius:12px; text-align:center; }
.ua-btn-outline { border:1px solid #e5e7eb; color:#1f2937; text-decoration:none; padding:10px 12px; border-radius:12px; text-align:center; background:#fff; }
.ua-btn-block { display:block; width:100%; }
.ua-row { display:grid; grid-template-columns: 1fr 1fr; gap:10px; }
.ua-btn-danger { background:#dc2626; color:#fff; text-decoration:none; padding:10px 12px; border-radius:12px; text-align:center; border:1px solid #b91c1c; }
.ua-btn-danger:hover { filter: brightness(0.95); }
.ua-form .ua-row { margin-top: 16px; }

.ua-guide { display:flex; align-items:center; gap:12px; padding:12px; border:1px solid #bbf7d0; border-radius:12px; background: linear-gradient(90deg, #ecfdf5, #f0fdf4); }
.ua-guide-avatar { width:56px; height:56px; border-radius:14px; background: linear-gradient(135deg, #10b981, #0ea5e9); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; }
.ua-guide-name { font-weight:700; }
.ua-guide-sub { font-size:12px; color:#6b7280; }
.ua-guide-meta { font-size:12px; color:#6b7280; margin-top:4px; }

.ua-callout { padding:12px; border-radius:12px; border:1px solid; }
.ua-callout-rose { background: linear-gradient(90deg, #fdf2f8, #ffe4e6); border-color:#fecdd3; }
.ua-callout-title { font-weight:700; margin-bottom:6px; }
.ua-callout-sub { font-size:13px; color:#6b7280; }

/* UA testimonial form */
.ua-alert { margin: 10px 0; padding:12px 14px; border-radius:12px; font-size:14px; }
.ua-alert-error { background:#fee2e2; color:#991b1b; border:1px solid #fecaca; }
.ua-alert-success { background:#ecfdf5; color:#065f46; border:1px solid #bbf7d0; }
.ua-form { display:block; }
.ua-field { margin-top:10px; }
.ua-label { display:block; margin:0 0 6px; font-weight:700; font-size:14px; color:#0f172a; }
.ua-input { width:100%; border:1px solid #cbd5e1; border-radius:10px; padding:10px 12px; background:#f8fafc; }
.ua-textarea { width:100%; height:140px; border:1px solid #cbd5e1; border-radius:10px; padding:10px 12px; background:#f8fafc; resize:vertical; }
.ua-input:focus, .ua-textarea:focus { box-shadow: 0 0 0 3px rgba(35,47,80,.12); border-color: #94a3b8; outline: none; }
.ua-textarea { height: 180px; }
.ua-form .ua-field .ua-input, .ua-form .ua-field .ua-textarea { transition: box-shadow .15s ease, border-color .15s ease, background-color .15s ease; }
.ua-form .ua-field { display:block; }
.ua-settings-grid { display:grid; grid-template-columns: 1fr 1fr; gap:16px; align-items:start; }
@media (max-width: 991px){ .ua-settings-grid { grid-template-columns: 1fr; } }
.ua-settings-grid .ua-form { max-width: 100% !important; }

/* Partner Dashboard Profile Form - Improved Grid Layout */
.partner-profile-form .ua-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: start;
}

.partner-profile-form .ua-field-full {
  grid-column: 1 / -1;
}

.partner-profile-form .ua-field {
  margin-top: 0;
}

.partner-profile-form .ua-field .form-text {
  display: block;
  font-weight: 600;
  font-size: 14px;
  color: #0f172a;
  margin-bottom: 8px;
}

.partner-profile-form .ua-field .input,
.partner-profile-form .ua-field .message {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  background: #fff;
  font-size: 15px;
  transition: all 0.2s ease;
}

.partner-profile-form .ua-field .input:focus,
.partner-profile-form .ua-field .message:focus {
  outline: none;
  border-color: #8FB6D9;
  box-shadow: 0 0 0 3px rgba(143, 182, 217, 0.1);
}

.partner-profile-form .ua-field .message {
  min-height: 100px;
  resize: vertical;
}

/* Partner Dashboard - Textarea styling for better visibility */
.ua-form .ua-field {
  margin-bottom: 16px;
}

.ua-form .ua-field:first-child {
  margin-top: 8px;
}

.ua-form .ua-field .form-text {
  display: block;
  font-weight: 600;
  font-size: 14px;
  color: #1f2937;
  margin-top: 8px;
  margin-bottom: 12px;
  line-height: 1.4;
}

.ua-form .ua-field textarea.message {
  width: 100%;
  padding: 12px 14px;
  border: 2px solid #cbd5e1;
  border-radius: 10px;
  background: #ffffff;
  line-height: 1.5;
  color: #1f2937;
  transition: all 0.2s ease;
  min-height: 100px;
  resize: vertical;
  font-family: inherit;
  display: block;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.ua-form .ua-field textarea.message:focus {
  outline: none;
  border-color: #8FB6D9;
  box-shadow: 0 0 0 3px rgba(143, 182, 217, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  background: #ffffff;
}

.ua-form .ua-field textarea.message::placeholder {
  color: #9ca3af;
  opacity: 1;
}

.partner-profile-form .ua-field-hint {
  display: block;
  margin-top: 6px;
  font-size: 13px;
  color: #6b7280;
  line-height: 1.4;
}

.partner-profile-form .ua-field-hint a {
  color: #3b82f6;
  text-decoration: none;
}

.partner-profile-form .ua-field-hint a:hover {
  text-decoration: underline;
}

.partner-profile-form .ua-form-actions {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid #e5e7eb;
  grid-column: 1 / -1;
}

@media (max-width: 991px) {
  .partner-profile-form .ua-form-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .partner-profile-form .ua-field {
    margin-top: 0;
  }
}
.ua-dropzone { display:flex; align-items:center; justify-content:center; gap:10px; text-align:center; border:1px solid #cbd5e1; border-radius:10px; padding:16px; min-height:64px; background:#f8fafc; cursor:pointer; }
.ua-dropzone:hover { box-shadow: 0 0 0 3px rgba(35,47,80,.12); border-color: #94a3b8; }
.ua-drop-icon { font-size:20px; color:#64748b; margin:0; }
.ua-drop-title { font-weight:600; color:#0f172a; }
.ua-drop-sub { font-size:12px; color:#6b7280; display:none; }

/* UA testimonial submit button - match footer color (#3D688E) */
.ua-form .button-second.w-button { 
  background-color: #8FB6D9 !important; 
  color:#fff !important; 
  border:0 !important; 
  border-radius:10px !important; 
  background-image: none !important; 
  padding: 10px 16px !important; 
  background-position: initial !important; 
  background-repeat: no-repeat !important; 
  text-indent: 0 !important; 
  display: inline-block !important;
  width: 100% !important;
  position: relative !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
}
.ua-form .button-second.w-button:hover { 
  background-color: #7AA5C8 !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(143, 182, 217, 0.4) !important;
}
.ua-form .button-second.w-button::after {
  display: none !important;
}
.ua-form .button-second.w-button:hover::after {
  display: none !important;
}

/* Home hero/video fit adjustments */
:root { --header-h: 0px; }
.slider-section { --hero-side-margin: clamp(16px, 4vw, 56px); --extra-hero-height: var(--hero-side-margin); --hero-top-gap: clamp(16px, 2.8vh, 36px); }
.navbar-logo-center-white { display: none; }
.slider-section { margin-top: 0; }
.slider-section .main-hero-bg { margin-top: 0 !important; }

/* Responsive hero side margins for smaller screens */
/* MacBook 14" and similar (1512px-1728px) */
@media (max-width: 1728px) {
  .slider-section { --hero-side-margin: clamp(8px, 1.2vw, 20px); --hero-top-gap: clamp(10px, 1.8vh, 20px); }
  /* Scale down text and icons for laptop screens */
  .slider-h1 {
    font-size: clamp(48px, 6vw, 72px) !important;
    margin-bottom: clamp(2rem, 3vh, 4rem) !important;
  }
  .slider-h1.slider-h1-2 {
    margin-left: clamp(40px, 6vw, 80px) !important;
    margin-top: clamp(30px, 4vh, 50px) !important;
  }
  .slider-h1.slider-h1-3 {
    margin-left: clamp(80px, 12vw, 180px) !important;
    margin-top: clamp(30px, 4vh, 50px) !important;
  }
  .hero-arrow {
    width: clamp(36px, 4vw, 44px) !important;
    height: clamp(36px, 4vw, 44px) !important;
    font-size: clamp(18px, 2.5vw, 24px) !important;
  }
  #heroDots img {
    width: clamp(32px, 4.5vw, 44px) !important;
    height: clamp(32px, 4.5vw, 44px) !important;
  }
  #heroSub,
  #heroDesc {
    font-size: clamp(16px, 2vw, 20px) !important;
  }
  .hero-cta {
    padding: clamp(12px, 1.5vw, 15px) clamp(24px, 3vw, 30px) !important;
    font-size: clamp(14px, 1.8vw, 16px) !important;
  }
}

/* MacBook 14" specific optimization (1512px-1600px) */
@media (max-width: 1600px) and (min-width: 1512px) {
  .slider-section { --hero-side-margin: clamp(6px, 1vw, 16px); --hero-top-gap: clamp(8px, 1.5vh, 16px); }
  .slider-h1 {
    font-size: clamp(44px, 5.5vw, 68px) !important;
  }
  .slider-h1.slider-h1-2 {
    margin-left: clamp(35px, 5vw, 70px) !important;
  }
  .slider-h1.slider-h1-3 {
    margin-left: clamp(70px, 10vw, 160px) !important;
  }
}

/* Standard laptop screens (1024px-1512px) */
@media (max-width: 1512px) and (min-width: 1024px) {
  .slider-h1 {
    font-size: clamp(42px, 5vw, 64px) !important;
    margin-bottom: clamp(1.5rem, 2.5vh, 3rem) !important;
  }
  .slider-h1.slider-h1-2 {
    margin-left: clamp(30px, 4.5vw, 60px) !important;
    margin-top: clamp(25px, 3.5vh, 45px) !important;
  }
  .slider-h1.slider-h1-3 {
    margin-left: clamp(60px, 9vw, 140px) !important;
    margin-top: clamp(25px, 3.5vh, 45px) !important;
  }
  .hero-arrow {
    width: clamp(34px, 3.5vw, 42px) !important;
    height: clamp(34px, 3.5vw, 42px) !important;
    font-size: clamp(16px, 2vw, 22px) !important;
  }
  #heroDots img {
    width: clamp(30px, 4vw, 42px) !important;
    height: clamp(30px, 4vw, 42px) !important;
  }
  #heroSub,
  #heroDesc {
    font-size: clamp(15px, 1.8vw, 19px) !important;
  }
}

/* Tablets and smaller laptops (768px-1024px) */
@media (max-width: 1024px) {
  .slider-section { --hero-side-margin: clamp(8px, 1.5vw, 16px); --hero-top-gap: clamp(8px, 1.5vh, 16px); }
  /* Homepage sections tablet optimizations */
  .main-section-1, .main-section-2, .main-section-3, .main-story-section {
    padding-top: clamp(50px, 7vh, 70px) !important;
    padding-bottom: clamp(50px, 7vh, 70px) !important;
  }
  
  /* main-about-section: reduce content padding to prevent overflow while maintaining spacing */
  .main-about-section {
    padding-top: clamp(40px, 6vh, 50px) !important;
    padding-bottom: clamp(40px, 6vh, 50px) !important;
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  .main-about-section .main-about-content {
    padding-top: clamp(40px, 6vh, 50px) !important;
    padding-bottom: clamp(40px, 6vh, 50px) !important;
  }
  
  .main-about-section .container-full {
    overflow: visible !important;
    max-height: none !important;
  }
  
  .main-about-section .main-about-grid {
    overflow: visible !important;
    max-height: none !important;
  }
  .main-section-1 .main-text-h1 {
    font-size: clamp(18px, 4.5vw, 24px) !important;
    line-height: 1.35 !important;
    padding: 0 12px;
  }
  .infinity-h2-sign {
    font-size: clamp(28px, 7vw, 40px) !important;
    line-height: 1.2 !important;
  }
  .main-grid-start {
    gap: 32px;
  }
  .main-loop-image {
    max-width: min(400px, 70vw);
  }
  .main-story-grid {
    gap: 32px;
  }
  .main-grid-3-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
  .main-grid-3-list .border-item {
    padding: 24px 20px;
  }
  .main-about-grid {
    gap: 40px;
  }
  .cta-grid {
    gap: 32px;
  }
}

/* Mobile devices (up to 767px) */
@media (max-width: 767px) {
  :root {
    --header-h: 70px; /* Approximate mobile header height */
  }
  .slider-section { 
    --hero-side-margin: 0 !important; 
    --hero-top-gap: 0 !important; 
    margin: 0 !important;
  }
  .main-hero-bg { 
    border-radius: 0 !important;
    margin: 0 !important;
    height: calc(100vh - var(--header-h)) !important;
    min-height: calc(100vh - var(--header-h)) !important;
    max-height: calc(100vh - var(--header-h)) !important;
  }
  .main-bacground-video.w-background-video video { border-radius: 0 !important; }
  .main-bacground-video.w-background-video {
    margin: 0 !important;
    height: calc(100vh - var(--header-h)) !important;
    min-height: calc(100vh - var(--header-h)) !important;
  }
}

/* Small mobile devices (up to 479px) */
@media (max-width: 479px) {
  :root {
    --header-h: 70px; /* Mobile header height */
  }
  .slider-section { 
    --hero-side-margin: 0 !important; 
    --hero-top-gap: 0 !important; 
    margin: 0 !important;
  }
  .main-hero-bg { 
    border-radius: 0 !important;
    margin: 0 !important;
    height: calc(100vh - var(--header-h)) !important;
    min-height: calc(100vh - var(--header-h)) !important;
    max-height: calc(100vh - var(--header-h)) !important;
  }
  .main-bacground-video.w-background-video video { border-radius: 0 !important; }
  .main-bacground-video.w-background-video {
    margin: 0 !important;
  }
  /* Further optimize for small screens */
  .slider-content {
    padding: clamp(10px, 2.5vh, 16px) clamp(12px, 3vw, 20px) clamp(12px, 2.5vh, 20px) !important;
  }
  .slider-h1 {
    font-size: clamp(28px, 7vw, 40px) !important;
    margin-bottom: clamp(2px, 0.8vh, 6px) !important;
  }
  .slider-h1.slider-h1-2,
  .slider-h1.slider-h1-3 {
    font-size: clamp(28px, 7vw, 40px) !important;
    margin-top: clamp(1px, 0.4vh, 3px) !important;
  }
  #heroSub {
    font-size: clamp(14px, 3.5vw, 18px) !important;
  }
  #heroDesc {
    font-size: clamp(13px, 3vw, 16px) !important;
  }
  .hero-cta,
  #heroCTA .w-button {
    padding: clamp(12px, 2.5vh, 16px) clamp(20px, 4vw, 28px) !important;
    font-size: clamp(13px, 3vw, 15px) !important;
  }
  .hero-arrow {
    width: clamp(40px, 9vw, 48px) !important;
    height: clamp(40px, 9vw, 48px) !important;
    font-size: clamp(20px, 4.5vw, 24px) !important;
  }
  #heroDots img {
    width: clamp(16px, 3.5vw, 20px) !important;
    height: clamp(16px, 3.5vw, 20px) !important;
  }
}

/* Slider transition animations */
@keyframes heroFadeIn { from { opacity: .15; } to { opacity: 1; } }
.main-hero-bg.hero-fade { animation: heroFadeIn .7s ease-in-out; }

/* Prevent FOUC on homepage hero: hide content until JS marks ready */
[data-hero-slider]:not([data-ready="1"]) .slider-h1,
[data-hero-slider]:not([data-ready="1"]) #heroSub,
[data-hero-slider]:not([data-ready="1"]) #heroDesc,
[data-hero-slider]:not([data-ready="1"]) #heroCTA,
[data-hero-slider]:not([data-ready="1"]) #heroDots,
[data-hero-slider]:not([data-ready="1"]) #heroPrev,
[data-hero-slider]:not([data-ready="1"]) #heroNext { visibility: hidden; }

@keyframes contentLiftIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
[data-hero-slider].content-fade .slider-h1,
[data-hero-slider].content-fade #heroSub,
[data-hero-slider].content-fade #heroDesc,
[data-hero-slider].content-fade #heroCTA { animation: contentLiftIn .55s ease-out both; }

/* Gentle stagger on hero headings for smoother perception */
[data-hero-slider].content-fade .slider-content-big-text .slider-h1:nth-child(1){ animation-delay: .01s; }
[data-hero-slider].content-fade .slider-content-big-text .slider-h1:nth-child(2){ animation-delay: .06s; }
[data-hero-slider].content-fade .slider-content-big-text .slider-h1:nth-child(3){ animation-delay: .1s; }

/* Directional slide animations */
@keyframes slideInFromRight { from { opacity:.0; transform: translateX(24px); } to { opacity:1; transform:none; } }
@keyframes slideInFromLeft { from { opacity:.0; transform: translateX(-24px); } to { opacity:1; transform:none; } }
[data-hero-slider].slide-next .slider-h1,
[data-hero-slider].slide-next #heroSub,
[data-hero-slider].slide-next #heroDesc,
[data-hero-slider].slide-next #heroCTA { animation: slideInFromRight .55s cubic-bezier(.2,.7,.2,1) both; }
[data-hero-slider].slide-prev .slider-h1,
[data-hero-slider].slide-prev #heroSub,
[data-hero-slider].slide-prev #heroDesc,
[data-hero-slider].slide-prev #heroCTA { animation: slideInFromLeft .55s cubic-bezier(.2,.7,.2,1) both; }

@keyframes bgShiftNext { from { transform: translateX(16px) scale(1.01); filter: brightness(1.02); } to { transform:none; filter:none; } }
@keyframes bgShiftPrev { from { transform: translateX(-16px) scale(1.01); filter: brightness(1.02); } to { transform:none; filter:none; } }
.main-hero-bg.bg-next { animation: bgShiftNext .7s ease-in-out; }
.main-hero-bg.bg-prev { animation: bgShiftPrev .7s ease-in-out; }

/* Header: ensure proper centered layout matching reference */
.navbar-wrapper-three {
  justify-content: center !important;
  align-items: center !important;
  position: relative !important;
  overflow: visible !important;
  width: 100% !important;
  display: flex !important;
  flex: 1 1 auto !important;
  align-self: stretch !important;
  padding: 0 !important;
  margin: 0 !important;
  min-height: fit-content !important;
  height: auto !important;
}

/* Hide hamburger button on desktop/laptop */
.menu-button.w-nav-button {
  display: none !important;
}
.navbar-brand-three {
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  z-index: 10 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  pointer-events: auto !important;
  overflow: visible !important;
  width: auto !important;
  max-width: none !important;
}
.navbar-brand-three a,
.navbar-brand-three {
  pointer-events: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.navbar-brand-three img {
  width: 140px !important;
  height: auto !important;
  display: block !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: contain !important;
  flex-shrink: 0 !important;
  min-width: 140px !important;
  overflow: visible !important;
}
@media (max-width: 991px) {
  .navbar-brand-three img { 
    width: 120px !important;
    min-width: 120px !important;
  }
}
.nav-menu-wrapper-three {
  width: 100% !important;
  position: relative !important;
  z-index: 5 !important;
  overflow: visible !important;
}
.nav-menu-three {
  justify-content: space-between !important;
  align-items: center !important;
  width: 100% !important;
  position: relative !important;
}
.nav-menu-block:first-child {
  justify-content: flex-start !important;
  position: relative !important;
  z-index: 6 !important;
}
.nav-menu-block:last-child {
  justify-content: flex-end !important;
  position: relative !important;
  z-index: 6 !important;
}
.main-bacground-video.w-background-video {
  height: calc(100vh + var(--extra-hero-height) - var(--header-h) - calc(var(--hero-side-margin) * 2));
  min-height: calc(100vh + var(--extra-hero-height) - var(--header-h) - calc(var(--hero-side-margin) * 2));
  display: flex;
  align-items: center;
  justify-content: center;
  margin: var(--hero-side-margin);
}
.main-bacground-video.w-background-video { margin-top: 0 !important; }
/* With top margin removed, increase height and push sections accordingly */
.main-bacground-video.w-background-video {
  height: calc(100vh + var(--extra-hero-height) - var(--header-h) - var(--hero-side-margin)) !important;
  min-height: calc(100vh + var(--extra-hero-height) - var(--header-h) - var(--hero-side-margin)) !important;
}
.main-hero-bg {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  /* Decrease height by the outer margin so the whole wrapper fits viewport */
  height: calc(100vh - var(--header-h) - var(--hero-side-margin) - var(--hero-top-gap));
  min-height: calc(100vh - var(--header-h) - var(--hero-side-margin) - var(--hero-top-gap));
  position: relative;
  overflow: hidden;
  margin: var(--hero-top-gap) var(--hero-side-margin) var(--hero-side-margin);
  border-radius: 20px;
}
/* Dark overlay on hero slider background for better text visibility */
.main-hero-bg::after { 
  content:""; 
  position:absolute; 
  inset:0; 
  background:rgba(0,0,0,.2); 
  pointer-events:none; 
  z-index: 1; 
}

/* Dark overlay on video background */
.main-bacground-video.w-background-video::after {
  content:""; 
  position:absolute; 
  inset:0; 
  background:rgba(0,0,0,.2); 
  pointer-events:none; 
  z-index: 1; 
}

/* Slide 2: ensure full coverage and better focal point */
.main-hero-bg[data-slide-idx="1"] {
  background-size: cover !important;
  background-position: 50% 40% !important; /* nudge focal point slightly up */
}
.main-bacground-video.w-background-video video {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: 20px !important;
}

/* Home: color for secondary phrase in hero headline */
.main-section-1 .main-text-h1 .text-span { color: #738EB3 !important; }

/* Header: user hover dropdown */
.user-dd { position: relative; }
.user-dd .user-link { display:inline-flex; align-items:center; }
.user-dd-panel {
  position: absolute;
  right: 0;
  top: calc(100% - 6px);
  margin-top: 0;
  width: 160px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  box-shadow: 0 12px 30px rgba(0,0,0,.12);
  padding: 14px;
  display: none;
  z-index: 1000;
}
.user-dd-panel::before { content:""; position:absolute; left:0; right:0; top:-12px; height:12px; }
.user-dd.is-open .user-dd-panel { display: block; }
.user-dd:hover .user-dd-panel { display: block; }
.user-dd-form .form-row { margin-bottom: 10px; }
.user-dd-form .w-input,
.user-dd-form input[type="text"],
.user-dd-form input[type="password"],
.user-dd-form input[type="email"] { width:100%; box-sizing:border-box; border:1px solid #cbd5e1; border-radius:10px; padding:10px 12px; }
.user-dd .user-dd-toggle + .user-dd-panel { width: 320px; }
.user-dd-form .form-row-split { display:flex; align-items:center; justify-content:space-between; }
.user-dd-form .remember-inline { display:flex; align-items:center; gap:6px; font-size:12px; color:#374151; }
.user-dd-link { font-size:12px; color:#1f2937; text-decoration:underline; }
.user-dd-submit { width:100%; background:#0f2747; color:#fff; padding:10px 14px; border-radius:10px; border:0; cursor:pointer; }
.user-dd-divider { height:1px; background:#e5e7eb; margin:10px 0; }
.user-dd-signup { display:block; text-align:center; width:100%; background:#eef2f7; color:#0f2747; padding:10px 14px; border-radius:10px; }
/* Header dropdown: notification styling */
.user-dd-panel .w-form-fail {
  margin-top: 0;
  margin-bottom: 12px;
  padding: 10px 12px;
  font-size: 13px;
  border-radius: 6px;
}
.user-dd-panel .w-form-success {
  margin-top: 0;
  margin-bottom: 12px;
  padding: 10px 12px;
  font-size: 13px;
  border-radius: 6px;
}

/* Header dropdown: button styles */
.user-dd-btn {
  display:block;
  width:100%;
  text-align:center;
  padding:10px 14px;
  border-radius:10px;
  font-weight:600;
  text-decoration:none;
  border:1px solid transparent;
}
.user-dd-btn + .user-dd-btn { margin-top:10px; }
.user-dd-btn.is-neutral { background:#eef2f7; color:#0f2747; }
.user-dd-btn.is-neutral:hover { filter:brightness(0.97); }
.user-dd-btn.is-danger { background:#ef4444; color:#fff; }
.user-dd-btn.is-danger:hover { filter:brightness(0.95); }

/* Shift hero overlay content up by header height so internal elements align */
.slider-content {
  position: relative;
  top: calc(-1 * var(--header-h));
}

/* Home hero: force overlay content to use full hero height */
.slider-content { top: 0 !important; margin-top: 0 !important; height: 100%; position: relative; }

/* Top-left titles */
.slider-content-big-text { 
  position: absolute; 
  top: calc(var(--hero-side-margin) + 8px); 
  left: calc(var(--hero-side-margin) + 8px); 
  padding: 0 !important; 
  margin: 0 !important; 
  max-width: calc(100% - calc(var(--hero-side-margin) * 2) - 16px);
}
/* Laptop: adjust positioning */
@media (max-width: 1728px) and (min-width: 1024px) {
  .slider-content-big-text {
    top: calc(var(--hero-side-margin) + clamp(8px, 1.5vh, 16px));
    left: calc(var(--hero-side-margin) + clamp(8px, 1.5vw, 16px));
    max-width: calc(100% - calc(var(--hero-side-margin) * 2) - clamp(16px, 3vw, 32px));
  }
}
@media (max-width: 1024px) {
  .slider-content-big-text {
    max-width: calc(100% - calc(var(--hero-side-margin) * 2) - 8px);
  }
}

/* Bottom-right supplemental content */
.hero-bottom-right { 
  position: absolute; 
  right: calc(var(--hero-side-margin) + 48px); 
  bottom: clamp(56px, 12vh, 180px); 
  text-align: right; 
  display: flex; 
  flex-direction: column; 
  gap: 10px; 
  align-items: flex-end; 
  max-width: calc(100% - calc(var(--hero-side-margin) * 2) - 96px);
}
/* Laptop: adjust bottom-right positioning */
@media (max-width: 1728px) and (min-width: 1024px) {
  .hero-bottom-right {
    right: calc(var(--hero-side-margin) + clamp(24px, 3vw, 40px));
    bottom: clamp(48px, 10vh, 160px);
    max-width: calc(100% - calc(var(--hero-side-margin) * 2) - clamp(48px, 6vw, 80px));
  }
}
@media (max-width: 1024px) {
  .hero-bottom-right {
    right: calc(var(--hero-side-margin) + 24px);
    bottom: clamp(48px, 10vh, 160px);
    max-width: calc(100% - calc(var(--hero-side-margin) * 2) - 48px);
  }
}

/* Tablet: improve arrow sizing and positioning */
@media (max-width: 1024px) and (min-width: 768px) {
  .slider-h1 {
    font-size: clamp(36px, 7vw, 56px) !important;
    margin-bottom: clamp(1.5rem, 2vh, 2.5rem) !important;
  }
  .slider-h1.slider-h1-2 {
    margin-left: clamp(25px, 4vw, 50px) !important;
    margin-top: clamp(20px, 3vh, 35px) !important;
  }
  .slider-h1.slider-h1-3 {
    margin-left: clamp(50px, 7vw, 120px) !important;
    margin-top: clamp(20px, 3vh, 35px) !important;
  }
  .hero-arrow {
    width: 40px;
    height: 40px;
    font-size: 24px;
  }
  #heroPrev { left: clamp(12px, 1.5vw, 20px) !important; }
  #heroNext { right: clamp(12px, 1.5vw, 20px) !important; }
  #heroDots img { 
    width: clamp(20px, 3vw, 32px) !important; 
    height: clamp(20px, 3vw, 32px) !important; 
  }
  #heroSub,
  #heroDesc {
    font-size: clamp(14px, 2vw, 18px) !important;
  }
}

/* Mobile: stack content and optimize for touch */
@media (max-width: 767px){
  /* Prevent scroll effects on hero slider container - but allow slider animations */
  .slider-section {
    position: relative !important;
    /* Don't override transform here - let slider animations work */
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    will-change: auto !important;
  }
  
  /* Prevent parallax background but allow slider animations */
  .main-hero-bg {
    position: relative !important;
    /* Don't override transform - allow bg-next/bg-prev animations */
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    background-attachment: scroll !important;
    background-position: center center !important;
  }
  
  /* Prevent scroll-based transforms on content but allow slider animations */
  .slider-content { 
    height: 100%;
    min-height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 0;
    padding: clamp(12px, 3vh, 20px) clamp(16px, 4vw, 24px) clamp(16px, 3vh, 24px) !important;
    margin: 0 !important;
    position: relative !important;
    /* Don't override transform - allow slide-next/slide-prev/content-fade animations */
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
  }
  
  /* Prevent scroll-based transforms on static elements */
  .slider-content:not(.slide-next):not(.slide-prev):not(.content-fade),
  .main-hero-bg:not(.bg-next):not(.bg-prev):not(.hero-fade) {
    transform: none !important;
  }
  
  /* Completely disable reveal-on-scroll effects on hero slider elements */
  .slider-section .reveal-on-scroll,
  .main-hero-bg .reveal-on-scroll,
  [data-hero-slider] .reveal-on-scroll,
  .slider-content .reveal-on-scroll,
  .slider-content-big-text .reveal-on-scroll,
  .hero-bottom-right .reveal-on-scroll,
  .slider-h1.reveal-on-scroll,
  #heroSub.reveal-on-scroll,
  #heroDesc.reveal-on-scroll,
  #heroCTA.reveal-on-scroll {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
    animation: none !important;
  }
  
  /* Ensure no scroll-based position changes */
  .slider-section,
  .main-hero-bg,
  .slider-content,
  .slider-content-big-text,
  .hero-bottom-right {
    /* Prevent any scroll-based positioning */
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
  }
  .slider-content-big-text, .hero-bottom-right { 
    position: static !important; 
    text-align: left !important; 
    align-items: flex-start !important; 
    margin: 0 !important;
    width: 100%;
    max-width: 100%;
    transform: none !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
  }
  .slider-content-big-text {
    padding: 0 !important;
    margin-bottom: clamp(16px, 4vh, 32px) !important;
    order: 1;
    flex-shrink: 0;
  }
  /* Optimized mobile font sizes for hero titles */
  .slider-h1 {
    font-size: clamp(32px, 8vw, 48px) !important;
    line-height: 1.15 !important;
    margin-bottom: clamp(4px, 1vh, 8px) !important;
    font-weight: 700 !important;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
    letter-spacing: -0.02em !important;
    position: static !important;
    transform: none !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
  }
  /* Remove left margins on mobile for slider-h1-2 and slider-h1-3 */
  .slider-h1.slider-h1-2,
  .slider-h1.slider-h1-3 {
    margin-left: 0 !important;
    margin-top: clamp(2px, 0.5vh, 4px) !important;
    font-size: clamp(32px, 8vw, 48px) !important;
  }
  /* Create bottom container for description, button, and dots */
  .hero-bottom-right {
    order: 2;
    margin-top: auto !important;
    margin-bottom: 0 !important;
    gap: clamp(10px, 2vh, 16px) !important;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
  }
  /* Optimize subtitle and description text for mobile */
  #heroSub {
    font-size: clamp(16px, 4vw, 20px) !important;
    line-height: 1.4 !important;
    margin-bottom: clamp(4px, 1vh, 8px) !important;
    font-weight: 500 !important;
    position: static !important;
    transform: none !important;
  }
  #heroDesc {
    font-size: clamp(14px, 3.5vw, 18px) !important;
    line-height: 1.5 !important;
    margin-bottom: clamp(8px, 2vh, 12px) !important;
    position: static !important;
    transform: none !important;
  }
  /* Optimize CTA button for mobile */
  #heroCTA {
    margin-top: clamp(8px, 2vh, 12px) !important;
    width: 100%;
  }
  .hero-cta,
  #heroCTA .w-button {
    width: 100% !important;
    max-width: 100% !important;
    padding: clamp(14px, 3vh, 18px) clamp(24px, 5vw, 32px) !important;
    font-size: clamp(14px, 3.5vw, 16px) !important;
    font-weight: 600 !important;
    border-radius: 12px !important;
    text-align: center !important;
    display: block !important;
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0.3);
    touch-action: manipulation;
    min-height: 48px !important; /* Better touch target */
  }
  /* Move hero dots to align with bottom content - override inline styles */
  #heroDots {
    position: static !important;
    left: auto !important;
    bottom: auto !important;
    transform: none !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: clamp(8px, 2vw, 12px) !important;
    margin: clamp(12px, 3vh, 20px) 0 0 0 !important;
    padding: 0 !important;
    order: 3 !important;
    z-index: auto !important;
    flex-wrap: wrap;
    width: 100% !important;
    flex-shrink: 0;
  }
  #heroDots img {
    width: clamp(18px, 4vw, 22px) !important;
    height: clamp(18px, 4vw, 22px) !important;
    /* Better touch target on mobile - minimum 44x44px for accessibility */
    min-width: 44px;
    min-height: 44px;
    padding: 12px;
    box-sizing: border-box;
    cursor: pointer;
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0.3);
    touch-action: manipulation;
    transition: transform 0.2s ease, opacity 0.2s ease;
  }
  #heroDots img:active {
    transform: scale(0.95);
    opacity: 0.8;
  }
  /* Optimize arrow buttons for mobile */
  .hero-arrow {
    width: clamp(44px, 10vw, 52px) !important;
    height: clamp(44px, 10vw, 52px) !important;
    font-size: clamp(24px, 5vw, 28px) !important;
    border-radius: 12px !important;
    background: rgba(255, 255, 255, 0.15) !important;
    border: 1px solid rgba(255, 255, 255, 0.4) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0.3);
    touch-action: manipulation;
    transition: background 0.2s ease, transform 0.2s ease !important;
    min-width: 44px !important;
    min-height: 44px !important;
  }
  .hero-arrow:active {
    background: rgba(255, 255, 255, 0.25) !important;
    transform: translateY(-50%) scale(0.95) !important;
  }
  #heroPrev {
    left: clamp(8px, 2vw, 16px) !important;
  }
  #heroNext {
    right: clamp(8px, 2vw, 16px) !important;
  }
  /* Ensure proper spacing for stacked content */
  .slider-content-big-text + .hero-bottom-right {
    margin-top: clamp(16px, 4vh, 32px) !important;
  }
  /* Optimize container for mobile - full screen */
  .main-hero-bg .container-full {
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    height: 100%;
    margin: 0 !important;
  }
  .slider-section .container-full {
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin: 0 !important;
  }
  /* Performance: reduce animation complexity on mobile */
  [data-hero-slider].content-fade .slider-h1,
  [data-hero-slider].content-fade #heroSub,
  [data-hero-slider].content-fade #heroDesc,
  [data-hero-slider].content-fade #heroCTA {
    animation-duration: 0.4s !important; /* Faster on mobile */
  }
  [data-hero-slider].slide-next .slider-h1,
  [data-hero-slider].slide-next #heroSub,
  [data-hero-slider].slide-next #heroDesc,
  [data-hero-slider].slide-next #heroCTA,
  [data-hero-slider].slide-prev .slider-h1,
  [data-hero-slider].slide-prev #heroSub,
  [data-hero-slider].slide-prev #heroDesc,
  [data-hero-slider].slide-prev #heroCTA {
    animation-duration: 0.4s !important; /* Faster transitions */
  }
  .main-hero-bg.hero-fade {
    animation-duration: 0.5s !important; /* Faster background fade */
  }
  .main-hero-bg.bg-next,
  .main-hero-bg.bg-prev {
    animation-duration: 0.5s !important; /* Faster background shift */
  }
}

/* Slide 4 (Staples): move staples to bottom center, text above it */
[data-hero-slider][data-slide-idx="3"] #heroStaples {
  position: absolute;
  left: calc(var(--hero-side-margin) + 16px);
  transform: none;
  bottom: calc(var(--hero-side-margin) + 12px);
  display: block !important;
  z-index: 2; /* keep below dots */
}
[data-hero-slider][data-slide-idx="3"] .hero-bottom-right {
  bottom: max(calc(var(--hero-side-margin) + 100px), 12vh);
}
/* Lift dots above staples on slide 4 */
@media (min-width: 768px) {
  [data-hero-slider][data-slide-idx="3"] #heroDots { bottom: 80px !important; z-index: 10 !important; }
}
/* Mobile: adjust staples slide positioning */
@media (max-width: 767px) {
  [data-hero-slider][data-slide-idx="3"] #heroStaples {
    position: static !important;
    left: auto !important;
    bottom: auto !important;
    margin-top: clamp(12px, 3vh, 20px) !important;
    order: 2.5 !important;
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
  }
  [data-hero-slider][data-slide-idx="3"] .hero-bottom-right {
    bottom: auto !important;
    position: static !important;
  }
  [data-hero-slider][data-slide-idx="3"] #heroDots {
    bottom: auto !important;
    position: static !important;
    z-index: auto !important;
  }
}

/* When slide 2 is active, tighten hero typography and spacing */
[data-hero-slider][data-slide-idx="1"] .slider-h1 { margin-bottom: 10px !important; }
[data-hero-slider][data-slide-idx="1"] .slider-h1.slider-h1-2,
[data-hero-slider][data-slide-idx="1"] .slider-h1.slider-h1-3 { margin-top: 6px !important; }
[data-hero-slider][data-slide-idx="1"] #heroSub { font-size: clamp(18px, 2vw, 24px); color:#232f50; max-width: 900px; }
[data-hero-slider][data-slide-idx="1"] #heroDesc { max-width: 900px; }

/* Desktop-only: Increase font-size for hero slide subtitle and description */
@media (min-width: 992px) {
  #heroSub,
  #heroDesc,
  [data-hero-slider][data-slide-idx="1"] #heroSub,
  [data-hero-slider][data-slide-idx="1"] #heroDesc {
    font-size: clamp(19px, 2vw, 26px) !important;
  }
}

/* Force white text for slides 1 and 2 (titles, sub, desc) */
[data-hero-slider][data-slide-idx="0"] .slider-h1,
[data-hero-slider][data-slide-idx="1"] .slider-h1,
[data-hero-slider][data-slide-idx="2"] .slider-h1,
[data-hero-slider][data-slide-idx="3"] .slider-h1,
[data-hero-slider][data-slide-idx="4"] .slider-h1,
[data-hero-slider][data-slide-idx="5"] .slider-h1,
[data-hero-slider][data-slide-idx="0"] #heroSub,
[data-hero-slider][data-slide-idx="1"] #heroSub,
[data-hero-slider][data-slide-idx="2"] #heroSub,
[data-hero-slider][data-slide-idx="3"] #heroSub,
[data-hero-slider][data-slide-idx="4"] #heroSub,
[data-hero-slider][data-slide-idx="5"] #heroSub,
[data-hero-slider][data-slide-idx="0"] #heroDesc,
[data-hero-slider][data-slide-idx="1"] #heroDesc,
[data-hero-slider][data-slide-idx="2"] #heroDesc,
[data-hero-slider][data-slide-idx="3"] #heroDesc,
[data-hero-slider][data-slide-idx="4"] #heroDesc,
[data-hero-slider][data-slide-idx="5"] #heroDesc { color: #fff !important; }

/* White CTA style on slides 1 and 2 */
[data-hero-slider][data-slide-idx="0"] #heroCTA .w-button,
[data-hero-slider][data-slide-idx="1"] #heroCTA .w-button,
[data-hero-slider][data-slide-idx="2"] #heroCTA .w-button,
[data-hero-slider][data-slide-idx="3"] #heroCTA .w-button,
[data-hero-slider][data-slide-idx="4"] #heroCTA .w-button,
[data-hero-slider][data-slide-idx="5"] #heroCTA .w-button {
  background: rgba(255,255,255,.06) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.5) !important;
  backdrop-filter: blur(2px);
}
@media (hover: hover){
  [data-hero-slider][data-slide-idx="0"] #heroCTA .w-button:hover,
  [data-hero-slider][data-slide-idx="1"] #heroCTA .w-button:hover,
  [data-hero-slider][data-slide-idx="2"] #heroCTA .w-button:hover,
  [data-hero-slider][data-slide-idx="3"] #heroCTA .w-button:hover,
  [data-hero-slider][data-slide-idx="4"] #heroCTA .w-button:hover,
  [data-hero-slider][data-slide-idx="5"] #heroCTA .w-button:hover { background: rgba(255,255,255,.16) !important; }
}

/* Slider-specific CTA variant: remove left icon and adjust padding */
.hero-cta {
  background-image: none !important;
  padding: 15px 30px !important;
}

/* Hero slider arrows */
[data-hero-slider] { position: static; }
.hero-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(40px, 5vw, 48px);
  height: clamp(40px, 5vw, 48px);
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.08);
  color: #fff;
  cursor: pointer;
  display: flex; 
  align-items:center; 
  justify-content:center;
  font-size: clamp(20px, 3vw, 28px);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: background .2s ease, transform .2s ease;
  z-index: 10;
}
#heroPrev { left: clamp(8px, 2vw, 24px) !important; transform: translateY(-50%); }
#heroNext { right: clamp(8px, 2vw, 24px) !important; transform: translateY(-50%); }
/* Base styles for hero dots container - desktop */
@media (min-width: 768px) {
  .slider-section #heroDots,
  [data-hero-slider] #heroDots { 
    z-index: 10 !important;
    position: absolute !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    bottom: 80px !important;
    display: inline-flex !important;
    gap: 6px !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
  }
  /* Laptop: adjust dots positioning */
  @media (max-width: 1728px) and (min-width: 1024px) {
    .slider-section #heroDots,
    [data-hero-slider] #heroDots {
      bottom: clamp(56px, 7vh, 80px) !important;
    }
  }
}

/* Hero stone dots: white border and gentle hover */
#heroDots img { 
  width: clamp(28px, 5vw, 48px); 
  height: clamp(28px, 5vw, 48px); 
  transition: transform .18s ease; 
  transform-origin: center; 
  border: 2px solid #fff; 
  border-radius: 50%; 
  box-sizing: border-box; 
}
@media (hover: hover) {
  #heroDots img:hover { transform: scale(1.15); }
}

.hero-arrow:hover { background: rgba(255,255,255,.16); }
.hero-arrow:active { transform: translateY(-50%) scale(.98); }

/* Hero background video (disabled in favor of images) */
.hero-bg-video { display: none !important; }
/* Ensure overlay content sits above the background video */
.main-hero-bg { position: relative; }
.slider-content { z-index: 2; position: relative; }
.slider-content-big-text { z-index: 2; position: relative; }

/* Style for animated main-4 video to match previous image sizing */
.main-about-image-block {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
  aspect-ratio: 16 / 9;
  background: transparent; /* let section background show behind video */
  padding: 0 !important; /* remove base padding that can reveal bg */
}
.main-4-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: contain; /* revert to original framing */
  background: transparent; /* show parent (section) background in letterboxing */
  padding: 12px; /* revert to original inner spacing */
  box-sizing: border-box; /* ensure padding shrinks content instead of overflowing */
  display: block;
  mix-blend-mode: screen !important; /* make black blend into the section background */
}

/* Hard-disable any animations/transforms on the homepage About video area */
.main-about-section .main-about-image-block,
.main-about-section .main-4-video {
  transition: none !important;
  animation: none !important;
  transform: none !important;
}

/* Hide video until it's ready to play to avoid initial black frame */
.main-4-video { visibility: hidden; }
.main-4-video.is-ready { visibility: visible; }

/* Shop: remove background color on "Our INFINITY Offerings" tiles */
.shop-main-image-block-item { background: transparent !important; }
.shop-image-block { background: transparent !important; }

/* Shop: center the offering tiles; force four across on desktop */
.shop-main-image-block {
  justify-content: center !important;
  justify-items: center !important;
  place-content: center !important;
  place-items: center !important;
  grid-template-columns: repeat(4, auto) !important;
  column-gap: 32px !important;
}
.shop-main-image-block .shop-main-image-block-item { justify-self: center !important; text-align: center; }

/* Shop: enforce circular category icons */
.shop-main-image-block .shop-image-block {
  width: auto; /* keep original width */
  height: auto; /* keep original height */
  border-radius: 50%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.shop-main-image-block .shop-image-block img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}
/* No fixed size on mobile; circle masks the existing size */

@media (max-width: 991px) {
  .shop-main-image-block { grid-template-columns: repeat(2, auto) !important; }
}
@media (max-width: 479px) {
  .shop-main-image-block { grid-template-columns: 1fr !important; }
}

/* Product detail layout */
.product-detail-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 40px; align-items: start; }
.product-gallery .product-hero-image { 
  width: 100%; 
  height: 500px; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  background-color: #f9fafb; 
  border-radius: 12px; 
  overflow: hidden; 
}
.product-gallery .product-hero-image img { 
  width: 100%; 
  height: 100%; 
  object-fit: cover; 
  object-position: center; 
  border-radius: 12px; 
  display: block; 
}
.product-dots { margin-top: 12px; text-align: center; }
.product-dots .dot { display: inline-block; width: 8px; height: 8px; background:#cfd4de; border-radius:50%; margin: 0 4px; }
.product-dots .dot.active { background:#232f50; }
.product-meta .product-kicker { font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color:#6b7280; }
.product-meta .product-title { margin: 6px 0 8px; font-size: 1.05em !important; }
.product-price { font-size: 21px; font-weight: 600; color:#232f50; margin-bottom: 12px; }
.product-short { color:#374151; font-size: 1.02em !important; }
.product-long { font-size: 1.02em !important; }
.product-info .sub-page-p-small { font-size: 1.02em !important; }
.product-chips { display:flex; flex-wrap: wrap; gap:8px; margin: 12px 0 16px; }
.product-chips .chip { background:#eef2f7; color:#111827; padding:6px 10px; border-radius:999px; font-size:12px; }
.product-cta-row { display:flex; align-items:center; gap:16px; margin: 14px 0 10px; }
.button-primary { 
  background:#232f50; 
  color:#fff; 
  padding:12px 18px; 
  border-radius:8px; 
  text-decoration:none; 
  transition: all 0.3s ease;
  display: inline-block;
}
.button-primary:hover {
  background:#1a2540;
  transform: translateY(-4px);
  box-shadow: 0 6px 16px rgba(35, 47, 80, 0.4);
}
.sub-note { font-size:12px; color:#6b7280; }
.product-benefits { display:flex; gap:10px; margin-top:10px; flex-wrap:wrap; }
.benefit-pill { border:1px solid #e5e7eb; padding:6px 10px; border-radius:999px; font-size:12px; }
.product-info-grid { display:grid; gap:30px; grid-template-columns: repeat(3, 1fr); }
.product-info-col .ul-clean { margin:0; padding-left:18px; }
@media (max-width: 991px){ .product-detail-grid{ grid-template-columns: 1fr; } }

/* Product detail page font sizes */
.product-info-left .sub-page-h1-small,
.product-accordion-right .sub-page-h1-small,
.product-info-left .sub-page-p-small,
.product-accordion-right .sub-page-p-small,
.product-accordion-right .acc-text {
  font-size: 1.02em !important;
}

/* Product: vertical details under Buy now */
.product-details-vertical { margin-top: 16px; display:flex; flex-direction:column; gap:18px; }
.product-details-vertical .p-block { border-top:1px solid #e5e7eb; padding-top:12px; }
.product-details-vertical .ul-clean { margin:6px 0 0; padding-left:18px; }

/* Product: new under-image layout */
.product-extra-grid { display:grid; grid-template-columns: 1.2fr 1fr; gap: 40px; align-items: start; }
.product-accordion-right .acc-list { border-top:1px solid #e5e7eb; }
.product-accordion-right .acc-item { border-bottom:1px solid #e5e7eb; }
.product-accordion-right .acc-title { position:relative; cursor:pointer; padding:16px 0; font-weight:600; margin:0; }
.product-accordion-right .acc-title::after { content:'+'; position:absolute; right:0; top:50%; transform:translateY(-50%); font-size:24px; transition: transform .2s ease; }
.product-accordion-right .acc-item.open .acc-title::after { transform: translateY(-50%) rotate(45deg); }
.product-accordion-right .acc-text { display:none; padding:8px 0 16px; }
.product-accordion-right .acc-item.open .acc-text { display:block; }
@media (max-width: 991px){ .product-extra-grid { grid-template-columns: 1fr; gap:24px; } }

/* Business page: make package images equal size */
.business-packages-grid .business-grid-image-block { width:100%; max-width: 300px; height: 180px; aspect-ratio: auto !important; }
.business-packages-grid .business-grid-image-block img { width:100%; height:100%; object-fit: cover; display:block; border-radius: 12px; }
/* Business page: subtle hover nudge on package blocks */
.business-grid-sub-grid { transition: transform .25s ease, box-shadow .25s ease; border-radius: 14px; }
.business-grid-sub-grid:hover { transform: translateY(-4px); box-shadow: 0 10px 28px rgba(0,0,0,.10); }

/* Checkout email page */
.checkout-email-wrapper { display:flex; justify-content:center; align-items:center; padding:60px 0; }
.checkout-email-card { max-width: 720px; width:100%; background:#fff; border:1px solid #e5e7eb; border-radius:20px; padding:40px 28px; }
.checkout-title { font-size:42px; font-weight:700; margin:0 0 16px; }
.checkout-sub { font-size:22px; color:#374151; margin-bottom:24px; }
.checkout-email-form { margin-top:10px; }
.checkout-input-row { display:flex; align-items:center; gap:10px; border:1px solid #cbd5e1; border-radius:999px; padding:6px 10px; }
.checkout-email-input { flex:1; border:0; outline:none; font-size:18px; padding:10px 14px; }
.checkout-arrow { width:44px; height:44px; border-radius:50%; border:1px solid #cbd5e1; background:#fff; cursor:pointer; font-size:20px; }
.checkout-note { font-size:12px; color:#6b7280; margin-top:10px; }

/* Testimonials: set themed background color for "Themes We've Worked With" only on testimonials page */
.sub-page-colored-section-block.is-testimonials { background-color: #3C7A4C !important; border-radius: 20px; padding: 40px 24px; }

/* Testimonials: color the entire section when flagged */
.testimonials-green { background-color: #3C7A4C !important; }
.testimonials-green * { color: #fff; }

/* Testimonials hero: clone typography from what-is-infinity hero */
.background-3-testimonials .sub-hero-h2-black,
.background-3-testimonials .sub-her-h1-black,
.background-3-testimonials .sub-hero-desc-block,
.background-3-testimonials .sub-hero-content-block,
.background-3-testimonials .sub-hero-h2,
.background-3-testimonials .sub-hero-h1 {
  color: #fff !important;
}
.background-3-testimonials .sub-her-h1-black { font-size: 44px !important; }
.background-3-testimonials .sub-hero-h2-black { font-size: clamp(18px, 2.6vw, 36px) !important; }
.background-3-testimonials .sub-hero-h2-black { white-space: nowrap !important; }
.background-3-testimonials .sub-hero-desc-block p { color:#fff !important; font-size: clamp(18px, 1.7vw, 22px) !important; line-height: 1.6 !important; max-width: 760px; margin-top: 10px; }

/* Testimonials list layout */
.testimonial-list-block { max-width: 900px; margin: 0 auto; }
.testimonials-list-entry { margin: 16px 0; }
.testimonials-sep { text-align: center; opacity: .7; margin: 10px 0; }

/* Testimonials: reduce item quote size for better balance */
.testimonials-tab-item-h2 { font-size: clamp(16px, 1.6vw, 20px) !important; line-height: 1.5 !important; }

/* Testimonials: normalize button sizing to match offering */
.testimonials-tab-item-text-block .sub-page-focus-button-third,
.testimonials-page-last-block .sub-page-focus-button-third {
  padding: 8px 12px !important;
  border: 1px solid #a0a0a0 !important;
  border-radius: 10px !important;
  background: rgba(255,255,255,0.06) !important;
  box-shadow: none !important;
}
.testimonials-tab-item-text-block .sub-page-focus-button-third .focus-text,
.testimonials-page-last-block .sub-page-focus-button-third .focus-text {
  font-size: 13px !important;
  letter-spacing: 0 !important;
}

/* Variant to mimic About-Us secondary button */
.button-like-about { color: #111827 !important; background: rgba(255,255,255,0.06) !important; border:1px solid #a0a0a0 !important; border-radius:8px !important; padding: 6px 12px !important; background-image: none !important; box-shadow:none !important; }
.button-like-about:hover { background: rgba(255,255,255,0.12) !important; }

/* Testimonials: unify image size and fit behavior */
.testimonial-tab-item-image-block { width: 260px; height: 260px; display:flex; align-items:center; justify-content:center; overflow: visible !important; }
.testimonial-tab-image-background-block { overflow: visible !important; }
.testimonial-tab-image-sub-block { 
  max-width: none !important; 
  border-radius: 30px !important; 
  overflow: hidden !important; 
  position: absolute !important;
  inset: 20px -20px 0 20px !important;
}
.testimonial-tab-image-sub-block img { 
  width: 100% !important; 
  height: 100% !important; 
  object-fit: cover !important; 
  object-position: center center !important; 
  display: block !important; 
}
@media (max-width: 991px){
  .testimonial-tab-item-image-block { width: 200px; height: 200px; }
}

/* The Process page */
.process-journey-block { 
  margin-top: 40px; 
  max-width: 1080px; 
  margin-left: auto; 
  margin-right: auto; 
  width: 100%;
}
.process-tips {
  margin-top: 24px;
  background:#f8f9fa; 
  border:1px solid #e5e7eb; 
  border-left:4px solid var(--primary);
  border-radius:12px; 
  padding:18px;
  max-width: 1080px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  width: 100%;
}
.process-steps-grid { 
  display:grid; 
  grid-template-columns: repeat(3, 1fr); 
  gap: 28px !important; 
  align-items: stretch; 
}
.process-step {
  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding: 28px 24px !important;
  display:flex;
  flex-direction:column;
  gap:8px;
  box-shadow: 0 6px 20px rgba(0,0,0,.05);
  transition: transform .18s ease, box-shadow .18s ease;
}
.process-step:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(0,0,0,.08); }
.process-icon {
  width: 52px !important; 
  height: 52px !important; 
  border-radius:50%; 
  background:#232f50; 
  color:#fff;
  display:flex; 
  align-items:center; 
  justify-content:center; 
  font-weight:700;
  font-size: 22px !important;
  box-shadow: 0 0 0 6px rgba(35,47,80,.08);
  margin-bottom: 14px !important;
}
.process-step h3 { 
  margin: 8px 0 8px !important; 
  font-size: 24px !important;
  line-height: 1.3 !important;
}
.process-step p { 
  margin: 0; 
  font-size: 17px !important;
  line-height: 1.6 !important;
}
.process-cta-grid { display:flex; gap:14px; align-items:center; justify-content:center; margin-top: 24px; flex-wrap: wrap; }

/* Desktop styles - ensure they apply above 768px */
@media (min-width: 768px) {
  .process-steps-grid { 
    gap: 28px !important; 
  }
  .process-step {
    padding: 28px 24px !important;
  }
  .process-icon {
    width: 52px !important; 
    height: 52px !important; 
    font-size: 22px !important;
    margin-bottom: 14px !important;
  }
  .process-step h3 { 
    font-size: 24px !important;
  }
  .process-step p { 
    font-size: 17px !important;
  }
}

@media (max-width: 991px){ 
  .process-steps-grid { 
    grid-template-columns: repeat(2, 1fr) !important; 
    gap: 20px !important;
  } 
}
@media (max-width: 767px){ 
  .process-steps-grid { 
    grid-template-columns: 1fr !important; 
  } 
  .process-tips { 
    text-align: center; 
  } 
}
@media (max-width: 479px){ 
  .process-steps-grid { 
    grid-template-columns: 1fr !important; 
  } 
}

/* Our Partners page */
.partners-cta-grid { display:flex; gap:14px; align-items:center; justify-content:center; flex-wrap: wrap; margin: 20px 0; }
.partners-invite-card { background:#f8f9fa; border:1px solid #e5e7eb; border-radius:14px; padding:20px; margin-top: 16px; text-align:left; }
@media (max-width: 767px){ .partners-invite-card { text-align:center; } }

/* Offering slider */
.offering-focus-main-image-block[data-slider] { position: relative; display:grid; grid-template-columns: auto auto auto; gap:52px; align-items:center; justify-content:center; overflow:hidden; padding:32px 160px; max-width: 1320px; margin: 0 auto; transform: translateZ(0); }
.offering-focus-main-image-block .offering-focus-image-block { opacity:1; transition: transform .6s cubic-bezier(.22,.61,.36,1), opacity .6s ease; cursor:pointer; will-change: transform, opacity; backface-visibility: hidden; -webkit-backface-visibility: hidden; }
.offering-focus-main-image-block .offering-focus-image-block img { width:100%; height:100%; border-radius:50%; object-fit:cover; display:block; }
.offering-focus-main-image-block [data-role="prev"],
.offering-focus-main-image-block [data-role="next"] { width:260px; height:260px; }
.offering-focus-main-image-block [data-role="current"] { width:520px; height:520px; z-index:2; }
.offering-focus-main-image-block .slider-nav { position:absolute; top:50%; transform:translateY(-50%); width:48px; height:48px; border-radius:12px; border:1px solid rgba(0,0,0,.12); background: rgba(255,255,255,.9); cursor:pointer; z-index:3; display:flex; align-items:center; justify-content:center; box-shadow: 0 2px 8px rgba(0,0,0,.08); backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.offering-focus-main-image-block .slider-nav.prev { left:16px; }
.offering-focus-main-image-block .slider-nav.next { right:16px; }
.offering-focus-main-image-block .slider-nav:hover { background: #fff; }
.offering-focus-main-image-block .slider-nav:active { transform: translateY(-50%) scale(.98); }

/* Subtle motion between roles - scale only, no bounce */
[data-slider] [data-role="prev"] { transform: scale(0.96); }
[data-slider] [data-role="current"] { transform: scale(1.02); }
[data-slider] [data-role="next"] { transform: scale(0.96); }

/* Slider: indicate small images are clickable */
.offering-focus-main-image-block [data-role="prev"] img,
.offering-focus-main-image-block [data-role="next"] img {
  transition: transform .2s ease;
}
.offering-focus-main-image-block [data-role="prev"]:hover img,
.offering-focus-main-image-block [data-role="next"]:hover img {
  transform: scale(1.08);
}

/* Offering page buttons/links hover affordance */
.sub-page-main-focus-block .focus-link-block {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transform: none;
  transition: transform .2s ease, filter .2s ease;
}
.sub-page-main-focus-block .focus-link-block:hover { transform: translateX(8px); filter: brightness(1.05); }
.sub-page-main-focus-block .focus-link-block img { transition: transform .2s ease; }
.sub-page-main-focus-block .focus-link-block:hover img { transform: translateX(4px); }

/* Match homepage "Read More Health Stories" hover behavior for offering arrow links */
.sub-page-main-focus-block .focus-link-block { text-decoration: none; }
.sub-page-main-focus-block .focus-link-block:hover { transform: translateX(8px); }

.offering-focus-block .sub-page-focus-button-third {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transform: translateY(0) scale(1);
  transition: transform .2s ease, box-shadow .2s ease;
  box-shadow: 0 6px 16px rgba(0,0,0,.08);
}
.offering-focus-block .sub-page-focus-button-third:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
}
.offering-focus-block .sub-page-focus-button-third img { transition: transform .2s ease; }
.offering-focus-block .sub-page-focus-button-third:hover img { transform: translateX(4px); }

/* Carousel swap with precise distances so only items move (not the grid) */
/* Desktop sizes: prev/next 260px, current 520px, gap 52px ⇒ delta 442px */
[data-slider].anim-next [data-role="prev"] { transform: scale(0.90); opacity:0; }
[data-slider].anim-next [data-role="current"] { transform: scale(0.96); opacity:.9; z-index:2; }
[data-slider].anim-next [data-role="next"] { transform: scale(1.02); opacity:1; z-index:3; }

[data-slider].anim-prev [data-role="prev"] { transform: scale(1.02); opacity:1; z-index:3; }
[data-slider].anim-prev [data-role="current"] { transform: scale(0.96); opacity:.9; z-index:2; }
[data-slider].anim-prev [data-role="next"] { transform: scale(0.90); opacity:0; }

@media (max-width: 991px){
  .offering-focus-main-image-block [data-role="prev"],
  .offering-focus-main-image-block [data-role="next"] { width:140px; height:140px; }
  .offering-focus-main-image-block [data-role="current"] { width:300px; height:300px; }
  .offering-focus-main-image-block { gap:20px; padding:24px 96px; }
  .offering-focus-main-image-block .slider-nav.prev { left:16px; }
  .offering-focus-main-image-block .slider-nav.next { right:16px; }
  /* Mobile - scale only, no horizontal movement */
  [data-slider].anim-next [data-role="prev"] { transform: scale(0.90); opacity:0; }
  [data-slider].anim-next [data-role="current"] { transform: scale(0.96); opacity:.9; }
  [data-slider].anim-next [data-role="next"] { transform: scale(1.02); opacity:1; }
  [data-slider].anim-prev [data-role="prev"] { transform: scale(1.02); opacity:1; }
  [data-slider].anim-prev [data-role="current"] { transform: scale(0.96); opacity:.9; }
  [data-slider].anim-prev [data-role="next"] { transform: scale(0.90); opacity:0; }
}

/* Testimonial upload form minor styles */
.testimonial-upload-form .sub-note { color:#6b7280; font-size:12px; margin-top:6px; }
.testimonial-upload-form input[type="text"],
.testimonial-upload-form textarea {
  border:1px solid #cbd5e1; border-radius:10px; padding:10px 12px; outline:0;
}
/* Tighter, readable form typography for testimonial section */
.testimonial-upload-form .sub-page-h1 {
  font-size: clamp(16px, 2.2vw, 18px) !important;
  line-height: 1.4;
  margin: 0 0 6px !important;
}
.testimonial-upload-form .support-input,
.testimonial-upload-form textarea {
  font-size: 16px;
}
.testimonial-upload-form input[type="file"] { font-size: 14px; }
.testimonial-upload-form .button-second { font-size: 16px; padding: 10px 16px; }

/* Set Password: stack inputs vertically and add spacing */
.set-password-form { 
  display: block;
  width: 100%;
  max-width: 600px;
}
.set-password-form .form-block { margin-bottom: 12px; }
/* Set Password: ensure text inputs span full width - match password page style */
.set-password-form .w-input,
.set-password-form input[type="text"],
.set-password-form input[type="password"],
.set-password-form input[type="email"],
.set-password-form textarea,
.set-password-form select {
  width: 100% !important;
  max-width: 100% !important;
  display: block;
  box-sizing: border-box;
}
/* Set Password: make button match input width */
.set-password-form .login-button-block-colored,
.set-password-form .w-button,
.set-password-form input[type="submit"] {
  width: 100% !important;
  max-width: 100% !important;
}

/* Home: center align Health Stories quote and button */
.main-story-section .main-story-grid { align-items: stretch !important; }
.main-story-section .story-text {
  text-align: center !important;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  min-height: 100%;
  align-self: stretch !important;
  gap: 12px;
}
.main-story-section .story-text-1 { margin: 0; }
.main-story-section .read-more-story-btn { display: inline-block; }

/* Infinity experience images: force circular crop and centered fit */
.infinity-experience-grid-image-block { border-radius: 50% !important; overflow: hidden; display: flex; align-items: center; justify-content: center; aspect-ratio: 1 / 1; width: 100%; }
.infinity-experience-grid-image-block img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }

/* CTA image spacing: match default spacing across pages */
.cta-image img { display:block; margin: 0 auto; padding: 0; }

/* Enforce Rosario for the literal INFINITY wordmarks without bolding */
.infinity-h2-sign,
.inifinity-h1,
.inifinity-h1 *,
.infinity-word,
.infinity-word * {
  font-family: 'Rosario', sans-serif !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em;
}

/* INFINITY word in paragraphs and normal text - lighter weight */
p .infinity-word,
p .infinity-word *,
.text-block .infinity-word,
.text-block .infinity-word *,
.text-block-2 .infinity-word,
.text-block-2 .infinity-word *,
.text-block-3 .infinity-word,
.text-block-3 .infinity-word *,
.sub-page-p-small .infinity-word,
.sub-page-p-small .infinity-word *,
.main-about-p .infinity-word,
.main-about-p .infinity-word *,
.cta-p .infinity-word,
.cta-p .infinity-word *,
.footer-item p .infinity-word,
.footer-item p .infinity-word * {
  font-weight: 300 !important;
}

/* Keep headers bold (600) - explicitly maintain header weight */
h1 .infinity-word,
h1 .infinity-word *,
h2 .infinity-word,
h2 .infinity-word *,
h3 .infinity-word,
h3 .infinity-word *,
h4 .infinity-word,
h4 .infinity-word *,
h5 .infinity-word,
h5 .infinity-word *,
h6 .infinity-word,
h6 .infinity-word *,
.sub-page-h1-medium .infinity-word,
.sub-page-h1-medium .infinity-word *,
.sub-page-h1-medium-light .infinity-word,
.sub-page-h1-medium-light .infinity-word *,
.main-text-h1 .infinity-word,
.main-text-h1 .infinity-word *,
.inifinity-h1 .infinity-word,
.inifinity-h1 .infinity-word *,
.infinity-h2-sign .infinity-word,
.infinity-h2-sign .infinity-word * {
  font-weight: 600 !important;
}

/* Ensure buttons on desktop keep bold INFINITY word */
@media (min-width: 768px) {
  .button-second .infinity-word,
  .button-second .infinity-word *,
  .button-second-white .infinity-word,
  .button-second-white .infinity-word *,
  a.button-second .infinity-word,
  a.button-second .infinity-word *,
  a.button-second-white .infinity-word,
  a.button-second-white .infinity-word *,
  .w-button .infinity-word,
  .w-button .infinity-word * {
    font-weight: 600 !important;
  }
}

/* Override boldness for infinity-word in partner page buttons - MOBILE ONLY */
@media (max-width: 767px) {
  .sub-focus-grid-button-block .infinity-word,
  .focus-colored-grid-block .sub-focus-grid-button-block .infinity-word,
  .sub-focus-grid-button-block .button-second-white .infinity-word,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white .infinity-word,
  .sub-focus-grid-button-block .button-second .infinity-word,
  .sub-focus-grid-button-block a.button-second-white .infinity-word,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white .infinity-word,
  .sub-focus-grid-button-block a.button-second .infinity-word,
  .sub-focus-grid-button-block .button-second-white.w-button .infinity-word,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white.w-button .infinity-word,
  .sub-focus-grid-button-block .button-second.w-button .infinity-word,
  .sub-focus-grid-button-block a.button-second-white.w-button .infinity-word,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white.w-button .infinity-word,
  .sub-focus-grid-button-block a.button-second.w-button .infinity-word,
  .main-section-1 .sub-focus-grid-button-block .button-second-white .infinity-word,
  .main-section-1 .sub-focus-grid-button-block a.button-second-white .infinity-word {
    font-weight: 300 !important;
    font-style: normal !important;
  }

  .sub-focus-grid-button-block .infinity-word *,
  .focus-colored-grid-block .sub-focus-grid-button-block .infinity-word *,
  .sub-focus-grid-button-block .button-second-white .infinity-word *,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white .infinity-word *,
  .sub-focus-grid-button-block .button-second .infinity-word *,
  .sub-focus-grid-button-block a.button-second-white .infinity-word *,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white .infinity-word *,
  .sub-focus-grid-button-block a.button-second .infinity-word *,
  .sub-focus-grid-button-block .button-second-white.w-button .infinity-word *,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white.w-button .infinity-word *,
  .sub-focus-grid-button-block .button-second.w-button .infinity-word *,
  .sub-focus-grid-button-block a.button-second-white.w-button .infinity-word *,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white.w-button .infinity-word *,
  .sub-focus-grid-button-block a.button-second.w-button .infinity-word *,
  .main-section-1 .sub-focus-grid-button-block .button-second-white .infinity-word *,
  .main-section-1 .sub-focus-grid-button-block a.button-second-white .infinity-word * {
    font-weight: 300 !important;
    font-style: normal !important;
  }
}

/* Global mobile improvements */
/* Ensure media never overflows containers */
img, video { 
  max-width: 100%; 
  height: auto; 
}
/* Prevent horizontal overflow */
body, html {
  overflow-x: hidden;
  width: 100%;
}
.container-full {
  max-width: 100%;
  overflow-x: hidden;
}

/* Unify section spacing for small screens */
@media (max-width: 767px){
  .main-section-1, .main-section-2, .main-section-3, .main-story-section, .main-about-section { 
    padding-top: clamp(40px, 8vh, 60px) !important; 
    padding-bottom: clamp(40px, 8vh, 60px) !important; 
  }
  .footer { padding-top: 40px !important; padding-bottom: 40px !important; }
}
@media (max-width: 479px){
  .main-section-1, .main-section-2, .main-section-3, .main-story-section, .main-about-section { 
    padding-top: clamp(32px, 6vh, 48px) !important; 
    padding-bottom: clamp(32px, 6vh, 48px) !important; 
  }
}

/* Normalize mobile tap targets for common buttons (slightly smaller than desktop) */
@media (max-width: 767px){
  .w-button,
  .button-second,
  .button-primary,
  .product-button-block,
  .blog-button,
  .sub-page-focus-button,
  .sub-page-focus-button-second,
  .sub-page-focus-button-third,
  .login-button-block,
  .login-button-block-colored,
  .submit-button,
  .user-button,
  .user-button-colored,
  .ua-btn,
  .ua-btn-primary,
  .ua-btn-outline {
    min-height: 44px;
    padding-top: 10px;
    padding-bottom: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}

/* About Us CTA: responsive layout and spacing tweaks */
@media (max-width: 991px){
  .cta-section { padding-top: 80px; padding-bottom: 80px; }
  .cta-grid { grid-template-columns: 1fr; max-width: 680px; }
  .cta-item, .cta-image { text-align: center; }
  .cta-section .heading { font-size: 28px; line-height: 36px; }
  .cta-section .cta-p { font-size: 18px; line-height: 28px; margin-bottom: 24px; }
  .cta-section .button-second,
  .cta-section .button-second-white,
  .cta-section .sub-page-focus-button-third {
    padding: 12px 22px 12px 46px;
    background-position: 12px center;
    background-size: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .cta-image img { width: 140px; height: auto; margin: 16px auto 0; }
}

@media (max-width: 767px){
  .cta-section { padding-top: 60px; padding-bottom: 60px; }
  .cta-grid { row-gap: 10px; }
  .cta-section .heading { font-size: 24px; line-height: 32px; }
  .cta-section .cta-p { font-size: 16px; line-height: 26px; margin-bottom: 20px; }
  .cta-section .button-second,
  .cta-section .button-second-white,
  .cta-section .sub-page-focus-button-third {
    padding: 10px 18px 10px 42px;
    background-size: 16px;
  }
  .main-section-2 .button-second {
    padding: 10px 18px 10px 42px;
    background-size: 16px;
  }
  .cta-image img { width: 120px; }
}

@media (max-width: 479px){
  .cta-section { padding-top: 40px; padding-bottom: 40px; }
  .cta-section .heading { font-size: 22px; line-height: 30px; }
  .cta-section .cta-p { font-size: 15px; line-height: 24px; }
  .cta-section .button-second,
  .cta-section .button-second-white,
  .cta-section .sub-page-focus-button-third {
    padding: 10px 16px 10px 38px;
    background-position: 14px center;
    background-size: 16px;
    display: inline-flex; /* keep intrinsic button width */
  }
  .main-section-2 .button-second {
    padding: 10px 16px 10px 38px;
    background-position: 14px center;
    background-size: 16px;
  }
  .cta-image img { width: 100px; }
}

/* Sub-hero: maintain left-bottom positioning on mobile */
@media (max-width: 767px){
  .sub-hero-content-block { align-items: flex-start !important; justify-content: flex-end !important; }
  .sub-hero-h1, .sub-her-h1-black, .sub-hero-h2, .sub-hero-h2-black { text-align: left !important; float: left !important; }
  .sub-hero-desc-block { 
    position: absolute !important; 
    bottom: 10px !important; 
    left: 10px !important; 
    right: auto !important; 
    max-width: 100% !important; 
    text-align: left !important; 
    padding: 0 16px !important;
  }
}

/* Overview page: stack list items and center content on mobile */
@media (max-width: 767px){
  .overview-item-block { display:flex; flex-direction: column; align-items: center; gap: 12px; }
  .overview-title-block { text-align: center; align-items: center; }
}

/* Testimonials tabs: allow horizontal scroll of tab headers on very small screens */
@media (max-width: 479px){
  .testimonial-tabs-block .w-tab-menu { display: flex; gap: 8px; overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 6px; }
  .testimonial-tabs-block .w-tab-menu .w-tab-link { flex: 0 0 auto; white-space: nowrap; }
}

/* Guides page: ensure guide cards center and spacing is tight on mobile */
@media (max-width: 767px){
  .products-grid .product-item { text-align: center; align-items: center; }
  .products-grid .product-item .button-second { margin-left: 0; margin-right: 0; }
}

/* Business page: keep package text centered on mobile (reinforce) */
@media (max-width: 767px){
  .business-sub-text-block { text-align: center; align-items: center; }
}

/* Explore: make two-column grid stack and center */
@media (max-width: 767px){
  .sub-page-explore-grid { flex-flow: column !important; gap: 20px !important; }
  .explore-grid-sub-block { margin-left: auto; margin-right: auto; text-align: center; align-items: center; }
}

/* FAQ: reduce extra spacing between nested items on mobile */
@media (max-width: 767px){
  .faq-page-main-block .faq-item-title, .faq-page-main-block .faq-sub-item-title { padding-bottom: 16px; }
}

/* Product page: ensure CTA button spans full width on very small screens */
@media (max-width: 479px){
  .product-cta-row .button-primary { display:block; width: 100%; text-align: center; }
}

/* Offering page: tighten mobile layout */
@media (max-width: 767px){
  .offering-sub-block-item { align-items: center; text-align: center; }
  .offering-focus-main-image-block { padding: 20px 40px; }
  .offering-focus-main-image-block .slider-nav { width: 44px; height: 44px; }
  .sub-page-main-text-block-big { text-align: center; }
}

/* What is INFINITY page: center section titles and size cards sensibly */
@media (max-width: 767px){
  .infinity-experience-grid-title-block, .infinity-questions-grid-title-block { text-align: center; }
  .infinity-get-started-sub-block { width: 100%; max-width: 360px; margin-left: auto; margin-right: auto; }
}

/* Mobile hero section improvements */
@media (max-width: 767px){
  /* Reduce hero height on mobile for better content visibility */
  .sub-page-hero { min-height: 50vh !important; }
  .sub-hero-content-block { min-height: 50vh !important; padding: 20px 0 !important; }
  
  /* Improve hero title sizing on mobile */
  .sub-hero-h1, .sub-her-h1-black { 
    font-size: clamp(28px, 6vw, 36px) !important; 
    padding-top: 30px !important;
    line-height: 1.2 !important;
  }
  
  /* Improve hero subtitle sizing and spacing */
  .sub-hero-h2, .sub-hero-h2-black { 
    font-size: clamp(18px, 4vw, 24px) !important; 
    line-height: 1.4 !important;
    white-space: normal !important;
    margin-top: 8px !important;
  }
  
  /* Better description block positioning on mobile */
  .sub-hero-desc-block { 
    min-height: auto !important; 
    margin-bottom: 30px !important;
    padding: 0 16px !important;
  }
  
  /* Ensure background video circles render properly */
  .background-video { 
    width: 240px !important; 
    margin: 12px auto 0 !important;
    float: none !important;
  }
}

/* Extra small mobile devices */
@media (max-width: 479px){
  .sub-page-hero { min-height: 45vh !important; }
  .sub-hero-content-block { min-height: 45vh !important; }
  
  .sub-hero-h1, .sub-her-h1-black { 
    font-size: 24px !important;
    padding-top: 24px !important;
  }
  
  .sub-hero-h2, .sub-hero-h2-black { 
    font-size: 16px !important;
  }
  
  .sub-hero-desc-block { 
    margin-bottom: 24px !important;
  }
  
  .background-video { 
    width: 200px !important;
  }
}

/* Homepage responsive refinements */
@media (max-width: 991px) {
  .slider-section {
    margin-top: 12px !important;
  }
  .main-hero-bg {
    min-height: 600px;
    height: calc(100vh - var(--header-h) - var(--hero-side-margin) - var(--hero-top-gap));
    padding: clamp(28px, 6vw, 48px) clamp(24px, 7vw, 48px);
  }
  .slider-content {
    padding: 0 !important;
  }
  .slider-content-big-text {
    position: static !important;
    margin: 0 0 18px !important;
  }
  .hero-bottom-right {
    position: static !important;
    text-align: left !important;
    align-items: flex-start !important;
    gap: 14px;
    margin: 0 !important;
  }
  #heroSub,
  #heroDesc {
    max-width: 100%;
    text-align: left;
    line-height: 1.55;
  }
  #heroCTA {
    width: 100%;
  }
  /* Improve arrow visibility on tablets */
  .hero-arrow {
    width: 44px;
    height: 44px;
    font-size: 26px;
  }
}

@media (max-width: 767px) {
  :root {
    --header-h: 70px; /* Mobile header height */
  }
  .main-hero-bg {
    height: calc(100vh - var(--header-h)) !important;
    min-height: calc(100vh - var(--header-h)) !important;
    max-height: calc(100vh - var(--header-h)) !important;
    padding: clamp(20px, 5vw, 32px) clamp(16px, 4vw, 20px);
    border-radius: 18px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    display: flex;
    flex-direction: column;
  }
  .slider-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    min-height: 100% !important;
    height: 100% !important;
    width: 100% !important;
    flex: 1 !important;
    justify-content: space-between !important;
    align-items: stretch !important;
  }
  .slider-content-big-text {
    margin-bottom: 0 !important;
    padding: 0 !important;
    width: 100%;
    flex-shrink: 0;
  }
  .slider-h1 {
    font-size: clamp(28px, 8.5vw, 36px) !important;
    line-height: 1.15 !important;
    margin-bottom: 6px !important;
    font-weight: 500;
    letter-spacing: -0.02em;
  }
  .slider-h1.slider-h1-2,
  .slider-h1.slider-h1-3 {
    margin-top: 2px !important;
    margin-bottom: 6px !important;
  }
  #heroSub {
    font-size: clamp(17px, 4.5vw, 19px) !important;
    margin-bottom: 10px !important;
    line-height: 1.4 !important;
    font-weight: 500;
  }
  #heroDesc {
    font-size: clamp(15px, 4vw, 17px) !important;
    line-height: 1.6 !important;
    margin-bottom: 8px !important;
    max-width: 100% !important;
  }
  #heroCTA {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    width: 100%;
  }
  #heroCTA .w-button {
    width: 100% !important;
    max-width: 100% !important;
    padding: 16px 24px !important;
    font-size: clamp(15px, 4vw, 17px) !important;
    min-height: 48px;
    touch-action: manipulation;
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0.3);
  }
  #heroPrev,
  #heroNext {
    display: none !important;
  }
  /* Group bottom elements together - create bottom section */
  .hero-bottom-right {
    margin-top: auto !important;
    margin-bottom: 0 !important;
    width: 100%;
    max-width: 100% !important;
    flex-shrink: 0;
    order: 2;
    position: static !important;
  }
  /* Position dots right after description/button - both at bottom */
  /* Override inline styles forcefully */
  #heroDots {
    position: static !important;
    left: auto !important;
    bottom: auto !important;
    transform: none !important;
    order: 3 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 8px !important;
    padding-bottom: 0 !important;
    flex-shrink: 0;
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
  }
  /* Ensure bottom group stays together - no gap between description/button and dots */
  .hero-bottom-right + #heroDots {
    margin-top: 0 !important;
  }
  /* Make sure both bottom elements are aligned and at the bottom */
  .hero-bottom-right,
  #heroDots {
    align-self: stretch !important;
  }
  /* Force bottom alignment - ensure they're truly at bottom */
  .slider-content > .hero-bottom-right {
    margin-top: auto !important;
  }
  .slider-content > #heroDots {
    margin-top: 0 !important;
  }
  #heroDesc {
    margin-bottom: 8px !important;
  }
  #heroCTA {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  /* Improve touch interactions */
  .slider-content * {
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0.2);
  }
  /* Prevent horizontal scroll */
  .slider-section {
    overflow-x: hidden;
    width: 100%;
  }
  .main-hero-bg {
    overflow-x: hidden;
    width: 100%;
  }
  /* Enable smooth scrolling on iOS */
  .slider-content {
    -webkit-overflow-scrolling: touch;
  }
  /* Better spacing between elements */
  .slider-content-big-text .slider-h1:not(:last-child) {
    margin-bottom: 4px !important;
  }
  /* Ensure CTA button is easily tappable */
  #heroCTA {
    display: flex;
    justify-content: flex-start;
    align-items: center;
  }
  /* Optimize text readability */
  #heroSub,
  #heroDesc {
    color: rgba(255, 255, 255, 0.95) !important;
  }
  .main-section-1 .container-full,
  .main-section-2 .container-full,
  .main-section-3 .container-full,
  .main-story-section .container-full,
  .main-about-section .container-full,
  .cta-section .container-full {
    padding-left: clamp(16px, 6vw, 24px) !important;
    padding-right: clamp(16px, 6vw, 24px) !important;
  }
  /* Main Section 1 - Intro Section */
  .main-section-1,
  .main-section-1.main-section-mobile-padding {
    padding-top: clamp(40px, 8vh, 60px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
  }
  .main-section-1 .main-text-h1,
  .main-section-1.main-section-mobile-padding .main-text-h1,
  .main-section-1 .main-text-block .main-text-h1,
  .main-section-1.main-section-mobile-padding .main-text-block .main-text-h1 {
    font-size: clamp(16px, 4vw, 22px) !important;
    line-height: 1.4 !important;
    text-align: center !important;
    margin-bottom: clamp(12px, 2.5vh, 20px) !important;
    font-weight: normal !important;
    padding: 0 16px;
  }
  .main-section-1 .main-text-h1 .text-span,
  .main-section-1.main-section-mobile-padding .main-text-h1 .text-span {
    display: block !important;
    margin: clamp(6px, 1.2vh, 10px) 0 !important;
    line-height: 1.45 !important;
  }
  .infinity-h2-sign,
  .main-section-1 .infinity-h2-sign,
  .main-section-1.main-section-mobile-padding .infinity-h2-sign {
    font-size: clamp(28px, 7vw, 40px) !important;
    text-align: center !important;
    margin: clamp(16px, 3vh, 24px) auto !important;
    max-width: 100% !important;
    font-weight: 300 !important;
    line-height: 1.2 !important;
  }
  .inifinity-h1,
  .main-loop-image .inifinity-h1,
  .inifinity-text-1 .inifinity-h1 {
    font-size: clamp(32px, 8vw, 48px) !important;
    line-height: 1.1 !important;
  }
  .main-grid-start {
    display: flex !important;
    flex-direction: column;
    gap: clamp(8px, 2vh, 16px) !important;
    margin-top: clamp(16px, 3vh, 24px) !important;
    align-items: center;
  }
  .main-loop-image {
    max-width: min(320px, 80vw);
    margin: 0 auto clamp(4px, 1vh, 8px) auto !important;
    width: 100%;
    display: flex !important;
    flex-direction: column !important;
  }
  
  /* Reorder elements: video first, then INFINITY heading */
  .main-loop-image .background-video {
    order: 1 !important;
  }
  .main-loop-image .inifinity-text-1 {
    order: 2 !important;
    position: static !important;
    bottom: auto !important;
    left: auto !important;
    margin-top: clamp(12px, 2vh, 20px) !important;
    text-align: center !important;
  }
  
  .background-video {
    width: 100% !important;
    max-width: 320px;
    margin: 0 auto clamp(4px, 1vh, 8px) auto !important;
    transform: scale(0.6) !important;
    transform-origin: center center;
  }
  .inifinity-text-block {
    display: flex;
    flex-direction: column;
    gap: 12px;
    text-align: center;
    width: 100%;
    max-width: 100%;
    margin-top: clamp(4px, 1vh, 8px) !important;
  }
  .inifinity-text-block .text-block,
  .inifinity-text-block .text-block-2,
  .inifinity-text-block .text-block-3,
  .main-section-1 .inifinity-text-block .text-block,
  .main-section-1 .inifinity-text-block .text-block-2,
  .main-section-1 .inifinity-text-block .text-block-3,
  .main-section-1.main-section-mobile-padding .inifinity-text-block .text-block,
  .main-section-1.main-section-mobile-padding .inifinity-text-block .text-block-2,
  .main-section-1.main-section-mobile-padding .inifinity-text-block .text-block-3 {
    font-size: clamp(20px, 5.5vw, 24px) !important;
    line-height: 1.4 !important;
    text-align: center !important;
    font-weight: 200 !important;
    margin-bottom: 0 !important;
  }

  /* Main Section 2 - INFINITY Description */
  .main-section-2.home-intro-tall {
    padding-top: clamp(40px, 8vh, 60px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
  }
  .main-p-container {
    max-width: 100% !important;
    padding: 0 clamp(16px, 4vw, 24px) !important;
  }
  .home-intro-tall .main-p {
    font-size: clamp(16px, 4.2vw, 18px);
    line-height: 1.5;
    text-align: center;
    padding: 0;
    margin: 0 auto;
    max-width: 100%;
  }
  .line-black {
    margin: 0 auto 20px;
    width: 60px;
    height: 2px;
  }

  /* Story Section */
  .main-story-section {
    padding-top: clamp(40px, 8vh, 60px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
  }
  .main-story-grid {
    display: flex !important;
    flex-direction: column;
    gap: 24px;
    align-items: center;
  }
  .main-story-section .image-block {
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
  }
  .main-story-section .image-block img {
    width: 50%;
    height: auto;
    border-radius: 12px;
    display: block;
    margin: 0 auto;
  }
  .main-story-section .story-text {
    padding: 0;
    text-align: center !important;
    width: 100%;
    max-width: 100%;
    font-size: 16px;
  }
  .main-story-section .story-text-1 {
    font-size: clamp(14px, 4vw, 16px);
    line-height: 1.6;
    margin-bottom: 16px;
  }
  .read-more-story-btn {
    font-size: clamp(13px, 3.5vw, 15px) !important;
    padding: 10px 35px 10px 20px !important;
    min-height: 40px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: auto;
    max-width: 90%;
    background-size: 20px !important;
    background-position: calc(100% - 10px) center !important;
  }

  /* Main Section 3 - What INFINITY can do */
  .main-section-3 {
    padding-top: clamp(40px, 8vh, 60px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
  }
  .title-block {
    margin-bottom: 24px;
    text-align: center;
  }
  .main-h1-center {
    font-size: clamp(24px, 7vw, 32px) !important;
    line-height: 1.3 !important;
    text-align: center !important;
    margin-bottom: 0;
  }
  .main-grid-3-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
    margin-top: 32px;
  }
  .main-grid-3-list .border-item {
    padding: 18px 16px;
    border-radius: 16px;
    text-align: center;
  }
  .main-grid-3-list .main-h1---bottom-border {
    font-size: clamp(14px, 4vw, 26px);
    margin-bottom: 10px;
    white-space: nowrap;
    overflow: visible;
  }
  .main-grid-3-list .main-text-1 {
    font-size: clamp(13px, 3.5vw, 20px);
    margin-bottom: 10px;
    line-height: 1.4;
  }
  .main-grid-3-list .border-item p {
    font-size: clamp(12px, 3vw, 16px);
    line-height: 1.6;
  }
  .btn-block {
    margin-top: 32px;
    text-align: center;
  }
  .btn-block .button-second {
    width: 100%;
    max-width: 280px;
    padding: 14px 28px;
    font-size: clamp(15px, 4vw, 17px);
    min-height: 48px;
  }

  /* About Section */
  .main-about-section {
    padding-top: clamp(40px, 8vh, 60px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
  }
  .main-about-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    align-items: center;
    text-align: center;
  }
  .main-about-content {
    order: 2;
    text-align: center;
    width: 100%;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    padding-right: 0 !important;
  }
  .main-about-content .main-about-h1 {
    font-size: clamp(24px, 6vw, 32px) !important;
    text-align: center;
    margin-bottom: clamp(12px, 2vh, 16px);
  }
  .main-about-content .main-about-image-block {
    margin: clamp(16px, 3vh, 24px) auto;
    max-width: min(280px, 70vw);
    width: 100%;
    overflow: visible !important;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative !important;
    aspect-ratio: auto !important;
    padding: 0 !important;
  }
  .main-about-content .main-4-video {
    position: relative !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    display: block;
    top: auto !important;
    left: auto !important;
  }
  .main-about-content .main-about-image-block .image-2 {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    object-fit: contain;
    display: block;
  }
  .main-about-content .main-about-h2 {
    font-size: clamp(18px, 5vw, 24px);
    margin-bottom: clamp(12px, 2vh, 16px);
    text-align: center;
    max-width: 100% !important;
  }
  .main-about-content .main-about-p {
    font-size: clamp(14px, 4vw, 16px);
    line-height: 1.5;
    text-align: center;
    margin-bottom: clamp(16px, 2.5vh, 20px);
    padding: 0 clamp(16px, 4vw, 24px);
  }
  .main-about-content .read-more.w-button {
    font-size: clamp(14px, 3.8vw, 16px);
  }
  .main-about-image-block {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
  }
  .main-about-image {
    order: 1;
    display: flex;
    justify-content: center;
    width: 100%;
    margin-bottom: 24px;
  }
  .main-about-image .about-image {
    max-width: min(210px, 50%);
    width: 50%;
    height: auto;
    margin: 0 auto;
  }
  .main-about-content .read-more.w-button {
    width: 100%;
    max-width: 280px;
    margin: 0 auto;
    padding: 14px 28px;
    font-size: clamp(15px, 4vw, 17px);
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  /* Instagram Section */
  .main-section-2:has(.instagram-media) {
    padding-top: clamp(40px, 8vh, 60px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
  }
  .instagram-media {
    margin: 0 auto !important;
    border-radius: 16px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: auto !important;
  }
  .main-section-2 .button-second {
    width: 100%;
    max-width: 280px;
    margin: 0 auto;
    padding: 12px 22px 12px 46px;
    background-position: 12px center;
    background-size: 18px;
    font-size: clamp(15px, 4vw, 17px);
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  
  /* Full width override for buttons inside sub-focus-grid-button-block - must come right after */
  .main-section-2 .sub-focus-grid-button-block .button-second,
  .main-section-2 .sub-focus-grid-button-block a.button-second,
  .main-section-2 .sub-focus-grid-button-block .button-second.w-button,
  .main-section-2 .sub-focus-grid-button-block a.button-second.w-button {
    max-width: 100% !important;
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    margin: 0 auto !important;
  }
  
  /* Override for mobile - full width button in sub-focus-grid-button-block */
  .main-section-2 .sub-focus-grid-button-block .button-second,
  .main-section-2 .sub-focus-grid-button-block a.button-second,
  .main-section-2 .sub-focus-grid-button-block .button-second.w-button,
  .main-section-2 .sub-focus-grid-button-block a.button-second.w-button {
    max-width: 100% !important;
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 auto !important;
    padding: 14px 20px 14px 44px !important;
    padding-top: 14px !important;
    padding-bottom: 14px !important;
    padding-left: 44px !important;
    padding-right: 20px !important;
    font-size: 15px !important;
    line-height: 1.4 !important;
    white-space: normal !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    text-align: center !important;
    flex-wrap: wrap !important;
    background-position: 16px center !important;
    background-size: 18px !important;
    background-repeat: no-repeat !important;
    border-radius: 10px !important;
    box-sizing: border-box !important;
  }

  /* CTA Section */
  .cta-section {
    padding-top: clamp(40px, 8vh, 60px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
  }
  .cta-grid {
    gap: 28px;
    grid-template-columns: 1fr;
    text-align: center;
  }
  .cta-item {
    order: 1;
    text-align: center;
  }
  .cta-image {
    order: 2;
    text-align: center;
    margin: 0 auto;
  }
  .cta-section .heading {
    font-size: clamp(24px, 7vw, 32px) !important;
    line-height: 1.3 !important;
    margin-bottom: 16px;
  }
  .cta-section .cta-p {
    font-size: clamp(16px, 4.5vw, 18px) !important;
    line-height: 1.6 !important;
    margin-bottom: 24px;
  }
  .cta-section .button-second.w-button {
    width: 100%;
    max-width: 280px;
    margin: 0 auto;
    padding: 14px 28px;
    font-size: clamp(15px, 4vw, 17px);
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .cta-image img {
    width: clamp(120px, 25vw, 175px);
    height: auto;
  }
}

@media (max-width: 479px) {
  :root {
    --header-h: 70px; /* Mobile header height */
  }
  .main-hero-bg {
    height: calc(100vh - var(--header-h)) !important;
    min-height: calc(100vh - var(--header-h)) !important;
    max-height: calc(100vh - var(--header-h)) !important;
    padding: clamp(18px, 4.5vw, 28px) clamp(14px, 3.5vw, 18px);
  }
  .slider-content-big-text {
    margin-bottom: 16px !important;
  }
  .slider-h1 {
    font-size: clamp(26px, 8vw, 32px) !important;
    line-height: 1.15 !important;
    margin-bottom: 4px !important;
  }
  .slider-h1.slider-h1-2,
  .slider-h1.slider-h1-3 {
    margin-top: 2px !important;
    margin-bottom: 4px !important;
  }
  #heroSub {
    font-size: clamp(16px, 4.2vw, 18px) !important;
    margin-bottom: 8px !important;
    line-height: 1.4 !important;
  }
  #heroDesc {
    font-size: clamp(14px, 3.8vw, 16px) !important;
    line-height: 1.6 !important;
    margin-bottom: 8px !important;
  }
  #heroDots {
    margin: 8px 0 0 !important;
    gap: 8px;
    flex-shrink: 0;
    padding-top: 6px !important;
  }
  #heroDots img {
    width: 18px !important;
    height: 18px !important;
    min-width: 44px;
    min-height: 44px;
    padding: 13px;
    transition: transform 0.2s ease, opacity 0.2s ease;
  }
  #heroDots img:active {
    transform: scale(0.95);
    opacity: 0.8;
  }
  #heroCTA .w-button {
    padding: 14px 20px !important;
    font-size: clamp(14px, 3.5vw, 16px) !important;
    min-height: 48px;
  }
  .hero-bottom-right {
    gap: 10px !important;
  }
  /* Small Mobile Optimizations */
  .main-section-1 .main-text-h1 {
    font-size: clamp(15px, 3.8vw, 20px) !important;
    line-height: 1.4 !important;
    margin-bottom: clamp(12px, 2vh, 18px) !important;
    padding: 0 12px;
  }
  .main-section-1 .main-text-h1 .text-span {
    display: block !important;
    margin: 8px 0 !important;
    line-height: 1.45 !important;
  }
  .infinity-h2-sign {
    font-size: clamp(24px, 6.5vw, 36px) !important;
    margin: clamp(14px, 2.5vh, 20px) auto !important;
    line-height: 1.2 !important;
  }
  .inifinity-h1 {
    font-size: clamp(28px, 7vw, 40px) !important;
    line-height: 1.1 !important;
  }
  .main-loop-image {
    max-width: min(280px, 75vw);
    display: flex !important;
    flex-direction: column !important;
  }
  
  /* Reorder elements: video first, then INFINITY heading */
  .main-loop-image .background-video {
    order: 1 !important;
  }
  .main-loop-image .inifinity-text-1 {
    order: 2 !important;
    position: static !important;
    bottom: auto !important;
    left: auto !important;
    margin-top: clamp(10px, 1.5vh, 16px) !important;
    text-align: center !important;
  }
  
  .background-video {
    max-width: 280px;
    transform: scale(0.6) !important;
    transform-origin: center center;
  }
  .inifinity-text-block .text-block,
  .inifinity-text-block .text-block-2,
  .inifinity-text-block .text-block-3 {
    font-size: clamp(18px, 5vw, 22px) !important;
    line-height: 1.35 !important;
  }
  .home-intro-tall .main-p {
    font-size: clamp(14px, 3.8vw, 16px);
    line-height: 1.5;
  }
  .main-story-section .story-text-1 {
    font-size: clamp(16px, 4.5vw, 18px);
  }
  .main-h1-center {
    font-size: clamp(22px, 6.5vw, 28px) !important;
  }
  .main-grid-3-list .border-item {
    padding: 16px 12px;
  }
  .main-grid-3-list .main-h1---bottom-border {
    font-size: clamp(12px, 3.5vw, 26px);
    margin-bottom: 8px;
    white-space: nowrap;
    overflow: visible;
  }
  .main-grid-3-list .main-text-1 {
    font-size: clamp(12px, 3.2vw, 20px);
    margin-bottom: 8px;
    line-height: 1.4;
  }
  .main-grid-3-list .border-item p {
    font-size: clamp(11px, 2.8vw, 16px);
    line-height: 1.6;
  }
  .main-about-content .main-about-h1 {
    font-size: clamp(22px, 5.5vw, 28px) !important;
    margin-bottom: clamp(10px, 1.5vh, 14px);
  }
  .main-about-content .main-about-image-block {
    margin: clamp(12px, 2vh, 20px) auto;
    max-width: min(240px, 65vw);
    width: 100%;
    overflow: visible !important;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative !important;
    aspect-ratio: auto !important;
    padding: 0 !important;
  }
  .main-about-content .main-4-video {
    position: relative !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    display: block;
    top: auto !important;
    left: auto !important;
  }
  .main-about-content .main-about-image-block .image-2 {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    object-fit: contain;
    display: block;
  }
  .main-about-content .main-about-h2 {
    font-size: clamp(16px, 4.5vw, 22px);
    margin-bottom: clamp(10px, 1.5vh, 14px);
  }
  .main-about-content .main-about-p {
    font-size: clamp(13px, 3.8vw, 15px);
    line-height: 1.5;
    padding: 0 clamp(12px, 3vw, 20px);
  }
  .main-about-content .read-more.w-button {
    font-size: clamp(13px, 3.5vw, 15px);
    padding: 12px 24px;
    transition: all 0.3s ease !important;
    position: relative !important;
    overflow: hidden !important;
  }
  .main-about-content .read-more.w-button::before {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: -100% !important;
    width: 100% !important;
    height: 100% !important;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent) !important;
    transition: left 0.6s ease !important;
    z-index: 1 !important;
  }
  .main-about-content .read-more.w-button:hover {
    transform: translateY(-3px) scale(1.02) !important;
    box-shadow: 0 6px 16px rgba(255, 255, 255, 0.3) !important;
    border-color: rgba(255, 255, 255, 0.8) !important;
  }
  .main-about-content .read-more.w-button:hover::before {
    left: 100% !important;
  }
  .main-about-content .read-more.w-button:active {
    transform: translateY(-1px) scale(1.01) !important;
  }
  .main-about-content .read-more.w-button > * {
    position: relative !important;
    z-index: 2 !important;
  }
  .cta-section .heading {
    font-size: clamp(22px, 6.5vw, 28px) !important;
  }
  .cta-section .cta-p {
    font-size: clamp(15px, 4.2vw, 17px) !important;
  }
}

/* Mobile landscape orientation optimizations */
@media (max-width: 767px) and (orientation: landscape) {
  :root {
    --header-h: 70px; /* Mobile header height */
  }
  .main-hero-bg {
    height: calc(100vh - var(--header-h)) !important;
    min-height: calc(100vh - var(--header-h)) !important;
    max-height: calc(100vh - var(--header-h)) !important;
    padding: clamp(16px, 3vw, 24px) clamp(14px, 3vw, 20px);
  }
  .slider-content-big-text {
    margin-bottom: 12px !important;
  }
  .slider-h1 {
    font-size: clamp(24px, 6vw, 30px) !important;
    margin-bottom: 3px !important;
  }
  #heroSub {
    font-size: clamp(15px, 3.5vw, 17px) !important;
    margin-bottom: 6px !important;
  }
  #heroDesc {
    font-size: clamp(14px, 3.2vw, 16px) !important;
    margin-bottom: 6px !important;
  }
  #heroDots {
    margin: 8px auto 0 !important;
    padding-top: 6px !important;
  }
  #heroCTA .w-button {
    padding: 12px 20px !important;
    min-height: 44px;
  }
}

/* What Is INFINITY responsive tweaks */
@media (max-width: 991px) {
  .sub-page-hero.background-1 .sub-hero-content-block,
  .sub-page-hero.background-2-about .sub-hero-content-block,
  .sub-page-hero.background-6-offering .sub-hero-content-block,
  .sub-page-hero.background-7-business .sub-hero-content-block,
  .sub-page-hero.background-8-explore .sub-hero-content-block {
    align-items: flex-start !important;
    justify-content: flex-end !important;
    padding: clamp(40px, 8vh, 80px) clamp(20px, 6vw, 48px) !important;
    min-height: 60vh;
  }
  .sub-page-hero.background-1 .sub-hero-h1,
  .sub-page-hero.background-2-about .sub-hero-h1,
  .sub-page-hero.background-6-offering .sub-hero-h1,
  .sub-page-hero.background-7-business .sub-hero-h1,
  .sub-page-hero.background-8-explore .sub-hero-h1 {
    text-align: left !important;
    margin: 0 0 12px !important;
    position: static !important;
    float: none !important;
    top: auto !important;
    right: auto !important;
    left: auto !important;
    bottom: auto !important;
    transform: none !important;
    z-index: auto !important;
  }
  
  .sub-page-hero.background-1 .sub-hero-h2,
  .sub-page-hero.background-2-about .sub-hero-h2,
  .sub-page-hero.background-5-partner .sub-hero-h2,
  .sub-page-hero.background-6-offering .sub-hero-h2,
  .sub-page-hero.background-7-business .sub-hero-h2,
  .sub-page-hero.background-8-explore .sub-hero-h2 {
    text-align: left !important;
    margin: 0 0 clamp(12px, 2vh, 20px) !important;
    position: static !important;
    float: none !important;
    top: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    right: auto !important;
    left: auto !important;
    bottom: auto !important;
    transform: none !important;
    z-index: auto !important;
  }
  .sub-page-hero.background-1 .sub-hero-desc-block,
  .sub-page-hero.background-2-about .sub-hero-desc-block,
  .sub-page-hero.background-6-offering .sub-hero-desc-block,
  .sub-page-hero.background-7-business .sub-hero-desc-block,
  .sub-page-hero.background-8-explore .sub-hero-desc-block {
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    z-index: auto !important;
  }
  .sub-page-hero.background-1 .sub-page-p-big-white,
  .sub-page-hero.background-2-about .sub-page-p-big-white,
  .sub-page-hero.background-6-offering .sub-page-p-big-white,
  .sub-page-hero.background-7-business .sub-page-p-big-white,
  .sub-page-hero.background-8-explore .sub-page-p-big-white {
    font-size: clamp(16px, 4.6vw, 20px) !important;
    line-height: 1.65 !important;
    margin: 0 !important;
  }

  .infinity-grid,
  .infinity-sub-grid,
  .infinity-experience-grid,
  .infinity-questions-grid,
  .infinity-get-started-grid {
    grid-template-columns: 1fr !important;
    grid-row-gap: 32px !important;
  }
  .infinity-grid {
    grid-column-gap: 32px !important;
  }
  .infinity-grid-image-block,
  .infinity-sub-grid-image-block,
  .infinity-experience-grid-image-block,
  .infinity-get-started-icon-block {
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
  }
  
  /* Reduce video size in infinity-grid-image-block on mobile */
  .infinity-grid-image-block {
    max-width: clamp(280px, 70vw, 400px) !important;
    width: 100% !important;
    margin: 0 auto !important;
  }
  
  .infinity-grid-image-block video {
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
    border-radius: 15px !important;
  }
  .infinity-grid-side-text-block,
  .infinity-sub-grid-side-text-block,
  .infinity-experience-grid-side-text-block {
    text-align: left;
  }
  .infinity-grid .sub-page-slogan-p {
    font-size: clamp(22px, 5.6vw, 30px);
    line-height: 1.4;
    padding: 0 8px;
  }
  .infinity-sub-grid-sub-block-first,
  .infinity-sub-grid-sub-block-second,
  .infinity-get-started-grid-sub-block,
  .infinity-questions-grid-sub-block,
  .infinity-experience-grid-sub-block {
    gap: 20px;
  }
  .infinity-sub-grid-sub-block-first,
  .infinity-experience-grid-sub-block {
    display: flex;
    flex-direction: column;
  }
  .infinity-sub-grid-sub-block-second {
    display: flex;
    flex-direction: column-reverse;
  }
  .sub-page-focus-button-second,
  .sub-page-focus-button.w-inline-block.is-note {
    width: 100%;
    max-width: 280px;
  }
}

@media (max-width: 767px) {
  /* Apply correct mobile hero styling to match partner page (but don't change partner page) */
  .sub-page-hero.background-1 .sub-hero-content-block,
  .sub-page-hero.background-2-about .sub-hero-content-block,
  .sub-page-hero.background-6-offering .sub-hero-content-block,
  .sub-page-hero.background-7-business .sub-hero-content-block,
  .sub-page-hero.background-8-explore .sub-hero-content-block {
    padding: clamp(32px, 8vh, 64px) clamp(18px, 6vw, 32px) !important;
    min-height: 52vh !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    display: flex !important;
    flex-direction: column !important;
  }
  
  /* Position h1 at top right on mobile (matching partner page behavior) */
  .sub-page-hero.background-1 .sub-hero-h1,
  .sub-page-hero.background-2-about .sub-hero-h1,
  .sub-page-hero.background-6-offering .sub-hero-h1,
  .sub-page-hero.background-7-business .sub-hero-h1,
  .sub-page-hero.background-8-explore .sub-hero-h1 {
    position: absolute !important;
    float: right !important;
    text-align: right !important;
    top: clamp(20px, 5vh, 40px) !important;
    right: clamp(18px, 4vw, 32px) !important;
    left: auto !important;
    bottom: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 2 !important;
    transform: none !important;
  }
  
  .sub-page-hero.background-1 .sub-hero-h2,
  .sub-page-hero.background-2-about .sub-hero-h2,
  .sub-page-hero.background-5-partner .sub-hero-h2,
  .sub-page-hero.background-6-offering .sub-hero-h2,
  .sub-page-hero.background-7-business .sub-hero-h2,
  .sub-page-hero.background-8-explore .sub-hero-h2 {
    text-align: left !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-bottom: clamp(16px, 3vh, 24px) !important;
    position: static !important;
    float: none !important;
    top: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    right: auto !important;
    left: auto !important;
    bottom: auto !important;
    transform: none !important;
    z-index: auto !important;
    display: block !important;
  }
  
  .sub-page-hero.background-1 .sub-hero-desc-block,
  .sub-page-hero.background-2-about .sub-hero-desc-block,
  .sub-page-hero.background-6-offering .sub-hero-desc-block,
  .sub-page-hero.background-7-business .sub-hero-desc-block,
  .sub-page-hero.background-8-explore .sub-hero-desc-block {
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    z-index: auto !important;
  }
  
  .sub-page-hero.background-1 .sub-page-p-big-white,
  .sub-page-hero.background-2-about .sub-page-p-big-white,
  .sub-page-hero.background-6-offering .sub-page-p-big-white,
  .sub-page-hero.background-7-business .sub-page-p-big-white,
  .sub-page-hero.background-8-explore .sub-page-p-big-white {
    font-size: clamp(16px, 4.6vw, 20px) !important;
    line-height: 1.65 !important;
    margin-top: clamp(16px, 3vh, 24px) !important;
    margin-bottom: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    display: block !important;
  }
  
  /* Fix overflow issues for infinity-grid section on mobile */
  .main-section-2:has(.infinity-grid) {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  .main-section-2:has(.infinity-grid) .container-full {
    overflow: visible !important;
    max-height: none !important;
  }
  .main-section-2:has(.infinity-grid) .w-layout-grid.infinity-grid {
    overflow: visible !important;
    max-height: none !important;
  }
  .main-section-2:has(.infinity-grid) .infinity-grid-title-block,
  .main-section-2:has(.infinity-grid) .infinity-grid-image-block,
  .main-section-2:has(.infinity-grid) .infinity-grid-side-text-block,
  .main-section-2:has(.infinity-grid) .infinity-grid-main-text-block {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  /* Fix overflow issues for infinity-sub-grid section on mobile */
  .main-section-2:has(.infinity-sub-grid) {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  .main-section-2:has(.infinity-sub-grid) .container-full {
    overflow: visible !important;
    max-height: none !important;
  }
  .main-section-2:has(.infinity-sub-grid) .w-layout-grid.infinity-sub-grid {
    overflow: visible !important;
    max-height: none !important;
  }
  .main-section-2:has(.infinity-sub-grid) .infinity-sub-grid-sub-block-first,
  .main-section-2:has(.infinity-sub-grid) .infinity-sub-grid-sub-block-second,
  .main-section-2:has(.infinity-sub-grid) .infinity-sub-grid-side-text-block,
  .main-section-2:has(.infinity-sub-grid) .infinity-sub-grid-image-block {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  /* Fix overflow issues for main-section-1 with colored section block on mobile */
  .main-section-1:has(.sub-page-colored-section-block) {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  .main-section-1:has(.sub-page-colored-section-block) .container-full {
    overflow: visible !important;
    max-height: none !important;
  }
  .main-section-1:has(.sub-page-colored-section-block) .sub-page-colored-section-block {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  .infinity-grid,
  .infinity-sub-grid,
  .infinity-experience-grid,
  .infinity-questions-grid,
  .infinity-get-started-grid {
    grid-row-gap: 26px !important;
  }
  .infinity-grid-side-text-block,
  .infinity-sub-grid-side-text-block,
  .infinity-experience-grid-side-text-block,
  .infinity-questions-grid-title-block,
  .infinity-get-started-grid-title-block {
    text-align: center;
  }
  
  /* Infinity grid title - "How does INFINITY work?" */
  .infinity-grid-title-block .sub-page-h1 {
    font-size: clamp(20px, 5.5vw, 28px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(12px, 3vh, 16px) !important;
  }
  
  /* Infinity grid side text - paragraph */
  .infinity-grid-side-text-block .sub-page-light-p,
  .infinity-grid-side-text-block p {
    font-size: clamp(14px, 3.8vw, 16px) !important;
    line-height: 1.6 !important;
  }
  
  /* Infinity grid main text - slogan paragraph */
  .infinity-grid-main-text-block .sub-page-slogan-p,
  .infinity-grid .sub-page-slogan-p {
    font-size: clamp(18px, 5vw, 24px) !important;
    line-height: 1.4 !important;
    padding: 0 !important;
  }
  
  /* Infinity sub-grid title - "A New Approach to Health" and "Your Natural State, Restored" */
  .infinity-sub-grid-side-text-block .sub-page-h1 {
    font-size: clamp(20px, 5.5vw, 28px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(12px, 3vh, 16px) !important;
  }
  
  /* Infinity sub-grid side text - paragraphs */
  .infinity-sub-grid-side-text-block .sub-page-light-p,
  .infinity-sub-grid-side-text-block p {
    font-size: clamp(14px, 3.8vw, 16px) !important;
    line-height: 1.6 !important;
    margin-bottom: clamp(12px, 3vh, 16px) !important;
  }
  
  /* Center heading in infinity-sub-grid-side-text-block on mobile */
  .infinity-sub-grid-side-text-block .sub-page-h1 {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  
  /* Infinity sub-grid focus button text */
  .infinity-sub-grid-side-text-block .focus-text {
    font-size: clamp(14px, 3.8vw, 16px) !important;
    line-height: 1.4 !important;
  }
}

/* Mobile: Style button in infinity-sub-grid-side-text-block */
@media (max-width: 767px) {
  .infinity-sub-grid-side-text-block .button-second,
  .infinity-sub-grid-side-text-block a.button-second,
  .infinity-sub-grid-side-text-block .button-second.w-button,
  .infinity-sub-grid-side-text-block a.button-second.w-button {
    font-size: clamp(12px, 3vw, 14px) !important;
    padding: clamp(10px, 2.5vh, 12px) clamp(16px, 4vw, 20px) !important;
    padding-left: clamp(40px, 10vw, 50px) !important;
    background-size: clamp(14px, 3.5vw, 18px) !important;
    background-position: clamp(12px, 3vw, 16px) center !important;
    max-width: 100% !important;
    width: auto !important;
    display: inline-flex !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  
  /* Center the button container horizontally */
  .infinity-sub-grid-side-text-block > div:has(.button-second),
  .infinity-sub-grid-side-text-block > div:has(a.button-second),
  .infinity-sub-grid-side-text-block > div[style*="margin-top"] {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* Desktop: Left-align heading in infinity-sub-grid-side-text-block */
@media (min-width: 768px) {
  .infinity-sub-grid-side-text-block .sub-page-h1 {
    text-align: left !important;
  }
  
  /* Desktop: Adjust button size in infinity-sub-grid-side-text-block */
  .infinity-sub-grid-side-text-block .button-second,
  .infinity-sub-grid-side-text-block a.button-second {
    font-size: clamp(13px, 1.2vw, 15px) !important;
    padding: clamp(12px, 1.5vh, 14px) clamp(20px, 2vw, 24px) !important;
    padding-left: clamp(45px, 5vw, 55px) !important;
    background-size: clamp(18px, 1.8vw, 20px) !important;
    background-position: clamp(14px, 1.5vw, 18px) center !important;
  }
  
  /* Center the button container horizontally */
  .infinity-sub-grid-side-text-block > div:has(.button-second),
  .infinity-sub-grid-side-text-block > div:has(a.button-second) {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }
  
  .infinity-experience-grid-side-text-block h1,
  .infinity-questions-grid-sub-block h1,
  .infinity-get-started-sub-block h1 {
    font-size: clamp(16px, 4.8vw, 18px);
    line-height: 1.6;
  }
  .infinity-sub-grid-image-block img,
  .infinity-get-started-icon-block img {
    width: min(280px, 70vw);
    margin: 0 auto;
    display: block;
  }
  /* Infinity experience grid images handled separately with circular styles */
  .infinity-get-started-sub-block {
    border-radius: 18px;
    padding: 20px 18px;
  }
}

@media (max-width: 479px) {
  .sub-page-hero.background-1 .sub-hero-h1,
  .sub-page-hero.background-2-about .sub-hero-h1,
  .sub-page-hero.background-7-business .sub-hero-h1,
  .sub-page-hero.background-8-explore .sub-hero-h1 {
    font-size: clamp(24px, 9vw, 30px) !important;
  }
  
  /* Infinity grid - smaller screens */
  .infinity-grid-title-block .sub-page-h1 {
    font-size: clamp(18px, 5vw, 24px) !important;
  }
  
  .infinity-grid-side-text-block .sub-page-light-p,
  .infinity-grid-side-text-block p {
    font-size: clamp(13px, 3.5vw, 15px) !important;
  }
  
  .infinity-grid-main-text-block .sub-page-slogan-p,
  .infinity-grid .sub-page-slogan-p {
    font-size: clamp(16px, 4.5vw, 20px) !important;
    padding: 0 !important;
  }
  
  /* Infinity sub-grid - smaller screens */
  .infinity-sub-grid-side-text-block .sub-page-h1 {
    font-size: clamp(18px, 5vw, 24px) !important;
  }
  
  .infinity-sub-grid-side-text-block .sub-page-light-p,
  .infinity-sub-grid-side-text-block p {
    font-size: clamp(13px, 3.5vw, 15px) !important;
  }
}

/* Desktop: Ensure font size for paragraph in infinity-sub-grid-side-text-block (after mobile rules) */
@media (min-width: 768px) {
  section.main-section-2 .infinity-sub-grid-side-text-block .sub-page-light-p,
  section.main-section-2 .infinity-sub-grid-side-text-block p.sub-page-light-p,
  .infinity-sub-grid-side-text-block .sub-page-light-p,
  .infinity-sub-grid-side-text-block p {
    font-size: 20px !important;
    line-height: 1.6 !important;
  }
  
  .infinity-sub-grid-side-text-block .focus-text {
    font-size: clamp(13px, 3.5vw, 15px) !important;
  }
  
  .infinity-get-started-sub-block h1 {
    font-size: clamp(16px, 5.4vw, 18px);
  }
}

/* What Is INFINITY image sizing */
.infinity-grid-image-block video {
  max-width: 100%;
  width: 100%;
  border-radius: 18px;
}

/* Mobile: Reduce video size in infinity-grid */
@media (max-width: 767px) {
  .infinity-grid-image-block {
    max-width: clamp(280px, 70vw, 400px) !important;
    width: 100% !important;
    margin: 0 auto !important;
  }
  
  .infinity-grid-image-block video {
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
    border-radius: 15px !important;
  }
  
  /* Reduce image size in infinity-sub-grid on mobile */
  .infinity-sub-grid-image-block {
    max-width: clamp(280px, 70vw, 400px) !important;
    width: 100% !important;
    margin: 0 auto !important;
  }
  
  .infinity-sub-grid-image-block img {
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
    border-radius: 18px !important;
  }
}

@media (max-width: 479px) {
  .infinity-grid-image-block {
    max-width: clamp(240px, 65vw, 320px) !important;
  }
  
  .infinity-sub-grid-image-block {
    max-width: clamp(240px, 65vw, 320px) !important;
  }
}

.infinity-sub-grid-image-block img {
  max-width: 100%;
  width: 100%;
  border-radius: 18px;
}
/* Infinity experience grid images should be circular - handled separately */
.infinity-sub-grid-sub-block-second .infinity-sub-grid-image-block img {
  max-width: 320px;
}
.infinity-get-started-icon-block img {
  max-width: 220px;
  border-radius: 16px;
}

@media (max-width: 991px) {
  .infinity-grid-image-block video {
    max-width: min(280px, 75vw);
  }
  .infinity-sub-grid-image-block img {
    max-width: min(300px, 78vw);
  }
  /* Infinity experience grid images handled separately with circular styles */
  .infinity-get-started-icon-block img {
    max-width: min(200px, 64vw);
  }
}

.infinity-get-started-grid-sub-block {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 20px;
  justify-items: stretch;
  align-items: stretch;
}
.infinity-get-started-sub-block {
  width: 100% !important;
  max-width: 100% !important;
  padding: 16px 12px;
  border-radius: 18px;
  background: rgba(255,255,255,0.78);
  box-shadow: 0 10px 24px rgba(0,0,0,0.06);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transition: transform .2s ease, box-shadow .2s ease;
}
.infinity-get-started-sub-block:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 30px rgba(0,0,0,0.08);
}
.infinity-get-started-icon-block {
  display: flex;
  justify-content: center;
}
.infinity-get-started-icon-block img {
  max-width: 120px;
  width: 100%;
  height: auto;
  border-radius: 16px;
}
.infinity-get-started-h1 {
  font-size: clamp(16px, 1.6vw, 20px);
  line-height: 1.3;
  margin-top: 12px;
}

@media (max-width: 767px) {
  .infinity-get-started-grid-sub-block {
    gap: clamp(8px, 2vw, 12px) !important;
    grid-template-columns: repeat(3, 1fr) !important;
  }
  .infinity-get-started-sub-block {
    padding: clamp(8px, 2vw, 12px) clamp(6px, 1.5vw, 10px) !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .infinity-get-started-icon-block {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }
  .infinity-get-started-icon-block img {
    max-width: clamp(45px, 12vw, 60px) !important;
    width: 100% !important;
    height: auto !important;
  }
  .infinity-get-started-h1 {
    font-size: clamp(10px, 2.5vw, 12px) !important;
    line-height: 1.3 !important;
    margin-top: clamp(6px, 1.5vw, 8px) !important;
    text-align: center !important;
  }
}

.infinity-experience-grid-sub-block {
  display: flex;
  gap: 36px;
  align-items: center;
  flex-wrap: wrap;
}

/* Desktop: Ensure circular images for infinity-experience-grid - reduced size */
@media (min-width: 992px) {
  /* First testimonial block: text on left, image on right */
  #w-node-c20b8e9b-7316-7350-e601-73aeabef9daa-131548fa.infinity-experience-grid-sub-block .infinity-experience-grid-image-block {
    order: 1 !important; /* Image second (right) */
  }
  
  #w-node-c20b8e9b-7316-7350-e601-73aeabef9daa-131548fa.infinity-experience-grid-sub-block .infinity-experience-grid-side-text-block {
    order: -1 !important; /* Text first (left) */
  }
  
  /* Second testimonial block: image on left, text on right */
  #w-node-_37c3aa49-75e8-02c4-64cd-036427472eb4-131548fa.infinity-experience-grid-sub-block .infinity-experience-grid-image-block {
    order: -1 !important; /* Image first (left) */
  }
  
  #w-node-_37c3aa49-75e8-02c4-64cd-036427472eb4-131548fa.infinity-experience-grid-sub-block .infinity-experience-grid-side-text-block {
    order: 1 !important; /* Text second (right) */
  }
  
  .infinity-experience-grid-image-block {
    display: flex;
    justify-content: center;
    align-items: center;
    flex: 0 0 200px !important; /* Reduced from 250px to 200px */
    width: 200px !important;
    height: 200px !important;
    max-width: 200px !important;
    max-height: 200px !important;
    min-width: 200px !important;
    min-height: 200px !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 50% !important;
    overflow: hidden !important;
  }
  .infinity-experience-grid-image-block img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    border-radius: 50% !important;
    display: block !important;
  }
}
.infinity-experience-grid-side-text-block {
  flex: 1 1 300px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media (max-width: 991px) {
  .infinity-experience-grid-sub-block {
    gap: 28px;
  }
  .infinity-experience-grid-image-block {
    flex: 0 0 clamp(120px, 28vw, 180px);
    width: clamp(120px, 28vw, 180px) !important;
    height: clamp(120px, 28vw, 180px) !important;
    aspect-ratio: 1 / 1 !important;
    max-width: 180px;
    max-height: 180px;
  }
  .infinity-experience-grid-image-block img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
  }
  .infinity-experience-grid-side-text-block h1 {
    font-size: clamp(18px, 3.2vw, 22px);
    line-height: 1.45;
  }
}

@media (max-width: 767px) {
  .infinity-experience-grid-sub-block {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 22px;
  }
  .infinity-experience-grid-image-block {
    order: -1;
    flex: 0 0 auto;
    width: clamp(120px, 32vw, 180px) !important;
    height: clamp(120px, 32vw, 180px) !important;
    aspect-ratio: 1 / 1 !important;
    max-width: 180px;
    max-height: 180px;
  }
  .infinity-experience-grid-image-block img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    border-radius: 50% !important;
  }
  .infinity-experience-grid-side-text-block {
    flex: 1 1 auto;
    align-items: center;
  }
  .infinity-experience-grid-side-text-block h1 {
    font-size: clamp(17px, 4.6vw, 20px);
  }
}

/* ... existing code ... */
/* Restore base note button styling and only adjust on narrow screens */
.sub-page-focus-button.is-note {
  cursor: default !important;
  background: #ffffff !important;
  border: 1px solid #e5e7eb !important;
  border-left: 4px solid var(--primary) !important;
  box-shadow: none !important;
}
.sub-page-focus-button.is-note .focus-text { color: var(--primary) !important; letter-spacing: 0 !important; }
.sub-page-focus-button.is-note:hover { transform: none !important; }

/* Testimonials CTA: force compact single-line layout */
#\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa.sub-page-focus-button-second {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  padding: 8px 16px !important;
  border-radius: 14px !important;
  white-space: nowrap;
}
#\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa .focus-icon-block {
  width: 14px;
  height: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa .focus-icon-block img {
  width: 12px;
  height: 12px;
}
/* CHECK OUR TESTIMONIALS button styles */
/* Desktop styles */
@media (min-width: 768px) {
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa .focus-text {
    font-size: clamp(12px, 2.8vw, 14px) !important;
    letter-spacing: 0.01em;
    white-space: nowrap !important;
    line-height: 1.2 !important;
  }
}

/* Mobile: Smaller font size for CHECK OUR TESTIMONIALS button */
@media (max-width: 767px) {
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa.sub-page-focus-button-second {
    gap: 6px !important;
    padding: 8px 16px !important;
    white-space: nowrap !important;
    display: inline-flex !important;
    flex-wrap: nowrap !important;
    border-width: 1px !important;
    border-radius: 12px !important;
  }
  
  /* Override ALL font-size declarations with fixed smaller size - use maximum specificity */
  .infinity-sub-grid-sub-block .sub-page-focus-button-second h1.focus-text,
  #w-node-b045a61b-1697-5ac3-0690-af112ac8e017-131548fa.sub-page-focus-button-second h1.focus-text,
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa.sub-page-focus-button-second h1.focus-text,
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa.sub-page-focus-button-second .focus-text,
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa .focus-text,
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa h1.focus-text {
    font-size: 11px !important;
    line-height: 1.3 !important;
    letter-spacing: 0 !important;
  }
  
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa.sub-page-focus-button-second .focus-icon-block,
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa .focus-icon-block {
    width: 14px !important;
    height: 14px !important;
  }
  
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa.sub-page-focus-button-second .focus-icon-block img,
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa .focus-icon-block img {
    width: 14px !important;
    height: 14px !important;
  }
}

/* Additional mobile override for CHECK OUR TESTIMONIALS button - must come after base CSS */
@media (max-width: 479px) {
  .infinity-sub-grid-sub-block .sub-page-focus-button-second h1.focus-text,
  #w-node-b045a61b-1697-5ac3-0690-af112ac8e017-131548fa.sub-page-focus-button-second h1.focus-text,
  #\31 -b045a61b-1697-5ac3-0690-af112ac8e017-131548fa.sub-page-focus-button-second h1.focus-text {
    font-size: 11px !important;
  }
}

@media (max-width: 767px) {
  .infinity-grid .sub-page-slogan-p {
    font-size: clamp(16px, 4.2vw, 20px) !important;
    line-height: 1.45 !important;
  padding: 0 6px !important;
  }
}

/* ... existing code ... */
/* FAQ page responsive tweaks */
.faq-page-main-block {
  display: grid;
  gap: 24px;
  margin: 0 auto;
  max-width: 960px;
  padding: 0 clamp(18px, 4vw, 48px);
}
.faq-page-item {
  border-radius: 18px;
  padding: 20px 24px;
  box-shadow: 0 12px 30px rgba(0,0,0,0.06);
  background: #fff;
}
.faq-item-title,
.faq-sub-item-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.faq-item-title h1,
.faq-sub-item-title h1 {
  margin: 0;
}
.faq-page-sub-block {
  margin-top: 14px;
  padding-top: 14px;
}
.faq-page-sub-block .faq-item-text {
  margin-top: 12px;
}
.faq-page-sub-block .faq-item-text p {
  font-size: clamp(16px, 1.6vw, 18px);
  line-height: 1.6;
}

@media (max-width: 991px) {
  .sub-page-hero.background-4-faq .sub-hero-content-block {
    align-items: flex-start !important;
    justify-content: flex-end !important;
    padding: clamp(40px, 8vh, 80px) clamp(20px, 6vw, 48px) !important;
    min-height: 60vh;
  }
  .sub-page-hero.background-4-faq .sub-hero-h1,
  .sub-page-hero.background-4-faq .sub-hero-h2 {
    text-align: left !important;
    margin: 0 0 12px !important;
  }
  .sub-page-hero.background-4-faq .sub-hero-desc-block {
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
  }
  .sub-page-hero.background-4-faq .sub-page-p-big-white {
    font-size: clamp(16px, 4.6vw, 20px);
    line-height: 1.65;
    margin: 10px 0 0;
  }
  .faq-page-main-block {
    padding: 0 clamp(16px, 5vw, 32px);
  }
  .faq-page-item {
    padding: 18px 20px;
  }
}

@media (max-width: 767px) {
  .sub-page-hero.background-4-faq .sub-hero-content-block {
    padding: clamp(32px, 8vh, 64px) clamp(18px, 6vw, 32px) !important;
    min-height: 52vh;
  }
  .background-4-faq ~ .main-section-2 {
    padding-top: clamp(36px, 7vh, 52px) !important;
    margin-top: 0 !important;
    position: relative;
    z-index: 3;
    background: #fff;
  }
  .faq-page-main-block {
    gap: 18px;
    padding: 0 16px;
  }
  .faq-page-item {
    padding: 16px 18px;
  }
  .faq-item-title,
  .faq-sub-item-title {
    flex-wrap: wrap;
    gap: 8px;
  }
  
  /* Mobile: Add padding to prevent text collision with "+" icon */
  .faq-item-title h1,
  .faq-sub-item-title h1 {
    padding-right: clamp(32px, 8vw, 40px) !important;
  }
  
  /* Mobile: Reduce FAQ font sizes */
  .faq-page-item .faq-item-title .sub-page-h1 {
    font-size: clamp(18px, 4.5vw, 24px) !important;
    line-height: 1.3 !important;
  }
  
  .faq-sub-item-title .sub-page-h1-small {
    font-size: clamp(12px, 3vw, 16px) !important;
    line-height: 1.4 !important;
  }
  
  .faq-item-text .sub-page-p-small-faq,
  .faq-page-sub-block .faq-item-text p,
  .faq-page-sub-block .faq-item-text .sub-page-p-small-faq {
    font-size: clamp(11px, 2.8vw, 14px) !important;
    line-height: 1.5 !important;
  }
}

@media (max-width: 479px) {
  .sub-page-hero.background-4-faq .sub-hero-h1 {
    font-size: clamp(24px, 9vw, 30px) !important;
  }
  .background-4-faq ~ .main-section-2 {
    padding-top: clamp(32px, 6vh, 44px) !important;
    margin-top: 0 !important;
    position: relative;
    z-index: 3;
    background: #fff;
  }
  .faq-page-main-block {
    gap: 14px;
    padding: 0 12px;
  }
  .faq-page-item {
    padding: 14px 16px;
    border-radius: 10px;
  }
  .faq-item-title,
  .faq-sub-item-title {
    padding-bottom: 10px;
  }
  .faq-page-sub-block {
    margin-top: 10px;
    padding-top: 10px;
  }
  
  /* Mobile (small): Increase padding for smaller screens */
  .faq-item-title h1,
  .faq-sub-item-title h1 {
    padding-right: clamp(28px, 7vw, 36px) !important;
  }
  
  /* Mobile (small): Further reduce FAQ font sizes */
  .faq-page-item .faq-item-title .sub-page-h1 {
    font-size: clamp(16px, 4vw, 22px) !important;
    line-height: 1.3 !important;
  }
  
  .faq-sub-item-title .sub-page-h1-small {
    font-size: clamp(11px, 2.8vw, 14px) !important;
    line-height: 1.4 !important;
  }
  
  .faq-item-text .sub-page-p-small-faq,
  .faq-page-sub-block .faq-item-text p,
  .faq-page-sub-block .faq-item-text .sub-page-p-small-faq {
    font-size: clamp(10px, 2.5vw, 12px) !important;
    line-height: 1.5 !important;
  }
}

/* ... existing code ... */
/* Offering page responsive tweaks */
.sub-page-hero.background-6-offering .sub-hero-content-block {
  position: relative;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 16px;
}
.sub-page-hero.background-6-offering .sub-hero-desc-block {
  position: static !important;
  width: 100% !important;
}

#unique .sub-page-main-focus-grid,
#togo .sub-page-main-focus-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 36px;
  align-items: center;
}
#unique .sub-focus-grid-image-block img,
#togo .sub-focus-grid-image-block img {
  width: 100%;
  height: auto;
  border-radius: 24px;
}
#unique .sub-focus-grid-text-block,
#togo .sub-focus-grid-text-block {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.offering-focus-sub-block {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}
.offering-sub-block-item {
  padding: 20px 18px;
  border-radius: 18px;
  box-shadow: 0 10px 26px rgba(0,0,0,0.05);
  background: #fff;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
  text-align: center;
}
.offering-sub-block-item img {
  width: 72px;
  height: 72px;
}

@media (max-width: 991px) {
  .sub-page-hero.background-6-offering {
    padding: clamp(44px, 9vh, 80px) clamp(28px, 6vw, 60px) clamp(32px, 8vh, 56px);
  }
  #unique .sub-page-main-focus-grid,
  #togo .sub-page-main-focus-grid {
    gap: 28px;
  }
  .offering-focus-sub-block {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
  }
}

@media (max-width: 767px) {
  .sub-page-hero.background-6-offering {
    padding: clamp(32px, 9vh, 56px) clamp(18px, 6vw, 32px) clamp(28px, 8vh, 44px);
  }
  .sub-page-hero.background-6-offering .sub-hero-content-block {
    gap: 12px;
  }
  .sub-page-hero.background-6-offering .sub-hero-h1 {
    font-size: clamp(34px, 8vw, 44px);
  }
  .sub-page-hero.background-6-offering .sub-hero-h2 {
    font-size: clamp(20px, 5.4vw, 26px);
  }
  .sub-page-hero.background-6-offering .sub-page-p-big-white {
    font-size: clamp(16px, 4.4vw, 20px);
  }
  #unique .sub-page-main-focus-grid,
  #togo .sub-page-main-focus-grid {
    grid-template-columns: minmax(0, 1fr);
    gap: 20px;
    text-align: left;
  }
  #unique .sub-focus-grid-text-block,
  #togo .sub-focus-grid-text-block {
    align-items: flex-start;
  }
  #unique .sub-focus-grid-image-block img,
  #togo .sub-focus-grid-image-block img {
    border-radius: 20px;
  }
  .offering-focus-sub-block {
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
  }
}

/* Mobile hamburger menu - hide desktop menu, show hamburger */
@media (max-width: 767px) {
  /* Hide desktop menu on mobile */
  .nav-menu-wrapper-three {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: #fff !important;
    z-index: 999 !important;
    transform: translateX(-100%) !important;
    transition: transform 0.3s ease !important;
    overflow-y: auto !important;
    padding-top: 80px !important;
  }
  
  /* Show mobile menu when hamburger is clicked */
  .w-nav[data-nav-menu-open="true"] .nav-menu-wrapper-three,
  .w-nav.w--open .nav-menu-wrapper-three {
    transform: translateX(0) !important;
  }
  
  /* Show hamburger button on mobile - positioned in top right but not sticky */
  .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;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    z-index: 1002 !important;
    position: relative !important;
    top: auto !important;
    right: auto !important;
    pointer-events: auto !important;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0.1) !important;
  }
  
  .menu-button.w-nav-button img {
    width: 24px !important;
    height: 24px !important;
    display: block !important;
    pointer-events: none !important;
  }
  
  /* Hamburger button stays in same position when menu is open */
  .w-nav[data-nav-menu-open="true"] .menu-button.w-nav-button,
  .w-nav.w--open .menu-button.w-nav-button {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    z-index: 1002 !important;
  }
  
  /* Mobile menu layout */
  .nav-menu-three {
    flex-direction: column !important;
    align-items: stretch !important;
    padding: 20px !important;
    gap: 0 !important;
  }
  
  .nav-menu-block {
    width: 100% !important;
    flex-direction: column !important;
    align-items: stretch !important;
    margin-bottom: 0 !important;
  }
  
  .nav-menu-block li {
    width: 100% !important;
    margin-bottom: 0 !important;
  }
  
  /* Add border to each dropdown category */
  .nav-dropdown {
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    margin-bottom: 12px !important;
    overflow: hidden !important;
    background: #fff !important;
  }
  
  /* Style the dropdown toggle */
  .nav-dropdown-toggle-2 {
    padding: 14px 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    transition: background-color 0.2s ease !important;
  }
  
  .nav-dropdown-toggle-2:hover {
    background-color: #f9fafb !important;
  }
  
  /* Style the dropdown icon */
  .nav-dropdown-icon {
    margin-left: auto !important;
    transition: transform 0.3s ease !important;
  }
  
  .nav-dropdown.w--open .nav-dropdown-icon {
    transform: rotate(180deg) !important;
  }
  
  /* Style the dropdown list - show in same box */
  .nav-dropdown-list.shadow-three.mobile-shadow-hide {
    position: static !important;
    box-shadow: none !important;
    border-top: 1px solid #e5e7eb !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    background: #f9fafb !important;
    width: 100% !important;
    display: none !important; /* Hidden by default */
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
  }
  
  /* Show dropdown when open */
  .nav-dropdown.w--open .nav-dropdown-list.shadow-three.mobile-shadow-hide {
    display: block !important;
    max-height: 1000px; /* Large enough to show all items */
    padding: 0 !important;
  }
  
  /* Style dropdown links */
  .nav-dropdown-link {
    display: block !important;
    padding: 12px 16px 12px 32px !important;
    color: #374151 !important;
    text-decoration: none !important;
    border-bottom: 1px solid #e5e7eb !important;
    transition: background-color 0.2s ease, color 0.2s ease !important;
    font-size: 14px !important;
  }
  
  .nav-dropdown-link:last-child {
    border-bottom: none !important;
  }
  
  .nav-dropdown-link:hover {
    background-color: #f3f4f6 !important;
    color: #1f2937 !important;
  }
  
  .nav-dropdown-link.is-active {
    background-color: #eff6ff !important;
    color: #1e40af !important;
    font-weight: 500 !important;
    border-left: 3px solid #1e40af !important;
    border-radius: 0 4px 4px 0 !important;
  }
  
  /* Ensure dropdown is visible when open */
  .nav-dropdown.w--open .nav-dropdown-list {
    display: block !important;
  }
  
  /* Style navigation links on mobile */
  .nav-link-2,
  .nav-link-accent-2 {
    display: block !important;
    padding: 14px 16px !important;
    width: 100% !important;
    text-align: left !important;
    border-radius: 12px !important;
    margin-bottom: 12px !important;
    background: #fff !important;
    border: 1px solid #e5e7eb !important;
    color: #374151 !important;
    text-decoration: none !important;
    transition: background-color 0.2s ease, color 0.2s ease !important;
    font-size: 14px !important;
    font-weight: 500 !important;
  }
  
  .nav-link-2:hover,
  .nav-link-accent-2:hover {
    background-color: #f9fafb !important;
    color: #1f2937 !important;
  }
  
  /* Style user dropdown and icons wrapper on mobile */
  .user-dd,
  .header-icons-wrapper {
    width: 100% !important;
    margin-bottom: 12px !important;
  }
  
  .user-dd {
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    padding: 14px 16px !important;
    background: #fff !important;
  }
  
  .header-icons-wrapper {
    display: flex !important;
    flex-direction: row !important;
    gap: 12px !important;
    justify-content: flex-start !important;
    padding: 14px 16px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    background: #fff !important;
  }
  
  /* Ensure hamburger button is visible and positioned correctly */
  .navbar-wrapper-three {
    justify-content: space-between !important;
    align-items: center !important;
    position: relative !important;
  }
  
  /* Ensure hamburger button is visible on mobile */
  .menu-button.w-nav-button {
    display: flex !important;
    order: 2 !important;
  }
  
  /* Ensure logo stays visible and positioned on left */
  .navbar-brand-three {
    position: relative !important;
    left: auto !important;
    transform: none !important;
    z-index: 1000 !important;
    order: 1 !important;
    flex: 0 0 auto !important;
  }
  
  /* Hide desktop menu by default on mobile - it will slide in when hamburger is clicked */
  .nav-menu-wrapper-three {
    display: block !important;
  }
}

/* Explore page animations */
.explore-grid-sub-block {
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
}

/* Removed card pop-up hover effect - only image and button animate */

.explore-grid-image-block {
  overflow: hidden !important;
  transition: transform 0.4s ease !important;
}

.explore-grid-sub-block:hover .explore-grid-image-block {
  transform: scale(1.05) !important;
}

.explore-grid-image-block img {
  transition: transform 0.4s ease !important;
}

.explore-grid-sub-block:hover .explore-grid-image-block img {
  transform: scale(1.08) !important;
}

.sub-focus-grid-image-block {
  overflow: hidden !important;
}

/* Removed image zoom hover effect for grid-sub-image-block */

.blog-button {
  transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease !important;
  position: relative !important;
  overflow: hidden !important;
}

.blog-button:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2) !important;
}

.blog-button::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent) !important;
  transition: left 0.5s ease !important;
}

.blog-button:hover::before {
  left: 100% !important;
}

/* Button second hover effects for Explore page sections */
.main-section-2 .button-second,
.cta-section .button-second {
  transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease !important;
  position: relative !important;
  overflow: hidden !important;
}

.main-section-2 .button-second:hover,
.cta-section .button-second:hover {
  transform: translateY(-3px) scale(1.02) !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25) !important;
}

.main-section-2 .button-second::after,
.cta-section .button-second::after {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 0 !important;
  height: 0 !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.2) !important;
  transform: translate(-50%, -50%) !important;
  transition: width 0.6s ease, height 0.6s ease, opacity 0.6s ease !important;
  opacity: 0 !important;
  z-index: 0 !important;
}

.main-section-2 .button-second:hover::after,
.cta-section .button-second:hover::after {
  width: 300px !important;
  height: 300px !important;
  opacity: 1 !important;
}

.main-section-2 .button-second > *,
.cta-section .button-second > *,
.button-second > *,
a.button-second > * {
  position: relative !important;
  z-index: 1 !important;
}

/* Explore page hero now uses same styling as What is Infinity page - see mobile sections above */

@media (max-width: 767px) {
  /* Process page main content - mobile */
  .sub-page-main-text-block {
    margin-bottom: clamp(24px, 5vh, 40px) !important;
    text-align: left !important;
  }
  
  .sub-page-main-text-block .sub-page-h1 {
    font-size: clamp(20px, 5vw, 32px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(12px, 3vh, 20px) !important;
  }
  
  .sub-page-main-text-block .sub-page-p-big {
    font-size: clamp(14px, 3.5vw, 18px) !important;
    line-height: 1.5 !important;
  }
  
  /* Process steps grid - mobile optimization */
  .process-journey-block {
    margin-top: clamp(24px, 5vh, 40px) !important;
  }
  
  .process-steps-grid {
    gap: clamp(12px, 3vw, 16px) !important;
  }
  
  .process-step {
    padding: clamp(14px, 3.5vw, 18px) !important;
    border-radius: 12px !important;
  }
  
  .process-step h3.sub-page-h1-small {
    font-size: clamp(16px, 4vw, 20px) !important;
    line-height: 1.3 !important;
    margin: 8px 0 6px !important;
  }
  
  .process-step p.sub-page-p-small {
    font-size: clamp(13px, 3.2vw, 15px) !important;
    line-height: 1.5 !important;
  }
  
  .process-icon {
    width: clamp(36px, 9vw, 44px) !important;
    height: clamp(36px, 9vw, 44px) !important;
    font-size: clamp(16px, 4vw, 20px) !important;
    margin-bottom: clamp(8px, 2vh, 12px) !important;
  }
  
  .process-step h3 {
    font-size: clamp(18px, 4.5vw, 22px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(8px, 2vh, 12px) !important;
  }
  
  .process-step p {
    font-size: clamp(14px, 3.5vw, 16px) !important;
    line-height: 1.5 !important;
  }
  
  /* Process tips section - mobile */
  .process-tips {
    margin-top: clamp(24px, 5vh, 40px) !important;
    padding: clamp(16px, 4vw, 20px) !important;
    text-align: left !important;
  }
  
  /* Process page CTA section - mobile optimization */
  .cta-section {
    padding-top: clamp(40px, 8vh, 60px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
  }
  
  .cta-section .cta-grid {
    gap: clamp(20px, 5vw, 28px) !important;
    grid-template-columns: 1fr !important;
  }
  
  .cta-section .cta-item {
    text-align: center !important;
  }
  
  .cta-section .heading {
    font-size: clamp(20px, 5vw, 28px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(12px, 3vh, 16px) !important;
  }
  
  .cta-section .cta-p {
    font-size: clamp(14px, 3.5vw, 18px) !important;
    line-height: 1.5 !important;
    margin-bottom: clamp(20px, 4vh, 24px) !important;
  }
  
  .cta-section .button-second.w-button {
    width: 100% !important;
    max-width: 280px !important;
    margin: 0 auto !important;
    padding: clamp(12px, 3vw, 14px) clamp(20px, 5vw, 28px) !important;
    font-size: clamp(14px, 3.5vw, 16px) !important;
  }
  
  .cta-section .cta-image {
    text-align: center !important;
  }
  
  .cta-section .cta-image img {
    width: clamp(120px, 30vw, 175px) !important;
    height: auto !important;
  }
  
  .process-tips h3 {
    font-size: clamp(20px, 5vw, 24px) !important;
    margin-bottom: clamp(12px, 3vh, 16px) !important;
  }
  
  .process-tips .sub-page-p-small,
  .process-tips ul {
    font-size: clamp(14px, 3.5vw, 16px) !important;
    line-height: 1.6 !important;
  }
  
  .process-tips ul {
    padding-left: clamp(20px, 5vw, 24px) !important;
    margin: clamp(12px, 3vh, 16px) 0 !important;
  }
  
  .process-tips li {
    margin-bottom: clamp(8px, 2vh, 12px) !important;
  }
  
  /* Testimonials page - mobile image optimization */
  .testimonials-sub-block-item-block .testimonial-tab-item-image-block,
  .testimonials-sub-block-item-block-last .testimonial-tab-item-image-block {
    width: clamp(100px, 25vw, 160px) !important;
    height: clamp(100px, 25vw, 160px) !important;
    flex-shrink: 0 !important;
    max-width: clamp(100px, 25vw, 160px) !important;
    max-height: clamp(100px, 25vw, 160px) !important;
  }
  
  .testimonials-sub-block-item-block .testimonial-tab-image-background-block,
  .testimonials-sub-block-item-block-last .testimonial-tab-image-background-block {
    min-width: clamp(100px, 25vw, 160px) !important;
    min-height: clamp(100px, 25vw, 160px) !important;
    width: 100% !important;
    height: 100% !important;
    max-width: clamp(100px, 25vw, 160px) !important;
    max-height: clamp(100px, 25vw, 160px) !important;
    overflow: visible !important;
  }
  
  .testimonials-sub-block-item-block .testimonial-tab-image-sub-block,
  .testimonials-sub-block-item-block-last .testimonial-tab-image-sub-block {
    max-width: 100% !important;
    width: 100% !important;
    height: calc(100% + clamp(16px, 4vw, 32px)) !important;
    inset: clamp(8px, 2vw, 16px) clamp(-8px, -2vw, -16px) clamp(-8px, -2vw, -16px) clamp(8px, 2vw, 16px) !important;
    overflow: visible !important;
  }
  
  .testimonials-sub-block-item-block .testimonial-tab-image-sub-block img,
  .testimonials-sub-block-item-block-last .testimonial-tab-image-sub-block img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center bottom !important;
  }
  
  /* Testimonials tabs menu - mobile optimization */
  .testimonial-tabs-block .tabs-menu {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-behavior: smooth !important;
    gap: clamp(12px, 3vw, 20px) !important;
    padding: 0 clamp(16px, 4vw, 24px) !important;
    margin: 0 !important;
    scrollbar-width: thin !important;
    scrollbar-color: rgba(0,0,0,0.2) transparent !important;
  }
  
  .testimonial-tabs-block .tabs-menu::-webkit-scrollbar {
    height: 4px !important;
  }
  
  .testimonial-tabs-block .tabs-menu::-webkit-scrollbar-track {
    background: transparent !important;
  }
  
  .testimonial-tabs-block .tabs-menu::-webkit-scrollbar-thumb {
    background-color: rgba(0,0,0,0.2) !important;
    border-radius: 2px !important;
  }
  
  .testimonial-tabs-block .testimonials-tab {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
    font-size: clamp(14px, 3.5vw, 18px) !important;
    padding: clamp(10px, 2.5vw, 14px) clamp(16px, 4vw, 24px) !important;
    min-height: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    border-radius: 8px !important;
    transition: all 0.2s ease !important;
  }
  
  .testimonial-tabs-block .testimonials-tab.w--current {
    font-size: clamp(14px, 3.5vw, 18px) !important;
    font-weight: 600 !important;
    background-color: rgba(0,0,0,0.05) !important;
  }
  
  .testimonial-tabs-block .testimonials-tab div {
    white-space: nowrap !important;
  }
  
  /* Testimonials green section - mobile optimization */
  .testimonials-green .sub-page-colored-section-block {
    padding: clamp(24px, 6vh, 40px) clamp(16px, 4vw, 24px) !important;
  }
  
  .testimonials-colored-section-sub-block-first {
    flex-direction: column !important;
    gap: clamp(20px, 5vw, 32px) !important;
    align-items: center !important;
    text-align: center !important;
  }
  
  .testimonials-colored-section-sub-block-first .sub-block-image-block {
    width: clamp(120px, 30vw, 200px) !important;
    height: clamp(120px, 30vw, 200px) !important;
    border-radius: 50% !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
  }
  
  .testimonials-colored-section-sub-block-first .sub-block-image-block img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }
  
  .testimonials-colored-section-sub-block-first .sub-block-text-block {
    text-align: center !important;
    align-items: center !important;
    width: 100% !important;
  }
  
  .testimonials-colored-section-sub-block-first .sub-page-h1-white {
    font-size: clamp(20px, 5vw, 28px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(12px, 3vh, 16px) !important;
  }
  
  .testimonials-colored-section-sub-block-first .sub-page-p-big-white {
    font-size: clamp(14px, 3.5vw, 18px) !important;
    line-height: 1.5 !important;
  }
  
  .testimonials-colored-section-sub-block-second {
    flex-direction: column !important;
    gap: clamp(16px, 4vw, 24px) !important;
    margin-top: clamp(24px, 6vh, 32px) !important;
  }
  
  .testimonials-list-block {
    min-width: auto !important;
    min-height: auto !important;
    width: 100% !important;
    padding: clamp(16px, 4vw, 24px) !important;
  }
  
  .testimonials-list {
    font-size: clamp(14px, 3.5vw, 16px) !important;
    line-height: 1.6 !important;
    padding-left: clamp(16px, 4vw, 20px) !important;
    gap: clamp(10px, 2.5vw, 14px) !important;
  }
  
  .testimonials-list li {
    font-size: clamp(14px, 3.5vw, 16px) !important;
    line-height: 1.6 !important;
  }
  
  /* Testimonials notice block - mobile optimization */
  .testimonials-notice-block {
    padding: clamp(20px, 5vh, 32px) clamp(16px, 4vw, 24px) !important;
    margin: clamp(24px, 6vh, 40px) auto !important;
    max-width: 100% !important;
    gap: clamp(16px, 4vw, 20px) !important;
  }
  
  .testimonials-notice-block .sub-page-light-p {
    font-size: clamp(14px, 3.5vw, 18px) !important;
    line-height: 1.6 !important;
    margin-bottom: clamp(12px, 3vh, 16px) !important;
  }
  
  .testimonials-notice-block .sub-page-light-p:last-child {
    margin-bottom: 0 !important;
  }
  
  .testimonials-notice-block .sub-page-light-p strong {
    font-weight: 600 !important;
  }
  
  /* Testimonials page last block - mobile optimization */
  .testimonials-page-last-block {
    flex-direction: column !important;
    gap: clamp(24px, 6vh, 40px) !important;
    align-items: center !important;
    padding: clamp(24px, 6vh, 40px) clamp(16px, 4vw, 24px) !important;
  }
  
  .testimonials-page-last-block .last-block-image-block {
    width: 100% !important;
    max-width: clamp(280px, 70vw, 460px) !important;
    min-width: auto !important;
    border-radius: clamp(15px, 4vw, 30px) !important;
    overflow: hidden !important;
  }
  
  .testimonials-page-last-block .last-block-image-block img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
  }
  
  .testimonials-page-last-block .last-block-text-block {
    width: 100% !important;
    text-align: left !important;
    align-items: flex-start !important;
    gap: clamp(12px, 3vw, 20px) !important;
  }
  
  .testimonials-page-last-block .last-block-h2 {
    font-size: clamp(18px, 4.5vw, 26px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(6px, 1.5vh, 10px) !important;
    font-weight: normal !important;
  }
  
  .testimonials-page-last-block .last-block-h1 {
    font-size: clamp(24px, 6vw, 36px) !important;
    line-height: 1.2 !important;
    margin-bottom: clamp(10px, 2.5vh, 14px) !important;
    font-weight: 500 !important;
  }
  
  .testimonials-page-last-block .last-block-h3 {
    font-size: clamp(14px, 3.5vw, 18px) !important;
    line-height: 1.5 !important;
    margin-bottom: clamp(16px, 4vh, 20px) !important;
    font-weight: 300 !important;
  }
  
  .testimonials-page-last-block .sub-page-focus-button-third {
    margin-top: clamp(12px, 3vh, 16px) !important;
    padding: clamp(10px, 2.5vw, 12px) clamp(18px, 4.5vw, 24px) !important;
    font-size: clamp(13px, 3.2vw, 15px) !important;
    border-radius: clamp(8px, 2vw, 10px) !important;
  }
  
  .testimonials-page-last-block .sub-page-focus-button-third .focus-text {
    font-size: clamp(13px, 3.2vw, 15px) !important;
    line-height: 1.4 !important;
  }
  
  .testimonials-page-last-block .sub-page-focus-button-third .focus-icon-block {
    width: clamp(16px, 4vw, 20px) !important;
    height: clamp(16px, 4vw, 20px) !important;
  }
  
  .testimonials-page-last-block .sub-page-focus-button-third .focus-icon-block img {
    width: 100% !important;
    height: 100% !important;
  }
  
}

/* Login page mobile optimizations */
@media (max-width: 767px) {
  .login-main-block {
    grid-template-columns: 1fr !important;
    gap: 30px !important;
    padding: 0 16px !important;
  }
  
  .login-text-block {
    order: 1 !important;
  }
  
  .login-image-block {
    order: 2 !important;
    text-align: center !important;
  }
  
  .login-image-block img {
    max-width: 100% !important;
    max-height: 300px !important;
    height: auto !important;
    border-radius: 16px !important;
  }
  
  .login-title-block {
    text-align: center !important;
  }
  
  .login-title-block h1 {
    font-size: clamp(24px, 6vw, 32px) !important;
  }
  
  .sign-in-text {
    font-size: clamp(16px, 4vw, 20px) !important;
    line-height: 1.4 !important;
    text-align: center !important;
  }
  
  .form-block {
    margin-bottom: 16px !important;
  }
  
  .form-text {
    font-size: clamp(14px, 3.5vw, 16px) !important;
    margin-bottom: 8px !important;
  }
  
  .input.w-input {
    font-size: 16px !important;
    padding: 12px 16px !important;
    border-radius: 12px !important;
  }
  
  .login-sub-text-block {
    margin-top: 16px !important;
    margin-bottom: 16px !important;
    justify-content: center !important;
  }
  
  .remember-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin: 20px 0 !important;
    padding: 12px 0 !important;
  }
  
  .remember-text {
    font-size: clamp(14px, 3.5vw, 16px) !important;
  }
  
  .button-divide-block {
    margin: 24px 0 !important;
  }
  
  .horizontal-line-block {
    width: 30% !important;
  }
  
  .login-button-block,
  .login-button-block-colored {
    width: 100% !important;
    padding: 14px 20px !important;
    font-size: clamp(16px, 4vw, 18px) !important;
    border-radius: 12px !important;
  }
  
  .log-in-block {
    text-align: center !important;
    margin-top: 24px !important;
  }
  
  .log-in-block h1 {
    font-size: clamp(14px, 3.5vw, 16px) !important;
  }
}


/* User area and dashboard pages mobile optimizations */
@media (max-width: 767px) {
  .user-area-wrapper {
    gap: 16px !important;
  }
  
  .user-area-navbar {
    padding: 16px !important;
    border-radius: 12px !important;
  }
  
  .user-navbar-header {
    margin-bottom: 16px !important;
    padding-bottom: 12px !important;
  }
  
  .user-navbar-title {
    font-size: clamp(18px, 4.5vw, 20px) !important;
  }
  
  .user-navbar-sub {
    font-size: clamp(12px, 3vw, 13px) !important;
    margin-top: 4px !important;
  }
  
  .user-navbar-nav {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 6px !important;
    justify-content: flex-start !important;
  }
  
  .user-navbar-item {
    width: 100% !important;
    padding: 12px 14px !important;
    justify-content: flex-start !important;
    flex-shrink: 1 !important;
  }
  
  .user-navbar-logout {
    margin-left: 0 !important;
    margin-top: 8px !important;
    border-top: 1px solid #e5e7eb !important;
    padding-top: 14px !important;
    flex-shrink: 1 !important;
    white-space: normal !important;
  }
  
  .user-navbar-item em {
    font-size: 11px !important;
  }
  
  .user-navbar-item strong {
    font-size: clamp(13px, 3.5vw, 14px) !important;
  }
  
  .user-content {
    padding: 0 !important;
    width: 100% !important;
  }
  
  /* Adjust main section padding on mobile */
  .main-section-2 {
    padding-top: 20px !important;
  }
  
  .user-content-header {
    padding-top: 0 !important;
    margin-bottom: 16px !important;
  }
  
  .user-content-header h1 {
    font-size: clamp(22px, 5.5vw, 28px) !important;
    margin-bottom: 8px !important;
  }
  
  .user-content-sub {
    font-size: clamp(14px, 3.5vw, 16px) !important;
  }
  
  /* User area grids and cards */
  .ua-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    margin-top: 16px !important;
  }
  
  .ua-card {
    border-radius: 12px !important;
    box-shadow: 0 4px 12px rgba(0,0,0,.08) !important;
  }
  
  .ua-card-header {
    padding: 12px 14px 8px !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }
  
  .ua-card-title {
    font-size: clamp(16px, 4vw, 18px) !important;
  }
  
  .ua-card-sub {
    font-size: clamp(12px, 3vw, 13px) !important;
  }
  
  .ua-card-body {
    padding: 12px 14px 14px !important;
    gap: 10px !important;
  }
  
  .ua-card-thumb {
    width: 40px !important;
    height: 40px !important;
    flex-shrink: 0 !important;
  }
  
  .ua-thumb-desc {
    font-size: clamp(14px, 3.5vw, 15px) !important;
    line-height: 1.5 !important;
  }
  
  .ua-list-title {
    font-size: clamp(14px, 3.5vw, 15px) !important;
  }
  
  .ua-list-sub {
    font-size: clamp(12px, 3vw, 13px) !important;
  }
  
  .ua-list-item {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
    padding: 12px !important;
  }
  
  .ua-right {
    text-align: left !important;
    width: 100% !important;
  }
  
  /* Guide card */
  .ua-guide {
    flex-direction: column !important;
    align-items: flex-start !important;
    padding: 14px !important;
    gap: 12px !important;
  }
  
  .ua-guide-avatar {
    width: 48px !important;
    height: 48px !important;
    font-size: 18px !important;
  }
  
  .ua-guide-name {
    font-size: clamp(15px, 3.8vw, 17px) !important;
  }
  
  .ua-guide-sub {
    font-size: clamp(11px, 2.8vw, 12px) !important;
  }
  
  /* Buttons */
  .ua-row {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
  
  .ua-btn-primary,
  .ua-btn-outline,
  .ua-btn-danger {
    width: 100% !important;
    padding: 12px 16px !important;
    font-size: clamp(14px, 3.5vw, 16px) !important;
    text-align: center !important;
    min-height: 44px !important;
  }
  
  .ua-btn-block {
    width: 100% !important;
  }
  
  /* Forms */
  .ua-form {
    width: 100% !important;
  }
  
  .ua-field {
    margin-top: 14px !important;
  }
  
  .ua-field label.form-text {
    font-size: clamp(14px, 3.5vw, 15px) !important;
    margin-bottom: 6px !important;
  }
  
  .ua-field .input,
  .ua-field .message {
    font-size: 16px !important;
    padding: 12px 14px !important;
    border-radius: 10px !important;
    width: 100% !important;
  }
  
  .ua-field textarea.message {
    min-height: 100px !important;
  }
  
  .ua-settings-grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  
  .ua-settings-grid .ua-form {
    width: 100% !important;
  }
  
  /* Dropzone */
  .ua-dropzone {
    padding: 20px 16px !important;
    min-height: 80px !important;
  }
  
  .ua-drop-title {
    font-size: clamp(14px, 3.5vw, 16px) !important;
  }
  
  /* Alerts */
  .ua-alert {
    padding: 12px 14px !important;
    font-size: clamp(13px, 3.2vw, 14px) !important;
    margin: 12px 0 !important;
  }
  
  /* Active card */
  .active-card {
    flex-direction: column !important;
    align-items: flex-start !important;
    padding: 16px !important;
    gap: 16px !important;
    border-radius: 12px !important;
  }
  
  .active-card-left {
    width: 100% !important;
  }
  
  .active-title {
    font-size: clamp(16px, 4vw, 18px) !important;
  }
  
  .active-sub {
    font-size: clamp(13px, 3.5vw, 14px) !important;
  }
  
  /* Support bar */
  .support-bar {
    flex-direction: column !important;
    gap: 12px !important;
    padding: 12px !important;
  }
  
  .support-input {
    width: 100% !important;
    font-size: 16px !important;
  }
  
  .support-button {
    width: 100% !important;
    text-align: center !important;
  }
  
  /* User sections */
  .user-section {
    padding: 0 !important;
  }
  
  /* Subscription cards specific adjustments */
  .ua-card .ua-card-header {
    flex-wrap: nowrap !important;
  }
  
  .ua-card .ua-card-header > div:last-child {
    flex: 1 !important;
    min-width: 0 !important;
  }
  
  /* Badges */
  .ua-badge {
    font-size: clamp(10px, 2.5vw, 11px) !important;
    padding: 4px 8px !important;
  }
  
  /* Dashboard tables and content */
  table {
    font-size: clamp(12px, 3vw, 14px) !important;
    display: block !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  
  table thead {
    display: none !important;
  }
  
  table tbody tr {
    display: block !important;
    margin-bottom: 16px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    padding: 12px !important;
  }
  
  table tbody td {
    display: block !important;
    text-align: left !important;
    padding: 8px 0 !important;
    border: none !important;
  }
  
  table tbody td:before {
    content: attr(data-label) ": ";
    font-weight: 600;
    display: inline-block;
    min-width: 100px;
  }
  
  /* Form buttons */
  .ua-form .button-second.w-button {
    width: 100% !important;
    padding: 12px 20px !important;
    font-size: clamp(15px, 3.8vw, 17px) !important;
    min-height: 44px !important;
  }
  
  /* Subscription cancel/resume forms */
  form[action*="subscription"] {
    width: 100% !important;
  }
  
  form[action*="subscription"] button {
    width: 100% !important;
  }
}

/* Partner and Guide dashboard mobile optimizations */
@media (max-width: 767px) {
  .partner-dashboard-content,
  .guide-dashboard-content {
    padding: 0 16px !important;
  }
  
  .dashboard-header h1 {
    font-size: clamp(22px, 5.5vw, 28px) !important;
  }
  
  .dashboard-header p {
    font-size: clamp(14px, 3.5vw, 16px) !important;
  }
  
  .dashboard-stats {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  
  .stat-card {
    padding: 16px !important;
  }
  
  .stat-card h2 {
    font-size: clamp(18px, 4.5vw, 22px) !important;
  }
  
  .stat-card p {
    font-size: clamp(14px, 3.5vw, 16px) !important;
  }
  
  .form-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  
  .form-group label {
    font-size: clamp(14px, 3.5vw, 16px) !important;
  }
  
  .form-group input,
  .form-group textarea,
  .form-group select {
    font-size: 16px !important;
    padding: 12px 16px !important;
    border-radius: 12px !important;
  }
  
  .dashboard-button {
    width: 100% !important;
    padding: 14px 20px !important;
    font-size: clamp(16px, 4vw, 18px) !important;
  }
}

/* Admin dashboard mobile optimizations */
@media (max-width: 767px) {
  .admin-dashboard-content {
    padding: 0 16px !important;
  }
  
  .admin-header h1 {
    font-size: clamp(22px, 5.5vw, 28px) !important;
  }
  
  .admin-stats-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  
  .admin-card {
    padding: 16px !important;
  }
  
  .admin-card h2 {
    font-size: clamp(18px, 4.5vw, 22px) !important;
  }
  
  .admin-table-wrapper {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
}

/* Extra small devices */
@media (max-width: 479px) {
  .login-main-block {
    padding: 0 12px !important;
    gap: 24px !important;
  }
  
  .login-image-block img {
    max-height: 250px !important;
  }
  
  .user-area-dashboard {
    padding: 0 12px !important;
    gap: 16px !important;
  }
  
  .user-sidebar {
    padding: 14px !important;
    margin-bottom: 16px !important;
  }
  
  .user-nav-item {
    padding: 12px 14px !important;
  }
  
  .ua-card {
    border-radius: 10px !important;
  }
  
  .ua-card-header {
    padding: 10px 12px 6px !important;
  }
  
  .ua-card-body {
    padding: 10px 12px 12px !important;
  }
  
  .ua-card-thumb {
    width: 36px !important;
    height: 36px !important;
  }
  
  .ua-guide {
    padding: 12px !important;
  }
  
  .ua-guide-avatar {
    width: 44px !important;
    height: 44px !important;
  }
  
  .active-card {
    padding: 14px !important;
    border-radius: 10px !important;
  }
  
  .ua-field {
    margin-top: 12px !important;
  }
  
  .ua-field .input,
  .ua-field .message {
    padding: 10px 12px !important;
  }
  
  .ua-btn-primary,
  .ua-btn-outline,
  .ua-btn-danger {
    padding: 11px 14px !important;
  }
  
  .ua-form .button-second.w-button {
    padding: 11px 18px !important;
  }
  
  .partner-dashboard-content,
  .guide-dashboard-content,
  .admin-dashboard-content {
    padding: 0 12px !important;
  }
  
  /* About-us page: Ensure ALL sections are full-size with no internal scrolling */
  .main-section-2,
  .cta-section {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
    height: auto !important;
  }
  
  .main-section-2 .container-full,
  .cta-section .container-full {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
    height: auto !important;
  }
  
  /* All about-us specific containers and grids */
  .about-history-grid,
  .about-faq-main-block,
  .about-text-block,
  .about-image-block,
  .about-faq-item,
  .about-faq-item .faq-item-text,
  .about-faq-item.open .faq-item-text,
  .cta-grid,
  .cta-item {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
    height: auto !important;
  }
  
  /* History grid section */
  .main-section-2:has(.about-history-grid) {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  .main-section-2:has(.about-history-grid) .container-full,
  .main-section-2 .container-full:has(.about-history-grid) {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: clamp(16px, 4vw, 24px) !important;
    padding-right: clamp(16px, 4vw, 24px) !important;
    margin-left: 0 !important;
    overflow: visible !important;
    max-height: none !important;
    margin-right: 0 !important;
  }
  
  /* FAQ section - fix overflow */
  .main-section-2:has(.about-faq-main-block) {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  .main-section-2:has(.about-faq-main-block) .container-full,
  .main-section-2 .container-full:has(.about-faq-main-block) {
    overflow: visible !important;
    max-height: none !important;
  }
  .about-faq-main-block {
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  .about-faq-item {
    overflow: visible !important;
  }
  .faq-item-text.about {
    overflow: visible !important;
  }
  .about-faq-item.open .faq-item-text {
    max-height: 10000px !important; /* Large enough for any content, but allows transition */
    overflow: visible !important;
  }
  
  /* Ensure all grid containers don't cause scrolling */
  .main-grid-3-list,
  .main-about-grid,
  .main-story-grid,
  .about-faq-main-block {
    overflow: visible !important;
    max-height: none !important;
  }
  
  .w-layout-grid.about-history-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    grid-column-gap: clamp(20px, 5vw, 40px) !important;
    grid-row-gap: clamp(24px, 6vh, 40px) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  .about-history-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    grid-column-gap: clamp(20px, 5vw, 40px) !important;
    grid-row-gap: clamp(24px, 6vh, 40px) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
    max-height: none !important;
    min-height: auto !important;
  }
  
  .about-history-grid-title-block {
    order: 1 !important;
    grid-column: 1 / -1 !important;
    grid-column-start: 1 !important;
    grid-column-end: -1 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  
  .about-history-grid-title-block .sub-page-h1 {
    font-size: clamp(24px, 6vw, 36px) !important;
    line-height: 1.3 !important;
    margin-bottom: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    text-align: left !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  
  .about-history-grid-p-block {
    order: 2 !important;
    grid-column: 1 / -1 !important;
    grid-column-start: 1 !important;
    grid-column-end: -1 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  
  .about-history-grid-p-block .sub-page-p-big {
    font-size: clamp(16px, 4vw, 20px) !important;
    line-height: 1.5 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  
  .about-grid-logo-block {
    order: 3 !important;
    grid-column: 1 / -1 !important;
    grid-column-start: 1 !important;
    grid-column-end: -1 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  
  .about-logo-block {
    min-width: auto !important;
    max-width: clamp(120px, 30vw, 200px) !important;
    width: 100% !important;
  }
  
  /* FAQ/Accordion section */
  .about-faq-main-block {
    margin-top: clamp(24px, 5vh, 40px) !important;
  }
  
  .about-faq-item {
    margin-bottom: clamp(8px, 2vh, 12px) !important;
    padding: clamp(16px, 4vw, 20px) !important;
  }
  
  .about-faq-item .faq-item-title {
    padding-bottom: clamp(12px, 3vh, 20px) !important;
    flex-wrap: wrap !important;
    gap: clamp(8px, 2vw, 12px) !important;
  }
  
  .about-faq-item .faq-item-title .sub-page-h1 {
    font-size: clamp(20px, 5vw, 28px) !important;
    line-height: 1.3 !important;
    margin-bottom: 0 !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }
  
  .about-faq-item .faq-item-text {
    margin-top: clamp(12px, 3vh, 24px) !important;
    grid-template-columns: 1fr !important;
    grid-column-gap: clamp(16px, 4vw, 40px) !important;
    grid-row-gap: clamp(16px, 4vh, 24px) !important;
    overflow: visible !important;
  }
  .about-faq-item.open .faq-item-text {
    max-height: 10000px !important; /* Large enough for any content, but allows transition */
    overflow: visible !important;
  }
  
  .about-faq-image-block {
    order: 1 !important;
    max-width: 65% !important;
    min-width: 0 !important;
    width: 65% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin-bottom: clamp(16px, 4vh, 24px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  
  .about-faq-image-block img,
  .about-faq-item .faq-item-text.about .about-faq-image-block img {
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
    display: block !important;
    border-radius: 12px !important;
    object-fit: contain !important;
  }
  
  .about-faq-text-block {
    order: 2 !important;
  }
  
  .about-faq-text-block .sub-page-p-small-light {
    font-size: clamp(14px, 3.5vw, 16px) !important;
    line-height: 1.6 !important;
  }
  
  /* Text block section */
  .about-text-block {
    margin-top: clamp(24px, 5vh, 40px) !important;
    margin-bottom: clamp(24px, 5vh, 40px) !important;
    text-align: left !important;
  }
  
  .about-text-title {
    font-size: clamp(24px, 6vw, 36px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(12px, 3vh, 20px) !important;
  }
  
  .about-text-block .sub-page-light-p {
    font-size: clamp(16px, 4vw, 20px) !important;
    line-height: 1.5 !important;
  }
  
  /* Founders image block section */
  .about-image-block {
    margin-top: clamp(24px, 5vh, 32px) !important;
    flex-direction: column !important;
    gap: clamp(16px, 4vh, 24px) !important;
    align-items: flex-start !important;
  }
  
  .about-image-right-block {
    order: 1 !important;
    max-width: 100% !important;
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
  }
  
  .about-image-right-block img {
    max-width: 100% !important;
    height: auto !important;
    width: auto !important;
  }
  
  .about-image-left-block {
    order: 2 !important;
    width: 100% !important;
  }
  
  .about-image-title {
    font-size: clamp(24px, 6vw, 32px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(4px, 1vh, 8px) !important;
  }
  
  .about-image-sub-title {
    font-size: clamp(18px, 4.5vw, 24px) !important;
    line-height: 1.3 !important;
  }
  
  /* CTA section adjustments for mobile */
  .cta-section {
    padding-top: clamp(60px, 12vh, 100px) !important;
    padding-bottom: clamp(60px, 12vh, 100px) !important;
  }
  
  .cta-grid {
    grid-template-columns: 1fr !important;
    gap: clamp(24px, 6vh, 40px) !important;
  }
  
  .cta-item {
    order: 1 !important;
    text-align: left !important;
  }
  
  .cta-item .heading {
    font-size: clamp(24px, 6vw, 36px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(12px, 3vh, 20px) !important;
  }
  
  .cta-item .cta-p {
    font-size: clamp(16px, 4vw, 18px) !important;
    line-height: 1.5 !important;
    margin-bottom: clamp(24px, 5vh, 40px) !important;
  }
  
  .cta-image {
    order: 2 !important;
    max-width: clamp(100px, 25vw, 175px) !important;
    margin: 0 auto !important;
  }
}

/* ============================================
   PARTNER PAGE MOBILE OPTIMIZATIONS
   ============================================ */

@media (max-width: 767px) {
  /* Partner page main sections spacing */
  .sub-page-hero.background-5-partner ~ .main-section-1 {
    padding-top: clamp(40px, 8vh, 60px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
    background-color: #1F3D2B !important;
  }
  
  /* Ensure focus-colored-grid-block has background color on mobile */
  .main-section-1 .focus-colored-grid-block {
    background-color: #1F3D2B !important;
  }
  
  /* Partner page main-section-2 - optimized top margin for mobile */
  .sub-page-hero.background-5-partner ~ .main-section-2 {
    padding-top: clamp(24px, 5vh, 40px) !important;
    padding-bottom: clamp(40px, 8vh, 60px) !important;
    margin-top: 0 !important;
  }
  
  /* Partner page first main-section-2 after hero - reduce top spacing even more */
  .sub-page-hero.background-5-partner ~ .main-section-2:first-of-type {
    padding-top: clamp(20px, 4vh, 32px) !important;
    margin-top: 0 !important;
  }
  
  /* Partner page main text block */
  .sub-page-main-text-block-big {
    padding: 0 clamp(16px, 5vw, 24px) !important;
    margin-bottom: clamp(24px, 5vh, 40px) !important;
  }
  
  .sub-page-main-text-block-big .sub-page-h1 {
    font-size: clamp(24px, 6vw, 32px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(16px, 4vh, 24px) !important;
  }
  
  .sub-page-main-text-block-big .sub-page-p-big {
    font-size: clamp(16px, 4.2vw, 18px) !important;
    line-height: 1.6 !important;
  }
  
  /* Partner page focus grid sections */
  .sub-page-main-focus-grid {
    gap: clamp(8px, 2vh, 14px) !important;
    padding: 0 clamp(16px, 5vw, 24px) !important;
  }
  
  /* Move button below section on mobile for main-section-2 */
  .main-section-2 .sub-page-main-focus-block {
    display: flex !important;
    flex-direction: column !important;
  }
  
  .main-section-2 .sub-page-main-focus-grid {
    display: grid !important;
  }
  
  .main-section-2 .sub-focus-grid-button-block {
    order: 999 !important;
    margin-top: clamp(20px, 5vh, 32px) !important;
    margin-bottom: 0 !important;
    width: 100% !important;
    padding: 0 clamp(16px, 5vw, 24px) !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }
  
  
  .sub-focus-grid-text-block {
    padding: 0 !important;
  }
  
  .sub-focus-grid-text-block .sub-page-h1-medium {
    font-size: clamp(22px, 5.5vw, 28px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(4px, 1vh, 8px) !important;
  }
  
  .sub-focus-grid-text-block .sub-page-light-p {
    font-size: clamp(16px, 4.2vw, 20px) !important;
    line-height: 1.5 !important;
    margin-bottom: clamp(6px, 1.5vh, 12px) !important;
  }
  
  .sub-focus-grid-text-block .sub-page-p-small {
    font-size: clamp(15px, 4vw, 17px) !important;
    line-height: 1.6 !important;
  }
  
  /* Partner page images */
  .sub-focus-grid-image-block {
    margin: clamp(8px, 2vh, 14px) auto !important;
  }
  
  .sub-focus-grid-image-block img {
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
    border-radius: 12px !important;
    object-fit: cover !important;
  }
  
  /* Partner page colored grid sections */
  .focus-colored-grid-block {
    padding: clamp(32px, 8vh, 48px) clamp(16px, 5vw, 24px) clamp(32px, 8vh, 48px) clamp(16px, 5vw, 24px) !important;
    display: flex !important;
    flex-direction: column !important;
    background-color: #1F3D2B !important;
  }
  
  /* Ensure main-section-1 with colored grid has background */
  .main-section-1:has(.focus-colored-grid-block) {
    background-color: #1F3D2B !important;
  }
  
  /* Ensure button block is at the bottom - removed conflicting rule */
  
  /* Force single column layout for partner page colored grid on mobile */
  .focus-colored-grid-block .sub-page-main-focus-grid-colored,
  .sub-page-main-focus-grid-colored {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important;
    grid-column-gap: 0 !important;
    grid-row-gap: clamp(20px, 5vh, 32px) !important;
    gap: clamp(20px, 5vh, 32px) !important;
    display: grid !important;
  }
  
  .main-focus-grid-title-block {
    grid-column: 1 !important;
    grid-row: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: clamp(24px, 6vh, 36px) !important;
  }
  
  .main-focus-grid-title-block .sub-page-h1-medium-light {
    font-size: clamp(22px, 5.5vw, 28px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(12px, 3vh, 18px) !important;
  }
  
  .main-focus-grid-text-block {
    grid-column: 1 !important;
    grid-row: auto !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  
  .main-focus-grid-text-block .sub-page-light-p-white {
    font-size: clamp(15px, 4vw, 18px) !important;
    line-height: 1.5 !important;
    padding: clamp(12px, 3vh, 18px) 0 !important;
  }
  
  .main-focus-grid-image-block {
    margin: clamp(20px, 5vh, 32px) auto !important;
  }
  
  .main-focus-grid-image-block img {
    max-width: 100% !important;
    width: 100% !important;
    height: auto !important;
    border-radius: 12px !important;
    object-fit: cover !important;
  }
  
  .main-focus-grid-text-block-second .sub-page-light-p-white-main {
    font-size: clamp(18px, 4.5vw, 22px) !important;
    line-height: 1.4 !important;
    margin-bottom: clamp(12px, 3vh, 18px) !important;
  }
  
  .main-focus-grid-text-block-second .sub-page-p-small-white {
    font-size: clamp(15px, 4vw, 17px) !important;
    line-height: 1.6 !important;
  }
  
  .colored-list {
    padding-left: clamp(20px, 5vw, 28px) !important;
    margin: clamp(12px, 3vh, 18px) 0 !important;
  }
  
  .colored-list li {
    font-size: clamp(15px, 4vw, 17px) !important;
    line-height: 1.6 !important;
    margin-bottom: clamp(8px, 2vh, 12px) !important;
  }
  
  /* Partner page buttons */
  .sub-focus-grid-button-block {
    margin-top: clamp(24px, 6vh, 36px) !important;
    margin-bottom: clamp(20px, 5vh, 32px) !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    padding: 0 clamp(16px, 5vw, 24px) !important;
  }
  
  /* Partner page colored grid button block - match other button blocks exactly */
  .focus-colored-grid-block .sub-focus-grid-button-block,
  .main-section-1 .sub-focus-grid-button-block {
    margin-top: clamp(24px, 6vh, 36px) !important;
    margin-bottom: clamp(20px, 5vh, 32px) !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    padding: 0 clamp(16px, 5vw, 24px) !important;
  }
  
  
  /* Partner page buttons - optimized mobile styles */
  .sub-focus-grid-button-block a.button-second.w-button,
  .sub-focus-grid-button-block a.button-second-white.w-button,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white.w-button,
  .main-section-1 .sub-focus-grid-button-block a.button-second-white.w-button,
  .main-section-2 .sub-focus-grid-button-block a.button-second.w-button,
  .main-section-2 .sub-focus-grid-button-block .button-second.w-button,
  .sub-focus-grid-button-block .button-second.w-button,
  .sub-focus-grid-button-block .button-second-white.w-button,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white.w-button,
  .main-section-1 .sub-focus-grid-button-block .button-second-white.w-button,
  .sub-focus-grid-button-block a.button-second,
  .sub-focus-grid-button-block a.button-second-white,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white,
  .main-section-1 .sub-focus-grid-button-block a.button-second-white,
  .main-section-2 .sub-focus-grid-button-block a.button-second,
  .main-section-2 .sub-focus-grid-button-block .button-second,
  .sub-focus-grid-button-block .button-second,
  .sub-focus-grid-button-block .button-second-white {
    /* Layout & Sizing */
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 48px !important;
    height: auto !important;
    box-sizing: border-box !important;
    
    /* Padding - optimized for mobile touch targets */
    padding: 14px 20px 14px 44px !important;
    padding-top: 14px !important;
    padding-bottom: 14px !important;
    padding-left: 44px !important;
    padding-right: 20px !important;
    
    /* Typography */
    font-size: 15px !important;
    line-height: 1.4 !important;
    font-weight: 500 !important;
    white-space: normal !important;
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    text-align: center !important;
    
    /* Display & Alignment */
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    
    /* Spacing */
    margin-left: auto !important;
    margin-right: auto !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    
    /* Background & Border */
    background-position: 16px center !important;
    background-size: 18px !important;
    background-repeat: no-repeat !important;
    border-radius: 10px !important;
    
    /* Other */
    text-decoration: none !important;
    cursor: pointer !important;
  }
  
  /* Preserve button-second colors and styles */
  .sub-focus-grid-button-block .button-second,
  .sub-focus-grid-button-block a.button-second,
  .sub-focus-grid-button-block .button-second.w-button,
  .sub-focus-grid-button-block a.button-second.w-button,
  .main-section-2 .sub-focus-grid-button-block .button-second,
  .main-section-2 .sub-focus-grid-button-block a.button-second,
  .main-section-2 .sub-focus-grid-button-block .button-second.w-button,
  .main-section-2 .sub-focus-grid-button-block a.button-second.w-button {
    color: var(--black) !important;
    background-color: #3898ec00 !important;
    background-image: url('../images/buton-icon1.svg') !important;
    border: 1px solid #a0a0a0 !important;
    max-width: 100% !important;
    width: 100% !important;
  }
  
  /* Force main-section-2 button to be full width on mobile - highest specificity */
  .main-section-2 .sub-page-main-focus-block .sub-focus-grid-button-block .button-second,
  .main-section-2 .sub-page-main-focus-block .sub-focus-grid-button-block a.button-second,
  .main-section-2 .sub-page-main-focus-block .sub-focus-grid-button-block .button-second.w-button,
  .main-section-2 .sub-page-main-focus-block .sub-focus-grid-button-block a.button-second.w-button {
    max-width: 100% !important;
    width: 100% !important;
    min-width: 0 !important;
  }
  
  /* Preserve button-second-white colors and styles */
  .sub-focus-grid-button-block .button-second-white,
  .sub-focus-grid-button-block a.button-second-white,
  .sub-focus-grid-button-block .button-second-white.w-button,
  .sub-focus-grid-button-block a.button-second-white.w-button,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white.w-button,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white.w-button,
  .main-section-1 .sub-focus-grid-button-block .button-second-white,
  .main-section-1 .sub-focus-grid-button-block a.button-second-white,
  .main-section-1 .sub-focus-grid-button-block .button-second-white.w-button,
  .main-section-1 .sub-focus-grid-button-block a.button-second-white.w-button {
    color: var(--grey) !important;
    background-color: #3898ec00 !important;
    background-image: url('../images/focus-icon-white.svg') !important;
    border: 1px solid #a0a0a0 !important;
  }
  
  /* Partner page CTA section */
  .cta-section {
    padding-top: clamp(48px, 10vh, 64px) !important;
    padding-bottom: clamp(48px, 10vh, 64px) !important;
  }
  
  .cta-grid {
    gap: clamp(28px, 7vh, 40px) !important;
    padding: 0 clamp(16px, 5vw, 24px) !important;
  }
  
  .cta-item .heading {
    font-size: clamp(24px, 6vw, 32px) !important;
    line-height: 1.3 !important;
    margin-bottom: clamp(16px, 4vh, 24px) !important;
  }
  
  .cta-item .cta-p {
    font-size: clamp(16px, 4.2vw, 18px) !important;
    line-height: 1.6 !important;
    margin-bottom: clamp(24px, 6vh, 32px) !important;
  }
  
  .cta-item .button-second {
    width: 100% !important;
    max-width: 320px !important;
    padding: clamp(14px, 3.5vh, 18px) clamp(24px, 6vw, 32px) !important;
    font-size: clamp(15px, 4vw, 17px) !important;
    min-height: 48px !important;
  }
  
  .cta-image {
    max-width: clamp(120px, 30vw, 175px) !important;
    margin: 0 auto !important;
  }
}

@media (max-width: 479px) {
  /* Extra small mobile optimizations */
  /* Partner page first main-section-2 - even tighter spacing on small screens */
  .sub-page-hero.background-5-partner ~ .main-section-2:first-of-type {
    padding-top: clamp(16px, 3vh, 24px) !important;
    margin-top: 0 !important;
  }
  
  .sub-page-main-text-block-big .sub-page-h1 {
    font-size: clamp(22px, 5.5vw, 28px) !important;
  }
  
  .sub-page-main-text-block-big .sub-page-p-big {
    font-size: clamp(15px, 4vw, 17px) !important;
  }
  
  .sub-focus-grid-text-block .sub-page-h1-medium {
    font-size: clamp(20px, 5vw, 26px) !important;
  }
  
  .sub-focus-grid-text-block .sub-page-light-p {
    font-size: clamp(15px, 4vw, 18px) !important;
  }
  
  .sub-focus-grid-text-block .sub-page-p-small {
    font-size: clamp(14px, 3.8vw, 16px) !important;
  }
  
  .main-focus-grid-title-block .sub-page-h1-medium-light {
    font-size: clamp(20px, 5vw, 26px) !important;
  }
  
  .main-focus-grid-text-block .sub-page-light-p-white {
    font-size: clamp(14px, 3.8vw, 17px) !important;
  }
  
  .main-focus-grid-text-block-second .sub-page-light-p-white-main {
    font-size: clamp(16px, 4.2vw, 20px) !important;
  }
  
  .main-focus-grid-text-block-second .sub-page-p-small-white {
    font-size: clamp(14px, 3.8vw, 16px) !important;
  }
  
  .colored-list li {
    font-size: clamp(14px, 3.8vw, 16px) !important;
  }
  
  .cta-item .heading {
    font-size: clamp(22px, 5.5vw, 28px) !important;
  }
  
  .cta-item .cta-p {
    font-size: clamp(15px, 4vw, 17px) !important;
  }
  
  /* Extra small mobile - optimized button styles */
  .sub-focus-grid-button-block .button-second,
  .sub-focus-grid-button-block .button-second-white,
  .sub-focus-grid-button-block a.button-second,
  .sub-focus-grid-button-block a.button-second-white,
  .sub-focus-grid-button-block .button-second.w-button,
  .sub-focus-grid-button-block .button-second-white.w-button,
  .sub-focus-grid-button-block a.button-second.w-button,
  .sub-focus-grid-button-block a.button-second-white.w-button,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white.w-button,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white.w-button,
  .main-section-1 .sub-focus-grid-button-block .button-second-white,
  .main-section-1 .sub-focus-grid-button-block a.button-second-white,
  .main-section-1 .sub-focus-grid-button-block .button-second-white.w-button,
  .main-section-1 .sub-focus-grid-button-block a.button-second-white.w-button,
  .cta-item .button-second {
    padding: 12px 18px 12px 40px !important;
    padding-top: 12px !important;
    padding-bottom: 12px !important;
    padding-left: 40px !important;
    padding-right: 18px !important;
    font-size: 14px !important;
    min-height: 44px !important;
    background-position: 14px center !important;
    background-size: 16px !important;
  }
  
  /* Ensure button text and infinity-word span - remove boldness completely with highest specificity */
  .sub-focus-grid-button-block .button-second-white .infinity-word,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white .infinity-word,
  .sub-focus-grid-button-block .button-second .infinity-word,
  .sub-focus-grid-button-block a.button-second-white .infinity-word,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white .infinity-word,
  .sub-focus-grid-button-block a.button-second .infinity-word,
  .sub-focus-grid-button-block .button-second-white.w-button .infinity-word,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white.w-button .infinity-word,
  .sub-focus-grid-button-block .button-second.w-button .infinity-word,
  .sub-focus-grid-button-block a.button-second-white.w-button .infinity-word,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white.w-button .infinity-word,
  .sub-focus-grid-button-block a.button-second.w-button .infinity-word {
    display: inline !important;
    vertical-align: baseline !important;
    font-family: 'Rosario', sans-serif !important;
    font-weight: 300 !important;
    font-style: normal !important;
    letter-spacing: 0.02em !important;
    font-size: inherit !important;
    line-height: inherit !important;
    color: inherit !important;
    margin-left: 0.5em !important;
    margin-right: 0.5em !important;
    white-space: normal !important;
    padding-left: 0.15em !important;
    padding-right: 0.15em !important;
    letter-spacing: 0.05em !important;
  }
  
  /* Override any nested elements inside infinity-word */
  .sub-focus-grid-button-block .button-second-white .infinity-word *,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white .infinity-word *,
  .sub-focus-grid-button-block .button-second .infinity-word *,
  .sub-focus-grid-button-block a.button-second-white .infinity-word *,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white .infinity-word *,
  .sub-focus-grid-button-block a.button-second .infinity-word * {
    font-weight: 300 !important;
    font-style: normal !important;
  }
  
  /* Ensure proper spacing in button text */
  
  /* CRITICAL: Force main-section-2 button full width - must come last */
  .main-section-2 .sub-page-main-focus-block .sub-focus-grid-button-block .button-second,
  .main-section-2 .sub-page-main-focus-block .sub-focus-grid-button-block a.button-second,
  .main-section-2 .sub-page-main-focus-block .sub-focus-grid-button-block .button-second.w-button,
  .main-section-2 .sub-page-main-focus-block .sub-focus-grid-button-block a.button-second.w-button {
    max-width: 100% !important;
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .sub-focus-grid-button-block .button-second-white,
  .focus-colored-grid-block .sub-focus-grid-button-block .button-second-white,
  .sub-focus-grid-button-block a.button-second-white,
  .focus-colored-grid-block .sub-focus-grid-button-block a.button-second-white {
    white-space: normal !important;
  }
  
  .cta-image {
    max-width: clamp(100px, 25vw, 150px) !important;
  }
}

/* Testimonials CTA section - decrease font sizes for desktop */
/* CRITICAL: Must override base CSS and mobile clamp() styles */
@media (min-width: 992px) {
  section.main-section-2 .container-full .testimonials-page-last-block .last-block-text-block h1.last-block-h2,
  section.main-section-2 .container-full .testimonials-page-last-block .last-block-text-block .last-block-h2,
  section.main-section-2 .testimonials-page-last-block .last-block-text-block h1.last-block-h2,
  section.main-section-2 .testimonials-page-last-block .last-block-text-block .last-block-h2,
  section.main-section-2 .testimonials-page-last-block h1.last-block-h2,
  section.main-section-2 .testimonials-page-last-block .last-block-h2 {
    font-size: 24px !important;
    line-height: 1.2 !important;
  }
  section.main-section-2 .container-full .testimonials-page-last-block .last-block-text-block h1.last-block-h1,
  section.main-section-2 .container-full .testimonials-page-last-block .last-block-text-block .last-block-h1,
  section.main-section-2 .testimonials-page-last-block .last-block-text-block h1.last-block-h1,
  section.main-section-2 .testimonials-page-last-block .last-block-text-block .last-block-h1,
  section.main-section-2 .testimonials-page-last-block h1.last-block-h1,
  section.main-section-2 .testimonials-page-last-block .last-block-h1 {
    font-size: 36px !important;
    line-height: 1.2 !important;
  }
  section.main-section-2 .container-full .testimonials-page-last-block .last-block-text-block h1.last-block-h3,
  section.main-section-2 .container-full .testimonials-page-last-block .last-block-text-block .last-block-h3,
  section.main-section-2 .testimonials-page-last-block .last-block-text-block h1.last-block-h3,
  section.main-section-2 .testimonials-page-last-block .last-block-text-block .last-block-h3,
  section.main-section-2 .testimonials-page-last-block h1.last-block-h3,
  section.main-section-2 .testimonials-page-last-block .last-block-h3 {
    font-size: 20px !important;
    line-height: 1.4 !important;
  }
  section.main-section-2 .testimonials-page-last-block .sub-page-focus-button-third h1.focus-text,
  section.main-section-2 .testimonials-page-last-block .sub-page-focus-button-third .focus-text {
    font-size: 16px !important;
  }
  /* Decrease button size */
  section.main-section-2 .testimonials-page-last-block .sub-page-focus-button-third {
    padding: 10px 18px !important;
    gap: 12px !important;
    transition: all 0.3s ease !important;
  }
  section.main-section-2 .testimonials-page-last-block .sub-page-focus-button-third .focus-icon-block {
    width: 18px !important;
    height: 18px !important;
    transition: transform 0.3s ease !important;
  }
  section.main-section-2 .testimonials-page-last-block .sub-page-focus-button-third .focus-icon-block img {
    width: 100% !important;
    height: 100% !important;
  }
  /* Button hover effect */
  section.main-section-2 .testimonials-page-last-block .sub-page-focus-button-third:hover {
    background-color: #3C7A4C !important;
    border-color: #3C7A4C !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(60, 122, 76, 0.3) !important;
  }
  section.main-section-2 .testimonials-page-last-block .sub-page-focus-button-third:hover .focus-text {
    color: #ffffff !important;
  }
  section.main-section-2 .testimonials-page-last-block .sub-page-focus-button-third:hover .focus-icon-block {
    transform: scale(1.1) !important;
  }
}

/* Product page: reduce gap between consecutive main-section-2 sections */
.main-section-2 + .main-section-2 {
  padding-top: 40px !important;
}

/* Testimonials green section: prevent list blocks from spreading too far apart on large screens */
.testimonials-green .testimonials-colored-section-sub-block-second {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  justify-content: center !important;
  gap: clamp(20px, 4vw, 40px) !important;
}
.testimonials-green .testimonials-list-block {
  max-width: 500px !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
}
@media (min-width: 768px) {
  .testimonials-green .testimonials-colored-section-sub-block-second {
    gap: clamp(24px, 3vw, 40px) !important;
  }
}

/* Ensure main-h1---bottom-border stays on one line and is responsive */
.main-grid-3-list {
  grid-template-columns: repeat(3, 1fr) !important;
}
@media (max-width: 991px) and (min-width: 768px) {
  .main-grid-3-list {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 767px) {
  .main-grid-3-list {
    grid-template-columns: 1fr !important;
  }
}
.main-grid-3-list .border-item {
  width: 100% !important;
  min-width: 0 !important;
  overflow: visible !important;
}
.main-grid-3-list .main-h1---bottom-border {
  white-space: nowrap !important;
  overflow: visible !important;
  font-size: clamp(14px, 1.8vw, 26px) !important;
  line-height: 1.2 !important;
  max-width: 100% !important;
  word-break: keep-all !important;
  display: block !important;
}
.main-grid-3-list .main-text-1 {
  font-size: clamp(14px, 1.5vw, 20px) !important;
  line-height: 1.4 !important;
  margin-bottom: 12px !important;
}
.main-grid-3-list .border-item p {
  font-size: clamp(13px, 1.3vw, 16px) !important;
  line-height: 1.6 !important;
}

/* Fix video testimonials - ensure first video is fully visible while keeping horizontal scroll */
.video-testimonials-section .container-full {
  max-width: 100% !important;
  overflow: visible !important;
  padding-left: 10% !important;
  padding-right: 10% !important;
}

.video-testimonials-container {
  justify-content: flex-start !important;
  -webkit-overflow-scrolling: touch !important;
}

@media (max-width: 767px) {
  .video-testimonials-section .container-full {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

/* Shop page: category tabs - 4 columns on desktop, 2 on mobile */
.shop-main-image-block {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 30px !important;
  justify-items: center !important;
  align-items: start !important;
  width: 100% !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  margin-top: 50px !important;
}

.shop-main-image-block-item {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: center !important;
  width: 100% !important;
}

.shop-main-image-block-item .shop-image-block {
  width: 240px !important;
  height: 240px !important;
  max-width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto !important;
  border-radius: 50% !important;
  overflow: hidden !important;
}

.shop-main-image-block-item .shop-image-block img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: 50% !important;
}

.shop-main-image-block-item .sub-page-h1-small {
  font-size: 22px !important;
  line-height: 1.3 !important;
  margin-top: 16px !important;
  word-break: break-word !important;
  text-align: center !important;
  width: 100% !important;
}

@media (max-width: 1200px) {
  .shop-main-image-block {
    margin-top: 45px !important;
  }
  .shop-main-image-block-item .shop-image-block {
    width: 200px !important;
    height: 200px !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 50% !important;
    overflow: hidden !important;
  }
  .shop-main-image-block-item .sub-page-h1-small {
    font-size: 20px !important;
  }
}

@media (max-width: 991px) {
  .shop-main-image-block {
    gap: 20px !important;
    margin-top: 40px !important;
  }
  .shop-main-image-block-item .shop-image-block {
    width: 160px !important;
    height: 160px !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 50% !important;
    overflow: hidden !important;
  }
  .shop-main-image-block-item .sub-page-h1-small {
    font-size: 18px !important;
  }
}

@media (max-width: 767px) {
  .shop-main-image-block {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto !important;
    gap: 12px !important;
    max-width: 100% !important;
    padding: 0 16px !important;
    margin-top: 40px !important;
    scroll-behavior: smooth !important;
    -webkit-overflow-scrolling: touch !important;
  }
  .shop-main-image-block-item {
    flex: 0 0 auto !important;
    min-width: calc(25% - 9px) !important;
    max-width: calc(25% - 9px) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
  }
  .shop-main-image-block-item .shop-image-block {
    width: 80px !important;
    height: 80px !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 50% !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
    margin: 0 auto !important;
  }
  .shop-main-image-block-item .shop-image-block img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 50% !important;
    display: block !important;
  }
  .shop-main-image-block-item .sub-page-h1-small {
    font-size: 12px !important;
    margin-top: 6px !important;
    text-align: center !important;
    line-height: 1.2 !important;
  }
}

/* Shop page: responsive products grid fixes */
.products-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 30px !important;
  width: 100% !important;
}

/* Product card styling */
.products-grid-item {
  width: 100% !important;
}

.products-grid-item .sub-page-h1-medium {
  font-size: 22px !important;
}

.products-grid-item .sub-page-p-small {
  font-size: 14px !important;
}

.products-grid-item .product-button-block .focus-text-white {
  font-size: 14px !important;
}

@media (max-width: 1200px) {
  .products-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 24px !important;
  }
  .products-grid-item .sub-page-h1-medium {
    font-size: 20px !important;
  }
  .products-grid-item .sub-page-p-small {
    font-size: 13px !important;
  }
}

@media (max-width: 991px) {
  .products-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 20px !important;
  }
  .products-grid-item .sub-page-h1-medium {
    font-size: 18px !important;
  }
  .products-grid-item .sub-page-p-small {
    font-size: 13px !important;
  }
}

@media screen and (max-width: 767px) {
  .products-grid {
    display: grid !important;
    grid-template-columns: calc(49% - 6px) calc(49% - 6px) !important;
    grid-column-gap: 12px !important;
    grid-row-gap: 16px !important;
    gap: 12px !important;
    width: 100% !important;
    padding: 0 16px !important;
    justify-items: stretch !important;
    box-sizing: border-box !important;
  }
  .products-grid-item {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 6px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    border-radius: 12px !important;
  }
  .products-grid-item .product-image-block {
    width: calc(100% - 0px) !important;
    max-width: 100% !important;
    height: 80px !important;
    min-height: 80px !important;
    max-height: 80px !important;
    aspect-ratio: unset !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    border-radius: 6px !important;
  }
  .products-grid-item .product-image-block img {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    border-radius: 6px !important;
    display: block !important;
  }
  .products-grid-item .sub-page-h1-medium {
    font-size: 14px !important;
    line-height: 1.3 !important;
    margin-top: 8px !important;
    margin-bottom: 4px !important;
  }
  .products-grid-item .sub-page-p-small {
    font-size: 11px !important;
    line-height: 1.4 !important;
    margin-bottom: 8px !important;
  }
  .products-grid-item .product-button-block {
    padding: 6px 12px !important;
    margin-top: 4px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: auto !important;
  }
  .products-grid-item .product-button-block .focus-text-white {
    font-size: 10px !important;
    line-height: 1.2 !important;
    padding: 0 !important;
    margin: 0 !important;
  }
}

/* Also ensure 1 column for very small screens */
@media screen and (max-width: 479px) {
  .products-grid {
    grid-template-columns: 1fr !important;
    grid-column-gap: 20px !important;
    grid-row-gap: 20px !important;
  }
}

/* FAQ page: reduce gap between FAQ items */
.faq-page-main-block {
  gap: 16px !important;
}

/* FAQ page: reduce padding inside FAQ items */
.faq-page-main-block .faq-page-item {
  padding: 22px 28px !important;
}

/* FAQ page: reduce padding under title when accordion is closed */
.faq-page-main-block .faq-item-title {
  padding-bottom: 0 !important;
  border-bottom: none !important;
  margin-bottom: 0 !important;
}

.faq-page-main-block .faq-item-title h1 {
  margin: 0 !important;
  padding: 0 !important;
}

/* Hide sub-blocks completely when closed (no space taken) */
.faq-page-main-block .faq-page-item .faq-page-sub-block {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Only show border and padding when accordion is open */
.faq-page-main-block .faq-page-item.open .faq-item-title {
  padding-bottom: 16px !important;
  margin-bottom: 16px !important;
  border-bottom: 1px solid #8383834d !important;
}

.faq-page-main-block .faq-page-item.open .faq-page-sub-block {
  margin-top: 0 !important;
}

/* Footer: 2 columns on mobile */
@media screen and (max-width: 767px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    grid-column-gap: 30px !important;
    grid-row-gap: 30px !important;
    gap: 30px !important;
  }
  .footer-h5 {
    font-size: 16px !important;
  }
  .footer-link {
    font-size: 13px !important;
  }
  .footer-h3 {
    font-size: 18px !important;
  }
  .copyright-text {
    font-size: 12px !important;
  }
  .nova-era-link {
    font-size: 12px !important;
  }
}

/* Sortable table headers */
.user-section table thead th a {
  transition: color 0.2s ease;
}

.user-section table thead th a:hover {
  color: #3b82f6 !important;
}
