/*! HTML5 Boilerplate v5.3.0 | MIT License | https://html5boilerplate.com/ */

/*
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */

/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */

html {
    color: #222;
    font-size: 1em;
    line-height: 1.4;
}

/*
 * Remove text-shadow in selection highlight:
 * https://twitter.com/miketaylr/status/12228805301
 *
 * These selection rule sets have to be separate.
 * Customize the background color to match your design.
 */

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

/*
 * A better looking default horizontal rule
 */

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}

/*
 * Remove the gap between audio, canvas, iframes,
 * images, videos and the bottom of their containers:
 * https://github.com/h5bp/html5-boilerplate/issues/440
 */

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */

textarea {
    resize: vertical;
}

/* ==========================================================================
   Browser Upgrade Prompt
   ========================================================================== */

.browserupgrade {
    margin: 0.2em 0;
    background: #ccc;
    color: #030503;
    padding: 0.2em 0;
}

/* ==========================================================================
   Author's custom styles
   ========================================================================== */

@import url('https://fonts.googleapis.com/css?family=Montserrat:400,700&display=swap');

@font-face {
    font-family: 'Neo Tech Std';
    src: url('../font/NeoTechStd-BlackItalic.woff') format('woff');
}

html {
    color: #030503;
    font: 16px/1.5em 'Montserrat', sans-serif;
}

@media only screen and (max-width: 1583px) { /* < 1600 */
}

@media only screen and (max-width: 1423px) { /* < 1440 */
}

@media only screen and (max-width: 1263px) { /* < 1280 */
}

@media only screen and (max-width: 1007px) { /* < 1024 */
    html {
        font-size: 14px;
        line-height: 1.5em;
    }
}

@media only screen and (max-width: 959px) { /* < 960 */
}

@media only screen and (max-width: 839px) { /* < 840 */
}

@media only screen and (max-width: 719px) { /* < 720 */
    html {
        font-size: 14px;
        line-height: 1.5em;
    }
}

@media only screen and (max-width: 599px) { /* < 600 */
}

@media only screen and (max-width: 479px) { /* < 480 */
}

@media only screen and (max-width: 399px) { /* < 400 */
}

@media only screen and (max-width: 359px) { /* < 360 */
}

html.mobile-menu-active body {
    overflow: hidden;
    position: fixed;
}

h1 {
    font-family: 'Neo Tech Std', sans-serif;
    font-size: 112px;
    line-height: 1.2em;
    margin: 0 0 24px 0;
    text-transform: uppercase;
}

h2 {
    font-family: 'Neo Tech Std', sans-serif;
    font-size: 56px;
    line-height: 1.2em;
    margin: 0 0 24px 0;
    text-transform: uppercase;
}

h3 {
    font-family: 'Neo Tech Std', sans-serif;
    font-size: 45px;
    line-height: 1.2em;
    margin: 0 0 24px 0;
    text-transform: uppercase;
}

h4 {
    font-family: 'Neo Tech Std', sans-serif;
    font-size: 34px;
    line-height: 1.2em;
    margin: 0 0 24px 0;
    text-transform: uppercase;
}

h5 {
    font-family: 'Neo Tech Std', sans-serif;
    font-size: 24px;
    line-height: 1.5em;
    margin: 0 0 24px 0;
    text-transform: uppercase;
}

h6 {
    font-family: 'Neo Tech Std', sans-serif;
    font-size: 20px;
    line-height: 1.5em;
    margin: 0 0 24px 0;
    text-transform: uppercase;
}

.display-4 {
    font-size: 112px;
    line-height: 1.2em;
}

.display-3 {
    font-size: 56px;
    line-height: 1.2em;
}

.display-2 {
    font-size: 45px;
    line-height: 1.2em;
}

.display-1 {
    font-size: 34px;
    line-height: 1.2em;
}

.headline {
    font-size: 24px;
    line-height: 1.5em;
}

.title {
    font-size: 20px;
    line-height: 1.5em;
}

.caption {
    font-size: 14px;
    line-height: 1.5em;
}

@media only screen and (max-width: 1007px) {
    h1 {
        font-size: 56px;
        line-height: 1.2em;
    }

    h2 {
        font-size: 45px;
        line-height: 1.2em;
    }

    h3 {
        font-size: 34px;
        line-height: 1.2em;
    }

    h4 {
        font-size: 24px;
        line-height: 1.5em;
    }

    h5 {
        font-size: 20px;
        line-height: 1.5em;
    }

    h6 {
        font-size: 16px;
        line-height: 1.5em;
    }

    .display-4 {
        font-size: 56px;
        line-height: 1.2em;
    }

    .display-3 {
        font-size: 45px;
        line-height: 1.2em;
    }

    .display-2 {
        font-size: 34px;
        line-height: 1.2em;
    }

    .display-1 {
        font-size: 24px;
        line-height: 1.2em;
    }

    .headline {
        font-size: 20px;
        line-height: 1.5em;
    }

    .title {
        font-size: 16px;
        line-height: 1.5em;
    }

    .caption {
        font-size: 12px;
        line-height: 1.5em;
    }
}

