@font-face {
    font-family: "Titillium Web";
    src: url("../fonts/Roboto-Regular.ttf") format("truetype");
    font-weight: 400;
}

* {
    margin: 0;
    padding: 0;
    border: 0;
    text-decoration: none
}

html {
    width: 100%;
    height: 100%;
}

body {
    font-family: 'Roboto', sans-serif;
    font-size: 15px;
    line-height: 20px;
    color: #706f6f;
    background-color: #fff;
    -moz-text-size-adjust: 100%;
    font-smoothing: antialiased;
    text-rendering: optimizelegibility
}

a {
    color:#ff7f33;
    text-decoration: none;
}
h1 {
    font-size: 133%;
    line-height: 115%;
    text-transform: uppercase;
    font-weight: normal;
    margin-bottom:15px;
    color:#ff7f33;
}
h2 {
    font-size: 120%;
    line-height: 105%;
    text-transform: uppercase;
    font-weight: normal;
    margin-bottom:10px;
    color:#ff7f33;
}
h2.withline {
    border-top: solid 1px #706f6f;
    text-transform: none;
    padding: 10px 0 23px 0;
    margin:0;
}
h2.noline {
    text-transform: none;
    padding: 10px 0 23px 0;
    margin:0;
}

h3 {
    font-size: 113%;
    line-height: 100%;
    font-weight: normal;
    margin-bottom:10px;
    color:#ff7f33;
}
h5 {
    font-size:100%;
    font-weight:normal;
    font-style:italic;
}
h5 em {
    font-size: 80%;
}

.nomargin {
    padding-bottom: 0 !important;
}

.nobr	{
    white-space:nowrap;
}

/*************
header
**************/

section.header {
    display:flex;
    margin: 0 auto;
    padding: 0 0 40px 0;
    max-width: 1240px;
    width: 100%;
    justify-content: space-between;
    font-size: 86%;
}
img.logo {
    padding:13px 0 0 72px;
}

table.header {
    padding-top:23px;
}
table.header td {
    padding:0 28px 0 23px;
    border-left: 1px solid #706f6f;
    vertical-align: top;
}
table.header td:first-child {
    border-left: none;
}
table.header td a{
    color: #706f6f;
    text-decoration: none;
}
table.calltime td {
    border-left:none;
    padding: 0 5px 0 0 !important;
    vertical-align: top;
}
div.mobilesearch {
    background-color: #eeeeee;
    padding: 5px 10px 5px 10px;
    display:none;
}
a.fontsmall {
    font-size: 15px;
    padding: 5px 5px 5px 0;
    display: inline-block;
}
a.fontmedium {
    font-size: 20px;
    padding: 5px 5px 5px 5px;
    display: inline-block;
}
a.fontlarge {
    font-size: 25px;
    padding: 5px 5px 5px 5px;
    display: inline-block;
}

/**********************
navigation
**********************/
nav {
    display:flex;
    margin: 0 auto;
    padding: 0 0 17px 0;
    max-width: 1240px;
    width: 100%;
    justify-content: space-between;
}
nav ul {
    list-style: none;
    margin: 0;
    padding-left: 134px;
}
nav ul li:before {
    content: "";
}

nav ul li {
    display: inline-block;
    margin-left: 10px;
    position:relative;
    margin-top:10px;
    padding-left:0;
}
nav ul li:first-child {
    margin-left:5px;
}
nav ul li a {
    color: #706f6f;
    text-transform: uppercase;
    font-size: 93%;
}
nav ul li a.active,
nav ul li a:hover {
    color: #ff7f33;
}

nav .topmenu ul{
    display:none;
    position: absolute;
    padding-left: 0;
    z-index: 2000;
    background-color: #eeeeee;
    margin-top:0;
    border-top: solid 17px #fff;
}
.topmenu:hover ul {
    display: block;
}
.topmenu:hover ul {
    display: block;
}

