/*
Theme Name: Bricks Child Theme
Theme URI: https://bricksbuilder.io/
Author: Bricks
Author URI: https://bricksbuilder.io/
Description: Visual website builder for WordPress.
Version: 2.0
License: GPLv2
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: bricks
Template: bricks
*/


/*******************************************************************************
						KAPITAN SPECIFIC STYLES
*******************************************************************************/
:root{
	--bricks-woo-input-height:45px;
	--cubic-clip: cubic-bezier(0.2,1,0.3,1); /*clip animations*/
	--cubic-line: cubic-bezier(.2,.75,.5,1); /*(under)line animations*/
}

/********* Generic Tags and Classes **********/

/*touchscreen: make sure that clicks work fine on first time*/
a, a::before, a::after {
  cursor: pointer;
  touch-action: manipulation;
  pointer-events: auto;
}

a::before, a::after {
  -webkit-tap-highlight-color: transparent;
}

#top .disabled, #top :disabled, #top disabled {
    opacity: .2;
}


html .button , #top .wc-block-components-button, html .bricks-button{
    transition: all 0.3s ease-in-out;
    padding: var(--space-xs) calc(var(--space-xs) * 2);
	line-height: 3rem;
	text-transform: uppercase;
	font-weight: normal;
	font-size: var(--text-s);
}

html .button , #top .wc-block-components-button, html .bricks-button:not([class*='bricks-background-'], [class*='bricks-color-']){
	background: var(--base-ultra-dark);
    color: var(--text-on-primary);
}

/*.button:not(.disabled):hover*/
html .button:hover , #top .wc-block-components-button:hover, #top .bricks-button:hover{
    background: var(--primary);
    color: var(--text-on-primary);
}

html select{
	padding-right: 40px;
	border: 1px solid var(--base-light);
	border-radius: 0px !important;
	background-image: linear-gradient(45deg, transparent 50%, var(--base-ultra-dark, #000) 0), linear-gradient(135deg, var(--base-ultra-dark, #000) 50%, transparent 0);
	line-height: var(--bricks-woo-input-height);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.select2-dropdown, .select2-search--dropdown, .select2-container--default .select2-search--dropdown .select2-search__field{
    border-color: var(--base-light);
	font-size: var(--text-s);
}

.select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: var(--base-meta) transparent transparent transparent;
}

.select2-container--default .select2-results__option--highlighted[aria-selected], .select2-container--default .select2-results__option--highlighted[data-selected] {
    background-color: var(--primary);
}

.select2-selection .select2-selection__rendered {
    line-height: var(--bricks-woo-input-height);
    font-weight: 400;
    font-size: var(--text-s);
	padding: 0 calc(var(--space-xs));
}

.select2-results__option {
    font-size: var(--text-s);
    font-weight: 400;
}

input{
  background-color: var(--base-bg);
}

input[type='checkbox'], 
input[type='radio']{
  padding: 0;
}

#top input{
	border-radius: 0;
}

#top input[type='radio']{
  border-radius: 100px;
  border-color: var(--base-light);
}



::placeholder{
	color:var(--base-meta);
}

.post-suffix{
	color: var(--base-meta);
	font-size: 0.5em;
	line-height: 1.2;
}

.post-suffix:empty{
	display: none;
}

/* .post-suffix:not(:empty)::before {
    content: " - ";
} */

:is(.brxe-post-content, .brxe-text, .brxe-text-basic) :is(ul, ol){
	margin-left: 1.65rem;
	margin-bottom:1em;
}

input:not(:placeholder-shown)::placeholder {
  display: none;
}


/*animated a links. __links for underline and __links-inv for underline on hover */
/* base link style */
:is(.brxe-post-content, [class*="brxe-text"]) a:not([class], :has(*)), 
[class*="__links"] a, 
.woocommerce-MyAccount-content a:not(.button),
:where(.bricks-widget-wrapper) a{
	text-decoration: none;
	background: linear-gradient(currentColor, currentColor) left bottom / 100% 1px no-repeat;
	transition: background-size .55s var(--cubic-line);
	display: inline;
  }
  
/* inverted links */
.__links-inv a, :where(.bricks-widget-wrapper) a{
	background-size: 0% 1px; /* expand underline */
	background-position: right bottom;
}

@media (hover: hover) and (pointer: fine) {
  /* apply hover effects only on devices that can hover precisely */

  /* hover animation */
  :is(.brxe-post-content, [class*="brxe-text"]) a:not([class], :has(*)):hover, [class*="__links"] a:hover, 
  .woocommerce-MyAccount-content a:not(.button):hover{
	  background-size: 0% 1px; /* expand underline */
	  background-position: right bottom;
  }

  /* inverted hover */
  .__links-inv a:hover, :where(.bricks-widget-wrapper) a:hover{
    background-size: 100% 1px; /* expand underline */
    background-position: left bottom;
  }
}



.bricks-posts-nothing-found{
	display: flex;
	place-content:center;
}


/*closing mouse cursor*/
.brx-offcanvas-backdrop,
.off-canvas-overlay,
.woocommerce-notices-wrapper:not(:empty){
	cursor: url('data:image/svg+xml;utf8,\<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24">\<line x1="4" y1="4" x2="20" y2="20" stroke="white" stroke-width="2"/>\<line x1="20" y1="4" x2="4" y2="20" stroke="white" stroke-width="2"/>\</svg>') 12 12, pointer;
}

