/* 
Theme Name: Bio Augustin
Version: 1.0
Author: SELBY & CO. Werbeagentur GmbH
Author URI: https://selbyco.com/
*/

@font-face {
    font-family: "DINNextRoundedLTPro-Regular";
    src: url(fonts/DINNextLTPro-Light.ttf) format('truetype');
    font-weight: 300;
    font-style: normal
}
@font-face {
    font-family: "DINNextRoundedLTPro-Regular";
    src: url(fonts/DINNextLTPro-Regular.ttf) format('truetype');
    font-weight: 400;
    font-style: normal
}
@font-face {
    font-family: "DINNextRoundedLTPro-Regular";
    src: url(fonts/DINNextLTPro-Medium.ttf) format('truetype');
    font-weight: 500;
    font-style: normal
}
@font-face {
    font-family: "DINNextRoundedLTPro-Regular";
    src: url(fonts/DINNextLTPro-Bold.ttf) format('truetype');
    font-weight: 700;
    font-style: normal
}

* {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    -webkit-tap-highlight-color: transparent;
    font-kerning: none;
    -webkit-text-rendering: optimizeSpeed;
    text-rendering: optimizeSpeed;
    -webkit-tap-highlight-color: rgba(0,0,0,0); 
    -webkit-focus-ring-color: rgba(0, 0, 0, 0);
}

body,
html {
    width: 100%;
    min-height: 100%;
}

body {
    font-size: 1.125rem;
    font-weight: 500;
    font-family: "DINNextRoundedLTPro-Regular", sans-serif;
    line-height: 1.6;
    color: #003e19;
    background-color: #fff;
    position: relative;
    overflow: hidden;
    overflow-y: scroll;
}
@media only screen and (min-width:1600px) {
    body {
        font-size: 1.25rem;
    }
}

body.lock-scroll{
    overflow: hidden;
}

::selection {
    opacity: 1;
    color: #fff;
    background: #003e19;
}
::-moz-selection {
    opacity: 1;
    color: #fff;
    background: #003e19;
}

.touchevents .d-touch {
    display: block
}
.touchevents .d-no-touch {
    display: none
}
.no-touchevents .d-touch {
    display: none
}
.no-touchevents .d-no-touch {
    display: block
}

@media only screen and (orientation:landscape) {
    .d-landscape {
        display: block
    }
    .d-portrait {
        display: none
    }
}
@media only screen and (orientation:portrait) {
    .d-landscape {
        display: none
    }
    .d-portrait {
        display: block
    }
}

.relative {
    position: relative!important;
}
.row-s {
    margin-right: -5px;
    margin-left: -5px;
}
.row-s>[class*=col-] {
    padding-left: 5px;
    padding-right: 5px
}
.row-s .mb {
    margin-bottom: 10px
}
.row-s .mt {
    margin-top: 10px
}
.fullheight {
    position: relative;
    width: 100%;
    height: 100vh;
    height: calc(var(--vh, 1vh) * 100);
}
.z1 {
    position: relative;
    z-index: 1;
}
.z2 {
    position: relative;
    z-index: 2;
}
.mt-c1 {
    margin-top: 30px;
}
.mb-c1 {
    margin-bottom: 30px;
}
.row_padding_left,
.row_padding_right {
    padding-right: 15px;
    padding-left: 15px;
}

@media only screen and (min-width:576px) {
    .w-sm-auto {
        width: auto!important;
    }
    .w-sm-100 {
        width: 100%!important;
    }
}
@media only screen and (min-width:712px) {
    .container-fluid,
    .row_padding_left,
    .row_padding_right {
        padding-left: 30px;
        padding-right: 30px
    }
    .w-md-auto {
        width: auto!important;
    }
    .w-md-100 {
        width: 100%!important;
    }
}
@media only screen and (min-width:992px) {
    .row-l {
        margin-right: -30px;
        margin-left: -30px;
    }
    .row-l>[class*=col-] {
        padding-left: 30px;
        padding-right: 30px
    }
    .row-s {
        margin-right: -8px;
        margin-left: -8px;
    }
    .row-s>[class*=col-] {
        padding-left: 8px;
        padding-right: 8px
    }
    .row-s .mb {
        margin-bottom: 16px
    }
    .row-s .mt {
        margin-top: 16px
    }
    .row_padding_left {
        padding-right: 0
    }
    .row_padding_right {
        padding-left: 0;
    }
    .w-lg-auto {
        width: auto!important;
    }
    .w-lg-100 {
        width: 100%!important;
    }
    .mt-c1 {
        margin-top: 40px;
    }
    .pl-lg-c1 {
        padding-left: 30px!important;
    }
    .pb-lg-c1 {
        padding-bottom: 300px;
    }
}
@media only screen and (min-width:1200px) {
    .row-xl {
        margin-right: -30px;
        margin-left: -30px;
    }
    .row-xl>[class*=col-] {
        padding-left: 30px;
        padding-right: 30px
    }
    .w-xl-auto {
        width: auto!important;
    }
    .w-xl-100 {
        width: 100%!important;
    }
    .mt-c1 {
        margin-top: 60px;
    }
}
@media only screen and (min-width:1340px) {
    .container-fluid {
        max-width: 1280px;
        padding-left: 0;
        padding-right: 0;
        margin: 0 auto;
    }
    .row_padding_left {
        padding-left: calc((100vw - 1280px)/2);
    }
    .row_padding_right {
        padding-right: calc((100vw - 1280px)/2);
    }
}
@media only screen and (min-width:1600px) {
    .col-xxl-1 {
        -ms-flex:0 0 8.333333%;
        flex:0 0 8.333333%;
        max-width:8.333333%
    }
    .col-xxl-2 {
        -ms-flex:0 0 16.666667%;
        flex:0 0 16.666667%;
        max-width:16.666667%
    }
    .col-xxl-3 {
        -ms-flex:0 0 25%;
        flex:0 0 25%;
        max-width:25%
    }
    .col-xxl-4 {
        -ms-flex: 0 0 33.333334%;
        flex: 0 0 33.333334%;
        max-width: 33.333334%;
    }
    .col-xxl-5 {
        -ms-flex: 0 0 41.666667%;
        flex: 0 0 41.666667%;
        max-width: 41.666667%;
    }
    .col-xxl-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
    }
    .col-xxl-7 {
        -ms-flex: 0 0 58.333333%;
        flex: 0 0 58.333333%;
        max-width: 58.333333%;
    }
    .col-xxl-8 {
        -ms-flex:0 0 66.666667%;
        flex:0 0 66.666667%;
        max-width:66.666667%
    }
    .col-xxl-9 {
        -ms-flex:0 0 75%;
        flex:0 0 75%;
        max-width:75%
    }
    .col-xxl-10 {
        -ms-flex:0 0 83.333333%;
        flex:0 0 83.333333%;
        max-width:83.333333%
    }
    .col-xxl-11 {
        -ms-flex:0 0 91.666667%;
        flex:0 0 91.666667%;
        max-width:91.666667%
    }
    .col-xxl-12 {
        -ms-flex:0 0 100%;
        flex:0 0 100%;
        max-width:100%
    }
    .d-xxl-block {
        display: block!important;
    }
    .d-xxl-none {
        display: none!important;
    }
    .offset-xxl-1 {
        margin-left: 8.333333%;
    }
}

h1,.h1,
h2,.h2,
h3,.h3,
h4,.h4,
h5,.h5,
h6,.h6 {
    line-height: 1.2;
    font-weight: 500;
    letter-spacing: 0.03em;
    color: inherit;
    margin-bottom: 1rem;
    -ms-word-wrap: break-word;
    word-wrap: break-word;
}
h1,.h1 {
    font-size: 2rem;
    line-height: 1.1;
}
h2,.h2,.single-post h1 {
    font-size: 1.875rem;
    line-height: 1.1;
}
h3,.h3 {
    font-size: 1.75rem;
}
h4,.h4 {
    font-size: 1.625rem;
}
h5,.h5 {
    font-size: 1.375rem;
}
h6,.h6 {
    font-size: 1.25rem;
}
.entry-title {
    line-height: 1.1;
}
.c-title-1 {
    font-size: 4vw;
    line-height: 1.3;
}
.product-title {
    text-transform: uppercase;
    line-height: 1.2;
}
.product-title::after {
    content: "";
    display: block;
    position: relative;
    width: 120px;
    height: 2px;
    background-color: #fff;
    margin-top: .5rem;
}
.product-title.text-center::after {
    margin-left: auto;
    margin-right: auto;
}
@media only screen and (min-width:480px) {
    .c-title-1 {
        font-size: 1.5rem;
    }
}
@media only screen and (min-width:712px) and (orientation:portrait) {
    h1,.h1 {
        font-size: 2.5rem;
    }
    h2,.h2,.single-post h1  {
        font-size: 2.25rem;
    }
    h3,.h3 {
        font-size: 2rem;
    }
    h4,.h4 {
        font-size: 1.875rem;
    }
    h5,.h5 {
        font-size: 1.5rem;
    }
    h6,.h6 {
        font-size: 1.375rem;
    }
}
@media only screen and (min-width:992px) {
    h1,.h1 {
        font-size: 2.5rem;
    }
    h2,.h2,.single-post h1  {
        font-size: 2.25rem;
    }
    h3,.h3 {
        font-size: 2rem;
    }
    h4,.h4 {
        font-size: 1.875rem;
    }
    h5,.h5 {
        font-size: 1.5rem;
    }
    h6,.h6 {
        font-size: 1.375rem;
    }
}
@media only screen and (min-width:1440px) {
    h1,.h1 {
        font-size: 2.75rem;
    }
    h2,.h2,.single-post h1  {
        font-size: 2.5rem;
    }
    h3,.h3 {
        font-size: 2.25rem;
    }
    h4,.h4 {
        font-size: 2rem;
    }
    h5,.h5 {
        font-size: 1.75rem;
    }
    h6,.h6 {
        font-size: 1.5rem;
    }
    .c-title-1 {
        font-size: 1.75rem;
    }
}