nav .topmenu ul li {
    margin:0 0 0 -10px;
    background-color: #eeeeee;
    padding: 5px 10px 5px 10px;
    white-space:nowrap;
}



nav form {
    background-color: #eeeeee;
    padding: 3px 0 3px 10px;
}
nav input[type=text],
.mobilesearch input[type=text],
div.input input[type=text],
div.tx-indexedsearch-searchbox input[type=text],
div.input textarea {
    background-color: #eeeeee;
    padding: 3px 5px 3px 5px;
    width: 140px;
    color: #706f6f;
    font-size: 100%;
    font-family: 'Roboto', sans-serif;
}

.form-group label {
    display: none;
}
div.input input[type=text],
div.input textarea {
    margin-bottom: 10px;
    width:300px;
}
div.input textarea {
    height: 100px;
}
button.btn {
    background-color: #706f6f;
    color: #fff;
    padding: 3px 5px 3px 5px;
    text-transform: uppercase;
    cursor: pointer;
    font-size: 100%;
}

nav.subnavi ul li:first-child {
    margin-left: 0;
}
nav.subnavi ul li {
    background-color: #eeeeee;
    padding: 5px 7px 5px 7px;
    margin-top:5px;
    margin-left: 0;
    margin-right: 10px;
}
nav.subnavi ul li a {
    font-size: 86%;
}
nav.subnavi ul li:hover,
nav.subnavi ul li.active {
    background-color: #a8a8a7;
}
nav.subnavi ul li:hover a,
nav.subnavi ul li.active a {
    color: #fff;
}
nav.subnavi {
    margin-bottom: 30px;
}


/**************
content
***************/
div.main {
    margin: 0 auto;
    padding: 0;
    max-width: 1240px;
    width: 100%;
}
section.slider {
    padding-bottom: 30px;
    position: relative;
}
section.slider ul li:before {
    content: "";
}
section.slider ul li {
    padding-left:0;
}

div.notice {
    width: 300px;
    height: 300px;
    border-radius: 150px;
    background-color: #3c3c3b;
    position: absolute;
    right:-60px;
    bottom:80px;
    background-image: url(../images/stab.png);
    background-repeat: no-repeat;
    background-position: 100px 15px;
    z-index: 5000;
}

div.noticemobilewrap .notice {
    width: 300px;
    height: 300px;
    border-radius: 150px;
    background-color: #3c3c3b;
    background-image: url(../images/stab.png);
    background-repeat: no-repeat;
    background-position: 100px 15px;
    display: inline-block;
    position: static;
}

div.noticemobilewrap {
    text-align:center;
    margin: 20px;
    display: none;
}



div.notice-inner {
    padding: 70px 30px 50px 55px;
    color: #c5c5c5;
    font-size: 93%;
    text-align: left;
}
div.notice-inner p, .twocol p, .content p{
    padding-bottom: 10px;
}

div.notice-inner h3 {
    color: #ff7f33;
    font-weight: normal;
    font-size: 120%;
}


.slider img {
    max-width: 100%;
}

div.onecol {
    float:left;
    width:33.3333%;
}
div.twocol {
    float:left;
    width:65%;
}

.content {

     padding: 0 134px 0 134px;
 }

.content.layout2 {

    padding: 20px 20px 20px 20px;
}

.portfolio {
    color:#ff7f33;
    padding-left: 10px;
}
section.intro {
    padding-bottom:61px;
    display:flex;
    justify-content: space-between;
}
.clear {
    clear: both;
    display: block;
    overflow: hidden;
    visibility: hidden;
    width: 0;
    height: 0
}
.onecol img, .twocol img {
    width: 100%;
}
.teaserlist {
    border-top: solid 1px #706f6f;
    padding-top: 44px;
    display:flex;
    justify-content: left;
    flex-flow: row wrap;
}
.teaserlist .teaser {
    width:32%;
    padding-bottom: 60px;
    padding-right: 2%;
}
.teaserlist .teaser.no-padding-right {
    padding-right: 0;
}
.teaserlist .teaser p {
    font-size: 86%;
}
.teaser img {
    padding-bottom: 17px;
    max-width:100%;
    height: auto;
}
.firstteaser .teasertext {
    padding-left: 10px;
}
.noborder {
    border: none;
}