@media only screen and (max-width: 719px) {
    h1 {
        font-size: 45px;
        line-height: 1.2em;
    }

    h2 {
        font-size: 34px;
        line-height: 1.2em;
    }

    h3 {
        font-size: 24px;
        line-height: 1.5em;
    }

    h4 {
        font-size: 20px;
        line-height: 1.5em;
    }

    h5 {
        font-size: 16px;
        line-height: 1.5em;
    }

    .display-4 {
        font-size: 45px;
        line-height: 1.2em;
    }

    .display-3 {
        font-size: 34px;
        line-height: 1.2em;
    }

    .display-2 {
        font-size: 24px;
        line-height: 1.2em;
    }

    .display-1 {
        font-size: 20px;
        line-height: 1.5em;
    }

    .headline {
        font-size: 16px;
        line-height: 1.5em;
    }
}

img {
    height: auto !important;
    max-width: 100%;
}

iframe {
    max-width: 100%;
}

p {
    margin: 0 0 24px 0;
}

a {
    color: #008A35;
    font-weight: bold;
}

a:focus {
    outline: none;
}

ul,
ol {
   margin: 0 0 24px 0;
}

blockquote {
    color: #BCBEC0;
    font-weight: bold;
    margin: 0 0 24px 24px;
}

.clear {
    clear: both;
}

@media only screen and (max-width: 1007px) {
    .clear {
        clear: none;
    }
    
    .clear-1024 {
        clear: both;
    }
}

@media only screen and (max-width: 719px) {
    .clear-1024 {
        clear: none;
    }
    
    .clear-720 {
        clear: both;
    }
}

.my-image img {
    width: 100% !important;
}

.my-video {
    padding: 56.25% 0 0 0;
    position: relative;
}

.my-video iframe {
    height: 100% !important;
    left: 0;
    position: absolute;
    top: 0;
    width: 100% !important;
}

.video-embed-field-responsive-video {
    margin: 0 0 24px 0;
}

a.button {
    -webkit-transition: background-color 250ms, color 250ms;
    transition: background-color 250ms, color 250ms;
    
    background: #008A35;
    border-radius: 2px;
    box-sizing: border-box;
    color: #FFF;
    font: 14px/1em 'Neo Tech Std', sans-serif;
    display: inline-block;
    margin: 6px 0;
    padding: 14px 32px;
    text-decoration: none;
    text-transform: uppercase;
}

a.button:hover {
    background: #030503;
}

span.button {
    -webkit-transition: background-color 250ms, color 250ms;
    transition: background-color 250ms, color 250ms;
    
    background: #008A35;
    border-radius: 2px;
    box-sizing: border-box;
    color: #FFF;
    display: inline-block;
    font: 14px/1em 'Neo Tech Std', sans-serif;
    padding: 14px 32px;
    text-transform: uppercase;
}

span.button:hover {
    background: #030503;
}

.color-2 {
    color: #008A35;
}

.font-family-2 {
    font-family: 'Neo Tech Std', sans-serif;
    text-transform: uppercase;
}

.alert {
    color: red;
}

/* form */
.form-item {
    margin: 0 0 12px 0;
}

.form-text {
    border: 1px solid #030503;
    border-radius: 0;
    box-sizing: border-box;
    color: #030503;
    display: block;
    font-size: 16px;
    line-height: 1em;
    padding: 12px 16px;
    width: 100%;
}

.form-text:focus {
    outline: none;
}

select {
    border: 1px solid #030503;
    border-radius: 0;
    box-sizing: border-box;
    display: block;
    font-size: 16px;
    line-height: 1em;
    padding: 12px 16px;
    width: 100%;
}

.select:focus {
    outline: none;
}

.form-actions {
    margin: 0 0 24px 0;
}

.form-submit {
    background: #008A35;
    border: none;
    border-radius: 2px;
    box-sizing: border-box;
    color: #FFF;
    font: 14px/1em 'Neo Tech Std', sans-serif;
    margin: 0 4px 0 0;
    padding: 14px 32px;
    text-transform: uppercase;
}

.form-submit:focus {
    outline: none;
}

/* table */
.table-container {
    overflow: auto;
}

table {
    margin: 0 0 24px 0;
    width: 100%;
}

tr:nth-child(odd) {
    background: #F1F1F2;
}

th {
    padding: 12px;
    text-align: left;
}

td {
    padding: 12px;
}

/* table-style-2 */
.table-style-2 tr:nth-child(odd) {
    background: transparent;
}

.table-style-2 th,
.table-style-2 td {
    border-bottom: 1px solid #008A35;
}

.table-style-2 .cell-style-2 {
    border-right: 1px dotted #008A35;
    text-align: center;
    width: 1px;
}

.table-style-2 .cell-style-3 {
   color: #008A35;
   font-weight: bold;
   text-align: right;
}

/* layout */
.container {
    margin: 0 auto;
    max-width: 1024px;
}

