/*******************************
            FONTS
*******************************/

@font-face {
    font-family: "Gilroy";
    font-weight: 100;
    src: url('assets/webFonts/GilroyThin/font.woff2') format('woff2'), url('assets/webFonts/GilroyThin/font.woff') format('woff');
}

@font-face {
    font-family: "Gilroy";
    font-weight: 300;
    src: url('assets/webFonts/GilroyLight/font.woff2') format('woff2'), url('assets/webFonts/GilroyLight/font.woff') format('woff');
}

@font-face {
    font-family: "Gilroy";
    font-weight: 400;
    src: url('assets/webFonts/GilroyRegular/font.woff2') format('woff2'), url('assets/webFonts/GilroyRegular/font.woff') format('woff');
}

@font-face {
    font-family: "Gilroy";
    font-weight: 500;
    src: url('assets/webFonts/GilroyMedium/font.woff2') format('woff2'), url('assets/webFonts/GilroyMedium/font.woff') format('woff');
}

@font-face {
    font-family: "Gilroy";
    font-weight: 600;
    src: url('assets/webFonts/GilroySemiBold/font.woff2') format('woff2'), url('assets/webFonts/GilroySemiBold/font.woff') format('woff');
}

@font-face {
    font-family: "Gilroy";
    font-weight: 700;
    src: url('assets/webFonts/GilroyBold/font.woff2') format('woff2'), url('assets/webFonts/GilroyBold/font.woff') format('woff');
}

@font-face {
    font-family: "Gilroy";
    font-weight: 800;
    src: url('assets/webFonts/GilroyExtraBold/font.woff2') format('woff2'), url('assets/webFonts/GilroyExtraBold/font.woff') format('woff');
}

.um-field-error{
	background: #f2f0e9 !important;
	color: #dc3232 !important;
	margin: 6px 0 0 0 !important;
	padding: 0px !important;
}

.wpcf7-list-item{
	display: inline-flex !important;
}

.um-toggle-terms{
	position: relative !important;
	top: -4px !important;
}

.um-field-arrow{
	background: transparent !important;
	color: #f2f0e9 !important;
}

.um-field-checkbox:hover i{
	color: #f2f0e9 !important;
}

.mobilitat-table{
	border-spacing: 0;
	border-collapse: separate;
}

.footer-gewerbe-link::after {
    content: none !important;
}
.history-back .text::after {
    content: none !important;
}
.history-back:hover {
    cursor: pointer;
}

.offnung-margin-big{
	margin-top: 33px !important;
}

.um-field-label label{
	position: relative;
	
	&::after{
		content: '*';
		position: absolute;
		top: 0px;
		right: -5px;
	}
}

.um-field-label label[for=email]::after{
}

.aktionen-section iframe {
    aspect-ratio: 16/9;
    width: 100%;
    min-height: 2000px; /* Adjust as needed */
}
.navbar {
	transform: none !important;
}
.page-template-page-center .navbar.scrolled-down,
.page-template-page-center .navbar.background{
	transform: translateY(-100px) !important;
}

.navbar.scrolled-down {
	transform: translateY(-100px) !important;
}
.sticky-section {
	z-index: 1 !important;
}
.disabled-link {
    pointer-events: none; /* Prevents clicking */
    opacity: 0.6; /* Visually indicate it's disabled */
    cursor: not-allowed;
}

.big-margin-form{
	margin-top: 30px !important;
}

.border-none{
	border: none !important;
}

.gesh-row{
	display: grid;
    grid-template-columns: repeat(2, 1fr);
	grid-gap: 1px;
	overflow: hidden;
	border-top: 1px solid #ECECEC;
	border-bottom: 1px solid #ECECEC;
}
.news-and-events-section{
	overflow-y: hidden;
}

.select2-container .select2-choice, .select2-container-multi .select2-choices, .select2-drop, .select2-drop-active, .select2-drop.select2-drop-above, .um .um-form input[type="number"], .um .um-form input[type="password"], .um .um-form input[type="search"], .um .um-form input[type="tel"], .um .um-form input[type="text"], .um .um-form textarea, .um .upload-progress{
	border: none !important;
}


/************************* HIDE UM - ONLY FILL IF YOU ARE NOT HUMAN *******************/
.um_request_name {
	display: none !important;
}
.bg-black {
	background: #191919 !important;
}
/* .sticky-section.more-down {
	transform: translateY(93px);
} */
.sortable .sort-icon {
	cursor: pointer;
	margin-left: 5px;
	align-content
	width: auto;
	max-width: 7px;
	height: auto;
}
.um-field-type_terms_conditions{
	line-height: 1 !important;
}
.btn-secondary:hover, .btn.btn-secondary:active {
	border-color: var(--secondary-color);
	background: var(--secondary-color) !important;
}
.table-responsive {
	max-height: 800px;
	overflow: auto;
}
.dropdown-toggle span {
	transition: all 0.3s ease-in-out;
}
.dropdown-toggle span.light {
	color: rgba(0, 0, 0, 0.3);
}
.footer-logo-box-text{
	font-weight: 500;
	font-size: 16px;
	color: #FFFFFF66;
	line-height: 1.67;
}
.filter .dropdown-menu.show {
	top: -4px !important;
	left: 0 !important;
	right: unset !important;
	bottom: unset !important;
	transform: translate(0px, 56px) !important;
	border-top: 1px solid #ECECEC;
}
.sortable th {
	cursor: pointer; 
	 -webkit-user-select: none; /* Safari */
  -ms-user-select: none; /* IE 10 and IE 11 */
  user-select: none; /* Standard syntax */
	& sup {
		top: 0.5em;
		z-index; -1;
	}
}
td sup {
	z-index: -1;
}

.pb-standort{
	padding-bottom: 120px !important;
}

.pt-standort{
	padding-top: 120px !important;
}
.filter-buttons-wrap{
	& a:last-child{
		padding-left: 0px;
	}
}
@media only screen and (min-width: 576px){
	.swiper-mobile-col {
		position: static;
		left: 0;
		padding-left: 20px;
		padding-right: 0 !important;
	}	
}
@media only screen and (min-width: 992px) {
	.filter-buttons-wrap{
		gap: 17px !important;
	}

}
@media only screen and (min-width: 1200px){
}
/*******************************
            ROOT 
*******************************/
.container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
	padding-left: 20px; 
	padding-right: 20px;
}

html :where(.wp-block) {
    max-width: 100%;
    margin: 0 !important;
}
.navbar.background {
	background-color: #fff !important;
	border-bottom: 1px solid #fff;
	& .navbar-brand {
		& img {
			filter: invert(1);
		}
	}
	& .offcanvas-header {
		& .navbar-brand {
			& img {
				filter: invert(0);
			}
		}
			& .mobile-time-block {
			& .time-block img {
				filter: invert(0);
			}
		}
	}
	 & ul.navbar-nav {
		 & .dropdown-box {
			 color: #fff !important;
		 }
	}
	& .mobile-time-block {
		& .time-block img {
			filter: invert(1);
		}
	}
	& .navbar-toggler {
		& span {
			filter: invert(1);
		}
	}
}
.container-xxl.no-padding {
	padding-left: 0;
	padding-right: 0;
}
.padding-sm {
	padding-bottom: 20px !important;
}
.sticky-section {
	transition: all 0.3s;
}
.sticky-section.more-down {
	top: 0 !important
}
.swiper-mobile-col {
	position: relative;
	left: 10px;
	padding-left: 0;
}
@media only screen and (min-width: 576px){

}
.kontakt-section .um-field-type_terms_conditions .um-field-checkbox{
	margin-bottom: 3px !important;
}
@media only screen and (min-width: 768px){
	.kontakt-section .um-field-type_terms_conditions .um-field-checkbox{
		margin-bottom: 8px !important;
	}
	
		nav{
		& .offcanvas-header{
			padding-left: 50px !important;
			padding-right: 50px !important;
		}
			  & ul.navbar-nav {
				  & li{
					padding-left: 50px !important;
					padding-right: 50px !important;
				  }
			}
	}
	


	
	
	
	.gesh-row{
        grid-template-columns: repeat(3, 1fr); /* 3 columns for medium screens */
		border: 1px solid #ECECEC;
	}
/* 	.container-xxl.no-padding {
		padding-right: calc(var(--bs-gutter-x) * 2.5);
		padding-left: calc(var(--bs-gutter-x) * 2.5);
	} */
	.container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl, .container-xxl.no-padding {
		padding-left: 50px; 
		padding-right: 50px;
	}
	body.admin-bar .sticky-section,
	body.admin-bar .navbar {
		top: 32px;
	}
	.sticky-section.more-down {
		top: 0 !important
	}	
}
.pt-mobilitat {
	padding-top: 40px !important
}
@media only screen and (min-width: 992px){
	.scrolling-text-section.pt-mobilitat {
		padding-top: 59px !important
	}
	.mt-lg-50 {
		margin-top: 50px;
	}
	.droppy .dropdown-box {
		visibility: hidden;
		opacity: 1;
	}
	.pb-lg-7{
		padding-bottom: 60px !important;
	}
	.aktionen-section iframe {
		aspect-ratio: 16/9;
		width: 100%;
		min-height: unset; /* Adjust as needed */
	}
	.droppy:hover .dropdown-box {
		
			visibility: visible;
			opacity: 1;
		}

/* 	.sticky-section.more-down {
		top: 126px !important
	}	 */

	.padding-sm {
		padding-bottom: 133px !important;
	}
	.container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl, .container-xxl.no-padding {
		padding-right: calc(var(--bs-gutter-x) * 2.5);
		padding-left: calc(var(--bs-gutter-x) * 2.5);
	}

	.navbar.background {
		border-bottom: 1px solid #fff;
		& .time-block {
			color: #191919;
			& img {
				filter: invert(1);
			}
		}
		& ul.navbar-nav {
			& li {
				& a {
					color: #191919;
					&::after {
						background-color: #191919;
					}
				}
				& .dropdown-box {

					&::before {
						background: #fff;
						border-top: 1px solid #19191966;
					}
					&::after {
						background: #19191966;
					}
/* 					& a {
						color: #fff !important;
						&::after {
							background-color: #fff;
						}
					} */
				}
			}
		}
	}
}


:root {
    --font-primary: "Gilroy", sans-serif;
    --prymary-color: #A48153;
    --secondary-color : #191919;
    --third-color: #ECECEC;
    --forth-color: #DFDAC7;
    --gap: 2rem;
    --line-offset: calc(var(--gap) / 2);
    --line-thickness: 2px;
}
#mieten tr.flat-row:hover td {
	background: rgba(236, 236, 236, 1);
}
.btn:active{
	background: var(--forth-color) !important;
}

.btn-flip{
	position: relative;
	text-decoration: none;
	
	&:hover{
		
		& .front{
			opacity: 1;
			transform: translateY(-50%) rotateX(0);
			top: 50%;
		}
		
		& .back{
			opacity: 0;
            transform: translateY(-50%) rotateX(90deg);
		}
	}
	
	& .front {
        bottom: -4px;
		padding: 0 28px;
		left: 0;
		opacity: 0;
		width: 100%;
		display: block;
		transition: 0.2s;
		position: absolute;
		
        transform: translateY(50%) rotateX(90deg);
        gap: 10px;
        justify-content: center;
	}
	
	& .back{
		top: 0;
		left: 0;
		opacity: 1;
		display: block;
		transition: 0.2s;
		position: relative;

		transform: translateY(0) rotateX(0);
        gap: 10px;
	}
}

@keyframes maskedReveal-bottom-r0 {
	0% {
		transform:translateY(100%);
		mask-size: 100% 0%;
		-webkit-mask-size: 100% 0%;
	}
	100% {
		transform:translateY(0);
		mask-size: 100% 100%;
		-webkit-mask-size: 100% 100%;
	}
}

.mask-animation{
	mask-repeat: no-repeat;
	transform: translateY(100%);
	mask-position: center top;
	mask-size: 100% 0%;
	animation-timing-function: ease;
	animation-duration: 0.7s;
	animation-delay: 0s;
	animation-fill-mode: forwards;
	animation-name: maskedReveal-bottom-r0;
	mask-image: linear-gradient(black 0%, black 100%);
}

