.button,
.text-center {
    text-align: center
}

.button,
.floater-box,
header #header-image,
ul.special-bullets>li {
    box-sizing: border-box
}

body {
    margin: 0;
    padding: 0
}

header {
    width: 100%
}

header #header-image-wrapper {
    margin: 0 auto;
    max-width: 1170px;
    overflow: hidden
}

footer {
    margin-top: -30px;
    margin-bottom: 50px;
}

.prod-img {
    margin-top: 1em;
    margin-bottom: 1em
}

.container-fluid {
    margin: 0 auto;
    max-width: 1170px
}

.container-vspace-m {
    padding-top: 50px;
    padding-bottom: 50px
}

.container-vspace-l {
    padding-top: 100px;
    padding-bottom: 100px
}

.container-vspace-l>div.row:first-child>div>:first-child {
    margin-top: 0
}

.container-vspace-l>div.row:last-child>div>:last-child,
.container-vspace-m>div.row:last-child>div>:last-child {
    margin-bottom: 0
}

.element-vspace-m {
    margin-top: 50px;
    margin-bottom: 50px
}

.element-vspace-s {
    margin-top: 25px;
    margin-bottom: 25px
}

.container-vspace-l>div.row>div>.keep-margin:last-child,
.container-vspace-m>div.row>div>.keep-margin:last-child,
.element-vspace-m>div>:last-child,
.element-vspace-s>div>:last-child {
    margin-bottom: 0
}

.element-vspace-m>div>:first-child,
.element-vspace-s>div>:first-child {
    margin-top: 0
}

.container-vspace-l>div.row>div>.keep-margin:first-child,
.container-vspace-m>div.row>div>.keep-margin:first-child {
    margin-top: 50px
}

.container-vspace-m.last,
.container-vspace-l.last {
    margin-bottom: 0;
    padding-bottom: 50px;
}

@media all and (max-width:767px) {
    .container-vspace-m {
        padding-top: 25px;
        padding-bottom: 25px
    }
    .container-vspace-l {
        padding-top: 50px;
        padding-bottom: 50px
    }
    .center-md {
        display: block;
        margin: 50px auto!important;
        text-align: center
    }
    .left-md {
        display: block;
        margin-bottom: 50px!important;
        margin-bottom: 50px!important;
        margin-left: 0!important;
        text-align: left;
    }
}

@media all and (max-width:575px) {
    .center-sm {
        display: block;
        margin: 25px auto!important;
        text-align: center
    }
    .left-sm {
        display: block;
        margin-bottom: 25px!important;
        margin-bottom: 25px!important;
        margin-left: 0!important;
        text-align: left;
    }
}

.floater-box.left {
    float: left;
    margin-right: 20px
}

.floater-box.right {
    float: right;
    margin-left: 20px
}

.item-enum-list {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    flex-direction: row; 
    box-sizing: border-box;
}

.item-enum-list.outset {
    margin-left: 20px;
    margin-right: 20px;
}

.item-enum-list.vert.outset {
    padding-top: 30px;
    padding-bottom: 30px;
}

.item-enum-list > * {
    flex: 0 0 auto;
}

.item-enum-list.fullheight {
    justify-content: space-between;
}

.item-enum-list.vert {    
    flex-direction: column;   
}

a.center,
img.center {
    margin-left: auto;
    margin-right: auto
}

.floater-box.width-1-3-sm {
    width: 33%
}

@media all and (max-width:575px) {
    .floater-box.width-1-3-sm {
        width: 100%
    }
}

.clearfix:after {
    content: ".";
    clear: both;
    display: block;
    visibility: hidden;
    height: 0
}

img.center {
    display: block
}

.button {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: 45px;
    margin-bottom: 45px;
    padding: 5px 15px 5px 15px;
    border: none;
    border-radius: 4px;
    width: 457px;
	min-height:70px;
    height: auto;
    cursor: pointer;
    font-weight: 700;
    color: #000;
    font-size: 18px;
    line-height: 24px
}

.button.focus,
.button:focus,
.button:hover {
    text-decoration: none;
    color: #000;
}

.buttonwrap {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 10px;
}

.buttonwrap> {
    flex: 0 1 200px;
    height: auto
}

.buttonwrap>a.button {
    flex: 0 1 457px;
    max-width: 457px
}

.buttonwrap::after {
    content: '.';
    flex: 0 200 200px;
    color: transparent;
    font-size: 0;
    line-height: 0
}

.clickable {
    cursor: pointer;
}

@media all and (max-width:590px) {
    .button {
        width: 100%;
        font-size: 13px
    }
}

.box {
    margin-top: 60px;
    margin-bottom: 60px;
    padding: 80px 100px
}

.box.last {
    margin-bottom: 0;
}

.box>div.row:first-child>div:first-child>:first-child {
    margin-top: 0
}

.box>div.row:last-child>div:last-child>:last-child {
    margin-bottom: 0
}

.rounded {
    border-radius: 5px
}

@media all and (max-width:575px) {
    .box {
        margin-left: -15px;
        margin-right: -15px;
        padding-left: 20px;
        padding-right: 20px
    }
}

@media all and (max-width:450px) {
    .box {
        padding: 30px
    }
}

@media all and (min-width:451px) and (max-width:700px) {
    .box {
        padding: 50px
    }
}

@media all and (max-width:950px) {
    .box a.button {
        width: 100%
    }
}

ol.spaced>li,
ul.spaced>li {
    margin-top: 1.2em;
    margin-bottom: 1.2em
}

