

/* =========================================================================
   OUTDOOR LIVING PAGE CSS  (post ID 630)
   ========================================================================= */

/* --- SHARED: eyebrows --- */
.page-id-630 .ol-eyebrow-dark .elementor-heading-title,
.page-id-630 .ol-eyebrow-light .elementor-heading-title,
.page-id-630 .ol-eyebrow-onblue .elementor-heading-title {
  display: inline-block;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin: 0 0 14px;
}
.page-id-630 .ol-eyebrow-dark .elementor-heading-title { color: var(--e-global-color-primary) !important; }
.page-id-630 .ol-eyebrow-light .elementor-heading-title { color: var(--e-global-color-secondary) !important; }
.page-id-630 .ol-eyebrow-onblue .elementor-heading-title { color: #A8C5E5 !important; }

/* --- SHARED: section titles --- */
.page-id-630 .ol-section-title-dark .elementor-heading-title,
.page-id-630 .ol-section-title-light .elementor-heading-title {
  font-size: clamp(2.2rem, 4.6vw, 3.4rem) !important;
  line-height: 1.06;
  letter-spacing: -0.02em;
  margin: 0 0 14px;
  max-width: 22ch;
}
.page-id-630 .ol-section-title-dark .elementor-heading-title { color: var(--e-global-color-accent) !important; }
.page-id-630 .ol-section-title-light .elementor-heading-title { color: #FFFFFF !important; }
.page-id-630 .ol-title-center .elementor-heading-title { text-align: center; max-width: 28ch; }
.page-id-630 .ol-section-title-dark em,
.page-id-630 .ol-section-title-light em,
.page-id-630 .ol-section-title-dark i,
.page-id-630 .ol-section-title-light i {
  font-style: italic;
  font-weight: 700;
  color: var(--e-global-color-secondary);
}

/* --- SHARED: lede paragraphs --- */
.page-id-630 .ol-lead-dark .elementor-heading-title,
.page-id-630 .ol-lead-light .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.96rem !important;
  font-weight: 400 !important;
  line-height: 1.65;
  max-width: 60ch;
  margin: 0 0 8px;
}
.page-id-630 .ol-lead-dark .elementor-heading-title { color: var(--e-global-color-6f59b15d) !important; }
.page-id-630 .ol-lead-light .elementor-heading-title { color: #C8D0D7 !important; }
.page-id-630 .ol-lead-center .elementor-heading-title { text-align: center; margin: 0 auto 12px; }

/* --- SHARED: primary/outline CTAs (square 4px) --- */
.page-id-630 .ol-cta-primary .elementor-button,
.page-id-630 .ol-cta-outline .elementor-button {
  border-radius: 4px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 0.78rem !important;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: background-color .2s ease, transform .2s ease, border-color .2s ease;
}
.page-id-630 .ol-cta-primary .elementor-button:hover {
  background-color: var(--e-global-color-secondary) !important;
  transform: translateY(-1px);
}
.page-id-630 .ol-cta-outline .elementor-button:hover {
  background-color: var(--e-global-color-secondary) !important;
  border-color: var(--e-global-color-secondary) !important;
}

/* ============== HERO ============== */
.page-id-630 .ol-hero { isolation: isolate; position: relative; }
.page-id-630 .ol-hero > .e-con-inner { width: 100%; max-width: 980px; }
.page-id-630 .ol-hero-title .elementor-heading-title {
  font-size: clamp(2.6rem, 6.4vw, 5.2rem) !important;
  line-height: 1.04;
  letter-spacing: -0.025em;
  color: #FFFFFF !important;
  margin: 0;
  text-align: center;
  max-width: 24ch;
}
.page-id-630 .ol-hero-title em,
.page-id-630 .ol-hero-title i {
  font-style: italic;
  font-weight: inherit;
  color: var(--e-global-color-secondary);
}
.page-id-630 .ol-hero-lead .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 400 !important;
  line-height: 1.65;
  color: #C8D0D7 !important;
  max-width: 64ch;
  margin: 8px auto 14px;
  text-align: center;
}
.page-id-630 .ol-hero-pills .elementor-icon-list-items {
  display: flex !important; justify-content: center; flex-wrap: wrap; gap: 10px 28px;
  padding: 0; margin: 18px 0 0;
}
.page-id-630 .ol-hero-pills .elementor-icon-list-item {
  background: transparent !important; border: 0 !important; padding: 0 !important; margin: 0 !important;
  display: inline-flex; align-items: center; gap: 8px;
}
.page-id-630 .ol-hero-pills .elementor-icon-list-icon { margin: 0 !important; }
.page-id-630 .ol-hero-pills .elementor-icon-list-icon i {
  color: var(--e-global-color-secondary) !important; font-size: 0.5rem !important;
}
.page-id-630 .ol-hero-pills .elementor-icon-list-text {
  color: #E5E7EB !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.95rem !important; font-weight: 500 !important;
  letter-spacing: 0.02em;
}

/* ============== SECTION 1: WHAT WE BUILD (LIGHT) ============== */
.page-id-630 .ol-what-we-build { background: #FFFFFF; }
.page-id-630 .ol-wb-text { max-width: 540px; }
.page-id-630 .ol-wb-card { box-shadow: 0 30px 80px -40px rgba(14,27,34,.06); }
.page-id-630 .ol-wb-card-head { width: auto !important; }
.page-id-630 .ol-wb-card-icon .elementor-icon {
  width: 32px; height: 32px; border-radius: 8px;
  background: rgba(21,56,137,0.12);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.page-id-630 .ol-wb-card-icon .elementor-icon i,
.page-id-630 .ol-wb-card-icon .elementor-icon svg {
  color: var(--e-global-color-primary) !important;
  fill: var(--e-global-color-primary) !important;
  font-size: 12px !important;
}
.page-id-630 .ol-wb-card-title .elementor-heading-title {
  font-size: 1.2rem !important;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--e-global-color-accent) !important;
  margin: 0;
}
.page-id-630 .ol-wb-bullets .elementor-icon-list-items { padding: 0; }
.page-id-630 .ol-wb-bullets .elementor-icon-list-item { padding: 0; align-items: center; }
.page-id-630 .ol-wb-bullets .elementor-icon-list-icon { margin-right: 12px; }
.page-id-630 .ol-wb-bullets .elementor-icon-list-icon i {
  color: var(--e-global-color-primary) !important; font-size: 0.5rem !important;
}
.page-id-630 .ol-wb-bullets .elementor-icon-list-text {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.92rem !important;
  font-weight: 500;
  color: var(--e-global-color-accent) !important;
}

/* ============== SECTION 2: CUSTOM OUTDOOR LIVING DESIGN (DARK, PILL TAGS) ============== */
.page-id-630 .ol-design { background: #0E1B22; }
.page-id-630 .ol-design-text { max-width: 480px; }
.page-id-630 .ol-design-pills-header .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.74rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #8A9199 !important;
  margin: 0 0 8px;
}
.page-id-630 .ol-design-pills .elementor-icon-list-items {
  display: flex !important; flex-wrap: wrap; gap: 12px;
  padding: 0; margin: 0;
}
.page-id-630 .ol-design-pills .elementor-icon-list-item {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  padding: 10px 18px !important;
  margin: 0 !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  transition: background-color .2s ease, border-color .2s ease;
}
.page-id-630 .ol-design-pills .elementor-icon-list-item:hover {
  background: rgba(102,151,199,0.10) !important;
  border-color: rgba(102,151,199,0.30) !important;
}
.page-id-630 .ol-design-pills .elementor-icon-list-icon { margin: 0 !important; }
.page-id-630 .ol-design-pills .elementor-icon-list-icon i {
  color: var(--e-global-color-secondary) !important; font-size: 0.42rem !important;
}
.page-id-630 .ol-design-pills .elementor-icon-list-text {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  color: #E5E7EB !important;
  letter-spacing: 0.01em;
}

/* ============== SECTION 3: BACKYARD TRANSFORMATIONS (LIGHT, 2 CARDS) ============== */
.page-id-630 .ol-transform { background: #FFFFFF; }
.page-id-630 .ol-transform-grid > .ol-tr-card {
  flex: 1 1 calc(50% - 12px); max-width: calc(50% - 12px); min-width: 280px;
  box-shadow: 0 30px 80px -40px rgba(14,27,34,.06);
  transition: transform .2s ease, box-shadow .2s ease;
}
.page-id-630 .ol-transform-grid > .ol-tr-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px -16px rgba(14,27,34,0.12);
}
.page-id-630 .ol-tr-head { width: auto !important; }
.page-id-630 .ol-tr-icon .elementor-icon {
  width: 38px; height: 38px; border-radius: 8px;
  background: rgba(21,56,137,0.12);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.page-id-630 .ol-tr-icon .elementor-icon i,
.page-id-630 .ol-tr-icon .elementor-icon svg {
  color: var(--e-global-color-primary) !important;
  fill: var(--e-global-color-primary) !important;
  font-size: 14px !important;
}
.page-id-630 .ol-tr-title .elementor-heading-title {
  font-size: 1.25rem !important;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--e-global-color-accent) !important;
  margin: 0;
}
.page-id-630 .ol-tr-desc .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.92rem !important;
  font-weight: 400 !important;
  color: var(--e-global-color-6f59b15d) !important;
  line-height: 1.6;
  margin: 0;
}
.page-id-630 .ol-tr-bullets .elementor-icon-list-items { padding: 0; }
.page-id-630 .ol-tr-bullets .elementor-icon-list-item { padding: 0; align-items: center; }
.page-id-630 .ol-tr-bullets .elementor-icon-list-icon { margin-right: 12px; }
.page-id-630 .ol-tr-bullets .elementor-icon-list-icon i {
  color: var(--e-global-color-primary) !important; font-size: 0.5rem !important;
}
.page-id-630 .ol-tr-bullets .elementor-icon-list-text {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.92rem !important;
  font-weight: 500;
  color: var(--e-global-color-accent) !important;
}

/* ============== SECTION 4: FEATURES (LIGHT GREY, 2x2) ============== */
.page-id-630 .ol-features { background: #F4F6F9; }
.page-id-630 .ol-features-grid > .ol-ft-card {
  flex: 1 1 calc(50% - 10px); max-width: calc(50% - 10px); min-width: 280px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.page-id-630 .ol-features-grid > .ol-ft-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px -16px rgba(14,27,34,0.10);
}
.page-id-630 .ol-ft-head { width: auto !important; }
.page-id-630 .ol-ft-icon .elementor-icon {
  width: 34px; height: 34px; border-radius: 8px;
  background: rgba(21,56,137,0.12);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.page-id-630 .ol-ft-icon .elementor-icon i,
.page-id-630 .ol-ft-icon .elementor-icon svg {
  color: var(--e-global-color-primary) !important;
  fill: var(--e-global-color-primary) !important;
  font-size: 13px !important;
}
.page-id-630 .ol-ft-title .elementor-heading-title {
  font-size: 1.15rem !important;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--e-global-color-accent) !important;
  margin: 0;
}
.page-id-630 .ol-ft-bullets .elementor-icon-list-items { padding: 0; }
.page-id-630 .ol-ft-bullets .elementor-icon-list-item { padding: 0; align-items: flex-start; }
.page-id-630 .ol-ft-bullets .elementor-icon-list-icon { margin-right: 10px; margin-top: 6px; }
.page-id-630 .ol-ft-bullets .elementor-icon-list-icon i {
  color: var(--e-global-color-primary) !important; font-size: 0.42rem !important;
}
.page-id-630 .ol-ft-bullets .elementor-icon-list-text {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 400;
  color: var(--e-global-color-6f59b15d) !important;
  line-height: 1.5;
}

/* ============== SECTION 5: LIGHTING (LIGHT, LEFT TEXT + RIGHT 2x2) ============== */
.page-id-630 .ol-lighting { background: #FFFFFF; }
.page-id-630 .ol-lighting-text { max-width: 380px; }
.page-id-630 .ol-lighting-bullets .elementor-icon-list-items { padding: 0; }
.page-id-630 .ol-lighting-bullets .elementor-icon-list-item { padding: 0; align-items: center; }
.page-id-630 .ol-lighting-bullets .elementor-icon-list-icon { margin-right: 12px; }
.page-id-630 .ol-lighting-bullets .elementor-icon-list-icon i {
  color: var(--e-global-color-primary) !important; font-size: 0.5rem !important;
}
.page-id-630 .ol-lighting-bullets .elementor-icon-list-text {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.92rem !important;
  font-weight: 500;
  color: var(--e-global-color-accent) !important;
}
.page-id-630 .ol-lighting-grid > .ol-lt-card {
  flex: 1 1 calc(50% - 8px); max-width: calc(50% - 8px); min-width: 240px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.page-id-630 .ol-lighting-grid > .ol-lt-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px -16px rgba(14,27,34,0.10);
}
.page-id-630 .ol-lt-icon .elementor-icon {
  width: 32px; height: 32px; border-radius: 8px;
  background: rgba(21,56,137,0.12);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.page-id-630 .ol-lt-icon .elementor-icon i,
.page-id-630 .ol-lt-icon .elementor-icon svg {
  color: var(--e-global-color-primary) !important;
  fill: var(--e-global-color-primary) !important;
  font-size: 12px !important;
}
.page-id-630 .ol-lt-title .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--e-global-color-accent) !important;
  line-height: 1.3;
  margin: 0;
}
.page-id-630 .ol-lt-bullets .elementor-icon-list-items { padding: 0; }
.page-id-630 .ol-lt-bullets .elementor-icon-list-item { padding: 0; align-items: flex-start; }
.page-id-630 .ol-lt-bullets .elementor-icon-list-icon { margin-right: 10px; margin-top: 6px; }
.page-id-630 .ol-lt-bullets .elementor-icon-list-icon i {
  color: var(--e-global-color-primary) !important; font-size: 0.42rem !important;
}
.page-id-630 .ol-lt-bullets .elementor-icon-list-text {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 400;
  color: var(--e-global-color-6f59b15d) !important;
  line-height: 1.5;
}

/* ============== SECTION 6: PATIOS, STONEWORK & INTEGRATION (DARK, PILL TAGS) ============== */
.page-id-630 .ol-patios { background: #0E1B22; }
.page-id-630 .ol-patios-text { max-width: 480px; }
.page-id-630 .ol-patios-tags-header .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.74rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #8A9199 !important;
  margin: 0 0 8px;
}
.page-id-630 .ol-patios-tags .elementor-icon-list-items {
  display: flex !important; flex-wrap: wrap; gap: 12px;
  padding: 0; margin: 0;
}
.page-id-630 .ol-patios-tags .elementor-icon-list-item {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  padding: 10px 18px !important;
  margin: 0 !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  transition: background-color .2s ease, border-color .2s ease;
}
.page-id-630 .ol-patios-tags .elementor-icon-list-item:hover {
  background: rgba(102,151,199,0.10) !important;
  border-color: rgba(102,151,199,0.30) !important;
}
.page-id-630 .ol-patios-tags .elementor-icon-list-icon { margin: 0 !important; }
.page-id-630 .ol-patios-tags .elementor-icon-list-icon i {
  color: var(--e-global-color-secondary) !important; font-size: 0.42rem !important;
}
.page-id-630 .ol-patios-tags .elementor-icon-list-text {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  color: #E5E7EB !important;
  letter-spacing: 0.01em;
}
.page-id-630 .ol-patios-links { gap: 20px; }
.page-id-630 .ol-patios-link .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.92rem !important;
  font-weight: 600 !important;
  color: var(--e-global-color-secondary) !important;
  margin: 0;
}
.page-id-630 .ol-patios-link a { color: inherit; text-decoration: none; }
.page-id-630 .ol-patios-link:hover .elementor-heading-title { color: #FFFFFF !important; }

/* ============== SECTION 7: POOLSIDE (LIGHT, LEFT TEXT + RIGHT IMAGE) ============== */
.page-id-630 .ol-poolside { background: #FFFFFF; }
.page-id-630 .ol-pool-text { max-width: 520px; }
.page-id-630 .ol-pool-bullets .elementor-icon-list-items { padding: 0; }
.page-id-630 .ol-pool-bullets .elementor-icon-list-item { padding: 0; align-items: center; }
.page-id-630 .ol-pool-bullets .elementor-icon-list-icon { margin-right: 12px; }
.page-id-630 .ol-pool-bullets .elementor-icon-list-icon i {
  color: var(--e-global-color-primary) !important; font-size: 0.5rem !important;
}
.page-id-630 .ol-pool-bullets .elementor-icon-list-text {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.92rem !important;
  font-weight: 500;
  color: var(--e-global-color-accent) !important;
}
.page-id-630 .ol-pool-link .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  color: var(--e-global-color-primary) !important;
  margin: 6px 0 0;
}
.page-id-630 .ol-pool-link a { color: inherit; text-decoration: none; }
.page-id-630 .ol-pool-link:hover .elementor-heading-title { color: var(--e-global-color-secondary) !important; }
.page-id-630 .ol-pool-image { position: relative; overflow: hidden; }
.page-id-630 .ol-pool-image::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(0,0,0,0.45) 100%);
  pointer-events: none;
}
.page-id-630 .ol-pool-chip .elementor-button {
  border-radius: 4px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  position: relative; z-index: 1;
}
.page-id-630 .ol-pool-chip .elementor-button:hover {
  background-color: var(--e-global-color-secondary) !important;
}

