.elementor-kit-9{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-kit-9 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}
/* Start custom CSS *//* =========================================================
   ZENITH FINANCIAL ADVISORY — GLOBAL CSS
   Brand:
   Primary: #064E3B
   Secondary: #10B981
   Accent: #FBBF24
   Background: #ECFDF5
   Text: #022C22
========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;9..144,700;9..144,800&family=Inter:wght@400;500;600;700;800&display=swap');

:root {
  --zfa-primary: #064E3B;
  --zfa-primary-dark: #022C22;
  --zfa-secondary: #10B981;
  --zfa-secondary-soft: rgba(16, 185, 129, 0.14);
  --zfa-accent: #FBBF24;
  --zfa-bg: #ECFDF5;
  --zfa-bg-soft: #F7FFFB;
  --zfa-white: #FFFFFF;
  --zfa-text: #022C22;
  --zfa-muted: #5A746B;
  --zfa-border: rgba(6, 78, 59, 0.14);
  --zfa-border-strong: rgba(6, 78, 59, 0.22);
  --zfa-shadow-soft: 0 20px 60px rgba(2, 44, 34, 0.10);
  --zfa-shadow-strong: 0 28px 90px rgba(2, 44, 34, 0.18);
  --zfa-radius-sm: 14px;
  --zfa-radius-md: 22px;
  --zfa-radius-lg: 34px;
  --zfa-radius-xl: 44px;
  --zfa-header-height: 92px;
  --zfa-container: min(1180px, calc(100% - 40px));
  --zfa-font-heading: 'Fraunces', Georgia, serif;
  --zfa-font-body: 'Inter', Arial, sans-serif;
}

/* ===============================
   GLOBAL RESET / BASE
=============================== */

html {
  scroll-behavior: smooth;
  scroll-padding-top: 110px;
}

body {
  margin: 0;
  background: var(--zfa-bg);
  color: var(--zfa-text);
  font-family: var(--zfa-font-body);
  font-size: clamp(0.96rem, 0.92rem + 0.2vw, 1.05rem);
  line-height: 1.75;
  overflow-x: hidden;
}

body.zfa-menu-open {
  overflow: hidden;
}

*, 
*::before, 
*::after {
  box-sizing: border-box;
}

img,
svg {
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration: none;
}

p {
  font-family: var(--zfa-font-body);
  font-size: clamp(0.98rem, 0.94rem + 0.22vw, 1.08rem);
  line-height: 1.8;
  color: var(--zfa-muted);
}

span,
li,
a,
button,
input,
textarea,
select {
  font-family: var(--zfa-font-body);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--zfa-font-heading);
  color: var(--zfa-primary-dark);
  line-height: 1.05;
  letter-spacing: -0.045em;
  margin-top: 0;
}

h1 {
  font-size: clamp(2.65rem, 5.4vw, 5.7rem);
}

h2 {
  font-size: clamp(2.1rem, 4vw, 4rem);
}

h3 {
  font-size: clamp(1.45rem, 2.2vw, 2.2rem);
}

h4 {
  font-size: clamp(1.12rem, 1.45vw, 1.4rem);
}

h5 {
  font-size: clamp(1rem, 1.15vw, 1.18rem);
}

h6 {
  font-size: clamp(0.9rem, 1vw, 1rem);
}

::selection {
  background: var(--zfa-accent);
  color: var(--zfa-primary-dark);
}

/* ===============================
   ACCESSIBILITY
=============================== */

:focus-visible {
  outline: 3px solid rgba(251, 191, 36, 0.85);
  outline-offset: 4px;
}

.zfa-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  white-space: nowrap;
  clip-path: inset(50%);
}

/* ===============================
   COMMON UTILITIES
=============================== */

.zfa-container {
  width: var(--zfa-container);
  margin-inline: auto;
}

.zfa-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  padding: 8px 13px;
  border: 1px solid rgba(16, 185, 129, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--zfa-primary);
  font-size: clamp(0.72rem, 0.66rem + 0.18vw, 0.82rem);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 0 12px 34px rgba(2, 44, 34, 0.06);
  backdrop-filter: blur(18px);
}

.zfa-kicker::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--zfa-secondary), var(--zfa-accent));
  box-shadow: 0 0 0 5px rgba(16, 185, 129, 0.10);
}

.zfa-btn,
.zfa-btn-primary,
.zfa-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 14px 22px;
  border-radius: 999px;
  font-size: clamp(0.9rem, 0.85rem + 0.14vw, 0.98rem);
  font-weight: 800;
  line-height: 1;
  transition: transform 0.28s ease, box-shadow 0.28s ease, background 0.28s ease, color 0.28s ease, border-color 0.28s ease;
}

.zfa-btn-primary {
  color: var(--zfa-primary-dark);
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.8), transparent 28%),
    linear-gradient(135deg, var(--zfa-accent), #FDE68A);
  box-shadow: 0 18px 44px rgba(251, 191, 36, 0.28);
}