.sr-only {
    position:absolute;
    left:-10000px;
    top:auto;
    width:1px;
    height:1px;
    overflow:hidden;
}

.form-control {
    color: #003e19;
    border: 1px solid #ced4da;
    border-radius: 0;
}
.form-control-lg {
    font-size: .9375rem;
}
@media only screen and (min-width:712px) {
    .form-control-lg {
        font-size: 1rem;
    }
}
@media only screen and (min-width:1600px) {
    .form-control-lg {
        font-size: 1.125rem;
    }
}

input:-webkit-autofill,
input:-webkit-autofill:hover, 
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
    border: 1px solid #ced4da;
    -webkit-text-fill-color: #000;
    -webkit-box-shadow: 0 0 0px 1000px #f8f8f8 inset;
    transition: background-color 5000s ease-in-out 0s;
}

p.lead {
    font-size: 1.25rem;
    line-height: 1.4;
}

p:last-of-type {
    margin-bottom: 0;
}

.ctx ol, 
.ctx ul,
.searchlist {
    margin: 0 0 1rem;
    padding: 0 0 0 1rem;
}

p + ul,
p + ol {
    margin-top: 1rem!important;
}

b, strong {
    font-weight: 700;
}

@media only screen and (min-width:992px) {
    .column-2 {
        column-count: 2;
        column-gap: 60px;
    }
    .column-2 p,
    .column-2 ul {
        page-break-inside: avoid;
        -webkit-column-break-inside: avoid;
        break-inside: avoid;
    }
}

.smart-hyphens {
    hyphens: auto;
    hyphenate-limit-chars: 14 3 4;
}

figure {
    margin: 0;
}

.table td, .table th {
    padding: 0 0 .75rem;
    border-top: 0;
}
.table td.summary-table-first-col {
    padding-right: .75rem;
}

.highlight {
    color: red;
}
.hideMe {
    display: none;
}

@media only screen and (min-width:576px) {
    .w-sm-auto {
        width: auto!important;
    }
    .h-sm-100 {
        height: 100%;
    }
}
@media only screen and (min-width:712px) {
    .w-md-auto {
        width: auto!important;
    }
    .h-md-100 {
        height: 100%;
    }
}
@media only screen and (min-width:992px) {
    .w-lg-auto {
        width: auto!important;
    }
    .h-lg-100 {
        height: 100%;
    }
}
@media only screen and (min-width:1200px) {
    .w-xl-auto {
        width: auto!important;
    }
    .h-xl-100 {
        height: 100%;
    }
}

.nowrap {
    white-space: nowrap;
}

img {
    max-width: 100%;
}

figure img {
    width: 100%;
    height: auto
}

.img-wrap {
    display: block;
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
}
.img-wrap img {
    position: relative;
    width: 100%;
    height: auto;
    transition: transform .9s;
    -webkit-transform: scale(1);
    transform: scale(1);
    z-index: 1
}
.no-touchevents a:hover .img-wrap img {
    -webkit-transform: scale(1.03);
    transform: scale(1.03);
}
.entry-content .wp-video {
    width: 100%!important;
    margin-bottom: 1rem;
}
.yt-video {
    aspect-ratio: 16 / 9;
    width: 100%;
}
.media-wrapper {
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
}
.media-wrapper.divider {
    height: calc(100vh - 60px);
}
.media-wrapper.abs {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    z-index: 1;
}
.media-wrapper video {
    width: 100%;
    height: auto;
}
.media-wrapper .img,
.media-wrapper .video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
}
.media-wrapper.divider .divider-content {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    font-size: 1.25rem;
    font-weight: 500;
}
.play-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
    cursor: pointer;
    opacity: 1;
    -webkit-transition: transform .3s;
    transition: transform .3s;
}
.play-video.video-active {
    opacity: 0;
    pointer-events: none;
}
.play-video i {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%) scale(1);
    font-size: 60px;
    line-height: 60px;
    color: #fff;
    padding: 0!important;
    transition: transform .5s;
}
.no-touchevents .play-video:hover i {
    transform: translate(-50%,-50%) scale(1.3);
}

.video-overlay {
    width: 100%;
    height: 100%;
    background-color: #000000;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9000;
    -webkit-transform: translateY(-110%);
    transform: translateY(-110%);
    -webkit-transition: -webkit-transform 0.5s ease-in-out .3s;
    transition: transform 0.5s ease-in-out .3s;
}
.video-overlay.video-active {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    -webkit-transition: -webkit-transform 0.5s ease-in-out 0s;
    transition: transform 0.5s ease-in-out 0s;
}

.video-overlay .video-holder {
    position: absolute;
    overflow: hidden;
    background-color: #000000;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    opacity: 0;
    -webkit-transition: opacity 0.3s ease-in 0s;
    transition: opacity 0.3s ease-in 0s;
}
.video-overlay.video-active .video-holder {
    opacity: 1;
    -webkit-transition: opacity 0.3s ease-in .7s;
    transition: opacity 0.3s ease-in .7s;
}

.video-overlay .video-holder .fullscreen-video {
    position: absolute;
    top: 50%;
    left: 50%;
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
}

.video-close {
    position: fixed;
    top: 15px;
    right: 15px;
    width: 40px;
    height: 40px;
    z-index: 50;
    cursor: pointer;
    background: rgba(0,17,46,.15);
}

.video-close::after,
.video-close::before {
    content: "";
    position: absolute;
    top: 5px;
    left: 20px;
    width: 2px;
    height: 30px;
    background-color: #fff;
    z-index: 10;
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transition: all .3s cubic-bezier(0.16, 0.01, 0.77, 1);
    transition: all .3s cubic-bezier(0.16, 0.01, 0.77, 1);
}

.video-close::before {
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg)
}

.video-close:hover::after {
    -moz-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg)
}

.video-close:hover::before {
    -moz-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg)
}
@media only screen and (min-width: 712px) and (orientation: portrait) {
    .media-wrapper.divider {
        height: calc(100vh - 70px);
    }
    .media-wrapper.divider .divider-content {
        font-size: 1.5rem;
    }
}
@media only screen and (min-width: 992px) {
    .media-wrapper.divider {
        height: calc(100vh - 70px);
    }
    .media-wrapper.divider .divider-content {
        font-size: 1.5rem;
    }
    .play-video-badge {
        width: 120px;
        height: 120px;
    }
    .play-video-badge .playicon svg {
        width: 25px;
        height: 25px;
    }
    .video-close {
        top: 30px;
        right: 30px;
        width: 60px;
        height: 60px;
    }
    .video-close::after,
    .video-close::before {
        top: 5px;
        left: 30px;
        height: 50px;
    }
}
@media only screen and (min-width: 1200px) {
    .media-wrapper.divider {
        height: calc(100vh - 80px);
    }
    .media-wrapper.divider .divider-content {
        font-size: 1.75rem;
    }
}

.text-white {
    color: #fff!important;
}
.text-black {
    color: #000!important
}
.text-red {
    color: #721511!important
}
.text-green {
    color: #003e19!important;
}
.text-light-green {
    color: #6f9e21!important;
}

.bg-white {
    background-color: #fff!important;
}
.bg-black {
    background-color: #000!important;
    color: #fff;
}
.bg-red {
    background-color: #721511!important;
    color: #fff;
}
.bg-green {
    background-color: #003e19!important;
}
.bg-light-green {
    background-color: #6f9e21!important;
}
.bg-light-grey {
    background-color: #f3f4f8!important;
}


