/* @override 
	https://kreismusikschule-bautzen.de/wp/wp-content/themes/kms/style.css?* */

/*
Theme Name: Kreismusikschule Bautzen
Description: 
Version: 1.0
Author: ZH2
*/



/* @group WEBFONTS */

/*	WEBFONTS
-------------------------------------------------------------------------------*/

/*https://variable-font-helper.web.app/ */


/* Georama latin */
@font-face {
  font-family: 'Georama';
  font-style: normal;
  font-weight: 200 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(assets/fonts/Georama-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Georama latin italic */
@font-face {
  font-family: 'Georama';
  font-style: italic;
  font-weight: 200 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(assets/fonts/Georama-latin-italic.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Georama latin-ext */
@font-face {
  font-family: 'Georama';
  font-style: normal;
  font-weight: 200 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(assets/fonts/Georama-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}


/* Georama latin-ext italic */
@font-face {
  font-family: 'Georama';
  font-style: italic;
  font-weight: 200 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(assets/fonts/Georama-latin-ext-italic.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}




/* Icon Font – extra here for iframe views in WP Editor and TinyMCE */
@font-face { 
  font-family: 'icons';
  font-style: normal;
  font-weight: normal;
  src: url('assets/icons/fonts/icons.woff') format('woff');
}



/* @end */

/* @group RESET */

/*	RESET
-------------------------------------------------------------------------------*/


article, aside, figure, footer, header, hgroup, nav, section {display: block;}
img, object, embed {max-width: 100%; height:auto;}

/* force a vertical scrollbar to prevent a jumpy page */
html {overflow-y: scroll;}

/* we use a lot of ULs that aren't bulleted.
	don't forget to restore the bullets within content. */
ul {list-style: none;}

blockquote, q {quotes: none;}

blockquote:before,
blockquote:after,
q:before,
q:after {content: ''; content: none;}

a {margin: 0; padding: 0; vertical-align: baseline;}
del {text-decoration: line-through;}
abbr[title], dfn[title] {border-bottom: 1px dotted #000; cursor: help;}

/* tables still need cellspacing="0" in the markup */
table {border-collapse: collapse; border-spacing: 0;}
th {font-weight: 800; vertical-align: bottom;}
td {font-weight: normal; vertical-align: top;}

input, select {vertical-align: middle;}

input[type="radio"] {vertical-align: text-bottom;}
input[type="checkbox"] {vertical-align: bottom; *vertical-align: baseline;}
input:focus, textarea:focus, select:focus { AUS_outline: none;}

input { /* remove top input shadow */
-webkit-appearance: none;
-moz-appearance: none;
}

*:focus:not(:focus-visible) { outline: none }

table {font-size: inherit; font: 100%;}

a:hover, a:active {outline: none;}
small {font-size: 85%;}
strong, th {font-weight: 700;}
td, td img {vertical-align: top;}

/* standardize any monospaced elements */
pre, code, kbd, samp {font-family: monospace, sans-serif;}

/* hand cursor on clickable elements */
.clickable,
label,
input[type=button],
input[type=submit],
button {cursor: pointer;}

/* Webkit browsers add a 2px margin outside the chrome of form elements */
button, input, select, textarea {margin: 0; border-radius: 0; font-family: inherit; 	font-weight: var(--base-font-weight);
}

/* make buttons play nice in IE */
button {width: auto; overflow: visible;}

/* let's clear some floats */
.clearfix:before, .clearfix:after { content: "\0020"; display: block; height: 0; overflow: hidden; }
.clearfix:after { clear: both; }
.clear { clear: both; height: 0px; overflow: hidden;}
.clr:after { content: ""; display: table; clear: both;}
.cf:after {	content: ""; display: table; clear: both; }

/* prevent flickering on touch */
* {
	-webkit-tap-highlight-color:transparent;
}

/* natural box layout model to all elements */
*, *:before, *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
 }

 /* subscript and superscript */
sub { vertical-align: sub; font-size: 70%; line-height: 0; }
sup { vertical-align: super; font-size: 70%; line-height: 0; }

/* fine-grained control over hyphenation in text */
* { hyphenate-limit-chars: 10 4 4; }

/* @end */


/* @group VARS */


/*	VARS
-------------------------------------------------------------------------------*/


/* Color Info

BFSG proved

kms blue			#009DDB
kms darkblue 	#01678F
kms orange		#F26622

blue-100			#E6F7FD
blue-200			#CCEFFC
blue-300			#B3E6FA

orange-100		#FDF0E9
orange-200		#FCE0D3
orange-300		#FBD1BD



*/

:root {
	--base-font-size: calc((18/16) * 1rem);
	--base-font-weight: 400;
	--base-line-height: 1.6;
	--bold: 600;

	--body-bg: #FFF;

	--blue:	#009DDB;
	--blue-100:	#E6F7FD;
	--blue-200:	#CCEFFC;
	--blue-300:	#B3E6FA;

	--orange: #F26622;
	--orange-100: #FDF0E9;
	--orange-200: #FCE0D3;
	--orange-300: #FBD1BD; 
	
	--red: #d80100;

	--text-color: #002330;
	--text-gray: #657982;
	--link-color: var(--text-color);
	--link-color-hover: var(--primary-color);

	--border-color: #D8D8D8;

	--primary-color: var(--blue);
	--primary-dark-color: #01678F;
	--secondary-color: var(--orange);

	--primary-bg: #E6F7FD;	
	--secondary-bg: #FDF0E9;
	--gray-bg: #f2f2f2;
		
	--font-sans: 'Georama', sans-serif;

	--text-tiny: calc(var(--base-font-size) * .7);
	--text-small: calc(var(--base-font-size) * .85);
	--text-base: var(--base-font-size);
	--text-large: calc(var(--base-font-size) * 1.2);

	--default-width: calc((860/16) * 1rem);
	--wide-width: calc((1440/16) * 1rem);
	--semiwide-width: 68rem;
	--full-width: 100%;
	
	--page-padding: 40px;

	--main-padding-top: clamp(60px, 10vw, 80px);
	--main-padding-bottom: clamp(100px, 10vw, 140px);
		
 	--space-xs: 10px;
	--space-sm: 20px;
	--space-md: 30px; /*default block gap*/
	--space-lg: clamp(40px, 5vw, 50px);  
	--space-xl: clamp(50px, 10vw, 80px); 
	--space-xxl: clamp(70px, 12vw, 110px);
	--space-xxxl: clamp(90px, 20vw, 140px);
	
	--block-gap: 2rem; /*2rem*/
	--block-gap-text: 1.5rem; /*1.5rem*/

	--columns-gap: 30px;
	
	--box-padding: clamp(20px, 5vw, 30px);
	
	--box-padding-sm: clamp(20px, 5vw, 20px);
	--box-padding-md: var(--box-padding);
	--box-padding-lg: clamp(20px, 5vw, 40px);
	--box-padding-xl: clamp(20px, 5vw, 60px);
	--box-padding-xxl: clamp(40px, 5vw, 80px);

	--radius: 4px;

	--header-height: calc(185/16*1rem); /*185px*/
 }
 
 @media screen and (max-width: 1024px) {
	 :root {
		--base-font-size: calc((17/16) * 1rem);
		--header-height: 130px; 
	} 	
 }


@media screen and (max-width: 600px) {
	 :root {
		--page-padding: 20px;
		--block-gap: 1.5rem;
		--header-height: 100px; 
	}
}

 @media screen and (max-width: 360px) {
	 :root {
		--base-font-size: calc((16/16) * 1rem);
		--space-lg: 30px;
	}
}



/* @end */



/* @group GENERAL */


/* GENERAL
---------------------------------------------------------------------------------*/


html {
	height: 100%;
	scroll-behavior: smooth;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	 -webkit-text-size-adjust: 100%;
}

body {
	height: 100%;
	font-family: var(--font-sans);
	font-size: var(--base-font-size);
	font-weight: var(--base-font-weight);
	line-height: var(--base-line-height);
	color: var(--text-color);
	background: #FFF;
}


a {
	position: relative;
	color: var(--link-color);
	text-decoration: underline;
	text-underline-offset: 0.1em;
	text-decoration-thickness: 1px;
}

a, input {
	transition: all 200ms ease;
}

a:visited {
}

a:active {
}

a:hover {
	color: var(--link-color-hover);
}


img {
	display: block;
	max-width: 100%;
}

svg {
	display: block;
	max-width: 100%;
}


/* TYPOGRAPHY
---------------------------------------------------------------------------------*/


h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
	margin-bottom: 0;
    font-weight: var(--bold);
	text-wrap: balance;
	word-break: break-word;
	overflow-wrap: break-word;
}


h1 {
	font-size: clamp(2.25rem, 1.9457rem + 1.5217vw, 3.125rem); /*36/50*/
	line-height: 1.3;
	margin-top: var(--space-xl);
	margin-bottom: var(--space-xl);
	color: var(--primary-color);
	text-align: center;
}

:is(.is-layout-flow, .is-layout-constrained) h1 {
	margin-top: var(--space-xl);
	margin-bottom: var(--space-xl);
}

h2, .h2 {
	--block-gap: 3rem; /*2.5*/
	font-size: clamp(28px, 6vw, 32px);
	line-height: 1.3;
	color: var(--text-color);
}

h3, .h3 {
	--block-gap: 3rem; /*2.5*/
	font-size: clamp(1.375rem, 1.3315rem + 0.2174vw, 1.5rem); /*22/24*/
	line-height: 1.35;
}

h4, .h4 {
	line-height: 1.4;
	font-size: 0.95rem;
	font-weight: 550;
	letter-spacing: .04em;
	text-transform: uppercase;
}

:is(.is-layout-flow, .is-layout-constrained) h4 + :where(h1,h2,h3) { /*eyebrow headline*/
	margin-top: 5px;
}


:where(h1,h2,h3,h4) em { /*headlines sorbisch*/
	display: block;
	font-style: normal;
	font-weight: 200; /*200 extralight*/
}


:where(p,ul,ol) {
	margin: var(--block-gap-text) 0 0 0;
	--block-gap: var(--block-gap-text);
}

strong, b {
  font-weight: var(--bold);
}

hr {
	position: relative;
	display: block;
	clear: both;
	height: 1px;
	border: 0;
	background: transparent;
	border-bottom: 1px solid var(--border-color);
	margin: 3rem 0;
}


@media screen and (max-width: 1024px) {

}


@media screen and (max-width: 840px) {

}


@media screen and (max-width: 600px) {

}


@media screen and (max-width: 360px) {

}

/* @end */


/* @group ELEMENTS */

/* === Lists */
ul, ol {
}

ul {
	padding-left: 2.5ch;
	list-style-type: revert;
}

li {
	position: relative;
	margin: 0 0 5px 0;
}

ul li::marker {
}


li ul {
	margin-top: 5px;
}

ol {
	padding-left: 2.5ch;
}

ol li {
	list-style: revert;
}

.list-unstyled,
.list-unstyled li {
	padding: 0;
	margin: 0;
	list-style: none;
}

.list-unstyled li:before {
	display: none;
}

/* list style: lines */

ul.is-style-lines,
ul.is-style-lines ul {
	list-style: none;
	padding: 0;
}

ul.is-style-lines ul li {

}

ul.is-style-lines li:before {
	display: none;
}

ul.is-style-lines,
ul.is-style-lines li {
	padding: 0;
}

ul.is-style-lines li {
	padding: 0.8rem 0;
	margin: 0;
	border-top: 1px solid var(--border-color);
}

ul.is-style-lines > li:first-child {
	border-top: none;
}

ul.is-style-lines li ul {
	padding: 0;
	margin: 0;
}

ul.is-style-lines ul li {
	padding-left: 1.5em;
}

ul.is-style-lines ul li:first-child {
	margin-top: .8rem;
}

ul.is-style-lines ul li:last-child {
	padding-bottom: 0;
}


/* list style: icon */

ul[class*="is-style-icon"],
ul[class*="is-style-icon"] ul {
	--list-icon-width: 2.2rem;
	list-style: none;
	padding-left: 0;
}

ul[class*="is-style-icon"] li {
	position: relative;
	padding-left: calc(var(--list-icon-width));
	padding-bottom: .1em;
}

ul[class*="is-style-icon"] li::before {
  content: '✓'; 
  position: absolute;
  left: 0;
  top: 0.0em;
  font-family: 'icons';
  font-size: 1.5em;
  display: inline-flex;
  width: var(--list-icon-width);
  align-items: center;
  line-height: 1;
  color: var(--primary-color);
 }
 
 ul.is-style-icon-check li::before {
  content: '\e94a';
 }

 ul.is-style-icon-download li::before {
  content: '\e948'; 
 }
 
 ul.is-style-icon-arrow li::before {
   content: '\e932'; 
 }


/* === Caption */


figcaption {
	font-size: var(--text-small);
	line-height: 1.4;
	margin: 10px 0 10px 0;
	text-align: left;
	word-break: break-word;
	overflow-wrap: break-word;
	margin: 1rem 0; 
	color: var(--text-gray)
}


/* WP Edit Link */

a.post-edit-link {
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 10;
	font-size: 11px;
	padding: 8px 12px;
	text-transform: uppercase;
	text-decoration: none;
	background: #0073AA;
	color: #FFF;
}



/* === Embeds, iFrames  */

.embed-responsive {
  position: relative;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
}

.embed-responsive iframe,
.embed-responsive object,
.embed-responsive embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
}


/* === Icons */


i[class^="icon-"] {
	font-family: 'icons';
}

i.icon {
	font-weight: normal!important;
}

.icon.download {
	font-size: 1.9rem;
	color: var(--link-color);
	margin: 0 5px 5px 0;
	vertical-align: middle;
	display: inline-block;
}

.icon.download:before {
	margin: 0;
}

.icon.bullet {
	font-size: 85%;
}


/* === WP Styles */

/* default padding for has-background + override WP default */
:is(p,ul,ol,*).has-background,
.has-background { 
	padding: var(--box-padding);
	border-radius: var(--radius);
}


.alignfull.has-background {
	border-radius: 0;
}

.has-global-padding.alignfull {
	border-radius: 0;
	padding-inline: 0;
	padding-inline: var(--page-padding);
}

.alignfull:not(.has-global-padding) {
	AUS_padding: inherit;
}

.alignfull > .has-background {
	padding: var(--box-padding);
}

.alignfull > .has-background > * { /*BE*/
       padding-inline: 0;
}

.is-root-container :where(.has-global-padding:not(.has-background)) { /*BE*/
	padding-inline: 0;
}


:is(ul,ol).has-background { /*add space for bullets*/
	padding-left: calc(var(--box-padding) + 1rem);
}

.has-small-font-size {
	font-size: var(--text-small);
}

.has-large-font-size {
	font-size: var(--text-large);
}


/* === Highlight Anchor Links */


.entry-content :target {
    animation: highlight 500ms ease-in;
}

@keyframes highlight {
    from {
        background-color: rgb(253 224 71);
    }
    to {
        background-color: #fff;
    }
}



/* @end */




/* @group LAYOUT */

/* LAYOUT
----------------------------------------------------------------------------------*/


/* # Container */

.page-wrap {
	position: relative;
	/*sticky footer*/
	min-height: 100%;
	display: grid;
	grid-template-rows: 1fr auto;
	overflow-x: clip;
}


.container,
.container-fluid {
	position: relative;
	max-width: calc(var(--wide-width) + 2 * var(--page-padding));
	margin: 0 auto;
	padding: 0 var(--page-padding);
}

.content-width { /*add to container class*/
	max-width: calc(var(--default-width) + 2 * var(--page-padding));
}


.entry-content {
}

.stack > *:first-child {
	margin-top: 0;
}


/*
.wp-block-post-content is root container for all content blocks
in backend editor AND frontend
*/

.wp-block-post-content {
	padding-left: var(--page-padding);
	padding-right: var(--page-padding);
}

.wp-block-post-content.is-root-container { /*backend editor*/
	padding-inline: var(--page-padding)!important;
}


.wp-block-post-content > *:first-child {
	margin-top: 0;
}

/* alignment */
  

.is-layout-flow > .alignwide {
	max-width: var(--wide-width);
}

.is-layout-constrained .alignsemiwide {
	max-width: var(--semiwide-width);
}

.is-layout-flow > .alignfull {
	margin-right: calc(var(--wp--style--root--padding-right) * -1);
	margin-left: calc(var(--wp--style--root--padding-left) * -1);
}


/* @end */


/* @group NOTIFICATION BAR */

/* Notification Bar
--------------------------------------------------------------------------------- */

.notification-bar {
	position: relative;
	z-index: 100;
	padding: 20px 0;
	color: var(--text-color);
	background: var(--blue-300);
	
}

.notification-bar.is-hidden {
	display: none;
}

.notification-bar a {
	color: var(--text-color);
}

.notification-bar a:hover {
	opacity: .6;
}

.notification-bar__content {
	padding: 0 80px;
	text-align: center;
	font-size: var(--text-small);
}

.notification-bar__content *{
	margin-top: 0;
}

.notification-bar__close {
	position: absolute;
	top: 50%;
	right: 20px;
	transform: translateY(-50%);
	border: none;
	background: none;
	width: 35px;
	height: 35px;
	outline: none;
	overflow: hidden;
	border-radius: 100%;
	border: 0px solid #333;
}

.notification-bar__close:hover {
	opacity: .6;
}

.notification-bar__close svg {
	margin: 0 auto;
	width: 15px;
    height: 15px;
}

.notification-bar__close svg path {
	fill: none;
    stroke: var(--text-color);
	stroke-width: 1.2;
}


@media screen and (max-width: 980px) {
	
	.notification-bar__content {
		padding: 0 50px;
	}
	
	.notification-bar__close {
		right: 10px;
	}	
}

/* @end */



/* @group HEADER */

/* HEADER
--------------------------------------------------------------------------------- */


#header {
	position: relative;
	height: var(--header-height);
	display: flex;
	align-items: center;
	background: #FFF;
	border-bottom: 0px solid #DDD;
}


#header > .container {
	width: 100%;
}

@media screen and (max-width: 1024px) {
}

@media screen and (max-width: 600px) {
}

/* Logo */


.logo-wrap {
	display: flex;
	gap: 30px;
	align-items: center;
}

.logo {
    transition: all 0.3s ease;
	border: 0px solid RED;
}

.logo a {
	display: block;
	width: 375px;
	width: clamp(300px, 30vw, 360px);
}

.logo img {
	display: block;
	width: 100%;
	height: auto;
	transform: translate(-2%,0%);
}

@media screen and (max-width: 1024px) {
	.logo a {
		width: 300px;
	}
}


@media screen and (max-width: 600px) {
	.logo a {
		width: 270px;
		max-width: 70vw;
	}
}

/* @end */



/* @group SEARCH */

/* Search */

button.search-trigger {
	display: flex;
	align-items: center;
	border: none;
	overflow: hidden;
	padding: 0;
	font-size: 1.3em;
	line-height: 10;
	color: var(--text-color);
	margin: 0 0 -.1em -5px;
	background: transparent;
	transition: 200ms ease;
}

button.search-trigger:hover {
	color: var(--primary-color);
}

button.search-trigger.open {
	color: var(--primary-color);
}

.site-search  {
	position: absolute;
	top: var(--header-height);
	display: flex;
	align-items: center;
	width: 100%;
	margin-top: -10px;
	padding: 10px 0 60px 0;
	visibility: hidden;
	opacity: 0;
	background: #FFF;
	overflow: hidden;
	z-index: 2;
	transition: all 400ms ease;
	box-shadow: 0px 50px 30px -10px rgba(0,0,0, .05);
}

.search-open .site-search {
	visibility: visible;
	opacity: 1;
	margin-top: 0;
}


.site-search .container {
	display: flex;
	flex: 1;
	justify-content: flex-end;
}

.searchform {
	position: relative;
	width: 100%;
	max-width: 20rem;
	overflow: hidden;
}

.searchform input.s {
	width: 100%;
	height: 3.3rem;
	padding: 20px 5px;
	padding-right: 3rem;
	background: transparent;
	font-size: 1.1rem;
	line-height: 100%;
	border:  none;
	color: var(--text-color);
	box-shadow: none /*remove red border */;
	border-bottom: 1px solid var(--text-color);
	transition: none;
}

.searchform input.s:focus {
	box-shadow: none;
}

.searchform input.s::placeholder {
	color: var(--text-gray);
}


.searchform .searchsubmit {
	position: absolute;
	top: 0;
	right: 0;
	border: none;
	padding: 0;
	text-transform: uppercase;
	overflow: hidden;
	width: 3rem;
	height: 3.3rem;
	z-index: 1;
	background: transparent;
	outline-offset: -3px;
}

.searchform i {
	position: absolute;
	top: 0;
	right: 0px;
	width: 2.5rem;
	height: 3.3rem;
	text-align: right;
	line-height: 3.3rem;
	font-size: 1.5rem;
	color: var(--text-color);
	background: transparent;
}

/* @end */



/* @group MENU */

/* MENU
--------------------------------------------------------------------------------- */


.featured-menu {
	margin-left: auto;
}

.featured-menu-button {
	position: relative;
	overflow: hidden;
	background: var(--primary-dark-color);
	border-radius: 10rem;
	outline-offset: 2px;
}

.featured-menu-button:focus-within {
	outline: 2px solid blue;
}

.featured-menu-button::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--secondary-color);
	transition: 300ms ease;
}

