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

/* ============== HERO ============== */
.page-id-12 .srv-hero { isolation: isolate; position: relative; }
.page-id-12 .srv-hero > .e-con-inner { width: 100%; max-width: 980px; }
.page-id-12 .srv-hero .elementor-divider__text {
  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;
}
.page-id-12 .srv-hero-title .elementor-heading-title {
  font-size: clamp(2.6rem, 6.4vw, 5.2rem) !important;
  line-height: 1.04;
  letter-spacing: -0.025em;
  margin: 0;
  max-width: 22ch;
}
.page-id-12 .srv-hero-title em,
.page-id-12 .srv-hero-title i {
  font-style: italic;
  font-weight: 700;
  color: var(--e-global-color-secondary);
}
.page-id-12 .srv-hero .elementor-widget-text-editor p {
  font-family: 'Montserrat', sans-serif !important;
  line-height: 1.6;
  max-width: 56ch;
  margin: 4px auto 8px;
}
.page-id-12 .srv-cta-primary .elementor-button,
.page-id-12 .srv-cta-outline .elementor-button {
  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, border-color .2s ease;
}
.page-id-12 .srv-cta-primary .elementor-button:hover {
  background-color: var(--e-global-color-secondary) !important;
  transform: translateY(-1px);
}
.page-id-12 .srv-cta-outline .elementor-button:hover {
  background-color: rgba(255,255,255,0.10) !important;
  border-color: #FFFFFF !important;
}
/* hero pills */
.page-id-12 .srv-hero-pills .elementor-icon-list-items {
  display: flex !important; flex-wrap: wrap;
  gap: 10px 14px; padding: 18px 0 0;
  justify-content: center;
}
.page-id-12 .srv-hero-pills .elementor-icon-list-item {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.14) !important;
  border-radius: 999px !important;
  padding: 8px 14px !important;
  margin: 0 !important;
  display: inline-flex; align-items: center; gap: 8px;
  backdrop-filter: blur(4px);
}
.page-id-12 .srv-hero-pills .elementor-icon-list-icon { margin: 0 !important; }
.page-id-12 .srv-hero-pills .elementor-icon-list-icon i {
  color: var(--e-global-color-secondary) !important;
  font-size: 0.42rem !important;
}
.page-id-12 .srv-hero-pills .elementor-icon-list-text {
  color: #E5E7EB !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em;
}

/* ============== SECTION 2 — SERVICES GRID ============== */
.page-id-12 .srv-grid-section { background: #FFFFFF; }
.page-id-12 .srv-grid-title .elementor-heading-title {
  font-size: clamp(2rem, 4.4vw, 3.2rem) !important;
  line-height: 1.08;
  letter-spacing: -0.02em;
  margin: 0 0 14px;
  text-align: center;
  max-width: 22ch;
}
.page-id-12 .srv-grid-title em {
  font-style: italic;
  font-weight: 700;
  color: var(--e-global-color-secondary);
}
.page-id-12 .srv-grid-lead .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.96rem !important;
  font-weight: 400 !important;
  line-height: 1.65;
  color: var(--e-global-color-6f59b15d) !important;
  max-width: 60ch;
  margin: 0 auto;
  text-align: center;
}
.page-id-12 .srv-grid { width: 100%; }
.page-id-12 .srv-grid > .srv-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);
  overflow: hidden;
  position: relative;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.page-id-12 .srv-grid > .srv-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px -16px rgba(14,27,34,0.18);
  border-color: transparent;
}
/* card image: flush to top + sides, content padding via card padding */
.page-id-12 .srv-card > .srv-card-img {
  --container-widget-width: calc(100% + 56px);
  width: calc(100% + 56px) !important;
  max-width: none !important;
  margin: -28px -28px 8px !important;
}
.page-id-12 .srv-card .srv-card-img .elementor-widget-container {
  padding: 0 !important; margin: 0 !important; line-height: 0;
}
.page-id-12 .srv-card .srv-card-img img {
  width: 100%; height: clamp(160px, 18vw, 220px);
  object-fit: cover; display: block;
}
/* card category pill (absolutely positioned over the image) */
.page-id-12 .srv-card .srv-card-pill .elementor-heading-title {
  display: inline-block;
  background: rgba(14,27,34,0.78);
  color: #FFFFFF !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.62rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
  margin: 0;
  backdrop-filter: blur(4px);
}
.page-id-12 .srv-card > .srv-card-pill {
  position: absolute !important;
  top: 16px; left: 16px;
  z-index: 2;
}
.page-id-12 .srv-card .srv-card-title .elementor-heading-title {
  font-size: 1.15rem !important;
  line-height: 1.25;
  margin: 0;
}
.page-id-12 .srv-card .srv-card-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-12 .srv-card .srv-card-link .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--e-global-color-primary) !important;
  margin-top: 4px;
}
.page-id-12 .srv-card .srv-card-link a { color: inherit; text-decoration: none; }
.page-id-12 .srv-card .srv-card-link:hover .elementor-heading-title {
  color: var(--e-global-color-secondary) !important;
}

