/*
 Theme Name:   Bricks Child Theme
 Theme URI:    https://bricksbuilder.io/
 Description:  Use this child theme to extend Bricks.
 Author:       Bricks
 Author URI:   https://bricksbuilder.io/
 Template:     bricks
 Version:      1.1
 Text Domain:  bricks
*/



/*
 * BUTTON
 */
/* Primary */
.primary-button {
   position: relative;
	width: fit-content;
}

.primary-button::after {
   content: "";
   position: absolute;
   left: 0;
   bottom: 0;
   width: 0%;
   height: 2px;
   margin-bottom: -2px;
   background: var(--secondary);
   transition: width 0.3s ease-in-out;
}

.primary-button:hover::after {
   width: 100%;
}


/*
 * QUOTE BLOCK
 */
.quote-block::before {
   content: "";
   position: absolute;
   left: 0;
   bottom: 0;
   width: 1rem;
   height: 100%;
   background: var(--secondary);	
}


/*
 * FOOTER
 */
.footer-menu li a,
.footer-link a {
   position: relative;
	width: fit-content;
}

.footer-menu li a::after {
   content: "";
   position: absolute;
   left: 0;
   bottom: 0;
   width: 0%;
   height: 1px;
   margin-bottom: -5px;
   background: #e6e6e6;
   transition: width 0.3s ease-in-out;
}

.footer-link a::after {
   content: "";
   position: absolute;
   left: 0;
   bottom: 0;
   width: 0%;
   height: 1px;
   margin-bottom: -2px;
   background: #e6e6e6;
   transition: width 0.3s ease-in-out;
}

.footer-menu li:hover a::after,
.footer-link a:hover::after {
   width: 100%;
}


/*
 * HEADER
 */
/* Desktop Menu */
.main-menu-desktop li a,
.main-menu-desktop li.current-menu-item .brx-submenu-toggle a {
   position: relative;
	width: fit-content;
}

.main-menu-desktop li > a::after,
.main-menu-desktop li.current-menu-item > .brx-submenu-toggle > a::after {
   content: "";
   position: absolute;
   left: 0;
   bottom: 0;
   width: 0%;
   height: 1px;
   margin-bottom: -1px;
   background: var(--secondary);
   transition: width 0.3s ease-in-out;
}

.main-menu-desktop li:hover > a::after,
.main-menu-desktop li.current-menu-item:hover > .brx-submenu-toggle > a::after {
   width: 100%;
}

.main-menu-desktop li.current-menu-item > a::after,
.main-menu-desktop li.current-menu-item > .brx-submenu-toggle > a::after {
	width: 100%;
	background: var(--primary);
}

.main-menu-desktop li:hover > a {
	color: var(--secondary) !important;
}

.main-menu-desktop .sub-menu > li > a {
	line-height: 1.2;
	width: fit-content;
	text-align: left;
	padding: 0 !important;
}

.main-menu-desktop .sub-menu > li {
    padding-top: 1.5rem;
    padding-right: 2rem;
    padding-bottom: 1.5rem;
    padding-left: 2rem;
}


:where(.brxe-nav-menu) .bricks-nav-menu .sub-menu {
	-webkit-box-shadow: 0px 8px 27px -18px #000000; 
	box-shadow: 0px 4px 30px -20px #00000050;
	top: calc(100% + 1rem);
}

/* Offcanvas */


/*
 * VERANSTALTUNGEN
 */
.wj_veranstaltungsliste {
	display: flex;
    flex-direction: column;
    gap: 3rem;
    position: relative;
}

.wj_veranstaltungsliste .veranstaltungs-monat {
	color: var(--secondary);
	position: relative;
	padding-left: 3rem;
	margin-top: 3rem;
	letter-spacing: 1px;
}	

.wj_veranstaltungsliste .veranstaltungs-monat::before {
   content: "";
   position: absolute;
   left: 0;
   top: 0;
   width: 1rem;
   height: 100%;
   background: var(--secondary);	
}

.wj_veranstaltungsliste .veranstaltung-eintrag {
	display: flex;
    flex-direction: column;
    gap: 0rem;
}

.wj_veranstaltungsliste .veranstaltung-eintrag .veranstaltung-datum {
	color: var(--text);
	letter-spacing: 0.5px;
}

.wj_veranstaltungsliste .veranstaltung-eintrag .veranstaltung-name {
	color: var(--primary);
	font-size: var(--text-l);
	letter-spacing: 1px;
	font-weight: 500;
}