.featured-menu-button:hover::before {
	opacity: 0;
}

.featured-menu-button a {
	display: flex;
	padding: 0.8em 2.8em;
	padding: .9em 2em;
	font-weight: var(--bold);
	font-size: calc((18/16) * 1rem);	
	color: #FFF;
	text-decoration: none;
	line-height: 1;
	letter-spacing: .02em;
	border-radius: 10rem;
}

.featured-menu a:hover {
}



.nav-wrap {
	display: flex;
	flex: 1;
	flex-direction: column;
	align-items: flex-end;
	gap: 25px;
	min-height: 100%;
	height: 100%;
	border: 1px solid #333;
}

#nav {
	--nav-x-gap: clamp(30px, 3vw, 50px); 
	display: flex;
	gap: var(--nav-x-gap);
	flex-wrap: nowrap;
	margin-top: 10px;
	padding: 0 0;
	flex-grow: 1;
	justify-content: flex-end;
}


#nav ul {
	display: flex;
	gap: 0 var(--nav-x-gap);
	flex-wrap: wrap;
	margin-bottom: -.15em; /*bottom logo align*/
}

#nav ul li {
	border-bottom: none;
}

#nav > ul li:last-child {
	margin-right: 0;
	padding-right: 0;
}


#nav ul li a {
	position: relative;
	margin: 0;
	font-size: 18px;
	display: block;
	color: var(--text-color);
	padding: 0rem 0rem;
	text-decoration: none;
}

#nav li.menu-item-has-children > a {
}


#nav li.menu-item-has-children > a:after {
	
}


#nav li.menu-item-has-children.active > a:after {
}

#nav > ul li.menu-item-has-children {
	AUS_position: relative;
	AUS_position: inherit;
}



#nav ul li:hover > a {
}


#nav ul li.current-menu-item > a {
}

#nav ul li a:hover {
	color: var(--primary-color);
	text-decoration: none;
}

#nav ul li.menu-item-has-children.active > a {
	color: var(--primary-color);
}

#nav ul li.current_page_parent a:hover,
#nav ul li.current_page_parent:hover a,
#nav ul li.current_page_item:hover a {
}


/* 2nd level */


.sub-menu-wrap-2 {	
	display: block;
	position: absolute;
	min-width: 300px;
	top: calc(100% + 25px);
	left: 0;
	margin-top: -10px;
	padding: 20px 0 65px 0;
	z-index: 20;
	color: #FFF;
	opacity: 0;
	visibility: hidden;
	transition: all 400ms ease;
}


.sub-menu-wrap-2::before { /* submenu BG*/
	content: "";
	position: absolute;
	top: -1px;
	left: -100vw; /**/
	height: 100%;
	width: 200vw;
	background: var(--primary-color);
	background: #FFF;
	box-shadow: 0px 50px 30px -10px rgba(0,0,0, .05);
	AUS_border-top: 1px solid rgba(0,0,0, .05);
}


#nav ul .active > .sub-menu-wrap-2 {  /*js class toggle*/
	opacity: 1;
	visibility: visible;
	margin-top: -2px;
}

#nav ul .sub-menu {
	position: relative;
	visibility: hidden;
	display: flex;
	flex-direction: column;
	max-width: 13rem;
}

#nav ul .active .sub-menu {
	visibility: visible;
}

#nav ul ul {
	display: block;
	margin: 0 0 0 0;
	padding: 0;
	transition: all 300ms ease;
}

/* align last menu item to the right to avoid off screen position*/

#nav ul li:last-child ul {
	left: auto;
	right: 0;
}

#nav ul ul li {
	margin: 0;
}


#nav ul ul li a {
	display: block;
	padding: .4em 0;
}

#nav ul ul li a:hover {
	color: rgba(255,255,255, .6);
	color: var(--primary-color);
}

#nav ul ul li a:after {
	display: none;
}

#nav ul ul li.current_page_item > a {
	color: var(--primary-color);
	
}


#nav ul ul li.menu-item-has-children > a {
}

#nav ul ul li.menu-item-has-children > a:hover {
}

/* 3rd level */


#nav ul ul ul {
	visibility: visible;
	opacity: 1;
}


/* mega menu */

#nav li.mega-menu {
	position: inherit;
}

#nav li.mega-menu .sub-menu-wrap-2 {
	width: 100%;
	padding-inline: var(--page-padding);
	border: 0px solid RED;

}

#nav li.mega-menu li {
	position: relative;
}

#nav li.mega-menu .sub-menu-2 {
	margin-left: 33px; /*align to logo*/
	max-width: 25%;
	border: 0px solid GREEN;
}

#nav li.mega-menu .sub-menu-2 li.menu-item-has-children {
	position: relative;
}

#nav li.mega-menu .sub-menu-wrap-3 {
	display: block;
	position: absolute;
	top: 0;
	left: 100%;
	width: calc(300% - 30px);
	padding-left: 30px;
	border: 0px solid #333;
}

.sub-menu-wrap-3::before { /* add bg in case it's submenu3 is larger then submenu2 */
	content: "";
	position: absolute;
	bottom: 0;
	left: -100vw;
	height: 50px;
	width: 200vw;
	transform: translateY(100%);
	background: var(--primary-color);
	background: #FFF;
}


#nav li.mega-menu ul.sub-menu-3 {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 6px;
	max-width: 100%;
}

#nav li.mega-menu ul.sub-menu-3 li {
}

#nav li.mega-menu ul.sub-menu-3 li a {
	font-size: calc(15/16 * 1rem);
	background: transparent;
	border: 1px solid var(--text-color);
	border-radius: 10rem;
	padding: 6px 16px;
}

#nav li.mega-menu ul.sub-menu-3 li a:hover {
	color: var(--primary-color);
	border-color: var(--primary-color);
}


/* 4th level */

#nav ul.sub-menu-4 {
	display: none!important;
}


@media screen and (max-width: 1024px) {
	.featured-menu,
	#nav {
		display: none;
	}
}




/* Mobile Menu
--------------------------------------------------------------------------------- */


.mob-menu {
	display: none; /*js trigger*/
	position: absolute;
   	top: 0;
   	left: 0;
	width: 100%;
	z-index: 10;
	opacity: 0;
	background: var(--text-color);
	animation: navfadeIn 400ms ease-in-out 1 forwards;
	box-shadow: 0px -10px 50px 0px rgba(0,0,0, .7);
	padding-block: clamp(80px, 50vw, 100px);
}

@media screen and (max-width: 1024px) {
	.mob-menu-open .mob-menu {
		display: flex;
		flex-direction: column;
		justify-content: center;
		text-align: center;
	}
}


.mob-menu .container {
	--page-padding: 40px;
	position: relative;
	width: 100%;
	max-width: 26rem;
	margin: 0 auto;
}

.mob-search {
	position: relative;
	margin-top: var(--space-lg);
}

.mob-search .searchform {
	border: none;
	box-shadow: none;
	border-radius: 0;
	max-width: 100%;

}

.mob-search .searchform input {
	font-size: calc((18/16) * 1rem);
	font-weight: var(--base-font-weight);
	padding: 0;
	padding-right: 60px;
	height: 3.3rem;
	background: transparent;
	color: #FFF;
	border-bottom: 1px solid #FFF;
}

.mob-search .searchform input::placeholder {
	color: rgba(255,255,255, .6);
}

.mob-search .searchform input:focus {
	box-shadow: none;
}

.mob-search .searchform button {
	position: absolute;
	top: 0;
	right: 0;
	height: 100%;
	border: none;
	line-height: 1;
	overflow: hidden;
	padding: 0;
	background: transparent;
	width: 2.5rem;
	outline-offset: -3px;
}

.mob-search .searchform button i {
	color: #FFF;
	font-size: 24px;
	display: flex;
	justify-content: center;
	width: auto;
	padding-left: 20px;
}


.mob-featured-menu {
	margin-block: var(--space-md);
	display: flex;
	}

.mob-featured-menu a {
	position: relative;
	overflow: hidden;
	display: inline-flex;
	margin: 0 auto;
	margin-left: 0;
	margin-right: auto;
	padding: .7rem 2.3rem;
	font-size: calc((18/16) * 1rem);
	font-weight: var(--bold);
	justify-content: center;
	text-align: center;
	text-decoration: none;
	background: transparent;
	color: #FFF;
	letter-spacing: .03em;
	border-radius: 10rem;
}

.mob-featured-menu a::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--secondary-color);
	transition: 300ms ease;
	z-index: -1;
}

.mob-menu nav {
	margin: 0;
}

.mob-menu nav li a {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: calc((20/16) * 1rem);
	line-height: 1.3;
	text-decoration: none;
	padding: 10px 0;
	text-align: left;
	color: #FFF;
	border-top: 0px solid #333;
}

.mob-menu nav li a br {
	display: none;
}

.mob-menu nav li:first-child a {
	border-top: 0;
}

.mob-menu nav li a:hover {
	color: rgba(255,255,255,.6);
}

.mob-menu nav li.current-menu-item > a {
	color: rgba(255,255,255,.6);
}

.mob-menu nav li.menu-item-has-children.active > a {
}

.mob-menu nav li.menu-item-has-children > a::after {
	content: "\e93b";
	display: flex;
	margin-bottom: auto; /*!*/
	align-items: flex-start;
	color: rgba(255,255,255,1);
	font-family: 'icons';
	font-weight: normal;
	font-size: 1.1em;
	line-height: 1;
	margin-top: 0px;
	transition: all 300ms ease;
	transform: translateY(.15em);
}

.mob-menu nav li.menu-item-has-children.active > a::after {
	transform: translateY(-.0em) rotate(180deg);
}

.mob-menu nav li.active > a {
}

.mob-menu nav li ul {
	position: relative;
	padding: 0 0 0 25px;
	margin-bottom: 10px;
}

.mob-menu nav li li {
	opacity: 1;
	animation: none;
}

.mob-menu nav li li a {
	padding: 10px 0;
	font-size: 18px;
}

.mob-menu nav li li.menu-item-has-children > a::after {
	display: none;
}


.mob-menu nav ul ul ul  { /*3rd level*/
	display: none!important;
}



/* Mobile Menu Animation */

@keyframes navfadeIn {
0% {
	opacity: 0.0;
	transform: translate(0px,-50px);
}

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

@keyframes navfadeOut {
0% {
	opacity: 1.0;
	transform: translate(0px,0);
}

100% {
	opacity: 0.0;
	transform: translate(0px,-50px);
	}
}


@keyframes fadeLiIn {
0% {
	opacity: 0.0;
	transform: translate(0px,-10px);
}

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


/* Mobile Menu Trigger */

.mob-menu-trigger {
	--hamburger-stroke-color: var(--primary-color);
	--hamburger-stroke-width: 30px;
	--hamburger-stroke-height: 1.5px;
	--hamburger-stroke-gap: 8px;
	
	display: none;
	position: absolute;
	top: 50%;
	right: var(--page-padding);
	transform: translateY(-50%);

	border: none;
	width: 50px;
	height: 49px;
	margin: 0 -10px 0 0;
	z-index: 999;
	text-transform: uppercase;
	background: transparent;
}

.mob-menu-trigger.open {
	--hamburger-stroke-color: #FFF;
}


@media screen and (max-width: 1024px) {

.mob-menu-trigger {
	display: block;
}

.mob-menu-open .mob-menu {
	display: flex;
	flex-direction: column;
	justify-content: center;
	text-align: center;
}


}


/* Hamburger Icon ani*/


.mob-menu-trigger span {
	margin: 0 auto;
	position: relative;
}
.mob-menu-trigger span:before,
.mob-menu-trigger span:after {
	position: absolute;
	content: '';
}
.mob-menu-trigger span,
.mob-menu-trigger span:before,
.mob-menu-trigger span:after {
	width: var(--hamburger-stroke-width);
	height: var(--hamburger-stroke-height);
	background-color: var(--hamburger-stroke-color);
	border-radius: 0;
	display: block;
}

.mob-menu-trigger span:before {
	margin-top: calc(var(--hamburger-stroke-gap) * -1);
}
.mob-menu-trigger span:after {
	margin-top: calc(var(--hamburger-stroke-gap) * 1);
}

.mob-menu-trigger span {
	transition-duration: 0s;
	transition-delay: 0.15s;
}
.mob-menu-trigger.open span {
	background-color: rgba(0,0,0,0.0);
	transition-delay: 0.15s;
}
.mob-menu-trigger span:before {
	transition-property: margin, transform;
	transition-duration: 0.15s;
	transition-delay: 0.15s, 0s;
}
.mob-menu-trigger.open span:before {
	margin-top: 0;
	transform: rotate(45deg);
	transition-delay: 0s, 0.15s;
}
.mob-menu-trigger span:after {
	transition-property: margin, transform;
	transition-duration: 0.15s;
	transition-delay: 0.15s, 0s;
}
.mob-menu-trigger.open span:after {
	margin-top: 0;
	transform: rotate(-45deg);
	transition-delay: 0s, 0.15s;
}

/* end Hambuger Icon ani*/

/* Menu Animation */

.mob-menu li {
 AUS_opacity: 0;
 AUS_animation: fadeLiIn 400ms ease-in-out 1 forwards;
 }

.mob-menu li:nth-child(1) {
  animation-delay: 100ms;
}

.mob-menu li:nth-child(2) {
  animation-delay: 200ms;
}

.mob-menu li:nth-child(3) {
  animation-delay: 300ms;
}

.mob-menu li:nth-child(4) {
  animation-delay: 400ms;
}

.mob-menu li:nth-child(5) {
  animation-delay: 500ms;
}

.mob-menu li:nth-child(6) {
  animation-delay: 600ms;
}

.mob-menu li:nth-child(7) {
  animation-delay: 700ms;
}

.mob-menu li:nth-child(8) {
  animation-delay: 750ms;
}

/* @end */



/* @group CONTENT */

/* CONTENT
--------------------------------------------------------------------------------- */

#content {
	position: relative;
	overflow: clip; /*important for swiperjs*/
	border-top: 0px solid rgba(0,0,0, .1);
}


AUS_#content::after { /*subtle gradient*/
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 200px;
	z-index: -1;
	background: linear-gradient(to bottom, rgba(0,0,0, .025) 0%,rgba(0,0,0,0) 100%);
	background: linear-gradient(to bottom, rgba(0, 49, 102, .025) 0%,rgba(0, 49, 102,0) 100%);	
}


