@charset "UTF-8";

body, html {
    min-height: 100%
}

.ja_wrap {
    align-content: center;
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: center;
    left: 0;
    margin: 0;
    overflow-y: auto;
    padding: 0;
    position: fixed;
    text-align: center;
    top: 0;
    -moz-user-select: -moz-none;
    -webkit-user-select: none;
    -o-user-select: none;
    user-select: none;
    width: 100%;
    z-index: 99999
}

    .ja_wrap.ja_wrap_white {
        background: hsla(0,0%,100%,.75)
    }

    .ja_wrap.ja_wrap_black {
        background: rgba(0,0,0,.75)
    }

body.ja_blur > :not(.ja_wrap) {
    filter: blur(5px) grayscale(.7)
}

.jAlert {
    font-family: Arial,Helvetica Neue,Helvetica,sans-serif;
    text-align: left;
    word-wrap: break-word;
    background: #fff;
    border-radius: 5px;
    box-shadow: 0 2px 10px 0 rgba(0,0,0,.75);
    display: inline-block;
    margin: 15px auto;
    max-width: 98%;
    min-height: 0;
    position: relative
}

.ja_xsm {
    width: 250px
}

.ja_sm {
    width: 350px
}

.ja_md {
    width: 550px
}

.ja_lg {
    width: 850px
}

.ja_xlg {
    width: 1200px
}

.ja_full {
    width: 100%
}

.ja_auto {
    width: auto
}

    .ja_auto .ja_img {
        max-width: none
    }

.ja_close {
    background: #f3f3f3;
    border-radius: 5px;
    color: #555;
    cursor: pointer;
    font-weight: 700;
    padding: 5px 10px;
    position: absolute;
    right: 3px;
    top: 3px;
    z-index: 99999
}

.ja_close_round, .ja_close_round_white {
    align-items: center;
    background: #e0e0e0;
    border: 0;
    border-radius: 50%;
    color: #232323;
    display: flex;
    font-size: 18px;
    height: 30px;
    justify-content: center;
    line-height: 1;
    padding: 0;
    right: 10px;
    top: 6px;
    width: 30px
}

.ja_close_x {
    display: inline-block;
    font-weight: 700;
    transform: translateY(-1px)
}

.ja_close_alt .ja_close_x, .ja_close_round .ja_close_x, .ja_close_round_white .ja_close_x {
    transform: none
}

.ja_default .ja_close_round, .ja_default .ja_close_round_white {
    background: rgba(0,0,0,.3) none repeat scroll 0 0;
    color: #fff
}

.ja_close_alt {
    background: #d51c1c;
    border: 1px solid #373737;
    border-radius: 50%;
    color: #fff;
    font-size: 14px;
    height: 25px;
    line-height: 23px;
    padding: 0;
    right: -18px;
    text-align: center;
    top: -16px;
    width: 25px
}

.ja_close:hover {
    background: #d4d4d4
}

.ja_close_alt:hover {
    background: #df2020
}

.ja_close_round:active, .ja_close_round:hover {
    background: rgba(0,0,0,.5);
    color: #fff
}

.ja_close_round_white:active, .ja_close_round_white:hover {
    background: #fff;
    color: #505050
}

.ja_noTitle .ja_body {
    border-radius: 5px
}

.ja_noTitle .ja_close_round {
    background: rgba(0,0,0,.7) none repeat scroll 0 0;
    color: #d4d4d4;
    right: -11px;
    top: -11px
}

    .ja_noTitle .ja_close_round:hover {
        background: #000;
        color: #fff
    }

.ja_noTitle .ja_close_round_white {
    background: #e0e0e0;
    color: #232323
}

    .ja_noTitle .ja_close_round_white:hover {
        background: #fff;
        color: #505050
    }

.ja_title {
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    width: 100%
}

    .ja_title > div {
        color: #505050;
        font-size: 18px;
        font-weight: 700;
        padding: 10px 20px
    }

    .ja_title > .ja_close_round, .ja_title > .ja_close_round_white {
        top: 8px !important
    }

    .ja_title > .closejAlert {
        top: 10px
    }

    .ja_title > .ja_close_alt {
        right: -12px;
        top: -12px
    }

.ja_default {
    background: #e0e0e0
}

.ja_green {
    background: #049304
}

.ja_dark_green {
    background: #006d00
}

.ja_yellow {
    background: #ffff54
}

.ja_orange {
    background: #ffc107
}

.ja_dark_orange {
    background: #b85c00
}

.ja_gray {
    background: #616161
}

.ja_dark_gray {
    background: #424242
}

.ja_brown {
    background: #633824
}

.ja_black {
    background: #232323
}

.ja_blue {
    background: #EC008B
}

.ja_dark_blue {
    background: #024986
}

.ja_red {
    background: #de0e0e
}

.ja_dark_red {
    background: #a20000
}

.ja_default > div {
    color: #505050 !important
}

.ja_yellow .ja_title > div {
    color: #636300 !important
}

.ja_black .ja_title > div, .ja_blue .ja_title > div, .ja_brown .ja_title > div, .ja_dark_blue .ja_title > div, .ja_dark_gray .ja_title > div, .ja_dark_green .ja_title > div, .ja_dark_red .ja_title > div, .ja_gray .ja_title > div, .ja_green .ja_title > div, .ja_red .ja_title > div {
    color: #fff !important
}

.ja_orange .ja_title > div {
    color: #2f2f2f !important
}

.ja_dark_orange .ja_title > div {
    color: #fff !important
}

.ja_body {
    background: #fff;
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
    box-sizing: border-box;
    color: #616161;
    overflow-y: auto;
    padding: 10px;
    position: relative;
    text-align: left;
    -moz-user-select: text;
    -webkit-user-select: text;
    -o-user-select: text;
    user-select: text
}

.ja_media_modal .ja_body {
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: center
}

.ja_stretch_height, .ja_stretch_height .ja_body {
    align-items: stretch;
    display: flex;
    flex: 1;
    flex-direction: column;
    height: 100%;
    justify-content: stretch
}

.ja_setheight .ja_body {
    height: 100%;
    height: calc(100% - 40px)
}

.ja_media_modal .ja_body:has(.ja_loader) {
    min-height: 140px
}

.ja_media_modal .ja_body.ja_loading {
    min-height: 140px
}

.ja_media_modal .ja_body:has(.ja_img_error) {
    min-height: 200px
}

.ja_media_modal .ja_body.ja_error {
    min-height: 200px
}

.ja_fullscreen.ja_media_modal .ja_body:has(.ja_loader) {
    min-height: 300px
}

