/* 05-header-nav.css — header, logo, nav bar, CTA buttons, and mobile nav */

/* ==========================================================================
   Mobile Phone Button & Hamburger
   ========================================================================== */

.mobile-phone-button {
	color: var(--sd-blue-gray) !important;
	background: var(--sd-light-blue) !important;
	border-color: var(--sd-light-blue) !important;
	box-shadow: inset var(--sd-light-blue) 0 0 0 1px;
	padding: 8px 16px;
	font-weight: 500;
	border-radius: 24px;
	margin-left: 4px;
}

.mmb-container .mobile-menu-button {
    padding: 0 16px 0 18px !important;
}
@media (max-width: 959px) {
    #logo-container-mobile #main-logo a > * {
        height: 55px !important;
    }
    .navbar .menu-container .logo-container {
        position: relative;
        padding: 27px 16px 27px 16px !important;
    }	
}

/* ==========================================================================
   Header — Main
   ========================================================================== */

.menu-container {
	box-shadow: rgba(0, 0, 0, .15) 0 0 5px;
}

.logo-container { 
	padding-top: 22px;
	padding-bottom: 22px;
}

/* Sunrise nav buttons live INSIDE .menu-primary-inner as <li class="btn-phone">
   and <li class="btn-appt"> menu items — the legacy .menu-cta-inner selectors
   from the Goodman/True codebase don't match this DOM. Rules below are
   re-targeted accordingly. */

.menu-primary-inner > li.btn-phone > a,
.menu-primary-inner > li.btn-appt > a {
	border-radius: 24px;
	overflow: hidden;
	padding: 0 20px !important;
	height: 48px;
	min-height: 48px;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	font-family: var(--sd-font-body, "Mona Sans"), system-ui, sans-serif !important;
	font-size: 18px !important;
	font-weight: 600 !important;
	line-height: 26px !important;
	letter-spacing: 0 !important;
	text-decoration: none !important;
	transition: background-color 0.2s, border-color 0.2s, color 0.2s;
}

/* Phone button — outline blue-gray (Sunrise spec) */
.menu-primary-inner > li.btn-phone > a {
	background-color: transparent !important;
	color: var(--sd-blue-gray) !important;
	border: 1px solid var(--sd-blue-gray) !important;
	box-shadow: none !important;
}

/* Outline Dark Hover — border/text flip from blue-gray (#114671) to
   Primary Blue (#216CA2) per Figma "Size=Med, Style=Secondary, Color=Dark,
   State=Hover, Type=Outline". Background stays transparent — do NOT fill. */
.menu-primary-inner > li.btn-phone > a:hover,
.menu-primary-inner > li.btn-phone > a:focus {
	background-color: transparent !important;
	background-image: none !important;
	border-color: var(--sd-blue) !important;
	color: var(--sd-blue) !important;
	box-shadow: none !important;
}

/* Outline Dark Pressed — Primary Blue border/text + 20% white overlay
   per Figma + 04-buttons-forms.css canonical Outline Dark active. */
.menu-primary-inner > li.btn-phone > a:active {
	background-color: transparent !important;
	background-image: linear-gradient(rgba(255, 255, 255, 0.20), rgba(255, 255, 255, 0.20)) !important;
	border-color: var(--sd-blue) !important;
	color: var(--sd-blue) !important;
	box-shadow: none !important;
}

/* Book Appointment button — filled blue-gray (Sunrise spec) */
.menu-primary-inner > li.btn-appt > a {
	background-color: var(--sd-blue-gray) !important;
	border: 1px solid var(--sd-blue-gray) !important;
	color: var(--sd-white) !important;
	box-shadow: none !important;
}

.menu-primary-inner > li.btn-appt > a:hover,
.menu-primary-inner > li.btn-appt > a:focus {
	background-color: #0d3559 !important;
	border-color: #0d3559 !important;
	color: var(--sd-white) !important;
	box-shadow: none !important;
}