main {
	padding-top: 0;
	padding-top: var(--main-padding-top);
	padding-bottom: var(--main-padding-bottom);
	min-height: 50vh;
}


/* @end */


/* @group WP BLOCK EDITOR  */

/* WP BLOCK EDITOR
--------------------------------------------------------------------------------- */


.editor-styles-wrapper { 
	overflow-y: auto; 
}

.block-editor-block-list__layout {
}

.is-root-container.wp-block-post-content {
	padding: var(--main-padding-top) 0 var(--main-padding-bottom) 0; 
}


.wp-block {
	box-sizing: border-box;
}


.wp-block.components-placeholder {
	margin-top: var(--block-gap); /*e.g. for Shortcode block*/
}


.wp-block[class*="wp-block-acf-"].is-selected { /* for selected custom ACF blocks */
}


.wp-block[data-align] {
	float: none!important;
	max-width: var(--default-width);
}

.wp-block[data-align="wide"] {
	
}

.wp-block input { /* unset */
	-webkit-appearance: auto;
	-moz-appearance: auto;
}


.wp-block.acf-block-preview a { /*disable link clickability*/
	pointer-events: none; 
}

/*fix double root padding in BE (bc has-global-padding is missing on is-root-container on PHP templates)*/
:where(.is-root-container) :where(.has-global-padding:not(.wp-block-block)) {
	padding-right: 0;
	padding-left: 0;
}

/* disable drop cap in block preview */
.has-drop-cap:not(:focus):first-letter {
	all: unset;
}


/* ACF fields */

.block-editor-block-list__block.acf-block-component.is-selected {
	display: block;
}

.acf-field {
	-moz-osx-font-smoothing: auto;
}

.acf-field ul, 
.acf-field ol {
	padding: 0;
	margin: 0;
}

.editor-styles-wrapper .acf-fields :where(th,tr,td) {
	box-sizing: initial;
}

.acf-field a,
.acf-field a:hover {
	color: #0783BE;
	text-decoration: none;
}

a.acf-icon {
	color: #0783BE;
}

.acf-fields table { 
	border-collapse: inherit;
}


 /* Helper - Block Outline */	
  
.block-editor-block-list__block.acf-block-preview:not(.block-visibility__has-visibility).wp-block,
.block-editor-block-list__block.acf-block-preview:not(.block-visibility__has-visibility) .wp-block,
.block-editor-block-list__block:not([data-type*="acf"]):not(.is-reusable):not(.block-visibility__has-visibility),
.block-editor-block-list__block.block-visibility__has-visibility.is-selected.wp-block {
	outline: 1px solid rgba(0,0,0, .13);
}


.block-editor-block-preview__content-iframe .block-editor-block-list__block {
	outline: none!important; /*no block outlines in block previews */
}


.block-editor-block-list__block:not([data-type*="acf"]):not(.is-reusable) .wp-block {
	outline-offset: -1px; /*prevent overlapping outline of nested blocks*/
}

/* Helper - Missing Blocks */

.wp-block.wp-block-missing {
	border: 2px solid RED;
}

/* TinyMCE - fix CSS conflicts, halbwegs */

.mce-tinymce .mce-btn button {
	font-size: 20px;
}

/* reset editor-styles in ACF fields with TinyMCE */

#tinymce {
	background: #FFF;
}

#tinymce * {
	margin: revert;
	padding: revert;
	font-size: .938rem;
	line-height: 1.4;
	color: #000;
	font-family: sans-serif;
	list-style: inside;
}

#tinymce::before,
#tinymce::after {
	display: none;
}

#tinymce :where(strong, b) {
	font-weight: var(--bold);
}

#tinymce a {
	color: #2171b1;
	text-decoration: underline;
}

#tinymce h1 { font-size: 2rem; }
#tinymce h2 { font-size: 1.5rem; }
#tinymce h3 { font-size: 1.25rem; }

#tinymce :where(p,h1,h2,h3,h4,h5,hr,ul,ol) { /*helper border*/
	position: relative;
	border: 1px dashed #CCC;
	border-color: #CCC;
	border-color: rgba(1,1,1, 0.25);
	padding: 2px;	
}


/*spacing helper - visualize spaces*/

.spacing-helper {
	display: flex;
	align-items: flex-end;
	gap: 20px;
}

.spacing-helper :where(.space) {
	position: relative;
	flex: 1 1 auto;
	display: flex;
	justify-content: center;
	align-items: center;
	background: #CCC;
	height: var(--space);
}

.space[data-size="xs"]   { --space: var(--space-xs); }
.space[data-size="sm"]   { --space: var(--space-sm); }
.space[data-size="md"]   { --space: var(--space-md); }
.space[data-size="lg"]   { --space: var(--space-lg); }
.space[data-size="xl"]   { --space: var(--space-xl); }
.space[data-size="xxl"]  { --space: var(--space-xxl); }
.space[data-size="xxxl"] { --space: var(--space-xxxl); }

.space::after {
	content: attr(data-size);
	font-size: 14px;
	text-transform: uppercase;
}

.space[data-size="md"] { /*default space*/
	background: lightblue;
}




/* @end */



/* @group WP BLOCKS  */

/* WP BLOCKS
--------------------------------------------------------------------------------- */

/* @group WP PARAGRAPH  */


/* WP PARAGRAPH
--------------------------------------------------------------------------------- */




/* @end */




/* @group WP IMAGE  */


/* WP IMAGE
--------------------------------------------------------------------------------- */


.wp-block-image {
}

.wp-block-image img {
	width: 100%;
}

.wp-block-image.alignwide img,
.wp-block-image.alignfull img {
	width: 100%;
}

.wp-block-image:not(.alignfull) img {
	border-radius: var(--radius);
}

.wp-block-image .aligncenter, 
.wp-block-image .alignleft, 
.wp-block-image .alignright {
    display: table;
}

.wp-block-image .aligncenter > figcaption, 
.wp-block-image .alignleft > figcaption, 
.wp-block-image .alignright > figcaption {
    display: table-caption;
    caption-side: bottom; 
}


figcaption,
.wp-block-image figcaption,
.wp-block-embed figcaption {
	font-size: var(--text-small);
	line-height: 1.4;
	font-style: italic;
	margin: 10px 0 10px 0;
	text-align: left;
	word-break:break-word;
	overflow-wrap:break-word;
}

/*custom image styles*/

.is-style-image-shadow img {
	box-shadow: 0px 3px 15px -5px rgba(0,0,0, .6);
}


/* wp lightbox*/

.wp-lightbox-overlay .scrim {
	/*add custom bg color here*/
}


/* for Block Editor */

.wp-block[data-align] > .wp-block-image {
}


.wp-block[data-align="left"] > .wp-block-image {
	float: left;
}

.wp-block[data-align="right"] > .wp-block-image {
	float: right;
}


.wp-block-image .components-resizable-box__container { /*remove small space below images*/
    vertical-align: top; 
}

/* @end */


/* @group WP MEDIA-TEXT  */


/* WP MEDIA-TEXT
--------------------------------------------------------------------------------- */


.wp-block-media-text {
	gap: 30px;
}

.wp-block-media-text .wp-block-media-text__media > * {
	border-radius: var(--radius);
}

.wp-block-media-text .wp-block-media-text__content {
	padding: 0;
}

.wp-block-media-text__content > :first-child {
	margin-top: 0;
}

.wp-block-media-text__content > :last-child {
	margin-bottom: 0;
}

:where(.wp-block-media-text__content) > * { /*WP missed this*/
	margin-top: var(--block-gap);
}

@media screen and (max-width: 600px) {
	.wp-block-media-text__content {
		
	}

}



/* @end */


/* @group WP GALLERY  */


/* WP GALLERY
--------------------------------------------------------------------------------- */


.wp-block-gallery {
	--wp--style--gallery-gap-default: 10px;
	AUS_--block-gap: 4rem; /*override block gap for this block*/
}

.wp-block-gallery.is-style-no-gap { /*custom style*/
	gap: 0;
}

.wp-block-gallery.has-nested-images figure.wp-block-image figcaption {
  background: linear-gradient(0deg,rgba(0,0,0,.6) 0%,rgba(0,0,0,.0) 100%,transparent);
  bottom:0;
  box-sizing:border-box;
  color:#fff;
  font-size: var(--text-small);
  padding: 10px 10px;

}



/* @end */

/* @group WP EMBED  */

/* WP EMBED
--------------------------------------------------------------------------------- */

.wp-block-embed {
}

.wp-block-embed__wrapper > * {
	margin: 0 auto!important;
}

.wp-block-embed__wrapper iframe {
	width: 100%;
	border-radius: var(--radius);
}

/* @end */


/* @group WP VIDEO  */


/* WP VIDEO (self hosted)
--------------------------------------------------------------------------------- */


.wp-block-video {
}

.wp-block-video video {
	display: block;
	width: 100%;
	border-radius: var(--radius);
}

/* @end */


/* @group WP COVER  */

/* WP COVER
--------------------------------------------------------------------------------- */

.wp-block-cover {
	padding: 30px;
}


.wp-block-cover:not(.alignfull) {
	border-radius: var(--radius);
}


/* @end */



/* @group WP QUOTE  */

/* WP QUOTE
--------------------------------------------------------------------------------- */

blockquote.wp-block-quote {
	margin-block: var(--space-lg);
	max-width: 40rem;
}


blockquote.wp-block-quote > * {
	font-weight: var(--bold);
	color: var(--primary-color);
}

.wp-block-quote p + p {
}

.wp-block-quote cite {
	display: block;
	font-style: normal;
	font-weight: var(--bold);
	font-size: var(--text-small);
	color: var(--text-gray);
	margin: 10px 0 0 0;
}

/* @end */


/* @group WP COLUMNS  */


/* WP COLUMNS
--------------------------------------------------------------------------------- */

.wp-block-columns {
	/*--block-gap is default the columns gap*/
	gap: var(--space-md); /*override gap*/
}


/* custom style: breakpoint 1024 */

@media screen and (max-width: 1024px) {
	.is-style-breakpoint-1024 {
		flex-wrap: wrap!important;
	}	
	.is-style-breakpoint-1024> .wp-block-column {
		flex-basis: 100%!important;
	}
}

/* custom style: breakpoint 840 */

@media screen and (max-width: 840px) {
	.is-style-breakpoint-840 {
		flex-wrap: wrap!important;
	}	
	.is-style-breakpoint-840 > .wp-block-column {
		flex-basis: 100%!important;
	}
}



.wp-block-column {
	
}



/* @end */


/* @group WP SPACER  */


/* WP SPACER
--------------------------------------------------------------------------------- */

.wp-block-spacer {
}


/* @end */


/* @group WP FILE  */


/* WP FILE
--------------------------------------------------------------------------------- */


.wp-block-file {
	position: relative;
	background: var(--primary-bg);
	background: transparent;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1ch 2ch;
	padding: 0 0 0 2.2rem;
}

.wp-block-file::before {
	position: absolute;
	top: -0.0em;
	content: "\e948";
	font-family: 'icons';
	font-size: 2em;
	line-height: 1;
	margin-left: -2.2rem;
	color: var(--primary-color);
}

.wp-block-file + .wp-block-file {
	margin-top: 0.75em;
	border-top: 0px solid var(--border-color);

}

.wp-block-file__embed {
	border: 1px solid var(--border-color);
}

.wp-block-file a:not(.wp-block-file__button) {
	font-size: var(--base-font-size);
	font-weight: var(--bold);
	display: inline-block;
	text-decoration: none;
}

.wp-block-file__button.wp-element-button {
	background: var(--link-color);
	font-weight: var(--bold);
	text-transform: uppercase;
	font-size: var(--text-tiny);
	border-radius: 0;
	padding: 4px 15px;
	margin: 0;
	border-radius: 100px;
	background: transparent;
	letter-spacing: .03em;
	color: var(--text-color);
	border: 1px solid var(--text-color);
}

.wp-block-file__button:hover {
	opacity: .6;
}

/*embedded PDF*/
.wp-block-file:has(.wp-block-file__embed) {
	padding-left: 0;
}

.wp-block-file:has(.wp-block-file__embed)::before {
	display: none;
}

.wp-block-file__embed {
	margin-bottom: 10px;
}




/* @end */


/* @group WP TABLE  */


/* WP TABLE
--------------------------------------------------------------------------------- */


.wp-block-table {
	line-height: 1.5;
}

/* for editor */
.wp-block[data-align] table {
	width: 100%;
}

.wp-block-table table {
	width: 100%;
	max-width: 100%;
}

.wp-block-table table thead {
	text-align: left;
	border-bottom: 3px solid var(--border-color);
}

table thead td {
	font-weight: var(--bold);
}

.wp-block-table  tfoot {
	border-top: 1px solid var(--border-color);
}


.wp-block-table tr {
	background: transparent;
	border-bottom: 1px solid var(--border-color);
}

.wp-block-table tr:last-child {
	border-bottom: none;
}

.wp-block-table tr th {
	font-weight: var(--bold);
}

.wp-block-table th,
.wp-block-table td {
	border-color: var(--border-color);
	padding: 0.6rem 0.5rem;
	font-weight:  var(--base-font-weight);
}

.wp-block-table tr td:last-child {
	padding-right: 0;
}

.wp-block-table p {
	margin: 0;
}

.wp-block-table figcaption {
	margin: 1rem 0; 
}

/* custom style: stripes */

.wp-block-table.is-style-stripes tbody tr:nth-child(2n+1) {
	background: rgba(0,0,0, .04);
}

.wp-block-table.is-style-stripes th,
.wp-block-table.is-style-stripes td {
	padding-left: 15px;
}

.wp-block-table.is-style-stripes tr,
.wp-block-table.is-style-stripes thead,
.wp-block-table.is-style-stripes tfoot {
	border: none;
}

/* custom style: blank */

.wp-block-table.is-style-blank {
	line-height: inherit;
}

.wp-block-table.is-style-blank :is(thead, tfoot, tr) {
	border: none;
}

.wp-block-table.is-style-blank th,
.wp-block-table.is-style-blank td {
	padding-block: 0;
	padding-left: 0;
	border: none;
}


/*for editor - show borders on select*/

.wp-block-table.is-selected table thead,
.wp-block-table.is-selected table tfoot,
.wp-block-table.is-selected table th,
.wp-block-table.is-selected table td,
.wp-block-table.is-selected table tr {
	border: 1px dashed #999;
}


/* @end */


/* @group WP GROUP  */

/* WP GROUP
--------------------------------------------------------------------------------- */

.wp-block-group {
	gap: var(--columns-gap)!important /*override WP defaults*/;
}

.wp-block-group.has-background {
	
}

.wp-block-group > .wp-block-group {
	margin-bottom: 0;
}

.wp-block-group > :first-child {
	margin-top: 0;
}

.wp-block-group > :last-child {
	margin-bottom: 0;
}


/* @end */


/* @group WP BUTTONS  */


/* WP BUTTONS
--------------------------------------------------------------------------------- */

.wp-block-buttons { 
	gap: 15px; /*override WP inline default*/
}

.wp-block-button__link  {
	width: auto;
	height: auto;
	text-transform: none;
	padding: .9em 2em;
	font-weight: var(--bold);
	font-size: calc((16/16) * 1rem);
	line-height: 1.4;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	color: var(--text-color);
	letter-spacing: 0.02em;
	text-decoration: none;
	background: transparent;
	border: 1px solid var(--text-color);
	border-radius: 10rem;
}

.wp-block-button__link:hover {
	color: var(--primary-color);
	border-color: var(--primary-color);
}

.wp-block-button__link:focus-visible {
	outline: 2px solid blue;
	outline-offset: 2px;
}

.wp-block-button__link {

}

.wp-block-button__link:hover {

}

/*custom style: btn-white*/



/*custom style: btn-cta*/

.wp-block-button.is-style-btn-cta {
	position: relative;
	display: inline-flex;
	background: var(--primary-dark-color);
	overflow: hidden;
	border-radius: 10rem;
	outline-offset: 2px;
}

