



.button,
button,
input[type='submit'],
input[type='reset'],
input[type='button'] {
    position: relative;
    display: inline-block;
    background-color: transparent;
    text-transform: uppercase;
    font-size: .97em;
    letter-spacing: .03em;
    cursor: pointer;
    font-weight: bolder;
    text-align: center;
    color: currentColor;
    text-decoration: none;
    border: 1px solid transparent;
    vertical-align: middle;
    border-radius: 0;
    margin-top: 0;
    margin-right: 1em;
    text-shadow: none;
    line-height: 2.4em;
    min-height: 2.5em;
    padding: 0 0em;
    max-width: 100%;
    transition: transform .3s, border .3s, background .3s, box-shadow .3s, opacity .3s, color .3s;
    text-rendering: optimizeLegibility;
    box-sizing: border-box
}

.button span {
    display: inline-block;
    line-height: 1.6
}

.button.is-outline {
    line-height: 2.19em
}


.nav>li>a.button:hover,
.nav>li>a.button {
    padding-top: 0;
    padding-bottom: 0
}

.nav>li>a.button:hover {
    color: #FFF
}

.button,
input[type='submit'],
input[type='submit'].button,
input[type='reset'].button,
input[type='button'].button {
    color: #fff;
    background-color: #446084;
    background-color: var(--primary-color);
    border-color: rgba(0, 0, 0, 0.05)
}

.button.is-outline,
input[type='submit'].is-outline,
input[type='reset'].is-outline,
input[type='button'].is-outline {
    border: 2px solid currentColor;
    background-color: transparent
}

.dark .button.is-form:hover,
.button:hover,
input[type='submit']:hover,
input[type='reset']:hover,
input[type='button']:hover {
    outline: none;
    opacity: 1;
    color: #fff;
    box-shadow: inset 0 0 0 100px rgba(0, 0, 0, 0.2)
}

.button.is-underline,
.button.is-link {
    background-color: transparent !important;
    border-color: transparent !important;
    padding-left: .15em;
    padding-right: .15em
}

.button.is-underline:before {
    content: "";
    height: 2px;
    background-color: currentColor;
    opacity: .3;
    transition: all .3s;
    position: absolute;
    bottom: 0;
    left: 20%;
    width: 60%
}

.button.is-underline:hover:before {
    left: 0%;
    width: 100%;
    opacity: 1
}

.overlay-icon {
    background-color: rgba(0, 0, 0, 0.2);
    width: 3.5em;
    color: #fff;
    height: 3.5em;
    line-height: 4em;
    border-radius: 100%;
    text-align: center;
    border: 2px solid #FFF;
    opacity: .8;
    transition: transform .2s, opacity .2s;
}

.overlay-icon i {
    font-size: 2em;
    transition: color .3s;
    margin-left: 5px;
    top: 3px
}

.has-hover {
    margin-bottom: 30px;
}


.has-hover:hover .overlay-icon {
    opacity: 1;
    -ms-transform: scale(1.15);
    transform: scale(1.15)
}

.box-shade .overlay-icon,
.box-overlay .overlay-icon {
    opacity: 0
}

.image-icon {
    display: inline-block;
    height: auto;
    vertical-align: middle;
    position: relative
}

span+.image-icon {
    margin-left: 10px
}

.image-icon img {
    max-width: 32px;
    min-width: 100%
}

.nav-small .image-icon {
    width: 16px;
    height: 16px;
    margin: 0 5px
}

.nav-small .image-icon img {
    vertical-align: top
}

[data-icon-label] {
    position: relative
}

[data-icon-label="0"]:after {
    display: none
}

[data-icon-label]:after {
    content: attr(data-icon-label);
    position: absolute;
    font-style: normal;
    font-family: Arial, Sans-serif !important;
    top: -10px;
    right: -10px;
    font-weight: bolder;
    background-color: #d26e4b;
    box-shadow: 1px 1px 3px 0px rgba(0, 0, 0, 0.3);
    font-size: 11px;
    padding-left: 2px;
    padding-right: 2px;
    opacity: .9;
    line-height: 17px;
    letter-spacing: -.5px;
    height: 17px;
    min-width: 17px;
    border-radius: 99px;
    color: #fff;
    text-align: center;
    z-index: 1;
    transition: transform .2s
}

.nav-small [data-icon-label]:after {
    min-width: 13px;
    top: -4px;
    right: -10px;
    height: 13px;
    font-size: 10px;
    line-height: 13px
}