/* ============== SECTION 8: WHY INVEST (LIGHT GREY, 2x3) ============== */
.page-id-630 .ol-invest { background: #F4F6F9; }
.page-id-630 .ol-invest-text { max-width: 460px; }
.page-id-630 .ol-invest-grid > .ol-iv-card {
  flex: 1 1 calc(50% - 8px); max-width: calc(50% - 8px); min-width: 240px;
  transition: transform .2s ease, box-shadow .2s ease;
}
.page-id-630 .ol-invest-grid > .ol-iv-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 32px -16px rgba(14,27,34,0.10);
}
.page-id-630 .ol-iv-icon .elementor-icon {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(21,56,137,0.12);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.page-id-630 .ol-iv-icon .elementor-icon i,
.page-id-630 .ol-iv-icon .elementor-icon svg {
  color: var(--e-global-color-primary) !important;
  fill: var(--e-global-color-primary) !important;
  font-size: 12px !important;
}
.page-id-630 .ol-iv-title .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: var(--e-global-color-accent) !important;
  line-height: 1.3;
  margin: 0;
}

/* ============== SECTION 9: GET A QUOTE (BLUE) ============== */
.page-id-630 .ol-quote-section { background: var(--e-global-color-primary); }
.page-id-630 .ol-quote-text { max-width: 620px; }
.page-id-630 .ol-quote-title .elementor-heading-title {
  font-size: clamp(2rem, 4.4vw, 3.2rem) !important;
  line-height: 1.06;
  letter-spacing: -0.02em;
  color: #FFFFFF !important;
  margin: 0 0 14px;
  max-width: 22ch;
}
.page-id-630 .ol-quote-title em {
  font-style: italic;
  font-weight: 700;
  color: #A8C5E5;
}
.page-id-630 .ol-quote-lead .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.95rem !important;
  font-weight: 400 !important;
  line-height: 1.65;
  color: #D7E3F2 !important;
  max-width: 56ch;
  margin: 0;
}
.page-id-630 .ol-quote-cta-stack { align-self: center; max-width: 360px; width: 100%; }
.page-id-630 .ol-quote-btn-light .elementor-button,
.page-id-630 .ol-quote-btn-outline .elementor-button {
  width: 100% !important;
  border-radius: 4px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 16px 20px !important;
  transition: background-color .2s ease, transform .2s ease, border-color .2s ease;
}
.page-id-630 .ol-quote-btn-light .elementor-button:hover {
  background-color: #f1f5fb !important;
  transform: translateY(-1px);
}
.page-id-630 .ol-quote-btn-outline .elementor-button:hover {
  background-color: rgba(255,255,255,0.10) !important;
  border-color: #FFFFFF !important;
}