a {
    color: #003e19;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
}
a:hover {
    color: #003e19;
    text-decoration: none;
}
a:focus, a.focus, button:focus, button.focus {
    outline: 0;
}
.text-white a,
.text-white a:hover {
    color: #fff;
}
.ctx a:not(.gallery-item a):not(.post-image-link) {
    color: #6f9e21;
    border-bottom: 1px solid transparent;
}
.ctx a:not(.gallery-item a):hover,
.ctx a:not(.post-image-link):hover {
    color: #6f9e21;
    border-bottom-color: #6f9e21;
}

.btn {
    border-radius: 0;
    text-transform: uppercase;
}
.btn-lg {
    padding: .625rem 1rem .375rem;
    font-size: .9375rem;
    letter-spacing: .5px;
}
.btn-secondary,
.btn-secondary:focus,
.btn-secondary.focus {
    background-color: #709e21;
    border-color: #709e21;
}
.btn-secondary:hover {
    background-color: #628a1e;
    border-color: #628a1e;
}
@media only screen and (min-width:712px) {
    .btn-lg {
        font-size: 1rem;
    }
}
@media only screen and (min-width:1600px) {
    .btn-lg {
        font-size: 1.125rem;
    }
}

.read-more {
    position: relative;
    display: inline-block;
    padding-right: 25px;
    line-height: 1.2;
}
.read-more span {
    border-bottom: 1px solid #003e19;
    -webkit-transition: all .3s;
    transition: all .3s
}
.text-white .read-more span {
    border-bottom-color: #fff;
}
.read-more::after {
    position: absolute;
    top: 0;
    right: 8px;
    font-family: 'fontello';
    content: "\e802";
    -webkit-transition: all .3s;
    transition: all .3s
}
.read-more:hover span {
    border-bottom-color: transparent;
}
.read-more:hover::after {
    right: 0;
}

.button {
    display: inline-block;
    line-height: 1;
    white-space: nowrap;
    text-align: center;
    min-width: 175px;
    color: #fff!important;
    text-transform: uppercase;
    font-size: .9375rem;
    letter-spacing: .5px;
    padding: 6px 15px!important;
    background-color: #003e19;
    border: 2px solid #003e19;
}
.button.mw {
    min-width: 200px;
}
.button.white {
    background-color: #fff;
    border: 2px solid #fff;
    color: #003e19!important;
}
.button.light-green {
    background-color: #709e21;
    border: 2px solid #709e21;
}
.button.red {
    background-color: #721511;
    border: 2px solid #721511;
}
.button.outline {
    background-color: transparent;
}
.button.white.outline {
    background-color: transparent;
    border: 2px solid #fff;
    color: #fff!important;
}
.button.red.outline {
    color: #721511;
    background-color: transparent;
    border: 2px solid #721511;
}
.button-text {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    line-height: 24px;
    overflow: hidden;
    width: auto;
    padding-right: 25px;
    transition: transform .2s ease-out;
}
.button-text::after {
    font-family: 'fontello';
    content: '\e817';
    font-size: 85%;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    color: inherit;
}
.button-text span {
    position: relative;
    display: inline-block;
    margin-top: 3px;
    -webkit-transition: -webkit-transform .2s;
    transition: transform .2s;
    width: auto;
    text-align: center;
    transform-origin: 100% 0%;
}
.button-text span::before {
    position: absolute;
    width: auto;
    top: 100%;
    left: 0;
    content: attr(data-hover)
}
.button:hover .button-text span,
a:hover .button-text span {
    -webkit-transform: translateY(-100%);
    transform: translateY(-100%);
    transform-origin: 0% 0%
}
@media only screen and (min-width:712px) {
    .button {
        font-size: 1rem;
    }
    .button.mw,
    .button.mw-md {
        min-width: 275px;
    }
    .button-text {
        line-height: 28px;
    }
}
@media only screen and (min-width:1600px) {
    .button {
        font-size: 1.125rem;
    }
}

.wp-caption.alignnone {
    width: 100%!important;
    max-width: 100%;
    margin: 1rem auto;
}
.alignleft {
    float: left
}
.wp-caption.alignleft {
    max-width: 50%;
    margin: .375rem 1rem 10px 0;
}
.alignright {
    float: right
}
.wp-caption.alignright {
    max-width: 50%;
    margin: .375rem 0 10px 1rem;
}
.wp-caption img {
    width: 100%;
    height: auto;
}
.aligncenter {
    margin-left: auto;
    margin-right: auto
}
img.alignleft {
    margin: .375rem 1rem 10px 0;
    max-width: 50%;
    height: auto
}
img.alignright {
    margin: .375rem 0 10px 1rem;
    max-width: 50%;
    height: auto
}
img.aligncenter {
    margin: 1rem auto;
    clear: both;
    display: block
}
img.alignnone {
    width: 100%;
    height: auto;
    margin: 1rem 0;
}
.wp-caption-text {
    font-size: .875rem;
    margin: 7px 0 0!important
}
@media only screen and (min-width:1600px) {
    .wp-caption-text {
        font-size: .9375rem;
    }
}

@media only screen and (max-width:480px) {
    .wp-caption.alignleft,
    .wp-caption.alignright,
    img.alignleft,
    img.alignright {
        margin: 0 0 1rem;
        width: 100%;
        max-width: 100%;
    }
}

.gallery {
    margin: 1rem 0!important
}
.gallery img {
    width: 100%;
    height: auto;
    border-color: #fff!important;
}
.gallery-item {
    margin: 0!important;
    position: relative;
    overflow: hidden;
}
.gallery-item a {
    position: relative;
    display: block;
    width: 100%;
    height: auto;
    overflow: hidden;
}
.gallery-item a::after {
    content: '';
    display: block;
    padding-bottom: 100%;
}
.gallery-item a img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%!important;
    max-width: none!important;
    height: 100%!important;
    border-color: #fff!important;
    object-position: center;
    object-fit: cover;
}

.has-animation {
    -webkit-transition: all .6s ease;
    transition: all .6s ease;
} 
.has-animation.image_clip_right {
    clip-path: inset(0 100% 0 0);
    -webkit-clip-path: inset(0 100% 0 0);
}
.has-animation.image_clip_left {
    clip-path: inset(0 0 0 100%);
    -webkit-clip-path: inset(0 0 0 100%);
}
.has-animation.image_clip_right.animated {
    clip-path: inset(0 0 0 0);
    -webkit-clip-path: inset(0 0 0 0);
}
.has-animation.image_clip_left.animated {
    clip-path: inset(0 0 0 0);
    -webkit-clip-path: inset(0 0 0 0);
} 
.has-animation.fade-up {
    opacity: 0;
    transform: translateY(60px)
}
.has-animation.fade-up.animated {
    opacity: 1;
    transform: translateY(0)
}
.has-animation.fade-in-left {
    opacity: 0;
    transform: translateX(-800px);
}
.has-animation.fade-in-left.animated {
    opacity: 1;
    transform: translateX(0)
}
.has-animation.fade-in-right {
    opacity: 0;
    transform: translateX(800px)
}
.has-animation.fade-in-right.animated {
    opacity: 1;
    transform: translateX(0)
}
.has-animation.has-scale {
    opacity: 0;
    transform: translateY(0) scale(1.05);
    transform-origin: 50% 0;
    will-change: transform
}
.has-animation.has-scale-vertical {
    opacity: 0;
    transform: translateY(0) scaleY(1.1);
    transform-origin: 50% 0;
    will-change: transform
}
.has-animation.has-scale-vertical.animated {
    opacity: 1;
    transform: translateY(0) scaleY(1);
}
.has-animation.has-cover {
    opacity: 1;
    transform: translateY(0);
    overflow: hidden
}
.has-animation.has-cover::after {
    content: "";
    width: 100%;
    height: 100%;
    background-color: inherit;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 10;
    -webkit-transition: .6s cubic-bezier(.54, .49, .2, 1.01);
    -o-transition: .6s cubic-bezier(.54, .49, .2, 1.01);
    transition: .6s cubic-bezier(.54, .49, .2, 1.01)
}
.has-animation.has-cover.animated::after {
    width: 0
}
.has-animation.has-cover img {
    display: block;
    margin: 0 auto;
    opacity: 1;
    transform: scale(1.05);
    -webkit-transition: .6s cubic-bezier(.54, .49, .2, 1.01);
    -o-transition: .6s cubic-bezier(.54, .49, .2, 1.01);
    transition: .6s cubic-bezier(.54, .49, .2, 1.01)
}
.has-animation.has-cover.animated img {
    opacity: 1;
    transform: scale(1)
}

.dropdown-item.active, .dropdown-item:active {
    background-color: #003e19;
}

