.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-media-player .oxy-pro-media-player_play{
--extras-play-icon-size:60px;
}

.oxy-pro-media-player .oxy-pro-media-player_play button:hover{
--vm-play-scale:1;
}

.oxy-pro-media-player .oxy-pro-media-player_play button{
transition-duration:.3s;
}

.oxy-pro-media-player vime-player{
--vm-control-scale:.9;
--extras-slider-height:2px;
--vm-control-group-spacing:12px;
--vm-controls-padding:15px;
--vm-controls-spacing:15px;
--vm-time-font-size:13px;
--vm-control-border-radius:3px;
--extras-spinner-size:80px;
--vm-spinner-thickness:3px;
--vm-spinner-spin-duration:1s;
--vm-tooltip-spacing:3px;
--vm-tooltip-padding:3px;
}

.oxy-pro-media-player .oxy-pro-media-player_custom-image{
--extras-poster-left:50%;
--extras-poster-top:50%;
}

.oxy-pro-media-player vime-player.video{
                            height: 0;
                            overflow: hidden;
                        }
.oxy-pro-media-player .extras-in-builder vime-spinner{
                                opacity: 0;
                            }
.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: 'Montserrat';}body {line-height: ;font-size: px;font-weight: ;color: ;}.oxy-nav-menu-hamburger-line {background-color: ;}h1, h2, h3, h4, h5, h6 {font-family: 'Mulish';}a {text-decoration: none;}a:hover {text-decoration: none;}.ct-link-text {text-decoration: ;}.ct-link {text-decoration: ;}.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;
				}
			}
.faq-accordion {
 margin-bottom:1rem;
 width:100%;
}
.faq-accordion .oxy-pro-accordion_item{
border_radius_border-radius:var(--border-radius-lg) ;
border-radius:var(--border-radius-lg) ;
}