.teaserlist.noborder {
    padding-top: 15px;
    margin-bottom: 30px;
}
.teaserlist.noborder img {
    padding-bottom: 17px;
    max-width:100%;
}
.teaserlist.noborder a {
    display: inline-block;
    max-width: 32%;
}

table td {
    vertical-align: top;
}

.line {
    border-top: solid 1px #706f6f;
    height: 1px;
    margin: 20px 0 20px 0;
}
hr.ce-div {
    border-top: solid 1px #706f6f;
    height: 1px;
    margin: 20px 0 20px 0;
}

table.philosophie {
    width: 90%;
}
table.philosophie td:first-child {
    padding-right: 30px;
}
table.philosophie td:last-child {
    padding-top: 20px;
}
table.philosophie td {
    vertical-align: top;
}

table.vita td:first-child {
    min-width: 90px;
    padding-right: 20px;
}
.content.vita,
.content.layout1 {
    max-width: 817px;
}

.teaserlist.team {
    padding-top: 15px;
    border: none;
    flex-direction: row;
    justify-content: flex-start;
}
.teaserlist.team img {
    padding-bottom: 10px;
}

.foldout {
    border-top: solid 1px #706f6f;
    width: 80%;
}

.layout1 .foldout {
    width: 90%;
}

.foldout a {
    display: block;
    color: #706f6f;
    padding: 5px 0 5px 0;
}
.foldout p {
    padding: 5px 0 5px 0;
}
.foldout a.open {
    color:#ff7f33;
}
.foldout a i {
    float: right;
    color: #706f6f;
}
.foldout-inner {
    display:none;
    padding: 0 0 8px 0;
}
.foldout.last {
    border-bottom: solid 1px #706f6f;
}

ul {
    list-style: none;
    padding: 0;
}
ol li {
    margin-left: 15px;
}
ul li {
    padding-left: 13px;
}
section.content ul li:before {
    content: "\f068"; /* FontAwesome Unicode */
    font-family: FontAwesome;
    font-size: 8px;
    display: inline-block;
    margin-left: -1.3em; /* same as padding-left set on li */
    width: 11px; /* same as padding-left set on li */
}

.ce-above .ce-gallery {
    margin-bottom: 0;
}
.ce-column {
    margin-right: 0;
}

.rslides {
    position: relative;
    list-style: none;
    overflow: hidden;
    width: 100%;
    padding: 0;
    margin: 0;
}

.rslides li {
    -webkit-backface-visibility: hidden;
    position: absolute;
    display: none;
    width: 100%;
    left: 0;
    top: 0;
}

.rslides li:first-child {
    position: relative;
    display: block;
    float: left;
}

.rslides img {
    display: block;
    height: auto;
    float: left;
    width: 100%;
    border: 0;
}
.rslides_nav.next {
    right: 0;
}
.rslides_nav {

    position: absolute;
    box-sizing: border-box;
    padding: 15px 10px 15px 10px;
    top: 45%;
    height: 50px;
    background-color:#706f6f;
    font-weight: normal;
    font-size: 20px;
    z-index: 99;
    color:#fff;
    opacity: 0.3;

}
.rslides_tabs {
    width: 100%;
    text-align:center;
    position:absolute;
    bottom:40px;
    z-index:99;
}
.rslides_tabs li {
    display: inline;
    float: none;
}
.rslides_tabs li a {
    color: #706f6f;
    opacity: 0.5;
    padding:0 5px 0 5px;
    visibility: hidden;
    display:inline-block;
    width:15px;
}
.rslides_tabs li.rslides_here a {
    opacity: 1;
}
.rslides_tabs li a::before {
    content: "\f111";
    font-family: FontAwesome;
    visibility: visible;
    margin-right: -10px;
}