.zfa-btn-secondary {
  color: var(--zfa-primary);
  border: 1px solid rgba(6, 78, 59, 0.18);
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(16px);
}

.zfa-btn:hover,
.zfa-btn-primary:hover,
.zfa-btn-secondary:hover {
  transform: translateY(-3px);
  box-shadow: var(--zfa-shadow-soft);
}

/* ===============================
   REVEAL ANIMATION
=============================== */

.zfa-reveal,
.zfa-reveal-left,
.zfa-reveal-right,
.zfa-reveal-up {
  opacity: 0;
  transition: opacity 0.8s ease, transform 0.8s ease;
  will-change: opacity, transform;
}

.zfa-reveal,
.zfa-reveal-up {
  transform: translateY(28px);
}

.zfa-reveal-left {
  transform: translateX(-32px);
}

.zfa-reveal-right {
  transform: translateX(32px);
}

.zfa-visible {
  opacity: 1;
  transform: translate(0, 0);
}

/* =========================================================
   HEADER
========================================================= */

.zfa-header {
  position: sticky;
  top: 0;
  z-index: 9999;
  width: 100%;
  padding: 14px 0;
  transition: padding 0.32s ease, background 0.32s ease, box-shadow 0.32s ease, border-color 0.32s ease;
}

.zfa-header::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(236, 253, 245, 0.92), rgba(255, 255, 255, 0.82)),
    radial-gradient(circle at top left, rgba(16, 185, 129, 0.14), transparent 34%),
    radial-gradient(circle at top right, rgba(251, 191, 36, 0.10), transparent 30%);
  border-bottom: 1px solid rgba(6, 78, 59, 0.10);
  backdrop-filter: blur(22px);
  opacity: 0;
  transition: opacity 0.32s ease;
}

.zfa-header.zfa-header-scrolled {
  padding: 9px 0;
}

.zfa-header.zfa-header-scrolled::before,
.zfa-header.zfa-mobile-active::before {
  opacity: 1;
}

.zfa-header-shell {
  position: relative;
  width: var(--zfa-container);
  margin-inline: auto;
  min-height: 66px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  padding: 10px 12px 10px 18px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 999px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.78), rgba(236, 253, 245, 0.64)),
    radial-gradient(circle at top left, rgba(16, 185, 129, 0.12), transparent 38%);
  box-shadow: 0 16px 50px rgba(2, 44, 34, 0.08);
  backdrop-filter: blur(24px);
}

.zfa-header-shell::after {
  content: "";
  position: absolute;
  inset: auto 32px -1px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(251, 191, 36, 0.9), transparent);
  opacity: 0.8;
  pointer-events: none;
}

.zfa-header-logo-wrap {
  display: flex;
  align-items: center;
  min-width: 170px;
}

.zfa-logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  line-height: 1;
}

.zfa-logo img,
.zfa-logo .custom-logo {
  width: auto;
  max-width: 184px;
  max-height: 48px;
  object-fit: contain;
  display: block;
}

.zfa-logo-text {
  color: var(--zfa-primary-dark);
}

.zfa-logo-mark {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  color: var(--zfa-primary-dark);
  background: linear-gradient(135deg, var(--zfa-accent), #FDE68A);
  font-family: var(--zfa-font-heading);
  font-size: 1.45rem;
  font-weight: 800;
  box-shadow: 0 14px 30px rgba(251, 191, 36, 0.24);
}

.zfa-logo-copy {
  display: grid;
  gap: 3px;
}

.zfa-logo-copy strong {
  font-family: var(--zfa-font-heading);
  font-size: 1.18rem;
  letter-spacing: -0.04em;
  color: var(--zfa-primary-dark);
}

.zfa-logo-copy small {
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--zfa-primary);
}

/* ===============================
   DESKTOP MENU
=============================== */

.zfa-desktop-nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex: 1;
}

.zfa-menu,
.zfa-menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.zfa-menu {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 3px;
}

.zfa-menu > li {
  position: relative;
}

.zfa-menu > li > a {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 10px 13px;
  border-radius: 999px;
  color: rgba(2, 44, 34, 0.82);
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  transition: color 0.24s ease, background 0.24s ease, transform 0.24s ease;
}

.zfa-menu > li > a:hover,
.zfa-menu > li.current-menu-item > a,
.zfa-menu > li.current-menu-ancestor > a {
  color: var(--zfa-primary-dark);
  background: rgba(16, 185, 129, 0.10);
}

/* Contact as Button */
.zfa-menu > li:last-child > a {
  margin-left: 5px;
  padding-inline: 20px;
  color: var(--zfa-primary-dark);
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.8), transparent 28%),
    linear-gradient(135deg, var(--zfa-accent), #FDE68A);
  box-shadow: 0 14px 34px rgba(251, 191, 36, 0.26);
}

.zfa-menu > li:last-child > a:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 44px rgba(251, 191, 36, 0.34);
}

