:root {
  --brand-navy: #001043;
  --brand-gold: #ffe79c;
  --brand-ink: #0a1330;
  --brand-ink-2: #0f1a3f;
  --text-dark: #0a1330;
  --text-muted: #6b7280;
  --surface-white: #ffffff;
  --surface-ivory: #fffdfa;
  --surface-warm: #f9f7f2;
}

/* Typography */
@font-face {
  font-family: "Heimat Display";
  src: local("Heimat Display");
  font-display: swap;
}
@font-face {
  font-family: "Gautreaux";
  src: local("Gautreaux");
  font-display: swap;
}

html, body {
  color: var(--text-dark);
  background-color: var(--surface-white);
  font-family: "DM Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

h1, h2, h3, h4, .hs-title-1, .section-title {
  font-family: "Heimat Display", "Gautreaux", "DM Sans", ui-sans-serif, system-ui, sans-serif;
  color: var(--text-dark);
  /* letter-spacing: -0.01em; */
}

/* Links & accents */
a { color: var(--brand-ink); }
a:hover { color: var(--brand-navy); }

/* Buttons */
.btn, .btn-mod {
  background-color: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
  color: var(--brand-ink) !important;
  border-radius: 999px;
  letter-spacing: 0.04em;
}
.btn:hover, .btn-mod:hover {
  background-color: var(--brand-navy) !important;
  border-color: var(--brand-navy) !important;
  color: #ffffff !important;
}

/* Navigation */
.main-nav .inner-nav > ul > li > a {
  color: var(--text-dark) !important;
  font-weight: 500;
}
.main-nav .inner-nav > ul > li > a:hover,
.main-nav .inner-nav > ul > li > a.active {
  color: var(--brand-navy) !important;
}

/* Transparent nav over dark hero */
body.has-dark-hero .main-nav.transparent .inner-nav > ul > li > a { color: #ffffff !important; }
body.has-dark-hero .main-nav.transparent .inner-nav > ul > li > a:hover,
body.has-dark-hero .main-nav.transparent .inner-nav > ul > li > a.active { color: var(--brand-gold) !important; }

.main-nav.stick-fixed:not(.transparent) {
  background: rgba(255,255,255,0.9) !important;
  backdrop-filter: saturate(180%) blur(8px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}

/* Hero */
.home-section.elegant-gradient-bg {
  background: radial-gradient(1200px 600px at 75% 20%, rgba(255,231,156,0.25), transparent 60%),
              linear-gradient(160deg, var(--brand-ink) 0%, var(--brand-ink-2) 55%, #000814 100%) !important;
  position: relative;
}
.home-section.elegant-gradient-bg:before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.2), rgba(0,0,0,0) 30%, rgba(0,0,0,0.25));
}
.home-section.elegant-gradient-bg .hs-title-1,
.home-section.elegant-gradient-bg .section-descr,
.home-section.elegant-gradient-bg .hero-decoration,
.home-section.elegant-gradient-bg .hero-decoration-bottom {
  color: #ffffff !important;
}
.home-section.elegant-gradient-bg .section-descr { opacity: 0.9; }
.home-section.elegant-gradient-bg .btn-border-w {
  background: transparent !important;
  color: #ffffff !important;
  border-color: #ffffff !important;
}
.home-section.elegant-gradient-bg .btn-border-w:hover {
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
  color: var(--brand-ink) !important;
}

/* Reusable dark luxe hero for internal pages */
.luxe-hero {
  background: radial-gradient(1200px 600px at 75% 20%, rgba(255,231,156,0.25), transparent 60%),
              linear-gradient(160deg, var(--brand-ink) 0%, var(--brand-ink-2) 55%, #000814 100%) !important;
  position: relative;
}
.luxe-hero:before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.2), rgba(0,0,0,0) 30%, rgba(0,0,0,0.25));
}
.luxe-hero .hs-title-1,
.luxe-hero .section-title,
.luxe-hero .section-descr,
.luxe-hero .hero-decoration,
.luxe-hero .hero-decoration-bottom { color: #ffffff !important; }
.luxe-hero .section-descr { opacity: 0.9; }
.luxe-hero .btn-border-w { background: transparent !important; color: #ffffff !important; border-color: #ffffff !important; }
.luxe-hero .btn-border-w:hover { background: var(--brand-gold) !important; border-color: var(--brand-gold) !important; color: var(--brand-ink) !important; }

/* Sections on light backgrounds should use dark text */
.page-section,
.bg-gray-light-1,
.bg-light-alpha-90,
.bg-light-alpha-50 {
  background-color: var(--surface-white);
  color: var(--text-dark);
}
.page-section .text-gray { color: var(--text-muted) !important; }

/* About section custom background */
#about {
  position: relative;
 
}
#about:before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

#about .section-title {
  font-family: "Playfair Display", "Heimat Display", "Gautreaux", serif;
  font-weight: 600;
}

