.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: 1366px;
}
body {font-family: 'General Sans';}body {line-height: ;font-size:  ;font-weight: ;color: ;}.oxy-nav-menu-hamburger-line {background-color: ;}h1, h2, h3, h4, h5, h6 {font-family: 'Satoshi';}a {text-decoration: none;}a:hover {text-decoration: none;}.ct-link-text {text-decoration: none;}.ct-link-text:hover {text-decoration: none;}.ct-link {text-decoration: none;}.ct-link:hover {text-decoration: none;}.ct-link-button {border-radius: px;}.ct-section-inner-wrap {
}.ct-new-columns > .ct-div-block {
}.oxy-header-container {
}@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_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-right:32px;
}
@media (max-width: 767px) {
.oxel_iconlist__row__icon {
 margin-right:12px;
}
}

.oxel_iconlist__row__label {
}
.oxel_iconlist__row--dark {
 background-color:#eceeef;
}
.oxel-image-accordion {
}
.oxel-image-accordion:not(.ct-section):not(.oxy-easy-posts),
.oxel-image-accordion.oxy-easy-posts .oxy-posts,
.oxel-image-accordion.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
}
@media (max-width: 767px) {
.oxel-image-accordion {
 height:600px;
}
.oxel-image-accordion:not(.ct-section):not(.oxy-easy-posts),
.oxel-image-accordion.oxy-easy-posts .oxy-posts,
.oxel-image-accordion.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
}
}

.oxel-image-accordion__item {
 position:relative;
 height:400px;
 overflow:hidden;
 transition-duration:0.6s;
 transition-timing-function:cubic-bezier(.69,.05,.67,.88);
 transition-property:all;
}
@media (max-width: 767px) {
.oxel-image-accordion__item {
 height:auto;
}
}

.oxel-image-accordion__details {
 z-index:10;
 position:absolute;
 left:18px;
 bottom:16px;
 width:10000px;
}
.oxel-image-accordion__details:not(.ct-section):not(.oxy-easy-posts),
.oxel-image-accordion__details.oxy-easy-posts .oxy-posts,
.oxel-image-accordion__details.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
align-items:center;
}
@media (max-width: 767px) {
.oxel-image-accordion__details {
 position:absolute;
 bottom:8px;
 left:8px;
}
}

.oxel-image-accordion__icon {
background-color: #f9f9fa;
border: 1px solid #f9f9fa;
padding: 10px;color: #374047;}.oxel-image-accordion__icon 
>svg {width: 14px;height: 14px;}.oxel-image-accordion__icon {
 margin-right:16px;
}
@media (max-width: 767px) {
.oxel-image-accordion__icon {
padding: 6px;}.oxel-image-accordion__icon {
}
}

.oxel-image-accordion__link {
 color:#f9f9fa;
}
.oxel-image-accordion__image {
 position:absolute;
 width:100%;
 height:100%;
}
.oxel_section_indicator {
 position:fixed;
 right:0px;
 top:0px;
 bottom:0px;
 width:30px;
 z-index:10;
 padding-left:8px;
 padding-right:32px;
}
.oxel_section_indicator:not(.ct-section):not(.oxy-easy-posts),
.oxel_section_indicator.oxy-easy-posts .oxy-posts,
.oxel_section_indicator.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
justify-content:center;
}
.oxel_section_indicator__dot {
 width:16px;
 height:16px;
 background-color:#606e79;
 border-radius:50%;
 margin-top:12px;
 margin-bottom:12px;
 color:#f9f9fa;
 transition-duration:0.3s;
 transition-timing-function:ease-in-out;
min-height: 0px !important; min-width: 0px !important;
}
.oxel_section_indicator__dot:not(.ct-section):not(.oxy-easy-posts),
.oxel_section_indicator__dot.oxy-easy-posts .oxy-posts,
.oxel_section_indicator__dot.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
justify-content:center;
}
.oxel_section_indicator__label:after{
transform:rotate(45deg); position:absolute;
 width:16px;
 height:16px;
 background-color:#606e79;
 right:-6px;
 z-index:-1;
 border-top-right-radius:4px;
 border-top-left-radius:0px;
 border-bottom-left-radius:0px;
 border-bottom-right-radius:0px;
 border-radius:0px;
  content:"";
}
.oxel_section_indicator__label {
 position:absolute;
 padding-top:4px;
 padding-bottom:4px;
 padding-left:16px;
 padding-right:16px;
 background-color:#606e79;
 border-radius:0px;
 transition-duration:0.3s;
 transition-timing-function:ease-in-out;
 right:calc(100% + 8px) ;
}
.oxel_section_indicator__label:not(.ct-section):not(.oxy-easy-posts),
.oxel_section_indicator__label.oxy-easy-posts .oxy-posts,
.oxel_section_indicator__label.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
justify-content:center;
}
.oxel_section_indicator__label__text {
 color:#f9f9fa;
}
.oxel_section_indicator__label--hidden {
transform:translate(112px); opacity:0;
}
.cell {
}
.oxel_number_counter {
}
.oxel_number_counter__number {
 font-family:Satoshi;
}
.oxel_logo_slider {
 width:100%;
 position:relative;
 overflow:hidden;
 background-color:#ffffff;
 text-align:center;
}
.oxel_logo_slider:not(.ct-section):not(.oxy-easy-posts),
.oxel_logo_slider.oxy-easy-posts .oxy-posts,
.oxel_logo_slider.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
}
.oxel_logo_slider__logo {
 transition-duration:0.3s;
 transition-timing-function:ease-in-out;
 width:20%;
 height:100px;
 text-align:center;
 padding-top:16px;
 padding-left:16px;
 padding-right:16px;
 padding-bottom:16px;
}
.oxel_logo_slider__logo:not(.ct-section):not(.oxy-easy-posts),
.oxel_logo_slider__logo.oxy-easy-posts .oxy-posts,
.oxel_logo_slider__logo.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
}
.oxel_logo_slider__image_carrier {
 width:100%;
 text-align:left;
 flex-shrink:0;
 transition-duration:0.1s;
 transition-timing-function:linear;
}
.oxel_logo_slider__image_carrier:not(.ct-section):not(.oxy-easy-posts),
.oxel_logo_slider__image_carrier.oxy-easy-posts .oxy-posts,
.oxel_logo_slider__image_carrier.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
align-items:center;
justify-content:flex-start;
}
.oxel_logo_slider__image_carrier--delay {
}
.section {
}
.section--light {
}
.stagger-container {
}
.container {
}
.sticky-parent {
}
.sticky {
}
.has-fade-in {
}
@media (max-width: 767px) {
.has-fade-in {
}
}

.mb-3-0 {
}
.faq-accordion {
 margin-bottom:0.5rem;
}
.faq-accordion .oxy-pro-accordion_header{
background-color:var(--color-neutral-200);
padding-top:0.4rem;
padding-right:0.2rem;
padding-bottom:0.4rem;
padding-left:0.2rem;
border_radius_border-radius:var(--border-radius-lg) ;
border-radius:var(--border-radius-lg) ;
}

.faq-accordion .oxy-pro-accordion_header:hover{
background-color:var(--color-neutral-400);
}

.faq-accordion .oxy-pro-accordion_item.active .oxy-pro-accordion_header{
color:var(--color-brand-primary);
}

.faq-accordion .oxy-pro-accordion_title{
font-size: var(--font-size-h6)  ;
}

.faq-accordion .oxy-pro-accordion_context-icon{
                                display: none;
                            }