/********* End Generic Tags and Classes **********/





/********* Site Passpartout **********/
:root{
	--passpartout: var(--space-xs, 0px);
  --sticky-admin-bar:var(--wp-admin--admin-bar--height, 0px);
	--sticky-top: var(--sticky-admin-bar, 0px); /*overwrite in bricks*/
	--toc-height: 0px; /*table of content menu - overwrite in bricks*/
	--full-height: calc(100vh - var(--sticky-top, 0px) - var(--passpartout) ); /*full height minus Admin Bar & ppt*/
	--full-width:  calc(100vw - ( var(--passpartout) * 2 ) ); /*full width & ppt*/
	--full-height-with-menu: calc( var( --full-height ) - var(--toc-height, 0px) ); /* Minus Sticky TOC Menu */
	--sticky-top-with-menu: calc( var(--sticky-top, 0px) + var(--toc-height, 0px) );
}

html, body {
  overflow-x: clip;
}

body{
background: var(--base-bg);
padding: var(--passpartout);
min-height: calc(100vh - var(--wp-admin--admin-bar--height, 0)); /*footer at bottom on small pages*/
}

html::before, html::after, body::before, body::after {
display: block;
position: fixed;
width: 100%;
height: var(--passpartout);
background: var(--site-bg);
content: "";
z-index: 2000;
top: var(--wp-admin--admin-bar--height, 0);
left:0;
}

body::after{
top:auto;
bottom:0;
left:0;
}

html::before, html::after{
width: var(--passpartout);
height: 100%;
}

html::after{
right:0;
left:auto;
}

@media (max-width: 767px) {
    :root{
		--passpartout: 0px;
		--sticky-top: var(--wp-admin--admin-bar--height, 0px);
	}

	html::before, html::after, body::before, body::after{
		display: none;
	}
}

@media (max-width: 600px) {
    :root{
		--sticky-admin-bar:0px; /*600px and the admin bar is unstuck*/
	}
}


/********** End Site Passpartout **********/


/********** Animated Icons **********/

/*Animated Burger icon*/
/*from: https://codepen.io/Prowhiz/pen/MWRQWRV */
svg.ham {
  --icon-size: 5rem;
  width: var(--icon-size);
}
.ham {
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: transform 400ms;
  user-select: none;
}
.is-active .hamRotate {
  transform: rotate(45deg);
}
.ham .line {
  fill:none;
  transition: stroke-dasharray 400ms, stroke-dashoffset 400ms;
  stroke:#000;
  stroke-width:3;
  stroke-linecap:round;
}

/*ham4*/
.ham4 .top {
  stroke-dasharray: 40 121;
}
.ham4 .bottom {
  stroke-dasharray: 40 121;
}
.is-active .ham4 .top {
  stroke-dashoffset: -68px;
}
.is-active .ham4 .bottom {
  stroke-dashoffset: -68px;
}



/********** Animated Close Icon **********/
.__animated-close-icon{
    --close-icon-size: 24px;
    --close-line-width: 1.5px;
    --close-line-offset: 14px;
    --close-offset: 0.3s;
	--close-wait-active:0;
    position: relative;
    display: inline-block;
    width: var(--close-icon-size);
    height: var(--close-icon-size);
	cursor: pointer;
	outline: 2px solid transparent;
    outline-offset: 8px;
	transition: all 0.3s var(--cubic-line);
	border-radius: 200px;
  color:var(--base-dark);
}

.__animated-close-icon:hover{
	outline-color: currentColor;
    transform: scale(0.8) rotateZ(90deg);
}

.__animated-close-icon::before {
    --close-rotation: -45deg;
    --close-start-x: calc(-50% - var(--close-line-offset));
    --close-start-y: calc(-50% + var(--close-line-offset));
    --close-animation-offset: calc(0.15s + var(--close-offset) * var(--close-wait-active));
}

.__animated-close-icon::after {
    --close-rotation: 45deg;
    --close-start-x: calc(-50% + var(--close-line-offset));
    --close-start-y: calc(-50% + var(--close-line-offset));
    --close-animation-offset: calc(0.3s + var(--close-offset) * var(--close-wait-active));
}

.__animated-close-icon::before,
.__animated-close-icon::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: var(--close-line-width);
    background: currentColor;
    opacity: 0;
    transform-origin: center;
    transform: translate(var(--close-start-x, -50%), var(--close-start-y, -50%)) rotate(var(--close-rotation, 0deg));
	  transition: all 0.4s var(--cubic-line) var(--close-animation-offset);
}



:where(.brx-open, .active, .brx-popup:not(.hide)) .__animated-close-icon::before,
:where(.brx-open, .active, .brx-popup:not(.hide)) .__animated-close-icon::after{
	transform: translate(-50%, -50%) rotate(var(--close-rotation, 0deg));
	opacity: 1;
	--close-wait-active:1;
}

.__animated-close-icon .brxa-wrap,  .__animated-close-icon svg{
	display: none;
}

.brx-popup .__animated-close-icon{
--close-offset: 0.7s;
}


/********** End Animated Icons **********/

/********** Default Non Bricks Page Styling **********/
/*Normalize Padding, Page Width and Max width*/
body.bricks-content-disabled{
    background: var(--base-bg);
}

body #brx-content.wordpress,
body #brx-content.layout-default,
body.woocommerce main.site-main{
	padding: var(--padding-section-small);
}