.col {
    float: left;
    min-height: 1px;
}

.col-1 {
    width: 8.333333333333333%;
}

.col-2 {
    width: 16.666666666666666%;
}

.col-2d4 {
    width: 20%;
}

.col-3 {
    width: 25%
}

.col-4 {
    width: 33.333333333333333%
}

.col-5 {
    width: 41.666666666666666%;
}

.col-6 {
    width: 50%;
}

.col-7 {
    width: 58.333333333333333%;
}

.col-8 {
    width: 66.666666666666%;
}

.col-9 {
    width: 75%;
}

.col-10 {
    width: 83.333333333333333%;
}

.col-11 {
    width: 91.666666666666666%;
}

.col-12 {
    width: 100%;
}

.gutter-12 {
    padding: 0 12px;
}

.gutter-12-r {
    padding: 0 12px 0 0;
}

.gutter-12-l {
    padding: 0 0 0 12px;
}

.margin-12 {
    margin: 0 0 12px 0;
    min-height: 1px;
}

.margin-24 {
    margin: 0 0 24px 0;
    min-height: 1px;
}

.margin-48 {
    margin: 0 0 48px 0;
    min-height: 1px;
}

@media only screen and (max-width: 1007px) {
    .col-1-1024 {
        width: 8.333333333333333%;
    }
    
    .col-2-1024 {
        width: 16.666666666666666%;
    }
    
    .col-2d4-1024 {
        width: 20%;
    }
    
    .col-3-1024 {
        width: 25%
    }

    .col-4-1024 {
        width: 33.333333333333333%
    }

    .col-5-1024 {
        width: 41.666666666666666%;
    }

    .col-6-1024 {
        width: 50%;
    }

    .col-7-1024 {
        width: 58.333333333333333%;
    }

    .col-8-1024 {
        width: 66.666666666666%;
    }

    .col-9-1024 {
        width: 75%;
    }

    .col-10-1024 {
        width: 83.333333333333333%;
    }

    .col-11-1024 {
        width: 91.666666666666666%;
    }

    .col-12-1024 {
        width: 100%;
    }
    
    .hidden-1024 {
        display: none;
    }
}

@media only screen and (max-width: 719px) {
    .col-1-720 {
        width: 8.333333333333333%;
    }
    
    .col-2-720 {
        width: 16.666666666666666%;
    }
    
    .col-2d4-720 {
        width: 20%;
    }
    
    .col-3-720 {
        width: 25%
    }

    .col-4-720 {
        width: 33.333333333333333%
    }

    .col-5-720 {
        width: 41.666666666666666%;
    }

    .col-6-720 {
        width: 50%;
    }

    .col-7-720 {
        width: 58.333333333333333%;
    }

    .col-8-720 {
        width: 66.666666666666%;
    }

    .col-9-720 {
        width: 75%;
    }

    .col-10-720 {
        width: 83.333333333333333%;
    }

    .col-11-720 {
        width: 91.666666666666666%;
    }

    .col-12-720 {
        width: 100%;
    }
    
    .hidden-720 {
        display: none;
    }
}

/* table */
.table {
    display: table;
    height: 100%;
    table-layout: fixed;
    width: 100%;
}

.table-row {
    display: table-row;
}

.table-cell {
    display: table-cell;
}

.table-cell.top {
    vertical-align: top;
}

.table-cell.middle {
    vertical-align: middle;
}

.table-cell.bottom {
    vertical-align: bottom;
}

/* anchor */
.anchor {
    position: relative;
    top: -102px;
}

@media only screen and (max-width: 1263px) {
    .anchor {
        top: -48px;
    }
}

/* header */
.header-holder {
    height: 80px;
    margin: 0 0 48px 0;
}

@media only screen and (max-width: 1263px) {
    .header-holder {
        display: none;
    }
}

.header {
    background: rgba(0, 138, 53, 0.9);
    box-sizing: border-box;
    height: 80px;
    left: 0;
    padding: 0 24px;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 501;
}

@media only screen and (max-width: 1263px) {
    .header {
        display: none;
    }
}

body.toolbar-horizontal .header {
    top: 39px;
}

body.toolbar-horizontal.toolbar-tray-open .header {
    top: 78px;
}

body.toolbar-vertical .header {
    top: 39px;
}

/* logo */
.logo {
    color: #FFF;
    float: left;
    font: bold 30px/1em 'Neo Tech Std', sans-serif;
    margin: 10px 0 0 0;
    text-decoration: none;
    text-transform: uppercase;
}

/* main-menu */
.main-menu {
    color: #030503;
    float: right;
    font-family: 'Neo Tech Std', sans-serif;
}

.main-menu ul {
    float: left;
    font-size: 14px;
    line-height: 80px;
    list-style: none;
    margin: 0;
    padding: 0;
    text-transform: uppercase;
}

.main-menu li {
    float: left;
    margin: 0 20px 0 0;
}

.main-menu li:last-child {
    margin: 0;
}