.wp-block-button.is-style-btn-cta:focus-within {
	outline: 2px solid blue;
}


.wp-block-button.is-style-btn-cta::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--secondary-color);
	transition: 300ms ease;
}

.wp-block-button.is-style-btn-cta:hover::before {
	opacity: 0;
}

.wp-block-button.is-style-btn-cta .wp-block-button__link {
	position: relative;
	font-size: clamp(calc((15/16) * 1rem), 4vw, calc((18/16) * 1rem));
	color: #FFF;
	border-color: var(--secondary-color);
	border: 1px solid rgba(0,0,0, .0);
	background: transparent;
}

.wp-block-button.is-style-btn-cta .wp-block-button__link:hover {
	background: var(--primary-dark-color);
	background: transparent;
}

/*custom style: btn-text*/

.wp-block-button.is-style-btn-text .wp-block-button__link {
	gap: 4px;
	padding: 0;
	border-radius: 0;
	color: var(--primary-dark-color);
	background: transparent;
	border: none;
}

.wp-block-button.is-style-btn-text .wp-block-button__link::before {
	content: "\e931";
	content: "\e932";
	font-family: 'icons';
	font-size: 1.6em;
	font-weight: normal;
	text-indent: -.16em;
}

.wp-block-button.is-style-btn-text .wp-block-button__link:hover {
	color: var(--primary-color);
	background: transparent;
}


/*custom style: btn-external*/

.wp-block-button.is-style-btn-external .wp-block-button__link {
	gap: 5px;
	padding: 0;
	border-radius: 0;
	color: var(--primary-dark-color);
	background: transparent;
	border: none;
}

.wp-block-button.is-style-btn-external .wp-block-button__link::after {
	content: "\e90c";
	font-family: 'icons';
	font-size: 1.1em;
	line-height: 1;
	font-weight: normal;
}

.wp-block-button.is-style-btn-external .wp-block-button__link:hover {
	color: var(--link-color-hover);
	background: transparent;
}








/* @end */



/* @group WP SHORTCODE  */

/* WP SHORTCODE
--------------------------------------------------------------------------------- */

.wp-block-shortcode { /* class only in editor */
}

/* @end */


/* @group WP HTML  */

/* WP HTML
--------------------------------------------------------------------------------- */

.wp-block-html { /* class only in editor */
}

/* @end */


/* @group WP VIDEO  */

/* WP VIDEO
--------------------------------------------------------------------------------- */

.wp-block-video {
}

/* @end */


/* @group WP AUDIO  */

/* WP AUDIO
--------------------------------------------------------------------------------- */

.wp-block-audio {
}

/* @end */


/* @group WP CODE  */


/* WP CODE
--------------------------------------------------------------------------------- */

.wp-block-code {
	background: var(--secondary-bg);
	border-radius: var(--radius);
}

.wp-block-code code {
	background: none;
	padding: var(--box-padding);
	font-size: 1rem;
}

code {
	margin: 0;
}

/* @end */


/* @group WP DETAILS  */


/* WP DETAILS
--------------------------------------------------------------------------------- */

.wp-block-details {
  --block-gap: 1.4em;
}

.wp-block-details[open] {
  padding-bottom: var(--space-md);
}

.wp-block-details summary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: .6em 1.2rem;
  font-size: var(--text-small);
  line-height: 1;
  background: transparent;
  border-radius: 10rem;
  border: 1px solid var(--text-color);
  transition: all 300ms ease;
}

.wp-block-details summary:hover {
  color: var(--link-color);
}

.wp-block-details summary::marker,
.wp-block-details summary::-webkit-details-marker  {
  /*::marker has no safari support*/
  display: none;
}

.wp-block-details summary::before {
  content: "\e93b";
  display: inline-block;
  margin-left: -.2em;
  font-family: 'icons';
  font-size: 1.3em;
  line-height: 1;
  transform: translateY(4%);
}

.wp-block-details[open] > summary::before {
  transform: rotate(180deg) translateY(5%);
}


.wp-block-details summary + * {
}

.wp-block-details + .wp-block-details {
  margin-top: 3px;
}


.wp-block-details .wp-block-details { /*details within details*/
  margin-left: 30px;
}



/* @end */


/* @group WP FOOTNOTES  */


/* WP FOOTNOTES
--------------------------------------------------------------------------------- */

.wp-block-footnotes {
	font-size: var(--text-tiny);
	padding-top: var(--space-sm);
	border-top: 1px solid var(--border-color);
}




/* @end */


/* @group WP SEPARATOR  */


/* WP SEPARATOR
--------------------------------------------------------------------------------- */


hr,
hr.wp-block-separator {
	position: relative;
	display: block;
	clear: both;
	height: 1px;
	border: 0;
	background: transparent;
	border-bottom: 1px solid var(--border-color);
	margin: var(--space-lg) 0;
}


/* @end */






/* @end */


/* @group CUSTOM BLOCKS  */

/* CUSTOM BLOCKS
--------------------------------------------------------------------------------- */


/* @group BANNER */

/* Banner
--------------------------------------------------------------------------------- */


.banner {
	display: flex;
	align-items: center;
	position: relative;
	z-index: 0;
	margin-bottom: var(--main-padding-top);
	margin-bottom: var(--space-xl);
	height: 730px; /*the height*/
	height: clamp(450px, 42vw, 640px);
}

.entry-content > .banner:first-child {
	margin-top: calc(var(--main-padding-top) * -1); /*  minus the main top padding*/
}

.is-root-container > .wp-block-acf-banner:first-child { /*for editor*/
	margin-top: calc(var(--main-padding-top) * -1);
}

.banner__image-wrap {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0, .1);
}

.banner img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	margin: 0 auto;
	opacity: 1;
}

.banner .focal-y-top img {
	object-position: top center;
}

.banner .focal-y-bottom img {
	object-position: bottom center;
}

@media screen and (max-width: 600px) {
	.banner {
		height: clamp(280px, 70vw, 360px);
	}	
}


/* @end */

/* @group HERO */

/* Hero
--------------------------------------------------------------------------------- */


.hero {
	position: relative;
	display: flex;
	margin-bottom: var(--main-padding-top);
	margin-bottom: var(--space-xl);
	height: 730px; /*the height*/
	height: clamp(580px, 45vw, 720px);
}

.hero.is-selected { /*editor*/
	height: auto;
}

.entry-content > .hero:first-child {
	margin-top: calc(var(--main-padding-top) * -1); /*  minus the main top padding*/
}

.is-root-container > .wp-block-acf-hero:first-child { /*for editor*/
	margin-top: calc(var(--main-padding-top) * -1);
}

.hero-gallery {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	background: var(--primary-color);
}


.hero-gallery .swiper {
	max-width: 100vw;
	overflow: hidden;
}

.hero-gallery img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	margin: 0 auto;
	opacity: 1;
}

.hero-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;	
	background: #000;
	z-index: 1;
	opacity: 0; /*field value*/
}



.hero-keyvisual {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	overflow: hidden;
	opacity: .5;
}

.hero-keyvisual svg {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 190%;
}


.hero-keyvisual path {
	--delay: 200ms;
	--duration: 4000ms;
	fill: none;
	stroke: #FFF;
	stroke-width: 0.2;
	stroke-miterlimit: 10;
	transform-box: fill-box; /*!*/
	transform-origin: center;
	will-change: transform; /*performance*/
	animation-iteration-count: infinite;
	animation-direction: alternate;
	animation-duration: var(--duration);
	AUS_animation: wave2 var(--duration) ease-in-out infinite alternate;  
}

.is-root-container .hero-keyvisual path {
    animation: none;	
}

.enable-animation .hero-keyvisual.animated path { /*enable animation only for modern/powerful devices*/
	animation-name: wave2;  
}


/* Offset animation delay for each line to create a layered effect */
.hero-keyvisual path:nth-child(1) { animation-delay: 0s; }
.hero-keyvisual path:nth-child(2) { animation-delay: calc(var(--delay) * 1) }
.hero-keyvisual path:nth-child(3) { animation-delay: calc(var(--delay) * 2) }
.hero-keyvisual path:nth-child(4) { animation-delay: calc(var(--delay) * 3) }
.hero-keyvisual path:nth-child(5) { animation-delay: calc(var(--delay) * 4) }
.hero-keyvisual path:nth-child(6) { animation-delay: calc(var(--delay) * 5) }
.hero-keyvisual path:nth-child(7) { animation-delay: calc(var(--delay) * 6) }
.hero-keyvisual path:nth-child(8) { animation-delay: calc(var(--delay) * 7) }
.hero-keyvisual path:nth-child(9) { animation-delay: calc(var(--delay) * 8) }
.hero-keyvisual path:nth-child(10){ animation-delay: calc(var(--delay) * 9) }
.hero-keyvisual path:nth-child(11){ animation-delay: calc(var(--delay) * 10) }
.hero-keyvisual path:nth-child(12){ animation-delay: calc(var(--delay) * 11) }

@keyframes wave {
  0% {
    transform: skew(0);
  }
  100% {
    transform: skew(-0.06turn, 30deg);
  }
}

@keyframes wave2 {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(50deg);
  }
}


@media (prefers-reduced-motion: reduce) {
  .hero-keyvisual path {
    animation: none;
  }
}


.hero-buttons {
	position: relative;
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
	padding-inline: var(--page-padding);
	max-width: var(--wide-width);
	margin-inline: auto;
	margin-top: auto;
	margin-bottom: 70px;
	z-index: 1;
}

.hero-button {
	position: relative;
	display: flex;
	flex: 1;
	text-decoration: none;
	font-size: clamp(26px, 2vw, 32px);
	line-height: 1.2;
	padding: 30px clamp(30px, 3vw, 40px);
	color: #FFF;
	text-transform: uppercase;
    background: linear-gradient(90deg, var(--primary-color) 30%, #00ADEF  80%);
	background: var(--primary-color);
	outline-offset: 3px;
	transition: 300ms ease;
}


.hero-button:hover {
	background: var(--primary-dark-color);
	color: #FFF;
}

.hero-button__title {
	position: relative;
	display: flex;
	flex-direction: column;
	width: 100%;

}

.hero-button__title span {
	display: block;
	font-weight: 300;
}


.hero-button__title::after {
	content: "\e932";
	display: block;
	margin-top: auto;
	margin-bottom: -5px;
	padding-top: 10px;
	font-family: 'icons';
	font-weight: normal;
	font-size: 1.3em;
	line-height: 1;
	text-indent: -.15em;
	transition: 300ms ease;
}

a:hover .hero-button__title::after {
	text-indent: 0em;
}



@media screen and (max-width: 840px) {
		
		.hero {
			display: block;
			height: auto;
		}
		
		.hero-gallery {
			position: relative;
			height: clamp(360px, 70vw, 480px);
		}
		
		.hero-keyvisual path {
			stroke-width: 0.3;
		}

		
		.hero-buttons {
			display: grid;
			gap: 12px;
			margin: 0;
			margin-top: -80px;
		}
		
		.hero-button {
			padding: 26px 30px;
			border-radius: 2px;
		}
		
		.hero-button__title {
			width: 100%;
			padding-right: 1.8em;
			font-size: 24px;
			position: relative;
		}
		
		.hero-button__title::after {
			position: absolute;
			bottom: 0;
			right: 0;
			margin: 0 -.35em -.1em 0;
			text-indent: 0;
		}
}



/* @end */



/* @group IMAGE-SLIDER */

/* Image-Slider
--------------------------------------------------------------------------------- */

.image-slider {
	AUS_margin-block: var(--space-lg);
}

.image-slider.alignwide {
}

.image-slider.alignfull {
}

.image-slider .swiper {
}

.image-slider .swiper-wrapper {
 }

.image-slider__image {
	position: relative;
	overflow: hidden;
	background: rgba(0,0,0, .05);
	border: 0px solid MAGENTA;
	height: 500px; /*the height*/
	height: clamp(300px, 70vw, 600px);
}

.image-slider.alignwide .image-slider__image,
.image-slider.alignfull .image-slider__image {
	height: clamp(300px, 60vw, 750px);
}

.image-slider:not(.alignfull) {
	border-radius: var(--radius);
	overflow: hidden;
}

.image-slider__image img {
    display: block;
    width: 100%;
    height: 100%;
	AUS_aspect-ratio: 3/2;
    object-fit: cover;
	border-radius: var(--radius);
}


.image-slider__caption {
	position: absolute;
	width: 100%;
	bottom: 0;
	left: 0;
	margin: 0;
	color: #FFF;
	font-size: var(--text-small);
	padding: 15px;
	padding-bottom: 50px; /*space fo bullets*/
	text-shadow: 0 2px 5px rgba(0,0,0, .5);
	background: rgba(0,0,0, .5);
}



.image-slider .swiper-pagination-bullets {
	position: absolute;
}


/* style: is-contain */

.image-slider__image.is-contain img {
    object-fit: contain;
}


/* style: is-overflow */

.swiper.is-overflow {
	overflow: visible;
}

.wp-block.wp-block-acf-image-slider {
	overflow: hidden; /*WP*/
}




/* @end */



/* @group GALLERY */

/* Gallery
--------------------------------------------------------------------------------- */


.gallery {
}

.gallery__grid {
	--gallery-gap: clamp(10px, 2vw, 20px);
	display: flex;
	flex-wrap: wrap;
	gap: var(--gallery-gap) 0;
	margin-left: calc(var(--gallery-gap) * -.5); /*  offset gap */
	margin-right: calc(var(--gallery-gap) * -.5); /*  offset gap */
}

.gallery__grid.columns-align-center {
	justify-content: center;

}
.gallery__grid.columns-align-right {
	justify-content: flex-end;
}

.gallery__item {
	position: relative;
	flex: 0 0 auto;
	width: calc(100% / 3); /*default 3 colums*/
	overflow: hidden;
	display: flex;
	flex-direction: column;
	margin: 0;	
	padding-right: calc(var(--gallery-gap) * .5);
	padding-left: calc(var(--gallery-gap) * .5);
	aspect-ratio: unset!important;
}

.gallery-columns-1 .gallery__item { width: calc(100% / 1); }
.gallery-columns-2 .gallery__item { width: calc(100% / 2); }
.gallery-columns-3 .gallery__item { width: calc(100% / 3); }
.gallery-columns-4 .gallery__item { width: calc(100% / 4); }
.gallery-columns-5 .gallery__item { width: calc(100% / 5); }
.gallery-columns-6 .gallery__item { width: calc(100% / 6); }


@media screen and (max-width: 1024px) {

.gallery-columns-2 .gallery__item { width: calc(100% / 2); }
.gallery-columns-3 .gallery__item { width: calc(100% / 2); }
.gallery-columns-4 .gallery__item { width: calc(100% / 2); }
.gallery-columns-5 .gallery__item { width: calc(100% / 3); }
.gallery-columns-6 .gallery__item { width: calc(100% / 3); }

}

@media screen and (max-width: 600px) {

.gallery-columns-2 .gallery__item { width: calc(100% / 2); }
.gallery-columns-3 .gallery__item { width: calc(100% / 2); }
.gallery-columns-4 .gallery__item { width: calc(100% / 2); }
.gallery-columns-5 .gallery__item { width: calc(100% / 2); }
.gallery-columns-6 .gallery__item { width: calc(100% / 2); }

}


.gallery .gap-zero .gallery__grid {
	--gallery-gap: 0;
}

.gallery__image {
}

.gallery__image a {
	display: block;
	height: 100%;
}

.gallery__image  img {
	display: block;
	margin: 0;
	width: 100%;
	border-radius: var(--radius);
	transition: all 600ms ease!important;
}

.gallery__image a:hover img {
	transform: scale(1.08);
	opacity: .8;
}


/* gallery cropped */
.gallery__item.is-cropped  {
	flex: 1 0 auto; /* images in last row take remaining space*/
}

.gallery__item.is-cropped img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	margin: 0 auto;
}

/* gallery has custom aspect ratio */
.gallery__item.has-ratio .ratio-wrap {
	position: relative;
}

.gallery__item.ratio-1-1 .gallery__image { aspect-ratio: 1 }
.gallery__item.ratio-4-3 .gallery__image { aspect-ratio: 4/3 }
.gallery__item.ratio-3-2 .gallery__image { aspect-ratio: 3/2 }
.gallery__item.ratio-16-9 .gallery__image { aspect-ratio: 16/9 }


.gallery__item.has-ratio .gallery__image {
	overflow: hidden;
	position: relative;
}

.gallery__item.has-ratio img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	margin: 0 auto;
}

.gallery__item figcaption {
}



/* -- Gallery Masonry (JS) */


.gallery .is-masonry {
}

.gallery .is-masonry .gallery__item {
	padding: calc(var(--gallery-gap) / 2);
}



/* @end */


/* @group ACCORDION  */

/* ACCORDION
--------------------------------------------------------------------------------- */


.accordion {
	position: relative;
	border: none;
	width: 100%;
	border-top: 1px solid var(--text-color);
	border-bottom: 1px solid var(--text-color);
}

.accordion + .accordion {
	border-top: none;
	margin-top: 0;
}

.accordion-heading {
	margin: 0;
	padding: 0;
	border: none;
	text-transform: none;
}

