/*
Theme Name: Jul I Vinterland
Author: Moxline Solutions
Description: Custom wordpress theme for julivinterland.no
Version: 0.0.1
*/

/*language menu*/ /* TEMPORARY SOLUTION*/
.lang-nav-cont select{
    background-color: transparent;
    border: 0px;
    text-transform: uppercase;
}
/*map container on homepage - this will change later*/
.map-container{
    background-color: #002148;
    padding: 70px 30px;
}
/*DELETE EVERYTHING FROM ABOVE THIS IS THE NEW STYLE !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!*/
/************************************************************************************************************/
html body {
    position: relative;
    overflow-x: hidden;
    font-family: "Gentium Basic";
    font-size: 18px;
    font-weight: 300;
    background-color: #f5f7f7;
    color: #464646;
}
h1, h2, h3, h4, h5, h6 {
    font-family: 'Clearface'; 
}
header,
footer{
    font-family: "Futura Medium";
}

.bg-light-blue{
    background-color: #2198d2;
    color: #fff;
}
.bg-blue{
    background-color: #002148;
    color: #fff;
}
.bg-grey{
    background-color: #464646;
    color: #fff;
}
.bg-white{
    background-color: #ffffff;
    color: #464646;
}
img{
    height: auto;
    width: 100%;
}
div a,
div a:hover,
div a:focus{
    text-decoration: none;
}
div .close {
    position: absolute;
    right: -75px;
    top: -38px;
    width: 30px;
    height: 30px;
    opacity: 1;
}
.close:hover {
    opacity: 1;
}
.close:before, .close:after {
    position: absolute;
    left: 15px;
    content: ' ';
    height: 24px;
    width: 2px;
    background-color: #2198d2;
}
.close:before {
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}
.close:after {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.container.vc_column_container{
    float: none!important;
}
.container.vc_column_container > .vc_column-inner {
    padding-left: 10px;
    padding-right: 10px;
}
/*HEADER*/
header .nav-row{
    position: relative;
    border-bottom: 5px solid #fff;
}
header .navbar{
    padding:  20px 0px;
}
header .navbar-brand {
    padding: 14px 0px;
    width: 135px;
}
header .navbar-expand-lg .navbar-nav .nav-link{
    position: relative;
    font-size: 14px;
    color: #fff;
    text-transform: uppercase;
    padding: 9px 14px;
    letter-spacing: 2px;
}
header .navbar-nav > li > a:before {
    background-color: #2198d2;
    border-radius: 3px;
    opacity: 0;
    content: "";
    position: absolute;
    left: 27px;
    right: 27px;
    height: 3px;
    bottom: 3px;
    -moz-transition: all .2s;
    -o-transition: all .2s;
    -webkit-transition: all .2s;
    transition: all .2s;
}
header .navbar-nav > li:first-of-type{
    display: none;
}
.navbar-nav > li.active > a:before {
    opacity: 1;
}
.navbar-nav > li:hover > a:before{
    background-color: #fff;
    opacity: 1;
}
.navbar-nav > li > a:focus:before{
    background-color: #b4b4b4;
    opacity: 1;
}
/*LANGUAGE SWITCHER*/
.langnav .trp-language-switcher{
    display: block;
    position: relative;
    margin: 0px;
}
.langnav .trp-language-switcher:before{
    /*      content: "\f0d7";
          font: normal normal normal 18px/1 FontAwesome;
          position: absolute;
          top: 0;
          bottom: 0;
          height: 14px;
          line-height: 100%;
          margin: auto;
          right: 32px;*/
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    height: 12px;
    line-height: 100%;
    margin: auto;
    right: 32px;

    border-style: solid;
    border-width: 10px 6px 0 6px;
    border-color: #fff transparent transparent transparent;
}
.langnav .trp-language-switcher .trp-ls-shortcode-current-language{
    background-color: transparent;
    border: 0;
    background: none;
    text-align: right;
    padding: 10px 0px;
    width: 100%!important;
}
.langnav .trp-language-switcher .trp-ls-shortcode-current-language img{
    display: none;
}
.langnav .trp-language-switcher .trp-ls-shortcode-current-language a{
    color: #fff;
    font-size: 14px;
    padding: 0px;
}
.langnav .trp-language-switcher:focus .trp-ls-shortcode-current-language,
.trp-language-switcher:hover .trp-ls-shortcode-current-language{
    visibility: visible!important;
}
.langnav .trp-language-switcher .trp-ls-shortcode-language{
    display: block;
    height: auto;
    overflow: visible;
    z-index: 5000;
    position: absolute;
    background-image: none;
    padding: 5px;
    border-radius: 1px;
    border: 1px solid #808080;
}
.langnav .trp-language-switcher:focus .trp-ls-shortcode-language,
.langnav .trp-language-switcher:hover .trp-ls-shortcode-language{
    top: 40px;
    width: 125px!important;
    right: -27px;
    left: auto;
}
.langnav .trp-language-switcher .trp-ls-shortcode-language a{
    font-size: 0px;
    display: block;
    float: right;
    width: auto;
    padding: 5px 6px;
}
.langnav .trp-language-switcher > div > a:hover{
    background: transparent;
}
.langnav .trp-language-switcher > div > a > img{
    margin: 0px;
    width: 43px;
    height: auto;
}
.langnav .trp-ls-shortcode-language:after, .trp-ls-shortcode-language:before {
    bottom: 100%;
    left: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
}

.langnav .trp-ls-shortcode-language:after {
    border-bottom-color: #fff;
    border-width: 10px 6px 10px 6px;
    margin-left: -8px;
}
.langnav .trp-ls-shortcode-language:before {
    border-bottom-color: #808080;
    border-width: 12px 8px 12px 8px;
    margin-left: -10px;
}
#menu-header-menu-no .trp-ls-shortcode-language{
    display: none;
}
/*SOCIAL MEDIA WIDGET*/
.widget-social.header{
    position: absolute;
    right: 5px;
    bottom: -205px;
    z-index: 10;
}
.widget-social.header > h4{
    display: none;
}
.widget-social.header ul{
    background-color: transparent;
    padding: 15px 10px 20px 10px;
}
.widget-social.header ul li{
    background-color: #002148;
    display: block;
    margin-right: 0px;
    margin-bottom: 10px;
}
.widget-social.header .fa{
    font-size: 20px;
}
/*HOMEPAGE VIDEO BANNER*/
.video-container{
    border-bottom: 5px solid #fff;
}
.video-container .vd-placeholder{
    height: calc(100% - 84px);
    min-height: 90vh;
    width: 100%;
}
.video-container .video{
    position: absolute;
    left: 0;
    top: 0px;
    width: 100%;
    height: 100%;
    /* height: 100vh; */
    overflow: hidden;
}
.video-container .video iframe{
    margin-top: -75px;
    width: 100%;
    height: 100%;
    /*height: calc((100vw*9) /16);*/
    height: calc(100vh + 25px);
}
.video-container .play-btn{
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    background-size: cover;

    position: absolute;
    left: 0;
    right: 0;
    top: 0px;
    bottom: 0px;
    margin: auto;
    width: 100%;
    height: 100%;
    background-color: #4dc4ff;
    z-index: 1;
}
.video-container .play-btn.inactive{
    z-index: -1;
    opacity: 0;
    -webkit-transition: z-index 3s step-end, opacity 2.7s linear;
    -moz-transition: z-index 3s step-end, opacity 2.7s linear;
    transition: z-index 3s step-end, opacity 2.7s linear;
}
.video-container .video-overlay{
    position: absolute;
    top: 120px;
    left: 0;
    right: 0;
    width: 550px;
    margin: 0 auto;
    z-index: 1;
}
.video-container .site-title{
    font-family: "Gentium BasicBold";
    color: #002148;
    font-size: 45px;
}
.video-container .site-sub{
    font-family: "Gentium BasicBold";
    color: #002148;
    font-size: 35px;
    line-height: 100%;
    margin-top: -7px;
}
.video-container .site-schedule{
    background: rgba(0,0,0,0.2);
    display: inline-block;
    letter-spacing: 1px;
    font-size: 14px;
    border: 2px solid #fff;
    color: #fff;
    border-radius: 40px;
    padding: 7px 17px;
    margin-top: 15px;
}
.video-container .site-schedule span:last-of-type{
    font-family: "Futura Bold";
}
.video-container .site-schedule span:first-of-type{
    font-family: "Futura Medium";
    text-transform: uppercase;
}
.video-container .play{
    cursor: pointer;
    position: relative;
    width: 100px;
    height: 100px;
    margin: 30px auto 0px;
    border: 5px solid #fff;
    border-radius: 100%;
    -webkit-transition: border-color 300ms;
    -moz-transition: border-color 300ms;
    transition: border-color 300ms;
    background-color: rgba(0,0,0,0.2);
}
.video-container .play::after{
    content: '';
    position: absolute;
    top: 20px;
    left: 27px;
    width: 0;
    height: 0;
    border-left: 50px solid #fff;
    border-top: 25px solid transparent!important;
    border-bottom: 25px solid transparent!important;
    -webkit-transition: border-color 300ms;
    -moz-transition: border-color 300ms;
    transition: border-color 300ms;
}
.video-container .play:hover,
.video-container .play:hover:after{
    border-color: #2198d1;
}
/*BANNER*/
.banner-container .banner{
    position: relative;
    overflow: hidden;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    height: 373px;
    border-bottom: 5px solid #fff;

    -webkit-box-shadow: 0px 10px 0px 0px #2198d2;
    -moz-box-shadow: 0px 10px 0px 0px #2198d2;
    box-shadow: 0px 10px 0px 0px #2198d2;

    margin-bottom: 30px;
}
.banner-container .banner:after,
.swiper-container:after{
    /*display: none;*/
    content: "";
    position:absolute;
    /*position:fixed;*/
    pointer-events:none;
    top:0;
    left:0;
    right:0;
    bottom:0;
    height:100vh;
    background: none;
    background-image: url('css/images/s1.png'), url('css/images/s2.png'), url('css/images/s3.png');
    /*z-index:100;*/
    -webkit-animation: snow 10s linear infinite;
    -moz-animation: snow 10s linear infinite;
    -ms-animation: snow 10s linear infinite;
    animation: snow 10s linear infinite;
}
@keyframes snow {
    0% {background-position: 0px 0px, 0px 0px, 0px 0px;}
    50% {background-position: 500px 500px, 100px 200px, -100px 150px;}
    100% {background-position: 500px 1000px, 200px 400px, -100px 300px;}
}
@-moz-keyframes snow {
    0% {background-position: 0px 0px, 0px 0px, 0px 0px;}
    50% {background-position: 500px 500px, 100px 200px, -100px 150px;}
    100% {background-position: 400px 1000px, 200px 400px, 100px 300px;}
}
@-webkit-keyframes snow {
    0% {background-position: 0px 0px, 0px 0px, 0px 0px;}
    50% {background-position: 500px 500px, 100px 200px, -100px 150px;}
    100% {background-position: 500px 1000px, 200px 400px, -100px 300px;}
}
@-ms-keyframes snow {
    0% {background-position: 0px 0px, 0px 0px, 0px 0px;}
    50% {background-position: 500px 500px, 100px 200px, -100px 150px;}
    100% {background-position: 500px 1000px, 200px 400px, -100px 300px;}
}
.banner-container .banner-icon{
    position: absolute;
    left: 0;
    right: 0;
    bottom: -58px;
    width: 185px;
    height: 185px;
    margin: auto;
    background-color: #f5f7f7;
    border: 1px solid #000;
    border-radius: 100%;

    background-position: 17px 15px;
    background-size: 150px;
    background-repeat: no-repeat;
} 
.banner-container .title-cont{
    background: url('css/images/heading-bg.png') no-repeat center;
    padding-bottom: 5px;
}
.banner-container h1{
    font-family: "Gentium BasicBold";
    position: relative;
    margin: 30px auto 30px;
    padding: 8px 0px;
    width: 300px;
}
.banner-container h1:before,
.banner-container h1:after{
    content: "";
    position: absolute;
    width: 95px;
    height: 40px;
    background: url('css/images/heading-side.png') no-repeat center;
    left: -150px;
    bottom: 0;
}
.banner-container h1:after{
    left: auto;
    right: -150px;
    -moz-transform: scaleX(-1);
    -o-transform: scaleX(-1);
    -webkit-transform: scaleX(-1);
    transform: scaleX(-1);
}
.banner-container .page-excerpt{
    font-family: "Playfair DisplayRegular";
    font-size: 22px;
    max-width: 785px;
    letter-spacing: 1px;
    line-height: 1.7;
    margin: 35px auto 0;
}
/*sticky navigation menu*/
.sticky-nav{
    background-color: transparent;
    -webkit-transition: background-color 300ms;
    -moz-transition: background-color 300ms;
    transition: background-color 300ms;
}
.sticky-nav .nav{
    max-width: 800px;
    justify-content: center;
    margin: 30px auto 0px;
    padding: 0px;
    list-style-type: none;
}
.sticky-nav .nav .nav-item{
    margin: 9px;
    width: 222px;
    text-align: center;
    letter-spacing: 1.5px;
    line-height: 100%;
}
.sticky-nav .nav .nav-item .nav-link{
    border: 2px solid #2198d1;
    padding: 11px 10px 8px;
    font-family: "Futura Medium";
    font-size: 14px;
    color: #464646;
}
.sticky-nav.fixed{
    z-index: 100;
    background-color: #2198d2;
    position: fixed;
    top: 0px;
    -webkit-box-shadow: 0px 3px 20px 0px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 3px 20px 0px rgba(0,0,0,0.75);
    box-shadow: 0px 3px 20px 0px rgba(0,0,0,0.75);

    -webkit-transition: background-color 300ms;
    -moz-transition: background-color 300ms;
    transition: background-color 300ms;

}
.sticky-nav.fixed .nav{
    width: 100%;
    margin: 2px auto;
}
.sticky-nav.fixed .nav .nav-item{
    width: auto;
    margin: 11px;
    -webkit-animation: fadeInFromNone 2.5s ease-out;
    -moz-animation: fadeInFromNone 2.5s ease-out;
    -o-animation: fadeInFromNone 2.5s ease-out;
    animation: fadeInFromNone 2.5s ease-out;
}
.sticky-nav.fixed .nav .nav-item .nav-link{
    color: #fff;
    padding: 7px 11px;
    border: 1px solid transparent;
}
.sticky-nav.fixed .nav .nav-item .nav-link.active{
    border: 1px solid #fff;
}
/*SEPARATORS*/
.wpb_wrapper .vc_separator_align_center{
    margin: 100px 0px 60px;
}
.wpb_wrapper .vc_separator.vc_separator_align_center h4{
    font-family: 'Gentium BasicBold';
    text-align: center;
    text-transform: uppercase;
    border: 2px solid #dddddd;
    font-size: 28px;
    line-height: 1;
    padding: 9px 10px 8px;
    background-color: #fff;
    width: 380px;
    z-index: 1;
}
.wpb_wrapper .vc_separator_align_center .vc_sep_holder .vc_sep_line{
    width: 165px;
    height: 1px;
    border-top: 1px solid #e0e0e0;
    border-bottom: 1px solid #e0e0e0;
    display: inline-block;
    position: relative;
}
.wpb_wrapper .vc_separator_align_center .vc_sep_holder.vc_sep_holder_l{
    text-align: right;
    height: 3px;
}
.wpb_wrapper .vc_separator_align_center .vc_sep_holder.vc_sep_holder_r{
    text-align: left;
    height: 3px;
}
.wpb_wrapper .vc_separator_align_center .vc_sep_holder .vc_sep_line:after{
    content: "";
    position: absolute;
    width: 15px;
    height: 15px;
    border-radius: 50%;
    border: 1px solid #e0e0e0;
    background-color: #fff;
    top: -7px;
}
.wpb_wrapper .vc_separator_align_center .vc_sep_holder.vc_sep_holder_l .vc_sep_line:after{
    left: 0;
}
.wpb_wrapper .vc_separator_align_center .vc_sep_holder.vc_sep_holder_r .vc_sep_line:after{
    right: 0;
}
/*CONTENT*/
/*CALENDAR DROPDOWNS*/
#program-calendar .vc_sep_holder .vc_sep_line{
    width: 140px;
}
#program-calendar .datepicker{
    font-family: "Gentium BasicBold";
    cursor: pointer;
    padding: 6px 30px 7px 15px;
    text-transform: uppercase;
    border: 2px solid #dddddd;
    text-shadow: 0 0 0 #464646;
    background-color: transparent;
    color: transparent;
    position: relative;
    text-align: center;
    font-size: 28px;
    line-height: 1;
    outline: none;
    min-width: 422px;
    z-index: 10000;
}
#program-calendar .picker{
    position: relative;
    background-color: #fff;
    z-index: 10;
}
#program-calendar .picker:after{
    font: normal normal normal 35px/1 FontAwesome;
    display: inline-block;
    content: "\f107";
    position: absolute;
    right: 0px;
    top: 0px;
    padding: 7px 13px;
    border-left: 2px solid #dddddd;
}
#program-calendar .picker:focus-within:after{
    color: #2198d2;
}
#ui-datepicker-div{
    border-radius: 0px;
    left: 0!important;
    right: 0!important;
    margin: -25px auto 0 !important;
    z-index: 1 !important;
    padding: 22px 15px 15px;
    width: 860px!important;

    -webkit-box-shadow: 0px -10px 0px 0px #f5f7f7;
    -moz-box-shadow: 0px -10px 0px 0px #f5f7f7;
    box-shadow: 0px -10px 0px 0px #f5f7f7;
}
#ui-datepicker-div .ui-datepicker-header{
    color: #464646;
    background: transparent;
    border: 0px;
    padding-bottom: 0px;
}
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-prev,
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-next{
    display: none;
}
#ui-datepicker-div .ui-datepicker-group{
    padding: 20px;
    font-family: "Futura Medium";
    font-size: 16px;
}
#ui-datepicker-div .ui-datepicker-group-first{
    padding-right: 0px;
}
#ui-datepicker-div .ui-datepicker-group-last{
    padding-left: 0px;
}