@media (max-width: 767px) {
	body #brx-content.wordpress,
	body #brx-content.layout-default,
	body.woocommerce main.site-main{
	    padding: var(--padding-section-small) var(--padding-mobile-side, 1.5em);
	}

  body .__padding-mobile-side{
    padding-left: var(--padding-mobile-side, 1.5em);
    padding-right: var(--padding-mobile-side, 1.5em);
  }
}

body .layout-default .brxe-container{
	padding:0;
}

body #brx-content.wordpress,
body.woocommerce main.site-main{
	width: 100%;
}

body #brx-content.wordpress > *,
body.woocommerce main.site-main > *{
	width: 100%;
	max-width: 1600px;
	margin-left: auto;
	margin-right: auto;
}

/********** Default Page Styling **********/




/********** Bricks Element Mini Cart **********/

.cart-detail{
	border:none;
	font-size: var(--text-s);
	z-index: 1002;
}

.mod_widget_shopping_cart_title{
    display: flex;
    background: var(--base-ultra-light);
    padding: var(--space-s);
	height:70px;
	align-items: center;
	font-size: var(--text-m);
  line-height: 1;
  margin-top: var(--passpartout);
}

.bricks-mini-cart-close {
    top: calc(var(--space-s) + 9px + var(--passpartout));
    right: calc(var(--space-s) + 5px);
    position: absolute;
}

.cart-detail .widget_shopping_cart_content{
	padding:0;
	height: calc(100% - 60px - var(--space-xs) - var(--passpartout) * 2);
}

.woocommerce-mini-cart, .woocommerce-mini-cart__total{
	padding:var(--space-m);
}

.woocommerce-mini-cart__buttons{
	padding:0 var(--space-m) var(--space-m) var(--space-m);
}

.woocommerce-mini-cart__buttons .button{
	line-height: 4rem;
}

.woocommerce-mini-cart__empty-message{
    font-size: var(--text-m);
    padding: var(--space-section) var(--space-l);
}

.wc-forward:not(.checkout) {
	background-color: var(--base-light);
    color: var(--base);
}

.cart-detail li {
    margin-bottom: var(--space-m);
}

.off-canvas-overlay{
	    background-color: rgba(0, 0, 0, .5);
}

.blockUI.blockOverlay{
	background: var(--base-bg) !important;
}

.brx-offcanvas-backdrop,
.off-canvas-overlay,
.brx-popup-backdrop{
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}

.brxe-woocommerce-mini-cart .cart-detail.off-canvas .woocommerce-mini-cart__total {
    margin-block: auto 20px;
}

/********** End Bricks Element Mini Cart **********/


/********** Bricks (Mobile Only) & Search Flyout **********/

.brxe-offcanvas .brx-offcanvas-inner{
	top:var(--sticky-top);
	bottom:var(--passpartout);
	max-height: var(--full-height);
}

.brxe-offcanvas[data-direction="top"] .brx-offcanvas-inner{
	bottom: auto;
	left:var(--passpartout);
	right:var(--passpartout);
	width: calc(100% - ( var(--passpartout) * 2 ) ); /*cant use vw because of scrollbar problem*/
}

.brxe-offcanvas[data-direction=left] .brx-offcanvas-inner{
	left:var(--passpartout);
}

.brxe-offcanvas[data-direction=right] .brx-offcanvas-inner{
	right:var(--passpartout);
}


/*clip reveal offcanvas*/
.brxe-offcanvas.__clip-offcanvas .brx-offcanvas-inner{
	transition: clip-path 0.8s var(--cubic-clip);
	transform: translate(0);
}

.brxe-offcanvas[data-direction="top"].__clip-offcanvas .brx-offcanvas-inner{
  clip-path: inset(0 0 100% 0);
}

.brxe-offcanvas[data-direction="left"].__clip-offcanvas .brx-offcanvas-inner{
  clip-path: inset(0 100% 0 0 );
}

.brxe-offcanvas[data-direction="right"].__clip-offcanvas .brx-offcanvas-inner{
  clip-path: inset(0 0 0 100%);
}

#top .brxe-offcanvas.__clip-offcanvas.brx-open .brx-offcanvas-inner{
  clip-path: inset(0);
  transition-delay: 0.1s;
}



@media (min-width: 992px) {
	.__mobile-only-offcanvas.brxe-offcanvas{
		visibility: visible;
	}

	.__mobile-only-offcanvas .brx-offcanvas-inner{
		position: static;
		transform: translate(0);
		height: auto;
		transition: none;
		max-height: none;
		width: auto;
		overflow: unset;
	}

	.__mobile-only-offcanvas .brx-offcanvas-backdrop,
	.__mobile-only-offcanvas .brxe-toggle{
		display: none;
	}

}
@media (max-width: 991px) 
{
	.__mobile-only-offcanvas .brx-offcanvas-inner{
		padding: var(--space-xl);
		width: 350px;
	}
}

/********** END Bricks Mobile Only Flyout **********/


/**********  Bricks Popup **********/
.brx-popup .brx-popup-content{
  clip-path: inset(0);
  transition: all 0.8s var(--cubic-clip);
}

.hide.brx-popup .brx-popup-content{
  clip-path: inset(100% 100% 100% 100%);
}

/********** END Bricks Popup **********/