.accordion-trigger {
	display: block;
	position: relative;
	border: none;
	text-align: left;
	width: 100%;
	padding: 22px 0;
	padding-right: 35px;
	font-size: var(--base-font-size);
	line-height: var(--base-line-height);
	color: var(--text-color);
	background: transparent;
	font-weight: var(--bold);
	transition: all 300ms ease;
	outline-offset: 4px;
}

.accordion-trigger:hover {
	text-decoration: none;
}

.accordion-trigger.active {
}

.accordion-trigger:hover,
.accordion-trigger:hover i,
.accordion-trigger:hover i::after {
	color: var(--primary-color);

}

.accordion-trigger:hover i {
	text-decoration: none;
}

.accordion-trigger i::after {
	position: absolute;
	top: 20px;
	right: 0;
	margin: 0;
	content: "\e93b";
	display: block;
	line-height: 1;
	border-radius:0;
	font-family: 'icons';
	font-size: 2rem;
	font-weight: normal;
	font-style: normal;
	color: var(--text-color);
	text-decoration: none;
	transition: all 250ms ease-in-out;
}

 .accordion-trigger.active i::after {
	transform: rotate(180deg);
}

.accordion-content {
	position: relative;
	padding: 5px 0 var(--space-md) 0;
}

.accordion-content > *:first-child,
.accordion-content .acf-innerblocks-container > *:first-child  {
	margin-top: 0;
}

/* style: large*/

.accordion.is-style-large .accordion-trigger {
	font-size: inherit;
}

.accordion.is-style-large .accordion-trigger i::after {
	top: 25px;
}


.wp-block-acf-accordion .accordion-content {
	display: none; /*WP preview: collapse item*/
}

.wp-block-acf-accordion.is-selected .accordion-content,
.wp-block-acf-accordion.has-child-selected .accordion-content {
	display: block; /*WP preview: expand item on select*/
}

.wp-block-acf-accordion.is-selected  .accordion-trigger i:after {
	transform: rotate(180deg); /*WP editor*/
}

@media screen and (max-width: 600px) {
}

/* @end */


/* @group FORM */

/* Form
--------------------------------------------------------------------------------- */


.form {
}

/* @end */

/* @group RECENT POSTS */

/* Recent Posts
--------------------------------------------------------------------------------- */


.recent-posts {
}

.recent-post-card {
}

.recent-post-card a {
	display: grid;
	grid-template-columns:  min(35%,270px) auto;
	gap: 20px 30px;
	overflow: hidden;
	text-decoration: none;
	transition: all 300ms ease;
}


.recent-post-card.no-image {
	grid-template-columns:  1fr;
}

.recent-post-card + .recent-post-card {
	margin-top: 30px;
}

.recent-post-card__image {
	aspect-ratio: 4/3;
	border-radius: var(--radius);
	overflow: hidden;
	margin: 0;
}

.recent-post-card__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	margin: 0 auto;
	border-radius: var(--radius);
	transition: all 600ms ease;
}

a:hover .recent-post-card__image img {
	transform: scale(1.1);
}

.recent-post-card__content {
	padding-block: 15px 30px;
}

.recent-post-card__title {
	margin: 0;
	padding: 0;
	font-size: var(--base-font-size);
	line-height: 1.4;
}

a:hover .recent-post-card__title {
	display: block;
	color: var(--primary-color);
	text-decoration: none;
	transition: 300ms ease;
}


.recent-post-card__date {
	margin-top: 5px;
	font-size: var(--text-small);
	color: var(--text-gray);
}

@media screen and (max-width: 600px) {
	.recent-post-card a {
		grid-template-columns: 1fr;
	}
	
	.recent-post-card + .recent-post-card {
	}
	
	.recent-post-card__content {
		padding-inline: var(--box-padding-sm);
		padding-block: 0 10px;
    }	
}



/* @end */



/* @group IFRAME EMBED */

/* iframe embed
--------------------------------------------------------------------------------- */


.iframe-embed {
}

.iframe-embed iframe {
	display: block;
	width: 100%;
	height: auto;
	margin: 0;
	background: rgba(0,0,0, .05);
}

.iframe-embed:not(.alignfull) iframe {
	border-radius: var(--radius);	
}

.wp-block.iframe-embed iframe {
	pointer-events: none; /*WP*/
}

.iframe-embed iframe {
	min-height: 320px; /*for mobile when ratio is to small*/
}

.ratio-1 { aspect-ratio: 1;}
.ratio-3-2 { aspect-ratio: 3/2;}
.ratio-4-3 { aspect-ratio: 4/3;}
.ratio-16-9 { aspect-ratio: 16/9;}
.ratio-2-1 { aspect-ratio: 2/1;}


/* @end */



/* @group TEASER-CARDS */

/* Teaser Cards
--------------------------------------------------------------------------------- */


.teaser-cards {
	--block-gap: var(--space-lg);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px;
}

.alignwide .teaser-cards, 
.teaser-cards.alignwide {
	grid-template-columns: 1fr 1fr 1fr;
	grid-template-columns: repeat(3, minmax(0,1fr));
}


.teaser-card {
	position: relative;
	background: #FFF;
	box-shadow: 0px 3px 35px -10px rgba(0,0,0, .25);
}

.teaser-card__image {
	aspect-ratio: 3/2;
	overflow: hidden;
}

.teaser-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.teaser-card__image a {
	display: block;
	height: 100%;
}

.teaser-card__image a img {
	transition: 600ms ease;
}

.teaser-card__image a:hover img {
	transform: scale(1.1);
}

.teaser-card__content {
	padding: var(--box-padding);
	padding-block: 30px;
}

.teaser-card__metatitle {
	color: var(--text-gray);
	color: rgba(0,0,0, .35);
	text-transform: uppercase;
	font-size: var(--text-small);
	font-weight: var(--bold);
}

.teaser-card__title {
	margin: 0;
	line-height: 1.3;
}

.teaser-card__excerpt {
	margin-top: .8rem;
	font-size: var(--text-small);
}

.teaser-card__button {
	margin-top: 1rem;
}

@media screen and (max-width: 1024px) {
	.teaser-cards,
	.alignwide .teaser-cards,
	.teaser-cards.alignwide  {
		grid-template-columns: 1fr 1fr;
	}
}

@media screen and (max-width: 600px) {
	.teaser-cards,
	.alignwide .teaser-cards,
	.teaser-cards.alignwide  {
		grid-template-columns: 1fr;
	}
}


/* style: rows */


.teaser-cards.is-style-rows {
	grid-template-columns: 1fr;
	gap: 30px;
}

.teaser-cards.is-style-rows .teaser-card {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
}

.teaser-cards.is-style-rows .teaser-card__content {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: var(--box-padding) var(--box-padding-xl);
}

.teaser-cards.is-style-rows .teaser-card__image {
	aspect-ratio: 3/2.3;
}

@media screen and (max-width: 600px) {
	.teaser-cards.is-style-rows .teaser-card {
		grid-template-columns: 1fr;
		gap: 0;
	}
	
	.teaser-cards.is-style-rows .teaser-card__image {
		aspect-ratio: 3/2;
	}
	
}


/* @end */



/* @group TEASER-IMAGE-TEXT */

/* Teaser Image-Text
--------------------------------------------------------------------------------- */


.teaser-image-text {
}

.teaser-image-text__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	overflow: hidden;
}

.teaser-image-text__image {
	overflow: hidden;
	border-radius: var(--radius);
	background: rgba(0,0,0, .05);
}

.teaser-image-text__image img {
	aspect-ratio: 4/3;
	height: 100%;
	width: 100%;
	object-fit: cover;
	display: block;
	margin: 0;
}

.teaser-image-text__content {
	display: flex;
	flex-direction: column;
	justify-content: center;
	max-width: 40rem;
	margin: 0 auto;
	padding: var(--space-xl) var(--box-padding-xl);
}


/* option: order */

.teaser-image-text__grid.order-text-first .teaser-image-text__image {
	order:  2;
}

/* option: bg color */

.teaser-image-text__grid.bg-secondary {
	background: var(--secondary-color);
	color: var(--text-color);
}

/* option: image ratio */

.teaser-image-text__image.image-ratio-3-2 img { aspect-ratio: 3/2; }
.teaser-image-text__image.image-ratio-1-1 img { aspect-ratio: 1; }


@media screen and (max-width: 1024px) {
	.teaser-image-text__content {
		padding: var(--space-lg) var(--space-lg);
	}
}



@media screen and (max-width: 840px) {
	.teaser-image-text__grid {
		grid-template-columns: 1fr;
	}
	
	.teaser-image-text__image {
		order: 0!important;
	}
	
	.teaser-image-text__content {
		text-align: center;
		padding: var(--space-lg) 0 0 0;
	}
	
	.teaser-image-text__content * {
		max-width: 32rem;
	}
	
	.teaser-image-text__content .wp-block-buttons {
		justify-content: center;
	}

}

/* @end */



/* @group LOGO GALLERY */

/* Logo Gallery
--------------------------------------------------------------------------------- */


.logo-gallery {
}

.logo-gallery__grid {
    container-type: inline-size;
	--gap: clamp(20px, 3vw, 40px);
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: calc(var(--gap)*2) 0;
	row-gap: 20px;
	margin-inline: calc(var(--gap) * -1);
}


.logo-gallery__image {
  flex: 0 0 calc(100%/3 - var(--gap)*2);
  margin-inline: var(--gap);
}

.logo-gallery__grid.columns-1 > div { flex-basis: calc(100%/1 - var(--gap)*2); }
.logo-gallery__grid.columns-2 > div { flex-basis: calc(100%/2 - var(--gap)*2); }
.logo-gallery__grid.columns-3 > div { flex-basis: calc(100%/3 - var(--gap)*2); }
.logo-gallery__grid.columns-4 > div { flex-basis: calc(100%/4 - var(--gap)*2); }
.logo-gallery__grid.columns-5 > div { flex-basis: calc(100%/5 - var(--gap)*2); }

.logo-gallery__image {
	position: relative;
	aspect-ratio: 4/3;
	border: 0px solid #333;

}

.logo-gallery__image a {
	display: block;
	width: 100%;
	height: 100%;
}

.logo-gallery__image img {
	height: 100%;
	width: 100%;
	object-fit: contain;
}

/*option: outline*/

.logo-gallery__image.style-outline {
		padding: 15px;
		border: 1px solid rgba(0,0,0, .08);
}

/*option: shadow*/

.logo-gallery__image.style-shadow {
		padding: 15px;
		background: #FFF;
		box-shadow: 0px 3px 25px -5px rgba(0,0,0, .15);
}

	
@media (max-width: 600px) {
	.logo-gallery__grid {
		--gap: 15px;
	}
	
	.logo-gallery__grid.columns-mob-1 > div { flex-basis: calc(100%/1 - var(--gap)*2); }
	.logo-gallery__grid.columns-mob-2 > div { flex-basis: calc(100%/2 - var(--gap)*2); }
	.logo-gallery__grid.columns-mob-3 > div { flex-basis: calc(100%/3 - var(--gap)*2); }
	.logo-gallery__grid.columns-mob-4 > div { flex-basis: calc(100%/4 - var(--gap)*2); }
	.logo-gallery__grid.columns-mob-5 > div { flex-basis: calc(100%/5 - var(--gap)*2); }
		
		
	.logo-gallery__image {
		max-width: 240px;
	}

}


/* @end */



/* @group EVENTS (EM) */

/* Events
--------------------------------------------------------------------------------- */


.events {
	
}

#em-wrapper > *:first-child {
	margin-top: 0;
}

.em-search-section-location,
.em-search-section-categories header { /*hide certain form elements */
	display: none; 
}


.em-submit-section { /* hide buttons, bc we trigger on change via js*/
	display: none;
}

.em-search {
}

.em-search-category {
	width: 20rem;
	max-width: 100%;
}

.events-listing {
	max-width: var(--semiwide-width)!important;
	margin-inline: auto;
}

.em-view-container {
}

.em-events-list__group-title {
	margin-block: var(--space-lg);
}

.em-group {

}

.em-item  {
}

.em-item__link {
	display: block;
	display: grid;
	gap: 30px clamp(30px, 4vw, 60px);	
	text-decoration: none;
}

.em-item__link:hover {
	color: var(--text-color);
}

.em-item.has-image .em-item__link {
	grid-template-columns: min(430px, 33%) auto;
}


.em-item + .em-item  {
	margin-top: 60px;
}

.em-item-image {
	border-radius: var(--radius);
	aspect-ratio: 4/3;
	overflow: hidden;
}

.em-item-image.has-placeholder {
	background: rgba(0,0,0, .05);
}

.em-item-image img {
	width: 100%;
	aspect-ratio: 4/3;
	object-fit: cover;
	border-radius: var(--radius);
	transition: all 600ms ease;
}


a:hover .em-item-image img {
	transform: scale(1.1);
}

.em-item-info {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 25px;
}

.em-item-date-cards {
	flex: 1 0 auto;
	position: relative;
	background: var(--text-color);
	margin-bottom: auto;
	overflow: hidden;
	border-radius: var(--radius);
}

.em-item-date-cards::before { /*contrast*/
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	background: var(--secondary-color);
}

.em-item-date-card {
	position: relative;
	color: #FFF;
	display: flex;
	flex-direction: column;
	gap: 5px;
	padding: 12px;
	text-align: center;
	justify-content: center;
	line-height: 1;
	text-transform: uppercase;
	font-weight: var(--bold);
}

.em-item-date-card__day {
	font-size: 1.35em;
}

.em-item-date-card__month {
	font-size: var(--base-font-size);

}

.em-item-date-card__date-divider {
	position: relative;
	text-align: center;
	color: #FFF;
	line-height: 0;
	margin-top: -3px;
	padding-bottom: 5px;	
}

.em-item-content {
	
}

.em-item-cancelled {
	color: red;
	color: var(--red);
	text-transform: uppercase;
	font-size: var(--text-small);
}

.em-item-categories {
	color: var(--text-color);
	font-size: var(--text-small);
	text-transform: uppercase;
	font-weight: var(--bold);
	margin-bottom: 0;
	display: none; /*turn on only to test cat filter*/
}

.em-item-title {
	margin: 0 0 2px 0;
	color: var(--text-color);
	transition: color 200ms ease;
}


a:hover .em-item-title  {
	color: var(--primary-color);
}

.em-item-location {
	margin: 2px 0 0 0;	
}

.em-item-location-name {
	
}

.em-item-button {
	margin-top: 20px;
}




@media screen and (max-width: 840px) {
	
	.em-item-title {
		font-size: clamp(1.3rem, 5vw, 1.5rem);
	}
}

@media screen and (max-width: 600px) {
	.em-item.has-image .em-item__link  {
		grid-template-columns: 1fr;
	}

}


/* EM pagination */

.em-pagination {
	margin-top: var(--space-xl);
	display: flex;
	flex-wrap: wrap;
	gap: 5px;
	justify-content: center;
}

.em-pagination.em-ajax {
	
}


.em-pagination a,
.em-pagination span {
	display: flex;
	flex: 0 1 auto;
	gap: 5px;
	justify-content: center;
	align-items: center;
	text-align: center;
	font-size: var(--base-font-size);
	font-weight: var(--bold);
	text-decoration: none;
	padding: 10px;
	border-bottom: 1px solid #FFF;
}

.em-pagination span.page-numbers {
	padding: 10px;
}

.em-pagination a.page-numbers:hover,
.em-pagination span.page-numbers.current {
	border-color: var(--text-color);
}

.em-pagination span:not(.page-numbers) {
	padding: 0;
}

.em-pagination a:hover {
	color: var(--text-color);
}

.em-pagination a.prev,
.em-pagination a.next {
	--size: 3.0rem; 
	font-size: 1.4em;
	flex: 0 0 auto;
	padding: 0;
	width: var(--size);
	height: var(--size);
	border-radius: 100%;
	overflow: hidden;
	text-indent: 10rem;
	border: 1px solid var(--text-color);
}


.em-pagination span {
	padding: 0;
}

.em-pagination a.prev {
	margin-right: 10px;
}

.em-pagination a.next {
	margin-left: 10px;
}

.em-pagination a.prev:before,
.em-pagination a.next:after {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	font-family: 'icons';
	font-weight: normal;
	font-size: 1.1em;
	text-indent: 0;
	color: var(--text-color);
	background: #FFF;
}

.em-pagination a.prev:before {
	content: "\e939";
}

.em-pagination a.prev.first:before {
	content: "\e938";
}

.em-pagination a.next:after {
	content: "\e934";
}

em-pagination a.next.last:after {
	content: "\e933";
}



/* @end */





/* @group UPCOMING EVENTS (EM) */

/* Upcoming Events
--------------------------------------------------------------------------------- */


.uc-events {
}

.uc-events__list {
	display: grid;
	gap: 0px;
}

.uc-event:not(:first-child) {
	--gap: 20px;
	margin-top: var(--gap);
	padding-top: var(--gap);
	border-top: 2px solid rgba(0, 49, 102, .1);
}

.uc-event {
}

.uc-event__link {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 25px;
	text-decoration: none;
}

.uc-event__link:hover {
	color: var(--text-color);
}