/*******************************
          ULTIMATE MEMBER
*******************************/
.um-1428.um {
	max-width: unset !important;
}
.um-field-label {
	margin-bottom: 0 !important;
}
.um-field .um-field-label label {
	font-size: 13px !important;
	line-height: 1 !important;
}
.um-col-alt {
	margin: 30px 0 5px 0 !important;
}
.um-col-alt .um-center .um-button {
	min-width: 142px !important;
}
.um-field-area {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 0px 30px;
}
.um-field-half {
	width: unset !important;
}
.um-col-1 {
	display: flex !important;
  flex-wrap: wrap !important;
  justify-content: space-between !important;
}
#um_field_1428_wohnungsreferenzummer {
	width: 100% !important;
	position: relative;
}
#um-error-for-wohnungsreferenzummer {
	position: absolute !important;
	left: 0 !important;
	bottom: -12px !important;
	z-index: 1;
}
#um_field_1428_wohnungsreferenzummer .um-field-checkbox {
	width: 106px !important;
}
#um_field_1428_first_name, #um_field_1428_last_name {
	width: 100% !important;
}
#um_field_1428_user_email {
	width: 100% !important;
}
.um-col-alt .um-center {
	text-align: start !important;
}
.kontakt-section .um-form input[type="number"], .kontakt-section .um-form input[type="password"], .kontakt-section .um-form input[type="search"], .kontakt-section .um-form input[type="tel"], .kontakt-section .um-form input[type="text"] {
	-webkit-appearance: none !important;
	transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out !important;
	background-color: #fff !important;
	border-radius: 0;
    padding: 0px !important;
	padding-top: 20px !important;
	padding-bottom: 20px !important;
	padding-left: 23px !important;
	padding-right: 23px !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
    color: #000 !important;
    border: 1px solid #fff !important; 
	appearance: none !important;
	height: 60px !important;
}
#um-submit-btn {
	border-radius: 36px !important;
	background-color: var(--prymary-color) !important;
  padding: 11px 28px !important;
  color: #fff !important;
  border-radius: 100px !important;
  border-color: var(--prymary-color) !important;
	font-size: 16px !important;
	height: 48px !important;
}
.um-field-area .um-clear {
	display: none !important;
}
.um-field-type_terms_conditions .um-field-area  a {
	color: #191919 !important;
	text-decoration: underline;
	margin-left: 6px;
}
.um-field-type_terms_conditions.margin .um-field-area a {
	margin-left: 27px;
}
/*******************************
          PRE-DEFINED
*******************************/
.margin-top-custom {
	margin-top: 42px;
}
.text-image-section {
	padding-top: 70px;
	padding-bottom: 35px;
}
.form-check-label a {
    color: var(--prymary-color);
    position: relative;

    &::after {
        width: 100%;
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        background-color: var(--prymary-color);
        height: 1px;
        transform-origin: left;
        transform: scaleX(0%);
        transition: all 0.3s ease-in-out;
    }
    &:hover::after {
        transform: scalex(100%);
    }
}
a{
    text-decoration: none;
}

.dropdown-toggle::after{
    display: none !important;
}

.btn-secondary{
    padding: 11px 28px;
    border-radius: 100px;
    font-weight: 500;
    letter-spacing: 0.16px;
    color: var(--secondary-color);
    background: transparent;
    border: 1px solid var(--secondary-color);
    margin-top: 40px;
    background-color: #fff;

    &:hover{
        background: var(--secondary-color);
    }

    &:hover img {
        filter: invert(1);
    }

    & img {
        margin-right: 7px;
        transition: 0.3s all ease-in-out;
    }

}
.border-top {
    border-top: 1px solid var(--third-color);
}

.btn-filter {
    background-color: var(--third-color);
    border-radius: 100px;
    font-weight: 500;
    font-size: 16px;
    line-height: 1.1;
    letter-spacing: 0.13;
    padding: 5px 10px 5px 15px;
    display: flex;
    align-items: center;

    &:hover {
        background-color: var(--third-color);
        color: #212529;
    }

    & img {
        margin-left: 5px;
    }
}

.btn-primary{
    padding: 11px 28px;
    border-radius: 80px;
    font-weight: 600;
    color: var(--prymary-color);
    background: var(--forth-color);
    border: 1px solid var(--forth-color);
    gap: 10px;
    font-size: 20px;
    border-color: var(--forth-color) !important;

    &:hover{
        background-color: var(--forth-color);
        color: var(--prymary-color);
        border-color: var(--forth-color) !important;
    }
}
.btn-sticky {
    background-color: var(--prymary-color);
    color: #fff;
	font-weight: 500;
    border-color: var(--prymary-color) !important;
    max-height: 49px;
	font-size: 16px;
    transition: all 0.3s ease-in-out;
    transform-origin: right;
    &:hover {
        background-color: var(--forth-color);
        border-color: var(--forth-color) !important;
    }
}
.btn-footer{
    padding: 10px 26px;
    border-radius: 100px;
    font-weight: 500;
    color: #fff;
    background: transparent;
    border: 1px solid #fff;
    font-size: 16px;
    letter-spacing: 0.14px;
    margin-top: 0px;

    &:hover{
        background-color: #fff;
        color: var(--secondary-color);
    }
}

@keyframes arrowAnimate {
    0% {
        transform: translateX(0%);
    }
    50% {
        transform: translateX(100%);
    }
    75% {
        transform: translateX(-100%);
    }

}
@keyframes arrowWhite {
    0% {
        opacity: 0;
    }
    62% {
        opacity: 1;
    }
}

.animated-button-wrap {

    &:hover {
        .image-animation::after {
            animation: arrowWhite 0.5s;

        }
        & img {
            animation: arrowAnimate 0.5s;
        }
		& .animated-button {
			background-position: 0 100%; 
            background-size: 0% 1px;
            color: var(--secondary-color);
		}
    }

    & .image-animation {
        height: 16px;
        width: 16px;
        display: inline-block;
        margin-left: 10px;
        overflow: hidden;
        position: relative;
		top: 3px;
		line-height: 1;

        & img {
            filter: invert(0);
            width: 100%;
            object-fit: contain;
            transform: translateX(0%);
            transform: all 0.3s ease-in-out;
            z-index: 1;
            position: relative;
        }
        &::after {
            content: '';
            opacity: 0;
            position: absolute;
            z-index: 2;
            width: 100%;
            height: 100%;
            background-color: #fff;
            transition: none;
            top: 0;
            left: 0;
            -webkit-transition: none !important;
            -moz-transition: none !important;
            -o-transition: none !important;
            transition: none !important;
        }

    }

    
    & .animated-button {
        color: #000;
        position: relative;
        display: inline-block;
        overflow: hidden;
        background-image: linear-gradient(#000 0 0);
        background-position: 100% 100%; /*OR bottom right*/
        background-size: 100% 1px;
        background-repeat: no-repeat;
        transition:
          background-size 0.3s,
          background-position 0s 0.3s; /*change after the size immediately*/
    
    
        &:hover{
            background-position: 0 100%; 
            background-size: 0% 1px;
            color: var(--secondary-color);
        
            color: #000;
    
            & img {
                transform: translateX(100%);
            }
        }
    
    }
}

@keyframes arrowRight {
    0% {

    }
    50% {

    }
    100% {

    }
}

.primary-color{
    background-color: #f8f4ec;
    color: var(--prymary-color);
}

.black-color{
    background-color: var(--secondary-color);
    color: #fff;
}

.bg-bronze {
    background-color: var(--prymary-color);
}

.bg-light-bronze {
    background-color: rgba(223, 218, 199, 0.4);
}

.text-bronze {
    color: var(--prymary-color) !important;
}

/*******************************
         BODY AND HTML
*******************************/

body{
    font-family: var(--font-primary);
    overflow-x: hidden;

    & .time-scroll{      
        gap: 23px;
        right: 15px;
        bottom: 15px;
        z-index: 3;
        transition: 0.5s all;
        opacity: 1;
        right: 15px;
        top: 21px;
        transform: translateY(calc(100% - 60px));




        & a.clock{
            width: 50px;
            height: 50px;
            background-color: var(--third-color);
            border-radius: 100%;
        }
        & img{
            width: 26px;
            height: auto;
            max-height: 26px;
            object-fit: contain;
        }

        &.not-visible{
            opacity: 0;
            visibility: hidden;
            right: 52px;
            top: 21px;
            transform: translateY(0%) !important;

            & .btn-sticky {

                transform: scaleX(0);
            }   
        }
    }
    & .time-scroll {
        & .btn-sticky.animate {
            transform: scaleX(0);
        }
    }

}

/*******************************
    KEY FRAMES AND ANIMATION
*******************************/


@keyframes upToDown {
    0% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-8px);
    }
    100% {
        transform: translateY(0);
    }
}
@keyframes upToDownMobile {
    0% {
        transform: translate(-50%, -40%);
    }
    50% {
        transform: translate(-50%, -60%);
    }
    100% {
        transform: translate(-50%, -40%);
    }
}

.up-down-animation{
    animation: upToDown 1.2s infinite !important;
}
.up-down-animation-mobile {
    animation: upToDownMobile 1.2s infinite !important;
}
/*******************************
           NAVIGATION
*******************************/

nav{
    padding-top: 23.5px !important;
    padding-bottom: 23.5px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.4) !important;
    left: 0;
    right: 0;
    top: 0;
    z-index: 4;
    transition: 0.3s all;
    transform: translateY(-100px);
	& .navbar-brand {
		position: relative;
	  top: -5px;
	}
    & .offcanvas.offcanvas-end{
        width: 100%;
		border-left: none !important;
    }

    & .offcanvas-body{
        background: var(--prymary-color);
        padding-left: 0;
        padding-right: 0;
        padding-top: 68px;
    }

    & .offcanvas-header{
        background: var(--prymary-color);
        padding-top: 24px;
        padding-bottom: 24px;
        padding-right: 20px;
        padding-left: 20px;
    }

    & .navbar-toggler{
        padding: 0px;
        box-shadow: none;
        border: none;

        & span{
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='white' stroke-linecap='' stroke-miterlimit='10' stroke-width='2' d='M0 7h30M0 16h30M0 25h30'/%3e%3c/svg%3e");


        }

        &:focus{
            box-shadow: none ;
        }
    }

    & .btn-close{
background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='10 10 24 24' fill='none'%3e%3cline x1='11.3905' y1='32.6054' x2='32.6038' y2='11.3922' stroke='white' stroke-width='2'/%3e%3cline x1='11.3907' y1='11.3925' x2='32.6039' y2='32.6057' stroke='white' stroke-width='2'/%3e%3c/svg%3e") !important;

        opacity: 1;
        padding: 0 !important;
        width: 22px;
        height: 22px;
        background-position: center;
        border-radius: 0;
        background-size: 100%;
        margin: 0 !important;
        margin-right: 0px !important;
    }

    & .navbar-brand{
        & img{
            max-height: 35px;
            height: auto;
            width: auto;
            max-width: 300px;
            object-fit: contain;
        }
    }

    & .time-block{
        font-weight: 500;
        color: #fff;
        text-decoration: none;

        & img{
            max-width: 35px;
            max-height: 35px;
            width: auto;
            height: auto;
        }
    }

    & .mobile-time-block{
        gap: 20px;

        & .time-block img{
            max-width: 30px;
            max-height: 30px;
        }
    }

    & ul.navbar-nav {
        position: relative;
        display: flex;
        justify-content: center;

        & .dropdown-box{
            transition: 0.3s all;
			padding-bottom: 18px;

            & a{
                letter-spacing: 0.16px;
                white-space: nowrap;
				color: #fff;
                font-size: 18px !important;
                font-weight: 400 !important;
                margin-top: 5px !important;
                margin-bottom: 5px;
                padding-top: 5px !important;
                padding-bottom: 5px !important;
                


                &:first-child{
                    padding-top: 0px !important;
                    margin-top: 0px !important;
                }
            }

    
        }

        & li{
            border-bottom: 1px solid #FFFFFF33;
            padding-right: 20px;
            padding-left: 20px;
            
            &:first-child{
                border-top: 1px solid #FFFFFF33;
            }

            & a {
                letter-spacing: 0.16px;
                font-size: 25px;
                font-weight: 600;
                color: #fff;
                text-decoration: none;
                position: relative;
                transition: color 0.3s;
                padding-left: 0 !important;
                padding-right: 0 !important;
                display: inline-block;
                padding-top: 10px !important;
                padding-bottom: 10px !important;
                margin-top: 10px !important;
                margin-bottom: 10px;
    
                &:hover{
                    color: #fff;
                }
    
                &:focus{
                    color: #fff;
                }
    
                &::after {
                    content: '';
                    position: absolute;
                    bottom: 0;
                    left: 0;
                    width: 100%;
                    height: 1px;
                    background-color: #fff;
                    transform: scaleX(0);
                    transform-origin: left;
                    transition: transform 0.3s ease-in-out;
                }
            }
        }
    }
}
body.single-geschaefte,
body.archive,

