.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: 1120px;
}
body {font-family: 'Open Sans';}body {line-height: 1.6;font-size: 16px;font-weight: 400;color: #404040;}.oxy-nav-menu-hamburger-line {background-color: #404040;}h1, h2, h3, h4, h5, h6 {font-family: 'Source Sans 3';font-size: 36px;font-weight: 700;}h2, h3, h4, h5, h6{font-size: 30px;}h3, h4, h5, h6{font-size: 24px;}h4, h5, h6{font-size: 20px;}h5, h6{font-size: 18px;}h6{font-size: 16px;}a {color: #ffffff;text-decoration: none;}a:hover {color: #fce200;text-decoration: none;}.ct-link-text {text-decoration: ;}.ct-link {text-decoration: ;}.ct-link-button {border-radius: 3px;}.ct-section-inner-wrap {
padding-top: 75px;
padding-right: 20px;
padding-bottom: 75px;
padding-left: 20px;
}.ct-new-columns > .ct-div-block {
padding-top: 20px;
padding-right: 20px;
padding-bottom: 20px;
padding-left: 20px;
}.oxy-header-container {
padding-right: 20px;
padding-left: 20px;
}@media (max-width: 992px) {
				.ct-columns-inner-wrap {
					display: block !important;
				}
				.ct-columns-inner-wrap:after {
					display: table;
					clear: both;
					content: "";
				}
				.ct-column {
					width: 100% !important;
					margin: 0 !important;
				}
				.ct-columns-inner-wrap {
					margin: 0 !important;
				}
			}
.brg-fs-cont {
background-size: cover; background-repeat:no-repeat;
 background-attachment:fixed;
 z-index:1;
 min-width:100vw;
 min-height:100vh;
 width:100%;
 height:100%;
 opacity:0.3;
 position:fixed;
}
.brg-fs-cont .ct-section-inner-wrap {
padding-top: 0;
padding-right: 0;
padding-bottom: 0;
padding-left: 0;
}
.brg-fs-cont:not(.ct-section):not(.oxy-easy-posts),
.brg-fs-cont.oxy-easy-posts .oxy-posts,
.brg-fs-cont.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
}
@media (max-width: 479px) {
.brg-fs-cont {
 position:fixed;
}
}

.brg-fs-bkgnd-img {
 object-fit:cover;
 aspect-ratio:initial;
 object-position:center center;
 width:100%;
 min-width:100vw;
 min-height:100vh;
 height:100%;
 position:absolute;
}
@media (max-width: 1120px) {
.brg-fs-bkgnd-img {
 position:absolute;
}
}

.brg-texture {
 object-fit:cover;
 aspect-ratio:initial;
 object-position:center center;
 width:100%;
 min-width:100vw;
 min-height:100vh;
 height:100%;
 position:absolute;
}
@media (max-width: 1120px) {
.brg-texture {
 position:absolute;
}
}

.brg-texture-cont {
background-size: cover; background-repeat:no-repeat;
 background-attachment:fixed;
 min-width:100vw;
 min-height:100vh;
 width:100%;
 height:100%;
 z-index:2;
 position:fixed;
 opacity:0.8;
 mix-blend-mode:normal;
}
.brg-texture-cont .ct-section-inner-wrap {
padding-top: 0;
padding-right: 0;
padding-bottom: 0;
padding-left: 0;
}
.brg-texture-cont:not(.ct-section):not(.oxy-easy-posts),
.brg-texture-cont.oxy-easy-posts .oxy-posts,
.brg-texture-cont.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
}
@media (max-width: 479px) {
.brg-texture-cont {
 position:fixed;
 text-align:center;
}
.brg-texture-cont:not(.ct-section):not(.oxy-easy-posts),
.brg-texture-cont.oxy-easy-posts .oxy-posts,
.brg-texture-cont.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
}
}

.brg-splash-cont {
 min-height:100vh;
 height:100%;
 width:100%;
 min-width:100vw;
 z-index:50;
 gap:4rem;
 border-top-color:#000000;
 border-top-width:36px;
 border-top-style:solid;
 border-bottom-color:#000000;
 border-bottom-width:36px;
 border-bottom-style:solid;
 padding-top:3rem;
 padding-right:2rem;
 padding-bottom:5rem;
 padding-left:2rem;
}
.brg-splash-cont:not(.ct-section):not(.oxy-easy-posts),
.brg-splash-cont.oxy-easy-posts .oxy-posts,
.brg-splash-cont.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
justify-content:flex-start;
gap:4rem;
}
@media (max-width: 1120px) {
.brg-splash-cont {
 gap:3rem;
 padding-top:3rem;
}
.brg-splash-cont:not(.ct-section):not(.oxy-easy-posts),
.brg-splash-cont.oxy-easy-posts .oxy-posts,
.brg-splash-cont.ct-section .ct-section-inner-wrap{
gap:3rem;
}
}

