* {
    padding: 0;
    margin: 0;
    box-sizing: inherit;
    list-style: none;
    text-decoration: none;
}

html {
    scroll-behavior: smooth;
}

body {
    box-sizing: border-box;
}

@font-face {
    font-family: 'DINOT';
    src: url("/fonts/DINOT.otf") format("opentype");
}

@font-face {
    font-family: 'DINOT-Bold';
    src: url("/fonts/DINOT-Bold.otf") format("opentype");
}

@font-face {
    font-family: 'Roboto';
    src: url("/fonts/Roboto-Regular.ttf") format("truetype");
}

@font-face {
    font-family: 'Roboto-Bold';
    src: url("/fonts/Roboto-Bold.ttf") format("truetype");
}

@font-face {
    font-family: 'Roboto-Light';
    src: url("/fonts/Roboto-Light.ttf") format("truetype");
}

@font-face {
    font-family: 'RobotoCondensed-Regular';
    src: url("/fonts/RobotoCondensed-Regular.ttf") format("truetype");
}

@font-face {
    font-family: 'RobotoCondensed-Bold';
    src: url("/fonts/RobotoCondensed-Bold.ttf") format("truetype");
}

@font-face {
    font-family: 'RobotoCondensed-Light';
    src: url("/fonts/RobotoCondensed-Light.ttf") format("truetype");
}

.DINOT {
    font-family: 'DINOT';
}

.DINOT-Bold {
    font-family: 'DINOT-Bold';
}

.Roboto {
    font-family: 'Roboto';
}

.Roboto-Bold {
    font-family: 'Roboto-Bold';
}

.Roboto-Light {
    font-family: 'Roboto-Light';
}

.RobotoCondensed-Bold {
    font-family: 'RobotoCondensed-Bold';
}

.RobotoCondensed-Light {
    font-family: 'RobotoCondensed-Light';
}

.RobotoCondensed-Regular {
    font-family: 'RobotoCondensed-Regular';
}

.Ueberschrift-1 {
    font-size: 85px;
    line-height: 95px;
    color: #fff;
}

.Ueberschrift-2 {
    /*font-size: 70px;*/
    font-size: 50px;
    line-height: 50px;
    color: #505356;
}

.immobilie-überschrift {
    font-size: 30px;
    line-height: 40px;
    color: #505356;
}

.menu-text {
    font-size: 30px;
    line-height: 35px;
    color: #fff;
}

.content-text {
    font-size: 20px;
    line-height: 30px;
    color: #505356;
}

.footer-text {
    font-size: 18px;
    line-height: 28px;
    color: #fff;
}

.name-text {
    font-size: 35px;
    line-height: 30px;
    color: #505356;
}

.success {
    color: green;
    position: fixed;
    bottom: 30px;
    right: 30px;
    padding: 10px;
    background-color: #ccebf4;
    border: 3px solid #bfd6de;

    -moz-animation: cssAnimation 0s ease-in 5s forwards;
    /* Firefox */
    -webkit-animation: cssAnimation 0s ease-in 5s forwards;
    /* Safari and Chrome */
    -o-animation: cssAnimation 0s ease-in 5s forwards;
    /* Opera */
    animation: cssAnimation 0s ease-in 5s forwards;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}

@keyframes cssAnimation {
    to {
        width:0;
        height:0;
        overflow:hidden;
        padding: 0;
        border: none;
    }
}

@-webkit-keyframes cssAnimation {
    to {
        width:0;
        height:0;
        visibility:hidden;
        padding: 0;
        border: none;
    }
}

.error {
    color: red;
}

#reithinger-body {
    width: 100%;
    /*max-width: 1920px;*/
    max-width: 1440px;
    margin: 0 auto;
    height: fit-content;
    border: 20px solid #fff;
}

.margin-top {
    margin-top: 20px;
}

.margin-top-menu {
    margin-top: 60px;
}

.margin-bottom-content-wrap {
    margin-bottom: 10px;
}

input, label, button {
    cursor: pointer;
}

