:root {
    --h1-size: 26px;
    --h2-size: 24px;
    --h3-size: 18px;
    --h4-size: 17px;
    --h5-size: 12px;
    --h6-size: 10px;
    --p-size: 15px;

}

html {
    height: 100%;
}

body {
    height: 100%;
    margin: 0px;
    font-family: 'Open Sans';
    font-weight: 400;
    font-size: 15px;
    background-color: #fff;
}

h1 {
    font-family: 'Open Sans';
}

h2, h3, h4, h5, h6 {
    font-family: 'Open Sans', sans-serif;
    font-weight: 200;
}

a {
    font-weight: 600;
    color: #888;
}

a:hover {
    color: #212529;
    text-decoration: unset;
}

.ra-text p, .ra-text ul, .ra-text {
    font-size: var(--p-size);
    line-height: 25.2px;
}

.ra-title h1 {
    font-size: var(--h1-size);
    letter-spacing: 1px;
    margin-top: 50px;
    font-weight: 200;
    margin-bottom: 20px;
}

.ra-title h2 {
    font-size: var(--h2-size);
    margin-top: 15px;
    margin-bottom: 15px;
}


.ra-title-portfolio h1 {
    font-family: 'Open Sans';
    font-weight: 200;
    letter-spacing: 0px;
    font-size: var(--h1-size);
    text-align: left;
}

.ra-title-portfolio h2 {
    font-weight: 300;
    letter-spacing: 0px;
    margin: 16px 0px;
    font-size: var(--h2-size);
}

.ra-title-portfolio h3 {
    font-weight: normal;
    letter-spacing: 0px;
    margin-bottom: 15px;
    font-size: var(--h3-size);
}

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


.floating-text {
    position: initial;
    margin-top: calc(100vh - 520px);
    margin-left: calc(100vw - 585px);
    max-width: 500px;
    max-height: 350px;
    background-color: rgba(116, 110, 101, 0.7);
    padding: 15px;
    color: #e5e5e5;
}

.floating-text h1 {
    font-size: var(--h1-size);
}

.floating-text p {
    font-size: var(--p-size);
    max-width: 500px;
    line-height: 20px;
}

.floating-footer-text {
    position: absolute;
    right: 10%;
}

/*#ra-home-bg{*/
/*background-image: url('../images/bg.jpg');*/
/*background-size: cover;*/
/*height: 100%;*/
/*}*/


#ra-home-bg{
    background-image: url('../images/background/bgw.jpg');
    height: 70vh;
    width: 100%;
    background-size: cover;
    background-position-y: center;
    background-position-x: center;
}

#ra-home-bg-text{
    height: 200px;
    background-color: #dcdcdc;
    display: flex;
}

#ra-home-bg-text .container{
    margin-bottom: auto !important;
    margin-top: auto !important;
}

#ra-home-bg-text h1{
    color: #3c3c3b;
    text-align: center;
    font-size: var(--h1-size);
}


#ra-home-txt-m {
    position: absolute;
    bottom: 50px;
    left: calc(50% - 150px);
}

#ra-home-txt-m h1 {
    color: #fff;
    font-weight: 400;
    font-size: var(--h1-size);
    text-align: center;
    width: 300px;
    margin: auto;
    margin-bottom: 5px;
}

#ra-home-txt-m p {
    color: #fff;
    text-align: center;
    font-weight: 200;
    font-size: var(--p-size);
    width: 300px;
    margin: auto;
}

.ra-home-link, .ra-home-link:hover {
    color: #fff;
    font-weight: 200;
    cursor: pointer;
    text-decoration: none;
    display: inline-block;
    font-size: var(--h3-size);
    margin: 50px 50px 20px 0px;
}

.portrait {
    width: 100%;
    cursor: pointer;
}

.ra-header-title p:first-child {
    line-height: 20px;
    font-size: 20px;
    letter-spacing: 1px;
    margin-bottom: 8px !important;
}