.newsitem {
    border-bottom: solid 1px #706f6f;
    margin: 0 0 20px 0;
    padding: 0 0 10px 0;
}
.newsitem:last-child {
    border-bottom: none;
}

#route_form input[type=text],
#bmiform input[type=text]{
    background-color: #eeeeee;
    padding: 3px 5px 3px 5px;
    width: 140px;
    color: #706f6f;
    font-size: 100%;
    font-family: 'Roboto', sans-serif;
    margin-bottom: 10px;
}

#route_form input[type=submit],
.tx-indexedsearch-searchbox input[type=submit],
#bmiform input[type=button]{
    background-color: #706f6f;
    color: #fff;
    padding: 3px 5px 3px 5px;
    text-transform: uppercase;
    cursor:pointer;
}
#bmiform label,
.tx-indexedsearch-form label {
    width: 120px;
    display: inline-block;
}
#bmiform input[type=text] {
    width: 50px;
}
#bmiform input[type=button],
.tx-indexedsearch-searchbox input[type=submit]{
    margin-left: 123px;
}
#bmiform {
    margin-bottom:30px;
}

#plz {
    width: 70px !important;
}
.route_label {
    margin-bottom: 7px;
    display: inline-block;
}

.route_form {
    margin-bottom: 15px;
}
.route_div {
    margin-bottom: 30px;
}
table.bmi td {
    padding: 3px;
    border-bottom: 1px solid #D9DADC;
    border-right: 1px solid #D9DADC;
}
table.bmi {
    margin-bottom: 30px;
}
table.bmi td.no_border {
    border-right: 0;
}
.tx-indexedsearch-searchbox legend {
    display:none;
}
.tx-indexedsearch-form {
    margin-bottom: 10px;
}
.tx-indexedsearch-searchbox {
    margin-bottom:20px;
}
.tx-indexedsearch-text-item-size,
.tx-indexedsearch-text-item-crdate,
.tx-indexedsearch-text-item-mtime,
dt.tx-indexedsearch-text-item-path{
    display: none;
}
.tx-indexedsearch-res {
    margin-bottom: 20px;
}
.tx-indexedsearch-browsebox {
    margin-bottom: 10px;
}
.tx-indexedsearch-percent {
    display:none;
}

div#kontakt-181 {
    font-weight: bold;
    padding-top: 20px;
}
.ce-gallery img {
    max-width:100%;
    height: auto !important;
}

/**************
footer
************************/

footer {
    margin: 0 auto 0 auto;
    padding:0 0 30px 0;
    max-width: 1240px;
    width: 100%;
    background-color:#f5f5f5;
    font-size:86%;
}
div.footer-wrap {
    background-color:#f5f5f5;
    width:100%;
}
footer .row {
    padding: 33px 10px 50px 10px;
    display:flex;
    justify-content: space-between;
}
.footer-item {
    border-left: solid 1px #706f6f;
    padding:0 20px 0 20px;
}
.footer-item a {
    color: #706f6f;
}
.flex {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}
.padding20 {
    padding-right: 20px;
}


a.bmi {
    background-image: url(../images/bmi.png);
    background-repeat: no-repeat;
    background-position: left 3px;
    padding: 0 0 0 30px;
    text-decoration: none;
    color: #706f6f;
    text-transform: uppercase;
}
a.pollen {
    background-image: url(../images/pollen.png);
    background-repeat: no-repeat;
    background-position: left 3px;
    padding: 5px 0 8px 30px;
    line-height: 3em;
    text-decoration: none;
    color: #706f6f;
    text-transform: uppercase;
}
a.bio {
    background-image: url(../images/bio.png);
    background-repeat: no-repeat;
    background-position: left 5px;
    padding: 7px 0 2px 30px;
    text-decoration: none;
    line-height: 2.3em;
    color: #706f6f;
    text-transform: uppercase;
}
footer .portfolio {
    padding: 0 20px 0 0;
}