.ja_fullscreen.ja_media_modal .ja_body.ja_loading {
    min-height: 300px
}

.ja_auto.ja_media_modal .ja_body {
    height: auto
}

    .ja_auto.ja_media_modal .ja_body:has(.ja_img_error), .ja_auto.ja_media_modal .ja_body:has(.ja_loader) {
        min-height: 300px;
        min-width: 400px
    }

.ja_auto.ja_slideshow_modal .ja_body:has(.ja_loader), .ja_auto.ja_slideshow_modal .ja_body:has(.ja_loading) {
    min-height: 300px;
    min-width: 400px
}

.ja_auto.ja_media_modal .ja_body.ja_error, .ja_auto.ja_media_modal .ja_body.ja_loading, .ja_auto.ja_slideshow_modal .ja_body .ja_loading, .ja_auto.ja_slideshow_modal .ja_body.ja_loading {
    min-height: 300px;
    min-width: 400px
}

.ja_auto.ja_media_modal .ja_body img {
    display: block;
    height: auto;
    max-height: calc(100vh - 200px);
    max-width: 100%;
    width: auto
}

.ja_auto.ja_media_modal .ja_body > .ja_loader {
    left: 50%;
    margin: 0;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%)
}

.ja_iframe {
    border: 0;
    display: none;
    flex: 1;
    width: 100%
}

.ja_video .ja_iframe {
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%
}

.ja_auto .ja_iframe[style*=height] {
    flex: none
}

.ja_video {
    display: none
}

    .ja_video.ja_video_loaded {
        display: block
    }

    .ja_video iframe {
        border: 0;
        height: 100%;
        left: 0;
        position: absolute;
        top: 0;
        width: 100%
    }

.ja_img {
    display: none;
    max-width: 100%
}

.ja_video_element {
    display: block;
    height: 100%;
    width: 100%
}

.ja_fullscreen {
    border-radius: 0;
    display: flex;
    flex-direction: column;
    height: 100%;
    margin: 0 !important;
    max-height: 100%;
    max-width: 100%;
    min-height: 100%;
    min-width: 100%;
    width: 100%
}

    .ja_fullscreen .ja_title {
        border-top-left-radius: 0;
        border-top-right-radius: 0;
        flex-shrink: 0
    }

    .ja_fullscreen .ja_body {
        flex: 1;
        height: auto
    }

.jAlert[style*="height:"] {
    display: flex;
    flex-direction: column
}

    .jAlert[style*="height:"] .ja_body {
        display: flex;
        flex: 1;
        flex-direction: column
    }

.ja_fullscreen .ja_close_round {
    right: 5px;
    top: 5px
}

.ja_btn_wrap {
    display: block;
    margin-bottom: -10px;
    margin-top: 10px;
    position: relative;
    text-align: center
}

    .ja_btn_wrap.optBack {
        background: #f3f3f3;
        border-bottom-left-radius: 5px;
        border-bottom-right-radius: 5px;
        margin: 25px -20px -20px;
        padding: 5px 0
    }

    .ja_btn, .ja_btn:active, .ja_btn:link, .ja_btn:visited, .ja_btn_wrap a, .ja_btn_wrap button {
        border: none;
        border-radius: 5px;
        display: inline-block;
        margin-top: 3px;
        padding: 8px 14px;
        text-decoration: none
    }

@media (max-width:450px) {
    .ja_btn, .ja_btn_wrap a, .ja_btn_wrap button {
        width: 90%
    }

        .ja_btn, .ja_btn:active, .ja_btn:link, .ja_btn:visited, .ja_btn_wrap a, .ja_btn_wrap button {
            margin-top: 8px;
            padding: 8px 10px
        }
}

.ja_btn:hover, .ja_btn_wrap a:hover, .ja_btn_wrap button:hover {
    text-decoration: none
}

.ja_btn_default, .ja_btn_default:link, .ja_btn_default:visited {
    background: #f3f3f3;
    color: #575757
}

    .ja_btn_default:hover {
        background: #fbfbfb
    }

    .ja_btn_default:active {
        background: #eee
    }

.ja_btn_green, .ja_btn_green:link, .ja_btn_green:visited {
    background: #00a000;
    color: #fff
}

    .ja_btn_green:hover {
        background: #2eb71f
    }

    .ja_btn_green:active {
        background: #259818
    }

.ja_btn_red, .ja_btn_red:link, .ja_btn_red:visited {
    background: #b90808;
    color: #fff
}

    .ja_btn_red:hover {
        background: #d62828
    }

    .ja_btn_red:active {
        background: #9f2020
    }

.ja_btn_black, .ja_btn_black:link, .ja_btn_black:visited {
    background: #535353;
    color: #fff
}

    .ja_btn_black:hover {
        background: #666
    }

    .ja_btn_black:active {
        background: #444
    }

.ja_btn_blue, .ja_btn_blue:link, .ja_btn_blue:visited {
    background: #0877b9;
    color: #fff
}

    .ja_btn_blue:hover {
        background: #0896e9
    }

    .ja_btn_blue:active {
        background: #056fad
    }

@keyframes ja-loader {
    0% {
        transform: rotate(0deg)
    }

    to {
        transform: rotate(1turn)
    }
}

.ja_loader:not(:required) {
    animation: ja-loader 1.5s linear infinite;
    border-radius: .5em;
    box-shadow: 1.5em 0 0 0 rgba(0,0,51,.3),1.1em 1.1em 0 0 rgba(0,0,51,.3),0 1.5em 0 0 rgba(0,0,51,.3),-1.1em 1.1em 0 0 rgba(0,0,51,.3),-1.5em 0 0 0 rgba(0,0,51,.3),-1.1em -1.1em 0 0 rgba(0,0,51,.3),0 -1.5em 0 0 rgba(0,0,51,.3),1.1em -1.1em 0 0 rgba(0,0,51,.3);
    display: inline-block;
    font-size: 20px;
    height: 1em;
    margin: auto;
    overflow: hidden;
    text-indent: 100%;
    width: 1em
}

.ja_body > .ja_loader {
    display: block;
    margin: 20px auto
}

.ja_media_modal .ja_body > .ja_loader {
    display: inline-block;
    margin: auto
}

/*!Animate.css - http://daneden.me/animate Licensed under the MIT license -http://opensource.org/licenses/MIT Copyright (c) 2015 Daniel Eden*/ .animated {
    animation-duration: .5s;
    animation-fill-mode: both
}

    .animated.infinite {
        animation-iteration-count: infinite
    }

    .animated.hinge {
        animation-duration: .5s
    }

    .animated.bounceIn, .animated.bounceOut, .animated.flipOutX, .animated.flipOutY {
        animation-duration: .75s
    }

