/* =============================================
   LIFT-365 HOMEPAGE CSS v7
   ============================================= */

/* ---- COLOUR VARIABLES ---- */
:root {
  --teal:        #2EC7C9;
  --teal-dk:     #219B9D;
  --teal-lt:     #6CD8D9;
  --copper:      #C57A43;
  --gold:        #FBCA6F;
  --navy:        #171B26;
  --navy-up:     #1F2536;
  --navy-lt:     #2A3148;
  --dark:        #0D0F18;
  --dark2:       #171B26;
  --dark3:       #1F2536;
  --text:        #B8C4CE;
  --white:       #FFFFFF;
  --radius-card: 16px;
  --font:        'Montserrat', sans-serif;
}

/* =============================================
   GLOBAL
   ============================================= */
body {
  background: var(--navy) !important;
  color: var(--text) !important;
  font-family: var(--font) !important;
}

.page-header,
.entry-title {
  display: none !important;
}

a { color: var(--teal); }
a:hover { color: var(--white); }

/* Force Montserrat everywhere */
h1, h2, h3, h4, h5, h6,
p, span, a, li, div,
.elementor-heading-title,
.elementor-widget-text-editor,
.elementor-widget-text-editor p,
.elementor-button,
.elementor-item,
.elementor-icon-box-title,
.elementor-icon-list-text {
  font-family: var(--font) !important;
}

/* =============================================
   HEADER
   ============================================= */
header.elementor-location-header,
header.elementor-65,
.elementor-location-header {
  position: sticky !important;
  top: 0;
  z-index: 9999;
  background: linear-gradient(155deg, #0D0F18 0%, #171B26 40%, #2A3148 100%) !important;
  border-bottom: 1px solid rgba(46,199,201,0.08) !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.25);
}

/* Override Elementor's container backgrounds at every level */
header.elementor-location-header .elementor-element-21168b9,
header.elementor-location-header .elementor-element-21168b9.e-con,
.elementor-location-header .e-con-boxed,
.elementor-location-header .e-con,
.elementor-location-header .elementor-element-30dca0c,
.elementor-location-header .elementor-element-fef6af1 {
  background: transparent !important;
  background-color: transparent !important;
}

.elementor-location-header .e-con-boxed,
.elementor-location-header .e-con {
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

.elementor-location-header .elementor-widget-image img {
  max-width: 200px !important;
  height: auto !important;
}

.elementor-location-header .elementor-nav-menu a.elementor-item {
  color: rgba(255,255,255,0.85) !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  padding: 6px 14px !important;
  transition: color 0.2s !important;
  text-decoration: none !important;
}

.elementor-location-header .elementor-nav-menu a.elementor-item:hover,
.elementor-location-header .elementor-nav-menu a.elementor-item-active {
  color: var(--teal) !important;
}

.elementor-location-header .elementor-nav-menu > li:last-child > a,
.elementor-location-header .menu-item-73 > a {
  background: var(--teal) !important;
  color: var(--navy) !important;
  border-radius: 999px !important;
  padding: 9px 22px !important;
  font-weight: 700 !important;
  transition: background 0.2s !important;
}

.elementor-location-header .elementor-nav-menu > li:last-child > a:hover,
.elementor-location-header .menu-item-73 > a:hover {
  background: var(--teal-dk) !important;
  color: var(--white) !important;
}

/* ── Desktop: space menu items ── */
@media (min-width: 1025px) {
  #menu-1-c7ef559.elementor-nav-menu {
    gap: 2rem;
  }

  #menu-1-c7ef559.elementor-nav-menu > .menu-item > .elementor-item {
    padding: 0.5rem 0;
  }

  #menu-1-c7ef559 .quote .elementor-item {
    background: var(--teal) !important;
    color: var(--navy) !important;
    padding: 0.5rem 1.2rem !important;
    border-radius: 999px;
    font-weight: 700 !important;
  }
}

/* ── Mobile: logo + toggle on same row ── */
@media (max-width: 1024px) {
  .elementor-element-21168b9 > .e-con-inner {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
  }

  .elementor-element-30dca0c {
    flex: 0 0 auto !important;
    width: auto !important;
  }

  .elementor-element-fef6af1 {
    flex: 0 0 auto !important;
    width: auto !important;
  }

  .elementor-element-c7ef559 .elementor-nav-menu--main {
    display: none !important;
  }

  .elementor-element-c7ef559 .elementor-menu-toggle {
    display: flex !important;
    color: var(--teal) !important;
  }
}