.mt-2-0 {
}
.oxel_horizontal_divider {
 margin-top:16px;
 margin-bottom:16px;
 width:100%;
}
.oxel_horizontal_divider:not(.ct-section):not(.oxy-easy-posts),
.oxel_horizontal_divider.oxy-easy-posts .oxy-posts,
.oxel_horizontal_divider.ct-section .ct-section-inner-wrap{
flex-direction:unset;
}
.oxel_horizontal_divider__line {
 height:1px;
 background-color:var(--color-brand-primary);
 opacity:0.5;
}
.oxel_horizontal_divider__icon {
color: var(--color-brand-primary);}.oxel_horizontal_divider__icon 
>svg {width: 16px;height: 16px;}.oxel_horizontal_divider__icon {
 opacity:0.5;
 margin-left:5px;
 margin-right:5px;
flex-shrink: 0;
}
.oxel_horizontal_divider__icon:not(.ct-section):not(.oxy-easy-posts),
.oxel_horizontal_divider__icon.oxy-easy-posts .oxy-posts,
.oxel_horizontal_divider__icon.ct-section .ct-section-inner-wrap{
display:flex;
}
.oxel_focus_section {
 transition-duration:0.4s;
 transition-timing-function:ease-in-out;
 overflow:hidden;
overflow-x: hidden;
}
.oxel_focus_section:not(.ct-section):not(.oxy-easy-posts),
.oxel_focus_section.oxy-easy-posts .oxy-posts,
.oxel_focus_section.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
align-items:center;
}
.oxel_focus_section__inner {
 transition-duration:0.4s;
 transition-timing-function:ease-in-out;
 width:100%;
 text-align:center;
 padding-top:32px;
 padding-left:32px;
 padding-right:32px;
 padding-bottom:32px;
 z-index:1001;
 position:relative;
}
.oxel_focus_section__inner:not(.ct-section):not(.oxy-easy-posts),
.oxel_focus_section__inner.oxy-easy-posts .oxy-posts,
.oxel_focus_section__inner.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
}
.oxel_focus_section__backdrop {
 position:fixed;
 right:0px;
 left:0px;
 bottom:0px;
 background-color:#ffffff;
 z-index:1000;
 opacity:0;
 transition-duration:0.8s;
 transition-timing-function:ease-in-out;
 transition-property:top bottom;
 top:0px;
pointer-events: none;
}
.x-megamenu-1_link-wrapper {
 transition-duration:.4s;
 transition-timing-function:ease;
 transition-property:all;
}
.x-mega-menu_link-heading {
 padding-left:1em;
 padding-right:1em;
 padding-bottom:5px;
 margin-top:-20px;
 background-color:#ffffff;
 padding-top:5px;
}
.x-megamenu-4_cta {
 width:100%;
 background-color:#f2f3f4;
 padding-top:20px;
 padding-left:20px;
 padding-right:20px;
 padding-bottom:20px;
 text-align:justify;
}
.x-megamenu-4_cta:not(.ct-section):not(.oxy-easy-posts),
.x-megamenu-4_cta.oxy-easy-posts .oxy-posts,
.x-megamenu-4_cta.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
justify-content:space-between;
}
.x-megamenu-4_menu-list-container {
 width:100%;
 text-align:justify;
}
.x-megamenu-4_menu-list-container:not(.ct-section):not(.oxy-easy-posts),
.x-megamenu-4_menu-list-container.oxy-easy-posts .oxy-posts,
.x-megamenu-4_menu-list-container.ct-section .ct-section-inner-wrap{
display:grid;
flex-wrap:wrap;
justify-content:space-between;
display: grid !important;align-items: stretch;grid-template-columns: repeat(7, minmax(50px, 1fr));grid-column-gap: 1rem;grid-row-gap: 1rem;}
.x-megamenu-4_menu-list-container:not(.ct-section):not(.oxy-easy-posts) > *,
.x-megamenu-4_menu-list-container.ct-section .ct-section-inner-wrap > *,
.x-megamenu-4_menu-list-container.oxy-easy-posts .oxy-posts > *{
grid-column: span 2;}
.x-megamenu-4_menu-list-container:not(.ct-section):not(.oxy-easy-posts) > :nth-child(2),
.x-megamenu-4_menu-list-container.ct-section .ct-section-inner-wrap > :nth-child(2),
.x-megamenu-4_menu-list-container.oxy-easy-posts .oxy-posts > :nth-child(2){
grid-column: span 3;}
.x-megamenu-4_menu-list {
 width:95%;
}
.x-megamenu-4_menu-list .oxy-slide-menu_title{
padding-bottom:10px;
padding-left:10px;
margin-bottom:3em;
border-bottom-color:#111;
border-bottom-style:solid;
border-bottom-width:1px;
font-family: 'General Sans';
letter-spacing: .2em;
text-transform: uppercase;
font-size: 13px;
color: rgba(0,0,0,0.39);
font-weight: 600;
}

.x-megamenu-4_menu-list .oxy-slide-menu_list .menu-item a{
transition-duration:0.5s;
border_radius_border-radius:var(--border-radius-lg) ;
border-radius:var(--border-radius-lg) ;
padding-bottom:var(--space-0-5) ;
padding-left:var(--space-1-0) ;
padding-right:var(--space-1-0) ;
padding-top:var(--space-0-5) ;
margin-bottom:var(--space-0-5) ;
}

.x-megamenu-4_menu-list .oxy-slide-menu_list .menu-item a:hover{
color:var(--color-brand-primary);
background-color:var(--color-neutral-200);
}

.x-megamenu-4_menu-list .menu-item a{
font-size: var(--font-size-sm)  ;
}

@media (max-width: 767px) {
.x-megamenu-4_menu-list {
 width:100%;
 margin-bottom:30px;
}
}

.x-mega-menu-2_column {
 width:33%;
 padding-top:30px;
 padding-left:30px;
 padding-right:30px;
 padding-bottom:30px;
}
@media (max-width: 991px) {
.x-mega-menu-2_column {
 width:100%;
}
}

.x-mega-menu_column-heading {
 color:#8898aa;
 font-size:16px;
 letter-spacing:.2em;
 text-transform:uppercase;
 margin-bottom:30px;
}
.x-mega-menu_icon-links:hover{
 background-color:#f2f3f4;
}
.x-mega-menu_icon-links {
 width:100%;
 text-align:left;
 color:inherit;
 padding-top:5px;
 padding-left:5px;
 padding-right:5px;
 padding-bottom:5px;
 font-size:16px;
 margin-bottom:10px;
 border-radius:10px;
 transition-duration:.5s;
 transition-timing-function:ease;
}
.x-mega-menu_icon-links:not(.ct-section):not(.oxy-easy-posts),
.x-mega-menu_icon-links.oxy-easy-posts .oxy-posts,
.x-mega-menu_icon-links.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
align-items:center;
justify-content:flex-start;
}
.x-mega-menu_link-icon {
background-color: #ffffff;
border: 1px solid #ffffff;
padding: 10px;color: #2f306b;}.x-mega-menu_link-icon 
>svg {width: 26px;height: 26px;}.x-mega-menu_link-icon {
 margin-right:1em;
}
.trigger-1 {
}
.x-logo {
 width:40px;
 height:40px;
 line-height:1;
 padding-top:5px;
 padding-left:5px;
 color:#232121;
 font-size:24px;
}
.x-megamenu-1 {
 color:#101010;
}
.x-megamenu-1 .oxy-mega-dropdown_inner{
padding-top:15px;
}

.x-megamenu-1 .oxy-mega-dropdown_link, .x-megamenu-1 .oxy-mega-menu_inner > .ct-link-text{
color:#111;
}

.x-megamenu-1 .oxy-mega-dropdown_container, .x-megamenu-1 .oxy-mega-dropdown_flyout .sub-menu{
box-shadow:0px 10px 40px rgba(0,0,0,0.1);transition-duration:400ms;
--dropdown-container-translatey:10px;
--dropdown-container-scale:.97;
}

.x-megamenu-1 .oxy-mega-dropdown_inner-open .oxy-mega-dropdown_container, .x-megamenu-1 .oxy-mega-dropdown_flyout .sub-menu{
transition-duration:200ms;
}

@media (max-width: 767px) {
.x-megamenu-1 {
}
.x-megamenu-1 .oxy-mega-dropdown_link, .x-megamenu-1 .oxy-mega-menu_inner > .ct-link-text{
padding-left:20px;
}

.x-megamenu-1 {
--megamenu-responsive-background:#111;
}

}

.x-megamenu-1_dropdown {
}
.x-megamenu-1_menu-list-container {
 width:100%;
 text-align:justify;
 padding-top:50px;
 padding-left:50px;
 padding-right:50px;
 padding-bottom:50px;
}
.x-megamenu-1_menu-list-container:not(.ct-section):not(.oxy-easy-posts),
.x-megamenu-1_menu-list-container.oxy-easy-posts .oxy-posts,
.x-megamenu-1_menu-list-container.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:row;
flex-wrap:wrap;
justify-content:space-between;
}
@media (max-width: 767px) {
.x-megamenu-1_menu-list-container {
 padding-top:30px;
 padding-left:30px;
 padding-right:30px;
 padding-bottom:30px;
}
}

.x-megamenu-1_menu-list {
 oxy-slide-menu__typography_font-family:Array;
 oxy-slide-menu__typography_font-weight:600;
 oxy-slide-menu__typography_letter-spacing:.05;
 width:25%;
}
.x-megamenu-1_menu-list .oxy-slide-menu_title{
margin-bottom:2em;
font-family: 'General Sans';
letter-spacing: .2em;
text-transform: uppercase;
font-size: 13px;
color: rgba(0,0,0,0.39);
font-weight: 600;
}

.x-megamenu-1_menu-list .oxy-slide-menu_list .menu-item a{
transition-duration:0.5s;
padding-top:10px;
padding-bottom:10px;
}

.x-megamenu-1_menu-list .oxy-slide-menu_list .menu-item a:hover{
color:#f05b51;
}

@media (max-width: 991px) {
.x-megamenu-1_menu-list {
 width:50%;
}
}