@keyframes bounce {
    0%,20%,53%,80%,to {
        animation-timing-function: cubic-bezier(.215,.61,.355,1);
        transform: translateZ(0)
    }

    40%,43% {
        animation-timing-function: cubic-bezier(.755,.05,.855,.06);
        transform: translate3d(0,-30px,0)
    }

    70% {
        animation-timing-function: cubic-bezier(.755,.05,.855,.06);
        transform: translate3d(0,-15px,0)
    }

    90% {
        transform: translate3d(0,-4px,0)
    }
}

.bounce {
    animation-name: bounce;
    transform-origin: center bottom
}

@keyframes flash {
    0%,50%,to {
        opacity: 1
    }

    25%,75% {
        opacity: 0
    }
}

.flash {
    animation-name: flash
}

@keyframes pulse {
    0% {
        transform: scaleX(1)
    }

    50% {
        transform: scale3d(1.05,1.05,1.05)
    }

    to {
        transform: scaleX(1)
    }
}

.pulse {
    animation-name: pulse
}

@keyframes rubberBand {
    0% {
        transform: scaleX(1)
    }

    30% {
        transform: scale3d(1.25,.75,1)
    }

    40% {
        transform: scale3d(.75,1.25,1)
    }

    50% {
        transform: scale3d(1.15,.85,1)
    }

    65% {
        transform: scale3d(.95,1.05,1)
    }

    75% {
        transform: scale3d(1.05,.95,1)
    }

    to {
        transform: scaleX(1)
    }
}

.rubberBand {
    animation-name: rubberBand
}

@keyframes shake {
    0%,to {
        transform: translateZ(0)
    }

    10%,30%,50%,70%,90% {
        transform: translate3d(-10px,0,0)
    }

    20%,40%,60%,80% {
        transform: translate3d(10px,0,0)
    }
}

.shake {
    animation-name: shake
}

@keyframes swing {
    20% {
        transform: rotate(15deg)
    }

    40% {
        transform: rotate(-10deg)
    }

    60% {
        transform: rotate(5deg)
    }

    80% {
        transform: rotate(-5deg)
    }

    to {
        transform: rotate(0deg)
    }
}

.swing {
    animation-name: swing;
    transform-origin: top center
}

@keyframes tada {
    0% {
        transform: scaleX(1)
    }

    10%,20% {
        transform: scale3d(.9,.9,.9) rotate(-3deg)
    }

    30%,50%,70%,90% {
        transform: scale3d(1.1,1.1,1.1) rotate(3deg)
    }

    40%,60%,80% {
        transform: scale3d(1.1,1.1,1.1) rotate(-3deg)
    }

    to {
        transform: scaleX(1)
    }
}

.tada {
    animation-name: tada
}

@keyframes wobble {
    0% {
        transform: none
    }

    15% {
        transform: translate3d(-25%,0,0) rotate(-5deg)
    }

    30% {
        transform: translate3d(20%,0,0) rotate(3deg)
    }

    45% {
        transform: translate3d(-15%,0,0) rotate(-3deg)
    }

    60% {
        transform: translate3d(10%,0,0) rotate(2deg)
    }

    75% {
        transform: translate3d(-5%,0,0) rotate(-1deg)
    }

    to {
        transform: none
    }
}

.wobble {
    animation-name: wobble
}

@keyframes jello {
    11.1% {
        transform: none
    }

    22.2% {
        transform: skewX(-12.5deg) skewY(-12.5deg)
    }

    33.3% {
        transform: skewX(6.25deg) skewY(6.25deg)
    }

    44.4% {
        transform: skewX(-3.125deg) skewY(-3.125deg)
    }

    55.5% {
        transform: skewX(1.5625deg) skewY(1.5625deg)
    }

    66.6% {
        transform: skewX(-.78125deg) skewY(-.78125deg)
    }

    77.7% {
        transform: skewX(.390625deg) skewY(.390625deg)
    }

    88.8% {
        transform: skewX(-.1953125deg) skewY(-.1953125deg)
    }

    to {
        transform: none
    }
}

.jello {
    animation-name: jello;
    transform-origin: center
}

@keyframes bounceIn {
    0%,20%,40%,60%,80%,to {
        animation-timing-function: cubic-bezier(.215,.61,.355,1)
    }

    0% {
        opacity: 0;
        transform: scale3d(.3,.3,.3)
    }

    20% {
        transform: scale3d(1.1,1.1,1.1)
    }

    40% {
        transform: scale3d(.9,.9,.9)
    }

    60% {
        opacity: 1;
        transform: scale3d(1.03,1.03,1.03)
    }

    80% {
        transform: scale3d(.97,.97,.97)
    }

    to {
        opacity: 1;
        transform: scaleX(1)
    }
}

.bounceIn {
    animation-name: bounceIn
}

@keyframes bounceInDown {
    0%,60%,75%,90%,to {
        animation-timing-function: cubic-bezier(.215,.61,.355,1)
    }

    0% {
        opacity: 0;
        transform: translate3d(0,-3000px,0)
    }

    60% {
        opacity: 1;
        transform: translate3d(0,25px,0)
    }

    75% {
        transform: translate3d(0,-10px,0)
    }

    90% {
        transform: translate3d(0,5px,0)
    }

    to {
        transform: none
    }
}

.bounceInDown {
    animation-name: bounceInDown
}

@keyframes bounceInLeft {
    0%,60%,75%,90%,to {
        animation-timing-function: cubic-bezier(.215,.61,.355,1)
    }

    0% {
        opacity: 0;
        transform: translate3d(-3000px,0,0)
    }

    60% {
        opacity: 1;
        transform: translate3d(25px,0,0)
    }

    75% {
        transform: translate3d(-10px,0,0)
    }

    90% {
        transform: translate3d(5px,0,0)
    }

    to {
        transform: none
    }
}

.bounceInLeft {
    animation-name: bounceInLeft
}

@keyframes bounceInRight {
    0%,60%,75%,90%,to {
        animation-timing-function: cubic-bezier(.215,.61,.355,1)
    }

    0% {
        opacity: 0;
        transform: translate3d(3000px,0,0)
    }

    60% {
        opacity: 1;
        transform: translate3d(-25px,0,0)
    }

    75% {
        transform: translate3d(10px,0,0)
    }

    90% {
        transform: translate3d(-5px,0,0)
    }

    to {
        transform: none
    }
}

.bounceInRight {
    animation-name: bounceInRight
}