.faq-accordion .oxy-pro-accordion_header{
background-color:var(--color-white);
padding-bottom:0rem;
padding-right:0rem;
padding-left:0rem;
padding-top:0rem;
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_item.active{
box-shadow:inset 0px 0px 0px 1px var(--color-brand-secondary);}

.faq-accordion .oxy-pro-accordion_context-icon{
                                display: none;
                            }
.has-fade-in {
}
.header {
}
.header__row {
}
.mi-auto {
}
.header__logo {
}
.uppercase {
}
.rounded-lg {
}
.grid-items-divider {
}
.stagger-container {
}
.text-left {
}
.text-secondary {
}
.mb-1-0 {
}
.mb-2-0 {
}
.card--interactive {
}
.card {
}
.bg-white {
}
.flex-fluid {
}
.mb-0-5 {
}
.text-primary {
}
.text-link {
}
.btn {
}
.btn--sm {
}
.btn--secondary {
}
.text-sm {
}
.wrapper--row {
}
.align-center {
}
.btn--primary {
}
.btn--no-after {
}
.container {
}
.section {
}
.section--dark {
}
.section--light {
}
.section--hero {
}
.btn--outline {
}
.btn--lg {
}
.btn--block {
}
.form-label {
}
.form-field {
}
.prose {
}
.section-label {
}
.section-label__icon {
}
.section-label__heading {
}
.section-label__line {
}
.section-label--reversed {
}
.section-label--secondary {
}
.enable-container {
}
.wrapper--column {
}
.width-100 {
}
.height-100 {
}
.justify-start {
}
.justify-center {
}
.justify-end {
}
.justify-between {
}
.align-start {
}
.align-end {
}
.ar-1-1 {
}
.ar-16-9 {
}
.ar-4-3 {
}
.ar-3-2 {
}
.ar-9-16 {
}
.ar-3-4 {
}
.ar-2-3 {
}
.is-hidden {
}
.position-relative {
}
.sticky {
}
.sticky-parent {
}
.collapse-top {
}
.collapse-bottom {
}
.collapse-both {
}
.flow {
}
.mt-0-5 {
}
.mt-1-0 {
}
.mt-1-5 {
}
.mt-2-0 {
}
.mt-2-5 {
}
.mt-3-0 {
}
.mt-4-0 {
}
.mt-5-0 {
}
.mt-6-0 {
}
.mb-1-5 {
}
.mb-2-5 {
}
.mb-3-0 {
}
.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-0-5 {
}
.p-1-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-3-0 {
}
.py-4-0 {
}
.py-5-0 {
}
.py-6-0 {
}
.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 {
}
.text-3xl {
}
.text-2xl {
}
.text-xl {
}
.text-lg {
}
.text-md {
}
.text-base {
}
.text-xs {
}
.font-light {
}
.font-regular {
}
.font-medium {
}
.font-semibold {
}
.font-bold {
}
.capitalize {
}
.text-center {
}
.text-right {
}
.max-991 {
}
.max-767 {
}
.max-479 {
}
.text-accent {
}
.text-white {
}
.text-black {
}
.text-success {
}
.text-warning {
}
.text-danger {
}
.text-info {
}
.bg-primary {
}
.bg-secondary {
}
.bg-accent {
}
.bg-light {
}
.bg-dark {
}
.bg-black {
}
.bg-success {
}
.bg-warning {
}
.bg-danger {
}
.bg-info {
}
.rounded-sm {
}
.rounded-md {
}
.rounded-full {
}
.shadow-sm {
}
.shadow-md {
}
.shadow-lg {
}
.has-hover-lift {
}
.is-visible {
}
.gradient-overlay {
}
.gradient-overlay--animated {
}
.columns-stack-at-md {
}
.mobile--text-left {
}
.mobile--text-center {
}
.mobile--text-right {
}
.columns-stack-at-sm {
}
.mobile--justify-start {
}
.mobile--justify-center {
}
.mobile--justify-end {
}
.mobile--justify-between {
}
.mobile--align-start {
}
.mobile--align-center {
}
.mobile--align-end {
}
.mobile--gap-0 {
}
.mobile--gap-0-5 {
}
.mobile--gap-1-0 {
}
.mobile--gap-1-5 {
}
.mobile--ar-1-1 {
}
.mobile--ar-4-3 {
}
.mobile--ar-16-9 {
}
.mobile--ar-3-2 {
}
.dark-context {
}
.text-display-sm {
}
.text-display-md {
}
.text-display-lg {
}
.mobile--text-base {
}
.mobile--text-sm {
}
.mobile--text-xs {
}
.transition-all {
}
:root {
  /* =========================================
     1. BRAND TOKENS (Ads Patients Identity)
     ========================================= */
  /* Primary: Deep Indigo/Blue */
  --color-brand-primary: #2C3465;
  /* Secondary: Gold */
  --color-brand-secondary: #DBB665;
  /* Accent: Slate Blue */
  --color-brand-accent: #28384B;

  /* RGB versions for opacity helpers */
  --color-brand-primary-rgb: 44, 52, 101;
  --color-brand-secondary-rgb: 219, 182, 101;
  --color-brand-accent-rgb: 40, 56, 75;

  /* =========================================
     2. NEUTRALS & SYSTEM COLORS
     ========================================= */
  --color-white: #FEFEFE;
  --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: #333333; /* Body Text */
  --color-neutral-900: #1a1a1a;
  --color-black: #292728;        /* Headings */

  /* Semantic Mappings */
  --color-text-body: var(--color-neutral-800);
  --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);

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

  /* =========================================
     2.1 CONTEXT PROXY VARIABLES (NEW)
     Default values match the brand tokens above.
     These are re-mapped in Layer 6 for Dark Contexts.
     ========================================= */
  --ctx-text-primary: var(--color-brand-primary);
  --ctx-text-secondary: var(--color-brand-secondary);
  --ctx-text-accent: var(--color-brand-accent);
  --ctx-text-heading: var(--color-black);
  --ctx-text-muted: var(--color-neutral-600);

  /* =========================================
     3. TYPOGRAPHY
     ========================================= */
  /* Client Fonts */
  --font-family-heading: 'Mulish', system-ui, sans-serif;
  --font-family-base: 'Montserrat', system-ui, sans-serif; 
  --font-family-mono: ui-monospace, Menlo, Monaco, 'Courier New', monospace;

  /* Use for: Hero titles, short impact statements */
  --font-size-display-sm: clamp(3rem, 1.8rem + 5vw, 6rem);

  /* Use for: Massive headlines, 1-3 words max */
  --font-size-display-md: clamp(4rem, 1.5rem + 8vw, 9.5rem);

  /* Use for: Background texture, watermarks, purely decorative numbers */
  --font-size-display-lg: clamp(5rem, 0.5rem + 13vw, 14rem);

  /* Fluid Size Scale */
  --font-size-h1: clamp(2.25rem, 1.5rem + 4vw, 4.5rem);
  --font-size-h2: clamp(1.8rem, 1.2rem + 3vw, 3.25rem);
  --font-size-h3: clamp(1.4rem, 1.1rem + 2vw, 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.125rem);
  --font-size-sm: calc(var(--font-size-base) * 0.875);
  --font-size-xs: calc(var(--font-size-base) * 0.75);

  --line-height-tight: 1.2;
  --line-height-normal: 1.5;
  --line-height-loose: 1.7;

  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;

  /* =========================================
     4. SPACING & LAYOUT VARIABLES
     ========================================= */
  /* 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);

  /* Layout Configuration */
  --size-container-max-width: 1366px;
  --size-container-padding-inline: clamp(1rem, 0.5rem + 2.5vw, 2rem);
   
  /* Dynamic Header & Section Variables */
  --header-height: 80px;
  --section-spacing: var(--space-6-0);

  /* =========================================
     5. UI PROPERTIES
     ========================================= */
  --border-radius-sm: 4px;
  --border-radius-md: 8px;
  --border-radius-lg: 16px;
  --border-radius-full: 9999px; /* Pill Shape */
   
  --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);

  /* Context Aware Defaults */
  --context-text-color: var(--color-text-body);
  --context-border-color: var(--color-brand-primary);
  --context-bg-hover: var(--color-brand-primary);

  /* Animations */
  --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);
  --gradient-animation-duration: 10s;
}