#ui-datepicker-div .ui-datepicker-calendar{
    table-layout: fixed;
}
#ui-datepicker-div .ui-datepicker-calendar th{
    font-size: 16px;
    padding: 4px 10px;
}
#ui-datepicker-div .ui-state-default{
    font-family: "Futura Bold";
    background: #646464;
    border: 1px solid #646464;
    text-align: center;
    color: #fff;
}
#ui-datepicker-div .ui-state-active{
    background: #2198d1;
    border: 1px solid #2198d1;
}
#ui-datepicker-div .ui-state-disabled .ui-state-default{
    background: #fff;
    color: #c8c8c8;
}
#ui-datepicker-div .ui-state-default{
    padding: 0px;
}
#ui-datepicker-div .ui-datepicker-calendar td{
    font-size: 16px;
    padding: 2px;
}
/*FAQ accordions and PROGRAM accordions*/
#program-accordions{
    position: relative;
}
#program-accordions .accordion:first-of-type .card-header,
#cat-faq-accordions .accordion:first-of-type .card-header{
    border-top: 1px solid #c8c8c8;
    border-radius: 0px;
}
#program-accordions .card-header,
#cat-faq-accordions .card-header{
    background-color: transparent;
    position: relative;
    /*font-size: 18px;*/
    cursor: pointer;
    padding: 21px 0px 21px 75px;
    border-bottom: 1px solid transparent;
}
#program-accordions .card-header.collapsed,
#cat-faq-accordions .card-header.collapsed{
    border-bottom: 1px solid #c8c8c8;
}
#program-accordions .card-header:before,
#cat-faq-accordions .card-header:before{
    content: " ";
    position: absolute;
    background-color: #2198d2;
    width: 12px;
    height: 2px;
    left: 0;
    top: 0px;
    bottom: 0px;
    margin: auto;
}
#program-accordions .card-header.collapsed:after,
#cat-faq-accordions .card-header.collapsed:after{
    content: " ";
    position: absolute;
    background-color: #2198d2;
    height: 12px;
    width: 2px;
    top: 0;
    bottom: 0;
    margin: auto;
    left: 5px;
}
#program-accordions .accordion .collapsing,
#program-accordions .accordion .collapse,
#cat-faq-accordions .accordion .collapsing,
#cat-faq-accordions .accordion .collapse{
    position: relative;
    border-top: 2px solid #2198d2;
    border-bottom: 2px solid #2198d2;
    margin-top: -1px;
    /*box-shadow: inset 0px 2px 0px 0px #CCC, inset 0px -2px 0px 0px #CCC*/
}
#cat-faq-accordions .ac-content{
    padding: 40px 0px 30px 75px;
}
#program-accordions .ac-content{
    padding: 70px 40px 40px;
}
#program-accordions .card-header .more-box,
#cat-faq-accordions .card-header .more-box{
    font-family: "Futura Medium";
    font-size: 14px;
    letter-spacing: 1px;
    display: inline-block;
    min-width: 120px;
    background-color: #fff;
    color: #464646;
    border: 2px solid #b4b4b4;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0px;
    margin: auto;
    height: 39px;
    padding: 7px 27px;
}
#program-accordions .card-header .more-box a{
    color: #464646;
}
#program-accordions .card-header .time{
    font-family: "Futura Medium";
    display: inline-block;
    font-size: 17px;
    width: 160px;
}
/*PARTNER BOXES*/
.partner-boxes .partner-box{
    margin-bottom: 30px;
}
.partner-boxes .partner-box .img-cont{
    display: flex;
    justify-content: center;
    border: 1px solid #d3d3d3;
    max-height: 350px;
    height: 100%;
    background-color: #fff;
}
.partner-boxes .partner-box .img-cont > a,
.partner-boxes .partner-box .img-cont > img{
    align-self: center;
}
.partner-boxes .partner-box.col-lg-4 .img-cont img{
    max-width: 200px;
}
.partner-boxes .partner-box.col-lg-8 .img-cont img{
    max-width: 300px;
}
/*POST BOXES*/
/*.wpb_wrapper .vc_separator_align_center,*/
.post .concert-accordions .post-head,
.post .post-boxes .post-head{
    position: relative;
    margin-bottom: 50px;
}
/*.wpb_wrapper .vc_separator_align_center:after,*/
.post .concert-accordions .post-head:after,
.post .post-boxes .post-head:after{
    content: "";
    width: auto;
    height: 3px;
    position: absolute;
    left: -100%;
    right: -100%;
    top: 0px;
    height: 3px;
    background-color: #dddddd;
}
/*.wpb_wrapper .vc_separator.vc_separator_align_center h4,*/
.post .concert-accordions .post-head h4,
.post .post-boxes .post-head h4{
    text-align: center;
    text-transform: uppercase;
    border: 2px solid #dddddd;
    position: absolute;
    top: -14px;
    left: 0;
    right: 0;
    height: 30px;
    font-size: 15px;
    line-height: 1;
    padding: 6px 0px;
    background-color: #fff;
    margin: auto;
    width: 33%;
    z-index: 1;
}
.post .post-boxes .box{
    margin-bottom: 30px;
}
.post .post-boxes .post-image{
    height: 360px;
    overflow: hidden;
    background-color: #2198d1;
}
.post .post-boxes .post-image .post-bg{
    height: 360px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    transition: all 1s;
}
.post .post-boxes .text-box{
    position: relative;
    background-color: #fff;
    margin: -35px 30px 0;
    min-height: 160px;
    border: 1px solid #d3d3d3;
    /*padding: 27px 30px 30px;*/
    padding: 27px 10px 30px;
}
.post .post-boxes .text-box .post-place{
    font-family: "Playfair DisplayBold";
    font-size: 13px;
    border: 1px solid #a3a3a3;
    border-top: 1px solid #fff;
    display: inline-block;
    margin-top: -45px;
    background-color: #464646;
    color: #fff;
    width: 120px;
    padding: 5px 3px;
}
.post .post-boxes .text-box .post-subtitle{
    font-family: "Futura Medium";
    color: #646464;
    margin-bottom: 6px;
    letter-spacing: 1px;
    font-size: 12px;
}
.post .post-boxes .text-box .post-title h3{
    word-break: break-word;
    cursor: pointer;
    font-family: "Gentium BasicBold";
    margin-bottom: 0px;
    line-height: 100%;
    font-size: 32px;
}
.post .post-boxes .text-box .post-title h3:hover{
    text-decoration: underline;
    -webkit-text-decoration-color: #2198d1;
    text-decoration-color: #2198d1;
}
.post .post-boxes .text-box .toggler{
    cursor: pointer;
    position: absolute;
    bottom: 12px;
    height: 10px;
    width: 100px;
    left: 0;
    right: 0;
    margin: auto;
    /*border-bottom: 3px solid grey;*/
}
.post .post-boxes .text-box .toggler .line-lg{
    width: 100%;
    height: 1px;
    background-color: #808080;
}
.post .post-boxes .text-box .toggler.active .line-lg{
    background-color: #2198d1;
}
.post .post-boxes .text-box .toggler .line-sm{
    display: inline-block;
    width: 10px;
    height: 2px;
    background-color: #fff;
    position: relative;
}
.post .post-boxes .text-box .toggler .line-sm:before{
    content: " ";
    display: block;
    width: 8px;
    height: 1px;
    background: #808080;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
    position: absolute;
    top: 3px;
    right: -2px;
}
.post .post-boxes .text-box .toggler .line-sm:after{
    content: " ";
    display: block;
    width: 8.5px;
    height: 1px;
    background: #808080;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    top: 3px;
    left: -2px;
}
.post .post-boxes .text-box .toggler.active .line-sm:before,
.post .post-boxes .text-box .toggler.active .line-sm:after{
    background: #4dc4ff;
}
/*post pupup*/
#post-box-popup {
    display: none;
    background: #fff;
    border-top: 2px solid #2198d2;
    border-bottom: 2px solid #2198d2;
    position: absolute;
    z-index: 1000;
    margin-top: 20px;
    min-height: 112px;
    left: 0px;
    right: 0;
    margin: auto;
    width: 100%;

    -webkit-box-shadow: 0px 3px 5px 0px rgba(0,0,0,0.75);
    -moz-box-shadow: 0px 3px 5px 0px rgba(0,0,0,0.75);
    box-shadow: 0px 3px 5px 0px rgba(0,0,0,0.75);
}
#post-box-popup .post-content .container{
    padding: 60px 40px 40px;
}
#post-box-popup .post-content .accordions .container {
    padding: 0;
}
#post-box-popup .post-content .accordions { width: 100%; }
#program-accordions .right-side,
#post-box-popup .post-content .right-side{
    padding-left: 55px;
}
#post-box-popup .title-cont{
    position: relative;
}
#post-box-popup .title-cont .subtitle{
    line-height: 100%;
}
#post-box-popup .post-content .pt-post .subtitle{
    display: none;
}
#program-accordions .ac-content .title,
#post-box-popup .title-cont .title{
    font-family: "Gentium BasicBold";
    font-size: 40px;
}
#program-accordions .title-cont .booking-link,
#post-box-popup .title-cont .booking-link{
    position: absolute;
    right: 0px;
    top: -10px;
    bottom: auto;
}
#program-accordions .title-cont .booking-link{
    right: 10px;
}
#program-accordions .title-cont .booking-link span,
#post-box-popup .title-cont .booking-link span{
    font-family: "Futura Medium";
    letter-spacing: 1px;
    font-size: 14px;
    color: #464646;
    text-transform: uppercase;
    padding: 7px 10px;
    text-align: center;
    width: 125px;
    display: inline-block;
    border: 2px solid #c8c8c8;
    text-transform: uppercase;
}
#post-box-popup .line-sm{
    display: inline-block;
    width: 20px;
    height: 2px;
    margin-top: -2px;
    background-color: #fff;
    position: relative;
}
#post-box-popup .line-sm:before{
    content: " ";
    display: block;
    position: absolute;
    top: -10px;
    left: -4px;
    border-left: 14px solid transparent;
    border-right: 14px solid transparent;
    border-bottom: 12px solid #2198d2;
}
#post-box-popup .line-sm:after{
    content: " ";
    display: block;
    position: absolute;
    top: -7px;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-bottom: 9px solid #fff;
}
.post-content .post-slide{
    width: 440px;
}
.post-slide .carousel-inner{
    border: 1px solid #c8c8c8;
}
.post-slide .carousel-item{
    height: 415px;
    padding: 10px;
}
.post-slide .carousel-item .slide-image{
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}
.post-slide .carousel-indicators{
    position: relative;
    bottom: auto;
    margin-bottom: 0px;
    margin-top: 30px;
}
.post-slide .carousel-indicators li {
    background-color: #fff;
    border-radius: 100%;
    width: 14px;
    height: 14px;
    margin-left: 8px;
    margin-right: 8px;
    border: 1px solid #c8c8c8;
}
.post-slide .carousel-indicators li.active {
    background-color: #c8c8c8;
}
/*WIDGETS*/
/*left contact*/
/*right social*/
.widget-social ul{
    background-color: #f5f6f6;
    display: inline-block;
    padding: 23px 0px 20px 15px;
    list-style-type: none;
}
.widget-social ul li{
    display: inline-block;
    margin-right: 15px;
    width: 40px;
    height: 40px;
    background-color: #404040;
    border-radius: 7px;
}
.widget-social ul li a{
    justify-content: center;
    display: flex;
    height: 100%;
}
.widget-social .fa{
    align-self: center;
    font-size: 30px;
    color: #fff;
}
/*FOOTER*/
footer{
    margin-top: 70px;
    padding: 38px 0px 98px;
    color: #fff;
}
footer h4{
    margin-bottom: 30px;
    font-size: 16px;
}
footer .widget-address{
    padding-left: 113px;
}
footer .widget-newsletter{
    padding-left: 68px;
}
footer .widget-social h4{
    margin-bottom: 17px;
}
footer .widget-social{
    padding-left: 17px;
}
footer .widget-address a{
    display: inline-block;
    margin-bottom: 9px;
}
footer a{
    color: #fff;
}
footer a:hover,
footer a:focus{
    color: #b4b4b4;
}