/* About page enhancements */
#about {
  position: relative;
  background: var(--surface-warm);
  overflow: hidden;
}
#about > .container { position: relative; z-index: 1; }
#about:before {
  content: "";
  position: absolute;
  top: -180px; left: -140px;
  width: 680px; height: 680px;
  background: radial-gradient( circle at 30% 30%, rgba(255, 231, 156, 0.28), transparent 62% );
  pointer-events: none;
  z-index: 0;
}
#about:after {
  content: "";
  position: absolute;
  bottom: -220px; right: -200px;
  width: 820px; height: 820px;
  background: radial-gradient( circle at 60% 60%, rgba(0, 16, 67, 0.05), transparent 65% );
  pointer-events: none;
  z-index: 0;
}

.shadow-soft {
  box-shadow: 0 18px 50px rgba(0, 16, 67, 0.08), 0 6px 18px rgba(0, 16, 67, 0.06);
}

.luxe-kicker {
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brand-navy);
  opacity: 0.9;
}

.luxe-media-card .luxe-photo,
.services-image {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(0, 16, 67, 0.10), 0 4px 10px rgba(0, 16, 67, 0.06);
}

.luxe-quote {
  font-style: italic;
  color: var(--text-muted);
  border-left: 3px solid rgba(255, 231, 156, 0.8);
  padding-left: 16px;
}

.luxe-icon-wrapper {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--surface-warm), var(--surface-white));
  border: 1px solid rgba(10, 19, 48, 0.10);
  color: var(--brand-navy);
}

.luxe-stats { row-gap: 24px; }
.luxe-stat-number {
  font-family: "Playfair Display", "Heimat Display", serif;
  font-weight: 600;
  font-size: clamp(28px, 5vw, 44px);
  color: var(--brand-navy);
  line-height: 1.1;
}
.luxe-stat-label { color: var(--text-muted); }

/* Cards / panels */
.elegant-card, .services-content, .bg-border-gradient:before {
  background: var(--surface-ivory);
  border-radius: 18px;
}

/* Dividers */
.elegant-divider {
  height: 1px; margin: 36px 0;
  background: linear-gradient(90deg, transparent, var(--brand-gold), transparent);
}

/* Forms */
.form-control, input, textarea {
  border-radius: 14px !important;
  border-color: rgba(10,19,48,0.15) !important;
}
.form-control:focus, input:focus, textarea:focus {
  border-color: var(--brand-navy) !important;
  box-shadow: 0 0 0 4px rgba(0,16,67,0.08) !important;
}

/* Social icons */
.social-icon { border-color: rgba(10,19,48,0.25) !important; }
.social-icon:hover { background: var(--brand-gold) !important; border-color: var(--brand-gold) !important; color: var(--brand-ink) !important; }

/* Logo sizing */
.nav-logo-wrap .logo img { max-height: 64px; width: auto !important; }

/* Utilities */
.text-brand { color: var(--brand-navy) !important; }
.bg-brand { background-color: var(--brand-navy) !important; color: #fff !important; }
.accent { color: var(--brand-gold) !important; }

/* Ensure contrast on white backgrounds */
body .bg-white, body .bg-white * { color: var(--text-dark); }

/* Headings rhythm */
.hs-title-1 {
  font-family: "Playfair Display", "Heimat Display", "Gautreaux", serif;
  font-weight: 500;
}
.hs-title-1 span { white-space: normal !important; }

@media (max-width: 767.98px) {
  .nav-logo-wrap .logo img { max-height: 56px; }
}

/* Luxe submenu (mega) */
.main-nav .mn-sub.mn-has-multi {
  background: var(--surface-white) !important;
  border: 1px solid rgba(0,16,67,0.08) !important;
  border-radius: 16px !important;
  padding: 14px 12px !important;
  box-shadow: 0 20px 50px rgba(0,16,67,0.10), 0 6px 18px rgba(0,16,67,0.06) !important;
  min-width: 260px;
  z-index: 1000;
  position: absolute;
}
.main-nav .mn-sub.mn-has-multi:before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, var(--brand-gold), transparent);
  border-top-left-radius: 16px; border-top-right-radius: 16px;
}
.main-nav .mn-sub.mn-has-multi ul > li > a {
  display: block;
  padding: 10px 14px !important;
  color: var(--text-dark) !important;
  border-radius: 10px;
  transition: background-color .2s ease, color .2s ease, transform .2s ease;
}
.main-nav .mn-sub.mn-has-multi ul > li > a:hover,
.main-nav .mn-sub.mn-has-multi ul > li > a:focus {
  background: var(--surface-warm) !important;
  color: var(--brand-navy) !important;
}
.main-nav .mn-sub.mn-has-multi ul > li + li { margin-top: 2px; }