.ra-header-title p:last-child {
    letter-spacing: 4px;
    font-size: 20px;
    margin-top: -5px !important;
    line-height: 18px;
}

.ra-nav-style {
    font-family: 'Open Sans' !important;
    font-size: var(--p-size);
    letter-spacing: 0px;
    font-weight: 200;
}

.ra-nav-brand {
    font-family: 'Open Sans' !important;
    letter-spacing: 0px;
    font-weight: 200;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

/*#navbarNavDropdown {*/
/*    position: relative;*/
/*}*/

.dropdown-menu {
    margin-top: 0;
}

@media (max-width: 991px) {
    #navbarNavDropdown {
        position: initial;
    }

    .navbar-nav {
        position: initial;
    }


    .ra-navbar-fixed-height {
        height: auto !important;
    }
}

.ra-navbar-sndlink {
    /*padding: 5px 0 5px 0;*/
    font-size: 20px;
    line-height: 20px;
    position: relative;
    z-index: 10;
}

.ra-navbar-sndlink span {
    position: absolute;
    bottom: .5rem;
}

.ra-purple {
    color: #d62e80 !important;
}

.ra-bg-red {
    background-color: rgb(130, 44, 62);
}


.ra-light-grey {
    color: #EFEFEF !important;
}

.ra-footer {
    height: 60px;
    background-color: #3c3c3b;
}

.ra-grey {
    color: #3c3c3b !important;
}

.ra-white {
    color: #fff !important;
}

.ra-dark-grey {
    color: #212529 !important;
}

.ra-bg-light-grey {
    background-color: #EFEFEF !important;
}

.ra-bg-grey {
    background-color: #3c3c3b !important;
}

ul {
    margin: 0;
}

ul.dashed {
    list-style-type: circle;
    list-style-position: inside;
    padding-left: 24px !important;
}

ul.dashed > li {
    text-indent: -22px;
}

ul.dashed-2 {
    list-style-type: circle;
    padding-left: 0px !important;
}

ul.dashed-2 > li {
    text-indent: 18px;
}


#atelier-slider {
    margin-top: 100px;
    width: 100%;
    max-height: 250px;
    overflow-x: auto;
    white-space: nowrap;
}

#atelier-slider * {
    white-space: normal
}

#atelier-slider img {
    height: 150px;
    margin: 0px 5px;
    display: inline-block;
    vertical-align: top;
}

img.portfolio {
    max-width: 100%;
    transition: .5s ease;
    backface-visibility: hidden;
}

img.portfolio_element {
    max-width: 100%;
    margin-top: 30px;
    margin-bottom: 5px;
}

.portfolio-link, .portfolio-link:active, .portfolio-link:hover, .portfolio-link:visited {
    color: black;
    text-decoration: none;
}

/*.style-3::-webkit-scrollbar-track*/
/*{*/
/*-webkit-box-shadow: inset 0 0 1px rgba(50,50,50,0.3);*/
/*background-color: #F5F5F5;*/
/*}*/

/*.style-3::-webkit-scrollbar*/
/*{*/
/*width: 3px;*/
/*height: 3px;*/
/*background-color: #F5F5F5;*/
/*}*/

/*.style-3::-webbkit-scrollbar-thumb*/
/*{*/
/*background-color: rgb(100,100,100);*/
/*}*/

.light-toggler.navbar-toggler {
    border: 0px;
}

.light-toggler .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(214,64,128, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E");
}

/* ----- Helper classes ----- */

.remove-all-margin {
    margin: 0 ! important;
}

.remove-all-margin-padding {
    margin: 0 ! important;
    padding: 0 ! important;
}

.mt-6 {
    margin-top: 3.5rem !important;
}

.ra-dropdown {
    background-color: #3c3c3b;
    border: 0px;
    border-radius: 0px;
}

.ra-dropdown-item {
    color: #CCC !important;
    padding: 3px 10px;
    font-size: 75%;
}