/* Dropdown */
.zfa-menu li ul {
  position: absolute;
  top: calc(100% + 14px);
  left: 0;
  min-width: 245px;
  padding: 10px;
  border: 1px solid rgba(6, 78, 59, 0.12);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(236, 253, 245, 0.94)),
    radial-gradient(circle at top left, rgba(16, 185, 129, 0.12), transparent 42%);
  box-shadow: 0 24px 70px rgba(2, 44, 34, 0.14);
  backdrop-filter: blur(22px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(10px);
  transition: opacity 0.24s ease, visibility 0.24s ease, transform 0.24s ease;
}

.zfa-menu li:hover > ul,
.zfa-menu li:focus-within > ul {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.zfa-menu li ul::before {
  content: "";
  position: absolute;
  top: -14px;
  left: 0;
  right: 0;
  height: 14px;
}

.zfa-menu li ul li {
  position: relative;
}

.zfa-menu li ul a {
  display: flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 12px;
  border-radius: 14px;
  color: rgba(2, 44, 34, 0.78);
  font-size: 0.88rem;
  font-weight: 750;
  transition: background 0.24s ease, color 0.24s ease, transform 0.24s ease;
}

.zfa-menu li ul a:hover,
.zfa-menu li ul li.current-menu-item > a {
  color: var(--zfa-primary-dark);
  background: rgba(16, 185, 129, 0.12);
  transform: translateX(3px);
}

/* ===============================
   MOBILE TOGGLE
=============================== */

.zfa-mobile-toggle {
  display: none;
  position: relative;
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 999px;
  background: var(--zfa-primary);
  cursor: pointer;
  box-shadow: 0 16px 34px rgba(2, 44, 34, 0.18);
}

.zfa-mobile-toggle span {
  position: absolute;
  left: 14px;
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: var(--zfa-white);
  transition: top 0.25s ease, transform 0.25s ease, opacity 0.25s ease;
}

.zfa-mobile-toggle span:nth-child(1) {
  top: 16px;
}

.zfa-mobile-toggle span:nth-child(2) {
  top: 23px;
}

.zfa-mobile-toggle span:nth-child(3) {
  top: 30px;
}

.zfa-mobile-active .zfa-mobile-toggle span:nth-child(1) {
  top: 23px;
  transform: rotate(45deg);
}

.zfa-mobile-active .zfa-mobile-toggle span:nth-child(2) {
  opacity: 0;
}

.zfa-mobile-active .zfa-mobile-toggle span:nth-child(3) {
  top: 23px;
  transform: rotate(-45deg);
}

/* ===============================
   MOBILE PANEL
=============================== */

.zfa-mobile-panel {
  position: fixed;
  inset: 0;
  z-index: -1;
  padding: 104px 20px 24px;
  background:
    radial-gradient(circle at top left, rgba(16, 185, 129, 0.18), transparent 34%),
    radial-gradient(circle at bottom right, rgba(251, 191, 36, 0.18), transparent 34%),
    linear-gradient(135deg, rgba(236, 253, 245, 0.98), rgba(255, 255, 255, 0.98));
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.28s ease, visibility 0.28s ease;
}

.zfa-mobile-active .zfa-mobile-panel {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.zfa-mobile-panel-inner {
  width: min(560px, 100%);
  max-height: calc(100vh - 130px);
  overflow-y: auto;
  margin-inline: auto;
  padding: 18px;
  border: 1px solid rgba(6, 78, 59, 0.14);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: var(--zfa-shadow-strong);
  backdrop-filter: blur(24px);
}

.zfa-mobile-menu,
.zfa-mobile-menu ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.zfa-mobile-menu {
  display: grid;
  gap: 6px;
}

.zfa-mobile-menu a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 50px;
  padding: 13px 14px;
  border-radius: 16px;
  color: var(--zfa-primary-dark);
  font-size: 1rem;
  font-weight: 850;
  background: rgba(236, 253, 245, 0.62);
  border: 1px solid rgba(6, 78, 59, 0.07);
}

.zfa-mobile-menu a:hover,
.zfa-mobile-menu .current-menu-item > a {
  background: rgba(16, 185, 129, 0.13);
}

.zfa-mobile-menu ul {
  margin: 6px 0 8px 14px;
  display: grid;
  gap: 5px;
}

.zfa-mobile-menu ul a {
  min-height: 44px;
  font-size: 0.92rem;
  font-weight: 750;
  color: rgba(2, 44, 34, 0.78);
  background: rgba(255, 255, 255, 0.76);
}

.zfa-mobile-menu > li:last-child > a {
  justify-content: center;
  color: var(--zfa-primary-dark);
  background: linear-gradient(135deg, var(--zfa-accent), #FDE68A);
  box-shadow: 0 14px 34px rgba(251, 191, 36, 0.24);
}

/* =========================================================
   FOOTER
========================================================= */

.zfa-footer {
  position: relative;
  overflow: hidden;
  padding: clamp(4.5rem, 8vw, 7rem) 0 0;
  color: rgba(255, 255, 255, 0.74);
  background:
    radial-gradient(circle at top left, rgba(16, 185, 129, 0.22), transparent 32%),
    radial-gradient(circle at bottom right, rgba(251, 191, 36, 0.16), transparent 34%),
    linear-gradient(135deg, #022C22 0%, #064E3B 58%, #022C22 100%);
}

.zfa-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,0.8), transparent 82%);
  pointer-events: none;
}