.main-menu a {
    color: #030503;
    display: block;
    font-weight: normal;
    text-decoration: none;
}

.main-menu a:hover,
.main-menu a.is-active {
    color: #FFF;
}

.main-menu a[data-drupal-link-system-path="cart"] {
    background: url(../images/cart.svg) no-repeat 50% 50%;
    overflow: hidden;
    position: relative;
    text-indent: 100%;
    white-space: nowrap;
    width: 30px;
}

.main-menu [data-drupal-link-system-path="cart"] span {
    color: #FFF;
    display: block;
    font-size: 10px;
    line-height: 10px;
    position: absolute;
    right: 0;
    top: 16px;
}

.main-menu a[data-drupal-link-system-path="user"] {
    background: url(../images/user.svg) no-repeat 50% 50%;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    width: 24px;
}

.main-menu a[data-drupal-link-system-path="search"] {
    background: url(../images/search.svg) no-repeat 50% 50%;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    width: 24px;
}

.main-menu span {
    display: block;
}

.main-menu ul ul {
    background: rgba(230, 231, 232, 0.95);
    box-sizing: border-box;
    color: #4D4D4F;
    display: none;
    font-size: 20px;
    left: 0;
    line-height: 1.2em;
    list-style: none;
    margin: 0;
    padding: 24px;
    position: absolute;
    text-align: center;
    top: 80px;
    width: 100%;
}

.main-menu ul li:hover ul {
    display: block;
}

.main-menu ul ul li {
    display: inline-block;
    float: none;
    margin: 0 24px;
    text-align: left;
}

.main-menu ul ul a {
    color: #4D4D4F;
    margin: 0 0 16px 0;
    text-decoration: none;
}

.main-menu ul ul a:hover {
    color: #008A35;
}

.main-menu ul ul span {
    margin: 0 0 16px 0;
}

.main-menu ul ul ul {
    background: none;
    font-size: 14px;
    left: auto;
    line-height: 1.5em;
    padding: 0;
    position: static;
    text-transform: none;
    top: auto;
    width: auto;
}

.main-menu ul ul ul li {
    display: block;
    margin: 0;
    width: auto;
}

.main-menu ul ul ul a {
    margin: 0;
    text-decoration: underline;
}

/* mobile-header */
.mobile-header-holder {
    display: none;
    height: 44px;
    margin: 0 0 24px 0;
}

@media only screen and (max-width: 1263px) {
    .mobile-header-holder {
        display: block;
    }
}

.mobile-header {
    display: none;
}

@media only screen and (max-width: 1263px) {
    .mobile-header {
        display: block;
    }
}

.mobile-header-panel {
    background: rgba(0, 138, 53, 0.9);
    height: 44px;
    left: 0;
    overflow: hidden;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 502;
}

.mobile-header-button {
    height: 40px;
    float: right;
    margin: 2px;
    position: relative;
    width: 40px;
}

.mobile-header-button span {
    -webkit-transition: background-color 250ms;
    transition: background-color 250ms;
    
    background: #FFF;
    display: block;
    height: 2px;
    left: 50%;
    margin: -1px 0 0 -9px;
    position: absolute;
    top: 50%;
    width: 18px;
}

.mobile-header-button.active span {
    background: none;
}

.mobile-header-button span:before {
    -webkit-transition: top 250ms, -webkit-transform 250ms, transform 250ms;
    transition: top 250ms, -webkit-transform 250ms, transform 250ms;
    
    background: #FFF;
    content: "";
    display: block;
    height: 2px;
    left: 0;
    position: absolute;
    top: -5px;
    width: 18px;
}

.mobile-header-button.active span:before {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    
    top: 0;
}

.mobile-header-button span:after {
    -webkit-transition: top 250ms, -webkit-transform 250ms, transform 250ms;
    transition: top 250ms, -webkit-transform 250ms, transform 250ms;
    
    background: #FFF;
    content: "";
    display: block;
    height: 2px;
    left: 0;
    position: absolute;
    top: 5px;
    width: 18px;
}

.mobile-header-button.active span:after {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    
    top: 0;
}

.mobile-header-panel-2 {
    background: rgba(255, 255, 255, 0.95);
    box-sizing: border-box;
    height: calc(100% - 44px);
    left: 0;
    overflow: auto;
    position: fixed;
    top: 44px;
    width: 100%;
    z-index: 501;
}

.mobile-header-panel-2-panel {
    padding: 12px 12px 1px 12px;
}

/* mobile-logo */
.mobile-logo {
    float: left;
    margin: 8px 0 0 12px;
}

/* mobile-menu */
.mobile-menu ul {
    font-size: 14px;
    line-height: 1em;
    list-style: none;
    margin: 0;
    padding: 0;
    text-transform: uppercase;
}

.mobile-menu a {
    display: block;
    font-weight: normal;
    margin: 0 0 12px 0;
    text-decoration: none;
}

.mobile-menu a.is-active {
    text-decoration: underline;
}

.mobile-menu span {
    display: block;
    margin: 0 0 12px 0;
}

