.ct-section {
width:100%;
background-size:cover;
background-repeat:repeat;
}
.ct-section>.ct-section-inner-wrap {
display:flex;
flex-direction:column;
align-items:flex-start;
}
.ct-div-block {
display:flex;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.ct-new-columns {
display:flex;
width:100%;
flex-direction:row;
align-items:stretch;
justify-content:center;
flex-wrap:wrap;
}
.ct-link-text {
display:inline-block;
}
.ct-link {
display:flex;
flex-wrap:wrap;
text-align:center;
text-decoration:none;
flex-direction:column;
align-items:center;
justify-content:center;
}
.ct-link-button {
display:inline-block;
text-align:center;
text-decoration:none;
}
.ct-link-button {
background-color: #1e73be;
border: 1px solid #1e73be;
color: #ffffff;
padding: 10px 16px;
}
.ct-image {
max-width:100%;
}
.ct-fancy-icon>svg {
width:55px;height:55px;}
.ct-inner-content {
width:100%;
}
.ct-slide {
display:flex;
flex-wrap:wrap;
text-align:center;
flex-direction:column;
align-items:center;
justify-content:center;
}
.ct-nestable-shortcode {
display:flex;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-comments {
width:100%;
text-align:left;
}
.oxy-comment-form {
width:100%;
}
.oxy-login-form {
width:100%;
}
.oxy-search-form {
width:100%;
}
.oxy-tabs-contents {
display:flex;
width:100%;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-tab {
display:flex;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-tab-content {
display:flex;
width:100%;
flex-wrap:nowrap;
flex-direction:column;
align-items:flex-start;
}
.oxy-testimonial {
width:100%;
}
.oxy-icon-box {
width:100%;
}
.oxy-pricing-box {
width:100%;
}
.oxy-posts-grid {
width:100%;
}
.oxy-gallery {
width:100%;
}
.ct-slider {
width:100%;
}
.oxy-tabs {
display:flex;
flex-wrap:nowrap;
flex-direction:row;
align-items:stretch;
}
.ct-modal {
flex-direction:column;
align-items:flex-start;
}
.ct-span {
display:inline-block;
text-decoration:inherit;
}
.ct-widget {
width:100%;
}
.oxy-dynamic-list {
width:100%;
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
			.ct-div-block,
			.oxy-post-content,
			.ct-text-block,
			.ct-headline,
			.oxy-rich-text,
			.ct-link-text { max-width: 100%; }
			img { flex-shrink: 0; }
			body * { min-height: 1px; }
		}            .oxy-testimonial {
                flex-direction: row;
                align-items: center;
            }
                        .oxy-testimonial .oxy-testimonial-photo-wrap {
                order: 1;
            }
            
                        .oxy-testimonial .oxy-testimonial-photo {
                width: 125px;                height: 125px;                margin-right: 20px;
            }
            
                        .oxy-testimonial .oxy-testimonial-photo-wrap, 
            .oxy-testimonial .oxy-testimonial-author-wrap, 
            .oxy-testimonial .oxy-testimonial-content-wrap {
                align-items: flex-start;                text-align: left;            }
            
                                                            .oxy-testimonial .oxy-testimonial-text {
                margin-bottom:8px;font-size: 21px;
line-height: 1.4;
-webkit-font-smoothing: subpixel-antialiased;
            }
            
                                    .oxy-testimonial .oxy-testimonial-author {
                font-size: 18px;
-webkit-font-smoothing: subpixel-antialiased;
            }
                            

                                                .oxy-testimonial .oxy-testimonial-author-info {
                font-size: 12px;
-webkit-font-smoothing: subpixel-antialiased;
            }
            
             
            
                        .oxy-icon-box {
                text-align: left;                flex-direction: column;            }
            
                        .oxy-icon-box .oxy-icon-box-icon {
                margin-bottom: 12px;
                align-self: flex-start;            }
            
                                                                        .oxy-icon-box .oxy-icon-box-heading {
                font-size: 21px;
margin-bottom: 12px;            }
            
                                                                                    .oxy-icon-box .oxy-icon-box-text {
                font-size: 16px;
margin-bottom: 12px;align-self: flex-start;            }
            
                        .oxy-icon-box .oxy-icon-box-link {
                margin-top: 20px;                            }
            
            
            /* GLOBALS */

                                                            .oxy-pricing-box .oxy-pricing-box-section {
                padding-top: 20px;
padding-left: 20px;
padding-right: 20px;
padding-bottom: 20px;
text-align: center;            }
                        
                        .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-price {
                justify-content: center;            }
            
            /* IMAGE */
                                                                                    .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-graphic {
                justify-content: center;            }
            
            /* TITLE */
                                                            
                                    .oxy-pricing-box .oxy-pricing-box-title-title {
                font-size: 48px;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-title-subtitle {
                font-size: 24px;
            }
            

            /* PRICE */
                                                .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-price {
                                                flex-direction: row;                                            }
            
                                    .oxy-pricing-box .oxy-pricing-box-currency {
                font-size: 28px;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-amount-main {
                font-size: 80px;
line-height: 0.7;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-amount-decimal {
                font-size: 13px;
            }
                        
                                    .oxy-pricing-box .oxy-pricing-box-term {
                font-size: 16px;
            }
            
                                    .oxy-pricing-box .oxy-pricing-box-sale-price {
                font-size: 12px;
color: rgba(0,0,0,0.5);
                margin-bottom: 20px;            }
            
            /* CONTENT */

                                                                        .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-content {
                font-size: 16px;
color: rgba(0,0,0,0.5);
            }
            
            /* CTA */

                                                                        .oxy-pricing-box .oxy-pricing-box-section.oxy-pricing-box-cta {
                justify-content: center;            }
            
        
                                .oxy-progress-bar .oxy-progress-bar-background {
            background-color: #000000;            background-image: linear-gradient(-45deg,rgba(255,255,255,.12) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.12) 75%,transparent 75%,transparent);            animation: none 0s paused;        }
                
                .oxy-progress-bar .oxy-progress-bar-progress-wrap {
            width: 85%;        }
        
                                                        .oxy-progress-bar .oxy-progress-bar-progress {
            background-color: #66aaff;padding: 40px;animation: none 0s paused, none 0s paused;            background-image: linear-gradient(-45deg,rgba(255,255,255,.12) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.12) 75%,transparent 75%,transparent);        
        }
                
                        .oxy-progress-bar .oxy-progress-bar-overlay-text {
            font-size: 30px;
font-weight: 900;
-webkit-font-smoothing: subpixel-antialiased;
        }
        
                        .oxy-progress-bar .oxy-progress-bar-overlay-percent {
            font-size: 12px;
        }
        
        .ct-slider .unslider-nav ol li {border-color: #ffffff; }.ct-slider .unslider-nav ol li.unslider-active {background-color: #ffffff; }.ct-slider .ct-slide {
				padding: 0px;			}
		
                        .oxy-superbox .oxy-superbox-secondary, 
            .oxy-superbox .oxy-superbox-primary {
                transition-duration: 0.5s;            }
            
            
            
            
            
        
        
        
        
            .oxy-shape-divider {
                width: 0px;
                height: 0px;
                
            }
            
            .oxy_shape_divider svg {
                width: 100%;
            }
            .oxy-pro-menu .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .sub-menu{
box-shadow:px px px px ;}

.oxy-pro-menu .oxy-pro-menu-show-dropdown .oxy-pro-menu-list .menu-item-has-children > a svg{
transition-duration:0.4s;
}

.oxy-pro-menu .oxy-pro-menu-show-dropdown .oxy-pro-menu-list .menu-item-has-children > a div{
margin-left:0px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-open-icon svg{
width:30px;
height:30px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-open-icon{
padding-top:15px;
padding-right:15px;
padding-bottom:15px;
padding-left:15px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-open-icon, .oxy-pro-menu .oxy-pro-menu-mobile-open-icon svg{
transition-duration:0.4s;
}

.oxy-pro-menu .oxy-pro-menu-mobile-close-icon{
top:20px;
left:20px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-close-icon svg{
width:24px;
height:24px;
}

.oxy-pro-menu .oxy-pro-menu-mobile-close-icon, .oxy-pro-menu .oxy-pro-menu-mobile-close-icon svg{
transition-duration:0.4s;
}

.oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-off-canvas-container, .oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-open-container{
background-color:#ffffff;
}

.oxy-pro-menu .oxy-pro-menu-off-canvas-container, .oxy-pro-menu .oxy-pro-menu-open-container{
background-image:url();
}

.oxy-pro-menu .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item-has-children > a svg, .oxy-pro-menu .oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item-has-children > a svg{
font-size:24px;
}

.oxy-pro-menu .oxy-pro-menu-dropdown-links-toggle.oxy-pro-menu-open-container .menu-item-has-children ul, .oxy-pro-menu .oxy-pro-menu-dropdown-links-toggle.oxy-pro-menu-off-canvas-container .menu-item-has-children ul{
background-color:rgba(0,0,0,0.2);
border-top-style:solid;
}

.oxy-pro-menu .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .oxy-pro-menu-list{
                    flex-direction: row;
               }
.oxy-pro-menu .oxy-pro-menu-container .menu-item a{
                    text-align: left;
                    justify-content: flex-start;
                }
.oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-open-container .menu-item, .oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-off-canvas-container .menu-item{
                    align-items: flex-start;
                }

            .oxy-pro-menu .oxy-pro-menu-off-canvas-container{
                    top: 0;
                    bottom: 0;
                    right: auto;
                    left: 0;
               }
.oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item a, .oxy-pro-menu .oxy-pro-menu-container.oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item a{
                    text-align: left;
                    justify-content: flex-start;
                }

            .oxy-site-navigation {
--oxynav-brand-color:#4831B0;
--oxynav-neutral-color:#FFFFFF;
--oxynav-activehover-color:#EFEDF4;
--oxynav-background-color:#4831B0;
--oxynav-border-radius:0px;
--oxynav-other-spacing:8px;
--oxynav-transition-duration:0.3s;
--oxynav-transition-timing-function:cubic-bezier(.84,.05,.31,.93);
}

.oxy-site-navigation .oxy-site-navigation__mobile-close-wrapper{
text-align:left;
}

.oxy-site-navigation > ul{ left: 0; }
.oxy-site-navigation {
                        --oxynav-animation-name: none; 
                    }

                .oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(1){ 
                    background-color: var(--oxynav-brand-color);
                    transition: var(--oxynav-transition-duration);
                    margin-left: var(--oxynav-other-spacing);
                    border: none;
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2){ 
                    background: transparent;
                    border: 1px solid currentColor;
                    transition: var(--oxynav-transition-duration);
                    margin-left: var(--oxynav-other-spacing);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2):not(:hover) > img{
                    filter: invert(0) !important;
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:hover{
                    background-color: var(--oxynav-activehover-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(1) > a{
                    color: var(--oxynav-neutral-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2) > a{
                    color: var(--oxynav-brand-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:hover > a{
                    color: var(--oxynav-brand-color);
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(1) > a::after{
                    color: var(--oxynav-neutral-color);   
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:nth-last-child(2) > a::after{
                    color: var(--oxynav-brand-color);   
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true']:hover > a::after{
                    color: var(--oxynav-brand-color);   
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true'] > ul{
                    display: none;
                }
.oxy-site-navigation > ul:not(.open) > li[data-cta='true'] > button, .oxy-site-navigation > ul:not(.open) > li[data-cta='true'] > ul{
                    display: none;
                }

                .ct-section-inner-wrap, .oxy-header-container{
  max-width: 1380px;
}
body {font-family: 'Inter';}body {line-height: 1.6;font-size: 16px;font-weight: 400;color: #334155;}.oxy-nav-menu-hamburger-line {background-color: #334155;}h1, h2, h3, h4, h5, h6 {font-family: 'Funnel Display';font-size: 36px;font-weight: 700;}h2, h3, h4, h5, h6{font-size: 30px;}h3, h4, h5, h6{font-size: 24px;}h4, h5, h6{font-size: 20px;}h5, h6{font-size: 18px;}h6{font-size: 16px;}a {color: #245da4;text-decoration: none;}a:hover {text-decoration: none;}.ct-link-text {text-decoration: ;}.ct-link {text-decoration: ;}.ct-link-button {border-radius: 8px;}.ct-section-inner-wrap {
padding-top: 120px;
padding-right: 20px;
padding-bottom: 120px;
padding-left: 20px;
}.ct-new-columns > .ct-div-block {
padding-top: 20px;
padding-right: 20px;
padding-bottom: 20px;
padding-left: 20px;
}.oxy-header-container {
padding-right: 20px;
padding-left: 20px;
}@media (max-width: 992px) {
				.ct-columns-inner-wrap {
					display: block !important;
				}
				.ct-columns-inner-wrap:after {
					display: table;
					clear: both;
					content: "";
				}
				.ct-column {
					width: 100% !important;
					margin: 0 !important;
				}
				.ct-columns-inner-wrap {
					margin: 0 !important;
				}
			}
.oxel_accordion {
 border-top-color:#adb4b9;
 border-right-color:#adb4b9;
 border-bottom-color:#adb4b9;
 border-left-color:#adb4b9;
 border-top-width:1px;
 border-right-width:1px;
 border-bottom-width:1px;
 border-left-width:1px;
 border-top-style:none;
 border-right-style:none;
 border-bottom-style:none;
 border-left-style:none;
 width:100%;
}
.oxel_accordion__row {
 font-family:Inter;
 width:100%;
 padding-top:12px;
 padding-left:8px;
 padding-right:8px;
 padding-bottom:12px;
 text-align:justify;
 border-bottom-color:#eceeef;
 border-bottom-width:1px;
 border-bottom-style:solid;
 border-top-style:none;
 background-color:#f9f9fa;
 border-right-style:none;
 border-left-style:none;
 font-weight:600;
cursor: pointer;
}
.oxel_accordion__row:not(.ct-section):not(.oxy-easy-posts),
.oxel_accordion__row.oxy-easy-posts .oxy-posts,
.oxel_accordion__row.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
justify-content:space-between;
}
.oxel_accordion__icon {
color: #374047;}.oxel_accordion__icon 
>svg {width: 18px;height: 18px;}.oxel_accordion__icon {
 margin-right:8px;
 transition-duration:0.3s;
}
.oxel_accordion__row_left {
}
.oxel_accordion__row_left:not(.ct-section):not(.oxy-easy-posts),
.oxel_accordion__row_left.oxy-easy-posts .oxy-posts,
.oxel_accordion__row_left.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
align-items:center;
}
.oxel_accordion__content {
 width:100%;
 padding-top:8px;
 padding-left:8px;
 padding-right:8px;
 padding-bottom:8px;
 border-bottom-color:#98a1a8;
 border-bottom-width:2px;
 border-bottom-style:none;
 overflow:hidden;
 opacity:1;
 transition-duration:3s;
 border-top-style:none;
 border-right-style:none;
 border-left-style:none;
 transition-property:max-height;
 text-align:left;
 max-height:3000px;
 margin-top:0px;
}
.oxel_accordion__content:not(.ct-section):not(.oxy-easy-posts),
.oxel_accordion__content.oxy-easy-posts .oxy-posts,
.oxel_accordion__content.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:flex-start;
}
.oxel_accordion__content__hidden {
 max-height:0px;
 padding-left:8px;
 padding-right:8px;
 padding-top:0px;
 z-index:-1;
 padding-bottom:0px;
 transition-duration:0s;
}
.oxel_accordion__content__hidden:not(.ct-section):not(.oxy-easy-posts),
.oxel_accordion__content__hidden.oxy-easy-posts .oxy-posts,
.oxel_accordion__content__hidden.ct-section .ct-section-inner-wrap{
display:flex;
}
.oxel_accordion__row__label {
}
.oxel_iconlist {
 max-width:100%;
}
.oxel_iconlist__row {
 padding-top:8px;
 padding-left:8px;
 padding-right:8px;
 padding-bottom:8px;
 width:100%;
 margin-top:0px;
}
.oxel_iconlist__row:not(.ct-section):not(.oxy-easy-posts),
.oxel_iconlist__row.oxy-easy-posts .oxy-posts,
.oxel_iconlist__row.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
align-items:center;
}
.oxel_iconlist__row__icon {
color: #7f8b93;}.oxel_iconlist__row__icon 
>svg {width: 18px;height: 18px;}.oxel_iconlist__row__icon {
 margin-left:32px;
 margin-right:32px;
}
.oxel_iconlist__row__label {
}
.oxel_iconlist__row--dark {
 background-color:#eceeef;
}
.btn-primary {
 font-family:Inter;
 padding-top:8px;
 padding-bottom:8px;
 padding-right:18px;
 padding-left:22px;
 border-radius:999px;
 color:#ffffff;
 gap:5px;
 background-color:#2dd4bf;
}
.btn-primary:not(.ct-section):not(.oxy-easy-posts),
.btn-primary.oxy-easy-posts .oxy-posts,
.btn-primary.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
align-items:center;
gap:5px;
}
@media (max-width: 767px) {
.btn-primary {
}
}

.btn-primary-lx {
 padding-top:14px;
 padding-right:32px;
 padding-bottom:14px;
 padding-left:32px;
 border-radius:999px;
 background-color:#2dd4bf;
 font-weight:400;
}
.btn-secondary {
 padding-top:12px;
 padding-right:24px;
 padding-bottom:12px;
 padding-left:24px;
 border-radius:999px;
 border-top-style:solid;
 border-right-style:solid;
 border-bottom-style:solid;
 border-left-style:solid;
 border-top-width:1px;
 border-right-width:1px;
 border-bottom-width:1px;
 border-left-width:1px;
 border-top-color:#245da4;
 border-right-color:#245da4;
 border-bottom-color:#245da4;
 border-left-color:#245da4;
 font-weight:600;
}
.eyebrow-s {
 font-family:Inter;
 border-bottom-style:solid;
 border-bottom-width:0.5px;
 border-bottom-color:#2dd4bf;
 font-size:22px;
}
.text-white {
 margin-top:0px;
 font-weight:300;
}
.text-dark {
}
.text-dark .oxy-pro-menu-list .menu-item, .text-dark .oxy-pro-menu-list .menu-item a{
font-family: 'Inter';
font-size: 16px;
}

.text-dark .oxy-pro-menu-list .menu-item a{
padding-right:10px;
padding-left:10px;
padding-bottom:2px;
}

.fs-1 {
}
.fs-0 {
}
.ppc-header {
}
@media (max-width: 1380px) {
.ppc-header {
 font-size:34px;
}
}

@media (max-width: 991px) {
.ppc-header {
 font-size:28px;
}
}

@media (max-width: 479px) {
.ppc-header {
}
}

.ppc-sec {
}
@media (max-width: 1380px) {
.ppc-sec {
}
.ppc-sec .ct-section-inner-wrap {
padding-top: 100px;
padding-bottom: 100px;
}
}

@media (max-width: 991px) {
.ppc-sec {
}
.ppc-sec .ct-section-inner-wrap {
padding-top: 80px;
padding-bottom: 80px;
}
.ppc-sec:not(.ct-section):not(.oxy-easy-posts),
.ppc-sec.oxy-easy-posts .oxy-posts,
.ppc-sec.ct-section .ct-section-inner-wrap{
display:flex;
}
}

@media (max-width: 767px) {
.ppc-sec {
}
.ppc-sec .ct-section-inner-wrap {
padding-top: 70px;
padding-bottom: 70px;
}
}

@media (max-width: 479px) {
.ppc-sec {
}
.ppc-sec .ct-section-inner-wrap {
padding-top: 60px;
padding-bottom: 60px;
}
}

.sticky {
}
.oxy-stock-content-styles {
}
.cda-section {
}
.cda-section .ct-section-inner-wrap {
padding-top: 0;
}
.cda-section:not(.ct-section):not(.oxy-easy-posts),
.cda-section.oxy-easy-posts .oxy-posts,
.cda-section.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
}
.cda-section--sm {
}
.cda-section--flush {
}
.cda-section--tint {
}
.cda-section--soft {
}
.cda-section--dark {
}
.cda-grid {
}
.cda-grid--2 {
}
.cda-grid--3 {
}
.cda-grid--4 {
}
.cda-split {
}
.cda-split--reverse {
}
.cda-split--top {
}
.cda-stack {
}
.cda-stack--tight {
}
.cda-stack--lg {
}
.cda-stack--center {
}
.cda-head {
}
.cda-head--center {
}
.cda-mw-sm {
}
.cda-mw-md {
}
.cda-mw-lg {
}
.cda-center {
}
.cda-eyebrow {
}
.cda-eyebrow--center {
}
.cda-title {
}
.cda-lead {
}
.cda-muted {
}
.cda-rule {
}
.cda-rule--center {
}
.cda-card {
}
.cda-card--tint {
}
.cda-card--flat {
}
.cda-card--accent {
}
.cda-card--dark {
}
.cda-card__title {
}
.cda-card__text {
}
.cda-badge {
}
.cda-badge--accent {
}
.cda-badge--round {
}
.cda-badge--lg {
}
.cda-pill {
}
.cda-pill--accent {
}
.cda-stat__num {
}
.cda-stat__label {
}
.cda-checks {
}
.cda-media {
}
.cda-media--tall {
}
.cda-btn {
}
.cda-btn--primary {
}
.cda-btn--accent {
}
.cda-btn--ghost {
}
.cda-btn--light {
}
.cda-btn--lg {
}
.cda-btn--block {
}
.cda-cta {
}
.cda-topbar {
}
.cda-header {
}
.cda-nav {
}
.cda-footer {
}
.cda-footer__grid {
}
.cda-footer__title {
}
.cda-footer__bottom {
}
.cda-arch {
}
.cda-rings {
}
.cda-dots {
}
.reveal {
}
@import url('https://fonts.googleapis.com/css2?family=Funnel+Display:wght@300..800&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');

/** -----------------------------------------------------------------
 * BRAND TOKENS (set these in Oxygen → Manage → Colors)
 * Primary    #245DA4
 * Secondary  #334155   ← #334155: heading text, social icon, table header
 * Accent     #2DD4BF
 * Gray       #A7A7A7
 * Light Gray #DBDBDB   ← used for borders below
 *
 * Fonts:
 * Display    Funnel Display  (H1–H4)
 * Body       Inter           (H5–H6, body, lists)
 * ----------------------------------------------------------------- */

  .sticky {
    position: -webkit-sticky;
    position: sticky;
    top: 120px;
  }

figure {
  margin: 0;
}

/** ----- Socials ----- **/
.seopress-socials-svg {
  display: flex;
  gap: 8px;
  list-style: none;
  padding-left: 0;
  align-items: center;
}
.seopress-socials-svg li {
  width: 32px;
  height: 32px;
  background: #2dd4bf;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.6s ease;
}
.seopress-socials-svg li svg {
  width: 20px;
  height: 20px;
  color: #334155;
  display: block;
}
.seopress-socials-svg li:hover {
  opacity: 0.8;
}

.text-white, .text-white a {
  color: #ffffff !important;
}

.text-dark, .text-dark a {
  color: #245DA4 !important;
}

/** ----- Sticky ----- **/
@media (min-width: 992px) {
  .sticky {
    position: -webkit-sticky;
    position: sticky;
    top: 120px;
  }
}

/** ----- Headings ----- **/
/* H1–H4 (Funnel Display) */
h1, h2, h3, h4,
.fs-0, .fs-1, .fs-2, .fs-3, .fs-4,
.oxy-stock-content-styles h1,
.oxy-stock-content-styles h2,
.oxy-stock-content-styles h3,
.oxy-stock-content-styles h4 {
  font-family: "Funnel Display", sans-serif;
  font-weight: 400;
  line-height: 1.3;
  color: #334155;
}
/* H5–H6 (Inter) */
h5, h6,
.fs-5, .fs-6,
.oxy-stock-content-styles h5,
.oxy-stock-content-styles h6 {
  font-family: "Inter", sans-serif;
  font-weight: 500;
  line-height: 1.6;
}
.oxy-stock-content-styles h1,
.oxy-stock-content-styles h2,
.oxy-stock-content-styles h3,
.oxy-stock-content-styles h4,
.oxy-stock-content-styles h5,
.oxy-stock-content-styles h6 {
  margin: 40px 0 0 0;
}

/** ----- Font Sizes ----- **/
/* Extra-large hero text */
.fs-0 {
  font-size: clamp(40px, 5.8vw, 60px);
}
h1, .fs-1 {
  font-size: clamp(30px, 4.6vw, 50px);
}
h2, .fs-2,
.oxy-stock-content-styles h2 {
  font-size: clamp(26px, 3.6vw, 38px);
}
h3, .fs-3,
.oxy-stock-content-styles h3 {
  font-size: clamp(22px, 2.6vw, 26px);
}
h4, .fs-4,
.oxy-stock-content-styles h4 {
  font-size: clamp(18px, 2.2vw, 20px);
}
h5, .fs-5,
.oxy-stock-content-styles h5 {
  font-size: clamp(16px, 1.9vw, 18px);
}
h6, .fs-6,
.oxy-stock-content-styles h6 {
  font-size: 13px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #0f172a;
  margin-bottom: 8px;
}

/** ----- Body Text (Inter) ----- **/
body,
p,
.oxy-rich-text,
ul {
  font-family: "Inter", sans-serif;
  font-size: clamp(15px, 1.1vw, 18px);
}
p,
.oxy-rich-text,
ul {
  margin: 16px 0;
  line-height: 1.7;
}

table {
  border-collapse: collapse;
  width: 100%;
  margin: 20px 0;
}

header ul {
  margin: 0;
}

/* ---------------------------------------
   GRAVITY FORM STYLING
--------------------------------------- */

.gform_wrapper.gravity-theme,
.gform_wrapper.gravity-theme * {
  font-family: var(--font-body);
  box-sizing: border-box;
}

.gform_wrapper.gravity-theme {
  width: 100%;
}

.gform_wrapper.gravity-theme .gform_heading {
  margin-bottom: 20px;
}

.gform_wrapper.gravity-theme .gform_description {
  font-size: 16px;
  line-height: 1.8;
  color: var(--color-light);
  margin: 0;
}

/* Field spacing */
.gform_wrapper.gravity-theme .gform-body {
  margin-bottom: 14px;
}

.gform_wrapper.gravity-theme .gfield {
  margin-bottom: 12px;
}

/* Hide labels since placeholders are used */
.gform_wrapper.gravity-theme .hidden_label .gfield_label,
.gform_wrapper.gravity-theme .gfield_label,
.gform_wrapper.gravity-theme .gfield_required,
.gform_wrapper.gravity-theme .gfield_required_text {
  display: none !important;
}

/* Inputs, select, textarea */
.gform_wrapper.gravity-theme input[type="text"],
.gform_wrapper.gravity-theme input[type="email"],
.gform_wrapper.gravity-theme input[type="tel"],
.gform_wrapper.gravity-theme input[type="number"],
.gform_wrapper.gravity-theme input[type="password"],
.gform_wrapper.gravity-theme input[type="url"],
.gform_wrapper.gravity-theme input[type="search"],
.gform_wrapper.gravity-theme input[type="date"],
.gform_wrapper.gravity-theme input[type="time"],
.gform_wrapper.gravity-theme input[type="datetime-local"],
.gform_wrapper.gravity-theme select,
.gform_wrapper.gravity-theme textarea {
  width: 100%;
  min-height: 46px;
  padding: 10px 16px;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
  color: var(--color-dark);
  background: #ffffff;
  border: 1px solid #d9e2ec;
  border-radius: 4px;
  box-shadow: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease;
  appearance: none;
}

/* Textarea */
.gform_wrapper.gravity-theme .gfield textarea.large {
      height: 120px !important;
}

.gform_wrapper.gravity-theme textarea {
  min-height: 130px;
  resize: vertical;
  padding-top: 12px;
}

/* Placeholder */
.gform_wrapper.gravity-theme ::placeholder {
  color: #6f7d8c;
  opacity: 1;
  font-size: 15px;
}

/* Select arrow */
.gform_wrapper.gravity-theme .ginput_container_select {
  position: relative;
}

.gform_wrapper.gravity-theme .ginput_container_select::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  width: 10px;
  height: 10px;
  border-right: 2px solid var(--color-secondary);
  border-bottom: 2px solid var(--color-secondary);
  transform: translateY(-60%) rotate(45deg);
  pointer-events: none;
}

/* Focus state */
.gform_wrapper.gravity-theme input:focus,
.gform_wrapper.gravity-theme select:focus,
.gform_wrapper.gravity-theme textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(70, 177, 201, 0.15);
}

/* Footer */
.gform_wrapper.gravity-theme .gform_footer,
.gform_wrapper.gravity-theme .gform_page_footer {
  margin-top: 4px;
  padding: 0;
}

/* Submit button */
.gform_wrapper.gravity-theme .gform_button,
.gform_wrapper.gravity-theme input[type="submit"],
.gform_wrapper.gravity-theme button[type="submit"] {
  display: inline-block;
  width: 100%;
  min-height: 46px;
  background-color: #245da4 !important;
  color: #ffffff;
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 600;
  line-height: 1.2;
  padding: 10px 24px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 0.25s ease;
  appearance: none;
  letter-spacing: 1px;
}

.gform_wrapper.gravity-theme .gform_button:hover,
.gform_wrapper.gravity-theme input[type="submit"]:hover,
.gform_wrapper.gravity-theme button[type="submit"]:hover {
  background-color: #245da4 !important;
  color: #ffffff;
}

/* Validation */
.gform_wrapper.gravity-theme .gfield_error input,
.gform_wrapper.gravity-theme .gfield_error select,
.gform_wrapper.gravity-theme .gfield_error textarea {
  border-color: #d63638;
}

.gform_wrapper.gravity-theme .validation_message,
.gform_wrapper.gravity-theme .gfield_validation_message,
.gform_wrapper.gravity-theme .validation_error {
  font-size: 14px !important;
  margin-top: 6px !important;
  color: #ff9697 !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}

/* Remove default GF theme backgrounds */
.gform_wrapper.gravity-theme .gform-theme--framework,
.gform_wrapper.gravity-theme .gform-theme--foundation {
  background: transparent;
}

/* Confirmation message */
.gform_wrapper.gravity-theme .gform_confirmation_message {
  font-size: 16px;
  line-height: 1.8;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.08);
  border-left: 4px solid var(--color-accent);
  padding: 16px 20px;
  border-radius: 4px;
}

/* Responsive */
@media (max-width: 767px) {
  .gform_wrapper.gravity-theme input[type="text"],
  .gform_wrapper.gravity-theme input[type="email"],
  .gform_wrapper.gravity-theme input[type="tel"],
  .gform_wrapper.gravity-theme select,
  .gform_wrapper.gravity-theme textarea {
    font-size: 15px;
  }

  .gform_wrapper.gravity-theme .gform_button,
  .gform_wrapper.gravity-theme input[type="submit"],
  .gform_wrapper.gravity-theme button[type="submit"] {
    font-size: 16px;
  }
}
:root :where(.is-layout-flex) {
    gap: 5.2rem !important;
}
:where(.wp-block-columns) {
    margin-bottom: 4.75em !important;
}/* =====================================================================
   CRANBERRY DENTAL ARTS — GLOBAL DESIGN SYSTEM  (v2, class-based)
   Single source of truth for site-wide styling. Edit here (Oxygen →
   Manage → Stylesheets → CDADesignSystem). All visual styling is driven
   by reusable .cda-* global classes — NOT per-element #id rules.
   Palette + fonts unchanged; built for WCAG AA contrast + full responsive.
   ===================================================================== */

/* ---------------------------------------------------------------------
   1. TOKENS
   --------------------------------------------------------------------- */
:root {
  /* Brand palette (matches oxygen_vsb_global_colors) */
  --color-primary:    #245da4;
  --color-primary-d:  #1b4a85;   /* hover / pressed */
  --color-secondary:  #334155;
  --color-accent:     #2dd4bf;
  --color-accent-d:   #0e7c70;   /* AA-safe deep teal for gradients/text */
  --color-gray:       #a7a7a7;
  --color-light-bg:   #f6f9fc;   /* section tint */
  --color-line:       #e7edf3;   /* hairline borders on light */
  --color-dark:       #0f172a;
  --color-dark-2:     #0b213d;
  --color-white:      #ffffff;

  /* Text — all AA on white / tint */
  --text-body:  #334155;
  --text-muted: #5b6b7a;
  --color-light: var(--text-muted);  /* legacy var used by form CSS */

  /* Fonts */
  --font-display: "Funnel Display", sans-serif;
  --font-body:    "Inter", sans-serif;
  --font-heading: var(--font-display);

  /* Spacing scale */
  --space-1: 4px;  --space-2: 8px;  --space-3: 16px; --space-4: 24px;
  --space-5: 32px; --space-6: 48px; --space-7: 64px; --space-8: 96px;
  --section-y: clamp(64px, 8vw, 120px);

  /* Radius / elevation */
  --radius-button: 10px;
  --radius-card:   20px;
  --radius-pill:   999px;
  --shadow-sm: 0 1px 2px rgba(15,23,42,.05);
  --shadow-md: 0 10px 30px rgba(15,23,42,.08);
  --shadow-lg: 0 22px 48px rgba(15,23,42,.12);

  /* Layout */
  --shell-max: 1240px;
}

.cda-header .logo, img.logo {
border-radius: 10px;
}


/* ---------------------------------------------------------------------
   2. BASE TYPOGRAPHY + CONTRAST
   --------------------------------------------------------------------- */
body, p, ul, li, .oxy-rich-text { font-family: var(--font-body); }
.ftour-h1, h1, h2, h3, h4, .fs-0, .fs-1, .fs-2, .fs-3, .fs-4 { font-family: var(--font-display); }
body, p, .oxy-rich-text { color: var(--text-body); }

/* Accent teal is a fill/border/icon colour — never small text on light */
.btn-primary, .btn-primary-lx, .btn-primary *, .btn-primary-lx * { color: var(--color-dark); }

/* ---------------------------------------------------------------------
   3. LAYOUT PRIMITIVES
   --------------------------------------------------------------------- */
/* Section vertical rhythm (applied to a ct_section element) */
.cda-section > .ct-section-inner-wrap { padding-top: var(--section-y); padding-bottom: var(--section-y); }
.cda-section--sm > .ct-section-inner-wrap { padding-top: clamp(40px,5vw,72px); padding-bottom: clamp(40px,5vw,72px); }
.cda-section--flush > .ct-section-inner-wrap { padding-top: 0; padding-bottom: 0; }
.cda-section--tint { background-color: var(--color-light-bg); }
.cda-section--soft { background: linear-gradient(180deg, #ffffff 0%, var(--color-light-bg) 100%); }
.cda-section--dark { background-color: var(--color-dark); }
.cda-section--dark,
.cda-section--dark :is(p, li, a, span, .ct-text-block, .ct-headline) { color: #cbd5e1; }
.cda-section--dark :is(h1,h2,h3,h4,h5,h6) { color: #ffffff; }

/* Responsive grid */
.cda-grid { display: grid; gap: clamp(20px, 2.4vw, 32px); grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); align-items: stretch; }
.cda-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.cda-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.cda-grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

/* Two-column media / content split */
.cda-split { display: flex; align-items: center; gap: clamp(28px, 5vw, 72px); }
.cda-split--reverse { flex-direction: row-reverse; }
.cda-split--top { align-items: flex-start; }
.cda-split > * { flex: 1 1 50%; min-width: 0; }

/* Vertical stack helper */
.cda-stack { display: flex; flex-direction: column; gap: var(--space-4); }
.cda-stack--tight { gap: var(--space-2); }
.cda-stack--lg { gap: var(--space-5); }
.cda-stack--center { align-items: center; text-align: center; }

/* Constrained intro / heading block */
.cda-head { max-width: 720px; }
.cda-head--center { margin-left: auto; margin-right: auto; text-align: center; }
.cda-mw-sm { max-width: 540px; }
.cda-mw-md { max-width: 760px; }
.cda-mw-lg { max-width: 960px; }
.cda-center { margin-left: auto; margin-right: auto; }

/* ---------------------------------------------------------------------
   4. TYPOGRAPHY HELPERS
   --------------------------------------------------------------------- */
.cda-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-body); font-size: 13px; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase; color: var(--color-primary);
  margin-bottom: var(--space-3);
}
.cda-eyebrow::before { content: ""; width: 26px; height: 2px; background: var(--color-accent); border-radius: 2px; }
.cda-eyebrow--center { justify-content: center; }

.cda-title { font-family: var(--font-display); font-weight: 600; line-height: 1.15; color: var(--color-secondary); }
.cda-lead  { font-size: clamp(17px, 1.5vw, 20px); line-height: 1.7; color: var(--text-body); }
.cda-muted { color: var(--text-muted); }
.cda-rule  { width: 64px; height: 3px; border: 0; background: var(--color-accent); border-radius: 3px; margin: 0; }
.cda-rule--center { margin-left: auto; margin-right: auto; }

/* ---------------------------------------------------------------------
   5. CARDS
   --------------------------------------------------------------------- */
.cda-card {
  display: flex; flex-direction: column; gap: var(--space-3);
  background: #ffffff; border: 1px solid var(--color-line);
  border-radius: var(--radius-card); padding: clamp(22px, 2.4vw, 32px);
  box-shadow: var(--shadow-sm); height: 100%;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.cda-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: #d8e2ec; }
.cda-card--tint { background: var(--color-light-bg); border-color: transparent; }
.cda-card--flat { box-shadow: none; }
.cda-card--flat:hover { transform: none; box-shadow: var(--shadow-md); }
.cda-card--accent { border-top: 4px solid var(--color-accent); }
.cda-card--dark { background: var(--color-dark-2); border-color: rgba(255,255,255,.08); }
.cda-card--dark, .cda-card--dark :is(p,li,a,span,.ct-text-block) { color: #cbd5e1; }
.cda-card--dark :is(h1,h2,h3,h4,h5,h6,.ct-headline) { color: #ffffff; }
.cda-card__title { font-family: var(--font-display); font-weight: 600; font-size: 22px; line-height: 1.25; color: var(--color-secondary); margin: 0; }
.cda-card__text  { color: var(--text-body); line-height: 1.65; margin: 0; }

/* Icon badge */
.cda-badge { display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 56px; border-radius: 16px; background: rgba(36,93,164,.08); color: var(--color-primary); flex: none; }
.cda-badge svg { width: 26px; height: 26px; }
.cda-badge--accent { background: rgba(45,212,191,.16); color: var(--color-accent-d); }
.cda-badge--round { border-radius: 50%; }
.cda-badge--lg { width: 68px; height: 68px; border-radius: 20px; }

/* Pill / tag */
.cda-pill { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: var(--radius-pill); background: rgba(36,93,164,.08); color: var(--color-primary); font-size: 13px; font-weight: 600; letter-spacing: .02em; }
.cda-pill--accent { background: rgba(45,212,191,.16); color: var(--color-accent-d); }

/* Stat */
.cda-stat__num   { font-family: var(--font-display); font-size: clamp(34px,4vw,48px); font-weight: 700; color: var(--color-primary); line-height: 1; }
.cda-stat__label { font-size: 14px; color: var(--text-muted); text-transform: uppercase; letter-spacing: .08em; margin-top: 6px; }

/* Checklist */
.cda-checks { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.cda-checks li { position: relative; padding-left: 34px; line-height: 1.5; color: var(--text-body); }
.cda-checks li::before {
  content: "\2713"; position: absolute; left: 0; top: 0;
  width: 22px; height: 22px; border-radius: 50%;
  background: rgba(45,212,191,.16); color: var(--color-accent-d);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}

/* Media frame */
.cda-media { border-radius: var(--radius-card); overflow: hidden; box-shadow: var(--shadow-md); }
.cda-media img { display: block; width: 100%; height: 100%; object-fit: cover; }
.cda-media--tall img { max-height: 560px; }

/* ---------------------------------------------------------------------
   6. BUTTONS
   --------------------------------------------------------------------- */
.cda-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-body); font-size: 16px; font-weight: 600; letter-spacing: .01em;
  line-height: 1; text-decoration: none; cursor: pointer;
  padding: 15px 28px; border-radius: var(--radius-button); border: 1.5px solid transparent;
  transition: background-color .2s ease, color .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.cda-btn--primary { background: var(--color-primary); color: #fff; }
.cda-btn--primary:hover { background: var(--color-primary-d); transform: translateY(-2px); box-shadow: 0 10px 24px rgba(36,93,164,.28); }
.cda-btn--accent { background: var(--color-accent); color: var(--color-dark); }
.cda-btn--accent:hover { background: #26bda9; transform: translateY(-2px); box-shadow: 0 10px 24px rgba(45,212,191,.30); }
.cda-btn--ghost { background: transparent; border-color: #cdd9e5; color: var(--color-secondary); }
.cda-btn--ghost:hover { border-color: var(--color-primary); color: var(--color-primary); }
.cda-btn--light { background: #fff; color: var(--color-primary); }
.cda-btn--light:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,.18); }
.cda-btn--lg { padding: 18px 36px; font-size: 17px; }
.cda-btn--block { width: 100%; }

/* Existing pill buttons — keep names, refine */
.btn-primary, .btn-primary-lx {
  transition: background-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.btn-primary:hover, .btn-primary-lx:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(45,212,191,.3); }
.ct-link-button { background-color: var(--color-primary); border-color: var(--color-primary); color: #fff; border-radius: var(--radius-button); transition: all .2s ease; }
.ct-link-button:hover { background-color: var(--color-secondary); border-color: var(--color-secondary); transform: translateY(-2px); }

/* ---------------------------------------------------------------------
   7. CTA BAND
   --------------------------------------------------------------------- */
.cda-cta {
  position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent-d) 100%);
  border-radius: var(--radius-card);
  padding: clamp(48px,6vw,88px) clamp(24px,5vw,72px);
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-4);
}
.cda-cta::after { content: ""; position: absolute; inset: auto -10% -60% auto; width: 420px; height: 420px; background: radial-gradient(circle, rgba(255,255,255,.16), transparent 70%); pointer-events: none; }
.cda-cta, .cda-cta :is(p,li,span,.ct-text-block,.ct-headline,h1,h2,h3,h4) { color: #ffffff; position: relative; }

/* ---------------------------------------------------------------------
   8. HEADER / NAV / FOOTER
   --------------------------------------------------------------------- */
.cda-topbar { background: var(--color-dark); }
.cda-topbar > .ct-section-inner-wrap { padding-top: 9px; padding-bottom: 9px; align-items: center; }
.cda-topbar, .cda-topbar * { color: #e2e8f0; font-size: 14px; letter-spacing: .02em; }
.cda-topbar a:hover { color: var(--color-accent); }

.cda-header { position: -webkit-sticky; position: sticky; top: 0; z-index: 1000; background: #fff;
  box-shadow: 0 1px 0 rgba(15,23,42,.06), 0 6px 24px rgba(15,23,42,.05); transition: box-shadow .25s ease; }
.cda-header > .ct-section-inner-wrap { padding-top: 12px; padding-bottom: 12px; align-items: center; }

.cda-nav .oxy-pro-menu-list .menu-item > a { padding-left: 14px; padding-right: 14px; transition: color .2s ease, border-color .2s ease; }
.cda-nav .oxy-pro-menu-list .menu-item:hover > a,
.cda-nav .oxy-pro-menu-list .menu-item.current-menu-item > a { color: var(--color-primary); border-color: var(--color-accent); }

.cda-footer { background: var(--color-dark); }
.cda-footer, .cda-footer :is(p,li,span,.ct-text-block,.ct-headline) { color: #cbd5e1; }
.cda-footer a { color: #cbd5e1; transition: color .2s ease; }
.cda-footer a:hover { color: var(--color-accent); }
.cda-footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 48px; width: 100%; }
.cda-footer__title { display: inline-block; color: #fff; font-family: var(--font-body); font-weight: 600; font-size: 13px; text-transform: uppercase; letter-spacing: .08em; border-bottom: 1px solid var(--color-accent); padding-bottom: 8px; margin-bottom: 6px; }
.cda-footer__bottom { border-top: 1px solid rgba(255,255,255,.12); margin-top: var(--space-5); padding-top: var(--space-4); }
.cda-footer__bottom, .cda-footer__bottom * { color: #94a3b8; font-size: 14px; }
.cda-footer iframe { width: 100%; min-height: 220px; border-radius: var(--radius-card); border: 1px solid rgba(255,255,255,.12); }

/* Socials (kept) */
.seopress-socials-svg { display: flex; gap: 8px; list-style: none; padding-left: 0; align-items: center; }
.seopress-socials-svg li { width: 32px; height: 32px; background: var(--color-accent); border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: all .4s ease; }
.seopress-socials-svg li svg { width: 18px; height: 18px; color: var(--color-secondary); display: block; }
.seopress-socials-svg li:hover { opacity: .85; transform: translateY(-2px); }

.text-white, .text-white a { color: #fff !important; }
.text-dark, .text-dark a { color: var(--color-primary) !important; }

/* ---------------------------------------------------------------------
   9. SERVICE SECTIONS REPEATER (.ss-* — Single Service ACF list)
   --------------------------------------------------------------------- */
.ss-row { display: flex; align-items: center; gap: clamp(24px, 4vw, 64px); }
#_dynamic_list-201-73 > .ct-code-block:not(:last-child) { display: block; margin-bottom: clamp(40px, 6vw, 80px); }
#_dynamic_list-201-73 > .ct-code-block:nth-child(even) .ss-row { flex-direction: row-reverse; }
.ss-media { flex: 1 1 50%; }
.ss-media img { width: 100%; max-height: 420px; object-fit: cover; border-radius: var(--radius-card); display: block; }
.ss-body { flex: 1 1 50%; }
.ss-title { font-family: var(--font-display); font-size: clamp(24px,3vw,34px); font-weight: 600; line-height: 1.2; color: var(--text-body); margin: 0 0 var(--space-3); }
.ss-text { color: var(--text-body); line-height: 1.7; }
.ss-text p { margin: 0 0 var(--space-3); }
.ss-text > :last-child { margin-bottom: 0; }
.ct-section:has(> .ct-section-inner-wrap > #_dynamic_list-201-73:empty) { display: none; }

/* ---------------------------------------------------------------------
   10. A11Y + MOTION
   --------------------------------------------------------------------- */
a:focus-visible, button:focus-visible, .ct-link:focus-visible,
input:focus-visible, textarea:focus-visible, select:focus-visible {
  outline: 2px solid var(--color-primary); outline-offset: 2px; border-radius: 2px;
}@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; }
  .cda-card:hover, .cda-btn:hover, .btn-primary:hover, .btn-primary-lx:hover { transform: none; }}


/* ---------------------------------------------------------------------
   11. RESPONSIVE
   --------------------------------------------------------------------- */
@media (max-width: 991px) {
  .cda-grid--3, .cda-grid--4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cda-footer__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  /* Pro Menu collapse to hamburger (markup/JS already present) */
  .cda-nav .oxy-pro-menu-mobile-open-icon { display: inline-flex; }
  .cda-nav .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .oxy-pro-menu-list { display: none; }
  .cda-nav .oxy-pro-menu-open-container .oxy-pro-menu-list,
  .cda-nav .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list { display: flex; }}@media (max-width: 767px) {
  .cda-split, .cda-split--reverse { flex-direction: column; }
  .cda-split > * { width: 100%; flex-basis: auto; }
  .cda-grid--2, .cda-grid--3, .cda-grid--4 { grid-template-columns: 1fr; }
  .cda-topbar { display: none; }
  .cda-footer__grid { grid-template-columns: 1fr; text-align: center; gap: var(--space-5); }
  .cda-footer__grid .ct-div-block { align-items: center; }
  .ss-row, #_dynamic_list-201-73 > .ct-code-block:nth-child(even) .ss-row { flex-direction: column; }
  .ss-media, .ss-body { width: 100%; flex-basis: auto; }
  .ss-media img { max-height: 280px; }
  div.ct-section-inner-wrap { padding-left: 18px; padding-right: 18px; }}@media (max-width: 480px) {
  .cda-footer__bottom { flex-direction: column; gap: 6px; text-align: center; }}



/* =====================================================================
   LEGACY #ID OVERRIDES — being migrated to .cda-* classes.
   Each block below is removed as its template/page is converted.
   ===================================================================== */

/* =====================================================================
   HOMEPAGE + SHARED TEMPLATE POLISH   (page 21 + template 19)
   Loads after 21.css / 19.css, so matched #id selectors win by source
   order. Layout/colors/fonts unchanged in spirit — this only makes the
   per-element hardcoded styling consistent and accessible.
   ===================================================================== */

/* ----- 1. Typography: one coherent scale + weights ----- */

/* Hero H1 — responsive{
  font-size: clamp(36px, 5vw, 55px);
  font-weight: 600;
  line-height: 1.15;
}
#headline-221-19 {
  font-size: clamp(28px, 3.6vw, 42px);
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: var(--space-3);
}/* Insurance / Financing sub-headings had NO size set — give them a real size */
/* Card / sub titles — were a thin weight-300 24px (read weak & low-contrast) */

/* Title on the dark image card stays white{
  font-weight: 600;
}

/* Eyebrow labels — unify size/spacing across every section{
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--color-primary);
  padding-bottom: 4px;
}

/* Body copy — consistent readable color + rhythm */
#text_block-6-21,
#text_block-39-21,
#text_block-51-21,
#text_block-146-21,
#text_block-150-21,
#text_block-154-21,
#text_block-416-21 {
  color: var(--text-body);
  line-height: 1.7;
}/* ----- 2. Spacing rhythm: even vertical padding on content sections ----- */


/* Slightly roomier{
  padding: var(--space-4);
}

/* Center + constrain the sparse Insurance block so it doesn't read as empty */
#div_block-333-21,
#div_block-379-21 {
  margin-left: auto;
  margin-right: auto;
}

/* ----- 3. Contrast / visibility (WCAG AA) ----- */

/* Final CTA: white text sat on a gradient that ended on light teal #2dd4bf
   (~1.6:1{
  background-image: linear-gradient(135deg, #245da4, #0e7c70);
}

/* Buttons are now a teal→navy blend → keep inner labels WHITE for AA contrast
   (needs !important to stay consistent with .text-white and beat base rules). */
.btn-primary .text-white,
.btn-primary-lx .text-white,
.btn-primary.text-white,
.btn-primary-lx.text-white,
.btn-primary .ct-text-block,
.btn-primary-lx .ct-text-block {
  color: #fff !important;
}
#div_block-268-21 {
  align-items: stretch;
}

/* ----- 5. Mobile: tighten section padding ----- */



/* =====================================================================
   HEADER + FOOTER REDESIGN + FULL RESPONSIVENESS   (template 19 + page 21)
   Premium dark footer, brand-accent top bar, sticky header{
  background-color: var(--color-dark);
}/* ----- B. Header -> premium + sticky (#section-2-19) ----- */
/* keep the sticky header below the WP admin bar for logged-in users */


/* Nav links: accent hover/active underline */
[id="-pro-menu-282-19"] .oxy-pro-menu-list .menu-item > a {
  transition: color 0.2s ease, border-color 0.2s ease;
  padding-left: 14px;
  padding-right: 14px;
}
[id="-pro-menu-282-19"] .oxy-pro-menu-list .menu-item:hover > a,
[id="-pro-menu-282-19"] .oxy-pro-menu-list .menu-item.current-menu-item > a {
  color: var(--color-primary);
  border-color: var(--color-accent);
}/* ----- C. Footer -> premium dark (#section-180-19 / grid #div_block-184-19) ----- */

/* Light text across the footer columns + bottom bar (NOT the CTA card{
  color: #e2e8f0;
}

/* Column headings keep their teal underline{
  color: #ffffff;
  font-weight: 600;
}

/* Footer logo is full-colour -> render solid white so it reads on navy */

/* Framed{
  width: 100%;
  min-height: 220px;
  border-radius: var(--radius-card);
  border: 1px solid rgba(255, 255, 255, 0.12);
}/* Bottom copyright bar: hairline divider + muted text */


/* ----- D. High-end micro-polish (tasteful{
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.ct-link-button,
.btn-primary,
.btn-primary-lx {
  transition: background-color 0.2s ease, border-color 0.2s ease,
              transform 0.2s ease, box-shadow 0.2s ease;
}
.ct-link-button:hover,
.btn-primary:hover,
.btn-primary-lx:hover {
  transform: translateY(-2px);
}
/* Keyboard focus visibility (a11y) */
a:focus-visible,
button:focus-visible,
.ct-link:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
  border-radius: 2px;
}

/* =====================================================================
   E. RESPONSIVENESS — Oxygen breakpoints 992 / 768 / 480
   ===================================================================== */

/* ---- Tablet & below (<= 992px) ---- */
@media (max-width: 992px) {
  /* Collapse the Pro Menu to the hamburger (no collapse point existed).
     Off-canvas markup + JS are already present; we just show the toggle
     and hide the inline list, re-showing it only when the overlay opens. */
  [id="-pro-menu-282-19"] .oxy-pro-menu-mobile-open-icon { display: inline-flex; }
  [id="-pro-menu-282-19"] .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .oxy-pro-menu-list {
    display: none;
  }
  [id="-pro-menu-282-19"] .oxy-pro-menu-open-container .oxy-pro-menu-list,
  [id="-pro-menu-282-19"] .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list {
    display: flex;
  }/* Services section: 40/60 split stacks */
}

/* ---- Phone landscape & below (<= 768px) ---- */
@media (max-width: 768px) {/* Hide the top utility bar to declutter */


  /* Hero: stop the fixed 900px height, ease the top padding */
  #section-3-21 { height: auto; max-height: none; min-height: 540px; }
  #section-3-21 > .ct-section-inner-wrap {
    flex-direction: column;
    padding-top: 96px;
  }
  #section-3-21 > .ct-section-inner-wrap > * { width: 100%; }
  #div_block-22-21 { width: 100%; }/* Services 2-col grid -> single column */
/* Insurance / generic two-column rows stack & center */


  /* Footer -> single column{
    grid-template-columns: 1fr;
    text-align: center;
    gap: var(--space-5);
  }/* CTA card: lighter vertical padding on small screens */


  /* Comfortable side gutters everywhere */
  div.ct-section-inner-wrap { padding-left: 18px; padding-right: 18px; }}

/* ---- Phone portrait (<= 480px) ---- */
@media (max-width: 480px) {
  #section-3-21 > .ct-section-inner-wrap { padding-top: 84px; }/* Stack the bottom copyright bar */
}
/* =====================================================================
   ATMOSPHERE · ARCH MOTIF · MOTION   (v3 add-on, class-based, global)
   Layered backgrounds, one signature arch shape, and disciplined motion.
   All ornaments are pointer-events:none; all motion respects
   prefers-reduced-motion. Palette/tokens unchanged.
   ===================================================================== */

/* ---------- A1. Film-grain overlay (whole page, static) ---------- */
body.oxygen-body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9998;
  mix-blend-mode: multiply;
  opacity: .045;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- A2. Stacking base for section ornaments ---------- */
.cda-section { position: relative; isolation: isolate; }
.cda-section > .ct-section-inner-wrap { position: relative; z-index: 1; }

/* ---------- A3. Accent glows (auto on tint/dark sections) ---------- */
.cda-section--tint::before,
.cda-section--dark::before {
  content: "";
  position: absolute;
  z-index: -1;
  pointer-events: none;
  width: 540px; height: 540px;
  top: -140px; right: -90px;
  border-radius: 50%;
}
.cda-section--tint::before { background: radial-gradient(circle at center, rgba(45,212,191,.13), transparent 70%); }
.cda-section--dark::before {
  top: auto; bottom: -180px; right: auto; left: -120px;
  width: 620px; height: 620px;
  background: radial-gradient(circle at center, rgba(36,93,164,.55), transparent 70%);
}

/* ---------- A4. Concentric hairline rings ornament (REMOVED per request) ---------- */
/* Keep heroes' base containment; ring ::after pseudo-elements removed from all sections. */
#section-3-21, #section-2-73 { position: relative; isolation: isolate; overflow: hidden; }

/* ---------- A5. Precision dot grid ornament ---------- */
.cda-dots { position: relative; isolation: isolate; }
.cda-dots::before {
  content: "";
  position: absolute;
  z-index: -1;
  pointer-events: none;
  inset: 0;
  color: var(--color-primary);
  opacity: .06;
  background-image: radial-gradient(currentColor 1px, transparent 1.6px);
  background-size: 22px 22px;
  -webkit-mask: radial-gradient(ellipse at 50% 0%, #000, transparent 72%);
          mask: radial-gradient(ellipse at 50% 0%, #000, transparent 72%);
}
/* dot grid reads on dark too */
.cda-section--dark.cda-dots::before,
.cda-cta.cda-dots::before { color: #ffffff; opacity: .07; }

/* =====================================================================
   C. MOTION
   ===================================================================== */
@keyframes cdaRise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: none; } }
@keyframes cdaFade { from { opacity: 0; } to { opacity: 1; } }

/* C1. One-time page-load sequence (CSS only; runs on every page header,
   plus a staggered entrance on the two hero types). */
@media (prefers-reduced-motion: no-preference) {
  .cda-header .oxy-logo, .cda-header > .ct-section-inner-wrap > .ct-link { animation: cdaRise .6s .04s both; }
  .cda-header .cda-nav { animation: cdaRise .6s .12s both; }
  .cda-header .btn-primary { animation: cdaRise .6s .20s both; }

  #section-3-21 .cda-eyebrow, #section-2-73 .cda-eyebrow { animation: cdaRise .7s .24s both; }
  #section-3-21 .cda-title,   #section-2-73 .cda-title   { animation: cdaRise .7s .34s both; }
  #section-3-21 .cda-lead,    #section-2-73 .cda-lead,
  #section-3-21 .ct-text-block { animation: cdaRise .7s .44s both; }
  #section-3-21 .btn-primary-lx, #section-3-21 .btn-primary,
  #section-2-73 .btn-primary-lx { animation: cdaRise .7s .54s both; }
}

/* C2. Scroll reveals (JS adds html.js-reveal + .reveal/.is-in) */
html.js-reveal .reveal { opacity: 0; transform: translateY(24px); will-change: opacity, transform; }
html.js-reveal .reveal.is-in {
  opacity: 1; transform: none;
  transition: opacity .7s ease, transform .7s ease;
}

/* C3. Reduced-motion: kill all entrance motion, show everything */
@media (prefers-reduced-motion: reduce) {
  .reveal, html.js-reveal .reveal { opacity: 1 !important; transform: none !important; }
  .cda-header .oxy-logo, .cda-header .cda-nav, .cda-header .btn-primary,
  #section-3-21 [class*="cda-"], #section-2-73 [class*="cda-"],
  #section-3-21 .ct-text-block { animation: none !important; }
}

/* =====================================================================
   WOW INTERACTIONS + MICRO-INTERACTIONS  (v5 add-on)
   Marquee proof strip · hover-expand tiles · gradient ghost wordmark ·
   button/link/card/tick micro-interactions. CSS-only. Touch + reduced-
   motion fallbacks included.
   ===================================================================== */

/* ---------- self-contained section utilities (for code-block sections) ---------- */
.cda-pad   { padding-top: var(--section-y); padding-bottom: var(--section-y); padding-left: 18px; padding-right: 18px; }
.cda-shell { max-width: var(--shell-max); margin-left: auto; margin-right: auto; position: relative; }

/* ====================== WOW #2/#3 — GALLERY: GHOST + TILES ====================== */
.cda-gallery { position: relative; overflow: hidden; isolation: isolate; }

.cda-gallery .cda-shell > * { position: relative; z-index: 1; }

.cda-tiles { display: flex; gap: 14px; align-items: stretch; }
.cda-tile {
  position: relative;
  flex: 1 1 0; min-width: 0;
  height: clamp(320px, 42vw, 460px);
  border-radius: var(--radius-card);
  overflow: hidden;
  transition: flex .55s cubic-bezier(.4, 0, .2, 1);
  cursor: pointer;
}
.cda-tile img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .6s ease;
}
.cda-tile::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(11,33,61,.82), rgba(11,33,61,.12) 46%, transparent 72%);
}
.cda-tile__label { position: absolute; left: 22px; right: 22px; bottom: 20px; z-index: 2; color: #fff; }
.cda-tile__title { font-family: var(--font-display); font-weight: 600; font-size: 20px; line-height: 1.2; }
.cda-tile__desc {
  margin-top: 6px; font-size: 14px; line-height: 1.5; color: #e2e8f0;
  max-height: 0; opacity: 0; transform: translateY(12px); overflow: hidden;
  transition: max-height .5s ease, opacity .45s ease, transform .45s ease;
}
@media (hover: hover) {
  .cda-tile:hover { flex: 2.6 1 0; }
  .cda-tile:hover img { transform: scale(1.06); }
  .cda-tile:hover .cda-tile__desc { max-height: 140px; opacity: 1; transform: none; }
}
@media (hover: none) {
  .cda-tiles { display: grid; grid-template-columns: repeat(2, 1fr); }
  .cda-tile { height: 240px; }
  .cda-tile__desc { max-height: 140px; opacity: 1; transform: none; }
}
@media (max-width: 600px) {
  .cda-tiles { display: grid; grid-template-columns: 1fr; }
  .cda-tile { height: 230px; }
  .cda-tile__desc { max-height: 140px; opacity: 1; transform: none; }
}

/* ====================== MICRO-INTERACTIONS ====================== */

/* Buttons: press-down on :active + physical-key top light on primary CTAs */
.btn-primary, .btn-primary-lx, .cda-btn--primary, .ct-link-button { position: relative; }
.btn-primary:active, .btn-primary-lx:active,
.cda-btn--primary:active, .cda-btn:active, .ct-link-button:active {
  transform: translateY(0) !important;
  box-shadow: 0 2px 6px rgba(15, 23, 42, .20) !important;
}
.btn-primary, .btn-primary-lx {
  background-image: linear-gradient(rgba(255,255,255,.22), rgba(255,255,255,0) 46%);
}
.cda-btn--primary {
  background-color: var(--color-primary);
  background-image: linear-gradient(rgba(255,255,255,.18), rgba(255,255,255,0) 46%);
}

/* Links: hairline underline that sweeps in left -> right */
.oxy-rich-text a, .ct-text-block a, .ss-text a, a.ct-text-link, .cda-tile + a {
  text-decoration: none;
  background-image: linear-gradient(currentColor, currentColor);
  background-size: 0% 1px;
  background-position: 0 100%;
  background-repeat: no-repeat;
  padding-bottom: 1px;
  transition: background-size .35s ease, color .2s ease;
}
.oxy-rich-text a:hover, .ct-text-block a:hover, .ss-text a:hover, a.ct-text-link:hover {
  background-size: 100% 1px;
}

/* Cards: top accent tick that sweeps to full width + arrow rotate + image zoom */
.cda-card { position: relative; overflow: hidden; }
.cda-card::before {
  content: ""; position: absolute; top: 0; left: 0; z-index: 2;
  height: 3px; width: 44px;
  background: var(--color-accent);
  opacity: 0;
  transition: width .45s ease, opacity .3s ease;
}
.cda-card:hover::before { width: 100%; opacity: 1; }
.cda-card .oxy-fancy-icon svg, .cda-card .ct-fancy-icon svg { transition: transform .3s ease; }
.cda-card:hover .oxy-fancy-icon svg, .cda-card:hover .ct-fancy-icon svg { transform: rotate(-45deg); }

/* Image zoom inside card / media frames */
.ss-media, .cda-media, .cda-card .ct-image, .cda-card img { overflow: hidden; }
.ss-media img, .cda-media img { transition: transform .6s ease; }
.ss-row:hover .ss-media img, .cda-media:hover img { transform: scale(1.05); }

/* Hover ticks: eyebrow accent line + .cda-rule sweep wider on section hover */
.cda-eyebrow::before { transition: width .4s ease; }
.cda-section:hover .cda-eyebrow::before,
.cda-gallery:hover .cda-eyebrow::before { width: 48px; }
.cda-rule { width: 44px; transition: width .45s ease; }
.cda-section:hover .cda-rule, .cda-gallery:hover .cda-rule { width: 96px; }

/* Logos (dormant utility — ships ready for a future carrier-logo row) */
.cda-logo { filter: grayscale(1); opacity: .7; transition: filter .3s ease, opacity .3s ease; }
.cda-logo:hover { filter: none; opacity: 1; }

/* ====================== REDUCED MOTION ====================== */
@media (prefers-reduced-motion: reduce) {
  .cda-tile, .cda-tile img, .cda-tile__desc { transition: none !important; }
  .oxy-rich-text a, .ct-text-block a, .ss-text a, a.ct-text-link,
  .cda-card::before, .cda-card .oxy-fancy-icon svg, .cda-card .ct-fancy-icon svg,
  .ss-media img, .cda-media img, .cda-eyebrow::before, .cda-rule { transition: none !important; }
}


/* =====================================================================
   PREMIUM HEADER · NAV · DROPDOWN · FOOTER   (v6 — 2026-06-17)
   Appended last in stylesheet id 2 → universal.css loads after 19/21.css,
   so these win at equal specificity. CSS-only, fully reversible.
   ===================================================================== */

/* ---------- Top utility bar: refined, accent hairline ---------- */
.cda-topbar {
  background: linear-gradient(90deg, #0b1220 0%, var(--color-dark) 55%, #13233b 100%);
  border-bottom: 1px solid rgba(45, 212, 191, 0.22);
}
.cda-topbar > .ct-section-inner-wrap { padding-top: 10px; padding-bottom: 10px; }
.cda-topbar, .cda-topbar * { color: #cbd5e1; font-size: 13.5px; letter-spacing: 0.015em; }
.cda-topbar a { transition: color 0.2s ease; }
.cda-topbar a:hover { color: var(--color-accent); }
.cda-topbar .seopress-hours-mini { color: #e2e8f0; }
.cda-topbar .seopress-hours-mini::before {
  content: ""; display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: var(--color-accent); margin-right: 9px; vertical-align: middle;
  box-shadow: 0 0 0 3px rgba(45, 212, 191, 0.18);
}

/* ---------- Header: frosted glass, soft elevation ---------- */
.cda-header {
  background: rgba(255, 255, 255, 0.85);
  -webkit-backdrop-filter: saturate(1.5) blur(14px);
  backdrop-filter: saturate(1.5) blur(14px);
  border-bottom: 1px solid rgba(15, 23, 42, 0.06);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04), 0 12px 30px -16px rgba(15, 23, 42, 0.18);
}
.cda-header > .ct-section-inner-wrap { padding-top: 14px; padding-bottom: 14px; }
.cda-header .logo { transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1); will-change: transform; }
.cda-header a:hover .logo { transform: scale(1.03); }

/* ---------- Nav: center-grow gradient underline + caret motion ---------- */
.cda-nav .oxy-pro-menu-list > .menu-item > a {
  position: relative;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: var(--color-secondary);
  border-bottom-color: transparent !important;
}
.cda-nav .oxy-pro-menu-list > .menu-item > a::after {
  content: ""; position: absolute; left: 14px; right: 14px; bottom: 0; height: 2px;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
  border-radius: 2px; transform: scaleX(0); transform-origin: center;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.cda-nav .oxy-pro-menu-list > .menu-item:hover > a,
.cda-nav .oxy-pro-menu-list > .menu-item.current-menu-item > a { color: var(--color-primary); }
.cda-nav .oxy-pro-menu-list > .menu-item:hover > a::after,
.cda-nav .oxy-pro-menu-list > .menu-item.current-menu-item > a::after { transform: scaleX(1); }
.cda-nav .oxy-pro-menu-list > .menu-item-has-children > a svg { transition: transform 0.25s ease; }
.cda-nav .oxy-pro-menu-list > .menu-item-has-children:hover > a svg { transform: rotate(180deg); }

/* ---------- Dropdown: floating white card, rounded tinted rows ----------
   Override Oxygen defaults (#f8f8f8 box / full-bleed teal). Selector mirrors
   the default container chain for equal specificity; source order wins.       */
#-pro-menu-282-19 .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .sub-menu {
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.07);
  border-radius: 16px;
  padding: 8px;
  margin-top: 0;
  min-width: 244px;
  box-shadow: 0 22px 55px -16px rgba(15, 23, 42, 0.26), 0 6px 16px rgba(15, 23, 42, 0.06);
}
#-pro-menu-282-19 .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .sub-menu .menu-item a {
  background: transparent;
  color: var(--color-secondary);
  font-size: 15px;
  font-weight: 500;
  text-align: left;
  justify-content: flex-start;
  padding: 11px 16px;
  border-radius: 10px;
  transition: background-color 0.18s ease, color 0.18s ease, padding-left 0.18s ease;
}
#-pro-menu-282-19 .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .sub-menu .menu-item a:hover,
#-pro-menu-282-19 .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .sub-menu .menu-item a:focus-within {
  background: var(--color-light-bg, #f6f9fc);
  color: var(--color-primary);
  padding-left: 20px;
}

/* ---------- Footer: top accent line, link slide, premium socials ---------- */
.cda-footer { position: relative; background: linear-gradient(180deg, var(--color-dark) 0%, #0b1120 100%); }
.cda-footer::after {
  content: ""; position: absolute; left: 0; right: 0; top: 0; height: 3px; pointer-events: none;
  background: linear-gradient(90deg, transparent, var(--color-accent), var(--color-primary), transparent);
  opacity: 0.7;
}
.cda-footer__title { transition: border-color 0.25s ease; }
.cda-footer__grid a { transition: color 0.2s ease, padding-left 0.2s ease; }
.cda-footer__grid li a:hover { color: #ffffff; padding-left: 4px; }

.cda-footer .seopress-socials-svg li {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.14);
  transition: background-color 0.25s ease, border-color 0.25s ease, transform 0.25s ease;
}
.cda-footer .seopress-socials-svg li svg { color: #cbd5e1; }
.cda-footer .seopress-socials-svg li:hover {
  background: var(--color-accent); border-color: var(--color-accent); transform: translateY(-3px); opacity: 1;
}
.cda-footer .seopress-socials-svg li:hover svg { color: var(--color-dark); }
.cda-footer__bottom { border-top: 1px solid rgba(255, 255, 255, 0.1); }

/* Reduced motion: neutralise the added micro-interactions */
@media (prefers-reduced-motion: reduce) {
  .cda-header a:hover .logo,
  .cda-nav .oxy-pro-menu-list > .menu-item-has-children:hover > a svg,
  .cda-footer .seopress-socials-svg li:hover { transform: none; }
  .cda-nav .oxy-pro-menu-list > .menu-item > a::after { transition-duration: 0.01ms; }
}


/* =====================================================================
   PREMIUM BUTTONS + NAV BREAKPOINTS + MOBILE   (v7 — 2026-06-17)
   Appended after v6 → wins by source order. CSS-only, reversible.
   ===================================================================== */

/* ---------- A. Premium gradient buttons — "Teal → navy blend" ----------
   Brand accent teal flows diagonally into brand navy (#245da4). White label
   (with a faint shadow) over a sheen→darken top layer; stops are biased so the
   centre — under the centred text — stays dark enough for AA white text. */
.btn-primary, .btn-primary-lx, .cda-btn--accent {
  border: none;
  color: #fff;
  background-color: #1f5390; /* solid fallback (navy, AA with white) */
  background-image:
    linear-gradient(180deg, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.02) 46%, rgba(0,0,0,0.12) 100%),
    linear-gradient(120deg, #23bcbf 0%, #1a86ad 38%, #1f5390 100%);
  text-shadow: 0 1px 2px rgba(8,28,56,0.30);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.30),
    inset 0 -1px 0 rgba(8,28,56,0.38),
    0 2px 4px -1px rgba(12,38,74,0.35),
    0 12px 28px -8px rgba(31,83,144,0.50);
  transition: background-image 0.25s ease, box-shadow 0.25s ease, transform 0.2s ease, filter 0.25s ease;
}
.btn-primary:hover, .btn-primary-lx:hover, .cda-btn--accent:hover {
  background-image:
    linear-gradient(180deg, rgba(255,255,255,0.24) 0%, rgba(255,255,255,0.04) 46%, rgba(0,0,0,0.10) 100%),
    linear-gradient(120deg, #2fcccb 0%, #2095bd 38%, #2a68b4 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.40),
    inset 0 -1px 0 rgba(8,28,56,0.36),
    0 3px 6px -1px rgba(12,38,74,0.35),
    0 18px 34px -10px rgba(31,83,144,0.58);
  transform: translateY(-2px);
  filter: saturate(1.04);
}
.btn-primary:active, .btn-primary-lx:active, .cda-btn--accent:active {
  transform: translateY(0);
  box-shadow:
    inset 0 1px 2px rgba(8,28,56,0.45),
    inset 0 1px 0 rgba(255,255,255,0.14),
    0 2px 6px rgba(12,38,74,0.40);
}
/* Labels / nested phone links are now white on the teal→navy blend */
.btn-primary, .btn-primary-lx, .cda-btn--accent,
.btn-primary *, .btn-primary-lx *, .cda-btn--accent *,
.btn-primary a, .btn-primary-lx a,
.btn-primary-lx .call-btn, .btn-primary .call-btn { color: #fff; }
.cda-btn--accent { transition: background-image 0.25s ease, box-shadow 0.25s ease, transform 0.2s ease, filter 0.25s ease; }

/* Blue buttons → parallel dimensional treatment, white text */
.cda-btn--primary, .ct-link-button {
  border: none;
  color: #fff;
  background-color: #1b4a85;
  background-image:
    linear-gradient(180deg, rgba(255,255,255,0.26) 0%, rgba(255,255,255,0.04) 44%, rgba(0,0,0,0.10) 100%),
    linear-gradient(135deg, #3a7ccd 0%, #245da4 50%, #1b4a85 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.32),
    inset 0 -1px 0 rgba(8,28,56,0.40),
    0 2px 4px -1px rgba(12,38,74,0.40),
    0 12px 26px -8px rgba(27,74,133,0.55);
}
.cda-btn--primary:hover, .ct-link-button:hover {
  background-color: #1b4a85;
  background-image:
    linear-gradient(180deg, rgba(255,255,255,0.32) 0%, rgba(255,255,255,0.06) 46%, rgba(0,0,0,0.08) 100%),
    linear-gradient(135deg, #4a8cdb 0%, #2a68b4 50%, #1f5394 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.40),
    inset 0 -1px 0 rgba(8,28,56,0.38),
    0 3px 6px -1px rgba(12,38,74,0.40),
    0 18px 34px -10px rgba(27,74,133,0.62);
  transform: translateY(-2px);
}
.ct-link-button { transition: background-image 0.25s ease, box-shadow 0.25s ease, transform 0.2s ease; }

/* Secondary → refined outline that fills on hover */
.btn-secondary {
  background-color: transparent;
  color: var(--color-primary);
  transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.btn-secondary:hover {
  background-color: var(--color-primary);
  color: #fff;
  box-shadow: 0 10px 24px -6px rgba(36,93,164,0.4);
  transform: translateY(-2px);
}

@media (prefers-reduced-motion: reduce) {
  .btn-primary:hover, .btn-primary-lx:hover,
  .cda-btn--accent:hover, .cda-btn--primary:hover,
  .ct-link-button:hover, .btn-secondary:hover { transform: none; filter: none; }
}

/* ---------- B. Nav: one clean collapse breakpoint (<=1024px) ---------- */
@media (max-width: 1024px) {
  .cda-nav .oxy-pro-menu-mobile-open-icon,
  [id="-pro-menu-282-19"] .oxy-pro-menu-mobile-open-icon { display: inline-flex; }
  .cda-nav .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .oxy-pro-menu-list,
  [id="-pro-menu-282-19"] .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .oxy-pro-menu-list { display: none; }
  .cda-nav .oxy-pro-menu-open-container .oxy-pro-menu-list,
  .cda-nav .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list,
  [id="-pro-menu-282-19"] .oxy-pro-menu-open-container .oxy-pro-menu-list,
  [id="-pro-menu-282-19"] .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list { display: flex; }
}
@media (min-width: 1025px) {
  .cda-nav .oxy-pro-menu-mobile-open-icon { display: none; }
  .cda-nav .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .oxy-pro-menu-list { display: flex; }
}

/* Tidy hamburger trigger into a pill */
.cda-nav .oxy-pro-menu-mobile-open-icon {
  gap: 8px; padding: 9px 16px; border-radius: 999px; font-weight: 600;
  color: var(--color-primary); background: var(--color-light-bg, #f6f9fc);
  border: 1px solid rgba(36,93,164,0.18); cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}
.cda-nav .oxy-pro-menu-mobile-open-icon:hover { background: #eaf1f9; border-color: rgba(36,93,164,0.35); }
.cda-nav .oxy-pro-menu-mobile-open-icon svg { width: 18px; height: 18px; }

/* ---------- C. Desktop dropdown: height-safe for the 8-item Services menu ---------- */
#-pro-menu-282-19 .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .sub-menu {
  min-width: 256px;
  max-height: min(72vh, 540px);
  overflow-y: auto;
  overscroll-behavior: contain;
}

/* ---------- D. Mobile off-canvas / open overlay polish ---------- */
.cda-nav .oxy-pro-menu-open .oxy-pro-menu-container,
.cda-nav .oxy-pro-menu-off-canvas .oxy-pro-menu-container {
  background: linear-gradient(180deg, #ffffff 0%, #f6f9fc 100%);
}
.cda-nav .oxy-pro-menu-open-container .oxy-pro-menu-list,
.cda-nav .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list { gap: 2px; padding: 8px 0; }
.cda-nav .oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item,
.cda-nav .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item {
  border-bottom: 1px solid rgba(15,23,42,0.06);
}
.cda-nav .oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item > a,
.cda-nav .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item > a {
  min-height: 48px; display: flex; align-items: center; justify-content: center;
  font-size: 17px; font-weight: 600; color: var(--color-secondary);
  padding: 12px 20px; width: 100%;
}
.cda-nav .oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item > a:hover,
.cda-nav .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item > a:hover,
.cda-nav .oxy-pro-menu-open-container .oxy-pro-menu-list .current-menu-item > a,
.cda-nav .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .current-menu-item > a { color: var(--color-primary); }
/* Accordion sub-menu: subtle tint + accent left border (replaces dashed default) */
#-pro-menu-282-19 .oxy-pro-menu-dropdown-links-toggle.oxy-pro-menu-open-container .menu-item-has-children ul,
#-pro-menu-282-19 .oxy-pro-menu-dropdown-links-toggle.oxy-pro-menu-off-canvas-container .menu-item-has-children ul {
  background-color: rgba(36,93,164,0.05) !important;
  border-top: none !important;
  border-left: 2px solid var(--color-accent) !important;
}
.cda-nav .oxy-pro-menu-open-container .sub-menu .menu-item > a,
.cda-nav .oxy-pro-menu-off-canvas-container .sub-menu .menu-item > a {
  min-height: 44px; font-size: 15.5px; font-weight: 500; color: var(--color-secondary);
}
/* Close icon */
.cda-nav .oxy-pro-menu-mobile-close-icon { color: var(--color-secondary); padding: 10px; cursor: pointer; }
.cda-nav .oxy-pro-menu-mobile-close-icon svg { width: 22px; height: 22px; }

/* ---------- E. Mobile menu fix: let the open overlay escape the header ----------
   .cda-header has backdrop-filter, which makes it the containing block for its
   position:fixed descendants. That traps the Pro Menu's full-screen open overlay
   inside the sticky header bar, so the links never appear on small screens. The
   toggle JS adds .oxy-nav-menu-prevent-overflow to <body> while the menu is open
   (and removes it on close), so we drop the filter only for that window. */
body.oxy-nav-menu-prevent-overflow .cda-header {
  -webkit-backdrop-filter: none !important;
          backdrop-filter: none !important;
}
/* Belt-and-suspenders: also drop the filter via :has() while the menu is open. */
.cda-header:has(.oxy-pro-menu-open) {
  -webkit-backdrop-filter: none !important;
          backdrop-filter: none !important;
}

/* ---------- F. Mobile menu: force a real full-screen overlay ----------
   The open panel was rendering as a narrow drawer anchored to the screen edge,
   clipping the link labels. It can be EITHER `.oxy-pro-menu-open-container`
   (regular) OR `.oxy-pro-menu-off-canvas-container` (off-canvas) — both only
   exist in the DOM while the menu is open, so targeting the container classes
   directly is safe. Force whichever is active to a centred, full-viewport
   overlay and override the inline width set by oxygen_pro_menu_set_static_width()
   (needs !important to beat inline styles). Scoped to the mobile range. */
@media (max-width: 1024px) {
  .cda-nav .oxy-pro-menu-open-container,
  .cda-nav .oxy-pro-menu-off-canvas-container,
  [id="-pro-menu-282-19"] .oxy-pro-menu-open-container,
  [id="-pro-menu-282-19"] .oxy-pro-menu-off-canvas-container {
    position: fixed !important;
    top: 0 !important; right: 0 !important; bottom: 0 !important; left: 0 !important;
    inset: 0 !important;
    transform: none !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column;
    align-items: center !important;
    justify-content: center !important;
    overflow-y: auto !important;
    background: linear-gradient(180deg, #ffffff 0%, #f6f9fc 100%) !important;
  }
  /* ROOT CAUSE of the off-screen/clipped overlay: the nav's finished `cdaRise`
     entrance animation leaves an identity-matrix `transform` on the nav, which
     makes it the containing block for the overlay's `position:fixed` and offsets
     it ~one-nav-width to the right (off-screen). A finished animation overrides
     inline/!important `transform`, so we must drop the ANIMATION while open. */
  .cda-nav.oxy-pro-menu-open,
  [id="-pro-menu-282-19"].oxy-pro-menu-open { animation: none !important; }
  .cda-nav .oxy-pro-menu-open-container > div:first-child,
  .cda-nav .oxy-pro-menu-off-canvas-container > div:first-child,
  [id="-pro-menu-282-19"] .oxy-pro-menu-open-container > div:first-child,
  [id="-pro-menu-282-19"] .oxy-pro-menu-off-canvas-container > div:first-child {
    width: auto !important;
    min-width: 0 !important;
    max-width: 92vw !important;
    margin: auto !important;
  }
  .cda-nav .oxy-pro-menu-open-container .oxy-pro-menu-list,
  .cda-nav .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list {
    width: 100% !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .cda-nav .oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item,
  .cda-nav .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item,
  .cda-nav .oxy-pro-menu-open-container .oxy-pro-menu-list .menu-item > a,
  .cda-nav .oxy-pro-menu-off-canvas-container .oxy-pro-menu-list .menu-item > a {
    width: 100% !important;
    white-space: normal !important;
    text-align: center !important;
    justify-content: center !important;
  }
}


/* === MOBILE HEADER FIX 2026-06-18: bottom-fixed CTA, no overlap/overflow, logo restored === */
/* a) Kill right-side horizontal overflow globally (clip, not hidden -> preserves position:sticky header) */
html, body { overflow-x: clip; }

/* b) Phone: move the primary CTA to a fixed bottom bar so the header row fits */
@media (max-width: 767px) {
  .cda-header > .ct-section-inner-wrap { gap: 12px; flex-wrap: nowrap; }
  /* logo stays visible, sized to fit */
  .cda-header > .ct-section-inner-wrap > .ct-link:not(.btn-primary) { flex: 0 1 auto; }
  .cda-header .logo, img.logo { max-height: 44px; width: auto; }

  /* the "Book an appointment" button -> full-width bar pinned to bottom */
  .cda-header .btn-primary {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 1090;
    border-radius: 0; justify-content: center; text-align: center;
    padding: 14px 16px; margin: 0;
    box-shadow: 0 -6px 20px rgba(15,23,42,.18);
  }
  /* stop the bottom bar from covering page content / footer */
  body { padding-bottom: 64px; }
  /* when the mobile menu overlay is open, hide the bottom CTA so it doesn't sit over the overlay */
  body.oxy-nav-menu-prevent-overflow .cda-header .btn-primary,
  .cda-header:has(.oxy-pro-menu-open) .btn-primary { display: none; }
}

/* === DESKTOP SUBMENU FIX 2026-06-19: 3rd-level fly-out sub-menus were clipped by the scrollable
   2nd-level dropdown (overflow-y:auto -> forces overflow-x:auto). Allow the
   dropdowns to overflow visibly on desktop so nested fly-outs are not cut off. === */
@media (min-width: 1025px) {
  #-pro-menu-282-19 .oxy-pro-menu-container:not(.oxy-pro-menu-open-container):not(.oxy-pro-menu-off-canvas-container) .sub-menu {
    overflow: visible !important;
    max-height: none !important;
  }
}