.zfa-footer::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 0%, rgba(251, 191, 36, 0.10), transparent 28%),
    linear-gradient(180deg, transparent, rgba(2, 44, 34, 0.52));
  pointer-events: none;
}

.zfa-footer-bg-orb {
  position: absolute;
  width: 340px;
  height: 340px;
  border-radius: 999px;
  filter: blur(70px);
  opacity: 0.32;
  pointer-events: none;
}

.zfa-footer-bg-orb-1 {
  top: -90px;
  left: -80px;
  background: var(--zfa-secondary);
}

.zfa-footer-bg-orb-2 {
  right: -100px;
  bottom: 40px;
  background: var(--zfa-accent);
}

.zfa-footer-shell {
  position: relative;
  z-index: 2;
  width: var(--zfa-container);
  margin-inline: auto;
}

.zfa-footer-brand {
  display: grid;
  gap: 24px;
  max-width: 720px;
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}

.zfa-footer .zfa-logo img,
.zfa-footer .zfa-logo .custom-logo {
  max-width: 200px;
  max-height: 58px;
  filter: brightness(0) invert(1);
}

.zfa-footer .zfa-logo-copy strong,
.zfa-footer .zfa-logo-copy small {
  color: var(--zfa-white);
}

.zfa-footer-brand p {
  max-width: 680px;
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  font-size: clamp(1rem, 0.95rem + 0.24vw, 1.13rem);
}

.zfa-footer-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.zfa-footer-socials a {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  color: var(--zfa-white);
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.14);
  transition: transform 0.26s ease, background 0.26s ease, color 0.26s ease;
}

.zfa-footer-socials a:hover {
  transform: translateY(-3px);
  color: var(--zfa-primary-dark);
  background: var(--zfa-accent);
}

.zfa-footer-socials span {
  font-size: 0.83rem;
  font-weight: 900;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}

.zfa-footer-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1.18fr;
  gap: clamp(1.5rem, 3vw, 2.4rem);
  padding: clamp(2rem, 4vw, 3rem);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--zfa-radius-lg);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.045)),
    radial-gradient(circle at top left, rgba(16, 185, 129, 0.12), transparent 42%);
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.20);
  backdrop-filter: blur(20px);
}

.zfa-footer-col h3 {
  margin: 0 0 18px;
  color: var(--zfa-white);
  font-family: var(--zfa-font-body);
  font-size: 0.86rem;
  font-weight: 900;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.zfa-footer-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 9px;
}

.zfa-footer-col a {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.95rem;
  font-weight: 650;
  transition: color 0.24s ease, transform 0.24s ease;
}

.zfa-footer-col a:hover {
  color: var(--zfa-accent);
}

.zfa-footer-col:not(.zfa-footer-contact) a:hover {
  transform: translateX(4px);
}

.zfa-footer-contact li {
  display: grid;
  gap: 3px;
}

.zfa-footer-contact span {
  color: rgba(255, 255, 255, 0.46);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.11em;
  text-transform: uppercase;
}

.zfa-footer-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 48px;
  margin-top: 20px;
  padding: 13px 18px;
  border-radius: 999px;
  color: var(--zfa-primary-dark) !important;
  background: linear-gradient(135deg, var(--zfa-accent), #FDE68A);
  box-shadow: 0 16px 38px rgba(251, 191, 36, 0.22);
  font-weight: 900 !important;
}

.zfa-footer-cta:hover {
  transform: translateY(-3px) !important;
}

.zfa-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 26px 0;
  margin-top: 30px;
  border-top: 1px solid rgba(255, 255, 255, 0.10);
}

.zfa-footer-bottom p {
  margin: 0;
  color: rgba(255, 255, 255, 0.58);
  font-size: 0.88rem;
}

.zfa-footer-bottom a {
  color: var(--zfa-accent);
  font-weight: 800;
}

/* =========================================================
   ZENITH FINANCIAL ADVISORY — HEADER FIX OVERRIDES
   Fixes oversized logo + stretched pill header
========================================================= */

/* Header should stay compact */
.zfa-header {
  padding: 14px 0 !important;
}

.zfa-header-shell {
  min-height: 78px !important;
  max-height: 86px !important;
  padding: 12px 18px !important;
  display: flex !important;
  align-items: center !important;
  gap: 34px !important;
  overflow: visible !important;
}

/* Logo area must not dominate the header */
.zfa-header-logo-wrap {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: unset !important;
  max-width: 230px !important;
  display: flex !important;
  align-items: center !important;
}