/*
 * REGION / TOURISMUS SHORTCODE STYLING
 */
.sit-tourism--object {
	display: flex;
	flex-direction: row;
	gap: 4rem;
	background-color: #f2f2f294;
    padding: 4rem;
	margin-top: 2rem;
}

.sit-tourism--object .sit-tourism--logo,
.sit-tourism--object .sit-tourism--image-instead-of-logo {
	max-width: 21rem;	
}

.sit-tourism--object-list {
    display: flex;
    flex-direction: column;
    gap: 4rem;	
}

.sit-tourism--object .sit-tourism--infos h2 {
    background-color: var(--secondary);
    color: var(--white);
    padding: 1rem;
    width: fit-content;	
}

.sit-tourism--object .sit-tourism--infos {
	display: flex;
    flex-direction: column;
    gap: 2rem;	
}

.sit-tourism--object .sit-tourism--infos * {
	margin: 0;
}

.sit-tourism--object .sit-tourism--infos > a {
	color: var(--secondary);
    letter-spacing: 1px;
    text-transform: uppercase;
    font-weight: 500;
	position: relative;
	width: fit-content;
}

.sit-tourism--object .sit-tourism--infos a::after {
   content: "";
   position: absolute;
   left: 0;
   bottom: 0;
   width: 0%;
   height: 2px;
   margin-bottom: -3px;
   background: var(--secondary);
   transition: width 0.3s ease-in-out;
}

.sit-tourism--object .sit-tourism--infos a:hover::after {
   width: 100%;
}

.sit-tourism--object .sit-tourism--infos .categories {
	margin-top: -1rem;
    font-size: calc(var(--text-l) * 0.9);
    color: var(--primary);
    font-weight: 500;
    letter-spacing: 0.5px;
}

.sit-tourism--pagination {
	margin-top: 2rem;
	margin-bottom: 2rem;
	display: flex;
    gap: 1rem;
	align-items: center;
    justify-content: flex-end;
}

.sit-tourism--pagination span {
	color: var(--secondary);
	font-weight: 500;
}

.sit-tourism--pagination span.active {
	color: var(--text);
}

.sit-tourism--footer {
	font-size: var(--text-xs);
	text-align: center;
	margin-top: 2rem;
}

.sit-tourism--footer a {
	color: var(--secondary);
	font-weight: 500;
}

.sit-tourism--result-count {
	color: var(--text);
    letter-spacing: 0.5px;
    font-size: calc(var(--text-m) * 0.9);
}

.sit-tourism--search-form {
	display: flex;
    flex-direction: row;
    align-content: center;
    justify-content: flex-start;
	position: relative;
	gap: 2rem;
	flex-wrap: wrap;
	margin-bottom: 1rem;
}

.sit-tourism--search-form input[type=submit] {
	margin-left: auto;
	
	background-color: hsla(0, 0%, 100%, 0);
    color: var(--secondary);
    padding-top: 0.2rem;
    padding-right: 0.6rem;
    padding-bottom: 0.2rem;
    padding-left: 0.6rem;
	
	position: relative;
    width: fit-content;
	
	align-items: center;
    border-width: 0;
    display: inline-flex;
    gap: 10px;
    justify-content: center;
    letter-spacing: .5px;
    text-align: center;
}

.sit-tourism--search-form input[type=submit]::after {
   content: "";
   position: absolute;
   left: 0;
   bottom: 0;
   width: 0%;
   height: 2px;
   margin-bottom: -2px;
   background: var(--secondary);
   transition: width 0.3s ease-in-out;
}

.sit-tourism--search-form input[type=submit]:hover::after {
   width: 100%;
}

.sit-tourism--search-form .sit-tourism--main-category label,
.sit-tourism--search-form .sit-tourism--search-text label,
.sit-tourism--search-form .sit-tourism--community label {
	background-color: var(--primary);
    color: var(--white);
    width: fit-content;
    padding: 0.4rem 1rem;
}

.sit-tourism--search-form .sit-tourism--main-category,
.sit-tourism--search-form .sit-tourism--search-text,
.sit-tourism--search-form .sit-tourism--community {
	min-width: 36rem;
}

@media only screen and (max-width: 1024px) {
	.sit-tourism--search-form .sit-tourism--main-category,
	.sit-tourism--search-form .sit-tourism--search-text,
	.sit-tourism--search-form .sit-tourism--community {
		max-width: 24rem;
	}
}