.menu-primary-inner > li.btn-appt > a:active {
	background-color: #082640 !important;
	border-color: #082640 !important;
	color: var(--sd-white) !important;
	box-shadow: none !important;
}

/* Hide chevron carets on top-level nav button items (desktop + mobile) */
.menu-primary-inner > li.btn-phone > a > i.fa-dropdown,
.menu-primary-inner > li.btn-appt > a > i.fa-dropdown {
	display: none !important;
}

/* Mobile book-appointment header icon (small circular icon next to menu toggle) */
.mobile-book-btn {
	background-color: var(--sd-blue-gray) !important;
	border-color: var(--sd-blue-gray) !important;
	color: var(--sd-white) !important;
	padding: 8px 16px;
	font-weight: 500;
	border-radius: 24px;
}

.mobile-book-icon.mobile-book-btn {
	color: var(--sd-blue-gray) !important;
	background: var(--sd-light-blue) !important;
	border-color: var(--sd-light-blue) !important;
	box-shadow: none !important;
}

/* ==========================================================================
   Desktop Nav (≥960px)
   ========================================================================== */

@media (min-width: 960px) {
body.hmenu .menu-container .navbar-nav:not(.uncode-close-offcanvas-mobile) {
	vertical-align: middle;
}

.navbar .limit-width {
	max-width: 1240px;
}

.row-menu-inner {
	padding-left: 0 !important;
	padding-right: 0 !important;
	box-sizing: border-box;
	max-width: 100%;
}

.navbar .menu-container {
	min-height: 120px;
}

.logo-container {
	padding-right: 20px !important;
}

.navbar #main-logo a > * {
	height: 74px !important;
	width: auto !important;
}

.menu-smart {
	height: auto;
	padding: 0!important;
}

.menu-primary-inner > li {
	vertical-align: middle !important;
}

/* Regular text nav items only — exclude the .btn-phone / .btn-appt buttons */
.menu-primary-inner > li.menu-item-link:not(.btn-phone):not(.btn-appt) > a {
	color: var(--sd-blue-gray) !important;
	font-family: var(--sd-font-body, "Mona Sans"), system-ui, sans-serif;
	font-size: 18px !important;
	font-weight: 600;
	line-height: 26px;
	padding: 10px 18px !important;
	white-space: nowrap;
	transition: color 0.2s;
}

.menu-primary-inner > li.menu-item-link:not(.btn-phone):not(.btn-appt) > a:hover,
.menu-primary-inner > li.menu-item-link:not(.btn-phone):not(.btn-appt) > a:focus {
	color: var(--sd-orange) !important;
}

/* Hide chevron carets on top-level nav links at desktop */
.menu-primary-inner > li.menu-item-link:not(.btn-phone):not(.btn-appt) > a > i.fa-dropdown {
	display: none !important;
}

/* Dropdown submenu panels — outlined card look */
.menu-primary-inner > li > ul {
	border: 1px solid #ccc !important;
	border-radius: 18px;
}

.hmenu .menu-smart, 
.hmenu-center .menu-smart, 
.navbar-cta ul.menu-smart {
    height: auto;
}

/* Active-state orange — exclude .btn-phone / .btn-appt so the CTA pills
   keep their own button colors when their target page is current. */
.menu-primary-inner > li.current-menu-item:not(.btn-phone):not(.btn-appt) > a,
.menu-primary-inner > li.current-menu-ancestor:not(.btn-phone):not(.btn-appt) > a,
.menu-primary-inner > li.current-menu-parent:not(.btn-phone):not(.btn-appt) > a {
	color: var(--sd-orange) !important;
}

.menu-primary-inner > li.weglot-parent-menu-item {
	vertical-align: middle !important;
}

.menu-primary-inner > li.weglot-parent-menu-item > a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	line-height: 22px;
}

.menu-cta-inner {
	margin: 0 -4px!important;
}

.menu-cta-inner > li {
	margin: 0 4px!important;
}

.menu-cta-inner > li > a {
	min-height: 40px;
	padding: 0 16px !important;
	display: inline-flex;
	align-items: center;
	font-size: 14px !important;
}