/* =========================================
   Responsive Variable Overrides
   ========================================= */
@media (max-width: 991px) {
  :root {
    --header-height: 70px;
    --section-spacing: var(--space-4-0);
  }
}

/* =========================================
   LAYER 1: BASE & RESETS
   ========================================= */
html {
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-height) + var(--space-1-0));
}

*, *::before, *::after {
  box-sizing: inherit;
  overflow-wrap: break-word;
}
*::selection {
  color: var(--color-brand-primary);
  background-color: var(--color-brand-secondary);
}
::-webkit-scrollbar {
    width: 10px;
}
::-webkit-scrollbar-thumb:hover {
    background: #bfa05a;
}
::-webkit-scrollbar-thumb {
    background: #DBB665;
    border-radius: 5px;
}
::-webkit-scrollbar-track {
    background: var(--color-neutral-700);
}
/* Brand Focus Ring */
:focus-visible {
  outline: 2px solid var(--color-brand-primary);
  outline-offset: 2px;
}

body {
  background-color: var(--color-background-body);
  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;
}

a { color: unset; text-decoration: none; }
ul { padding-inline-start: 22px; }

/* Typography Defaults */
h1, h2, h3, h4, h5, h6, p {
  hyphens: auto;
  line-height: 1.3;
}

/* Text Balancing */
h1, h2, h3, .section-label__heading {
  text-wrap: balance;
}

p { margin-block: 0; }
img { object-fit: cover; }

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(0,99,172), transparent 40%),
        radial-gradient(circle at 90% 80%, rgb(236,126,0), transparent 50%),
        /* New blob with an accent color */
        radial-gradient(circle at 40% 50%, rgb(228,63,90), transparent 45%),
        radial-gradient(circle at 50% 90%, rgb(0,99,172), 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; */
}