body.page-id-617,
	body.page-id-612,
	body.page-id-605,
	body.page-id-648,
	body.page-id-319, 
	body.single-post {
    
    padding-top: 158px;
    nav {
        border-color: #ECECEC;

        & .navbar-toggler {
            & span {
                filter: invert(1);
            }
        }
        & .navbar-brand {
            & img {
                filter: invert(1);
            }
        }
        & .offcanvas-header {
            & .navbar-brand {
                & img {
                    filter: invert(0);
                }
            } 
			& .time-block {
				& img {
					filter: invert(0);
				}
			}
        }
		& .time-block {
			& img {
				filter: invert(1);
			}
		}
    }
}
body.page-id-648,
body.page-id-605{
	padding-top: 200px;
}
body.single-post {
    padding-top: 158px;
	navbar {
	background-color: #fff !important;	
	}
    nav {
        background-color: #fff !important;
    

    }
}
/*******************************
            HERO
*******************************/

.hero-section{
    
    & .content-block{
        min-height: 100svh;
        z-index: 3;
        position: relative;
    }

    & .scroll-block{
        gap: 8px;
        margin-bottom: 78.5px;
        text-decoration: none;

        & .scroll-text{
            color: #fff;
            letter-spacing: 0.16px;
            font-size: 16px;
            font-weight: 500;
            line-height: 1;
        }

        & img {
            max-width: 20px;
            max-height: 20px;
            width: auto;
            height: auto;
            object-fit: contain;
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
        }
        & .circle {
            border: 1px solid #fff;
            border-radius: 50%;
            width: 20px;
            height: 20px;
            position: relative;
        }
    }


    
    & .scroll-block-desktop{
        gap: 8px;
        text-decoration: none;
        right: 48px;
        bottom: 48px;
        z-index: 3;

        & .scroll-text{
            color: #fff;
            letter-spacing: 0.16px;
            font-size: 16px;
            font-weight: 500;
            line-height: 1;
            top: -55px;
            left: -39px;
            white-space: nowrap;
            transform: rotate(-90deg);
            padding-left: 10px;
        }

        & img{
            max-width: 20px;
            max-height: 20px;
            width: auto;
            height: auto;
            object-fit: contain;
        }
    }

    & h1{
        font-size: 48px;
        line-height: 1.2;
        font-weight: 600;
        color: #fff;
        padding-bottom: 21px;
        padding-top: 114px;
        margin-bottom: 0px;
    }

    & img{
        left: 0;
        top: 0;
        object-fit: cover;
    }

    & .overlay-top{
        background: linear-gradient(180deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 50%);
        z-index: 2;
        left: 0;
        top: 0;
    }

    & .overlay-bottom{
        background: linear-gradient(179.85deg, rgba(0, 0, 0, 0) 44.38%, rgba(0, 0, 0, 0.6) 107.44%);
        z-index: 2;
        left: 0;
        bottom: 0;
    }
}

/*******************************
        TITLE TEXT
*******************************/

.text-title-section{
    padding-top: 62px;
    padding-bottom: 62px;
    margin-bottom: 62px;

    & h2{
        font-size: 40px;
        line-height: 1.1;
        font-weight: 600;
        margin-bottom: 27px;
    }

    & p{
        font-size: 21px;
        line-height: 1.4;
        font-weight: 500;
    }
}
.text-title-section.small {
	padding-top: 62px;
}
.text-title-section.big {
	padding-top: 155px;
}
/*******************************
      GESCHAEFTE SLIDERS
*******************************/

.gesh-slider-section{
    gap: 20px;
    padding-top: 50px;
    padding-bottom: 50px;


    & .marquee-slider-wrapper{
        display: flex;
        position: relative;

        & .marquee-slider-slides-wrapper{
            display: flex;
            position: relative;
            gap: 0px 60px !important;
            margin: 0px 30px !important;
        
            & .marquee-slider-slide{
                height: 85px;
                width: auto;
				width: 160px;
        
                & img{
                    width: auto;
                    max-height: 100%;
					max-width: 100%;
					height: auto;
                    object-fit: contain;
                }
            }
        }
    }
}

/*******************************
         NEWS & EVENTS
*******************************/

.news-and-events-section{
    padding-top: 50px;
    padding-bottom: 50px;
	overflow-x: hidden;

    & .upper-block{
        margin-bottom: 40px;

        & h2{
            font-weight: 600;
            font-size: 40px;
            line-height: 1.1;
            color: var(--secondary-color);
            margin-bottom: 0px;
        }

        & .alle-btn{
            color: var(--secondary-color);
            letter-spacing: 0.16px;
            font-weight: 500;
            line-height: 1;
            text-decoration: none;
            gap: 8px;
            font-size: 16px;
    
            & img{
                width: 21px;
                height: auto;
            }
        }
    }

    & .news-box{
		& .date-box > *{
			transition: all 0.15s ease-in-out;
		}
        &:hover {
            & img {
                scale: 1.05;
            }

        }

        & a{
            text-decoration: none;
        }

        & .img-box{
            display: inline-block;
            overflow: hidden;

            & img{
                object-fit: cover;
                width: 100%;
                height: auto;
                aspect-ratio: 1.4/1;
                transition: all 0.3s ease-in-out;
            }
        }

        & .type{
            font-weight: 500;
            font-size: 13px;
            letter-spacing: 0.13px;
            color: var(--prymary-color);
            margin-top: 10px;
        }

        & h3{
            margin-top: 4px;
            font-size: 25px;
            letter-spacing: 0.25px;
            color: var(--secondary-color);
            font-weight: 600;
        }
    }

    & .date-box{
        left: calc(var(--bs-gutter-x) * .5 + 18px);
        top: 18px;
        background: white;
        border-radius: 6px;
        padding-top: 17px;
        padding-bottom: 11.5px;
        width: 88px;
        text-decoration: none;
        color: var(--secondary-color);
        z-index: 1;

        & .date{
            font-size: 37px;
            font-weight: 600;
            letter-spacing: 0.16px;
            color: var(--secondary-color);
            line-height: 1;
        }

        & .month{
            font-size: 13px;
            letter-spacing: 0.13px;
            font-weight: 500;
        }
    }
}

/*******************************
        SCROLLING TEXT
*******************************/

.scrolling-text-section{
    padding-top: 80px;
    padding-bottom: 80px;
    
    & .marquee-slider-slide{
        font-weight: 600;
        font-size: 50px;
        color: var(--third-color);
        white-space: nowrap;
		line-height: 1.2;
    }
}

/*******************************
        WHONEN CARDS
*******************************/

.whonen-cards-section{
    padding-top: 50px;
    padding-bottom: 50px;
    margin-top: 50px;
    margin-bottom: 50px;
	
	.whonen-hover1 {
        width: 100%;
        left: 0;
        top: 0;
        height: 50%;
		z-index: 2;
    }
	
	.whonen-hover2 {
        width: 100%;
        right: 0;
        bottom: 0;
        height: 50%;
		z-index: 2;
    }

	& .hover-box {
		position: absolute;
		top: 0;
		height: 50%;
		width: 100%;
		margin-bottom: 12px;
	}
	& .hover-box.left {
		left: 0;
	}
	& .hover-box.right {
		right: 0;
	}
    & .wohnen-card-wrap {
        & .img-box {
            display: inline-block;
            overflow: hidden;
			&:hover {
				& img {
                    scale: 1.05;
                }
			}
        }
		& .whonen-link:hover {
			& .bigger-arrow-wrap .left {
				opacity: 1;
				transform: translateX(-50%) translateY(-50%) rotateX(0);              

			}
			& .bigger-arrow-wrap .right {
				opacity: 0;
				transform: translateX(50%) translateY(-50%) rotateX(90deg);
			}
		}
    }



    .bigger-arrow-wrap{
        position: relative;
        text-decoration: none;
        overflow: hidden;
        width: 37px;
        height: 37px;
        border-radius: 50%;
        padding: 6px;
        border: 2px solid #fff;
        
        & .left {
            top: 50%;
            left: 50%;
            width: 20px;
            height: 20px;
            opacity: 0;
            display: block;
            transition: 0.2s;
            position: absolute;
            transform: translateX(-110%) translateY(-50%) rotateX(0);
            display: flex;
            justify-content: center;
            align-items: center;
            & img {
                width: 100%;
                height: 100%;
                object-fit: contain;
            }
        }
        
        & .right{
            top: 50%;
            left: 50%;
            width: 20px;
            height: 20px;
            opacity: 1;
            display: block;
            transition: 0.2s;
            position: relative;
            transform: translateX(-50%) translateY(-50%) rotateX(0);
            display: flex;
            justify-content: center;
            align-items: center;
            & img {
                width: 100%;
                height: 100%;
                object-fit: contain;
            }
        }
    }



    &::after{
        content: '';
        position: absolute;
        top: calc(50% + 10px);
        left: 0;
        width: 100%;
        transform: translateY(-50%);
        height: 2px;
        background:#FFFFFF33;
    }

    & .img-box{
        width: 100%;
        height: 315px;

        & img{
            width: 100%;
            height: 100%;
            object-fit: cover;
            transition: all 0.3s ease-in-out;
        }
    }

    & .whonen-link{
        gap: 15px;
        font-size: 40px;
        color: #fff;
        font-weight: 600;
        line-height: 1.1;
        margin-bottom: 25px;
        width: fit-content;

        & img{
            height: 32px;
            width: auto;
            max-width: 32px;
            object-fit: contain;
        }
    }
}

.zoom-shopping-section{
    padding-bottom: 50px;
    padding-top: 92px;

    & h3{
        font-size: 40px;
        line-height: 1.1;
        font-weight: 600;
        color: var(--secondary-color);
        margin-bottom: 30px;
    }

    & .button-block{
        gap: 14px;

        & .button-box{
            gap: 14px;

            & img{
                max-height: 19px;
                max-width: 19px;
                width: auto;
                height: auto;
                object-fit: contain;
            }
        }
    }
}

/*******************************
            FOOTER
*******************************/

.above-footer-section{
	font-weight: 500;
    padding-bottom: 50px;
    padding-top: 50px;
    margin-top: 44px;
    background: var(--secondary-color);

    & .img-box-logo{
        width: auto;
        height: 52px;
        margin-bottom: 23px;
        display: inline-block;
		max-width: 200px;

        & img{
            width: auto;
            max-width: 100%;
            height: auto;
            max-height: 100%;
            object-fit: contain;
        }
    }

    & .street{
        font-weight: 500;
        font-size: 16px;
        line-height: 1.56;
        color: #fff;
        letter-spacing: 0.16px;
    }
    
    & .navbar-nav-footer{
        list-style-type: none;
        margin-bottom: 0px !important;

        & .text{
            font-size: 16px;
            color: #fff;
        }

        & a{
            font-size: 16px;
            color: #fff;
            position: relative;
            width: fit-content;
            margin-bottom: 10px;
			font-weight: 500;
            &::after {
                content: '';
                position: absolute;
                bottom: 0;
                left: 0;
                width: 100%;
                height: 1px;
                background-color: #fff;
                transform: scaleX(0);
                transform-origin: left;
                transition: transform 0.3s ease-in-out;
            }

            &:hover::after {
                transform: scaleX(1);
            }
        }

        & .text-div{
            font-size: 16px;
            color: #fff;
            position: relative;
            width: fit-content;
            margin-bottom: 10px;
        }

        & .nav-link-footer{
            font-weight: 700;
            font-size: 16px;
        }

        & .dropdown-box-footer{
            margin-top: 10px;
        }
    }

    & .imgs-box{
        gap: 30px;

        & a:hover {
            & img {
                opacity: 0.4;
            }
        }

        & img{
            max-width: 23px;
            max-height: 23px;
            object-fit: contain;
            width: auto;
            height: auto;
            transition: all 0.3s ease-in-out;
        }
    }
}

