
/* =========================================================================
   ABOUT PAGE CSS  (post ID 143)
   All selectors scoped to .page-id-143 so rules cannot leak.
   ========================================================================= */

/* --- SHARED: eyebrows --- */
.page-id-143 .ab-eyebrow-dark .elementor-heading-title,
.page-id-143 .ab-eyebrow-light .elementor-heading-title,
.page-id-143 .ab-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-143 .ab-eyebrow-dark .elementor-heading-title { color: var(--e-global-color-primary) !important; }
.page-id-143 .ab-eyebrow-light .elementor-heading-title { color: var(--e-global-color-secondary) !important; }
.page-id-143 .ab-eyebrow-onblue .elementor-heading-title { color: #A8C5E5 !important; }

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

/* --- SHARED: lede paragraphs --- */
.page-id-143 .ab-lead-dark .elementor-heading-title,
.page-id-143 .ab-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: 56ch;
  margin: 0 0 8px;
}
.page-id-143 .ab-lead-dark .elementor-heading-title { color: var(--e-global-color-6f59b15d) !important; }
.page-id-143 .ab-lead-light .elementor-heading-title { color: #C8D0D7 !important; }

/* --- SHARED: primary/outline CTAs (square 4px) --- */
.page-id-143 .ab-cta-primary .elementor-button,
.page-id-143 .ab-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-143 .ab-cta-primary .elementor-button:hover {
  background-color: var(--e-global-color-secondary) !important;
  transform: translateY(-1px);
}
.page-id-143 .ab-cta-outline .elementor-button:hover {
  background-color: rgba(255,255,255,0.10) !important;
  border-color: #ffffff !important;
}

/* --- SHARED: image badge overlay (bottom-left over the image) --- */
.page-id-143 .ab-image-badge {
  position: absolute !important;
  left: -24px;
  bottom: 28px;
  width: 150px !important;
  padding: 16px 20px !important;
  background: var(--e-global-color-primary) !important;
  box-shadow: 0 14px 36px -14px rgba(21,56,137,.55);
  z-index: 3;
}
.page-id-143 .ab-wwd-img,
.page-id-143 .ab-family-img { width: 100%; }
.page-id-143 .ab-badge-title .elementor-heading-title {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: #FFFFFF !important;
  line-height: 1;
  margin: 0;
}
.page-id-143 .ab-badge-label .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.62rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.78) !important;
  margin-top: 4px;
}

/* ============== HERO ============== */
.page-id-143 .ab-hero { isolation: isolate; position: relative; }
.page-id-143 .ab-hero > .e-con-inner { width: 100%; max-width: 1240px; }

.page-id-143 .ab-hero-eyebrow .elementor-heading-title {
  display: inline-block;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.74rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--e-global-color-secondary) !important;
  margin: 0;
}
.page-id-143 .ab-hero-subeyebrow .elementor-heading-title {
  display: inline-block;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #9CA8B0 !important;
  margin: 6px 0 8px;
}
.page-id-143 .ab-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;
  max-width: 22ch;
}
.page-id-143 .ab-hero-title em,
.page-id-143 .ab-hero-title i {
  font-style: normal;
  font-weight: inherit;
  color: var(--e-global-color-secondary);
}
/* Second line in <h1>: "Designed to last." via inserting text + <br>. Color the second line via ::after isn't needed since we used inline accent classes below. */
.page-id-143 .ab-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: 56ch;
  margin: 8px 0 12px;
}
.page-id-143 .ab-hero-bullets .elementor-icon-list-items {
  display: flex !important; flex-wrap: wrap; gap: 8px 28px; padding: 0; margin: 18px 0 0;
}
.page-id-143 .ab-hero-bullets .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-143 .ab-hero-bullets .elementor-icon-list-icon { margin: 0 !important; }
.page-id-143 .ab-hero-bullets .elementor-icon-list-icon i {
  color: var(--e-global-color-secondary) !important; font-size: 0.5rem !important;
}
.page-id-143 .ab-hero-bullets .elementor-icon-list-text {
  color: #E5E7EB !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.78rem !important; font-weight: 500 !important;
  letter-spacing: 0.02em;
}

/* HERO: second line of H1 colored blue via <br>+<span>; here we color via :nth-line workaround */
/* (Set via the heading title directly with a wrapping span; see below.) */