.button [data-icon-label]:after {
    top: -12px;
    right: -12px
}

.reveal-icon i {
    width: 1em
}

.reveal-icon i,
.reveal-icon span {
    display: inline-block;
    transition: opacity .3s, transform .3s
}

.reveal-icon span {
    -ms-transform: translateX(0.75em);
    transform: translateX(0.75em)
}

.reveal-icon i+span {
    -ms-transform: translateX(-0.75em);
    transform: translateX(-0.75em)
}

.reveal-icon:hover>span {
    -ms-transform: translateX(0);
    transform: translateX(0)
}

.reveal-icon:not(:hover) i {
    opacity: 0
}

img {
    transition: opacity 1s;
    opacity: 1
}

.col-inner>.img:not(:last-child),
.col>.img:not(:last-child) {
    margin-bottom: 1em
}

.img {
    position: relative
}

.img .img-inner {
    position: relative;
    overflow: hidden
}

.img,
.img img {
    width: 100%
}

.overlay {
    position: absolute;
    top: 0;
    bottom: 0;
    height: 100%;
    left: -1px;
    right: -1px;
/*    background-color: rgba(0, 0, 0, 0.15);*/
    transition: transform .3s, opacity .6s;
    pointer-events: none
}

.img .caption {
    position: absolute;
    transition: transform .5s;
    -ms-transform: translateY(100%);
    transform: translateY(100%);
    max-height: 100% !important;
    overflow-y: auto;
    bottom: 0;
    padding: 4px 10px;
    font-size: 14px;
    color: #FFF;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.3)
}

.img .caption-show,
.img:hover .caption {
    -ms-transform: translateY(0);
    transform: translateY(0)
}

.lazy-load {
    background-color: rgba(0, 0, 0, 0.03)
}

.has-format,
.video-fit,
.image-cover {
    position: relative;
    height: auto;
    overflow: hidden;
    padding-top: 100%;
    background-position: 50% 50%;
    background-size: cover
}

.video-fit {
    padding-top: 56.5%
}

.video-fit video,
.video-fit iframe,
img.back-image,
.image-cover img,
.has-format img,
.has-equal-box-heights .box-image img {
    right: 0;
    width: 100%;
    height: 100%;
    bottom: 0;
    left: 0;
    top: 0;
    position: absolute;
    object-position: 50% 50%;
    object-fit: cover;
    font-family: 'object-fit: cover;'
}

.has-equal-box-heights .box-image {
    padding-top: 100%
}

.video-fit iframe {
    object-fit: fill
}

.image-tools {
    padding: 10px;
    position: absolute
}

.image-tools a:last-child {
    margin-bottom: 0
}

.image-tools a.button {
    display: block
}

.image-tools.bottom.left {
    padding-top: 0;
    padding-right: 0
}

.image-tools.top.right {
    padding-bottom: 0;
    padding-left: 0
}

.image-tools .cart-icon {
    position: absolute;
    left: 10px;
    margin: 5px;
    bottom: 100%
}

.image-tools .wishlist-button:hover {
    background-color: #b20000;
    border-color: #b20000
}

@media only screen and (max-device-width: 1024px) {
    .image-tools {
        opacity: 1 !important;
        padding: 5px
    }
}

.overlay-tools {
    margin-top: 10px
}

.overlay-tools a {
    display: inline-block;
    font-size: .8em;
    background-color: rgba(0, 0, 0, 0.4);
    padding: 2px 10px 3px;
    margin-right: 5px;
    border-radius: 99px;
    text-shadow: none;
    transition: all .3s
}

.overlay-tools a:hover {
    background-color: #FFF;
    color: #000 !important
}

.tag-label {
    text-transform: uppercase;
    display: inline-block;
    font-size: .65em;
    line-height: 1;
    letter-spacing: 1.1px;
    font-weight: bold;
    border-radius: 2px;
    padding: 2px 5px;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.4);
    transition: background-color .3s, opacity .3s
}

.has-hover:hover .tag-label {
    opacity: 1;
    background-color: #d26e4b
}

.lightbox-content {
    background-color: #fff;
    max-width: 875px;
    margin: 0 auto;
    transform: translateZ(0);
    box-shadow: 3px 3px 20px 0 rgba(0, 0, 0, 0.15);
    position: relative
}

.lightbox-content .lightbox-inner {
    padding: 30px 20px
}