/* Caret & parent link styling */
.main-nav .mn-has-sub { position: relative; }
.main-nav .mn-has-sub:hover > a,
.main-nav .mn-has-sub > a:focus { color: var(--brand-navy) !important; }

/* Mobile submenu fallback */
@media (max-width: 991.98px) {
  .main-nav .mn-sub.mn-has-multi {
    position: static;
    box-shadow: none !important;
    border-radius: 12px !important;
    margin-top: 6px;
  }
}



/* Mobile navigation readability overrides */
/* Hamburger icon visible over dark transparent hero */
body.has-dark-hero .main-nav.transparent .mobile-nav-icon,
body.has-dark-hero .main-nav.transparent .mobile-nav-icon:before,
body.has-dark-hero .main-nav.transparent .mobile-nav-icon:after {
  background: #ffffff !important;
}
/* Force dark icon color when the mobile modal is open over a light panel */
body.has-dark-hero .main-nav.transparent.mobile-on .mobile-nav-icon,
body.has-dark-hero .main-nav.transparent.mobile-on .mobile-nav-icon:before,
body.has-dark-hero .main-nav.transparent.mobile-on .mobile-nav-icon:after {
  background: var(--text-dark) !important;
}

/* Force dark link color for mobile menu regardless of transparent/dark states */
.main-nav.mobile-on .inner-nav > ul > li > a {
  color: var(--text-dark) !important;
  -webkit-text-fill-color: var(--text-dark) !important;
  opacity: 1 !important;
}
body.has-dark-hero .main-nav.mobile-on.transparent .inner-nav > ul > li > a {
  color: var(--text-dark) !important;
  -webkit-text-fill-color: var(--text-dark) !important;
}

/* Mobile menu panel: switch to light surface with dark text for readability */
.mobile-on .desktop-nav ul { background: var(--surface-white) !important; }
.mobile-on .desktop-nav ul li a {
  color: var(--text-dark) !important;
  border-bottom: 1px solid rgba(10,19,48, 0.08) !important;
}
.mobile-on .desktop-nav ul li a:hover,
.mobile-on .desktop-nav ul li a.active {
  background: var(--surface-warm) !important;
  color: var(--brand-navy) !important;
}

/* Mobile submenu chevrons and states */
.mobile-on .mn-has-sub > .mi-chevron-down,
.mobile-on .mn-has-sub > .mi-chevron-right {
  border-color: rgba(10,19,48, 0.2) !important;
}
.mobile-on .js-opened > .mn-has-sub > .mi-chevron-down,
.mobile-on .js-opened > .mn-has-sub > .mi-chevron-right {
  border-color: rgba(10,19,48, 0.5) !important;
}

/* Full-viewport modal mobile menu */
.main-nav.mobile-on { z-index: 3000 !important; }
.mobile-on .desktop-nav {
  /* legacy modal removed when Bootstrap offcanvas is present */
  display: none !important;
}
.mobile-on .desktop-nav ul { background: transparent !important; }
.mobile-on .desktop-nav ul li a {
  pointer-events: auto !important;
}

/* Keep hamburger/close button accessible over modal */
.mobile-on .mobile-nav {
  position: fixed !important;
  top: 16px;
  right: 16px;
  height: 44px;
  width: 44px !important;
  padding: 0 !important;
  margin: 0 !important;
  justify-content: center;
  align-items: center;
  z-index: 2101 !important;
}
.mobile-on .mobile-nav-icon,
.mobile-on .mobile-nav-icon:before,
.mobile-on .mobile-nav-icon:after {
  height: 3px !important;
  background: var(--text-dark) !important;
}
.main-nav .mobile-nav.active .mobile-nav-icon { background: transparent !important; }
.main-nav .mobile-nav.active .mobile-nav-icon:before,
.main-nav .mobile-nav.active .mobile-nav-icon:after { background: var(--text-dark) !important; }

/* Ensure the close (X) icon is clearly visible over the light modal */
.mobile-on .mobile-nav-icon,
.mobile-on .mobile-nav-icon:before,
.mobile-on .mobile-nav-icon:after {
  background: var(--text-dark) !important;
}
/* When active, hide the middle bar so the icon forms a clear X */
.mobile-on .mobile-nav.active .mobile-nav-icon { background: transparent !important; }
.mobile-on .mobile-nav.active .mobile-nav-icon:before,
.mobile-on .mobile-nav.active .mobile-nav-icon:after { background: var(--text-dark) !important; }
/* Explicitly force the chevron bars to rotate into an X */
.mobile-on .mobile-nav.active .mobile-nav-icon:before {
  top: 0 !important;
  transform: rotate(45deg) !important;
}
.mobile-on .mobile-nav.active .mobile-nav-icon:after {
  top: 0 !important;
  transform: rotate(-45deg) !important;
}