/*RESPONSIVE*/
/*Extra large devices (large desktops, 1200px and up)*/
@media (min-width: 1200px) { 

}
/*Large devices (desktops, 992px and up)*/
@media (min-width: 992px) and (max-width: 1199px) { 
    header .navbar-expand-lg .navbar-nav .nav-link{
        padding: 9px 15px;
    }
    div .close{
        right: -25px;
    }
    .post-content .post-slide{
        width: 100%;
    }
    .post .post-boxes .text-box{
        padding: 30px 10px;
    }
}
/*all devices up to tablet sizes*/
@media (max-width: 991px) { 
    header .nav-row .container{
        max-width: 100%;
    }
    header .navbar-toggler{
        margin-left: auto;
        border: 0px;
        outline: none;
    }
    header .navbar-toggler:focus{
        outline: none;
    }
    header .navbar-toggler {
        position: absolute;
        z-index: 10000;
        right: 0px;
        top: -60px;
        display: block;
        width: 40px;
        height: 40px;
        margin: 0px;
        border: 0px;
        padding: 0px;
    }
    .navbar-toggler .toggler-icon:nth-child(1) { top: 10px; }
    .navbar-toggler .toggler-icon:nth-child(2) { top: 18px; opacity: 0; }
    .navbar-toggler .toggler-icon:nth-child(3) { top: 26px; }

    .navbar-default .navbar-toggler .toggler-icon{  }
    .navbar-toggler .toggler-icon {
        position: absolute;
        right: 0px; 
        height: 5px;
        width: 40px;
        border-radius: 5px;
        background-color: #fff;
        margin-top: 0!important;
        -moz-transform: rotate(0);
        -ms-transform: rotate(0);
        -webkit-transform: rotate(0);
        transform: rotate(0);
        -moz-transition: all .1s;
        -o-transition: all .1s;
        -webkit-transition: all .1s;
        transition: all .1s;
        -moz-transform-origin: 50% 50%;
        -ms-transform-origin: 50% 50%;
        -webkit-transform-origin: 50% 50%;
        transform-origin: 50% 50%;
    }
    .navbar-toggler:not(.collapsed) .toggler-icon {
        top: 50%;
    }
    .navbar-toggler:not(.collapsed) .toggler-icon:nth-child(1){
        -moz-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
    }
    .navbar-toggler:not(.collapsed) .toggler-icon:nth-child(2) {
        opacity: 0; 
    }
    .navbar-toggler:not(.collapsed) .toggler-icon:nth-child(3) {
        -moz-transform: rotate(-45deg);
        -ms-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
    }
    header .navbar{
        padding: 0px;
        position: relative;
    }
    header .navbar-nav > li:first-of-type{
        display: list-item;
    }
    header .navbar .navbar-collapse {
        position: absolute;
        top: -75px;
        left: -15px;
        right: -15px;
        z-index: 1000;
        background-color: #002148;
    }
    header .navbar .dropdown-toggle::after{
        display: none;
    }
    /*dropdown menu*/
    header .navbar-expand-lg .navbar-nav > li {
        border-top: 1px solid #acc4cc;
    }
    header .navbar-expand-lg .navbar-nav > li:last-of-type{
        border-bottom: 1px solid #acc4cc;
    }
    header .navbar-expand-lg .navbar-nav > li .nav-link{
        font-family: "Gentium BasicBold";
        padding: 13px 24px 13px 85px;
        letter-spacing: 0px;
        font-size: 28px;
        position: relative;
    }
    header .navbar-expand-lg .navbar-nav > li .nav-link:before{
        content: " ";
        position: absolute;
        background-color: #2198d2;
        width: 12px;
        height: 2px;
        left: 0;
        right: auto;
        /*top: 0px;*/
        top: 33px;
        bottom: 0px;
        /*margin: auto;*/
        margin: 0;
        opacity: 1;
    }
    header .navbar-expand-lg .navbar-nav > li .nav-link:after {
        content: " ";
        position: absolute;
        background-color: #2198d2;
        height: 12px;
        width: 2px;
        top: 0;
        bottom: 0;
        margin: auto;
        left: 5px;
    }
    header .navbar-expand-lg .navbar-nav > li .nav-link.opened{
        padding-bottom: 3px;
    }
    header .navbar-expand-lg .navbar-nav > li .nav-link.opened:after {
        display: none;
    }
    header .navbar .navbar-nav{
        height: 100%;
        min-height: 100vh;
        padding-top: 175px;
        position: relative;
    }
    header .navbar .navbar-nav .mobile-logo{
        content: "";
        position: absolute;
        cursor: pointer;
        width: 189px;
        height: 70px;
        top: 45px;
        left: 0;
        background: url('css/images/top-logo.png') no-repeat center;
    }
    header .navbar .navbar-nav .trp-ls-shortcode-language{
        display: block!important;
        position: absolute;
        width: 140px;
        top: 87px;
        right: 0;
    }
    header .navbar .navbar-nav .trp-ls-shortcode-language a{
        font-size: 0px;
    }
    header .navbar .navbar-nav .trp-ls-shortcode-language img{
        margin-left: 22px;
        width: 43px;
        float: right;
    }

    header .navbar-nav .dropdown-menu{
        background-color: transparent;
        border: 0px;
        padding: 0px 0px 20px;
        margin-top: 0px;
    }
    header .navbar-nav .dropdown-menu .dropdown-item{
        padding: 4px 24px 4px 85px; 
        font-size: 14px;
        letter-spacing: 1.5px;
        text-transform: uppercase;
        color: #fff;
    }
    header .navbar-nav .dropdown-menu .dropdown-item:focus,
    header .navbar-nav .dropdown-menu .dropdown-item:hover{
        background-color: transparent;
    }
    /*social icons*/
    .widget-social.header {
        bottom: auto;
        top: 0;
        left: 0;
        right: 0;
        margin: auto;
        width: 165px;
    }
    .widget-social.header ul{
        padding: 15px 0px 0px 0px;
        margin-bottom: 0;
    }
    .widget-social.header ul li{
        border: 1px solid #fff;
        margin: 0px 7px;
        background-color: transparent;
        display: inline-block;
    }
    /*banner*/
    .banner-container .page-excerpt{
        max-width: 720px;
    }
    div .close{
        right: -35px;
    }
    /*post boxes*/
    .post .post-boxes .text-box{
        padding: 30px 10px;
    }
    .post .post-boxes .title-cont.d-lg-none{
        margin-bottom: 30px;
    }
    #post-box-popup .title-cont .title{
        margin-top: 10px;
    }
    .post-slide .carousel-item{
        height: 450px;
    }
    .post-slide .carousel-indicators{
        margin-bottom: 30px;
    }
    /*post popup*/
    .post-content .post-slide{
        width: 100%;
    }
    #program-accordions .right-side,
    #post-box-popup .post-content .right-side{
        padding-left: 15px;
    }
    /*program calendar*/
    #ui-datepicker-div{
        width: 700px!important;
    }
    /*footer*/
    footer .widget-social,
    footer .widget-newsletter,
    footer .widget-address{
        padding-left: 0px;
    }
    footer .widget-social ul{
        padding: 23px 0px 20px 12px;
    }
    .widget-social ul li{
        margin-right: 12px;
    }
}
/*Medium devices (tablets, 768px and up)*/
@media (min-width: 768px) and (max-width: 991px) { 
    .navbar .navbar-nav{
        max-width: 720px;
        margin: auto;
    }
    
    #program-accordions .card-header, #cat-faq-accordions .title {
          padding-right: 140px; 
    }
    #program-accordions .card-header, #cat-faq-accordions .title {
          padding-right: 140px; 
    }
}