/* =========================================
   LAYER 1.1: ANIMATIONS (UNCHANGED LOCATION)
   ========================================= */

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

.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, .oxygen-builder-body .has-fade-in {
  opacity: 1;
  transform: translateY(0);
}

.text-link {
  display: inline;
  text-decoration: none;
  font-weight: 700;
  padding-bottom: 2px;
  /* UPDATED: Uses proxy var to ensure visibility in dark mode */
  color: var(--ctx-text-primary, var(--color-brand-primary));
  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), 
              opacity 400ms var(--transition-easing-default), 
              transform 400ms var(--transition-easing-default);
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
.text-link:hover, a:hover .text-link { background-size: 100% 2px; }

.gradient-overlay {
  position: relative;
  z-index: 0;
  overflow: hidden;
}
.gradient-overlay::before {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  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.25), 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.25), transparent 35%),
    radial-gradient(circle at 50% 50%, rgba(var(--color-brand-secondary-rgb), 0.25), transparent 40%),
    radial-gradient(circle at 85% 30%, rgba(var(--color-brand-accent-rgb), 0.2), transparent 45%),
    radial-gradient(circle at 70% 85%, rgba(var(--color-brand-primary-rgb), 0.2), transparent 40%);
  background-size: 300% 300%;
  animation: gradientPan var(--gradient-animation-duration) ease-in-out infinite alternate;
}

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

@keyframes gradientWarp {
    0% { background-position: 0% 0%; } 
    40% { background-position: 70% 30%; } 
    100% { background-position: 100% 100%; } 
}

@keyframes gradientZoom {
    0% { background-size: 350% 350%; }
    50% { background-size: 300% 300%; }
    100% { background-size: 400% 400%; }
}

@keyframes pulse {
  50% { opacity: .5; }
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-20px); }
}


/* =========================================
   LAYER 2: LAYOUT SYSTEM
   ========================================= */

/* Container */
.container {
  width: 100%;
  max-width: var(--size-container-max-width);
  margin-inline: auto;
  padding-inline: var(--size-container-padding-inline);
  position: relative;
  z-index: 2;
   
  &:where(.dark-context) {
    padding-block: var(--space-4-0);
  }
}

/* Sections */
.section {
  position: relative;
  contain: layout paint; /* Performance Boost */
}

/* Oxygen Wrapper Override using Variables */
.section > .ct-section-inner-wrap {
  padding-block: var(--section-spacing);
  gap: var(--section-spacing);
  justify-content: center;
}

.section--dark {
  color: var(--color-white);
  background-color: var(--color-black);
  background-size: cover;
  background-position: center;
}

.section--dark::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(to bottom, rgba(41, 39, 40, 0.7), rgba(41, 39, 40, 0.9));
}

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

.section--hero {
  min-height: 100vh;
}

/* Header */
.header {
  position: relative;
  height: var(--header-height);
}

.header__row {
  padding: 0 1rem;
  height: var(--header-height);
}

.header__logo {
  position: relative;
}

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

.header__logo::before {
  content: '';
  position: absolute;
  z-index: 0;
  width: 100%;
  height: 100%;
  top: -50%;
  transform: translateY(50%);
  left: 0;
  filter: blur(25px);
  pointer-events: none;
  transition: opacity 0.4s ease;
}

.oxy-sticky-header-active {
  background-color: #ffffff30;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

/* =========================================
   LAYER 3: COMPONENTS
   ========================================= */

/* Button (Pill Shape) */
.btn {
  display: inline-flex;
  place-items: center;
  padding: var(--space-0-5) var(--space-0-5) var(--space-0-5) var(--space-1-5);
  font-family: var(--font-family-heading);
  font-weight: 700;
  line-height: 1;
  font-size: var(--font-size-base);
  text-align: center;
  text-decoration: none;
  border: var(--border-width-md) solid transparent;
  border-radius: var(--border-radius-full);
  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),
              transform 400ms var(--transition-easing-default);
  cursor: pointer;
}