/* ── Mobile: offscreen slide-in menu ── */
@media (max-width: 1024px) {
  .elementor-element-c7ef559 .elementor-nav-menu--dropdown {
    position: fixed !important;
    top: 0 !important;
    right: -100% !important;
    width: 75vw !important;
    max-width: 320px !important;
    height: 100vh !important;
    background: linear-gradient(180deg, #0D0F18, #171B26) !important;
    z-index: 10000 !important;
    box-shadow: -4px 0 20px rgba(0,0,0,0.3) !important;
    transition: right 0.35s ease !important;
    padding: 80px 1.5rem 2rem !important;
    overflow-y: auto !important;
    display: block !important;
    visibility: visible !important;
  }

  .elementor-element-c7ef559 .elementor-nav-menu--dropdown.l365-open {
    right: 0 !important;
  }

  .elementor-element-c7ef559 .elementor-nav-menu--dropdown .elementor-nav-menu {
    flex-direction: column;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .elementor-element-c7ef559 .elementor-nav-menu--dropdown li {
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
  }

  .elementor-element-c7ef559 .elementor-nav-menu--dropdown .elementor-item {
    color: rgba(255,255,255,0.75) !important;
    font-size: 0.95rem !important;
    font-weight: 500 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    padding: 0.9rem 1rem !important;
    border-bottom: 1px solid rgba(255,255,255,0.07) !important;
    border-radius: 0 !important;
    margin: 0 !important;
    display: block !important;
    transition: color 0.2s ease, padding-left 0.2s ease !important;
    background: transparent !important;
  }

  .elementor-element-c7ef559 .elementor-nav-menu--dropdown .elementor-item:hover {
    color: var(--teal) !important;
    padding-left: 1.4rem !important;
    background: transparent !important;
  }

  .elementor-element-c7ef559 .elementor-nav-menu--dropdown .elementor-item-active {
    color: var(--teal) !important;
    border-left: 2px solid var(--teal) !important;
  }

  .elementor-element-c7ef559 .elementor-nav-menu--dropdown .quote {
    margin-top: 1.5rem !important;
    border-bottom: none !important;
  }

  .elementor-element-c7ef559 .elementor-nav-menu--dropdown .quote .elementor-item {
    background: var(--teal) !important;
    color: var(--navy) !important;
    border-radius: 999px !important;
    text-align: center !important;
    border: none !important;
    font-weight: 700 !important;
    padding: 0.9rem 1rem !important;
    letter-spacing: 0.06em !important;
  }

  .elementor-element-c7ef559 .elementor-nav-menu--dropdown .quote .elementor-item:hover {
    color: var(--navy) !important;
    padding-left: 1rem !important;
    background: var(--teal-dk) !important;
  }

  #l365-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    z-index: 9998;
  }

  #l365-overlay.active {
    display: block;
  }
}

/* =============================================
   HERO SECTION
   ============================================= */
#hero {
  position: relative !important;
}

#hero .elementor-container,
#hero .e-con-inner {
  position: relative;
  z-index: 1;
}

/* Hero heading */
#hero .elementor-widget-heading .elementor-heading-title {
  font-size: clamp(30px, 4vw, 52px) !important;
  line-height: 1.2 !important;
  margin-bottom: 20px !important;
  font-weight: 400;
  color: var(--white);
}

#hero .elementor-widget-heading .elementor-heading-title strong {
  font-weight: 400;
  color: var(--copper);
}

#hero .elementor-widget-text-editor {
  color: var(--text) !important;
  font-size: 17px !important;
  line-height: 1.7 !important;
  margin-bottom: 32px !important;
}

#hero .elementor-widget-button {
  display: inline-block !important;
  margin-right: 12px !important;
  margin-bottom: 12px !important;
}

#hero .elementor-widget-button:first-of-type .elementor-button,
#hero .elementor-button {
  background: var(--teal) !important;
  color: var(--navy) !important;
  border-radius: 999px !important;
  padding: 14px 32px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  border: 2px solid var(--teal) !important;
  transition: background 0.2s, transform 0.15s !important;
  text-decoration: none !important;
}

