/* 05-header-nav.css — header, logo, nav bar, CTA buttons, and mobile nav */

/* ==========================================================================
   Mobile Phone Button & Hamburger
   ========================================================================== */

.mobile-phone-button {
	color: var(--uncode-palette-color-210407) !important;
	background: var(--uncode-palette-color-154758) !important;
	border-color: var(--uncode-palette-color-154758) !important;
	box-shadow: inset var(--uncode-palette-color-154758) 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: 38px !important;
    }
    .navbar .menu-container .logo-container {
        position: relative;
        padding: 27px 16px 27px 16px !important;
    }	
}

/* ==========================================================================
   Header — Main
   ========================================================================== */

.menu-container {
	box-shadow: rgba(0, 0, 0, .25) 0 0 15px;
}

.logo-container { 
	padding-top: 22px;
	padding-bottom: 22px;
}

.menu-cta-inner > li > a {
	border-radius: 24px;
	overflow: hidden;
	padding: 15px 25px!important;
}

/* Phone button — matches .btn.btn-default.btn-circle.btn-outline */
.menu-cta-inner > li:first-child > a {
	background-color: transparent !important;
	color: var(--uncode-palette-color-589256) !important;
	border: 2px solid rgba(21, 34, 41, 0.2) !important;
	box-shadow: none !important;
}

.menu-cta-inner > li:first-child > a:hover,
.menu-container .cta-phone.menu-item a:hover {
	background-color: transparent !important;
	border-color: #252D30 !important;
	color: #252D30 !important;
	box-shadow: none !important;
}

.menu-cta-inner > li:first-child > a:active,
.menu-cta-inner > li:first-child > a:focus,
.menu-container .cta-phone.menu-item a:active,
.menu-container .cta-phone.menu-item a:focus {
	background-color: transparent !important;
	border-color: #252D30 !important;
	color: #252D30 !important;
	opacity: 0.70 !important;
	box-shadow: none !important;
}

/* Book Appointment button — matches .btn.btn-color-210407.btn-circle (filled) */
.menu-cta-inner > li:nth-child(2) > a {
	background-color: var(--uncode-palette-color-210407) !important;
	border-color: var(--uncode-palette-color-210407) !important;
	color: #ffffff !important;
	box-shadow: none !important;
}
.mobile-book-btn {
	background-color: var(--uncode-palette-color-210407) !important;
	border-color: var(--uncode-palette-color-210407) !important;
	color: #ffffff !important;
	padding: 8px 16px;
	font-weight: 500;
	border-radius: 24px;
}

.mobile-book-icon.mobile-book-btn {
	color: var(--uncode-palette-color-210407) !important;
	background: var(--uncode-palette-color-154758) !important;
	border-color: var(--uncode-palette-color-154758) !important;
	box-shadow: none !important;
}

.menu-cta-inner > li:nth-child(2) > a:hover {
	background-color: #784458 !important;
	border-color: #784458 !important;
	color: #ffffff !important;
	box-shadow: none !important;
}

.menu-cta-inner > li:nth-child(2) > a:active,
.menu-cta-inner > li:nth-child(2) > a:focus {
	background-color: #693C4D !important;
	border-color: #693C4D !important;
	color: #ffffff !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: 88px;
}

.logo-container {
	padding-right: 20px !important;
}

.navbar #main-logo a > * {
	height: 50px !important;
	width: auto !important;
}

.menu-smart {
	height: auto;
	padding: 0!important;
}

.menu-primary-inner > li {
	vertical-align: middle !important;
}

.menu-primary-inner > li > a {
	color: #252D30 !important;
	font-size: 15px !important;
	font-weight: 500;
	line-height: 22px;
	padding: 10px 10px !important;
	white-space: nowrap;
}

.hmenu .menu-smart, 
.hmenu-center .menu-smart, 
.navbar-cta ul.menu-smart {
    height: auto;
}

.menu-primary-inner > li.current-menu-item > a,
.menu-primary-inner > li.current-menu-ancestor > a,
.menu-primary-inner > li.current-menu-parent > a {
	color: #96556E !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;
}
}

@media (min-width: 960px) and (max-width: 1099px) {
#main-logo a > * {
    height: 28px !important;
}

.menu-primary-inner > li > a {
	font-size: 13px !important;
	padding: 8px 6px !important;
}

.menu-cta-inner > li > a {
	padding: 0 12px !important;
	font-size: 13px !important;
}
}

@media (min-width: 1100px) and (max-width: 1249px) {
#main-logo a > * {
    height: 30px !important;
}

.menu-primary-inner > li > a {
	font-size: 14px !important;
	padding: 10px 8px !important;
}

.menu-cta-inner > li > a {
	padding: 0 14px !important;
	font-size: 14px !important;
}
}

/* ==========================================================================
   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;
}

.menu-cta-inner {
	margin: 0!important;
	padding: 8px 24px!important;
}

.menu-cta-inner > li {
	margin-bottom: 15px!important;
	border-bottom: none!important;
}

.menu-cta-inner > li > a {
	padding: 8px 12px!important;
	justify-content: center!important;
	text-decoration: none!important;
}

.menu-cta-inner > li:first-child > a {
	border: 2px solid rgba(21, 34, 41, 0.2) !important;
}

/* Phone hover — darken border/text, stay transparent (matches .btn-default.btn-outline) */
.menu-cta-inner > li:first-child > a:hover {
	background-color: transparent !important;
	border-color: #252D30 !important;
	color: #252D30 !important;
	box-shadow: none !important;
}

.menu-cta-inner > li:first-child > a:active,
.menu-cta-inner > li:first-child > a:focus {
	background-color: transparent !important;
	border-color: #252D30 !important;
	color: #252D30 !important;
	opacity: 0.70 !important;
	box-shadow: none !important;
}

/* Book hover — lighter purple fill, stay filled (matches .btn-color-210407) */
.menu-cta-inner > li:nth-child(2) > a:hover {
	background-color: #784458 !important;
	border-color: #784458 !important;
	color: #ffffff !important;
	box-shadow: none !important;
}

.menu-cta-inner > li:nth-child(2) > a:active,
.menu-cta-inner > li:nth-child(2) > a:focus {
	background-color: #693C4D !important;
	border-color: #693C4D !important;
	color: #ffffff !important;
	box-shadow: none !important;
}

/* Hide carets on CTA buttons */
.menu-cta-inner > li > 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: 28px !important;
	}
	/* Slightly smaller mobile CTA pill buttons */
	.menu-cta-inner > li > 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 rgba(21, 34, 41, 0.2);
    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: 'Lora', serif;
    font-size: 24px;
    line-height: 32px;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0;
    color: #286179 !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;
}