@keyframes bounceInUp {
    0%,60%,75%,90%,to {
        animation-timing-function: cubic-bezier(.215,.61,.355,1)
    }

    0% {
        opacity: 0;
        transform: translate3d(0,3000px,0)
    }

    60% {
        opacity: 1;
        transform: translate3d(0,-20px,0)
    }

    75% {
        transform: translate3d(0,10px,0)
    }

    90% {
        transform: translate3d(0,-5px,0)
    }

    to {
        transform: translateZ(0)
    }
}

.bounceInUp {
    animation-name: bounceInUp
}

@keyframes bounceOut {
    20% {
        transform: scale3d(.9,.9,.9)
    }

    50%,55% {
        opacity: 1;
        transform: scale3d(1.1,1.1,1.1)
    }

    to {
        opacity: 0;
        transform: scale3d(.3,.3,.3)
    }
}

.bounceOut {
    animation-name: bounceOut
}

@keyframes bounceOutDown {
    20% {
        transform: translate3d(0,10px,0)
    }

    40%,45% {
        opacity: 1;
        transform: translate3d(0,-20px,0)
    }

    to {
        opacity: 0;
        transform: translate3d(0,2000px,0)
    }
}

.bounceOutDown {
    animation-name: bounceOutDown
}

@keyframes bounceOutLeft {
    20% {
        opacity: 1;
        transform: translate3d(20px,0,0)
    }

    to {
        opacity: 0;
        transform: translate3d(-2000px,0,0)
    }
}

.bounceOutLeft {
    animation-name: bounceOutLeft
}

@keyframes bounceOutRight {
    20% {
        opacity: 1;
        transform: translate3d(-20px,0,0)
    }

    to {
        opacity: 0;
        transform: translate3d(2000px,0,0)
    }
}

.bounceOutRight {
    animation-name: bounceOutRight
}

@keyframes bounceOutUp {
    20% {
        transform: translate3d(0,-10px,0)
    }

    40%,45% {
        opacity: 1;
        transform: translate3d(0,20px,0)
    }

    to {
        opacity: 0;
        transform: translate3d(0,-2000px,0)
    }
}

.bounceOutUp {
    animation-name: bounceOutUp
}