/* Arrow Icon */
.btn::after {
  content: "⇢";
  line-height:0;
  margin-left: 0.6rem;
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  padding: 0 0 0 0;
  border-radius: var(--border-radius-full);
  background-color: var(--color-white);
  transition: transform var(--transition-speed-normal) var(--transition-easing-bounce);
}

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

/* Variants */
.btn--primary {
  background-color: var(--color-brand-primary);
  color: var(--color-white);
}
.btn--primary::after { color: var(--color-brand-primary); }
.btn--primary:hover { opacity: 0.95; box-shadow: 0 4px 12px rgba(var(--color-brand-primary-rgb), 0.3); }

.btn--secondary {
  background-color: var(--color-brand-secondary);
  color: var(--color-brand-primary);
}
.btn--secondary::after { color: var(--color-brand-secondary); background-color: var(--color-brand-primary); }
.btn--secondary:hover { opacity: 0.95; }

.btn--outline {
  background-color: transparent;
  border-color: var(--context-border-color);
  color: var(--context-border-color);
}
.btn--outline:hover {
  background-color: var(--context-bg-hover);
  color: var(--color-white);
}
.btn--outline:hover::after { color: var(--context-bg-hover); }

/* Sizes & Modifiers */
.btn--sm {
  padding: 0.4rem 0.4rem 0.4rem var(--space-1-0);
  font-size: var(--font-size-sm);
}
.btn--sm::after { width: 20px; height: 20px; margin-left: 0.35rem; font-size: 0.8em; }

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

.btn--lg::after { width: 40px; height: 40px; margin-left: 1rem; font-size: 1.2em; }

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

.btn--no-after {
  padding: var(--space-0-5) var(--space-1-5);
}
.btn--no-after::after { content: none; display: none; }

/* Card 
   Uses "Has Me" Pattern to turn parent into container automatically 
*/
.card {
  /* Enable Container Query on Parent */
  :has(> &) { container-type: inline-size; }

  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-md);
  padding: var(--space-1-5);
  contain: layout paint;
  background-color: var(--color-white);
}

.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-secondary);
  transform: translateY(-8px);
  box-shadow: var(--shadow-glow-primary);
}

/* Forms */
.form-label {
  display: block;
  margin-bottom: var(--space-0-5);
  font-size: var(--font-size-sm);
  font-weight: 700;
  font-family: var(--font-family-heading);
}

.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;
  font-family: var(--font-family-base);
}

.form-field:focus {
  border-color: var(--color-brand-primary);
  outline: none;
  box-shadow: 0 0 0 3px rgba(var(--color-brand-primary-rgb), 0.1);
}

/* Prose (Rich Text Wrapper) 
   Automatically spaces and styles raw HTML content
*/
.prose {
  --prose-spacing: 1.5em;
  max-width: 65ch; /* Optimal reading width */
}
.prose p {
  text-wrap: pretty; /* Prevents orphans */
}
.prose > * + * { margin-top: var(--prose-spacing); }
.prose :is(h1, h2, h3, h4, h5, h6) {
  margin-top: 2.5em;
  margin-bottom: 0.75em;
  line-height: 1.2;
}
.prose :is(ul, ol) { padding-left: 1.5em; }
.prose li + li { margin-top: 0.5em; }
.prose blockquote {
  border-left: 4px solid var(--color-brand-primary);
  padding-left: 1em;
  font-style: italic;
  color: var(--color-text-muted);
}

/* Grid Items Divider 
   Uses "Has Me" Pattern to turn parent into container 
*/
.grid-items-divider {
  /* Enable Container Query on Parent */
  :has(> &) { container-type: inline-size; }
}

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

.grid-items-divider > *:not(:first-child)::before {
  content: '';
  position: absolute;
  background-color: rgba(var(--color-brand-accent-rgb), 0.2);
  top: 20%; bottom: 20%; left: calc(var(--space-0-5) * -1);
  width: 1px; border-radius: 10px;
}