@media (max-width: 991px) {
.brg-splash-cont {
 padding-bottom:7rem;
 padding-top:5rem;
}
}

@media (max-width: 767px) {
.brg-splash-cont {
 gap:2rem;
 padding-right:1rem;
 padding-left:1rem;
}
.brg-splash-cont:not(.ct-section):not(.oxy-easy-posts),
.brg-splash-cont.oxy-easy-posts .oxy-posts,
.brg-splash-cont.ct-section .ct-section-inner-wrap{
gap:2rem;
}
}

.brg-splash-cta:hover{
transform:translateY(-2px); border-top-color:#fce200;
 border-right-color:#fce200;
 border-bottom-color:#fce200;
 border-left-color:#fce200;
 color:#000000;
 background-color:#fce200;
 padding-left:32px;
 padding-right:32px;
}
.brg-splash-cta {
 font-family:'Montserrat';
 padding-left:24px;
 padding-right:24px;
 padding-top:12px;
 padding-bottom:12px;
 border-top-color:#ffffff;
 border-right-color:#ffffff;
 border-bottom-color:#ffffff;
 border-left-color:#ffffff;
 border-top-width:2px;
 border-right-width:2px;
 border-bottom-width:2px;
 border-left-width:2px;
 border-top-style:solid;
 border-right-style:solid;
 border-bottom-style:solid;
 border-left-style:solid;
 transition-duration:0.4s;
 transition-timing-function:ease-out;
 color:#ffffff;
 font-size:32px;
 font-weight:600;
 line-height:1;
 letter-spacing:5px;
}
@media (max-width: 1120px) {
.brg-splash-cta {
 font-size:28px;
}
}

@media (max-width: 991px) {
.brg-splash-cta {
 font-size:24px;
}
}

@media (max-width: 767px) {
.brg-splash-cta {
 font-size:20px;
 padding-top:8px;
 padding-left:20px;
 padding-bottom:8px;
 padding-right:20px;
}
.brg-splash-cta:hover{
 padding-left:28px;
 padding-right:28px;
}
}

@media (max-width: 479px) {
.brg-splash-cta {
 padding-top:8px;
 padding-bottom:8px;
 padding-left:20px;
 padding-right:20px;
}
}

.icon-bar-trigger {
}
.icon-bar-trigger:not(.ct-section):not(.oxy-easy-posts),
.icon-bar-trigger.oxy-easy-posts .oxy-posts,
.icon-bar-trigger.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
}
.bkgnd-icons {
background-size: cover; background-repeat:no-repeat;
 background-attachment:fixed;
 min-width:100vw;
 min-height:100vh;
 width:100%;
 height:100%;
 z-index:4;
 position:fixed;
 opacity:0.8;
 mix-blend-mode:normal;
}
.bkgnd-icons .ct-section-inner-wrap {
padding-top: 0;
padding-right: 0;
padding-bottom: 0;
padding-left: 0;
}
.bkgnd-icons:not(.ct-section):not(.oxy-easy-posts),
.bkgnd-icons.oxy-easy-posts .oxy-posts,
.bkgnd-icons.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
}
@media (max-width: 479px) {
.bkgnd-icons {
 position:fixed;
 text-align:center;
}
.bkgnd-icons:not(.ct-section):not(.oxy-easy-posts),
.bkgnd-icons.oxy-easy-posts .oxy-posts,
.bkgnd-icons.ct-section .ct-section-inner-wrap{
display:flex;
flex-direction:column;
align-items:center;
}
}

.brg-comingsoon {
 z-index:4;
}
.brg-cs {
 visibility:visible;
}
.brg-cs__bar {
 z-index:8;
}
.brg-cs__bar--top {
 z-index:8;
}
.brg-cs__bar--bottom {
 z-index:8;
}
.brg-cs__bg {
 z-index:0;
}
.brg-photo {
background-size: cover;}
.brg-photo--skater {
 width:100%;
}
.brg-photo--car {
 visibility:visible;
}
.brg-photo--surfer {
 visibility:visible;
}
.brg-photo--crown {
 visibility:visible;
}
.brg-fx-blob {
}
.brg-fx-blob--1 {
 visibility:visible;
}
.brg-fx-blob--2 {
 visibility:visible;
}
.brg-fx-blob--3 {
 visibility:visible;
}
.brg-grit {
background-size: cover;}
.brg-bg__noise {
 background-repeat:repeat;
}
.brg-cs__frame {
 z-index:7;
}
.brg-cs__frame--top {
 visibility:visible;
}
.brg-cs__frame--bottom {
 z-index:7;
}
.brg-tagline {
}
.brg-tagline:not(.ct-section):not(.oxy-easy-posts),
.brg-tagline.oxy-easy-posts .oxy-posts,
.brg-tagline.ct-section .ct-section-inner-wrap{
display:block;
}
.brg-cs__content {
 z-index:5;
}
.brg-icons {
 position:relative;
}
.brg-ic--smiley-fill {
 z-index:1;
}
.brg-ic--text {
 z-index:2;
 width:100%;
}
.brg-ic--bolt {
 z-index:4;
}
.brg-ic--asterisk {
 z-index:5;
}
.brg-logo {
}
.brg-cta-wrap {
 position:relative;
}
.brg-cta {
 z-index:40;
}
.brg-comingsoon__text {
}
.brg-comingsoon__text:not(.ct-section):not(.oxy-easy-posts),
.brg-comingsoon__text.oxy-easy-posts .oxy-posts,
.brg-comingsoon__text.ct-section .ct-section-inner-wrap{
display:inline-block;
}
.brg-doodle {
 z-index:2;
}
.brg-fx-grain {
 z-index:6;
}
.brg-cta__sizer {
}
/* @version 1.03.00  ·  updated 2026-06-17  ·  Blacktop Restaurant Group — "Coming Soon" splash — stylesheet · Oxygen (assets at /wp-content/uploads/2026/06/; fonts loaded by theme)
   bump VERSION in build.py and run `python3 build.py` to re-stamp every file */