@media (max-width: 767px) {
.x-megamenu-1_menu-list {
 width:45%;
 margin-bottom:60px;
}
}

.trigger-2 {
}
.x-carousel-1 {
}
.x-carousel-1 .flickity-page-dots .dot.is-selected{
background-color:#c43838;
}

.x-carousel-1 {
                        --carousel-cell-width: calc((100% - (2 * var(--carousel-space-between))) / 3);
                        }

                        .x-carousel-1_cell {
background-image:linear-gradient(rgba(0,0,0,0.56), rgba(0,0,0,0.56)), url();background-size:auto,  cover; text-align:left;
 border-top-style:none;
 border-right-style:none;
 border-bottom-style:none;
 border-left-style:none;
 border-top-width:1px;
 border-right-width:1px;
 border-bottom-width:1px;
 border-left-width:1px;
 background-position:50% 50%;
}
.x-carousel-1_cell:not(.ct-section):not(.oxy-easy-posts),
.x-carousel-1_cell.oxy-easy-posts .oxy-posts,
.x-carousel-1_cell.ct-section .ct-section-inner-wrap{
align-items:flex-start;
justify-content:flex-end;
}
.x-post-carousel_prev {
color: #fff;}.x-post-carousel_prev 
>svg {width: 25px;height: 25px;}.x-post-carousel_prev {
 position:absolute;
 top:43%;
 left:-60px;
cursor: pointer;
}
@media (max-width: 1366px) {
.x-post-carousel_prev {
 position:absolute;
 left:0px;
}
}

.x-post-carousel_next {
color: #fff;}.x-post-carousel_next 
>svg {width: 25px;height: 25px;}.x-post-carousel_next {
transform:rotate(180deg); position:absolute;
 top:43%;
 right:-60px;
cursor: pointer;
}
@media (max-width: 1366px) {
.x-post-carousel_next {
 position:absolute;
 right:0px;
}
}

.btn {
}
.btn--secondary {
}
.btn--primary {
}
.rounded-md {
}
.rounded-lg {
}
.section--hero {
}
.text-lg {
}
.card {
}
.justify-center {
}
.align-center {
}
.mb-2-0 {
}
.mb-1-5 {
}
.mb-1-0 {
}
.mb-0-5 {
}
.wrapper--column {
}
.wrapper--row {
}
.bg-primary {
}
.bg-secondary {
}
.text-md {
}
.text-white {
}
.section--dark {
}
.bg-light {
}
.bg-white {
}
.text-primary {
}
.text-secondary {
}
.p-0-5 {
}
.text-center {
}
.card--interactive {
}
.p-1-0 {
}
.text-sm {
}
.rounded-sm {
}
.mt-4-0 {
}
.text-black {
}
.py-3-0 {
}
.uppercase {
}
.text-3xl {
}
.text-2xl {
}
.mi-auto {
}
.text-xs {
}
.header {
}
.header__row {
}
.header__logo {
}
.btn--outline {
}
.btn--sm {
}
.btn--lg {
}
.btn--block {
}
.form-field {
}
.form-label {
}
.text-xl {
}
.text-base {
}
.font-light {
}
.font-regular {
}
.font-medium {
}
.font-semibold {
}
.font-bold {
}
.text-link {
}
.capitalize {
}
.text-accent {
}
.text-success {
}
.text-warning {
}
.text-danger {
}
.text-info {
}
.bg-accent {
}
.bg-dark {
}
.bg-black {
}
.bg-success {
}
.bg-warning {
}
.bg-danger {
}
.bg-info {
}
.mt-0-5 {
}
.mt-1-0 {
}
.mt-1-5 {
}
.mt-2-5 {
}
.mt-3-0 {
}
.mt-5-0 {
}
.mt-6-0 {
}
.mb-2-5 {
}
.mb-4-0 {
}
.mb-5-0 {
}
.mb-6-0 {
}
.ml-0-5 {
}
.ml-1-0 {
}
.ml-1-5 {
}
.ml-2-0 {
}
.ml-2-5 {
}
.ml-3-0 {
}
.ml-4-0 {
}
.ml-5-0 {
}
.ml-6-0 {
}
.mr-0-5 {
}
.mr-1-0 {
}
.mr-1-5 {
}
.mr-2-0 {
}
.mr-2-5 {
}
.mr-3-0 {
}
.mr-4-0 {
}
.mr-5-0 {
}
.mr-6-0 {
}
.p-1-5 {
}
.p-2-0 {
}
.p-2-5 {
}
.p-3-0 {
}
.p-4-0 {
}
.p-5-0 {
}
.p-6-0 {
}
.px-0-5 {
}
.px-1-0 {
}
.px-1-5 {
}
.px-2-0 {
}
.px-2-5 {
}
.px-3-0 {
}
.px-4-0 {
}
.px-5-0 {
}
.px-6-0 {
}
.py-0-5 {
}
.py-1-0 {
}
.py-1-5 {
}
.py-2-0 {
}
.py-2-5 {
}
.py-4-0 {
}
.py-5-0 {
}
.py-6-0 {
}
.text-left {
}
.text-right {
}
.transition {
}
.has-hover-lift {
}
.shadow-sm {
}
.shadow-md {
}
.shadow-lg {
}
.rounded-full {
}
.is-hidden {
}
.is-visible {
}
.grid-items-divider {
}
.tabs-8324-tab:hover{
}
.tabs-8324-tab {
 font-size:var(--font-size-sm) ;
 transition-duration:0.3s;
 transition-timing-function:ease-in;
}
.tabs-8324-tab-active {
 color:var(--color-brand-secondary);
}
.tabs-contents-8324-tab {
}
.tabs-1679-tab {
}
.tabs-1679-tab-active {
}
.tabs-contents-1679-tab {
}
.megamenu-mobile-trigger {
}
.gap-0-5 {
}
.gap-1-0 {
}
.gap-1-5 {
}
.gap-2-0 {
}
.gap-2-5 {
}
.gap-3-0 {
}
.gap-4-0 {
}
.gap-5-0 {
}
.gap-6-0 {
}
.row-gap-0-5 {
}
.row-gap-1-0 {
}
.row-gap-1-5 {
}
.row-gap-2-0 {
}
.row-gap-2-5 {
}
.row-gap-3-0 {
}
.row-gap-4-0 {
}
.row-gap-5-0 {
}
.row-gap-6-0 {
}
.col-gap-0-5 {
}
.col-gap-1-0 {
}
.col-gap-1-5 {
}
.col-gap-2-0 {
}
.col-gap-2-5 {
}
.col-gap-3-0 {
}
.col-gap-4-0 {
}
.col-gap-5-0 {
}
.col-gap-6-0 {
}
.flex-fluid {
}
.tabs-5714-tab:hover{
 background-color:rgba(var(--color-brand-primary-rgb),0.1);
}
.tabs-5714-tab {
}
.tabs-5714-tab-active {
 background-color:var(--color-brand-primary);
}
.tabs-contents-5714-tab {
}
.tabs-contents-5714-tab:not(.ct-section):not(.oxy-easy-posts),
.tabs-contents-5714-tab.oxy-easy-posts .oxy-posts,
.tabs-contents-5714-tab.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
}
@media (max-width: 767px) {
.tabs-contents-5714-tab {
 padding-top:0px;
 padding-right:0px;
 padding-bottom:0px;
 padding-left:0px;
}
}

.checkmark-list {
}
.tabs-5186-tab:hover{
 border-top-color:var(--color-brand-primary);
 border-right-color:var(--color-brand-primary);
 border-bottom-color:var(--color-brand-primary);
 border-left-color:var(--color-brand-primary);
}
.tabs-5186-tab {
 border-radius:var(--border-radius-md) ;
 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;
 font-size:var(--font-size-h6) ;
 font-weight:600;
 transition-duration:0.3s;
 border-top-color:var(--color-neutral-400);
 border-right-color:var(--color-neutral-400);
 border-bottom-color:var(--color-neutral-400);
 border-left-color:var(--color-neutral-400);
 padding-top:var(--space-0-5) ;
 padding-right:var(--space-1-0) ;
 padding-bottom:var(--space-0-5) ;
 padding-left:var(--space-1-0) ;
}
@media (max-width: 1366px) {
.tabs-5186-tab {
 font-size:var(--font-size-base) ;
}
}

@media (max-width: 991px) {
.tabs-5186-tab {
 font-size:var(--font-size-sm) ;
 padding-top:var(--space-0-5) ;
 padding-right:var(--space-0-5) ;
 padding-bottom:var(--space-0-5) ;
 padding-left:var(--space-0-5) ;
}
}

.tabs-5186-tab-active {
 background-color:var(--color-brand-primary);
 color:var(--color-white);
}
.tabs-contents-5186-tab {
}
.animated-tabs-links {
}
.animated-tabs-content {
}
.scrollerRepeaterDiv {
}
.scrollerRepeaterNext {
}
.scrollerRepeater {
}
.testimonial-card__star {
color: var(--color-brand-secondary);}.testimonial-card__star 
>svg {width: 25px;height: 25px;}.testimonial-card__star {
}
.dark-context {
}
.mobile--text-left {
}
.mobile--text-center {
}
.mobile--text-right {
}
.columns-stack-at-md {
}
.columns-stack-at-sm {
}
.gradient-overlay {
}
.gradient-overlay--animated {
}
.oxy-sticky-header-active {
}
.position-relative {
}
.oxygen-builder-body {
}
.max-991 {
}
.max-767 {
}
.max-479 {
}
.btn--no-after {
}
.oxy-stock-content-styles {
}
.tabs-6833-tab:hover{
 border-top-color:var(--color-brand-primary);
 border-right-color:var(--color-brand-primary);
 border-bottom-color:var(--color-brand-primary);
 border-left-color:var(--color-brand-primary);
}
.tabs-6833-tab {
 border-radius:var(--border-radius-md) ;
 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;
 font-size:var(--font-size-h6) ;
 font-weight:600;
 transition-duration:0.3s;
 border-top-color:var(--color-neutral-400);
 border-right-color:var(--color-neutral-400);
 border-bottom-color:var(--color-neutral-400);
 border-left-color:var(--color-neutral-400);
 padding-top:var(--space-0-5) ;
 padding-right:var(--space-1-5) ;
 padding-bottom:var(--space-0-5) ;
 padding-left:var(--space-1-5) ;
}
@media (max-width: 1366px) {
.tabs-6833-tab {
 font-size:var(--font-size-base) ;
}
}

@media (max-width: 991px) {
.tabs-6833-tab {
 font-size:var(--font-size-sm) ;
 padding-top:var(--space-0-5) ;
 padding-right:var(--space-0-5) ;
 padding-bottom:var(--space-0-5) ;
 padding-left:var(--space-0-5) ;
}
}

.tabs-6833-tab-active {
 color:var(--color-white);
 background-color:var(--color-brand-primary);
--color-brand-secondary: white;
}
.tabs-contents-6833-tab {
}
.fancy-carousel_wrapper {
 width:100%;
 height:100%;
 position:relative;
 border-radius:var(--border-radius-lg) ;
}
.fancy-carousel_img {
 position:absolute;
 top:0px;
 left:0px;
 width:100%;
 z-index:3;
 aspect-ratio:2/1;
 object-position:center center;
 object-fit:cover;
}
.section-label {
}
.section-label__icon {
}
.section-label__heading {
}
.section-label__line {
}
.section-label--reversed {
}
.section-label--secondary {
}
.parallax-section {
}
.floating-parallax {
}
.floating-parallax-absolute {
}
.ignore-toc {
}
.oxy-superbox-primary {
}
.oxy-superbox-secondary {
}
:root {
	/* Brand Colors (Preserved from original site) */
	--color-brand-primary: #0063ac;
	--color-brand-secondary: #ec7e00;
	--color-brand-accent: #e43f5a;

	/* RGB component variables (Updated to match original brand) */
	--color-brand-primary-rgb: 0, 99, 172;
	--color-brand-secondary-rgb: 236, 126, 0;
	--color-brand-accent-rgb: 228, 63, 90;

	/* Neutral/Greyscale Palette */
	--color-white: #ffffff;
	--color-neutral-100: #f8f9fa;
	--color-neutral-200: #e9ecef;
	--color-neutral-300: #dee2e6;
	--color-neutral-400: #ced4da;
	--color-neutral-500: #adb5bd;
	--color-neutral-600: #6c757d;
	--color-neutral-700: #495057;
	--color-neutral-800: #343a40;
	--color-neutral-900: #000c1e;
	--color-black: #000000;

	/* Semantic Colors */
	--color-text-body: var(--color-neutral-700);
	--color-text-heading: var(--color-black);
	--color-text-muted: var(--color-neutral-600);
	--color-text-link: currentcolor;
	--color-background-body: var(--color-white);
	--color-background-subtle: var(--color-neutral-100);
	--color-border-default: var(--color-neutral-300);

	/* System/Feedback Colors */
	--color-success: #28a745;
	--color-warning: #ffc107;
	--color-danger: #dc3545;
	--color-info: #17a2b8;

	/* Font Families (Preserved from original site) */
	--font-family-base: 'General Sans', system-ui, sans-serif;
	--font-family-heading: 'Satoshi', system-ui, sans-serif;
	--font-family-mono: ui-monospace, Menlo, Monaco, 'Courier New', monospace;

	/* UPGRADED: Fluid Typography */
	--font-size-h1: clamp(2.25rem, 1rem + 6vw, 4.5rem);
	--font-size-h2: clamp(1.8rem, 1rem + 4vw, 3.25rem);
	--font-size-h3: clamp(1.4rem, 1rem + 1.8vw, 2.0rem);
	--font-size-h4: clamp(1.25rem, 1rem + 1.5vw, 1.75rem);
	--font-size-h5: clamp(1.125rem, 1rem + 1.0vw, 1.50rem);
	--font-size-h6: clamp(1.00rem, 1rem + 0.5vw, 1.25rem);
	--font-size-base: clamp(1rem, 0.9rem + 0.5vw, 1.1rem);
	--font-size-sm: calc(var(--font-size-base) * 0.875);
	--font-size-xs: calc(var(--font-size-base) * 0.75);

	/* Line Heights */
	--line-height-tight: 1.2;
	--line-height-normal: 1.5;
	--line-height-loose: 1.7;

	/* Font Weights */
	--font-weight-light: 300;
	--font-weight-normal: 400;
	--font-weight-medium: 500;
	--font-weight-semibold: 600;
	--font-weight-bold: 700;

	/* UPGRADED: Fluid Spacing Scale */
	--space-0-5: clamp(0.4rem, 0.25rem + 0.6vw, 0.5rem);
	--space-1-0: clamp(0.75rem, 0.5rem + 1.25vw, 1rem);
	--space-1-5: clamp(1rem, 0.75rem + 1.5vw, 1.5rem);
	--space-2-0: clamp(1.25rem, 1rem + 2vw, 2rem);
	--space-2-5: clamp(1.5rem, 1rem + 2.5vw, 2.5rem);
	--space-3-0: clamp(1.75rem, 1.25rem + 3vw, 3rem);
	--space-3-5: clamp(2rem, 1.5rem + 3.5vw, 3.5rem);
	--space-4-0: clamp(2.5rem, 2rem + 4vw, 4rem);
	--space-5-0: clamp(3rem, 2.25rem + 4.5vw, 5rem);
	--space-6-0: clamp(3.5rem, 2.5rem + 5vw, 6rem);

	/* Sizing */
	--size-container-max-width: 1366px;
	--size-container-padding-inline: clamp(1rem, 0.5rem + 2.5vw, 1.5rem);

	/* Borders & Shadows */
	--border-radius-sm: 4px;
	--border-radius-md: 8px;
	--border-radius-lg: 16px;
	--border-radius-full: 9999px;
	--border-width-sm: 1px;
	--border-width-md: 2px;
	--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
	--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
	--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
	--shadow-glow-primary: 0 25px 50px -12px rgba(var(--color-brand-primary-rgb), 0.25);

	/* NEW: Motion & Transitions */
	--transition-speed-fast: 150ms;
	--transition-speed-normal: 300ms;
	--transition-speed-slow: 500ms;
	--transition-easing-default: cubic-bezier(0.25, 0.46, 0.45, 0.94);
	--transition-easing-bounce: cubic-bezier(0.175, 0.885, 0.32, 1.275);
	
	/* REVISED: Gradient animation specific variables */
	--gradient-animation-duration: 15s; /* Controls speed of global blob animation */
}
/**
 * ==========================================================================
 * EndTag Digital - Upgraded CSS Framework
 *
 * This framework provides a comprehensive set of styles for base resets,
 * layout, components, and utility classes, tailored for modern web
 * development and optimized for use with builders like Oxygen.
 *
 * TABLE OF CONTENTS (RESTRUCTURED)
 * -----------------
 * 1.  BASE & RESETS
 * 2.  LAYOUT
 * 3.  ANIMATIONS & TRANSITIONS (MOVED UP)
 * 4.  COMPONENTS
 * 5.  UTILITY CLASSES
 * 5.1. Sizing & Layout
 * 5.2. Display & Position
 * 5.3. Spacing (Margin, Padding, Gap)
 * 5.4. Typography
 * 5.5. Backgrounds
 * 5.6. Borders & Shadows
 * 6.  CONTEXTUAL & OVERRIDE STYLES
 * ==========================================================================
*/


/* ==========================================================================
   1. BASE & RESETS
   ========================================================================== */

/* Set a more intuitive box-sizing model and improve font rendering. */
html {
	box-sizing: border-box;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	scroll-behavior: smooth;
}

/* Inherit box-sizing for all elements and enable word wrapping. */
*,
*::before,
*::after {
	box-sizing: inherit;
	overflow-wrap: break-word;
}

/* Set project-wide body defaults and ensure the footer sticks to the bottom. */
body {
	background-color: var(--color-background-subtle);
	color: var(--color-text-body);
	font-family: var(--font-family-base);
	font-size: var(--font-size-base);
	line-height: var(--line-height-normal);
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

/* --- NEW RULE --- */
/* Creates a stacking context to "clip" the fixed-position ::before gradient */
main {
	isolation: isolate;
	position: relative; /* Fallback for older browsers */
}

/* --- NEW RULE --- */
/* Global animated gradient, clipped by the <main> tag.
   Sits behind all content. */
main::before {
	content: "";
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1; /* Sits BEHIND the <main> element's content */
	pointer-events: none;
	/* Main control for subtlety. Slightly increased to better show the dynamic movement. */
	opacity: 0.15; 

	/* Gradient blob definitions: Added an ACCENT color for more variety */
	background-image:
		radial-gradient(circle at 10% 20%, rgb(var(--color-brand-primary-rgb)), transparent 40%),
		radial-gradient(circle at 90% 80%, rgb(var(--color-brand-secondary-rgb)), transparent 50%),
		/* New blob with an accent color */
		radial-gradient(circle at 40% 50%, rgb(var(--color-brand-accent-rgb)), transparent 45%),
		radial-gradient(circle at 50% 90%, rgb(var(--color-brand-primary-rgb)), transparent 45%);
	
	/* Creates a single, giant, seamless pattern to animate */
	background-size: 100% 100%; /* Increased size for a larger movement canvas */
	
	/* Fixes all blobs to the viewport for a seamless scroll effect */
	background-attachment: fixed;
	
	/* Apply TWO distinct animations for a more organic, 'breathing' effect */
	/*animation: 
		gradientWarp calc(var(--gradient-animation-duration) * 1.5) ease-in-out infinite alternate,
		gradientZoom var(--gradient-animation-duration) ease-in-out infinite alternate;
*/}
/* Basic resets for common elements. */
a {
	color: unset;
	text-decoration: none;
}

ul {
	padding-inline-start: 22px;
}

h1, h2, h3, h4, h5, h6, p {
	hyphens: auto;
    line-height: 1.5;
}

p {
	margin-block: 0;
}

img {
	object-fit: cover;
}


/* ==========================================================================
   2. LAYOUT
   ========================================================================== */

/**
 * Main site container with a max-width and centered alignment.
 * Provides consistent horizontal padding.
 */
.container {
	width: 100%;
	max-width: var(--size-container-max-width);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--size-container-padding-inline);
	padding-right: var(--size-container-padding-inline);
	
	/* Ensures all content containers sit on top 
	   of section overlays and pseudo-elements. */
	position: relative;
	z-index: 2;
}

/**
 * Sets a default vertical padding on dark containers.
 * Using :where() makes this rule have zero specificity, so any
 * padding utility class (e.g., .py-6-0) will easily override it.
 */
:where(.container.dark-context) {
	padding-top: var(--space-4-0);
	padding-bottom: var(--space-4-0);
}

/**
 * Site Header styles.
 */
.header {
	position: relative;
	height: 100px;
}

.header__row {
	padding: 0rem 1rem;
	height: 100px;
}

.header__logo {
	position: relative;
}

.header__logo img {
	z-index: 1;
	max-width: 100%;
	height: 55px;
	object-position: center;
	object-fit: contain;
}

/* Decorative blur effect behind the logo. */
.header__logo::before {
	content: '';
	position: absolute;
	z-index: 0;
	width: 100%;
	height: 100%;
	top: -50%;
	transform: translateY(50%);
	left: 0;  
	/* background: linear-gradient( to right, #00000000 0%, rgba(0,0,0,0.8) 50%, rgba(0,0,0,1) 200% ); */
	filter: blur(25px);
	border-radius: var(--border-radius-md);
	pointer-events: none;
	transition: opacity 0.4s ease;
}

/* Style for the header when it becomes sticky. */
.oxy-sticky-header-active {
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
}

/**
 * Section styles for content blocking.
 * Establishes stacking context for overlays and pseudo-elements.
 */
.section {
    position: relative;
}

.section > .ct-section-inner-wrap {
	padding-top: var(--space-6-0);
	padding-bottom: var(--space-6-0);
	gap: var(--space-6-0);
	justify-content: center;
}

/* Section color variants. */
.section--dark {
	color: var(--color-neutral-200);
	background-size: cover;
	background-position: center;
	background-attachment: scroll; /* 'scroll' is safer, 'fixed' gives parallax */
}

/* This creates the dark overlay on top of ANY background image 
   (placeholder or custom) on .section--dark */
.section--dark::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;

	/* Sits on top of the BG image, but below blobs and content */
	z-index: 0; 

	/* The dark gradient overlay */
	background: linear-gradient(
		to bottom,
		rgba(0, 0, 0, 0.4), 
		rgba(0, 0, 0, 0.7)
	);
}