footer{
    background-color: var(--secondary-color);
    padding-top: 20px;
    padding-bottom: 20px;
    border-top: 1px solid #FFFFFF33;
    
    & .rights-text{
        color: #FFFFFF66;
        font-size: 16px;
		font-weight: 500;
    }

    & .block-wrap{

        & img{
            width: auto;
            height: auto;
            max-height: 40px;
            max-width: 300px;
            object-fit: contain;
        }

        & ul{
            padding: 0;
            margin: 0;
            list-style-type: none;
            gap: 24px;
            font-weight: 500;
            
            & a{
                color: #FFFFFF66;
                font-size: 16px;
                position: relative;
                &::before {
                    content: '';
                    position: absolute;
                    width: 100%;
                    height: 1px;
                    transform: scaleX(0);
                    background-color: #FFFFFF66;
                    left: 0;
                    bottom: 0;
                    transform-origin: left;
                    transition: all 0.3s ease-in-out;
                }

                &:hover{
                    color: #FFFFFF66;
                    &::before {
                        transform: scaleX(1);
                    }
                }
            }
        }
    }
}

/*******************************
        MOBILITAT
*******************************/

.mobilitat-section {
    padding-top: 92px;
    padding-bottom: 40px;


    & h2{
        font-weight: 600;
        font-size: 40px;
        line-height: 1.1;
        color: var(--secondary-color);
        margin-bottom: 40px;
    }
    table {
        min-width: 1195px;
        width: 100%;
    
        & td, th {
            font-size: 14px;
            color: #000;
            line-height: 1.5;
            padding-top: 15px;
            padding-bottom: 15px;
            letter-spacing: 0.16;
        }
		& tr.bold td {
			font-weight: 600;
		}
        & th {
            border-top: 1px solid #000;
            border-bottom: 1px solid #000;
            font-weight: 600;
        }
        & th span{
            font-weight: 400;
        }
        & td {
            font-weight: 400;
            border-bottom: 1px solid rgba(0, 0, 0, 0.12);
			vertical-align: top;
        }
        & tr td {
            transition: all 0.3s ease-in-out;
            
        }
        & tr:hover td {
            background-color: var(--third-color);
        }
        & .btn {
            padding: 4px 8px;
            font-size: 12px;
            line-height: 1;
        }
    }
}
.scroll-container {
    width: 100%;
    overflow: auto;

}

.table-btn {
    border-radius: 3px;
    padding: 4px 6px;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.1;
    display: inline-block;
}
.reserviert {
    color: #FAB521;
    background-color: #FEF0D1;
}
.frei {
    color: #45937A;
    background-color: #DDF9D4;
}
.vermietet {
    color: #DF494E;
    background-color: rgba(223, 73, 78, 0.2);
}
#warteliste .um .um-form input[type="text"]:focus {
	border: 1px solid #A48153 !important;
}
.wohnungen-section {
    padding-top: 42px;
    padding-bottom: 100px;
	    
    & .dropdown-menu{
        border-radius: 0px;
        border: 1px solid black;
        padding: 6px 17px !important;

        & li{

            & input[type="checkbox"]{
                appearance: none;
                background-color: #ECECEC;
                flex-shrink: 0;
                margin: 0;
                color: red;
                width: 17px;
                height: 17px;
                border: 0;
                border-radius: 0;
                transform: translateY(-1px);
                display: grid;
                place-content: center;
                padding: 2px;

                &:checked{
                    background-color: #ECECEC;
					background-image: url('assets/images/filter-check-icon.svg');
					background-size: 13px;
					background-position: center;
					background-repeat: no-repeat;
                }
				&:before {
					content: none;
				}
            }

            & label{
                border-radius: 0;
                font-size: 16px;
                line-height: 1.1;
                letter-spacing: 0.13px;
                padding: 6px;
            }
        }
    }

    & h2{
        font-weight: 600;
        font-size: 40px;
        line-height: 1.1;
        color: var(--secondary-color);
        margin-bottom: 40px;
    }

    & .form-select {
        border-radius: 0;
        border: 1px solid #000;
        font-size: 16px;
        line-height: 1.1;
        letter-spacing: 0.13;
        padding: 17px;
    }

    & .select-title {
        font-size: 13px;
        font-weight: 600;
        line-height: 1.1;
        margin-bottom: 8px;
    }

    & .btn-zuruck {
        border-radius: 100px;
    }

    & .btn-zuruck img {
        margin-right: 6px;
    }

    & .form-select:focus, .form-select:focus-visible {
        box-shadow: none;
        outline: 0;
    }

    & .ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default, .ui-button, html .ui-button.ui-state-disabled:hover, html .ui-button.ui-state-disabled:active {
        background-color: #000;
        border: 0;
        height: 20px;
        width: 20px;
    }

    & .ui-slider-horizontal {
        height: 4px;
        width: 92%;
    }
	& .gewerbe-filter-column {
		padding-left: 19px;
		padding-right: 19px;
	}
	& .gewerbe-filter-column .ui-slider-horizontal {
		width: 100%;
	}
    & .ui-widget.ui-widget-content {
        border: 0;
        background-color: var(--third-color);
    }

    & .ui-slider .ui-slider-range {
        background-color: #000;
    }

    & .ui-slider-horizontal .ui-slider-handle {
        top: -7.5px;
    }

    & .filter {
        padding-bottom: 55px;
    }

    & td, tr {
        padding-top: 11px;
        padding-bottom: 11px;
    }
    & .isometry-box svg .up {
        transform: translateY(-15%);
    }
    & .isometry-box svg .hover > *{
        fill: var(--prymary-color);
    }
    & .isometry-box svg g {
        transition: all 0.3s ease-in-out;
    }

    & #table_1 tr.hover td {
        background-color: var(--third-color);
    }

}
.wohnungen-section {
	& .mieten-filter {
		& .ui-slider-horizontal {
			margin-left: 0;
		}
	}
}
.um-row._um_row_1 {
	margin: 0 0 27px 0 !important;
}
.um-field-type_terms_conditions {
	padding-top: 0 !important;
}
#um_field_1428_wohnungsreferenzummer {
	padding-top: 0 !important;
}
.lightbox .lb-image {
    border: none;
    border-radius: 0;
}

.lightbox {
    position: fixed!important;
	display: flex; 
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
}
.lb-outerContainer {
	background-color: unset; 
	width: 100% !important;
	height: 100% !important;
}
.lb-container {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	width: 100%;
}
.lb-outerContainer {
	position: absolute;
}
.lb-number {
    display: none!important;
}

.lb-prev, .lb-next {
    position: fixed;
    display: block!important;
    opacity: 1!important;
    background-size: 37px!important;
}

.lb-nav a.lb-next {
    right: 20px;
    background: url(assets/images/arrow-right-white.svg);
    background-repeat: no-repeat;
    background-position: right center;
}

.lb-nav a.lb-prev {
    left: 20px;
    background: url(assets/images/arrow-right-white.svg);
    background-repeat: no-repeat;
    background-position: right center;
    transform: rotate(180deg);
}

.lb-data .lb-close {
    width: 20px;
    height: 20px;
    background-size: 20px;
    background: url(assets/images/close-icon.svg);
    filter: invert(1);
	opacity: 1;
}
.filter {
	& input[type="checkbox"]:checked {
		background-image: url('assets/images/filter-check-icon.svg');
		background-color: #fff;
		background-repeat: no-repeat;
		background-position: center; 
		background-size: cover;
	}
}
.lb-nav {
  position: absolute;
  top: 0;
  left: 0;
  height: 60%;
  width: 100%;
  z-index: 10;
  top: 20%;
}
.lb-nav a.lb-prev, .lb-nav a.lb-next {
	height: 75%;
  top: 12.5%;
}
.lb-close {
    position: absolute;
	top: 20px;
    right: 15px;
    z-index: 99999;
}

#lightbox {
    top: 50%!important;
    left: 50%!important;
    transform: translate(-50%, -50%);
}

.slider-section {
    padding-top: 50px;
    padding-bottom: 50px;
    overflow: hidden;
    & a {
        width: 100%;
        height: 100%;
    }

    & .subtitle {
        margin-bottom: 20px;
    }
    & h2 {
        font-weight: 600;
        font-size: 40px;
        line-height: 1.1;
        margin-bottom: 25px;
    }
    & .subtitle-text {
        font-size: 25px;
        color: var(--prymary-color);
        line-height: 1.2;
        margin-right: 20px;
		font-weight: 600;
    }
    & .sub-image {
        width: auto;
        max-height: 100px;
        & img {
            width: 100%;
            height: 100%;
            object-fit: contain;
        }
    }
    & .rundgangSwiper {
        width: 100%;
        height: 100%;
        padding-top: 50px;
        }

    &  .swiper-slide {
        text-align: center;
        font-size: 18px;
        background: #fff;
        height: auto;
        display: flex;
        justify-content: center;
        align-items: center;
        }

    &  .swiper-slide img {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
		aspect-ratio: 1.475/1;
    }
    .double-swiper-button {
        border-radius: 50%;
        border: 1px solid #191919;
        width: 30px;
        height: 30px;
        transition: all 0.3s ease-in-out;
		& .smaller-arrow-wrap {
			height: 100%;
			  width: 100%;
			  padding: 2px;
			  overflow: hidden;
			align-items: center;
			& .left, .right {
				transition: all 0.3s ease-in-out;
				display: flex;
				justify-content: center;
				align-items: center;
				height: 18px;
				width: 18px;
				flex-shrink: 0;
			}
			& .left {
				margin-right: 4px;
				transform: translateX(-110%);
			}
			& .right {
				transform: translateX(-100%);
			}
			
		}
        & img {
            width: 100%;
            height: 100%;
            object-fit: contain;
            transition: all 0.3s ease-in-out;
        }
        &:hover {
			& .smaller-arrow-wrap {
				& .left {
					transform: translateX(18%);
				}
				& .right {
					transform: translateX(75%);
				}
			}
        }
    }
    & .double-swiper-button-prev {
        left: auto;
        right: calc(17% + 40px);
        transform: rotate(180deg);
    }
    & .double-swiper-button-next {
        right: 17%;
    }
    & .double-swiper-button-next, .double-swiper-button-prev {
        top: 22px;
        &::after {
            content: '';
        }
    }
}
/*******************************
        KONTAKT
*******************************/
.kontakt-section {
    padding-top: 62px;
    padding-bottom: 70px;
    background-color: rgba(223, 218, 199, 0.4);


    & .upper-part {
        margin-bottom: 29px;
    }
    
    & h2{
        font-weight: 600;
        font-size: 38px;
        line-height: 1.1;
        color: var(--secondary-color);
        margin-bottom: 22px;
    }
    & p {
        font-size: 16px;
        line-height: 1.5;
        letter-spacing: 0.13;
        font-weight: 400;
    }
    & label {
        font-size: 13px !important;
        font-weight: 600 !important;
        margin-bottom: 9px !important;
		color: #000 !important;
    }
    & .form-control {
        border-radius: 0;
        padding: 20px 23px;
        font-size: 16px;
        line-height: 1.5;
        color: #000;
        border: 1px solid #fff;
    }
    & .form-control:focus {
        border-color: var(--prymary-color);
        box-shadow: none;
    }
    & input[type="checkbox"], .um-field-checkbox-state {
        border-radius: 100%;
        appearance: none;
        position: relative;
        border-color: #fff;
        height: 17px;
        width: 17px;
        margin-right: 10px;
		background: var(--prymary-color); 
		top: 4px;
		flex-shrink: 0;
    }
	& .um-field-checkbox-state {
		top: unset !important;
	}
    & .wpcf7-list-item-label, .um-field-checkbox-option {
        font-size: 16px;
        font-weight: 400;
        color: #000 !important;
    }
	.um-icon-android-checkbox-outline-blank, .um-icon-android-checkbox-outline {
		display: none !important;
	}
	.um-field-checkbox {
		display: flex !important;
	  justify-content: start !important;
	  align-items: center !important;
	}
	.um-field-checkbox:not(.um-field),
	.um-field-radio:not(.um-field) {
		margin: 0;
	}
	}
	.um-field-checkbox-option {
		margin-left: 0 !important;
	}
    & input[type="checkbox"]::before, .um-field-checkbox-state::before {
        background-color: #fff;
        width: 9px;
        height: 9px;
        position: absolute;
        border-radius: 50%;
        content: '';
        top: 4px;
        left: 4px;
        transition: all 0.2s ease-in-out;
    }
	.um-field-checkbox.active .um-field-checkbox-state::before {
		background: var(--prymary-color);
	}
	input[type="checkbox"] {
		margin-right: 0;
	}
    & input[type="checkbox"]:focus {
        box-shadow: none;
    }
    & input[type="checkbox"]:checked[type="checkbox"] {
        background-image: none;
        background-color: #fff;
        border-color: #fff;
    }
    & input[type="checkbox"]:checked[type="checkbox"]::before {
        background-color: var(--prymary-color) !important;
    }
}
.wpcf7-checkbox {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px 43px;
}
.kontakt-section .wpcf7-list-item {
	margin-left: 0 !important;
	flex: 1 1 calc(5% - 20px);
}
span[data-name="checkbox-449"] .wpcf7-checkbox {
	display: flex;
  	flex-wrap: wrap;
	  gap: 10px 30px;
}
.wpcf7-list-item a {
    color: #000;
	text-decoration: underline;
}
.wpcf7-form .row > * {
	margin-top: 21px;
}
.wpcf7-not-valid-tip {
	font-size: 13px;
}
.wpcf7-checkbox label, .wpcf7-list-item label {
    display: flex;
    justify-content: start;
    align-items: start;
}
.kontakt-section.bg-white {
    & input[type="checkbox"] {
        background-color: #f2f0e9 !important;
    }

    & input[type="checkbox"]::before {
        background-color: #f2f0e9;
    }
	& input[type="checkbox"]:checked[type="checkbox"] {
		background-color: #f2f0e9 !important;
	}
}
.btn-submit {
    background-color: var(--prymary-color);
    padding: 11px 28px;
    color: #fff;
    border-radius: 100px;
    border-color: var(--prymary-color);
	&:hover {
		background-color: var(--prymary-color);
		border-color: var(--prymary-color);
		color: #fff;
	}
}
.um-field-checkbox-state {
	margin-right: 10px;
}
.um-field-checkbox input {
	margin-right: 0 !important;
}
.um-field-checkbox.active .um-field-checkbox-state::before {
	background: var(--prymary-color);
}
.um-field-checkbox-state::before {
	background: #fff;
}
.kontakt-section {
	& .um-field-checkbox-state {
		background: #fff;
	}
}
.btn-bewerben {
    border: 1px solid #000;
    font-size: 12px;
    padding: 2px 8px;
    border-radius: 35px;
    &:hover {
        background-color: #000;
        color: #fff;
    }
}
/*******************************
        STANDORT
*******************************/