/* Unnamed container query targets nearest parent */
@container (max-width: 768px) {
  .grid-items-divider > *:not(:first-child)::before {
    top: calc(var(--space-0-5) * -1);
    bottom: unset;
    left: 20%; right: 20%;
    width: 60%; height: 1px;
  }
}

/* Section Label 
   Uses "Has Me" Pattern to turn parent into container 
*/
.section-label {
  /* Enable Container Query on Parent */
  :has(> &) { container-type: inline-size; }

  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1-0);
  width: 100%;
  margin-bottom: var(--space-1-0);
  text-align: left;
  flex-direction: row;
}

.section-label__icon {
  width: 70px;
  height: 14px;
  flex-shrink: 0;
  position: relative;
}

.section-label__icon::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgb(var(--color-brand-primary-rgb));
  --mask-url: 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-image: var(--mask-url);
  mask-image: var(--mask-url);
  -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;
}

.section-label__heading {
  font-size: var(--font-size-h5);
  font-weight: 800;
  text-transform: uppercase;
  /* UPDATED: Uses proxy var so it turns white in dark sections */
  color: var(--ctx-text-accent, var(--color-brand-accent));
  letter-spacing: 0.05em;
  margin: 0;
  white-space: nowrap;
}

.section-label__line {
  flex-grow: 1;
  height: 2px;
  position: relative;
}

.section-label__line::before {
  content: "";
  position: absolute;
  inset: 0;
  transform: scaleY(0.5);
  transform-origin: center;
  background: linear-gradient(to right, rgba(var(--color-brand-primary-rgb), 0.8), rgba(var(--color-brand-primary-rgb), 0.1));
}

.section-label--reversed {
  flex-direction: row-reverse;
}
.section-label--reversed .section-label__icon::before { transform: scaleX(-1); }
.section-label--reversed .section-label__line::before {
  background: linear-gradient(to left, rgba(var(--color-brand-primary-rgb), 0.8), rgba(var(--color-brand-primary-rgb), 0.1));
}

.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.8), rgba(var(--color-brand-secondary-rgb), 0.1));
}
.section-label--secondary.section-label--reversed .section-label__line::before {
   background: linear-gradient(to left, rgba(var(--color-brand-secondary-rgb), 0.8), rgba(var(--color-brand-secondary-rgb), 0.1));
}

/* Unnamed container queries for Section Label */
@container (max-width: 768px) {
  .section-label { gap: var(--space-0-5); flex-direction: row !important; }
  .section-label .section-label__icon { width: 55px; height: 11px; }
  .section-label .section-label__icon::before { transform: scaleX(1) !important; }
  .section-label .section-label__heading { font-size: var(--font-size-h6); }
  .section-label .section-label__line { width: 100%; flex-basis: 100%; order: 1; margin-top: 0.25em; }
  .section-label .section-label__line::before { background: linear-gradient(to right, rgba(var(--color-brand-primary-rgb), 0.8), rgba(var(--color-brand-primary-rgb), 0.1)) !important; }
}

@container (max-width: 400px) {
  .section-label { flex-direction: column !important; align-items: flex-start; gap: var(--space-0-5); }
  .section-label .section-label__line { flex-basis: auto; order: 0; margin-top: 0; }
}

/* =========================================
   LAYER 4: UTILITY CLASSES
   ========================================= */

/* JS Hook for staggered animations (Empty by design) */
.stagger-container {}

/* Generic "Has Me" Utility
   Place on a child to enable Container Queries on the parent 
*/
.enable-container {
  :has(> &) { container-type: inline-size; }
}

/* --- 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; }

.width-100 { width: 100%; }
.height-100 { height: 100%; }

/* Flex Alignment (Replaces old center-only utils) */
.justify-start { justify-content: flex-start; }
.justify-center { justify-content: center; }
.justify-end { justify-content: flex-end; }
.justify-between { justify-content: space-between; }

.align-start { align-items: flex-start; }
.align-center { align-items: center; }
.align-end { align-items: flex-end; }

