.elementor-292 .elementor-element.elementor-element-44e70c7{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;border-style:none;--border-style:none;}.elementor-292 .elementor-element.elementor-element-5ba8c94{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-292 .elementor-element.elementor-element-c761130{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-292 .elementor-element.elementor-element-ba4be32{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-292 .elementor-element.elementor-element-ccba976{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-292 .elementor-element.elementor-element-3fb124e{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-292 .elementor-element.elementor-element-8bf9e66{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}/* Start custom CSS *//* ============================================================
   NUASENSE — GLOBAL CUSTOM CSS
   Paste this into: Elementor → Site Settings → Custom CSS
   ============================================================ */


/* ─── GOOGLE FONT IMPORT ─── */
@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap');


/* ─── CSS VARIABLES ─── */
:root {
  --ns-dark:        #141b2d;
  --ns-teal:        #4cceac;
  --ns-teal-mid:    #3da58a;
  --ns-white:       #fcfcfc;
  --ns-sage:        #f2f0f0;
  --ns-teal-light:  #dbf5ee;
  --ns-gray:        #727681;
  --ns-border:      #d0d1d5;
}


/* ─── GLOBAL BODY & TYPOGRAPHY ─── */
/* SAFE list: only text-bearing elements. No span, div, i — those break Elementor icons. */
body,
p, a, li, td, th,
h1, h2, h3, h4, h5, h6,
input, textarea, select, button, label,
.elementor-widget-text-editor,
.elementor-widget-text-editor p,
.elementor-heading-title,
.elementor-widget-button .elementor-button,
.elementor-tab-title,
.elementor-tab-content,
.elementor-accordion-title,
.elementor-toggle-title {
  font-family: 'Source Sans 3', sans-serif !important;
}

body {
  background-color: var(--ns-white);
  color: var(--ns-dark);
}


/* ─── ELEMENTOR PAGE WRAPPER ─── */
.elementor-section {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.elementor-section .elementor-container {
  max-width: 100% !important;
  padding: 0 !important;
}

.elementor-column-gap-default > .elementor-row > .elementor-column > .elementor-element-populated {
  padding: 0 !important;
}

.elementor-widget-wrap {
  padding: 0 !important;
}


/* ─── NAVIGATION BAR ─── */
.elementor-nav-menu .menu-item a,
.elementor-nav-menu--main .menu-item a {
  font-size: 0.78rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--ns-gray) !important;
  transition: color 0.2s !important;
}

.elementor-nav-menu .menu-item a:hover,
.elementor-nav-menu--main .menu-item a:hover {
  color: var(--ns-dark) !important;
}

/* Sticky header — NO border-bottom (the HTML header handles its own) */
.elementor-sticky--active,
.e-con.elementor-sticky--active {
  background: rgba(252, 252, 252, 0.95) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-bottom: none !important;
}

.site-title a,
.custom-logo-link,
h1.site-title a {
  font-weight: 600 !important;
  font-size: 1rem !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--ns-dark) !important;
  text-decoration: none !important;
}


/* ─── HEADINGS ─── */
h1, h2, h3, h4, h5, h6,
.elementor-heading-title {
  color: var(--ns-dark) !important;
  letter-spacing: -0.015em !important;
}

h1 { font-size: clamp(2.4rem, 4.5vw, 4rem) !important; font-weight: 600 !important; line-height: 1.1 !important; }
h2 { font-size: clamp(1.8rem, 3vw, 2.6rem) !important; font-weight: 600 !important; line-height: 1.18 !important; }
h3 { font-size: 1.1rem !important; font-weight: 600 !important; }

p,
.elementor-widget-text-editor p {
  font-weight: 300 !important;
  font-size: 0.95rem !important;
  line-height: 1.8 !important;
  color: var(--ns-gray) !important;
}


/* ─── BUTTONS ─── */
.elementor-button,
.elementor-button-wrapper .elementor-button,
a.ns-btn-primary,
button.ns-btn-primary,
.ns-btn-primary {
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  border-radius: 2px !important;
  padding: 14px 32px !important;
  transition: background 0.2s, transform 0.15s !important;
}

.elementor-button.elementor-size-md,
.elementor-button-primary,
a.ns-btn-primary,
button.ns-btn-primary,
.ns-btn-primary {
  background: var(--ns-dark) !important;
  color: var(--ns-white) !important;
  -webkit-text-fill-color: var(--ns-white) !important;
  border: none !important;
}
.elementor-button.elementor-size-md:hover,
.elementor-button-primary:hover,
a.ns-btn-primary:hover,
button.ns-btn-primary:hover,
.ns-btn-primary:hover {
  background: var(--ns-teal-mid) !important;
  color: var(--ns-white) !important;
  -webkit-text-fill-color: var(--ns-white) !important;
  transform: translateY(-1px) !important;
}

.elementor-button span,
.elementor-button a,
.elementor-button .elementor-button-text,
a.ns-btn-primary span {
  color: var(--ns-white) !important;
  -webkit-text-fill-color: var(--ns-white) !important;
}


/* ─── FORM ELEMENTS ─── */
input[type="text"],
input[type="email"],
input[type="tel"],
textarea,
select,
.wpcf7-form-control,
.wpforms-field input,
.wpforms-field textarea,
.elementor-field-group input,
.elementor-field-group textarea {
  font-size: 0.9rem !important;
  font-weight: 300 !important;
  background: var(--ns-white) !important;
  border: 1px solid var(--ns-border) !important;
  border-radius: 2px !important;
  padding: 12px 16px !important;
  color: var(--ns-dark) !important;
  outline: none !important;
  transition: border-color 0.2s !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

input:focus,
textarea:focus,
.wpcf7-form-control:focus,
.wpforms-field input:focus,
.elementor-field-group input:focus,
.elementor-field-group textarea:focus {
  border-color: var(--ns-teal) !important;
  box-shadow: none !important;
}

.elementor-field-label,
.wpforms-field-label {
  font-size: 0.68rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--ns-gray) !important;
}

input[type="submit"],
.wpcf7-submit,
.wpforms-submit,
.elementor-button[type="submit"] {
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  background: var(--ns-dark) !important;
  color: var(--ns-white) !important;
  -webkit-text-fill-color: var(--ns-white) !important;
  border: none !important;
  border-radius: 2px !important;
  padding: 14px 32px !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
}
input[type="submit"]:hover,
.wpcf7-submit:hover,
.wpforms-submit:hover,
.elementor-button[type="submit"]:hover {
  background: var(--ns-teal-mid) !important;
}


/* ─── FOOTER — NO border-top (the HTML footer handles its own) ─── */
footer,
.site-footer,
#colophon {
  background: var(--ns-white) !important;
  border-top: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

footer a,
.site-footer a {
  color: var(--ns-dark) !important;
  text-decoration: none !important;
  transition: color 0.2s !important;
}

footer a:hover,
.site-footer a:hover {
  color: var(--ns-teal) !important;
}


/* ─── SCROLLBAR ─── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--ns-white); }
::-webkit-scrollbar-thumb { background: var(--ns-border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--ns-gray); }


/* ─── SELECTION ─── */
::selection {
  background: var(--ns-teal) !important;
  color: var(--ns-dark) !important;
}


/* ─── Dark section headings ─── */
.ns-process h2,
.ns-process h3 {
  color: #fcfcfc !important;
}


/* ─── MOBILE ─── */
@media (max-width: 768px) {
  footer,
  .site-footer,
  #colophon {
    text-align: center !important;
  }
}/* End custom CSS */