.standort-section{
	& .map-desktop {
		margin-top: 10px;
	}
    & .cards-block{
		& .row:last-child .col-lg-6:last-child .card-box,
		.row:last-child .col-lg-4:last-child .card-box{
			border-bottom: 0;
		}
        &::after{
            display: none;
        }
    }

    & h2{
        font-size: 40px;
        line-height: 1.1;
        font-weight: 600;
        color: var(--secondary-color);
        margin-bottom: 22px;
    }

    & p{
        font-size: 21px;
        line-height: 1.4;
        margin-bottom: 23px;
    }
	
	&.standort-text{
		& p{
			font-size: 16px;
		}
	}
	
	& .accordion-item{
		border-bottom: 0;
		& p{
			font-size: 16px;
		}
	}

    & iframe{
        width: 100%;
        aspect-ratio: 1.57 / 1;
    }

    & .row{
        border-top: none;

        & .card-box{
            padding-left: 0px;
            padding-right: 0px;
            padding-top: 30px;
            padding-bottom: 50px;
            border-bottom: 1px solid var(--third-color);
        }

        &:first-child{
            border-top: none;
        }
        
        & .card-title{
            color: var(--secondary-color);
            font-size: 28px;
            letter-spacing: 0.28px;
            font-weight: 600;
            margin-bottom: 14px;
        }

        & .card-text{
            font-size: 16px;
            line-height: 1.56;
            letter-spacing: 0.16px;
			font-weight: 300;
			& a {
				color: #191919;
				position: relative;
				&:before {
					content: '';
					position: absolute;
					width: 100%;
					height: 1px; 
					background: #191919;
					bottom: 0;
					left: 0;
					transform: scaleX(0%);
					transform-origin: left;
					transition: all 0.3s ease-in-out;
				}
				&:hover:before {
					transform: scaleX(100%);
				}
			}
        }

        & .img-box{
            width: 46px;
            height: 46px;
            margin-bottom: 25px;

            & img{
                width: auto;
                height: auto;
                max-width: 100%;
                max-height: 100%;
                object-fit: contain;

            }
        }
    }

}

/*******************************
        GESCHAEFTE
*******************************/

.geschaefte-section{
    padding-top: 50px;
    padding-bottom: 100px;
	
	& .col-custom{
		background: #fff;
		position: relative;

		&::after{
			content: "";
			left: 0;
			top: -1px;
			width: 100vw;
			height: 1px;
			position: absolute;
			background: #ECECEC;
		}

		&::before{
			content: "";
			top: 0;
			height: 100vh;
			width: 1px;
			position: absolute;
			right: -1px;
			background: #ECECEC;
		}
	}
	
	& .gesh-box{
		background: #fff;
	}
	
	& a:hover {
		& .gesh-box {
		
			& img {
				transform: scale(1.075);
			}
		}
	}
    & .row{
        margin-left: 0px;
        margin-right: 0px;
    }

    & .col-md-4{
        height: 120px;
        padding-left: 0px;
        padding-right: 0px;
    }

    & .gesh-box{
        padding: 35px 25px;
        text-align: center;
        height: 100%;
        width: 100%;
        display: flex;
        justify-content: center;
        align-items: center;

        & img{
            object-fit: contain;
            max-width: 100%;
            max-height: 100%;
            width: auto;
            height: auto;
			max-height: 75px;
			transition: all 0.3s ease-in-out;
        }
    }

    & .btn-box{
        gap: 10px;
        margin-bottom: 30px;

        & .filter-button{
            font-size: 16px;
            line-height: 1;
            color: var(--secondary-color);
            letter-spacing: 0.16px;
            font-weight: 500;
            padding: 7.5px 14px;
            background: transparent;
            border: 1px solid #ECECEC;
            border-radius: 68px;
            transition: 0.3s all;
    
            &:hover{
                background: #ECECEC;
                border-color: #ECECEC;
                color: #191919;
            }

            &.active{
                background: #ECECEC;
                border-color: #ECECEC;
                color: #191919;
            }
        }
    }

    & h2{
        font-size: 40px;
        font-weight: 600;
        margin-bottom: 18px;
        color: var(--secondary-color);
    }
}

/*******************************
        SERVICES
*******************************/
.services-section {
    padding-top: 100px;
    padding-bottom: 50px !important;

    & .row{
        border-top: none;

        & .card-box{
            border-color: #fff;
            padding-left: 0;
        }
    }
}


/*******************************
        ACCORDIONS
*******************************/
.parking-section {
    padding-top: 100px;
    padding-bottom: 40px;
}
.accordion {
    margin-bottom: 60px;

    & .accordion-item {

        & .accordion-header {
            margin-bottom: 0;
        }
        & .accordion-button {
            padding: 25px 5px;
            font-size: 25px;
            font-weight: 600;
            line-height: 1.15;
            letter-spacing: 0.25;
            border-top: 1px solid #000;
            background-color: #fff;
            color: #000;
            position: relative;
            border-bottom: 0;
			box-shadow: none !important;
        }
        & .accordion-button::before, .accordion-button::after {
            background-image: url('assets/images/minus.svg');
            flex-shrink: 0;
            width: 20px;
            height: 2px;
            margin-left: auto;
            content: "";
        }
        & .accordion-button::before {
            right: 5px;
            position: absolute;
            transform: rotate(90deg);
            transition: all 0.3s ease-in-out;
        }
        & .accordion-button:focus,
        .accordion-button:focus-visible {
            box-shadow: none;
            outline: 0;
        }
        .accordion-button:not(.collapsed)::after {
            transform: rotate(0deg);
        }
        .accordion-button:not(.collapsed)::before {
            transform: rotate(-360deg);
        }
        & .accordion-body {
            padding-left: 5px;

        }
    }
    & .accordion-item:last-child {
        border-bottom: 1px solid #000;
    }
}

/*******************
    AKTIONEN
*******************/
.aktionen-section {
    padding-top: 100px;
    & .text-box {
		background-color: #191919;
        padding-top: 50px;
        padding-left: 36px;
        padding-right: 36px;
        padding-bottom: 50px;
    }
}
.text-box {
    & h2 {
        font-weight: 600;
        font-size: 40px;
        line-height: 1.1;
        margin-bottom: 14px;
    }
    & p {
        font-weight: 500;
        font-size: 21px;
        line-height: 1.4;
    }
    & .arrow-right {
        height: 46px;
        width: 46px;
        margin-top: 30px;
        border: 1px solid #fff;
        border-radius: 50%;        
        transition: all 0.3s ease-in-out;

        & img {
            width: 25px;
            height: 25px;
            object-fit: contain;
            transition: all 0.3s ease-in-out;
            filter: invert(1);
			
			&.front{
				left: 10.5px;
			}
        }
    }
}
.text-box:hover {
    & .arrow-right {
        background-color: #fff;
    }
    & img {
        filter: invert(0);
    }
}
/*******************************
          NEWS ARCHIVE
*******************************/
.news-and-events-section {
    h1 {
        font-size: 48px;
        line-height: 1.2;
        margin-bottom: 39px;
        font-weight: 600;
    }
    & .news-wrap {
        padding-top: 55px;
        border-top: 1px solid #ECECEC;
    }
    & .alle-btn {
            
        & .text {
            position: relative;
        }

        & .text::after {
            width: 100%;
            content: '';
            position: absolute;
            left: 0;
            bottom: 0;
            height: 1px;
            background-color: #191919;
            transform: scaleX(0);
            transform-origin: left;
            transition: transform 0.3s ease-in-out;
        }

        &:hover {
            & .text::after {
                transform: scaleX(100%);
            }
            & .left {
                transform: translateX(0);
            }
            & .right {
                transform: translateX(0);
            }
        }
        & .smaller-arrow-wrap {
            height: 21px;
            width: 21px;
            border-radius: 50%;
            border: 1px solid #191919;
            padding: 2px;
            overflow: hidden;
            & img {
                filter: invert(1);
                width: 15px;
            }
        }
        & .left {
            margin-right: 4px;
            transform: translateX(-125%);
        }
        & .left, .right {
            transition: all 0.3s ease-in-out;
            display: flex;
            justify-content: center;
            align-items: center;
        }
        & .right {
            transform: translateX(-125%);
        }
    }
}
/*************************
    GESCHAFTE SINGLE
**************************/
.geschafte-single-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.geschafte-single {
	& h1 {
		margin-bottom: 22px;
	}
	
    & .alle-btn {
      & .smaller-arrow-wrap {
		  border-color: var(--prymary-color) !important;
        & img {
			transform: rotate(180deg);
			filter: unset !important;
			margin-right: 0;
		  }
		}
	 }
	& .text {
		&::after {
			transform: scaleX(0) !important;
		}
	}
}

.range-text {
	line-height: 1;
}
.geschafte-single {

    & .carousel, .carousel-inner, .carousel-item {
        height: 100%;
    }
    & .carousel-control-next, .carousel-control-prev {
        & .smaller-arrow-wrap {
            width: 37px;
            height: 37px;
            border-radius: 50%;
            border: 1px solid #fff;
            overflow: hidden;
            & .left, .right {
                width: 30px;
                height: auto;
                transition: all 0.3s ease-in-out;
                & img {
                    object-fit: contain;
                }
            }
            & .left {
                transform: translateX(-100%);
            }
            & .right {
                transform: translateX(-50%);
            }
        }
        &:hover {
            & .right {
                transform: translateX(100%);
            }
            & .left {
                transform: translateX(50%);
            }
        }
    }
    & .carousel-control-prev {
        rotate: 180deg;
    }
}
.geschafte-single {
    & .alle-btn {
      & .text::after { 
		  background-color: var(--prymary-color) !important;
		}
		}
	}

