/* v1.0.5 Elementor visual fidelity layer
   This file is intentionally loaded after Elementor frontend/post CSS.
   It maps the original static CleanXpert HTML classes to the real Elementor Container/Widget markup. */

body.cleanxpert-theme-active .elementor,
body.elementor-editor-active .elementor,
body.elementor-editor-preview .elementor {
  font-family: var(--site-font-body) !important;
  color: var(--deep) !important;
  width: 100% !important;
  max-width: none !important;
  --widgets-spacing: 0px 0px !important;
  --widgets-spacing-row: 0px !important;
  --widgets-spacing-column: 0px !important;
}

body.cleanxpert-theme-active .elementor *,
body.elementor-editor-active .elementor *,
body.elementor-editor-preview .elementor * {
  box-sizing: border-box;
}

body.cleanxpert-theme-active .elementor .elementor-widget:not(:last-child),
body.elementor-editor-active .elementor .elementor-widget:not(:last-child),
body.elementor-editor-preview .elementor .elementor-widget:not(:last-child) {
  margin-block-end: 0 !important;
  margin-bottom: 0 !important;
}

body.cleanxpert-theme-active .elementor .e-con,
body.elementor-editor-active .elementor .e-con,
body.elementor-editor-preview .elementor .e-con {
  min-width: 0 !important;
  box-sizing: border-box !important;
  --widgets-spacing: 0px 0px !important;
  --widgets-spacing-row: 0px !important;
  --widgets-spacing-column: 0px !important;
  --container-widget-width: 100% !important;
}

body.cleanxpert-theme-active .elementor .e-con > .e-con-inner,
body.elementor-editor-active .elementor .e-con > .e-con-inner,
body.elementor-editor-preview .elementor .e-con > .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  gap: inherit !important;
}

body.cleanxpert-theme-active .elementor .e-con > .elementor-element,
body.cleanxpert-theme-active .elementor .e-con > .e-con-inner > .elementor-element,
body.elementor-editor-active .elementor .e-con > .elementor-element,
body.elementor-editor-active .elementor .e-con > .e-con-inner > .elementor-element,
body.elementor-editor-preview .elementor .e-con > .elementor-element,
body.elementor-editor-preview .elementor .e-con > .e-con-inner > .elementor-element {
  min-width: 0 !important;
  max-width: none !important;
}

/* Full-width Elementor pages must not inherit WordPress/Elementor page width restrictions. */
body.cleanxpert-theme-active .cleanxpert-main,
body.cleanxpert-theme-active .cleanxpert-main .entry-content,
body.cleanxpert-theme-active .cleanxpert-main .elementor,
body.cleanxpert-theme-active .cleanxpert-main .elementor-section-wrap,
body.cleanxpert-theme-active .page-content,
body.cleanxpert-theme-active .elementor-location-single,
body.cleanxpert-theme-active .elementor-location-archive {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Sections */
body.cleanxpert-theme-active .elementor .e-con.hero,
body.elementor-editor-active .elementor .e-con.hero,
body.elementor-editor-preview .elementor .e-con.hero {
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
  width: 100% !important;
  max-width: none !important;
  min-height: auto !important;
  padding: var(--space-4xl) 0 !important;
  background:
    radial-gradient(circle at 82% 18%, rgba(12, 191, 197, .14), transparent 34%),
    radial-gradient(circle at 18% 82%, rgba(149, 189, 38, .13), transparent 34%),
    var(--white) !important;
  --width: 100% !important;
  --max-width: none !important;
  --content-width: 100% !important;
  --padding-top: 0px !important;
  --padding-right: 0px !important;
  --padding-bottom: 0px !important;
  --padding-left: 0px !important;
}

body.cleanxpert-theme-active .elementor .e-con.page-hero,
body.elementor-editor-active .elementor .e-con.page-hero,
body.elementor-editor-preview .elementor .e-con.page-hero {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  padding: var(--space-4xl) 0 var(--space-3xl) !important;
  background:
    radial-gradient(circle at 80% 20%, rgba(12, 191, 197, .14), transparent 36%),
    var(--white) !important;
  --width: 100% !important;
  --max-width: none !important;
  --content-width: 100% !important;
  --padding-top: 0px !important;
  --padding-right: 0px !important;
  --padding-bottom: 0px !important;
  --padding-left: 0px !important;
}

body.cleanxpert-theme-active .elementor .e-con.section,
body.elementor-editor-active .elementor .e-con.section,
body.elementor-editor-preview .elementor .e-con.section {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  padding: var(--space-4xl) 0 !important;
  --width: 100% !important;
  --max-width: none !important;
  --content-width: 100% !important;
  --padding-top: 0px !important;
  --padding-right: 0px !important;
  --padding-bottom: 0px !important;
  --padding-left: 0px !important;
}

body.cleanxpert-theme-active .elementor .e-con.section-tight,
body.elementor-editor-active .elementor .e-con.section-tight,
body.elementor-editor-preview .elementor .e-con.section-tight {
  padding: var(--space-3xl) 0 !important;
}

body.cleanxpert-theme-active .elementor .e-con.soft-section,
body.elementor-editor-active .elementor .e-con.soft-section,
body.elementor-editor-preview .elementor .e-con.soft-section {
  background:
    radial-gradient(circle at 10% 10%, rgba(12, 191, 197, .10), transparent 32%),
    radial-gradient(circle at 90% 90%, rgba(149, 189, 38, .10), transparent 32%),
    rgba(12, 191, 197, .045) !important;
}

body.cleanxpert-theme-active .elementor .e-con.dark-section,
body.elementor-editor-active .elementor .e-con.dark-section,
body.elementor-editor-preview .elementor .e-con.dark-section {
  color: var(--white) !important;
  background:
    radial-gradient(circle at 82% 15%, rgba(12, 191, 197, .24), transparent 36%),
    radial-gradient(circle at 10% 90%, rgba(149, 189, 38, .18), transparent 32%),
    var(--deep) !important;
}

/* Original container width inside Elementor. */
body.cleanxpert-theme-active .elementor .e-con.container,
body.elementor-editor-active .elementor .e-con.container,
body.elementor-editor-preview .elementor .e-con.container {
  display: block !important;
  width: min(100% - 48px, var(--container)) !important;
  max-width: var(--container) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 0 !important;
  --width: min(100% - 48px, var(--container)) !important;
  --max-width: var(--container) !important;
  --content-width: var(--container) !important;
  --padding-top: 0px !important;
  --padding-right: 0px !important;
  --padding-bottom: 0px !important;
  --padding-left: 0px !important;
}

/* Layout containers and their optional .e-con-inner wrapper. */
body.cleanxpert-theme-active .elementor .e-con.hero-grid,
body.cleanxpert-theme-active .elementor .e-con.hero-grid > .e-con-inner,
body.elementor-editor-active .elementor .e-con.hero-grid,
body.elementor-editor-active .elementor .e-con.hero-grid > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.hero-grid,
body.elementor-editor-preview .elementor .e-con.hero-grid > .e-con-inner {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1.02fr) minmax(360px, .88fr) !important;
  gap: var(--space-3xl) !important;
  align-items: center !important;
}

body.cleanxpert-theme-active .elementor .e-con.page-hero-grid,
body.cleanxpert-theme-active .elementor .e-con.page-hero-grid > .e-con-inner,
body.elementor-editor-active .elementor .e-con.page-hero-grid,
body.elementor-editor-active .elementor .e-con.page-hero-grid > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.page-hero-grid,
body.elementor-editor-preview .elementor .e-con.page-hero-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(300px, .46fr) !important;
  gap: var(--space-3xl) !important;
  align-items: center !important;
}

body.cleanxpert-theme-active .elementor .e-con.split,
body.cleanxpert-theme-active .elementor .e-con.split > .e-con-inner,
body.elementor-editor-active .elementor .e-con.split,
body.elementor-editor-active .elementor .e-con.split > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.split,
body.elementor-editor-preview .elementor .e-con.split > .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr) !important;
  gap: var(--space-4xl) !important;
  align-items: center !important;
}

body.cleanxpert-theme-active .elementor .e-con.split.reverse,
body.cleanxpert-theme-active .elementor .e-con.split.reverse > .e-con-inner,
body.elementor-editor-active .elementor .e-con.split.reverse,
body.elementor-editor-active .elementor .e-con.split.reverse > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.split.reverse,
body.elementor-editor-preview .elementor .e-con.split.reverse > .e-con-inner {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr) !important;
}

body.cleanxpert-theme-active .elementor .e-con.grid-2,
body.cleanxpert-theme-active .elementor .e-con.grid-2 > .e-con-inner,
body.elementor-editor-active .elementor .e-con.grid-2,
body.elementor-editor-active .elementor .e-con.grid-2 > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.grid-2,
body.elementor-editor-preview .elementor .e-con.grid-2 > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: var(--space-xl) !important;
}