@media only screen and (max-width: 820px) {
	.sit-tourism--search-form,
	.sit-tourism--search-form .sit-tourism--main-category,
	.sit-tourism--search-form .sit-tourism--search-text,
	.sit-tourism--search-form .sit-tourism--community {
		width: 100%;
		max-width: 100%;
		gap: 0.5rem;
        display: flex;
        flex-direction: column;
	}
	
	.sit-tourism--object {
		flex-direction: column;
		gap: 3rem;
	}
}

.sit-tourism--period-selector {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 4rem;
    margin-bottom: 2rem;	
}

.sit-tourism--period-selector p {
    margin: 0;
}

.sit-tourism--period-selector .sit-tourism--current-period {
    font-size: var(--text-xl);	
}

.sit-tourism--result-count > span a {
	color: var(--secondary);
	text-decoration: underline;
}

.sit-tourism--result-count > span a:hover {
	color: var(--primary);
}

.sit-tourism--period-selector .sit-tourism--previous-period,
.sit-tourism--period-selector .sit-tourism--next-period {
	color: var(--secondary);
	font-weight: 500;
	letter-spacing: 0.5px;
}

.sit-tourism-communities-list {
	margin-top: -1rem !important;
}

.sit-tourism--date {
    font-size: var(--text-l);
    font-weight: 500;	
}

#sit-tourism--container .sit-tourism-backlink {
	color: var(--secondary);
	text-decoration: underline;
}


#sit-tourism--container .sit-tourism-backlink:hover {
	color: var(--primary);
}

.sit-tourism--detail h1 {
    text-align: center;
    max-width: 80rem;
    background-color: var(--secondary);
    color: var(--white);
    padding: 2rem;	
	align-self: center;
	order: 2;
}

.sit-tourism--detail {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.sit-tourism--request-change {
	margin: 0;
	order: 98;
}

.sit-tourism--request-change a {
	color: var(--secondary);
	font-size: var(--text-s);
}

.sit-tourism--detail .sit-tourism--categories {
    text-align: center;
    color: var(--primary);
    font-weight: 500;
    letter-spacing: 1px;	
	order: 1;
	margin: 0;
}

.sit-tourism--detail p:last-child {
	order: 99;
}

.sit-tourism--detail .sit-tourism--dates {
    text-align: center;
    color: var(--primary);
    font-weight: 500;
    letter-spacing: 1px;	
	
	font-size: calc(var(--text-m)*1.6);
	
	margin-top: 2rem;
    margin-bottom: 2rem;
}

.sit-tourism--detail .sit-tourism--event-infos {
	order: 3;	
}

.sit-tourism--detail .sit-tourism--sub-title {
	order: 5;
    margin: 0;
    font-weight: 500;
    font-size: calc(var(--text-m) * 1.2);
    letter-spacing: 0.5px;
}

 .sit-tourism--detail .sit-tourism--logo {
	order: 4;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sit-tourism--detail > div {
	order: 7;
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.sit-tourism--detail .sit-tourism--communities {
    order: 6;
    margin: 0;
    background-color: var(--primary);
    color: var(--white);
    width: fit-content;
    padding: 0.2rem 1rem;
}

.sit-tourism--detail .sit-tourism--description {
	order: 8;
    margin: 0;
    background-color: #efefef57;
    padding: 2rem;
}

.sit-tourism--contact-data a {
    font-weight: 500;
    font-size: calc(var(--text-m) * 1.2);
    letter-spacing: 0.5px;	
	color: var(--secondary);
	position: relative;
	width: fit-content;
}

.sit-tourism--contact-data a::after {
   content: "";
   position: absolute;
   left: 0;
   bottom: 0;
   width: 0%;
   height: 2px;
   margin-bottom: -3px;
   background: var(--secondary);
   transition: width 0.3s ease-in-out;
}

.sit-tourism--contact-data a:hover::after {
   width: 100%;
}

.sit-tourism--address {
	margin: 0;
}

.sit-tourism--images {
    display: flex;
    flex-direction: row !important;
	flex-wrap: wrap;
    gap: 2rem;	
}

.sit-tourism--downloads a {
    font-weight: 500;
    font-size: calc(var(--text-m) * 1.2);
    letter-spacing: 0.5px;	
	color: var(--secondary);
	position: relative;
	width: fit-content;	
}

.sit-tourism--downloads a::after {
   content: "";
   position: absolute;
   left: 0;
   bottom: 0;
   width: 0%;
   height: 2px;
   margin-bottom: -3px;
   background: var(--secondary);
   transition: width 0.3s ease-in-out;
}

.sit-tourism--downloads a:hover::after {
   width: 100%;
}

/*
 * WARENKORB 
 */
#warenkorb form.cart .button, form.woocommerce-cart-form .button {
    padding: 1rem 2rem;
}

#warenkorb .product-name a {
	font-weight: 400;
    letter-spacing: 1px;
    font-size: var(--text-l);	
}

#warenkorb .product-subtotal {
	text-align: right;
	font-weight: 500;
	padding-right: 2rem;
}