.uc-event-date-cards {
	flex: 1 0 auto;
	position: relative;
	background: var(--text-color);
	margin-bottom: auto;
	overflow: hidden;
	border-radius: var(--radius);
}

.uc-event-date-cards::before { /*contrast*/
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	background: var(--secondary-color);
}

.uc-event-date-card {
	position: relative;
	color: #FFF;
	display: flex;
	flex-direction: column;
	gap: 5px;
	padding: 12px;
	text-align: center;
	justify-content: center;
	line-height: 1;
	text-transform: uppercase;
	font-weight: var(--bold);
}

.uc-event-date-card__day {
	font-size: 1.35em;
}

.uc-event-date-card__month {
	font-size: var(--base-font-size);

}

.uc-event-date-card__date-divider {
	position: relative;
	text-align: center;
	color: #FFF;
	line-height: 0;
	margin-top: -3px;
	padding-bottom: 5px;	
}


.uc-event-content {
}

.uc-event-cancelled {
	color: red;
	color: var(--red);
	text-transform: uppercase;
	font-size: var(--text-small);
}

.uc-event-title {
	margin: 0;
	font-size: var(--base-font-size);
	line-height: var(--base-line-height);
	line-height: 1.4;
	transition: 250ms ease;
}

a:hover .uc-event-title {
	color: var(--primary-dark-color);
}

.uc-event-location {
	font-size: var(--text-small);
}

.uc-event-time {
	font-size: var(--text-small);
}

/* @end */




/* @group TEACHERS */

/* Teachers
--------------------------------------------------------------------------------- */


.teachers {
	margin-top: var(--space-lg);
}


.teachers-search {
	margin: var(--space-lg) auto;
	display: flex;
	flex-direction: column;
}

.teachers-search__form {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto;
	width: 100%;
	max-width: 400px;
}

.teachers-search__form::after { /*search icon*/ 
	content: "\e928";
	position: absolute;
	top: 0;
	right: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 50px;
	height: 100%;
	font-size: 1.3em;
	font-family: 'icons';
	pointer-events: none;
	background: transparent;
}

.teachers-search__form:focus-within::after {
	display: none;
}


.teachers-search__form .reset-btn {
	position: absolute;
	right: 2px;
	top: 2px;
	width: 50px;
	border: none;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.2em;
	line-height: 1;
	height: calc(100% - 4px);
	z-index: 1;
	border-radius: var(--radius);
	color: var(--text-gray);
	background: #FFF;
}

.teachers-search #resultsCount {
	margin-inline: auto;
	padding: 5px 20px;
	border-radius: 10rem;
	font-size: var(--text-small);
	background: var(--gray-bg);
}

.teachers-search input {
	font-size: var(--base-font-size);
	padding: 15px;
	padding-right: 50px;
	width: 100%;
	min-height: auto; /*BE*/
	line-height: 1; /*BE*/
	background: #FFF;
	border-radius: var(--radius);
	border: 1px solid var(--border-color);
}

.teachers-search input::placeholder {
}

.is-root-container .teachers-search input {
	pointer-events: none; /*disable for BE*/
}


.teachers-search input:focus {
	border-color: var(--text-color);
}

.teachers__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0,1fr));
	gap: clamp(30px, 3vw, 40px);
}


.teachers.alignwide .teachers__grid {
	grid-template-columns: repeat(3, minmax(0,1fr));
}

.teacher-card {
	position: relative;
	display: grid;
	grid-template-columns: min(160px, 30%) auto;
	gap: clamp(20px, 5vw, 30px);
	align-items: center;
	transition: all 300ms ease;
	border: 0px solid #DDD;
	overflow: hidden;
}

.teacher-card.no-match {
	display: none;
}

.teacher-card__image {
	margin: 0;
	width: 100%;
	height: auto;
	aspect-ratio: 1;
	overflow: hidden;
	align-self: flex-start;
	border-radius: 100%;
}

.teacher-card__image a {
	display: block;
}

.teacher-card__image img {	
	width: 100%;
	height: 100%;
	object-fit: cover;
	AUS_object-position: 50% 8%; /*center face*/
	transition: all 600ms ease;
}

.teacher-card.no-image .teacher-card__image {
	background: rgba(16, 159, 218, .1) url(assets/images/person-placeholder.svg) no-repeat center;
	background-size: 75%;
}


.teacher-card__content {
		--block-gap: 0;
}

.teacher-card__title {
	font-size: var(--base-font-size);
	line-height: 1.4;
}

.teacher-card__title a {
	position: inherit;
	display: inline-block;
	text-decoration: none;
	color: var(--link-color);
	color: var(--primary-dark-color);
}


.teacher-card__title a::after { /*link area*/
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}


.teacher-card__title a:hover {
	color: var(--link-color-hover);
}

.teacher-card__subtitle {
	font-size: var(--text-small);
}

.teacher-card__button {
	line-height: 1;
}


@media screen and (max-width: 1136px) {
	.teachers.alignwide .teachers__grid {
		grid-template-columns: repeat(2, minmax(0,1fr));
	}
	.teacher-card {
	grid-template-columns: min(120px, 30%) auto;
}

}

@media screen and (max-width: 600px) {
	.teachers__grid,
	.teachers.alignwide .teachers__grid {
		grid-template-columns: 1fr;
	}

}





/* @end */




/* @group TEACHERS TEASER */

/* Teachers Teaser
--------------------------------------------------------------------------------- */


.teachers-teaser {
}

.teachers-teaser__images {
	display: flex;
	justify-content: center;
	gap: 0;
	max-width: calc(100vw - var(--page-padding)*2); /*FF, Chrome*/
}

.teachers-teaser__image {
	margin: 0;
	
}

.teachers-teaser__image:not(:first-child) {
	margin-left: -20px;
}

.teachers-teaser__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	AUS_object-position: 50% 8%; /*center face*/
	max-width: 140px;
	min-width: 110px;
	aspect-ratio: 1;
	border-radius: 100%;
	border: 4px solid #FFF;
}

/* @end */




/* @group SUBJECTS */

/* Subjects
--------------------------------------------------------------------------------- */


.subjects {
  margin-block: var(--space-xl);
  container-type: inline-size;
}

.subjects__grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0,1fr));
	gap: clamp(20px, 4vw, 35px);
}


.subject-card {
	height: 100%;
	min-height: 250px;
	text-align: center;
	overflow: hidden;
	border-radius: var(--radius);
}

.subject-card a {
	display: block;
	width: 100%;
	height: 100%;
	padding: var(--box-padding-lg) var(--box-padding);
	color: var(--primary-dark-color);
	background: var(--primary-bg);
	text-decoration: none;
	outline-offset: -2px;
	transition: 300ms ease;
}


.subject-card a:hover {
	background: var(--secondary-color);
	background: var(--blue-200);
}

.subject-card__image {
	aspect-ratio: 1;
	margin: 0 auto;
	max-width: 135px; /*limitsize*/
}

.subject-card__image svg {
	width: 100%;
	height: auto;
	object-fit: contain;
	transition: 300ms ease;

}

.subject-card a:hover svg {
	transform: scale(1.1);
}

.subject-card svg path {
	fill: var(--primary-dark-color);
}

.subject-card a:hover svg path {
	fill:  var(--secondary-color);
}



.subject-card__title {
	margin: 20px 0 20px 0;
	font-size: var(--base-font-size);
	line-height: 1.3;
	/*
	-webkit-hyphens: auto;
     hyphens: auto;
	 */
}


@container (max-width: 1136px) {
	.subjects__grid {
		grid-template-columns: repeat(3, minmax(0,1fr));
	}
}


@container (max-width: 840px) {
	.subjects__grid {
		grid-template-columns: repeat(2, minmax(0,1fr));
	}
	
	.subject-card {
		min-height: auto;
	}


}





/* @end */



/* @group LOCATIONS MAP*/

/* Locations Map
--------------------------------------------------------------------------------- */

.locations-map {
	width: 100%;
	height: clamp(500px, 70vw, 600px);
}

.locations-map.alignwide {
	width: 100%;
	height: clamp(500px, 50vw, 700px);
}

.locations-map .acf-map {
}

/* Fixes potential theme css conflict. */
.locations-map .acf-map img {
    max-width: inherit !important;
}

.locations-map .markers {
   
}

.acf-map {
    width: 100%;
	height: 100%;
    margin: 0;
	border-radius: var(--radius);
	overflow: hidden;
	background: #f2f2f2;
	AUS_background: #d2f7e0; /*maps green*/
	border: 0px solid rgba(0,0,0, .02);
}

/* Fixes potential theme css conflict. */
.acf-map img {
    max-width: inherit !important;
}

.is-root-container .acf-map::after { /*for editor*/
	content: "Google Maps - Vorschau im Editor nicht verfügbar.";
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}


.gm-style-iw-chr {
	display: none;
}

.gm-style .gm-style-iw-c { /*google infowindow*/
	padding: 0;
	font-family: var(--font-sans);
	font-size: var(--text-small);
	border-radius: var(--radius);
	 max-height: 350px!important;
	box-shadow: 0px 8px 20px 0px rgba(0,0,0, .2);
}

.gm-style .gm-style-iw-d {
	 overflow: hidden!important;
	 max-height: 350px!important;
}


.gm-style .gm-ui-hover-effect {
	opacity: 0; /*hide close button*/
}

.acf-map .gm-style-iw-tc { /*bottom tip*/
	filter: none;
	-webkit-filter: none;
	top: -3px;
}


.map-infowindow {
	position: relative;
	max-width: clamp(190px, 10vw, 220px);
}

.map-infowindow:after { /*fake close button*/
	content: "\e916";
	position: absolute;
	top: 5px;
	right: 5px;
	text-align: center;
	font-size: 24px;
	color: rgba(0,0,0, .5);
	font-family: 'icons';
	pointer-events: none;
	
	display: none;
}

.map-infowindow__image {
	padding: 0px;
	margin-bottom: -2px;
}

.map-infowindow__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	aspect-ratio: 3/2;
}

.map-infowindow__content {
	font-weight: var(--base-font-weight);
	font-size: var(--text-tiny);
	line-height: var(--base-line-height);
	padding: clamp(10px, 1.8vw, 15px);
}

.map-infowindow__title {
	font-weight: var(--bold);
}

.map-infowindow__button {
	margin-top: 10px;
}

.map-infowindow__button .wp-block-button__link {
	width: 100%;
	font-size: var(--text-tiny);
	padding: 10px;
}


@media screen and (max-width: 600px) {
	.locations-map,
	.locations-map.alignwide {
		height: auto;
		aspect-ratio: 1/1.2;
	}
	
	.map-infowindow__image img {
		aspect-ratio: 3/1.8;
	}
	
	
}


/* @end */



/* @group LOCATIONS LIST*/

/* Locations List
--------------------------------------------------------------------------------- */

.locations-list {
	
}

.wp-block-acf-locations-list .accordion-content {
	display: none; /*WP preview: collapse item*/
}


/* @end */




/* @group RELATED PAGES */

/* Related Pages
--------------------------------------------------------------------------------- */


.related-pages {
	margin-top: var(--space-xl);
}

.related-pages hr {
	display: none;
	margin-block: var(--space-lg);
}

.related-pages h3 {
}

.related-pages a {
	font-weight: var(--bold);
	text-decoration: none;
}

/* @end */

/* @group iMIKEL */

/* iMikel
--------------------------------------------------------------------------------- */


.imikel {
}

/* Note: CSS can not applied to JS loaded iMikel form! */



/* @end */

/* @end */




/* @group BLOG */

/* BLOG
--------------------------------------------------------------------------------- */


.blog-entry-grid {
	margin-top: var(--space-xxxl);
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	grid-template-columns: repeat(3, minmax(0,1fr));
	gap: 30px;
}


.blog-entry {
	position: relative;
	border-radius: var(--radius);

}

.blog-entry a {
	display: block;
	height: 100%;
	text-decoration: none;
}

.blog-entry__image {
	margin: 0;
	overflow: hidden;
	border-radius: var(--radius);
}

.blog-entry__image img {
	display: block;
	aspect-ratio: 4/3;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	margin: 0 auto;
	transition: all 600ms ease!important;
}

.blog-entry__image:hover img {
	transform: scale(1.1);
}

.blog-entry__content {
	padding: 20px;
	padding-inline: var(--box-padding-sm);
	padding-bottom: var(--space-md);
}


.blog-entry__title {
	margin: 0;
	padding: 0;
	font-size: var(--base-font-size);
	line-height: 1.4;
	transition: 200ms ease;
}

.blog-entry__title a {
	position: inherit;
	display: block;
	color: var(--text-color);
	text-decoration: none;
}

a:hover .blog-entry__title   {
	color: var(--primary-color);
}

.blog-entry__date {
	font-size: var(--text-small);
	color: var(--text-gray);
}

.blog-entry__more-btn {
	margin: 1rem 0 0 0;
}

@media screen and (max-width: 1024px) {
	.blog-entry-grid {
		grid-template-columns: 1fr 1fr;
	}
	
	.blog-entry__content {
		padding-inline: 0;
	}
	
}

@media screen and (max-width: 600px) {
	.blog-entry-grid {
		grid-template-columns: 1fr;
	}
	
	.blog-entry__content {
		padding-bottom: 10px;
		padding-inline: var(--box-padding-sm);
	}

	
}

/* single post */

.blog-post-header {
	border: 1px solid RED;
}

h1.blog-post__title {
	margin: 0;
	text-align: left;
}

.blog-post__date {
	margin-top: 10px;
	color: var(--text-gray);
	font-size: var(--text-small);
}

.blog-post__date + * {
	margin-top: var(--space-xl);
}

.blog-post__image {
	position: relative;
	width: 100%;
	aspect-ratio: 4/3;
	border-radius: var(--radius);
	overflow: hidden;
}

.blog-post__image + * {
	margin-top: var(--space-lg);
}

.blog-post__image img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}

.blog-post__image p.wp-caption-text {
	margin: 0.6rem 0 0 0;
	font-size: 0.8rem;
}


.blog-post__cats {
	border-top: 1px solid var(--border-color);
	margin-top: var(--space-lg);
	padding-top: var(--space-md);
	color: var(--link-color);
	display: none; /*AUS*/
}


.blog-post__cats a {
	font-weight: var(--bold);
}

.blog-post__cats a:hover {
}



.blog-post__tags {
	text-transform: uppercase;
	font-size: var(--text-small);
	display: none; /*AUS*/
}

.blog-post__tags a {
	color: var(--text-gray);
	font-weight: var(--bold);
	margin-right: 5px;
}

.blog-post__tags a:hover {
	color: var(--primary-color);
}

.blog-post__tags span {
	display: none;
}

.back-to-blog {
	margin-top: var(--space-xl);
	font-weight: var(--bold);
	text-align: center;
	font-size: 1.2rem;
}

.back-to-blog a {
}

.back-to-blog a:hover {
}





/* Archive */


.show-tax {
	display: flex;
	flex-wrap: wrap;
	position: relative;
	padding: var(--box-padding);
	margin-bottom: calc(var(--space-xxl) * -1);
	background: var(--primary-bg);
	border-radius: var(--radius);
}

.show-tax__tax {
	flex: 1;
	color: var(--text-gray);
}

.show-tax__title {
	color: var(--text-color);
	font-weight: var(--bold);
}

.show-tax__all {
	margin: 0 0 0 auto;
	line-height: 1;
	font-size: 1.5rem;
}



/* post-pagination */

.post-pagination {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 15px;
	margin-top: var(--space-xl);
	text-transform: uppercase;
}

.post-pagination .page-numbers.dots {
	max-width: 2ch;
	border: none;
	margin-inline: -5px;
	font-weight: normal;
}

.post-pagination .page-numbers {
	border-bottom: 1px solid #FFF;
}

.post-pagination .page-numbers.current {
	color: var(--text-color);
	border-color: var(--text-color);
}

.post-pagination > span,
.post-pagination > a {
	display: flex;
	flex: 0 1 auto;
	justify-content: center;
	align-items: center;
	text-align: center;
	font-size: var(--base-font-size);
	font-weight: var(--bold);
	text-decoration: none;
	padding: 3px 10px;
}

.post-pagination a:hover {
	color: var(--text-color);
	border-color: var(--text-color);
}

.post-pagination a.prev,
.post-pagination a.next {
	--size: 3.0rem; 
	font-size: 1.4em;
	flex: 0 0 auto;
	padding: 0;
	width: var(--size);
	height: var(--size);
	border-radius: 10rem;
	border-radius: 10rem;
	border: 1px solid var(--text-color);
}

.post-pagination a.prev:hover,
.post-pagination a.next:hover {
} 

.post-pagination a.prev {
}

.post-pagination a.next {
}


a.prev span,
a.next span {
	display: none;
}

body:not(.paged) .post-pagination a.next,
body:not(.paged) .post-pagination a.next {
}

.post-pagination a.prev:before,
.post-pagination a.next:after {
	font-family: 'icons';
	font-weight: normal;
	font-size: 1.1em;
}

.post-pagination a.prev:before {
	content: "\e939";
}

.post-pagination a.next:after {
	content: "\e934";
}

@media screen and (max-width: 600px) {
	.post-pagination > span,
	.post-pagination > a {
			padding: 0;
			display: none;
		}
		
		.post-pagination a.prev,
		.post-pagination a.next {
			display: flex;
		}
		
}