#pageloader {
    background: #fff;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 4900
}
.loader-item {
    position: absolute;
    width: 44px;
    height: 44px;
    font-size: 44px;
    line-height: 44px;
    margin: -22px 0 0 -22px;
    top: 50%;
    left: 50%;
    text-align: center;
    color: #003e19
}

.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 900;
    background-color: rgba(0,62,25,1);
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
}
.header-wrapper {
    position: relative;
    z-index: 1;
    height: 60px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
}
.header-wrapper .logo {
    position: relative;
    height: 100%;
    padding: 10px 0;
}
.header-wrapper .logo img {
    position: relative;
    height: 100%;
    width: auto;
}
.header-wrapper .logo img.lc {
    display: none;
}
.header-wrapper .logo img.lw {
    display: block;
}
#main-nav {
    padding: 0;
    height: 100%;
}
#navCollapse,
#menu-navigation {
    height: 100%;
}
#menu-navigation {
    align-items: center;
}
#main-nav .navbar-nav .nav-item {
    display: flex;
    align-items: center;
    position: relative;
    height: 100%;
    margin: 0 .5rem;
}
#main-nav .navbar-nav .nav-item.dropdown {
    cursor: pointer;
}
#main-nav .navbar-nav .nav-item.dropdown .nav-item {
    margin: 0;
}
#main-nav .navbar-nav .nav-link {
    position: relative;
    cursor: pointer;
    font-size: 1rem;
    font-weight: 500;
    padding: .375rem .25rem;
    color: #fff;
    text-transform: uppercase;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
}
#main-nav .navbar-nav .sub-menu {
    position: absolute;
    top: 100%;
    left: -.5rem;
    z-index: 1000;
    display: none;
    min-width: 100%;
    padding: 0;
    margin: 0;
    font-size: 1rem;
    color: #212529;
    text-align: left;
    list-style: none;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid rgba(0,0,0,.15);
    border-radius: .25rem;
}
.no-touchevents #main-nav .navbar-nav .nav-item.dropdown:hover > .sub-menu {
      display: block;
}
#main-nav .navbar-nav .sub-menu .sub-menu {
    left: 100%;
    top: 0;
}
.no-touchevents #main-nav .navbar-nav .nav-item.dropdown .nav-link .dropdown-menu > li:hover > .dropdown-menu {
      display: block;
}
#main-nav .navbar-nav .nav-item .dropdown-item {
    position: relative;
    padding: .25rem 1rem;
    font-weight: 500;
    font-size: 1.125rem;
    color: #003e19;
}
#main-nav .navbar-nav .dropdown-menu li:first-child .dropdown-item {
    padding-top: .5rem;
}
#main-nav .navbar-nav .nav-item .dropdown-item:hover,
#main-nav .navbar-nav .nav-item .current-menu-item > .dropdown-item,
#main-nav .navbar-nav .nav-item .current-menu-parent > .dropdown-item {
    color: #fff;
    background: #003e19!important;
}
.dropdown-toggle::after {
    margin-left: .375em;
    vertical-align: .2em;
}
#main-nav .navbar-nav .sub-menu .menu-item-has-children.dropdown > a::after {
    position: absolute;
    right: .5rem;
    top: 50%;
    transform: translateY(-50%) rotate(-90deg);
    content: "";
    border-top: .3em solid;
    border-right: .3em solid transparent;
    border-bottom: 0;
    border-left: .3em solid transparent;
}
.header-wrapper .header-cta {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    display: none;
}
.header-wrapper .blog {
    display: block;
    position: relative;
    padding: 6px 14px 3px 40px;
    font-weight: 500;
    text-transform: uppercase;
    color: #fff;
    border: 2px solid #fff;
}
.header-wrapper .blog::before {
    content: '';
    position: absolute;
    left: 14px;
    top: 50%;
    width: 18px;
    height: 19px;
    transform: translateY(-50%);
    background-image: url(img/apple-icon-white.png);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.burger-menu {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    cursor: pointer;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 2000;
}
.burger-menu > div {
    position: relative;
    width: 30px;
    height: 32px;
}
.burger-menu b {
    -webkit-transition: opacity .3s ease-in-out, -webkit-transform .3s ease-in-out, border-color .1s ease;
    transition: opacity .3s ease-in-out, transform .3s ease-in-out, border-color .1s ease;
    position: absolute;
    display: block;
    width: 30px;
    height: 0;
    border-top: 2px solid #fff
}
.burger-menu b:nth-child(1) {
    top: 8px;
    left: 0;
}
.burger-menu b:nth-child(2) {
    top: 16px;
    left: 0;
}
.burger-menu b:nth-child(3) {
    top: 24px;
    right: 0;
    width: 20px;
}
body.menu-open .burger-menu b:nth-child(1) {
    transform: translateY(8px) rotate(45deg);
}
body.menu-open .burger-menu b:nth-child(2) {
    opacity: 0;
    width: 0;
}
body.menu-open .burger-menu b:nth-child(3) {
    transform: translateY(-8px) rotate(-45deg);
    width: 30px;
}

.overlay {
    visibility: hidden;
    opacity: 0;
    position: fixed;
    left: 0;
    top: 60px;
    bottom: 0;
    width: 100%;
    background: rgba(0, 0, 0, .4);
    z-index: 500;
    -webkit-transition: all .5s;
    transition: all .5s
}
body.menu-open .overlay {
    opacity: 1;
    visibility: visible;
    width: 200%
}
.aside {
    position: fixed;
    right: -100%;
    top: 60px;
    bottom: 0;
    width: 100%;
    background: #fff;
    border-left: 1px solid #e7e7e8;
    padding-top: 40px;
    z-index: 600;
    -webkit-transition: all .5s ease;
    transition: all .5s ease
}
body.menu-open .aside {
    right: 0
}
.aside .aside-inner {
    height: 100%;
    overflow-y: auto;
    padding: 5px 0 20px
}
nav.main ul {
    margin: 0;
    padding: 0;
    list-style: none
}
nav.main ul.sub-menu {
    display: none;
    overflow: hidden
}
nav.main li {
    padding: 0;
}
nav.main a {
    color: #003e19;
    cursor: pointer;
    font-size: 1.125rem;
    display: block;
    padding: 10px 15px 5px;
    opacity: 1;
    position: relative;
    text-transform: uppercase;
    border-bottom: 1px solid #003e19;
}
nav.main a:hover,
nav.main .current-menu-item > a,
nav.main .current-menu-parent > a {
    color: #6f9e21;
}
nav.main li.menu-item-has-children > a {
    padding-right: 50px
}
nav.main li.menu-item-has-children > a span {
    position: absolute;
    top: 0;
    right: 0;
    width: 60px;
    height: 100%;
}
nav.main li.menu-item-has-children > a span::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 1px;
    height: 70%;
    background: #003e19;
}
nav.main li.menu-item-has-children > a span::after {
    position: absolute;
    top: 60%;
    left: 50%;
    font-family: 'fontello';
    content: "\e813";
    color: #000;
    -webkit-transform: -webkit-translate(-50%,-50%) rotate(0);
    transform: translate(-50%,-50%) rotate(0);
    transition: transform .2s ease;
}
nav.main li.menu-item-has-children > a span.active::after {
    -webkit-transform: -webkit-translate(-50%,-50%) rotate(-180deg);
    transform: translate(-50%,-50%) rotate(-180deg)
}
nav.main ul.sub-menu li {
    border-bottom: none
}
nav.main ul.sub-menu li a {
    padding-left: 30px;
    text-transform: none
}
nav.main ul.sub-menu ul.sub-menu li a {
    padding-left: 45px
}
nav.cta {
    padding: 30px 15px 0;
}
nav.bottom {
    padding: 30px 15px 0;
}
nav.cta a,
nav.bottom a {
    font-weight: 500;
    text-transform: uppercase;
    display: inline-block;
    position: relative;
    margin-right: .25rem;
}
nav.cta .blog {
    display: inline-block;
    position: relative;
    padding: 6px 14px 3px 40px;
    font-weight: 500;
    text-transform: uppercase;
    color: #003e19;
    border: 2px solid #003e19;
}
nav.cta .blog::before {
    content: '';
    position: absolute;
    left: 14px;
    top: 50%;
    width: 18px;
    height: 19px;
    transform: translateY(-50%);
    background-image: url(img/apple-icon-green.png);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}
nav.bottom .social {
    font-size: 2rem;
}
nav.bottom .dropdown a {
    font-size: 1.125rem;
}
nav.bottom .social i::before {
    margin: 0;
}
.search-wrap {
    width: 100%;
    position: relative;
    padding: 15px;
}
.search-wrap button.submit {
    background: transparent;
    border: none;
    text-align: center;
    cursor: pointer;
    display: block;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    width: 45px;
    height: 45px;
    text-align: center;
}
.search-wrap button.submit::after {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 20px;
    font-family: 'fontello';
    content: "\f4a4";
    font-size: 1.25rem;
}