.suche-display-none {
    display: none!important;
}

/* HEADER */

#reithinger-header {
    width: 100%;
    /*background-color: #131619;*/
    color: #fff;
    text-align: center;
    position: relative;
}

#reithinger-header-bg {
    width: 100%;
    height: auto;
}

#reithinger-header-logo {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 2;
    width: 160px;
    height: 150px;
}

#reithinger-header-farbbalken-links {
    position: absolute;
    top: calc(50% - 100px);
    left: 10px;
    z-index: 2;
}

#reithinger-header-farbbalken-rechts {
    position: absolute;
    top: calc(50% - 100px);
    right: 10px;
    z-index: 2;
}

#reithinger-header-kontakt {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: calc(50% - 50px);
    right: 25px;
}

#reithinger-header-kontakt > a {
    height: 50px;
}

#reithinger-header-farbbalken-links-2 {
    position: absolute;
    bottom: 50px;
    left: 10px;
    z-index: 2;
}

#reithinger-header-farbbalken-rechts-2 {
    position: absolute;
    bottom: 50px;
    right: 10px;
    z-index: 2;
}

#reithinger-header-kontakt-2 {
    display: flex;
    flex-direction: column;
    position: absolute;
    bottom: 100px;
    right: 25px;
}

#reithinger-header-kontakt-2 > a {
    height: 50px;
}

#reithinger-header > h1 {
    position: absolute;
    bottom: 50px;
    left: 0;
    right: 0;
    margin: 0 auto;
    font-weight: inherit;
}

.reithinger-header-bg-mobile {
    display: none;
}

/* MENU */

#reithinger-menu {
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    z-index: 1;
    display: none;
    justify-content: center;
    align-items: center;
    position: absolute;
    background-color: rgb(20 109 147 / 90%);
}

.reithinger-menu-flex {
    display: flex!important;
}

#reithinger-menu > ul {
    width: 50%;
    text-align: left;
}

.menu-toggle {
    width: 60px;
    height: 60px;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 100;
    border: 10px solid transparent;
}

.menu-toggle > img {
    width: 100%;
    height: auto;
}

.menu-on-borders-1 {
    border: 10px solid #1b1c1b!important;
    border-top: none!important;
}

.menu-on-borders-2 {
    border: 10px solid #1b1c1b;
    left: 0!important;
    top: calc(50% - 110px)!important;
}

.menu-on-borders-3 {
    border: 10px solid #1b1c1b;
    right: 0!important;
    top: calc(50% - 110px)!important;
}

.menu-on-borders-2-2 {
    border: 10px solid #1b1c1b;
    left: 0!important;
    bottom: 40px!important;
}

.menu-on-borders-3-2 {
    border: 10px solid #1b1c1b;
    right: 0!important;
    bottom: 40px!important;
}

.menu-on-borders-4 {
    border: 10px solid #1b1c1b;
}

#menu-on {
    display: block;
}

#menu-off {
    display: none;
}

/* CONTENT */

.reithinger-content-wrap {
    margin: 10px 0;
    border: 5px solid #bfd6de;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    position: relative;
}

.reithinger-content {
    display: flex;
    flex-direction: column;
    border: 5px solid #bfd6de;
}

.reithinger-content-p-big {
    width: 100%;
    padding: 50px 20%;
}

.reithinger-content-p {
    /*padding: 50px;  xxx */
    padding: 20px 50px;
}

.reithinger-content :is(a) {
    color: #505356;
}

/* WELCOME */

#reithinger-content-1 {
    width: 100%;
    position: relative;
}

#reithinger-content-2 {
    /*width: 50%;*/
    width: 40%;
}

#reithinger-content-3 {
    width: 30%;
}

#reithinger-content-4 {
    /*width: 20%;*/
    width: 30%;
}

#reithinger-content-5 {
    width: 50%;
    padding: 0;
}

#reithinger-content-5 > h2 {
    width: 100%;
    height: 100%;
}

#reithinger-content-5 > h2 > a {
    padding: 20px 50px;
    width: 100%;
    height: 100%;
    display: block;
}