ul.footernav {
    list-style: none;
    margin: 0;

}
ul.footernav li {
    display: inline-block;
    margin-left: 10px;
    position:relative;
    padding-left:0;
}
ul.footernav li:before {
    content: "";
}

ul.footernav li a {
    color: #706f6f;
    border-left: 1px solid  #706f6f;
    line-height: 14px;
    padding-left: 10px;
}
ul.footernav li:first-child a {
    border-left: none;
    padding-left: 0;
}
ul.footernav li span {
    border-left: 1px solid  #706f6f;
    line-height: 14px;
    padding-left: 10px;
}
.mobile {
    display:none;
}

.goto-top {
    font-size: 20px;
    color:#fff;
    border-radius: 50%;
    background-color: #706f6f;
    width: 36px;
    height: 36px;
    position: fixed;
    right: 20px;
    bottom: 18px;
    text-align: center;
    z-index: 9;
    opacity: 0.5;
    visibility: hidden;
}
.goto-top i {
    margin-top: 5px;
}
.visible {
    visibility: visible !important;
}

table.contact {
    width: 100%;
    margin-top:20px;
}
table.contact td {
    width: 50%;
}
table.contact td.right {
    text-align: right;
}
table.contact td.right img {
    max-width: 90%;
    height: auto !important;
}


@media only screen and (max-width:1400px) {
    div.notice {
        right:0px;
    }
}


@media only screen and (max-width:1250px) {
    .teaserlist .teaser .teasertext {
        padding: 0 10px 0 10px;
    }
}



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

    img.logo {
        padding: 13px 0 0 25px;
        max-width: 100%;
    }

    .teaserlist .teaser {
        padding-bottom: 30px;

    }



    footer .portfolio {
        padding-bottom: 20px;
    }

    footer .flex {
        display: block;
    }

    footer .flex .padding20 {
        padding-bottom: 20px;
    }

    footer .row {
        display: block;
        padding: 20px 10px 20px 10px;
    }

    .footer-item {
        border-left: 1px solid #706f6f;
        padding: 0 20px 0 17px;
        margin-bottom: 20px;
        margin-left: 20px;
    }

    nav ul {
        padding-left: 13px;
    }
    div.notice {
        right:0px;
        bottom:0px;
    }


    div.portfolio.hidemobile {
        display:none;
    }

    .content {
        padding: 0 13px 0 13px;
    }


}