@media only screen and (min-width:712px) and (orientation:portrait) {
    .header-wrapper {
        height: 70px;
    }
    .header-wrapper .logo {
        padding: 12px 0;
    }
    .aside {
        padding-top: 70px;
    }
}
@media (min-width:992px) {
    .header-wrapper {
        height: 70px;
    }
    .header-wrapper .logo {
        padding: 12px 0;
    }
}
@media (min-width:1200px) {
    .header {
        background-color: rgba(0,62,25,0);
    }
    body.scrol .header {
        background-color: rgba(0,62,25,1)!important;
    }
    .header-wrapper .logo {
        padding: 12px 0;
        margin-right: 2rem;
    }
    .header-wrapper .logo img.lc {
        display: block;
    }
    .header-wrapper .logo img.lw {
        display: none;
    }
    body.scrol .header-wrapper .logo img.lc,
    body.page-template-tpl-home .header-wrapper .logo img.lc,
    body.page-template-tpl-produkte .header-wrapper .logo img.lc {
        display: none;
    }
    body.scrol .header-wrapper .logo img.lw,
    body.page-template-tpl-home .header-wrapper .logo img.lw,
    body.page-template-tpl-produkte .header-wrapper .logo img.lw {
        display: block;
    }
    .header-wrapper .header-cta {
        display: block;
    }
    #main-nav .navbar-nav .nav-link {
        color: #003e19;
    }
    .header-wrapper .blog {
        color: #003e19;
        border-color: #003e19;
    }
    .header-wrapper .blog::before {
        background-image: url(img/apple-icon-green.png);
    }
    body.scrol #main-nav .navbar-nav .nav-link,
    body.page-template-tpl-home #main-nav .navbar-nav .nav-link,
    body.page-template-tpl-produkte #main-nav .navbar-nav .nav-link {
        color: #fff;
    }
    body.scrol .header-wrapper .blog,
    body.page-template-tpl-home .header-wrapper .blog,
    body.page-template-tpl-produkte .header-wrapper .blog {
        color: #fff;
        border-color: #fff;
    }
    body.scrol .header-wrapper .blog::before,
    body.page-template-tpl-home .header-wrapper .blog::before,
    body.page-template-tpl-produkte .header-wrapper .blog::before {
        background-image: url(img/apple-icon-white.png);
    }
    .burger-menu {
        display: none;
    }
}
@media only screen and (min-width:1440px) {
    .header-wrapper {
        height: 80px;
    }
    .header-wrapper .logo {
        margin-right: 3rem;
    }
    #main-nav .navbar-nav .nav-item {
        margin: 0 .75rem;
    }
    #main-nav .navbar-nav .nav-link {
        padding: .375rem .5rem;
    }
}

#main {
    position: relative;
    width: 100%;
    height: auto;
    min-height: 100vh;
    min-height: calc(var(--vh, 1vh) * 100);
    padding-top: 80px;
    z-index: 1;
    overflow: hidden;
}
.page-template-tpl-home #main {
    padding-top: 0;
}
.page-template-tpl-produkte #main {
    padding-top: 60px;
}

.fbc-page .fbc-wrap .fbc-items {
    margin-bottom: 1.5rem!important;
    padding: 0!important;
    background-color: transparent!important;
}
.fbc-page .fbc-wrap .fbc-items li {
    padding: 0 2px!important;
}
.page-template-tpl-produkte .fbc-page .fbc-wrap .fbc-items li a,
.page-template-tpl-produkte .fbc-page .fbc-wrap .fbc-items li.active span, 
.page-template-tpl-produkte .fbc-page .fbc-wrap .fbc-items li .fbc-end-text,
.page-template-tpl-produkte .fbc-page .fbc-wrap .fbc-items li .fbc-separator {
    color: #fff!important;
}

.hero {
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
}
.hero .container-fluid,
.hero .container {
    position: relative;
    z-index: 5;
}
.hero .hero-content {
    position: absolute;
    bottom: 100px;
    left: 15px;
    right: 15px;
}
.hero img.claim {
    max-width: 300px;
}
.hero .icon-bio {
    max-width: 100px;
    position: absolute;
    bottom: 40px;
    right: 20px;
    z-index: 3;
}
.hero .hero-bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    overflow: hidden;
    z-index: 1;
    -webkit-transition: -webkit-transform .7s;
    transition: transform .7s;
}
.hero-bg .img,
.hero-bg .video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
    object-position: center;
}
.hero-bg .img-b {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}
.section {
    position: relative;
    padding: 60px 0;
}
.section .icon-bio {
    display: inline-block;
    height: 60px;
    width: auto;
}
.section .icon-demeter {
    display: inline-block;
    width: auto;
    height: 50px;
}
.section .augustin-siegel {
    display: inline-block;
    max-width: 100px;
}
.next-section {
    position: absolute;
    right: 0;
    bottom: 5px;
    width: 100%;
    font-size: 1.25rem;
    color: rgba(0,0,0,.5);
    text-align: center;
    cursor: pointer;
    z-index: 100;
}
.next-section i {
    display: inline-block;
	animation: bounce 1.5s infinite;
	-webkit-animation: bounce 1.5s infinite;
}
.arrow-down::after {
	content: '';
    display: block;
    position: absolute;
    top: 100%;
    left: -5px;
    width: 1px;
    height: 10px;
    border-top: 10px solid #000;
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
}

@-webkit-keyframes bounce {
    0%, 20%, 50%, 80%, 100% {-webkit-transform: translateY(0);}
    40% {-webkit-transform: translateY(-10px);}
    60% {-webkit-transform: translateY(-5px);}
} 
 
@keyframes bounce {
    0%, 20%, 50%, 80%, 100% {transform: translateY(0);}
    40% {transform: translateY(-10px);}
    60% {transform: translateY(-5px);}
}

.home-grid-item,
.hover-item {
    position: relative;
    overflow: hidden;
    display: block;
}
.home-grid-item .item-body {
    padding-top: 1rem;
}
.home-grid-item.hover .img {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 100%;
    overflow: hidden;
    background-size: cover;
    background-position: center center;
}
.touchevents .home-grid-item.hover .img {
    height: auto;
    padding-bottom: 0;
    background: none!important;
}
.home-grid-item .grid-title,
.hover-item .grid-title {
    font-size: 1.675rem;
}
.home-grid-item.hover .grid-title {
    position: absolute;
    top: 25px;
    left: 0;
    width: 100%;
    padding: 0 1rem;
    text-align: center;
}
@media only screen and (min-width:712px) and (orientation:portrait) {
    .home-grid-item .grid-title,
    .hover-item .grid-title {
        font-size: 2rem;
    }
}
@media only screen and (min-width:992px) {
    .home-grid-item .grid-title,
    .hover-item .grid-title {
        font-size: 1.75rem;
    }
}
@media only screen and (min-width:1200px) {
    .hero .hero-bg::after {
        content: '';
        position: absolute;
        left: 0;
        width: 100%;
        height: 25%;
        background: linear-gradient(to bottom, rgba(0,0,0,0.5) 0%,rgba(0,0,0,0) 100%);
    }
}
@media only screen and (min-width:1440px) {
    .home-grid-item .grid-title,
    .hover-item .grid-title {
        font-size: 2rem;
    }
}
.home-grid-item .hover-content,
.hover-item .hover-content {
    position: absolute;
    bottom: -1px;
    left: -1px;
    right: -1px;
    transform: translateY(100%);
    overflow: hidden;
    z-index: 5;
    transition: all .3s cubic-bezier(.25,.54,.41,1);
}
.hover-item .hover-content {
    transform: translateY(calc(100% - 1rem));
}
.no-touchevents .home-grid-item:hover .hover-content,
.no-touchevents .hover-item:hover .hover-content {
    transform: translateY(0);
    transition: all .6s cubic-bezier(.25,.54,.41,1);
}
.touchevents .home-grid-item .hover-content,
.touchevents .hover-item .hover-content {
    position: relative;
    transform: translateY(0);
}
.hover-content .hover-text {
    position: relative;
    overflow: hidden;
    background: #fff;
    text-align: left;
    padding: 1rem 1rem 0;
    font-size: 1.0625rem;
}
.hover-item .hover-content .hover-text {
    background: #f6f0ed;
    padding: 1.5rem 1rem 1rem!important;
}
.touchevents .hover-content .hover-text {
    padding: 1rem 0 0;
    font-size: 1.125rem;
}
.hover-text ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.hover-text ul li {
    position: relative;
    padding-left: 25px;
}
.hover-text ul li::before {
    font-family: 'fontello';
    content: "\e81a";
    position: absolute;
    top: 2px;
    left: 0;
    font-size: 14px;
}