#hero .elementor-widget-button:first-of-type .elementor-button:hover,
#hero .elementor-button:hover {
  background: var(--teal-dk) !important;
  border-color: var(--teal-dk) !important;
  transform: translateY(-2px) !important;
}

#hero .elementor-widget-button + .elementor-widget-button .elementor-button {
  background: transparent !important;
  color: var(--copper) !important;
  border: 2px solid var(--copper) !important;
  border-radius: 999px !important;
  padding: 13px 30px !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  transition: background 0.2s, color 0.2s, transform 0.15s !important;
}

#hero .elementor-widget-button + .elementor-widget-button .elementor-button:hover {
  background: var(--copper) !important;
  color: var(--navy) !important;
  transform: translateY(-2px) !important;
}

#hero .elementor-widget-image img {
  border-radius: var(--radius-card) !important;
  width: 100% !important;
  object-fit: cover !important;
  max-height: 520px !important;
  display: block !important;
}

#hero .elementor-container {
  padding: 80px 40px 60px !important;
  max-width: 1200px !important;
}

#hero .elementor-col-50:first-child .elementor-widget-wrap {
  padding: 0 40px 0 0 !important;
}

/* =============================================
   SERVICE CARDS SECTION
   ============================================= */
#services {

  padding: 42px 0 !important;
}

#services > .elementor-container > .elementor-row > .elementor-col-100 .elementor-heading-title,
#services > .e-con-inner > .elementor-widget-heading .elementor-heading-title {
  color: var(--white) !important;
  text-align: center !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  margin-bottom: 40px !important;
}

#services .elementor-column,
#services .e-con.e-child {
  padding: 0 10px !important;
}

#services .elementor-widget-wrap,
#services .e-con.e-child > .e-con-inner {
  background: var(--navy) !important;
  border-radius: var(--radius-card) !important;
  overflow: hidden !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.35) !important;
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 0 !important;
  gap: 0 !important;
}

#services .elementor-element { padding: 15px; }
#services .elementor-widget:not(:last-child) { --kit-widget-spacing: 0px; }

#services .elementor-widget-wrap:hover,
#services .e-con.e-child:hover > .e-con-inner {
  transform: translateY(-6px) !important;
  box-shadow: 0 20px 48px rgba(0,0,0,0.5) !important;
}

#services .elementor-widget-image {
  flex-shrink: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100% !important;
}

#services .elementor-widget-image .elementor-widget-container {
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
}

#services .elementor-widget-image img {
  width: 100% !important;
  height: 300px !important;
  object-fit: cover !important;
  border-radius: var(--radius-card) var(--radius-card) 0 0 !important;
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}

#services .elementor-widget-heading .elementor-heading-title {
  color: var(--white) !important;
  font-size: 20px !important;
  margin: 0 !important;
  line-height: 1.3 !important;
}

#services .elementor-widget-text-editor {
  color: var(--text) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
}

#services .elementor-widget-button .elementor-button {
  background: transparent !important;
  color: var(--teal) !important;
  padding: 0 !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  border-radius: 0 !important;
  border: none !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  transition: color 0.2s, gap 0.2s !important;
  margin-bottom: 30px;
}

#services .elementor-widget-button .elementor-button::after {
  content: '\2192';
  transition: transform 0.2s;
}

#services .elementor-widget-button .elementor-button:hover {
  color: var(--white) !important;
}

#services .elementor-widget-button .elementor-button:hover::after {
  transform: translateX(4px);
}

#services .elementor-container {
  padding: 72px 24px !important;
  max-width: 1200px !important;
}

@media (max-width: 1024px) {
  #services .elementor-column {
    margin-bottom: 1.25rem !important;
    padding: 0 0.75rem !important;
  }

  #services .elementor-column:last-child {
    margin-bottom: 0 !important;
  }
}

/* =============================================
   WHY CHOOSE US SECTION
   ============================================= */
#why-choose {
  position: relative !important;
}

#why-choose .e-con-inner,
#why-choose .elementor-container {
  position: relative;
  z-index: 1;
}

#why-choose .elementor-widget-heading .elementor-heading-title {
  font-size: clamp(26px, 3vw, 40px) !important;
  font-weight: 400;
  line-height: 1.25 !important;
  color: var(--white);
}

#why-choose .elementor-widget-heading .elementor-heading-title strong {
  font-weight: 400;
  color: var(--teal);
}