#reithinger-content-6 {
    width: 50%;
    padding: 0;
}

#reithinger-content-6 > h2 {
    width: 100%;
    height: 100%;
}

#reithinger-content-6 > h2 > a {
    padding: 20px 50px;
    width: 100%;
    height: 100%;
    display: block;
}

#reithinger-content-2:hover,
#reithinger-content-3:hover,
#reithinger-content-4:hover,
#reithinger-content-5:hover,
#reithinger-content-6:hover,
.reithinger-content.slick-slide:hover,
.reithinger-content-verkauf:hover,
.reithinger-content-immobilienangebot:hover,
.reithinger-toggle-immobilien-suche:hover {
    background-color: #ccebf4;
}

.reithinger-content-2-colums {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

.reithinger-content-2-colums > ul {
    width: 50%;
    margin-top: 20px;
}

#reithinger-footer {
    background-color: #131619;
    padding: 60px 120px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

/* SEARCH */

#immobilien-suche {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.immobilien-suche-element {
    width: calc(100% / 7);
    padding: 20px 0 0 0;
}

.immobilien-suche-button {
    position: absolute;
    background-color: #bfd7dd;
    /*width: calc(100% / 12);*/
    width: 100px;
    padding: 10px;
    border: none;
    /*right: calc(100% / 12 + 50px);*/
    bottom: 20px;
}

.immobilien-suche-zuruecksetzen {
    position: absolute;
    background-color: #bfd7dd;
    /*width: calc(100% / 12);*/
    width: 100px;
    padding: 10px;
    border: none;
    /*right: calc(100% / 12 + 50px);*/
    bottom: 20px;
    right: 170px;
}

.immobilien-suche-arrow {
    transform: rotate(270deg);
    display: block;
    float: right;
}

.immobilien-suche-arrow-toggle {
    transform: rotate(90deg)!important;
}

.reithinger-toggle-immobilien-suche > h2 {
    cursor: pointer;
}

.immobilien-suche-part {
    display: flex;
    margin-top: 10px;
}

.immobilien-suche-part > label {
    margin: 0 5px;
}

/* FOOTER */

.reithinger-footer-ul {
    width: 33.33%;
}

.reithinger-footer-ul:last-of-type {
    padding: 16px 0 0 0;
}

.reithinger-footer-ul :is(li, a) {
    color: #fff;
}

/* MAKLERSERVICE */

.reithinger-content-maklerservice {
    width: 100%;
}

.reithinger-content-maklerservice > img {
    width: 100%;
    height: auto;
    padding: 20px;
}

.reithinger-maklerservice-mobile {
    display: none;
}

.maklerservice-h2 {
    padding: 50px 20%;
}

/* ÜBER UNS */

.reithinger-content-ue-leer {
    width: 20%;
}

.reithinger-content-ue-pers {
    width: 30%;
    position: relative;
}

.reithinger-content-p.reithinger-content-ue-pers {
    padding: 20px 40px;
}

.reithinger-content-ue-pers > img {
    width: 100%;
}

/* IMMOBILIE */

.reithinger-content-verkauf {
    flex-direction: row;
    /*width: calc(100% / 8);*/
    min-width: 33.33%;
    text-align: center;
    justify-content: center;
}

.reithinger-content-verkauf > a {
    padding: 20px 0;
    width: 100%;
    height: 100%;
}

::-webkit-scrollbar {
    display: none;
}

#reithinger-immobilienangebot-wrapper {
    width: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    /*max-height: 100vh;*/
    max-height: 90vh;
    overflow: scroll;
    -moz-box-shadow: inset 0 -200px 400px -200px grey;
    -webkit-box-shadow: inset 0 -200px 400px -200px grey;
    box-shadow: inset 0 -200px 400px -200px grey;
    position: relative;
    scroll-behavior: smooth;
}

#scroll-top.immoangebote {
    z-index: 10;
    position: absolute;
}