/*all devices up to tablet sizes*/
@media (max-width: 767px) { 
    html body {
        font-size: 16px;
    }
    
    #cat-faq-accordions .ac-content {
    padding: 40px 0px 30px 0px;
}
    
    /*header*/
    header .navbar .navbar-collapse {
        left: -10px;
        right: -10px;
    }
    header .nav-row{
        height: 64px;
    }
    header .navbar .navbar-nav .trp-ls-shortcode-language{
        width: 140px;
        top: 92px;
        right: 30px;
    }
    header .navbar .navbar-nav .trp-ls-shortcode-language a{
        font-size: 0px;
    }
    header .navbar .navbar-nav .trp-ls-shortcode-language img{
        margin-left: 17px;
        width: 26px;
        float: right;
    }
    /*navigation*/
    header .navbar .navbar-nav{
        padding: 150px 30px 60px;
    }
    header .navbar-brand {
        padding: 12px 20px 12px 0px;
        margin-right: 0;
        width: 100px;
    }
    header .navbar .navbar-nav .mobile-logo{
        left: 30px;
        top: 50px;
        width: 140px;
        background-size: contain;
    }
    header .navbar-expand-lg .navbar-nav > li .nav-link{
        z-index: 100000;
        font-size: 20px;
        padding: 16px 10px 15px 22px;
    }
    header .navbar-nav .dropdown-menu .dropdown-item{
        padding: 5px 24px 5px 22px;
    }
    header .navbar-expand-lg .navbar-nav > li .nav-link:before{
        top: 0;
        bottom: 0;
        margin: auto;
    }
    header .navbar-toggler{
        top: -40px;
        right: 0px;
    }
    .navbar-toggler .toggler-icon{
        height: 3px;
        width: 20px;
    }
    .navbar-toggler .toggler-icon:nth-child(3){
        top: 20px;
    }
    .navbar-toggler:not(.collapsed) .toggler-icon{
        top: 40%;
    }
    /*header social*/
    .widget-social.header {
        left: 50px;
        width: 120px;
    }
    .widget-social.header ul li{
        margin: 0px 5px;
        width: 30px;
        height: 30px;
    }
    .widget-social.header .fa {
        font-size: 15px;
    }
    /*banner*/
    .container-fluid.video-container{
        min-height: 400px;
    }
    .video-container .video-overlay{
        width: auto;
        top: 65px;
        max-width: 500px;
    }
    .video-container .video-overlay .site-banner img{
        max-width: 80%;
    }
    .video-container .site-title{
        font-size: 26px;
        margin-top: 10px;
    }
    .video-container .site-sub{
        font-size: 20px;
    }
    .video-container .site-schedule{
        font-size: 10px;
        border-radius: 10px;
    }
    .video-container .play{
        width: 55px;
        height: 55px;
        margin: 16px auto 0px;
        border: 3px solid #fff;
    }
    .video-container .play:after{
        top: 13px;
        left: 18px;
        border-left: 23px solid #fff;
        border-top: 13px solid transparent!important;
        border-bottom: 13px solid transparent!important;
    }
    .video-container .vd-placeholder{
        min-height: 400px;
    }
    /*banner*/
    .banner-container .banner{
        height: 200px;
        margin: 0px -10px 30px;
        border-bottom: 4px solid #fff;
        -webkit-box-shadow: 0px 6px 0px 0px #2198d2;
        -moz-box-shadow: 0px 6px 0px 0px #2198d2;
        box-shadow: 0px 6px 0px 0px #2198d2;
    }
    .banner-container .banner-icon {
        bottom: -30px;
        width: 125px;
        height: 125px;
        background-position: 12px 11px;
        background-size: 100px;
    }
    .banner-container .title-cont{
        background-image: none;
        position: relative;
        max-width: 520px;
        margin: auto;
        padding: 0px 23px 5px;
    }
    .banner-container .title-cont:before{
        position: absolute;
        right: 0;
        bottom: 18px;
        content: "";
        width: 70px;
        height: 50px;
        background-image: url(css/images/heading-bg.png);
        background-position: right bottom;
        background-size: 230px 43px;
        background-repeat: no-repeat;
    }
    .banner-container .title-cont:after{
        position: absolute;
        left: 0;
        bottom: 18px;
        content: "";
        width: 70px;
        height: 50px;
        background-image: url(css/images/heading-bg.png);
        background-position: left bottom;
        background-size: 230px 43px;
        background-repeat: no-repeat;
    }
    .banner-container h1 {
        width: 100%;
        font-size: 26px;
        margin: 19px auto 24px;
        padding: 6px 0px;
    }
    .banner-container h1:before,
    .banner-container h1:after{
        display: none;
    }
    /*separators*/
    .post.content{
        overflow: hidden;
    }
    .wpb_wrapper .vc_separator_align_center{
        margin: 60px 0px 40px;
    }
    .wpb_wrapper .vc_separator.vc_separator_align_center h4{
        max-width: 520px;
        width: 100%;
        font-size: 20px;
    }
    .wpb_wrapper .vc_separator_align_center .vc_sep_holder{
        min-width: 0px;
    }
    .wpb_wrapper .vc_separator_align_center .vc_sep_holder .vc_sep_line{
        width: 0;
    }
    .wpb_wrapper .vc_separator_align_center .vc_sep_holder .vc_sep_line:after{
        content: "";
        position: absolute;
        width: 1000px;
        height: 2px;
        border-radius: 50%;
        background-color: #e0e0e0;
        top: -1px;
    }
    .banner-container .page-excerpt,
    .sticky-nav .nav{
        max-width: 540px;
    }
    /*sticky navbar*/
    .sticky-nav .nav .nav-item{
        width: 100%;
    }
    .sticky-nav.fixed .nav .nav-item{
        margin: 5px;
    }
    .sticky-nav.fixed .nav .nav-item .nav-link{
        padding: 7px 5px;
    }
    /*content boxes*/
    .post .post-boxes .box{
        margin-bottom: 40px;
    }
    .post .post-boxes .post-image,
    .post .post-boxes .post-image .post-bg{
        height: 285px;
    }
    .post .post-boxes .text-box{
        min-height: 130px;
        padding: 20px 10px;
    }
    .post .post-boxes .text-box .post-place{
        font-size: 14px;
        margin-top: -35px;
    }
    .post .post-boxes .text-box .post-subtitle{
        font-size: 14px;
    }
    .post .post-boxes .text-box .post-title h3{
        font-size: 26px;
    }
    #post-box-popup .title-cont{
        padding-right: 0px;
    }
    #post-box-popup .post-content .container{
        padding: 85px 40px 40px;
    }
    #program-accordions .title-cont .booking-link,
    #post-box-popup .title-cont .booking-link {
        position: absolute;
        right: auto;
        left: 0px;
        bottom: auto;
        font-size: 12px;
        line-height: 100%;
        min-width: 82px;
        padding: 4px 0px;
        top: -50px;
        height: 22px;
    }
    #program-accordions .title-cont .booking-link{
        padding-left: 10px;
    }
    .post-slide .carousel-item{
        height: 285px;
    }
    .post-slide .carousel-indicators{
        margin: 20px auto 25px;
    }
    #program-accordions .title-cont .booking-link span,
    #post-box-popup .title-cont .booking-link span {
        font-size: 12px;
        width: 80px;
        padding: 3px;
    }                                                                                                               
    /*program calendar and accordions*/
    #program-calendar .datepicker{
        font-size: 20px;
        min-width: 100%;
    }
    #program-calendar .picker:after{
        font-size: 24px;
        padding: 7px 6px;
    }
    #ui-datepicker-div {
        width: auto!important;
        max-width: 540px;
        margin: -20px auto 0 !important;
    }
    #ui-datepicker-div .ui-datepicker-group-first,
    #ui-datepicker-div .ui-datepicker-group-last{
        padding: 20px 10px;
        width: 100%;
    }
    #cat-faq-accordions .card-header:before,
    #program-accordions .card-header:before{
        margin: 0;
        top: 30px;
    }
    #cat-faq-accordions .card-header.collapsed:after,
    #program-accordions .card-header.collapsed:after{
        margin: 0;
        top: 25px;
    }
    #program-accordions .card-header .more-box{
        margin: 0px;
        top: 15px;
    }
    #program-accordions .card-header,
    #cat-faq-accordions .card-header{
        padding: 21px 0px 21px 30px;
    }
    #program-accordions .card-header .time{
        font-size: 14px;
    }
    #program-accordions .card-header .more-box {
        font-size: 12px;
        line-height: 100%;
        min-width: 82px;
        padding: 4px 10px;
        top: 15px;
        height: 22px;
    }
    #program-accordions .ac-content{
        padding: 85px 20px 40px;
    }
    #program-accordions .title-cont .title{
        font-size: 35px;
        margin: 10px 0px 20px;
    }
    #program-accordions div.close{
        top: -60px;
        right: 3px;
    }
    #program-accordions .carousel.slide{
        margin: 0px -30px;
    }
    /*faq accordion*/
    #cat-faq-accordions .card-header .more-box {
        display: none;
    }
    /*footer*/
    footer{
        padding: 40px 0px 30px;
    }
    footer h4{
        margin-bottom: 20px;
    }
    footer .widget-social ul{
        padding: 10px 0px 10px 10px;
    }
    footer .widget-social .fa{
        font-size: 25px;
    }

}
/*Small devices (landscape phones, 576px and up)*/
@media (min-width: 576px) and (max-width: 767px) { 
      
}

/*Extra small devices (portrait phones, less than 576px)*/
@media (max-width: 575px) { 
}