/* Icon box cards */
#why-choose .elementor-icon-box-wrapper {
  background: rgba(255,255,255,0.05) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: 14px !important;
  padding: 1.5rem 1rem !important;
  text-align: center !important;
  transition: background 0.3s ease, transform 0.3s ease !important;
  height: 100% !important;
}

#why-choose .elementor-icon-box-wrapper:hover {
  background: rgba(255,255,255,0.09) !important;
  transform: translateY(-4px) !important;
}

#why-choose .elementor-icon svg,
#why-choose .elementor-icon i {
  width: 48px !important;
  height: 48px !important;
  color: var(--teal) !important;
  fill: var(--teal) !important;
}

#why-choose .elementor-icon {
  color: var(--teal) !important;
  font-size: 2.5rem !important;
  margin-bottom: 0.75rem !important;
}

#why-choose .elementor-icon-box-title {
  color: var(--white) !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  margin-top: 0.5rem !important;
  margin-bottom: 0 !important;
}

#why-choose .elementor-widget-heading h5.elementor-heading-title,
#why-choose .elementor-widget-heading h6.elementor-heading-title {
  color: var(--text) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  text-align: center !important;
  margin: 0 !important;
}

#why-choose .elementor-widget-heading h3.elementor-heading-title {
  color: var(--teal) !important;
  font-size: 36px !important;
  line-height: 1 !important;
  margin-bottom: 4px !important;
}

#why-choose .elementor-widget-text-editor p {
  color: var(--white) !important;
  font-size: clamp(18px, 2.2vw, 26px) !important;
  line-height: 1.4 !important;
}

#why-choose .elementor-widget-text-editor strong,
#why-choose .elementor-widget-text-editor b {
  color: var(--teal) !important;
}

#why-choose .elementor-element-6748d23 {
  margin-top: 32px !important;
}

#why-choose .elementor-element-93606c8 {
  margin-top: 8px !important;
}

#why-choose .elementor-widget-button .elementor-button {
  background: var(--teal) !important;
  border-radius: 999px !important;
  padding: 0.75rem 2rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  border: none !important;
  color: var(--navy) !important;
  transition: background 0.2s ease !important;
}

#why-choose .elementor-widget-button .elementor-button:hover {
  background: var(--teal-dk) !important;
}

#why-choose .elementor-widget-image img {
  border-radius: var(--radius-card) !important;
  width: 100% !important;
  object-fit: cover !important;
}

#why-choose > .e-con-inner {
  padding: 80px 40px !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
}

#why-choose .elementor-element-9b22a4d {
  gap: 24px !important;
}

#why-choose .elementor-widget-icon-box {
  padding: 16px 12px !important;
}

/* =============================================
   FOOTER
   ============================================= */
.elementor-location-footer {
  background: var(--dark3) !important;
  border-top: 1px solid rgba(255,255,255,0.06) !important;
}

.elementor-location-footer .e-con-inner {
  padding-top: 52px !important;
  padding-bottom: 40px !important;
  gap: 48px !important;
  align-items: flex-start !important;
}

.elementor-location-footer .elementor-widget-text-editor:first-of-type {
  color: var(--text) !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
  margin-top: 10px !important;
}

.elementor-location-footer .elementor-widget-heading .elementor-heading-title {
  color: var(--white) !important;
  letter-spacing: 0.3px !important;
  text-align: left !important;
}

.elementor-location-footer .elementor-nav-menu--layout-horizontal .elementor-nav-menu {
  flex-direction: column !important;
  gap: 0 !important;
}

.elementor-location-footer .elementor-nav-menu li {
  padding: 0 !important;
  margin: 0 !important;
}

.elementor-location-footer .elementor-nav-menu a,
.elementor-location-footer .elementor-nav-menu a.elementor-item {
  color: var(--text) !important;
  font-size: 14px !important;
  text-decoration: none !important;
  display: block !important;
  padding: 5px 0 !important;
  transition: color 0.2s !important;
  text-align: left !important;
  justify-content: flex-start !important;
}

.elementor-location-footer .elementor-nav-menu a:hover {
  color: var(--teal) !important;
}

.elementor-location-footer .e--pointer-underline .elementor-item::after,
.elementor-location-footer .e--pointer-underline .elementor-item::before {
  display: none !important;
}

.elementor-location-footer .elementor-nav-menu--main {
  justify-content: flex-start !important;
}