/**********  Bricks Form Extra **********/
:where(.brxe-form) .message .text {
    padding: var(--space-m);
	width: 100%;
    text-align: left;
    margin-left: 4px;
    background: var(--base-ultra-light);
    color: var(--base-dark);
}

.__hide_on_submit:has(.message){
	padding: 0 !important;
}

.__hide_on_submit:has(.message) > .form-group{
	display: none;
}

.message{
	--bricks-text-danger: var(--text-on-primary);
    --bricks-bg-danger: var(--danger);
    --bricks-text-success: var(--text-on-primary);
    --bricks-bg-success: var(--success);
}

.brxe-form li:has(> input[type="checkbox"] + label) {
  display: flex;
  align-items: baseline; /* optional, aligns checkbox + text nicely */
  gap: 0.5em;          /* optional spacing */
}

.brxe-form input[type="checkbox"] + label{
	font-size:var(--text-s);
}

.brxe-form .submit-button-wrapper{
	width: 100%;
}

/*for message and honeypot: your_name*/
.brxe-form .message, 
.brxe-form .form-group:has( input[name="your_name"]),
.brxe-form.__grid-2 .submit-button-wrapper{
	grid-column: 1 / -1;
}

.brxe-form [role="group"]:not(.form-group),
.form-group.captcha{
	display: none;
}

.__form-bold input:not([type="checkbox"], [type="submit"]){
	border:1.5px solid var(--base-dark);
	height: 2.5em;
}

.__form-bold input[type="submit"],
.__form-bold button[type="submit"]{
	height: 100%;
}

.__bg-color-site-inverse input{
	background-color: var(--base-ultra-dark);
	border-color: var(--base);
	color: var(--base-meta);
}

/********** END Bricks Form Extra **********/

/********** Bricks Table of Contents Element **********/
.toc-list-item > :is(ul, ol){
	padding-left:1.65em;
	list-style-type: disc;
}
/********** End Bricks Table of Contents Element **********/

/********** Bricks Simple Slider **********/

/*zoom effect image*/
.__zoom .image{
	transform: scale(1) rotate(0deg) translate(0px, 0px);
	transition: transform 2.5s ease-out;
	transform-origin: center;
}

.__zoom [class*='active'] .image{
    opacity: 1;
	transition: transform 8s ease-out;
	transform: scale(1.2) rotate(0deg) translate(-0px, 0px);
}

/********** End Bricks Simple Slider **********/

/********** Bricks Nested Slider **********/
.splide__track{
	overflow: visible;
}

/********** End Bricks Nested Slider **********/



/********** Bricks Photoswipe Lightbox **********/
/* .pswp.brx .pswp__content:has(video, iframe){
  
}
.pswp.brx .pswp__content:has(video, iframe) video{
    
}
.pswp.brx .pswp__item:has(video){
  
} */
body .pswp.brx .pswp__top-bar .pswp__button--close {
    outline: 2px solid transparent;
    border-radius: 300px;
    outline-offset: 8px;
    transition: all 0.3s var(--cubic-line);
}

body .pswp.brx .pswp__top-bar .pswp__button--close:hover{
  outline-color: currentColor;
  transform: scale(0.8) rotateZ(90deg);
  outline-offset: 3px;
}

/* .pswp.brx .pswp__content iframe, 
.pswp.brx .pswp__content video {
    height: 84%;
    width: 84%;
    margin: 16% 8%;
} */


@media (max-width: 767px) {
    .pswp.brx .pswp__button {
    position: absolute;
    top: 10px;
    right: 10px;
    height: 50px;
    width: 50px;
  }
}


/********** End Bricks Photoswipe Lightbox **********/

/********** Bricks Video Element **********/

/*fix fullscreen mode*/
#top video:fullscreen {
  object-fit: contain;
}

/********** End Video Element **********/


/********** Bricks Loader **********/

@layer bricks {
	.brx-loading-animation {
		--brx-loader-color: #9e9e9e;
		display: grid;
		height: 100%;
		max-height: inherit;
		min-height: inherit;
		place-content: center;
		position: relative;
		width: 100%
	}

  .brx-loading-ring {
		display: inline-block;
		height: 48px;
		position: relative;
		width: 48px
	}

	.brx-loading-ring div {
		animation: brx-loading-ring 1.2s cubic-bezier(.5, 0, .5, 1) infinite;
		border: 5px solid var(--brx-loader-color);
		border-color: var(--brx-loader-color) transparent transparent transparent;
		border-radius: 50%;
		box-sizing: border-box;
		display: block;
		height: 38px;
		margin: 5px;
		position: absolute;
		width: 38px
	}

	.brx-loading-ring div:first-child {
		animation-delay: -.45s
	}

	.brx-loading-ring div:nth-child(2) {
		animation-delay: -.3s
	}

	.brx-loading-ring div:nth-child(3) {
		animation-delay: -.15s
	}

	@keyframes brx-loading-ring {
		0% {
			transform: rotate(0deg)
		}

		to {
			transform: rotate(1turn)
		}
	}
}
/********** End Bricks Loader **********/