#scroll-top {
    display: none;
    position: fixed;
    right: 20px;
    bottom: 120px;
    width: 70px;
    height: 70px;
    background: white;
    border: 2px solid #58585a;
}

#scroll-top:hover {
    background-color: #ccebf4;
}

#scroll-top > a {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

#scroll-top > a > img {
    transform: rotate(90deg);
}

.reithinger-content-immobilienangebot {
    width: 50%;
    flex-direction: row;
    flex-wrap: wrap;
}

.reithinger-content-immobilienangebot > a {
    flex-direction: row;
    display: flex;
    height: 100%;
    width: 100%;
    padding: 10px 30px;
}

.reithinger-content-immobilienangebot > a > div:first-of-type {
    width: 50%;
    padding-right: 30px;
}

.reithinger-content-immobilienangebot > a > div {
    width: 50%;
}

.reithinger-content-immobilienangebot > a > div > img {
    width: 100%;
    height: auto;
}

.reithinger-content-immobilie {
    flex-wrap: wrap;
    flex-direction: row;
    padding: 10px;
    width: 100%;

    -moz-box-shadow: inset 0 -200px 400px -200px grey;
    -webkit-box-shadow: inset 0 -200px 400px -200px grey;
    box-shadow: inset 0 -200px 400px -200px grey;
}

.reithinger-content-immobilie > div {
    width: 50%;
}

.reithinger-content-immobilie > div:first-of-type {
    padding: 10px 30px;
}

.reithinger-content-immobilie > div > img {
    width: 100%;
    height: auto;
}

/* KONTAKTFORMULAR */

.kontaktformular-element {
    display: flex;
    flex-direction: column;
}

.kontaktformular-input {
    max-width: 100%;
    padding: 10px;
    font-size: 20px;
    bordeR: 1px solid #505356;
}

.kontaktformular-button {
    background-color: #bfd7dd;
    width: 100px;
    padding: 10px;
    border: none;
}

/* Slider Home */

.reithinger-content-slider-control {
    display: flex;
    justify-content: center;
    align-items: center;
}

.reithinger-content-slider-prev {
    width: calc(2.5% - 2.5px);
}

.reithinger-content-slider-next {
    width: calc(2.5% + 2.5px);
    border-left: 10px solid #bfd6de;
}

.reithinger-content-slider-element {
    position: relative;
    padding: 20px;
    height: 100%;
    width: 100%;
}

.reithinger-content-slider-element-stamp {
    position: absolute;
    right: 10px;
    top: 10px;
    width: 80px;
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #1e92d0;
}

.reithinger-content-slider-element-stamp > p {
    color: #fff!important;
}

.slider-wrapper-home {
    width: 95%;
    margin: 0 auto;
    overflow: hidden;
}

.slider-wrapper-home .slider {
    position: relative;
}

.slider-wrapper-home .slick-track {
    display: flex;
}

.reithinger-content-slider-control.next > img {
    transform: rotate(180deg);
}

.reithinger-content-slider-control.prev:hover {
    cursor: pointer;
}

.reithinger-content-slider-control.next:hover {
    cursor: pointer;
}

/* Slider Immobilie Detailseite */

.slider-wrapper-immobilie {
    width: 100%;
    margin: 0 auto;
    overflow: hidden;
    position: relative;
}

.slider-wrapper-immobilie .slick-track {
    display: flex;
}

.slider-wrapper-immobilie .slick-track .slick-slide {
    text-align: center;
    overflow: hidden;
    height: calc(100vh - 70px);
}

.slider-wrapper-immobilie .slick-track .slick-slide > img {
    max-height: 100%;
    max-width: 100%;
    width: auto;
    height: auto;
}

.slider-dots-immobilien .slick-dots {
    display: flex;
    justify-content: center;
    margin: 0;
    padding: 1rem 0;
    flex-wrap: wrap;
    list-style-type: none;
}

.slider-dots-immobilien .slick-dots li {
    margin: 0 0.25rem 10px 0.25rem;
}