.breadcrumb-section {
    position: absolute;
    top: 80px;
    left: 0;
    width: 100%;
    z-index: 200;
}
.piling-section {
    background: #721511;
    color: #fff;
}
.product-slider {
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
    background: #721511;
    color: #fff;
    z-index: 1;
}
.product-slider .swiper-pagination-bullet,
.product-slider .swiper-pagination-bullet-active {
    background: #fff;
}
.product-slider .slider-button-next, 
.product-slider .slider-button-prev {
    position: absolute;
    bottom: 8px;
    color: #fff;
    font-size: 1.5rem;
    cursor: pointer;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 15;
}
.product-slider .slider-button-prev {
    left: 0;
}
.product-slider .slider-button-next {
    right: 0;
}
.product-slider .slider-button-prev::after {
    font-family: 'fontello';
    content: '\e814';
}
.product-slider .slider-button-next::after {
    font-family: 'fontello';
    content: '\e817';
}
.product-slider .swiper-pagination-fraction {
    color: #fff;
    font-size: 1rem;
    bottom: 15px;
}
.product-slider .product-img {
    position: relative;
    width: 100%;
}
.product-slider .product-img img {
    position: relative;
    width: 100%;
}
.product-slider .product-text {
    position: relative;
    padding: 25px 15px 70px;
}
.product-slider .product-text strong {
    line-height: 1.2;
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: 0.03em;
}
.product-nav {
    position: absolute;
    top: 140px;
    bottom: 60px;
    right: 30px;
    width: auto;
    max-width: 235px;
    height: auto;
    overflow: hidden;
    color: #fff;
    opacity: 1;
    z-index: 200;
}
.product-nav.hidden {
    opacity: 0;
    pointer-events: none;
}
#product-nav::before,
#product-nav-clone::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 15%;
    pointer-events: none;
    background: linear-gradient(0deg, rgba(113,22,17,0) 0%, rgba(113,22,17,1) 100%);
    z-index: 2;
}
#product-nav::after,
#product-nav-clone::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 15%;
    pointer-events: none;
    background: linear-gradient(0deg, rgba(113,22,17,1) 0%, rgba(113,22,17,0) 100%);
    z-index: 2;
}
#product-nav-2 .swiper-wrapper,
#product-nav-clone-2 .swiper-wrapper {
    top: 50%!important;
    transform: translateY(-50%)!important;
    height: auto!important;
}
.product-nav .swiper-slide {
    cursor: pointer;
    display: flex;
    align-items: center;
    width: auto;
}
.product-nav .swiper-slide .bullet {
    display: inline-block;
    vertical-align: top;
    border-radius: 100%;
    margin: -2px 0 0;
    width: 16px;
    height: 16px;
    background: rgba(255,255,255,0);
    border: 1px solid #fff;
}
.product-nav .swiper-slide-active .bullet {
    background: rgba(255,255,255,1);
}
.product-nav .swiper-slide .name {
    margin-left: 10px;
    line-height: 1;
    font-size: 1rem;
    display: none;
}
.info-content {
    position: fixed;
    right: -100%;
    top: 60px;
    bottom: 0;
    width: 100%;
    display: flex;
    justify-content: flex-end;
    z-index: 700;
    -webkit-transition: all .5s ease;
    transition: all .5s ease
}
.info-content.active {
    right: 0
}
.info-content .info-inner {
    position: relative;
    width: 100%;
    height: 100%;
    background: #721511;
    color: #fff;
    overflow-y: auto;
    padding: 50px 15px
}
.info-content .info-inner .content {
    opacity: 0;
    transform: translateY(60px);
    -webkit-transition: all .6s ease .6s;
    transition: all .6s ease .6s;
}
.info-content.active .info-inner .content {
    opacity: 1;
    transform: translateY(0);
}
.close-info {
    position: absolute;
    top: 10px;
    right: 20px;
    width: 40px;
    height: 40px;
    z-index: 50;
    cursor: pointer;
    background: rgba(114,21,17,.75);
}

.close-info::after,
.close-info::before {
    content: "";
    position: absolute;
    top: 5px;
    left: 20px;
    width: 2px;
    height: 30px;
    background-color: #fff;
    z-index: 10;
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transition: all .3s cubic-bezier(0.16, 0.01, 0.77, 1);
    transition: all .3s cubic-bezier(0.16, 0.01, 0.77, 1);
}

.close-info::before {
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg)
}

.close-info:hover::after {
    -moz-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg)
}

.close-info:hover::before {
    -moz-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg)
}
@media only screen and (min-width: 712px) and (orientation: portrait) {
    .page-template-tpl-produkte #main {
        padding-top: 70px;
    }
    .breadcrumb-section {
        top: 100px;
    }
    .product-slider .product-text {
        padding: 30px 60px 70px;
    }
    .product-slider .product-text strong {
        font-size: 1.75rem;
    }
    .info-content {
        top: 70px;
    }
    .info-content .info-inner {
        padding: 60px 30px
    }
}
@media (min-width: 992px) {
    .page-template-tpl-produkte #main {
        padding-top: 0;
    }
    .breadcrumb-section {
        top: 90px;
    }
    .piling-section .product-img {
        height: 100vh;
        height: calc(var(--vh, 1vh) * 100);
    }
    .piling-section .product-img img {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center top;
    }
    .piling-section .product-text {
        padding: 30px 80px 30px 30px;
    }
    .piling-section .product-text strong {
        line-height: 1.2;
        font-size: 1.75rem;
        font-weight: 500;
        letter-spacing: 0.03em;
    }
    .info-content {
        top: 70px;
    }
    .info-content .info-inner {
        width: 50%;
        padding: 60px 30px;
    }
}
@media (min-width: 1200px) {
    .breadcrumb-section {
        top: 100px;
    }
    .product-nav {
        position: absolute;
        top: 150px;
    }
    .info-content {
        top: 80px;
    }
}
@media (min-width: 1440px) {
    .product-nav .swiper-slide .name {
        vertical-align: top;
        display: inline-block;
    }
    .piling-section .product-text {
        padding: 30px 300px 30px 40px;
    }
    .piling-section .product-text strong {
        font-size: 2rem;
    }
    .info-content .info-inner {
        padding: 60px 40px;
    }
}
@media (min-width: 1600px) {
    .piling-section .product-text {
        padding: 30px 360px 30px 60px;
    }
    .info-content .info-inner {
        padding: 60px;
    }
}

.grid-icons {
    text-align: center;
}
.grid-icons img {
    display: inline-block;
    width: 80%;
    max-width: 250px;
    border-radius: 50%;
    margin-bottom: 30px;
}
.grid-link {
    position: relative;
    display: block;
    width: 100%;
    height: auto;
    overflow: hidden;
}
.grid-link img {
    position: relative;
    width: 100%;
    height: auto;
}
.grid-link img.fg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    font-family: "object-fit: cover;";
    filter: brightness(80%);
    z-index: 2;
    -webkit-transition: all .3s;
    transition: all .3s;
}
.grid-link:hover img.fg,
.grid-link:focus img.fg,
.grid-link.active img.fg {
    opacity: 0;
}
.grid-link .text {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    transform: translateY(-50%);
    color: #fff;
    font-size: 1.375rem;
    line-height: 1.4;
    text-transform: uppercase;
    text-align: center;
    padding: 15px;
    z-index: 5;
}
.link-content {
    display: none;
}
.link-content.active {
    display: block;
}

.tilewall {
    position: relative;
    width: 100%;
    height: auto;
    margin-top: .5rem;
    margin-bottom: .25rem;
    overflow: hidden;
}

.tilewall:after,
.tilewall:before,
.tilewall__content:after,
.tilewall__content:before {
    content: " ";
    display: table
}

.tilewall:after,
.tilewall__content:after,
.tilewall__group {
    clear: both
}

.tilewall--spacing .tilewall__content {
    margin: -.25rem
}

.tilewall--layout-q12 .tilewall__content--reverse .tile:first-child,
.tilewall--layout-q13 .tilewall__content--reverse .tile:first-child,
.tilewall--layout-q16 .tilewall__content--reverse .tile:first-child,
.tilewall--layout-q5 .tilewall__content--reverse .tile:first-child,
.tilewall--layout-q7 .tilewall__content--reverse .tile:first-child,
.tilewall--layout-q8 .tilewall__content--reverse .tile:first-child,
.tilewall--layout-q9 .tilewall__content--reverse .tile:first-child {
    float: right
}

.tilewall--spacing:last-child {
    margin-bottom: .25rem
}

.tilewall--spacing+.tilewall--spacing {
    margin-top: .25rem
}