/* --- Aspect Ratios --- */
/* Square */
.ar-1-1 { aspect-ratio: 1 / 1; }
/* Landscape */
.ar-16-9 { aspect-ratio: 16 / 9; }
.ar-4-3 { aspect-ratio: 4 / 3; }
.ar-3-2 { aspect-ratio: 3 / 2; }
/* Portrait */
.ar-9-16 { aspect-ratio: 9 / 16; }
.ar-3-4 { aspect-ratio: 3 / 4; }
.ar-2-3 { aspect-ratio: 2 / 3; }

/* --- Display & Position --- */
.is-hidden { display: none !important; }
.position-relative { position: relative; }
.sticky { position: sticky; top: calc(var(--header-height) + 1rem); }
.sticky-parent { position: relative; }

/* --- Collapse (Merge) Utilities --- */
.collapse-top > .ct-section-inner-wrap { padding-top: 0 !important; }
.collapse-bottom > .ct-section-inner-wrap { padding-bottom: 0 !important; }
.collapse-both > .ct-section-inner-wrap { padding-block: 0 !important; }

/* --- The Flow Utility --- */
.flow > * + * { margin-block-start: var(--flow-space, 1em); }

/* --- Spacing: Margins --- */
.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); }

.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); }

.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); }

.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); }

.mi-auto { margin-left: auto; margin-right: auto; }

/* --- Spacing: Padding --- */
.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); }

.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); }

.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); }

/* --- Spacing: Gaps --- */
.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-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); }

.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); }

/* --- Typography Utilities --- */
.text-display-sm { font-weight: 700; font-size: var(--font-size-display-sm); line-height: 1.1; }
.text-display-md { font-weight: 700; font-size: var(--font-size-display-md); line-height: 1; letter-spacing: -0.02em; }
.text-display-lg { font-weight: 700; font-size: var(--font-size-display-lg); line-height: 0.9; letter-spacing: -0.04em; }
h1, .text-3xl { font-weight: 700; font-size: var(--font-size-h1); line-height: var(--line-height-tight); text-transform: uppercase; }
h2, .text-2xl { font-weight: 700; font-size: var(--font-size-h2); line-height: var(--line-height-tight); }
h3, .text-xl { font-weight: 700; font-size: var(--font-size-h3); line-height: var(--line-height-tight); }
h4, .text-lg { font-weight: 700; font-size: var(--font-size-h4); line-height: var(--line-height-tight); }
h5, .text-md { font-weight: 700; font-size: var(--font-size-h5); line-height: var(--line-height-normal); }
h6 { font-weight: 700; 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-light { font-weight: 300; }
.font-regular { font-weight: 400; }
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }

.uppercase { text-transform: uppercase; }
.capitalize { text-transform: capitalize; }
.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; }

/* Colors (UPDATED WITH PROXY VARIABLES) */
.text-primary { color: var(--ctx-text-primary, var(--color-brand-primary)); }
.text-secondary { color: var(--ctx-text-secondary, var(--color-brand-secondary)); }
.text-accent { color: var(--ctx-text-accent, var(--color-brand-accent)); }
.text-black { color: var(--ctx-text-heading, var(--color-black)); }
.text-muted { color: var(--ctx-text-muted, var(--color-neutral-600)); }

/* Non-proxied colors (these are always legible or have their own bg contexts) */
.text-white { color: var(--color-white); }
.text-success { color: var(--color-success); }
.text-warning { color: var(--color-warning); }
.text-danger { color: var(--color-danger); }
.text-info { color: var(--color-info); }

.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); }

/* UI Utilities */
.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); }

.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }


/* =========================================
   LAYER 5: MEDIA QUERY OVERRIDES
   ========================================= */

@media (max-width: 991px) {
  .columns-stack-at-md > .ct-div-block {
    padding-block: var(--space-1-0) !important;
    padding-inline: 0 !important;
  }
}