body.hormenu-position-left:not(.hmenu-center-split):not(.hmenu-center-double):not(.menu-overlay):not(.rtl) .navbar-cta.navbar-nav-last > ul > li:last-child > a {
	padding-right: 16px!important;
}

/* Override Uncode core's inline <style> rule that strips padding-right on the
   last menu item. That rule has specificity (0,5,4); we match it here and win
   on source order so the .btn-appt pill keeps symmetric 20px padding. */
body[class*="hmenu-"]:not(.hormenu-position-right) .navbar-nav-last > ul.menu-primary-inner > li.btn-phone > a,
body[class*="hmenu-"]:not(.hormenu-position-right) .navbar-nav-last > ul.menu-primary-inner > li.btn-appt > a {
	padding-right: 20px !important;
	padding-left: 20px !important;
}
}

@media (min-width: 960px) and (max-width: 1099px) {
#main-logo a > * {
    height: 40px !important;
}

.menu-primary-inner > li.menu-item-link:not(.btn-phone):not(.btn-appt) > a {
	font-size: 14px !important;
	padding: 8px 8px !important;
}

.menu-primary-inner > li.btn-phone > a,
.menu-primary-inner > li.btn-appt > a {
	padding: 0 14px !important;
	font-size: 14px !important;
	height: 40px;
	min-height: 40px;
}
}

@media (min-width: 1100px) and (max-width: 1249px) {
#main-logo a > * {
    height: 48px !important;
}

.menu-primary-inner > li.menu-item-link:not(.btn-phone):not(.btn-appt) > a {
	font-size: 16px !important;
	padding: 10px 12px !important;
}

.menu-primary-inner > li.btn-phone > a,
.menu-primary-inner > li.btn-appt > a {
	padding: 0 16px !important;
	font-size: 16px !important;
	height: 44px;
	min-height: 44px;
}
}

/* ==========================================================================
   Mobile Nav Drawer (≤959px)
   ========================================================================== */

@media (max-width: 959px) {
body.menu-mobile-default .main-menu-container .menu-sidebar-inner, 
body.menu-mobile-default .main-menu-container .menu-horizontal-inner {
	padding: 4px 0 16px;
}

.menu-smart {
	padding: 0!important;
	margin: 0!important;
}

.menu-smart > li {
	margin: 0!important;
	border-bottom: 1px solid #f0f2f5;
}

.menu-smart > li > a {
	padding: 14px 24px!important;
	display: flex!important;
	justify-content: space-between!important;
	align-items: center!important;
}

.menu-smart > li > a i.fa-dropdown {
	display: block!important;
}

/* Hide carets on submenu items */
.menu-smart > li > ul li a i.fa-dropdown {
	display: none!important;
}

/* Weglot: flag next to text, not pushed apart */
.menu-smart > li.weglot-parent-menu-item > a {
	justify-content: flex-start!important;
	gap: 8px;
}

/* Mobile drawer — .btn-phone / .btn-appt are inline in .menu-primary-inner.
   Give them spacing + button styling to look like proper CTAs instead of
   regular menu rows. */
.menu-primary-inner > li.btn-phone,
.menu-primary-inner > li.btn-appt {
	margin: 8px 24px !important;
	padding: 0 !important;
	border-bottom: none !important;
}

.menu-primary-inner > li.btn-phone > a,
.menu-primary-inner > li.btn-appt > a {
	padding: 0 16px !important;
	justify-content: center !important;
	text-decoration: none !important;
	min-height: 44px;
	height: 44px;
}

/* Hide carets on CTA buttons (also handled at desktop above; mobile menu
   re-shows .fa-dropdown by default so we re-hide here) */
.menu-primary-inner > li.btn-phone > a i.fa-dropdown,
.menu-primary-inner > li.btn-appt > a i.fa-dropdown {
	display: none !important;
}
}