.section--light {
	background-color: var(--color-background-subtle);
}

/* Hero section now only controls layout. Use .gradient-overlay for the background. */
.section--hero {
	min-height: 100vh;
}

/* ==========================================================================
   3. ANIMATIONS & TRANSITIONS (MOVED UP)
   ========================================================================== */

.transition {
	transition: all var(--transition-speed-normal) var(--transition-easing-default);
}

/* Simple lift effect on hover. */
.has-hover-lift {
	transition: transform var(--transition-speed-normal) var(--transition-easing-default);
}
.has-hover-lift:hover {
	transform: translateY(-4px);
}

/* Stagger container for sequencing animations (JS controlled). */
.stagger-container {}

/* Fade-in animation triggered by adding the 'is-visible' class. */
.has-fade-in {
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 400ms var(--transition-easing-default), transform 400ms var(--transition-easing-default);
}

.has-fade-in.is-visible {
	opacity: 1;
	transform: translateY(0);
}


/* Disable fade-in effect within the Oxygen Builder for a better editing experience. */
.oxygen-builder-body .has-fade-in {
	opacity: 1 !important;
	transform: translateY(0) !important;
}

/**
 * Animated Gradient Background System (Original)
 * This class can be applied to other elements like cards or divs.
 */
.gradient-overlay {
	position: relative;
	z-index: 0;
	overflow: hidden;
}