body.cleanxpert-theme-active .elementor .e-con.grid-3,
body.cleanxpert-theme-active .elementor .e-con.grid-3 > .e-con-inner,
body.cleanxpert-theme-active .elementor .e-con.testimonial-grid,
body.cleanxpert-theme-active .elementor .e-con.testimonial-grid > .e-con-inner,
body.elementor-editor-active .elementor .e-con.grid-3,
body.elementor-editor-active .elementor .e-con.grid-3 > .e-con-inner,
body.elementor-editor-active .elementor .e-con.testimonial-grid,
body.elementor-editor-active .elementor .e-con.testimonial-grid > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.grid-3,
body.elementor-editor-preview .elementor .e-con.grid-3 > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.testimonial-grid,
body.elementor-editor-preview .elementor .e-con.testimonial-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: var(--space-xl) !important;
}

body.cleanxpert-theme-active .elementor .e-con.grid-4,
body.cleanxpert-theme-active .elementor .e-con.grid-4 > .e-con-inner,
body.elementor-editor-active .elementor .e-con.grid-4,
body.elementor-editor-active .elementor .e-con.grid-4 > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.grid-4,
body.elementor-editor-preview .elementor .e-con.grid-4 > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: var(--space-xl) !important;
}

body.cleanxpert-theme-active .elementor .e-con.cta-box,
body.cleanxpert-theme-active .elementor .e-con.cta-box > .e-con-inner,
body.elementor-editor-active .elementor .e-con.cta-box,
body.elementor-editor-active .elementor .e-con.cta-box > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.cta-box,
body.elementor-editor-preview .elementor .e-con.cta-box > .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(0, .88fr) minmax(0, 1.12fr) !important;
  gap: var(--space-2xl) !important;
  align-items: start !important;
}

body.cleanxpert-theme-active .elementor .e-con.contact-grid,
body.cleanxpert-theme-active .elementor .e-con.contact-grid > .e-con-inner,
body.elementor-editor-active .elementor .e-con.contact-grid,
body.elementor-editor-active .elementor .e-con.contact-grid > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.contact-grid,
body.elementor-editor-preview .elementor .e-con.contact-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(0, .84fr) minmax(0, 1.16fr) !important;
  gap: var(--space-2xl) !important;
  align-items: start !important;
}

body.cleanxpert-theme-active .elementor .e-con.form-row,
body.cleanxpert-theme-active .elementor .e-con.form-row > .e-con-inner,
body.elementor-editor-active .elementor .e-con.form-row,
body.elementor-editor-active .elementor .e-con.form-row > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.form-row,
body.elementor-editor-preview .elementor .e-con.form-row > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: var(--space-lg) !important;
}

body.cleanxpert-theme-active .elementor .e-con.footer-grid,
body.cleanxpert-theme-active .elementor .e-con.footer-grid > .e-con-inner,
body.elementor-editor-active .elementor .e-con.footer-grid,
body.elementor-editor-active .elementor .e-con.footer-grid > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.footer-grid,
body.elementor-editor-preview .elementor .e-con.footer-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(240px, 1.35fr) repeat(3, minmax(150px, .7fr)) !important;
  gap: var(--space-2xl) !important;
}

body.cleanxpert-theme-active .elementor .e-con.button-row,
body.cleanxpert-theme-active .elementor .e-con.button-row > .e-con-inner,
body.cleanxpert-theme-active .elementor .e-con.testimonial-top,
body.cleanxpert-theme-active .elementor .e-con.testimonial-top > .e-con-inner,
body.cleanxpert-theme-active .elementor .e-con.footer-bottom,
body.cleanxpert-theme-active .elementor .e-con.footer-bottom > .e-con-inner,
body.elementor-editor-active .elementor .e-con.button-row,
body.elementor-editor-active .elementor .e-con.button-row > .e-con-inner,
body.elementor-editor-active .elementor .e-con.testimonial-top,
body.elementor-editor-active .elementor .e-con.testimonial-top > .e-con-inner,
body.elementor-editor-active .elementor .e-con.footer-bottom,
body.elementor-editor-active .elementor .e-con.footer-bottom > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.button-row,
body.elementor-editor-preview .elementor .e-con.button-row > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.testimonial-top,
body.elementor-editor-preview .elementor .e-con.testimonial-top > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.footer-bottom,
body.elementor-editor-preview .elementor .e-con.footer-bottom > .e-con-inner {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: var(--space-md) !important;
  align-items: center !important;
}

body.cleanxpert-theme-active .elementor .e-con.footer-bottom,
body.cleanxpert-theme-active .elementor .e-con.footer-bottom > .e-con-inner,
body.elementor-editor-active .elementor .e-con.footer-bottom,
body.elementor-editor-active .elementor .e-con.footer-bottom > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.footer-bottom,
body.elementor-editor-preview .elementor .e-con.footer-bottom > .e-con-inner {
  justify-content: space-between !important;
}

/* Typography: override Elementor generated fonts only inside CleanXpert template classes. */
body.cleanxpert-theme-active .elementor .hero-copy .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .hero-copy .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .hero-copy .elementor-widget-heading .elementor-heading-title {
  max-width: 900px !important;
  margin: 0 0 var(--space-xl) !important;
  color: var(--deep) !important;
  font-family: var(--site-font-heading) !important;
  font-size: clamp(2.5rem, 4.2vw, 3.5rem) !important;
  line-height: 1 !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
}