/* =========================================================================
   BLACKTOP RESTAURANT GROUP — "Coming Soon" splash
   Self-contained stylesheet for Oxygen Builder.
   Everything is namespaced under .brg-cs so it can't collide with the theme.

   This SOURCE file uses ../assets/ paths (for the local index.html preview).
   The Oxygen copy (oxygen/brg-coming-soon.css) is generated by build.py with all
   asset URLs flattened to WP_UPLOADS — set that path in build.py and re-run.
   ========================================================================= */

/* ----------------------------- Fonts ----------------------------------- */
/* ----------------------------- Tokens ---------------------------------- */
.brg-cs {
    --brg-yellow: #FCE200;
    /* Summer Sun  */
    --brg-white: #FFFFFF;
    /* Cloud Daze  */
    --brg-black: #000000;
    /* true black (marker doodle) */
    --brg-dark: #231F20;
    /* brand off-black (CTA hover text) */
    --brg-bg: #201f1d;
    /* dark charcoal base behind the photo collage (darkened) */
    --brg-bg-2: #131210;
    /* near-black at the edges (darkened) */
    --brg-mute: rgba(16, 15, 13, .66);
    /* dark veil that mutes the car/surfer to the skater's faint level */

    --brg-bar: 30px;
    /* top & bottom black screen-border bars */

    /* Pinned to the viewport and OUT OF FLOW: this guarantees true full-screen
     (breaks out of Oxygen's max-width content container → no 1440 cap) and means
     nothing inside can push the page taller than the screen (no scroll). */
    position: fixed;
    inset: 0;
    overflow: hidden;
    background:
        radial-gradient(120% 90% at 50% 12%, #2a2825 0%, var(--brg-bg) 45%, var(--brg-bg-2) 100%);
    color: var(--brg-white);
    font-family: "Montserrat", system-ui, sans-serif;
    isolation: isolate;
}

.brg-cs * {
    box-sizing: border-box;
}

/* The splash owns the whole viewport — no page scrolling. (Scope to the splash
   page; remove if this stylesheet is ever loaded site-wide.) */
html:has(.brg-cs),
body:has(.brg-cs) {
    margin: 0;
    height: 100%;
    overflow: hidden;
}

/* Neutralise any site-wide scroll-animation (AOS / Oxygen entrance effects) that
   injects data-aos onto these elements and fights the built-in entrance reveal
   (causes it to freeze partway / show wrong opacity). Higher specificity than
   aos.css but NO !important — so our own @keyframes still take over and play. */
.brg-cs[data-aos],
.brg-cs [data-aos] {
    opacity: 1;
    transform: none;
    transition: none;
}

/* 30px black screen-border bars, top & bottom (above everything) */
.brg-cs__bar {
    position: absolute;
    left: 0;
    right: 0;
    height: var(--brg-bar);
    background: #000;
    z-index: 8;
    pointer-events: none;
}

.brg-cs__bar--top {
    top: 0;
}

.brg-cs__bar--bottom {
    bottom: 0;
}

/* =========================================================================
   1. BACKGROUND LAYERS  (drop your photo collage / doodles in here)
   Each .brg-bg__layer is an independently-drifting plate. Set its image with
   an inline style or an extra class — placeholders are visible until you do.
   ========================================================================= */
.brg-cs__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}

/* --- Photo collage: each silhouette is its own faint, drifting plate.
   Positions are MOBILE-FIRST here; desktop layout is in the @media block.
   Tune the inset/width/opacity freely — the photos are meant to sit faint.
   webp first, jpg fallback via image-set(). ----------------------------- */
.brg-photo {
    position: absolute;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    opacity: .30;
    /* faint: whites read as grey on the dark bg */
    filter: grayscale(1) contrast(1.04);
    will-change: transform, opacity;
}