.gradient-overlay::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	pointer-events: none;
	border-radius: inherit;
	background-image:
		radial-gradient(circle at 20% 20%, rgba(var(--color-brand-primary-rgb), 0.2), transparent 40%),
		radial-gradient(circle at 80% 70%, rgba(var(--color-brand-secondary-rgb), 0.2), transparent 50%);
	background-size: 100% 100%;
	transition: all var(--transition-speed-normal) var(--transition-easing-default);
}

.gradient-overlay > * {
	position: relative;
	z-index: 2;
}

.gradient-overlay--animated::before {
	background-image:
		radial-gradient(circle at 15% 25%, rgba(var(--color-brand-primary-rgb), 0.2), transparent 50%),
		radial-gradient(circle at 50% 50%, rgba(var(--color-brand-secondary-rgb), 0.2), transparent 20%),
		radial-gradient(circle at 90% 85%, rgba(var(--color-brand-primary-rgb), 0.2), transparent 50%);
	background-size: 400% 300%;
	animation: gradientPan var(--gradient-animation-duration) ease-in-out infinite;
}

/* Animation keyframes for all animated gradients */
@keyframes gradientPan {
	0% { background-position: 0% 50%; }
	100% { background-position: 100% 50%; }
}

/* ### NEW Animation keyframes for the Dynamic, Breathing Effect ### */
@keyframes gradientWarp {
	/* New 0% state: offset background position on both X and Y */
	0% { background-position: 0% 0%; } 
	/* Midpoint for more fluid motion */
	40% { background-position: 70% 30%; } 
	/* New 100% state: significant shift in background position */
	100% { background-position: 100% 100%; } 
}

@keyframes gradientZoom {
	/* Subtle changes to background-size over time */
	0% { background-size: 350% 350%; }
	50% { background-size: 300% 300%; }
	100% { background-size: 400% 400%; }
}

/* ==========================================================================
   4. COMPONENTS
   ========================================================================== */

/**
 * Button component styles.
 */
