 .u-section-1 {
  background-image: none;
}

.u-section-1 .u-sheet-1 {
  min-height: 550px;
}

.u-section-1 .u-custom-html-1 {
  height: auto;
  min-height: 445px;
  width: 100%;
  max-width: 1008px;
  margin: 42px auto 60px;
  padding: 0 20px;
  box-sizing: border-box;
}

/* Enhanced responsive container for #promenade content */
#promenade {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: auto !important;
  box-sizing: border-box !important;
}

/* Responsive styles for dynamically loaded content */
#promenade * {
  box-sizing: border-box !important;
}

/* Card container responsiveness */
#promenade > div,
#promenade > section,
#promenade .card-container,
#promenade .content-wrapper {
  width: 100% !important;
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 10px !important;
}

/* Card grid layout */
#promenade .cards-grid,
#promenade .card-list,
#promenade .offers-container {
  display: flex !important;
  flex-direction: column !important;
  gap: 20px !important;
  width: 100% !important;
}

/* Individual card responsiveness */
#promenade .card,
#promenade .offer-card,
#promenade .credit-card,
#promenade [class*="card"] {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 auto 20px !important;
  padding: 15px !important;
  flex-shrink: 0 !important;
}

/* Image responsiveness */
#promenade img {
  max-width: 100% !important;
  height: auto !important;
  object-fit: contain !important;
  display: block !important;
  margin: 0 auto !important;
}

/* Text responsiveness */
#promenade h1,
#promenade h2,
#promenade h3,
#promenade h4 {
  font-size: clamp(1.2rem, 4vw, 2rem) !important;
  line-height: 1.3 !important;
  margin: 0 0 15px 0 !important;
  text-align: center !important;
}

#promenade p,
#promenade div:not([class*="card"]) {
  font-size: clamp(0.9rem, 3vw, 1.1rem) !important;
  line-height: 1.5 !important;
  margin: 0 0 15px 0 !important;
  text-align: center !important;
}

/* Button responsiveness */
#promenade button,
#promenade a[class*="btn"],
#promenade input[type="submit"],
#promenade .button {
  width: 100% !important;
  max-width: 300px !important;
  padding: 12px 20px !important;
  margin: 10px auto !important;
  display: block !important;
  font-size: 1rem !important;
  touch-action: manipulation !important;
  min-height: 44px !important;
}

@media (max-width: 1199px) {
  .u-section-1 .u-sheet-1 {
    min-height: 510px;
  }

  .u-section-1 .u-custom-html-1 {
    margin-top: 20px;
    padding: 0 30px;
  }
}

@media (max-width: 991px) {
  .u-section-1 .u-sheet-1 {
    min-height: auto;
    padding: 20px 0;
  }

  .u-section-1 .u-custom-html-1 {
    margin-top: 20px;
    padding: 0 25px;
  }
  
  #promenade .cards-grid,
  #promenade .card-list {
    gap: 15px !important;
  }
}

@media (max-width: 767px) {
  .u-section-1 .u-sheet-1 {
    min-height: auto;
    padding: 15px 0;
  }

  .u-section-1 .u-custom-html-1 {
    margin-top: 20px;
    padding: 0 20px;
    min-height: auto;
  }
  
  #promenade .card,
  #promenade .offer-card,
  #promenade .credit-card {
    padding: 12px !important;
    margin-bottom: 15px !important;
  }
  
  #promenade h1,
  #promenade h2 {
    font-size: clamp(1.1rem, 5vw, 1.8rem) !important;
  }
}

@media (max-width: 575px) {
  .u-section-1 .u-sheet-1 {
    min-height: auto;
    padding: 10px 0;
  }

  .u-section-1 .u-custom-html-1 {
    margin-top: 15px;
    padding: 0 15px;
    min-height: auto;
  }
  
  #promenade > div {
    padding: 8px !important;
  }
  
  #promenade .card,
  #promenade .offer-card {
    padding: 10px !important;
    margin-bottom: 12px !important;
  }
  
  #promenade h1,
  #promenade h2,
  #promenade h3 {
    font-size: clamp(1rem, 6vw, 1.5rem) !important;
    margin-bottom: 10px !important;
  }
  
  #promenade p {
    font-size: clamp(0.85rem, 4vw, 1rem) !important;
    margin-bottom: 10px !important;
  }
}

/* Additional mobile optimizations */
@media (max-width: 480px) {
  .u-section-1 .u-custom-html-1 {
    padding: 0 10px;
  }
  
  #promenade {
    padding: 5px !important;
  }
}

/* Fallback styles for unknown content structures */
#promenade table {
  width: 100% !important;
  display: block !important;
  overflow-x: auto !important;
  white-space: nowrap !important;
}

#promenade table td,
#promenade table th {
  display: inline-block !important;
  vertical-align: top !important;
  white-space: normal !important;
  width: auto !important;
  min-width: 120px !important;
  padding: 8px !important;
}

/* Iframe responsiveness */
#promenade iframe {
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 300px !important;
}

/* Form elements responsiveness */
#promenade form {
  width: 100% !important;
  max-width: 400px !important;
  margin: 0 auto !important;
}

#promenade input,
#promenade select,
#promenade textarea {
  width: 100% !important;
  max-width: 100% !important;
  padding: 12px !important;
  margin: 5px 0 !important;
  box-sizing: border-box !important;
  font-size: 16px !important; /* Prevents zoom on iOS */
}

/* Prevent horizontal scrolling */
#promenade,
#promenade * {
  overflow-x: auto !important;
  word-wrap: break-word !important;
  hyphens: auto !important;
}

/* Touch-friendly spacing */
#promenade a,
#promenade button,
#promenade [onclick] {
  min-height: 44px !important;
  min-width: 44px !important;
  padding: 10px !important;
  margin: 5px !important;
  display: inline-block !important;
}

/* Hide or adapt elements that don't work well on mobile */
@media (max-width: 575px) {
  #promenade .desktop-only {
    display: none !important;
  }
  
  #promenade .hide-mobile {
    display: none !important;
  }
}

/* Specific fixes for credit card offers layout based on content structure */
#promenade .offer,
#promenade .credit-offer,
#promenade [class*="offer"] {
  background: #fff !important;
  border-radius: 8px !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
  margin-bottom: 20px !important;
  overflow: hidden !important;
}

/* Card image containers */
#promenade .card-image,
#promenade .offer-image {
  width: 100% !important;
  text-align: center !important;
  padding: 15px !important;
}

/* Credit card images specifically */
#promenade img[src*="card"],
#promenade img[src*="credit"],
#promenade img[alt*="card"],
#promenade img[alt*="Credit"] {
  max-width: 280px !important;
  width: 90% !important;
  height: auto !important;
  border-radius: 12px !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
}

/* Text content within cards */
#promenade .card-content,
#promenade .offer-content {
  padding: 15px !important;
  text-align: center !important;
}

/* Links and CTAs */
#promenade a {
  color: #007bff !important;
  text-decoration: none !important;
  word-break: break-word !important;
}

#promenade a:hover {
  text-decoration: underline !important;
}

/* Ensure proper stacking of content */
@media (max-width: 768px) {
  #promenade > * {
    display: block !important;
    width: 100% !important;
    margin-bottom: 15px !important;
  }
  
  #promenade img[src*="card"],
  #promenade img[src*="credit"] {
    max-width: 250px !important;
    width: 85% !important;
  }
}