.mobile-menu ul ul {
    margin: 0 0 0 24px;
}

/* tabs */
.tabs {
    list-style: none;
    margin: 0;
    padding: 0;
}

.tabs li {
    float: left;
    margin: 0 12px 0 0;
}

.tabs li:last-child {
    margin: 0;
}

.tabs a {
    font-weight: normal;
    text-decoration: none;
}

.tabs a:hover,
.tabs a.is-active {
    text-decoration: underline;
}

/* slideshow */
.slideshow {
    margin: 0 0 48px 0;
    padding: 33.333333333333333% 0 0 0;
    position: relative;
}

@media only screen and (max-width: 1263px) {
    .slideshow {
        padding: 50% 0 0 0;
    }
}

@media only screen and (max-width: 1007px) {
    .slideshow {
        padding: 75% 0 0 0;
    }
}

@media only screen and (max-width: 719px) {
    .slideshow {
        padding: 100% 0 0 0;
    }
}

.slideshow-panel {
    height: 100%;
    left: 0;
    overflow: hidden;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}

.slideshow-slideshow {
    height: 100%;
}

.slideshow-slide {
    background-position: 50% 50%;
    background-repeat: no-repeat;
    background-size: cover;
    box-sizing: border-box;
    height: 100%;
    padding: 24px 0 84px 0;
    width: 100%;
}

.slideshow-slide-panel {
    background: rgba(255, 255, 255, 0.9);
    padding: 24px 24px 1px 24px;
}

.slideshow-pager {
    bottom: 48px;
    left: 0;
    line-height: 12px;
    position: absolute;
    text-align: center;
    width: 100%;
    z-index: 101;
}

@media only screen and (max-width: 1007px) {
    .slideshow-pager {
        bottom: 24px;
    }
}

.slideshow-pager span {
    background: #FFF;
    border-radius: 50%;
    cursor: pointer;
    display: inline-block;
    height: 12px;
    margin: 0 3px;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    width: 12px;
}

.slideshow-pager span.cycle-pager-active {
    background: #008A35;
}

/* teaser */
.teaser {
    background-position: 50% 50%;
    background-repeat: no-repeat;
    background-size: cover;
    color: #FFF;
    padding: 75% 0 0 0;
    position: relative;
    text-align: center;
}

@media only screen and (max-width: 719px) {
    .teaser {
        padding: 0;
    }
}

.teaser-panel {
    box-sizing: border-box;
    height: 100%;
    left: 0;
    overflow: hidden;
    padding: 48px 48px 24px 48px;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}

.teaser-color-1 .teaser-panel {
    background: rgba(0, 138, 53, 0.8);
}

.teaser-color-2 .teaser-panel {
    background: rgba(79, 174, 47, 0.8);
}

.teaser-color-3 .teaser-panel {
    background: rgba(0, 138, 53, 0.8);
}

.teaser-color-4 .teaser-panel {
    background: rgba(3, 5, 3, 0.8);
}

@media only screen and (max-width: 1007px) {
    .teaser-panel {
        padding: 24px 24px 0px 24px;
    }
}

@media only screen and (max-width: 719px) {
    .teaser-panel {
        position: static;
    }
}

.teaser a {
    color: #FFF;
}

.teaser .button {
    background: #FFF;
    border: 2px solid #FFF;
}

.teaser-color-1 .button {
    color: #008A35;
}

.teaser-color-2 .button {
    color: #4FAE2F;
}

.teaser-color-3 .button {
    color: #008A35;
}

.teaser-color-4 .button {
    color: #030503;
}

.teaser .button:hover {
    background: none;
    color: #FFF;
}

/* teaser-2 */
.teaser-2 {
    color: #030503;
    display: block;
    text-decoration: none;
}

.teaser-2-panel {
    height: 4.5em;
    margin: 0 0 24px 0;
    overflow: hidden;
}

/* social */
.social {
    color: #FFF;
    display: block;
    padding: 100% 0 0 0;
    position: relative;
    text-align: center;
    text-decoration: none;
}

.social-facebook {
    background: #030503;
}

.social-twitter {
    background: #008A35;
}

.social-instagram {
    background: #4FAE2F;
}

.social-panel {
    box-sizing: border-box;
    height: 100%;
    left: 0;
    padding: 32px 32px 1px 32px;
    position: absolute;
    top: 0;
    width: 100%;
}

/* footer */
.footer {
    font-size: 14px;
    line-height: 1.5em;
}

.footer-panel {
    background: #F8F8F9;
    color: #808285;
    padding: 48px 0 24px 0;
    text-align: center;
}

.footer-panel-2 {
    background: #BCBEC0;
    color: #4D4D4F;
    padding: 48px 0 24px 0;
}

.footer-panel-2 h2 {
    font-size: 20px;
    line-height: 1.2em;
}

@media only screen and (max-width: 1007px) {
    .footer-panel-2 h2 {
        font-size: 16px;
        line-height: 1.2em;
    }
}