/* Control Elementor/custom-logo link */
.zfa-header .zfa-logo,
.zfa-header .custom-logo-link {
  display: inline-flex !important;
  align-items: center !important;
  width: auto !important;
  max-width: 220px !important;
  height: 54px !important;
  overflow: hidden !important;
}

/* Force the actual logo image to behave */
.zfa-header .zfa-logo img,
.zfa-header .custom-logo-link img,
.zfa-header img.custom-logo {
  display: block !important;
  width: auto !important;
  max-width: 220px !important;
  height: 54px !important;
  max-height: 54px !important;
  object-fit: contain !important;
  object-position: left center !important;
}

/* Desktop nav should remain aligned */
.zfa-desktop-nav {
  flex: 1 1 auto !important;
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center !important;
  min-width: 0 !important;
}

.zfa-menu {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 4px !important;
  flex-wrap: nowrap !important;
}

/* Prevent nav labels from breaking badly */
.zfa-menu > li > a {
  white-space: nowrap !important;
  min-height: 44px !important;
  padding: 10px 12px !important;
  font-size: clamp(0.82rem, 0.72rem + 0.22vw, 0.94rem) !important;
}

/* Make Contact button balanced */
.zfa-menu > li:last-child > a {
  padding-inline: 20px !important;
  min-width: 112px !important;
}

/* Better dropdown positioning */
.zfa-menu li ul {
  top: calc(100% + 12px) !important;
}

/* Tablet/mobile switch earlier if needed */
@media (max-width: 1180px) {
  .zfa-desktop-nav {
    display: none !important;
  }

  .zfa-mobile-toggle {
    display: inline-flex !important;
  }

  .zfa-header-shell {
    max-height: 82px !important;
  }

  .zfa-header .zfa-logo,
  .zfa-header .custom-logo-link {
    max-width: 190px !important;
    height: 50px !important;
  }

  .zfa-header .zfa-logo img,
  .zfa-header .custom-logo-link img,
  .zfa-header img.custom-logo {
    max-width: 190px !important;
    height: 50px !important;
    max-height: 50px !important;
  }
}

@media (max-width: 767px) {
  .zfa-header-shell {
    min-height: 68px !important;
    max-height: 76px !important;
    padding: 10px 12px !important;
    border-radius: 24px !important;
  }

  .zfa-header .zfa-logo,
  .zfa-header .custom-logo-link {
    max-width: 155px !important;
    height: 44px !important;
  }

  .zfa-header .zfa-logo img,
  .zfa-header .custom-logo-link img,
  .zfa-header img.custom-logo {
    max-width: 155px !important;
    height: 44px !important;
    max-height: 44px !important;
  }
}

/* =========================================================
   ZENITH FINANCIAL ADVISORY — PREMIUM ANIMATED HEADER BG
   Improves logo visibility + adds subtle animated gradient
========================================================= */

/* Animated gradient header shell */
.zfa-header-shell {
  position: relative !important;
  overflow: hidden !important;
  isolation: isolate !important;
  background:
    linear-gradient(
      120deg,
      rgba(2, 44, 34, 0.92) 0%,
      rgba(6, 78, 59, 0.88) 18%,
      rgba(236, 253, 245, 0.92) 46%,
      rgba(255, 255, 255, 0.92) 70%,
      rgba(236, 253, 245, 0.94) 100%
    ) !important;
  background-size: 220% 220% !important;
  animation: zfaHeaderGradientFlow 12s ease-in-out infinite !important;
  border: 1px solid rgba(255, 255, 255, 0.78) !important;
  box-shadow:
    0 18px 60px rgba(2, 44, 34, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.62) !important;
}

/* Soft animated sheen */
.zfa-header-shell::before {
  content: "" !important;
  position: absolute !important;
  inset: -2px !important;
  z-index: -1 !important;
  background:
    radial-gradient(circle at 12% 50%, rgba(16, 185, 129, 0.36), transparent 24%),
    radial-gradient(circle at 88% 50%, rgba(251, 191, 36, 0.22), transparent 22%),
    linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.22) 45%, transparent 68%) !important;
  background-size: 180% 180% !important;
  animation: zfaHeaderSheen 8s ease-in-out infinite !important;
  pointer-events: none !important;
}

/* Keep gold divider visible above the animation */
.zfa-header-shell::after {
  z-index: 2 !important;
}