/* Car & surfer sit on a FULLY OPAQUE base (the dark bg colour) so the skater
   never shows through them. A radial overlay (transparent → solid bg) fades the
   photo into that base at the edges, so there's no hard rectangle and no skater
   bleed. They're fully opaque (no element opacity); subtlety comes from the
   overlay. (Base #2b2a28 = --brg-bg.) */
.brg-photo--car,
.brg-photo--surfer {
    opacity: 1;
    background-color: var(--brg-bg-2);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

/* === Photo ENTRANCES (play once, on a black screen) ===
   1) skater = full-screen center cover; fades in while scaling DOWN to size.
   2) surfer slides in from the bottom-right; car from the left; crown fades.
   Each then hands off to its slow drift loop (delayed past the entrance). */

.brg-photo--skater {
    /* FULL-SCREEN cover hero — always covers the viewport */
    inset: 0;
    width: 100%;
    height: 100%;
    min-width: 100vw;
    min-height: 100vh;
    background-position: center;
    background-size: cover;
    transform-origin: center;
    -webkit-mask-image: radial-gradient(ellipse 100% 100% at 50% 46%, #000 64%, transparent 100%);
    mask-image: radial-gradient(ellipse 100% 100% at 50% 46%, #000 64%, transparent 100%);
    background-image: image-set(url("/wp-content/uploads/2026/06/skater.webp") type("image/webp"),
        url("/wp-content/uploads/2026/06/skater.jpg") type("image/jpeg"));
    /* scales DOWN 120% → 102% and eases out to its final 102% (no jump back up);
     its drift loop also lives at 102% so the hand-off is seamless */
    animation: brg-skater-in 1.4s cubic-bezier(.16, .7, .2, 1) both,
        brg-skater-drift 36s ease-in-out infinite 1.4s;
}

@keyframes brg-skater-drift {
    0% {
        transform: scale(1.02) translate3d(0, 0, 0);
    }

    50% {
        transform: scale(1.05) translate3d(-1%, .8%, 0);
    }

    100% {
        transform: scale(1.02) translate3d(0, 0, 0);
    }
}

.brg-photo--car {
    /* car silhouette — enters from the LEFT */
    left: 0;
    bottom: 0;
    width: 50%;
    height: 30%;
    background-image:
        radial-gradient(ellipse 86% 86% at 50% 50%, transparent 58%, var(--brg-bg-2) 100%),
        /* soft edge → base */
        linear-gradient(var(--brg-mute), var(--brg-mute)),
        /* mute to skater level */
        image-set(url("/wp-content/uploads/2026/06/car.webp") type("image/webp"),
        url("/wp-content/uploads/2026/06/car.jpg") type("image/jpeg"));
    animation: brg-car-in 1s cubic-bezier(.2, .7, .2, 1) both .9s,
        brg-drift-a 40s ease-in-out infinite 1.9s;
}

.brg-photo--surfer {
    /* surfer — enters from the BOTTOM-RIGHT */
    right: 0;
    bottom: 0;
    width: 54%;
    height: 40%;
    background-image:
        radial-gradient(ellipse 86% 86% at 50% 50%, transparent 58%, var(--brg-bg-2) 100%),
        /* soft edge → base */
        linear-gradient(var(--brg-mute), var(--brg-mute)),
        /* mute to skater level */
        image-set(url("/wp-content/uploads/2026/06/surfer.webp") type("image/webp"),
        url("/wp-content/uploads/2026/06/surfer.jpg") type("image/jpeg"));
    animation: brg-surfer-in 1s cubic-bezier(.2, .7, .2, 1) both 1.05s,
        brg-drift-c 30s ease-in-out infinite 2.05s;
}

.brg-photo--crown {
    /* spray crown: pre-knocked-out white crown on transparent */
    top: 2%;
    right: 4%;
    width: 40%;
    aspect-ratio: 1/1;
    height: auto;
    background-size: contain;
    opacity: .8;
    filter: invert(1);
    transform-origin: center;
    background-image: image-set(url("/wp-content/uploads/2026/06/crown-white.webp") type("image/webp"),
        url("/wp-content/uploads/2026/06/crown-white.png") type("image/png"));
    animation: brg-crown-in .8s cubic-bezier(.2, .7, .2, 1) both 1.25s,
        brg-drift-c 26s ease-in-out infinite 2.05s;
}

@keyframes brg-skater-in {
    0% {
        opacity: 0;
        transform: scale(1.2);
    }

    100% {
        opacity: .30;
        transform: scale(1.02);
    }
}

@keyframes brg-car-in {
    0% {
        opacity: 0;
        transform: translateX(-60%);
    }

    100% {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes brg-surfer-in {
    0% {
        opacity: 0;
        transform: translate(58%, 46%);
    }

    100% {
        opacity: 1;
        transform: translate(0, 0);
    }
}

@keyframes brg-crown-in {
    0% {
        opacity: 0;
        transform: scale(.7);
    }

    100% {
        opacity: .8;
        transform: scale(1);
    }
}

/* Grit texture plate — sits over the photos, under the content */
.brg-grit {
    position: absolute;
    inset: -4%;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-image: url("/wp-content/uploads/2026/06/grit.webp");
    opacity: .45;
    mix-blend-mode: overlay;
    animation: brg-drift-a 48s ease-in-out infinite;
}

/* Animated noise texture — sits ON TOP OF THE PHOTOS (under the content).
   More present now: higher opacity + overlay blend, finer grain, faster jitter. */
.brg-bg__noise {
    position: absolute;
    inset: -15%;
    z-index: 1;
    pointer-events: none;
    opacity: .16;
    mix-blend-mode: overlay;
    /* extra grit on the photos/mid-tones */
    background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20width%3D%27150%27%20height%3D%27150%27%3E%3Cfilter%20id%3D%27n%27%3E%3CfeTurbulence%20type%3D%27fractalNoise%27%20baseFrequency%3D%270.9%27%20numOctaves%3D%272%27%20stitchTiles%3D%27stitch%27%2F%3E%3CfeColorMatrix%20type%3D%27saturate%27%20values%3D%270%27%2F%3E%3C%2Ffilter%3E%3Crect%20width%3D%27100%25%27%20height%3D%27100%25%27%20filter%3D%27url%28%23n%29%27%2F%3E%3C%2Fsvg%3E");
    background-repeat: repeat;
    background-size: 150px 150px;
    animation: brg-grain .42s steps(1, end) infinite;
}

/* --- Amoebic blobs: soft, blurred, morphing shapes drifting behind content.
   Pure CSS (just Divs) — very subtle. Sit inside .brg-cs__bg. ----------- */
.brg-fx-blob {
    position: absolute;
    border-radius: 45%;
    filter: blur(42px);
    opacity: .06;
    mix-blend-mode: screen;
    will-change: transform, border-radius;
    pointer-events: none;
}

.brg-fx-blob--1 {
    width: 46vmax;
    height: 46vmax;
    left: -10%;
    top: -12%;
    background: radial-gradient(circle at 50% 50%, var(--brg-yellow), transparent 68%);
    animation: brg-blob-1 34s ease-in-out infinite;
}

.brg-fx-blob--2 {
    width: 38vmax;
    height: 38vmax;
    right: -8%;
    bottom: -10%;
    background: radial-gradient(circle at 50% 50%, var(--brg-white), transparent 70%);
    opacity: .045;
    animation: brg-blob-2 46s ease-in-out infinite;
}

.brg-fx-blob--3 {
    width: 30vmax;
    height: 30vmax;
    left: 38%;
    top: 30%;
    background: radial-gradient(circle at 50% 50%, var(--brg-yellow), transparent 72%);
    opacity: .04;
    animation: brg-blob-3 40s ease-in-out infinite;
}

/* --- Animated film grain: subtle noise on TOP of everything ------------ */
.brg-fx-grain {
    /* CRSSD-style film grain over everything: big over-scan + large hard jumps so it
     "boils". Finer, contrastier grain tile; overlay blend so it reads on the dark bg. */
    position: absolute;
    inset: -10rem;
    z-index: 6;
    pointer-events: none;
    opacity: .42;
    mix-blend-mode: overlay;
    background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20width%3D%27200%27%20height%3D%27200%27%3E%3Cfilter%20id%3D%27n%27%3E%3CfeTurbulence%20type%3D%27fractalNoise%27%20baseFrequency%3D%270.72%27%20numOctaves%3D%273%27%20stitchTiles%3D%27stitch%27%2F%3E%3CfeColorMatrix%20type%3D%27saturate%27%20values%3D%270%27%2F%3E%3CfeComponentTransfer%3E%3CfeFuncA%20type%3D%27gamma%27%20amplitude%3D%271.1%27%20exponent%3D%271.6%27%20offset%3D%270%27%2F%3E%3C%2FfeComponentTransfer%3E%3C%2Ffilter%3E%3Crect%20width%3D%27100%25%27%20height%3D%27100%25%27%20filter%3D%27url%28%23n%29%27%2F%3E%3C%2Fsvg%3E");
    background-repeat: repeat;
    background-size: 200px 200px;
    animation: brg-grain-boil .4s steps(1, end) infinite;
    will-change: transform;
    backface-visibility: hidden;
}

/* CRSSD-style movement: large hard jumps each frame */
@keyframes brg-grain-boil {
    0% {
        transform: translate3d(0, 9rem, 0);
    }

    10% {
        transform: translate3d(-1rem, -4rem, 0);
    }

    20% {
        transform: translate3d(-8rem, 2rem, 0);
    }

    30% {
        transform: translate3d(9rem, -9rem, 0);
    }

    40% {
        transform: translate3d(-2rem, 7rem, 0);
    }

    50% {
        transform: translate3d(-9rem, -4rem, 0);
    }

    60% {
        transform: translate3d(2rem, 6rem, 0);
    }

    70% {
        transform: translate3d(7rem, -8rem, 0);
    }

    80% {
        transform: translate3d(-9rem, 1rem, 0);
    }

    90% {
        transform: translate3d(6rem, -5rem, 0);
    }

    100% {
        transform: translate3d(-7rem, 0, 0);
    }
}

/* thin frame lines — sit just inside the black screen-border bars */
.brg-cs__frame {
    position: absolute;
    left: -2%;
    right: -2%;
    height: 1px;
    background: rgba(255, 255, 255, 0.01);
    z-index: 7;
}

.brg-cs__frame--top {
    top: var(--brg-bar);
}

.brg-cs__frame--bottom {
    bottom: var(--brg-bar);
}

/* =========================================================================
   2. TAGLINE  "MAKE YOUR DAY GREAT!"  — faded, behind, jump-cut rock
   ========================================================================= */
.brg-tagline {
    position: absolute;
    top: calc(var(--brg-bar) + 1.5%);
    left: 4%;
    z-index: 2;
    width: clamp(150px, 22vw, 420px);
    opacity: .14;
    color: var(--brg-white);
    transform-origin: 18% 60%;
    /* fades in after the logo settles (~3.9s), then keeps rocking */
    animation: brg-rock 1.9s steps(1, end) infinite,
        brg-tagline-in .8s ease both 3.9s;
}

@keyframes brg-tagline-in {
    from {
        opacity: 0;
    }

    to {
        opacity: .14;
    }
}

.brg-tagline svg {
    display: block;
    width: 100%;
    height: auto;
}

.brg-tagline svg [id="tagline"],
.brg-tagline svg #tagline {
    opacity: 1 !important;
}

/* CSS owns the fade */

/* =========================================================================
   3. CONTENT STACK  (icons → logo → CTA), centered
   ========================================================================= */
.brg-cs__content {
    position: absolute;
    inset: 0;
    z-index: 5;
    /* fills the splash; above .brg-comingsoon (4) so the CTA stays on top */
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: clamp(6px, 1.8vh, 26px);
    /* leave room for the 30px bars + breathing space */
    padding: calc(var(--brg-bar) + clamp(20px, 6vh, 70px)) 24px;
    text-align: center;
}

/* Icons CLUSTER — the four standalone icon components are positioned into the
   original arrangement (bolt left, smiley upper-right, asterisk star on top,
   BRG below). Each component still carries its own jump-cut animation; only the
   placement lives here. Aspect ratio matches the source cluster (170 x 179). */
.brg-icons {
    position: relative;
    margin-inline: auto;
    /* bounded by BOTH width and height so the whole stack always fits the screen */
    width: clamp(150px, min(19vw, 21vh), 270px);
    aspect-ratio: 303 / 317;
}

.brg-icons .brg-ic {
    position: absolute;
}

/* override standalone inline-block */
/* positions measured from graphics/icons.svg so the overlap matches exactly */
.brg-icons .brg-ic--bolt {
    left: 0.0%;
    top: 24.8%;
    width: 30.8%;
    z-index: 4;
}

.brg-icons .brg-ic--smiley-fill {
    left: 37.6%;
    top: 2.4%;
    width: 60.8%;
    z-index: 1;
}

.brg-icons .brg-ic--asterisk {
    left: 31.0%;
    top: 0%;
    width: 18.7%;
    z-index: 5;
}

.brg-icons .brg-ic--text {
    left: 22.2%;
    top: 46.2%;
    width: 77.6%;
    z-index: 2;
}

/* Logo container — the logo component fills it. Bump --brg-logo-w to scale up.
   Capped by height (70vh) too so it never forces the page taller than the screen. */
.brg-cs {
    --brg-logo-w: clamp(280px, min(60vw, 72vh), 1040px);
}

.brg-logo {
    width: var(--brg-logo-w);
    height: auto;
}

/* CTA — SAY HELLO. Reveal: a centre line expands left+right, then the line opens
   up into the box and the (always-present) "Say Hello" text is revealed. */
/* shared CTA typography (sizer + visible text must match) */
.brg-cta__sizer,
.brg-cta__text {
    font-family: "Montserrat", sans-serif;
    font-weight: 600;
    font-size: clamp(13px, 1.4vw, 20px);
    letter-spacing: .42em;
    text-indent: .42em;
    text-transform: uppercase;
    white-space: nowrap;
}

/* wrap defines the FINAL button size via the (invisible) sizer */
.brg-cta-wrap {
    position: relative;
    display: inline-block;
    line-height: 0;
    margin-top: clamp(14px, 4vh, 40px);
}

.brg-cta__sizer {
    display: block;
    visibility: hidden;
    pointer-events: none;
    padding: .75em 1.15em;
    border: 2px solid transparent;
    line-height: 1;
}

/* the bordered box: grows from a 0×0 point at the wrap's centre, overflow-clipped */
.brg-cta {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 0;
    height: 0;
    overflow: hidden;
    border: 2px solid var(--brg-white);
    box-sizing: border-box;
    display: block;
    text-decoration: none;
    transform: translate(-50%, -50%);
    animation: brg-cta-grow 1.05s both 3.85s;
    transition: background-color .25s ease;
}

.brg-cta:hover,
.brg-cta:focus-visible {
    background: var(--brg-white);
}

/* "Say Hello" pinned to the button centre; clipped by the box until it opens */
.brg-cta__text {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    color: var(--brg-white);
    line-height: 1;
}

.brg-cta:hover .brg-cta__text,
.brg-cta:focus-visible .brg-cta__text {
    color: var(--brg-dark);
}

@keyframes brg-cta-grow {
    0% {
        width: 0;
        height: 0;
        animation-timing-function: ease-out;
    }

    /* nothing */
    9% {
        width: 0;
        height: 2px;
        animation-timing-function: cubic-bezier(.5, 0, .2, 1);
    }

    /* 2px high */
    58% {
        width: 100%;
        height: 2px;
        animation-timing-function: linear;
    }

    /* width eases out */
    100% {
        width: 100%;
        height: 100%;
    }

    /* opens (no ease) */
}

/* =========================================================================
   4. COMING SOON  — yellow brush script, rotated
   ========================================================================= */
/* Coming-soon lives in its OWN absolute container: a max-1440 box CENTERED in the
   viewport and pinned to the bottom, BELOW the content layer (z 4 < 5). The unit
   (text + smiley) sits inside it — centred on mobile, pinned RIGHT on desktop.
   Being absolute + low z-index, it never adds to the content height. */
.brg-comingsoon {
    position: absolute;
    z-index: 4;
    left: 0;
    right: 0;
    bottom: 30px;
    /* full width, pinned to the bottom */
    padding: 0 clamp(20px, 4vw, 90px) calc(var(--brg-bar) + clamp(10px, 2.5vh, 28px));
    display: flex;
    justify-content: center;
    /* base (≤980): centred */
    pointer-events: none;
}

.brg-comingsoon__inner {
    position: relative;
    display: inline-block;
    z-index: 4;
    /* never wider than the viewport: the text WRAPS instead of running off-screen */
    max-width: min(88vw, 1150px);
    transform-origin: center bottom;
    animation: brg-cs-in .7s cubic-bezier(.34, 1.45, .5, 1) both 4.2s;
}

@keyframes brg-cs-in {
    0% {
        opacity: 0;
        transform: scale(.85);
    }

    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.brg-comingsoon__text {
  position: relative;  
  display: inline-block;
    font-family: "Blanco Cavelary", cursive;
    color: var(--brg-yellow);
    /* big on phones (13vw → wraps to two lines), capped so one line fits on desktop */
    font-size: clamp(3rem, 13vw, 6rem);
    line-height: .82;
    transform: rotate(-8deg);
    z-index: 4;
}

/* marker smiley — pinned to the lower-right of "Coming soon", moves with it; zooms in */
.brg-doodle {
    position: absolute;
    right: -0.55em;
    bottom: -1.75em;
    width: clamp(66px, 13vw, 122px);
    color: var(--brg-white);
    pointer-events: none;
    transform-origin: center;
    z-index: 3;
    animation: brg-doodle-in .55s cubic-bezier(.34, 1.5, .5, 1) both 4.55s;
}

.brg-doodle svg {
    display: block;
    width: 100%;
    height: auto;
    z-index: 3;
    overflow: visible;
}

@keyframes brg-doodle-in {
    0% {
        opacity: 0;
        transform: scale(.2);
    }

    100% {
        opacity: .92;
        transform: scale(1);
    }
}

/* =========================================================================
   5. RESPONSIVE  — desktop spreads tagline TL / coming-soon BR
   ========================================================================= */
/* ≥980px: the coming-soon unit pins to the RIGHT inside the centred 1440 box.
   Below 980 it stays centred (the base rule). */
@media (min-width:980px) {
    .brg-comingsoon {
        justify-content: flex-end;
    }
}

@media (min-width:992px) {
    .brg-cs__content {
        gap: clamp(8px, 2vh, 30px);
    }

    .brg-tagline {
        top: calc(var(--brg-bar) + 4%);
        left: 5%;
    }

    /* desktop: skater stays full-cover; accents sit at the edges */
    .brg-photo--car {
        left: 0;
        bottom: 0;
        width: 31%;
        height: 58%;
    }

    .brg-photo--surfer {
        right: 0;
        bottom: 0;
        top: auto;
        width: 29%;
        height: 78%;
    }

    .brg-photo--crown {
        top: 3%;
        right: 3%;
        width: 11%;
    }
}

/* =========================================================================
   KEYFRAMES
   ========================================================================= */

/* --- background drift (smooth, subtle) --- */
@keyframes brg-drift-a {
    0% {
        transform: translate3d(0, 0, 0) scale(1.02);
    }

    50% {
        transform: translate3d(-1.4%, 1%, 0) scale(1.05);
    }

    100% {
        transform: translate3d(0, 0, 0) scale(1.02);
    }
}

@keyframes brg-drift-b {
    0% {
        transform: translate3d(0, 0, 0) scale(1.04);
    }

    50% {
        transform: translate3d(1.6%, -1.2%, 0) scale(1.07);
    }

    100% {
        transform: translate3d(0, 0, 0) scale(1.04);
    }
}

@keyframes brg-drift-c {
    0% {
        transform: translate3d(0, 0, 0) rotate(0deg);
    }

    50% {
        transform: translate3d(-1%, -0.6%, 0) rotate(.4deg);
    }

    100% {
        transform: translate3d(0, 0, 0) rotate(0deg);
    }
}

/* --- amoebic blob morph + drift (smooth, organic) --- */
@keyframes brg-blob-1 {
    0% {
        border-radius: 42% 58% 63% 37%/45% 38% 62% 55%;
        transform: translate(0, 0) rotate(0deg) scale(1);
    }

    50% {
        border-radius: 58% 42% 38% 62%/55% 62% 38% 45%;
        transform: translate(6%, 4%) rotate(18deg) scale(1.08);
    }

    100% {
        border-radius: 42% 58% 63% 37%/45% 38% 62% 55%;
        transform: translate(0, 0) rotate(0deg) scale(1);
    }
}

@keyframes brg-blob-2 {
    0% {
        border-radius: 60% 40% 47% 53%/52% 55% 45% 48%;
        transform: translate(0, 0) rotate(0deg) scale(1);
    }

    50% {
        border-radius: 40% 60% 55% 45%/48% 42% 58% 52%;
        transform: translate(-5%, -4%) rotate(-15deg) scale(1.06);
    }

    100% {
        border-radius: 60% 40% 47% 53%/52% 55% 45% 48%;
        transform: translate(0, 0) rotate(0deg) scale(1);
    }
}

@keyframes brg-blob-3 {
    0% {
        border-radius: 50% 50% 55% 45%/55% 45% 55% 45%;
        transform: translate(0, 0) rotate(0deg) scale(1);
    }

    50% {
        border-radius: 45% 55% 45% 55%/45% 55% 45% 55%;
        transform: translate(4%, -5%) rotate(24deg) scale(1.1);
    }

    100% {
        border-radius: 50% 50% 55% 45%/55% 45% 55% 45%;
        transform: translate(0, 0) rotate(0deg) scale(1);
    }
}

/* --- film grain jitter: shift the noise tile each frame (hard cuts) --- */
@keyframes brg-grain {
    0% {
        transform: translate(0, 0);
    }

    10% {
        transform: translate(-4%, 3%);
    }

    20% {
        transform: translate(5%, -3%);
    }

    30% {
        transform: translate(-3%, -5%);
    }

    40% {
        transform: translate(4%, 4%);
    }

    50% {
        transform: translate(-5%, 2%);
    }

    60% {
        transform: translate(3%, -4%);
    }

    70% {
        transform: translate(-2%, 5%);
    }

    80% {
        transform: translate(5%, -2%);
    }

    90% {
        transform: translate(-4%, -3%);
    }

    100% {
        transform: translate(0, 0);
    }
}

/* --- tagline jump-cut rock: 3 frames, hard cuts (stop-motion) --- */
@keyframes brg-rock {

    0%,
    32% {
        transform: rotate(-3deg) translate(0px, 0px);
    }

    33%,
    65% {
        transform: rotate(2.6deg) translate(6px, -5px);
    }

    66%,
    100% {
        transform: rotate(-0.8deg) translate(-3px, 2px);
    }
}

/* NOTE: the LOGO reveal and the four ICON jump-cuts now live inside their own
   self-contained components (see /components/*.html). Each component ships its
   own <style> + keyframes + reduced-motion guard, so they're fully portable —
   drop one into any Oxygen Code Block and it animates on its own. */

/* =========================================================================
   ACCESSIBILITY — respect reduced motion (everything rests in final state)
   ========================================================================= */
@media (prefers-reduced-motion:reduce) {

    .brg-tagline,
    .brg-comingsoon__inner,
    .brg-doodle,
    .brg-photo--skater,
    .brg-photo--car,
    .brg-photo--surfer,
    .brg-photo--crown,
    .brg-grit,
    .brg-bg__noise,
    .brg-cta,
    .brg-fx-blob--1,
    .brg-fx-blob--2,
    .brg-fx-blob--3,
    .brg-fx-grain {
        animation: none !important;
    }

    .brg-tagline {
        opacity: .14;
    }

    /* reveal the size/scale-hidden elements at rest */
    .brg-cta {
        width: 100%;
        height: 100%;
    }

    .brg-photo--skater {
        transform: scale(1.02);
    }

    /* (component animations have their own reduced-motion guards) */