.tile,
.tile--four-quarter.tile--double-height,
.tile--four-quarter.tile--quadruple-height,
.tile--four-quarter.tile--single-height,
.tile--four-quarter.tile--triple-height,
.tile--one-quarter.tile--double-height,
.tile--one-quarter.tile--quadruple-height,
.tile--one-quarter.tile--single-height,
.tile--one-quarter.tile--triple-height,
.tile--one-third.tile--double-height,
.tile--one-third.tile--quadruple-height,
.tile--one-third.tile--single-height,
.tile--one-third.tile--triple-height,
.tile--three-quarter.tile--double-height,
.tile--three-quarter.tile--quadruple-height,
.tile--three-quarter.tile--single-height,
.tile--three-quarter.tile--triple-height,
.tile--three-third.tile--double-height,
.tile--three-third.tile--quadruple-height,
.tile--three-third.tile--single-height,
.tile--three-third.tile--triple-height,
.tile--two-quarter.tile--double-height,
.tile--two-quarter.tile--quadruple-height,
.tile--two-quarter.tile--single-height,
.tile--two-quarter.tile--triple-height,
.tile--two-third.tile--double-height,
.tile--two-third.tile--quadruple-height,
.tile--two-third.tile--single-height,
.tile--two-third.tile--triple-height {
    position: relative
}

.tile {
    display: inline-block;
    float: left;
    color: #fff
}

.tilewall__content--right .tile {
    float: right
}

.tile--clear {
    clear: both
}

.tile__link {
    color: currentColor;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0
}

.tile--one-quarter {
    width: 50%
}

.tile--one-quarter.tile--single-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 66%
}

.tile--one-quarter.tile--double-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 132%
}

.tile--one-quarter.tile--triple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 198%
}

.tile--one-quarter.tile--quadruple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 264%
}

.tile--two-quarter {
    width: 100%
}

.tile--two-quarter.tile--single-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 33%
}

.tile--two-quarter.tile--double-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 66%
}

.tile--two-quarter.tile--triple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 99%
}

.tile--two-quarter.tile--quadruple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 132%
}

.tile--three-quarter {
    width: 100%
}

.tile--three-quarter.tile--single-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 25%
}

.tile--three-quarter.tile--double-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 50%
}

.tile--three-quarter.tile--triple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 75%
}

.tile--three-quarter.tile--quadruple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 100%
}

.tile--four-quarter {
    width: 100%
}

.tile--four-quarter.tile--single-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 18.75%
}

.tile--four-quarter.tile--double-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 37.5%
}

.tile--four-quarter.tile--triple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 56.25%
}

.tile--four-quarter.tile--quadruple-height:before,
.tile--one-third.tile--single-height:before {
    padding-top: 50%;
    width: 100%;
    display: block;
    content: ""
}

.tile--one-third {
    width: 100%
}

.tile--one-third.tile--double-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 100%
}

.tile--one-third.tile--triple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 150%
}

.tile--one-third.tile--quadruple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 200%
}

.tile--two-third {
    width: 100%
}

.tile--two-third.tile--single-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 37.5%
}

.tile--two-third.tile--double-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 75%
}

.tile--two-third.tile--triple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 112.5%
}

.tile--two-third.tile--quadruple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 150%
}

.tile--three-third {
    width: 100%
}

.tile--three-third.tile--single-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 25%
}

.tile--three-third.tile--double-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 50%
}

.tile--three-third.tile--triple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 75%
}

.tile--three-third.tile--quadruple-height:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 100%
}

.tile__wrap,
.tilewall.tilewall--spacing {
    overflow: hidden
}

.tile__wrap {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover
}

.tilewall--spacing .tile__wrap {
    position: absolute;
    top: .25rem;
    left: .25rem;
    right: .25rem;
    bottom: .25rem
}

.tile__bg {
    position: relative;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
}
.tile__text {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    right: 0;
    text-align: center;
    text-transform: uppercase;
    color: #fff!important;
    z-index: 10;
}

.box {
    display: flex;
    flex-flow: column;
}

.box .box-header {
    flex: 0 1 auto;
}

.box .box-content {
    position: relative;
    flex: 1 1 auto;
}
.box .box-content .box-content-bg {
    position: absolute;
    top: 0;
    height: 100%;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
}
.box .box-content .box-content-bg img {
    width: calc(100% + 30px);
    max-width: none;
}
.box .box-content.left .box-content-bg {
    left: -30px;
    right: 0;
}
.box .box-content.left .box-content-bg.ws {
    left: -30px;
    right: 10%;
}
.box .box-content.right .box-content-bg {
    right: -30px;
    left: 0;
}
.box .box-content .box-content-bg.contain {
    background-position: left top;
    background-size: 100% auto;
}
.box .box-content .box-content-bg.ws img {
    position: absolute;
    top: 10%;
    right: -15%;
    width: 20%;
    z-index: 5;
}
@media (min-width:1340px) {
    .box .box-content.left .box-content-bg,
    .box .box-content.left .box-content-bg.ws {
        left: calc(1px - calc((100vw - 1278px)/2));
    }
    .box .box-content.right .box-content-bg {
        right: calc(1px - calc((100vw - 1278px)/2));
    }
    .box .box-content .box-content-bg.ws img {
        right: -10%;
        width: 18%;
    }
    .box .box-content .box-content-bg img {
        width: calc(100% + calc((100vw - 1278px)/2));
    }
}

.accordion {
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
}
.accordion-item {
    background-color: #f3f4f8;
    margin-bottom: 5px;
    -webkit-transition: 0.4s ease-in-out;
    transition: 0.4s ease-in-out;
    overflow: hidden;
}
.accordion-item:last-of-type {
    margin-bottom: 0;
}
.accordion-title {
    cursor: pointer;
    padding: 12px 50px 12px 20px;
    position: relative;
    color: #6f9e21;
    text-transform: uppercase;
}
.accordion-title span {
    width: 30px;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    text-align: center;
}
.accordion-title span::before {
    content: '+';
    top: 0;
    left: 0;
    width: 100%;
    color: #6f9e21;
    font-size: 1.5rem;
    display: block;
}
.accordion-title span::after {
    content: '-';
    top: 0;
    left: 0;
    width: 100%;
    color: #6f9e21;
    font-size: 1.5rem;
    display: none;
}
.accordion-title.active span::before {
    display: none;
}
.accordion-title.active span::after {
    display: block;
}
.accordion-content {
    padding: 5px 20px 20px;
    display: none;
}
.accordion-content.open {
    display: block
}
.numbers {
    position: relative;
    width: 100%;
    height: auto;
}
.numbers .number {
    margin-bottom: 2rem;
}
.numbers .number .number-counter {
    display: block;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1;
    margin-left: -.2vw
}
.farm {
    margin-bottom: 2rem;
}
.farm .farm-image {
    position: relative;
    width: 100%;
    z-index: 2;
}
.farm .farm-image.left {
    margin-left: -15px;
}
.farm .farm-image.right {
    margin-left: 15px;
}
.farm .farm-text {
    position: relative;
    width: 100%;
    margin-top: -30px;
    padding: 50px 15px 20px;
    z-index: 1;
}
.farm .bg-light-green .ctx {
    color: #fff!important;
}
.farm .bg-light-grey .h3 {
    color: #6f9e21!important;
}