.ra-dropdown-item:hover {
    color: #3c3c3b !important;
    background-color: #CCCCCC !important;
}

.nav-link {
    font-weight: 200;
}

.nav-link:hover {
    color: #DDD !important;
}

.dropdown-item {
    text-transform: initial;
    line-height: 24px;
    font-size: var(--p-size);
    font-weight: 200;
}

.dropdown-item:hover {
    background-color: initial;
    color: #000000;
}

.dropdown-menu {
    border-radius: 0px;
}

.map-responsive {
    overflow: hidden;
    padding-bottom: 50%;
    position: relative;
    height: 0;
}

.map-responsive iframe {
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    position: absolute;
}

.ra-navbar-fixed-height {
    height: 58px;
}

.ra-navbar-header {
    min-height: 85px;
}
.ra-navbar-footer1 .container:last-child{
    margin-bottom: 0px !important;
}

.ra-navbar-footer2 .container:last-child{
    margin-bottom: 0px !important;
}

.ra-navbar-footer2 a {
    display: inline-block;
}

.ra-footer-ul {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    padding: 0px;
    width: fit-content;
    margin: auto;
}

.ra-footer-item{
    display: inline-block;
    border-right: 1px solid #999;
    padding: 0px 10px 0px 6px;
    margin-left: 0px;
}

.ra-footer-item:last-child{
    border-right: 0px;
}
.ra-footer-item a{
    font-weight: 400;
}

.ra-color-strip {
    width: 100%;
    height: 60px;
}

.ra-cs-blue {
    background-color: #7590AE;
}

.ra-cs-red {
    background-color: #822C3E;
}

.ra-dl {
    background-color: #f6f6f6;
}

.ra-container {
    /*margin-bottom: 100px !important;*/
}

.ra-section {
    padding: 50px 0px;
}

.ra-card-header, .ra-card-footer {
    width: 250px;
    margin: 0px auto;
    background-color: #f2f3f4;
    padding: 20px;
}

.ra-card-footer {

}

.container {
    margin-bottom: 20px !important;
}

.ra-min-height {
    min-height: calc(100vh - 326px);
}

.container-small {
    max-width: 880px;
    padding-right: 15px;
    padding-left: 15px;
}

.ra-card-image {
    width: 250px;
    margin: 0px auto;
}

.ra-card-image img {
    width: 250px;
}

.ra-portrait-image {
    width: 100%;
    margin-top: 5px;
}

.ra-portrait-image img {
    width: 100%;
    object-fit: cover;
}



.ra-card-button {
    border: 5px solid #822c3e;
    background-color: #822c3e;
    color: #efefef;
    cursor: pointer;
    display: inline-block;
    margin-bottom: 10px;
    font-weight: 200;
    padding: 5px 10px;
}

.ra-card-button:hover {
    color: #fff;
    text-decoration: none;
}


.ra-button {
    border: 5px solid #E9E9E9;
    background-color: #EFEFEF;
    color: #822c3e;
    cursor: pointer;
}

.ra-button-kontakt {
    border: 5px solid #3c3c3b;
    background-color: #3c3c3b;
    color: #fff;
    cursor: pointer;
}


.middle {
    transition: .5s ease;
    opacity: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    text-align: center;
    width: 75%;
}


.ra-image:hover img {
    opacity: 0.2;
}

.ra-image:hover .middle {
    opacity: 1;
}

.atelier-item img:hover {
    opacity: 0.6;
    transition: .5s ease;
    cursor: pointer;
}

#portfolio-selector a, #blog-selector a {
    margin: 10px;
    color: #212529;
    font-weight: 200;
    text-decoration: none;
    font-size: var(--h5-size);
    line-height: 22px;
}

#portfolio-selector a:first-of-type, #blog-selector a:first-of-type {
    margin-left: 0px;
}

#portfolio-selector a:hover, #farb-selector a:hover {
    text-decoration: underline;
}