/* Logo visibility panel */
.zfa-header-logo-wrap {
  position: relative !important;
  z-index: 3 !important;
  align-self: stretch !important;
  display: flex !important;
  align-items: center !important;
  padding: 8px 18px 8px 14px !important;
  margin: -6px 0 -6px -8px !important;
  border-radius: 999px !important;
  background:
    radial-gradient(circle at 25% 25%, rgba(251, 191, 36, 0.20), transparent 32%),
    linear-gradient(135deg, rgba(2, 44, 34, 0.92), rgba(6, 78, 59, 0.86)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 14px 34px rgba(2, 44, 34, 0.16) !important;
}

/* Brighten the current light logo so text reads better on dark green */
.zfa-header .zfa-logo img,
.zfa-header .custom-logo-link img,
.zfa-header img.custom-logo {
  filter:
    brightness(1.18)
    contrast(1.18)
    saturate(1.1)
    drop-shadow(0 2px 7px rgba(255, 255, 255, 0.26))
    drop-shadow(0 8px 18px rgba(2, 44, 34, 0.32)) !important;
}

/* Make nav sit above animated layers */
.zfa-desktop-nav,
.zfa-mobile-toggle {
  position: relative !important;
  z-index: 4 !important;
}

/* Improve menu readability on the lighter side */
.zfa-menu > li > a {
  color: rgba(2, 44, 34, 0.92) !important;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.25) !important;
}

.zfa-menu > li > a:hover,
.zfa-menu > li.current-menu-item > a,
.zfa-menu > li.current-menu-ancestor > a {
  background: rgba(6, 78, 59, 0.10) !important;
  color: #022C22 !important;
}

/* Contact button remains premium */
.zfa-menu > li:last-child > a {
  color: #022C22 !important;
  text-shadow: none !important;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, 0.78), transparent 30%),
    linear-gradient(135deg, #FBBF24, #FDE68A) !important;
  box-shadow:
    0 14px 30px rgba(251, 191, 36, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.42) !important;
}

/* Animation keyframes */
@keyframes zfaHeaderGradientFlow {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 85% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

@keyframes zfaHeaderSheen {
  0% {
    background-position: 0% 50%;
    opacity: 0.55;
  }
  50% {
    background-position: 100% 50%;
    opacity: 0.85;
  }
  100% {
    background-position: 0% 50%;
    opacity: 0.55;
  }
}

/* Scrolled state: slightly richer and more compact */
.zfa-header.zfa-header-scrolled .zfa-header-shell {
  background:
    linear-gradient(
      120deg,
      rgba(2, 44, 34, 0.96) 0%,
      rgba(6, 78, 59, 0.92) 18%,
      rgba(236, 253, 245, 0.96) 48%,
      rgba(255, 255, 255, 0.96) 100%
    ) !important;
  box-shadow:
    0 16px 54px rgba(2, 44, 34, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.58) !important;
}

/* Mobile: keep it cleaner and readable */
@media (max-width: 1180px) {
  .zfa-header-shell {
    background:
      linear-gradient(
        120deg,
        rgba(2, 44, 34, 0.94) 0%,
        rgba(6, 78, 59, 0.9) 34%,
        rgba(236, 253, 245, 0.94) 100%
      ) !important;
  }

  .zfa-header-logo-wrap {
    padding: 7px 14px 7px 12px !important;
    margin-left: -6px !important;
  }
}

@media (max-width: 767px) {
  .zfa-header-logo-wrap {
    max-width: 180px !important;
    padding: 6px 12px 6px 10px !important;
  }

  .zfa-header .zfa-logo,
  .zfa-header .custom-logo-link {
    max-width: 142px !important;
  }

  .zfa-header .zfa-logo img,
  .zfa-header .custom-logo-link img,
  .zfa-header img.custom-logo {
    max-width: 142px !important;
  }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .zfa-header-shell,
  .zfa-header-shell::before {
    animation: none !important;
  }
}

/* =========================================================
   ZENITH FINANCIAL ADVISORY — FOOTER REFINEMENT OVERRIDES
   Fixes oversized footer logo + improves premium footer layout
========================================================= */

/* Main footer spacing refinement */
.zfa-footer {
  padding: clamp(4rem, 7vw, 6rem) 0 0 !important;
}

/* Keep footer content centered and premium */
.zfa-footer-shell {
  width: min(1180px, calc(100% - 40px)) !important;
}

/* Brand block should not feel oversized */
.zfa-footer-brand {
  max-width: 760px !important;
  margin-bottom: clamp(2.25rem, 4vw, 3.4rem) !important;
  gap: 20px !important;
}

/* Footer logo wrapper */
.zfa-footer .zfa-logo,
.zfa-footer .custom-logo-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: fit-content !important;
  max-width: 260px !important;
  height: 92px !important;
  overflow: hidden !important;
  padding: 14px 18px !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 25% 18%, rgba(251, 191, 36, 0.16), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.035)) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    0 18px 44px rgba(0,0,0,0.14) !important;
}

/* Actual footer logo image */
.zfa-footer .zfa-logo img,
.zfa-footer .custom-logo-link img,
.zfa-footer img.custom-logo {
  display: block !important;
  width: auto !important;
  max-width: 220px !important;
  height: 64px !important;
  max-height: 64px !important;
  object-fit: contain !important;
  object-position: left center !important;
  filter:
    brightness(1.2)
    contrast(1.16)
    saturate(1.08)
    drop-shadow(0 2px 5px rgba(255,255,255,0.18))
    drop-shadow(0 10px 20px rgba(0,0,0,0.24)) !important;
}