/* ============== RESPONSIVE ============== */
@media (max-width: 1024px) {
  .page-id-630 .ol-what-we-build .e-con-inner,
  .page-id-630 .ol-design .e-con-inner,
  .page-id-630 .ol-lighting .e-con-inner,
  .page-id-630 .ol-patios .e-con-inner,
  .page-id-630 .ol-poolside .e-con-inner,
  .page-id-630 .ol-invest .e-con-inner,
  .page-id-630 .ol-quote-section .e-con-inner { flex-direction: column !important; }
  .page-id-630 .ol-wb-text,
  .page-id-630 .ol-wb-card,
  .page-id-630 .ol-design-text,
  .page-id-630 .ol-design-pills-col,
  .page-id-630 .ol-lighting-text,
  .page-id-630 .ol-lighting-grid,
  .page-id-630 .ol-patios-text,
  .page-id-630 .ol-patios-tags-col,
  .page-id-630 .ol-pool-text,
  .page-id-630 .ol-pool-image,
  .page-id-630 .ol-invest-text,
  .page-id-630 .ol-invest-grid,
  .page-id-630 .ol-quote-text,
  .page-id-630 .ol-quote-cta-stack { width: 100% !important; max-width: none !important; }
  .page-id-630 .ol-pool-image { min-height: 320px !important; }
}
@media (max-width: 767px) {
  .page-id-630 .ol-hero-title .elementor-heading-title { font-size: clamp(2.2rem, 10vw, 3rem) !important; max-width: none; }
  .page-id-630 .ol-section-title-dark .elementor-heading-title,
  .page-id-630 .ol-section-title-light .elementor-heading-title { font-size: clamp(1.8rem, 8vw, 2.4rem) !important; max-width: none; }
  .page-id-630 .ol-transform-grid > .ol-tr-card,
  .page-id-630 .ol-features-grid > .ol-ft-card,
  .page-id-630 .ol-lighting-grid > .ol-lt-card,
  .page-id-630 .ol-invest-grid > .ol-iv-card { flex: 1 1 100% !important; max-width: 100% !important; min-width: 0 !important; }
  .page-id-630 .ol-hero-cta-row { flex-direction: column !important; align-items: stretch !important; }
  .page-id-630 .ol-patios-links { flex-direction: column !important; align-items: flex-start !important; gap: 10px !important; }
}

/* --- Recent Project image badges --- */
.page-id-630 .ol-photo-wrap {
  position: relative;
}
.page-id-630 .ol-invest-photo {
  width: 100%;
  margin-top: 16px;
}
.page-id-630 .ol-recent-badge {
  position: absolute !important;
  bottom: 16px;
  left: 16px;
  z-index: 2;
  pointer-events: none;
  width: auto !important;
}
.page-id-630 .ol-recent-badge .elementor-heading-title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--e-global-color-primary);
  color: #FFFFFF !important;
  padding: 8px 14px;
  border-radius: 999px;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 0;
  line-height: 1;
}
.page-id-630 .ol-recent-badge .elementor-heading-title::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #FFFFFF;
  flex: 0 0 6px;
}
