.elementor-703 .elementor-element.elementor-element-e9fab8e{--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;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-theme-builder-content-area{height:400px;}.elementor-location-header:before, .elementor-location-footer:before{content:"";display:table;clear:both;}/* Start custom CSS for html, class: .elementor-element-e2696af *//* ======================================================================== */
/* Header Styles v1.7 (Premium Refinements & Mobile Menu Fix)             */
/* Enhances transitions, shadows, mobile menu feel, includes height fix.    */
/* ======================================================================== */

/* 0. Keyframes & Reduced Motion (Ensure Present Globally) */
@keyframes ns-content-fade-slide-up {
  from { opacity: 0; transform: translateY(25px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .ns-header,
  .ns-header *,
  .ns-mobile-menu,
  .ns-mobile-menu * {
      animation: none !important;
      transition: none !important;
  }
   .ns-header.is-mobile-menu-open .ns-mobile-menu-toggle .ns-hamburger-line {
      transition: none !important;
  }
  /* Add specific hover/active state resets if needed */
}

/* Ensure HSL variables are defined globally in :root */
/* Example: :root { --clr-accent-primary-hsl: 188 82% 26%; --timing-function-smooth: cubic-bezier(0.25, 0.8, 0.25, 1); } */

/* 1. Header Main Bar */
.ns-header.ns-header--enhanced {
  background-color: var(--clr-bg-light, #F8F9FA);
  padding: clamp(var(--space-md, 24px), 3vw, var(--space-lg, 40px)) 0;
  border-bottom: 1px solid var(--clr-border-light, #E0E0E0);
  position: relative; /* Keep relative unless overridden by sticky */
  z-index: 1000;
  /* === Premium: Slightly longer, smoother transition === */
  transition: background-color 0.5s var(--timing-function-smooth, ease),
              box-shadow 0.5s var(--timing-function-smooth, ease),
              padding 0.5s var(--timing-function-smooth, ease),
              border-color 0.5s var(--timing-function-smooth, ease);
}

/* Sticky Header Functionality (Applied via Elementor) */
.ns-header--sticky {
  /* Styles applied by Elementor sticky */
  position: sticky; 
  top: 0;
  width: 100%;
}

/* Scrolled state - Refined */
.ns-header--scrolled {
  background-color: rgba(255, 255, 255, 0.9); /* Slightly less opaque */
  /* === Premium: Softer, more diffused shadow === */
  box-shadow: 0 10px 40px rgba(80, 90, 120, 0.1); 
  padding: clamp(var(--space-sm, 16px), 2vw, var(--space-md, 24px)) 0;
  /* === Premium: More pronounced blur === */
  backdrop-filter: blur(12px); 
  border-bottom-color: transparent;
}


/* 2. Header Container */
.ns-header-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1360px;
  margin: 0 auto;
  padding: 0 clamp(var(--space-md, 24px), 5vw, var(--space-xl, 64px));
}

/* 3. Logo (Text) */
.ns-header-logo {
  flex-shrink: 0;
  margin-right: clamp(var(--space-lg, 40px), 6vw, var(--space-xxl, 80px));
  transition: margin-right 0.5s var(--timing-function-smooth, ease); /* Match header transition */
}

.ns-header-logo a {
    text-decoration: none;
    display: block;
    transition: transform 0.35s var(--timing-function-smooth);
}
.ns-header-logo a:hover { transform: scale(1.02); }

.ns-header-logo-text {
  font-family: 'Poppins', sans-serif;
  font-weight: 700;
  font-size: clamp(1.6rem, 2.6vw, 1.9rem);
  color: var(--clr-text-dark, #212529);
  letter-spacing: 0.2px;
  line-height: 1;
  transition: color 0.35s var(--timing-function-smooth),
              font-size 0.5s var(--timing-function-smooth, ease); /* Match header transition */
}
.ns-header-logo a:hover .ns-header-logo-text { color: var(--clr-accent-primary); }

/* Scrolled state logo text size */
.ns-header--scrolled .ns-header-logo-text {
  font-size: clamp(1.5rem, 2.4vw, 1.7rem);
}
/* Adjust margin when scrolled */
.ns-header--scrolled .ns-header-logo {
    margin-right: clamp(var(--space-md, 24px), 4.5vw, var(--space-xl, 64px));
}


/* 4. Desktop Navigation (Centered) */
.ns-header-nav {
  flex-grow: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: opacity 0.3s ease; 
}

.ns-header-nav-list {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: clamp(var(--space-md, 24px), 4vw, var(--space-xl, 64px));
  transition: gap 0.5s var(--timing-function-smooth, ease); /* Match header transition */
}

.ns-header-nav-link {
  font-family: 'Poppins', sans-serif;
  font-size: 1rem; 
  font-weight: 500;
  color: var(--clr-text-dark, #212529);
  text-decoration: none;
  padding: clamp(var(--space-sm, 16px), 2.5vw, var(--space-md, 24px)) 0;
  position: relative;
  transition: color 0.35s var(--timing-function-smooth),
              padding 0.5s var(--timing-function-smooth, ease); /* Match header transition */
}
/* Reduce link padding on scroll */
.ns-header--scrolled .ns-header-nav-link {
   padding: clamp(var(--space-xs, 8px), 1.8vw, var(--space-sm, 16px)) 0;
}

/* Underline effect */
.ns-header-nav-link::after {
  content: '';
  position: absolute;
  bottom: clamp(5px, 1vh, 10px); 
  left: 0;
  width: 100%;
  height: 1px;
  background-color: var(--clr-accent-primary, #0D6E7A);
  transform: scaleX(0);
  transform-origin: center;
  /* === Premium: Slightly adjusted timing === */
  transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1), 
              bottom 0.5s var(--timing-function-smooth, ease); /* Match header transition */
}
.ns-header--scrolled .ns-header-nav-link::after {
    bottom: clamp(3px, 0.8vh, 5px); 
}

.ns-header-nav-link:hover,
.ns-header-nav-link:focus-visible { color: var(--clr-accent-primary, #0D6E7A); }
.ns-header-nav-link:hover::after,
.ns-header-nav-link:focus-visible::after { transform: scaleX(1); }

/* Active Link State (Set by JS) */
.ns-header-nav-link.is-active { color: var(--clr-accent-primary, #0D6E7A); font-weight: 600; }
.ns-header-nav-link.is-active::after { transform: scaleX(1); transform-origin: center; }


/* 5. Header Call to Action Button - SOLID STYLE */
.ns-header-cta {
  margin-left: clamp(var(--space-md, 24px), 4vw, var(--space-xl, 64px));
  display: block;
  flex-shrink: 0;
  transition: margin-left 0.5s var(--timing-function-smooth, ease); /* Match header transition */
}
/* Adjust margin on scroll */
.ns-header--scrolled .ns-header-cta {
    margin-left: clamp(var(--space-sm, 16px), 3vw, var(--space-lg, 40px));
}

/* Target the button within the header CTA specifically */
.ns-header .ns-header-cta .ns-button.ns-button--small {
  /* !important justification: Override Elementor/broad styles */
  background-color: var(--clr-accent-primary, #0D6E7A) !important;
  color: var(--clr-cta-text-light, #FFFFFF) !important;
  border: 1px solid var(--clr-accent-primary, #0D6E7A) !important; 
  padding: clamp(calc(var(--space-xs, 8px)*0.8), 1.2vw, calc(var(--space-xs, 8px) * 1.4))
           clamp(calc(var(--space-sm, 16px)*0.8), 2.5vw, calc(var(--space-sm, 16px) * 1.6)) !important;
  font-size: 0.9rem !important;
  border-radius: var(--radius-md, 8px) !important;
  font-weight: 600 !important;
  letter-spacing: 0.3px !important;
  text-transform: none !important; 
  box-shadow: 0 2px 5px rgba(0,0,0, 0.1) !important; 
  transition: background-color 0.3s ease, border-color 0.3s ease,
              color 0.3s ease, transform 0.3s ease,
              box-shadow 0.3s ease,
              padding 0.5s var(--timing-function-smooth, ease) !important; /* Include padding transition */
}

/* Hover/Focus State for the solid header button */
.ns-header .ns-header-cta .ns-button.ns-button--small:hover,
.ns-header .ns-header-cta .ns-button.ns-button--small:focus-visible {
  background-color: #0B5F6A !important; 
  border-color: #0B5F6A !important;
  color: var(--clr-cta-text-light, #FFFFFF) !important; 
  transform: translateY(-3px) scale(1.02) !important;
  box-shadow: 0 6px 15px rgba(13, 110, 122, 0.25) !important; 
}


/* 6. Mobile Menu Toggle */
.ns-mobile-menu-toggle {
  display: none;
  background: none;
  border: none;
  padding: var(--space-sm, 16px);
  cursor: pointer;
  margin-left: var(--space-sm, 16px);
  z-index: 1001; /* Above mobile menu */
  position: relative;
  width: 44px;
  height: 44px;
}
.ns-hamburger-line {
  display: block;
  width: 26px;
  height: 2px;
  background-color: var(--clr-text-dark, #212529);
  margin: 0;
  border-radius: 1px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  /* === Premium: Use consistent timing function === */
  transition: transform 0.4s var(--timing-function-smooth, ease), 
              opacity 0.4s var(--timing-function-smooth, ease),
              background-color 0.4s var(--timing-function-smooth, ease);
}
.ns-hamburger-line:nth-child(1) { top: 13px; }
.ns-hamburger-line:nth-child(2) { top: 20px; }
.ns-hamburger-line:nth-child(3) { top: 27px; }
/* Hamburger Animation */
.ns-header.is-mobile-menu-open .ns-mobile-menu-toggle .ns-hamburger-line { background-color: var(--clr-text-light, #F8F9FA); }
.ns-header.is-mobile-menu-open .ns-mobile-menu-toggle .ns-hamburger-line:nth-child(1) { top: 20px; transform: translateX(-50%) rotate(45deg); }
.ns-header.is-mobile-menu-open .ns-mobile-menu-toggle .ns-hamburger-line:nth-child(2) { opacity: 0; transform: translateX(-50%) scaleX(0); }
.ns-header.is-mobile-menu-open .ns-mobile-menu-toggle .ns-hamburger-line:nth-child(3) { top: 20px; transform: translateX(-50%) rotate(-45deg); }

/* 7. Mobile Navigation Menu (Height/Overflow Fix & Premium) */
.ns-mobile-menu {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  /* === FIX: Apply !important to height properties === */
  height: 100vh !important; /* Force full viewport height */
  max-height: 100vh !important; /* Ensure max-height doesn't restrict */
  overflow-y: auto !important; /* Ensure internal scrolling */
  /* ================================================== */
  /* === Premium: Refined background & padding === */
  background: linear-gradient(170deg, rgba(31, 31, 31, 0.98) 0%, rgba(40, 40, 42, 0.99) 100%); 
  backdrop-filter: blur(15px); /* Stronger blur */
  padding: calc(var(--space-xxxl, 100px) + var(--space-sm)) var(--space-lg, 40px) var(--space-xl, 64px); /* Generous padding */
  box-shadow: 0 15px 50px rgba(0,0,0,0.3);
  z-index: 1000; 
  visibility: hidden;
  opacity: 0;
  transform: scale(0.97) translateY(10px); /* Start slightly smaller/lower */
   /* === Premium: Smoother transition === */
  transition: opacity 0.45s var(--timing-function-smooth, ease),
              visibility 0s linear 0.45s,
              transform 0.45s var(--timing-function-smooth, ease);
}
/* Styles for when the menu IS open */
.ns-header.is-mobile-menu-open .ns-mobile-menu {
  visibility: visible;
  opacity: 1;
  transform: scale(1) translateY(0);
  transition: opacity 0.45s var(--timing-function-smooth, ease),
              visibility 0s linear 0s,
              transform 0.45s var(--timing-function-smooth, ease);
   /* Re-apply !important height fix */
   height: 100vh !important; 
   max-height: 100vh !important; 
   overflow-y: auto !important; 
}
.ns-mobile-nav-list {
  list-style: none;
  margin: var(--space-lg) 0 var(--space-xl, 64px) 0;
  padding: 0;
  text-align: center;
}
.ns-mobile-nav-item {
  margin-bottom: var(--space-lg, 40px);
  opacity: 0;
  transform: translateY(15px);
  /* === Premium: Use consistent smooth timing === */
  transition: opacity 0.45s var(--timing-function-smooth, ease), 
              transform 0.45s var(--timing-function-smooth, ease); 
}
/* Staggered animation */
.ns-header.is-mobile-menu-open .ns-mobile-nav-item { opacity: 1; transform: translateY(0); }
.ns-header.is-mobile-menu-open .ns-mobile-nav-item:nth-child(1) { transition-delay: 0.18s; }
.ns-header.is-mobile-menu-open .ns-mobile-nav-item:nth-child(2) { transition-delay: 0.23s; }
.ns-header.is-mobile-menu-open .ns-mobile-nav-item:nth-child(3) { transition-delay: 0.28s; }
.ns-header.is-mobile-menu-open .ns-mobile-nav-item:nth-child(4) { transition-delay: 0.33s; } 

.ns-mobile-nav-link {
  font-family: 'Poppins', sans-serif;
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--clr-text-light, #F8F9FA);
  text-decoration: none;
  padding: var(--space-sm, 16px);
  display: inline-block;
  transition: color 0.3s ease, transform 0.3s ease;
}
.ns-mobile-nav-link:hover, .ns-mobile-nav-link:focus-visible { color: var(--clr-accent-primary, #0D6E7A); transform: scale(1.08); }
.ns-mobile-nav-link.is-active { color: var(--clr-accent-primary, #0D6E7A); font-weight: 600; }
.ns-mobile-menu-cta {
    text-align: center;
    margin-top: var(--space-xl, 64px);
    opacity: 0;
    transform: translateY(15px);
     /* === Premium: Use consistent smooth timing === */
    transition: opacity 0.45s var(--timing-function-smooth, ease) 0.4s, 
                transform 0.45s var(--timing-function-smooth, ease) 0.4s; /* Adjusted delay */
}
.ns-header.is-mobile-menu-open .ns-mobile-menu-cta { opacity: 1; transform: translateY(0); }
.ns-mobile-menu-cta .ns-button {
    width: auto;
    display: inline-block;
    padding: var(--space-md, 24px) var(--space-xl, 64px) !important;
    font-size: 1.1rem !important;
    border-radius: var(--radius-lg) !important;
}
/* Ensure mobile CTA button is primary solid */
.ns-mobile-menu-cta .ns-button.ns-button--primary.ns-button--small {
    background-color: var(--clr-accent-primary) !important;
    color: var(--clr-cta-text-light) !important;
    border: none !important; /* No border for solid */
}

/* 8. Responsive Breakpoints */
@media (max-width: 991px) { /* Tablet */
  .ns-header-nav, .ns-header-cta { display: none !important; }
  .ns-mobile-menu-toggle { display: block !important; }
  .ns-header-container { padding: 0 clamp(var(--space-sm, 16px), 4vw, var(--space-lg, 40px)); }
  .ns-header-logo { margin-right: var(--space-lg, 40px); }
}

@media (max-width: 767px) { /* Mobile */
    .ns-header-container { padding: 0 var(--space-md, 24px); }
    .ns-header-logo { margin-right: var(--space-md, 24px); }
    .ns-mobile-menu { padding: calc(var(--space-xxxl) + var(--space-xs)) var(--space-lg, 40px) var(--space-lg, 40px); }
    .ns-mobile-nav-link { font-size: 1.3rem; }
    .ns-mobile-menu-cta .ns-button { padding: var(--space-sm) var(--space-lg) !important; }
}

/* 9. Accessibility */
.ns-mobile-menu-toggle:focus-visible {
    outline: 2px solid var(--clr-accent-tertiary, #FD7E14);
    outline-offset: 2px;
    border-radius: var(--radius-sm, 6px);
}/* End custom CSS */