/* ============== SECTION 3 — HOW WE WORK ============== */
.page-id-12 .srv-how-section { background: #0E1B22; }
.page-id-12 .srv-how-title .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;
  text-align: center;
  max-width: 18ch;
}
.page-id-12 .srv-how-title em {
  font-style: italic;
  font-weight: 700;
  color: var(--e-global-color-primary);
}
.page-id-12 .srv-how-lead .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.96rem !important;
  font-weight: 400 !important;
  line-height: 1.65;
  max-width: 58ch;
  margin: 0 auto;
  text-align: center;
}
.page-id-12 .srv-how-grid { width: 100%; }
.page-id-12 .srv-how-grid > .srv-step-card {
  flex: 1 1 calc(25% - 15px); max-width: calc(25% - 15px); min-width: 200px;
  border: 1px solid rgba(255,255,255,0.06);
  transition: transform .2s ease, border-color .2s ease;
}
.page-id-12 .srv-how-grid > .srv-step-card:hover {
  transform: translateY(-2px); border-color: rgba(102,151,199,0.35);
}
.page-id-12 .srv-step-card .srv-step-num .elementor-heading-title {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--e-global-color-primary);
  color: #FFFFFF !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.85rem !important;
  font-weight: 700 !important;
  margin: 0 0 8px;
}
.page-id-12 .srv-step-card .srv-step-title .elementor-heading-title {
  font-size: 1.15rem !important;
  font-weight: 600 !important;
  line-height: 1.2;
  color: #FFFFFF !important;
  margin: 0;
}
.page-id-12 .srv-step-card .srv-step-desc .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.88rem !important;
  font-weight: 400 !important;
  line-height: 1.55;
  color: #B8C0C5 !important;
  margin: 0;
}
.page-id-12 .srv-how-warranty-link .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--e-global-color-secondary) !important;
  margin: 28px 0 0;
}
.page-id-12 .srv-how-warranty-link a { color: inherit; text-decoration: none; transition: color .2s ease; }
.page-id-12 .srv-how-warranty-link a:hover { color: #FFFFFF !important; }

/* ============== SECTION 4 — QUOTE CTA ============== */
.page-id-12 .srv-quote-section { isolation: isolate; }
.page-id-12 .srv-quote-text { max-width: 620px; }
.page-id-12 .srv-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-12 .srv-quote-title em {
  font-style: italic;
  font-weight: 700;
  color: #A8C5E5;
}
.page-id-12 .srv-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-12 .srv-quote-cta-stack { align-self: center; max-width: 360px; width: 100%; }
.page-id-12 .srv-quote-btn-light .elementor-button,
.page-id-12 .srv-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-12 .srv-quote-btn-light .elementor-button:hover {
  background-color: #f1f5fb !important; transform: translateY(-1px);
}
.page-id-12 .srv-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-12 .srv-grid > .srv-card,
  .page-id-12 .srv-how-grid > .srv-step-card {
    flex: 1 1 calc(50% - 10px); max-width: calc(50% - 10px);
  }
  .page-id-12 .srv-quote-section .e-con-inner { flex-direction: column !important; }
  .page-id-12 .srv-quote-text,
  .page-id-12 .srv-quote-cta-stack { width: 100% !important; max-width: none !important; }
  .page-id-12 .srv-quote-cta-stack { align-self: stretch; }
}
@media (max-width: 767px) {
  .page-id-12 .srv-hero-title .elementor-heading-title { font-size: clamp(2.2rem, 9vw, 3rem) !important; max-width: none; }
  .page-id-12 .srv-grid-title .elementor-heading-title,
  .page-id-12 .srv-how-title .elementor-heading-title,
  .page-id-12 .srv-quote-title .elementor-heading-title {
    font-size: clamp(1.8rem, 8vw, 2.4rem) !important;
    max-width: none;
  }
  .page-id-12 .srv-grid > .srv-card,
  .page-id-12 .srv-how-grid > .srv-step-card {
    flex: 1 1 100% !important; max-width: 100% !important;
  }
  .page-id-12 .srv-hero-cta-row { flex-direction: column !important; align-items: stretch !important; }
  .page-id-12 .srv-hero-cta-row .elementor-widget-button { width: 100%; }
  .page-id-12 .srv-hero-cta-row .elementor-button { width: 100%; }
}