/* Post Navigation */

.post-nav-section {
	display: none; /*AUS*/
}

.post-nav {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px;
	justify-content: space-between;
}


.post-nav.first-post {
	grid-template-columns: 1fr;
	justify-content: flex-end;
}

.post-nav .prev-post,
.post-nav .next-post {
	display: flex;
}

.post-nav .next-post {
	justify-content: flex-end;
}

.post-nav a {
	position: relative;
	display: flex;
	gap: 10px;
	font-weight: var(--bold);
	max-width: 25rem;
}

.post-nav .prev-post a {

}

.post-nav .next-post a {
	justify-content: flex-end;
	text-align: right;
}


.post-nav .prev-post a::before,
.post-nav .next-post a::after {
	content: "\e907";
	font-family: 'icons';
	font-weight: normal;
	font-size: 1.25em;
	margin-top: -.1em;
	
}

.post-nav .prev-post a::before {
	content: "\e901";
	left: 0;
}

.post-nav .next-post a::after {
	right: 0;
}


.post-nav span {
	display: block;
	font-size: 0.75rem;
	margin: 0 0 0.5rem 0;
	display: none;
}

.post-nav a br {
	display: none;
}

.post-nav a:hover {
}



.post-nav.first-post .next-post a,
.post-nav.last-post .prev-post a {

}



/* Post Taxonomies  */

.post-tax-section {
	position: relative;
	padding: 0 0 var(--main-padding-bottom) 0;
	border-top: 0px solid var(--border-color);
}


.post-tax-section .container {
}

.post-tax {
}

.post-tax__title {
	margin-top: 0;
}


.post-tax__list {
	margin-top: var(--space-md);
}

.post-tax__list li a {
	display: block;
	padding: 2px 0;
	text-decoration: none;
}

.post-tax__list li a:hover {
}



/* @end */



/* @group SEARCH PAGE*/

/* Search Page
--------------------------------------------------------------------------------- */



.search-result {
	margin-bottom: var(--space-xl);
}

.search-result__title {

}

.search-result__title span {
	font-weight: var(--bold);
}

.search-result.no-result .searchform {

}

.searchform-wrap {
	position: relative;
	max-width: 100%;
	margin-top: var(--space-md);
}

.search-result .searchform {
	position: relative;
	border: 1px solid var(--border-color);
	border-radius: 5px;
	overflow: hidden;
	background: #FFF;
	width: 100%;
	max-width: 30rem;
	box-shadow: 0px 5px 35px -10px rgba(0,0,0, .15);
}

.search-result .searchform input[type="text"] {
	border: none;
	padding: 20px;
	width: 100%;
	height: 3.3rem;
	font-size: 1.1rem;
	line-height: 1;
	color: var(--text-color);
	border:  none;
	border-radius: 0;
	box-shadow: none /*remove red border */;
}

.search-result .searchform input::placeholder {
}

.search-result .searchform .searchsubmit {
	position: absolute;
	top: 0;
	right: 0;
	border: none;
	padding: 0 20px;
	text-transform: uppercase;
	overflow: hidden;
	width: 3rem;
	font-size: 1.4rem;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	background: transparent;
}

.search-result .searchform i {
	position: relative;
	text-align: center;
	background: transparent;
	color: var(--text-color);
}


.search-result__list {
	margin-top: var(--space-md);
}



.search .hentry {
	border: 0;
	border-bottom: 1px solid var(--border-color);
	margin: 0;
}

.search-result__entry a {
	display: block;
	text-decoration: none;
	padding: 10px 0;
}

.search-result__post-type {
	color: var(--text-gray);
	text-transform: uppercase;
	font-size: var(--text-small);
	font-weight: var(--bold);
	letter-spacing: .03em;
	margin-left: 1ch;
}

.search-result__entry .type-page .entry-details {
	display: none;
}

.search .post-pagination {
	margin-top: 30px;
}


.search-results .entry-details span {
	display: none;
}

/* @end */



/* @group EVENTS  */

/* Events 
--------------------------------------------------------------------------------- */


/* single post */

.em-header {
	position: relative;
	margin: 0 0 var(--space-xl) 0;
	padding: var(--space-xxl);
	background: var(--primary-bg);
}

.em-header::after {
	content: "";
	position: absolute;
	top: 0; 
	right: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	transform: translate(10%,0%);
	background: transparent url(assets/images/keyvisual-blue.svg) no-repeat right top;
	background-size: 100%;
	opacity: .25;
	border: 0px solid #333;
}

.em-header__grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 50px 30px;
}

.blog-post.event:not(.has-post-thumbnail) .em-header__content {
	grid-column: 1/-1;
}

.em-header__content {
	display: flex;
	flex-direction: column;
}

.em-header__archive-title {
	margin: 0 0 10px 0;
}

.em-header__cats {
	margin-top: var(--space-sm);
	color: var(--text-color);
	font-size: var(--text-small);
	text-transform: uppercase;
	font-weight: var(--bold);
	margin-bottom: -10px;
}


h1.em-header__title {
	margin: var(--space-sm) 0 0 0;
	max-width: 33rem;
	text-align: left;
	AUS_font-size: clamp(30px, 28.1818px + 0.5682vw, 38px);
}


.em-header__image {
	position: relative;
	width: 100%;
	margin: 0;
	aspect-ratio: 4/3;
	border-radius: var(--radius);
	overflow: hidden;
}

.em-header__image img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}

.em-header__image p.wp-caption-text {
	margin: 0.6rem 0 0 0;
	font-size: 0.8rem;
}


@media screen and (max-width: 1024px) {	
	.em-header::after {
		top: 0;
		transform-origin: top;
		transform: rotate(0deg) scale(1.5);
	}

.em-header__grid {
		grid-template-columns: 1fr;
	}
	
	h1.em-header__title {
		max-width: none;
	}
	
	.em-header__image {
		order: -1;
	}
}


.em-meta {
	margin-top: var(--space-lg);
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.em-meta__item {
	--icon-size: 2.5rem;
	position: relative;
	padding-left: var(--icon-size);
}


.em-meta__item::before {
	content: "\e916";
	position: absolute;
	left: 0;
	font-family: 'icons';
	font-size: 1.5em;
	line-height: 1;
	font-weight: normal;
	margin-top: rem;
	margin-left: -.2rem;
	width: var(--icon-size);
}


.em-meta__item--date::before {
	content: "\e916";
}

.em-meta__item--time::before {
	content: "\e914";
}

.em-meta__item--location::before {
	content: "\e91c";
}

.em-meta__item--cancelled {
	padding: 0;
	color: red;
	color: var(--red);
	text-transform: uppercase;
}

.em-meta__item--cancelled::before {
	display: none;
}

.em-meta__item span {
	display: block;
}

.em-backtooverview {
	margin-top: var(--space-xl);
}


/* EM Location single */


.em-location-single {
	display: block;
}

.em-location-single > *:first-child {
	margin-top: 0;
}

.em-location-single > * {
	margin-top: var(--block-gap);	
}

.em-location-single .em-location-next-events ul a {
	display: block;
	font-weight: var(--bold);
}

/* @end */



/* @group SUBJECT (CPT) */

/* Subject
--------------------------------------------------------------------------------- */


.location-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	padding: 0;
	list-style: none;
}

.location-tags li {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0;
	padding: 5px 20px 7px 20px;
	border-radius: 100px;
	background: var(--primary-bg);
	background: var(--gray-bg);
}

.location-tags li::before {
	content: "\e91c";
	font-family: 'icons';
	font-size: 1.2em;
	margin-left: -.2em;
	font-weight: normal;
}





.teacher-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0,1fr));
	gap: 20px;
}

.teacher-list-item {
	position: relative;
	display: grid;
	grid-template-columns: min(160px, 30%) auto;
	gap: clamp(20px, 5vw, 30px);
	align-items: center;
	transition: all 300ms ease;
	border: 0px solid #DDD;
	overflow: hidden;
}

.teacher-list-item.no-match {
	display: none;
}

.teacher-list-item__image {
	margin: 0;
	aspect-ratio: 1;
	overflow: hidden;
	align-self: flex-start;
	border-radius: 100%;
}

.teacher-list-item__image a {
	display: block;
	height: 100%;
}

.teacher-list-item__image img {	
	width: 100%;
	height: 100%;
	object-fit: cover;
	AUS_object-position: 50% 8%; /*center face*/
	transition: all 600ms ease;
}

.teacher-list-item__image a:hover img {
}


.teacher-list-item.no-image .teacher-list-item__image {
	background: var(--primary-bg) url(assets/images/person-placeholder.svg) no-repeat center;
	background-size: 75%;
}


.teacher-list-item__content {
		--block-gap: 0;
}

.teacher-list-item__title {
	font-size: var(--base-font-size);
	line-height: var(--base-line-height);
}

.teacher-list-item__title a {
	position: inherit;
	text-decoration: none;
	color: var(--primary-dark-color);
}

.teacher-list-item__title a::after { /*link area*/
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

.teacher-list-item__title a:hover {
	color: var(--link-color-hover);
}

.teacher-list-item__subtitle {
	font-size: var(--text-small);
}


@media screen and (max-width: 600px) {	
	.teacher-list {
		grid-template-columns: 1fr;
	}

}





/* @end */




/* @group TEACHER (CPT) */

/* Teacher
--------------------------------------------------------------------------------- */



.teacher-header {
	text-align: center;
}

.teacher-header h1 {
	margin-bottom: 0;
}

.teacher-header__subtitle {
	margin-top: 5px;
}

.teacher-content {
	margin-top: var(--space-xxl);
	display: grid;
	grid-template-columns: 1fr;
	justify-content: center;
	gap: clamp(30px, 6vw, 120px);
	border: 0px solid #333;
	
}

.teacher-content.no-image {
	grid-template-columns: 1fr!important;
	justify-content: center;
	max-width: var(--default-width);
}


.teacher-content.has-text {
	grid-template-columns: min(430px, 33%) auto;
	justify-content: flex-start;
}

.teacher-content__text > * {
	max-width: 50rem;
}

.teacher-content__image {
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
}

.teacher-content__image img {
	width: 100%;
	border-radius: var(--radius);
}

.teacher-subjects {
	margin-top: var(--space-xl);
}

.back-to-teacher {
	margin-top: var(--space-xl);
}


@media screen and (max-width: 600px) {	
	.teacher-content.has-text {
		grid-template-columns: 1fr;
	}

}




/* Subjects Slider */


.subjects-slider {
	margin-top: var(--space-lg);
	padding-bottom: 40px; /*pagination height*/
	max-width: calc(100vw - var(--page-padding)*2); /*FF, Chrome*/
	border: 0px solid RED;
}

 .subjects-slider .swiper {
	overflow: visible; /**/
 }

.subjects-slider .swiper-wrapper {
	height: auto!important;
}


.subjects-slider .swiper-slide {
	height: auto;
	flex-shrink: 1;
	align-self: stretch;
	width: auto;
}

.subjects-slider-card {
	height: 100%;
	width: 200px;
	width: calc(220/16 * 1rem);
	min-height: 250px;
	text-align: center;
	border-radius: var(--radius);
	background: var(--primary-bg);
}

.subject-slider-card:focus-within {
	outline: 2px solid blue;
	outline-offset: 2px
}

.subjects-slider-card a {
	display: block;
	width: 100%;
	height: 100%;
	padding: var(--space-md);
	color: var(--primary-dark-color);
	text-decoration: none;
	transition: 300ms ease;
}

.subjects-slider-card a:hover {
	background: var(--blue-200);
}


.subjects-slider-card__image {
	aspect-ratio: 1;
	margin: 0;
	padding: 10px; /*reduce size*/
	transition: 300ms ease;
}



.subjects-slider-card__image svg {
	width: 100%;
	height: auto;
	object-fit: contain;
	transition: 300ms ease;
}

.subjects-slider-card a:hover svg {
	transform: scale(1.05);
}

.subjects-slider-card svg path {
	fill: var(--primary-dark-color);
}


.subjects-slider-card a:hover svg path {
	fill: var(--secondary-color);
}



.subjects-slider-card__title {
	margin: 10px 0 20px 0;
	font-size: var(--base-font-size);
	line-height: 1.3;
	transition: all 300ms ease;
	/*
	-webkit-hyphens: auto;
     hyphens: auto;
	 */
}


.subjects-slider .swiper .swiper-pagination-bullets {
	bottom: -50px;
}



/* @end */




/* @group PW protected */

/* PW Protected
--------------------------------------------------------------------------------- */


.post-password-form {
	text-align: center;
	padding: var(--box-padding);
	background: var(--primary-bg);
	border-radius: var(--radius);
}

.post-password-form p { /*WP info text*/
	display: none;
}

.post-password-form p + p {
	display: block;
	margin: 0;
}

.post-password-form label {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 20px
}

.post-password-form input {
	flex: 1 0 auto;
	font-size: 1rem;
	padding: 10px;
	max-width: 10rem;
	border: 1px solid var(--border-color);
}

.post-password-form input[type="submit"] {
	display: none;
}

/* @end */



/* @group FLUENT FORMS  */

/* Fluent Forms
--------------------------------------------------------------------------------- */


.fluentform {
  --fluentform-primary: var(--primary-color);
  --fluentform-secondary :var(--blue);
  --fluentform-danger: red;
  --fluentform-border-color: var(--border-color);
  --fluentform-border-radius: 5px;
  --fluentform-input-select-height: auto;
  
  --border-color: rgba(0,0,0, .3);
  accent-color: var(--primary-color);
  
  padding: var(--box-padding-lg);
  border-radius: var(--radius);
  background: var(--primary-bg);
}

.fluentform form {
	margin: 0 auto;
	max-width: var(--default-width);
}

.is-root-container .fluentform form {
	pointer-events: none; /*editor only*/
}

.fluentform .ff_screen_reader_title {
	height: 0px;
}


/* FF HTML */

.fluentform .ff-custom_html > *:first-child,
.fluentform .ff-custom_html .form-field > *:first-child {
	margin-top: 0;	
}

.fluentform .ff-custom_html h2 {
}


 .fluentform .frm-fluent-form .ff-t-container {
 	gap: 30px;
 }
 
 /* FF section break */

.fluentform .ff-el-section-break {
	margin-top: var(--block-gap);
	border-top: 1px solid var(--border-color);
}

.fluentform *:not(.ff-el-group) + .ff-el-group.ff-el-section-break {
}

.fluentform .ff-el-section-break hr {
	display: none;
}

.fluentform *.ff-el-section-title {
}

 
 /* FF fields */
  
 .fluentform .ff-el-group {
   margin-bottom: 15px; /*20*/
}


.fluentform .ff-el-input--label label {
  font-weight: var(--bold);
  font-size: var(--text-small);
 }

.fluentform .ff-el-input--label.ff-el-is-required.asterisk-right label:after {
  color: var(--text-color);
  content: "*";
  margin-left: 3px
}

.fluentform .ff-el-help-message {
	color: var(--text-color);
	font-size: var(--text-tiny);
	font-style: normal;
} 


.fluentform .ff-el-form-control {
  font-family: var(--font-sans);
  font-size: var(--base-font-size);
  line-height:1;
  margin-bottom:0;
  max-width: 100%;  
  padding: 0.8em;
  line-height: 1.3;
  color: var(--text-color);
  background-color: #FFF;
  width: 100%;
  box-sizing: border-box;
  font-weight: normal;
  border: none;
  border: 1px solid var(--border-color);
  transition: all 300ms ease;
}


.fluentform .ff-el-form-control:focus {
  color: var(--text-color);
  outline: 2px solid var(--text-color);
}

.fluentform .ff-el-form-control:focus-visible {
} 


/*FF checkbox & radio */


.fluentform .ff-el-form-check label.ff-el-form-check-label {
  display: grid;
  grid-template-columns: 30px auto;
  gap: 8px;
}

.fluentform .ff-el-tc label.ff_tc_label > span {
  display: contents;
}


.fluentform :is(input[type="checkbox"], input[type="radio"]) {
	--size: 26px;
    appearance: none;
    position: relative;
    width: var(--size);
    height:  var(--size);
	margin-top: 2px;
    border: 1px solid var(--border-color);
	border-radius: var(--field-radius);
    line-height: 1;
    background: #FFF;
}

/* FF checkbox */
  
 .fluentform input[type="checkbox"]::before {
	content: "";
	position: absolute;
	left: 8px;
	top: 3px;
	width: 9px;
	height: 14px;
	margin: 0;
	border: solid #FFF;
	border-width: 0 3px 3px 0;
	transform: rotate(45deg);
	opacity: 0;
}

.fluentform input[type="checkbox"]:checked {
	background: var(--primary-color);
	border-color: var(--primary-color);
}

.fluentform input[type="checkbox"]:checked::before {
    opacity: 1;
 }


/* FF radio */


 .fluentform input[type="radio"] {
 	border-radius: 100%; 	
 }
 
 
  .fluentform input[type="radio"]::before {
  	--size: 18px;
	content: "";
	position: absolute;
	left: 3px;
	top: 3px;
	width: var(--size);
	height: var(--size);
	margin: 0;
	background: var(--primary-color);
	border-radius: 100%;
	opacity: 0;
}
 
 
 .fluentform input[type="radio"]:checked {
	border-color: var(--primary-color);
}

.fluentform input[type="radio"]:checked::before {
    opacity: 1;
 }
 
 
/* FF select */

/* https://codepen.io/chriscoyier/pen/zYYZaGP */
.fluentform select.ff-el-form-control {
	display: block;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	transition: all 200ms ease;
	background-color: #FFF;
	/* https://websemantics.uk/tools/svg-to-background-image-conversion */
	background-image: url("data:image/svg+xml;charset=utf8,%3Csvg width='14' height='9' viewBox='0 0 14 9' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='718 26 725 35 732 26' transform='translate(-718 -26)' fill='%231C4E60' fill-rule='evenodd'/%3E%3C/svg%3E");
	background-repeat: no-repeat, repeat;
	background-position: right .8em top 50%, 0 0;
	background-size: 0.7em auto, 100%;
}
.fluentform select::-ms-expand {
	display: none;
}

.fluentform .select-css:focus {
	/* It'd be nice to use -webkit-focus-ring-color here but it doesn't work on box-shadow */
	box-shadow: 0 0 0 3px -moz-mac-focusring;
	outline: none;
}

.fluentform select option {
	font-weight: normal;
	font-size: 1rem;
}

select:disabled, select[aria-disabled=true] {
	opacity: .5;
}

 
 /* FF Upload  */

.fluentform .ff_file_upload_holder .ff_upload_btn.ff-btn {
	color: var(--text-color);
	font-size: var(--text-small);
	background: #FFF;
	border: 1px dashed var(--text-color);
	transition: 200ms ease;
}

.fluentform .ff_file_upload_holder .ff_upload_btn.ff-btn:hover {
}

.fluentform .ff-upload-preview {
	background: #FFF;
}

.fluentform .ff-upload-details {
	font-size: var(--text-small);
}

.fluentform .ff-uploaded-list:empty {
	margin-top: 0!important;
}

 
/* FF submit */


.fluentform .ff_submit_btn_wrapper {
	margin-top: var(--space-sm);
	margin-bottom: 0;
}


.fluentform.ff-default .ff-btn.ff-btn-submit  {
	text-transform: none;
	padding: .9em 2em;
	font-weight: var(--bold);
	font-size: calc((16/16) * 1rem);
	line-height: 1.4;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	color: var(--text-color);
	letter-spacing: 0.02em;
	text-decoration: none;
	color: #FFF;
	background: var(--primary-dark-color);
	border: 1px solid var(--primary-dark-color);
	border-radius: 10rem;
	
	
}

.fluentform .ff-btn.ff-btn-submit:hover {
  background: var(--text-color);
  border-color: var(--text-color);
  color: #FFF;
  text-decoration: none;
  opacity: 1;
}

.fluentform .ff_t_c {
  font-size: var(--text-small)!important;	
}

.fluentform .has-small-font-size {
  font-size: var(--text-small)!important;
}

/* FF success */


.fluentform .ff-message-success {
	padding: 0;
	text-align: center;
	margin: 0;
	border: none;
	box-shadow: none;
}

.fluentform .ff-message-success > *:first-child {
	margin-top: 0;
}




/* @end */





/* @group SLIDER (swiperjs) */

/* SLIDER
--------------------------------------------------------------------------------- */


.swiper {
	--swiper-theme-color: var(--primary-color);
	
	--swiper-navigation-size: 50px;
	--swiper-navigation-color: var(--primary-dark-color);
	
	--swiper-pagination-bullet-horizontal-gap: 5px;
    --swiper-pagination-bullet-vertical-gap: 5px;
    --swiper-pagination-bullet-size: 10px;
	--swiper-pagination-bullet-width: inherit;
	--swiper-pagination-bullet-height: inherit;
	--swiper-pagination-bullet-border-radius: 100px;
    --swiper-pagination-color: var(--primary-dark-color);
	--swiper-pagination-bullet-inactive-color: rgba(0,0,0, .3);
	--swiper-pagination-bullet-inactive-opacity: .7;
	
	--swiper-pagination-height: 25px;

	height: 100%;
}


.swiper-wrapper {

}

.swiper-slide {
}

.swiper-button {
	--size: 50px;
	width: var(--size);
	height: var(--size);
	margin: 0;
	transform: translateY(-50%);
	transition: all 250ms ease-in-out;
	border-radius: 10rem;	
	background: rgba(255,255,255,.9);
	border: 1px solid var(--primary-dark-color);
	opacity: 0; /* ON/OFF*/
}

.swiper:hover .swiper-button,
.swiper:focus-within .swiper-button {
	opacity: 1;
}

.swiper-button:hover {
}

.swiper-button::after {
	font-family: 'icons';
	font-size: 32px;
}

.swiper-button-prev {
	left: 10px;
	right: auto;
}

.swiper-button-prev::after {
	content: "\e939";
}

.swiper-button-next {
	right: 10px;
	left: auto;
}

.swiper-button-next::after {
	content: "\e934";
}

.swiper-button.swiper-button-disabled {
	opacity: 0!important;
}

.swiper > .swiper-pagination-bullets {
	AUS_bottom: 0;
	AUS_display: flex;
	justify-content: center;
	align-items: flex-start;
	height: var(--swiper-pagination-height);
}

.swiper-pagination-bullet {
}

.swiper-pagination-bullet-active {
	outline: 2px solid #FFF;
}

.swiper:has(.image-slider__caption) .swiper-pagination-bullet {
	--swiper-pagination-bullet-inactive-color: #FFF;
	--swiper-pagination-bullet-inactive-opacity: 1;
}



.swiper-pagination-bullet-active,
.swiper-pagination-bullet-active-main {
}

.swiper-pagination-bullet:only-child {
   visibility: hidden;
}

.swiper:has(.swiper-pagination-bullet:only-child) { /*no pagination if only 1 slide*/
	--swiper-pagination-height: 0;
}

@media screen and (max-width: 600px) {

	.swiper {
    --swiper-pagination-bullet-size: 8px;
	--swiper-pagination-height: 20px;
	}
	
	.swiper-button {
		display: none;
	}
	
}





/* @end */



/* @group LIGHTBOX */

/* Lightbox PhotoSwipe Plugin
--------------------------------------------------------------------------------- */

.pswp {
	--pswp-bg: rgba(0,0,0, 1);
}


.pswp__caption {
	
}

.pswp__caption__text {
	font-size: var(--text-small);
	line-height: 1.4;
}

.pswp__button.pswp__button--zoom {
	display: none;
}

/* @end */




/* @group FOOTER */

/* FOOTER
--------------------------------------------------------------------------------- */


#footer {
	--page-padding: 80px;
	overflow: hidden;
}