/*******************************************************************************
							Custom Animations
*******************************************************************************/
.widget_shopping_cart_content > * {
	--text-stagger:0.2s;
	--show-distance:80px;
	--text-dur:0.7s;
	opacity: 0;
	transform: translateX(var(--show-distance));
	transition: all var(--text-dur) var(--text-ease);
	will-change: opacity, transform;
	transition-delay: calc(var(--base-delay, 0s) + var(--at, var(--ac, 0)) * var(--text-stagger, .0s));
}
.widget_shopping_cart_content > *:nth-child(1) { --at: 1; }
.widget_shopping_cart_content > *:nth-child(2) { --at: 2; }
.widget_shopping_cart_content > *:nth-child(3) { --at: 3; }
.widget_shopping_cart_content > *:nth-child(4) { --at: 5; }
.widget_shopping_cart_content > *:nth-child(5) { --at: 5; }



.active .widget_shopping_cart_content > *, /*custom trigger by woo: flyout cart */
.ani\:noscroll[class*="open"] [class*="ani-show"]{ /*custom trigger by bricks: flyout menu */
  opacity: 1;
  transform: translate(0);
}




/*******************************************************************************
							FANCY Framework
*******************************************************************************/


[id]{
  scroll-margin-top: calc( var(--toc-height) + var(--space-xs)  );
}

html {
  scroll-behavior: smooth;
}

/*Accessibility*/

body.bricks-is-frontend :focus{
  outline: none;
}

body.bricks-is-frontend :focus-visible{
  outline: solid 1px var(--primary);
  outline-offset: 5px;
  transition: all .3s;
}

/*Normalizar*/

ul{
  padding: 0;
  margin: 0;
}

.bricks-nav-menu {
  flex-wrap: wrap;
  justify-content: center;
}

/*Text*/

body{
  font-size: var(--text-m);
  color: var(--text-color);
  font-weight: var(--text-font-weight);
}

:where(p, span){
  line-height: var(--text-line-height);
}


h1, h2, h3, h4, h5, h6{
  line-height: var(--heading-line-height);
  color: var(--heading-color);
  font-weight: var(--heading-font-weight);
}

h1 {
  font-size: var(--h1);
}

h2 {
  font-size: var(--h2);
}

h3 {
  font-size: var(--h3);
}

h4 {
  font-size: var(--h4);
}

h5 {
  font-size: var(--h5);
}

h6 {
  font-size: var(--h6);
}

/*Containers*/
main section{
	background-color: var(--base-bg);
}

:where(section:not(section section)){
  padding: var(--padding-section-small);
}

@media (max-width: 767px) {
	:where(section:not(section section)) {
	    padding: var(--padding-section-small) 1.5em;
	}
}

section:where(:not(.bricks-shape-divider)){
  gap: var(--container-gap);
}

:where(.brxe-container) > .brxe-block, :where(.brxe-container){
  gap: var(--content-gap);
}

/*fix overflow*/

.bricks-is-frontend header{
  max-width: 100vw;
}

body.bricks-is-frontend{
  overflow-x: clip;
}

body.bricks-is-frontend.no-scroll, 
html:has(body.bricks-is-frontend.no-scroll){
  overflow: clip !important;
}



/*******************************************************************************
						KRIESI REUSABELE UTILITY
*******************************************************************************/

/*Generic*/
body{
	font-family: var(--font-text);
}

h1, h2, h3, h4, h5 ,h6{
  font-family: var(--font-heading);
  letter-spacing: 0.3rem;
}

aside :is(h1,h2,h3), .__small_heading :is(h1,h2,h3){
    font-size: 2.5rem;
    letter-spacing: 0.1rem;
}

aside :is(h4,h5,h6) , .__small_heading :is(h4,h5,h6){
    font-size: 2rem;
    letter-spacing: 0.1rem;
}

:is(h1, h2, h3, h4, h5, h6) + :is(p , ul, ol, h1, h2, h3, h4, h5, h6){
	margin-top:0.9em;
}

:is(p , ul, ol) + :is(h1, h2, h3, h4, h5, h6){
	margin-top:1.8em;
}

:is(p){
  margin-block: 0 1em;
}

:is(p):empty {
    display: none;
}

:is(p:last-of-type) {
    margin-block-end: 0;
}

#top :focus{
  outline: none;
  box-shadow: none;
}

/*Bricks*/

.__text_hero,
.bricks-type-hero{
	font-family: var(--font-heading);
	border: 1px solid currentColor;
	padding:var(--space-l, 3rem) 0;
	border-left: none;
	border-right: none;
	text-transform: uppercase;
    letter-spacing: 0.5rem;
	font-weight: 400;
}

.__text_lead,
.bricks-type-lead{
	font-family: var(--font-text);
    letter-spacing: 0.3rem;
	text-transform: uppercase;
    font-weight: var(--text-font-weight);
}
[data-object-fit=cover]{ object-fit: cover; }
[data-object-fit=contain]{ object-fit: contain; }




/*gaps*/
.__gap-0{gap:0;} /*u*/
.__gap-xs{gap:var(--space-xs);} /*u*/
.__gap-s{gap:var(--space-s);} /*u*/
.__gap-m{gap:var(--space-m);} /*u*/
.__gap-l{gap:var(--space-l);} /*u*/
.__gap-xl{gap:var(--space-xl);} /*u*/
.__gap-xxl{gap:var(--space-xxl);} /*u*/
.__gap-gallery{gap:var(--gallery-gap);} /*u*/