/* Brand description readability */
.zfa-footer-brand p {
  max-width: 690px !important;
  color: rgba(255, 255, 255, 0.78) !important;
  font-size: clamp(0.96rem, 0.9rem + 0.22vw, 1.06rem) !important;
  line-height: 1.8 !important;
}

/* Social icons refinement */
.zfa-footer-socials {
  gap: 9px !important;
}

.zfa-footer-socials a {
  width: 40px !important;
  height: 40px !important;
  background: rgba(255,255,255,0.09) !important;
  border-color: rgba(255,255,255,0.14) !important;
}

/* Footer grid card refinement */
.zfa-footer-grid {
  grid-template-columns: 1fr 1fr 1fr 1.25fr !important;
  gap: clamp(1.4rem, 2.6vw, 2.2rem) !important;
  padding: clamp(2rem, 3.8vw, 2.8rem) !important;
  border-radius: 30px !important;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.105), rgba(255,255,255,0.045)),
    radial-gradient(circle at top left, rgba(16,185,129,0.14), transparent 42%) !important;
  border: 1px solid rgba(255,255,255,0.13) !important;
}

/* Footer column headings */
.zfa-footer-col h3 {
  margin-bottom: 17px !important;
  color: #ffffff !important;
  font-size: 0.76rem !important;
  letter-spacing: 0.16em !important;
}

/* Footer links */
.zfa-footer-col ul {
  gap: 10px !important;
}

.zfa-footer-col a {
  color: rgba(255,255,255,0.72) !important;
  font-size: 0.91rem !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
}

.zfa-footer-col a:hover {
  color: #FBBF24 !important;
}

/* Contact info */
.zfa-footer-contact span {
  color: rgba(255,255,255,0.48) !important;
  font-size: 0.69rem !important;
  letter-spacing: 0.13em !important;
}

.zfa-footer-contact li {
  gap: 4px !important;
  margin-bottom: 4px !important;
}

/* CTA button */
.zfa-footer-cta {
  margin-top: 18px !important;
  min-height: 46px !important;
  padding: 13px 18px !important;
  font-size: 0.9rem !important;
}

/* Bottom bar */
.zfa-footer-bottom {
  margin-top: 28px !important;
  padding: 24px 0 !important;
}

.zfa-footer-bottom p {
  font-size: 0.82rem !important;
  line-height: 1.5 !important;
}

/* =========================================================
   FOOTER RESPONSIVE FIXES
========================================================= */

@media (max-width: 1024px) {
  .zfa-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .zfa-footer .zfa-logo,
  .zfa-footer .custom-logo-link {
    max-width: 240px !important;
    height: 86px !important;
  }

  .zfa-footer .zfa-logo img,
  .zfa-footer .custom-logo-link img,
  .zfa-footer img.custom-logo {
    max-width: 205px !important;
    height: 60px !important;
    max-height: 60px !important;
  }
}

@media (max-width: 767px) {
  .zfa-footer {
    padding-top: 3.5rem !important;
  }

  .zfa-footer-shell {
    width: min(100% - 24px, 1180px) !important;
  }

  .zfa-footer-brand {
    align-items: flex-start !important;
    margin-bottom: 2rem !important;
  }

  .zfa-footer .zfa-logo,
  .zfa-footer .custom-logo-link {
    max-width: 220px !important;
    height: 78px !important;
    padding: 12px 14px !important;
    border-radius: 20px !important;
  }

  .zfa-footer .zfa-logo img,
  .zfa-footer .custom-logo-link img,
  .zfa-footer img.custom-logo {
    max-width: 190px !important;
    height: 54px !important;
    max-height: 54px !important;
  }

  .zfa-footer-brand p {
    font-size: 0.95rem !important;
  }

  .zfa-footer-grid {
    grid-template-columns: 1fr !important;
    padding: 1.4rem !important;
    border-radius: 24px !important;
  }

  .zfa-footer-bottom {
    align-items: flex-start !important;
    gap: 8px !important;
  }
}

@media (max-width: 420px) {
  .zfa-footer .zfa-logo,
  .zfa-footer .custom-logo-link {
    max-width: 200px !important;
    height: 72px !important;
  }

  .zfa-footer .zfa-logo img,
  .zfa-footer .custom-logo-link img,
  .zfa-footer img.custom-logo {
    max-width: 172px !important;
    height: 50px !important;
    max-height: 50px !important;
  }
}

/* =========================================================
   ZENITH FINANCIAL ADVISORY — OVERLAY HEADER + 50VH STICKY
   Elementor Pro Theme Builder compatible
========================================================= */

/* Remove Elementor header from normal document flow */
body:not(.elementor-editor-active) .elementor-location-header {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  z-index: 99999 !important;
  pointer-events: none !important;
}

/* Allow header itself to remain clickable */
body:not(.elementor-editor-active) .elementor-location-header .zfa-header {
  pointer-events: auto !important;
}