@media only screen and (max-width:925px) {
    img.logo {
        max-width: 80%;
    }
    header,nav,main,footer {
        /*min-width: 870px;*/
    }
    nav.desktop {
        display:none;
    }
    table.header {
        display:none;
    }

    table.header.startmobile {
        display:block;
        padding-top:0;
    }
    table.header.startmobile td:first-child {
        display: none;
    }
	table.header.startmobile table.calltime td {
        display: table-cell !important;
		float:none;
		width:auto;
    }
    table.header.startmobile td {
        display:block;
        float:left;
        width: 100%;
        border-left: 0;
        padding: 0 10px 20px 41px;
    }


    .mobile {
        display: block;
    }
    .hidemobile {
        display:none;
    }
    .mobile table.border {
        margin-left: 35px;
    }
    .mobile table.border td.border {
        border-left: 1px solid #706f6f;
        padding: 0 20px 10px 17px;
    }
    .mobile table.border td {
        vertical-align: top;
        padding-right: 20px;
    }
    .mobile table.border table td {
        margin-left: 0;
        border-left: none;
        padding-left: 0;
        padding-bottom: 0;
        padding-right: 5px;
    }
    section.mobile {
        padding-bottom: 27px;
    }

    section.slider {
        padding-bottom:15px;
    }
    section.intro {
        padding: 0 27px 27px 35px;
    }

    section.header {
        display:block;
        padding-bottom: 15px;
    }
    .portfolio {
        padding: 12px 0 0 41px;
        font-size: 93%;
        line-height: 20px;
    }
    .teaserlist {
        border-top: none;
        padding-top:0;
    }
    div.twocol {
        width: 100%;
    }

    section.header {
        position:relative;
    }

    div.mobilesearch {
        display: block;
    }
    div.noticemobilewrap {
        display: block;
    }

    div.notice {
        display: none;
    }


    nav.mobile {
        position: absolute;
        right:0px;
        top: 40px;
        display:block;
        width: auto;

    }

    nav.mobile ul {
        position: absolute;
        right:0;
        top: -19px;
        z-index: 1000;
        display: none;
        width: 180px;
        padding-left: 0;
        padding-bottom: 10px;
        background-color: #eeeeee;
    }
    nav.mobile ul li {
        display: list-item;
        margin-left:0;
        border-bottom: 1px solid #fff;
    }
    nav.mobile ul li:last-child {
        border-bottom: none;
    }
    nav.mobile ul li:first-child {
        padding-top: 30px;
    }
    nav.mobile ul li a {
        line-height: 30px;
        font-size: 113%;
        font-weight: normal;
        display: block;
        padding: 3px 20px 3px 20px;
    }
    a.navicon {
        color: #706f6f;
        font-size: 45px;
        display: inline-block;
        padding-right: 25px;
        z-index: 5000;
        position: absolute;
        right: 0;
    }
    table.philosophie {
        width: 100%;
    }
    .teaserlist.team .teaser {
        padding-right: 15px;
    }
    nav.subnavi {
        display:block;
    }
    nav.subnavi ul {
        padding-left: 0;
    }
    nav.subnavi ul li {
        margin-left: 0;
    }


}

@media only screen and (max-width:740px) {
    .teaserlist {
        display:block;
        width: 100%;
    }
    .teaserlist .teaser {
        width: 100%;
    }
    .teaserlist .teaser img {
        padding-left: 27px;
    }
    .teasertext {
        padding: 0 27px 0 27px !important;
    }
    img.philosophie {
        width: 280px;
    }
    .teaserlist.noborder {
        display:flex;
    }
    .foldout {
        width: 100%;
    }
    nav.subnavi ul li {
        display:block;
        width:100%;
    }
    nav.subnavi ul li a {
        display: block;
    }
    nav.subnavi {
        margin-top: -15px;
    }

    table.contact td {
        float: left;
        width: 100%;
    }
    table.contact td.right {
        text-align:left;
        padding-top: 20px;
    }
    table.contact td.right img {
        width: auto;
        max-width:100%;
    }

}

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

    .mobile table.border {
        margin-left: 0;
    }

    .mobile table.border td {
        display:block;
        width: 100%;
        margin-left: 35px;
        border-left: 1px solid #706f6f;
        padding: 0 0 10px 17px;
    }
    .mobile table.border table td {
        display: table-cell;
        width:auto;
        margin-left: 0;
        border-left: none;
        padding-left: 0;
        padding-bottom: 0;
    }
    table.philosophie td {
        display: block;
        width: 100%;
    }
    table.philosophie td:first-child {
        padding-right: 0;
    }
    img.philosophie {
        width:auto;
    }
    .teaserlist.noborder img {
        width: 100%;
        padding-bottom:10px;
    }
    .rslides_tabs {
        bottom:20px;
    }
}

@media only screen and (max-width:500px) {
    .teaserlist .teaser img {
        padding-left: 0;
        width: 100%;
        max-width: 100%;
    }
    img.logo {
        max-width: 60%;
    }
    .teaserlist.team .teaser img {
        width: auto;
    }
    .teaserlist.team .teasertext {
        padding: 0 !important;
    }

}