.zuruck-button {
    display: inline-block;
    font-size: 16px;
    font-weight: 500;
    margin-bottom: 50px;
    color: var(--prymary-color);
    position: relative;
    &::after {
/*         content: ''; */
        position: absolute;
        bottom: 0;
        right: 0;
        width: 88%;
        height: 1px;
        background-color: var(--prymary-color);
        transform: scaleX(0);
        transform-origin: left;
        transition: transform 0.3s ease-in-out;
    }
    &:hover {
        
        color: var(--prymary-color);
        text-decoration: none;
        &::after {
            transform: scaleX(1);
        }
    }

    & img {
        transform: rotate(180deg);
        filter: invert(45%) sepia(82%) saturate(242%) hue-rotate(354deg) brightness(100%) contrast(84%);
        margin-right: 8px;
    }
}
.zuruck-button-black {
    color: #000;
    position: relative;
    &::after {
        content: '';
        position: absolute;
        bottom: 0;
        right: 0;
        width: 65%;
        height: 1px;
        background-color: #000;
        transform: scaleX(0);
        transform-origin: left;
        transition: transform 0.3s ease-in-out;
    }
    & img {
        transform: rotate(180deg);
        filter: none;
        margin-right: 8px;
    }
    &:hover {
        text-decoration: none;
        color: #000;
        &::after {
            transform: scaleX(1);
        }
    }
}
.share-button {
    color: var(--prymary-color);
    position: relative;
    &::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 68%;
        height: 1px;
        background-color: var(--prymary-color);
        transform: scaleX(0);
        transform-origin: left;
        transition: transform 0.3s ease-in-out;
    }
    &:hover {
        &::after {
            transform: scaleX(1);
        }
        color: var(--prymary-color);
    }
    & img {
        margin-left: 10px;
    }
}
.geschafte-info-wrap {
    & .geschafte-info {
        margin-bottom: 25px;
        font-size: 16px;
        line-height: 1.5;
        & a {
            font-size: 16px;
            line-height: 1.5;
            color: #000;
            position: relative;
            &::after {
                content: '';
                position: absolute;
                bottom: 0;
                left: 0;
                width: 100%;
                height: 1px;
                background-color: #000;
                transform: scaleX(0);
                transform-origin: left;
                transition: transform 0.3s ease-in-out;
            }
            &:hover {
                &::after {
                    transform: scaleX(1);
                }
            }
        }
    &:last-child {
        margin-bottom: 0;
    }

    }
    & .info-icon {
        width: 20px;
        height: 20px;
        display: flex;
        margin-right: 15px;

        & img {
            width: 100%;
            height: 100%;
            object-fit: contain;
            flex-shrink: 0;
        }
    }
}
.single-logo {
    height: 105px;
    width: auto;
    display: block;
    margin-bottom: 15px;
	display: flex;
	justify-content: start;
    & img {
		width: auto;
		height: auto;
		object-fit: contain;
		max-width: 100%;
		max-height: 100%;
    }
    & p {
        font-size: 16px;
        line-height: 1.5;
    }
   
}
.single-text {
    padding-top: 20px;

    & .geschafte-info-wrap {
        margin-top: 42px;
    }
	& .animated-button-wrap {
		margin-top: 35px !important;
		font-weight: 400 !important;
		& .image-animation img {
			filter: invert(0);
		}
	}
}
/*******************************
          OFFNUNGZEITEN
*******************************/
.primary-color {
    & .offnung-table {
        
        & tr {
        
            &:hover {
                & td {
                    background-color: #f8f4ec
                }
                
            }
            &:first-child {
                td {
                    border-top: 1px solid var(--prymary-color);
                }
            }
            & td {
                
                color: var(--prymary-color);
                border-color: var(--prymary-color);
            }
        }
    }
}


.offnung-table {
    max-width: unset;
	width: 100%;
    min-width: unset;
    & tr {
    
        &:hover {
            & td {
                background-color: var(--prymary-color);
            }
            
        }
        &:first-child {
            td {
                border-top: 1px solid rgba(223, 218, 199, 0.5);
            }
        }
        & td {
            border-bottom: 1px solid rgba(0, 0, 0, 0.12);
            color: #fff;
            border-color: rgba(223, 218, 199, 0.5);
            padding-top: 9px;
            padding-bottom: 9px;

            &:last-child {
                text-align: end;
            }
        }
		& td, th {
			padding-left: 0;
			padding-right: 0;
		}
    }
}
.privacy-editor {
    & h3 {
        font-weight: 600;
        font-size: 25px;
        line-height: 1.15;
        margin-bottom: 37px;
        margin-top: 74px;
        letter-spacing: 0.25px;
    }
    & p, a {
        font-size: 16px;
        line-height: 1.5;
        color: #000;
        letter-spacing: 0.16px;
		margin-bottom: 20px;
    }
    & a {
        position: relative;
        &::before {
            content: '';
            position: absolute;
            width: 100%;
            height: 1px;
            background-color: #000;
            transition: all 0.3s ease-in-out;
            transform: scaleX(0);
            transform-origin: left;
            bottom: 0;
            left: 0;
        }
        &:hover::before {
                transform: scaleX(1);


        }
    }
}
.sortable {
	& th {
		position: sticky;
		  top: 0;
		  background: #fff;
	}
}
.wohnungen-section {
    & table {
		border-collapse: separate;
		  border-spacing: 0;

        th {
            border-top: 1px solid #000;
            border-bottom: 1px solid #000;
            padding-top: 15px;
            padding-bottom: 15px;

        }
        & td, & th {
            padding-top: 15px;
            padding-bottom: 15px;
			min-width: 131px;
        }
        & td {
            border-bottom: 1px solid rgba(0, 0, 0, 0.12);
        }
    }
}
.offnungcards-section {
    & table {
        & td, & th {
            padding-top: 9px;
            padding-bottom: 9px;
        }
    }
    & .col-md-4 {
        height: unset !important;
		
    }
    & .offnung-box {
		& .image-animation {
			& img {
				filter: invert(0);
			}
		}
        padding: 47px 24px;
        height: 100%;
        & table {
            max-width: unset;
			width: 100%;
            min-width: unset;
        }
        & tr:hover {
            & td {
                background-color: #fff;
            }          
        }
        & td {
            border-color: #000;
            border-bottom: 1px solid;
        }

        & tr {
            & td:first-child {
                padding-left: 0;
            }
            & td:last-child {
                text-align: end;
                padding-right: 0;
            }
            
        }
        & tr:first-child {
            & td {
                border-top: 1px solid #000;
            }
        }
        & .offnung-logo {
            height: 85px; /*60px*/
            width: auto;
            max-width: 100%;
            display: flex;
            margin-bottom: 47px;
            & img {
                height: auto;
                width: auto;
                max-width: 100%;
                max-height: 100%;
                object-fit: contain;
            }
        }
    }
    & .container {
        padding-left: 0;
        padding-right: 0;
    }
    & .col-md-6 {
        border-bottom: 1px solid #ECECEC;
    }
/*     & .col-md-6:last-child {
        border-bottom: 1px solid #ECECEC;
    }
	& .col-md-6:first-child {
        border-top: none;
    } */
}

/***************************************
          SPEZIELLE-OFFNUNGZEITEN
**************************************/
.zurruk-arrow {
	transform: rotate(180deg);
}
.spezielle-offnungzeiten {
    padding-top: 50px;
    padding-bottom: 50px;
    & .spezielle-table {
        min-width: unset;
        width: 100%;
		& strong {
			font-weight: 500;
		}
    }
    & tr {
        transition: all 0.3s ease-in-out;
        &:hover {
            background-color: var(--third-color);
        }
        & td {
            border-color: #000;
            border-bottom: 1px solid #000;
            padding-top: 15px;
            padding-bottom: 15px;

        }
        
        &:first-child {
            & td {
                border-top: 1px solid #000;
            }
        }
    }
    
}
/***************************************
          NEWS SIGNLE
**************************************/
.news-single {
    & .carousel {
        margin-bottom: 55px;
    }
    & .carousel-item {
        & img {
            aspect-ratio: 3/2;
        }
    }
    & .news-single-buttons {
        margin-top: 55px;
    }
    .subtitle {
        font-size: 21px;
        margin-bottom: 14px;
    }
    & h1 {
        font-size: 50px;
        line-height: 1.1;
        margin-bottom: 20px;
        font-weight: 600;
    }
    & .event-duration {
        margin-bottom: 37px;
        & .event-info:last-child {
            margin-bottom: 0;
        }
        
    }
    & .event-info {
        line-height: 2;
        margin-bottom: 12px;
    }
    & .event-info-subtitle {
        font-size: 13px;
    }
    & .event-info-title {
        font-size: 21px;
        font-weight: 600;
        line-height: 1.38;
    }
    & .swiper {
        width: 100%;
        height: 100%;
        margin-bottom: 55px;
      }
      & .swiper-button-next::after, .swiper-button-prev::after {
        color: #fff;
      }
    &  .swiper-slide {
        text-align: center;
        height: auto;
        font-size: 18px;
        background: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
      }
  
    &  .swiper-slide img {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
      }
    & p {
        font-size: 16px;
        line-height: 1.5;
    }
}
.fragen-section {
    padding-top: 100px;
    padding-bottom: 100px;
    & .info-text a{
        color: #fff;
        font-size: 16px;
        &::after {
            content: '';
            position: absolute;
            bottom: 0;
            right: 0;
            width: 100%;
            height: 1px;
            background-color: #fff;
            transform: scaleX(0);
            transform-origin: left;
            transition: transform 0.3s ease-in-out;
        }
    }
    

    .geschafte-info-wrap {
        & .info-icon {
          & img {
            filter: invert(1);
          }
        }
        & .geschafte-info {
            margin-bottom: 16px;
        }
    }
    .text-box {
        & p {
            font-size: 16px !important;
        }
		& p.bigger-text {
            font-size: 21px !important;
			font-weight: 500;
        }
    }
}
.kontakt-page {
    & .form-control {
        background-color: rgba(223, 218, 199, 0.4);
    }
}
.slider-section {
    border-bottom: 1px solid var(--third-color);
    & .col-lg-9 {
        padding-right: 0;
    }
}
.page-not-found {
    height: 100svh;
    display: flex;
    justify-content: center;
    flex-direction: column;

    & .btn-secondary {
        border-color: #fff;
        margin-top: 37px;
        &:hover {
            border-color: #191919;
        }
    }

}
.sticky-part {
    position: relative;
}
.sticky-section {

    position: sticky; 
    top: 0;
    left: 0;
    background-color: #fff;
    z-index: 11;

    & .sticky-menu {
        padding-top: 20px;
        padding-bottom: 20px;
        list-style: none;
        padding-left: 0;
        padding-right: 12px;
        margin-bottom: 0;
        overflow-x: auto;
        & li {
            margin-right: 27px;
            &:last-child {
                margin-right: 0;
            }
        }

        & a {
            white-space: nowrap;
            color: #000;
            position: relative;

            &.active {
                &::after {
                    transform: scaleX(100%);
                }
            }
            &::after {
                content: '';
                position: absolute;
                bottom: 0;
                left: 0;
                height: 1px;
                width: 100%;
                background-color: #000;
                transform: scaleX(0%);
                transform-origin: left;
                transition: all 0.3s ease-in-out;
            }
            &:hover::after {
                transform: scaleX(100%);
            }
        }
    }
}
/*******************************
          RESPONSIVE
*******************************/
@media only screen and (min-width: 992px){
	.slider-section {
		& .double-swiper-button-next {
			right: auto;
			left: 40px;
		}
		& .double-swiper-button-prev {
			left: 0;
			  right: 24% !important;
		}
		#services{
			padding-top: 128px !important;
			padding-bottom: 128px !important;
		}
	}
}
@media only screen and (min-width: 576px){
	.um-col-alt {
		margin: 15px 0 5px 0 !important;
	}
	.um-field-type_terms_conditions.margin .um-field-area a {
		margin-left: 6px;
	}
	#um_field_1428_wohnungsreferenzummer .um-field-checkbox {
		width: auto !important;
	}