@media (max-width: 767px) {
  .mobile--text-left { text-align: left; align-items: start; }
  .mobile--text-center { text-align: center; align-items: center; }
  .mobile--text-right { text-align: right; align-items: end; }
   
  .columns-stack-at-sm > .ct-div-block {
    padding-block: var(--space-1-0) !important;
    padding-inline: 0 !important;
  }

  /* --- Mobile Utility Overrides --- */

  .mobile--text-base { font-size: var(--font-size-base); }
  .mobile--text-sm { font-size: var(--font-size-sm); }
  .mobile--text-xs { font-size: var(--font-size-xs); }
   
  /* Mobile Flex Alignment */
  .mobile--justify-start { justify-content: flex-start; }
  .mobile--justify-center { justify-content: center; }
  .mobile--justify-end { justify-content: flex-end; }
  .mobile--justify-between { justify-content: space-between; }

  .mobile--align-start { align-items: flex-start; }
  .mobile--align-center { align-items: center; }
  .mobile--align-end { align-items: flex-end; }

  /* Mobile Gap Overrides */
  .mobile--gap-0 { gap: 0; }
  .mobile--gap-0-5 { gap: var(--space-0-5); }
  .mobile--gap-1-0 { gap: var(--space-1-0); }
  .mobile--gap-1-5 { gap: var(--space-1-5); }

  /* Mobile Aspect Ratio Overrides */
  .mobile--ar-1-1 { aspect-ratio: 1 / 1; }
  .mobile--ar-4-3 { aspect-ratio: 4 / 3; }
  .mobile--ar-16-9 { aspect-ratio: 16 / 9; }
  .mobile--ar-3-2 { aspect-ratio: 3 / 2; }
}

/* =========================================
   LAYER 6: CONTEXTUAL OVERRIDES
   ========================================= */

/* 1. DARK CONTEXT CONFIGURATION
   Redefine the proxy variables to White/Light for dark backgrounds. 
   Includes both .dark-context and .section--dark */
.dark-context,
.section--dark {
  color: var(--color-white);
  
  /* Map text proxies to White/Light */
  --ctx-text-primary: var(--color-white);
  --ctx-text-accent: var(--color-white);
  --ctx-text-heading: var(--color-white);
  --ctx-text-muted: var(--color-neutral-400); /* Lighter gray for dark backgrounds */
  
  /* Note: We leave --ctx-text-secondary as default (Gold) because it looks good on dark.
     If you want Gold to turn white too, uncomment the line below: */
  /* --ctx-text-secondary: var(--color-white); */

  /* Standard Context Variables */
  --context-text-color: var(--color-white);
  --context-border-color: var(--color-white);
  --context-bg-hover: var(--color-white);
}

.dark-context:focus-visible { outline-color: var(--color-white); }

.dark-context .card, .dark-context .shadow-sm { 
  box-shadow: 0 1px 2px 0 rgb(255 255 255 / 0.05); 
  background-color: rgba(255,255,255, 0.05); 
  border: 1px solid rgba(255,255,255,0.1); 
}
.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); }

.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); }


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


/* 2. NESTED LIGHT CONTEXT RESET (The Fix)
   If a light container exists INSIDE a dark context, reset variables 
   back to their original Brand Colors. */ 
.bg-white, 
.bg-light,
.bg-subtle,
.section--light {
  /* Reset proxies to brand colors */
  --ctx-text-primary: var(--color-brand-primary);
  --ctx-text-accent:  var(--color-brand-accent);
  --ctx-text-heading: var(--color-black);
  --ctx-text-muted:   var(--color-neutral-600);
  
  /* Reset Standard Contexts */
  color: var(--color-text-body);
  --context-text-color: var(--color-text-body);
  --context-border-color: var(--color-brand-primary);
}


/* Oxygen Specific Fixes */
main > .section:first-of-type > .ct-section-inner-wrap {
  padding-top: calc(var(--header-height) + 2rem) !important;
}:is(#_header-26-500010.oxy-header.oxy-overlay-header:not(.oxy-sticky-header-active)) {
  background-color: var(--color-white) !important;
}

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