.footer-panel-2 a {
    color: inherit;
    font-weight: normal;
}

.footer-panel-2 ul {
    list-style: none;
    margin: 0 0 24px 0;
    padding: 0;
}

/* footer-panel-3 */
.footer-panel-3 {
    /*background: #6D6E71;*/
    background: #030503;
    color: #FFF;
    padding: 48px 0 24px 0;
}

/* footer-social */
.footer-social {
    float: right;
    list-style: none;
    margin: 0 0 24px 0;
    padding: 0;
}

@media only screen and (max-width: 1007px) {
    .footer-social {
        float: left;
    }
}

.footer-social li {
    float: left;
    margin: 0 12px 0 0;
}

.footer-social li.last {
    margin: 0;
}

/* footer-panel-4 */
.footer-panel-4 {
    background: #4D4D4F;
    color: #FFF;
    padding: 32px 0 1px 0;
}

.footer-panel-4-panel {
    text-align: right;
}

@media only screen and (max-width: 719px) {
    .footer-panel-4-panel {
        text-align: left;
    }
}

/* logo-2 */
.logo-2 {
    -webkit-filter: grayscale(100%);
    filter: grayscale(100%);
    
    line-height: 232px;
    margin: 0 0 24px 0;
    text-align: center;
}

/* teaser-3 */
.teaser-3 {
    color: #FFF;
    margin: 0 0 24px 0;
    padding: 100% 0 0 0;
    position: relative;
    text-align: center;
}

.teaser-3-panel {
    border: 1px solid #E6E7E8;
    box-sizing: border-box;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}

.teaser-3-panel {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}

.teaser-3-panel-2 {
    -webkit-transition: opacity 250ms;
    transition: opacity 250ms;
    
    background: rgba(105, 70, 133, 0.8);
    box-sizing: border-box;
    height: 100%;
    left: 0;
    opacity: 0;
    padding: 24px 24px 1px 24px;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2;
}

.teaser-3:hover .teaser-3-panel-2 {
    opacity: 1;
}

.teaser-3 a {
    color: #FFF;
}

/* teaser-4 */
.teaser-4 {
    color: #030503;
    display: block;
    margin: 0 0 24px 0;
    padding: 75% 0 0 0;
    position: relative;
    text-decoration: none;
}

.teaser-4-panel {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}

.teaser-4-panel-2 {
    background: #FFF;
    border-radius: 4px;
    color: #008A35;
    font-weight: bold;
    left: 24px;
    padding: 24px;
    position: absolute;
    top: 24px;
    z-index: 2;
}

@media only screen and (max-width: 1007px) {
    .teaser-4-panel-2 {
        display: none;
    }
}

.teaser-4-panel-3 {
    background: #F1F1F2;
    bottom: 0;
    box-sizing: border-box;
    left: 0;
    padding: 24px 24px 1px 24px;
    position: absolute;
    width: 100%;
    z-index: 3;
}

.teaser-4 h4 {
    color: #008A35;
    margin: 0;
}

.teaser-4 h5 {
    color: #008A35;
    margin: 0;
}

/* filter */
.filter {
    list-style: none;
    margin: 0 0 24px 0;
    padding: 0;
    text-transform: uppercase;
}

.filter li {
    margin: 0 0 12px 0;
}

.filter a {
    background: #008A35;
    color: #FFF;
    display: block;
    padding: 12px;
    text-decoration: none;
}

.filter a:hover,
.filter a.active {
    text-decoration: underline;
}

/* teaser-5 */
.teaser-5 {
    background: #F1F1F2;
    margin: 0 0 24px 0;
    padding: 24px 12px 1px 12px;
}

.teaser-5-style-2 {
    background: #CDE3E8;
}

/* views-exposed-form-search-page-1 */
#views-exposed-form-search-page-1 {
    margin: 0 0 48px 0;
}

/* pager */
.pager__items {
    list-style: none;
    margin: 0 0 48px 0;
    padding: 0;
}

/*
 * Clearfix: contain floats
 *
 * For modern browsers
 * 1. The space content is one way to avoid an Opera bug when the
 *    `contenteditable` attribute is included anywhere else in the document.
 *    Otherwise it causes space to appear at the top and bottom of elements
 *    that receive the `clearfix` class.
 * 2. The use of `table` rather than `block` is only necessary if using
 *    `:before` to contain the top-margins of child elements.
 */

.pager__items:before,
.pager__items:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.pager__items:after {
    clear: both;
}

.pager__items li {
    float: left;
    margin: 0 12px 0 0;
}

.pager__items li:last-child {
    margin: 0;
}

.pager__items a {
    text-decoration: none;
}

.pager__items a:hover,
.pager__items .is-active a {
    text-decoration: underline;
}

/* share */
.share {
    list-style: none;
    margin: 0 0 24px 0;
    padding: 0;
}

.share li {
    float: left;
    margin: 0 12px 0 0;
}

.share li.last {
    margin: 0;
}

/* disqus */
#disqus_thread {
    margin: 0 0 48px 0;
}