#brxe-vatwdh .wc-proceed-to-checkout .button {
    padding: 1rem 2rem;
}

/*
 * KASSE 
 */
#kasse .woocommerce-billing-fields h3,
#kasse .woocommerce-additional-fields h3,
#kasse #order_review_heading {
	background-color: var(--secondary);
	color: var(--white);
	padding: 0.5rem 1rem;
	margin-bottom: 2rem;
}

.woocommerce-checkout .place-order .button {
    background-color: var(--primary);
	color: var(--white);
	padding: 0.5rem 1rem;
	margin-bottom: 2rem;
	letter-spacing 1px;
	font-size: var(--text-l);
	text-align: center;
}

.woocommerce-checkout .shop_table td, .woocommerce-checkout .shop_table th {
    text-align: left;
}

#kasse .order-total th,
#kasse .order-total td {
	color: var(--secondary);
	letter-spacing 1px;
	font-size: var(--text-l);
	font-weight: 500;
}


/* 
 * WOOCOMMERCE NOTICES STYLING 
*/

.product #product-hero {
	order: 1;
}

.product #product-main-information {
	order: 3;
}

.product #product-more-items {
	order: 4;
}

.product .woocommerce-notices-wrapper {
	order: 2;
	margin-top: 2rem;
    margin-bottom: 2rem;
}

.woocommerce-notices-wrapper .woocommerce-message {
    background-color: var(--secondary);
	color: var(--white);
}

.woocommerce-notices-wrapper .woocommerce-message a {
	background-color: var(--primary);
}

.woocommerce .woocommerce-notice.woocommerce-notice--success {
    color: var(--white);
    background-color: var(--primary);
    width: fit-content;
    align-self: center;
    padding: 0.5rem 1rem;
}

.woocommerce-order-details__title,
.woocommerce-column__title,
.woocommerce-Address-title.title h2 {
    background-color: var(--secondary);
    color: var(--white);
    width: fit-content;
    padding: 0.5rem 1rem;
    margin-bottom: 2rem;	
}

.woocommerce-orders-table.woocommerce-MyAccount-orders .button {
	background-color: var(--primary);
    color: var(--white);	
}

.woocommerce-orders-table.woocommerce-MyAccount-orders .button:hover {
	background-color: var(--secondary);
}

.woocommerce-MyAccount-content .woocommerce-info {
	background-color: var(--primary);
    color: var(--white);
} 

.woocommerce-MyAccount-content .woocommerce-info .button {
	background-color: var(--white);
    color: var(--secondary);
} 

.woocommerce-MyAccount-content .woocommerce-info .button:hover {
	color: var(--white);
    background-color: var(--secondary);
} 

/*
 * SUB MENU DESKTOP
 */
#menu-hauptmenue li .sub-menu li .sub-menu {
	top: 0;
}

#menu-hauptmenue li .brx-submenu-toggle a {
	padding: 0 !important;
	line-height: 1.4;
}

@media (max-width: 767px) {
    #brxe-cipcbj .bricks-nav-menu .sub-menu > li > a {
		line-height: 2 !important;
	}
	
	#brxe-cipcbj .bricks-nav-menu .sub-menu {
		margin-top: 1rem;
	}
}

/*
 * REGION GRID 
 */
.wj_region-box:hover img {
	transform: scale(1.05);
	transition: transform .4s ease;
}

.wj_region-box img {
	transition: transform .4s ease;
}

.wj_region-box {
	overflow: hidden;
}


/* Kasse */
form.woocommerce-checkout.bricks-default-checkout {
    display: flex;
    gap: 2rem;
	flex-direction: row;
	flex-wrap: wrap;
}

.woocommerce-NoticeGroup.woocommerce-NoticeGroup-checkout {
	width: 100%;
}

form.woocommerce-checkout > div {
	width: calc(50% - 2rem);
}

@media (max-width: 767px) {
	form.woocommerce-checkout > div {
		width: 100%;
	}
}