.elementor-location-footer .elementor-icon-list-items {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  gap: 0 !important;
}

.elementor-location-footer .elementor-icon-list-item {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  margin-bottom: 10px !important;
}

.elementor-location-footer .elementor-icon-list-icon svg {
  width: 16px !important;
  height: 16px !important;
  fill: var(--teal) !important;
  flex-shrink: 0 !important;
  margin-top: 3px !important;
}

footer,
footer p {
  color: var(--text) !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

.elementor-element-f5ecc26 > .e-con-inner {
  padding: 52px 40px 40px !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  column-gap: 48px !important;
  row-gap: 32px !important;
  grid-template-columns: 1fr 1fr 1fr !important;
}

.elementor-element-7177e43,
.elementor-element-5aa8bb7,
.elementor-element-920a74e {
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

.elementor-element-5c26bec { margin-bottom: 8px !important; }
.elementor-element-a976baa { margin-bottom: 8px !important; }

/* Copyright bar */
#copyright {
  background: #0D0F18 !important;
  border-top: 1px solid rgba(255,255,255,0.05) !important;
  padding: 14px 0 !important;
}

#copyright > .e-con-inner {
  padding: 16px 40px !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
}

#copyright .elementor-widget-text-editor,
#copyright .elementor-widget-text-editor p {
  color: rgba(255,255,255,0.35) !important;
  font-size: 13px !important;
  margin: 0 !important;
  text-align: center !important;
}

#copyright .elementor-widget-text-editor a {
  color: rgba(255,255,255,0.45) !important;
  text-decoration: none !important;
}

#copyright .elementor-widget-text-editor a:hover {
  color: var(--teal) !important;
}

/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 1024px) {
  #hero { padding: 60px 0 !important; }
  #services { padding: 56px 0 !important; }
  #why-choose { padding: 60px 0 !important; }

  #hero .elementor-container {
    padding: 60px 32px 48px !important;
  }

  #hero .elementor-col-50:first-child .elementor-widget-wrap {
    padding: 0 !important;
  }

  #why-choose > .e-con-inner {
    padding: 60px 32px !important;
  }

  .elementor-element-f5ecc26 > .e-con-inner {
    padding: 40px 32px 32px !important;
  }
}

@media (max-width: 767px) {
  #hero { padding: 44px 0 !important; }

  #hero .elementor-container {
    padding: 40px 20px 32px !important;
  }

  #hero .elementor-widget-heading .elementor-heading-title {
    font-size: 28px !important;
  }

  #hero .elementor-widget-text-editor {
    font-size: 15px !important;
  }

  #services { padding: 44px 0 !important; }

  #services .elementor-container {
    padding: 40px 20px !important;
  }

  #services .elementor-widget-image img {
    height: 180px !important;
  }

  #why-choose { padding: 44px 0 !important; }

  #why-choose > .e-con-inner {
    padding: 40px 20px !important;
  }

  .elementor-location-footer .e-con-inner {
    padding-top: 36px !important;
    padding-bottom: 28px !important;
    gap: 32px !important;
  }

  .elementor-element-f5ecc26 > .e-con-inner {
    padding: 32px 20px 24px !important;
    column-gap: 24px !important;
  }

  #copyright > .e-con-inner {
    padding: 14px 20px !important;
  }
}

/* =============================================
   OVERLAY FIXES
   ============================================= */
#why-choose .elementor-background-overlay {
  z-index: 0 !important;
}

#why-choose .e-con-inner {
  position: relative !important;
  z-index: 10 !important;
}

#why-choose > .e-con-inner > * {
  position: relative;
  z-index: 10;
}

/* ── Fix Hero image column visibility ── */
#hero .elementor-element-65625230 > .elementor-widget-wrap {
  min-height: 400px !important;
}

/* ── Hero image column: fade edges into dark bg ── */
#hero .elementor-element-65625230 > .elementor-widget-wrap {
  -webkit-mask-image: linear-gradient(
    to right, transparent 0%, black 25%
  );
  mask-image: linear-gradient(
    to right, transparent 0%, black 25%
  );
}

/* ── Hero: stop image bleeding over text ── 
#hero .elementor-element-7ea42b8e > .elementor-widget-wrap {
  position: relative;
  z-index: 2;
  background: var(--navy) !important;
}*/