ol.outset,
ul.outset {
    margin-top: 2.2em;
    margin-bottom: 2.2em
}

ul.checklist {
    list-style: none;
    margin-left: 0;
    padding-left: 0
}

ul.checklist>li {
    margin-top: 7px;
    padding-top: 2px;
    padding-bottom: 7px;
    padding-left: 30px;
    background-position: top left;
    background-repeat: no-repeat
}

ul.checklist-small {
    list-style: none;
    margin-left: 0;
    padding-left: 0
}

ul.checklist-small>li {
    margin-top: 12px;
    padding-top: 0;
    padding-bottom: 2px;
    padding-left: 20px;
    background-position: top left;
    background-repeat: no-repeat
}

ul.special-bullets>li {
    margin-top: 7px;
    padding-bottom: 7px;
    padding-left: 55px;
    padding-top: 5px;
    min-height: 40px;
    list-style: none
}

.large-bullet {
    display: flex;
    flex-direction: row
}

.large-bullet>div:first-child {
    flex: 0 1 auto;
    margin-right: 10px
}

.large-bullet>div:first-child>img {
    width: auto;
}

.large-bullet>div:last-child {
    flex: 1 0;
    margin-left: 10px
}

.large-bullet>div:last-child>*:first-child {
    margin-top: 0;
}
.large-bullet>div:last-child>*:last-child  {
    margin-bottom: 0;
}

@media all and (max-width:576px) {
    .large-bullet>div:first-child {
        flex: 0 0 40px;
        margin-right: 15px
    }
}

.borderless {
    border: none;
}

.bg-transparent {
    background: transparent;
}

.bg-white {
    background: #fff
}

.bg-grey {
    background: #efefef
}

.bg-yellow {
    background: #f2c600;
}

.font-red {
    color: #d60613
}

.font-white {
    color: #fff
}

.font-black {
    color: #000
}

.text-r {
    text-align: right
}

.text-l {
    text-align: left
}

.text-marked {
    display: inline-block;
    padding: 0 10px;
    -webkit-box-decoration-break:clone;
}

.font-small {
    font-size: 14px;
    line-height: 22px
}

h1,
h2,
h3,
h4 {
    margin-top: 1em;
    margin-bottom: 1em
}

@media all and (max-width: 420px) {
    h1 {
        font-size: 24px;
        line-height: 30px;
    }
}

p {
    margin-top: 1.3em;
    margin-bottom: 1.3em
}

p.preheader {
    margin-bottom: 0;
    font-size: 20px;
    font-weight: 400;
    line-height: 22px
}

h1,
h2,
h3 {
    font-weight: 700
}

p.preheader+h1,
p.preheader+h2,
p.preheader+h3 {
    margin-top: .3em
}

h1 {
    font-family: Arial;
    color: #cc1400;
    font-size: 34px;
    line-height: 44px
}

h2 {
    font-size: 24px;
    line-height: 28px
}

h3 {
    margin-top: 1.3em;
    margin-bottom: 1.3em;
    font-size: inherit;
    line-height: inherit
}

.carousel-control-next,
.carousel-control-prev {
    top: 35%;
    flex: 0 0 80px;
    height: 80px;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain
}

.carousel-indicators {
    bottom: -80px;
    z-index: 99999999;
    top: auto
}

.carousel-indicators li {
    max-width: 10px;
    height: 10px;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%
}

header #header-image {
    margin: 0;
    padding: 0;
    height: auto;
}

nav.custom-nav {
    margin: 0 auto;
    padding: 0;
    max-width: 1140px
}

nav.custom-nav .navbar-brand {
    margin: 0;
    padding: 0
}

.navbar-toggler-right {
    align-self: right;
    position: static;
    right: 0;
    margin: 5px
}

@media all and (max-width:1150px) {
    header #header-image {
        margin: 7px
    }
}

@media all and (max-width:992px) {
    .navbar-light .navbar-nav .nav-link.active,
    .navbar-light .navbar-nav .nav-link.open,
    .navbar-light .navbar-nav .open>.nav-link,
    nav.navbar-light .navbar-nav .active>.nav-link,
    nav.navbar-light .navbar-nav .nav-link,
    nav.navbar-light .navbar-nav .nav-link:hover {
        padding-left: 10px;
        padding-right: 10px
    }
    header .navbar-wrapper {
        margin: 0 auto;
        max-width: 80%;
        box-shadow: 0 2px 5px #cdcdcd
    }
    nav.custom-nav .navbar-collapse .show {
        padding-bottom: 5px
    }
    nav.custom-nav .navbar-nav {
        align-items: center
    }
}

header #header-image-wrapper {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between
}

header .navbar-toggler {
    margin-right: 10px;
    border: 1px solid #fff;
    align-self: center;
    display: none;
    color: #fff;
    font-size: 20px
}

@media all and (max-width:992px) {
    header .navbar-toggler {
        display: block
    }
}

@media all and (max-width:600px) {
    footer p {
        margin-top: 25px;
        text-align: center
    }
    footer .text-l,
    footer .text-r {
        text-align: center;
        margin-bottom: 25px
    }
}

@media all and (max-width:500px) {
    .buttonwrap::after,
    .buttonwrap>img {
        display: none
    }
    .buttonwrap>a {
        flex: 0 1 457px;
        max-width: 457px
    }
}

@media all and (max-width:420px) {
    header #header-image {
        max-width: 60%;
        height: auto
    }
    h1 {
        font-size: 24px;
        line-height: 30px
    }
}