body {
    color: var(--text-default-color);
    font-size: var(--text-default-size);
    line-height: var(--text-default-line-height);
}
a {
    color: var(--link-color);
}
a:hover {
    color: var(--link-color-hover);
}

.btn-link {
    color: var(--link-color);
}
.btn-link:hover,
.btn-link:focus {
    color: var(--link-color-hover);
}

.visually-hidden {
    display: none;
}
.tabs--primary {
    margin-bottom: 20px;
    margin-top: 20px;
}
.alert {
    margin-top: 20px;
}
.feed-icons {
    display: none;
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
}

.form-wrapper {
    margin-bottom: 0;
}

figure {
    display: inline-block;
}
figure > figcaption {
    text-align: center;
    font-size: 90%;
    font-style: italic;
}
.text-align-right {
    text-align: right;
}
.text-align-left {
    text-align: left;
}
.text-align-center {
    text-align: center;
}
.align-center {
    margin: 0 auto;
}
.align-left {
    float: left;
}
.align-right {
    float: right;
}

img.align-left,
figure.align-left {
    margin: 0 20px 20px 0;
}
img.align-right,
figure.align-right {
    margin: 0 0 20px 20px;
}
figure.align-center {
    display: block;
}
img.align-center,
figure.align-center img {
    display: block;
    margin: 0 auto 10px;
}

label.form-required:after {
    content: ' *';
    color: #f00;
    font-size: 90%;
}

.carousel-infinite {
    overflow: hidden;
}
.carousel-wrapper {
    margin-left: -15px;
    margin-right: -15px;
}
.carousel .owl-item {
    padding-left: 15px;
    padding-right: 15px;
}
.owl-carousel {
    list-style: none;
    margin: 0;
    padding: 0;
}
.owl-theme .owl-nav {
    margin-top: 0;
}
.owl-theme .owl-nav .owl-prev {
    left: 0;
}
.owl-theme .owl-nav .owl-next {
    right: 0;
}
.owl-theme .owl-nav .owl-prev,
.owl-theme .owl-nav .owl-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.owl-theme .owl-nav .owl-prev:focus,
.owl-theme .owl-nav .owl-next:focus {
    outline: 1px dotted #999;
}
.owl-theme .owl-nav [class*='owl-']:hover {
    background: transparent;
    color: var(--link-color);
}
.owl-theme .nav-right,
.owl-theme .nav-left,
.owl-theme .nav-right > svg,
.owl-theme .nav-left > svg {
    display: block;
}

.main {
    padding-bottom: 40px;
    padding-top: 50px;
}

.google-map iframe {
    border: 0;
    min-height: 400px;
    width: 100%;
}

.columns {
    overflow: hidden;
}
.columns .block-heading,
.block .block-heading {
    margin-bottom: 50px;
    position: relative;
    text-align: center;
}
.columns .block-heading:after,
.block .block-heading:after {
    content: '';
    display: block;
    width: 40px;
    border-top: 2px solid var(--block-title-border-color);
    margin: 25px auto 0;
}
.columns .block-title,
.block .block-title {
    color: var(--block-title-color);
    letter-spacing: 1px;
    font-size: 3rem;
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 10px;
}
.columns .block-subtitle,
.block .block-subtitle {
    color: var(--block-subtitle-color);
    display: block;
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
    font-size: 2rem;
    line-height: 1.1;
    font-weight: 300;
}

.tab-wrapper {
    margin-bottom: 20px;
}
.tab-wrapper .tab-content {
    padding-top: 15px;
}

.bkg-grey {
    background-color: var(--section-background-gray);
}
.text-white {
    color: var(--white);
}

.section-map {
    line-height: 0;
}
.section-map iframe {
    width: 100%;
}

.bgimage-text {
    position: relative;
}

label.webform-file-button {
    margin-top: 0;
}
.form-type-managed-file .help-block {
    font-size: 80%;
}
.form-wrapper > .form-group:not(.form-item) {
    margin-bottom: 0;
}
.form-composite legend {
    margin-bottom: 5px;
}

@media screen and (max-width: 767px) {
    .owl-theme .owl-nav .owl-prev,
    .owl-theme .owl-nav .owl-next {
        height: 48px;
        width: 48px;
    }
    .form-control {
        font-size: 16px;
    }
}

@media screen and (min-width: 992px) {
    .bgimage-text > .img-side {
        background-repeat: no-repeat;
        background-position: 50% 50%;
        background-size: cover;
        height: 100%;
        position: absolute;
        top: 0;
        width: 50%;
    }
    .bgimage-text > .img-side.img-left {
        left: 0;
    }
    .bgimage-text > .img-side.img-right {
        right: 0;
    }
}

@media screen and (min-width: 1200px) {
    .columns .block-heading,
    .block .block-heading {
        margin-left: auto;
        margin-right: auto;
        max-width: 800px;
    }
}