/* ============== SECTION 2: WHAT WE DO ============== */
.page-id-143 .ab-what-we-do { background: #FFFFFF; }
.page-id-143 .ab-wwd-text { max-width: 680px; }
.page-id-143 .ab-what-we-do .ab-section-title-dark .elementor-heading-title { max-width: 24ch; }
.page-id-143 .ab-wwd-visual { position: relative; align-self: stretch; }
.page-id-143 .ab-wwd-img img {
  width: 100%; height: auto; aspect-ratio: 4 / 5;
  object-fit: cover; border-radius: 10px;
  box-shadow: 0 30px 80px -30px rgba(14,27,34,.35);
}
.page-id-143 .ab-wwd-img .elementor-widget-container { padding: 0 !important; margin: 0 !important; }

/* ============== SECTION 3: WHAT MAKES US DIFFERENT ============== */
.page-id-143 .ab-different { background: #0E1B22; }
.page-id-143 .ab-different .ab-section-title-light .elementor-heading-title { max-width: 20ch; margin-bottom: 18px; }
.page-id-143 .ab-diff-cards { width: 100%; }
.page-id-143 .ab-diff-cards > .ab-diff-card {
  flex: 1 1 calc(33.33% - 14px); max-width: calc(33.33% - 14px); min-width: 240px;
  border: 1px solid rgba(255,255,255,0.06);
  transition: transform .2s ease, border-color .2s ease;
}
.page-id-143 .ab-diff-card:hover { transform: translateY(-2px); border-color: rgba(102,151,199,0.35); }
.page-id-143 .ab-diff-card .ab-diff-icon .elementor-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--e-global-color-primary);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.page-id-143 .ab-diff-card .ab-diff-icon .elementor-icon i,
.page-id-143 .ab-diff-card .ab-diff-icon .elementor-icon svg {
  color: #ffffff !important; fill: #ffffff !important; font-size: 14px !important;
}
.page-id-143 .ab-diff-card .ab-diff-title .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  line-height: 1.35;
  color: #ffffff !important;
  margin: 0;
}
.page-id-143 .ab-diff-footnote .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.95rem !important;
  font-weight: 400 !important;
  color: #C8D0D7 !important;
  margin: 6px 0 0;
}
.page-id-143 .ab-diff-footnote em {
  font-style: normal;
  font-weight: 600;
  color: var(--e-global-color-secondary);
}

/* ============== SECTION 4: BUILT LIKE OUR OWN HOME ============== */
.page-id-143 .ab-family { background: #FAFAFA; }
.page-id-143 .ab-family-visual { position: relative; align-self: stretch; }
.page-id-143 .ab-family-img img {
  width: 100%; height: clamp(360px, 38vw, 460px);
  object-fit: cover; border-radius: 10px;
  box-shadow: 0 30px 80px -30px rgba(14,27,34,.35);
}
.page-id-143 .ab-family-img .elementor-widget-container { padding: 0 !important; margin: 0 !important; }
.page-id-143 .ab-family-text { max-width: 580px; }
.page-id-143 .ab-family-bullets .elementor-icon-list-items {
  display: grid !important; grid-template-columns: 1fr 1fr; gap: 14px 22px; padding: 8px 0 0;
}
.page-id-143 .ab-family-bullets .elementor-icon-list-item { padding: 0; align-items: flex-start; }
.page-id-143 .ab-family-bullets .elementor-icon-list-icon {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--e-global-color-primary);
  display: inline-flex; align-items: center; justify-content: center;
  margin-right: 12px; margin-top: 2px; flex-shrink: 0;
}
.page-id-143 .ab-family-bullets .elementor-icon-list-icon i {
  color: #ffffff !important; font-size: 10px !important;
}
.page-id-143 .ab-family-bullets .elementor-icon-list-text {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.9rem !important;
  font-weight: 500;
  color: var(--e-global-color-accent) !important;
  line-height: 1.4;
}
.page-id-143 .ab-family-footnote .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 400 !important;
  color: var(--e-global-color-6f59b15d) !important;
  margin: 14px 0 0;
}
.page-id-143 .ab-family-footnote em {
  font-style: normal; font-weight: 600;
  color: var(--e-global-color-primary);
}

/* ============== SECTION 5: YOUR PROJECT, DONE RIGHT ============== */
.page-id-143 .ab-process { background: var(--e-global-color-primary); }
.page-id-143 .ab-process-text { max-width: 560px; }
.page-id-143 .ab-process-title .elementor-heading-title {
  font-size: clamp(2rem, 4vw, 3rem) !important;
  line-height: 1.06;
  letter-spacing: -0.02em;
  color: #FFFFFF !important;
  margin: 0 0 14px;
  max-width: 22ch;
}
.page-id-143 .ab-process-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-143 .ab-process-cta-stack { align-self: center; max-width: 440px; width: 100%; }
.page-id-143 .ab-process-btn-light .elementor-button {
  background-color: #FFFFFF !important;
  color: var(--e-global-color-primary) !important;
  border-radius: 4px !important;
  width: 100%;
  padding: 16px 20px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: background-color .2s ease, transform .2s ease;
}
.page-id-143 .ab-process-btn-light .elementor-button:hover {
  background-color: #f1f5fb !important; transform: translateY(-1px);
}
.page-id-143 .ab-process-btn-outline .elementor-button {
  background-color: transparent !important;
  color: #FFFFFF !important;
  border: 1px solid rgba(255,255,255,0.45) !important;
  border-radius: 4px !important;
  width: 100%;
  padding: 16px 20px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: background-color .2s ease, border-color .2s ease;
}
.page-id-143 .ab-process-btn-outline .elementor-button:hover {
  background-color: rgba(255,255,255,0.10) !important;
  border-color: #FFFFFF !important;
}