body.cleanxpert-theme-active .elementor .page-hero .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .page-hero .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .page-hero .elementor-widget-heading .elementor-heading-title {
  max-width: 900px !important;
  margin: 0 0 var(--space-xl) !important;
  color: var(--deep) !important;
  font-family: var(--site-font-heading) !important;
  font-size: clamp(2.5rem, 4.2vw, 3.5rem) !important;
  line-height: 1.08 !important;
  font-weight: 500 !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-heading.section-title .elementor-heading-title,
body.elementor-editor-active .elementor .elementor-widget-heading.section-title .elementor-heading-title,
body.elementor-editor-preview .elementor .elementor-widget-heading.section-title .elementor-heading-title {
  max-width: 780px !important;
  margin: 0 0 var(--space-lg) !important;
  color: var(--deep) !important;
  font-family: var(--site-font-heading) !important;
  font-size: clamp(2rem, 3.1vw, 3rem) !important;
  line-height: 1 !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
}

body.cleanxpert-theme-active .elementor .split-copy > .elementor-widget-heading .elementor-heading-title,
body.cleanxpert-theme-active .elementor .card > .elementor-widget-heading .elementor-heading-title,
body.cleanxpert-theme-active .elementor .mini-card > .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .split-copy > .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .card > .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .mini-card > .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .split-copy > .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .card > .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .mini-card > .elementor-widget-heading .elementor-heading-title {
  margin: 0 0 var(--space-md) !important;
  color: var(--deep) !important;
  font-family: var(--site-font-heading) !important;
  font-size: clamp(1.35rem, 1.8vw, 1.5rem) !important;
  line-height: 1.25 !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-text-editor,
body.cleanxpert-theme-active .elementor .elementor-widget-text-editor p,
body.elementor-editor-active .elementor .elementor-widget-text-editor,
body.elementor-editor-active .elementor .elementor-widget-text-editor p,
body.elementor-editor-preview .elementor .elementor-widget-text-editor,
body.elementor-editor-preview .elementor .elementor-widget-text-editor p {
  color: var(--muted) !important;
  font-family: var(--site-font-body) !important;
  font-size: 18px !important;
  line-height: 1.5 !important;
  font-weight: 400 !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-text-editor.lead,
body.cleanxpert-theme-active .elementor .elementor-widget-text-editor.lead p,
body.elementor-editor-active .elementor .elementor-widget-text-editor.lead,
body.elementor-editor-active .elementor .elementor-widget-text-editor.lead p,
body.elementor-editor-preview .elementor .elementor-widget-text-editor.lead,
body.elementor-editor-preview .elementor .elementor-widget-text-editor.lead p {
  max-width: 760px !important;
  margin: 0 !important;
  font-size: clamp(1.05rem, 1.35vw, 1.125rem) !important;
  line-height: 1.55 !important;
  letter-spacing: -0.01em !important;
}

body.cleanxpert-theme-active .elementor .hero-copy .elementor-widget-text-editor.lead,
body.cleanxpert-theme-active .elementor .hero-copy .elementor-widget-text-editor.lead p,
body.elementor-editor-active .elementor .hero-copy .elementor-widget-text-editor.lead,
body.elementor-editor-active .elementor .hero-copy .elementor-widget-text-editor.lead p,
body.elementor-editor-preview .elementor .hero-copy .elementor-widget-text-editor.lead,
body.elementor-editor-preview .elementor .hero-copy .elementor-widget-text-editor.lead p {
  margin-bottom: var(--space-2xl) !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-text-editor.service-copy,
body.cleanxpert-theme-active .elementor .elementor-widget-text-editor.service-copy p,
body.elementor-editor-active .elementor .elementor-widget-text-editor.service-copy,
body.elementor-editor-active .elementor .elementor-widget-text-editor.service-copy p,
body.elementor-editor-preview .elementor .elementor-widget-text-editor.service-copy,
body.elementor-editor-preview .elementor .elementor-widget-text-editor.service-copy p {
  max-width: 720px !important;
  margin: var(--space-xl) 0 var(--space-2xl) !important;
  color: var(--muted) !important;
  font-size: 18px !important;
  line-height: 27px !important;
}

body.cleanxpert-theme-active .elementor .text-center,
body.elementor-editor-active .elementor .text-center,
body.elementor-editor-preview .elementor .text-center {
  text-align: center !important;
}

body.cleanxpert-theme-active .elementor .text-center .elementor-widget-heading.section-title .elementor-heading-title,
body.cleanxpert-theme-active .elementor .text-center .elementor-widget-text-editor.lead,
body.cleanxpert-theme-active .elementor .text-center .elementor-widget-text-editor.lead p,
body.elementor-editor-active .elementor .text-center .elementor-widget-heading.section-title .elementor-heading-title,
body.elementor-editor-active .elementor .text-center .elementor-widget-text-editor.lead,
body.elementor-editor-active .elementor .text-center .elementor-widget-text-editor.lead p,
body.elementor-editor-preview .elementor .text-center .elementor-widget-heading.section-title .elementor-heading-title,
body.elementor-editor-preview .elementor .text-center .elementor-widget-text-editor.lead,
body.elementor-editor-preview .elementor .text-center .elementor-widget-text-editor.lead p {
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}

body.cleanxpert-theme-active .elementor .eyebrow,
body.cleanxpert-theme-active .elementor .elementor-widget-html.eyebrow .elementor-widget-container,
body.elementor-editor-active .elementor .eyebrow,
body.elementor-editor-active .elementor .elementor-widget-html.eyebrow .elementor-widget-container,
body.elementor-editor-preview .elementor .eyebrow,
body.elementor-editor-preview .elementor .elementor-widget-html.eyebrow .elementor-widget-container {
  display: inline-flex !important;
  gap: var(--space-sm) !important;
  align-items: center !important;
  margin-bottom: var(--space-lg) !important;
  color: var(--dark) !important;
  font-family: var(--site-font-body) !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  line-height: 14px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
}

body.cleanxpert-theme-active .elementor .badge,
body.cleanxpert-theme-active .elementor .elementor-widget-html.badge .elementor-widget-container,
body.elementor-editor-active .elementor .badge,
body.elementor-editor-active .elementor .elementor-widget-html.badge .elementor-widget-container,
body.elementor-editor-preview .elementor .badge,
body.elementor-editor-preview .elementor .elementor-widget-html.badge .elementor-widget-container {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-sm) !important;
  width: auto !important;
  max-width: max-content !important;
  margin: 0 0 var(--space-xl) !important;
  padding: var(--space-xs) var(--space-md) !important;
  color: var(--deep) !important;
  background: var(--soft-strong) !important;
  border: 1px solid rgba(12, 191, 197, .24) !important;
  border-radius: 999px !important;
  font-weight: 500 !important;
  font-size: 16px !important;
  line-height: 24px !important;
}

body.cleanxpert-theme-active .elementor .badge .badge,
body.elementor-editor-active .elementor .badge .badge,
body.elementor-editor-preview .elementor .badge .badge {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

/* Buttons */
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn .elementor-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--space-sm) !important;
  min-height: 48px !important;
  padding: var(--space-md) var(--space-xl) !important;
  border: 1px solid transparent !important;
  border-radius: var(--radius-md) !important;
  font-size: 18px !important;
  line-height: 27px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-primary .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn-primary .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-primary .elementor-button {
  color: var(--deep) !important;
  background: var(--turquoise) !important;
  border-color: var(--turquoise) !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-outline .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn-outline .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-outline .elementor-button {
  color: var(--deep) !important;
  background: var(--white) !important;
  border-color: var(--deep) !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-lime .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn-lime .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-lime .elementor-button {
  color: var(--deep) !important;
  background: var(--lime) !important;
  border-color: var(--lime) !important;
}

/* Cards/images */
body.cleanxpert-theme-active .elementor .e-con.card,
body.cleanxpert-theme-active .elementor .e-con.card > .e-con-inner,
body.elementor-editor-active .elementor .e-con.card,
body.elementor-editor-active .elementor .e-con.card > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.card,
body.elementor-editor-preview .elementor .e-con.card > .e-con-inner {
  display: grid !important;
  gap: var(--space-lg) !important;
  padding: var(--space-xl) !important;
  background: var(--white) !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: 0 8px 20px rgba(3, 64, 79, .04) !important;
}

body.cleanxpert-theme-active .elementor .e-con.mini-card,
body.cleanxpert-theme-active .elementor .e-con.mini-card > .e-con-inner,
body.elementor-editor-active .elementor .e-con.mini-card,
body.elementor-editor-active .elementor .e-con.mini-card > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.mini-card,
body.elementor-editor-preview .elementor .e-con.mini-card > .e-con-inner {
  display: block !important;
  padding: var(--space-xl) !important;
  background: var(--soft) !important;
  border: 1px solid rgba(12, 191, 197, .18) !important;
  border-radius: var(--radius-md) !important;
}

body.cleanxpert-theme-active .elementor .e-con.hero-visual,
body.elementor-editor-active .elementor .e-con.hero-visual,
body.elementor-editor-preview .elementor .e-con.hero-visual {
  position: relative !important;
  display: block !important;
  min-height: 460px !important;
  height: 460px !important;
  padding: 0 !important;
}

body.cleanxpert-theme-active .elementor .e-con.hero-card,
body.elementor-editor-active .elementor .e-con.hero-card,
body.elementor-editor-preview .elementor .e-con.hero-card {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  overflow: hidden !important;
  width: 100% !important;
  height: 100% !important;
  padding: 0 !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow) !important;
  isolation: isolate !important;
}

body.cleanxpert-theme-active .elementor .e-con.hero-card::after,
body.elementor-editor-active .elementor .e-con.hero-card::after,
body.elementor-editor-preview .elementor .e-con.hero-card::after {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  content: "" !important;
  background: linear-gradient(135deg, rgba(3, 64, 79, .60), rgba(4, 92, 108, .18) 55%, rgba(12, 191, 197, .16)) !important;
  pointer-events: none !important;
}

body.cleanxpert-theme-active .elementor .e-con.hero-card .elementor-widget-image,
body.cleanxpert-theme-active .elementor .e-con.hero-card .elementor-widget-container,
body.cleanxpert-theme-active .elementor .e-con.hero-card img,
body.elementor-editor-active .elementor .e-con.hero-card .elementor-widget-image,
body.elementor-editor-active .elementor .e-con.hero-card .elementor-widget-container,
body.elementor-editor-active .elementor .e-con.hero-card img,
body.elementor-editor-preview .elementor .e-con.hero-card .elementor-widget-image,
body.elementor-editor-preview .elementor .e-con.hero-card .elementor-widget-container,
body.elementor-editor-preview .elementor .e-con.hero-card img {
  width: 100% !important;
  height: 100% !important;
}

body.cleanxpert-theme-active .elementor .e-con.hero-card img,
body.elementor-editor-active .elementor .e-con.hero-card img,
body.elementor-editor-preview .elementor .e-con.hero-card img {
  object-fit: cover !important;
}

body.cleanxpert-theme-active .elementor .e-con.media-card,
body.cleanxpert-theme-active .elementor .e-con.service-hero-img,
body.cleanxpert-theme-active .elementor .e-con.about-hero-photo,
body.elementor-editor-active .elementor .e-con.media-card,
body.elementor-editor-active .elementor .e-con.service-hero-img,
body.elementor-editor-active .elementor .e-con.about-hero-photo,
body.elementor-editor-preview .elementor .e-con.media-card,
body.elementor-editor-preview .elementor .e-con.service-hero-img,
body.elementor-editor-preview .elementor .e-con.about-hero-photo {
  display: block !important;
  overflow: hidden !important;
  padding: 0 !important;
  background: var(--soft) !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-sm) !important;
}

body.cleanxpert-theme-active .elementor .e-con.media-card img,
body.cleanxpert-theme-active .elementor .e-con.service-hero-img img,
body.cleanxpert-theme-active .elementor .e-con.about-hero-photo img,
body.elementor-editor-active .elementor .e-con.media-card img,
body.elementor-editor-active .elementor .e-con.service-hero-img img,
body.elementor-editor-active .elementor .e-con.about-hero-photo img,
body.elementor-editor-preview .elementor .e-con.media-card img,
body.elementor-editor-preview .elementor .e-con.service-hero-img img,
body.elementor-editor-preview .elementor .e-con.about-hero-photo img {
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
}

body.cleanxpert-theme-active .elementor .testimonial-top img,
body.elementor-editor-active .elementor .testimonial-top img,
body.elementor-editor-preview .elementor .testimonial-top img {
  width: 64px !important;
  height: 64px !important;
  border-radius: 999px !important;
  border: 1px solid var(--line) !important;
  object-fit: cover !important;
}

/* Lists/forms */
body.cleanxpert-theme-active .elementor .check-list,
body.elementor-editor-active .elementor .check-list,
body.elementor-editor-preview .elementor .check-list {
  display: grid !important;
  gap: var(--space-md) !important;
  padding: 0 !important;
  margin: var(--space-xl) 0 0 !important;
  list-style: none !important;
}

body.cleanxpert-theme-active .elementor .check-list li,
body.elementor-editor-active .elementor .check-list li,
body.elementor-editor-preview .elementor .check-list li {
  display: flex !important;
  gap: var(--space-md) !important;
  align-items: flex-start !important;
  color: var(--muted) !important;
  font-size: 16px !important;
  line-height: 24px !important;
}

body.cleanxpert-theme-active .elementor .e-con.cta-box,
body.elementor-editor-active .elementor .e-con.cta-box,
body.elementor-editor-preview .elementor .e-con.cta-box {
  padding: var(--space-2xl) !important;
  background: rgba(254, 254, 254, .94) !important;
  border: 1px solid rgba(254, 254, 254, .62) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow) !important;
}

body.cleanxpert-theme-active .elementor .contact-form,
body.elementor-editor-active .elementor .contact-form,
body.elementor-editor-preview .elementor .contact-form {
  display: grid !important;
  gap: var(--space-lg) !important;
}

/* Footer */
body.cleanxpert-theme-active .elementor .e-con.site-footer,
body.elementor-editor-active .elementor .e-con.site-footer,
body.elementor-editor-preview .elementor .e-con.site-footer {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  padding: var(--space-3xl) 0 var(--space-xl) !important;
  color: rgba(254, 254, 254, .76) !important;
  background: var(--deep) !important;
}

body.cleanxpert-theme-active .elementor .footer-brand img,
body.cleanxpert-theme-active .footer-brand img,
body.elementor-editor-active .elementor .footer-brand img,
body.elementor-editor-preview .elementor .footer-brand img {
  width: 210px !important;
  height: auto !important;
  margin-bottom: var(--space-lg) !important;
  padding: var(--space-sm) var(--space-md) !important;
  background: var(--white) !important;
  border-radius: var(--radius-md) !important;
  overflow: hidden !important;
}

body.cleanxpert-theme-active .elementor .site-footer .elementor-widget-text-editor,
body.cleanxpert-theme-active .elementor .site-footer .elementor-widget-text-editor p,
body.cleanxpert-theme-active .elementor .site-footer a,
body.cleanxpert-theme-active .elementor .site-footer li,
body.elementor-editor-active .elementor .site-footer .elementor-widget-text-editor,
body.elementor-editor-active .elementor .site-footer .elementor-widget-text-editor p,
body.elementor-editor-active .elementor .site-footer a,
body.elementor-editor-active .elementor .site-footer li,
body.elementor-editor-preview .elementor .site-footer .elementor-widget-text-editor,
body.elementor-editor-preview .elementor .site-footer .elementor-widget-text-editor p,
body.elementor-editor-preview .elementor .site-footer a,
body.elementor-editor-preview .elementor .site-footer li {
  color: rgba(254, 254, 254, .76) !important;
  font-size: 16px !important;
  line-height: 24px !important;
}

body.cleanxpert-theme-active .elementor .footer-title,
body.elementor-editor-active .elementor .footer-title,
body.elementor-editor-preview .elementor .footer-title {
  margin-bottom: var(--space-lg) !important;
  color: var(--white) !important;
  font-weight: 600 !important;
}

body.cleanxpert-theme-active .elementor .footer-bottom,
body.elementor-editor-active .elementor .footer-bottom,
body.elementor-editor-preview .elementor .footer-bottom {
  margin-top: var(--space-2xl) !important;
  padding-top: var(--space-xl) !important;
  border-top: 1px solid rgba(254, 254, 254, .14) !important;
  font-size: 14px !important;
  line-height: 21px !important;
}

/* Elementor editor should show content even before animation JS runs. */
body.elementor-editor-active .reveal,
body.elementor-editor-preview .reveal,
body.cleanxpert-elementor-preview .reveal {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Responsive parity with the static version. */
@media (max-width: 1024px) {
  body.cleanxpert-theme-active .elementor .e-con.hero-grid,
  body.cleanxpert-theme-active .elementor .e-con.hero-grid > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.page-hero-grid,
  body.cleanxpert-theme-active .elementor .e-con.page-hero-grid > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.split,
  body.cleanxpert-theme-active .elementor .e-con.split > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.split.reverse,
  body.cleanxpert-theme-active .elementor .e-con.split.reverse > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.cta-box,
  body.cleanxpert-theme-active .elementor .e-con.cta-box > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.contact-grid,
  body.cleanxpert-theme-active .elementor .e-con.contact-grid > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.hero-grid,
  body.elementor-editor-active .elementor .e-con.hero-grid > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.page-hero-grid,
  body.elementor-editor-active .elementor .e-con.page-hero-grid > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.split,
  body.elementor-editor-active .elementor .e-con.split > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.split.reverse,
  body.elementor-editor-active .elementor .e-con.split.reverse > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.cta-box,
  body.elementor-editor-active .elementor .e-con.cta-box > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.contact-grid,
  body.elementor-editor-active .elementor .e-con.contact-grid > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  body.cleanxpert-theme-active .elementor .e-con.grid-4,
  body.cleanxpert-theme-active .elementor .e-con.grid-4 > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.grid-3,
  body.cleanxpert-theme-active .elementor .e-con.grid-3 > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.grid-4,
  body.elementor-editor-active .elementor .e-con.grid-4 > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.grid-3,
  body.elementor-editor-active .elementor .e-con.grid-3 > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 860px) {
  body.cleanxpert-theme-active .elementor .e-con.container,
  body.elementor-editor-active .elementor .e-con.container,
  body.elementor-editor-preview .elementor .e-con.container {
    width: min(100% - 32px, var(--container)) !important;
    --width: min(100% - 32px, var(--container)) !important;
  }

  body.cleanxpert-theme-active .elementor .e-con.grid-4,
  body.cleanxpert-theme-active .elementor .e-con.grid-4 > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.grid-3,
  body.cleanxpert-theme-active .elementor .e-con.grid-3 > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.grid-2,
  body.cleanxpert-theme-active .elementor .e-con.grid-2 > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.footer-grid,
  body.cleanxpert-theme-active .elementor .e-con.footer-grid > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.form-row,
  body.cleanxpert-theme-active .elementor .e-con.form-row > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.grid-4,
  body.elementor-editor-active .elementor .e-con.grid-4 > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.grid-3,
  body.elementor-editor-active .elementor .e-con.grid-3 > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.grid-2,
  body.elementor-editor-active .elementor .e-con.grid-2 > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.footer-grid,
  body.elementor-editor-active .elementor .e-con.footer-grid > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.form-row,
  body.elementor-editor-active .elementor .e-con.form-row > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  body.cleanxpert-theme-active .elementor .e-con.hero-visual,
  body.elementor-editor-active .elementor .e-con.hero-visual,
  body.elementor-editor-preview .elementor .e-con.hero-visual {
    min-height: 340px !important;
    height: 340px !important;
  }
}

/* v1.0.6 Elementor desktop fidelity corrections
   Fixes: service heading scale, CTA contrast, button alignment, media aspect ratio, hero image overlay/height.
   These selectors intentionally target the imported CleanXpert template class structure, not global Elementor widgets. */
body.cleanxpert-theme-active .elementor .e-con.hero-grid,
body.cleanxpert-theme-active .elementor .e-con.hero-grid > .e-con-inner,
body.elementor-editor-active .elementor .e-con.hero-grid,
body.elementor-editor-active .elementor .e-con.hero-grid > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.hero-grid,
body.elementor-editor-preview .elementor .e-con.hero-grid > .e-con-inner {
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.92fr) !important;
  gap: clamp(32px, 4vw, 56px) !important;
}

body.cleanxpert-theme-active .elementor .e-con.hero-copy,
body.elementor-editor-active .elementor .e-con.hero-copy,
body.elementor-editor-preview .elementor .e-con.hero-copy {
  position: relative !important;
  z-index: 1 !important;
  max-width: 800px !important;
}

body.cleanxpert-theme-active .elementor .e-con.hero-visual,
body.elementor-editor-active .elementor .e-con.hero-visual,
body.elementor-editor-preview .elementor .e-con.hero-visual {
  min-height: 520px !important;
  height: auto !important;
}

body.cleanxpert-theme-active .elementor .e-con.hero-visual.hero-no-panel,
body.elementor-editor-active .elementor .e-con.hero-visual.hero-no-panel,
body.elementor-editor-preview .elementor .e-con.hero-visual.hero-no-panel {
  min-height: 430px !important;
}

body.cleanxpert-theme-active .elementor .e-con.hero-card,
body.elementor-editor-active .elementor .e-con.hero-card,
body.elementor-editor-preview .elementor .e-con.hero-card,
body.cleanxpert-theme-active .elementor .e-con.media-card,
body.elementor-editor-active .elementor .e-con.media-card,
body.elementor-editor-preview .elementor .e-con.media-card,
body.cleanxpert-theme-active .elementor .e-con.service-hero-img,
body.elementor-editor-active .elementor .e-con.service-hero-img,
body.elementor-editor-preview .elementor .e-con.service-hero-img {
  border-radius: 18px !important;
}

body.cleanxpert-theme-active .elementor .e-con.hero-visual.hero-no-panel .e-con.hero-card::after,
body.cleanxpert-theme-active .elementor .e-con.hero-no-panel .e-con.hero-card::after,
body.elementor-editor-active .elementor .e-con.hero-visual.hero-no-panel .e-con.hero-card::after,
body.elementor-editor-preview .elementor .e-con.hero-visual.hero-no-panel .e-con.hero-card::after {
  background: linear-gradient(135deg, rgba(3, 64, 79, .28), rgba(4, 92, 108, .08) 55%, rgba(12, 191, 197, .08)) !important;
}

body.cleanxpert-theme-active .elementor .e-con.service-section .e-con.split,
body.cleanxpert-theme-active .elementor .e-con.service-section .e-con.split > .e-con-inner,
body.elementor-editor-active .elementor .e-con.service-section .e-con.split,
body.elementor-editor-active .elementor .e-con.service-section .e-con.split > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.service-section .e-con.split,
body.elementor-editor-preview .elementor .e-con.service-section .e-con.split > .e-con-inner {
  gap: clamp(28px, 4vw, 56px) !important;
}

body.cleanxpert-theme-active .elementor .e-con.media-card,
body.elementor-editor-active .elementor .e-con.media-card,
body.elementor-editor-preview .elementor .e-con.media-card {
  aspect-ratio: 4 / 3 !important;
}

body.cleanxpert-theme-active .elementor .e-con.media-card .elementor-widget-image,
body.cleanxpert-theme-active .elementor .e-con.media-card .elementor-widget-container,
body.cleanxpert-theme-active .elementor .e-con.media-card img,
body.elementor-editor-active .elementor .e-con.media-card .elementor-widget-image,
body.elementor-editor-active .elementor .e-con.media-card .elementor-widget-container,
body.elementor-editor-active .elementor .e-con.media-card img,
body.elementor-editor-preview .elementor .e-con.media-card .elementor-widget-image,
body.elementor-editor-preview .elementor .e-con.media-card .elementor-widget-container,
body.elementor-editor-preview .elementor .e-con.media-card img {
  width: 100% !important;
  height: 100% !important;
}

body.cleanxpert-theme-active .elementor .e-con.media-card img,
body.elementor-editor-active .elementor .e-con.media-card img,
body.elementor-editor-preview .elementor .e-con.media-card img {
  object-fit: cover !important;
}

/* Elementor copied headings were keeping some Elementor generated font sizes. Restore original h2/h3 scale by context. */
body.cleanxpert-theme-active .elementor .e-con.split-copy .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .e-con.split-copy .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .e-con.split-copy .elementor-widget-heading .elementor-heading-title,
body.cleanxpert-theme-active .elementor .e-con.soft-section > .e-con.container .elementor-widget-heading:not(.section-title) .elementor-heading-title,
body.elementor-editor-active .elementor .e-con.soft-section > .e-con.container .elementor-widget-heading:not(.section-title) .elementor-heading-title,
body.elementor-editor-preview .elementor .e-con.soft-section > .e-con.container .elementor-widget-heading:not(.section-title) .elementor-heading-title,
body.cleanxpert-theme-active .elementor .e-con.cta-box .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .e-con.cta-box .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .e-con.cta-box .elementor-widget-heading .elementor-heading-title {
  margin: 0 0 var(--space-lg) !important;
  color: var(--deep) !important;
  font-family: var(--site-font-heading) !important;
  font-size: clamp(2rem, 3.1vw, 3rem) !important;
  line-height: 1 !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
}

body.cleanxpert-theme-active .elementor .e-con.card .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .e-con.card .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .e-con.card .elementor-widget-heading .elementor-heading-title {
  margin: 0 0 var(--space-md) !important;
  color: var(--deep) !important;
  font-family: var(--site-font-heading) !important;
  font-size: clamp(1.35rem, 1.8vw, 1.5rem) !important;
  line-height: 1.25 !important;
  font-weight: 600 !important;
  letter-spacing: -0.02em !important;
}

body.cleanxpert-theme-active .elementor .e-con.card .elementor-widget-text-editor,
body.cleanxpert-theme-active .elementor .e-con.card .elementor-widget-text-editor p,
body.elementor-editor-active .elementor .e-con.card .elementor-widget-text-editor,
body.elementor-editor-active .elementor .e-con.card .elementor-widget-text-editor p,
body.elementor-editor-preview .elementor .e-con.card .elementor-widget-text-editor,
body.elementor-editor-preview .elementor .e-con.card .elementor-widget-text-editor p {
  font-size: 16px !important;
  line-height: 24px !important;
  margin: 0 !important;
}

/* Button rows: Elementor makes button widgets behave like full-width blocks. Keep the original inline/flex behavior. */
body.cleanxpert-theme-active .elementor .e-con.button-row,
body.cleanxpert-theme-active .elementor .e-con.button-row > .e-con-inner,
body.elementor-editor-active .elementor .e-con.button-row,
body.elementor-editor-active .elementor .e-con.button-row > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.button-row,
body.elementor-editor-preview .elementor .e-con.button-row > .e-con-inner {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: var(--space-md) !important;
  width: auto !important;
  max-width: 100% !important;
}

body.cleanxpert-theme-active .elementor .e-con.button-row .elementor-widget-button,
body.elementor-editor-active .elementor .e-con.button-row .elementor-widget-button,
body.elementor-editor-preview .elementor .e-con.button-row .elementor-widget-button {
  width: auto !important;
  max-width: max-content !important;
  flex: 0 0 auto !important;
  --container-widget-width: auto !important;
  --container-widget-flex-grow: 0 !important;
  align-self: auto !important;
}

body.cleanxpert-theme-active .elementor .e-con.button-row .elementor-widget-button .elementor-button,
body.elementor-editor-active .elementor .e-con.button-row .elementor-widget-button .elementor-button,
body.elementor-editor-preview .elementor .e-con.button-row .elementor-widget-button .elementor-button {
  width: auto !important;
}

/* CTA panel: restore contrast inside the white card placed on the dark background. */
body.cleanxpert-theme-active .elementor .e-con.dark-section .e-con.cta-box,
body.elementor-editor-active .elementor .e-con.dark-section .e-con.cta-box,
body.elementor-editor-preview .elementor .e-con.dark-section .e-con.cta-box {
  color: var(--deep) !important;
  background: rgba(254, 254, 254, .94) !important;
}

body.cleanxpert-theme-active .elementor .e-con.cta-box .elementor-widget-text-editor,
body.cleanxpert-theme-active .elementor .e-con.cta-box .elementor-widget-text-editor p,
body.cleanxpert-theme-active .elementor .e-con.cta-box .lead,
body.cleanxpert-theme-active .elementor .e-con.cta-box .check-list,
body.cleanxpert-theme-active .elementor .e-con.cta-box .check-list li,
body.cleanxpert-theme-active .elementor .e-con.cta-box .check-list a,
body.cleanxpert-theme-active .elementor .e-con.cta-box .contact-form,
body.cleanxpert-theme-active .elementor .e-con.cta-box .contact-form h3,
body.cleanxpert-theme-active .elementor .e-con.cta-box .contact-form label,
body.cleanxpert-theme-active .elementor .e-con.cta-box .form-hint,
body.elementor-editor-active .elementor .e-con.cta-box .elementor-widget-text-editor,
body.elementor-editor-active .elementor .e-con.cta-box .elementor-widget-text-editor p,
body.elementor-editor-active .elementor .e-con.cta-box .lead,
body.elementor-editor-active .elementor .e-con.cta-box .check-list,
body.elementor-editor-active .elementor .e-con.cta-box .check-list li,
body.elementor-editor-active .elementor .e-con.cta-box .check-list a,
body.elementor-editor-active .elementor .e-con.cta-box .contact-form,
body.elementor-editor-active .elementor .e-con.cta-box .contact-form h3,
body.elementor-editor-active .elementor .e-con.cta-box .contact-form label,
body.elementor-editor-active .elementor .e-con.cta-box .form-hint,
body.elementor-editor-preview .elementor .e-con.cta-box .elementor-widget-text-editor,
body.elementor-editor-preview .elementor .e-con.cta-box .elementor-widget-text-editor p,
body.elementor-editor-preview .elementor .e-con.cta-box .lead,
body.elementor-editor-preview .elementor .e-con.cta-box .check-list,
body.elementor-editor-preview .elementor .e-con.cta-box .check-list li,
body.elementor-editor-preview .elementor .e-con.cta-box .check-list a,
body.elementor-editor-preview .elementor .e-con.cta-box .contact-form,
body.elementor-editor-preview .elementor .e-con.cta-box .contact-form h3,
body.elementor-editor-preview .elementor .e-con.cta-box .contact-form label,
body.elementor-editor-preview .elementor .e-con.cta-box .form-hint {
  color: var(--muted) !important;
}

body.cleanxpert-theme-active .elementor .e-con.cta-box .contact-form h3,
body.cleanxpert-theme-active .elementor .e-con.cta-box .contact-form label,
body.elementor-editor-active .elementor .e-con.cta-box .contact-form h3,
body.elementor-editor-active .elementor .e-con.cta-box .contact-form label,
body.elementor-editor-preview .elementor .e-con.cta-box .contact-form h3,
body.elementor-editor-preview .elementor .e-con.cta-box .contact-form label {
  color: var(--deep) !important;
}

body.cleanxpert-theme-active .elementor .e-con.cta-box .contact-form h3,
body.elementor-editor-active .elementor .e-con.cta-box .contact-form h3,
body.elementor-editor-preview .elementor .e-con.cta-box .contact-form h3 {
  margin: 0 0 var(--space-md) !important;
  font-size: clamp(1.35rem, 1.8vw, 1.5rem) !important;
  line-height: 1.25 !important;
  font-weight: 600 !important;
}

body.cleanxpert-theme-active .elementor .e-con.cta-box input,
body.cleanxpert-theme-active .elementor .e-con.cta-box select,
body.cleanxpert-theme-active .elementor .e-con.cta-box textarea,
body.elementor-editor-active .elementor .e-con.cta-box input,
body.elementor-editor-active .elementor .e-con.cta-box select,
body.elementor-editor-active .elementor .e-con.cta-box textarea,
body.elementor-editor-preview .elementor .e-con.cta-box input,
body.elementor-editor-preview .elementor .e-con.cta-box select,
body.elementor-editor-preview .elementor .e-con.cta-box textarea {
  width: 100% !important;
  min-height: 52px !important;
  padding: var(--space-md) var(--space-lg) !important;
  color: var(--ink) !important;
  background: var(--white) !important;
  border: 1px solid var(--deep) !important;
  border-radius: var(--radius-sm) !important;
}

body.cleanxpert-theme-active .elementor .e-con.cta-box textarea,
body.elementor-editor-active .elementor .e-con.cta-box textarea,
body.elementor-editor-preview .elementor .e-con.cta-box textarea {
  min-height: 126px !important;
}

body.cleanxpert-theme-active .elementor .e-con.cta-box button.btn-lime,
body.elementor-editor-active .elementor .e-con.cta-box button.btn-lime,
body.elementor-editor-preview .elementor .e-con.cta-box button.btn-lime {
  width: 100% !important;
  min-height: 48px !important;
  padding: var(--space-md) var(--space-xl) !important;
  color: var(--deep) !important;
  background: var(--lime) !important;
  border: 1px solid var(--lime) !important;
  border-radius: var(--radius-md) !important;
  font-size: 18px !important;
  line-height: 27px !important;
  font-weight: 600 !important;
}

/* Footer logo final radius and size parity. */
body.cleanxpert-theme-active .footer-brand a,
body.cleanxpert-theme-active .elementor .footer-brand a,
body.elementor-editor-active .elementor .footer-brand a,
body.elementor-editor-preview .elementor .footer-brand a {
  display: inline-block !important;
  line-height: 0 !important;
  border-radius: var(--radius-md) !important;
  overflow: hidden !important;
}

@media (max-width: 1040px) {
  body.cleanxpert-theme-active .elementor .e-con.hero-grid,
  body.cleanxpert-theme-active .elementor .e-con.hero-grid > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.page-hero-grid,
  body.cleanxpert-theme-active .elementor .e-con.page-hero-grid > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.split,
  body.cleanxpert-theme-active .elementor .e-con.split > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.split.reverse,
  body.cleanxpert-theme-active .elementor .e-con.split.reverse > .e-con-inner,
  body.cleanxpert-theme-active .elementor .e-con.cta-box,
  body.cleanxpert-theme-active .elementor .e-con.cta-box > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.hero-grid,
  body.elementor-editor-active .elementor .e-con.hero-grid > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.page-hero-grid,
  body.elementor-editor-active .elementor .e-con.page-hero-grid > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.split,
  body.elementor-editor-active .elementor .e-con.split > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.split.reverse,
  body.elementor-editor-active .elementor .e-con.split.reverse > .e-con-inner,
  body.elementor-editor-active .elementor .e-con.cta-box,
  body.elementor-editor-active .elementor .e-con.cta-box > .e-con-inner,
  body.elementor-editor-preview .elementor .e-con.hero-grid,
  body.elementor-editor-preview .elementor .e-con.hero-grid > .e-con-inner,
  body.elementor-editor-preview .elementor .e-con.page-hero-grid,
  body.elementor-editor-preview .elementor .e-con.page-hero-grid > .e-con-inner,
  body.elementor-editor-preview .elementor .e-con.split,
  body.elementor-editor-preview .elementor .e-con.split > .e-con-inner,
  body.elementor-editor-preview .elementor .e-con.split.reverse,
  body.elementor-editor-preview .elementor .e-con.split.reverse > .e-con-inner,
  body.elementor-editor-preview .elementor .e-con.cta-box,
  body.elementor-editor-preview .elementor .e-con.cta-box > .e-con-inner {
    grid-template-columns: 1fr !important;
  }

  body.cleanxpert-theme-active .elementor .e-con.hero-visual,
  body.cleanxpert-theme-active .elementor .e-con.hero-visual.hero-no-panel,
  body.elementor-editor-active .elementor .e-con.hero-visual,
  body.elementor-editor-active .elementor .e-con.hero-visual.hero-no-panel,
  body.elementor-editor-preview .elementor .e-con.hero-visual,
  body.elementor-editor-preview .elementor .e-con.hero-visual.hero-no-panel {
    min-height: 380px !important;
  }
}

@media (max-width: 860px) {
  body.cleanxpert-theme-active .elementor .e-con.hero,
  body.elementor-editor-active .elementor .e-con.hero,
  body.elementor-editor-preview .elementor .e-con.hero {
    padding: 44px 0 48px !important;
  }

  body.cleanxpert-theme-active .elementor .e-con.hero-visual,
  body.cleanxpert-theme-active .elementor .e-con.hero-visual.hero-no-panel,
  body.elementor-editor-active .elementor .e-con.hero-visual,
  body.elementor-editor-active .elementor .e-con.hero-visual.hero-no-panel,
  body.elementor-editor-preview .elementor .e-con.hero-visual,
  body.elementor-editor-preview .elementor .e-con.hero-visual.hero-no-panel {
    min-height: 360px !important;
  }

  body.cleanxpert-theme-active .elementor .hero-copy .elementor-widget-heading .elementor-heading-title,
  body.elementor-editor-active .elementor .hero-copy .elementor-widget-heading .elementor-heading-title,
  body.elementor-editor-preview .elementor .hero-copy .elementor-widget-heading .elementor-heading-title {
    font-size: clamp(2.15rem, 10vw, 2.75rem) !important;
    line-height: 1.04 !important;
  }

  body.cleanxpert-theme-active .elementor .e-con.split-copy .elementor-widget-heading .elementor-heading-title,
  body.cleanxpert-theme-active .elementor .e-con.cta-box .elementor-widget-heading .elementor-heading-title,
  body.elementor-editor-active .elementor .e-con.split-copy .elementor-widget-heading .elementor-heading-title,
  body.elementor-editor-active .elementor .e-con.cta-box .elementor-widget-heading .elementor-heading-title,
  body.elementor-editor-preview .elementor .e-con.split-copy .elementor-widget-heading .elementor-heading-title,
  body.elementor-editor-preview .elementor .e-con.cta-box .elementor-widget-heading .elementor-heading-title {
    font-size: clamp(1.85rem, 8vw, 2.35rem) !important;
    line-height: 1.06 !important;
  }
}

@media (max-width: 560px) {
  body.cleanxpert-theme-active .elementor .e-con.hero-visual,
  body.cleanxpert-theme-active .elementor .e-con.hero-visual.hero-no-panel,
  body.elementor-editor-active .elementor .e-con.hero-visual,
  body.elementor-editor-active .elementor .e-con.hero-visual.hero-no-panel,
  body.elementor-editor-preview .elementor .e-con.hero-visual,
  body.elementor-editor-preview .elementor .e-con.hero-visual.hero-no-panel {
    min-height: 280px !important;
  }
}


/* v1.0.7 Elementor design polish
   Fixes based on live /test-2/ and service-page screenshots:
   - no duplicate eyebrow lines from HTML widget wrapper;
   - inline button rows, smaller buttons, no forced centering/full-width widgets;
   - image widgets cover their cards/containers;
   - all section headings use the CleanXpert deep color unless inside dark section;
   - footer contact details are visible and the obsolete “Website actual” link is removed from templates;
   - header remains sticky to the top. */

/* Sticky header parity */
body.cleanxpert-theme-active .site-header,
body.cleanxpert-theme-active .elementor .site-header,
body.elementor-editor-preview .site-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
}
body.admin-bar.cleanxpert-theme-active .site-header {
  top: 32px !important;
}
@media (max-width: 782px) {
  body.admin-bar.cleanxpert-theme-active .site-header { top: 46px !important; }
}

/* Eyebrow: Elementor HTML widgets had class="eyebrow" on the wrapper and the inner <span>, creating two lines. */
body.cleanxpert-theme-active .elementor .elementor-widget-html.eyebrow::before,
body.cleanxpert-theme-active .elementor .elementor-widget-html.eyebrow > .elementor-widget-container::before,
body.elementor-editor-active .elementor .elementor-widget-html.eyebrow::before,
body.elementor-editor-active .elementor .elementor-widget-html.eyebrow > .elementor-widget-container::before,
body.elementor-editor-preview .elementor .elementor-widget-html.eyebrow::before,
body.elementor-editor-preview .elementor .elementor-widget-html.eyebrow > .elementor-widget-container::before {
  content: none !important;
  display: none !important;
}
body.cleanxpert-theme-active .elementor .elementor-widget-html.eyebrow,
body.elementor-editor-active .elementor .elementor-widget-html.eyebrow,
body.elementor-editor-preview .elementor .elementor-widget-html.eyebrow {
  display: block !important;
  width: 100% !important;
  margin: 0 0 var(--space-lg) !important;
}
body.cleanxpert-theme-active .elementor .elementor-widget-html.eyebrow > .elementor-widget-container,
body.elementor-editor-active .elementor .elementor-widget-html.eyebrow > .elementor-widget-container,
body.elementor-editor-preview .elementor .elementor-widget-html.eyebrow > .elementor-widget-container {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
}
body.cleanxpert-theme-active .elementor .elementor-widget-html.eyebrow .eyebrow,
body.elementor-editor-active .elementor .elementor-widget-html.eyebrow .eyebrow,
body.elementor-editor-preview .elementor .elementor-widget-html.eyebrow .eyebrow {
  display: inline-flex !important;
  width: auto !important;
  max-width: max-content !important;
  gap: var(--space-sm) !important;
  align-items: center !important;
  margin: 0 !important;
  color: var(--dark) !important;
  font-family: var(--site-font-body) !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  line-height: 14px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
}
body.cleanxpert-theme-active .elementor .elementor-widget-html.eyebrow .eyebrow::before,
body.elementor-editor-active .elementor .elementor-widget-html.eyebrow .eyebrow::before,
body.elementor-editor-preview .elementor .elementor-widget-html.eyebrow .eyebrow::before {
  content: "" !important;
  display: inline-block !important;
  width: 32px !important;
  height: 2px !important;
  flex: 0 0 32px !important;
  border-radius: 999px !important;
  background: var(--turquoise) !important;
}
body.cleanxpert-theme-active .elementor .dark-section .elementor-widget-html.eyebrow .eyebrow,
body.elementor-editor-active .elementor .dark-section .elementor-widget-html.eyebrow .eyebrow,
body.elementor-editor-preview .elementor .dark-section .elementor-widget-html.eyebrow .eyebrow {
  color: var(--white) !important;
}
body.cleanxpert-theme-active .elementor .dark-section .elementor-widget-html.eyebrow .eyebrow::before,
body.elementor-editor-active .elementor .dark-section .elementor-widget-html.eyebrow .eyebrow::before,
body.elementor-editor-preview .elementor .dark-section .elementor-widget-html.eyebrow .eyebrow::before {
  background: var(--lime) !important;
}
body.cleanxpert-theme-active .elementor .text-center .elementor-widget-html.eyebrow,
body.cleanxpert-theme-active .elementor .text-center .elementor-widget-html.eyebrow > .elementor-widget-container,
body.elementor-editor-active .elementor .text-center .elementor-widget-html.eyebrow,
body.elementor-editor-active .elementor .text-center .elementor-widget-html.eyebrow > .elementor-widget-container,
body.elementor-editor-preview .elementor .text-center .elementor-widget-html.eyebrow,
body.elementor-editor-preview .elementor .text-center .elementor-widget-html.eyebrow > .elementor-widget-container {
  text-align: center !important;
}

/* Uniform heading color and scale. Elementor sometimes imports generated colors from previous edits. */
body.cleanxpert-theme-active .elementor .e-con:not(.dark-section) .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .e-con:not(.dark-section) .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .e-con:not(.dark-section) .elementor-widget-heading .elementor-heading-title {
  color: var(--deep) !important;
}
body.cleanxpert-theme-active .elementor .dark-section .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .dark-section .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .dark-section .elementor-widget-heading .elementor-heading-title {
  color: var(--white) !important;
}
body.cleanxpert-theme-active .elementor .dark-section .cta-box .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-active .elementor .dark-section .cta-box .elementor-widget-heading .elementor-heading-title,
body.elementor-editor-preview .elementor .dark-section .cta-box .elementor-widget-heading .elementor-heading-title {
  color: var(--deep) !important;
}

/* Button row fidelity: real Elementor widgets must behave like inline buttons, not full-width blocks. */
body.cleanxpert-theme-active .elementor .e-con.button-row,
body.cleanxpert-theme-active .elementor .e-con.button-row > .e-con-inner,
body.elementor-editor-active .elementor .e-con.button-row,
body.elementor-editor-active .elementor .e-con.button-row > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.button-row,
body.elementor-editor-preview .elementor .e-con.button-row > .e-con-inner {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 12px !important;
  width: auto !important;
  max-width: 100% !important;
  --display: flex !important;
  --flex-direction: row !important;
  --flex-wrap: wrap !important;
  --justify-content: flex-start !important;
  --align-items: center !important;
  --gap: 12px !important;
}
body.cleanxpert-theme-active .elementor .e-con.hero-single-cta,
body.cleanxpert-theme-active .elementor .e-con.hero-single-cta > .e-con-inner,
body.elementor-editor-active .elementor .e-con.hero-single-cta,
body.elementor-editor-active .elementor .e-con.hero-single-cta > .e-con-inner,
body.elementor-editor-preview .elementor .e-con.hero-single-cta,
body.elementor-editor-preview .elementor .e-con.hero-single-cta > .e-con-inner {
  margin-top: var(--space-xl) !important;
}
body.cleanxpert-theme-active .elementor .e-con.button-row .elementor-widget-button,
body.elementor-editor-active .elementor .e-con.button-row .elementor-widget-button,
body.elementor-editor-preview .elementor .e-con.button-row .elementor-widget-button {
  display: inline-flex !important;
  width: auto !important;
  max-width: max-content !important;
  flex: 0 0 auto !important;
  align-self: auto !important;
  --container-widget-width: auto !important;
  --container-widget-flex-grow: 0 !important;
  --container-widget-align-self: auto !important;
}
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn .elementor-widget-container,
body.elementor-editor-active .elementor .elementor-widget-button.btn .elementor-widget-container,
body.elementor-editor-preview .elementor .elementor-widget-button.btn .elementor-widget-container {
  display: inline-flex !important;
  width: auto !important;
}
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn .elementor-button {
  width: auto !important;
  min-width: 0 !important;
  min-height: 44px !important;
  padding: 10px 22px !important;
  font-size: 16px !important;
  line-height: 22px !important;
  border-radius: 10px !important;
}
/* Form submit remains full-width by design. */
body.cleanxpert-theme-active .elementor .contact-form button.btn-lime,
body.elementor-editor-active .elementor .contact-form button.btn-lime,
body.elementor-editor-preview .elementor .contact-form button.btn-lime {
  width: 100% !important;
  min-height: 44px !important;
  padding: 10px 22px !important;
  font-size: 16px !important;
  line-height: 22px !important;
}

/* Images must fill the visual cards with cover, including service hero cards that previously showed an empty tinted strip. */
body.cleanxpert-theme-active .elementor .e-con.media-card,
body.cleanxpert-theme-active .elementor .e-con.service-hero-img,
body.cleanxpert-theme-active .elementor .e-con.about-hero-photo,
body.elementor-editor-active .elementor .e-con.media-card,
body.elementor-editor-active .elementor .e-con.service-hero-img,
body.elementor-editor-active .elementor .e-con.about-hero-photo,
body.elementor-editor-preview .elementor .e-con.media-card,
body.elementor-editor-preview .elementor .e-con.service-hero-img,
body.elementor-editor-preview .elementor .e-con.about-hero-photo {
  position: relative !important;
  display: block !important;
  overflow: hidden !important;
  aspect-ratio: 4 / 3 !important;
  padding: 0 !important;
  background: var(--soft) !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--radius-md) !important;
}
body.cleanxpert-theme-active .elementor .e-con.service-hero-img.hero-photo-wide,
body.elementor-editor-active .elementor .e-con.service-hero-img.hero-photo-wide,
body.elementor-editor-preview .elementor .e-con.service-hero-img.hero-photo-wide {
  aspect-ratio: 4 / 3 !important;
}
body.cleanxpert-theme-active .elementor .e-con.media-card .elementor-widget-image,
body.cleanxpert-theme-active .elementor .e-con.media-card .elementor-widget-container,
body.cleanxpert-theme-active .elementor .e-con.service-hero-img .elementor-widget-image,
body.cleanxpert-theme-active .elementor .e-con.service-hero-img .elementor-widget-container,
body.cleanxpert-theme-active .elementor .e-con.about-hero-photo .elementor-widget-image,
body.cleanxpert-theme-active .elementor .e-con.about-hero-photo .elementor-widget-container,
body.elementor-editor-active .elementor .e-con.media-card .elementor-widget-image,
body.elementor-editor-active .elementor .e-con.media-card .elementor-widget-container,
body.elementor-editor-active .elementor .e-con.service-hero-img .elementor-widget-image,
body.elementor-editor-active .elementor .e-con.service-hero-img .elementor-widget-container,
body.elementor-editor-active .elementor .e-con.about-hero-photo .elementor-widget-image,
body.elementor-editor-active .elementor .e-con.about-hero-photo .elementor-widget-container,
body.elementor-editor-preview .elementor .e-con.media-card .elementor-widget-image,
body.elementor-editor-preview .elementor .e-con.media-card .elementor-widget-container,
body.elementor-editor-preview .elementor .e-con.service-hero-img .elementor-widget-image,
body.elementor-editor-preview .elementor .e-con.service-hero-img .elementor-widget-container,
body.elementor-editor-preview .elementor .e-con.about-hero-photo .elementor-widget-image,
body.elementor-editor-preview .elementor .e-con.about-hero-photo .elementor-widget-container {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}
body.cleanxpert-theme-active .elementor .e-con.media-card img,
body.cleanxpert-theme-active .elementor .e-con.service-hero-img img,
body.cleanxpert-theme-active .elementor .e-con.about-hero-photo img,
body.elementor-editor-active .elementor .e-con.media-card img,
body.elementor-editor-active .elementor .e-con.service-hero-img img,
body.elementor-editor-active .elementor .e-con.about-hero-photo img,
body.elementor-editor-preview .elementor .e-con.media-card img,
body.elementor-editor-preview .elementor .e-con.service-hero-img img,
body.elementor-editor-preview .elementor .e-con.about-hero-photo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
}