.pswp__bg {
    background-color: rgba(0, 0, 0, 0.6)
}

@media (min-width: 549px) {
    .pswp__top-bar {
        background-color: transparent !important
    }
}

.pswp__item {
    transition: opacity .5s;
    opacity: 0
}

.pswp--visible .pswp__item {
    opacity: 1
}

.pswp__caption__center {
    text-align: center
}

.mfp-bg {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1042;
    overflow: hidden;
    position: fixed;
    background: #0b0b0b;
    opacity: 0;
    transition: opacity .25s
}

.mfp-bg.mfp-ready {
    opacity: .6
}

.mfp-bg.mfp-removing {
    opacity: 0 !important
}

.mfp-wrap {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1043;
    position: fixed;
    outline: none !important;
    -webkit-backface-visibility: hidden
}

.mfp-container {
    text-align: center;
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    padding: 30px;
    box-sizing: border-box
}

.mfp-container:before {
    content: '';
    display: inline-block;
    height: 100%;
    vertical-align: middle
}

.mfp-image-holder {
    padding: 40px 6.66%
}

.mfp-align-top .mfp-container:before {
    display: none
}

.mfp-content {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    max-width: 100%;
    margin: 0 auto;
    text-align: left;
    z-index: 1045;
    -ms-transform: translateY(-30px);
    transform: translateY(-30px);
    opacity: 0;
    transition: transform .5s, opacity .3s
}

.mfp-content-inner {
    box-shadow: 1px 1px 5px 0 rgba(0, 0, 0, 0.2)
}

.mfp-ready .mfp-content {
    opacity: 1;
    -ms-transform: translateY(0);
    transform: translateY(0)
}

.mfp-ready.mfp-removing .mfp-content {
    opacity: 0
}

.mfp-inline-holder .mfp-content,
.mfp-ajax-holder .mfp-content {
    width: 100%;
    cursor: auto
}

.mfp-ajax-cur {
    cursor: progress
}

.mfp-zoom-out-cur,
.mfp-zoom-out-cur .mfp-image-holder .mfp-close {
    cursor: zoom-out
}

.mfp-zoom {
    cursor: pointer;
    cursor: zoom-in
}

.mfp-auto-cursor .mfp-content {
    cursor: auto
}