@media only screen and (min-width: 712px) and (orientation: portrait) {
    #main {
        padding-top: 100px;
    }
    .grid-link .text {
        font-size: 1.5rem;
    }
    .accordion-title {
        padding: 15px 55px 15px 30px;
    }
    .accordion-title span {
        width: 32px;
        height: 32px;
    }
    .accordion-title span::before,
    .accordion-title span::after {
        font-size: 1.75rem;
    }
    .farm .farm-image.left {
        margin-left: -30px;
    }
    .farm .farm-image.right {
        margin-left: 30px;
    }
    .farm .farm-text {
        margin-top: -40px;
        padding: 60px 25px 30px;
        z-index: 1;
    }
}
@media (min-width:712px) {
    .hero img.claim {
        max-width: 500px;
    }
    .hero .icon-bio {
        max-width: 110px;
        bottom: 60px;
        right: 60px;
    }
    .section .augustin-icon {
        width: 240px;
        top: -120px;
    }
    .section .icon-bio {
        height: 90px;
    }
    .section .icon-demeter {
        height: 65px;
    }
    .accordion-title {
        padding: 15px 55px 15px 30px;
    }
    .accordion-title span::before,
    .accordion-title span::after {
        font-size: 1.75rem;
    }
    .numbers .number .number-counter {
        font-size: 2.5rem;
    }
}
@media(min-width:768px) {
    .tilewall--spacing .tilewall__content {
        margin: -.5rem
    }
    .tilewall--spacing:last-child {
        margin-bottom: .5rem
    }
    .tilewall--spacing+.tilewall--spacing {
        margin-top: .5rem
    }
    .tile--one-quarter {
        width: 25%
    }
    .tile--one-third {
        width: 33.3333333333%
    }
    .tile--two-third {
        width: 66.6666666667%
    }
    .tile--two-quarter {
        width: 50%
    }
    .tile--three-quarter {
        width: 75%
    }
}
@media only screen and (min-width:992px) {
    #main {
        padding-top: 90px;
    }
    .section {
        padding: 90px 0;
    }
    .section .augustin-icon {
        width: 320px;
        top: -220px;
    }
    .next-section {
        font-size: 1.75rem;
    }
    .next-section.right {
        right: 30px;
        width: 40px;
    }
    .hero .icon-bio {
        max-width: 120px;
        bottom: 60px;
        right: 60px;
    }
    .section .augustin-siegel {
        max-width: 120px;
    }
    .box .box-header {
        padding-bottom: 60px;
    }
    .accordion-title {
        padding: 15px 60px 15px 30px;
    }
    .accordion-title span {
        right: 30px;
    }
    .accordion-content {
        padding: 5px 30px 30px;
    }
    .numbers .number {
        margin-bottom: 2.5rem;
    }
    .numbers .number .number-counter {
        font-size: 3rem;
    }
    .farm {
        margin-bottom: 3rem;
    }
    .farm .farm-image.left,
    .farm .farm-image.right {
        margin: 0;
    }
    .farm .farm-text {
        margin-top: 30px;
        width: calc(100% + 30px);
        padding: 30px;
        z-index: 1;
    }
    .farm .farm-text.left {
        margin-right: 30px;
        padding-right: 60px;
    }
    .farm .farm-text.right {
        margin-left: -30px;
        padding-left: 60px;
    }
}
@media only screen and (min-width:1200px) {
    #main {
        padding-top: 100px;
    }
    .hero img.claim {
        max-width: 600px;
    }
    .hero .icon-bio {
        right: 5vw;
        max-width: 130px;
    }
    .next-section {
        font-size: 2rem;
    }
    .section .icon-bio {
        height: 110px;
    }
    .section .icon-demeter {
        height: 85px;
    }
    .tilewall {
        margin-top: 1rem;
        margin-bottom: .5rem;
    }
    .tilewall--spacing .tile__wrap {
        top: .5rem;
        left: .5rem;
        right: .5rem;
        bottom: .5rem;
    }
}
@media only screen and (min-width:1440px) {
    .section {
        padding: 120px 0;
    }
    .next-section {
        font-size: 2.5rem;
    }
    .farm {
        margin-bottom: 4rem;
    }
    .farm .farm-text {
        margin-top: 40px;
        width: calc(100% + 40px);
        z-index: 1;
    }
    .farm .farm-text.left {
        margin-right: 40px;
        padding-right: 70px;
    }
    .farm .farm-text.right {
        margin-left: -40px;
        padding-left: 70px;
    }
}
@media only screen and (min-width:1600px) {
    .grid-link .text {
        font-size: 1.5rem;
    }
    .section .augustin-icon {
        width: 30vw;
        top: -20vw;
    }
    .section .augustin-siegel {
        max-width: 140px;
    }
}

.grid-masonry {
    margin-left: -1rem;
    margin-right: -1rem;
}
.grid-item {
    position: relative;
    overflow: hidden;
    float: left;
    width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
    margin-bottom: 3rem;
}
@media only screen and (min-width:640px) {
    .grid-item {
        width: 50%;
    }
}
@media only screen and (min-width:1200px) {
    .grid-masonry {
        margin-left: -1.25rem;
        margin-right: -1.25rem;
    }
    .grid-item {
        width: 33.333333%;
        padding-left: 1.25rem;
        padding-right: 1.25rem;
    }
}

.post-thumbnail {
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden;
    margin-bottom: 2rem;
}
.post-thumbnail img {
	display: block;
	margin: 0 auto;
    max-width: 100%;
    height: auto
}
.post-meta {
    font-size: .9375rem;
    margin-bottom: 1rem;
}
.post-meta a {
    display: inline-block;
    color: #003e19;
}
.post-meta a:hover {
    color: #6f9e21;
}
.posted-on,
.by {
    margin-right: 10px;
}
.posted-on::before,
.by::before,
.tags-links::before {
    font-family: 'fontello';
    margin-right: 7px;
}
.posted-on::before {
    content: '\e811';
}
.by::before {
    content: '\f2c0';
}
.tags-links::before {
    content: '\e812';
}
.cat-item {
    margin-bottom: .25rem;
}

@media only screen and (min-width:1600px) {
    .post-meta {
        font-size: 1rem;
    }
}

.pagination .nav-links {
    width: 100%;
    display: block;
    position: relative;
    text-align: center;
}
.pagination .page-numbers {
    position: relative;
    display: inline-block;
    margin: 0 5px;
    padding: 0;
    width: auto;
    height: 34px;
    line-height: 34px;
    text-align: center;
    border-bottom: none!important;
}
.pagination .page-numbers.current {
    width: 34px;
    background-color: #f6f0ed;
}
@media only screen and (min-width:992px) {
    .pagination .page-numbers {
        height: 40px;
        line-height: 40px;
    }
    .pagination .page-numbers.current {
        width: 40px;
    }
}

.error-404 {
    text-align: center;
}
.error-404 h1 {
    font-size: 100px;
    margin-bottom: 20px;
    text-shadow: 3px 3px 0 rgba(178,178,178,1),8px 8px 0 rgba(0,0,0,.15);
}
.error-404 h2 {
    line-height: 30px;
    letter-spacing: 0px;
    font-weight: 400;
    font-size: 24px;
}
.error-404 .searchform {
    border: 3px dashed rgba(0,0,0,.05);
    padding: 15px;
    margin-top: 40px;
}
@media (min-width:768px) {
    .error-404 h1 {
        font-size: 200px;
        margin-bottom: 30px;
    }
    .error-404 h2 {
        line-height: 42px;
        font-size: 30px;
    }
    .error-404 .searchform {
        padding: 30px 90px;
        margin-top: 40px;
    }
}

.newsletter {
    position: relative;
    width: 100%;
    height: auto;
    padding: 40px 0;
    background-color: #721511;
    color: #fff;
    z-index: 2
}
.footer {
    position: relative;
    width: 100%;
    height: auto;
    padding: 40px 0 20px;
    font-size: 1rem;
    background-color: #003e19;
    color: #fff;
    z-index: 2
}
.footer .copyright {
    font-size: .9375rem;
    text-align: center;
    margin-top: 1rem;
}
.footer .footer-logo img {
    display: inline-block;
    max-width: 210px;
    margin-bottom: .75rem;
}
.footer .menu-block {
    position: relative;
    width: 100%;
    height: auto;
    overflow: hidden
}
.footer .headline,
.footer .headline > a,
.footer .menu-block li.menu-item-has-children > a {
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.5px;
    line-height: 1;
    color: #fff;
    margin-bottom: .25rem;
}
.footer a {
    color: #fff
}
.footer a:hover,
.footer a:focus {
    color: #fff;
    text-decoration: none
}
.footer ul {
    margin: 0 0 1.375rem 0;
    padding: 0;
    list-style: none
}
.footer ul li {
    display: block;
}
.footer ul li a {
    display: inline-block;
}
.footer ul li a span {
	background-image: linear-gradient(transparent calc(100% - 1px), #fff 1px);
	background-size: 0 calc(105% - 1px);
	background-repeat: no-repeat;
	display: inline;
    padding-bottom: 2px;
	transition: .3s ease;
}
.footer ul li a:hover span,
.footer ul li.current-menu-item > a span {    
  	background-size: 100% calc(105% - 1px);
}
.footer ul li.current-menu-item > a {
    pointer-events: none;
}
.footer .address {
    padding-bottom: .25rem;
}
.footer .contact-coordinates span {
    display: inline-block;
    min-width: 3.75rem;
}
.footer .social-media {
    margin-top: 1.375rem;
}
.footer .social-media a {
    display: inline-block;
    font-size: 1.875rem;
    margin-right: .125rem;
}
@media only screen and (min-width:992px) {
    .newsletter {
        padding: 60px 0;
    }
    .footer {
        padding: 60px 0 20px;
    }
    .footer .footer-logo img {
        max-width: 230px;
    }
    .footer .copyright {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
        justify-content: space-between;
        text-align: left;
        font-size: 1rem;
    }
}
@media only screen and (min-width:1200px) {
    .footer {
        font-size: 1.125rem;
    }
    .footer .footer-logo img {
        max-width: 265px;
    }
    .footer .social-media a {
        font-size: 2rem;
    }
}

@media print {
    .noPrint {
        display: none;
    }
}