/*******************
        HERO
*******************/

    .hero-section{
            
        & h1{
            font-size: 54px;
        }
    }
    .slider-section {
        & .col-lg-9 {
            padding-right: 12px;
            gap: 20px;
            & .rundgangSwiper2 {
                & img {
                    aspect-ratio: 4/3;
                }
            }

            & .rundgangSwiper { 
                min-width: 36.58536585365854%;
                align-self: end;
                height: auto;
                & img {
                    aspect-ratio: 3/2;
                }
                
            }
            & .swiper {

                max-height: 388px;
            }
        }
        & .swiper-slide {
            height: auto;
            & img {
                height: 100%;
                
            }
        }
        & .swiper-slide.swiper-slide-next{
            align-items: end;
            justify-content: end; 

        }
        .double-swiper-button {
            border-radius: 50%;
            border: 1px solid #000;
            width: 30px;
            height: 30px;
        }
        & .double-swiper-button-prev {
            transform: rotate(180deg);
        }

        & .double-swiper-button-next, .double-swiper-button-prev {
            bottom: 27px;
            &::after {
                content: '';
            }
        }
        & .title-wrap {
            margin-bottom: 50px;
        }
    }
	    .standort-section{
		&.standort-text{
			& p{
				font-size: 23px;
				margin-bottom: 21px;
			}
		}
        & .row{
            border-top: none;
    
            & .card-box{
                padding-left: 20px;
                padding-right: 20px;
            }
        }
		


        & .cards-block{
            
            &::after{
                display: block;
                content: '';
                position: absolute;
                left: 50%;
                transform: translateX(-50%);
                top: 0;
                height: 100%;
                width: 1px;
                background-color: var(--third-color);
            }
            /* &::before{
                display: block;
                content: '';
                position: absolute;
                right: 33.33333333%;
                transform: translateX(-50%);
                top: 0;
                height: 100%;
                width: 1px;
                background-color: var(--third-color);
            } */
        }

        & .row{
            border-top: 1px solid var(--third-color);

            & .card-box{
                border-bottom: none;
            }

            & .card-title{
                color: var(--secondary-color);
                font-size: 25px;
                letter-spacing: 0.25px;
            }
        }

        & h2{
            font-size: 40px;
            margin-bottom: 29px;
        }

        & p{
            font-size: 23px;
            margin-bottom: 26px;
        }
		
		& .accordion-item{
			& p{
				font-size: 16px;
			}
		}
    }
}

@media only screen and (min-width: 768px){
	.services-section {
		padding-top: 100px;
		padding-bottom: 100px !important; 
	}
	.slider-section {
		& .container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
			padding-right: 0;
		}
	}
	.above-footer-section {
		& .img-box-logo{
			max-width: unset;
		}
	}
	.single-logo {
		height: 110px;
	}
	
	.kontakt-section .wpcf7-list-item{
		flex: unset;
	}
	#um_field_1428_first_name, #um_field_1428_last_name {
		width: 49% !important;
	}

	.offnungcards-section {
  & .offnung-box {
	  padding: 47px 45px;
	  
	  & table {
		  		max-width: 329px;
	  		}
		}
	}
    .offnungcards-section {
		
		& .row{
			overflow: hidden;
			border-bottom: 1px solid #ECECEC;
		}
        & .col-md-6{
            border: none !important;
            position: relative;
    
            padding-left: 0px;
            padding-right: 0px;
			
			&::after{
				content: "";
				left: 0;
				top: -1px;
				width: 100vw;
				height: 1px;
				position: absolute;
				background: #ECECEC;
			}

			&::before{
				content: "";
				top: 0;
				height: 100vh;
				width: 1px;
				position: absolute;
				right: -1px;
				background: #ECECEC;
		}
        }
		

		
		
/* 		& .col-md-6:first-child{
			border-top: 1px solid #ECECEC;
		} */
    }
/*******************
        HERO
*******************/

    .hero-section{
            
        & h1{
            font-size: 68px;
        }
    }
/*******************
    WHONEN CARDS
*******************/
	
	.whonen-cards-section{
		
		& .img-box{
            width: 100%;
            height: 415px;
        }
		
		.whonen-hover1 {
			width: 50%;
			left: 0;
			top: 0;
			height: 100%;
		}

		.whonen-hover2 {
			width: 50%;
			right: 0;
			top: 0;
			height: 100%;
		}
		
		&::after{
            content: '';
            position: absolute;
            left: 50%;
            top: 0;
            height: 100%;
            transform: translateX(-50%);
            width: 2px;
            background:#FFFFFF33;
        }
		
		& .whonen-link-reverse{
			margin-bottom: 0px !important;
		}

    }

/*******************
    GESCHAEFTE
*******************/

    .geschaefte-section{
        padding-top: 60px;
        padding-bottom: 100px;

        & .col-md-4{
            height: 175px;
        }
    }

}
.offnungcards-section .container-xxl {
	padding-left: 0;
	padding-right: 0;
}
@media only screen and (min-width: 992px){
		.slider-section {
		& .container, .container-fluid, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
			padding-right: calc(var(--bs-gutter-x) * 2.5);
		}
	}
	
	.offnungcards-section{
		& .row{
			border: 1px solid #ECECEC;
		}
	}
	.standort-section{
		& h2{
            font-size: 50px;
        }
	}

	.um-field-area {
		gap: 10px 30px;
	}
	.offnungcards-section .container-xxl {
		padding-right: calc(var(--bs-gutter-x) * 2.5);
    	padding-left: calc(var(--bs-gutter-x) * 2.5);
	}
	
	.fragen-section{
		padding-top: 178px;
		padding-bottom: 168px;
		
		  & .text-box {
			  & p.bigger-text{
			  	font-size: 23px !important;
				max-width: 419px;
			}
		}
	}
		.offnungcards-section {
			& .offnung-box {
				padding: 62px !important; 
			}
	}
	.geschaefte-section{


		& .gesh-box{


			& img{

				max-height: 125px;
			}
		} 
	}
	.news-and-events-section {
		padding-bottom: 40px;
	  & .upper-block {
		  & h2 { 
		  	font-size: 50px;
		  }
		}
	}
	.pb-lg-6{
		padding-bottom: 120px !important
	}
	
	body.no-scroll {
	  overflow: hidden;
	}

	.wohnungen-section {
		padding-top: 126px;
		& .upper-part { 
			padding-top: 42px; 
		}

		  & table {
			& td, & th {
				min-width: unset;
			  }
		}
		


	}
	

/* 	#wohnungen {
		& .upper-part { 
			position: sticky;
			top: 0;
			background: #fff;
		}
		& .filter {
			position: sticky;
			top: 140px;
			background: #fff;
			z-index: 111;
		}
		& .scroll-container {
			position: sticky;
			top: 200px;
		}
	} */
/*******************
    PRE-DEFINED
*******************/
	.mt-lg-6{
		margin-top: 80px;
	}

	.single-text {
		& .animated-button-wrap {
			margin-top: 42px !important;
		}
	}
	.kontakt-section {
		padding-bottom: 70px;

		& .upper-part {
			margin-bottom: 49px;
		}
		& p {
			font-size: 23px;
		}
	}
	.offnung-table {
		max-width: 342px;
	}
    .btn-secondary{
        margin-top: 70px;
    }

    .btn-primary{
        gap: 14px;
    }

    .btn-footer{
        padding: 11px 28x;
        border-radius: 100px;
        font-size: 16px;
        letter-spacing: 0.16px;
        margin-top: 15px;
    }

    .container-small{
        max-width: 876px !important;
    }
    
/*******************
    BODY AND HTML
*******************/
    body{
        & .time-scroll.not-visible{
            right: 23px;
            top: 23px;
            transform: translateY(0%);
        }
        & .time-scroll {
            right: 23px;
            top: 23px;
            transform: translateY(calc(100% - 60px));
            /* bottom: 23px; */
        }
    }
/*******************
    NAVIGATION
*******************/
    nav{
        & ul.navbar-nav{
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%, -50%);

            & li{
                border-bottom: 0;
                padding-right: 0 !important;
                padding-left: 0 !important;

                &:first-child{
                    border-top: 0;
                }

                & a{
                    font-size: 18px;
                    display: unset;
                    padding: 0 !important;
                    margin: 0 !important;
					
					&:hover::after {
						transform: scaleX(1);
					}
                }
            }

            & .dropdown-box{
                position: absolute;
                top: 62px;
                visibility: hidden;
                opacity: 0;
                padding-top: 25px;
                padding-bottom: 25px;

                & a{
                    font-size: 16px;
                    white-space: nowrap;
                    font-size: 18px !important;
                    font-weight: 400 !important;
                    margin-top: 0px !important;
                    margin-bottom: 0px !important;
                    padding-top: 0px !important;
                    padding-bottom: 0px !important;
                    
                    &:last-child{
                        padding-bottom: 0px !important;
                        margin-bottom: 0px !important;
                    }
    
                    &:first-child{
                        padding-top: 0px !important;
                        margin-top: 0px!important;
                    }
                }
    
                &::after{
                    content: '';
                    position: absolute;
                    left: 0;
                    bottom: 0px;
                    width: 3840px;
                    height: 1px;
                    background: rgba(255, 255, 255, 0.4);
                    transform: translateX(-50%);
                }
        
                &::before{
                    content: '';
                    position: absolute;
                    left: 0;
                    bottom: 0px;
                    width: 3840px;
                    height: 100%;
/*                     background: rgba(0, 0, 0, .5); */
                    transform: translateX(-50%);
                }
            }
        }

        & .navbar-brand{
            & img{  
                max-height: 39px;
            }
        }

        & ul.navbar-nav{
            gap: 40px;
        }

        & .time-block{
            gap: 13px;
        }
    }
    body.single-post {
        padding-top: 275px;
        & .offcanvas-header .navbar-brand {
            filter: invert(0) !important;
        }
    }
    body.single-geschaefte,
    body.archive,
    body.page-id-617,
	body.page-id-612,
	body.page-id-605,
	body.page-id-648,
	body.page-id-319,
	body.single-post{
        


        padding-top: 270px;
        nav {
            border: 1px solid #ECECEC !important;
    
            & .navbar-toggler {
                & span {
                    filter: invert(1);
                }
            }
            & .navbar-brand {
                & img {
                    filter: invert(1);
                }
            }
            & .offcanvas-header {
                & .navbar-brand {
                    & img {
                        filter: invert(0);
                    }
                } 
            }
            
            & .time-block {
                color: #191919;
                & img {
                    filter: invert(1) !important;
                }
            }
            & ul.navbar-nav {
                & li{
                    & a {
                        color: #191919;
                        &::after {
                            background-color: #191919;
                        }
                    }
                    
                    
                }
				& .dropdown-box {
					& a {
						color: #191919;
						 &::after {
                            background-color: #191919;
                        }
					}
				}
                & .dropdown-box::after {
                        background: #ECECEC;
                }
				& .dropdown-box::before {
					background: #fff;
				}
            }
        }
		nav.background {
			border: 1px solid #fff !important;
			& ul.navbar-nav {
				& .dropdown-box {
					& a {
						color: #191919 !important;
						&::after {
							background-color: #191919 !important;
						}
					}
				}
			}
		}
    }
/*******************
        HERO
*******************/

    .hero-section{
        
        & h1{
            font-size: 84px;
            padding-bottom: 44px;
        }
    }

/*******************
    TITLE TEXT
*******************/

    .text-title-section{
        padding-top: 92px;
        padding-bottom: 92px;
        margin-bottom: 92px;

        & h2{
            font-size: 41px;
            margin-bottom: 0px;
        }

        & p{
            font-size: 23px;
        }
    }
	.text-title-section.small {
		padding-top: 92px;
	}
	.text-title-section.big {
		padding-top: 155px;
	}
    .text-title-section.offnungzeiten-section {
        padding-top: 280px;
    }