.mfp-close,
.mfp-arrow,
.mfp-preloader,
.mfp-counter {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.mfp-loading.mfp-figure {
    display: none
}

.mfp-hide {
    display: none !important
}

.mfp-preloader {
    color: #cccccc;
    position: absolute;
    top: 50%;
    width: auto;
    text-align: center;
    margin-top: -.8em;
    left: 8px;
    right: 8px;
    z-index: 1044
}

.mfp-preloader a {
    color: #cccccc
}

.mfp-preloader a:hover {
    color: white
}

.mfp-s-ready .mfp-preloader {
    display: none
}

.mfp-s-error .mfp-content {
    display: none
}

.mfp-close {
    cursor: pointer;
    outline: none;
    z-index: 1046;
    box-shadow: none;
    position: fixed;
    top: 0;
    right: 0;
    text-decoration: none;
    text-align: center;
    opacity: 0;
    padding: 0;
    mix-blend-mode: difference;
    margin: 0 !important;
    color: #fff;
    font-style: normal;
    font-weight: 300;
    font-size: 40px;
    min-height: 0;
    width: 40px;
    -webkit-backface-visibility: hidden;
    height: 40px;
    line-height: 40px;
    font-family: Arial, monospace;
    transition: opacity .6s, transform .6s;
    transform: translateY(50%) translateZ(1px)
}

.mfp-close svg {
    pointer-events: none
}

.mfp-content .mfp-close {
    position: absolute
}

.mfp-ready .mfp-close {
    opacity: .6;
    transform: translateY(0) translateZ(1px)
}

.mfp-removing .mfp-close {
    display: none !important
}

.mfp-close:hover {
    opacity: 1
}

.mfp-close-btn-in .mfp-close {
    top: 0 !important;
    color: currentColor
}

.mfp-counter {
    position: absolute;
    top: 0;
    right: 0;
    color: #cccccc;
    font-size: 12px;
    line-height: 18px
}

.mfp-arrow {
    position: fixed;
    opacity: .6;
    color: #fff;
    mix-blend-mode: difference;
    top: 50%;
    z-index: 1046;
    margin: 0;
    text-align: center;
    width: 50px;
    height: 50px
}

.mfp-arrow i {
    pointer-events: none;
    font-size: 42px !important
}

.mfp-arrow:hover {
    opacity: 1
}

.mfp-arrow:active {
    top: 50.1%
}

.mfp-arrow-left {
    left: 0;
    -ms-transform: translateX(100%);
    transform: translateX(100%)
}

.mfp-arrow-right {
    right: 0;
    -ms-transform: translateX(-100%);
    transform: translateX(-100%)
}

.mfp-ready .mfp-arrow-right,
.mfp-ready .mfp-arrow-left {
    -ms-transform: translateX(0);
    transform: translateX(0)
}

.mfp-iframe-holder {
    padding-top: 40px;
    padding-bottom: 40px
}

.mfp-iframe-holder .mfp-content {
    line-height: 0;
    width: 100%;
    max-width: 900px
}

.mfp-iframe-holder .mfp-close {
    top: -40px
}

.mfp-iframe-scaler {
    width: 100%;
    height: 0;
    overflow: hidden;
    padding-top: 56.25%
}

.mfp-iframe-scaler iframe {
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: black
}

img.mfp-img {
    width: auto;
    max-width: 100%;
    height: auto;
    display: block;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    line-height: 0;
    padding: 0 0 40px;
    margin: 0 auto
}

.mfp-figure {
    line-height: 0
}

.mfp-figure:after {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 40px;
    display: block;
    right: 0;
    width: auto;
    height: auto;
    z-index: -1;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: #444444
}

.mfp-figure small {
    color: #bdbdbd;
    display: block;
    font-size: 12px;
    line-height: 14px
}

.mfp-figure figure {
    margin: 0
}

.mfp-bottom-bar {
    margin-top: -36px;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    cursor: auto
}

.mfp-title {
    font-size: 11px;
    text-align: left;
    line-height: 18px;
    color: #f3f3f3;
    word-wrap: break-word;
    padding-right: 36px
}

.mfp-title a {
    text-decoration: underline;
    color: #f3f3f3
}

.mfp-title a:hover {
    text-decoration: none;
    color: #f3f3f3;
    opacity: .8
}

.mfp-image-holder .mfp-content {
    max-width: 100%
}

.mfp-gallery .mfp-image-holder .mfp-figure {
    cursor: pointer
}

.button.loading {
    opacity: 1 !important;
    position: relative;
    color: rgba(255, 255, 255, 0.05);
    pointer-events: none !important
}

.button.loading:after {
    animation: spin 500ms infinite linear;
    border: 2px solid #fff;
    border-radius: 32px;
    border-right-color: transparent !important;
    border-top-color: transparent !important;
    content: "";
    display: block;
    height: 16px;
    top: 50%;
    margin-top: -8px;
    left: 50%;
    margin-left: -8px;
    position: absolute;
    width: 16px
}



.relative {
    position: relative !important
}

.absolute {
    position: absolute !important
}

.fixed {
    position: fixed !important;
    z-index: 12
}



.screen-reader-text {
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute !important;
    height: 1px;
    width: 1px;
    overflow: hidden
}

.screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    color: #21759b;
    display: block;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000
}

@media screen and (max-width: 549px) {
    .x50 {
        left: 50%;
        -ms-transform: translateX(-50%);
        transform: translateX(-50%)
    }
    .y50 {
        top: 50.3%;
        -ms-transform: translateY(-50%);
        transform: translateY(-50%)
    }
    .y50.x50 {
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%)
    }
}

@media screen and (min-width: 550px) and (max-width: 849px) {

    .md-x50 {
        left: 50%;
        -ms-transform: translateX(-50%) !important;
        transform: translateX(-50%) !important
    }
    .md-y50 {
        top: 50%;
        -ms-transform: translateY(-50%) !important;
        transform: translateY(-50%) !important
    }
    .md-x50.md-y50 {
        -ms-transform: translate(-50%, -50%) !important;
        transform: translate(-50%, -50%) !important
    }
}

@media screen and (min-width: 850px) {

    .lg-x50 {
        left: 50%;
        -ms-transform: translateX(-50%) !important;
        transform: translateX(-50%) !important
    }
    .lg-y50 {
        top: 50%;
        -ms-transform: translateY(-50%) !important;
        transform: translateY(-50%) !important
    }
    .lg-x50.lg-y50 {
        -ms-transform: translate(-50%, -50%) !important;
        transform: translate(-50%, -50%) !important
    }
}