/* ============== SECTION 6: WHY HOMEOWNERS CHOOSE OZO ============== */
.page-id-143 .ab-why { background: #FFFFFF; }
.page-id-143 .ab-why-grid { width: 100%; }
.page-id-143 .ab-why-grid > .ab-why-card {
  flex: 1 1 calc(33.33% - 14px); max-width: calc(33.33% - 14px); min-width: 260px;
  border: 1px solid var(--e-global-color-1772e48d);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.page-id-143 .ab-why-grid > .ab-why-card:not(.ab-why-card-feature):hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px -16px rgba(14,27,34,0.18);
  border-color: transparent;
}
.page-id-143 .ab-why-grid > .ab-why-card-feature {
  border: 0 !important;
  background: var(--e-global-color-primary) !important;
}
.page-id-143 .ab-why-card .ab-why-icon .elementor-icon {
  width: 38px; height: 38px; border-radius: 8px;
  background: var(--e-global-color-primary);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 4px;
}
.page-id-143 .ab-why-card .ab-why-icon .elementor-icon i,
.page-id-143 .ab-why-card .ab-why-icon .elementor-icon svg {
  color: #FFFFFF !important; fill: #FFFFFF !important; font-size: 15px !important;
}
.page-id-143 .ab-why-card .ab-why-title .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  line-height: 1.35;
  color: var(--e-global-color-accent) !important;
  margin: 0;
}
.page-id-143 .ab-why-card .ab-why-desc .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 400 !important;
  line-height: 1.55;
  color: var(--e-global-color-6f59b15d) !important;
  margin: 0;
}
.page-id-143 .ab-why-card-feature .ab-why-feature-quote .elementor-heading-title {
  font-family: 'Marcellus', Georgia, serif !important;
  font-weight: 500 !important;
  font-style: italic;
  font-size: 1.15rem !important;
  line-height: 1.4;
  color: #FFFFFF !important;
  margin: 0;
}
.page-id-143 .ab-why-card-feature .ab-why-feature-btn .elementor-button {
  background-color: #FFFFFF !important;
  color: var(--e-global-color-primary) !important;
  border-radius: 4px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.page-id-143 .ab-why-card-feature .ab-why-feature-btn .elementor-button:hover {
  background-color: #f1f5fb !important;
}

/* ============== SECTION 7: FINAL CTA ============== */
.page-id-143 .ab-final-cta { isolation: isolate; }
.page-id-143 .ab-final-title .elementor-heading-title {
  font-size: clamp(2.4rem, 5.2vw, 4.2rem) !important;
  line-height: 1.04;
  letter-spacing: -0.025em;
  color: #FFFFFF !important;
  margin: 0 0 14px;
}
.page-id-143 .ab-final-title em {
  font-style: italic;
  font-weight: 700;
  color: var(--e-global-color-secondary);
}
.page-id-143 .ab-final-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: 56ch;
  margin: 0 auto 14px;
  text-align: center;
}

/* ============== RESPONSIVE ============== */
@media (max-width: 1024px) {
  .page-id-143 .ab-what-we-do .e-con-inner,
  .page-id-143 .ab-family .e-con-inner,
  .page-id-143 .ab-process .e-con-inner { flex-direction: column !important; }
  .page-id-143 .ab-wwd-text,
  .page-id-143 .ab-wwd-visual,
  .page-id-143 .ab-family-visual,
  .page-id-143 .ab-family-text,
  .page-id-143 .ab-process-text,
  .page-id-143 .ab-process-cta-stack { width: 100% !important; max-width: none !important; }
  .page-id-143 .ab-diff-cards > .ab-diff-card,
  .page-id-143 .ab-why-grid > .ab-why-card { flex: 1 1 calc(50% - 10px); max-width: calc(50% - 10px); }
}
@media (max-width: 767px) {
  .page-id-143 .ab-hero-title .elementor-heading-title { font-size: clamp(2.2rem, 9.5vw, 3rem) !important; max-width: none; }
  .page-id-143 .ab-section-title-dark .elementor-heading-title,
  .page-id-143 .ab-section-title-light .elementor-heading-title { font-size: clamp(1.8rem, 8vw, 2.5rem) !important; max-width: none; }
  .page-id-143 .ab-process-title .elementor-heading-title { font-size: clamp(1.8rem, 8vw, 2.4rem) !important; }
  .page-id-143 .ab-final-title .elementor-heading-title { font-size: clamp(2rem, 9vw, 2.8rem) !important; }
  .page-id-143 .ab-diff-cards > .ab-diff-card,
  .page-id-143 .ab-why-grid > .ab-why-card { flex: 1 1 100% !important; max-width: 100% !important; }
  .page-id-143 .ab-family-bullets .elementor-icon-list-items { grid-template-columns: 1fr; }
  .page-id-143 .ab-image-badge { left: 12px; bottom: 12px; }
  .page-id-143 .ab-final-cta-row { flex-direction: column !important; align-items: stretch !important; }
}