.btn {
	display: inline-block;
	padding: var(--space-0-5) var(--space-0-5) var(--space-0-5) var(--space-1-0);
	font-family: var(--font-family-base);
	font-weight: 500;
	font-size: var(--font-size-base);
	text-align: center;
	text-decoration: none;
	border: var(--border-width-md) solid transparent;
	border-radius: var(--border-radius-lg);
	transition: background-color var(--transition-speed-normal) var(--transition-easing-default), 
	            opacity var(--transition-speed-normal) var(--transition-easing-default), 
	            color var(--transition-speed-normal) var(--transition-easing-default),
	            /* This is the missing piece for your .has-fade-in */
	            transform 400ms var(--transition-easing-default);
    cursor: pointer;
}

/* Arrow icon for buttons. */
.btn::after {
	content: "↗";
	margin-left: 0.6rem;
	display: inline-grid;
	place-items: center;
	width: 30px;
	height: 30px;
	border-radius: var(--border-radius-md);
	background-color: var(--color-white);
	transition: transform var(--transition-speed-normal) var(--transition-easing-bounce);
}

.btn:hover::after {
	transform: rotate(45deg);
}

/* Button variants: Color */
.btn--primary {
	background-color: var(--color-brand-primary);
	color: var(--color-white);
}

.btn--primary::after {
	color: var(--color-brand-primary);
}

.btn--primary:hover {
	background-color: var(--color-brand-primary);
	opacity: 0.9;
	color: var(--color-white);
}

.btn--secondary {
	background-color: var(--color-brand-secondary);
	color: var(--color-white);
}

.btn--secondary::after {
	color: var(--color-brand-secondary);
}

.btn--secondary:hover {
	background-color: var(--color-brand-secondary);
	opacity: 0.9;
	color: var(--color-white);
}

.btn--outline {
	background-color: transparent;
	border-color: var(--color-brand-primary);
	color: var(--color-brand-primary);
}

.btn--outline:hover {
	background-color: var(--color-brand-primary);
	color: var(--color-white);
}

.btn--outline:hover::after {
	color: var(--color-brand-primary);
}

/* Button variants: Size */
.btn--sm {
	padding: var(--space-0-5);
	font-size: var(--font-size-sm);
}

.btn--sm::after {
	margin-left: 0.35rem;
}

.btn--lg {
	padding: var(--space-1-0) var(--space-2-5);
	font-size: var(--font-size-h6);
}

.btn--block {
	display: block;
	width: 100%;
}

/* NEW: Modifier to remove the arrow icon */
.btn--no-after {
	padding: var(--space-0-5) var(--space-1-0); /* Symmetrical horizontal padding */
}

.btn--no-after::after {
	content: none;
	display: none;
}


/**
 * Card component styles.
 */
.card {
	border-radius: var(--border-radius-lg);
	box-shadow: var(--shadow-md);
	padding: var(--space-1-0);
}

.card--interactive {
	border: var(--border-width-md) solid transparent;
	transition: transform var(--transition-speed-normal) var(--transition-easing-default),
				box-shadow var(--transition-speed-normal) var(--transition-easing-default),
				border-color var(--transition-speed-normal) var(--transition-easing-default),
				opacity 400ms var(--transition-easing-default);
}

.card--interactive:hover {
	border-color: var(--color-brand-primary);
	transform: translateY(-8px);
	box-shadow: var(--shadow-glow-primary);
}

/**
 * Form element styles.
 */
.form-label {
	display: block;
	margin-bottom: var(--space-0-5);
	font-size: var(--font-size-sm);
	font-weight: 500;
}

.form-field {
	width: 100%;
	padding: var(--space-1-0) var(--space-1-5);
	font-size: var(--font-size-base);
	border: var(--border-width-sm) solid var(--color-border-default);
	border-radius: var(--border-radius-md);
	background-color: var(--color-white);
	transition: all 200ms ease-in-out;
}

/**
 * Grid Items Divider
 */
.grid-items-divider > *:not(:first-child) {
	position: relative;
}

.grid-items-divider > *:not(:first-child)::before {
	content: '';
	position: absolute;
	background-color: #a5a5a540;
}

/* Vertical divider for desktop. */
.grid-items-divider > *:not(:first-child)::before {
	top: 20%;
	bottom: 20%;
	left: calc(var(--space-0-5) * -1);
	width: 1px;
	border-radius: 10px;
}

/* Switches to a horizontal divider on mobile. */
@media (max-width: 991px) {
	.grid-items-divider > *:not(:first-child)::before {
		top: calc(var(--space-0-5) * -1);
		bottom: unset;
		left: 20%;
		right: 20%;
		width: 60%;
		height: 1px;
	}
}


/* ==========================================================================
   5. UTILITY CLASSES
   ========================================================================== */

/* --- 5.1. Sizing & Layout --- */
.wrapper--row {
	width: 100%;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}

.wrapper--column {
	width: 100%;
	display: flex;
	flex-direction: column;
}

.flex-fluid {
	flex: 1 1 0;
	min-width: 0;
}

.justify-center {
	justify-content: center;
}

.align-center {
	align-items: center;
}

/* --- 5.2. Display & Position --- */
.is-hidden {
	display: none !important;
}

.position-relative {
	position: relative;
}

.sticky {
	position: sticky;
	top: 100px;
}

.sticky-parent {
	position: relative;
}

/* --- 5.3. Spacing (Margin, Padding, Gap) --- */

/* Margin Top */
.mt-0-5 { margin-top: var(--space-0-5); }
.mt-1-0 { margin-top: var(--space-1-0); }
.mt-1-5 { margin-top: var(--space-1-5); }
.mt-2-0 { margin-top: var(--space-2-0); }
.mt-2-5 { margin-top: var(--space-2-5); }
.mt-3-0 { margin-top: var(--space-3-0); }
.mt-4-0 { margin-top: var(--space-4-0); }
.mt-5-0 { margin-top: var(--space-5-0); }
.mt-6-0 { margin-top: var(--space-6-0); }

/* Margin Bottom */
.mb-0-5 { margin-bottom: var(--space-0-5); }
.mb-1-0 { margin-bottom: var(--space-1-0); }
.mb-1-5 { margin-bottom: var(--space-1-5); }
.mb-2-0 { margin-bottom: var(--space-2-0); }
.mb-2-5 { margin-bottom: var(--space-2-5); }
.mb-3-0 { margin-bottom: var(--space-3-0); }
.mb-4-0 { margin-bottom: var(--space-4-0); }
.mb-5-0 { margin-bottom: var(--space-5-0); }
.mb-6-0 { margin-bottom: var(--space-6-0); }

/* Margin Left */
.ml-0-5 { margin-left: var(--space-0-5); }
.ml-1-0 { margin-left: var(--space-1-0); }
.ml-1-5 { margin-left: var(--space-1-5); }
.ml-2-0 { margin-left: var(--space-2-0); }
.ml-2-5 { margin-left: var(--space-2-5); }
.ml-3-0 { margin-left: var(--space-3-0); }
.ml-4-0 { margin-left: var(--space-4-0); }
.ml-5-0 { margin-left: var(--space-5-0); }
.ml-6-0 { margin-left: var(--space-6-0); }

/* Margin Right */
.mr-0-5 { margin-right: var(--space-0-5); }
.mr-1-0 { margin-right: var(--space-1-0); }
.mr-1-5 { margin-right: var(--space-1-5); }
.mr-2-0 { margin-right: var(--space-2-0); }
.mr-2-5 { margin-right: var(--space-2-5); }
.mr-3-0 { margin-right: var(--space-3-0); }
.mr-4-0 { margin-right: var(--space-4-0); }
.mr-5-0 { margin-right: var(--space-5-0); }
.mr-6-0 { margin-right: var(--space-6-0); }

/* Margin Inline Auto (Centering) */
.mi-auto {
	margin-left: auto;
	margin-right: auto;
}

/* Padding All Sides */
.p-0-5 { padding: var(--space-0-5); }
.p-1-0 { padding: var(--space-1-0); }
.p-1-5 { padding: var(--space-1-5); }
.p-2-0 { padding: var(--space-2-0); }
.p-2-5 { padding: var(--space-2-5); }
.p-3-0 { padding: var(--space-3-0); }
.p-4-0 { padding: var(--space-4-0); }
.p-5-0 { padding: var(--space-5-0); }
.p-6-0 { padding: var(--space-6-0); }

/* Padding X-Axis (Left & Right) */
.px-0-5 { padding-left: var(--space-0-5); padding-right: var(--space-0-5); }
.px-1-0 { padding-left: var(--space-1-0); padding-right: var(--space-1-0); }
.px-1-5 { padding-left: var(--space-1-5); padding-right: var(--space-1-5); }
.px-2-0 { padding-left: var(--space-2-0); padding-right: var(--space-2-0); }
.px-2-5 { padding-left: var(--space-2-5); padding-right: var(--space-2-5); }
.px-3-0 { padding-left: var(--space-3-0); padding-right: var(--space-3-0); }
.px-4-0 { padding-left: var(--space-4-0); padding-right: var(--space-4-0); }
.px-5-0 { padding-left: var(--space-5-0); padding-right: var(--space-5-0); }
.px-6-0 { padding-left: var(--space-6-0); padding-right: var(--space-6-0); }