/* Footer contact values and link readability. */
body.cleanxpert-theme-active .site-footer .footer-brand p,
body.cleanxpert-theme-active .site-footer .footer-brand strong,
body.cleanxpert-theme-active .site-footer .footer-brand a,
body.cleanxpert-theme-active .elementor .site-footer .footer-brand p,
body.cleanxpert-theme-active .elementor .site-footer .footer-brand strong,
body.cleanxpert-theme-active .elementor .site-footer .footer-brand a,
body.elementor-editor-active .elementor .site-footer .footer-brand p,
body.elementor-editor-active .elementor .site-footer .footer-brand strong,
body.elementor-editor-active .elementor .site-footer .footer-brand a,
body.elementor-editor-preview .elementor .site-footer .footer-brand p,
body.elementor-editor-preview .elementor .site-footer .footer-brand strong,
body.elementor-editor-preview .elementor .site-footer .footer-brand a {
  color: rgba(254, 254, 254, .86) !important;
  opacity: 1 !important;
  visibility: visible !important;
}
body.cleanxpert-theme-active .site-footer .footer-brand a,
body.cleanxpert-theme-active .elementor .site-footer .footer-brand a,
body.elementor-editor-active .elementor .site-footer .footer-brand a,
body.elementor-editor-preview .elementor .site-footer .footer-brand a {
  display: inline !important;
  line-height: inherit !important;
}
body.cleanxpert-theme-active .site-footer .footer-brand > a:first-child,
body.cleanxpert-theme-active .elementor .site-footer .footer-brand > a:first-child,
body.elementor-editor-active .elementor .site-footer .footer-brand > a:first-child,
body.elementor-editor-preview .elementor .site-footer .footer-brand > a:first-child {
  display: inline-block !important;
  line-height: 0 !important;
  overflow: hidden !important;
  border-radius: var(--radius-md) !important;
}