/* Big elegant type for primary links on mobile */
.mobile-on .desktop-nav > ul.clearlist > li > a {
  font-family: "Playfair Display", "Heimat Display", "Gautreaux", serif !important;
  font-weight: 500 !important;
  font-size: clamp(28px, 7vw, 44px) !important;
  line-height: 1.15 !important;
  letter-spacing: -0.01em !important;
  padding: 12px 0 !important;
}

/* Social/footer row pinned to bottom */
.mobile-on .desktop-nav > ul.items-end {
  position: absolute !important;
  left: 24px;
  right: 24px;
  bottom: 24px;
  display: flex !important;
  justify-content: flex-start;
  gap: 8px;
}
.mobile-on .desktop-nav > ul.items-end li { margin: 0 6px 0 0 !important; }
.mobile-on .desktop-nav > ul.items-end li:last-child { margin-right: 0 !important; }

/* Modal backdrop for mobile menu */
.mobile-menu-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(10, 19, 48, 0.45);
  backdrop-filter: saturate(180%) blur(4px);
  z-index: 900;
  display: none;
}

/* Prevent background scroll when modal open */
body.mobile-modal-open { overflow: hidden !important; }

/* Bootstrap offcanvas mobile menu (full-width + luxe styles) */
.offcanvas.show + .main-nav .mobile-nav { display: none !important; }
.offcanvas.show ~ .main-nav .mobile-nav { display: none !important; }
.offcanvas.show ~ .mobile-nav { display: none !important; }
.mobile-menu-offcanvas {
  --bs-offcanvas-width: 100vw !important;
  width: 100vw !important;
  max-width: 100vw !important;
  background: var(--surface-white) !important;
  color: var(--text-dark) !important;
}
.mobile-menu-offcanvas .offcanvas-header {
  padding: 16px 18px;
}
.mobile-menu-offcanvas .btn-close {
  filter: invert(11%) sepia(26%) saturate(3278%) hue-rotate(206deg) brightness(94%) contrast(111%);
}
.mobile-menu-offcanvas .offcanvas-body {
  padding: 24px;
  display: flex;
  flex-direction: column;
}
.mobile-menu-offcanvas a { text-decoration: none !important; }
.mobile-menu-offcanvas .offcanvas-body > ul.clearlist:not(.items-end) > li { 
  border-bottom: 1px solid rgba(10,19,48, 0.08) !important;
}
.mobile-menu-offcanvas .offcanvas-body > ul.clearlist:not(.items-end) > li:last-child { border-bottom: none !important; }
.mobile-menu-offcanvas .offcanvas-body > ul.clearlist:not(.items-end) > li.dropdown { border-bottom: none !important; }
.mobile-menu-offcanvas #m-sub-pricing.collapse {
  border-top: 1px solid rgba(10,19,48, 0.06);
  margin-top: 10px;
  padding-top: 6px;
}
.mobile-menu-offcanvas .offcanvas-body > ul.clearlist:not(.items-end) > li > a {
  font-family: "Playfair Display", "Heimat Display", "Gautreaux", serif !important;
  font-weight: 500 !important;
  font-size: clamp(28px, 7vw, 44px) !important;
  line-height: 1.15 !important;
  letter-spacing: -0.01em !important;
  padding: 14px 0 !important;
  color: var(--text-dark) !important;
  display: block;
}
.mobile-menu-offcanvas .offcanvas-body > ul.clearlist:not(.items-end) > li > a:hover,
.mobile-menu-offcanvas .offcanvas-body > ul.clearlist:not(.items-end) > li > a.active {
  background: transparent !important;
  color: var(--brand-navy) !important;
}
.mobile-menu-offcanvas .collapse { margin-left: 0; }
.mobile-menu-offcanvas .collapse li { margin: 0; }
.mobile-menu-offcanvas .collapse li > a {
  display: block;
  padding: 10px 0 !important;
  color: var(--text-dark) !important;
  border-radius: 10px;
}
.mobile-menu-offcanvas .collapse li > a:hover {
  background: transparent !important;
  color: var(--brand-navy) !important;
}
.mobile-menu-offcanvas .items-end { 
  margin-top: auto; 
  display: flex !important; 
  gap: 8px; 
}
.mobile-menu-offcanvas .items-end li { margin: 0 6px 0 0 !important; }
.mobile-menu-offcanvas .items-end li:last-child { margin-right: 0 !important; }