.site-footer {
	position: relative;
	width: 100%;
	padding: var(--space-xxl) 0;
	background: var(--text-color);
	font-size: calc(16/16 * 1rem);
}


.site-footer > .container {
	margin: 0 auto;
}


:where(.site-footer),
:where(.site-footer) a {
	color: #FFF;
	text-decoration: none;
}

:where(.site-footer) a:hover {
	color: var(--primary-color);
}


.footer-keyvisual {
	position: absolute;
	top: 0;
	right: -150px;
	width: 1500px;
	max-width: 130vw;
	height: 120%;
	background: transparent url(assets/images/footer-keyvisual.svg) no-repeat left bottom;
	background-size: 1500px;	
	border: 0px solid CYAN;
	opacity: .12;
}


.footer-columns {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
}

.footer-column {
	line-height: 2;
	flex: 1 0 20%;
	max-width: 18rem;
}

.footer-column :is(ul,li) {
	margin: 0;
	padding: 0;
	list-style: none;
}

.footer-column a {
	display: block;
}

.footer-column a:hover {
}


.footer-social {
	display: flex;
	gap: 36px;
	margin-top: var(--space-lg);
	margin-left: -2px;
	font-size: 2.3rem;
}

.footer-social a {
	display: flex;
	aspect-ratio: 1;
	height: 100%;
	overflow: hidden;
	line-height: 1;
	color: #FFF;
}

.footer-social a:hover {
	color: var(--primary-color);
}

.footer-menu {
	margin-top: var(--space-lg);
}

.footer-menu ul {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 30px;
}

.footer-menu a {
	display: block;
	color: rgba(255,255,255, .4);
}

.footer-menu a:hover {
	color: var(--primary-color);
}

@media screen and (max-width: 810px) { /*810 iPad*/
	.footer-column {
		flex: 100%;
		max-width: 100%;
	}

	.footer-keyvisual {
		top: auto;
		right: 0;
		bottom: -20px;
		width: 100%;
		height: 80%;
		margin: 0;
		max-width: auto;
		background-position: center bottom;
		background-size: clamp(800px, 140vw, 1000px);	
	}


}

@media screen and (max-width: 600px) {
	#footer {
		--page-padding: 40px;
	}
	.footer-menu ul {
		flex-direction: column;
	}
		
	
}



/* @end */


/* @group SCROLL TO TOP BUTTON */

/* Scroll to top button
--------------------------------------------------------------------------------- */

.scrolltopbtn {
	position: fixed;
	bottom: 20px;
	right: var(--page-padding);
	height: 46px;
	width: 46px;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 28px;
	text-align: center;
	border-radius: 100%;
	transition: 300ms;
	transform: translateY(100%);
	opacity: 0;
	z-index: 5;
    color: #FFF;
	border: none;
	padding: 0;
	background: rgba(0,0,0, .15);
	background: var(--secondary-color);
}

.scrolltopbtn i {
	margin-bottom: 1px;
	transition: 250ms ease;
}

.scrolltopbtn.active:hover i {
}


.scrolltopbtn.active {
	transform: translateY(0);
	opacity: 1;
}

/* @end */



/* @group BORLABS COOKIE */

/* Borlabs Cookie Banner
--------------------------------------------------------------------------------- */


#BorlabsCookieBox,
.brlbs-cmpnt-container {
	--dialog-text-color: var(--text-color);
	
	--dialog-border-radius-bottom-left: var(--radius);
    --dialog-border-radius-bottom-right: var(--radius);
    --dialog-border-radius-top-left: var(--radius);
    --dialog-border-radius-top-right: var(--radius);
	
    --dialog-button-border-radius-bottom-left: 10rem;
    --dialog-button-border-radius-bottom-right: 10rem;
    --dialog-button-border-radius-top-left: 10rem;
    --dialog-button-border-radius-top-right: 10rem;
	
    --dialog-card-border-radius-bottom-left: 4px;
    --dialog-card-border-radius-bottom-right: 4px;
    --dialog-card-border-radius-top-left: 4px;
    --dialog-card-border-radius-top-right: 4px;
	
	--dialog-backdrop-background-color: #000;
	--dialog-backdrop-background-opacity: .7;
	
	
	--content-blocker-text-color: var(--text-color);
    
	--content-blocker-border-radius-top-left: var(--radius);
    --content-blocker-border-radius-top-right: var(--radius);
    --content-blocker-border-radius-bottom-left: var(--radius);
    --content-blocker-border-radius-bottom-right: var(--radius);
}


#BorlabsCookieBox .brlbs-cmpnt-container :is(.brlbs-text-2xl) {
}

.brlbs-cmpnt-container.brlbs-cmpnt-content-blocker .brlbs-cmpnt-cb-buttons .brlbs-cmpnt-cb-btn {
	border-radius: 10rem;
}



/* @end */


/* @group ACCESSIBILITY */

/* ACCESSIBILITY */


.sr-only {
	position: absolute;
	width: .0625rem;
	height: .0625rem;
	padding: 0;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

.sr-only-focusable {
	transition: all 0s ease;
}

.sr-only-focusable:focus {
	position: static;
	width: auto;
	height: auto;
	margin: 0;
	overflow: visible;
	clip: auto;
}

.skip-link:focus {
	position: absolute;
	top: 0;
	left: 0;
	width: auto;
	height: auto;
	padding: 5px;
	margin: 0;
	overflow: visible;
	clip: auto;
	z-index: 100;
	color: #FFF;
	text-decoration: none;
	background: var(--text-color);
	line-height: 1;
}




/* @end */


/* @group ANIMATIONS */

/* ANIMATIONS
---------------------------------------------------------------------------------*/


/* scroll reveal */

.reveal {
  opacity: 0;
  transform: translate3d(0, 100px, 0);
  transition: opacity 700ms, transform 600ms;
}

.reveal-notransform,
.reveal-notransform.reveal-visible {
	opacity: 1;
	transform: none;
	transition: none;
}

.reveal--slow {
  transition: opacity 1000ms, transform 1000ms;
}

:where(.is-root-container) .reveal,
.reveal-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
    /*prevent old safari flicker*/
  -webkit-transform: translateZ(0);
  -webkit-backface-visibility: hidden;
}



/*  https://github.com/daneden/animate.css */


.animated {
	animation-duration: 1s;
	animation-fill-mode: both;
	animation-timing-function: ease-in-out;
}

.animated.infinite {
	animation-iteration-count: infinite;
}

@keyframes fadeIn {
  0% {opacity: 0;}
  100% {opacity: 1;}
}

.fadeIn {
  animation-name: fadeIn;
}


@keyframes fadeInDown {
  0% {
    opacity: 0;
   transform: translate3d(0, -100%, 0);
  }

  100% {
    opacity: 1;
    transform: none;
  }
}

.fadeInDown {
	animation-name: fadeInDown;
}


@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translate3d(0, 100%, 0);
  }

  100% {
    opacity: 1;
    transform: none;
  }
}

.fadeInUp {
  animation-name: fadeInUp;
}

/* @end */


/* @group UTILITES */

/* UTILITES
---------------------------------------------------------------------------------*/

.mt-0  { 	margin-top: 0!important; }
.mt-5  { 	margin-top: 5px!important; }
.mt-10 {	margin-top: 10px!important; }
.mt-20  {	margin-top: 20px!important; }
.mt-30  {	margin-top: 30px!important; }
.mt-40  {	margin-top: 40px!important; }
.mt-50  {	margin-top: 50px!important; }
.mt-60  {	margin-top: 60px!important; }
.mt-70  {	margin-top: 70px!important; }
.mt-80  {	margin-top: 80px!important; }
.mt-90  {	margin-top: 90px!important; }
.mt-100  {	margin-top: 100px!important; }
.mt-110  {	margin-top: 110px!important; }
.mt-120  {	margin-top: 120px!important; }
.mt-130  {	margin-top: 130px!important; }
.mt-140  {	margin-top: 140px!important; }
.mt-150  {	margin-top: 150px!important; }


.mb-0  { 	margin-bottom: 0!important; }
.mb-5  { 	margin-bottom: 5px!important; }
.mb-10 {	margin-bottom: 10px!important; }
.mb-20  {	margin-bottom: 20px!important; }
.mb-30  {	margin-bottom: 30px!important; }
.mb-40  {	margin-bottom: 40px!important; }
.mb-50  {	margin-bottom: 50px!important; }
.mb-60  {	margin-bottom: 60px!important; }
.mb-70  {	margin-bottom: 70px!important; }
.mb-80  {	margin-bottom: 80px!important; }
.mb-90  {	margin-bottom: 90px!important; }
.mb-100  {	margin-bottom: 100px!important; }
.mb-110  {	margin-bottom: 110px!important; }
.mb-120  {	margin-bottom: 120px!important; }
.mb-130  {	margin-bottom: 130px!important; }
.mb-140  {	margin-bottom: 140px!important; }
.mb-150  {	margin-bottom: 150px!important; }


.ratio-1 	{ aspect-ratio: 1;}
.ratio-3-2	{ aspect-ratio: 3/2;}
.ratio-2-3	{ aspect-ratio: 2/3;}
.ratio-3-4	{ aspect-ratio: 3/4;}
.ratio-4-3 	{ aspect-ratio: 4/3;}
.ratio-16-9 { aspect-ratio: 16/9;}



.min-w-100 { min-width: 100px; }
.min-w-200 { min-width: 200px; }
.min-w-300 { min-width: 300px; }
.min-w-400 { min-width: 300px; }
.min-w-500 { min-width: 500px; }
.min-w-600 { min-width: 600px; }
.min-w-700 { min-width: 700px; }
.min-w-800 { min-width: 800px; }
.min-w-900 { min-width: 900px; }



.whitespace-nowrap {
	white-space: nowrap;
}


/* @end */


/* ------------------------------------------------------------------------------

MEDIA QUERIES

---------------------------------------------------------------------------------*/


@media screen and (max-width: 1136px) {
body:after {
	content: "<1136";
	position: fixed;
	top: 0;
	line-height: 1;
	padding: 5px;
	font-size: 11px;
	background: lawngreen;
	z-index: 1000;
	opacity: .8;

	display: none; /* AN/AUS*/
}

}


@media screen and (max-width: 1024px) {
body:after {
	content: "<1024";
	background: TAN;
}


}


@media screen and (max-width: 840px) {
body:after {
	content: "<840";
	background: PINK;
}

}


@media screen and (max-width: 600px) {
body:after {
	content: "<600";
	background: YELLOW;
}

}


@media screen and (max-width: 360px) {
body:after {
	content: "<360";
	background: MAGENTA;
}


}




/* END
---------------------------------------------------------------------------------*/