@media (max-width: 860px) {
  body.cleanxpert-theme-active .elementor .elementor-widget-button.btn .elementor-button,
  body.elementor-editor-active .elementor .elementor-widget-button.btn .elementor-button,
  body.elementor-editor-preview .elementor .elementor-widget-button.btn .elementor-button {
    min-height: 44px !important;
    padding: 10px 18px !important;
    font-size: 16px !important;
    line-height: 22px !important;
  }
}


/* v1.0.8: Final Elementor button-wrapper cleanup.
   Elementor receives classes like "btn btn-outline" on the widget wrapper.
   The original static CSS then styled the wrapper as a second button while
   Elementor also styled the real <a>. Reset the wrapper and keep only the
   real .elementor-button styled. */
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-primary,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-outline,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-secondary,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-ghost,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-lime,
body.elementor-editor-active .elementor .elementor-widget-button.btn,
body.elementor-editor-active .elementor .elementor-widget-button.btn-primary,
body.elementor-editor-active .elementor .elementor-widget-button.btn-outline,
body.elementor-editor-active .elementor .elementor-widget-button.btn-secondary,
body.elementor-editor-active .elementor .elementor-widget-button.btn-ghost,
body.elementor-editor-active .elementor .elementor-widget-button.btn-lime,
body.elementor-editor-preview .elementor .elementor-widget-button.btn,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-primary,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-outline,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-secondary,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-ghost,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-lime {
  display: inline-flex !important;
  width: auto !important;
  max-width: max-content !important;
  min-width: 0 !important;
  min-height: 0 !important;
  flex: 0 0 auto !important;
  align-self: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: inherit !important;
  box-shadow: none !important;
  transform: none !important;
  line-height: normal !important;
  text-decoration: none !important;
  overflow: visible !important;
  --container-widget-width: auto !important;
  --container-widget-flex-grow: 0 !important;
  --container-widget-align-self: auto !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn:hover,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn:focus,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn:focus-visible,
body.elementor-editor-active .elementor .elementor-widget-button.btn:hover,
body.elementor-editor-active .elementor .elementor-widget-button.btn:focus,
body.elementor-editor-active .elementor .elementor-widget-button.btn:focus-visible,
body.elementor-editor-preview .elementor .elementor-widget-button.btn:hover,
body.elementor-editor-preview .elementor .elementor-widget-button.btn:focus,
body.elementor-editor-preview .elementor .elementor-widget-button.btn:focus-visible {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: none !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn > .elementor-widget-container,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-primary > .elementor-widget-container,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-outline > .elementor-widget-container,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-secondary > .elementor-widget-container,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-ghost > .elementor-widget-container,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-lime > .elementor-widget-container,
body.elementor-editor-active .elementor .elementor-widget-button.btn > .elementor-widget-container,
body.elementor-editor-active .elementor .elementor-widget-button.btn-primary > .elementor-widget-container,
body.elementor-editor-active .elementor .elementor-widget-button.btn-outline > .elementor-widget-container,
body.elementor-editor-active .elementor .elementor-widget-button.btn-secondary > .elementor-widget-container,
body.elementor-editor-active .elementor .elementor-widget-button.btn-ghost > .elementor-widget-container,
body.elementor-editor-active .elementor .elementor-widget-button.btn-lime > .elementor-widget-container,
body.elementor-editor-preview .elementor .elementor-widget-button.btn > .elementor-widget-container,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-primary > .elementor-widget-container,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-outline > .elementor-widget-container,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-secondary > .elementor-widget-container,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-ghost > .elementor-widget-container,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-lime > .elementor-widget-container {
  display: inline-flex !important;
  width: auto !important;
  max-width: max-content !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

/* The real button only. */
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn .elementor-button {
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: max-content !important;
  min-height: 44px !important;
  padding: 10px 22px !important;
  border-width: 1px !important;
  border-style: solid !important;
  border-radius: 10px !important;
  font-size: 16px !important;
  line-height: 22px !important;
  font-weight: 600 !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-primary .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn-primary .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-primary .elementor-button {
  background: var(--turquoise) !important;
  border-color: var(--turquoise) !important;
  color: var(--deep) !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-outline .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn-outline .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-outline .elementor-button {
  background: var(--white) !important;
  border-color: var(--deep) !important;
  color: var(--deep) !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-secondary .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn-secondary .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-secondary .elementor-button {
  background: var(--deep) !important;
  border-color: var(--deep) !important;
  color: var(--white) !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-ghost .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn-ghost .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-ghost .elementor-button {
  background: rgba(254, 254, 254, .88) !important;
  border-color: rgba(254, 254, 254, .72) !important;
  color: var(--deep) !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn-lime .elementor-button,
body.elementor-editor-active .elementor .elementor-widget-button.btn-lime .elementor-button,
body.elementor-editor-preview .elementor .elementor-widget-button.btn-lime .elementor-button {
  background: var(--lime) !important;
  border-color: var(--lime) !important;
  color: var(--deep) !important;
}

body.cleanxpert-theme-active .elementor .elementor-widget-button.btn .elementor-button:hover,
body.cleanxpert-theme-active .elementor .elementor-widget-button.btn .elementor-button:focus-visible,
body.elementor-editor-active .elementor .elementor-widget-button.btn .elementor-button:hover,
body.elementor-editor-active .elementor .elementor-widget-button.btn .elementor-button:focus-visible,
body.elementor-editor-preview .elementor .elementor-widget-button.btn .elementor-button:hover,
body.elementor-editor-preview .elementor .elementor-widget-button.btn .elementor-button:focus-visible {
  transform: translateY(-1px) !important;
  box-shadow: var(--shadow-sm) !important;
}

/* Elementor sometimes adds alignment wrappers that stretch a button to 100%. */
body.cleanxpert-theme-active .elementor .elementor-align-left .elementor-button,
body.cleanxpert-theme-active .elementor .elementor-align-center .elementor-button,
body.cleanxpert-theme-active .elementor .elementor-align-right .elementor-button,
body.elementor-editor-active .elementor .elementor-align-left .elementor-button,
body.elementor-editor-active .elementor .elementor-align-center .elementor-button,
body.elementor-editor-active .elementor .elementor-align-right .elementor-button,
body.elementor-editor-preview .elementor .elementor-align-left .elementor-button,
body.elementor-editor-preview .elementor .elementor-align-center .elementor-button,
body.elementor-editor-preview .elementor .elementor-align-right .elementor-button {
  width: auto !important;
}

/* Keep header sticky in the public site and Elementor preview. */
body.cleanxpert-theme-active .site-header,
body.cleanxpert-theme-active .elementor .site-header,
body.elementor-editor-preview .site-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 99999 !important;
}
body.admin-bar.cleanxpert-theme-active .site-header {
  top: 32px !important;
}
@media (max-width: 782px) {
  body.admin-bar.cleanxpert-theme-active .site-header { top: 46px !important; }
}