/* Additional mobile header tightening */
@media (max-width: 959px) {
	/* Reduce logo block height and vertical header padding */
	.logo-container {
		padding-top: 20px;
		padding-bottom: 20px;
	}
	/* Constrain raster/SVG logo height */
	#main-logo a > * {
		height: 32px !important;
	}
	/* Slightly smaller mobile CTA pill buttons */
	.menu-primary-inner > li.btn-phone > a,
	.menu-primary-inner > li.btn-appt > a {
		border-radius: 24px;
	}
	/* Compact dedicated mobile buttons if present */
	.mobile-book-btn,
	.mobile-book-icon.mobile-book-btn {
		padding: 6px 10px;
	}

}

/* ==========================================================================
   Mobile Book Appointment (from aqua.css §8)
   ========================================================================== */

/* Hide mobile book appointment button by default */
.book-appt.mobile {
  display: none;
}

/* Show mobile book appointment button only on mobile (below 959px) */
@media (max-width: 959px) {
  .book-appt.mobile {
    display: block;
  }
}

/* Add scroll offset for sticky nav - no visual spacing added */
#book-appointment {
  scroll-margin-top: 64px;
}

/* ==========================================================================
   Menu & Navigation (from aqua.css §9)
   ========================================================================== */

.static-map {
    margin-top: 0px !important;
}

.location-map-image img {
    border-radius: 24px;
}

.menu-section-css,
.menu-locations-menu-container {
    padding-left: 0px !important;
}

#menu-locations-menu {
    list-style: none !important;
    padding-left: 0 !important;
    margin-left: 0 !important;
}

.menu-section-css li,
#menu-locations-menu li {
    margin: 0;
    padding: 24px 0;
    border-bottom: 1px solid var(--sd-border-on-light);
    list-style: none;
}

.menu-section-css li:last-child,
#menu-locations-menu li:last-child {
    border-bottom: none;
}

.menu-section-css li a,
#menu-locations-menu li a {
    font-family: var(--sd-font-display), serif;
    font-size: 24px;
    line-height: 32px;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0;
    color: var(--sd-blue-gray) !important;
}

#menu-locations-menu li.menu-item a:hover {
    color: #000 !important;
}

.menu-section-css li a::after,
#menu-locations-menu li a::after {
    font-family: "uncodeicon";
    content: "\f105";
    font-size: 24px;
    font-weight: 900;
    flex-shrink: 0;
}

.div-left {
    width: 100%;
    max-width: 66.66666666666666%;
    display: inline-block;
    float: left;
    box-sizing: border-box;
}

.div-right {
    width: 100%;
    max-width: 33.33333333333333%;
    display: inline-block;
    float: left;
    box-sizing: border-box;
    padding-left: 72px;
}

.sp-css {
    font-size: 28px;
}

@media screen and (max-width: 959px) {
    .div-left {
        width: 100%;
        max-width: 100%;
        display: block;
        float: left;
        box-sizing: border-box;
        padding-bottom: 25px;
    }
    
    .div-right {
        width: 100%;
        max-width: 100%;
        display: block;
        float: left;
        box-sizing: border-box;
        padding-left: 0px;
    }
    
    .sp-css {
        font-size: 25px;
    }
    
    .menu-section-css {
        padding-left: 0px !important;
    }
}

/* ==========================================================================
   Birdeye List-Style Fix
   ========================================================================== */

.post-content ul li,
.uncode_text_column ul li {
	list-style-type: inherit !important;
}

/* ==========================================================================
   Style-Dark Link Overrides
   ========================================================================== */

body.textual-accent-color .post-content  .style-dark ul:not(.menu-smart):not(.nav-tabs):not(.pagination) a:not(.btn):not(.unmenu-block *){
	color: #ffffff !important;
}
body.textual-accent-color .post-content .style-dark ul:not(.menu-smart):not(.nav-tabs):not(.pagination) a:not(.btn-text-skin):hover:not(.btn):not(.unmenu-block *) {
	text-decoration: underline !important;
	color: #ffffff !important;
}