/*******************
    TITLE TEXT
*******************/
    .gesh-slider-section{
        gap: 50px;
        padding-top: 60px;
        padding-bottom: 60px;

        & .marquee-slider-wrapper{

            & .marquee-slider-slides-wrapper{
                gap: 0px 100px !important;
                margin: 0px 50px !important;
            
                & .marquee-slider-slide{
                    height: 90px;
                }
            }
        }
    }

 /*******************
    NEWS & EVENTS
*******************/

    .news-and-events-section{
        padding-top: 60px;
        padding-bottom: 60px;

        & .news-box{

            & .type{
        
                margin-top: 24px;
            }


            & h3{
                font-size: 28px;
                letter-spacing: 0.28px;
            }
        }
        
        & .alle-btn {
            
            & .text {
                position: relative;
            }

            & .text::after {
                width: 100%;
                content: '';
                position: absolute;
                left: 0;
                bottom: -5px;
                height: 1px;
                background-color: #191919;
                transform: scaleX(0);
                transform-origin: left;
                transition: transform 0.3s ease-in-out;
            }

            &:hover {
                & .text::after {
                    transform: scaleX(100%);
                }
                & .left {
                    transform: translateX(0);
                }
                & .right {
                    transform: translateX(0);
                }
            }
            & .smaller-arrow-wrap {
                height: 21px;
                width: 21px;
                border-radius: 50%;
                border: 1px solid #191919;
                padding: 2px;
                overflow: hidden;
                & img {
                    filter: invert(1);
                    width: 15px;
                }
            }
            & .left {
                margin-right: 4px;
                transform: translateX(-125%);
            }
            & .left, .right {
                transition: all 0.3s ease-in-out;
                display: flex;
                justify-content: center;
                align-items: center;
            }
            & .right {
                transform: translateX(-125%);
            }
        }
    }
/*******************
    SCROLLING TEXT
*******************/

    .scrolling-text-section{
        padding-top: 100px !important;
        padding-bottom: 100px !important;
        
        & .marquee-slider-slide{
            font-size: 80px;
        }
    }
	.error404  {
		& .scrolling-text-section{
			& .marquee-slider-slide{
				font-size: 109px;
			}
		}
	}
/*******************
    WHONEN CARDS
*******************/

    .whonen-cards-section{
        padding-top: 80px;
        padding-bottom: 80px;
        margin-bottom: 80px;
        margin-top: 80px;
		& .hover-box {
			width: 50%;
			height: 100%;
		}
		& .hover-box.left {
			left: 0;
		}
		& .hover-box.right {
			right: 0;
		}
    }

/*******************
    WHONEN CARDS
*******************/

    .whonen-cards-section{



        & .img-box{
            width: 100%;
            height: 500px;
        }

        & .whonen-link{
            gap: 20px;
            font-size: 50px;
            color: #fff;
            font-weight: 600;
            margin-bottom: 50px;
            line-height: 1;

            & img{
                height: 37px;
                max-width: 37px;
            }

        }
    }

/*******************
    ZUM SHOPPING
*******************/

    .zoom-shopping-section{
        padding-bottom: 60px;
        padding-top: 60px;

        & h3{
            font-size: 80px;
            line-height: 1.1;
            font-weight: 600;
            color: var(--secondary-color);
            margin-bottom: 50px;
        }

        & .button-block{
            gap: 26px;
            max-width: 705px;

            & .button-box{
                gap: 26px;
    
                & img{
                    max-height: 24px;
                    max-width: 27px;
                }
				
				& .btn-primary{
					font-size: 28px;
				}
            }
        }
    }

/*******************
        MOBILITAT
*******************/
    td, th {
        padding-left: 10px;
        padding-right: 10px;
    }
    .mobilitat-section {
        padding-top: 170px;
        padding-bottom: 100px;

        & h2 {
            font-size: 50px;
            margin-bottom: 45px;
        }
        
        & .btn-secondary {
            margin-top: 45px;
        }
    }

/*******************
        STANDORT
*******************/


/*******************************
        SERVICES
*******************************/
.services-section{
    padding-top: 178px;
    padding-bottom: 128px !important;

    & .cards-block{
        
        & .card-box {
            padding-left: 20px;
            padding-right: 20px;
            padding-top: 30px;
            padding-bottom: 50px;

            & .card-title {
                font-size: 28px;
            }
        }

/*         &::after{
            display: block;
            content: '';
            position: absolute;
            left: 33%;
            transform: translateX(-50%);
            top: 0;
            height: 100%;
            width: 1px;
            background-color: #fff;
        }
        &::before{
            display: block;
            content: '';
            position: absolute;
            right: 33%;
            transform: translateX(-50%);
            top: 0;
            height: 100%;
            width: 1px;
            background-color: #fff;
        } */
    }
    & .row{
        border-color: #fff;
    }
}
	
	.services-section#services{
		    padding-top: 128px !important;
    		padding-bottom: 128px !important;
	}
/*******************
    FOOTER
*******************/

    .above-footer-section{
		font-weight: 500;
        & .img-box-logo{
            height: 66px;
        }

        & .navbar-nav-footer{

            & .text{
                font-size: 16px;
            }

            & a{
                font-size: 16px;
				font-weight: 500;
            }

            & .text-div{
                font-size: 16px;
            }

            & .nav-link-footer{
                font-size: 20px;
            }

            & .dropdown-box-footer{
                margin-top: 12px;
            }
        }
    }

    footer{
        & .block-wrap{

            & ul{
                gap: 32px;
            }
        }
    }

    /*******************
        GESCHAEFTE
    *******************/

    .geschaefte-section{
        padding-top: 106px !important;
        padding-bottom: 60px;
        
        & .col-md-4{
            height: 215px;
        }

        .btn-box{
            margin-bottom: 40px;
        }

        & h2{
            font-size: 50px;
            margin-bottom: 30px;
        }
    }
	.sticky-part .geschaefte-section {
		padding-bottom: 178px;
	}
    /*******************************
            ACCORDIONS
    *******************************/
    .parking-section {
        padding-top: 178px;
        padding-bottom: 100px;
    }
    .accordion {
        margin-bottom: 65px;

        & .accordion-item {

            & .accordion-header {
                margin-bottom: 0;
            }
            & .accordion-button {
                font-size: 28px;
                padding: 30px 10px;
            }
            & .accordion-button::before {
                right: 9px;
            }
            & .accordion-body {
                font-size: 16px;
                padding-left: 10px;
            }
        }
    }
    /*******************
        AKTIONEN
    *******************/
    .aktionen-section {
        & .text-box {
            padding-left: 110px;
            padding-right: 110px;
            padding-top: 110px;
            padding-bottom: 110px;

            & h2 {
                font-size: 40px;
                margin-bottom: 0;
            }
            & p {
                font-size: 23px;
            }
            & .arrow-right {
                width: 95px;
                height: 95px;
                margin-top: 0;
				
                & img {
                    width: 43px;
                    height: 43px;
					
					&.front{
						left: 26px;
					}
                }
            }
        }
    }
    /*******************************
            NEWS ARCHIVE
    *******************************/
    .news-and-events-section {
        h1 {
            font-size: 109px;
            margin-bottom: 72px;
        }
        & .news-wrap {
            padding-top: 105px;
        }
        
    }

    /*************************
        GESCHAFTE SINGLE
    **************************/
    .text-image {
        border-top: 1px solid var(--third-color);
        border-bottom: 1px solid var(--third-color);
        padding-top: 65px;
        padding-bottom: 80px;
    }
	.geschafte-single {
		h1 {
			font-size: 77px;
		}
		
	}
    .geschafte-single-image {
        position: absolute;
        height: 100%;
        width: 50%;
        left: 0;
        top: 0;
    }
    .geschafte-info-wrap {
        margin-top: 50px;
    }
    .single-logo {
        max-height: 150px;
		height: 120px;
        margin-bottom: 15px;
    
    }
    .single-text {
        padding-top: 0;
        & .geschafte-info-wrap {
            margin-top: 50px;
        }
    }

    /*******************************
            WOHNUNGEN
    ******************************/
    .wohnungen-section {
		& .isometry-box {
			position: sticky;
			top: 100px;
		}
        & h2 {
            font-size: 50px;
			padding-bottom: 45px;
            margin-bottom: 0;
        }

        & table {
            min-width: 100%;
        }
    }
    /*******************************
        KONTAKT
    *******************************/
    .kontakt-section {
        padding-top: 133px;
        padding-bottom: 133px;
        
        & h2 {
            font-size: 50px;
            margin-bottom: 45px;
        }
    }
    /***************************************
            SPEZIELLE-OFFNUNGZEITEN
    **************************************/
    .spezielle-offnungzeiten {
        padding-top: 110px;
        padding-bottom: 130px;
    }
    /***************************************
            NEWS SIGNLE
    **************************************/
    .news-single {

        & .carousel {
            margin-bottom: 65px;
        }
        .subtitle {
            font-size: 23px;
            margin-bottom: 14px;
        }
        & h1 {
            font-size: 77px;
            margin-bottom: 31px;
        }
        & .event-duration {
            gap: 34px;
            margin-bottom: 61px;
            & .event-info {
                margin-bottom: 0;
            }
            
        }
        & .event-info {
            
            & .event-info-title {
                font-size: 23px;
            }
        }
        & .swiper {
            margin-bottom: 66px;
        }
    }
.privacy-editor {
    & h3 {
        font-size: 28px;
        margin-bottom: 39px;
        margin-top: 100px;
    }
}
	.slider-section {
        padding-top: 70px;
        padding-bottom: 70px;
    }
}


@media only screen and (min-width: 1200px){
	.aktionen-section {
		& .text-box {
			padding-left: 110px;
			padding-right: 110px;
			padding-top: 110px;
			padding-bottom: 110px;

			& h2 { 
				font-size: 50px;
			}
		}
	}
	.offnungcards-section {
		& .offnung-box {
			& .offnung-logo {
				height: 120px;
			}
		}
	}
	.gesh-row{
		grid-template-columns: repeat(4, 1fr); /* 4 columns for extra-large screens */
	}
	.slider-section {
		& h2 {
			font-size: 50px;
			font-weight: 600;
		}

		& .subtitle-text {
			font-weight: 600;
			font-size: 28px;
		}
	}
	.mobilitat-section {
		& table {
			min-width: 1280px;
			& td, th {
				font-size: 16px;
			}	
		}

	}
/*******************
        HERO
*******************/

    .hero-section{
            
        & h1{
            font-size: 100px;
            padding-bottom: 64px;
        }
    }

/*******************
    TITLE TEXT
*******************/

    .text-title-section{
        padding-top: 122px;
        padding-bottom: 122px;
    }
	.text-title-section.small {
		padding-top: 122px;
	}
	.text-title-section.big {
		padding-top: 260px;
		padding-bottom: 146px;
	}
/*******************
    ZUM SHOPPING
*******************/

    .zoom-shopping-section{
        padding-top: 158px;
        padding-bottom: 78px;
        & h3{
            font-size: 100px;
            margin-bottom: 60px;
        }
    }
    .smaller {
        width: 13.7% !important;
    }
    .bigger {
        width: 23.76666666666667% !important;
    }
    .above-footer-section .row {
        gap: 5%;
    }
}

@media only screen and (min-width: 1300px){

}
@media only screen and (min-width: 1400px){
/*******************
    PRE-DEFINED
*******************/
    .container-xxl{
        max-width: 1818px;
        padding-left: 110px;
        padding-right: 110px;
    }
	#geschaefte .container-xxl.no-padding,
	.offnungcards-section .container-xxl {
        padding-left: 110px;
        padding-right: 110px;
	}
    .container-xxl.container-small {
        padding-left: 12px;
        padding-right: 12px;
    }

/*******************
        HERO
*******************/

    .hero-section{
                
        & h1{
            font-size: 110px;
            padding-bottom: 84px;
        }
    }

/*******************
    TITLE TEXT
*******************/
    
    .text-title-section{
        padding-top: 170px;
        padding-bottom: 170px;

        & h2{
            font-size: 50px;
        }
    }
	.text-title-section.small {
		padding-top: 170px;
	}
/*******************
    WHONEN CARDS
*******************/

    .whonen-cards-section{

        & .col-lg-6:first-child{
            padding-right: 5rem !important;
        }

        & .col-lg-6:nth-child(2){
            padding-left: 5rem !important;
        }
    }

/*******************
    ZUM SHOPPING
*******************/

    .zoom-shopping-section{

        & h3{
            font-size: 107px;
        }
    }
}