/* Header starts as an overlay, not layout-blocking */
body:not(.elementor-editor-active) .zfa-header {
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  width: 100% !important;
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
  transition:
    opacity 0.42s ease,
    transform 0.42s ease,
    padding 0.32s ease,
    background 0.32s ease,
    box-shadow 0.32s ease !important;
}

/* Let homepage/sections slide behind the header */
body:not(.elementor-editor-active) .zfa-home-hero {
  margin-top: 0 !important;
  padding-top: clamp(8.5rem, 12vw, 10.5rem) !important;
}

/* Smooth sticky activation after 50vh */
body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
  animation: zfaHeaderDropIn 0.46s cubic-bezier(0.22, 1, 0.36, 1) both !important;
}

/* Hidden transition state before fixed header appears */
body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-ready:not(.zfa-header-fixed-active) {
  opacity: 0 !important;
  transform: translateY(-120%) scale(0.985) !important;
}

/* Premium fixed state styling */
body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .zfa-header-shell {
  max-width: min(1180px, calc(100% - 40px)) !important;
  min-height: 72px !important;
  max-height: 78px !important;
  margin-top: 12px !important;
  box-shadow:
    0 22px 70px rgba(2, 44, 34, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.62) !important;
}

/* Make fixed header slightly more compact */
body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .zfa-header-logo-wrap {
  padding-top: 6px !important;
  padding-bottom: 6px !important;
}

body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .zfa-logo,
body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .custom-logo-link {
  height: 48px !important;
  max-width: 190px !important;
}

body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .zfa-logo img,
body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .custom-logo-link img,
body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active img.custom-logo {
  height: 48px !important;
  max-height: 48px !important;
  max-width: 190px !important;
}

/* Admin bar compatibility */
body.admin-bar:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active {
  top: 32px !important;
}

@media (max-width: 782px) {
  body.admin-bar:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active {
    top: 46px !important;
  }
}

/* Smooth drop-in animation */
@keyframes zfaHeaderDropIn {
  0% {
    opacity: 0;
    transform: translateY(-120%) scale(0.985);
  }

  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Mobile/tablet spacing */
@media (max-width: 1180px) {
  body:not(.elementor-editor-active) .zfa-home-hero {
    padding-top: clamp(7.5rem, 14vw, 9.5rem) !important;
  }

  body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .zfa-header-shell {
    margin-top: 10px !important;
    max-width: min(100% - 32px, 1180px) !important;
  }
}

@media (max-width: 767px) {
  body:not(.elementor-editor-active) .zfa-home-hero {
    padding-top: clamp(7rem, 18vw, 8.5rem) !important;
  }

  body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .zfa-header-shell {
    max-width: min(100% - 24px, 1180px) !important;
    min-height: 66px !important;
    max-height: 74px !important;
    margin-top: 8px !important;
  }

  body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .zfa-logo,
  body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .custom-logo-link {
    height: 44px !important;
    max-width: 150px !important;
  }

  body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .zfa-logo img,
  body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active .custom-logo-link img,
  body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active img.custom-logo {
    height: 44px !important;
    max-height: 44px !important;
    max-width: 150px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  body:not(.elementor-editor-active) .zfa-header.zfa-header-fixed-active {
    animation: none !important;
  }
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width: 1120px) {
  :root {
    --zfa-container: min(100% - 32px, 1180px);
  }

  .zfa-desktop-nav {
    display: none;
  }

  .zfa-mobile-toggle {
    display: inline-flex;
  }

  .zfa-header-shell {
    min-height: 64px;
    padding: 9px 10px 9px 16px;
  }

  .zfa-logo img,
  .zfa-logo .custom-logo {
    max-width: 170px;
    max-height: 46px;
  }

  .zfa-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  :root {
    --zfa-container: min(100% - 24px, 1180px);
  }

  html {
    scroll-padding-top: 96px;
  }

  .zfa-header {
    padding: 10px 0;
  }

  .zfa-header-shell {
    border-radius: 26px;
  }

  .zfa-logo img,
  .zfa-logo .custom-logo {
    max-width: 145px;
    max-height: 42px;
  }

  .zfa-logo-copy {
    display: none;
  }

  .zfa-mobile-panel {
    padding: 92px 12px 18px;
  }

  .zfa-mobile-panel-inner {
    border-radius: 24px;
    padding: 14px;
  }

  .zfa-footer {
    padding-top: 4rem;
  }

  .zfa-footer-brand {
    margin-bottom: 2rem;
  }

  .zfa-footer-grid {
    grid-template-columns: 1fr;
    padding: 1.4rem;
    border-radius: 26px;
  }

  .zfa-footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 420px) {
  .zfa-header-shell {
    padding-left: 12px;
  }

  .zfa-mobile-toggle {
    width: 44px;
    height: 44px;
  }

  .zfa-mobile-toggle span {
    left: 12px;
  }
}

/* =========================================================
   REDUCED MOTION
========================================================= */

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
}/* End custom CSS */