/* Padding Y-Axis (Top & Bottom) */
.py-0-5 { padding-top: var(--space-0-5); padding-bottom: var(--space-0-5); }
.py-1-0 { padding-top: var(--space-1-0); padding-bottom: var(--space-1-0); }
.py-1-5 { padding-top: var(--space-1-5); padding-bottom: var(--space-1-5); }
.py-2-0 { padding-top: var(--space-2-0); padding-bottom: var(--space-2-0); }
.py-2-5 { padding-top: var(--space-2-5); padding-bottom: var(--space-2-5); }
.py-3-0 { padding-top: var(--space-3-0); padding-bottom: var(--space-3-0); }
.py-4-0 { padding-top: var(--space-4-0); padding-bottom: var(--space-4-0); }
.py-5-0 { padding-top: var(--space-5-0); padding-bottom: var(--space-5-0); }
.py-6-0 { padding-top: var(--space-6-0); padding-bottom: var(--space-6-0); }

/* Flex/Grid Gap */
.gap-0-5 { gap: var(--space-0-5); }
.gap-1-0 { gap: var(--space-1-0); }
.gap-1-5 { gap: var(--space-1-5); }
.gap-2-0 { gap: var(--space-2-0); }
.gap-2-5 { gap: var(--space-2-5); }
.gap-3-0 { gap: var(--space-3-0); }
.gap-4-0 { gap: var(--space-4-0); }
.gap-5-0 { gap: var(--space-5-0); }
.gap-6-0 { gap: var(--space-6-0); }

/* Row Gap */
.row-gap-0-5 { row-gap: var(--space-0-5); }
.row-gap-1-0 { row-gap: var(--space-1-0); }
.row-gap-1-5 { row-gap: var(--space-1-5); }
.row-gap-2-0 { row-gap: var(--space-2-0); }
.row-gap-2-5 { row-gap: var(--space-2-5); }
.row-gap-3-0 { row-gap: var(--space-3-0); }
.row-gap-4-0 { row-gap: var(--space-4-0); }
.row-gap-5-0 { row-gap: var(--space-5-0); }
.row-gap-6-0 { row-gap: var(--space-6-0); }

/* Column Gap */
.col-gap-0-5 { column-gap: var(--space-0-5); }
.col-gap-1-0 { column-gap: var(--space-1-0); }
.col-gap-1-5 { column-gap: var(--space-1-5); }
.col-gap-2-0 { column-gap: var(--space-2-0); }
.col-gap-2-5 { column-gap: var(--space-2-5); }
.col-gap-3-0 { column-gap: var(--space-3-0); }
.col-gap-4-0 { column-gap: var(--space-4-0); }
.col-gap-5-0 { column-gap: var(--space-5-0); }
.col-gap-6-0 { column-gap: var(--space-6-0); }


/* --- 5.4. Typography --- */

/* Headings & Font Size Scale */
h1, .text-3xl { font-weight: 400; font-size: var(--font-size-h1); line-height: var(--line-height-tight); text-transform: uppercase; }
h2, .text-2xl { font-weight: 400; font-size: var(--font-size-h2); line-height: var(--line-height-tight); }
h3, .text-xl { font-weight: 500; font-size: var(--font-size-h3); line-height: var(--line-height-tight); }
h4, .text-lg { font-weight: 500; font-size: var(--font-size-h4); line-height: var(--line-height-tight); }
h5, .text-md { font-weight: 500; font-size: var(--font-size-h5); line-height: var(--line-height-normal); }
h6 { font-weight: 500; font-size: var(--font-size-h6); line-height: var(--line-height-normal); }

.text-base { font-size: var(--font-size-base); }
.text-sm { font-size: var(--font-size-sm); }
.text-xs { font-size: var(--font-size-xs); }

/* Font Weight */
.font-light { font-weight: 300; }
.font-regular { font-weight: 400; }
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }

/* Text Transform */
.uppercase { text-transform: uppercase; }
.capitalize { text-transform: capitalize; }

/* Text Alignment */
.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }

.max-991 {
	max-width: 991px;
}
.max-767 {
	max-width: 767px;
}
.max-479 {
	max-width: 479px;
}

/* Responsive Text Alignment */
@media (max-width: 767px) {
	.mobile--text-left { text-align: left !important; align-items: start; }
	.mobile--text-center { text-align: center !important; align-items: center;}
	.mobile--text-right { text-align: right !important; align-items: end;}
}

/* Text Color Palette */
.text-primary { color: var(--color-brand-primary); }
.text-secondary { color: var(--color-brand-secondary); }
.text-accent { color: var(--color-brand-accent); }
.text-white { color: var(--color-white); }
.text-black { color: var(--color-black); }
.text-success { color: var(--color-success); }
.text-warning { color: var(--color-warning); }
.text-danger { color: var(--color-danger); }
.text-info { color: var(--color-info); }

/* REVISED: Animated Text Link with Multi-line Support */
.text-link {
	display:inline;
	/* Basic styles */
	text-decoration: none;
	font-weight: 500;
	padding-bottom: 2px;

	/* Setup for the animated background underline */
	background-image: linear-gradient(currentColor, currentColor);
	background-position: 0% 100%;
	background-repeat: no-repeat;
	background-size: 0% 2px;
	transition: background-size var(--transition-speed-normal) var(--transition-easing-default),
	            /* These are the missing pieces for your .has-fade-in */
	            opacity 400ms var(--transition-easing-default),
	            transform 400ms var(--transition-easing-default);

	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}

/* * This group selector triggers the animation in both cases:
 * 1. When hovering the parent <a> tag.
 * 2. When hovering the .text-link element directly.
 */
.text-link:hover,
a:hover .text-link {
	background-size: 100% 2px; /* Animate to full width on hover */
}


/* --- 5.5. Backgrounds --- */
.bg-primary { background-color: var(--color-brand-primary); color: var(--color-white); }
.bg-secondary { background-color: var(--color-brand-secondary); color: var(--color-white); }
.bg-accent { background-color: var(--color-brand-accent); color: var(--color-white); }
.bg-light { background-color: var(--color-background-subtle); color: var(--color-text-body); }
.bg-dark { background-color: var(--color-neutral-900); color: var(--color-neutral-200); }
.bg-white { background-color: var(--color-white); color: var(--color-text-body); }
.bg-black { background-color: var(--color-black); color: var(--color-white); }
.bg-success { background-color: var(--color-success); color: var(--color-white); }
.bg-warning { background-color: var(--color-warning); color: var(--color-black); }
.bg-danger { background-color: var(--color-danger); color: var(--color-white); }
.bg-info { background-color: var(--color-info); color: var(--color-white); }


/* --- 5.6. Borders & Shadows --- */

/* Border Radius */
.rounded-sm { border-radius: var(--border-radius-sm); }
.rounded-md { border-radius: var(--border-radius-md); }
.rounded-lg { border-radius: var(--border-radius-lg); }
.rounded-full { border-radius: var(--border-radius-full); }

/* Box Shadow */
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }


/* ==========================================================================
   6. CONTEXTUAL & OVERRIDE STYLES
   ========================================================================== */
/**
 * Global Layout Adjustments
 */
main .section:first-of-type > .ct-section-inner-wrap {
	padding-top: 6rem !important;  /* Fixed top padding for the first section. !important to override inline styles from builder */
}
/**
 * Contextual Inversion System
 * Allows components to adapt to dark backgrounds.
 */
.dark-context {
	color: var(--color-white);
}

/* Invert outline buttons on dark backgrounds. */
.bg-dark .btn--outline,
.dark-context .btn--outline {
	border-color: var(--color-white);
	color: var(--color-white);
}

.bg-dark .btn--outline::after,
.dark-context .btn--outline::after {
	background-color: var(--color-white);
	color: var(--color-neutral-900);
}

.bg-dark .btn--outline:hover,
.dark-context .btn--outline:hover {
	background-color: var(--color-white);
	color: var(--color-neutral-900);
}

/* Invert shadows for dark backgrounds. */
.bg-dark .card,
.dark-context .card,
.bg-dark .shadow-sm,
.dark-context .shadow-sm {
	box-shadow: 0 1px 2px 0 rgb(255 255 255 / 0.05);
}

.bg-dark .shadow-md,
.dark-context .shadow-md {
	box-shadow: 0 4px 6px -1px rgb(255 255 255 / 0.1), 0 2px 4px -2px rgb(255 255 255 / 0.1);
}