/* teaser-6 */
.teaser-6 {
    background: #F1F1F2;
    margin: 0 0 4px 0;
    padding: 12px;
}

.teaser-6:hover {
    background: #008A35;
    color: #FFF;
}

.teaser-6-panel {
    background: #FFF;
    padding: 12px 0 1px 0;
}

.teaser-6:hover .teaser-6-panel {
    background: #008A35;
}

.teaser-6:hover a {
    color: #FFF;
}

/* gm */
.gm-style .gm-style-iw img {
    max-width: 100%;
}

/* map */
.map {
    padding: 41.666666666666666% 0 0 0;
    position: relative;
}

@media only screen and (max-width: 1263px) {
    .map {
        padding: 50% 0 0 0;
    }
}

@media only screen and (max-width: 1007px) {
    .map {
        padding: 75% 0 0 0;
    }
}

@media only screen and (max-width: 719px) {
    .map {
        padding: 100% 0 0 0;
    }
}

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

/* section */
.section {
    background: #F8F8F9;
    font-size: 14px;
    line-height: 1.5em;
    margin: 0 0 48px 0;
    padding: 48px 0 24px 0;
}

/* block-facet--links */
#block-author ul,
#block-author-2 ul,
#block-author-3 ul,
#block-racecategory ul,
#block-racecategory-2 ul,
#block-racecategory-3 ul,
#block-topic ul,
#block-topic-2 ul,
#block-topic-3 ul,
#block-country ul,
#block-country-2 ul,
#block-country-3 ul,
#block-productcategory ul,
#block-productcategory-2 ul,
#block-productcategory-3 ul {
    font-family: 'Neo Tech Std', sans-serif;
    list-style: none;
    margin: 0;
    padding: 0;
    text-transform: uppercase;
}

#block-author a,
#block-author-2 a,
#block-author-3 a,
#block-racecategory a,
#block-racecategory-2 a,
#block-racecategory-3 a,
#block-topic a,
#block-topic-2 a,
#block-topic-3 a,
#block-country a,
#block-country-2 a,
#block-country-3 a,
#block-productcategory a,
#block-productcategory-2 a,
#block-productcategory-3 a {
    color: #008A35;
    text-decoration: none;
}

#block-author ul ul,
#block-author-2 ul ul,
#block-author-3 ul ul,
#block-racecategory ul ul,
#block-racecategory-2 ul ul,
#block-racecategory-3 ul ul,
#block-topic ul ul,
#block-topic-2 ul ul,
#block-topic-3 ul ul,
#block-country ul ul,
#block-country-2 ul ul,
#block-country-3 ul ul,
#block-productcategory ul ul,
#block-productcategory-2 ul ul,
#block-productcategory-3 ul ul {
    margin: 0 0 0 24px;
}

#block-tags ul,
#block-tags-2 ul,
#block-tags-3 ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

#block-tags li,
#block-tags-2 li,
#block-tags-3 li {
    display: inline;
}

#block-tags a,
#block-tags-2 a,
#block-tags-3 a {
    background: #F1F1F2;
    color: #030503;
    display: inline-block;
    margin: 0 8px 8px 0;
    padding: 4px 8px;
    text-decoration: none;
}

/* tags */
.tags {
    list-style: none;
    margin: 0 0 24px 0;
    padding: 0;
}

.tags li {
    display: inline;
}

.tags a {
    background: #F1F1F2;
    color: #030503;
    display: inline-block;
    margin: 0 8px 8px 0;
    padding: 4px 8px;
    text-decoration: none;
}

/* teaser-7 */
.teaser-7 {
    background: #F8F8F9;
    color: #808285;
    font-size: 14px;
    line-height: 1.5em;
    margin: 0 0 48px 0;
    padding: 48px 0 24px 0;
    text-align: center;
}

/* teaser-8 */
.teaser-8 {
    margin: 0 0 32px 0;
}

.teaser-8 a {
    text-decoration: none;
}

.teaser-8-panel {
    border: 1px solid #BCBEC0;
    margin: 0 0 24px 0;
}

/* slider */
.slider {
    border: 1px solid #BCBEC0;
    margin: 0 0 80px 0;
    position: relative;
}

.slider .slick-prev,
.slider .slick-next {
    background-color: transparent;
    background-size: 100% auto;
    border: none;
    bottom: -48px;
    color: transparent;
    cursor: pointer;
    display: block;
    font-size: 0;
    height: 24px;
    line-height: 0;
    outline: none;
    padding: 0;
    position: absolute;
    width: 24px;
    z-index: 2;
}

.slider .slick-prev {
    background-image: url(../images/arrow-left.svg);
    left: 0;
}

.slider .slick-next {
    background-image: url(../images/arrow-right.svg);
    right: 0;
}

/* section-2 */
.section-2 {
    border: 1px solid #BCBEC0;
    margin: 0 0 32px 0;
    padding: 24px 24px 0 24px;
}