.text p {
    font-size: var(--p-size);
    font-weight: 200;
}
.ra-link-white{
    color: #e9eaeb;
    font-weight: 200;
}
.ra-link-white:hover{
    color: #ffffff;
    font-weight: 200;
}
.ra-link {
    color: #000;
    text-decoration: none;
}

.ra-link:hover {
    color: #555;
    text-decoration: none;
}

.ra-link:visited {
    color: #000;
    text-decoration: none;
}

.sb-n {
    /*height: calc(100vh - 80px); overflow: hidden;*/
}

.unsub-container{
    min-height: calc(100vh - 320px);
}

.atelier-frame {
    width: 100%;
    margin-bottom: 0.5em;
    padding-bottom: 1em;
    position: relative;
    overflow-x: hidden;
    white-space: nowrap;
}

.atelier-frame ul {
    margin: 0;
    padding: 0;
    height: 100%;
    list-style: none;
}

.atelier-frame li.atelier-item {
    cursor: pointer;
    display: inline-block;
    margin: 0 5px 0 0;
    padding: 0;
}

.atelier-frame li.atelier-item img {
    height: 130px;
    width: 195px;
}

#toTopBtn {
    display: none;
    position: fixed;
    bottom: 110px;
    right: 30px;
    z-index: 99;
    font-size: 15px;
    border: none;
    outline: none;
    background-color: #a0a0a0;
    color: white;
    cursor: pointer;
    padding: 5px 10px;
}

#toTopBtn:hover {
    background-color: #555;
}

@media (max-width: 575.98px) {
    .floating-text {
        position: initial;
        margin-top: calc(50vh - 250px);
        max-width: 300px;
        max-height: unset;
        margin-left: calc(50vw - 150px);
        padding: 10px 20px;
    }

    .floating-text h1 {
        font-size: var(--h1-size);
    }

    .floating-text p {
        font-size: var(--p-size);
        max-width: 320px;
        line-height: 15px;

    }

    .floating-footer-text {
        position: initial;
        right: 0;
        font-size: var(--p-size);
    }

    .ra-nav-brand {
        font-size: 17px;
        padding-left: 5px !important;
    }

    .navbar-toggler {
        font-size: 17px;
    }

    .ra-color-strip {
        height: 30px;
    }

    #ra-home-bg-text h1{
        font-size: 18px;
    }
}

@media (min-width: 992px) {

    .pl-c {
        padding-left: 35px;
    }
}

@media (max-width: 991px) {

    .mt-c {
        margin-top: 20px !important;
    }

    .fixed-bottom {
        position: initial !important;
    }

    .fixed-bottom-override-rev {
        position: fixed !important;
    }

    .sb-n {
        /*height: calc(100%); overflow: hidden;*/
    }

    .ra-container {
        margin-bottom: 0px !important;
    }

    .dropdown-menu {
        background-color: #3c3c3b;
        border: 0px;
        padding-top: 0px;
    }

    .dropdown-item {
        color: #DDDDDD !important;
        line-height: 20px;
    }

    .dropdown-item span {
        max-width: calc(100vw - 60px);
        display: block;
        white-space: normal;
        font-weight: 200;
    }

}

@media (min-width: 1400px) {
    .d-custom-block {
        display: block !important;
    }
}

.text-highlighted {
    color: #822c3e;
}


/* Remove dropdown caret */
.dropdown-toggle::after {
    display: none;
}

.element-center {
    margin: auto;
    max-width: 1140px;
}

.hide-robot {
    display: none;
}

.ra-form-input {
    padding: 5px;
    width: 250px;
    margin: 5px 0px;
    border: 1px solid #E9E9E9;
    background-color: #EFEFEF;
}

.ra-form-input::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
    color: #212529;
    opacity: 1; /* Firefox */
}

.ra-form-label {
    vertical-align: top;
}

.ra-form-checkbox-wrapper {
    margin-top: 5px;
}

.ra-form-checkbox {
    margin-right: 5px;
}