/*font size*/
.__font-size-xs{font-size: var(--text-xs);}
.__font-size-s{font-size: var(--text-s);} /*u*/
.__font-size-m{font-size: var(--text-m);}
.__font-size-mm{font-size: var(--text-mm);}
.__font-size-l{font-size: var(--text-l);}
.__font-size-xl{font-size: var(--text-xl);}
.__font-size-xxl{font-size: var(--text-xxl);}


/*bg colors*/
.__bg-transparent{background-color: transparent; }
.__bg-color-base{ background-color: var(--base-bg);} /*u*/
.__bg-color-base-ultra-light{background-color: var(--base-ultra-light);} /*u*/
.__bg-color-site{ background-color: var(--site-bg);} /*u*/
.__bg-color-transparent{ background-color: transparent;} /*u*/


.__bg-color-site-inverse{background-color: var(--base-ultra-dark); color: var(--text-on-primary);}
.__bg-color-site-inverse :is(h1,h2,h3,h4,h5,h6){color: var(--text-on-primary);}
.__bg-color-site-inverse .brxe-form .message .text{background: var(--base-ultra-dark); color: var(--text-on-primary); border: 1px solid var(--base-dark);}

/*padding*/
.__padding-0{padding:0;} /*u*/
.__padding-left-0{padding-left:0;}
.__padding-right-0{padding-right:0;}
.__padding-top-0{padding-top:0;}
.__padding-bottom-0{padding-bottom:0;}

.__padding-xs{padding:var(--space-xs, 0.5rem);}
.__padding-left-xs{padding-left:var(--space-xs, 0.5rem);}
.__padding-right-xs{padding-right:var(--space-xs, 0.5rem);}
.__padding-top-xs{padding-top:var(--space-xs, 0.5rem);}
.__padding-bottom-xs{padding-bottom:var(--space-xs, 0.5rem);}

.__padding-s{padding:var(--space-s, 1rem);}
.__padding-left-s{padding-left:var(--space-s, 1rem);}
.__padding-right-s{padding-right:var(--space-s, 1rem);}
.__padding-top-s{padding-top:var(--space-s, 1rem);}
.__padding-bottom-s{padding-bottom:var(--space-s, 1rem);}

.__padding-m{padding:var(--space-m, 2rem);}
.__padding-left-m{padding-left:var(--space-m, 2rem);}
.__padding-right-m{padding-right:var(--space-m, 2rem);}
.__padding-top-m{padding-top:var(--space-m, 2rem);}
.__padding-bottom-m{padding-bottom:var(--space-m, 2rem);}

.__padding-l{padding:var(--space-l, 3rem);}
.__padding-left-l{padding-left:var(--space-l, 3rem);}
.__padding-right-l{padding-right:var(--space-l, 3rem);}
.__padding-top-l{padding-top:var(--space-l, 3rem);}
.__padding-bottom-l{padding-bottom:var(--space-l, 3rem);}

.__padding-xl{padding:var(--space-xl, 4rem);}
.__padding-left-xl{padding-left:var(--space-xl, 4rem);}
.__padding-right-xl{padding-right:var(--space-xl, 4rem);}
.__padding-top-xl{padding-top:var(--space-xl, 4rem);}
.__padding-bottom-xl{padding-bottom:var(--space-xl, 4rem);}

.__padding-xxl{padding:var(--space-xxl, 5rem);}
.__padding-left-xxl{padding-left:var(--space-xxl, 5rem);}
.__padding-right-xxl{padding-right:var(--space-xxl, 5rem);}
.__padding-top-xxl{padding-top:var(--space-xxl, 5rem);}
.__padding-bottom-xxl{padding-bottom:var(--space-xxl, 5rem);}

.__padding-section-small{padding:var(--padding-section-small);}
.__padding-section{padding:var(--padding-section);}

/*margin*/
.__margin-0{margin:0;}
.__margin-left-0{margin-left:0;}
.__margin-right-0{margin-right:0;}
.__margin-top-0{margin-top:0;}
.__margin-bottom-0{margin-bottom:0;}

.__margin-xs{margin:var(--space-xs, 0.5rem);}
.__margin-left-xs{margin-left:var(--space-xs, 0.5rem);}
.__margin-right-xs{margin-right:var(--space-xs, 0.5rem);}
.__margin-top-xs{margin-top:var(--space-xs, 0.5rem);}
.__margin-bottom-xs{margin-bottom:var(--space-xs, 0.5rem);}

.__margin-s{margin:var(--space-s, 1rem);}
.__margin-left-s{margin-left:var(--space-s, 1rem);}
.__margin-right-s{margin-right:var(--space-s, 1rem);}
.__margin-top-s{margin-top:var(--space-s, 1rem);}
.__margin-bottom-s{margin-bottom:var(--space-s, 1rem);}

.__margin-m{margin:var(--space-m, 2rem);}
.__margin-left-m{margin-left:var(--space-m, 2rem);}
.__margin-right-m{margin-right:var(--space-m, 2rem);}
.__margin-top-m{margin-top:var(--space-m, 2rem);}
.__margin-bottom-m{margin-bottom:var(--space-m, 2rem);}

.__margin-l{margin:var(--space-l, 3rem);}
.__margin-left-l{margin-left:var(--space-l, 3rem);}
.__margin-right-l{margin-right:var(--space-l, 3rem);}
.__margin-top-l{margin-top:var(--space-l, 3rem);}
.__margin-bottom-l{margin-bottom:var(--space-l, 3rem);}