@keyframes fadeIn {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.fadeIn {
    animation-name: fadeIn
}

@keyframes fadeInDown {
    0% {
        opacity: 0;
        transform: translate3d(0,-100%,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.fadeInDown {
    animation-name: fadeInDown
}

@keyframes fadeInDownBig {
    0% {
        opacity: 0;
        transform: translate3d(0,-2000px,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.fadeInDownBig {
    animation-name: fadeInDownBig
}

@keyframes fadeInLeft {
    0% {
        opacity: 0;
        transform: translate3d(-100%,0,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.fadeInLeft {
    animation-name: fadeInLeft
}

@keyframes fadeInLeftBig {
    0% {
        opacity: 0;
        transform: translate3d(-2000px,0,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.fadeInLeftBig {
    animation-name: fadeInLeftBig
}

@keyframes fadeInRight {
    0% {
        opacity: 0;
        transform: translate3d(100%,0,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.fadeInRight {
    animation-name: fadeInRight
}

@keyframes fadeInRightBig {
    0% {
        opacity: 0;
        transform: translate3d(2000px,0,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.fadeInRightBig {
    animation-name: fadeInRightBig
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        transform: translate3d(0,100%,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.fadeInUp {
    animation-name: fadeInUp
}

@keyframes fadeInUpBig {
    0% {
        opacity: 0;
        transform: translate3d(0,2000px,0)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.fadeInUpBig {
    animation-name: fadeInUpBig
}

@keyframes fadeOut {
    0% {
        opacity: 1
    }

    to {
        opacity: 0
    }
}

.fadeOut {
    animation-name: fadeOut
}

@keyframes fadeOutDown {
    0% {
        opacity: 1
    }

    to {
        opacity: 0;
        transform: translate3d(0,100%,0)
    }
}

.fadeOutDown {
    animation-name: fadeOutDown
}

@keyframes fadeOutDownBig {
    0% {
        opacity: 1
    }

    to {
        opacity: 0;
        transform: translate3d(0,2000px,0)
    }
}

.fadeOutDownBig {
    animation-name: fadeOutDownBig
}

@keyframes fadeOutLeft {
    0% {
        opacity: 1
    }

    to {
        opacity: 0;
        transform: translate3d(-100%,0,0)
    }
}

.fadeOutLeft {
    animation-name: fadeOutLeft
}

@keyframes fadeOutLeftBig {
    0% {
        opacity: 1
    }

    to {
        opacity: 0;
        transform: translate3d(-2000px,0,0)
    }
}

.fadeOutLeftBig {
    animation-name: fadeOutLeftBig
}

@keyframes fadeOutRight {
    0% {
        opacity: 1
    }

    to {
        opacity: 0;
        transform: translate3d(100%,0,0)
    }
}

.fadeOutRight {
    animation-name: fadeOutRight
}

@keyframes fadeOutRightBig {
    0% {
        opacity: 1
    }

    to {
        opacity: 0;
        transform: translate3d(2000px,0,0)
    }
}

.fadeOutRightBig {
    animation-name: fadeOutRightBig
}

@keyframes fadeOutUp {
    0% {
        opacity: 1
    }

    to {
        opacity: 0;
        transform: translate3d(0,-100%,0)
    }
}

.fadeOutUp {
    animation-name: fadeOutUp
}

@keyframes fadeOutUpBig {
    0% {
        opacity: 1
    }

    to {
        opacity: 0;
        transform: translate3d(0,-2000px,0)
    }
}

.fadeOutUpBig {
    animation-name: fadeOutUpBig
}

@keyframes flip {
    0% {
        animation-timing-function: ease-out;
        transform: perspective(400px) rotateY(-1turn)
    }

    40% {
        animation-timing-function: ease-out;
        transform: perspective(400px) translateZ(150px) rotateY(-190deg)
    }

    50% {
        animation-timing-function: ease-in;
        transform: perspective(400px) translateZ(150px) rotateY(-170deg)
    }

    80% {
        animation-timing-function: ease-in;
        transform: perspective(400px) scale3d(.95,.95,.95)
    }

    to {
        animation-timing-function: ease-in;
        transform: perspective(400px)
    }
}

.animated.flip {
    animation-name: flip;
    backface-visibility: visible
}

@keyframes flipInX {
    0% {
        animation-timing-function: ease-in;
        opacity: 0;
        transform: perspective(400px) rotateX(90deg)
    }

    40% {
        animation-timing-function: ease-in;
        transform: perspective(400px) rotateX(-20deg)
    }

    60% {
        opacity: 1;
        transform: perspective(400px) rotateX(10deg)
    }

    80% {
        transform: perspective(400px) rotateX(-5deg)
    }

    to {
        transform: perspective(400px)
    }
}

.flipInX {
    animation-name: flipInX;
    backface-visibility: visible !important
}

@keyframes flipInY {
    0% {
        animation-timing-function: ease-in;
        opacity: 0;
        transform: perspective(400px) rotateY(90deg)
    }

    40% {
        animation-timing-function: ease-in;
        transform: perspective(400px) rotateY(-20deg)
    }

    60% {
        opacity: 1;
        transform: perspective(400px) rotateY(10deg)
    }

    80% {
        transform: perspective(400px) rotateY(-5deg)
    }

    to {
        transform: perspective(400px)
    }
}

.flipInY {
    animation-name: flipInY;
    backface-visibility: visible !important
}

@keyframes flipOutX {
    0% {
        transform: perspective(400px)
    }

    30% {
        opacity: 1;
        transform: perspective(400px) rotateX(-20deg)
    }

    to {
        opacity: 0;
        transform: perspective(400px) rotateX(90deg)
    }
}

.flipOutX {
    animation-name: flipOutX;
    backface-visibility: visible !important
}

@keyframes flipOutY {
    0% {
        transform: perspective(400px)
    }

    30% {
        opacity: 1;
        transform: perspective(400px) rotateY(-15deg)
    }

    to {
        opacity: 0;
        transform: perspective(400px) rotateY(90deg)
    }
}

.flipOutY {
    animation-name: flipOutY;
    backface-visibility: visible !important
}

@keyframes lightSpeedIn {
    0% {
        opacity: 0;
        transform: translate3d(100%,0,0) skewX(-30deg)
    }

    60% {
        opacity: 1;
        transform: skewX(20deg)
    }

    80% {
        opacity: 1;
        transform: skewX(-5deg)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.lightSpeedIn {
    animation-name: lightSpeedIn;
    animation-timing-function: ease-out
}

@keyframes lightSpeedOut {
    0% {
        opacity: 1
    }

    to {
        opacity: 0;
        transform: translate3d(100%,0,0) skewX(30deg)
    }
}

.lightSpeedOut {
    animation-name: lightSpeedOut;
    animation-timing-function: ease-in
}

@keyframes rotateIn {
    0% {
        opacity: 0;
        transform: rotate(-200deg);
        transform-origin: center
    }

    to {
        opacity: 1;
        transform: none;
        transform-origin: center
    }
}

.rotateIn {
    animation-name: rotateIn
}

@keyframes rotateInDownLeft {
    0% {
        opacity: 0;
        transform: rotate(-45deg);
        transform-origin: left bottom
    }

    to {
        opacity: 1;
        transform: none;
        transform-origin: left bottom
    }
}

.rotateInDownLeft {
    animation-name: rotateInDownLeft
}

@keyframes rotateInDownRight {
    0% {
        opacity: 0;
        transform: rotate(45deg);
        transform-origin: right bottom
    }

    to {
        opacity: 1;
        transform: none;
        transform-origin: right bottom
    }
}

.rotateInDownRight {
    animation-name: rotateInDownRight
}

@keyframes rotateInUpLeft {
    0% {
        opacity: 0;
        transform: rotate(45deg);
        transform-origin: left bottom
    }

    to {
        opacity: 1;
        transform: none;
        transform-origin: left bottom
    }
}

.rotateInUpLeft {
    animation-name: rotateInUpLeft
}

@keyframes rotateInUpRight {
    0% {
        opacity: 0;
        transform: rotate(-90deg);
        transform-origin: right bottom
    }

    to {
        opacity: 1;
        transform: none;
        transform-origin: right bottom
    }
}

.rotateInUpRight {
    animation-name: rotateInUpRight
}

@keyframes rotateOut {
    0% {
        opacity: 1;
        transform-origin: center
    }

    to {
        opacity: 0;
        transform: rotate(200deg);
        transform-origin: center
    }
}

.rotateOut {
    animation-name: rotateOut
}

@keyframes rotateOutDownLeft {
    0% {
        opacity: 1;
        transform-origin: left bottom
    }

    to {
        opacity: 0;
        transform: rotate(45deg);
        transform-origin: left bottom
    }
}

.rotateOutDownLeft {
    animation-name: rotateOutDownLeft
}

@keyframes rotateOutDownRight {
    0% {
        opacity: 1;
        transform-origin: right bottom
    }

    to {
        opacity: 0;
        transform: rotate(-45deg);
        transform-origin: right bottom
    }
}

.rotateOutDownRight {
    animation-name: rotateOutDownRight
}

@keyframes rotateOutUpLeft {
    0% {
        opacity: 1;
        transform-origin: left bottom
    }

    to {
        opacity: 0;
        transform: rotate(-45deg);
        transform-origin: left bottom
    }
}

.rotateOutUpLeft {
    animation-name: rotateOutUpLeft
}

@keyframes rotateOutUpRight {
    0% {
        opacity: 1;
        transform-origin: right bottom
    }

    to {
        opacity: 0;
        transform: rotate(90deg);
        transform-origin: right bottom
    }
}

.rotateOutUpRight {
    animation-name: rotateOutUpRight
}

@keyframes hinge {
    0% {
        animation-timing-function: ease-in-out;
        transform-origin: top left
    }

    20%,60% {
        animation-timing-function: ease-in-out;
        transform: rotate(80deg);
        transform-origin: top left
    }

    40%,80% {
        animation-timing-function: ease-in-out;
        opacity: 1;
        transform: rotate(60deg);
        transform-origin: top left
    }

    to {
        opacity: 0;
        transform: translate3d(0,700px,0)
    }
}

.hinge {
    animation-name: hinge
}

@keyframes rollIn {
    0% {
        opacity: 0;
        transform: translate3d(-100%,0,0) rotate(-120deg)
    }

    to {
        opacity: 1;
        transform: none
    }
}

.rollIn {
    animation-name: rollIn
}

@keyframes rollOut {
    0% {
        opacity: 1
    }

    to {
        opacity: 0;
        transform: translate3d(100%,0,0) rotate(120deg)
    }
}

.rollOut {
    animation-name: rollOut
}

@keyframes zoomIn {
    0% {
        opacity: 0;
        transform: scale3d(.3,.3,.3)
    }

    50% {
        opacity: 1
    }
}

.zoomIn {
    animation-name: zoomIn
}

@keyframes zoomInDown {
    0% {
        animation-timing-function: cubic-bezier(.55,.055,.675,.19);
        opacity: 0;
        transform: scale3d(.1,.1,.1) translate3d(0,-1000px,0)
    }

    60% {
        animation-timing-function: cubic-bezier(.175,.885,.32,1);
        opacity: 1;
        transform: scale3d(.475,.475,.475) translate3d(0,60px,0)
    }
}

.zoomInDown {
    animation-name: zoomInDown
}

@keyframes zoomInLeft {
    0% {
        animation-timing-function: cubic-bezier(.55,.055,.675,.19);
        opacity: 0;
        transform: scale3d(.1,.1,.1) translate3d(-1000px,0,0)
    }

    60% {
        animation-timing-function: cubic-bezier(.175,.885,.32,1);
        opacity: 1;
        transform: scale3d(.475,.475,.475) translate3d(10px,0,0)
    }
}

.zoomInLeft {
    animation-name: zoomInLeft
}

@keyframes zoomInRight {
    0% {
        animation-timing-function: cubic-bezier(.55,.055,.675,.19);
        opacity: 0;
        transform: scale3d(.1,.1,.1) translate3d(1000px,0,0)
    }

    60% {
        animation-timing-function: cubic-bezier(.175,.885,.32,1);
        opacity: 1;
        transform: scale3d(.475,.475,.475) translate3d(-10px,0,0)
    }
}

.zoomInRight {
    animation-name: zoomInRight
}

@keyframes zoomInUp {
    0% {
        animation-timing-function: cubic-bezier(.55,.055,.675,.19);
        opacity: 0;
        transform: scale3d(.1,.1,.1) translate3d(0,1000px,0)
    }

    60% {
        animation-timing-function: cubic-bezier(.175,.885,.32,1);
        opacity: 1;
        transform: scale3d(.475,.475,.475) translate3d(0,-60px,0)
    }
}

.zoomInUp {
    animation-name: zoomInUp
}

@keyframes zoomOut {
    0% {
        opacity: 1
    }

    50% {
        opacity: 0;
        transform: scale3d(.3,.3,.3)
    }

    to {
        opacity: 0
    }
}

.zoomOut {
    animation-name: zoomOut
}

@keyframes zoomOutDown {
    40% {
        animation-timing-function: cubic-bezier(.55,.055,.675,.19);
        opacity: 1;
        transform: scale3d(.475,.475,.475) translate3d(0,-60px,0)
    }

    to {
        animation-timing-function: cubic-bezier(.175,.885,.32,1);
        opacity: 0;
        transform: scale3d(.1,.1,.1) translate3d(0,2000px,0);
        transform-origin: center bottom
    }
}

.zoomOutDown {
    animation-name: zoomOutDown
}

@keyframes zoomOutLeft {
    40% {
        opacity: 1;
        transform: scale3d(.475,.475,.475) translate3d(42px,0,0)
    }

    to {
        opacity: 0;
        transform: scale(.1) translate3d(-2000px,0,0);
        transform-origin: left center
    }
}

.zoomOutLeft {
    animation-name: zoomOutLeft
}

@keyframes zoomOutRight {
    40% {
        opacity: 1;
        transform: scale3d(.475,.475,.475) translate3d(-42px,0,0)
    }

    to {
        opacity: 0;
        transform: scale(.1) translate3d(2000px,0,0);
        transform-origin: right center
    }
}

.zoomOutRight {
    animation-name: zoomOutRight
}

@keyframes zoomOutUp {
    40% {
        animation-timing-function: cubic-bezier(.55,.055,.675,.19);
        opacity: 1;
        transform: scale3d(.475,.475,.475) translate3d(0,60px,0)
    }

    to {
        animation-timing-function: cubic-bezier(.175,.885,.32,1);
        opacity: 0;
        transform: scale3d(.1,.1,.1) translate3d(0,-2000px,0);
        transform-origin: center bottom
    }
}

.zoomOutUp {
    animation-name: zoomOutUp
}

@keyframes slideInDown {
    0% {
        transform: translate3d(0,-100%,0);
        visibility: visible
    }

    to {
        transform: translateZ(0)
    }
}

.slideInDown {
    animation-name: slideInDown
}

@keyframes slideInLeft {
    0% {
        transform: translate3d(-100%,0,0);
        visibility: visible
    }

    to {
        transform: translateZ(0)
    }
}

.slideInLeft {
    animation-name: slideInLeft
}

@keyframes slideInRight {
    0% {
        transform: translate3d(100%,0,0);
        visibility: visible
    }

    to {
        transform: translateZ(0)
    }
}

.slideInRight {
    animation-name: slideInRight
}

@keyframes slideInUp {
    0% {
        transform: translate3d(0,100%,0);
        visibility: visible
    }

    to {
        transform: translateZ(0)
    }
}

.slideInUp {
    animation-name: slideInUp
}

@keyframes slideOutDown {
    0% {
        transform: translateZ(0)
    }

    to {
        transform: translate3d(0,100%,0);
        visibility: hidden
    }
}

.slideOutDown {
    animation-name: slideOutDown
}

@keyframes slideOutLeft {
    0% {
        transform: translateZ(0)
    }

    to {
        transform: translate3d(-100%,0,0);
        visibility: hidden
    }
}

.slideOutLeft {
    animation-name: slideOutLeft
}

@keyframes slideOutRight {
    0% {
        transform: translateZ(0)
    }

    to {
        transform: translate3d(100%,0,0);
        visibility: hidden
    }
}

.slideOutRight {
    animation-name: slideOutRight
}

@keyframes slideOutUp {
    0% {
        transform: translateZ(0)
    }

    to {
        transform: translate3d(0,-100%,0);
        visibility: hidden
    }
}

.slideOutUp {
    animation-name: slideOutUp
}

.ja_no_pad .ja_body {
    padding: 0
}

.ja_no_pad .ja_btn_wrap.optBack {
    margin-bottom: 0;
    margin-top: 25px
}

.jAlert.ja_slideshow_modal {
    display: flex;
    flex-direction: column;
    margin: 0 auto !important
}

    .jAlert.ja_slideshow_modal.ja_fullscreen {
        height: 100vh;
        max-height: 100vh
    }

    .jAlert.ja_slideshow_modal .ja_title {
        flex-shrink: 0
    }

    .jAlert.ja_slideshow_modal .ja_body {
        display: flex;
        flex: 1;
        flex-direction: column;
        min-height: 0;
        padding: 0
    }

    .jAlert.ja_slideshow_modal:not(.ja_no_pad) .ja_body {
        padding: 20px
    }

    .jAlert.ja_slideshow_modal .ja_slideshow_thumbnails {
        flex-shrink: 0;
        order: 2
    }

    .jAlert.ja_slideshow_modal .ja_slideshow_wrap {
        order: 1
    }

    .jAlert.ja_slideshow_modal .ja_btn_wrap.optBack {
        flex-shrink: 0;
        margin-bottom: 0 !important;
        margin-top: 0 !important
    }

.jAlert.ja_full.ja_slideshow_modal .ja_slideshow_container, .jAlert.ja_full.ja_slideshow_modal .ja_slideshow_main {
    align-items: center;
    display: flex;
    justify-content: center
}

.ja_slideshow_wrap {
    display: flex;
    flex-direction: column;
    height: 100%;
    width: 100%
}

    .ja_slideshow_wrap > .ja_loader {
        display: block;
        margin: 120px auto;
        text-align: center;
        z-index: 10
    }

.ja_slideshow_main {
    align-items: center;
    display: flex;
    flex: 1;
    justify-content: center;
    min-height: 0;
    overflow: hidden;
    position: relative;
    width: 100%
}

.ja_slideshow_container, .ja_slideshow_slide {
    align-items: center;
    display: flex;
    height: 100%;
    justify-content: center;
    position: relative;
    width: 100%
}

.ja_slideshow_slide {
    background-repeat: no-repeat
}

    .ja_slideshow_slide.ja_cover_mode {
        aspect-ratio: 1/1;
        background-position: 50%;
        background-size: cover;
        height: auto;
        max-height: none
    }

@supports not (aspect-ratio:1/1) {
    .ja_slideshow_slide.ja_cover_mode {
        background-position: 50%;
        background-size: cover;
        height: 0;
        padding-bottom: 100%
    }
}

.ja_slideshow_img {
    display: block;
    height: auto;
    margin: 0;
    max-height: 100%;
    max-width: 100%;
    -o-object-fit: contain;
    object-fit: contain;
    padding: 0;
    width: auto
}

@supports not ((-o-object-fit:contain) or (object-fit:contain)) {
    .ja_slideshow_img {
        background-position: 50%;
        background-repeat: no-repeat;
        background-size: contain;
        height: 100% !important;
        width: 100% !important
    }

        .ja_slideshow_img.cover {
            background-size: cover
        }
}

.ja_slideshow_thumbnail_bg {
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    cursor: pointer;
    height: 80px;
    opacity: .8;
    overflow: hidden;
    position: relative;
    transition: all .3s ease;
    width: 80px
}

    .ja_slideshow_thumbnail_bg:hover {
        opacity: 1;
        transform: scale(1.1)
    }

    .ja_slideshow_thumbnail_bg.active {
        opacity: 1
    }

    .ja_slideshow_thumbnail_bg.error {
        align-items: center;
        background-color: rgba(220,53,69,.1);
        background-image: none !important;
        border: 1px solid rgba(220,53,69,.2);
        display: flex;
        justify-content: center
    }

        .ja_slideshow_thumbnail_bg.error:before {
            color: rgba(220,53,69,.6);
            content: "⚠";
            font-size: 24px;
            line-height: 1
        }

.ja_slideshow_caption {
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    background: rgba(0,0,0,.7);
    border-radius: 0;
    bottom: 0;
    color: #fff;
    font-size: 14px;
    left: 0;
    line-height: 1em;
    margin: 0;
    padding: 10px;
    position: absolute;
    right: 0;
    text-align: center;
    z-index: 5
}

.ja_slideshow_error {
    background: rgba(220,53,69,.9);
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,.3);
    color: #fff;
    display: block;
    font-size: 16px;
    margin: 120px auto;
    max-width: 80%;
    min-width: 200px;
    padding: 20px 30px;
    text-align: center;
    z-index: 10
}

.ja_slideshow_arrow {
    align-items: center;
    background: rgba(0,0,0,.7);
    border: none;
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    display: flex;
    font-size: 18px;
    font-weight: 700;
    height: 40px;
    justify-content: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    transition: all .3s ease;
    width: 40px;
    z-index: 10
}

    .ja_slideshow_arrow:hover {
        background: rgba(0,0,0,.9);
        transform: translateY(-50%) scale(1.1)
    }

    .ja_slideshow_arrow.disabled {
        cursor: not-allowed;
        opacity: .5;
        transform: translateY(-50%)
    }

        .ja_slideshow_arrow.disabled:hover {
            background: rgba(0,0,0,.7);
            transform: translateY(-50%)
        }

.ja_slideshow_prev {
    left: 10px
}

.ja_slideshow_next {
    right: 10px
}

.ja_slideshow_counter {
    background: rgba(0,0,0,.7);
    border-radius: 20px;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 8px 15px
}

.ja_slideshow_counter, .ja_slideshow_dots {
    bottom: 10px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    z-index: 10
}

.ja_slideshow_dots {
    display: flex;
    flex-shrink: 0;
    gap: 8px;
    height: auto;
    min-height: 0;
    min-width: 0;
    pointer-events: auto;
    width: auto
}

.ja_slideshow_dot {
    background: hsla(0,0%,100%,.5);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    flex-grow: 0;
    flex-shrink: 0;
    height: 12px;
    max-height: 12px;
    max-width: 12px;
    min-height: 12px;
    min-width: 12px;
    transition: all .3s ease;
    width: 12px
}

    .ja_slideshow_dot:hover {
        background: hsla(0,0%,100%,.8)
    }

    .ja_slideshow_dot.active {
        background: #fff;
        transform: scale(1.2)
    }

.ja_slideshow_nav {
    align-items: center;
    background: rgba(0,0,0,.7);
    border-radius: 20px;
    bottom: 10px;
    display: flex;
    gap: 15px;
    left: 50%;
    padding: 8px 15px;
    position: absolute;
    transform: translateX(-50%);
    z-index: 10
}

.ja_slideshow_next:not(.ja_slideshow_arrow), .ja_slideshow_prev:not(.ja_slideshow_arrow) {
    align-items: center;
    background: hsla(0,0%,100%,.9);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    font-size: 16px;
    font-weight: 700;
    height: 30px;
    justify-content: center;
    transition: all .3s ease;
    width: 30px
}

    .ja_slideshow_next:not(.ja_slideshow_arrow):hover, .ja_slideshow_prev:not(.ja_slideshow_arrow):hover {
        background: #fff;
        transform: scale(1.1)
    }

    .ja_slideshow_next:not(.ja_slideshow_arrow).disabled, .ja_slideshow_prev:not(.ja_slideshow_arrow).disabled {
        cursor: not-allowed;
        opacity: .5;
        transform: none
    }

        .ja_slideshow_next:not(.ja_slideshow_arrow).disabled:hover, .ja_slideshow_prev:not(.ja_slideshow_arrow).disabled:hover {
            background: hsla(0,0%,100%,.9);
            transform: none
        }

.ja_slideshow_counter:not(.ja_slideshow_counter) {
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    min-width: 40px;
    text-align: center
}

@media (max-width:768px) {
    .ja_slideshow_arrow {
        font-size: 16px;
        height: 35px;
        width: 35px
    }

    .ja_slideshow_prev {
        left: 5px
    }

    .ja_slideshow_next {
        right: 5px
    }

    .ja_slideshow_counter {
        font-size: 11px;
        padding: 6px 12px
    }

    .ja_slideshow_dots {
        gap: 6px
    }

    .ja_slideshow_dot {
        height: 10px;
        width: 10px
    }

    .ja_slideshow_caption {
        font-size: 12px;
        padding: 8px
    }
}

.ja_slideshow_thumbnails {
    display: none;
    flex-shrink: 0;
    height: 80px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    scrollbar-color: hsla(0,0%,100%,.5) transparent;
    scrollbar-width: thin;
    width: 100%;
    -webkit-overflow-scrolling: touch;
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    will-change: scroll-position
}

    .ja_slideshow_thumbnails::-webkit-scrollbar {
        height: 6px;
        width: 6px
    }

    .ja_slideshow_thumbnails::-webkit-scrollbar-track {
        background: rgba(0,0,0,.1);
        border-radius: 3px
    }

    .ja_slideshow_thumbnails::-webkit-scrollbar-thumb {
        background: hsla(0,0%,100%,.5);
        border-radius: 3px
    }

        .ja_slideshow_thumbnails::-webkit-scrollbar-thumb:hover {
            background: hsla(0,0%,100%,.7)
        }

.ja_slideshow_has_thumbnails .ja_slideshow_thumbnails {
    display: flex
}

.ja_slideshow_thumbnails.dragging {
    cursor: grabbing;
    scroll-behavior: auto
}

.ja_slideshow_thumbnails_bottom, .ja_slideshow_thumbnails_top {
    background: transparent;
    cursor: grab;
    display: flex;
    gap: 0;
    justify-content: center;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0;
    width: 100%
}

.ja_slideshow_thumbnails_top {
    order: 1
}

.ja_slideshow_main {
    order: 2
}

.ja_slideshow_thumbnails_bottom {
    order: 3
}

.ja_slideshow_thumbnail {
    background: none;
    border: none;
    cursor: pointer;
    display: inline-block;
    flex: 0 0 80px !important;
    height: 80px;
    max-height: 80px;
    max-width: 80px;
    min-height: 80px;
    min-width: 80px;
    opacity: .8;
    overflow: hidden;
    padding: 0;
    position: relative;
    transition: all .3s ease;
    width: 80px
}

    .ja_slideshow_thumbnail.active, .ja_slideshow_thumbnail:hover {
        opacity: 1
    }

        .ja_slideshow_thumbnail.active:after {
            background: hsla(0,0%,100%,.2);
            bottom: 0;
            content: "";
            left: 0;
            pointer-events: none;
            position: absolute;
            right: 0;
            top: 0
        }

@media (max-width:480px) {
    .ja_slideshow_thumbnails {
        height: 60px
    }

    .ja_slideshow_thumbnail {
        flex: 0 0 60px !important;
        height: 60px;
        max-height: 60px;
        max-width: 60px;
        min-height: 60px;
        min-width: 60px;
        width: 60px
    }

    .ja_slideshow_thumbnail_bg {
        height: 60px;
        width: 60px
    }

        .ja_slideshow_thumbnail_bg.error:before {
            font-size: 18px
        }
}

@media (min-width:481px) and (max-width:1024px) {
    .ja_slideshow_thumbnails {
        height: 70px
    }

    .ja_slideshow_thumbnail {
        flex: 0 0 70px !important;
        height: 70px;
        max-height: 70px;
        max-width: 70px;
        min-height: 70px;
        min-width: 70px;
        width: 70px
    }

    .ja_slideshow_thumbnail_bg {
        height: 70px;
        width: 70px
    }

        .ja_slideshow_thumbnail_bg.error:before {
            font-size: 20px
        }
}

@media (min-width:451px) and (max-width:1024px) {
    .ja_btn, .ja_btn_wrap a, .ja_btn_wrap button {
        align-items: center;
        display: inline-flex;
        font-size: 16px !important;
        justify-content: center;
        padding: 8px 16px !important
    }

    .ja_btn_wrap {
        margin-bottom: -15px;
        margin-top: 15px
    }

        .ja_btn_wrap.optBack {
            margin: 30px -20px -20px;
            padding: 10px 0
        }

    .ja_no_pad .ja_btn_wrap.optBack {
        margin-bottom: 0;
        margin-top: 30px
    }
}

.ja_media_modal .ja_body > .ja_loader {
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%);
    z-index: 10
}

.ja_slideshow_slide > .ja_loader {
    display: block;
    margin: 120px auto;
    pointer-events: none;
    text-align: center;
    z-index: 100
}

.ja_slideshow_slide.ja_cover_mode > .ja_loader {
    left: 50%;
    margin-left: -.5em;
    margin-top: -.5em;
    pointer-events: none;
    position: absolute;
    top: 50%;
    z-index: 100
}

.ja_fullscreen .ja_slideshow_slide:has(.ja_loader) {
    min-height: 300px
}

.ja_fullscreen .ja_slideshow_slide.ja_loading {
    min-height: 300px
}

.ja_fullscreen .ja_slideshow_slide > .ja_loader {
    display: block;
    left: 50% !important;
    margin: -.5em 0 0 -.5em !important;
    pointer-events: none;
    position: absolute !important;
    text-align: center;
    top: 50% !important;
    z-index: 100
}

.ja_slideshow_slide.ja_cover_mode > .ja_slideshow_error {
    left: 50%;
    margin: 0;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%)
}

.ja_img_error {
    left: 50%;
    max-width: calc(100% - 40px);
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%)
}

.ja_ajax_error, .ja_img_error {
    background: rgba(220,53,69,.9);
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,.3);
    color: #fff;
    font-size: 16px;
    min-width: 200px;
    padding: 20px 30px;
    text-align: center;
    z-index: 10
}

.ja_ajax_error {
    display: block;
    margin: 60px 20px;
    max-width: 100%
}