.ra-form-input-kontakt {
    padding: 5px;
    width: 100%;
    margin: 5px 0px;
    border: 1px solid #E9E9E9;
    background-color: #EFEFEF;
}

.ra-form-input-kontakt::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
    color: #212529;
    opacity: 1; /* Firefox */
}


.ra-blog-divider {
    border-color: #822c3e;
}

.ra-blog-row {
    padding: 15px;
}

.ra-blog-preview-img {
    padding: 0px;
}

.ra-blog-preview-img img {
    width: 100%;
}

.ra-blog-title {
    font-weight: 400;
    margin-top: 20px;
}

.ra-blog-date {
    color: #3c3c3b;
}

.ra-blog-preview {
    padding-left: 20px;
}

.ra-blog-date-header p {
    vertical-align: center;
    border-bottom: 1px solid #822c3e;
    padding-bottom: 10px;
}

.ra-image-30 {
    width: 30%;
}

.ra-image-50 {
    width: 50%;
}

.ra-image-65 {
    width: 65%;
}

.ra-image-70 {
    width: 70%;
}

.ra-image-80 {
    width: 80%;
}

.ra-image-90 {
    width: 90%;
}

.ra-image-95 {
    width: 95%;
}

.ra-image-100 {
    width: 100%;
}

.ra-hr {
    border-color: #822c3e;
}

.ra-autosize-right{
    height: calc(100% - 35px);
    background-image: url('');
    background-size: cover;
    margin-top: 30px;
    margin-bottom: 5px;
}
.tracking-container{
    position: fixed;
    bottom: 0;
    background-color: rgba(255,255,255, 0.95);
    border-top: 1px solid #bbbbbb;
    width: 100%;
    z-index: 11000;
}

.tracking-link{
    font-size: 12px;
    font-weight: 200;
    cursor: pointer;
}

.my-big {
    margin-bottom: 2rem!important;
    margin-top: 2rem!important;
}


.mt-big {
    margin-top: 4rem !important;
}

.cmb-5, .cmy-5 {
    margin-bottom: 5px;
}
.cmt-5, .cmy-5 {
    margin-top: 5px;
}

.cmb-10, .cmy-10 {
    margin-bottom: 10px;
}
.cmt-10, .cmy-10 {
    margin-top: 10px;
}

.cmb-15, .cmy-15 {
    margin-bottom: 15px;
}
.cmt-15, .cmy-15 {
    margin-top: 15px;
}

.cmb-20, .cmy-20 {
    margin-bottom: 20px;
}
.cmt-20, .cmy-20 {
    margin-top: 20px;
}

.cmb-25, .cmy-25 {
    margin-bottom: 25px;
}
.cmt-25, .cmy-25 {
    margin-top: 25px;
}

.cmb-30, .cmy-30 {
    margin-bottom: 30px;
}
.cmt-30, .cmy-30 {
    margin-top: 30px;
}

.cmb-35, .cmy-35 {
    margin-bottom: 35px;
}
.cmt-35, .cmy-35 {
    margin-top: 35px;
}

.cmb-40, .cmy-40 {
    margin-bottom: 40px;
}
.cmt-40, .cmy-40 {
    margin-top: 40px;
}

.cmb-45, .cmy-45 {
    margin-bottom: 45px;
}
.cmt-45, .cmy-45 {
    margin-top: 45px;
}

.cmb-50, .cmy-50 {
    margin-bottom: 50px;
}
.cmt-50, .cmy-50 {
    margin-top: 50px;
}

.cmb-55, .cmy-55 {
    margin-bottom: 55px;
}
.cmt-55, .cmy-55 {
    margin-top: 55px;
}

.cmb-60, .cmy-60 {
    margin-bottom: 60px;
}
.cmt-60, .cmy-60 {
    margin-top: 60px;
}

.calendly-inline-widget {
    position: relative;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    min-width: 320px;
    height: 1100px;
    left: -30px;
}