.slider-dots-immobilien .slick-dots button {
    display: block;
    width: 1.2rem;
    height: 1.2rem;
    padding: 0;
    border: none;
    background-color: #969697;
    font-family: 'Roboto';
    color: white;
    cursor: pointer;
}

.slider-dots-immobilien .slick-dots li.slick-active button {
    background-color: #58585a;
}

.next-immo > img {
    transform: rotate(180deg);
}

.prev-immo:hover {
    cursor: pointer;
}

.next-immo:hover {
    cursor: pointer;
}

/*.slider-immobilien-popup-button {*/
/*    display: flex;*/
/*    justify-content: center;*/
/*}*/

/*.slider-immobilien-popup-button > button {*/
/*    background-color: #bfd7dd;*/
/*    padding: 10px;*/
/*}*/

.slider-immobilien-popup {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%!important;
    max-width: 1440px;
    margin: auto;
    background: rgb(0 0 0 / 70%);
    z-index: 100;
}

#map {
    margin-top: 20px;
}

@media screen and (max-width: 1500px) {

    #reithinger-content-2 {
        width: 100%;
    }

    #reithinger-content-3 {
        width: 50%;
    }

    #reithinger-content-4 {
        width: 50%;
    }

    .reithinger-content-verkauf {
        width: calc(100% / 4);
    }

}

@media screen and (max-width: 1440px) {

    .immobilien-suche-element {
        min-width: 25%;
    }

    #immobilien-suche {
        justify-content: flex-start;
    }

    .immobilien-suche-button {
        right: 50px;
    }

    .immobilien-suche-zuruecksetzen {
        right: 50px;
    }

    #reithinger-menu {
        position: fixed;
        border: 20px solid white;
    }

    #reithinger-menu > ul {
        width: unset;
    }

    .reithinger-content-ue-pers {
        width: 40%;
        position: relative;
    }

    .reithinger-content-ue-leer {
        width: 10%;
    }

    .reithinger-content-ue-pers.reithinger-content-p {
        padding: 10px;
    }

    .reithinger-content-p-big, .maklerservice-h2 {
        padding: 50px 10%;
    }

}

@media screen and (max-width: 1024px) {
    #reithinger-header-logo {
        width: 120px;
        height: 110px;
        border: 10px solid transparent;
        border-top: none;
    }

    #reithinger-header-logo > img {
        width: 100%;
        height: auto;
    }
}

@media screen and (max-width: 970px) {

    #reithinger-header-logo {
        width: 80px;
        height: 70px;
    }

    .Ueberschrift-1 {
        font-size: 40px;
        line-height: 40px;
    }

    .Ueberschrift-2 {
        font-size: 40px;
        line-height: 40px;
    }

    .immobilie-überschrift {
        font-size: 25px;
        line-height: 25px;
    }

    .menu-text {
        font-size: 20px;
        line-height: 30px;
    }

    .content-text {
        font-size: 18px;
        line-height: 25px;
    }

    .margin-top-menu {
        margin-top: 20px;
    }

    .immobilien-suche-element {
        width: calc(100% / 3);
    }

    .immobilien-suche-button {
        width: 100px;
    }

    .slider-wrapper {
        width: 90%;
    }

    .reithinger-content-slider-prev {
        width: calc(5% - 2.5px);
    }

    .reithinger-content-slider-next {
        width: calc(5% + 2.5px);
    }

    .reithinger-content-2-colums > ul {
        width: 100%;
    }

    #reithinger-content-3 {
        width: 100%;
    }

    #reithinger-content-4 {
        width: 100%;
    }

    #reithinger-footer {
        padding: 30px 60px;
        justify-content: flex-end;
    }

    .reithinger-footer-ul {
        width: 50%;
    }

    .reithinger-content-verkauf {
        width: calc(100% / 2);
    }

    .reithinger-content-immobilienangebot {
        width: 100%;
    }

    .reithinger-content-immobilienangebot > a {
        padding: 20px;
    }

    .reithinger-content-ue-leer {
         width: 0;
         display: none;
     }

    .reithinger-content-ue-pers {
        width: 50%;
    }

    .reithinger-content-p {
        padding: 20px;
    }

    .reithinger-content-verkauf > a .name-text {
        font-size: 25px;
        line-height: 25px;
    }

    #reithinger-content-5 > h2 > a, #reithinger-content-6 > h2 > a {
        padding: 20px;
    }

    .reithinger-content-immobilie > div:first-of-type {
        padding: 10px;
    }

    .immobilien-suche-button {
        right: 20px;
    }

    .immobilien-suche-zuruecksetzen {
        right: 140px;
    }

    .reithinger-content-p.reithinger-content-ue-pers {
        padding: 10px;
    }

}