.__margin-xl{margin:var(--space-xl, 4rem);}
.__margin-left-xl{margin-left:var(--space-xl, 4rem);}
.__margin-right-xl{margin-right:var(--space-xl, 4rem);}
.__margin-top-xl{margin-top:var(--space-xl, 4rem);}
.__margin-bottom-xl{margin-bottom:var(--space-xl, 4rem);}

.__margin-xxl{margin:var(--space-xxl, 5rem);}
.__margin-left-xxl{margin-left:var(--space-xxl, 5rem);}
.__margin-right-xxl{margin-right:var(--space-xxl, 5rem);}
.__margin-top-xxl{margin-top:var(--space-xxl, 5rem);}
.__margin-bottom-xxl{margin-bottom:var(--space-xxl, 5rem);}



/*******************************************************************************
							Image related.
*******************************************************************************/

.__aspect_auto{aspect-ratio: auto;}
.__aspect_1{aspect-ratio: 1;}
.__aspect_1-2{aspect-ratio: 1/2;}
.__aspect_2-1{aspect-ratio: 2/1;}
.__aspect_1-3{aspect-ratio: 1/3;}
.__aspect_2-3{aspect-ratio: 2/3;}
.__aspect_3-2{aspect-ratio: 3/2;}
.__aspect_3-1{aspect-ratio: 3/1;}
.__aspect_children_portrait > * , .__aspect_children_portrait .image { aspect-ratio: 10/15; } /*u*/
.__aspect_children_landscape > *{ aspect-ratio: 16/9; }


.__object_position-top, .__object_position-top img{object-position: top;}
.__object_position-bottom, .__object_position-bottom img{object-position: bottom;}
.__object_position-center, .__object_position-center img{object-position: center;}


.__object_fit-cover, .__object_fit-cover img{ object-fit: cover; }
.__object_fit-contain, .__object_fit-contain img{ object-fit: contain; }
/*******************************************************************************
							grids - simple common grid reuse
*******************************************************************************/
.__grid-2, .__grid-3, .__grid-4{
	display: grid;
}

.__grid-2{grid-template-columns: var(--grid-2);}
.__grid-3{grid-template-columns: var(--grid-3);}
.__grid-4{grid-template-columns: var(--grid-4);}

@media (max-width: 767px)
{
	.__grid-2.__responsive{
		grid-template-columns: var(--grid-1);
    }

    .__grid-3.__responsive > :nth-child(3n + 1) {
        grid-column: 1 / -1;
		grid-template-columns: var(--grid-2);
    }

	.__grid-4.__responsive {
        grid-template-columns: var(--grid-2);
    }
}

@media (max-width: 478px){
    .__grid-3.__responsive, .__grid-4.__responsive{
        grid-template-columns: var(--grid-1);
    }
}

/*******************************************************************************
							misc - single rule classes
*******************************************************************************/

.__display_block{display:block;} /*u*/
.__display_none{display:none;} /*u*/
.__position_relative{position:relative;} /*u*/
.__glass{ backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); }
.__font_weight_default{font-weight: var(--text-font-weight);}
.__overflow_hidden{overflow: clip;}
.__nowrap {white-space: nowrap;}



/*******************************************************************************
							single purpose classes
*******************************************************************************/

.__absolute_center{position: absolute; top: 50%; transform: translateY(-50%);}
.__absolute_fill{position: absolute; inset:0; z-index: 0; }
.__square_full { width: min(100vw, 100vh); height: min(100vw, 100vh);}
.__square_full_with_menu { width: min(100vw, var(--full-height-with-menu)); height: min(100vw, var(--full-height-with-menu));}
.__link_overlay a:first-of-type::before{ position: absolute; inset:0; content:""; z-index: 10;}
.__center_all{align-items: center;text-align: center;}
.__z_index-1{z-index: 1;}



/*simple bubble display*/
.__bubble{
	padding:var(--space-m);
	gap:var(--space-m);
	border-radius: var(--radius-m);
	background: var(--base-bg);
}

.__bubble-l{
	padding:var(--space-l);
	gap:var(--space-l);
	border-radius: var(--radius-m);
	background: var(--base-bg);
}


/*simple center top tooltip*/
[class*='__tooltip']{
    position: absolute;
    left: 50%;
    bottom: 100%;
    font-size: 12px;
    line-height: 1.5em;
    text-align: center;
    text-indent: 0;
    white-space: nowrap;
    padding: 4px 10px;
    margin-bottom: 10px;
    transform: translateX(-50%);
    color: #fff;
    background-color: #212121;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: all .3s;
	max-width:none;
	font-weight: 400;
}

[class*='__tooltip']::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -5px;
    transform: translateX(-50%);
    border-left: 5px solid rgba(0, 0, 0, 0);
    border-right: 5px solid rgba(0, 0, 0, 0);
    border-top: 5px solid #212121;
}

:hover > [class*='__tooltip'] {
    opacity: 1;
    margin-bottom: 15px;
    visibility: visible;
}

.__tooltip--left{
	top: 50%;
	bottom: auto;
    left: 0;
    margin-bottom: 0;
    transform: translate(calc(-100% - 10px), -50%);
}

.__tooltip--left::after{
	left: 100%;
	top: 50%;
	bottom: auto;
	transform: translateY(-50%);
    border-top: 5px solid rgba(0, 0, 0, 0);
    border-bottom: 5px solid rgba(0, 0, 0, 0);
    border-left: 5px solid #212121;
}