/* divider */
.divider {
    background: #030503;
    height: 1px;
    margin: 0 0 32px 0;
}

/* accordion */
.accordion {
    background: #EDEDEE;
    margin: 0 0 48px 0;
    padding: 24px 24px 1px 24px;
}

/* teaser-9 */
.teaser-9 {
    background: #FFF;
    margin: 0 0 24px 0;
}

.teaser-9-header {
    cursor: pointer;
    margin: 0;
    padding: 24px;
}

.teaser-9-panel {
    padding: 0 24px 1px 24px;
}

/* Block */
.a-0 {
    background: #296383;
    color: #FFF;
    margin: 0 0 24px 0;
    padding: 24px 12px;
}

.a-0 select {
    color: #030503;
}

.a-0 .form-submit {
    background: #E6A045;
    transition: background-color 250ms;
}

.a-0 .form-submit:hover {
    background: #487DB0;
}

/* Link */
.a-1 {
    background: #FFF;
    float: right;
    font-family: 'Neo Tech Std', sans-serif;
    font-size: 14px;
    font-weight: normal;
    line-height: 40px;
    margin: 20px 10px 0 0;
    padding: 0 10px;
    text-decoration: none;
    text-transform: uppercase;
}

/* Link */
.a-2 {
    background: #FFF;
    font-family: 'Neo Tech Std', sans-serif;
    font-size: 14px;
    font-weight: normal;
    line-height: 32px;
    padding: 0 10px;
    position: absolute;
    right: 44px;
    text-decoration: none;
    text-transform: uppercase;
    top: 6px;
}

/* results */
.results .file a {
    background-repeat: no-repeat;
    display: inline-block;
    height: 46px;
    font-size: 0;
    line-height: 0;
    vertical-align: middle;
    width: 36px;
}

.results .file--mime-application-pdf a {
    background-image: url(../images/pdf.svg);
}

.results .file--mime-text-csv a,
.results .file--mime-application-vnd-ms-excel a {
    background-image: url(../images/xls.svg);
}

.results .views-field-field-file {
    white-space: nowrap;
}

/* ==========================================================================
   Helper classes
   ========================================================================== */

/*
 * Hide visually and from screen readers
 */

.hidden {
    display: none !important;
}

/*
 * Hide only visually, but have it available for screen readers:
 * http://snook.ca/archives/html_and_css/hiding-content-for-accessibility
 */

.visuallyhidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

/*
 * Extends the .visuallyhidden class to allow the element
 * to be focusable when navigated to via the keyboard:
 * https://www.drupal.org/node/897638
 */

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto;
}

/*
 * Hide visually and from screen readers, but maintain layout
 */

.invisible {
    visibility: hidden;
}

/*
 * Clearfix: contain floats
 *
 * For modern browsers
 * 1. The space content is one way to avoid an Opera bug when the
 *    `contenteditable` attribute is included anywhere else in the document.
 *    Otherwise it causes space to appear at the top and bottom of elements
 *    that receive the `clearfix` class.
 * 2. The use of `table` rather than `block` is only necessary if using
 *    `:before` to contain the top-margins of child elements.
 */

.clearfix:before,
.clearfix:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.clearfix:after {
    clear: both;
}

/* ==========================================================================
   EXAMPLE Media Queries for Responsive Design.
   These examples override the primary ('mobile first') styles.
   Modify as content requires.
   ========================================================================== */

@media only screen and (min-width: 35em) {
    /* Style adjustments for viewports that meet the condition */
}

@media print,
       (-webkit-min-device-pixel-ratio: 1.25),
       (min-resolution: 1.25dppx),
       (min-resolution: 120dpi) {
    /* Style adjustments for high resolution devices */
}

/* ==========================================================================
   Print styles.
   Inlined to avoid the additional HTTP request:
   http://www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */

@media print {
    *,
    *:before,
    *:after,
    *:first-letter,
    *:first-line {
        background: transparent !important;
        color: #030503 !important; /* Black prints faster:
                                   http://www.sanbeiji.com/archives/953 */
        box-shadow: none !important;
        text-shadow: none !important;
    }

    a,
    a:visited {
        text-decoration: underline;
    }

    /*a[href]:after {
        content: " (" attr(href) ")";
    }*/

    abbr[title]:after {
        content: " (" attr(title) ")";
    }

    /*
     * Don't show links that are fragment identifiers,
     * or use the `javascript:` pseudo protocol
     */

    a[href^="#"]:after,
    a[href^="javascript:"]:after {
        content: "";
    }

    pre,
    blockquote {
        border: 1px solid #999;
        page-break-inside: avoid;
    }

    /*
     * Printing Tables:
     * http://css-discuss.incutio.com/wiki/Printing_Tables
     */

    thead {
        display: table-header-group;
    }

    tr,
    img {
        page-break-inside: avoid;
    }

    img {
        max-width: 100% !important;
    }

    p,
    h2,
    h3 {
        orphans: 3;
        widows: 3;
    }

    h2,
    h3 {
        page-break-after: avoid;
    }
}