@media screen and (max-width: 768px) {
    #reithinger-menu {
        border: none;
    }

    .reithinger-maklerservice-desktop {
        display: none;
    }

    .reithinger-maklerservice-mobile {
        display: block;
    }

    .reithinger-content-maklerservice > img {
        padding: 10px;
    }

    .reithinger-header-bg-desktop {
        display: none;
    }

    .reithinger-header-bg-mobile {
        display: block;
    }
}

@media screen and (max-width: 600px) {

    #reithinger-header-logo {
        width: 60px;
        height: 60px;
        margin: unset;
        left: unset;
        border-top: 10px solid #1b1c1b!important;
    }

    #reithinger-header > h1 {
        bottom: 10px;
    }

    #reithinger-header-farbbalken-links,
    #reithinger-header-farbbalken-links-2,
    #reithinger-header-farbbalken-rechts,
    #reithinger-header-farbbalken-rechts-2,
    #reithinger-header-kontakt,
    #reithinger-header-kontakt-2 {
        display: none;
    }

    .Ueberschrift-1 {
        font-size: 30px;
        line-height: 30px;
    }

    .Ueberschrift-2 {
        font-size: 30px;
        line-height: 30px;
    }

    .name-text {
        font-size: 25px;
        line-height: 25px;
    }

    .margin-top-menu {
        margin-top: 0;
    }

    .slider-wrapper {
        width: 80%;
    }

    .reithinger-content-slider-prev {
        width: 10%;
    }

    .reithinger-content-slider-next {
        width: 10%;
        border-left: 5px solid #bfd6de;
    }

    .immobilien-suche-element {
        width: 50%;
    }

    #reithinger-content-5, #reithinger-content-6 {
        width: 100%;
    }

    #reithinger-footer {
        padding: 20px;
    }

    .reithinger-footer-ul {
        width: 100%;
    }

    .reithinger-footer-ul:nth-of-type(2) {
        padding: 16px 0 0 0;
    }

    .reithinger-footer-ul:last-of-type {
        padding: 0;
    }

    .reithinger-content-verkauf {
        padding: 10px;
        min-width: 50%;
    }

    .reithinger-content-verkauf:nth-last-of-type(2):nth-of-type(odd) {
        min-width: 100%;
    }

    .reithinger-content-verkauf > a {
        padding: 0;
    }

    .reithinger-content-verkauf > a .name-text {
        font-size: 20px;
        line-height: 20px;
    }

    .reithinger-content-immobilienangebot > a {
        flex-wrap:  wrap;
    }

    .reithinger-content-immobilienangebot > a > div {
        width: 100%;
    }

    .reithinger-content-immobilienangebot > a > div:first-of-type {
        padding-right: 0;
    }

    .reithinger-content-immobilienangebot > a > div:last-of-type {
        padding-top: 30px;
    }

    .reithinger-content-immobilie > div {
        width: 100%;
    }

    .reithinger-content-ue-pers {
        width: 100%;
    }

    .reithinger-content-p-big, .maklerservice-h2 {
        padding: 20px;
    }

    .immobilien-suche-zuruecksetzen {
        right: 20px;
        bottom: 75px;
    }

    #scroll-top {
        bottom: 180px;
    }

}

@media screen and (max-width: 450px) {

    .immobilien-suche-element {
        width: 100%;
    }

    .reithinger-content-verkauf {
        min-width: 100%;
        display: none;
    }

}