:hover > .__tooltip--left {
	margin-bottom: 0;
	transform: translate(calc(-100% - 15px), -50%);
}


/*Simple pulse animation: Attach to any element you want to pulse*/

.__pulse {
  position: relative;            /* create positioning context for ::after */
  z-index: 0;                    /* stack context helper */
  overflow: visible;             /* allow the pulse to grow beyond bounds */
  isolation: isolate;
}

/* The pulse ring */
.__pulse::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  min-width: auto;
  min-height: auto;
  border-radius: inherit;
  background: #fff;
  opacity: 0;
  transform: scale(0.5);
  pointer-events: none;
  animation: __pulse 2s linear infinite;
  will-change: transform, opacity;
  z-index: -1;
}

.__pulse > *{
	position: absolute;
	inset: 0;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}

.__pulse::before {
    content: "";
    background: inherit;
    position: absolute;
    inset: 0;
    border-radius: inherit;
}



/* Keyframes as requested */
@keyframes __pulse {
  0% 	{transform: scale(1); opacity: 0.5; }
  50% 	{opacity: 0.7;}
  100% 	{transform: scale(2); opacity: 0.0;}
}



/*Simple float animation: Attach to any element you want to float*/
.__float, .__float_hover:hover{
  animation: __float 3s ease-in-out infinite;
}


@keyframes __float {
  0% {transform: 	translateY(0)}
  50% {transform: 	translateY(-10%)}
  100% {transform: 	translateY(0)}
}




/* animated button */
#top .__fill_button,
#top .single_add_to_cart_button{
	position: relative;
    overflow: hidden;
}

.__fill_button > *,
.single_add_to_cart_button > *{
	position: relative;
	z-index: 1;
}

.__fill_button::before,
.single_add_to_cart_button::before{
    content: "";
    position: absolute;
    top: 100%;
    left: -10%;
    width: 0;
	aspect-ratio: 1 / 1; /* height = width */
    background: var(--primary);
    z-index: 0;
	border-radius: 50%;
    transition: all 0.6s ease-out;
	transform: translate(-50%, -50%);
}

.__fill_button:hover, .__fill_button:hover *,
.single_add_to_cart_button:hover, .single_add_to_cart_button:hover *{
	color:var(--text-on-primary);
}


.__fill_button:hover::before,
.__fill_button:focus::before,
.__fill_button:focus-within::before,
.single_add_to_cart_button:hover::before,
.single_add_to_cart_button:focus::before,
.single_add_to_cart_button:focus-within::before{
	width: 250%;
}


/*Image hover effect*/
figure.__effect-lines {
    background: #000;
	color:#fff;
	--fig-padding: var(--space-s);
	margin:0;
}

figure.__effect-lines *{
	color: inherit;
}

figure.__effect-lines img{
    transition: all 0.6s var(--cubic-line);
}

figure.__effect-lines:hover img {
    opacity: 0.7;
	transform: scale(1.2);
}

:where(figure.__effect-lines .brxe-image){ /*low prio or clashes with parallax*/
	  position: relative;
    height: 100%;
    width: 100%;
}


figure.__effect-lines  figcaption, 
figure.__effect-lines figcaption > a{
    position: absolute;
    inset:0;
}

figure.__effect-lines .brxe-image > a::before{
	position: absolute;
    inset:0;
	content:"";
	z-index: 10;
}

figure.__effect-lines  figcaption{
	flex-direction: column;
	margin:0;
	padding: var(--fig-padding);
	display: flex;
	align-items: flex-start;
	justify-content: flex-end;
	text-align: left;
	pointer-events: none;
    background: linear-gradient(21deg, rgb(0 0 0 / 70%), rgb(255 0 0 / 0%) 50%, transparent);
}

figure.__effect-lines.__effect-lines-show-caption  figcaption{
	background: linear-gradient(0deg, rgb(0 0 0 / 70%), rgb(255 0 0 / 0%) 100%, transparent);
}

figure.__effect-lines  figcaption > *{
	padding: var(--fig-padding);
}

figure.__effect-lines  figcaption > * *{
	transition: all 0.6s var(--cubic-line);
}

figure.__effect-lines:not(.__effect-lines-show-caption)  figcaption > * span{
	opacity: 0;
	max-height: 0px;
	overflow: hidden;
	display: block;
}

figure.__effect-lines:not(.__effect-lines-show-caption):hover  figcaption > * span{
	opacity: 1;
	max-height: calc( var(--text-line-height) * 3);
	transition-duration: 1.5s;
}

figure.__effect-lines.__effect-lines-hide-caption  figcaption > * span{
	display: none;
}

figure.__effect-lines figcaption::before {
    border-top: 1px solid #fff;
    border-bottom: 1px solid #fff;
    transform: scale(0, 1);
}

figure.__effect-lines figcaption::after {
    border-right: 1px solid #fff;
    border-left: 1px solid #fff;
    transform: scale(1, 0);
}

figure.__effect-lines figcaption::before, figure.__effect-lines figcaption::after {
    position: absolute;
    inset: var(--fig-padding);
    content: '';
    opacity: 0;
    transition: all 0.6s var(--cubic-line);
}

figure.__effect-lines:hover figcaption::before, figure.__effect-lines:hover figcaption::after {
    opacity: 1;
    transform: scale(1);
}