.bg-dark .shadow-lg,
.dark-context .shadow-lg {
	box-shadow: 0 10px 15px -3px rgb(255 255 255 / 0.1), 0 4px 6px -4px rgb(255 255 255 / 0.1);
}


/**
 * Oxygen Builder Specific Overrides
 */
.columns-stack-at-md > .ct-div-block,
.columns-stack-at-sm > .ct-div-block {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	padding-left: var(--space-1-0) !important;
	padding-right: var(--space-1-0) !important;
}

/* Add vertical padding when columns stack. */
@media (max-width: 991px) {
	.columns-stack-at-md > .ct-div-block {
		padding-top: var(--space-1-0) !important;
		padding-bottom: var(--space-1-0) !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
	}
}

@media (max-width: 767px) {
	.columns-stack-at-sm > .ct-div-block {
		padding-top: var(--space-1-0) !important;
		padding-bottom: var(--space-1-0) !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
	}
}

/**
 * Contextual Section Padding (Final Corrected Logic)
 * ----------------------------------------------------
 * These rules ONLY apply to light sections containing dark containers.
 * A .section--dark will always keep its default padding.
 */

/* * Rule 1: Controls TOP PADDING of Section B.
 * Removes top padding from a LIGHT section that starts with a dark container
 * ONLY IF the preceding section (A) was completely light.
 */
.section:not(:is(.dark-context, :has(.ct-section-inner-wrap > .container:last-child.dark-context))) + .section:not(.dark-context):has(.ct-section-inner-wrap > .container:first-child.dark-context) > .ct-section-inner-wrap {
	padding-top: 0;
}

/* * Rule 2: Controls BOTTOM PADDING of Section B.
 * Removes bottom padding from a LIGHT section that ends with a dark container
 * ONLY IF the following section (C) is also a LIGHT section.
 */
.section:not(.dark-context):has(.ct-section-inner-wrap > .container:last-child.dark-context):has(+ .section:not(.dark-context)) > .ct-section-inner-wrap {
	padding-bottom: 0;
}/* =========================================
   Base Component
   DOM Order: [Icon] [Heading] [Line]
   ========================================= */

.section-label {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1-0);
  width: 100%;
  margin-bottom: var(--space-1-0);
  
  /* 1. Explicit Overrides for Oxygen */
  text-align: left;
  flex-direction: row; 
}

/* --- Icon Container (Animation Safe) --- */
.section-label__icon {
  width: 70px;
  height: 14px;
  flex-shrink: 0;
  position: relative;
}

/* --- The Visual Icon (Pseudo-element) --- */
.section-label__icon::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgb(var(--color-brand-primary-rgb));
  
  /* Mask: 0.4 (Left) -> 0.7 (Right) */
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 20'%3E%3Ccircle cx='15' cy='10' r='10' opacity='0.4'/%3E%3Ccircle cx='50' cy='10' r='10' opacity='0.55'/%3E%3Ccircle cx='85' cy='10' r='10' opacity='0.7'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 20'%3E%3Ccircle cx='15' cy='10' r='10' opacity='0.4'/%3E%3Ccircle cx='50' cy='10' r='10' opacity='0.55'/%3E%3Ccircle cx='85' cy='10' r='10' opacity='0.7'/%3E%3C/svg%3E");
  
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: center left;
  
  transition: background-color 0.3s ease, transform 0.3s ease; 
}

/* --- Heading --- */
.section-label__heading {
  font-size: var(--font-size-h5);
  text-transform: uppercase;
  color: #666;
  margin: 0;
  white-space: nowrap;
}

/* --- Line --- */
.section-label__line {
  flex-grow: 1;
  height: 1px;
  position: relative;
}

.section-label__line::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: scaleY(0.5);
  transform-origin: center;
  
  /* Standard Gradient: Strong Left (0.6) -> Weak Right (0.3) */
  background: linear-gradient(
    to right, 
    rgba(var(--color-brand-primary-rgb), 0.6), 
    rgba(var(--color-brand-primary-rgb), 0.3)
  );
}

/* =========================================
   Modifier: Reversed Layout (--reversed)
   ========================================= */
.section-label--reversed {
  flex-direction: row-reverse; 
}

.section-label--reversed .section-label__icon::before {
  transform: scaleX(-1); 
}

.section-label--reversed .section-label__line::before {
  /* Gradient: Strong Right (0.6) -> Weak Left (0.3) */
  background: linear-gradient(
    to left, 
    rgba(var(--color-brand-primary-rgb), 0.6), 
    rgba(var(--color-brand-primary-rgb), 0.3)
  );
}

/* =========================================
   Modifier: Secondary Color (--secondary)
   ========================================= */
.section-label--secondary .section-label__icon::before {
  background-color: rgb(var(--color-brand-secondary-rgb));
}

.section-label--secondary .section-label__line::before {
  background: linear-gradient(
    to right, 
    rgba(var(--color-brand-secondary-rgb), 0.6), 
    rgba(var(--color-brand-secondary-rgb), 0.3)
  );
}

.section-label--secondary.section-label--reversed .section-label__line::before {
  background: linear-gradient(
    to left, 
    rgba(var(--color-brand-secondary-rgb), 0.6), 
    rgba(var(--color-brand-secondary-rgb), 0.3)
  );
}

/* =========================================
   Tablet Layout (Oxygen Breakpoint)
   ========================================= */
@media (max-width: 767px) {
  .section-label {
    gap: var(--space-0-5);
    /* Force standard direction, overriding --reversed */
    flex-direction: row !important; 
  }

  /* --- Tablet Sizes --- */
  .section-label__icon {
    width: 55px;
    height: 11px;
  }
  .section-label__heading {
    font-size: var(--font-size-h6);
  }

  /* --- Tablet Resets --- */
  
  /* Reset flip on icon */
  .section-label__icon::before {
    transform: scaleX(1) !important; 
  }

  /* This is the "Tablet" wrap logic: line drops to bottom */
  .section-label__line {
    width: 100%;
    flex-basis: 100%; 
    order: 1; /* Force to bottom */
    margin-top: 0.25em;
  }
  
  /* Reset Gradient Direction on Tablet */
  .section-label__line::before {
    background: linear-gradient(
      to right, 
      rgba(var(--color-brand-primary-rgb), 0.6), 
      rgba(var(--color-brand-primary-rgb), 0.3)
    ) !important;
  }
  
  /* Reset Secondary Gradient on Tablet */
  .section-label--secondary .section-label__line::before {
    background: linear-gradient(
      to right, 
      rgba(var(--color-brand-secondary-rgb), 0.6), 
      rgba(var(--color-brand-secondary-rgb), 0.3)
    ) !important;
  }
}

/* =========================================
   Mobile Layout (Vertical Stack)
   ========================================= */
@media (max-width: 479px) {
  .section-label {
    /* Override Tablet styles to stack all items */
    flex-direction: column !important;
    align-items: flex-start; /* Force left-alignment */
    gap: var(--space-0-5); /* Tighter vertical gap */
  }
  
  /* Size/font changes from 767px are inherited */

  .section-label__line {
    /* Override Tablet wrap logic */
    flex-basis: auto; /* Reset from 100% */
    order: 0;         /* Reset from 1 */
    margin-top: 0;    /* Reset from 0.25em */
    /* width: 100% is still correct */
  }
  
  /* NOTE: All the '!important' resets for icon transform 
    and line gradient from the 767px breakpoint 
    will correctly cascade down and apply here.
  */
}/* Anchor for the absolute images */
.parallax-section {
  position: relative;
}

/* Pulls the element out of the flow */
.floating-parallax-absolute {
  position: absolute;
  /* Control top, left, bottom, right, and z-index in your builder */
}

/* Normal flow element - just needs to be a block or inline-block */
.floating-parallax {
  display: block; 
}

/* Hardware acceleration only on desktop */
@media (min-width: 992px) {
  .floating-parallax-absolute,
  .floating-parallax {
    will-change: transform;
  }
}/* 1. ENABLE NATIVE SPA TRANSITIONS */
/* This tells modern browsers to automatically crossfade between page navigations */
@view-transition {
    navigation: auto;
}

/* 2. PIN THE HEADER & FOOTER */
/* By giving them unique names, the browser pulls them out of the crossfade 
   and keeps them perfectly static like a React app. */
header {
    view-transition-name: bauk-static-header;
}

footer {
    view-transition-name: bauk-static-footer;
}

/* 3. ISOLATE THE MAIN CONTENT */
/* Only the content inside the <main> tag will perform the smooth dissolve. */
main {
    view-transition-name: bauk-dynamic-main;
}

/* 4. PREVENT THE WHITE FLASH */
/* Forces the browser's "camera" to see the fade-in elements as fully visible 
   *only* during the split-second it takes the transition snapshot. 
html:active-view-transition .has-fade-in {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
}
*/#shortcode-23-651 h2{
 margin-bottom:1.5rem;
}
